@graphrefly/graphrefly 0.30.0 → 0.31.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/{cascading-dNCtjW8j.d.cts → cascading-BfQmSmjU.d.cts} +21 -2
- package/dist/{cascading-BszPheHD.d.ts → cascading-D3sapjue.d.ts} +21 -2
- package/dist/{chunk-T5SHIKJD.js → chunk-3JRKP4BH.js} +1 -1
- package/dist/{chunk-GJR3P6JG.js → chunk-3Q2WXM6X.js} +1 -1
- package/dist/chunk-4KAUNEKV.js +3 -0
- package/dist/{chunk-SLMYTGTU.js → chunk-4UUDNFYG.js} +1 -1
- package/dist/chunk-4VXL3UZK.js +1 -0
- package/dist/{chunk-AV3PIDFQ.js → chunk-4ZPO2EL5.js} +1 -1
- package/dist/{chunk-VWPRPPKR.js → chunk-5LJAQTSS.js} +1 -1
- package/dist/{chunk-W4TSQ6RJ.js → chunk-7AJKUA36.js} +1 -1
- package/dist/{chunk-RD52SNH2.js → chunk-7EJTWGKW.js} +1 -1
- package/dist/{chunk-GNCBXARM.js → chunk-7EQPXQ7H.js} +1 -1
- package/dist/chunk-7QMVU3IX.js +1 -0
- package/dist/{chunk-BA5URFYW.js → chunk-A4JT4SAD.js} +1 -1
- package/dist/chunk-ASDKRNOJ.js +60 -0
- package/dist/{chunk-Y32RJO24.js → chunk-CZVYLXFK.js} +1 -1
- package/dist/{chunk-567NWZ3T.js → chunk-DWIAG62L.js} +1 -1
- package/dist/{chunk-33FA6V4B.js → chunk-EBQ6FXKW.js} +1 -1
- package/dist/chunk-FTA5TB2A.js +1 -0
- package/dist/{chunk-P7JXGKDO.js → chunk-GF5T7PGC.js} +1 -1
- package/dist/{chunk-WANIEEKV.js → chunk-I4U3TPK2.js} +1 -1
- package/dist/{chunk-KA6MMXIY.js → chunk-JMGGCSIC.js} +1 -1
- package/dist/chunk-JXRZXP3N.js +1 -0
- package/dist/{chunk-5Z4HDCO6.js → chunk-K54OKWNY.js} +1 -1
- package/dist/{chunk-DDPYNMGG.js → chunk-KN4Q5MQO.js} +1 -1
- package/dist/chunk-LWGLBCMU.js +1 -0
- package/dist/{chunk-TWMEGG45.js → chunk-N2KKISCE.js} +1 -1
- package/dist/{chunk-4OFIQ66T.js → chunk-OKQUPJRY.js} +1 -1
- package/dist/chunk-PNTBXOQ6.js +5 -0
- package/dist/chunk-PSQNYY72.js +7 -0
- package/dist/{chunk-XHVB6G6M.js → chunk-PZP4MEXK.js} +1 -1
- package/dist/{chunk-7TDOES3L.js → chunk-Q2SY7M7K.js} +1 -1
- package/dist/{chunk-OL33ZI6R.js → chunk-RWGJQQLT.js} +1 -1
- package/dist/chunk-SGS4OJGS.js +1 -0
- package/dist/chunk-UMH3HSP7.js +1 -0
- package/dist/{chunk-BZP5T4X6.js → chunk-W6FQIFVE.js} +1 -1
- package/dist/{chunk-SHYH5SXV.js → chunk-WLPVGXQ6.js} +1 -1
- package/dist/chunk-WQ7I7JVU.js +1 -0
- package/dist/{chunk-XQAXYVXX.js → chunk-WYJTXYWX.js} +1 -1
- package/dist/{chunk-3NEPQO2E.js → chunk-X2VHDT26.js} +1 -1
- package/dist/{chunk-GLSM33ZM.js → chunk-XEFAMCEA.js} +1 -1
- package/dist/{chunk-AUY2YKCO.js → chunk-XRSHMHEG.js} +1 -1
- package/dist/chunk-Y26UN6J5.js +18 -0
- package/dist/{chunk-BKPLTBL5.js → chunk-YQJPYEAL.js} +1 -1
- package/dist/{chunk-73Z3W2RN.js → chunk-YZ6VYLFD.js} +1 -1
- package/dist/{chunk-4JJCCD5S.js → chunk-YZKGGMPT.js} +1 -1
- package/dist/chunk-Z3UWIJ3A.js +1 -0
- package/dist/{chunk-Y36UZ5VS.js → chunk-ZM7C2FUM.js} +1 -1
- package/dist/compat/index.cjs +1 -1
- package/dist/compat/index.js +1 -1
- package/dist/compat/jotai/index.cjs +1 -1
- package/dist/compat/jotai/index.js +1 -1
- package/dist/compat/nanostores/index.cjs +1 -1
- package/dist/compat/nanostores/index.js +1 -1
- package/dist/compat/nestjs/index.cjs +5 -5
- package/dist/compat/nestjs/index.js +1 -1
- package/dist/compat/zustand/index.cjs +1 -1
- package/dist/compat/zustand/index.js +1 -1
- package/dist/{composite-DGspwCqk.d.ts → composite-BY9hMxN7.d.ts} +1 -1
- package/dist/{composite-nrRumJ7l.d.cts → composite-CH0S8DFn.d.cts} +1 -1
- package/dist/content-addressed-storage-BUiREIuj.d.ts +124 -0
- package/dist/content-addressed-storage-DqIWCmZG.d.cts +124 -0
- package/dist/core/index.cjs +1 -1
- package/dist/core/index.js +1 -1
- package/dist/extra/browser.cjs +1 -1
- package/dist/extra/browser.js +1 -1
- package/dist/extra/index.cjs +18 -18
- package/dist/extra/index.d.cts +6 -5
- package/dist/extra/index.d.ts +6 -5
- package/dist/extra/index.js +1 -1
- package/dist/extra/node.cjs +2 -2
- package/dist/extra/node.js +1 -1
- package/dist/extra/operators.cjs +1 -1
- package/dist/extra/operators.d.cts +41 -1
- package/dist/extra/operators.d.ts +41 -1
- package/dist/extra/operators.js +1 -1
- package/dist/extra/reactive.cjs +1 -1
- package/dist/extra/reactive.d.cts +1 -1
- package/dist/extra/reactive.d.ts +1 -1
- package/dist/extra/reactive.js +1 -1
- package/dist/extra/sources.cjs +1 -1
- package/dist/extra/sources.d.cts +62 -2
- package/dist/extra/sources.d.ts +62 -2
- package/dist/extra/sources.js +1 -1
- package/dist/extra/storage-browser.cjs +1 -1
- package/dist/extra/storage-browser.js +1 -1
- package/dist/{fallback-BaTS7vVY.d.cts → fallback-Cb3GH1O7.d.cts} +6 -14
- package/dist/{fallback-eOm3LNxP.d.ts → fallback-DRjJ_ZM8.d.ts} +6 -14
- package/dist/graph/index.cjs +4 -4
- package/dist/graph/index.js +1 -1
- package/dist/{index-ClB7TCfL.d.cts → index-BMe3pCom.d.cts} +1 -1
- package/dist/{index-Dljd76bC.d.ts → index-BXzl1NDD.d.ts} +1 -1
- package/dist/{index-ClgKmOHe.d.ts → index-Bd6oFZqO.d.ts} +223 -115
- package/dist/{index-BJHQUCZx.d.ts → index-CJymKyzT.d.ts} +81 -6
- package/dist/{index-D6ajK8Mh.d.cts → index-CZChc85Q.d.cts} +223 -115
- package/dist/{index-BXbQUn4n.d.ts → index-CcS0t-l2.d.ts} +1 -1
- package/dist/{index-B2HBxvMb.d.ts → index-CwhcFzTA.d.ts} +1 -1
- package/dist/{index-B8Aj_z8S.d.cts → index-D-kHVedZ.d.cts} +1 -1
- package/dist/{index-ybtSyjWB.d.cts → index-DD7RhHNJ.d.cts} +1 -1
- package/dist/{index-BHu_Wba0.d.cts → index-Dm3_D5Ta.d.cts} +1 -1
- package/dist/{index-Cc8VQIgL.d.ts → index-DxMS0cHM.d.ts} +1 -1
- package/dist/{index-BS220yqj.d.cts → index-gJQqJTKx.d.cts} +81 -6
- package/dist/index.cjs +99 -121
- package/dist/index.d.cts +14 -13
- package/dist/index.d.ts +14 -13
- package/dist/index.js +1 -1
- package/dist/patterns/ai/browser.cjs +5 -22
- package/dist/patterns/ai/browser.d.cts +3 -3
- package/dist/patterns/ai/browser.d.ts +3 -3
- package/dist/patterns/ai/browser.js +1 -1
- package/dist/patterns/ai/index.cjs +27 -44
- package/dist/patterns/ai/index.d.cts +9 -7
- package/dist/patterns/ai/index.d.ts +9 -7
- package/dist/patterns/ai/index.js +1 -1
- package/dist/patterns/ai/node.cjs +2 -2
- package/dist/patterns/ai/node.d.cts +5 -4
- package/dist/patterns/ai/node.d.ts +5 -4
- package/dist/patterns/ai/node.js +1 -1
- package/dist/patterns/audit/index.cjs +3 -3
- package/dist/patterns/audit/index.js +1 -1
- package/dist/patterns/cqrs/index.cjs +6 -6
- package/dist/patterns/cqrs/index.js +1 -1
- package/dist/patterns/demo-shell/index.cjs +1 -1
- package/dist/patterns/demo-shell/index.js +1 -1
- package/dist/patterns/domain-templates/index.cjs +4 -4
- package/dist/patterns/domain-templates/index.js +1 -1
- package/dist/patterns/graphspec/index.cjs +6 -6
- package/dist/patterns/graphspec/index.d.cts +2 -2
- package/dist/patterns/graphspec/index.d.ts +2 -2
- package/dist/patterns/graphspec/index.js +1 -1
- package/dist/patterns/guarded-execution/index.cjs +7 -7
- package/dist/patterns/guarded-execution/index.js +1 -1
- package/dist/patterns/harness/index.cjs +11 -11
- package/dist/patterns/harness/index.d.cts +2 -2
- package/dist/patterns/harness/index.d.ts +2 -2
- package/dist/patterns/harness/index.js +1 -1
- package/dist/patterns/job-queue/index.cjs +5 -5
- package/dist/patterns/job-queue/index.js +1 -1
- package/dist/patterns/lens/index.cjs +5 -5
- package/dist/patterns/lens/index.d.cts +2 -2
- package/dist/patterns/lens/index.d.ts +2 -2
- package/dist/patterns/lens/index.js +1 -1
- package/dist/patterns/memory/index.cjs +4 -4
- package/dist/patterns/memory/index.js +1 -1
- package/dist/patterns/messaging/index.cjs +5 -5
- package/dist/patterns/messaging/index.js +1 -1
- package/dist/patterns/orchestration/index.cjs +1 -1
- package/dist/patterns/orchestration/index.js +1 -1
- package/dist/patterns/reactive-layout/index.cjs +1 -1
- package/dist/patterns/reactive-layout/index.js +1 -1
- package/dist/patterns/reduction/index.cjs +5 -5
- package/dist/patterns/reduction/index.js +1 -1
- package/dist/patterns/refine-loop/index.cjs +8 -8
- package/dist/patterns/refine-loop/index.js +1 -1
- package/dist/patterns/resilient-pipeline/index.cjs +1 -1
- package/dist/patterns/resilient-pipeline/index.js +1 -1
- package/dist/patterns/surface/index.cjs +7 -7
- package/dist/patterns/surface/index.d.cts +3 -3
- package/dist/patterns/surface/index.d.ts +3 -3
- package/dist/patterns/surface/index.js +1 -1
- package/dist/{reactive-map-BvDrRuwt.d.ts → reactive-map-CtRaCddO.d.ts} +59 -1
- package/dist/{reactive-map-CmlPPKHN.d.cts → reactive-map-IJIfZxoh.d.cts} +59 -1
- package/dist/{resilience-XRUF267O.js → resilience-IVNDYORD.js} +1 -1
- package/dist/{types-O3GzJY2U.d.cts → types-BgMqbc7N.d.cts} +41 -14
- package/dist/{types-u64Ose53.d.ts → types-CdfO2QTt.d.ts} +41 -14
- package/package.json +1 -1
- package/dist/chunk-2GQREQ6C.js +0 -1
- package/dist/chunk-4C2OR2GH.js +0 -18
- package/dist/chunk-5JDE5JHE.js +0 -1
- package/dist/chunk-7JDLFI6N.js +0 -1
- package/dist/chunk-AMBYCIOH.js +0 -3
- package/dist/chunk-ISCENNXS.js +0 -1
- package/dist/chunk-IUK4EFCE.js +0 -1
- package/dist/chunk-KASHOCF5.js +0 -1
- package/dist/chunk-LI3E75VE.js +0 -64
- package/dist/chunk-MGKAO4EK.js +0 -7
- package/dist/chunk-NSG4C6BF.js +0 -23
- package/dist/chunk-VIEUJSTT.js +0 -1
|
@@ -1,15 +1,15 @@
|
|
|
1
|
-
"use strict";var kr=Object.create;var we=Object.defineProperty;var nn=Object.getOwnPropertyDescriptor;var Rr=Object.getOwnPropertyNames;var Cr=Object.prototype.hasOwnProperty;var rn=(t,e)=>(e=Symbol[t])?e:Symbol.for("Symbol."+t),He=t=>{throw TypeError(t)};var Mr=(t,e,n)=>e in t?we(t,e,{enumerable:!0,configurable:!0,writable:!0,value:n}):t[e]=n;var Zt=(t,e)=>we(t,"name",{value:e,configurable:!0});var V=(t,e)=>()=>(t&&(e=t(t=0)),e);var Dr=(t,e)=>{for(var n in e)we(t,n,{get:e[n],enumerable:!0})},Ar=(t,e,n,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let o of Rr(e))!Cr.call(t,o)&&o!==n&&we(t,o,{get:()=>e[o],enumerable:!(r=nn(e,o))||r.enumerable});return t};var Gr=t=>Ar(we({},"__esModule",{value:!0}),t);var on=t=>[,,,kr(t?.[rn("metadata")]??null)],sn=["class","method","getter","setter","accessor","field","value","get","set"],$e=t=>t!==void 0&&typeof t!="function"?He("Function expected"):t,Ir=(t,e,n,r,o)=>({kind:sn[t],name:e,metadata:r,addInitializer:s=>n._?He("Already initialized"):o.push($e(s||null))}),Lr=(t,e)=>Mr(e,rn("metadata"),t[3]),an=(t,e,n,r)=>{for(var o=0,s=t[e>>1],i=s&&s.length;o<i;o++)e&1?s[o].call(n):r=s[o].call(n,r);return r},un=(t,e,n,r,o,s)=>{var i,a,d,u,l,f=e&7,p=!!(e&8),h=!!(e&16),c=f>3?t.length+1:f?p?1:2:0,g=sn[f+5],m=f>3&&(t[c-1]=[]),v=t[c]||(t[c]=[]),_=f&&(!h&&!p&&(o=o.prototype),f<5&&(f>3||!h)&&nn(f<4?o:{get[n](){return en(this,s)},set[n](b){return tn(this,s,b)}},n));f?h&&f<4&&Zt(s,(f>2?"set ":f>1?"get ":"")+n):Zt(o,n);for(var y=r.length-1;y>=0;y--)u=Ir(f,n,d={},t[3],v),f&&(u.static=p,u.private=h,l=u.access={has:h?b=>Pr(o,b):b=>n in b},f^3&&(l.get=h?b=>(f^1?en:$r)(b,o,f^4?s:_.get):b=>b[n]),f>2&&(l.set=h?(b,x)=>tn(b,o,x,f^4?s:_.set):(b,x)=>b[n]=x)),a=(0,r[y])(f?f<4?h?s:_[g]:f>4?void 0:{get:_.get,set:_.set}:o,u),d._=1,f^4||a===void 0?$e(a)&&(f>4?m.unshift(a):f?h?s=a:_[g]=a:o=a):typeof a!="object"||a===null?He("Object expected"):($e(i=a.get)&&(_.get=i),$e(i=a.set)&&(_.set=i),$e(i=a.init)&&m.unshift(i));return f||Lr(t,o),_&&we(o,n,_),h?f^4?s:_:o};var Ot=(t,e,n)=>e.has(t)||He("Cannot "+n),Pr=(t,e)=>Object(e)!==e?He('Cannot use the "in" operator on this value'):t.has(e),en=(t,e,n)=>(Ot(t,e,"read from private field"),n?n.call(t):e.get(t));var tn=(t,e,n,r)=>(Ot(t,e,"write to private field"),r?r.call(t,n):e.set(t,n),n),$r=(t,e,n)=>(Ot(t,e,"access private method"),n);var Fe,C,W,Z,ee,K,te,F,L,A,xe,Nt,Hr,St,Fr,qr,kt,dn,cn,ln,Rt,re=V(()=>{"use strict";Fe=Symbol.for("graphrefly/START"),C=Symbol.for("graphrefly/DATA"),W=Symbol.for("graphrefly/DIRTY"),Z=Symbol.for("graphrefly/RESOLVED"),ee=Symbol.for("graphrefly/INVALIDATE"),K=Symbol.for("graphrefly/PAUSE"),te=Symbol.for("graphrefly/RESUME"),F=Symbol.for("graphrefly/TEARDOWN"),L=Symbol.for("graphrefly/COMPLETE"),A=Symbol.for("graphrefly/ERROR"),xe=Object.freeze([W]),Nt=Object.freeze([Z]),Hr=Object.freeze([ee]),St=Object.freeze([Fe]),Fr=Object.freeze([L]),qr=Object.freeze([F]),kt=Object.freeze([xe]),dn=Object.freeze([Nt]),cn=Object.freeze([Hr]),ln=Object.freeze([Fr]),Rt=Object.freeze([qr])});function Ce(){return Math.trunc(performance.now()*1e6)}function ae(){return Date.now()*1e6}var je=V(()=>{"use strict"});function En(t,e){let n=new TextEncoder().encode(t.name);if(n.length===0||n.length>255)throw new Error(`encodeEnvelope: codec name "${t.name}" encodes to ${n.length} bytes (must be 1\u2013255)`);let r=t.version;if(!Number.isInteger(r)||r<0||r>65535)throw new Error(`encodeEnvelope: codec.version ${r} out of u16 range (expected integer 0\u201365535)`);let o=2+n.length+2+e.length;if(o>4294967295)throw new Error(`encodeEnvelope: total envelope size ${o} exceeds 2^32-1 bytes (payload ${e.length} bytes)`);let s=new Uint8Array(o),i=0;return s[i++]=Mt,s[i++]=n.length,s.set(n,i),i+=n.length,s[i++]=r>>>8&255,s[i++]=r&255,s.set(e,i),s}function On(t,e){if(t.length<Tn)throw new Error(`decodeEnvelope: bytes too short (${t.length} < ${Tn})`);let n=0,r=t[n++];if(r!==Mt)throw new Error(`decodeEnvelope: unsupported envelope version ${r} (expected ${Mt})`);let o=t[n++];if(o===0)throw new Error("decodeEnvelope: name_len must be >= 1");if(n+o+2>t.length)throw new Error(`decodeEnvelope: envelope truncated (need ${n+o+2} bytes, have ${t.length})`);let s=new TextDecoder().decode(t.subarray(n,n+o));n+=o;let i=(t[n]<<8|t[n+1])>>>0;n+=2;let a=t.subarray(n),d=e.lookupCodec(s);if(d==null)throw new Error(`decodeEnvelope: codec "${s}" not registered (envelope codec_v=${i})`);return{codec:d,codecVersion:i,payload:a}}function Nn(t){t.registerCodec(jr)}var jr,Mt,Tn,Dt=V(()=>{"use strict";jr={name:"json",version:1,contentType:"application/json",encode(t){let e=JSON.stringify(t);return new TextEncoder().encode(e)},decode(t,e){let n=new TextDecoder().decode(t);return JSON.parse(n)}},Mt=1,Tn=4});function he(t){if(t==null)return ue;let{type:e,id:n,...r}=t;return{type:e??"system",id:n??"",...r}}var ue,Be=V(()=>{"use strict";ue={type:"system",id:""}});function et(){return Me>0||Ve}function Sn(){return Me>0}function ze(t){Me>0?We.push(t):t()}function Ae(t){Me+=1;let e=!1;try{t()}catch(n){throw e=!0,n}finally{if(Me-=1,Me===0)if(e){if(!Ve){let n=We.splice(0);for(let r of n)try{r()}catch{}ge.length=0,me.length=0,De.length=0}}else Br()}}function Br(){let t=!Ve;t&&(Ve=!0);let e=[],n=0;try{for(;ge.length>0||me.length>0||De.length>0||t&&We.length>0;){if(t&&We.length>0){let s=We.splice(0);for(let i of s)try{i()}catch(a){e.push(a)}continue}if(n+=1,n>1e3)throw ge.length=0,me.length=0,De.length=0,new Error("batch drain exceeded 1000 iterations \u2014 likely a reactive cycle");let o=(ge.length>0?ge:me.length>0?me:De).splice(0);for(let s of o)try{s()}catch(i){e.push(i)}}}finally{t&&(Ve=!1)}if(e.length===1)throw e[0];if(e.length>1)throw new AggregateError(e,"batch drain: multiple callbacks threw")}function tt(t,e,n){if(e.length===0)return;if(e.length===1){let u=n(e[0][0]);if(u<3||!et()){t(e);return}(u>=5?De:u===4?me:ge).push(()=>t(e));return}let r=e.length,o=r,s=r,i=r,a=0;for(;a<r&&n(e[a][0])<3;)a++;for(o=a;a<r&&n(e[a][0])===3;)a++;for(s=a;a<r&&n(e[a][0])===4;)a++;i=a;let d=et();if(o>0){let u=e.slice(0,o);t(u)}if(s>o){let u=e.slice(o,s);d?ge.push(()=>t(u)):t(u)}if(i>s){let u=e.slice(s,i);d?me.push(()=>t(u)):t(u)}if(r>i){let u=e.slice(i,r);d?De.push(()=>t(u)):t(u)}}var Me,Ve,ge,me,De,We,Ue=V(()=>{"use strict";Me=0,Ve=!1,ge=[],me=[],De=[],We=[]});function kn(t){t.registerMessageType(Fe,{tier:0,wireCrossing:!1}),t.registerMessageType(W,{tier:1,wireCrossing:!1}),t.registerMessageType(ee,{tier:1,wireCrossing:!1,metaPassthrough:!1}),t.registerMessageType(K,{tier:2,wireCrossing:!1}),t.registerMessageType(te,{tier:2,wireCrossing:!1}),t.registerMessageType(C,{tier:3,wireCrossing:!0}),t.registerMessageType(Z,{tier:3,wireCrossing:!0}),t.registerMessageType(L,{tier:4,wireCrossing:!0,metaPassthrough:!1}),t.registerMessageType(A,{tier:4,wireCrossing:!0,metaPassthrough:!1}),t.registerMessageType(F,{tier:5,wireCrossing:!0,metaPassthrough:!1})}var nt,Rn=V(()=>{"use strict";re();nt=class{_messageTypes=new Map;_codecs=new Map;_onMessage;_onSubscribe;_defaultVersioning;_defaultHashFn;_inspectorEnabled=!(typeof process<"u"&&process.env?.NODE_ENV==="production");_globalInspector;_frozen=!1;tierOf;constructor(e){this._onMessage=e.onMessage,this._onSubscribe=e.onSubscribe,this._defaultVersioning=e.defaultVersioning,this._defaultHashFn=e.defaultHashFn,this.tierOf=n=>{let r=this._messageTypes.get(n);return r!=null?r.tier:1}}get onMessage(){return this._frozen=!0,this._onMessage}get onSubscribe(){return this._frozen=!0,this._onSubscribe}set onMessage(e){this._assertUnfrozen(),this._onMessage=e}set onSubscribe(e){this._assertUnfrozen(),this._onSubscribe=e}get defaultVersioning(){return this._defaultVersioning}set defaultVersioning(e){this._assertUnfrozen(),this._defaultVersioning=e}get defaultHashFn(){return this._defaultHashFn}set defaultHashFn(e){this._assertUnfrozen(),this._defaultHashFn=e}get inspectorEnabled(){return this._inspectorEnabled}set inspectorEnabled(e){this._inspectorEnabled=e}get globalInspector(){return this._globalInspector}set globalInspector(e){this._globalInspector=e}registerMessageType(e,n){return this._assertUnfrozen(),this._messageTypes.set(e,{tier:n.tier,wireCrossing:n.wireCrossing??n.tier>=3,metaPassthrough:n.metaPassthrough??!0}),this}messageTier(e){let n=this._messageTypes.get(e);return n!=null?n.tier:1}isWireCrossing(e){let n=this._messageTypes.get(e);return n!=null?n.wireCrossing:!0}isLocalOnly(e){return!this.isWireCrossing(e)}isMetaPassthrough(e){let n=this._messageTypes.get(e);return n!=null?n.metaPassthrough:!0}isKnownMessageType(e){return this._messageTypes.has(e)}registerCodec(e){return this._assertUnfrozen(),this._codecs.set(e.name,e),this}lookupCodec(e){return this._codecs.get(e)}_isFrozen(){return this._frozen}_assertUnfrozen(){if(this._frozen)throw new Error("GraphReFlyConfig is frozen: a node has already captured this config. Register custom types and set hooks before creating any node.")}}});function Cn(t){return Array.isArray(t)?[...t]:[t]}function Vr(t,e){return t.has(e)||t.has("*")}function rt(t){let e=[];return t((o,s)=>{e.push({kind:"allow",actions:new Set(Cn(o)),where:s?.where??(()=>!0)})},(o,s)=>{e.push({kind:"deny",actions:new Set(Cn(o)),where:s?.where??(()=>!0)})}),(o,s)=>{let i=!1,a=!1;for(let d of e)Vr(d.actions,s)&&d.where(o)&&(d.kind==="deny"?i=!0:a=!0);return i?!1:a}}function At(t){let e=Wr.filter(n=>t({type:n,id:""},"write"));return e.length===0?"restricted":e.includes("human")&&e.includes("llm")&&e.every(n=>n==="human"||n==="llm"||n==="system")?"both":e.length===1?e[0]:e.join("+")}var J,Wr,Ge=V(()=>{"use strict";J=class extends Error{actor;action;nodeName;constructor(e,n){super(n??`GuardDenied: action "${String(e.action)}" denied for actor type "${String(e.actor.type)}"`),this.name="GuardDenied",this.actor=e.actor,this.action=e.action,this.nodeName=e.nodeName}get node(){return this.nodeName}};Wr=["human","llm","wallet","system"]});function Gt(t){if(t===void 0)return null;if(typeof t=="number"){if(!Number.isFinite(t))throw new TypeError(`Cannot hash non-finite number: ${t}`);if(Number.isInteger(t)&&!Number.isSafeInteger(t))throw new TypeError(`Cannot hash integer outside safe range (|n| > 2^53-1): ${t}. Cross-language cid parity is not guaranteed for unsafe integers.`);return t}if(typeof t=="string"||typeof t=="boolean"||t===null)return t;if(Array.isArray(t))return t.map(Gt);if(typeof t=="object"&&t!==null){let e={};for(let n of Object.keys(t).sort())e[n]=Gt(t[n]);return e}return null}function Kr(t){let e=Ur.encode(t),n=e.length,r=n*8,o=n+9+63&-64,s=new Uint8Array(o);s.set(e),s[n]=128;let i=new DataView(s.buffer);i.setUint32(o-4,r>>>0,!1),i.setUint32(o-8,Math.floor(r/4294967296)>>>0,!1);let a=1779033703,d=3144134277,u=1013904242,l=2773480762,f=1359893119,p=2600822924,h=528734635,c=1541459225,g=new Uint32Array(64),m=(_,y)=>_>>>y|_<<32-y;for(let _=0;_<o;_+=64){for(let S=0;S<16;S++)g[S]=i.getUint32(_+S*4,!1);for(let S=16;S<64;S++){let R=g[S-15],k=g[S-2],$=m(R,7)^m(R,18)^R>>>3,B=m(k,17)^m(k,19)^k>>>10;g[S]=g[S-16]+$+g[S-7]+B>>>0}let y=a,b=d,x=u,T=l,w=f,E=p,N=h,M=c;for(let S=0;S<64;S++){let R=m(w,6)^m(w,11)^m(w,25),k=w&E^~w&N,$=M+R+k+zr[S]+g[S]>>>0,B=m(y,2)^m(y,13)^m(y,22),X=y&b^y&x^b&x,fe=B+X>>>0;M=N,N=E,E=w,w=T+$>>>0,T=x,x=b,b=y,y=$+fe>>>0}a=a+y>>>0,d=d+b>>>0,u=u+x>>>0,l=l+T>>>0,f=f+w>>>0,p=p+E>>>0,h=h+N>>>0,c=c+M>>>0}let v=_=>_.toString(16).padStart(8,"0");return v(a)+v(d)+v(u)+v(l)+v(f)+v(p)+v(h)+v(c)}function It(t){let e=Gt(t??null),n=JSON.stringify(e);return Kr(n).slice(0,16)}function Yr(){let t=globalThis.crypto;if(t?.randomUUID)return t.randomUUID();let e=()=>Math.floor(Math.random()*4294967296).toString(16).padStart(8,"0"),n=e()+e()+e()+e();return`${n.slice(0,8)}-${n.slice(8,12)}-4${n.slice(13,16)}-${(parseInt(n.slice(16,17),16)&3|8).toString(16)}${n.slice(17,20)}-${n.slice(20,32)}`}function Lt(t,e,n){let r=n?.id??Yr();if(t===0)return{id:r,version:0};let s=(n?.hash??It)(e);return{id:r,version:0,cid:s,prev:null}}function Mn(t,e,n){t.version+=1,"cid"in t&&(t.prev=t.cid,t.cid=n(e))}var zr,Ur,Dn=V(()=>{"use strict";zr=new Uint32Array([1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298]),Ur=new TextEncoder});function In(t){return{node:t,unsub:null,prevData:void 0,dirty:!1,involvedThisWave:!1,dataBatch:[],terminal:void 0}}function Pt(t){t.prevData=void 0,t.dirty=!1,t.involvedThisWave=!1,t.dataBatch.length=0,t.terminal=void 0}function ot(t){return t.length===0?t:typeof t[0]=="symbol"?[t]:t}function be(t,e,n){let r=Ln(t)?t:[],o=typeof t=="function"?t:typeof e=="function"?e:void 0,s={};return Ln(t)?s=($t(e)?e:n)??{}:$t(t)?s=t:s=($t(e)?e:n)??{},new P(r,o,s)}var An,Gn,Jr,Qr,ye,P,Ln,$t,Ie=V(()=>{"use strict";Dt();Be();Ue();je();Rn();Ge();re();Dn();An=()=>{},Gn=100;Jr=(t,e,n,r)=>{n.direction==="down-in"&&t._onDepMessage(n.depIndex,e)},Qr=(t,e,n,r)=>{let o=t;if(o._status==="completed"||o._status==="errored")return;let s=o._cached,i=s===void 0?[St]:[St,[C,s]];o._status==="dirty"&&i.push(xe),tt(e,i,o._config.tierOf)},ye=new nt({onMessage:Jr,onSubscribe:Qr});kn(ye);Nn(ye);P=class t{_optsName;_describeKind;meta;_hasMeta;_config;_deps;_sinks=null;_sinkCount=0;_cached;_status;_cleanup;_store={};_waveHasNewData=!1;_hasNewTerminal=!1;_hasCalledFnOnce=!1;_paused=!1;_pendingWave=!1;_isExecutingFn=!1;_pendingRerun=!1;_rerunDepth=0;_dirtyDepCount=0;_batchPendingMessages=null;_pauseLocks=null;_pauseBuffer=null;_fn;_equals;_resubscribable;_resetOnTeardown;_autoComplete;_autoError;_pausable;_partial;_guard;_extraGuards;_hashFn;_versioning;_versioningLevel;_lastMutation;_inspectorHooks;_actions;constructor(e,n,r){this._config=r.config??ye,this._config.onMessage,this._optsName=r.name,this._describeKind=r.describeKind,this._equals=r.equals??Object.is,this._resubscribable=r.resubscribable??!1,this._resetOnTeardown=r.resetOnTeardown??!1,this._autoComplete=r.completeWhenDepsComplete??!0,this._autoError=r.errorWhenDepsError??!0,this._pausable=r.pausable??!0,this._guard=r.guard,this._fn=n,this._partial=r.partial??!1,this._cached=r.initial!==void 0?r.initial:void 0,this._status=e.length===0&&n==null&&this._cached!==void 0?"settled":"sentinel",this._hashFn=r.versioningHash??this._config.defaultHashFn??It;let o=r.versioning??this._config.defaultVersioning;this._versioningLevel=o,this._versioning=o!=null?Lt(o,this._cached===void 0?void 0:this._cached,{id:r.versioningId,hash:this._hashFn}):void 0,this._deps=e.map(In);let s={};for(let[a,d]of Object.entries(r.meta??{})){let u={initial:d,name:`${r.name??"node"}:meta:${a}`,describeKind:"state",config:this._config};r.guard!=null&&(u.guard=r.guard),s[a]=new t([],void 0,u)}Object.freeze(s),this.meta=s,this._hasMeta=Object.keys(s).length>0;let i=this;this._actions={emit(a){i._emit([[C,a]])},down(a){i._emit(ot(a))},up(a){i._emitUp(ot(a))}},this.down=this.down.bind(this),this.up=this.up.bind(this)}get _isTerminal(){return this._status==="completed"||this._status==="errored"}get name(){return this._optsName}get status(){return this._status}get cache(){return this._cached===void 0?void 0:this._cached}get lastMutation(){return this._lastMutation}get v(){return this._versioning}hasGuard(){return this._guard!=null}_applyVersioning(e,n){if(this._isExecutingFn)throw new Error(`Node "${this.name}": _applyVersioning cannot run mid-fn \u2014 call it outside of \`_execFn\` (typically at graph setup time before the first subscribe).`);let r=this._versioningLevel;if(r!=null&&e<=r)return;let o=n?.hash??this._hashFn;o!==this._hashFn&&(this._hashFn=o);let s=this._cached===void 0?void 0:this._cached,i=this._versioning,a=i?.id??n?.id,d=i?.version??0,u=Lt(e,s,{id:a,hash:o});u.version=d,this._versioning=u,this._versioningLevel=e}_setInspectorHook(e){return e==null?()=>{}:(this._inspectorHooks==null&&(this._inspectorHooks=new Set),this._inspectorHooks.add(e),()=>{this._inspectorHooks?.delete(e),this._inspectorHooks?.size===0&&(this._inspectorHooks=void 0)})}_pushGuard(e){return this._extraGuards==null&&(this._extraGuards=new Set),this._extraGuards.add(e),()=>{this._extraGuards?.delete(e),this._extraGuards?.size===0&&(this._extraGuards=void 0)}}allowsObserve(e){if(this._guard==null&&this._extraGuards==null)return!0;let n=he(e);if(this._guard!=null&&!this._guard(n,"observe"))return!1;if(this._extraGuards!=null){for(let r of this._extraGuards)if(!r(n,"observe"))return!1}return!0}_checkGuard(e){if(e?.internal)return;let n=this._guard!=null||this._extraGuards!=null,r=e?.actor!=null;if(!n&&!r)return;let o=he(e?.actor),s=e?.delivery==="signal"?"signal":"write";if(this._guard!=null&&!this._guard(o,s))throw new J({actor:o,action:s,nodeName:this.name});if(this._extraGuards!=null){for(let i of this._extraGuards)if(!i(o,s))throw new J({actor:o,action:s,nodeName:this.name})}this._lastMutation={actor:o,timestamp_ns:ae()}}down(e,n){let r=ot(e);r.length!==0&&(this._checkGuard(n),this._emit(r))}emit(e,n){this._checkGuard(n),this._emit([[C,e]])}up(e,n){if(this._deps.length===0)return;let r=ot(e);if(r.length===0)return;this._checkGuard(n);let o=n??{internal:!0};this._validateUpTiers(r);for(let s of this._deps)s.node.up?.(r,o)}_emitUp(e){if(this._deps.length!==0&&e.length!==0){this._validateUpTiers(e);for(let n of this._deps)n.node.up?.(e,{internal:!0})}}_validateUpTiers(e){let n=this._config.tierOf;for(let r of e){let o=n(r[0]);if(o===3||o===4)throw new Error(`Node "${this.name}": tier-${o} messages cannot flow up \u2014 DATA/RESOLVED/COMPLETE/ERROR are downstream-only. Use \`down(...)\` for value delivery; \`up(...)\` is for control signals (DIRTY, INVALIDATE, PAUSE, RESUME, TEARDOWN).`)}}subscribe(e,n){if(n!=null&&this._guard!=null){let d=he(n);if(!this._guard(d,"observe"))throw new J({actor:d,action:"observe",nodeName:this.name})}let o=this._isTerminal&&this._resubscribable;if(o){this._cached=void 0,this._status="sentinel",this._store={},this._hasCalledFnOnce=!1,this._waveHasNewData=!1,this._hasNewTerminal=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._isExecutingFn=!1,this._rerunDepth=0,this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null;for(let d of this._deps)Pt(d);if(this._partial===!1){for(let d of this._deps)if(d.prevData!==void 0||d.dataBatch.length!==0||d.terminal!==void 0||d.dirty)throw new Error(`resubscribable-reset invariant: DepRecord not fully reset for node ${this._optsName??"(anonymous)"}`)}}this._sinkCount+=1;let s;try{s=this._config.onSubscribe(this,e,{sinkCount:this._sinkCount,afterTerminalReset:o},this._actions)}catch(d){throw this._sinkCount-=1,d}this._sinks==null?this._sinks=e:typeof this._sinks=="function"?this._sinks=new Set([this._sinks,e]):this._sinks.add(e);let i=this._isTerminal;if(this._sinkCount===1&&!i)try{this._activate()}catch(d){if(this._sinkCount-=1,this._removeSink(e),this._sinkCount===0&&(this._status="sentinel"),typeof s=="function")try{s()}catch{}throw d}this._status==="sentinel"&&this._cached===void 0&&(this._status="pending");let a=!1;return()=>{a||(a=!0,this._sinkCount-=1,this._removeSink(e),typeof s=="function"&&s(),this._sinks==null&&this._deactivate())}}_removeSink(e){if(this._sinks===e)this._sinks=null;else if(this._sinks!=null&&typeof this._sinks!="function")if(this._sinks.delete(e),this._sinks.size===1){let[n]=this._sinks;this._sinks=n}else this._sinks.size===0&&(this._sinks=null)}_activate(){if(this._deps.length===0){this._fn&&this._execFn();return}this._dirtyDepCount=0;let e=this._deps.length,n=0;try{for(let r=0;r<e;r++){let o=r,s=this._deps[r];s.unsub=An,s.unsub=s.node.subscribe(i=>{if(s.unsub===null)return;let a=this._config.tierOf,d=!1;for(let u of i)a(u[0])>=3&&(d=!0),this._config.onMessage(this,u,{direction:"down-in",depIndex:o},this._actions);d&&this._maybeRunFnOnSettlement()}),n++}}catch(r){this._deps[n].unsub=null;for(let o=0;o<n;o++){let s=this._deps[o];if(s.unsub!=null){let i=s.unsub;s.unsub=null;try{i()}catch{}Pt(s)}}throw this._dirtyDepCount=0,r}}_addDep(e){for(let o=0;o<this._deps.length;o++)if(this._deps[o].node===e)return o;let n=this._deps.length,r=In(e);if(this._deps.push(r),this._sinks==null)return n;r.dirty=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(kt),r.unsub=An;try{r.unsub=e.subscribe(o=>{if(r.unsub===null)return;let s=this._config.tierOf,i=!1;for(let a of o)s(a[0])>=3&&(i=!0),this._config.onMessage(this,a,{direction:"down-in",depIndex:n},this._actions);i&&this._maybeRunFnOnSettlement()})}catch(o){throw r.unsub=null,this._deps.pop(),this._dirtyDepCount--,o}return n}_deactivate(e=!1){let n=this._cleanup;if(this._cleanup=void 0,typeof n=="function")try{n()}catch(r){this._emit([[A,this._wrapFnError("cleanup threw",r)]])}else if(n!=null&&typeof n=="object"){let r=n.deactivate;if(typeof r=="function")try{r()}catch(o){this._emit([[A,this._wrapFnError("cleanup.deactivate threw",o)]])}}for(let r of this._deps){if(r.unsub!=null){let o=r.unsub;r.unsub=null;try{o()}catch{}}Pt(r)}this._waveHasNewData=!1,this._hasNewTerminal=!1,this._hasCalledFnOnce=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._rerunDepth=0,this._store={},this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null,this._fn!=null&&(this._cached=void 0),e||(this._fn!=null||this._deps.length>0)&&(!this._isTerminal||this._resubscribable)&&(this._status="sentinel")}_onDepMessage(e,n){let r=this._deps[e],o=n[0];if(this._inspectorHooks!=null){let s={kind:"dep_message",depIndex:e,message:n};for(let i of this._inspectorHooks)i(s)}if(o!==Fe){if(o===W){this._depDirtied(r);return}if(o===ee){this._depInvalidated(r),this._emit(cn);return}if(o===K||o===te){this._emit([n]);return}if(o===F){this._emit(Rt);return}if(o===C)this._depSettledAsData(r,n[1]);else if(o===Z)this._depSettledAsResolved(r);else if(o===L)this._depSettledAsTerminal(r,!0);else if(o===A)this._depSettledAsTerminal(r,n[1]);else{this._emit([n]);return}if(!this._fn){(o===C||o===Z)&&this._emit([n]),(o===L||o===A)&&this._maybeAutoTerminalAfterWave();return}}}_depDirtied(e){e.dirty||(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(kt))}_depSettledAsData(e,n){e.dirty&&(e.dirty=!1,this._dirtyDepCount--),e.involvedThisWave=!0,e.dataBatch.push(n),this._waveHasNewData=!0}_depSettledAsResolved(e){e.dirty&&(e.dirty=!1,this._dirtyDepCount--)}_depSettledAsTerminal(e,n){e.dirty&&(e.dirty=!1,this._dirtyDepCount--),e.terminal=n,e.involvedThisWave=!0,this._hasNewTerminal=!0}_depInvalidated(e){e.prevData=void 0,e.terminal=void 0,e.dataBatch.length=0,e.dirty?e.involvedThisWave=!1:(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++)}_maybeRunFnOnSettlement(){if(!(this._isTerminal&&!this._resubscribable)&&!(this._dirtyDepCount>0)){if(!this._partial&&!this._hasCalledFnOnce)for(let e=0;e<this._deps.length;e++){let n=this._deps[e];if(n.dataBatch.length===0&&n.prevData===void 0&&n.terminal===void 0){this._maybeAutoTerminalAfterWave();return}}if(this._paused){this._pendingWave=!0;return}if(!this._waveHasNewData&&!this._hasNewTerminal&&this._hasCalledFnOnce){this._clearWaveFlags(),this._emit(dn),this._maybeAutoTerminalAfterWave();return}this._fn&&this._execFn(),this._maybeAutoTerminalAfterWave()}}_maybeAutoTerminalAfterWave(){if(this._deps.length===0||this._isTerminal)return;let e=this._deps.find(n=>n.terminal!==void 0&&n.terminal!==!0);if(e!=null){this._autoError&&this._emit([[A,e.terminal]]);return}this._autoComplete&&this._deps.every(n=>n.terminal!==void 0)&&this._emit(ln)}_execFn(){if(!this._fn||this._isTerminal&&!this._resubscribable)return;if(this._isExecutingFn){this._pendingRerun=!0;return}let e=this._cleanup;if(typeof e=="function"){this._cleanup=void 0;try{e()}catch(i){this._emit([[A,this._wrapFnError("cleanup threw",i)]]);return}}else if(e!=null&&typeof e=="object"){let i=e.beforeRun;if(typeof i=="function"){e.beforeRun=void 0;try{i()}catch(a){this._emit([[A,this._wrapFnError("cleanup.beforeRun threw",a)]]);return}}}let n=this._deps.map(i=>i.involvedThisWave?i.dataBatch.length>0?[...i.dataBatch]:[]:void 0),r=this._deps.map(i=>i.prevData);for(let i=0;i<this._deps.length;i++){let a=n[i];a!=null&&a.length>0&&(this._deps[i].prevData=a[a.length-1])}let o=this._deps.map(i=>i.terminal),s={prevData:r,terminalDeps:o,store:this._store};if(this._hasCalledFnOnce=!0,this._clearWaveFlags(),this._inspectorHooks!=null){let i={kind:"run",batchData:n,prevData:r};for(let a of this._inspectorHooks)a(i)}this._isExecutingFn=!0;try{let i=this._fn(n,this._actions,s);if(typeof i=="function")this._cleanup=i;else if(i!=null&&typeof i=="object"){let a=i;(typeof a.beforeRun=="function"||typeof a.deactivate=="function"||typeof a.invalidate=="function")&&(this._cleanup=i)}}catch(i){this._emit([[A,this._wrapFnError("fn threw",i)]])}finally{this._isExecutingFn=!1,this._pendingRerun?(this._pendingRerun=!1,this._rerunDepth+=1,this._rerunDepth>Gn?(this._rerunDepth=0,this._emit([[A,new Error(`Node "${this.name}": _pendingRerun depth exceeded ${Gn} \u2014 likely a reactive cycle`)]])):this._maybeRunFnOnSettlement()):this._rerunDepth=0,this._clearWaveFlags()}}_clearWaveFlags(){this._waveHasNewData=!1,this._hasNewTerminal=!1;for(let e of this._deps)e.involvedThisWave=!1,e.dataBatch.length=0}_wrapFnError(e,n){let r=n instanceof Error?n.message:String(n);return new Error(`Node "${this.name}": ${e}: ${r}`,{cause:n})}_frameBatch(e){let n=this._config.tierOf;if(e.length===1)return n(e[0][0])===3&&this._status!=="dirty"?[xe,e[0]]:e;let r=!0,o=!1,s=!1,i=-1;for(let d of e){let u=n(d[0]);u<i&&(r=!1),u===3&&(o=!0),d[0]===W&&(s=!0),i=u}let a=e;if(!r){let d=e.map((u,l)=>({m:u,i:l,tier:n(u[0])}));d.sort((u,l)=>u.tier-l.tier||u.i-l.i),a=d.map(u=>u.m)}if(o&&!s&&this._status!=="dirty"){let d=0;for(;d<a.length&&n(a[d][0])===0;)d++;return d===0?[xe,...a]:[...a.slice(0,d),xe,...a.slice(d)]}return a}_emit(e){if(e.length===0)return;for(let a=0;a<e.length;a++){let d=e[a];if(d[0]===A&&d[1]===void 0)throw new TypeError('[ERROR, payload] requires a non-undefined payload (spec \xA71.2). Pass an Error object or domain tag instead \u2014 e.g. node.down([[ERROR, new Error("reason")]])')}let n=e;if(this._isTerminal&&!this._resubscribable){let a=e.filter(d=>d[0]===F||d[0]===ee);if(a.length===0)return;n=a}n=this._frameBatch(n);let o=null;for(let a=0;a<n.length;a++){let d=n[a],u=d[0];if(u!==K&&u!==te){o?.push(d);continue}if(d.length<2)throw new Error(`Node "${this.name}": [[${u===K?"PAUSE":"RESUME"}]] must carry a lockId payload \u2014 bare PAUSE/RESUME is a protocol violation (C0 rule). Use \`[[PAUSE, lockId]]\` / \`[[RESUME, lockId]]\`.`);let l=!0;if(this._pausable!==!1){let f=d[1];if(u===K)this._pauseLocks==null&&(this._pauseLocks=new Set),this._pauseLocks.add(f),this._paused=!0,this._pausable==="resumeAll"&&this._pauseBuffer==null&&(this._pauseBuffer=[]);else if(this._pauseLocks==null||!this._pauseLocks.has(f))l=!1;else if(this._pauseLocks.delete(f),this._pauseLocks.size===0){if(this._paused=!1,this._pauseBuffer!=null&&this._pauseBuffer.length>0){let p=this._pauseBuffer;this._pauseBuffer=[],this._emit(p)}this._pendingWave&&(this._pendingWave=!1,this._maybeRunFnOnSettlement())}}l?o?.push(d):o==null&&(o=n.slice(0,a))}if(o!=null){if(o.length===0)return;n=o}if(this._hasMeta&&n.some(a=>a[0]===F))for(let a of Object.keys(this.meta))try{this.meta[a]._emit(Rt)}catch{}let{finalMessages:s,equalsError:i}=this._updateState(n);if(s.length>0&&this._config.inspectorEnabled){let a=this._config.globalInspector;if(a!=null)try{a({kind:"emit",node:this,messages:s})}catch{}}if(s.length>0)if(this._paused&&this._pausable==="resumeAll"&&this._pauseBuffer!=null){let a=this._config.tierOf,d=[];for(let u of s)a(u[0])===3?this._pauseBuffer.push(u):d.push(u);d.length>0&&this._dispatchOrAccumulate(d)}else this._dispatchOrAccumulate(s);i!=null&&this._emit([[A,i]])}_updateState(e){let n=this._config.tierOf,r,o,s=-1,i=0;for(let l of e)n(l[0])===3&&i++;let a=i<=1,d=-1;if(this._versioning!=null&&i>1){for(let l=e.length-1;l>=0;l--)if(e[l][0]===C){d=l;break}}for(let l=0;l<e.length;l++){let f=e[l],p=f[0];if(p===C){if(f.length>=2){let h=!1;if(a&&this._cached!==void 0)try{h=this._equals(this._cached,f[1])}catch(c){o=this._wrapFnError("equals threw",c),s=l;break}if(h){r==null&&(r=e.slice(0,l)),r.push(Nt),this._status="resolved";continue}this._cached=f[1],this._versioning!=null&&(d<0||l===d)&&Mn(this._versioning,f[1],this._hashFn)}this._status="settled",r?.push(f)}else if(r?.push(f),p===W)this._status="dirty";else if(p===Z)this._status="resolved";else if(p===L)this._status="completed";else if(p===A)this._status="errored";else if(p===ee){this._cached=void 0,this._status="dirty";let h=this._cleanup;if(typeof h=="function"){this._cleanup=void 0;try{h()}catch{}}else if(h!=null&&typeof h=="object"){let c=h.invalidate;if(typeof c=="function")try{c()}catch{}}}else p===F&&(this._resetOnTeardown&&(this._cached=void 0),this._deactivate(!0),this._status="sentinel")}let u=s>=0?r??e.slice(0,s):r??e;return o!=null?{finalMessages:u,equalsError:o}:{finalMessages:u}}_deliverToSinks=e=>{if(this._sinks==null)return;if(typeof this._sinks=="function"){this._sinks(e);return}let n=[...this._sinks];for(let r of n)r(e)};_dispatchOrAccumulate(e){if(Sn()){this._batchPendingMessages===null&&(this._batchPendingMessages=[],ze(()=>this._flushBatchPending()));for(let n of e)this._batchPendingMessages.push(n);return}tt(this._deliverToSinks,e,this._config.tierOf)}_flushBatchPending(){let e=this._batchPendingMessages;if(e===null||(this._batchPendingMessages=null,e.length===0))return;let n=this._frameBatch(e);tt(this._deliverToSinks,n,this._config.tierOf)}},Ln=t=>Array.isArray(t),$t=t=>typeof t=="object"&&t!=null&&!Array.isArray(t)});function oe(t,e){return be([],{...e,initial:t})}function Le(t,e){return be((r,o,s)=>t(o,s)??void 0,{describeKind:"producer",...e})}function se(t,e,n){return be(t,(o,s,i)=>{let a=o.map((d,u)=>d!=null&&d.length>0?d.at(-1):i.prevData[u]);s.emit(e(a,i))},{describeKind:"derived",...n})}var Ke=V(()=>{"use strict";Ie()});function Ye(t,e,n){let r=new Set;for(let o of t.split(",")){let[s,i]=o.split("/"),a=i?Number.parseInt(i,10):1;if(Number.isNaN(a)||a<1)throw new Error(`Invalid cron step: ${o}`);let d,u;if(s==="*")d=e,u=n;else if(s.includes("-")){let[l,f]=s.split("-");d=Number.parseInt(l,10),u=Number.parseInt(f,10)}else d=Number.parseInt(s,10),u=d;if(Number.isNaN(d)||Number.isNaN(u))throw new Error(`Invalid cron field: ${t}`);if(d<e||u>n)throw new Error(`Cron field out of range: ${t} (${e}-${n})`);if(d>u)throw new Error(`Invalid cron range: ${d}-${u} in ${t}`);for(let l=d;l<=u;l+=a)r.add(l)}return r}function Pn(t){let e=t.trim().split(/\s+/);if(e.length!==5)throw new Error(`Invalid cron: expected 5 fields, got ${e.length}`);return{minutes:Ye(e[0],0,59),hours:Ye(e[1],0,23),daysOfMonth:Ye(e[2],1,31),months:Ye(e[3],1,12),daysOfWeek:Ye(e[4],0,6)}}function $n(t,e){return t.minutes.has(e.getMinutes())&&t.hours.has(e.getHours())&&t.daysOfMonth.has(e.getDate())&&t.months.has(e.getMonth()+1)&&t.daysOfWeek.has(e.getDay())}var Hn=V(()=>{"use strict"});function Fn(t){return{describeKind:"producer",...t}}function qn(t,e){let{signal:n,period:r,...o}=e??{};return Le(s=>{let i=!1,a=0,d,u,l=()=>{i=!0,d!==void 0&&clearTimeout(d),u!==void 0&&clearInterval(u),n?.removeEventListener("abort",p)},f=()=>{i||(r!=null?(s.emit(a++),u=setInterval(()=>{i||s.emit(a++)},r)):(i=!0,n?.removeEventListener("abort",p),s.emit(a++),s.down([[L]])))},p=()=>{i||(l(),s.down([[A,n.reason]]))};if(n?.aborted){p();return}return d=setTimeout(f,t),n?.addEventListener("abort",p,{once:!0}),l},Fn(o))}function jn(t,e){let n=Pn(t),{tickMs:r,output:o,...s}=e??{},i=r??6e4,a=o==="date";return Le(d=>{let u=-1,l=()=>{let p=new Date,h=p.getFullYear()*1e8+(p.getMonth()+1)*1e6+p.getDate()*1e4+p.getHours()*100+p.getMinutes();h!==u&&$n(n,p)&&(u=h,d.emit(a?p:ae()))};l();let f=setInterval(l,i);return()=>clearInterval(f)},{...Fn(s),name:s.name??`cron:${t}`})}function de(t){return t.subscribe(()=>{})}var st=V(()=>{"use strict";je();re();Ke();Hn()});var ct,Yn=V(()=>{"use strict";ct=class{_timer;_gen=0;start(e,n){this.cancel(),this._gen+=1;let r=this._gen;this._timer=setTimeout(()=>{this._timer=void 0,r===this._gen&&n()},e)}cancel(){this._timer!==void 0&&(clearTimeout(this._timer),this._timer=void 0)}get pending(){return this._timer!==void 0}}});var ts={};Dr(ts,{ACTOR_KEY:()=>ut,COMMAND_HANDLERS:()=>Ne,CQRS_EVENT_HANDLERS:()=>Se,CRON_HANDLERS:()=>Oe,CommandHandler:()=>vn,EVENT_HANDLERS:()=>Te,EventHandler:()=>_n,GRAPHREFLY_REQUEST_GRAPH:()=>pe,GRAPHREFLY_ROOT_GRAPH:()=>Y,GraphCron:()=>bn,GraphInterval:()=>yn,GraphReflyEventExplorer:()=>ve,GraphReflyGuard:()=>Kn,GraphReflyGuardImpl:()=>Je,GraphReflyModule:()=>_t,INTERVAL_HANDLERS:()=>Ee,InjectCqrsGraph:()=>hn,InjectGraph:()=>pn,InjectNode:()=>gn,ObserveGateway:()=>at,OnGraphEvent:()=>mn,QUERY_HANDLERS:()=>ke,QueryHandler:()=>wn,SAGA_HANDLERS:()=>Re,SagaHandler:()=>xn,fromHeader:()=>zn,fromJwtPayload:()=>qt,getActor:()=>Un,getGraphToken:()=>j,getNodeToken:()=>ne,observeSSE:()=>Vn,observeSubscription:()=>Wn,toObservable:()=>fn});module.exports=Gr(ts);var Ct=require("rxjs");re();function fn(t,e){return e?.raw?new Ct.Observable(n=>t.subscribe(o=>{if(!n.closed){n.next(o);for(let s of o){if(s[0]===A){n.error(s[1]);return}if(s[0]===L){n.complete();return}}}})):new Ct.Observable(n=>t.subscribe(o=>{for(let s of o){if(n.closed)return;if(s[0]===C)n.next(s[1]);else if(s[0]===A){n.error(s[1]);return}else if(s[0]===L){n.complete();return}}}))}var qe=require("@nestjs/common");var Y=Symbol.for("graphrefly:root-graph");var pe=Symbol.for("graphrefly:request-graph");function j(t){return Symbol.for(`graphrefly:graph:${t}`)}function ne(t){return Symbol.for(`graphrefly:node:${t}`)}var Te=new Map,Ee=new Map,Oe=new Map,Ne=new Map,Se=new Map,ke=new Map,Re=new Map;function pn(t){return t==="request"?(0,qe.Inject)(pe):(0,qe.Inject)(t?j(t):Y)}function hn(t){return(0,qe.Inject)(j(t))}function gn(t){return(0,qe.Inject)(ne(t))}function mn(t){return(e,n)=>{let r=n.name;n.addInitializer(function(){let o=this.constructor,s=Te.get(o)??[];s.push({nodeName:t,methodKey:r}),Te.set(o,s)})}}function yn(t){return(e,n)=>{let r=n.name;n.addInitializer(function(){let o=this.constructor,s=Ee.get(o)??[];s.push({ms:t,methodKey:r}),Ee.set(o,s)})}}function bn(t){return(e,n)=>{let r=n.name;n.addInitializer(function(){let o=this.constructor,s=Oe.get(o)??[];s.push({expr:t,methodKey:r}),Oe.set(o,s)})}}function vn(t,e){return(n,r)=>{let o=r.name;r.addInitializer(function(){let s=this.constructor,i=Ne.get(s)??[];i.push({cqrsName:t,commandName:e,methodKey:o}),Ne.set(s,i)})}}function _n(t,e){return(n,r)=>{let o=r.name;r.addInitializer(function(){let s=this.constructor,i=Se.get(s)??[];i.push({cqrsName:t,eventName:e,methodKey:o}),Se.set(s,i)})}}function wn(t,e){return(n,r)=>{let o=r.name;r.addInitializer(function(){let s=this.constructor,i=ke.get(s)??[];i.push({cqrsName:t,projectionName:e,methodKey:o}),ke.set(s,i)})}}function xn(t,e,n){return(r,o)=>{let s=o.name;o.addInitializer(function(){let i=this.constructor,a=Re.get(i)??[];a.push({cqrsName:t,eventNames:n,sagaName:e,methodKey:s}),Re.set(i,a)})}}re();st();var Bn=0,ve=class{constructor(e,n){this.graph=e;this.moduleRef=n}disposers=[];scheduleNodeNames=[];onModuleInit(){this.wireEvents(),this.wireIntervals(),this.wireCrons(),this.wireCqrsCommands(),this.wireCqrsEvents(),this.wireCqrsQueries(),this.wireCqrsSagas()}onModuleDestroy(){for(let e of this.disposers)e();this.disposers.length=0;for(let e of this.scheduleNodeNames)try{this.graph.remove(e)}catch{}this.scheduleNodeNames.length=0}wireEvents(){for(let[e,n]of Te){let r=this.resolveInstance(e);if(r)for(let o of n)this.wireEventHandler(r,o)}}wireEventHandler(e,n){let r=e[n.methodKey];if(typeof r!="function")return;let o=r.bind(e),i=this.observeNode(n.nodeName).subscribe(a=>{for(let d of a)d[0]===C&&o(d[1])});this.disposers.push(i)}wireIntervals(){for(let[e,n]of Ee){let r=this.resolveInstance(e);if(r)for(let o of n)this.wireIntervalHandler(r,e,o)}}wireIntervalHandler(e,n,r){let o=e[r.methodKey];if(typeof o!="function")return;let s=o.bind(e),a=`__schedule__.${n.name??"anonymous"}.${String(r.methodKey)}.${Bn++}`,d=qn(r.ms,{period:r.ms,name:a});this.graph.add(d),this.scheduleNodeNames.push(a);let l=this.observeNode(a).subscribe(f=>{for(let p of f)p[0]===C&&s(p[1])});this.disposers.push(l)}wireCrons(){for(let[e,n]of Oe){let r=this.resolveInstance(e);if(r)for(let o of n)this.wireCronHandler(r,e,o)}}wireCronHandler(e,n,r){let o=e[r.methodKey];if(typeof o!="function")return;let s=o.bind(e),a=`__schedule__.${n.name??"anonymous"}.${String(r.methodKey)}.${Bn++}`,d=jn(r.expr,{name:a});this.graph.add(d),this.scheduleNodeNames.push(a);let l=this.observeNode(a).subscribe(f=>{for(let p of f)p[0]===C&&s(p[1])});this.disposers.push(l)}wireCqrsCommands(){for(let[e,n]of Ne){let r=this.resolveInstance(e);if(r)for(let o of n)this.wireCqrsCommand(r,o)}}wireCqrsCommand(e,n){let r=e[n.methodKey];if(typeof r!="function")return;let o=r.bind(e),s=this.resolveCqrsGraph(n.cqrsName);s&&s.command(n.commandName,o)}wireCqrsEvents(){for(let[e,n]of Se){let r=this.resolveInstance(e);if(r)for(let o of n)this.wireCqrsEventHandler(r,o)}}wireCqrsEventHandler(e,n){let r=e[n.methodKey];if(typeof r!="function")return;let o=r.bind(e),s=this.resolveCqrsGraph(n.cqrsName);if(!s)return;s.event(n.eventName);let a=s.resolve(n.eventName).cache,d=a&&a.length>0?a[a.length-1].seq:0,l=this.observeNodeOn(s,n.eventName).subscribe(f=>{for(let p of f)if(p[0]===C){let h=p[1];for(let c of h)c.seq>d&&(o(c),d=c.seq)}});this.disposers.push(l)}wireCqrsQueries(){for(let[e,n]of ke){let r=this.resolveInstance(e);if(r)for(let o of n)this.wireCqrsQuery(r,o)}}wireCqrsQuery(e,n){let r=e[n.methodKey];if(typeof r!="function")return;let o=r.bind(e),s=this.resolveCqrsGraph(n.cqrsName);if(!s)return;let a=this.observeNodeOn(s,n.projectionName).subscribe(d=>{for(let u of d)u[0]===C&&o(u[1])});this.disposers.push(a)}wireCqrsSagas(){for(let[e,n]of Re){let r=this.resolveInstance(e);if(r)for(let o of n)this.wireCqrsSaga(r,o)}}wireCqrsSaga(e,n){let r=e[n.methodKey];if(typeof r!="function")return;let o=r.bind(e),s=this.resolveCqrsGraph(n.cqrsName);s&&s.saga(n.sagaName,n.eventNames,o)}observeNode(e){return this.graph.observe(e)}observeNodeOn(e,n){return e.observe(n)}resolveCqrsGraph(e){try{return this.moduleRef.get(j(e),{strict:!1})}catch{return console.warn(`[GraphReFly] CqrsGraph "${e}" not found in DI \u2014 did you import GraphReflyModule.forCqrs({ name: "${e}" })?`),null}}resolveInstance(e){try{return this.moduleRef.get(e,{strict:!1})}catch{return null}}};re();re();var Xr=0;function it(t,e){if(e.highWaterMark<1)throw new RangeError("highWaterMark must be >= 1");if(e.lowWaterMark<0)throw new RangeError("lowWaterMark must be >= 0");if(e.lowWaterMark>=e.highWaterMark)throw new RangeError("lowWaterMark must be < highWaterMark");let n=Symbol(`bp-${++Xr}`),r=0,o=!1;return{onEnqueue(){return r+=1,!o&&r>=e.highWaterMark?(o=!0,t([[K,n]]),!0):!1},onDequeue(){return r>0&&(r-=1),o&&r<=e.lowWaterMark?(o=!1,t([[te,n]]),!0):!1},get pending(){return r},get paused(){return o},dispose(){o&&(o=!1,t([[te,n]]))}}}function Vn(t,e,n){let{actor:r,serialize:o=Zr,keepAliveMs:s,signal:i}=n??{},a=new TextEncoder,d,u=n?.highWaterMark!=null,l,f,p=[],h=!1;return new ReadableStream({start(c){let g,m=()=>{},v=()=>{if(!h){h=!0,g!==void 0&&clearInterval(g),i?.removeEventListener("abort",_),m(),l?.dispose(),f?.(),f=void 0;for(let b of p)c.enqueue(b.frame);p.length=0,c.close()}};d=v;let _=()=>v(),y=t.observe(e,{actor:r});u&&(l=it(b=>y.up(b),{highWaterMark:n.highWaterMark,lowWaterMark:n.lowWaterMark??Math.floor(n.highWaterMark/2)})),m=y.subscribe(b=>{for(let x of b){if(h)return;let T=x[0];if(T===C){let w=a.encode(Ht("data",o(x[1])));u?(p.push({frame:w,counted:!0}),l.onEnqueue(),f?.(),f=void 0):c.enqueue(w)}else if(T===A){let w=a.encode(Ht("error",o(x[1])));u?(p.push({frame:w,counted:!1}),f?.(),f=void 0):c.enqueue(w),v();return}else if(T===L||T===F){if(T===L){let w=a.encode(Ht("complete"));u?(p.push({frame:w,counted:!1}),f?.(),f=void 0):c.enqueue(w)}v();return}}}),s!==void 0&&s>0&&(g=setInterval(()=>{h||(u?(p.push({frame:a.encode(`: keepalive
|
|
1
|
+
"use strict";var kr=Object.create;var we=Object.defineProperty;var nn=Object.getOwnPropertyDescriptor;var Cr=Object.getOwnPropertyNames;var Rr=Object.prototype.hasOwnProperty;var rn=(t,e)=>(e=Symbol[t])?e:Symbol.for("Symbol."+t),He=t=>{throw TypeError(t)};var Mr=(t,e,n)=>e in t?we(t,e,{enumerable:!0,configurable:!0,writable:!0,value:n}):t[e]=n;var Zt=(t,e)=>we(t,"name",{value:e,configurable:!0});var V=(t,e)=>()=>(t&&(e=t(t=0)),e);var Dr=(t,e)=>{for(var n in e)we(t,n,{get:e[n],enumerable:!0})},Ar=(t,e,n,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let o of Cr(e))!Rr.call(t,o)&&o!==n&&we(t,o,{get:()=>e[o],enumerable:!(r=nn(e,o))||r.enumerable});return t};var Gr=t=>Ar(we({},"__esModule",{value:!0}),t);var on=t=>[,,,kr(t?.[rn("metadata")]??null)],sn=["class","method","getter","setter","accessor","field","value","get","set"],$e=t=>t!==void 0&&typeof t!="function"?He("Function expected"):t,Ir=(t,e,n,r,o)=>({kind:sn[t],name:e,metadata:r,addInitializer:s=>n._?He("Already initialized"):o.push($e(s||null))}),Lr=(t,e)=>Mr(e,rn("metadata"),t[3]),an=(t,e,n,r)=>{for(var o=0,s=t[e>>1],i=s&&s.length;o<i;o++)e&1?s[o].call(n):r=s[o].call(n,r);return r},un=(t,e,n,r,o,s)=>{var i,a,d,u,l,f=e&7,p=!!(e&8),h=!!(e&16),c=f>3?t.length+1:f?p?1:2:0,g=sn[f+5],m=f>3&&(t[c-1]=[]),v=t[c]||(t[c]=[]),_=f&&(!h&&!p&&(o=o.prototype),f<5&&(f>3||!h)&&nn(f<4?o:{get[n](){return en(this,s)},set[n](b){return tn(this,s,b)}},n));f?h&&f<4&&Zt(s,(f>2?"set ":f>1?"get ":"")+n):Zt(o,n);for(var y=r.length-1;y>=0;y--)u=Ir(f,n,d={},t[3],v),f&&(u.static=p,u.private=h,l=u.access={has:h?b=>Pr(o,b):b=>n in b},f^3&&(l.get=h?b=>(f^1?en:$r)(b,o,f^4?s:_.get):b=>b[n]),f>2&&(l.set=h?(b,x)=>tn(b,o,x,f^4?s:_.set):(b,x)=>b[n]=x)),a=(0,r[y])(f?f<4?h?s:_[g]:f>4?void 0:{get:_.get,set:_.set}:o,u),d._=1,f^4||a===void 0?$e(a)&&(f>4?m.unshift(a):f?h?s=a:_[g]=a:o=a):typeof a!="object"||a===null?He("Object expected"):($e(i=a.get)&&(_.get=i),$e(i=a.set)&&(_.set=i),$e(i=a.init)&&m.unshift(i));return f||Lr(t,o),_&&we(o,n,_),h?f^4?s:_:o};var Ot=(t,e,n)=>e.has(t)||He("Cannot "+n),Pr=(t,e)=>Object(e)!==e?He('Cannot use the "in" operator on this value'):t.has(e),en=(t,e,n)=>(Ot(t,e,"read from private field"),n?n.call(t):e.get(t));var tn=(t,e,n,r)=>(Ot(t,e,"write to private field"),r?r.call(t,n):e.set(t,n),n),$r=(t,e,n)=>(Ot(t,e,"access private method"),n);var Fe,R,W,Z,ee,K,te,F,L,A,xe,Nt,Hr,St,Fr,qr,kt,dn,cn,ln,Ct,re=V(()=>{"use strict";Fe=Symbol.for("graphrefly/START"),R=Symbol.for("graphrefly/DATA"),W=Symbol.for("graphrefly/DIRTY"),Z=Symbol.for("graphrefly/RESOLVED"),ee=Symbol.for("graphrefly/INVALIDATE"),K=Symbol.for("graphrefly/PAUSE"),te=Symbol.for("graphrefly/RESUME"),F=Symbol.for("graphrefly/TEARDOWN"),L=Symbol.for("graphrefly/COMPLETE"),A=Symbol.for("graphrefly/ERROR"),xe=Object.freeze([W]),Nt=Object.freeze([Z]),Hr=Object.freeze([ee]),St=Object.freeze([Fe]),Fr=Object.freeze([L]),qr=Object.freeze([F]),kt=Object.freeze([xe]),dn=Object.freeze([Nt]),cn=Object.freeze([Hr]),ln=Object.freeze([Fr]),Ct=Object.freeze([qr])});function Re(){return Math.trunc(performance.now()*1e6)}function ae(){return Date.now()*1e6}var je=V(()=>{"use strict"});function En(t,e){let n=new TextEncoder().encode(t.name);if(n.length===0||n.length>255)throw new Error(`encodeEnvelope: codec name "${t.name}" encodes to ${n.length} bytes (must be 1\u2013255)`);let r=t.version;if(!Number.isInteger(r)||r<0||r>65535)throw new Error(`encodeEnvelope: codec.version ${r} out of u16 range (expected integer 0\u201365535)`);let o=2+n.length+2+e.length;if(o>4294967295)throw new Error(`encodeEnvelope: total envelope size ${o} exceeds 2^32-1 bytes (payload ${e.length} bytes)`);let s=new Uint8Array(o),i=0;return s[i++]=Mt,s[i++]=n.length,s.set(n,i),i+=n.length,s[i++]=r>>>8&255,s[i++]=r&255,s.set(e,i),s}function On(t,e){if(t.length<Tn)throw new Error(`decodeEnvelope: bytes too short (${t.length} < ${Tn})`);let n=0,r=t[n++];if(r!==Mt)throw new Error(`decodeEnvelope: unsupported envelope version ${r} (expected ${Mt})`);let o=t[n++];if(o===0)throw new Error("decodeEnvelope: name_len must be >= 1");if(n+o+2>t.length)throw new Error(`decodeEnvelope: envelope truncated (need ${n+o+2} bytes, have ${t.length})`);let s=new TextDecoder().decode(t.subarray(n,n+o));n+=o;let i=(t[n]<<8|t[n+1])>>>0;n+=2;let a=t.subarray(n),d=e.lookupCodec(s);if(d==null)throw new Error(`decodeEnvelope: codec "${s}" not registered (envelope codec_v=${i})`);return{codec:d,codecVersion:i,payload:a}}function Nn(t){t.registerCodec(jr)}var jr,Mt,Tn,Dt=V(()=>{"use strict";jr={name:"json",version:1,contentType:"application/json",encode(t){let e=JSON.stringify(t);return new TextEncoder().encode(e)},decode(t,e){let n=new TextDecoder().decode(t);return JSON.parse(n)}},Mt=1,Tn=4});function he(t){if(t==null)return ue;let{type:e,id:n,...r}=t;return{type:e??"system",id:n??"",...r}}var ue,Be=V(()=>{"use strict";ue={type:"system",id:""}});function et(){return Me>0||Ve}function Sn(){return Me>0}function ze(t){Me>0?We.push(t):t()}function Ae(t){Me+=1;let e=!1;try{t()}catch(n){throw e=!0,n}finally{if(Me-=1,Me===0)if(e){if(!Ve){let n=We.splice(0);for(let r of n)try{r()}catch{}ge.length=0,me.length=0,De.length=0}}else Br()}}function Br(){let t=!Ve;t&&(Ve=!0);let e=[],n=0;try{for(;ge.length>0||me.length>0||De.length>0||t&&We.length>0;){if(t&&We.length>0){let s=We.splice(0);for(let i of s)try{i()}catch(a){e.push(a)}continue}if(n+=1,n>1e3)throw ge.length=0,me.length=0,De.length=0,new Error("batch drain exceeded 1000 iterations \u2014 likely a reactive cycle");let o=(ge.length>0?ge:me.length>0?me:De).splice(0);for(let s of o)try{s()}catch(i){e.push(i)}}}finally{t&&(Ve=!1)}if(e.length===1)throw e[0];if(e.length>1)throw new AggregateError(e,"batch drain: multiple callbacks threw")}function tt(t,e,n){if(e.length===0)return;if(e.length===1){let u=n(e[0][0]);if(u<3||!et()){t(e);return}(u>=5?De:u===4?me:ge).push(()=>t(e));return}let r=e.length,o=r,s=r,i=r,a=0;for(;a<r&&n(e[a][0])<3;)a++;for(o=a;a<r&&n(e[a][0])===3;)a++;for(s=a;a<r&&n(e[a][0])===4;)a++;i=a;let d=et();if(o>0){let u=e.slice(0,o);t(u)}if(s>o){let u=e.slice(o,s);d?ge.push(()=>t(u)):t(u)}if(i>s){let u=e.slice(s,i);d?me.push(()=>t(u)):t(u)}if(r>i){let u=e.slice(i,r);d?De.push(()=>t(u)):t(u)}}var Me,Ve,ge,me,De,We,Ue=V(()=>{"use strict";Me=0,Ve=!1,ge=[],me=[],De=[],We=[]});function kn(t){t.registerMessageType(Fe,{tier:0,wireCrossing:!1}),t.registerMessageType(W,{tier:1,wireCrossing:!1}),t.registerMessageType(ee,{tier:1,wireCrossing:!1,metaPassthrough:!1}),t.registerMessageType(K,{tier:2,wireCrossing:!1}),t.registerMessageType(te,{tier:2,wireCrossing:!1}),t.registerMessageType(R,{tier:3,wireCrossing:!0}),t.registerMessageType(Z,{tier:3,wireCrossing:!0}),t.registerMessageType(L,{tier:4,wireCrossing:!0,metaPassthrough:!1}),t.registerMessageType(A,{tier:4,wireCrossing:!0,metaPassthrough:!1}),t.registerMessageType(F,{tier:5,wireCrossing:!0,metaPassthrough:!1})}var nt,Cn=V(()=>{"use strict";re();nt=class{_messageTypes=new Map;_codecs=new Map;_onMessage;_onSubscribe;_defaultVersioning;_defaultHashFn;_inspectorEnabled=!(typeof process<"u"&&process.env?.NODE_ENV==="production");_globalInspector;_frozen=!1;tierOf;constructor(e){this._onMessage=e.onMessage,this._onSubscribe=e.onSubscribe,this._defaultVersioning=e.defaultVersioning,this._defaultHashFn=e.defaultHashFn,this.tierOf=n=>{let r=this._messageTypes.get(n);return r!=null?r.tier:1}}get onMessage(){return this._frozen=!0,this._onMessage}get onSubscribe(){return this._frozen=!0,this._onSubscribe}set onMessage(e){this._assertUnfrozen(),this._onMessage=e}set onSubscribe(e){this._assertUnfrozen(),this._onSubscribe=e}get defaultVersioning(){return this._defaultVersioning}set defaultVersioning(e){this._assertUnfrozen(),this._defaultVersioning=e}get defaultHashFn(){return this._defaultHashFn}set defaultHashFn(e){this._assertUnfrozen(),this._defaultHashFn=e}get inspectorEnabled(){return this._inspectorEnabled}set inspectorEnabled(e){this._inspectorEnabled=e}get globalInspector(){return this._globalInspector}set globalInspector(e){this._globalInspector=e}registerMessageType(e,n){return this._assertUnfrozen(),this._messageTypes.set(e,{tier:n.tier,wireCrossing:n.wireCrossing??n.tier>=3,metaPassthrough:n.metaPassthrough??!0}),this}messageTier(e){let n=this._messageTypes.get(e);return n!=null?n.tier:1}isWireCrossing(e){let n=this._messageTypes.get(e);return n!=null?n.wireCrossing:!0}isLocalOnly(e){return!this.isWireCrossing(e)}isMetaPassthrough(e){let n=this._messageTypes.get(e);return n!=null?n.metaPassthrough:!0}isKnownMessageType(e){return this._messageTypes.has(e)}registerCodec(e){return this._assertUnfrozen(),this._codecs.set(e.name,e),this}lookupCodec(e){return this._codecs.get(e)}_isFrozen(){return this._frozen}_assertUnfrozen(){if(this._frozen)throw new Error("GraphReFlyConfig is frozen: a node has already captured this config. Register custom types and set hooks before creating any node.")}}});function Rn(t){return Array.isArray(t)?[...t]:[t]}function Vr(t,e){return t.has(e)||t.has("*")}function rt(t){let e=[];return t((o,s)=>{e.push({kind:"allow",actions:new Set(Rn(o)),where:s?.where??(()=>!0)})},(o,s)=>{e.push({kind:"deny",actions:new Set(Rn(o)),where:s?.where??(()=>!0)})}),(o,s)=>{let i=!1,a=!1;for(let d of e)Vr(d.actions,s)&&d.where(o)&&(d.kind==="deny"?i=!0:a=!0);return i?!1:a}}function At(t){let e=Wr.filter(n=>t({type:n,id:""},"write"));return e.length===0?"restricted":e.includes("human")&&e.includes("llm")&&e.every(n=>n==="human"||n==="llm"||n==="system")?"both":e.length===1?e[0]:e.join("+")}var J,Wr,Ge=V(()=>{"use strict";J=class extends Error{actor;action;nodeName;constructor(e,n){super(n??`GuardDenied: action "${String(e.action)}" denied for actor type "${String(e.actor.type)}"`),this.name="GuardDenied",this.actor=e.actor,this.action=e.action,this.nodeName=e.nodeName}get node(){return this.nodeName}};Wr=["human","llm","wallet","system"]});function Gt(t){if(t===void 0)return null;if(typeof t=="number"){if(!Number.isFinite(t))throw new TypeError(`Cannot hash non-finite number: ${t}`);if(Number.isInteger(t)&&!Number.isSafeInteger(t))throw new TypeError(`Cannot hash integer outside safe range (|n| > 2^53-1): ${t}. Cross-language cid parity is not guaranteed for unsafe integers.`);return t}if(typeof t=="string"||typeof t=="boolean"||t===null)return t;if(Array.isArray(t))return t.map(Gt);if(typeof t=="object"&&t!==null){let e={};for(let n of Object.keys(t).sort())e[n]=Gt(t[n]);return e}return null}function Kr(t){let e=Ur.encode(t),n=e.length,r=n*8,o=n+9+63&-64,s=new Uint8Array(o);s.set(e),s[n]=128;let i=new DataView(s.buffer);i.setUint32(o-4,r>>>0,!1),i.setUint32(o-8,Math.floor(r/4294967296)>>>0,!1);let a=1779033703,d=3144134277,u=1013904242,l=2773480762,f=1359893119,p=2600822924,h=528734635,c=1541459225,g=new Uint32Array(64),m=(_,y)=>_>>>y|_<<32-y;for(let _=0;_<o;_+=64){for(let S=0;S<16;S++)g[S]=i.getUint32(_+S*4,!1);for(let S=16;S<64;S++){let C=g[S-15],k=g[S-2],$=m(C,7)^m(C,18)^C>>>3,B=m(k,17)^m(k,19)^k>>>10;g[S]=g[S-16]+$+g[S-7]+B>>>0}let y=a,b=d,x=u,T=l,w=f,E=p,N=h,M=c;for(let S=0;S<64;S++){let C=m(w,6)^m(w,11)^m(w,25),k=w&E^~w&N,$=M+C+k+zr[S]+g[S]>>>0,B=m(y,2)^m(y,13)^m(y,22),X=y&b^y&x^b&x,fe=B+X>>>0;M=N,N=E,E=w,w=T+$>>>0,T=x,x=b,b=y,y=$+fe>>>0}a=a+y>>>0,d=d+b>>>0,u=u+x>>>0,l=l+T>>>0,f=f+w>>>0,p=p+E>>>0,h=h+N>>>0,c=c+M>>>0}let v=_=>_.toString(16).padStart(8,"0");return v(a)+v(d)+v(u)+v(l)+v(f)+v(p)+v(h)+v(c)}function It(t){let e=Gt(t??null),n=JSON.stringify(e);return Kr(n).slice(0,16)}function Yr(){let t=globalThis.crypto;if(t?.randomUUID)return t.randomUUID();let e=()=>Math.floor(Math.random()*4294967296).toString(16).padStart(8,"0"),n=e()+e()+e()+e();return`${n.slice(0,8)}-${n.slice(8,12)}-4${n.slice(13,16)}-${(parseInt(n.slice(16,17),16)&3|8).toString(16)}${n.slice(17,20)}-${n.slice(20,32)}`}function Lt(t,e,n){let r=n?.id??Yr();if(t===0)return{id:r,version:0};let s=(n?.hash??It)(e);return{id:r,version:0,cid:s,prev:null}}function Mn(t,e,n){t.version+=1,"cid"in t&&(t.prev=t.cid,t.cid=n(e))}var zr,Ur,Dn=V(()=>{"use strict";zr=new Uint32Array([1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298]),Ur=new TextEncoder});function In(t){return{node:t,unsub:null,prevData:void 0,dirty:!1,involvedThisWave:!1,dataBatch:[],terminal:void 0}}function Pt(t){t.prevData=void 0,t.dirty=!1,t.involvedThisWave=!1,t.dataBatch.length=0,t.terminal=void 0}function ot(t){return t.length===0?t:typeof t[0]=="symbol"?[t]:t}function be(t,e,n){let r=Ln(t)?t:[],o=typeof t=="function"?t:typeof e=="function"?e:void 0,s={};return Ln(t)?s=($t(e)?e:n)??{}:$t(t)?s=t:s=($t(e)?e:n)??{},new P(r,o,s)}var An,Gn,Jr,Qr,ye,P,Ln,$t,Ie=V(()=>{"use strict";Dt();Be();Ue();je();Cn();Ge();re();Dn();An=()=>{},Gn=100;Jr=(t,e,n,r)=>{n.direction==="down-in"&&t._onDepMessage(n.depIndex,e)},Qr=(t,e,n,r)=>{let o=t;if(o._status==="completed"||o._status==="errored")return;let s=o._cached,i=s===void 0?[St]:[St,[R,s]];o._status==="dirty"&&i.push(xe),tt(e,i,o._config.tierOf)},ye=new nt({onMessage:Jr,onSubscribe:Qr});kn(ye);Nn(ye);P=class t{_optsName;_describeKind;meta;_hasMeta;_config;_deps;_sinks=null;_sinkCount=0;_cached;_status;_cleanup;_store={};_waveHasNewData=!1;_hasNewTerminal=!1;_hasCalledFnOnce=!1;_paused=!1;_pendingWave=!1;_isExecutingFn=!1;_pendingRerun=!1;_rerunDepth=0;_dirtyDepCount=0;_batchPendingMessages=null;_pauseLocks=null;_pauseBuffer=null;_fn;_equals;_resubscribable;_resetOnTeardown;_autoComplete;_autoError;_pausable;_partial;_guard;_extraGuards;_hashFn;_versioning;_versioningLevel;_lastMutation;_inspectorHooks;_actions;constructor(e,n,r){this._config=r.config??ye,this._config.onMessage,this._optsName=r.name,this._describeKind=r.describeKind,this._equals=r.equals??Object.is,this._resubscribable=r.resubscribable??!1,this._resetOnTeardown=r.resetOnTeardown??!1,this._autoComplete=r.completeWhenDepsComplete??!0,this._autoError=r.errorWhenDepsError??!0,this._pausable=r.pausable??!0,this._guard=r.guard,this._fn=n,this._partial=r.partial??!1,this._cached=r.initial!==void 0?r.initial:void 0,this._status=e.length===0&&n==null&&this._cached!==void 0?"settled":"sentinel",this._hashFn=r.versioningHash??this._config.defaultHashFn??It;let o=r.versioning??this._config.defaultVersioning;this._versioningLevel=o,this._versioning=o!=null?Lt(o,this._cached===void 0?void 0:this._cached,{id:r.versioningId,hash:this._hashFn}):void 0,this._deps=e.map(In);let s={};for(let[a,d]of Object.entries(r.meta??{})){let u={initial:d,name:`${r.name??"node"}:meta:${a}`,describeKind:"state",config:this._config};r.guard!=null&&(u.guard=r.guard),s[a]=new t([],void 0,u)}Object.freeze(s),this.meta=s,this._hasMeta=Object.keys(s).length>0;let i=this;this._actions={emit(a){i._emit([[R,a]])},down(a){i._emit(ot(a))},up(a){i._emitUp(ot(a))}},this.down=this.down.bind(this),this.up=this.up.bind(this)}get _isTerminal(){return this._status==="completed"||this._status==="errored"}get name(){return this._optsName}get status(){return this._status}get cache(){return this._cached===void 0?void 0:this._cached}get lastMutation(){return this._lastMutation}get v(){return this._versioning}hasGuard(){return this._guard!=null}_applyVersioning(e,n){if(this._isExecutingFn)throw new Error(`Node "${this.name}": _applyVersioning cannot run mid-fn \u2014 call it outside of \`_execFn\` (typically at graph setup time before the first subscribe).`);let r=this._versioningLevel;if(r!=null&&e<=r)return;let o=n?.hash??this._hashFn;o!==this._hashFn&&(this._hashFn=o);let s=this._cached===void 0?void 0:this._cached,i=this._versioning,a=i?.id??n?.id,d=i?.version??0,u=Lt(e,s,{id:a,hash:o});u.version=d,this._versioning=u,this._versioningLevel=e}_setInspectorHook(e){return e==null?()=>{}:(this._inspectorHooks==null&&(this._inspectorHooks=new Set),this._inspectorHooks.add(e),()=>{this._inspectorHooks?.delete(e),this._inspectorHooks?.size===0&&(this._inspectorHooks=void 0)})}_pushGuard(e){return this._extraGuards==null&&(this._extraGuards=new Set),this._extraGuards.add(e),()=>{this._extraGuards?.delete(e),this._extraGuards?.size===0&&(this._extraGuards=void 0)}}allowsObserve(e){if(this._guard==null&&this._extraGuards==null)return!0;let n=he(e);if(this._guard!=null&&!this._guard(n,"observe"))return!1;if(this._extraGuards!=null){for(let r of this._extraGuards)if(!r(n,"observe"))return!1}return!0}_checkGuard(e){if(e?.internal)return;let n=this._guard!=null||this._extraGuards!=null,r=e?.actor!=null;if(!n&&!r)return;let o=he(e?.actor),s=e?.delivery==="signal"?"signal":"write";if(this._guard!=null&&!this._guard(o,s))throw new J({actor:o,action:s,nodeName:this.name});if(this._extraGuards!=null){for(let i of this._extraGuards)if(!i(o,s))throw new J({actor:o,action:s,nodeName:this.name})}this._lastMutation={actor:o,timestamp_ns:ae()}}down(e,n){let r=ot(e);r.length!==0&&(this._checkGuard(n),this._emit(r))}emit(e,n){this._checkGuard(n),this._emit([[R,e]])}up(e,n){if(this._deps.length===0)return;let r=ot(e);if(r.length===0)return;this._checkGuard(n);let o=n??{internal:!0};this._validateUpTiers(r);for(let s of this._deps)s.node.up?.(r,o)}_emitUp(e){if(this._deps.length!==0&&e.length!==0){this._validateUpTiers(e);for(let n of this._deps)n.node.up?.(e,{internal:!0})}}_validateUpTiers(e){let n=this._config.tierOf;for(let r of e){let o=n(r[0]);if(o===3||o===4)throw new Error(`Node "${this.name}": tier-${o} messages cannot flow up \u2014 DATA/RESOLVED/COMPLETE/ERROR are downstream-only. Use \`down(...)\` for value delivery; \`up(...)\` is for control signals (DIRTY, INVALIDATE, PAUSE, RESUME, TEARDOWN).`)}}subscribe(e,n){if(n!=null&&this._guard!=null){let d=he(n);if(!this._guard(d,"observe"))throw new J({actor:d,action:"observe",nodeName:this.name})}let o=this._isTerminal&&this._resubscribable;if(o){this._cached=void 0,this._status="sentinel",this._store={},this._hasCalledFnOnce=!1,this._waveHasNewData=!1,this._hasNewTerminal=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._isExecutingFn=!1,this._rerunDepth=0,this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null;for(let d of this._deps)Pt(d);if(this._partial===!1){for(let d of this._deps)if(d.prevData!==void 0||d.dataBatch.length!==0||d.terminal!==void 0||d.dirty)throw new Error(`resubscribable-reset invariant: DepRecord not fully reset for node ${this._optsName??"(anonymous)"}`)}}this._sinkCount+=1;let s;try{s=this._config.onSubscribe(this,e,{sinkCount:this._sinkCount,afterTerminalReset:o},this._actions)}catch(d){throw this._sinkCount-=1,d}this._sinks==null?this._sinks=e:typeof this._sinks=="function"?this._sinks=new Set([this._sinks,e]):this._sinks.add(e);let i=this._isTerminal;if(this._sinkCount===1&&!i)try{this._activate()}catch(d){if(this._sinkCount-=1,this._removeSink(e),this._sinkCount===0&&(this._status="sentinel"),typeof s=="function")try{s()}catch{}throw d}this._status==="sentinel"&&this._cached===void 0&&(this._status="pending");let a=!1;return()=>{a||(a=!0,this._sinkCount-=1,this._removeSink(e),typeof s=="function"&&s(),this._sinks==null&&this._deactivate())}}_removeSink(e){if(this._sinks===e)this._sinks=null;else if(this._sinks!=null&&typeof this._sinks!="function")if(this._sinks.delete(e),this._sinks.size===1){let[n]=this._sinks;this._sinks=n}else this._sinks.size===0&&(this._sinks=null)}_activate(){if(this._deps.length===0){this._fn&&this._execFn();return}this._dirtyDepCount=0;let e=this._deps.length,n=0;try{for(let r=0;r<e;r++){let o=r,s=this._deps[r];s.unsub=An,s.unsub=s.node.subscribe(i=>{if(s.unsub===null)return;let a=this._config.tierOf,d=!1;for(let u of i)a(u[0])>=3&&(d=!0),this._config.onMessage(this,u,{direction:"down-in",depIndex:o},this._actions);d&&this._maybeRunFnOnSettlement()}),n++}}catch(r){this._deps[n].unsub=null;for(let o=0;o<n;o++){let s=this._deps[o];if(s.unsub!=null){let i=s.unsub;s.unsub=null;try{i()}catch{}Pt(s)}}throw this._dirtyDepCount=0,r}}_addDep(e){for(let o=0;o<this._deps.length;o++)if(this._deps[o].node===e)return o;let n=this._deps.length,r=In(e);if(this._deps.push(r),this._sinks==null)return n;r.dirty=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(kt),r.unsub=An;try{r.unsub=e.subscribe(o=>{if(r.unsub===null)return;let s=this._config.tierOf,i=!1;for(let a of o)s(a[0])>=3&&(i=!0),this._config.onMessage(this,a,{direction:"down-in",depIndex:n},this._actions);i&&this._maybeRunFnOnSettlement()})}catch(o){throw r.unsub=null,this._deps.pop(),this._dirtyDepCount--,o}return n}_deactivate(e=!1){let n=this._cleanup;if(this._cleanup=void 0,typeof n=="function")try{n()}catch(r){this._emit([[A,this._wrapFnError("cleanup threw",r)]])}else if(n!=null&&typeof n=="object"){let r=n.deactivate;if(typeof r=="function")try{r()}catch(o){this._emit([[A,this._wrapFnError("cleanup.deactivate threw",o)]])}}for(let r of this._deps){if(r.unsub!=null){let o=r.unsub;r.unsub=null;try{o()}catch{}}Pt(r)}this._waveHasNewData=!1,this._hasNewTerminal=!1,this._hasCalledFnOnce=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._rerunDepth=0,this._store={},this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null,this._fn!=null&&(this._cached=void 0),e||(this._fn!=null||this._deps.length>0)&&(!this._isTerminal||this._resubscribable)&&(this._status="sentinel")}_onDepMessage(e,n){let r=this._deps[e],o=n[0];if(this._inspectorHooks!=null){let s={kind:"dep_message",depIndex:e,message:n};for(let i of this._inspectorHooks)i(s)}if(o!==Fe){if(o===W){this._depDirtied(r);return}if(o===ee){if(this._depInvalidated(r),this._cached===void 0)return;this._emit(cn);return}if(o===K||o===te){this._emit([n]);return}if(o===F){this._emit(Ct);return}if(o===R)this._depSettledAsData(r,n[1]);else if(o===Z)this._depSettledAsResolved(r);else if(o===L)this._depSettledAsTerminal(r,!0);else if(o===A)this._depSettledAsTerminal(r,n[1]);else{this._emit([n]);return}if(!this._fn){(o===R||o===Z)&&this._emit([n]),(o===L||o===A)&&this._maybeAutoTerminalAfterWave();return}}}_depDirtied(e){e.dirty||(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(kt))}_depSettledAsData(e,n){e.dirty&&(e.dirty=!1,this._dirtyDepCount--),e.involvedThisWave=!0,e.dataBatch.push(n),this._waveHasNewData=!0}_depSettledAsResolved(e){e.dirty&&(e.dirty=!1,this._dirtyDepCount--)}_depSettledAsTerminal(e,n){e.dirty&&(e.dirty=!1,this._dirtyDepCount--),e.terminal=n,e.involvedThisWave=!0,this._hasNewTerminal=!0}_depInvalidated(e){e.prevData=void 0,e.terminal=void 0,e.dataBatch.length=0,e.dirty?e.involvedThisWave=!1:(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++)}_maybeRunFnOnSettlement(){if(!(this._isTerminal&&!this._resubscribable)&&!(this._dirtyDepCount>0)){if(!this._partial&&!this._hasCalledFnOnce)for(let e=0;e<this._deps.length;e++){let n=this._deps[e];if(n.dataBatch.length===0&&n.prevData===void 0&&n.terminal===void 0){this._maybeAutoTerminalAfterWave();return}}if(this._paused){this._pendingWave=!0;return}if(!this._waveHasNewData&&!this._hasNewTerminal&&this._hasCalledFnOnce){this._clearWaveFlags(),this._emit(dn),this._maybeAutoTerminalAfterWave();return}this._fn&&this._execFn(),this._maybeAutoTerminalAfterWave()}}_maybeAutoTerminalAfterWave(){if(this._deps.length===0||this._isTerminal)return;let e=this._deps.find(n=>n.terminal!==void 0&&n.terminal!==!0);if(e!=null){this._autoError&&this._emit([[A,e.terminal]]);return}this._autoComplete&&this._deps.every(n=>n.terminal!==void 0)&&this._emit(ln)}_execFn(){if(!this._fn||this._isTerminal&&!this._resubscribable)return;if(this._isExecutingFn){this._pendingRerun=!0;return}let e=this._cleanup;if(typeof e=="function"){this._cleanup=void 0;try{e()}catch(i){this._emit([[A,this._wrapFnError("cleanup threw",i)]]);return}}else if(e!=null&&typeof e=="object"){let i=e.beforeRun;if(typeof i=="function"){e.beforeRun=void 0;try{i()}catch(a){this._emit([[A,this._wrapFnError("cleanup.beforeRun threw",a)]]);return}}}let n=this._deps.map(i=>i.involvedThisWave?i.dataBatch.length>0?[...i.dataBatch]:[]:void 0),r=this._deps.map(i=>i.prevData);for(let i=0;i<this._deps.length;i++){let a=n[i];a!=null&&a.length>0&&(this._deps[i].prevData=a[a.length-1])}let o=this._deps.map(i=>i.terminal),s={prevData:r,terminalDeps:o,store:this._store};if(this._hasCalledFnOnce=!0,this._clearWaveFlags(),this._inspectorHooks!=null){let i={kind:"run",batchData:n,prevData:r};for(let a of this._inspectorHooks)a(i)}this._isExecutingFn=!0;try{let i=this._fn(n,this._actions,s);if(typeof i=="function")this._cleanup=i;else if(i!=null&&typeof i=="object"){let a=i;(typeof a.beforeRun=="function"||typeof a.deactivate=="function"||typeof a.invalidate=="function")&&(this._cleanup=i)}}catch(i){this._emit([[A,this._wrapFnError("fn threw",i)]])}finally{this._isExecutingFn=!1,this._pendingRerun?(this._pendingRerun=!1,this._rerunDepth+=1,this._rerunDepth>Gn?(this._rerunDepth=0,this._emit([[A,new Error(`Node "${this.name}": _pendingRerun depth exceeded ${Gn} \u2014 likely a reactive cycle`)]])):this._maybeRunFnOnSettlement()):this._rerunDepth=0,this._clearWaveFlags()}}_clearWaveFlags(){this._waveHasNewData=!1,this._hasNewTerminal=!1;for(let e of this._deps)e.involvedThisWave=!1,e.dataBatch.length=0}_wrapFnError(e,n){let r=n instanceof Error?n.message:String(n);return new Error(`Node "${this.name}": ${e}: ${r}`,{cause:n})}_frameBatch(e){let n=this._config.tierOf;if(e.length===1)return n(e[0][0])===3&&this._status!=="dirty"?[xe,e[0]]:e;let r=!0,o=!1,s=!1,i=-1;for(let d of e){let u=n(d[0]);u<i&&(r=!1),u===3&&(o=!0),d[0]===W&&(s=!0),i=u}let a=e;if(!r){let d=e.map((u,l)=>({m:u,i:l,tier:n(u[0])}));d.sort((u,l)=>u.tier-l.tier||u.i-l.i),a=d.map(u=>u.m)}if(o&&!s&&this._status!=="dirty"){let d=0;for(;d<a.length&&n(a[d][0])===0;)d++;return d===0?[xe,...a]:[...a.slice(0,d),xe,...a.slice(d)]}return a}_emit(e){if(e.length===0)return;for(let a=0;a<e.length;a++){let d=e[a];if(d[0]===A&&d[1]===void 0)throw new TypeError('[ERROR, payload] requires a non-undefined payload (spec \xA71.2). Pass an Error object or domain tag instead \u2014 e.g. node.down([[ERROR, new Error("reason")]])')}let n=e;if(this._isTerminal&&!this._resubscribable){let a=e.filter(d=>d[0]===F||d[0]===ee);if(a.length===0)return;n=a}n=this._frameBatch(n);let o=null;for(let a=0;a<n.length;a++){let d=n[a],u=d[0];if(u!==K&&u!==te){o?.push(d);continue}if(d.length<2)throw new Error(`Node "${this.name}": [[${u===K?"PAUSE":"RESUME"}]] must carry a lockId payload \u2014 bare PAUSE/RESUME is a protocol violation (C0 rule). Use \`[[PAUSE, lockId]]\` / \`[[RESUME, lockId]]\`.`);let l=!0;if(this._pausable!==!1){let f=d[1];if(u===K)this._pauseLocks==null&&(this._pauseLocks=new Set),this._pauseLocks.add(f),this._paused=!0,this._pausable==="resumeAll"&&this._pauseBuffer==null&&(this._pauseBuffer=[]);else if(this._pauseLocks==null||!this._pauseLocks.has(f))l=!1;else if(this._pauseLocks.delete(f),this._pauseLocks.size===0){if(this._paused=!1,this._pauseBuffer!=null&&this._pauseBuffer.length>0){let p=this._pauseBuffer;this._pauseBuffer=[],this._emit(p)}this._pendingWave&&(this._pendingWave=!1,this._maybeRunFnOnSettlement())}}l?o?.push(d):o==null&&(o=n.slice(0,a))}if(o!=null){if(o.length===0)return;n=o}if(this._hasMeta&&n.some(a=>a[0]===F))for(let a of Object.keys(this.meta))try{this.meta[a]._emit(Ct)}catch{}let{finalMessages:s,equalsError:i}=this._updateState(n);if(s.length>0&&this._config.inspectorEnabled){let a=this._config.globalInspector;if(a!=null)try{a({kind:"emit",node:this,messages:s})}catch{}}if(s.length>0)if(this._paused&&this._pausable==="resumeAll"&&this._pauseBuffer!=null){let a=this._config.tierOf,d=[];for(let u of s)a(u[0])===3?this._pauseBuffer.push(u):d.push(u);d.length>0&&this._dispatchOrAccumulate(d)}else this._dispatchOrAccumulate(s);i!=null&&this._emit([[A,i]])}_updateState(e){let n=this._config.tierOf,r,o,s=-1,i=0;for(let l of e)n(l[0])===3&&i++;let a=i<=1,d=-1;if(this._versioning!=null&&i>1){for(let l=e.length-1;l>=0;l--)if(e[l][0]===R){d=l;break}}for(let l=0;l<e.length;l++){let f=e[l],p=f[0];if(p===R){if(f.length>=2){let h=!1;if(a&&this._cached!==void 0)try{h=this._equals(this._cached,f[1])}catch(c){o=this._wrapFnError("equals threw",c),s=l;break}if(h){r==null&&(r=e.slice(0,l)),r.push(Nt),this._status="resolved";continue}this._cached=f[1],this._versioning!=null&&(d<0||l===d)&&Mn(this._versioning,f[1],this._hashFn)}this._status="settled",r?.push(f)}else if(r?.push(f),p===W)this._status="dirty";else if(p===Z)this._status="resolved";else if(p===L)this._status="completed";else if(p===A)this._status="errored";else if(p===ee){this._cached=void 0,this._status="dirty";let h=this._cleanup;if(typeof h=="function"){this._cleanup=void 0;try{h()}catch{}}else if(h!=null&&typeof h=="object"){let c=h.invalidate;if(typeof c=="function")try{c()}catch{}}}else p===F&&(this._resetOnTeardown&&(this._cached=void 0),this._deactivate(!0),this._status="sentinel")}let u=s>=0?r??e.slice(0,s):r??e;return o!=null?{finalMessages:u,equalsError:o}:{finalMessages:u}}_deliverToSinks=e=>{if(this._sinks==null)return;if(typeof this._sinks=="function"){this._sinks(e);return}let n=[...this._sinks];for(let r of n)r(e)};_dispatchOrAccumulate(e){if(Sn()){this._batchPendingMessages===null&&(this._batchPendingMessages=[],ze(()=>this._flushBatchPending()));for(let n of e)this._batchPendingMessages.push(n);return}tt(this._deliverToSinks,e,this._config.tierOf)}_flushBatchPending(){let e=this._batchPendingMessages;if(e===null||(this._batchPendingMessages=null,e.length===0))return;let n=this._frameBatch(e);tt(this._deliverToSinks,n,this._config.tierOf)}},Ln=t=>Array.isArray(t),$t=t=>typeof t=="object"&&t!=null&&!Array.isArray(t)});function oe(t,e){return be([],{...e,initial:t})}function Le(t,e){return be((r,o,s)=>t(o,s)??void 0,{describeKind:"producer",...e})}function se(t,e,n){return be(t,(o,s,i)=>{let a=o.map((d,u)=>d!=null&&d.length>0?d.at(-1):i.prevData[u]);s.emit(e(a,i))},{describeKind:"derived",...n})}var Ke=V(()=>{"use strict";Ie()});function Ye(t,e,n){let r=new Set;for(let o of t.split(",")){let[s,i]=o.split("/"),a=i?Number.parseInt(i,10):1;if(Number.isNaN(a)||a<1)throw new Error(`Invalid cron step: ${o}`);let d,u;if(s==="*")d=e,u=n;else if(s.includes("-")){let[l,f]=s.split("-");d=Number.parseInt(l,10),u=Number.parseInt(f,10)}else d=Number.parseInt(s,10),u=d;if(Number.isNaN(d)||Number.isNaN(u))throw new Error(`Invalid cron field: ${t}`);if(d<e||u>n)throw new Error(`Cron field out of range: ${t} (${e}-${n})`);if(d>u)throw new Error(`Invalid cron range: ${d}-${u} in ${t}`);for(let l=d;l<=u;l+=a)r.add(l)}return r}function Pn(t){let e=t.trim().split(/\s+/);if(e.length!==5)throw new Error(`Invalid cron: expected 5 fields, got ${e.length}`);return{minutes:Ye(e[0],0,59),hours:Ye(e[1],0,23),daysOfMonth:Ye(e[2],1,31),months:Ye(e[3],1,12),daysOfWeek:Ye(e[4],0,6)}}function $n(t,e){return t.minutes.has(e.getMinutes())&&t.hours.has(e.getHours())&&t.daysOfMonth.has(e.getDate())&&t.months.has(e.getMonth()+1)&&t.daysOfWeek.has(e.getDay())}var Hn=V(()=>{"use strict"});function Fn(t){return{describeKind:"producer",...t}}function qn(t,e){let{signal:n,period:r,...o}=e??{};return Le(s=>{let i=!1,a=0,d,u,l=()=>{i=!0,d!==void 0&&clearTimeout(d),u!==void 0&&clearInterval(u),n?.removeEventListener("abort",p)},f=()=>{i||(r!=null?(s.emit(a++),u=setInterval(()=>{i||s.emit(a++)},r)):(i=!0,n?.removeEventListener("abort",p),s.emit(a++),s.down([[L]])))},p=()=>{i||(l(),s.down([[A,n.reason]]))};if(n?.aborted){p();return}return d=setTimeout(f,t),n?.addEventListener("abort",p,{once:!0}),l},Fn(o))}function jn(t,e){let n=Pn(t),{tickMs:r,output:o,...s}=e??{},i=r??6e4,a=o==="date";return Le(d=>{let u=-1,l=()=>{let p=new Date,h=p.getFullYear()*1e8+(p.getMonth()+1)*1e6+p.getDate()*1e4+p.getHours()*100+p.getMinutes();h!==u&&$n(n,p)&&(u=h,d.emit(a?p:ae()))};l();let f=setInterval(l,i);return()=>clearInterval(f)},{...Fn(s),name:s.name??`cron:${t}`})}function de(t){return t.subscribe(()=>{})}var st=V(()=>{"use strict";je();re();Ke();Hn()});var ct,Yn=V(()=>{"use strict";ct=class{_timer;_gen=0;start(e,n){this.cancel(),this._gen+=1;let r=this._gen;this._timer=setTimeout(()=>{this._timer=void 0,r===this._gen&&n()},e)}cancel(){this._timer!==void 0&&(clearTimeout(this._timer),this._timer=void 0)}get pending(){return this._timer!==void 0}}});var ts={};Dr(ts,{ACTOR_KEY:()=>ut,COMMAND_HANDLERS:()=>Ne,CQRS_EVENT_HANDLERS:()=>Se,CRON_HANDLERS:()=>Oe,CommandHandler:()=>vn,EVENT_HANDLERS:()=>Te,EventHandler:()=>_n,GRAPHREFLY_REQUEST_GRAPH:()=>pe,GRAPHREFLY_ROOT_GRAPH:()=>Y,GraphCron:()=>bn,GraphInterval:()=>yn,GraphReflyEventExplorer:()=>ve,GraphReflyGuard:()=>Kn,GraphReflyGuardImpl:()=>Je,GraphReflyModule:()=>_t,INTERVAL_HANDLERS:()=>Ee,InjectCqrsGraph:()=>hn,InjectGraph:()=>pn,InjectNode:()=>gn,ObserveGateway:()=>at,OnGraphEvent:()=>mn,QUERY_HANDLERS:()=>ke,QueryHandler:()=>wn,SAGA_HANDLERS:()=>Ce,SagaHandler:()=>xn,fromHeader:()=>zn,fromJwtPayload:()=>qt,getActor:()=>Un,getGraphToken:()=>j,getNodeToken:()=>ne,observeSSE:()=>Vn,observeSubscription:()=>Wn,toObservable:()=>fn});module.exports=Gr(ts);var Rt=require("rxjs");re();function fn(t,e){return e?.raw?new Rt.Observable(n=>t.subscribe(o=>{if(!n.closed){n.next(o);for(let s of o){if(s[0]===A){n.error(s[1]);return}if(s[0]===L){n.complete();return}}}})):new Rt.Observable(n=>t.subscribe(o=>{for(let s of o){if(n.closed)return;if(s[0]===R)n.next(s[1]);else if(s[0]===A){n.error(s[1]);return}else if(s[0]===L){n.complete();return}}}))}var qe=require("@nestjs/common");var Y=Symbol.for("graphrefly:root-graph");var pe=Symbol.for("graphrefly:request-graph");function j(t){return Symbol.for(`graphrefly:graph:${t}`)}function ne(t){return Symbol.for(`graphrefly:node:${t}`)}var Te=new Map,Ee=new Map,Oe=new Map,Ne=new Map,Se=new Map,ke=new Map,Ce=new Map;function pn(t){return t==="request"?(0,qe.Inject)(pe):(0,qe.Inject)(t?j(t):Y)}function hn(t){return(0,qe.Inject)(j(t))}function gn(t){return(0,qe.Inject)(ne(t))}function mn(t){return(e,n)=>{let r=n.name;n.addInitializer(function(){let o=this.constructor,s=Te.get(o)??[];s.push({nodeName:t,methodKey:r}),Te.set(o,s)})}}function yn(t){return(e,n)=>{let r=n.name;n.addInitializer(function(){let o=this.constructor,s=Ee.get(o)??[];s.push({ms:t,methodKey:r}),Ee.set(o,s)})}}function bn(t){return(e,n)=>{let r=n.name;n.addInitializer(function(){let o=this.constructor,s=Oe.get(o)??[];s.push({expr:t,methodKey:r}),Oe.set(o,s)})}}function vn(t,e){return(n,r)=>{let o=r.name;r.addInitializer(function(){let s=this.constructor,i=Ne.get(s)??[];i.push({cqrsName:t,commandName:e,methodKey:o}),Ne.set(s,i)})}}function _n(t,e){return(n,r)=>{let o=r.name;r.addInitializer(function(){let s=this.constructor,i=Se.get(s)??[];i.push({cqrsName:t,eventName:e,methodKey:o}),Se.set(s,i)})}}function wn(t,e){return(n,r)=>{let o=r.name;r.addInitializer(function(){let s=this.constructor,i=ke.get(s)??[];i.push({cqrsName:t,projectionName:e,methodKey:o}),ke.set(s,i)})}}function xn(t,e,n){return(r,o)=>{let s=o.name;o.addInitializer(function(){let i=this.constructor,a=Ce.get(i)??[];a.push({cqrsName:t,eventNames:n,sagaName:e,methodKey:s}),Ce.set(i,a)})}}re();st();var Bn=0,ve=class{constructor(e,n){this.graph=e;this.moduleRef=n}disposers=[];scheduleNodeNames=[];onModuleInit(){this.wireEvents(),this.wireIntervals(),this.wireCrons(),this.wireCqrsCommands(),this.wireCqrsEvents(),this.wireCqrsQueries(),this.wireCqrsSagas()}onModuleDestroy(){for(let e of this.disposers)e();this.disposers.length=0;for(let e of this.scheduleNodeNames)try{this.graph.remove(e)}catch{}this.scheduleNodeNames.length=0}wireEvents(){for(let[e,n]of Te){let r=this.resolveInstance(e);if(r)for(let o of n)this.wireEventHandler(r,o)}}wireEventHandler(e,n){let r=e[n.methodKey];if(typeof r!="function")return;let o=r.bind(e),i=this.observeNode(n.nodeName).subscribe(a=>{for(let d of a)d[0]===R&&o(d[1])});this.disposers.push(i)}wireIntervals(){for(let[e,n]of Ee){let r=this.resolveInstance(e);if(r)for(let o of n)this.wireIntervalHandler(r,e,o)}}wireIntervalHandler(e,n,r){let o=e[r.methodKey];if(typeof o!="function")return;let s=o.bind(e),a=`__schedule__.${n.name??"anonymous"}.${String(r.methodKey)}.${Bn++}`,d=qn(r.ms,{period:r.ms,name:a});this.graph.add(d),this.scheduleNodeNames.push(a);let l=this.observeNode(a).subscribe(f=>{for(let p of f)p[0]===R&&s(p[1])});this.disposers.push(l)}wireCrons(){for(let[e,n]of Oe){let r=this.resolveInstance(e);if(r)for(let o of n)this.wireCronHandler(r,e,o)}}wireCronHandler(e,n,r){let o=e[r.methodKey];if(typeof o!="function")return;let s=o.bind(e),a=`__schedule__.${n.name??"anonymous"}.${String(r.methodKey)}.${Bn++}`,d=jn(r.expr,{name:a});this.graph.add(d),this.scheduleNodeNames.push(a);let l=this.observeNode(a).subscribe(f=>{for(let p of f)p[0]===R&&s(p[1])});this.disposers.push(l)}wireCqrsCommands(){for(let[e,n]of Ne){let r=this.resolveInstance(e);if(r)for(let o of n)this.wireCqrsCommand(r,o)}}wireCqrsCommand(e,n){let r=e[n.methodKey];if(typeof r!="function")return;let o=r.bind(e),s=this.resolveCqrsGraph(n.cqrsName);s&&s.command(n.commandName,o)}wireCqrsEvents(){for(let[e,n]of Se){let r=this.resolveInstance(e);if(r)for(let o of n)this.wireCqrsEventHandler(r,o)}}wireCqrsEventHandler(e,n){let r=e[n.methodKey];if(typeof r!="function")return;let o=r.bind(e),s=this.resolveCqrsGraph(n.cqrsName);if(!s)return;s.event(n.eventName);let a=s.resolve(n.eventName).cache,d=a&&a.length>0?a[a.length-1].seq:0,l=this.observeNodeOn(s,n.eventName).subscribe(f=>{for(let p of f)if(p[0]===R){let h=p[1];for(let c of h)c.seq>d&&(o(c),d=c.seq)}});this.disposers.push(l)}wireCqrsQueries(){for(let[e,n]of ke){let r=this.resolveInstance(e);if(r)for(let o of n)this.wireCqrsQuery(r,o)}}wireCqrsQuery(e,n){let r=e[n.methodKey];if(typeof r!="function")return;let o=r.bind(e),s=this.resolveCqrsGraph(n.cqrsName);if(!s)return;let a=this.observeNodeOn(s,n.projectionName).subscribe(d=>{for(let u of d)u[0]===R&&o(u[1])});this.disposers.push(a)}wireCqrsSagas(){for(let[e,n]of Ce){let r=this.resolveInstance(e);if(r)for(let o of n)this.wireCqrsSaga(r,o)}}wireCqrsSaga(e,n){let r=e[n.methodKey];if(typeof r!="function")return;let o=r.bind(e),s=this.resolveCqrsGraph(n.cqrsName);s&&s.saga(n.sagaName,n.eventNames,o)}observeNode(e){return this.graph.observe(e)}observeNodeOn(e,n){return e.observe(n)}resolveCqrsGraph(e){try{return this.moduleRef.get(j(e),{strict:!1})}catch{return console.warn(`[GraphReFly] CqrsGraph "${e}" not found in DI \u2014 did you import GraphReflyModule.forCqrs({ name: "${e}" })?`),null}}resolveInstance(e){try{return this.moduleRef.get(e,{strict:!1})}catch{return null}}};re();re();var Xr=0;function it(t,e){if(e.highWaterMark<1)throw new RangeError("highWaterMark must be >= 1");if(e.lowWaterMark<0)throw new RangeError("lowWaterMark must be >= 0");if(e.lowWaterMark>=e.highWaterMark)throw new RangeError("lowWaterMark must be < highWaterMark");let n=Symbol(`bp-${++Xr}`),r=0,o=!1;return{onEnqueue(){return r+=1,!o&&r>=e.highWaterMark?(o=!0,t([[K,n]]),!0):!1},onDequeue(){return r>0&&(r-=1),o&&r<=e.lowWaterMark?(o=!1,t([[te,n]]),!0):!1},get pending(){return r},get paused(){return o},dispose(){o&&(o=!1,t([[te,n]]))}}}function Vn(t,e,n){let{actor:r,serialize:o=Zr,keepAliveMs:s,signal:i}=n??{},a=new TextEncoder,d,u=n?.highWaterMark!=null,l,f,p=[],h=!1;return new ReadableStream({start(c){let g,m=()=>{},v=()=>{if(!h){h=!0,g!==void 0&&clearInterval(g),i?.removeEventListener("abort",_),m(),l?.dispose(),f?.(),f=void 0;for(let b of p)c.enqueue(b.frame);p.length=0,c.close()}};d=v;let _=()=>v(),y=t.observe(e,{actor:r});u&&(l=it(b=>y.up(b),{highWaterMark:n.highWaterMark,lowWaterMark:n.lowWaterMark??Math.floor(n.highWaterMark/2)})),m=y.subscribe(b=>{for(let x of b){if(h)return;let T=x[0];if(T===R){let w=a.encode(Ht("data",o(x[1])));u?(p.push({frame:w,counted:!0}),l.onEnqueue(),f?.(),f=void 0):c.enqueue(w)}else if(T===A){let w=a.encode(Ht("error",o(x[1])));u?(p.push({frame:w,counted:!1}),f?.(),f=void 0):c.enqueue(w),v();return}else if(T===L||T===F){if(T===L){let w=a.encode(Ht("complete"));u?(p.push({frame:w,counted:!1}),f?.(),f=void 0):c.enqueue(w)}v();return}}}),s!==void 0&&s>0&&(g=setInterval(()=>{h||(u?(p.push({frame:a.encode(`: keepalive
|
|
2
2
|
|
|
3
3
|
`),counted:!1}),f?.(),f=void 0):c.enqueue(a.encode(`: keepalive
|
|
4
4
|
|
|
5
|
-
`)))},s)),i?.aborted?_():i?.addEventListener("abort",_,{once:!0})},pull(c){if(u&&!h){if(p.length>0){let g=p.shift();c.enqueue(g.frame),g.counted&&l.onDequeue();return}return new Promise(g=>{f=g})}},cancel(){try{d?.()}catch{}}})}function Wn(t,e,n){let{actor:r,filter:o}=n??{},s=[],i=[],a=!1,d=t.observe(e,{actor:r}),u=n?.highWaterMark!=null?it(c=>d.up(c),{highWaterMark:n.highWaterMark,lowWaterMark:n.lowWaterMark??Math.floor(n.highWaterMark/2)}):void 0,l=()=>{a||(a=!0,u?.dispose(),p())},f=c=>{if(!a)if(i.length>0){let g=i.shift();c.done&&c.error?g.reject(c.error):c.done?g.resolve({done:!0,value:void 0}):g.resolve({done:!1,value:c.value})}else s.push(c),c.done||u?.onEnqueue()},p=d.subscribe(c=>{for(let g of c){let m=g[0];if(m===
|
|
5
|
+
`)))},s)),i?.aborted?_():i?.addEventListener("abort",_,{once:!0})},pull(c){if(u&&!h){if(p.length>0){let g=p.shift();c.enqueue(g.frame),g.counted&&l.onDequeue();return}return new Promise(g=>{f=g})}},cancel(){try{d?.()}catch{}}})}function Wn(t,e,n){let{actor:r,filter:o}=n??{},s=[],i=[],a=!1,d=t.observe(e,{actor:r}),u=n?.highWaterMark!=null?it(c=>d.up(c),{highWaterMark:n.highWaterMark,lowWaterMark:n.lowWaterMark??Math.floor(n.highWaterMark/2)}):void 0,l=()=>{a||(a=!0,u?.dispose(),p())},f=c=>{if(!a)if(i.length>0){let g=i.shift();c.done&&c.error?g.reject(c.error):c.done?g.resolve({done:!0,value:void 0}):g.resolve({done:!1,value:c.value})}else s.push(c),c.done||u?.onEnqueue()},p=d.subscribe(c=>{for(let g of c){let m=g[0];if(m===R){let v=g[1];if(o&&!o(v))continue;f({done:!1,value:v})}else if(m===A){let v=g[1]instanceof Error?g[1]:new Error(String(g[1]));f({done:!0,error:v}),l();return}else if(m===L||m===F){f({done:!0}),l();return}}});return{next(){if(s.length>0){let c=s.shift();return c.done||u?.onDequeue(),c.done&&c.error?Promise.reject(c.error):Promise.resolve(c.done?{done:!0,value:void 0}:{done:!1,value:c.value})}return a?Promise.resolve({done:!0,value:void 0}):new Promise((c,g)=>{i.push({resolve:c,reject:g})})},return(){l();for(let c of i)c.resolve({done:!0,value:void 0});return i.length=0,Promise.resolve({done:!0,value:void 0})},throw(c){return l(),Promise.reject(c)},[Symbol.asyncIterator](){return this}}}var at=class{constructor(e,n){this.graph=e;this.extractActor=n?.extractActor??(()=>{}),this.parse=n?.parse??eo,this.highWaterMark=n?.highWaterMark,this.lowWaterMark=n?.lowWaterMark}clients=new Map;extractActor;parse;highWaterMark;lowWaterMark;handleConnection(e){this.clients.has(e)||this.clients.set(e,new Map)}handleDisconnect(e){let n=this.clients.get(e);if(n){for(let r of n.values())r.wm?.dispose(),r.unsub();this.clients.delete(e)}}handleMessage(e,n,r){let o=r??to.bind(null,e),s;try{s=typeof n=="string"?this.parse(n):n}catch{o({type:"err",message:"invalid command"});return}s.type==="subscribe"?this.subscribe(e,s.path,o):s.type==="unsubscribe"?this.unsubscribe(e,s.path,o):s.type==="ack"?this.ack(e,s.path,s.count??1):o({type:"err",message:`unknown command type: ${s.type}`})}subscriptionCount(e){return this.clients.get(e)?.size??0}destroy(){for(let[e]of this.clients)this.handleDisconnect(e)}subscribe(e,n,r){let o=this.clients.get(e);if(o||(o=new Map,this.clients.set(e,o)),o.has(n)){r({type:"subscribed",path:n});return}let s=this.extractActor(e),i;try{i=this.graph.observe(n,{actor:s})}catch(l){let f=l instanceof Error?l.message:String(l);r({type:"err",message:f});return}let a=this.highWaterMark!=null?it(l=>i.up(l),{highWaterMark:this.highWaterMark,lowWaterMark:this.lowWaterMark??Math.floor(this.highWaterMark/2)}):void 0,d=()=>{a?.dispose(),u(),o.delete(n)},u=i.subscribe(l=>{for(let f of l){let p=f[0];if(p===R)a?.onEnqueue(),Ft(r,{type:"data",path:n,value:f[1]});else if(p===A){let h=f[1]instanceof Error?f[1].message:String(f[1]);Ft(r,{type:"error",path:n,error:h}),d();return}else if(p===L||p===F){Ft(r,{type:"complete",path:n}),d();return}}});o.set(n,{unsub:u,wm:a}),r({type:"subscribed",path:n})}unsubscribe(e,n,r){let o=this.clients.get(e),s=o?.get(n);s&&(s.wm?.dispose(),s.unsub(),o.delete(n)),r({type:"unsubscribed",path:n})}ack(e,n,r){let o=this.clients.get(e)?.get(n);if(!o?.wm)return;let s=Math.min(Math.max(0,Math.floor(r)),1024);for(let i=0;i<s;i++)o.wm.onDequeue()}};function Zr(t){if(t instanceof Error)return t.message;try{return JSON.stringify(t)}catch{return String(t)}}function Ht(t,e){let n=`event: ${t}
|
|
6
6
|
`;if(e!==void 0)for(let r of e.split(`
|
|
7
7
|
`))n+=`data: ${r}
|
|
8
8
|
`;return n+=`
|
|
9
9
|
`,n}function eo(t){return JSON.parse(t)}function to(t,e){try{t.send(JSON.stringify(e))}catch{}}function Ft(t,e){try{t(e)}catch{}}Be();var ut="graphReflyActor";function qt(t){return e=>{let r=e.switchToHttp().getRequest()?.user;if(r!=null)return t?t(r):r}}function zn(t="x-graphrefly-actor"){return e=>{let r=e.switchToHttp().getRequest()?.headers?.[t.toLowerCase()];if(!(typeof r!="string"||r.length===0))try{return JSON.parse(r)}catch{return}}}function Un(t){let e=t?.[ut];return e!=null?he(e):ue}var Je=class{constructor(e){this.extractor=e}canActivate(e){let n=he(this.extractor(e)),r=e.switchToHttp().getRequest();return r!=null&&(r[ut]=n),!0}};function Kn(t){return new Je(t??qt())}var Xe=require("@nestjs/common"),Sr=require("@nestjs/core");Be();Ue();je();Ge();re();Ge();Ie();function dt(t,e){if(e!=null&&e.length>0)return new Set(e);switch(t){case"standard":return new Set(["type","status","value","deps","meta","v"]);case"full":return null;default:return new Set(["type","deps"])}}function no(t){return t._describeKind!=null?t._describeKind:t._deps.length>0?"derived":t._fn!=null?"producer":"state"}function ro(t){let e={};for(let[n,r]of Object.entries(t.meta))try{e[n]=r.cache}catch{}return e}function jt(t,e){let n=e==null,r=!n&&e!=null?[...e].filter(u=>u.startsWith("meta.")).map(u=>u.slice(5)):null,o=n||e.has("meta")||r!=null&&r.length>0,s="state",i=[];t instanceof P&&(s=no(t),i=t._deps.map(u=>u.node.name??""));let a={type:s,deps:i};(n||e.has("status"))&&(a.status=t.status);let d=t instanceof P?t._guard:void 0;if(o){let u={...ro(t)};if(d!=null&&u.access===void 0&&(u.access=At(d)),r!=null&&r.length>0&&!e.has("meta")){let l={};for(let f of r)f in u&&(l[f]=u[f]);a.meta=l}else a.meta=u}if(t.name!=null&&(a.name=t.name),n||e.has("value")){t.status==="sentinel"&&(a.sentinel=!0);try{a.value=t.cache}catch{}}if((n||e.has("v"))&&t.v!=null){let u={id:t.v.id,version:t.v.version};"cid"in t.v&&(u.cid=t.v.cid,u.prev=t.v.prev),a.v=u}return(n||e.has("guard"))&&d!=null&&(a.guard=At(d)),(n||e.has("lastMutation"))&&t.lastMutation!=null&&(a.lastMutation=t.lastMutation),a}Ie();Ke();st();Yn();var Qe=class{constructor(e){this.capacity=e;if(!Number.isInteger(e)||e<=0)throw new Error(`RingBuffer capacity must be a positive integer (got ${e})`);this.buf=new Array(e)}buf;head=0;_size=0;get size(){return this._size}get maxSize(){return this.capacity}push(e){let n=(this.head+this._size)%this.capacity;this.buf[n]=e,this._size<this.capacity?this._size++:this.head=(this.head+1)%this.capacity}shift(){if(this._size===0)return;let e=this.buf[this.head];return this.buf[this.head]=void 0,this.head=(this.head+1)%this.capacity,this._size--,e}at(e){if(this._size===0)return;let n=e<0?this._size+e:e;if(!(n<0||n>=this._size))return this.buf[(this.head+n)%this.capacity]}toArray(){let e=new Array(this._size);for(let n=0;n<this._size;n++)e[n]=this.buf[(this.head+n)%this.capacity];return e}clear(){for(let e=0;e<this._size;e++)this.buf[(this.head+e)%this.capacity]=void 0;this.head=0,this._size=0}};Dt();function Bt(t){return t>=768&&t<=879||t>=1155&&t<=1161||t>=1425&&t<=1469||t>=1552&&t<=1562||t>=1611&&t<=1631||t>=1648&&t===1648||t>=1750&&t<=1756||t>=1759&&t<=1764||t>=1767&&t<=1768||t>=1770&&t<=1773||t>=1840&&t<=1866||t>=1958&&t<=1968||t>=2304&&t<=2307||t>=2362&&t<=2383||t>=2385&&t<=2391||t>=2402&&t<=2403||t>=2433&&t<=2435||t>=2492&&t<=2509||t>=2561&&t<=2563||t>=2620&&t<=2641||t>=2672&&t<=2673||t>=2677&&t===2677||t>=3633&&t===3633||t>=3636&&t<=3642||t>=3655&&t<=3662||t>=3761&&t===3761||t>=3764&&t<=3772||t>=3784&&t<=3790||t>=7616&&t<=7679||t>=8400&&t<=8447||t>=65024&&t<=65039||t>=65056&&t<=65071||t===8205?0:t>=4352&&t<=4447||t>=8986&&t<=8987||t>=9001&&t<=9002||t>=9193&&t<=9203||t>=9208&&t<=9210||t>=9725&&t<=9726||t>=9748&&t<=9749||t>=9800&&t<=9811||t===9855||t===9875||t===9889||t>=9898&&t<=9899||t>=9917&&t<=9918||t>=9924&&t<=9925||t===9934||t===9940||t===9962||t>=9970&&t<=9971||t===9973||t===9978||t===9981||t===9986||t===9989||t>=9992&&t<=9997||t===9999||t>=10067&&t<=10069||t===10071||t>=10133&&t<=10135||t===10160||t===10175||t>=10548&&t<=10549||t>=11013&&t<=11015||t>=11035&&t<=11036||t===11088||t===11093||t>=11904&&t<=12350||t>=12352&&t<=12447||t>=12448&&t<=12543||t>=12549&&t<=12591||t>=12593&&t<=12686||t>=12688&&t<=12771||t>=12784&&t<=12830||t>=12832&&t<=12871||t>=12880&&t<=19903||t>=19968&&t<=40959||t>=43360&&t<=43388||t>=44032&&t<=55203||t>=63744&&t<=64255||t>=65040&&t<=65049||t>=65072&&t<=65131||t>=65281&&t<=65376||t>=65504&&t<=65510||t>=126980&&t===126980||t===127183||t>=127344&&t<=127345||t===127358||t===127359||t===127374||t>=127377&&t<=127386||t>=127456&&t<=127487||t>=127488&&t<=127490||t===127514||t===127535||t>=127538&&t<=127546||t>=127568&&t<=127569||t>=127744&&t<=129535||t>=129536&&t<=129791||t>=129792&&t<=130047||t>=131072&&t<=196605||t>=196608&&t<=262141?2:1}function lt(t){let e=0;for(let n of t)e+=Bt(n.codePointAt(0));return e}function Jn(t,e){if(e<=0)return"";let n=0,r="";for(let o of t){let s=Bt(o.codePointAt(0));if(n+s>e){if(e<=1)return"\u2026";for(;n+1>e&&r.length>0;){let i=[...r].pop();r=r.slice(0,-i.length),n-=Bt(i.codePointAt(0))}return`${r}\u2026`}r+=o,n+=s}return r}var oo={horizontal:"\u2500",vertical:"\u2502",cornerTL:"\u250C",cornerTR:"\u2510",cornerBL:"\u2514",cornerBR:"\u2518",tDown:"\u252C",tUp:"\u2534",tRight:"\u251C",tLeft:"\u2524",cross:"\u253C",arrowRight:"\u25B6",arrowDown:"\u25BC",arrowLeft:"\u25C0",arrowUp:"\u25B2",boxTL:"\u250C",boxTR:"\u2510",boxBL:"\u2514",boxBR:"\u2518",boxH:"\u2500",boxV:"\u2502"},so={horizontal:"-",vertical:"|",cornerTL:"+",cornerTR:"+",cornerBL:"+",cornerBR:"+",tDown:"+",tUp:"+",tRight:"+",tLeft:"+",cross:"+",arrowRight:">",arrowDown:"v",arrowLeft:"<",arrowUp:"^",boxTL:"+",boxTR:"+",boxBL:"+",boxBR:"+",boxH:"-",boxV:"|"};function er(t,e){let n=e.charset==="ascii"?so:oo,r=t.width,o=t.height,s=Array.from({length:o},()=>Array.from({length:r},()=>" ")),i=Array.from({length:o},()=>Array.from({length:r},()=>"empty"));for(let a of t.edges)ao(s,i,n,a);for(let a of t.boxes)io(s,i,n,a,e.labelOf(a.id));return s.map(a=>fo(a.join(""))).join(`
|
|
10
|
-
`)}function io(t,e,n,r,o){let{x:s,y:i,w:a,h:d}=r;if(a<2||d<2){d>0&&Qn(t,e,s,i,a,o);return}ce(t,e,s,i,n.boxTL);for(let l=s+1;l<s+a-1;l+=1)ce(t,e,l,i,n.boxH);ce(t,e,s+a-1,i,n.boxTR);for(let l=i+1;l<i+d-1;l+=1){ce(t,e,s,l,n.boxV);for(let f=s+1;f<s+a-1;f+=1)tr(t,e,f,l," ","empty");ce(t,e,s+a-1,l,n.boxV)}ce(t,e,s,i+d-1,n.boxBL);for(let l=s+1;l<s+a-1;l+=1)ce(t,e,l,i+d-1,n.boxH);ce(t,e,s+a-1,i+d-1,n.boxBR);let u=i+Math.floor(d/2);Qn(t,e,s+1,u,a-2,o)}function ce(t,e,n,r,o){tr(t,e,n,r,o,o===" "?"empty":o==="\u2500"||o==="-"?"boxH":o==="\u2502"||o==="|"?"boxV":"boxCorner")}function tr(t,e,n,r,o,s){if(r<0||r>=t.length)return;let i=t[r];n<0||n>=i.length||(i[n]=o,e[r][n]=s)}function Qn(t,e,n,r,o,s){if(r<0||r>=t.length)return;let i=n,a=o;for(let d of s){let u=lt(d);if(u!==0){if(a<u)break;i>=0&&i<t[r].length&&(t[r][i]=d,e[r][i]="label",u===2&&i+1<t[r].length&&(t[r][i+1]="",e[r][i+1]="label")),i+=u,a-=u}}for(;a>0;)i>=0&&i<t[r].length&&(t[r][i]=" ",e[r][i]="empty"),i+=1,a-=1}function ao(t,e,n,r){let o=r.points;if(o.length<2)return;for(let d=0;d+1<o.length;d+=1)uo(t,e,n,o[d],o[d+1]);for(let d=1;d+1<o.length;d+=1){let u=o[d-1],l=o[d],f=o[d+1],p=co(u,l,f,n);p&&Zn(t,e,l.x,l.y,p,"edgeCorner")}let s=o[o.length-1],i=o[o.length-2],a=lo(i,s,n);a&&Zn(t,e,s.x,s.y,a,"arrow")}function uo(t,e,n,r,o){if(!(r.x===o.x&&r.y===o.y)){if(r.y===o.y){let s=r.y,i=Math.min(r.x,o.x),a=Math.max(r.x,o.x);for(let d=i;d<=a;d+=1)Xn(t,e,d,s,n,"h")}else if(r.x===o.x){let s=r.x,i=Math.min(r.y,o.y),a=Math.max(r.y,o.y);for(let d=i;d<=a;d+=1)Xn(t,e,s,d,n,"v")}}}function Xn(t,e,n,r,o,s){if(r<0||r>=t.length)return;let i=t[r];if(n<0||n>=i.length)return;let a=e[r][n];if(!(a==="boxH"||a==="boxV"||a==="boxCorner"||a==="label")){if(a==="empty"){i[n]=s==="h"?o.horizontal:o.vertical,e[r][n]=s==="h"?"edgeH":"edgeV";return}if(a==="edgeH"&&s==="v"){i[n]=o.cross,e[r][n]="edgeCorner";return}if(a==="edgeV"&&s==="h"){i[n]=o.cross,e[r][n]="edgeCorner";return}}}function Zn(t,e,n,r,o,s){if(r<0||r>=t.length)return;let i=t[r];if(n<0||n>=i.length)return;let a=e[r][n];a==="boxH"||a==="boxV"||a==="boxCorner"||a==="label"||(i[n]=o,e[r][n]=s)}function co(t,e,n,r){let o=t.y===e.y,s=e.y===n.y;if(o===s)return;if(o){let d=t.x<e.x,u=n.y>e.y;return d&&u?r.cornerTR:d&&!u?r.cornerBR:!d&&u?r.cornerTL:r.cornerBL}let i=t.y<e.y,a=n.x>e.x;return i&&a?r.cornerBL:i&&!a?r.cornerBR:!i&&a?r.cornerTL:r.cornerTR}function lo(t,e,n){if(e.x>t.x)return n.arrowRight;if(e.x<t.x)return n.arrowLeft;if(e.y>t.y)return n.arrowDown;if(e.y<t.y)return n.arrowUp}function fo(t){let e=t.length;for(;e>0&&t.charCodeAt(e-1)===32;)e-=1;return t.slice(0,e)}function or(t){let e=po(t);ho(e),go(e),mo(e),yo(e,t);let n=_o(e,t),{width:r,height:o}=xo(e),s=[];for(let i of e.layers)for(let a of i)a.isVirtual||s.push({id:a.id,layer:a.layer,order:a.order,x:a.x,y:a.y,w:a.w,h:a.h});return{boxes:s,edges:n,width:r,height:o}}function po(t){let e=new Map;for(let o of t.nodes)e.set(o,{id:o,isVirtual:!1,layer:-1,order:0,x:0,y:0,w:t.widthCells(o),h:t.heightCells(o),in:[],out:[]});let n=[],r=0;for(let o of t.edges){if(o.from===o.to)continue;let s=e.get(o.from),i=e.get(o.to);if(!s||!i)continue;let a={chainId:r++,chainFrom:o.from,chainTo:o.to,fromId:o.from,toId:o.to,hopIndex:0,chainLen:1};s.out.push(a),i.in.push(a),n.push(a)}return{nodes:e,layers:[],hops:n}}function ho(t){let e=new Map;for(let s of t.nodes.values())e.set(s.id,s.in.length);let n=[];for(let s of t.nodes.values())(e.get(s.id)??0)===0&&(s.layer=0,n.push(s));let r=new Set,o=0;for(;o<n.length;){let s=n[o++];if(!r.has(s.id)){r.add(s.id);for(let i of s.out){let a=t.nodes.get(i.toId);a.layer=Math.max(a.layer,s.layer+1);let d=(e.get(a.id)??0)-1;e.set(a.id,d),d<=0&&n.push(a)}}}for(let s of t.nodes.values())s.layer<0&&(s.layer=0)}function go(t){let e=Math.max(0,...Array.from(t.nodes.values(),s=>s.layer)),n=Array.from({length:e+1},()=>[]);for(let s of t.nodes.values())n[s.layer].push(s);let r=[],o=0;for(let s of t.hops){let i=t.nodes.get(s.fromId),a=t.nodes.get(s.toId),d=a.layer-i.layer;if(d<=0){i.out=i.out.filter(f=>f!==s),a.in=a.in.filter(f=>f!==s);continue}if(d===1){s.hopIndex=0,s.chainLen=1,r.push(s);continue}i.out=i.out.filter(f=>f!==s),a.in=a.in.filter(f=>f!==s);let u=i;for(let f=1;f<d;f+=1){let p=`__virt_${o++}__`,h={id:p,isVirtual:!0,layer:i.layer+f,order:0,x:0,y:0,w:0,h:1,in:[],out:[]};t.nodes.set(p,h),n[h.layer].push(h);let c={chainId:s.chainId,chainFrom:s.chainFrom,chainTo:s.chainTo,fromId:u.id,toId:p,hopIndex:f-1,chainLen:d};u.out.push(c),h.in.push(c),r.push(c),u=h}let l={chainId:s.chainId,chainFrom:s.chainFrom,chainTo:s.chainTo,fromId:u.id,toId:a.id,hopIndex:d-1,chainLen:d};u.out.push(l),a.in.push(l),r.push(l)}for(let s of n)for(let i=0;i<s.length;i+=1)s[i].order=i;t.layers=n,t.hops=r}function mo(t){for(let n=0;n<4;n+=1){for(let r=1;r<t.layers.length;r+=1)nr(t,t.layers[r],"in"),ft(t.layers[r]);for(let r=t.layers.length-2;r>=0;r-=1)nr(t,t.layers[r],"out"),ft(t.layers[r])}for(let n=0;n<2;n+=1){let r=!1;for(let o=1;o<t.layers.length;o+=1){let s=t.layers[o];for(let i=0;i+1<s.length;i+=1){let a=rr(t,s[i],s[i+1],"in");[s[i],s[i+1]]=[s[i+1],s[i]],ft(s),rr(t,s[i],s[i+1],"in")<a?r=!0:([s[i],s[i+1]]=[s[i+1],s[i]],ft(s))}}if(!r)break}}function nr(t,e,n){let r=new Map;for(let o of e){let s=n==="in"?o.in:o.out;if(s.length===0){r.set(o.id,o.order);continue}let i=0,a=0;for(let d of s){let u=t.nodes.get(n==="in"?d.fromId:d.toId);u&&(i+=u.order,a+=1)}r.set(o.id,a===0?o.order:i/a)}e.sort((o,s)=>{let i=r.get(o.id),a=r.get(s.id);return i!==a?i-a:o.order-s.order})}function ft(t){for(let e=0;e<t.length;e+=1)t[e].order=e}function rr(t,e,n,r){let o=r==="in"?e.in:e.out,s=r==="in"?n.in:n.out,i=0;for(let a of o)for(let d of s){let u=t.nodes.get(r==="in"?a.fromId:a.toId)?.order??0,l=t.nodes.get(r==="in"?d.fromId:d.toId)?.order??0;(e.order<n.order&&u>l||e.order>n.order&&u<l)&&(i+=1)}return i}function yo(t,e){e.direction==="LR"?bo(t,e):vo(t,e)}function bo(t,e){let n=[],r=0;for(let o=0;o<t.layers.length;o+=1){n.push(r);let s=0;for(let i of t.layers[o])s=Math.max(s,i.w);r+=s+e.layerGap}for(let o=0;o<t.layers.length;o+=1)for(let s of t.layers[o])s.x=n[o];for(let o of t.layers){let s=0;for(let i of o)i.y=s,s+=i.h+e.nodeGap}sr(t,e,"y")}function vo(t,e){let n=[],r=0;for(let o=0;o<t.layers.length;o+=1){n.push(r);let s=0;for(let i of t.layers[o])s=Math.max(s,i.h);r+=s+e.layerGap}for(let o=0;o<t.layers.length;o+=1)for(let s of t.layers[o])s.y=n[o];for(let o of t.layers){let s=0;for(let i of o)i.x=s,s+=i.w+e.nodeGap}sr(t,e,"x")}function sr(t,e,n){let r=s=>n==="y"?s.h:s.w,o=e.nodeGap;for(let s=0;s<2;s+=1){let i=s===0?t.layers.slice(1):t.layers.slice(0,-1).reverse();for(let a of i){let d=new Map;for(let l of a){let f=s===0?l.in:l.out;if(f.length===0)continue;let p=[];for(let c of f){let g=t.nodes.get(s===0?c.fromId:c.toId);if(!g)continue;let m=n==="y"?g.y:g.x;p.push(m+Math.floor(r(g)/2))}if(p.length===0)continue;p.sort((c,g)=>c-g);let h=p[Math.floor(p.length/2)];d.set(l.id,h-Math.floor(r(l)/2))}let u=0;for(let l of a){let f=d.get(l.id),p=n==="y"?l.y:l.x,c=Math.max(f??p,u);n==="y"?l.y=c:l.x=c,u=c+r(l)+o}}}}function _o(t,e){let n=new Map;for(let u of t.hops){let l=n.get(u.chainId);l?l.push(u):n.set(u.chainId,[u])}for(let u of n.values())u.sort((l,f)=>l.hopIndex-f.hopIndex);let r=e.direction==="LR",o=u=>r?u.x:u.y,s=u=>r?u.w:u.h,i=u=>r?u.y+Math.floor(u.h/2):u.x+Math.floor(u.w/2),a=new Map;for(let u=0;u+1<t.layers.length;u+=1){let l=t.layers[u],f=t.layers[u+1],p=0;for(let E of l)p=Math.max(p,o(E)+s(E));let h=Number.POSITIVE_INFINITY;for(let E of f)h=Math.min(h,o(E));let c=Number.isFinite(h)?h-1:p,g=Math.max(1,c-p+1),m=[];for(let E of l)for(let N of E.out)m.push(N);m.sort((E,N)=>{let M=i(t.nodes.get(E.fromId)),S=i(t.nodes.get(N.fromId));if(M!==S)return M-S;let R=i(t.nodes.get(E.toId)),k=i(t.nodes.get(N.toId));return R-k});let v=[],_=new Map;for(let E of m){let N=i(t.nodes.get(E.fromId)),M=i(t.nodes.get(E.toId)),S=Math.min(N,M),R=Math.max(N,M),k=-1;for(let $=0;$<v.length;$+=1){let B=v[$],X=!0;for(let fe of B)if(fe.lo<=R&&S<=fe.hi){X=!1;break}if(X){B.push({lo:S,hi:R}),k=$;break}}k<0&&(v.push([{lo:S,hi:R}]),k=v.length-1),_.set(E,k)}let y=v.length,b=g>=Math.max(3,y+2),x=b?p+1:p,T=b?c-1:c,w=Math.max(1,T-x+1);for(let E of m){let N=_.get(E),M;if(y<=1)M=x+Math.floor(w/2);else{let S=(w-1)/(y-1);M=x+Math.floor(N*S)}a.set(E,Math.max(p,Math.min(c,M)))}}let d=[];for(let[,u]of n){let l=[];for(let p=0;p<u.length;p+=1){let h=u[p],c=t.nodes.get(h.fromId),g=t.nodes.get(h.toId),m=a.get(h),v=c.isVirtual?o(c):o(c)+s(c),_=g.isVirtual?o(g):o(g)-1,y=i(c),b=i(g);p===0&&pt(l,r,v,y),y!==b&&(pt(l,r,m,y),pt(l,r,m,b)),pt(l,r,_,b)}let f=u[0];d.push({from:f.chainFrom,to:f.chainTo,points:wo(l)})}return d}function pt(t,e,n,r){t.push(e?{x:n,y:r}:{x:r,y:n})}function wo(t){let e=[];for(let n of t){let r=e[e.length-1];(!r||r.x!==n.x||r.y!==n.y)&&e.push(n)}return e}function xo(t){let e=0,n=0;for(let r of t.layers)for(let o of r)e=Math.max(e,o.x+o.w),n=Math.max(n,o.y+o.h);return{width:e,height:n}}var To=24,Eo=4,Oo=1,No=3;function ir(t,e){let n=So(e.direction),r=Math.max(3,e.maxLabelWidth??To),o=e.asciiCharset??"unicode",s=Object.keys(t.nodes).sort(),i=new Set(s),a=t.edges.filter(h=>i.has(h.from)&&i.has(h.to)),d=new Map,u=new Map;for(let h of s){let c=Jn(h,r);d.set(h,c),u.set(h,lt(c)+4)}let l=or({nodes:s,edges:a,widthCells:h=>u.get(h)??3,heightCells:()=>No,layerGap:Eo,nodeGap:Oo,direction:n}),f=er(l,{charset:o,labelOf:h=>d.get(h)??h}),p=e.logger;return p&&p(f),f}function So(t){if(t===void 0||t==="LR")return"LR";if(t==="TD")return"TD";throw new Error(`ascii describe supports direction "LR" or "TD" only; got ${String(t)}`)}function ar(t,e,n,r={}){let o=e in t.nodes,s=n in t.nodes;if(!o)return ht(e,n,"no-such-from");if(!s)return ht(e,n,"no-such-to");let i=r.maxDepth;if(i!=null&&(!Number.isInteger(i)||i<0))throw new Error("explainPath: maxDepth must be an integer >= 0");if(e===n){if(r.findCycle===!0){let u=ko(t,e,r);if(u!=null)return u}let d=gt(e,t.nodes[e],0,r);return mt(e,n,[d])}if(i===0)return ht(e,n,"no-path");let a=ur(t,e,n,i);return a.found?mt(e,n,dr(t,a.pathOrder,r)):ht(e,n,a.truncated?"max-depth-exceeded":"no-path")}function ur(t,e,n,r){let o=new Map,s=[{path:n,depth:0}],i=new Set([n]),a=0,d=!1;for(;a<s.length;){let f=s[a++];if(f.path===e)break;if(r!=null&&f.depth>=r){let g=t.nodes[f.path];g?.deps&&g.deps.length>0&&(d=!0);continue}let p=t.nodes[f.path];if(p==null)continue;let h=p.deps??[],c=new Map;for(let g=0;g<h.length;g++){let m=h[g];if(!m)continue;let v=c.get(m);v==null&&(v=[],c.set(m,v)),v.push(g)}for(let[g,m]of c)i.has(g)||(i.add(g),o.set(g,{from:f.path,depIndices:m}),s.push({path:g,depth:f.depth+1}))}if(!o.has(e))return{found:!1,pathOrder:[],truncated:d};let u=[{path:e}],l=e;for(;l!==n;){let f=o.get(l);if(f==null)return{found:!1,pathOrder:[],truncated:!1};u[u.length-1].depIndices=f.depIndices,u.push({path:f.from}),l=f.from}return{found:!0,pathOrder:u,truncated:!1}}function ko(t,e,n){let r=t.nodes[e];if(r==null)return null;let o=r.deps??[],s=[];for(let a=0;a<o.length;a++)o[a]===e&&s.push(a);if(s.length>0){let a=gt(e,r,0,n);a.dep_index=s[0];let d=gt(e,r,1,n);return mt(e,e,[a,d])}let i=null;for(let a=0;a<o.length;a++){let d=o[a];if(!d||d===e)continue;let u=ur(t,d,e,n.maxDepth);u.found&&(i==null||u.pathOrder.length<i.pathOrder.length)&&(i=u,i={found:!0,pathOrder:[{path:e,depIndices:[a]},...u.pathOrder],truncated:!1})}return i==null?null:mt(e,e,dr(t,i.pathOrder,n))}function dr(t,e,n){return e.map((r,o)=>{let s=t.nodes[r.path],i=gt(r.path,s,o,n);return r.depIndices!=null&&r.depIndices.length>0&&(i.dep_index=r.depIndices[0],r.depIndices.length>1&&(i.dep_indices=[...r.depIndices])),i})}function gt(t,e,n,r){let o={path:t,type:e.type,hop:n};e.status!==void 0&&(o.status=e.status),"value"in e&&(o.value=e.value),e.v!=null&&(o.v=e.v);let s=r.annotations?.get(t)??e.annotation;s!=null&&(o.annotation=s);let i=r.lastMutations?.get(t)??e.lastMutation;return i!=null&&(o.lastMutation=i),o}function mt(t,e,n){return cr(t,e,!0,"ok",n)}function ht(t,e,n){return cr(t,e,!1,n,[])}function cr(t,e,n,r,o){let s=Ro(t,e,n,r,o);return{from:t,to:e,found:n,reason:r,steps:o,text:s,toJSON(){return{from:t,to:e,found:n,reason:r,steps:o}}}}function Ro(t,e,n,r,o){if(!n)switch(r){case"no-such-from":return`explainPath: no node named "${t}"`;case"no-such-to":return`explainPath: no node named "${e}"`;case"max-depth-exceeded":return`explainPath: no path from "${t}" to "${e}" within maxDepth`;default:return`explainPath: no path from "${t}" to "${e}"`}let s=[`Causal path: ${t} \u2192 ${e} (${o.length} step(s))`];for(let i of o){let d=` ${i.hop===0?"\xB7":"\u2193"} ${i.path} (${i.type}${i.status?`/${i.status}`:""})`;if(s.push(d),"value"in i&&s.push(` value: ${Co(i.value)}`),i.annotation!=null&&s.push(` annotation: ${i.annotation}`),i.lastMutation!=null){let u=i.lastMutation.actor;s.push(` actor: ${u.type}${u.id?`:${u.id}`:""}`)}}return s.join(`
|
|
11
|
-
`)}function
|
|
10
|
+
`)}function io(t,e,n,r,o){let{x:s,y:i,w:a,h:d}=r;if(a<2||d<2){d>0&&Qn(t,e,s,i,a,o);return}ce(t,e,s,i,n.boxTL);for(let l=s+1;l<s+a-1;l+=1)ce(t,e,l,i,n.boxH);ce(t,e,s+a-1,i,n.boxTR);for(let l=i+1;l<i+d-1;l+=1){ce(t,e,s,l,n.boxV);for(let f=s+1;f<s+a-1;f+=1)tr(t,e,f,l," ","empty");ce(t,e,s+a-1,l,n.boxV)}ce(t,e,s,i+d-1,n.boxBL);for(let l=s+1;l<s+a-1;l+=1)ce(t,e,l,i+d-1,n.boxH);ce(t,e,s+a-1,i+d-1,n.boxBR);let u=i+Math.floor(d/2);Qn(t,e,s+1,u,a-2,o)}function ce(t,e,n,r,o){tr(t,e,n,r,o,o===" "?"empty":o==="\u2500"||o==="-"?"boxH":o==="\u2502"||o==="|"?"boxV":"boxCorner")}function tr(t,e,n,r,o,s){if(r<0||r>=t.length)return;let i=t[r];n<0||n>=i.length||(i[n]=o,e[r][n]=s)}function Qn(t,e,n,r,o,s){if(r<0||r>=t.length)return;let i=n,a=o;for(let d of s){let u=lt(d);if(u!==0){if(a<u)break;i>=0&&i<t[r].length&&(t[r][i]=d,e[r][i]="label",u===2&&i+1<t[r].length&&(t[r][i+1]="",e[r][i+1]="label")),i+=u,a-=u}}for(;a>0;)i>=0&&i<t[r].length&&(t[r][i]=" ",e[r][i]="empty"),i+=1,a-=1}function ao(t,e,n,r){let o=r.points;if(o.length<2)return;for(let d=0;d+1<o.length;d+=1)uo(t,e,n,o[d],o[d+1]);for(let d=1;d+1<o.length;d+=1){let u=o[d-1],l=o[d],f=o[d+1],p=co(u,l,f,n);p&&Zn(t,e,l.x,l.y,p,"edgeCorner")}let s=o[o.length-1],i=o[o.length-2],a=lo(i,s,n);a&&Zn(t,e,s.x,s.y,a,"arrow")}function uo(t,e,n,r,o){if(!(r.x===o.x&&r.y===o.y)){if(r.y===o.y){let s=r.y,i=Math.min(r.x,o.x),a=Math.max(r.x,o.x);for(let d=i;d<=a;d+=1)Xn(t,e,d,s,n,"h")}else if(r.x===o.x){let s=r.x,i=Math.min(r.y,o.y),a=Math.max(r.y,o.y);for(let d=i;d<=a;d+=1)Xn(t,e,s,d,n,"v")}}}function Xn(t,e,n,r,o,s){if(r<0||r>=t.length)return;let i=t[r];if(n<0||n>=i.length)return;let a=e[r][n];if(!(a==="boxH"||a==="boxV"||a==="boxCorner"||a==="label")){if(a==="empty"){i[n]=s==="h"?o.horizontal:o.vertical,e[r][n]=s==="h"?"edgeH":"edgeV";return}if(a==="edgeH"&&s==="v"){i[n]=o.cross,e[r][n]="edgeCorner";return}if(a==="edgeV"&&s==="h"){i[n]=o.cross,e[r][n]="edgeCorner";return}}}function Zn(t,e,n,r,o,s){if(r<0||r>=t.length)return;let i=t[r];if(n<0||n>=i.length)return;let a=e[r][n];a==="boxH"||a==="boxV"||a==="boxCorner"||a==="label"||(i[n]=o,e[r][n]=s)}function co(t,e,n,r){let o=t.y===e.y,s=e.y===n.y;if(o===s)return;if(o){let d=t.x<e.x,u=n.y>e.y;return d&&u?r.cornerTR:d&&!u?r.cornerBR:!d&&u?r.cornerTL:r.cornerBL}let i=t.y<e.y,a=n.x>e.x;return i&&a?r.cornerBL:i&&!a?r.cornerBR:!i&&a?r.cornerTL:r.cornerTR}function lo(t,e,n){if(e.x>t.x)return n.arrowRight;if(e.x<t.x)return n.arrowLeft;if(e.y>t.y)return n.arrowDown;if(e.y<t.y)return n.arrowUp}function fo(t){let e=t.length;for(;e>0&&t.charCodeAt(e-1)===32;)e-=1;return t.slice(0,e)}function or(t){let e=po(t);ho(e),go(e),mo(e),yo(e,t);let n=_o(e,t),{width:r,height:o}=xo(e),s=[];for(let i of e.layers)for(let a of i)a.isVirtual||s.push({id:a.id,layer:a.layer,order:a.order,x:a.x,y:a.y,w:a.w,h:a.h});return{boxes:s,edges:n,width:r,height:o}}function po(t){let e=new Map;for(let o of t.nodes)e.set(o,{id:o,isVirtual:!1,layer:-1,order:0,x:0,y:0,w:t.widthCells(o),h:t.heightCells(o),in:[],out:[]});let n=[],r=0;for(let o of t.edges){if(o.from===o.to)continue;let s=e.get(o.from),i=e.get(o.to);if(!s||!i)continue;let a={chainId:r++,chainFrom:o.from,chainTo:o.to,fromId:o.from,toId:o.to,hopIndex:0,chainLen:1};s.out.push(a),i.in.push(a),n.push(a)}return{nodes:e,layers:[],hops:n}}function ho(t){let e=new Map;for(let s of t.nodes.values())e.set(s.id,s.in.length);let n=[];for(let s of t.nodes.values())(e.get(s.id)??0)===0&&(s.layer=0,n.push(s));let r=new Set,o=0;for(;o<n.length;){let s=n[o++];if(!r.has(s.id)){r.add(s.id);for(let i of s.out){let a=t.nodes.get(i.toId);a.layer=Math.max(a.layer,s.layer+1);let d=(e.get(a.id)??0)-1;e.set(a.id,d),d<=0&&n.push(a)}}}for(let s of t.nodes.values())s.layer<0&&(s.layer=0)}function go(t){let e=Math.max(0,...Array.from(t.nodes.values(),s=>s.layer)),n=Array.from({length:e+1},()=>[]);for(let s of t.nodes.values())n[s.layer].push(s);let r=[],o=0;for(let s of t.hops){let i=t.nodes.get(s.fromId),a=t.nodes.get(s.toId),d=a.layer-i.layer;if(d<=0){i.out=i.out.filter(f=>f!==s),a.in=a.in.filter(f=>f!==s);continue}if(d===1){s.hopIndex=0,s.chainLen=1,r.push(s);continue}i.out=i.out.filter(f=>f!==s),a.in=a.in.filter(f=>f!==s);let u=i;for(let f=1;f<d;f+=1){let p=`__virt_${o++}__`,h={id:p,isVirtual:!0,layer:i.layer+f,order:0,x:0,y:0,w:0,h:1,in:[],out:[]};t.nodes.set(p,h),n[h.layer].push(h);let c={chainId:s.chainId,chainFrom:s.chainFrom,chainTo:s.chainTo,fromId:u.id,toId:p,hopIndex:f-1,chainLen:d};u.out.push(c),h.in.push(c),r.push(c),u=h}let l={chainId:s.chainId,chainFrom:s.chainFrom,chainTo:s.chainTo,fromId:u.id,toId:a.id,hopIndex:d-1,chainLen:d};u.out.push(l),a.in.push(l),r.push(l)}for(let s of n)for(let i=0;i<s.length;i+=1)s[i].order=i;t.layers=n,t.hops=r}function mo(t){for(let n=0;n<4;n+=1){for(let r=1;r<t.layers.length;r+=1)nr(t,t.layers[r],"in"),ft(t.layers[r]);for(let r=t.layers.length-2;r>=0;r-=1)nr(t,t.layers[r],"out"),ft(t.layers[r])}for(let n=0;n<2;n+=1){let r=!1;for(let o=1;o<t.layers.length;o+=1){let s=t.layers[o];for(let i=0;i+1<s.length;i+=1){let a=rr(t,s[i],s[i+1],"in");[s[i],s[i+1]]=[s[i+1],s[i]],ft(s),rr(t,s[i],s[i+1],"in")<a?r=!0:([s[i],s[i+1]]=[s[i+1],s[i]],ft(s))}}if(!r)break}}function nr(t,e,n){let r=new Map;for(let o of e){let s=n==="in"?o.in:o.out;if(s.length===0){r.set(o.id,o.order);continue}let i=0,a=0;for(let d of s){let u=t.nodes.get(n==="in"?d.fromId:d.toId);u&&(i+=u.order,a+=1)}r.set(o.id,a===0?o.order:i/a)}e.sort((o,s)=>{let i=r.get(o.id),a=r.get(s.id);return i!==a?i-a:o.order-s.order})}function ft(t){for(let e=0;e<t.length;e+=1)t[e].order=e}function rr(t,e,n,r){let o=r==="in"?e.in:e.out,s=r==="in"?n.in:n.out,i=0;for(let a of o)for(let d of s){let u=t.nodes.get(r==="in"?a.fromId:a.toId)?.order??0,l=t.nodes.get(r==="in"?d.fromId:d.toId)?.order??0;(e.order<n.order&&u>l||e.order>n.order&&u<l)&&(i+=1)}return i}function yo(t,e){e.direction==="LR"?bo(t,e):vo(t,e)}function bo(t,e){let n=[],r=0;for(let o=0;o<t.layers.length;o+=1){n.push(r);let s=0;for(let i of t.layers[o])s=Math.max(s,i.w);r+=s+e.layerGap}for(let o=0;o<t.layers.length;o+=1)for(let s of t.layers[o])s.x=n[o];for(let o of t.layers){let s=0;for(let i of o)i.y=s,s+=i.h+e.nodeGap}sr(t,e,"y")}function vo(t,e){let n=[],r=0;for(let o=0;o<t.layers.length;o+=1){n.push(r);let s=0;for(let i of t.layers[o])s=Math.max(s,i.h);r+=s+e.layerGap}for(let o=0;o<t.layers.length;o+=1)for(let s of t.layers[o])s.y=n[o];for(let o of t.layers){let s=0;for(let i of o)i.x=s,s+=i.w+e.nodeGap}sr(t,e,"x")}function sr(t,e,n){let r=s=>n==="y"?s.h:s.w,o=e.nodeGap;for(let s=0;s<2;s+=1){let i=s===0?t.layers.slice(1):t.layers.slice(0,-1).reverse();for(let a of i){let d=new Map;for(let l of a){let f=s===0?l.in:l.out;if(f.length===0)continue;let p=[];for(let c of f){let g=t.nodes.get(s===0?c.fromId:c.toId);if(!g)continue;let m=n==="y"?g.y:g.x;p.push(m+Math.floor(r(g)/2))}if(p.length===0)continue;p.sort((c,g)=>c-g);let h=p[Math.floor(p.length/2)];d.set(l.id,h-Math.floor(r(l)/2))}let u=0;for(let l of a){let f=d.get(l.id),p=n==="y"?l.y:l.x,c=Math.max(f??p,u);n==="y"?l.y=c:l.x=c,u=c+r(l)+o}}}}function _o(t,e){let n=new Map;for(let u of t.hops){let l=n.get(u.chainId);l?l.push(u):n.set(u.chainId,[u])}for(let u of n.values())u.sort((l,f)=>l.hopIndex-f.hopIndex);let r=e.direction==="LR",o=u=>r?u.x:u.y,s=u=>r?u.w:u.h,i=u=>r?u.y+Math.floor(u.h/2):u.x+Math.floor(u.w/2),a=new Map;for(let u=0;u+1<t.layers.length;u+=1){let l=t.layers[u],f=t.layers[u+1],p=0;for(let E of l)p=Math.max(p,o(E)+s(E));let h=Number.POSITIVE_INFINITY;for(let E of f)h=Math.min(h,o(E));let c=Number.isFinite(h)?h-1:p,g=Math.max(1,c-p+1),m=[];for(let E of l)for(let N of E.out)m.push(N);m.sort((E,N)=>{let M=i(t.nodes.get(E.fromId)),S=i(t.nodes.get(N.fromId));if(M!==S)return M-S;let C=i(t.nodes.get(E.toId)),k=i(t.nodes.get(N.toId));return C-k});let v=[],_=new Map;for(let E of m){let N=i(t.nodes.get(E.fromId)),M=i(t.nodes.get(E.toId)),S=Math.min(N,M),C=Math.max(N,M),k=-1;for(let $=0;$<v.length;$+=1){let B=v[$],X=!0;for(let fe of B)if(fe.lo<=C&&S<=fe.hi){X=!1;break}if(X){B.push({lo:S,hi:C}),k=$;break}}k<0&&(v.push([{lo:S,hi:C}]),k=v.length-1),_.set(E,k)}let y=v.length,b=g>=Math.max(3,y+2),x=b?p+1:p,T=b?c-1:c,w=Math.max(1,T-x+1);for(let E of m){let N=_.get(E),M;if(y<=1)M=x+Math.floor(w/2);else{let S=(w-1)/(y-1);M=x+Math.floor(N*S)}a.set(E,Math.max(p,Math.min(c,M)))}}let d=[];for(let[,u]of n){let l=[];for(let p=0;p<u.length;p+=1){let h=u[p],c=t.nodes.get(h.fromId),g=t.nodes.get(h.toId),m=a.get(h),v=c.isVirtual?o(c):o(c)+s(c),_=g.isVirtual?o(g):o(g)-1,y=i(c),b=i(g);p===0&&pt(l,r,v,y),y!==b&&(pt(l,r,m,y),pt(l,r,m,b)),pt(l,r,_,b)}let f=u[0];d.push({from:f.chainFrom,to:f.chainTo,points:wo(l)})}return d}function pt(t,e,n,r){t.push(e?{x:n,y:r}:{x:r,y:n})}function wo(t){let e=[];for(let n of t){let r=e[e.length-1];(!r||r.x!==n.x||r.y!==n.y)&&e.push(n)}return e}function xo(t){let e=0,n=0;for(let r of t.layers)for(let o of r)e=Math.max(e,o.x+o.w),n=Math.max(n,o.y+o.h);return{width:e,height:n}}var To=24,Eo=4,Oo=1,No=3;function ir(t,e){let n=So(e.direction),r=Math.max(3,e.maxLabelWidth??To),o=e.asciiCharset??"unicode",s=Object.keys(t.nodes).sort(),i=new Set(s),a=t.edges.filter(h=>i.has(h.from)&&i.has(h.to)),d=new Map,u=new Map;for(let h of s){let c=Jn(h,r);d.set(h,c),u.set(h,lt(c)+4)}let l=or({nodes:s,edges:a,widthCells:h=>u.get(h)??3,heightCells:()=>No,layerGap:Eo,nodeGap:Oo,direction:n}),f=er(l,{charset:o,labelOf:h=>d.get(h)??h}),p=e.logger;return p&&p(f),f}function So(t){if(t===void 0||t==="LR")return"LR";if(t==="TD")return"TD";throw new Error(`ascii describe supports direction "LR" or "TD" only; got ${String(t)}`)}function ar(t,e,n,r={}){let o=e in t.nodes,s=n in t.nodes;if(!o)return ht(e,n,"no-such-from");if(!s)return ht(e,n,"no-such-to");let i=r.maxDepth;if(i!=null&&(!Number.isInteger(i)||i<0))throw new Error("explainPath: maxDepth must be an integer >= 0");if(e===n){if(r.findCycle===!0){let u=ko(t,e,r);if(u!=null)return u}let d=gt(e,t.nodes[e],0,r);return mt(e,n,[d])}if(i===0)return ht(e,n,"no-path");let a=ur(t,e,n,i);return a.found?mt(e,n,dr(t,a.pathOrder,r)):ht(e,n,a.truncated?"max-depth-exceeded":"no-path")}function ur(t,e,n,r){let o=new Map,s=[{path:n,depth:0}],i=new Set([n]),a=0,d=!1;for(;a<s.length;){let f=s[a++];if(f.path===e)break;if(r!=null&&f.depth>=r){let g=t.nodes[f.path];g?.deps&&g.deps.length>0&&(d=!0);continue}let p=t.nodes[f.path];if(p==null)continue;let h=p.deps??[],c=new Map;for(let g=0;g<h.length;g++){let m=h[g];if(!m)continue;let v=c.get(m);v==null&&(v=[],c.set(m,v)),v.push(g)}for(let[g,m]of c)i.has(g)||(i.add(g),o.set(g,{from:f.path,depIndices:m}),s.push({path:g,depth:f.depth+1}))}if(!o.has(e))return{found:!1,pathOrder:[],truncated:d};let u=[{path:e}],l=e;for(;l!==n;){let f=o.get(l);if(f==null)return{found:!1,pathOrder:[],truncated:!1};u[u.length-1].depIndices=f.depIndices,u.push({path:f.from}),l=f.from}return{found:!0,pathOrder:u,truncated:!1}}function ko(t,e,n){let r=t.nodes[e];if(r==null)return null;let o=r.deps??[],s=[];for(let a=0;a<o.length;a++)o[a]===e&&s.push(a);if(s.length>0){let a=gt(e,r,0,n);a.dep_index=s[0];let d=gt(e,r,1,n);return mt(e,e,[a,d])}let i=null;for(let a=0;a<o.length;a++){let d=o[a];if(!d||d===e)continue;let u=ur(t,d,e,n.maxDepth);u.found&&(i==null||u.pathOrder.length<i.pathOrder.length)&&(i=u,i={found:!0,pathOrder:[{path:e,depIndices:[a]},...u.pathOrder],truncated:!1})}return i==null?null:mt(e,e,dr(t,i.pathOrder,n))}function dr(t,e,n){return e.map((r,o)=>{let s=t.nodes[r.path],i=gt(r.path,s,o,n);return r.depIndices!=null&&r.depIndices.length>0&&(i.dep_index=r.depIndices[0],r.depIndices.length>1&&(i.dep_indices=[...r.depIndices])),i})}function gt(t,e,n,r){let o={path:t,type:e.type,hop:n};e.status!==void 0&&(o.status=e.status),"value"in e&&(o.value=e.value),e.v!=null&&(o.v=e.v);let s=r.annotations?.get(t)??e.annotation;s!=null&&(o.annotation=s);let i=r.lastMutations?.get(t)??e.lastMutation;return i!=null&&(o.lastMutation=i),o}function mt(t,e,n){return cr(t,e,!0,"ok",n)}function ht(t,e,n){return cr(t,e,!1,n,[])}function cr(t,e,n,r,o){let s=Co(t,e,n,r,o);return{from:t,to:e,found:n,reason:r,steps:o,text:s,toJSON(){return{from:t,to:e,found:n,reason:r,steps:o}}}}function Co(t,e,n,r,o){if(!n)switch(r){case"no-such-from":return`explainPath: no node named "${t}"`;case"no-such-to":return`explainPath: no node named "${e}"`;case"max-depth-exceeded":return`explainPath: no path from "${t}" to "${e}" within maxDepth`;default:return`explainPath: no path from "${t}" to "${e}"`}let s=[`Causal path: ${t} \u2192 ${e} (${o.length} step(s))`];for(let i of o){let d=` ${i.hop===0?"\xB7":"\u2193"} ${i.path} (${i.type}${i.status?`/${i.status}`:""})`;if(s.push(d),"value"in i&&s.push(` value: ${Ro(i.value)}`),i.annotation!=null&&s.push(` annotation: ${i.annotation}`),i.lastMutation!=null){let u=i.lastMutation.actor;s.push(` actor: ${u.type}${u.id?`:${u.id}`:""}`)}}return s.join(`
|
|
11
|
+
`)}function Ro(t){if(t===void 0)return"<sentinel>";if(t===null)return"null";if(typeof t=="string")return JSON.stringify(t);if(typeof t=="number"||typeof t=="boolean"||typeof t=="bigint")return String(t);try{let e=JSON.stringify(t);return e.length>80?`${e.slice(0,77)}...`:e}catch{return String(t)}}Ie();var H={object:56,array:64,string:40,number:8,boolean:4,null:0,undefined:0,symbol:40,bigint:16,function:120,map:72,set:72,mapEntry:40,setEntry:24,date:24,regexp:48,error:64,url:80,promise:48,weakmap:40,weakset:40},Mo=Symbol.for("sizeof");function lr(t){let e=new WeakSet,n=new WeakSet,r=[t],o=0;for(;r.length>0;){let s=r.pop();o+=Do(s,e,n,r)}return o}function Do(t,e,n,r){if(t==null)return 0;switch(typeof t){case"number":return H.number;case"boolean":return H.boolean;case"string":return H.string+t.length*2;case"bigint":return H.bigint+Ao(t);case"symbol":return H.symbol;case"function":return e.has(t)?0:(e.add(t),H.function);case"undefined":return 0}let s=t;if(e.has(s))return 0;e.add(s);let i=s[Mo];if(typeof i=="function")try{let u=i.call(s);if(typeof u=="number"&&Number.isFinite(u))return u}catch{}if(s instanceof Date)return H.date;if(s instanceof RegExp)return H.regexp+s.source.length*2;if(s instanceof Error){let u=s.message?s.message.length*2:0,l=s.stack?s.stack.length*2:0;return H.error+u+l}if(typeof URL<"u"&&s instanceof URL)return H.url+s.href.length*2;if(typeof Promise<"u"&&s instanceof Promise)return H.promise;if(s instanceof WeakMap)return H.weakmap;if(s instanceof WeakSet)return H.weakset;if(s instanceof Map){let u=H.map;for(let[l,f]of s)u+=H.mapEntry,r.push(l),r.push(f);return u}if(s instanceof Set){let u=H.set;for(let l of s)u+=H.setEntry,r.push(l);return u}if(Array.isArray(s)){let u=H.array+s.length*8;for(let l of s)r.push(l);return u}if(s instanceof ArrayBuffer)return n.has(s)?0:(n.add(s),s.byteLength);if(ArrayBuffer.isView(s)){let u=s;return n.has(u.buffer)?48:(n.add(u.buffer),u.buffer.byteLength+48)}let a=H.object,d=Object.keys(s);for(let u of d){a+=H.string+u.length*2;try{r.push(s[u])}catch{}}return a}function Ao(t){let e=t<0n?-t:t;if(e===0n)return 0;let n=e.toString(2).length;return Math.ceil(n/32)*8}function fr(t,e){let n=e?.topN??10,r=t.describe({detail:"standard"}),o=[],s=t._collectObserveTargets;typeof s=="function"&&s.call(t,"",o);let i=new Map;for(let[p,h]of o)i.set(p,h);let a=[];for(let[p,h]of Object.entries(r.nodes)){let c=i.get(p),g=c instanceof P?c:null,m=g?lr(g.cache):0,v=g?g._sinkCount:0,_=h.deps?.length??0,y=h.type==="effect"&&v===0,b=v===0?h.type==="effect"?"orphan-effect":h.type==="derived"?"idle-derived":h.type==="producer"?"idle-producer":null:null;a.push({path:p,type:h.type,status:h.status??"unknown",valueSizeBytes:m,subscriberCount:v,depCount:_,isOrphanEffect:y,orphanKind:b})}let d=a.reduce((p,h)=>p+h.valueSizeBytes,0),u=(p,h)=>[...a].sort(h??((c,g)=>g[p]-c[p])).slice(0,n),l=a.filter(p=>p.orphanKind!=null),f=a.filter(p=>p.isOrphanEffect);return{nodeCount:a.length,edgeCount:r.edges.length,subgraphCount:r.subgraphs.length,nodes:a,totalValueSizeBytes:d,hotspots:{byValueSize:u("valueSizeBytes"),bySubscriberCount:u("subscriberCount"),byDepCount:u("depCount")},orphans:l,orphanEffects:f}}var I="::",Q="__meta__",_e=1;function pr(t,e){let n=Math.max(16,t.size*4),r=0;for(;t.size>0;){if(r++>=n){console.error(`[Graph "${e}".destroy] disposer drain exceeded cap (${n}); ${t.size} disposer(s) discarded`),t.clear();return}let o=t.values().next();if(o.done)return;let s=o.value;t.delete(s);try{s()}catch(i){console.error(`[Graph "${e}".destroy] disposer threw:`,i)}}}function Go(t){let e=[];for(let n of Object.keys(t).sort()){let r=t[n].v;r!=null&&e.push(`${n} ${r.id} ${r.version}`)}return e.join(`
|
|
12
12
|
`)}function hr(t){if(t.version!==_e)throw new Error(`unsupported snapshot version ${String(t.version)} (expected ${_e})`);for(let e of["name","nodes","edges","subgraphs"])if(!(e in t))throw new Error(`snapshot missing required key "${e}"`);if(typeof t.name!="string")throw new TypeError("snapshot 'name' must be a string");if(typeof t.nodes!="object"||t.nodes===null||Array.isArray(t.nodes))throw new TypeError("snapshot 'nodes' must be an object");if(!Array.isArray(t.edges))throw new TypeError("snapshot 'edges' must be an array");if(!Array.isArray(t.subgraphs))throw new TypeError("snapshot 'subgraphs' must be an array")}function Io(t,e){let n=new WeakMap,r=(o,s)=>{if(Object.is(o,s))return!0;if(o==null||s==null||typeof o!="object"||typeof s!="object")return!1;let i=n.get(o);if(i==null&&(i=new WeakSet,n.set(o,i)),i.has(s))return!0;i.add(s);let a=o.constructor,d=s.constructor;if(a!==d)return!1;if(o instanceof Date)return o.getTime()===s.getTime();if(o instanceof RegExp)return o.source===s.source&&o.flags===s.flags;if(Array.isArray(o)){let p=s;if(o.length!==p.length)return!1;for(let h=0;h<o.length;h++)if(!r(o[h],p[h]))return!1;return!0}if(o instanceof Map){let p=s;if(o.size!==p.size)return!1;for(let[h,c]of o)if(!p.has(h)||!r(c,p.get(h)))return!1;return!0}if(o instanceof Set){let p=s;if(o.size!==p.size)return!1;for(let h of o){let c=!1;for(let g of p)if(r(h,g)){c=!0;break}if(!c)return!1}return!0}if(ArrayBuffer.isView(o)){let p=o,h=s;if(p.length!==h.length)return!1;for(let c=0;c<p.length;c++)if(p[c]!==h[c])return!1;return!0}let u=Object.keys(o),l=Object.keys(s);if(u.length!==l.length)return!1;let f=new Set(l);for(let p of u)if(!f.has(p)||!r(o[p],s[p]))return!1;return!0};return r(t,e)}function Wt(t){if(t===null||typeof t!="object")return t;if(Array.isArray(t))return t.map(Wt);let e=t,n=Object.keys(e).sort(),r={};for(let o of n)r[o]=Wt(e[o]);return r}function Lo(t){return t.replaceAll("\\","\\\\").replaceAll('"','\\"')}function Po(t){return t.replaceAll("\\","\\\\").replaceAll('"','\\"')}function $o(t){return t==="TD"?"down":t==="BT"?"up":t==="RL"?"left":"right"}function mr(t){let e=new Set,n=[];function r(o,s){let i=`${o}\0${s}`;e.has(i)||(e.add(i),n.push([o,s]))}for(let[o,s]of Object.entries(t.nodes)){let i=s.deps;if(i)for(let a of i)r(a,o)}for(let o of t.edges)r(o.from,o.to);return n}function yr(t){if(t===void 0)return"LR";if(t==="TD"||t==="LR"||t==="BT"||t==="RL")return t;throw new Error(`invalid diagram direction ${String(t)}; expected one of: TD, LR, BT, RL`)}function Ho(t,e){let n=e.includeEdges??!0,r=e.includeSubgraphs??!0,{expand:o,...s}=t,i={...s,edges:n?t.edges:[],subgraphs:r?t.subgraphs:[]},a=JSON.stringify(Wt(i),null,e.indent??2);return e.logger?.(a),a}function Fo(t,e){let n=e.includeEdges??!0,r=e.includeSubgraphs??!0,o=[];o.push(`Graph ${t.name}`),o.push("Nodes:");for(let i of Object.keys(t.nodes).sort()){let a=t.nodes[i];o.push(`- ${i} (${a.type}/${a.status}): ${bt(a.value)}`)}if(n){o.push("Edges:");for(let i of t.edges)o.push(`- ${i.from} -> ${i.to}`)}if(r){o.push("Subgraphs:");for(let i of t.subgraphs)o.push(`- ${i}`)}let s=o.join(`
|
|
13
13
|
`);return e.logger?.(s),s}function br(t,e){let n=yr(e.direction),r=Object.keys(t.nodes).sort(),o=new Map;for(let i=0;i<r.length;i+=1)o.set(r[i],`n${i}`);let s=[`flowchart ${n}`];for(let i of r){let a=o.get(i);s.push(` ${a}["${Lo(i)}"]`)}for(let[i,a]of mr(t)){let d=o.get(i),u=o.get(a);!d||!u||s.push(` ${d} --> ${u}`)}return s.join(`
|
|
14
14
|
`)}function qo(t,e){let n=br(t,e);return vr(n)}function vr(t,e){let n=e?.theme??"default",r=e?.autoSync??!0,s=JSON.stringify({code:t,mermaid:{theme:n},autoSync:r}),i=new TextEncoder().encode(s),a="";for(let u=0;u<i.length;u++)a+=String.fromCharCode(i[u]);return`https://mermaid.live/edit#base64:${globalThis.btoa(a).replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/,"")}`}function jo(t,e){let n=yr(e.direction),r=Object.keys(t.nodes).sort(),o=new Map;for(let i=0;i<r.length;i+=1)o.set(r[i],`n${i}`);let s=[`direction: ${$o(n)}`];for(let i of r){let a=o.get(i);s.push(`${a}: "${Po(i)}"`)}for(let[i,a]of mr(t)){let d=o.get(i),u=o.get(a);!d||!u||s.push(`${d} -> ${u}`)}return s.join(`
|
|
15
|
-
`)}function Bo(t){return t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function yt(t){let e="^";for(let n=0;n<t.length;n+=1){let r=t[n];if(r==="*"){e+=".*";continue}if(r==="?"){e+=".";continue}if(r==="["){let o=t.indexOf("]",n+1);if(o<=n+1){e+="\\[";continue}let s=t.slice(n+1,o);s.startsWith("!")&&(s=`^${s.slice(1)}`),s=s.replace(/\\/g,"\\\\"),e+=`[${s}]`,n=o;continue}e+=Bo(r)}return e+="$",new RegExp(e)}var Vo={data:"\x1B[32m",dirty:"\x1B[33m",resolved:"\x1B[36m",invalidate:"\x1B[93m",pause:"\x1B[90m",resume:"\x1B[96m",complete:"\x1B[34m",error:"\x1B[31m",teardown:"\x1B[91m",derived:"\x1B[35m",path:"\x1B[90m",reset:"\x1B[0m"},Wo={data:"",dirty:"",resolved:"",invalidate:"",pause:"",resume:"",complete:"",error:"",teardown:"",derived:"",path:"",reset:""};function bt(t){if(typeof t=="string")return JSON.stringify(t);if(typeof t=="number"||typeof t=="boolean"||t==null)return String(t);try{return JSON.stringify(t)}catch{return"[unserializable]"}}function zo(t){return t==="none"?Wo:t==="ansi"||t==null?Vo:{data:t.data??"",dirty:t.dirty??"",resolved:t.resolved??"",invalidate:t.invalidate??"",pause:t.pause??"",resume:t.resume??"",complete:t.complete??"",error:t.error??"",teardown:t.teardown??"",derived:t.derived??"",path:t.path??"",reset:t.reset??""}}function gr(t){if(t==null)return{};let e=t.detail;return e==="full"?{...t,structured:t.structured??!0,timeline:t.timeline??!0,causal:t.causal??!0,derived:t.derived??!0}:e==="minimal"?{...t,structured:t.structured??!0}:t.format==="stage-log"?{...t,structured:t.structured??!0,timeline:t.timeline??!0}:t}function Uo(t,e,n){for(let r=0;r<t.length;r++){let o=t.charCodeAt(r);if(o<32||o===127)throw new Error(`Graph "${e}": ${n} "${t}" must not contain control character (U+${o.toString(16).padStart(4,"0").toUpperCase()} at index ${r})`)}}function Vt(t,e,n){if(t==="")throw new Error(`Graph "${e}": ${n} name must be non-empty`);if(t.includes(I))throw new Error(`Graph "${e}": ${n} "${t}" must not contain '${I}' (path separator)`);if(t===Q)throw new Error(`Graph "${e}": ${n} name "${Q}" is reserved for meta companion paths`);Uo(t,e,n)}function Ko(t,e){if(t==="")throw new Error(`Graph "${e}": resolve path must be non-empty`);let n=t.split(I);for(let r of n)if(r==="")throw new Error(`Graph "${e}": resolve path has empty segment`);return n}function Yo(t,e){let n=!1;for(let o of t)if(!e.isMetaPassthrough(o[0])){n=!0;break}return n?t.filter(o=>e.isMetaPassthrough(o[0])):t}function _r(t){for(let e of t._mounts.values())_r(e);for(let e of t._nodes.values())try{e.down([[F]],{internal:!0})}catch{}}var ie=class t{name;opts;config;_nodes=new Map;_nodeToName=new WeakMap;_mounts=new Map;_parent=void 0;_storageDisposers=new Set;_disposers=new Set;_topology;_topologyEmitters=new Set;constructor(e,n){if(e==="")throw new Error("Graph name must be non-empty");if(e.includes(I))throw new Error(`Graph name must not contain '${I}' (got "${e}")`);if(e===Q)throw new Error(`Graph name "${Q}" is reserved for meta companion paths`);this.name=e,this.opts=Object.freeze({...n??{}}),this.config=n?.config??ye,this._traceRing=new Qe(n?.traceCapacity??1e3),n?.versioning!=null&&this.setVersioning(n.versioning)}ancestors(e=!0){let n=[],r=e?this:this._parent;for(;r!=null;)n.push(r),r=r._parent;return n}get topology(){return this._topology==null&&(this._topology=Le(e=>{let n=r=>{e.emit(r)};return this._topologyEmitters.add(n),()=>{this._topologyEmitters.delete(n)}},{name:`${this.name}_topology`})),this._topology}_emitTopology(e){if(!(this._topology==null||this._topologyEmitters.size===0))for(let n of this._topologyEmitters)n(e)}add(e,n){let r=e.name,o=n?.name??r;if(o==null||o==="")throw new Error(`Graph "${this.name}": graph.add requires a non-empty name \u2014 pass via opts.name or set it on the node (e.g. state(0, { name: "x" }))`);let s=o,i=n?.annotation;if(Vt(s,this.name,"add"),this._mounts.has(s))throw new Error(`Graph "${this.name}": name "${s}" is already a mount point`);if(this._nodes.has(s))throw new Error(`Graph "${this.name}": node "${s}" already exists`);let a=this._nodeToName.get(e);if(a!==void 0)throw new Error(`Graph "${this.name}": node instance already registered as "${a}"`);return this._nodes.set(s,e),this._nodeToName.set(e,s),this._emitTopology({kind:"added",name:s,nodeKind:"node"}),i!=null&&(this._annotations.set(s,i),this.config.inspectorEnabled&&this._traceRing.push({path:s,annotation:i,timestamp_ns:Ce()})),e}setVersioning(e){if(e!=null)for(let n of this._nodes.values())n instanceof P&&n._applyVersioning(e)}remove(e){Vt(e,this.name,"remove");let n=this._mounts.get(e);if(n){let s={kind:"mount",nodes:[],mounts:[]},i=[];n._collectObserveTargets("",i);for(let[a,d]of i)a.includes(`${I}${Q}${I}`)||s.nodes.push(a);return s.nodes.sort(),s.mounts.push(e),s.mounts.push(...n._collectSubgraphs(`${e}${I}`)),this._mounts.delete(e),n._parent=void 0,_r(n),this._emitTopology({kind:"removed",name:e,nodeKind:"mount",audit:s}),s}let r=this._nodes.get(e);if(!r)throw new Error(`Graph "${this.name}": unknown node or mount "${e}"`);this._nodes.delete(e),this._nodeToName.delete(r),r.down([[F]],{internal:!0});let o={kind:"node",nodes:[e],mounts:[]};return this._emitTopology({kind:"removed",name:e,nodeKind:"node",audit:o}),o}removeAll(e){let n=typeof e=="function"?e:(()=>{let s=yt(e);return i=>s.test(i)})(),r={kind:"mount",nodes:[],mounts:[]},o=[...this._nodes.keys(),...this._mounts.keys()].filter(s=>n(s));for(let s of o){let i=this.remove(s);r.nodes.push(...i.nodes),r.mounts.push(...i.mounts)}return r.nodes.sort(),r.mounts.sort(),r}[Symbol.iterator](){let e=[...this._nodes.keys()].sort(),n=this._nodes,r=0;return{[Symbol.iterator](){return this},next(){if(r>=e.length)return{value:void 0,done:!0};let o=e[r++];return{value:[o,n.get(o)],done:!1}}}}node(e){if(e==="")throw new Error(`Graph "${this.name}": node name must be non-empty`);if(e.includes(I))return this.resolve(e);let n=this._nodes.get(e);if(!n)throw new Error(`Graph "${this.name}": unknown node "${e}"`);return n}get(e){return this.node(e).cache}set(e,n,r){let o=r?.internal===!0;this.node(e).down([[C,n]],{actor:r?.actor,internal:o,delivery:"write"})}setAll(e,n){let r=Symbol.iterator in e?e:Object.entries(e);Ae(()=>{for(let[o,s]of r)this.set(o,s,n)})}invalidate(e,n){let r=n?.internal===!0;this.node(e).down([[ee]],{actor:n?.actor,internal:r,delivery:"write"})}error(e,n,r){let o=r?.internal===!0;this.node(e).down([[A,n]],{actor:r?.actor,internal:o,delivery:"write"})}complete(e,n){let r=n?.internal===!0;this.node(e).down([[L]],{actor:n?.actor,internal:r,delivery:"write"})}edges(e){let n=e?.recursive===!0,r=new Map;if(!n){for(let[d,u]of this._nodes)r.set(u,d);let a=[];for(let[d,u]of this._nodes)if(u instanceof P)for(let l of u._deps){let f=r.get(l.node);f!=null&&a.push([f,d])}return a.sort((d,u)=>d[0]<u[0]?-1:d[0]>u[0]?1:d[1]<u[1]?-1:d[1]>u[1]?1:0),a}let o=[];this._collectObserveTargets("",o);let s=new Map;for(let[a,d]of o)s.set(d,a);let i=[];for(let[a,d]of o)if(d instanceof P)for(let u of d._deps){let l=s.get(u.node);l!=null&&i.push([l,a])}return i.sort((a,d)=>a[0]<d[0]?-1:a[0]>d[0]?1:a[1]<d[1]?-1:a[1]>d[1]?1:0),i}mount(e,n){if(Vt(e,this.name,"mount"),this._nodes.has(e))throw new Error(`Graph "${this.name}": cannot mount at "${e}" \u2014 node with that name exists`);if(this._mounts.has(e))throw new Error(`Graph "${this.name}": mount "${e}" already exists`);if(n===this)throw new Error(`Graph "${this.name}": cannot mount a graph into itself`);if(n._parent!=null)throw new Error(`Graph "${this.name}": this child graph is already mounted on "${n._parent.name}"`);for(let r=this;r!=null;r=r._parent)if(r===n)throw new Error(`Graph "${this.name}": mount("${e}", \u2026) would create a mount cycle`);return this._mounts.set(e,n),n._parent=this,this._emitTopology({kind:"added",name:e,nodeKind:"mount"}),n}resolve(e){let n=Ko(e,this.name);return this._resolveFromSegments(n)}tryResolve(e){try{return this.resolve(e)}catch{return}}_resolveFromSegments(e){let n=e;if(n[0]===this.name&&(n=n.slice(1),n.length===0))throw new Error(`Graph "${this.name}": resolve path ends at graph name only`);let r=n[0],o=n.slice(1);if(o.length===0){let a=this._nodes.get(r);if(a)return a;throw this._mounts.has(r)?new Error(`Graph "${this.name}": path ends at subgraph "${r}" \u2014 not a node (GRAPHREFLY-SPEC \xA73.5)`):new Error(`Graph "${this.name}": unknown name "${r}"`)}let s=this._nodes.get(r);if(s&&o.length>0&&o[0]===Q)return this._resolveMetaChainFromNode(s,o,n.join(I));let i=this._mounts.get(r);if(!i)throw this._nodes.has(r)?new Error(`Graph "${this.name}": "${r}" is a node; trailing path "${o.join(I)}" is invalid`):new Error(`Graph "${this.name}": unknown mount or node "${r}"`);return i.resolve(o.join(I))}_resolveMetaChainFromNode(e,n,r){let o=e,s=0,i=[...n];for(;s<i.length;){if(i[s]!==Q)throw new Error(`Graph "${this.name}": expected ${Q} segment in meta path "${r}"`);if(s+1>=i.length)throw new Error(`Graph "${this.name}": meta path requires a key after ${Q} in "${r}"`);let a=i[s+1],d=o.meta[a];if(!d)throw new Error(`Graph "${this.name}": unknown meta "${a}" in path "${r}"`);o=d,s+=2}return o}signal(e,n){if(n?.internal!==!0){for(let o of e)if(this.config.messageTier(o[0])===3)throw new Error(`Graph "${this.name}": Graph.signal() rejects tier-3 messages (DATA / RESOLVED). Broadcast is for control-plane tiers (START / DIRTY / INVALIDATE / PAUSE / RESUME / COMPLETE / ERROR / TEARDOWN). For per-node value writes, use Graph.set or graph.node(name).down(...).`)}let r=[];if(this._signalDeliver(e,n??{},new Set,r),r.length>0)throw r[0]}_signalDeliver(e,n,r,o){for(let d of this._mounts.values())d._signalDeliver(e,n,r,o);let i=n.internal===!0?{internal:!0}:{actor:n.actor,delivery:"signal"},a=Yo(e,this.config);for(let d of[...this._nodes.keys()].sort()){let u=this._nodes.get(d);if(!r.has(u)){r.add(u);try{u.down(e,i)}catch(l){if(l instanceof J)throw l;o.push(l)}a.length!==0&&this._signalMetaSubtree(u,a,r,i,o)}}}_signalMetaSubtree(e,n,r,o,s){for(let i of Object.keys(e.meta).sort()){let a=e.meta[i];if(!r.has(a)){r.add(a);try{a.down(n,o)}catch(d){if(d instanceof J)throw d;s.push(d)}this._signalMetaSubtree(a,n,r,o,s)}}}describe(e){if(e?.reactive===!0)return this._describeReactive(e);let n=e?.actor,r=e?.filter,o=dt(e?.detail,e?.fields),s=e?.format==="spec",i=s?dt("minimal"):o,a=[];this._collectObserveTargets("",a);let d=new Map;for(let[T,w]of a)d.set(w,T);let u=[];{let T=a.map(([,N])=>N),w=new Set(d.values()),E=0;for(;T.length>0;){let N=T.shift();if(N instanceof P)for(let M of N._deps){let S=M.node;if(d.has(S))continue;let R=S.name??"",k=R;if(!k||w.has(k))if(R){let $=2;for(;w.has(`${R}#${$}`);)$++;k=`${R}#${$}`}else for(k=`__internal__/${E++}`;w.has(k);)k=`__internal__/${E++}`;d.set(S,k),w.add(k),u.push([k,S]),T.push(S)}}}let l=[...a,...u],f={};for(let[T,w]of l){if(n!=null&&!w.allowsObserve(n))continue;let E=jt(w,i),N=w instanceof P?w._deps.map(k=>d.get(k.node)??k.node.name??""):[],{name:M,...S}=E,R={...S,deps:N};if(!s){let k=this._annotations.get(T);k!=null&&(R.annotation=k)}if(r!=null)if(typeof r=="function"){let k=r;if(!(k.length>=2?k(T,R):k(R)))continue}else{let k=!0;for(let[$,B]of Object.entries(r)){let X=$==="deps_includes"?"depsIncludes":$==="meta_has"?"metaHas":$;if(X==="depsIncludes"){if(!R.deps.includes(String(B))){k=!1;break}continue}if(X==="metaHas"){if(!Object.hasOwn(R.meta??{},String(B))){k=!1;break}continue}if(R[X]!==B){k=!1;break}}if(!k)continue}f[T]=R}let p=new Set(Object.keys(f)),h=[];for(let[T,w]of l)if(w instanceof P)for(let E of w._deps){let N=d.get(E.node);N!=null&&h.push([N,T])}h.sort((T,w)=>T[0]<w[0]?-1:T[0]>w[0]?1:T[1]<w[1]?-1:T[1]>w[1]?1:0);let c=h.map(([T,w])=>({from:T,to:w}));(n!=null||r!=null)&&(c=c.filter(T=>p.has(T.from)&&p.has(T.to)));let g=this._collectSubgraphs(""),m=n!=null||r!=null?g.filter(T=>{let w=`${T}${I}`;return[...p].some(E=>E===T||E.startsWith(w))}):g,v=this,_=e,y={name:this.name,nodes:f,edges:c,subgraphs:m,expand(T){let w={..._,format:void 0};return Array.isArray(T)?(w.fields=T,w.detail=void 0):(w.detail=T,w.fields=void 0),v.describe(w)}},b=e??{},x=b.format;return x==="json"?Ho(y,b):x==="pretty"?Fo(y,b):x==="mermaid"?br(y,b):x==="mermaid-url"?qo(y,b):x==="d2"?jo(y,b):x==="ascii"?ir(y,b):y}_collectSubgraphs(e){let n=[];for(let r of[...this._mounts.keys()].sort()){let o=e===""?r:`${e}${r}`;n.push(o),n.push(...this._mounts.get(r)._collectSubgraphs(`${o}${I}`))}return n}resourceProfile(e){return fr(this,e)}reachable(e,n,r={}){return r.withDetail===!0?zt(this.describe(),e,n,{...r,withDetail:!0}):zt(this.describe(),e,n,r)}explain(e,n,r){return r?.reactive===!0?this._explainReactive(e,n,r):this._explainStatic(e,n,r)}_explainStatic(e,n,r){let o=this.describe({detail:"full"}),s=new Map(this._annotations),i=new Map;for(let[a,d]of Object.entries(o.nodes))d.lastMutation!=null&&i.set(a,d.lastMutation);return ar(o,e,n,{...r?.maxDepth!=null?{maxDepth:r.maxDepth}:{},...r?.findCycle===!0?{findCycle:!0}:{},annotations:s,lastMutations:i})}_describeReactive(e){let n={...e,reactive:!1},r=e.reactiveName??"describe",o=0,s=oe(o,{name:`${r}_version`}),i=this.observe({timeline:!0,structured:!0}),a=!1,d=!1,u=()=>{a||d||(a=!0,ze(()=>{a=!1,!d&&(o+=1,s.emit(o))}))},l=i.onEvent(m=>{let v=m.type;v!=="data"&&v!=="error"&&v!=="complete"&&v!=="teardown"||u()}),f=[],p=new WeakSet,h=m=>{if(p.has(m)||d)return;p.add(m);let v=m.topology.subscribe(_=>{for(let y of _){if(y[0]!==C)continue;let b=y[1];if(u(),b.kind==="added"&&b.nodeKind==="mount"){let x=m._mounts.get(b.name);x!=null&&h(x)}}});f.push(v);for(let _ of m._mounts.keys()){let y=m._mounts.get(_);y!=null&&h(y)}};h(this);let c;try{c=se([s],()=>this.describe(n),{name:r,describeKind:"derived",meta:{domain:"audit",kind:"describe"},equals:(m,v)=>m===v})}catch(m){l();for(let v of f)v();throw i.dispose(),m}let g=de(c);return{node:c,dispose(){d=!0,l();for(let m of f)m();f.length=0,i.dispose(),g()}}}_explainReactive(e,n,r){let o=0,s=oe(o,{name:"explain_version"}),i=this.observe({timeline:!0,structured:!0}),a=!1,d=!1,u=i.onEvent(h=>{let c=h.type;c!=="data"&&c!=="error"&&c!=="complete"&&c!=="teardown"||a||d||(a=!0,ze(()=>{a=!1,!d&&(o+=1,s.emit(o))}))}),l={...r?.maxDepth!=null?{maxDepth:r.maxDepth}:{},...r?.findCycle===!0?{findCycle:!0}:{}},f;try{f=se([s],()=>this._explainStatic(e,n,l),{name:r?.name??"explain",describeKind:"derived",meta:{domain:"audit",kind:"explain_path",from:e,to:n},equals:(h,c)=>h.found===c.found&&h.reason===c.reason&&h.steps.length===c.steps.length&&Jo(h.steps,c.steps)})}catch(h){throw u(),i.dispose(),h}let p=de(f);return{node:f,dispose(){d=!0,u(),i.dispose(),p()}}}_pathsMatching(e){let n=yt(e),r=[];return this._collectObserveTargets("",r),r.map(([o])=>o).filter(o=>n.test(o))}_collectObserveTargets(e,n){for(let r of[...this._mounts.keys()].sort()){let o=e===""?r:`${e}${I}${r}`;this._mounts.get(r)._collectObserveTargets(o,n)}for(let r of[...this._nodes.keys()].sort()){let o=this._nodes.get(r),s=e===""?r:`${e}${I}${r}`;n.push([s,o]),this._appendMetaObserveTargets(s,o,n)}}_appendMetaObserveTargets(e,n,r){for(let o of Object.keys(n.meta).sort()){let s=n.meta[o],i=`${e}${I}${Q}${I}${o}`;r.push([i,s]),this._appendMetaObserveTargets(i,s,r)}}observe(e,n){let r=typeof e=="string",s=gr(r?n:e),i=s.structured===!0||s.timeline===!0||s.causal===!0||s.derived===!0||s.detail==="minimal"||s.detail==="full"||s.format!=null,a=s.actor;if(r){let l=e,f=this.resolve(l);if(a!=null&&!f.allowsObserve(a))throw new J({actor:a,action:"observe",nodeName:l});return i?this._buildStructuredObserver([[l,f]],s,"one"):{subscribe(p){return f.subscribe(p)},up(p){try{f.up?.(p)}catch(h){if(h instanceof J)return;throw h}}}}let d=[];this._collectObserveTargets("",d),d.sort((l,f)=>l[0]<f[0]?-1:l[0]>f[0]?1:0);let u=a==null?d:d.filter(([,l])=>l.allowsObserve(a));return i?this._buildStructuredObserver(u,s,"all"):{subscribe:l=>{let f=u.map(([p,h])=>h.subscribe(c=>{l(p,c)}));return()=>{for(let p of f)p()}},up:(l,f)=>{try{this.resolve(l).up?.(f)}catch(p){if(p instanceof J)return;throw p}}}}_buildStructuredObserver(e,n,r){let o=r==="one"?e[0]?.[0]:void 0,s=i=>{if(r==="one"&&o!=null){let l=this.resolve(o);return this._buildStructuredObserver([[o,l]],i,"one")}let a=[];this._collectObserveTargets("",a),a.sort((l,f)=>l[0]<f[0]?-1:l[0]>f[0]?1:0);let d=i.actor,u=d==null?a:a.filter(([,l])=>l.allowsObserve(d));return this._buildStructuredObserver(u,i,"all")};return this._createObserveResult(e,n,s)}_createObserveResult(e,n,r){let o=n.timeline===!0,s=n.causal===!0,i=n.derived===!0,a=n.detail==="minimal",d=this.config.inspectorEnabled,u=(s||i)&&d,l=n.maxEvents,f=l!=null&&l>0?new Qe(l):null,p=[],h=new Set,c={},g=new Set,m=0,v=0,_=0,y=0,b=0,x=0,T=!1,w=!1,E=0,N=new Map,M=new Map,S=new Map,R=O=>{f?f.push(O):p.push(O);for(let G of h)G(O)},k=()=>o?{timestamp_ns:Ce(),in_batch:et(),batch_id:E}:{},$=(O,G)=>{if(!(!u||!(O instanceof P)))return O._setInspectorHook(z=>{if(z.kind==="dep_message")N.set(O,z.depIndex);else if(z.kind==="run"){let Pe=z.batchData.map((D,q)=>D!=null&&D.length>0?D.at(-1):z.prevData[q]);M.set(O,Pe);let U=z.batchData.map(D=>D!=null?[...D]:void 0);S.set(O,U),i&&R({type:"derived",path:G,dep_values:Pe,dep_batches:U,...k()})}})},B=O=>{let G=N.get(O),z=M.get(O);if(!s||z==null)return{};let U=(G!=null&&G>=0&&O instanceof P?O._deps[G]:void 0)?.node,D=U?.v,q=S.get(O);return{trigger_dep_index:G,trigger_dep_name:U?.name,...D!=null?{trigger_version:{id:D.id,version:D.version}}:{},dep_values:[...z],...q!=null?{dep_batches:q}:{}}},X=[],fe=[];for(let[O,G]of e){let z=$(G,O);z&&X.push(z),fe.push(G.subscribe(Pe=>{E++;for(let U of Pe){let D=U[0],q=k();if(D===C){c[O]=U[1];let Et=G instanceof P?G.lastMutation?.actor??ue:ue;R({type:"data",path:O,data:U[1],actor:Et,...q,...B(G)})}else if(a)D===W?m++:D===Z?v++:D===ee?_++:D===K?y++:D===te?b++:D===F?x++:D===L&&!g.has(O)?T=!0:D===A&&(w=!0,g.add(O));else if(D===W)m++,R({type:"dirty",path:O,...q});else if(D===Z)v++,R({type:"resolved",path:O,...q,...B(G)});else if(D===ee)_++,R({type:"invalidate",path:O,...q});else if(D===K)y++,R({type:"pause",path:O,lockId:U[1],...q});else if(D===te)b++,R({type:"resume",path:O,lockId:U[1],...q});else if(D===L)g.has(O)||(T=!0),R({type:"complete",path:O,...q});else if(D===A){w=!0,g.add(O);let Et=G instanceof P?G.lastMutation?.actor??ue:ue;R({type:"error",path:O,data:U[1],actor:Et,...q})}else D===F&&(x++,R({type:"teardown",path:O,...q}))}}))}let wt=!1,xt=()=>{if(!wt){wt=!0;for(let O of fe)O();for(let O of X)O();for(let O of Ze)O({value:void 0,done:!0});Ze.length=0}},Tt=[],Ze=[];h.add(O=>{let G=Ze.shift();G?G({value:O,done:!1}):Tt.push(O)});let Xt={get values(){return c},get dirtyCount(){return m},get resolvedCount(){return v},get invalidateCount(){return _},get pauseCount(){return y},get resumeCount(){return b},get teardownCount(){return x},get events(){return f?f.toArray():[...p]},get anyCompletedCleanly(){return T},get anyErrored(){return w},get completedWithoutErrors(){return T&&!w},onEvent(O){return h.add(O),()=>h.delete(O)},dispose:xt,expand(O){xt();let G={...n};return typeof O=="string"?G.detail=O:Object.assign(G,O),r(gr(G))},[Symbol.asyncIterator](){return{next(){return Tt.length>0?Promise.resolve({value:Tt.shift(),done:!1}):wt?Promise.resolve({value:void 0,done:!0}):new Promise(O=>Ze.push(O))},return(){return xt(),Promise.resolve({value:void 0,done:!0})}}}};return n.format!=null&&this._attachFormatLogger(Xt,n),Xt}_attachFormatLogger(e,n){let r=n.format;if(r==null)return;let o=n.logger??(c=>console.log(c)),s=n.includeTypes?new Set(n.includeTypes):null,i=n.excludeTypes?new Set(n.excludeTypes):null,a=s==null&&i==null?()=>!0:c=>(s==null||s.has(c))&&(i==null||!i.has(c)),d=zo(n.theme),u=r==="stage-log"?Ce():0,l=c=>c==null?"":n.stageLabels?.[c]??c,f=(c,g)=>c.length>g?`${c.slice(0,g-1)}\u2026`:c,p=c=>c.type==="data"||c.type==="error"?f(bt(c.data),120):"",h=c=>{if(r==="stage-log"){let w=(Ce()-u)/1e9,E=l(c.path).padEnd(9);if(c.type==="data"){let N=p(c);return`[${w.toFixed(3)}s] ${E} \u2190${N?` ${N}`:""}`}if(c.type==="error"){let N=p(c);return`[${w.toFixed(3)}s] ${E} \u2717${N?` ${N}`:""}`}return c.type==="complete"?`[${w.toFixed(3)}s] ${E} \u25A0 complete`:`[${w.toFixed(3)}s] ${E} ${c.type}`}if(r==="json")try{return JSON.stringify(c)}catch{return JSON.stringify({type:c.type,path:c.path,data:"[unserializable]"})}let g=d[c.type]??"",m=c.path?`${d.path}${c.path}${d.reset} `:"",v=c.type==="data"||c.type==="error",_=c.type==="pause"||c.type==="resume",y=v?` ${bt(c.data)}`:_?` ${bt(c.lockId)}`:"",b=c.type==="data"||c.type==="resolved"||c.type==="derived"?c:void 0,x=b?.trigger_dep_name!=null?` <- ${b.trigger_dep_name}`:b?.trigger_dep_index!=null?` <- #${b.trigger_dep_index}`:"",T=c.in_batch?" [batch]":"";return`${m}${g}${c.type.toUpperCase()}${d.reset}${y}${x}${T}`};e.onEvent(c=>{a(c.type)&&o(h(c),c)})}addDisposer(e){return this._disposers.add(e),()=>{this._disposers.delete(e)}}destroy(){pr(this._disposers,this.name),this.signal([[F]],{internal:!0}),pr(this._storageDisposers,this.name);for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0}_destroyClearOnly(){for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0}snapshot(e){let{expand:n,...r}=this.describe({detail:"full"}),o={};for(let a of Object.keys(r.nodes).sort()){let{lastMutation:d,guard:u,...l}=r.nodes[a];o[a]=l}let s=[...r.subgraphs].sort(),i={...r,version:1,nodes:o,subgraphs:s};if(e?.format==null)return i;if(e.format==="json-string")return JSON.stringify(i);if(e.format==="bytes"){if(e.codec==null)throw new Error("snapshot({format: 'bytes'}) requires a `codec` name");let a=this.config.lookupCodec(e.codec);if(a==null)throw new Error(`snapshot: codec "${e.codec}" is not registered on this graph's config. Call config.registerCodec(...) before creating nodes.`);return En(a,a.encode(i))}throw new Error(`snapshot: unknown format "${String(e.format)}"`)}static decode(e,n){let r=n?.config??ye,{codec:o,codecVersion:s,payload:i}=On(e,r);return o.decode(i,s)}restore(e,n){if(hr(e),e.name!==this.name)throw new Error(`Graph "${this.name}": restore snapshot name "${e.name}" does not match this graph`);let r=n?.only==null?null:(Array.isArray(n.only)?n.only:[n.only]).map(s=>yt(s)),o=n?.includeProducers===!0;for(let s of Object.keys(e.nodes).sort()){if(r!==null&&!r.some(a=>a.test(s)))continue;let i=e.nodes[s];if(i!==void 0){if(!("value"in i)||i.value===void 0){"value"in i&&i.value===void 0&&n?.onError?.(s,new Error(`restore: slice.value is undefined for "${s}" (undefined is the global SENTINEL; not valid DATA)`));continue}if(!(i.type==="derived"||i.type==="effect")&&!(i.type==="producer"&&!o)){if(i.v!=null){let d=this.tryResolve(s)?.v;if(d!=null&&d.id===i.v.id&&d.version===i.v.version)continue}try{this.set(s,i.value)}catch(a){n?.onError?.(s,a)}}}}}static fromSnapshot(e,n){hr(e);let r=typeof n=="function"?n:n?.build,o=typeof n=="function"?void 0:n?.factories,s=new t(e.name);if(r)return r(s),s.restore(e),s;for(let h of[...e.subgraphs].sort((c,g)=>{let m=c.split(I).length,v=g.split(I).length;return m!==v?m-v:c<g?-1:c>g?1:0})){let c=h.split(I),g=s;for(let m of c)g._mounts.has(m)||g.mount(m,new t(m)),g=g._mounts.get(m)}let i=o?Object.entries(o).map(([h,c])=>({re:yt(h),factory:c})):[],a=h=>{for(let c of i)if(c.re.test(h))return c.factory},d=h=>{let c=h.split(I),g=c.pop();if(g==null||g.length===0)throw new Error(`invalid snapshot path "${h}"`);let m=s;for(let v of c){let _=m._mounts.get(v);if(!_)throw new Error(`unknown mount "${v}" in path "${h}"`);m=_}return[m,g]},u=Object.entries(e.nodes).filter(([h])=>!h.includes(`${I}${Q}${I}`)).sort((h,c)=>h[0]<c[0]?-1:h[0]>c[0]?1:0),l=new Map(u),f=new Map,p=!0;for(;l.size>0&&p;){p=!1;for(let[h,c]of[...l.entries()]){let g=c?.deps??[];if(!g.every(x=>f.has(x)))continue;let[m,v]=d(h),_={...c?.meta??{}},y=a(h),b;if(c?.type==="state")b=oe(c.value,{meta:_});else{if(y==null)continue;b=y(v,{path:h,type:c.type,value:c.value,meta:_,deps:g,resolvedDeps:g.map(x=>f.get(x))})}m.add(b,{name:v}),f.set(h,b),l.delete(h),p=!0}}if(l.size>0){let h=[...l.keys()].sort().join(", ");throw new Error(`Graph.fromSnapshot could not reconstruct nodes without build callback: ${h}. Pass matching factories via fromSnapshot(data, { factories: { pattern: factoryFn } }).`)}return s.restore(e),s}toJSON(){return this.snapshot()}attachStorage(e,n={}){let r=e.map(u=>({tier:u,debounceMs:Math.max(0,u.debounceMs??0),compactEvery:Math.max(1,u.compactEvery??10),timer:void 0,seq:0,lastSnapshot:void 0,lastFingerprint:"",disposed:!1,savePending:void 0}));n.autoRestore===!0&&this._cascadeRestore(e,n.onError);let o=(u,l)=>{if(u.disposed)return;let f=Go(l.nodes);if(u.lastSnapshot!=null&&f!==""&&f===u.lastFingerprint)return;let p=u.seq+1,h=ae(),m=u.lastSnapshot==null||p%u.compactEvery===0?{mode:"full",snapshot:l,seq:p,timestamp_ns:h,format_version:_e}:{mode:"diff",diff:wr(u.lastSnapshot,l),seq:p,timestamp_ns:h,format_version:_e};if(u.tier.filter&&!u.tier.filter(this.name,m))return;let v;try{v=u.tier.save(this.name,m)}catch(_){n.onError?.(_,u.tier);return}if(v&&typeof v.then=="function"){let b=(u.savePending??Promise.resolve()).then(()=>v,()=>v).then(()=>{u.disposed||(u.seq=p,u.lastSnapshot=l,u.lastFingerprint=f)},x=>{n.onError?.(x,u.tier)});u.savePending=b.finally(()=>{u.savePending===b&&(u.savePending=void 0)})}else u.seq=p,u.lastSnapshot=l,u.lastFingerprint=f},s=(u,l)=>{try{o(u,l)}catch(f){n.onError?.(f,u.tier)}},i=(u,l)=>{if(!l.some(c=>{let g=this.config.messageTier(c[0]);return g>=3&&g<5}))return;if(n.filter){let c=this.tryResolve(u);if(c==null)return;let g=jt(c,dt("standard"));if(!n.filter(u,g))return}let p,h=()=>(p==null&&(p=this.snapshot()),p);for(let c of r)c.disposed||(c.debounceMs===0?s(c,h()):(c.timer==null&&(c.timer=new ct),c.timer.start(c.debounceMs,()=>{c.disposed||s(c,this.snapshot())})))},a;if(n.paths!=null){let l=(typeof n.paths=="string"?this._pathsMatching(n.paths):n.paths).map(f=>{let p=this.tryResolve(f);return p==null?()=>{}:p.subscribe(h=>i(f,h))});a=()=>{for(let f of l)f()}}else a=this.observe().subscribe((u,l)=>i(u,l));let d=()=>{a();for(let u of r)u.disposed=!0,u.timer?.cancel();this._storageDisposers.delete(d)};return this._storageDisposers.add(d),{dispose:d}}async _cascadeRestore(e,n){for(let r of e){let o;try{o=await r.load(this.name)}catch(i){n?.(i,r);continue}if(o==null||typeof o!="object"||Array.isArray(o))continue;let s=o;try{if(s.mode==="full"&&s.snapshot!=null)return this.restore(s.snapshot),!0;if(s.version===_e&&s.nodes!=null)return this.restore(s),!0}catch(i){n?.(i,r)}}return!1}static async fromStorage(e,n,r){for(let o of n){let s;try{s=await o.load(e)}catch(d){r?.onError?.(d,o);continue}if(s==null||typeof s!="object"||Array.isArray(s))continue;let i=s,a=i.mode==="full"&&i.snapshot!=null?i.snapshot:i.version===_e&&i.nodes!=null?i:void 0;if(a!=null)try{return t.fromSnapshot(a,r)}catch(d){r?.onError?.(d,o)}}throw new Error(`Graph.fromStorage: no tier held a restorable record for "${e}" across ${n.length} tier(s)`)}_annotations=new Map;_traceRing;trace(e,n,r){if(e!=null&&n!=null){if(this.tryResolve(e)==null)return;if(this._annotations.set(e,n),this.config.inspectorEnabled){let o={path:e,annotation:n,timestamp_ns:Ce(),...r?.actor!=null?{actor:r.actor}:{}};this._traceRing.push(o)}return}return e!=null?this.config.inspectorEnabled?this._annotations.get(e):void 0:this.config.inspectorEnabled?this._traceRing.toArray():[]}annotation(e){return this._annotations.get(e)}clearTrace(){this._annotations.clear(),this._traceRing.clear()}pruneTrace(e){let n=this._traceRing.toArray().filter(o=>!e(o)),r=this._traceRing.size-n.length;this._traceRing.clear();for(let o of n)this._traceRing.push(o);return r}static diff(e,n){let r=new Set(Object.keys(e.nodes)),o=new Set(Object.keys(n.nodes)),s=[...o].filter(_=>!r.has(_)).sort(),i=[...r].filter(_=>!o.has(_)).sort(),a=[],d=[];for(let _ of r){if(!o.has(_))continue;let y=e.nodes[_],b=n.nodes[_],x=y.v,T=b.v;x!=null&&T!=null&&x.id===T.id&&x.version!==T.version&&d.push({path:_,id:x.id,from:x.version,to:T.version});let w=x!=null&&T!=null&&x.id===T.id&&x.version===T.version;for(let E of["type","status","sentinel"]){let N=y[E],M=b[E];N!==M&&a.push({path:_,field:E,from:N,to:M})}if(!w)for(let E of["value","meta"]){let N=y[E],M=b[E];Io(N,M)||a.push({path:_,field:E,from:N,to:M})}}let u=_=>`${_.from} ${_.to}`,l=new Set(e.edges.map(u)),f=new Set(n.edges.map(u)),p=n.edges.filter(_=>!l.has(u(_))),h=e.edges.filter(_=>!f.has(u(_))),c=new Set(e.subgraphs),g=new Set(n.subgraphs),m=[...g].filter(_=>!c.has(_)).sort(),v=[...c].filter(_=>!g.has(_)).sort();return{nodesAdded:s,nodesRemoved:i,nodesChanged:a,versionChanges:d,edgesAdded:p,edgesRemoved:h,subgraphsAdded:m,subgraphsRemoved:v}}};function wr(t,e){let n=ie.diff(t,e),r={};for(let o of n.nodesAdded){let s=e.nodes[o];s!=null&&(r[o]=s)}return{...n,nodesAddedFull:r}}function zt(t,e,n,r={}){let o={paths:[],depths:new Map,truncated:!1};if(!e)return r.withDetail?o:[];if(!r.both&&n!=="upstream"&&n!=="downstream")throw new Error('reachable: direction must be "upstream" or "downstream"');let s=r.maxDepth;if(s!=null&&(!Number.isInteger(s)||s<0))throw new Error("reachable: maxDepth must be an integer >= 0");if(s===0)return r.withDetail?o:[];let i=new Map,a=new Map,d=new Map,u=new Map,l=new Set;for(let[y,b]of Object.entries(t.nodes)){if(!y)continue;l.add(y);let x=b.deps??[];i.set(y,x);for(let T of x)T&&(l.add(T),a.has(T)||a.set(T,new Set),a.get(T).add(y))}for(let y of t.edges){if(y==null||typeof y!="object")continue;let b=typeof y.from=="string"?y.from:"",x=typeof y.to=="string"?y.to:"";!b||!x||(l.add(b),l.add(x),u.has(b)||u.set(b,new Set),u.get(b).add(x),d.has(x)||d.set(x,new Set),d.get(x).add(b))}if(!l.has(e))return r.withDetail?o:[];let f=r.both===!0,p=y=>{if(f){let w=i.get(y)??[],E=d.get(y),N=a.get(y),M=u.get(y),S=[...w];return E&&S.push(...E),N&&S.push(...N),M&&S.push(...M),S}if(n==="upstream"){let w=i.get(y)??[],E=d.get(y);return E?[...w,...E]:w}let b=a.get(y),x=u.get(y),T=b?[...b]:[];return x&&T.push(...x),T},h=new Set([e]),c=new Map,g=[{path:e,depth:0}],m=0,v=!1;for(;m<g.length;){let y=g[m++];if(s!=null&&y.depth>=s){p(y.path).length>0&&(v=!0);continue}for(let b of p(y.path))!b||h.has(b)||(h.add(b),c.set(b,y.depth+1),g.push({path:b,depth:y.depth+1}))}let _=[...c.keys()].sort((y,b)=>y<b?-1:y>b?1:0);return r.withDetail?{paths:_,depths:c,truncated:v}:_}function Jo(t,e){if(t.length!==e.length)return!1;for(let n=0;n<t.length;n++){let r=t[n],o=e[n];if(r.path!==o.path||r.type!==o.type||r.status!==o.status||r.hop!==o.hop||r.dep_index!==o.dep_index||r.annotation!==o.annotation||r.value!==o.value||r.lastMutation!==o.lastMutation)return!1;let s=r.v,i=o.v;if(s!==i&&(s==null||i==null||s.id!==i.id||s.version!==i.version))return!1}return!0}Ue();je();Ge();Be();Ge();Ie();Ke();Ue();re();Ke();var Ut=class{_version=0;_maxSize;_buf;_head=0;_size=0;constructor(e,n){if(n!==void 0&&n<1)throw new RangeError("maxSize must be >= 1");if(this._maxSize=n,n!==void 0){if(this._buf=new Array(n),e&&e.length>0){let r=Math.min(e.length,n),o=e.length-r;for(let s=0;s<r;s++)this._buf[s]=e[o+s];this._size=r}}else this._buf=e?[...e]:[],this._size=this._buf.length}get version(){return this._version}get size(){return this._size}at(e){if(!Number.isInteger(e))return;let n=e>=0?e:this._size+e;if(!(n<0||n>=this._size))return this._maxSize!==void 0?this._buf[(this._head+n)%this._maxSize]:this._buf[n]}append(e){this._rawAppend(e),this._version+=1}appendMany(e){if(e.length===0)return;let n=this._maxSize!==void 0&&e.length>this._maxSize?e.length-this._maxSize:0;for(let r=n;r<e.length;r++)this._rawAppend(e[r]);this._version+=1}clear(){if(this._size===0)return 0;let e=this._size;if(this._maxSize===void 0)this._buf.length=0;else for(let n=0;n<e;n++)this._buf[(this._head+n)%this._maxSize]=void 0;return this._head=0,this._size=0,this._version+=1,e}trimHead(e){if(!Number.isInteger(e)||e<0)throw new RangeError(`trimHead: n must be a non-negative integer (got ${e})`);if(e===0||this._size===0)return 0;let n=Math.min(e,this._size);if(this._maxSize===void 0)this._buf.splice(0,n);else{for(let r=0;r<n;r++)this._buf[(this._head+r)%this._maxSize]=void 0;this._head=(this._head+n)%this._maxSize}return this._size-=n,this._version+=1,n}slice(e,n){if(!Number.isInteger(e)||e<0)throw new RangeError(`slice: start must be a non-negative integer (got ${e})`);if(n!==void 0&&(!Number.isInteger(n)||n<0))throw new RangeError(`slice: stop must be a non-negative integer or undefined (got ${n})`);let r=n===void 0?this._size:Math.min(Math.max(n,0),this._size),o=Math.min(e,this._size);if(o>=r)return[];let s=r-o;if(this._maxSize===void 0)return this._buf.slice(o,r);let i=new Array(s);for(let a=0;a<s;a++)i[a]=this._buf[(this._head+o+a)%this._maxSize];return i}tail(e){if(!Number.isInteger(e)||e<0)throw new RangeError(`tail: n must be a non-negative integer (got ${e})`);if(e===0||this._size===0)return[];let n=Math.min(e,this._size);return this.slice(this._size-n,this._size)}toArray(){if(this._maxSize===void 0)return[...this._buf];let e=new Array(this._size);for(let n=0;n<this._size;n++)e[n]=this._buf[(this._head+n)%this._maxSize];return e}_rawAppend(e){if(this._maxSize===void 0){this._buf.push(e),this._size=this._buf.length;return}this._size<this._maxSize?(this._buf[(this._head+this._size)%this._maxSize]=e,this._size+=1):(this._buf[this._head]=e,this._head=(this._head+1)%this._maxSize)}};function xr(t){return t.subscribe(()=>{})}var Qo=64;function Tr(t,e={}){let{name:n,maxSize:r,versioning:o,backend:s}=e,i=s??new Ut(t,r),a=oe(i.toArray(),{name:n,describeKind:"state",equals:(c,g)=>c===g,...o!=null?{versioning:o}:{}});function d(){let c=i.toArray();Ae(()=>{a.down([[W]]),a.down([[C,c]])})}let u=new Map,l=new Map;function f(c,g){return`${c}:${g===void 0?"END":g}`}function p(c){if(c.size<Qo)return;let g=c.keys().next();if(g.done)return;let m=c.get(g.value);m!==void 0&&m.dispose(),c.delete(g.value)}function h(c){let g=i.version;try{return c()}finally{i.version!==g&&d()}}return{entries:a,get size(){return i.size},at(c){return i.at(c)},append(c){h(()=>i.append(c))},appendMany(c){c.length!==0&&h(()=>i.appendMany(c))},clear(){h(()=>i.clear())},trimHead(c){h(()=>i.trimHead(c))},tail(c){if(!Number.isInteger(c)||c<0)throw new RangeError(`tail: n must be a non-negative integer (got ${c})`);let g=u.get(c);if(g!==void 0)return u.delete(c),u.set(c,g),g.node;p(u);let m=se([a],([_])=>{let y=_;return c===0||y.length===0?[]:y.slice(Math.max(0,y.length-c))},{initial:i.tail(c),describeKind:"derived"}),v=xr(m);return u.set(c,{node:m,dispose:v}),m},slice(c,g){if(!Number.isInteger(c)||c<0)throw new RangeError(`slice: start must be a non-negative integer (got ${c})`);if(g!==void 0&&(!Number.isInteger(g)||g<0))throw new RangeError(`slice: stop must be a non-negative integer or undefined (got ${g})`);let m=f(c,g),v=l.get(m);if(v!==void 0)return l.delete(m),l.set(m,v),v.node;p(l);let _=se([a],([b])=>{let x=b;return g===void 0?x.slice(c):x.slice(c,g)},{initial:i.slice(c,g),describeKind:"derived"}),y=xr(_);return l.set(m,{node:_,dispose:y}),_},disposeTail(c){let g=u.get(c);return g===void 0?!1:(g.dispose(),u.delete(c),!0)},disposeSlice(c,g){let m=f(c,g),v=l.get(m);return v===void 0?!1:(v.dispose(),l.delete(m),!0)},disposeAllViews(){for(let c of u.values())c.dispose();u.clear();for(let c of l.values())c.dispose();l.clear()},dispose(){for(let c of u.values())c.dispose();u.clear();for(let c of l.values())c.dispose();l.clear()}}}st();function Er(t,e,n){return{[t]:!0,[`${t}_type`]:e,...n??{}}}var Xo=rt((t,e)=>{t("write"),t("signal"),e("observe")}),Zo=rt((t,e)=>{t("observe"),t("signal"),e("write")}),es=rt((t,e)=>{t("observe"),t("signal"),e("write")});function vt(t,e){return Er("cqrs",t,e)}var Kt=class extends ie{_eventLogs=new Map;_commandHandlers=new Map;_projections=new Set;_sagas=new Set;_keepaliveDisposers=[];_eventStore;_seq=0;constructor(e,n={}){super(e,n.graph)}destroy(){for(let e of this._keepaliveDisposers)e();this._keepaliveDisposers.length=0,super.destroy()}event(e){let n=this._eventLogs.get(e);if(n)return n.node;let r=Tr([],{name:e,versioning:0}),o=r.entries,s=se([o],([i])=>i,{name:e,describeKind:"state",meta:vt("event",{event_name:e}),guard:es,initial:o.cache});return this.add(s,{name:e}),this._keepaliveDisposers.push(de(s)),this._eventLogs.set(e,{log:r,node:s}),s}_appendEvent(e,n){let r=this._eventLogs.get(e);if(r||(this.event(e),r=this._eventLogs.get(e)),r.node.status==="completed"||r.node.status==="errored")throw new Error(`Cannot dispatch to terminated event stream "${e}" (status: ${r.node.status}).`);let o=r.log.entries.v,s={type:e,payload:n,timestampNs:ae(),seq:++this._seq,...o!=null?{v0:{id:o.id,version:o.version}}:{}};r.log.append(s),this._eventStore&&this._eventStore.persist(s)}command(e,n){let r=oe(void 0,{name:e,describeKind:"state",meta:{...vt("command",{command_name:e}),error:null},guard:Xo});return this.add(r,{name:e}),this._commandHandlers.set(e,n),r}dispatch(e,n){let r=this._commandHandlers.get(e);if(!r)throw new Error(`Unknown command: "${e}". Register with .command() first.`);let o=this.resolve(e);Ae(()=>{o.emit(n,{internal:!0});try{r(n,{emit:(s,i)=>this._appendEvent(s,i)}),o.meta.error.emit(null,{internal:!0})}catch(s){throw o.meta.error.emit(s,{internal:!0}),s}})}projection(e,n,r,o){let s=n.map(a=>(this._eventLogs.has(a)||this.event(a),this._eventLogs.get(a).node)),i=se(s,a=>{let d=[];for(let u of a){let l=u;d.push(...l)}return d.sort((u,l)=>u.timestampNs-l.timestampNs||u.seq-l.seq),r(o,d)},{name:e,describeKind:"derived",meta:vt("projection",{projection_name:e,source_events:n}),guard:Zo,initial:o});return this.add(i,{name:e}),this._keepaliveDisposers.push(de(i)),this._projections.add(e),i}saga(e,n,r){let o=n.map(d=>(this._eventLogs.has(d)||this.event(d),this._eventLogs.get(d).node)),s=new Map,i={},a=be(o,(d,u)=>{let l=i.n.meta.error;for(let f=0;f<d.length;f++){let p=d[f];if(p==null||p.length===0)continue;let h=p.at(-1);if(!h)continue;let c=n[f],g=s.get(c)??0;if(h.length>g){let m=h.slice(g);for(let v of m)try{r(v),l.emit(null,{internal:!0})}catch(_){l.emit(_,{internal:!0})}s.set(c,h.length)}}},{name:e,describeKind:"effect",meta:{...vt("saga",{saga_name:e,source_events:n}),error:null}});return i.n=a,this.add(a,{name:e}),this._keepaliveDisposers.push(de(a)),this._sagas.add(e),a}useEventStore(e){this._eventStore=e}async rebuildProjection(e,n,r){if(!this._eventStore)throw new Error("No event store wired. Call useEventStore() first.");let o=[];for(let s of e){let i=await this._eventStore.loadEvents(s);o.push(...i.events)}return o.sort((s,i)=>s.timestampNs-i.timestampNs||s.seq-i.seq),n(r,o)}};function Or(t,e){return new Kt(t,e)}var Jt=class{constructor(e){this.graph=e}onModuleDestroy(){this.graph.destroy()}},Qt=class{graph=new ie("request");onModuleDestroy(){this.graph.destroy()}},Nr,Yt;Nr=[(0,Xe.Module)({})];var le=class le{static forRoot(e){let n=e??{},r=n.name??"root",o=[{provide:Y,useFactory:()=>{let s=new ie(r);return n.build&&n.build(s),n.snapshot&&s.restore(n.snapshot),s}},{provide:Symbol.for("graphrefly:root-lifecycle"),useFactory:s=>new Jt(s),inject:[Y]},{provide:ve,useFactory:(s,i)=>new ve(s,i),inject:[Y,Sr.ModuleRef]}];if(n.nodes)for(let s of n.nodes)o.push({provide:ne(s),useFactory:i=>i.resolve(s),inject:[Y]});return n.requestScope&&o.push({provide:Symbol.for("graphrefly:request-lifecycle"),useFactory:()=>new Qt,scope:Xe.Scope.REQUEST},{provide:pe,useFactory:s=>s.graph,inject:[Symbol.for("graphrefly:request-lifecycle")],scope:Xe.Scope.REQUEST}),{module:le,global:!0,providers:o,exports:[Y,...(n.nodes??[]).map(ne),...n.requestScope?[pe]:[]]}}static forFeature(e){let n=[{provide:j(e.name),useFactory:r=>{let o=new ie(e.name);return e.build&&e.build(o),e.snapshot&&o.restore(e.snapshot),r.mount(e.name,o),o},inject:[Y]}];if(e.nodes)for(let r of e.nodes)n.push({provide:ne(`${e.name}::${r}`),useFactory:o=>o.resolve(r),inject:[j(e.name)]});return{module:le,providers:n,exports:[j(e.name),...(e.nodes??[]).map(r=>ne(`${e.name}::${r}`))]}}static forCqrs(e){let n=[{provide:j(e.name),useFactory:r=>{let o=Or(e.name,e.cqrs);return e.eventStore&&o.useEventStore(e.eventStore),e.build&&e.build(o),r.mount(e.name,o),o},inject:[Y]}];if(e.nodes)for(let r of e.nodes)n.push({provide:ne(`${e.name}::${r}`),useFactory:o=>o.resolve(r),inject:[j(e.name)]});return{module:le,providers:n,exports:[j(e.name),...(e.nodes??[]).map(r=>ne(`${e.name}::${r}`))]}}};Yt=on(null),le=un(Yt,0,"GraphReflyModule",Nr,le),an(Yt,1,le);var _t=le;0&&(module.exports={ACTOR_KEY,COMMAND_HANDLERS,CQRS_EVENT_HANDLERS,CRON_HANDLERS,CommandHandler,EVENT_HANDLERS,EventHandler,GRAPHREFLY_REQUEST_GRAPH,GRAPHREFLY_ROOT_GRAPH,GraphCron,GraphInterval,GraphReflyEventExplorer,GraphReflyGuard,GraphReflyGuardImpl,GraphReflyModule,INTERVAL_HANDLERS,InjectCqrsGraph,InjectGraph,InjectNode,ObserveGateway,OnGraphEvent,QUERY_HANDLERS,QueryHandler,SAGA_HANDLERS,SagaHandler,fromHeader,fromJwtPayload,getActor,getGraphToken,getNodeToken,observeSSE,observeSubscription,toObservable});
|
|
15
|
+
`)}function Bo(t){return t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function yt(t){let e="^";for(let n=0;n<t.length;n+=1){let r=t[n];if(r==="*"){e+=".*";continue}if(r==="?"){e+=".";continue}if(r==="["){let o=t.indexOf("]",n+1);if(o<=n+1){e+="\\[";continue}let s=t.slice(n+1,o);s.startsWith("!")&&(s=`^${s.slice(1)}`),s=s.replace(/\\/g,"\\\\"),e+=`[${s}]`,n=o;continue}e+=Bo(r)}return e+="$",new RegExp(e)}var Vo={data:"\x1B[32m",dirty:"\x1B[33m",resolved:"\x1B[36m",invalidate:"\x1B[93m",pause:"\x1B[90m",resume:"\x1B[96m",complete:"\x1B[34m",error:"\x1B[31m",teardown:"\x1B[91m",derived:"\x1B[35m",path:"\x1B[90m",reset:"\x1B[0m"},Wo={data:"",dirty:"",resolved:"",invalidate:"",pause:"",resume:"",complete:"",error:"",teardown:"",derived:"",path:"",reset:""};function bt(t){if(typeof t=="string")return JSON.stringify(t);if(typeof t=="number"||typeof t=="boolean"||t==null)return String(t);try{return JSON.stringify(t)}catch{return"[unserializable]"}}function zo(t){return t==="none"?Wo:t==="ansi"||t==null?Vo:{data:t.data??"",dirty:t.dirty??"",resolved:t.resolved??"",invalidate:t.invalidate??"",pause:t.pause??"",resume:t.resume??"",complete:t.complete??"",error:t.error??"",teardown:t.teardown??"",derived:t.derived??"",path:t.path??"",reset:t.reset??""}}function gr(t){if(t==null)return{};let e=t.detail;return e==="full"?{...t,structured:t.structured??!0,timeline:t.timeline??!0,causal:t.causal??!0,derived:t.derived??!0}:e==="minimal"?{...t,structured:t.structured??!0}:t.format==="stage-log"?{...t,structured:t.structured??!0,timeline:t.timeline??!0}:t}function Uo(t,e,n){for(let r=0;r<t.length;r++){let o=t.charCodeAt(r);if(o<32||o===127)throw new Error(`Graph "${e}": ${n} "${t}" must not contain control character (U+${o.toString(16).padStart(4,"0").toUpperCase()} at index ${r})`)}}function Vt(t,e,n){if(t==="")throw new Error(`Graph "${e}": ${n} name must be non-empty`);if(t.includes(I))throw new Error(`Graph "${e}": ${n} "${t}" must not contain '${I}' (path separator)`);if(t===Q)throw new Error(`Graph "${e}": ${n} name "${Q}" is reserved for meta companion paths`);Uo(t,e,n)}function Ko(t,e){if(t==="")throw new Error(`Graph "${e}": resolve path must be non-empty`);let n=t.split(I);for(let r of n)if(r==="")throw new Error(`Graph "${e}": resolve path has empty segment`);return n}function Yo(t,e){let n=!1;for(let o of t)if(!e.isMetaPassthrough(o[0])){n=!0;break}return n?t.filter(o=>e.isMetaPassthrough(o[0])):t}function _r(t){for(let e of t._mounts.values())_r(e);for(let e of t._nodes.values())try{e.down([[F]],{internal:!0})}catch{}}var ie=class t{name;opts;config;_nodes=new Map;_nodeToName=new WeakMap;_mounts=new Map;_parent=void 0;_storageDisposers=new Set;_disposers=new Set;_topology;_topologyEmitters=new Set;constructor(e,n){if(e==="")throw new Error("Graph name must be non-empty");if(e.includes(I))throw new Error(`Graph name must not contain '${I}' (got "${e}")`);if(e===Q)throw new Error(`Graph name "${Q}" is reserved for meta companion paths`);this.name=e,this.opts=Object.freeze({...n??{}}),this.config=n?.config??ye,this._traceRing=new Qe(n?.traceCapacity??1e3),n?.versioning!=null&&this.setVersioning(n.versioning)}ancestors(e=!0){let n=[],r=e?this:this._parent;for(;r!=null;)n.push(r),r=r._parent;return n}get topology(){return this._topology==null&&(this._topology=Le(e=>{let n=r=>{e.emit(r)};return this._topologyEmitters.add(n),()=>{this._topologyEmitters.delete(n)}},{name:`${this.name}_topology`})),this._topology}_emitTopology(e){if(!(this._topology==null||this._topologyEmitters.size===0))for(let n of this._topologyEmitters)n(e)}add(e,n){let r=e.name,o=n?.name??r;if(o==null||o==="")throw new Error(`Graph "${this.name}": graph.add requires a non-empty name \u2014 pass via opts.name or set it on the node (e.g. state(0, { name: "x" }))`);let s=o,i=n?.annotation;if(Vt(s,this.name,"add"),this._mounts.has(s))throw new Error(`Graph "${this.name}": name "${s}" is already a mount point`);if(this._nodes.has(s))throw new Error(`Graph "${this.name}": node "${s}" already exists`);let a=this._nodeToName.get(e);if(a!==void 0)throw new Error(`Graph "${this.name}": node instance already registered as "${a}"`);return this._nodes.set(s,e),this._nodeToName.set(e,s),this._emitTopology({kind:"added",name:s,nodeKind:"node"}),i!=null&&(this._annotations.set(s,i),this.config.inspectorEnabled&&this._traceRing.push({path:s,annotation:i,timestamp_ns:Re()})),e}setVersioning(e){if(e!=null)for(let n of this._nodes.values())n instanceof P&&n._applyVersioning(e)}remove(e){Vt(e,this.name,"remove");let n=this._mounts.get(e);if(n){let s={kind:"mount",nodes:[],mounts:[]},i=[];n._collectObserveTargets("",i);for(let[a,d]of i)a.includes(`${I}${Q}${I}`)||s.nodes.push(a);return s.nodes.sort(),s.mounts.push(e),s.mounts.push(...n._collectSubgraphs(`${e}${I}`)),this._mounts.delete(e),n._parent=void 0,_r(n),this._emitTopology({kind:"removed",name:e,nodeKind:"mount",audit:s}),s}let r=this._nodes.get(e);if(!r)throw new Error(`Graph "${this.name}": unknown node or mount "${e}"`);this._nodes.delete(e),this._nodeToName.delete(r),r.down([[F]],{internal:!0});let o={kind:"node",nodes:[e],mounts:[]};return this._emitTopology({kind:"removed",name:e,nodeKind:"node",audit:o}),o}removeAll(e){let n=typeof e=="function"?e:(()=>{let s=yt(e);return i=>s.test(i)})(),r={kind:"mount",nodes:[],mounts:[]},o=[...this._nodes.keys(),...this._mounts.keys()].filter(s=>n(s));for(let s of o){let i=this.remove(s);r.nodes.push(...i.nodes),r.mounts.push(...i.mounts)}return r.nodes.sort(),r.mounts.sort(),r}[Symbol.iterator](){let e=[...this._nodes.keys()].sort(),n=this._nodes,r=0;return{[Symbol.iterator](){return this},next(){if(r>=e.length)return{value:void 0,done:!0};let o=e[r++];return{value:[o,n.get(o)],done:!1}}}}node(e){if(e==="")throw new Error(`Graph "${this.name}": node name must be non-empty`);if(e.includes(I))return this.resolve(e);let n=this._nodes.get(e);if(!n)throw new Error(`Graph "${this.name}": unknown node "${e}"`);return n}get(e){return this.node(e).cache}set(e,n,r){let o=r?.internal===!0;this.node(e).down([[R,n]],{actor:r?.actor,internal:o,delivery:"write"})}setAll(e,n){let r=Symbol.iterator in e?e:Object.entries(e);Ae(()=>{for(let[o,s]of r)this.set(o,s,n)})}invalidate(e,n){let r=n?.internal===!0;this.node(e).down([[ee]],{actor:n?.actor,internal:r,delivery:"write"})}error(e,n,r){let o=r?.internal===!0;this.node(e).down([[A,n]],{actor:r?.actor,internal:o,delivery:"write"})}complete(e,n){let r=n?.internal===!0;this.node(e).down([[L]],{actor:n?.actor,internal:r,delivery:"write"})}edges(e){let n=e?.recursive===!0,r=new Map;if(!n){for(let[d,u]of this._nodes)r.set(u,d);let a=[];for(let[d,u]of this._nodes)if(u instanceof P)for(let l of u._deps){let f=r.get(l.node);f!=null&&a.push([f,d])}return a.sort((d,u)=>d[0]<u[0]?-1:d[0]>u[0]?1:d[1]<u[1]?-1:d[1]>u[1]?1:0),a}let o=[];this._collectObserveTargets("",o);let s=new Map;for(let[a,d]of o)s.set(d,a);let i=[];for(let[a,d]of o)if(d instanceof P)for(let u of d._deps){let l=s.get(u.node);l!=null&&i.push([l,a])}return i.sort((a,d)=>a[0]<d[0]?-1:a[0]>d[0]?1:a[1]<d[1]?-1:a[1]>d[1]?1:0),i}mount(e,n){if(Vt(e,this.name,"mount"),this._nodes.has(e))throw new Error(`Graph "${this.name}": cannot mount at "${e}" \u2014 node with that name exists`);if(this._mounts.has(e))throw new Error(`Graph "${this.name}": mount "${e}" already exists`);if(n===this)throw new Error(`Graph "${this.name}": cannot mount a graph into itself`);if(n._parent!=null)throw new Error(`Graph "${this.name}": this child graph is already mounted on "${n._parent.name}"`);for(let r=this;r!=null;r=r._parent)if(r===n)throw new Error(`Graph "${this.name}": mount("${e}", \u2026) would create a mount cycle`);return this._mounts.set(e,n),n._parent=this,this._emitTopology({kind:"added",name:e,nodeKind:"mount"}),n}resolve(e){let n=Ko(e,this.name);return this._resolveFromSegments(n)}tryResolve(e){try{return this.resolve(e)}catch{return}}_resolveFromSegments(e){let n=e;if(n[0]===this.name&&(n=n.slice(1),n.length===0))throw new Error(`Graph "${this.name}": resolve path ends at graph name only`);let r=n[0],o=n.slice(1);if(o.length===0){let a=this._nodes.get(r);if(a)return a;throw this._mounts.has(r)?new Error(`Graph "${this.name}": path ends at subgraph "${r}" \u2014 not a node (GRAPHREFLY-SPEC \xA73.5)`):new Error(`Graph "${this.name}": unknown name "${r}"`)}let s=this._nodes.get(r);if(s&&o.length>0&&o[0]===Q)return this._resolveMetaChainFromNode(s,o,n.join(I));let i=this._mounts.get(r);if(!i)throw this._nodes.has(r)?new Error(`Graph "${this.name}": "${r}" is a node; trailing path "${o.join(I)}" is invalid`):new Error(`Graph "${this.name}": unknown mount or node "${r}"`);return i.resolve(o.join(I))}_resolveMetaChainFromNode(e,n,r){let o=e,s=0,i=[...n];for(;s<i.length;){if(i[s]!==Q)throw new Error(`Graph "${this.name}": expected ${Q} segment in meta path "${r}"`);if(s+1>=i.length)throw new Error(`Graph "${this.name}": meta path requires a key after ${Q} in "${r}"`);let a=i[s+1],d=o.meta[a];if(!d)throw new Error(`Graph "${this.name}": unknown meta "${a}" in path "${r}"`);o=d,s+=2}return o}signal(e,n){if(n?.internal!==!0){for(let o of e)if(this.config.messageTier(o[0])===3)throw new Error(`Graph "${this.name}": Graph.signal() rejects tier-3 messages (DATA / RESOLVED). Broadcast is for control-plane tiers (START / DIRTY / INVALIDATE / PAUSE / RESUME / COMPLETE / ERROR / TEARDOWN). For per-node value writes, use Graph.set or graph.node(name).down(...).`)}let r=[];if(this._signalDeliver(e,n??{},new Set,r),r.length>0)throw r[0]}_signalDeliver(e,n,r,o){for(let d of this._mounts.values())d._signalDeliver(e,n,r,o);let i=n.internal===!0?{internal:!0}:{actor:n.actor,delivery:"signal"},a=Yo(e,this.config);for(let d of[...this._nodes.keys()].sort()){let u=this._nodes.get(d);if(!r.has(u)){r.add(u);try{u.down(e,i)}catch(l){if(l instanceof J)throw l;o.push(l)}a.length!==0&&this._signalMetaSubtree(u,a,r,i,o)}}}_signalMetaSubtree(e,n,r,o,s){for(let i of Object.keys(e.meta).sort()){let a=e.meta[i];if(!r.has(a)){r.add(a);try{a.down(n,o)}catch(d){if(d instanceof J)throw d;s.push(d)}this._signalMetaSubtree(a,n,r,o,s)}}}describe(e){if(e?.reactive===!0)return this._describeReactive(e);let n=e?.actor,r=e?.filter,o=dt(e?.detail,e?.fields),s=e?.format==="spec",i=s?dt("minimal"):o,a=[];this._collectObserveTargets("",a);let d=new Map;for(let[T,w]of a)d.set(w,T);let u=[];{let T=a.map(([,N])=>N),w=new Set(d.values()),E=0;for(;T.length>0;){let N=T.shift();if(N instanceof P)for(let M of N._deps){let S=M.node;if(d.has(S))continue;let C=S.name??"",k=C;if(!k||w.has(k))if(C){let $=2;for(;w.has(`${C}#${$}`);)$++;k=`${C}#${$}`}else for(k=`__internal__/${E++}`;w.has(k);)k=`__internal__/${E++}`;d.set(S,k),w.add(k),u.push([k,S]),T.push(S)}}}let l=[...a,...u],f={};for(let[T,w]of l){if(n!=null&&!w.allowsObserve(n))continue;let E=jt(w,i),N=w instanceof P?w._deps.map(k=>d.get(k.node)??k.node.name??""):[],{name:M,...S}=E,C={...S,deps:N};if(!s){let k=this._annotations.get(T);k!=null&&(C.annotation=k)}if(r!=null)if(typeof r=="function"){let k=r;if(!(k.length>=2?k(T,C):k(C)))continue}else{let k=!0;for(let[$,B]of Object.entries(r)){let X=$==="deps_includes"?"depsIncludes":$==="meta_has"?"metaHas":$;if(X==="depsIncludes"){if(!C.deps.includes(String(B))){k=!1;break}continue}if(X==="metaHas"){if(!Object.hasOwn(C.meta??{},String(B))){k=!1;break}continue}if(C[X]!==B){k=!1;break}}if(!k)continue}f[T]=C}let p=new Set(Object.keys(f)),h=[];for(let[T,w]of l)if(w instanceof P)for(let E of w._deps){let N=d.get(E.node);N!=null&&h.push([N,T])}h.sort((T,w)=>T[0]<w[0]?-1:T[0]>w[0]?1:T[1]<w[1]?-1:T[1]>w[1]?1:0);let c=h.map(([T,w])=>({from:T,to:w}));(n!=null||r!=null)&&(c=c.filter(T=>p.has(T.from)&&p.has(T.to)));let g=this._collectSubgraphs(""),m=n!=null||r!=null?g.filter(T=>{let w=`${T}${I}`;return[...p].some(E=>E===T||E.startsWith(w))}):g,v=this,_=e,y={name:this.name,nodes:f,edges:c,subgraphs:m,expand(T){let w={..._,format:void 0};return Array.isArray(T)?(w.fields=T,w.detail=void 0):(w.detail=T,w.fields=void 0),v.describe(w)}},b=e??{},x=b.format;return x==="json"?Ho(y,b):x==="pretty"?Fo(y,b):x==="mermaid"?br(y,b):x==="mermaid-url"?qo(y,b):x==="d2"?jo(y,b):x==="ascii"?ir(y,b):y}_collectSubgraphs(e){let n=[];for(let r of[...this._mounts.keys()].sort()){let o=e===""?r:`${e}${r}`;n.push(o),n.push(...this._mounts.get(r)._collectSubgraphs(`${o}${I}`))}return n}resourceProfile(e){return fr(this,e)}reachable(e,n,r={}){return r.withDetail===!0?zt(this.describe(),e,n,{...r,withDetail:!0}):zt(this.describe(),e,n,r)}explain(e,n,r){return r?.reactive===!0?this._explainReactive(e,n,r):this._explainStatic(e,n,r)}_explainStatic(e,n,r){let o=this.describe({detail:"full"}),s=new Map(this._annotations),i=new Map;for(let[a,d]of Object.entries(o.nodes))d.lastMutation!=null&&i.set(a,d.lastMutation);return ar(o,e,n,{...r?.maxDepth!=null?{maxDepth:r.maxDepth}:{},...r?.findCycle===!0?{findCycle:!0}:{},annotations:s,lastMutations:i})}_describeReactive(e){let n={...e,reactive:!1},r=e.reactiveName??"describe",o=0,s=oe(o,{name:`${r}_version`}),i=this.observe({timeline:!0,structured:!0}),a=!1,d=!1,u=()=>{a||d||(a=!0,ze(()=>{a=!1,!d&&(o+=1,s.emit(o))}))},l=i.onEvent(m=>{let v=m.type;v!=="data"&&v!=="error"&&v!=="complete"&&v!=="teardown"||u()}),f=[],p=new WeakSet,h=m=>{if(p.has(m)||d)return;p.add(m);let v=m.topology.subscribe(_=>{for(let y of _){if(y[0]!==R)continue;let b=y[1];if(u(),b.kind==="added"&&b.nodeKind==="mount"){let x=m._mounts.get(b.name);x!=null&&h(x)}}});f.push(v);for(let _ of m._mounts.keys()){let y=m._mounts.get(_);y!=null&&h(y)}};h(this);let c;try{c=se([s],()=>this.describe(n),{name:r,describeKind:"derived",meta:{domain:"audit",kind:"describe"},equals:(m,v)=>m===v})}catch(m){l();for(let v of f)v();throw i.dispose(),m}let g=de(c);return{node:c,dispose(){d=!0,l();for(let m of f)m();f.length=0,i.dispose(),g()}}}_explainReactive(e,n,r){let o=0,s=oe(o,{name:"explain_version"}),i=this.observe({timeline:!0,structured:!0}),a=!1,d=!1,u=i.onEvent(h=>{let c=h.type;c!=="data"&&c!=="error"&&c!=="complete"&&c!=="teardown"||a||d||(a=!0,ze(()=>{a=!1,!d&&(o+=1,s.emit(o))}))}),l={...r?.maxDepth!=null?{maxDepth:r.maxDepth}:{},...r?.findCycle===!0?{findCycle:!0}:{}},f;try{f=se([s],()=>this._explainStatic(e,n,l),{name:r?.name??"explain",describeKind:"derived",meta:{domain:"audit",kind:"explain_path",from:e,to:n},equals:(h,c)=>h.found===c.found&&h.reason===c.reason&&h.steps.length===c.steps.length&&Jo(h.steps,c.steps)})}catch(h){throw u(),i.dispose(),h}let p=de(f);return{node:f,dispose(){d=!0,u(),i.dispose(),p()}}}_pathsMatching(e){let n=yt(e),r=[];return this._collectObserveTargets("",r),r.map(([o])=>o).filter(o=>n.test(o))}_collectObserveTargets(e,n){for(let r of[...this._mounts.keys()].sort()){let o=e===""?r:`${e}${I}${r}`;this._mounts.get(r)._collectObserveTargets(o,n)}for(let r of[...this._nodes.keys()].sort()){let o=this._nodes.get(r),s=e===""?r:`${e}${I}${r}`;n.push([s,o]),this._appendMetaObserveTargets(s,o,n)}}_appendMetaObserveTargets(e,n,r){for(let o of Object.keys(n.meta).sort()){let s=n.meta[o],i=`${e}${I}${Q}${I}${o}`;r.push([i,s]),this._appendMetaObserveTargets(i,s,r)}}observe(e,n){let r=typeof e=="string",s=gr(r?n:e),i=s.structured===!0||s.timeline===!0||s.causal===!0||s.derived===!0||s.detail==="minimal"||s.detail==="full"||s.format!=null,a=s.actor;if(r){let l=e,f=this.resolve(l);if(a!=null&&!f.allowsObserve(a))throw new J({actor:a,action:"observe",nodeName:l});return i?this._buildStructuredObserver([[l,f]],s,"one"):{subscribe(p){return f.subscribe(p)},up(p){try{f.up?.(p)}catch(h){if(h instanceof J)return;throw h}}}}let d=[];this._collectObserveTargets("",d),d.sort((l,f)=>l[0]<f[0]?-1:l[0]>f[0]?1:0);let u=a==null?d:d.filter(([,l])=>l.allowsObserve(a));return i?this._buildStructuredObserver(u,s,"all"):{subscribe:l=>{let f=u.map(([p,h])=>h.subscribe(c=>{l(p,c)}));return()=>{for(let p of f)p()}},up:(l,f)=>{try{this.resolve(l).up?.(f)}catch(p){if(p instanceof J)return;throw p}}}}_buildStructuredObserver(e,n,r){let o=r==="one"?e[0]?.[0]:void 0,s=i=>{if(r==="one"&&o!=null){let l=this.resolve(o);return this._buildStructuredObserver([[o,l]],i,"one")}let a=[];this._collectObserveTargets("",a),a.sort((l,f)=>l[0]<f[0]?-1:l[0]>f[0]?1:0);let d=i.actor,u=d==null?a:a.filter(([,l])=>l.allowsObserve(d));return this._buildStructuredObserver(u,i,"all")};return this._createObserveResult(e,n,s)}_createObserveResult(e,n,r){let o=n.timeline===!0,s=n.causal===!0,i=n.derived===!0,a=n.detail==="minimal",d=this.config.inspectorEnabled,u=(s||i)&&d,l=n.maxEvents,f=l!=null&&l>0?new Qe(l):null,p=[],h=new Set,c={},g=new Set,m=0,v=0,_=0,y=0,b=0,x=0,T=!1,w=!1,E=0,N=new Map,M=new Map,S=new Map,C=O=>{f?f.push(O):p.push(O);for(let G of h)G(O)},k=()=>o?{timestamp_ns:Re(),in_batch:et(),batch_id:E}:{},$=(O,G)=>{if(!(!u||!(O instanceof P)))return O._setInspectorHook(z=>{if(z.kind==="dep_message")N.set(O,z.depIndex);else if(z.kind==="run"){let Pe=z.batchData.map((D,q)=>D!=null&&D.length>0?D.at(-1):z.prevData[q]);M.set(O,Pe);let U=z.batchData.map(D=>D!=null?[...D]:void 0);S.set(O,U),i&&C({type:"derived",path:G,dep_values:Pe,dep_batches:U,...k()})}})},B=O=>{let G=N.get(O),z=M.get(O);if(!s||z==null)return{};let U=(G!=null&&G>=0&&O instanceof P?O._deps[G]:void 0)?.node,D=U?.v,q=S.get(O);return{trigger_dep_index:G,trigger_dep_name:U?.name,...D!=null?{trigger_version:{id:D.id,version:D.version}}:{},dep_values:[...z],...q!=null?{dep_batches:q}:{}}},X=[],fe=[];for(let[O,G]of e){let z=$(G,O);z&&X.push(z),fe.push(G.subscribe(Pe=>{E++;for(let U of Pe){let D=U[0],q=k();if(D===R){c[O]=U[1];let Et=G instanceof P?G.lastMutation?.actor??ue:ue;C({type:"data",path:O,data:U[1],actor:Et,...q,...B(G)})}else if(a)D===W?m++:D===Z?v++:D===ee?_++:D===K?y++:D===te?b++:D===F?x++:D===L&&!g.has(O)?T=!0:D===A&&(w=!0,g.add(O));else if(D===W)m++,C({type:"dirty",path:O,...q});else if(D===Z)v++,C({type:"resolved",path:O,...q,...B(G)});else if(D===ee)_++,C({type:"invalidate",path:O,...q});else if(D===K)y++,C({type:"pause",path:O,lockId:U[1],...q});else if(D===te)b++,C({type:"resume",path:O,lockId:U[1],...q});else if(D===L)g.has(O)||(T=!0),C({type:"complete",path:O,...q});else if(D===A){w=!0,g.add(O);let Et=G instanceof P?G.lastMutation?.actor??ue:ue;C({type:"error",path:O,data:U[1],actor:Et,...q})}else D===F&&(x++,C({type:"teardown",path:O,...q}))}}))}let wt=!1,xt=()=>{if(!wt){wt=!0;for(let O of fe)O();for(let O of X)O();for(let O of Ze)O({value:void 0,done:!0});Ze.length=0}},Tt=[],Ze=[];h.add(O=>{let G=Ze.shift();G?G({value:O,done:!1}):Tt.push(O)});let Xt={get values(){return c},get dirtyCount(){return m},get resolvedCount(){return v},get invalidateCount(){return _},get pauseCount(){return y},get resumeCount(){return b},get teardownCount(){return x},get events(){return f?f.toArray():[...p]},get anyCompletedCleanly(){return T},get anyErrored(){return w},get completedWithoutErrors(){return T&&!w},onEvent(O){return h.add(O),()=>h.delete(O)},dispose:xt,expand(O){xt();let G={...n};return typeof O=="string"?G.detail=O:Object.assign(G,O),r(gr(G))},[Symbol.asyncIterator](){return{next(){return Tt.length>0?Promise.resolve({value:Tt.shift(),done:!1}):wt?Promise.resolve({value:void 0,done:!0}):new Promise(O=>Ze.push(O))},return(){return xt(),Promise.resolve({value:void 0,done:!0})}}}};return n.format!=null&&this._attachFormatLogger(Xt,n),Xt}_attachFormatLogger(e,n){let r=n.format;if(r==null)return;let o=n.logger??(c=>console.log(c)),s=n.includeTypes?new Set(n.includeTypes):null,i=n.excludeTypes?new Set(n.excludeTypes):null,a=s==null&&i==null?()=>!0:c=>(s==null||s.has(c))&&(i==null||!i.has(c)),d=zo(n.theme),u=r==="stage-log"?Re():0,l=c=>c==null?"":n.stageLabels?.[c]??c,f=(c,g)=>c.length>g?`${c.slice(0,g-1)}\u2026`:c,p=c=>c.type==="data"||c.type==="error"?f(bt(c.data),120):"",h=c=>{if(r==="stage-log"){let w=(Re()-u)/1e9,E=l(c.path).padEnd(9);if(c.type==="data"){let N=p(c);return`[${w.toFixed(3)}s] ${E} \u2190${N?` ${N}`:""}`}if(c.type==="error"){let N=p(c);return`[${w.toFixed(3)}s] ${E} \u2717${N?` ${N}`:""}`}return c.type==="complete"?`[${w.toFixed(3)}s] ${E} \u25A0 complete`:`[${w.toFixed(3)}s] ${E} ${c.type}`}if(r==="json")try{return JSON.stringify(c)}catch{return JSON.stringify({type:c.type,path:c.path,data:"[unserializable]"})}let g=d[c.type]??"",m=c.path?`${d.path}${c.path}${d.reset} `:"",v=c.type==="data"||c.type==="error",_=c.type==="pause"||c.type==="resume",y=v?` ${bt(c.data)}`:_?` ${bt(c.lockId)}`:"",b=c.type==="data"||c.type==="resolved"||c.type==="derived"?c:void 0,x=b?.trigger_dep_name!=null?` <- ${b.trigger_dep_name}`:b?.trigger_dep_index!=null?` <- #${b.trigger_dep_index}`:"",T=c.in_batch?" [batch]":"";return`${m}${g}${c.type.toUpperCase()}${d.reset}${y}${x}${T}`};e.onEvent(c=>{a(c.type)&&o(h(c),c)})}addDisposer(e){return this._disposers.add(e),()=>{this._disposers.delete(e)}}destroy(){pr(this._disposers,this.name),this.signal([[F]],{internal:!0}),pr(this._storageDisposers,this.name);for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0}_destroyClearOnly(){for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0}snapshot(e){let{expand:n,...r}=this.describe({detail:"full"}),o={};for(let a of Object.keys(r.nodes).sort()){let{lastMutation:d,guard:u,...l}=r.nodes[a];o[a]=l}let s=[...r.subgraphs].sort(),i={...r,version:1,nodes:o,subgraphs:s};if(e?.format==null)return i;if(e.format==="json-string")return JSON.stringify(i);if(e.format==="bytes"){if(e.codec==null)throw new Error("snapshot({format: 'bytes'}) requires a `codec` name");let a=this.config.lookupCodec(e.codec);if(a==null)throw new Error(`snapshot: codec "${e.codec}" is not registered on this graph's config. Call config.registerCodec(...) before creating nodes.`);return En(a,a.encode(i))}throw new Error(`snapshot: unknown format "${String(e.format)}"`)}static decode(e,n){let r=n?.config??ye,{codec:o,codecVersion:s,payload:i}=On(e,r);return o.decode(i,s)}restore(e,n){if(hr(e),e.name!==this.name)throw new Error(`Graph "${this.name}": restore snapshot name "${e.name}" does not match this graph`);let r=n?.only==null?null:(Array.isArray(n.only)?n.only:[n.only]).map(s=>yt(s)),o=n?.includeProducers===!0;for(let s of Object.keys(e.nodes).sort()){if(r!==null&&!r.some(a=>a.test(s)))continue;let i=e.nodes[s];if(i!==void 0){if(!("value"in i)||i.value===void 0){"value"in i&&i.value===void 0&&n?.onError?.(s,new Error(`restore: slice.value is undefined for "${s}" (undefined is the global SENTINEL; not valid DATA)`));continue}if(!(i.type==="derived"||i.type==="effect")&&!(i.type==="producer"&&!o)){if(i.v!=null){let d=this.tryResolve(s)?.v;if(d!=null&&d.id===i.v.id&&d.version===i.v.version)continue}try{this.set(s,i.value)}catch(a){n?.onError?.(s,a)}}}}}static fromSnapshot(e,n){hr(e);let r=typeof n=="function"?n:n?.build,o=typeof n=="function"?void 0:n?.factories,s=new t(e.name);if(r)return r(s),s.restore(e),s;for(let h of[...e.subgraphs].sort((c,g)=>{let m=c.split(I).length,v=g.split(I).length;return m!==v?m-v:c<g?-1:c>g?1:0})){let c=h.split(I),g=s;for(let m of c)g._mounts.has(m)||g.mount(m,new t(m)),g=g._mounts.get(m)}let i=o?Object.entries(o).map(([h,c])=>({re:yt(h),factory:c})):[],a=h=>{for(let c of i)if(c.re.test(h))return c.factory},d=h=>{let c=h.split(I),g=c.pop();if(g==null||g.length===0)throw new Error(`invalid snapshot path "${h}"`);let m=s;for(let v of c){let _=m._mounts.get(v);if(!_)throw new Error(`unknown mount "${v}" in path "${h}"`);m=_}return[m,g]},u=Object.entries(e.nodes).filter(([h])=>!h.includes(`${I}${Q}${I}`)).sort((h,c)=>h[0]<c[0]?-1:h[0]>c[0]?1:0),l=new Map(u),f=new Map,p=!0;for(;l.size>0&&p;){p=!1;for(let[h,c]of[...l.entries()]){let g=c?.deps??[];if(!g.every(x=>f.has(x)))continue;let[m,v]=d(h),_={...c?.meta??{}},y=a(h),b;if(c?.type==="state")b=oe(c.value,{meta:_});else{if(y==null)continue;b=y(v,{path:h,type:c.type,value:c.value,meta:_,deps:g,resolvedDeps:g.map(x=>f.get(x))})}m.add(b,{name:v}),f.set(h,b),l.delete(h),p=!0}}if(l.size>0){let h=[...l.keys()].sort().join(", ");throw new Error(`Graph.fromSnapshot could not reconstruct nodes without build callback: ${h}. Pass matching factories via fromSnapshot(data, { factories: { pattern: factoryFn } }).`)}return s.restore(e),s}toJSON(){return this.snapshot()}attachStorage(e,n={}){let r=e.map(u=>({tier:u,debounceMs:Math.max(0,u.debounceMs??0),compactEvery:Math.max(1,u.compactEvery??10),timer:void 0,seq:0,lastSnapshot:void 0,lastFingerprint:"",disposed:!1,savePending:void 0}));n.autoRestore===!0&&this._cascadeRestore(e,n.onError);let o=(u,l)=>{if(u.disposed)return;let f=Go(l.nodes);if(u.lastSnapshot!=null&&f!==""&&f===u.lastFingerprint)return;let p=u.seq+1,h=ae(),m=u.lastSnapshot==null||p%u.compactEvery===0?{mode:"full",snapshot:l,seq:p,timestamp_ns:h,format_version:_e}:{mode:"diff",diff:wr(u.lastSnapshot,l),seq:p,timestamp_ns:h,format_version:_e};if(u.tier.filter&&!u.tier.filter(this.name,m))return;let v;try{v=u.tier.save(this.name,m)}catch(_){n.onError?.(_,u.tier);return}if(v&&typeof v.then=="function"){let b=(u.savePending??Promise.resolve()).then(()=>v,()=>v).then(()=>{u.disposed||(u.seq=p,u.lastSnapshot=l,u.lastFingerprint=f)},x=>{n.onError?.(x,u.tier)});u.savePending=b.finally(()=>{u.savePending===b&&(u.savePending=void 0)})}else u.seq=p,u.lastSnapshot=l,u.lastFingerprint=f},s=(u,l)=>{try{o(u,l)}catch(f){n.onError?.(f,u.tier)}},i=(u,l)=>{if(!l.some(c=>{let g=this.config.messageTier(c[0]);return g>=3&&g<5}))return;if(n.filter){let c=this.tryResolve(u);if(c==null)return;let g=jt(c,dt("standard"));if(!n.filter(u,g))return}let p,h=()=>(p==null&&(p=this.snapshot()),p);for(let c of r)c.disposed||(c.debounceMs===0?s(c,h()):(c.timer==null&&(c.timer=new ct),c.timer.start(c.debounceMs,()=>{c.disposed||s(c,this.snapshot())})))},a;if(n.paths!=null){let l=(typeof n.paths=="string"?this._pathsMatching(n.paths):n.paths).map(f=>{let p=this.tryResolve(f);return p==null?()=>{}:p.subscribe(h=>i(f,h))});a=()=>{for(let f of l)f()}}else a=this.observe().subscribe((u,l)=>i(u,l));let d=()=>{a();for(let u of r)u.disposed=!0,u.timer?.cancel();this._storageDisposers.delete(d)};return this._storageDisposers.add(d),{dispose:d}}async _cascadeRestore(e,n){for(let r of e){let o;try{o=await r.load(this.name)}catch(i){n?.(i,r);continue}if(o==null||typeof o!="object"||Array.isArray(o))continue;let s=o;try{if(s.mode==="full"&&s.snapshot!=null)return this.restore(s.snapshot),!0;if(s.version===_e&&s.nodes!=null)return this.restore(s),!0}catch(i){n?.(i,r)}}return!1}static async fromStorage(e,n,r){for(let o of n){let s;try{s=await o.load(e)}catch(d){r?.onError?.(d,o);continue}if(s==null||typeof s!="object"||Array.isArray(s))continue;let i=s,a=i.mode==="full"&&i.snapshot!=null?i.snapshot:i.version===_e&&i.nodes!=null?i:void 0;if(a!=null)try{return t.fromSnapshot(a,r)}catch(d){r?.onError?.(d,o)}}throw new Error(`Graph.fromStorage: no tier held a restorable record for "${e}" across ${n.length} tier(s)`)}_annotations=new Map;_traceRing;trace(e,n,r){if(e!=null&&n!=null){if(this.tryResolve(e)==null)return;if(this._annotations.set(e,n),this.config.inspectorEnabled){let o={path:e,annotation:n,timestamp_ns:Re(),...r?.actor!=null?{actor:r.actor}:{}};this._traceRing.push(o)}return}return e!=null?this.config.inspectorEnabled?this._annotations.get(e):void 0:this.config.inspectorEnabled?this._traceRing.toArray():[]}annotation(e){return this._annotations.get(e)}clearTrace(){this._annotations.clear(),this._traceRing.clear()}pruneTrace(e){let n=this._traceRing.toArray().filter(o=>!e(o)),r=this._traceRing.size-n.length;this._traceRing.clear();for(let o of n)this._traceRing.push(o);return r}static diff(e,n){let r=new Set(Object.keys(e.nodes)),o=new Set(Object.keys(n.nodes)),s=[...o].filter(_=>!r.has(_)).sort(),i=[...r].filter(_=>!o.has(_)).sort(),a=[],d=[];for(let _ of r){if(!o.has(_))continue;let y=e.nodes[_],b=n.nodes[_],x=y.v,T=b.v;x!=null&&T!=null&&x.id===T.id&&x.version!==T.version&&d.push({path:_,id:x.id,from:x.version,to:T.version});let w=x!=null&&T!=null&&x.id===T.id&&x.version===T.version;for(let E of["type","status","sentinel"]){let N=y[E],M=b[E];N!==M&&a.push({path:_,field:E,from:N,to:M})}if(!w)for(let E of["value","meta"]){let N=y[E],M=b[E];Io(N,M)||a.push({path:_,field:E,from:N,to:M})}}let u=_=>`${_.from} ${_.to}`,l=new Set(e.edges.map(u)),f=new Set(n.edges.map(u)),p=n.edges.filter(_=>!l.has(u(_))),h=e.edges.filter(_=>!f.has(u(_))),c=new Set(e.subgraphs),g=new Set(n.subgraphs),m=[...g].filter(_=>!c.has(_)).sort(),v=[...c].filter(_=>!g.has(_)).sort();return{nodesAdded:s,nodesRemoved:i,nodesChanged:a,versionChanges:d,edgesAdded:p,edgesRemoved:h,subgraphsAdded:m,subgraphsRemoved:v}}};function wr(t,e){let n=ie.diff(t,e),r={};for(let o of n.nodesAdded){let s=e.nodes[o];s!=null&&(r[o]=s)}return{...n,nodesAddedFull:r}}function zt(t,e,n,r={}){let o={paths:[],depths:new Map,truncated:!1};if(!e)return r.withDetail?o:[];if(!r.both&&n!=="upstream"&&n!=="downstream")throw new Error('reachable: direction must be "upstream" or "downstream"');let s=r.maxDepth;if(s!=null&&(!Number.isInteger(s)||s<0))throw new Error("reachable: maxDepth must be an integer >= 0");if(s===0)return r.withDetail?o:[];let i=new Map,a=new Map,d=new Map,u=new Map,l=new Set;for(let[y,b]of Object.entries(t.nodes)){if(!y)continue;l.add(y);let x=b.deps??[];i.set(y,x);for(let T of x)T&&(l.add(T),a.has(T)||a.set(T,new Set),a.get(T).add(y))}for(let y of t.edges){if(y==null||typeof y!="object")continue;let b=typeof y.from=="string"?y.from:"",x=typeof y.to=="string"?y.to:"";!b||!x||(l.add(b),l.add(x),u.has(b)||u.set(b,new Set),u.get(b).add(x),d.has(x)||d.set(x,new Set),d.get(x).add(b))}if(!l.has(e))return r.withDetail?o:[];let f=r.both===!0,p=y=>{if(f){let w=i.get(y)??[],E=d.get(y),N=a.get(y),M=u.get(y),S=[...w];return E&&S.push(...E),N&&S.push(...N),M&&S.push(...M),S}if(n==="upstream"){let w=i.get(y)??[],E=d.get(y);return E?[...w,...E]:w}let b=a.get(y),x=u.get(y),T=b?[...b]:[];return x&&T.push(...x),T},h=new Set([e]),c=new Map,g=[{path:e,depth:0}],m=0,v=!1;for(;m<g.length;){let y=g[m++];if(s!=null&&y.depth>=s){p(y.path).length>0&&(v=!0);continue}for(let b of p(y.path))!b||h.has(b)||(h.add(b),c.set(b,y.depth+1),g.push({path:b,depth:y.depth+1}))}let _=[...c.keys()].sort((y,b)=>y<b?-1:y>b?1:0);return r.withDetail?{paths:_,depths:c,truncated:v}:_}function Jo(t,e){if(t.length!==e.length)return!1;for(let n=0;n<t.length;n++){let r=t[n],o=e[n];if(r.path!==o.path||r.type!==o.type||r.status!==o.status||r.hop!==o.hop||r.dep_index!==o.dep_index||r.annotation!==o.annotation||r.value!==o.value||r.lastMutation!==o.lastMutation)return!1;let s=r.v,i=o.v;if(s!==i&&(s==null||i==null||s.id!==i.id||s.version!==i.version))return!1}return!0}Ue();je();Ge();Be();Ge();Ie();Ke();Ue();re();Ke();var Ut=class{_version=0;_maxSize;_buf;_head=0;_size=0;constructor(e,n){if(n!==void 0&&n<1)throw new RangeError("maxSize must be >= 1");if(this._maxSize=n,n!==void 0){if(this._buf=new Array(n),e&&e.length>0){let r=Math.min(e.length,n),o=e.length-r;for(let s=0;s<r;s++)this._buf[s]=e[o+s];this._size=r}}else this._buf=e?[...e]:[],this._size=this._buf.length}get version(){return this._version}get size(){return this._size}at(e){if(!Number.isInteger(e))return;let n=e>=0?e:this._size+e;if(!(n<0||n>=this._size))return this._maxSize!==void 0?this._buf[(this._head+n)%this._maxSize]:this._buf[n]}append(e){this._rawAppend(e),this._version+=1}appendMany(e){if(e.length===0)return;let n=this._maxSize!==void 0&&e.length>this._maxSize?e.length-this._maxSize:0;for(let r=n;r<e.length;r++)this._rawAppend(e[r]);this._version+=1}clear(){if(this._size===0)return 0;let e=this._size;if(this._maxSize===void 0)this._buf.length=0;else for(let n=0;n<e;n++)this._buf[(this._head+n)%this._maxSize]=void 0;return this._head=0,this._size=0,this._version+=1,e}trimHead(e){if(!Number.isInteger(e)||e<0)throw new RangeError(`trimHead: n must be a non-negative integer (got ${e})`);if(e===0||this._size===0)return 0;let n=Math.min(e,this._size);if(this._maxSize===void 0)this._buf.splice(0,n);else{for(let r=0;r<n;r++)this._buf[(this._head+r)%this._maxSize]=void 0;this._head=(this._head+n)%this._maxSize}return this._size-=n,this._version+=1,n}slice(e,n){if(!Number.isInteger(e)||e<0)throw new RangeError(`slice: start must be a non-negative integer (got ${e})`);if(n!==void 0&&(!Number.isInteger(n)||n<0))throw new RangeError(`slice: stop must be a non-negative integer or undefined (got ${n})`);let r=n===void 0?this._size:Math.min(Math.max(n,0),this._size),o=Math.min(e,this._size);if(o>=r)return[];let s=r-o;if(this._maxSize===void 0)return this._buf.slice(o,r);let i=new Array(s);for(let a=0;a<s;a++)i[a]=this._buf[(this._head+o+a)%this._maxSize];return i}tail(e){if(!Number.isInteger(e)||e<0)throw new RangeError(`tail: n must be a non-negative integer (got ${e})`);if(e===0||this._size===0)return[];let n=Math.min(e,this._size);return this.slice(this._size-n,this._size)}toArray(){if(this._maxSize===void 0)return[...this._buf];let e=new Array(this._size);for(let n=0;n<this._size;n++)e[n]=this._buf[(this._head+n)%this._maxSize];return e}_rawAppend(e){if(this._maxSize===void 0){this._buf.push(e),this._size=this._buf.length;return}this._size<this._maxSize?(this._buf[(this._head+this._size)%this._maxSize]=e,this._size+=1):(this._buf[this._head]=e,this._head=(this._head+1)%this._maxSize)}};function xr(t){return t.subscribe(()=>{})}var Qo=64;function Tr(t,e={}){let{name:n,maxSize:r,versioning:o,backend:s}=e,i=s??new Ut(t,r),a=oe(i.toArray(),{name:n,describeKind:"state",equals:(c,g)=>c===g,...o!=null?{versioning:o}:{}});function d(){let c=i.toArray();Ae(()=>{a.down([[W]]),a.down([[R,c]])})}let u=new Map,l=new Map;function f(c,g){return`${c}:${g===void 0?"END":g}`}function p(c){if(c.size<Qo)return;let g=c.keys().next();if(g.done)return;let m=c.get(g.value);m!==void 0&&m.dispose(),c.delete(g.value)}function h(c){let g=i.version;try{return c()}finally{i.version!==g&&d()}}return{entries:a,get size(){return i.size},at(c){return i.at(c)},append(c){h(()=>i.append(c))},appendMany(c){c.length!==0&&h(()=>i.appendMany(c))},clear(){h(()=>i.clear())},trimHead(c){h(()=>i.trimHead(c))},tail(c){if(!Number.isInteger(c)||c<0)throw new RangeError(`tail: n must be a non-negative integer (got ${c})`);let g=u.get(c);if(g!==void 0)return u.delete(c),u.set(c,g),g.node;p(u);let m=se([a],([_])=>{let y=_;return c===0||y.length===0?[]:y.slice(Math.max(0,y.length-c))},{initial:i.tail(c),describeKind:"derived"}),v=xr(m);return u.set(c,{node:m,dispose:v}),m},slice(c,g){if(!Number.isInteger(c)||c<0)throw new RangeError(`slice: start must be a non-negative integer (got ${c})`);if(g!==void 0&&(!Number.isInteger(g)||g<0))throw new RangeError(`slice: stop must be a non-negative integer or undefined (got ${g})`);let m=f(c,g),v=l.get(m);if(v!==void 0)return l.delete(m),l.set(m,v),v.node;p(l);let _=se([a],([b])=>{let x=b;return g===void 0?x.slice(c):x.slice(c,g)},{initial:i.slice(c,g),describeKind:"derived"}),y=xr(_);return l.set(m,{node:_,dispose:y}),_},disposeTail(c){let g=u.get(c);return g===void 0?!1:(g.dispose(),u.delete(c),!0)},disposeSlice(c,g){let m=f(c,g),v=l.get(m);return v===void 0?!1:(v.dispose(),l.delete(m),!0)},disposeAllViews(){for(let c of u.values())c.dispose();u.clear();for(let c of l.values())c.dispose();l.clear()},dispose(){for(let c of u.values())c.dispose();u.clear();for(let c of l.values())c.dispose();l.clear()}}}st();function Er(t,e,n){return{[t]:!0,[`${t}_type`]:e,...n??{}}}var Xo=rt((t,e)=>{t("write"),t("signal"),e("observe")}),Zo=rt((t,e)=>{t("observe"),t("signal"),e("write")}),es=rt((t,e)=>{t("observe"),t("signal"),e("write")});function vt(t,e){return Er("cqrs",t,e)}var Kt=class extends ie{_eventLogs=new Map;_commandHandlers=new Map;_projections=new Set;_sagas=new Set;_keepaliveDisposers=[];_eventStore;_seq=0;constructor(e,n={}){super(e,n.graph)}destroy(){for(let e of this._keepaliveDisposers)e();this._keepaliveDisposers.length=0,super.destroy()}event(e){let n=this._eventLogs.get(e);if(n)return n.node;let r=Tr([],{name:e,versioning:0}),o=r.entries,s=se([o],([i])=>i,{name:e,describeKind:"state",meta:vt("event",{event_name:e}),guard:es,initial:o.cache});return this.add(s,{name:e}),this._keepaliveDisposers.push(de(s)),this._eventLogs.set(e,{log:r,node:s}),s}_appendEvent(e,n){let r=this._eventLogs.get(e);if(r||(this.event(e),r=this._eventLogs.get(e)),r.node.status==="completed"||r.node.status==="errored")throw new Error(`Cannot dispatch to terminated event stream "${e}" (status: ${r.node.status}).`);let o=r.log.entries.v,s={type:e,payload:n,timestampNs:ae(),seq:++this._seq,...o!=null?{v0:{id:o.id,version:o.version}}:{}};r.log.append(s),this._eventStore&&this._eventStore.persist(s)}command(e,n){let r=oe(void 0,{name:e,describeKind:"state",meta:{...vt("command",{command_name:e}),error:null},guard:Xo});return this.add(r,{name:e}),this._commandHandlers.set(e,n),r}dispatch(e,n){let r=this._commandHandlers.get(e);if(!r)throw new Error(`Unknown command: "${e}". Register with .command() first.`);let o=this.resolve(e);Ae(()=>{o.emit(n,{internal:!0});try{r(n,{emit:(s,i)=>this._appendEvent(s,i)}),o.meta.error.emit(null,{internal:!0})}catch(s){throw o.meta.error.emit(s,{internal:!0}),s}})}projection(e,n,r,o){let s=n.map(a=>(this._eventLogs.has(a)||this.event(a),this._eventLogs.get(a).node)),i=se(s,a=>{let d=[];for(let u of a){let l=u;d.push(...l)}return d.sort((u,l)=>u.timestampNs-l.timestampNs||u.seq-l.seq),r(o,d)},{name:e,describeKind:"derived",meta:vt("projection",{projection_name:e,source_events:n}),guard:Zo,initial:o});return this.add(i,{name:e}),this._keepaliveDisposers.push(de(i)),this._projections.add(e),i}saga(e,n,r){let o=n.map(d=>(this._eventLogs.has(d)||this.event(d),this._eventLogs.get(d).node)),s=new Map,i={},a=be(o,(d,u)=>{let l=i.n.meta.error;for(let f=0;f<d.length;f++){let p=d[f];if(p==null||p.length===0)continue;let h=p.at(-1);if(!h)continue;let c=n[f],g=s.get(c)??0;if(h.length>g){let m=h.slice(g);for(let v of m)try{r(v),l.emit(null,{internal:!0})}catch(_){l.emit(_,{internal:!0})}s.set(c,h.length)}}},{name:e,describeKind:"effect",meta:{...vt("saga",{saga_name:e,source_events:n}),error:null}});return i.n=a,this.add(a,{name:e}),this._keepaliveDisposers.push(de(a)),this._sagas.add(e),a}useEventStore(e){this._eventStore=e}async rebuildProjection(e,n,r){if(!this._eventStore)throw new Error("No event store wired. Call useEventStore() first.");let o=[];for(let s of e){let i=await this._eventStore.loadEvents(s);o.push(...i.events)}return o.sort((s,i)=>s.timestampNs-i.timestampNs||s.seq-i.seq),n(r,o)}};function Or(t,e){return new Kt(t,e)}var Jt=class{constructor(e){this.graph=e}onModuleDestroy(){this.graph.destroy()}},Qt=class{graph=new ie("request");onModuleDestroy(){this.graph.destroy()}},Nr,Yt;Nr=[(0,Xe.Module)({})];var le=class le{static forRoot(e){let n=e??{},r=n.name??"root",o=[{provide:Y,useFactory:()=>{let s=new ie(r);return n.build&&n.build(s),n.snapshot&&s.restore(n.snapshot),s}},{provide:Symbol.for("graphrefly:root-lifecycle"),useFactory:s=>new Jt(s),inject:[Y]},{provide:ve,useFactory:(s,i)=>new ve(s,i),inject:[Y,Sr.ModuleRef]}];if(n.nodes)for(let s of n.nodes)o.push({provide:ne(s),useFactory:i=>i.resolve(s),inject:[Y]});return n.requestScope&&o.push({provide:Symbol.for("graphrefly:request-lifecycle"),useFactory:()=>new Qt,scope:Xe.Scope.REQUEST},{provide:pe,useFactory:s=>s.graph,inject:[Symbol.for("graphrefly:request-lifecycle")],scope:Xe.Scope.REQUEST}),{module:le,global:!0,providers:o,exports:[Y,...(n.nodes??[]).map(ne),...n.requestScope?[pe]:[]]}}static forFeature(e){let n=[{provide:j(e.name),useFactory:r=>{let o=new ie(e.name);return e.build&&e.build(o),e.snapshot&&o.restore(e.snapshot),r.mount(e.name,o),o},inject:[Y]}];if(e.nodes)for(let r of e.nodes)n.push({provide:ne(`${e.name}::${r}`),useFactory:o=>o.resolve(r),inject:[j(e.name)]});return{module:le,providers:n,exports:[j(e.name),...(e.nodes??[]).map(r=>ne(`${e.name}::${r}`))]}}static forCqrs(e){let n=[{provide:j(e.name),useFactory:r=>{let o=Or(e.name,e.cqrs);return e.eventStore&&o.useEventStore(e.eventStore),e.build&&e.build(o),r.mount(e.name,o),o},inject:[Y]}];if(e.nodes)for(let r of e.nodes)n.push({provide:ne(`${e.name}::${r}`),useFactory:o=>o.resolve(r),inject:[j(e.name)]});return{module:le,providers:n,exports:[j(e.name),...(e.nodes??[]).map(r=>ne(`${e.name}::${r}`))]}}};Yt=on(null),le=un(Yt,0,"GraphReflyModule",Nr,le),an(Yt,1,le);var _t=le;0&&(module.exports={ACTOR_KEY,COMMAND_HANDLERS,CQRS_EVENT_HANDLERS,CRON_HANDLERS,CommandHandler,EVENT_HANDLERS,EventHandler,GRAPHREFLY_REQUEST_GRAPH,GRAPHREFLY_ROOT_GRAPH,GraphCron,GraphInterval,GraphReflyEventExplorer,GraphReflyGuard,GraphReflyGuardImpl,GraphReflyModule,INTERVAL_HANDLERS,InjectCqrsGraph,InjectGraph,InjectNode,ObserveGateway,OnGraphEvent,QUERY_HANDLERS,QueryHandler,SAGA_HANDLERS,SagaHandler,fromHeader,fromJwtPayload,getActor,getGraphToken,getNodeToken,observeSSE,observeSubscription,toObservable});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{A as B,B as C,C as D,D as E,E as F,F as G,a as b,b as c,c as d,d as e,e as f,f as g,g as h,h as i,i as j,j as k,k as l,l as m,m as n,n as o,o as p,p as q,q as r,r as s,s as t,t as u,u as v,v as w,w as x,x as y,y as z,z as A}from"../../chunk-
|
|
1
|
+
import{A as B,B as C,C as D,D as E,E as F,F as G,a as b,b as c,c as d,d as e,e as f,f as g,g as h,h as i,i as j,j as k,k as l,l as m,m as n,n as o,o as p,p as q,q as r,r as s,s as t,t as u,u as v,v as w,w as x,x as y,y as z,z as A}from"../../chunk-GF5T7PGC.js";import"../../chunk-Z3UWIJ3A.js";import"../../chunk-K54OKWNY.js";import"../../chunk-CZVYLXFK.js";import"../../chunk-7EQPXQ7H.js";import{a}from"../../chunk-5QDBSZBV.js";import"../../chunk-XRSHMHEG.js";import"../../chunk-PSQNYY72.js";import"../../chunk-SGS4OJGS.js";import"../../chunk-ESMPEKEV.js";import"../../chunk-N2KKISCE.js";import"../../chunk-UMH3HSP7.js";import"../../chunk-7AJKUA36.js";import"../../chunk-CK2E7BTU.js";import"../../chunk-QYADASLV.js";export{A as ACTOR_KEY,i as COMMAND_HANDLERS,j as CQRS_EVENT_HANDLERS,h as CRON_HANDLERS,s as CommandHandler,f as EVENT_HANDLERS,t as EventHandler,c as GRAPHREFLY_REQUEST_GRAPH,b as GRAPHREFLY_ROOT_GRAPH,r as GraphCron,q as GraphInterval,w as GraphReflyEventExplorer,F as GraphReflyGuard,E as GraphReflyGuardImpl,G as GraphReflyModule,g as INTERVAL_HANDLERS,n as InjectCqrsGraph,m as InjectGraph,o as InjectNode,z as ObserveGateway,p as OnGraphEvent,k as QUERY_HANDLERS,u as QueryHandler,l as SAGA_HANDLERS,v as SagaHandler,C as fromHeader,B as fromJwtPayload,D as getActor,d as getGraphToken,e as getNodeToken,x as observeSSE,y as observeSubscription,a as toObservable};
|