@directive-run/core 1.10.0 → 1.12.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/adapter-utils.d.cts +1 -1
- package/dist/adapter-utils.d.ts +1 -1
- package/dist/audit-ledger-9IElAHH9.d.ts +205 -0
- package/dist/audit-ledger-qMjEBqiP.d.cts +205 -0
- package/dist/chunk-26Z5VNPZ.js +16 -0
- package/dist/{chunk-FCOZCTLY.js.map → chunk-26Z5VNPZ.js.map} +1 -1
- package/dist/chunk-4VZOZWXM.cjs +2 -0
- package/dist/chunk-4VZOZWXM.cjs.map +1 -0
- package/dist/chunk-7NMXRATK.cjs +3 -0
- package/dist/chunk-7NMXRATK.cjs.map +1 -0
- package/dist/chunk-7TSYQEN3.js +2 -0
- package/dist/chunk-7TSYQEN3.js.map +1 -0
- package/dist/{chunk-2OS4RCLV.cjs → chunk-EX3XG667.cjs} +3 -3
- package/dist/{chunk-2OS4RCLV.cjs.map → chunk-EX3XG667.cjs.map} +1 -1
- package/dist/chunk-TPOKS4RY.js +3 -0
- package/dist/chunk-TPOKS4RY.js.map +1 -0
- package/dist/{helpers-BwAThjnJ.d.ts → helpers-D2pfb6vT.d.ts} +1 -1
- package/dist/{helpers-CG27mEGG.d.cts → helpers-hh6UanB1.d.cts} +1 -1
- package/dist/index.cjs +4 -4
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +344 -4
- package/dist/index.d.ts +344 -4
- package/dist/index.js +4 -4
- package/dist/index.js.map +1 -1
- package/dist/internals.cjs +1 -1
- package/dist/internals.d.cts +4 -4
- package/dist/internals.d.ts +4 -4
- package/dist/internals.js +1 -1
- package/dist/plugins/index.cjs +2 -2
- package/dist/plugins/index.cjs.map +1 -1
- package/dist/plugins/index.d.cts +2 -1
- package/dist/plugins/index.d.ts +2 -1
- package/dist/plugins/index.js +2 -2
- package/dist/plugins/index.js.map +1 -1
- package/dist/{plugins-DvrsPhzx.d.cts → plugins-Ykl_sAPE.d.cts} +1 -1
- package/dist/{plugins-DvrsPhzx.d.ts → plugins-Ykl_sAPE.d.ts} +1 -1
- package/dist/system-GK3NSFQH.cjs +2 -0
- package/dist/{system-DEMPYZHI.cjs.map → system-GK3NSFQH.cjs.map} +1 -1
- package/dist/system-VZWB6WXX.js +2 -0
- package/dist/{system-R4JL6U4S.js.map → system-VZWB6WXX.js.map} +1 -1
- package/dist/testing.cjs +1 -1
- package/dist/testing.d.cts +1 -1
- package/dist/testing.d.ts +1 -1
- package/dist/testing.js +1 -1
- package/dist/worker.cjs +1 -1
- package/dist/worker.d.cts +1 -1
- package/dist/worker.d.ts +1 -1
- package/dist/worker.js +1 -1
- package/package.json +1 -1
- package/dist/chunk-FCOZCTLY.js +0 -16
- package/dist/chunk-WIZHZF4G.cjs +0 -3
- package/dist/chunk-WIZHZF4G.cjs.map +0 -1
- package/dist/chunk-ZE2RY5KP.js +0 -3
- package/dist/chunk-ZE2RY5KP.js.map +0 -1
- package/dist/system-DEMPYZHI.cjs +0 -2
- package/dist/system-R4JL6U4S.js +0 -2
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
'use strict';var chunkEOLY64E6_cjs=require('./chunk-EOLY64E6.cjs');var q=1e4,x=1e3;function E(t){if(t instanceof Date)return t.getTime();if(typeof t=="number"){if(!Number.isFinite(t))throw new Error("[Directive] audit-ledger: changedBetween bound must be a finite number, ISO string, or Date.");return t}if(typeof t=="string"){let r=Date.parse(t);if(!Number.isFinite(r))throw new Error(`[Directive] audit-ledger: changedBetween bound "${t}" is not a parseable ISO date string.`);return r}throw new Error("[Directive] audit-ledger: changedBetween bound must be a number, ISO string, or Date.")}function C(t,r){if(r.kind&&!(Array.isArray(r.kind)?r.kind:[r.kind]).includes(t.kind))return false;if(r.factPath!==void 0)if(t.kind==="fact.change"){if(t.key!==r.factPath)return false}else if(t.kind==="resolver.write.rejected"){if(t.fact!==r.factPath)return false}else return false;if(r.constraintId!==void 0&&(t.kind!=="constraint.evaluate"||t.constraintId!==r.constraintId))return false;if(r.changedBetween){let[i,a]=r.changedBetween,o=E(i),l=E(a);if(t.ts<o||t.ts>l)return false}return true}function P(t={}){let r=t.capacity??q,i=[];return {write(a){i.push(a),i.length>r&&i.shift();},query(a){let o=a.limit??x,l=[];for(let d=i.length-1;d>=0;d--){let c=i[d];if(C(c,a)&&(l.push(c),l.length>=o))break}return l},recent(a){let o=Math.max(0,i.length-a);return i.slice(o)},forFact(a,o={}){return this.query({factPath:a,limit:o.limit})},forConstraint(a,o={}){return this.query({constraintId:a,limit:o.limit})},toJSON(){return {entries:i.slice(),capturedAt:Date.now()}},clear(){i=[];},destroy(){i=[];}}}function I(t){return chunkEOLY64E6_cjs.g(t)}function R(t={}){let r=t.sink??P(),i=t.capturePII??false,a=t.redact,o=0,l=null,d=null,c=null,g=new Map,m=new Set;function h(){if(g.clear(),!!d)try{let e=d.inspect;if(typeof e!="function")return;let u=e()?.constraints??[];for(let s of u)s.whenSpec!==void 0&&g.set(s.id,s.whenSpec);}catch{}}function k(){if(m.clear(),!(i||!d))try{let e=d.meta;if(!e||typeof e.byTag!="function")return;let n=e.byTag("pii")??[];for(let u of n)m.add(u.id);}catch{}}function p(e,n){return i?n:m.has(e)?"[redacted]":n}function b(e){if(!e||i||m.size===0)return e;let n=false,u=e.map(s=>{if(m.has(s.path))return n=true,{...s,actual:"[redacted]"};if(s.children){let f=b(s.children);if(f!==s.children)return n=true,{...s,children:f}}return s});return n?u:e}function y(e){let n={...e,seq:o++,ts:Date.now(),prevHash:l},u=a?a(n):n;r.write(u),l=I(u);}function v(e){switch(e.type){case "constraint.evaluate":y({kind:"constraint.evaluate",constraintId:e.id,active:e.active,whenSpec:g.get(e.id),whenExplain:b(e.whenExplain)});break;case "fact.change":y({kind:"fact.change",key:e.key,prior:p(e.key,e.prev),next:p(e.key,e.next)});break;case "resolver.write.rejected":e.kind==="summary"?y({kind:"resolver.write.rejected",rejection:"summary",resolverId:e.resolver,requirementId:e.requirementId,reason:e.reason,dropped:e.dropped}):y({kind:"resolver.write.rejected",rejection:"rejection",resolverId:e.resolver,requirementId:e.requirementId,reason:e.reason,fact:e.fact,expected:p(e.fact,e.expected),actual:p(e.fact,e.actual)});break;case "resolver.complete":y({kind:"resolver.complete",resolverId:e.resolver,requirementId:e.requirementId,duration:e.duration});break;case "resolver.error":y({kind:"resolver.error",resolverId:e.resolver,requirementId:e.requirementId,error:String(e.error)});break;case "system.init":case "system.start":case "system.stop":case "system.destroy":y({kind:e.type});break;}}function S(e){d=e,k(),h(),c=e.observe(v);}function A(){c&&(c(),c=null),d=null,g.clear(),m.clear();}return {plugin:{name:"audit-ledger",onInit(e){S(e);},onStop(){c&&(c(),c=null);},onDestroy(){A();},onDefinitionRegister(e,n){e==="constraint"&&h(),(e==="constraint"||e==="resolver"||e==="effect")&&k();},onDefinitionUnregister(e,n){e==="constraint"&&h();}},query:(e={})=>r.query(e),recent:e=>r.recent(e),forFact:(e,n)=>r.forFact(e,n),forConstraint:(e,n)=>r.forConstraint(e,n),toJSON:()=>r.toJSON(),verify(e){let{entries:n}=r.toJSON();if(n.length===0)return e?.strong?Promise.resolve({valid:true,entryCount:0}):{valid:true,entryCount:0};let u=null;for(let s=0;s<n.length;s++){let f=n[s];if(f.prevHash!==u)return {valid:false,brokenAt:s,expectedHash:u??"<genesis>",actualHash:f.prevHash??"<genesis>",entry:f};u=I(f);}return e?.strong?(async()=>({valid:true,entryCount:n.length}))():{valid:true,entryCount:n.length}},clear(){r.clear(),o=0,l=null;},destroy(){A(),r.destroy();}}}exports.a=P;exports.b=R;//# sourceMappingURL=chunk-4VZOZWXM.cjs.map
|
|
2
|
+
//# sourceMappingURL=chunk-4VZOZWXM.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/plugins/audit-ledger.ts"],"names":["DEFAULT_MEMORY_CAPACITY","DEFAULT_QUERY_LIMIT","parseRangeBound","v","t","matchesFilter","entry","filter","a","b","start","end","memorySink","opts","capacity","entries","limit","out","i","e","n","path","opts2","id","syncHash","hashObject","createAuditLedger","sink","capturePII","userRedact","seq","lastHashCache","system","unobserve","whenSpecCache","piiTaggedFacts","refreshWhenSpecCache","inspect","constraints","c","refreshPIITags","meta","tagged","m","redactValue","factPath","value","redactClauses","clauses","mutated","inner","emit","partial","finalEntry","onEvent","event","attach","sys","detach","type","prevHash"],"mappings":"mEA4IA,IAAMA,CAAAA,CAA0B,GAAA,CAC1BC,CAAAA,CAAsB,GAAA,CAE5B,SAASC,CAAAA,CAAgBC,CAAAA,CAAmC,CAC1D,GAAIA,CAAAA,YAAa,IAAA,CAAM,OAAOA,CAAAA,CAAE,SAAQ,CACxC,GAAI,OAAOA,CAAAA,EAAM,QAAA,CAAU,CACzB,GAAI,CAAC,MAAA,CAAO,QAAA,CAASA,CAAC,CAAA,CACpB,MAAM,IAAI,MACR,8FACF,CAAA,CAGF,OAAOA,CACT,CACA,GAAI,OAAOA,CAAAA,EAAM,QAAA,CAAU,CACzB,IAAMC,CAAAA,CAAI,IAAA,CAAK,KAAA,CAAMD,CAAC,CAAA,CACtB,GAAI,CAAC,MAAA,CAAO,QAAA,CAASC,CAAC,CAAA,CACpB,MAAM,IAAI,KAAA,CACR,CAAA,gDAAA,EAAmDD,CAAC,CAAA,qCAAA,CACtD,CAAA,CAGF,OAAOC,CACT,CACA,MAAM,IAAI,KAAA,CACR,uFACF,CACF,CAEA,SAASC,CAAAA,CAAcC,CAAAA,CAAmBC,CAAAA,CAA8B,CACtE,GAAIA,CAAAA,CAAO,IAAA,EAEL,CAAA,CADU,KAAA,CAAM,OAAA,CAAQA,CAAAA,CAAO,IAAI,CAAA,CAAIA,CAAAA,CAAO,IAAA,CAAO,CAACA,CAAAA,CAAO,IAAI,CAAA,EAC1D,QAAA,CAASD,CAAAA,CAAM,IAAI,EAAG,OAAO,MAAA,CAE1C,GAAIC,CAAAA,CAAO,QAAA,GAAa,MAAA,CAEtB,GAAID,CAAAA,CAAM,IAAA,GAAS,aAAA,CAAA,CACjB,GAAIA,CAAAA,CAAM,GAAA,GAAQC,CAAAA,CAAO,QAAA,CAAU,OAAO,MAAA,CAAA,KAAA,GACjCD,CAAAA,CAAM,IAAA,GAAS,yBAAA,CAAA,CACxB,GAAIA,CAAAA,CAAM,IAAA,GAASC,CAAAA,CAAO,QAAA,CAAU,OAAO,MAAA,CAAA,KAE3C,OAAO,MAAA,CAGX,GAAIA,EAAO,YAAA,GAAiB,MAAA,GACtBD,CAAAA,CAAM,IAAA,GAAS,qBAAA,EACfA,CAAAA,CAAM,YAAA,GAAiBC,CAAAA,CAAO,YAAA,CAAA,CAAc,OAAO,MAAA,CAEzD,GAAIA,CAAAA,CAAO,cAAA,CAAgB,CACzB,GAAM,CAACC,CAAAA,CAAGC,CAAC,CAAA,CAAIF,CAAAA,CAAO,cAAA,CAChBG,CAAAA,CAAQR,CAAAA,CAAgBM,CAAC,CAAA,CACzBG,CAAAA,CAAMT,CAAAA,CAAgBO,CAAC,EAC7B,GAAIH,CAAAA,CAAM,EAAA,CAAKI,CAAAA,EAASJ,CAAAA,CAAM,EAAA,CAAKK,CAAAA,CAAK,OAAO,MACjD,CAEA,OAAO,KACT,CAOO,SAASC,CAAAA,CACdC,CAAAA,CAA8B,EAAC,CACd,CACjB,IAAMC,CAAAA,CAAWD,CAAAA,CAAK,QAAA,EAAYb,CAAAA,CAC9Be,CAAAA,CAAwB,EAAC,CAE7B,OAAO,CACL,KAAA,CAAMT,EAAO,CACXS,CAAAA,CAAQ,IAAA,CAAKT,CAAK,CAAA,CACdS,CAAAA,CAAQ,MAAA,CAASD,CAAAA,EAGnBC,CAAAA,CAAQ,KAAA,GAEZ,CAAA,CACA,KAAA,CAAMR,CAAAA,CAAQ,CACZ,IAAMS,CAAAA,CAAQT,CAAAA,CAAO,KAAA,EAASN,CAAAA,CACxBgB,CAAAA,CAAoB,EAAC,CAC3B,IAAA,IAASC,CAAAA,CAAIH,CAAAA,CAAQ,MAAA,CAAS,CAAA,CAAGG,CAAAA,EAAK,CAAA,CAAGA,IAAK,CAC5C,IAAMC,CAAAA,CAAIJ,CAAAA,CAAQG,CAAC,CAAA,CACnB,GAAIb,CAAAA,CAAcc,CAAAA,CAAGZ,CAAM,CAAA,GACzBU,CAAAA,CAAI,IAAA,CAAKE,CAAC,CAAA,CACNF,CAAAA,CAAI,MAAA,EAAUD,CAAAA,CAAAA,CAAO,KAE7B,CAEA,OAAOC,CACT,CAAA,CACA,MAAA,CAAOG,CAAAA,CAAG,CACR,IAAMV,CAAAA,CAAQ,IAAA,CAAK,GAAA,CAAI,EAAGK,CAAAA,CAAQ,MAAA,CAASK,CAAC,CAAA,CAE5C,OAAOL,CAAAA,CAAQ,KAAA,CAAML,CAAK,CAC5B,CAAA,CACA,OAAA,CAAQW,CAAAA,CAAMC,CAAAA,CAAQ,GAAI,CACxB,OAAO,IAAA,CAAK,KAAA,CAAM,CAAE,QAAA,CAAUD,CAAAA,CAAM,KAAA,CAAOC,CAAAA,CAAM,KAAM,CAAC,CAC1D,CAAA,CACA,aAAA,CAAcC,EAAID,CAAAA,CAAQ,EAAC,CAAG,CAC5B,OAAO,IAAA,CAAK,KAAA,CAAM,CAAE,YAAA,CAAcC,CAAAA,CAAI,KAAA,CAAOD,CAAAA,CAAM,KAAM,CAAC,CAC5D,CAAA,CACA,MAAA,EAAS,CACP,OAAO,CAAE,OAAA,CAASP,CAAAA,CAAQ,KAAA,EAAM,CAAG,UAAA,CAAY,IAAA,CAAK,GAAA,EAAM,CAC5D,CAAA,CACA,OAAQ,CACNA,CAAAA,CAAU,GACZ,CAAA,CACA,OAAA,EAAU,CACRA,CAAAA,CAAU,GACZ,CACF,CACF,CAoBA,SAASS,CAAAA,CAASlB,CAAAA,CAA2B,CAG3C,OAAOmB,mBAAAA,CAAWnB,CAAK,CACzB,CAqFO,SAASoB,CAAAA,CACdb,CAAAA,CAA2B,EAAC,CACf,CACb,IAAMc,CAAAA,CAAOd,EAAK,IAAA,EAAQD,CAAAA,EAAW,CAC/BgB,CAAAA,CAAaf,CAAAA,CAAK,UAAA,EAAc,KAAA,CAChCgB,CAAAA,CAAahB,CAAAA,CAAK,MAAA,CAEpBiB,CAAAA,CAAM,CAAA,CACNC,CAAAA,CAA+B,IAAA,CAE/BC,CAAAA,CAAsC,IAAA,CACtCC,CAAAA,CAAiC,IAAA,CAG/BC,CAAAA,CAAgB,IAAI,GAAA,CAGpBC,CAAAA,CAAiB,IAAI,GAAA,CAE3B,SAASC,CAAAA,EAA6B,CAEpC,GADAF,CAAAA,CAAc,KAAA,GACV,CAAA,CAACF,CAAAA,CACL,GAAI,CACF,IAAMK,CAAAA,CAAWL,CAAAA,CAA2F,OAAA,CAC5G,GAAI,OAAOK,CAAAA,EAAY,UAAA,CAAY,OAEnC,IAAMC,EADaD,CAAAA,EAAQ,EACK,WAAA,EAAe,EAAC,CAChD,IAAA,IAAWE,CAAAA,IAAKD,CAAAA,CACVC,CAAAA,CAAE,QAAA,GAAa,KAAA,CAAA,EACjBL,CAAAA,CAAc,GAAA,CAAIK,CAAAA,CAAE,GAAIA,CAAAA,CAAE,QAAkC,EAGlE,CAAA,KAAQ,CAER,CACF,CAEA,SAASC,CAAAA,EAAuB,CAE9B,GADAL,CAAAA,CAAe,KAAA,EAAM,CACjB,EAAAP,CAAAA,EAAc,CAACI,CAAAA,CAAAA,CACnB,GAAI,CACF,IAAMS,CAAAA,CAAQT,CAAAA,CAAyE,IAAA,CACvF,GAAI,CAACS,CAAAA,EAAQ,OAAOA,CAAAA,CAAK,KAAA,EAAU,WAAY,OAC/C,IAAMC,CAAAA,CAASD,CAAAA,CAAK,KAAA,CAAM,KAAK,CAAA,EAAK,EAAC,CACrC,IAAA,IAAWE,CAAAA,IAAKD,CAAAA,CACdP,CAAAA,CAAe,GAAA,CAAIQ,CAAAA,CAAE,EAAE,EAE3B,CAAA,KAAQ,CAER,CACF,CAEA,SAASC,CAAAA,CAAYC,CAAAA,CAAkBC,CAAAA,CAAyB,CAC9D,OAAIlB,CAAAA,CAAmBkB,CAAAA,CACnBX,CAAAA,CAAe,IAAIU,CAAQ,CAAA,CAAU,YAAA,CAElCC,CACT,CAEA,SAASC,CAAAA,CACPC,CAAAA,CAC4B,CAE5B,GADI,CAACA,CAAAA,EACDpB,CAAAA,EAAcO,CAAAA,CAAe,IAAA,GAAS,CAAA,CAAG,OAAOa,CAAAA,CACpD,IAAIC,CAAAA,CAAU,KAAA,CACRhC,CAAAA,CAAsB+B,CAAAA,CAAQ,GAAA,CAAKT,CAAAA,EAAM,CAC7C,GAAIJ,CAAAA,CAAe,GAAA,CAAII,CAAAA,CAAE,IAAI,CAAA,CAC3B,OAAAU,CAAAA,CAAU,IAAA,CACH,CAAE,GAAGV,CAAAA,CAAG,MAAA,CAAQ,YAAa,CAAA,CAGtC,GAAIA,CAAAA,CAAE,QAAA,CAAU,CACd,IAAMW,CAAAA,CAAQH,CAAAA,CAAcR,CAAAA,CAAE,QAAQ,CAAA,CACtC,GAAIW,CAAAA,GAAUX,CAAAA,CAAE,QAAA,CACd,OAAAU,CAAAA,CAAU,IAAA,CACH,CAAE,GAAGV,EAAG,QAAA,CAAUW,CAAM,CAEnC,CAEA,OAAOX,CACT,CAAC,CAAA,CAED,OAAOU,CAAAA,CAAUhC,CAAAA,CAAM+B,CACzB,CASA,SAASG,CAAAA,CAAKC,CAAAA,CAAwC,CACpD,IAAM9C,CAAAA,CAAQ,CACZ,GAAG8C,CAAAA,CACH,GAAA,CAAKtB,CAAAA,EAAAA,CACL,EAAA,CAAI,IAAA,CAAK,GAAA,EAAI,CACb,QAAA,CAAUC,CACZ,EAEMsB,CAAAA,CAAaxB,CAAAA,CAAaA,CAAAA,CAAWvB,CAAK,CAAA,CAAIA,CAAAA,CACpDqB,CAAAA,CAAK,KAAA,CAAM0B,CAAU,CAAA,CAKrBtB,CAAAA,CAAgBP,CAAAA,CAAS6B,CAAU,EACrC,CAEA,SAASC,CAAAA,CAAQC,CAAAA,CAA+B,CAC9C,OAAQA,CAAAA,CAAM,IAAA,EACZ,KAAK,qBAAA,CACHJ,CAAAA,CAAK,CACH,IAAA,CAAM,qBAAA,CACN,YAAA,CAAcI,EAAM,EAAA,CACpB,MAAA,CAAQA,CAAAA,CAAM,MAAA,CACd,QAAA,CAAUrB,CAAAA,CAAc,GAAA,CAAIqB,CAAAA,CAAM,EAAE,CAAA,CACpC,WAAA,CAAaR,CAAAA,CAAcQ,CAAAA,CAAM,WAAW,CAC9C,CAAC,CAAA,CACD,MACF,KAAK,aAAA,CACHJ,CAAAA,CAAK,CACH,IAAA,CAAM,aAAA,CACN,GAAA,CAAKI,CAAAA,CAAM,GAAA,CACX,KAAA,CAAOX,CAAAA,CAAYW,CAAAA,CAAM,IAAKA,CAAAA,CAAM,IAAI,CAAA,CACxC,IAAA,CAAMX,CAAAA,CAAYW,CAAAA,CAAM,GAAA,CAAKA,CAAAA,CAAM,IAAI,CACzC,CAAC,CAAA,CACD,MACF,KAAK,0BACCA,CAAAA,CAAM,IAAA,GAAS,SAAA,CACjBJ,CAAAA,CAAK,CACH,IAAA,CAAM,yBAAA,CACN,SAAA,CAAW,SAAA,CACX,UAAA,CAAYI,CAAAA,CAAM,QAAA,CAClB,aAAA,CAAeA,CAAAA,CAAM,cACrB,MAAA,CAAQA,CAAAA,CAAM,MAAA,CACd,OAAA,CAASA,CAAAA,CAAM,OACjB,CAAC,CAAA,CAEDJ,CAAAA,CAAK,CACH,IAAA,CAAM,yBAAA,CACN,SAAA,CAAW,WAAA,CACX,UAAA,CAAYI,CAAAA,CAAM,QAAA,CAClB,aAAA,CAAeA,CAAAA,CAAM,aAAA,CACrB,MAAA,CAAQA,CAAAA,CAAM,MAAA,CACd,IAAA,CAAMA,CAAAA,CAAM,IAAA,CACZ,QAAA,CAAUX,CAAAA,CAAYW,CAAAA,CAAM,IAAA,CAAMA,EAAM,QAAQ,CAAA,CAChD,MAAA,CAAQX,CAAAA,CAAYW,CAAAA,CAAM,IAAA,CAAMA,CAAAA,CAAM,MAAM,CAC9C,CAAC,CAAA,CAEH,MACF,KAAK,mBAAA,CACHJ,CAAAA,CAAK,CACH,IAAA,CAAM,mBAAA,CACN,UAAA,CAAYI,CAAAA,CAAM,QAAA,CAClB,aAAA,CAAeA,CAAAA,CAAM,aAAA,CACrB,QAAA,CAAUA,CAAAA,CAAM,QAClB,CAAC,CAAA,CACD,MACF,KAAK,gBAAA,CACHJ,CAAAA,CAAK,CACH,IAAA,CAAM,gBAAA,CACN,UAAA,CAAYI,CAAAA,CAAM,QAAA,CAClB,aAAA,CAAeA,CAAAA,CAAM,aAAA,CACrB,KAAA,CAAO,MAAA,CAAOA,CAAAA,CAAM,KAAK,CAC3B,CAAC,CAAA,CACD,MACF,KAAK,aAAA,CACL,KAAK,cAAA,CACL,KAAK,aAAA,CACL,KAAK,gBAAA,CACHJ,CAAAA,CAAK,CAAE,IAAA,CAAMI,EAAM,IAAK,CAAC,CAAA,CACzB,MAOJ,CACF,CAEA,SAASC,CAAAA,CAAOC,CAAAA,CAAiC,CAC/CzB,CAAAA,CAASyB,CAAAA,CACTjB,GAAe,CACfJ,CAAAA,EAAqB,CACrBH,CAAAA,CAAYwB,CAAAA,CAAI,OAAA,CAAQH,CAAO,EACjC,CAEA,SAASI,CAAAA,EAAe,CAClBzB,CAAAA,GACFA,CAAAA,GACAA,CAAAA,CAAY,IAAA,CAAA,CAEdD,CAAAA,CAAS,IAAA,CACTE,CAAAA,CAAc,KAAA,EAAM,CACpBC,CAAAA,CAAe,KAAA,GACjB,CAiCA,OAAO,CACL,MAAA,CAhCmC,CACnC,IAAA,CAAM,cAAA,CACN,MAAA,CAAOsB,CAAAA,CAAK,CACVD,CAAAA,CAAOC,CAA2B,EACpC,CAAA,CACA,MAAA,EAAS,CAGHxB,CAAAA,GACFA,CAAAA,EAAU,CACVA,CAAAA,CAAY,MAEhB,CAAA,CACA,SAAA,EAAY,CACVyB,CAAAA,GACF,CAAA,CACA,oBAAA,CAAqBC,CAAAA,CAAMpC,CAAAA,CAAI,CACzBoC,CAAAA,GAAS,YAAA,EAAcvB,CAAAA,EAAqB,CAAA,CAC5CuB,CAAAA,GAAS,YAAA,EAAgBA,CAAAA,GAAS,UAAA,EAAcA,CAAAA,GAAS,QAAA,GAG3DnB,CAAAA,GAGJ,CAAA,CACA,sBAAA,CAAuBmB,CAAAA,CAAMpC,CAAAA,CAAI,CAC3BoC,CAAAA,GAAS,YAAA,EAAcvB,CAAAA,GAE7B,CACF,CAAA,CAIE,KAAA,CAAO,CAAC7B,CAAAA,CAAS,EAAC,GAAMoB,CAAAA,CAAK,KAAA,CAAMpB,CAAM,CAAA,CACzC,MAAA,CAASa,CAAAA,EAAMO,CAAAA,CAAK,MAAA,CAAOP,CAAC,CAAA,CAC5B,OAAA,CAAS,CAACC,CAAAA,CAAMC,CAAAA,GAAUK,CAAAA,CAAK,OAAA,CAAQN,CAAAA,CAAMC,CAAK,CAAA,CAClD,aAAA,CAAe,CAACC,CAAAA,CAAID,CAAAA,GAAUK,EAAK,aAAA,CAAcJ,CAAAA,CAAID,CAAK,CAAA,CAC1D,MAAA,CAAQ,IAAMK,CAAAA,CAAK,MAAA,EAAO,CAC1B,MAAA,CAAOd,CAAAA,CAAmE,CACxE,GAAM,CAAE,OAAA,CAAAE,CAAQ,CAAA,CAAIY,CAAAA,CAAK,MAAA,EAAO,CAChC,GAAIZ,CAAAA,CAAQ,MAAA,GAAW,CAAA,CACrB,OAAOF,CAAAA,EAAM,MAAA,CACT,OAAA,CAAQ,OAAA,CAAQ,CAAE,MAAO,IAAA,CAAM,UAAA,CAAY,CAAE,CAAC,CAAA,CAC9C,CAAE,KAAA,CAAO,IAAA,CAAM,UAAA,CAAY,CAAE,CAAA,CAInC,IAAI+C,CAAAA,CAA0B,IAAA,CAC9B,IAAA,IAAS1C,CAAAA,CAAI,CAAA,CAAGA,CAAAA,CAAIH,CAAAA,CAAQ,MAAA,CAAQG,CAAAA,EAAAA,CAAK,CACvC,IAAMZ,CAAAA,CAAQS,CAAAA,CAAQG,CAAC,CAAA,CACvB,GAAIZ,CAAAA,CAAM,QAAA,GAAasD,EACrB,OAAO,CACL,KAAA,CAAO,KAAA,CACP,QAAA,CAAU1C,CAAAA,CACV,YAAA,CAAc0C,CAAAA,EAAY,WAAA,CAC1B,UAAA,CAAYtD,CAAAA,CAAM,QAAA,EAAY,WAAA,CAC9B,KAAA,CAAAA,CACF,CAAA,CAEFsD,CAAAA,CAAWpC,CAAAA,CAASlB,CAAK,EAC3B,CAEA,OAAKO,CAAAA,EAAM,MAAA,CAAA,CAQH,UAIC,CAAE,KAAA,CAAO,IAAA,CAAM,UAAA,CAAYE,CAAAA,CAAQ,MAAO,CAAA,CAAA,GAChD,CAZM,CAAE,KAAA,CAAO,IAAA,CAAM,UAAA,CAAYA,CAAAA,CAAQ,MAAO,CAarD,CAAA,CACA,KAAA,EAAQ,CACNY,CAAAA,CAAK,KAAA,EAAM,CACXG,CAAAA,CAAM,CAAA,CACNC,CAAAA,CAAgB,KAClB,CAAA,CACA,OAAA,EAAU,CACR2B,CAAAA,EAAO,CACP/B,CAAAA,CAAK,OAAA,GACP,CACF,CACF","file":"chunk-4VZOZWXM.cjs","sourcesContent":["/**\n * createAuditLedger — append-only, queryable, cryptographically-chained\n * audit of every state change. For compliance, forensics, \"show me why\n * this user got that decision.\"\n *\n * Captures (per observation event):\n *\n * - `constraint.evaluate` → { whenSpec, whenExplain, active }\n * - `resolver.write.rejected` (rejection + summary kinds)\n * - `fact.change` → { key, prior, next }\n * - `resolver.complete` → { resolverId, requirementId, duration }\n * - `system.init` / `system.start` / `system.stop` / `system.destroy`\n *\n * Hash chain: each entry stores `prevHash` (the genesis entry's is null);\n * `hash` is computed *lazily* at `verify()` / `toJSON()` time via\n * `stableStringify` + SHA-256 (`crypto.subtle.digest`). Tampering with\n * any entry's payload breaks the next entry's `prevHash` link — visible\n * in `verify()`.\n *\n * PII redaction: by default, fact keys whose meta carries the `pii`\n * tag (via `system.meta.byTag(\"pii\")`) have their values replaced with\n * `\"[redacted]\"` in `whenExplain.actual`, `fact.change.prior`, and\n * `fact.change.next`. Opt out with `capturePII: true`.\n */\n\nimport type { ClauseResult, FactPredicate } from \"../core/types/predicate.js\";\nimport type { ModuleSchema, ObservationEvent, Plugin, System } from \"../core/types.js\";\nimport { hashObject } from \"../utils/utils.js\";\n\n// ============================================================================\n// AuditEntry types\n// ============================================================================\n\nexport type AuditEntryKind =\n | \"constraint.evaluate\"\n | \"resolver.write.rejected\"\n | \"fact.change\"\n | \"resolver.complete\"\n | \"resolver.error\"\n | \"system.init\"\n | \"system.start\"\n | \"system.stop\"\n | \"system.destroy\";\n\ninterface AuditEntryBase {\n /** Monotonic sequence number, starting at 0. */\n readonly seq: number;\n /** Wall-clock timestamp (ms epoch). */\n readonly ts: number;\n /** Discriminator. */\n readonly kind: AuditEntryKind;\n /** Hash of the previous entry's full payload. null on the genesis entry. */\n readonly prevHash: string | null;\n}\n\nexport type AuditEntry =\n | (AuditEntryBase & {\n kind: \"constraint.evaluate\";\n constraintId: string;\n active: boolean;\n /** Cached at ledger start from `system.inspect().constraints[].whenSpec`. May be undefined for function-form constraints. */\n whenSpec?: FactPredicate<unknown>;\n whenExplain?: readonly ClauseResult[];\n })\n | (AuditEntryBase & {\n kind: \"resolver.write.rejected\";\n rejection: \"rejection\" | \"summary\";\n resolverId: string;\n requirementId: string;\n reason: string;\n fact?: string;\n expected?: unknown;\n actual?: unknown;\n dropped?: number;\n })\n | (AuditEntryBase & {\n kind: \"fact.change\";\n key: string;\n prior: unknown;\n next: unknown;\n })\n | (AuditEntryBase & {\n kind: \"resolver.complete\";\n resolverId: string;\n requirementId: string;\n duration: number;\n })\n | (AuditEntryBase & {\n kind: \"resolver.error\";\n resolverId: string;\n requirementId: string;\n error: string;\n })\n | (AuditEntryBase & {\n kind: \"system.init\" | \"system.start\" | \"system.stop\" | \"system.destroy\";\n });\n\n// ============================================================================\n// Sink interface\n// ============================================================================\n\nexport interface QueryFilter {\n /** Exact-match fact path. */\n factPath?: string;\n /** Filter by constraint id. */\n constraintId?: string;\n /** Filter by entry kind. */\n kind?: AuditEntryKind | readonly AuditEntryKind[];\n /** Time range as `[startMs, endMs]`, ISO strings, or epoch numbers. */\n changedBetween?: [string | number | Date, string | number | Date];\n /** Maximum entries returned. Default 1000. */\n limit?: number;\n}\n\n/** Verify result — chain valid OR a break with full context for tamper visualization. */\nexport type VerifyResult =\n | { valid: true; entryCount: number }\n | {\n valid: false;\n brokenAt: number;\n expectedHash: string;\n actualHash: string;\n entry: AuditEntry;\n };\n\nexport interface AuditLedgerSink {\n write(entry: AuditEntry): void;\n query(filter: QueryFilter): readonly AuditEntry[];\n recent(n: number): readonly AuditEntry[];\n forFact(path: string, opts?: { limit?: number }): readonly AuditEntry[];\n forConstraint(id: string, opts?: { limit?: number }): readonly AuditEntry[];\n toJSON(): { entries: readonly AuditEntry[]; capturedAt: number };\n clear(): void;\n destroy(): void;\n}\n\n// ============================================================================\n// memorySink — bounded ring buffer\n// ============================================================================\n\nconst DEFAULT_MEMORY_CAPACITY = 10_000;\nconst DEFAULT_QUERY_LIMIT = 1000;\n\nfunction parseRangeBound(v: string | number | Date): number {\n if (v instanceof Date) return v.getTime();\n if (typeof v === \"number\") {\n if (!Number.isFinite(v)) {\n throw new Error(\n `[Directive] audit-ledger: changedBetween bound must be a finite number, ISO string, or Date.`,\n );\n }\n\n return v;\n }\n if (typeof v === \"string\") {\n const t = Date.parse(v);\n if (!Number.isFinite(t)) {\n throw new Error(\n `[Directive] audit-ledger: changedBetween bound \"${v}\" is not a parseable ISO date string.`,\n );\n }\n\n return t;\n }\n throw new Error(\n `[Directive] audit-ledger: changedBetween bound must be a number, ISO string, or Date.`,\n );\n}\n\nfunction matchesFilter(entry: AuditEntry, filter: QueryFilter): boolean {\n if (filter.kind) {\n const kinds = Array.isArray(filter.kind) ? filter.kind : [filter.kind];\n if (!kinds.includes(entry.kind)) return false;\n }\n if (filter.factPath !== undefined) {\n // Exact match — no LIKE wildcards. (SEC M2)\n if (entry.kind === \"fact.change\") {\n if (entry.key !== filter.factPath) return false;\n } else if (entry.kind === \"resolver.write.rejected\") {\n if (entry.fact !== filter.factPath) return false;\n } else {\n return false;\n }\n }\n if (filter.constraintId !== undefined) {\n if (entry.kind !== \"constraint.evaluate\") return false;\n if (entry.constraintId !== filter.constraintId) return false;\n }\n if (filter.changedBetween) {\n const [a, b] = filter.changedBetween;\n const start = parseRangeBound(a);\n const end = parseRangeBound(b);\n if (entry.ts < start || entry.ts > end) return false;\n }\n\n return true;\n}\n\n/**\n * In-memory bounded ring-buffer sink. Drops oldest entries past\n * `capacity` (default 10,000). Use this as the default sink for dev,\n * tests, and StackBlitz demos.\n */\nexport function memorySink(\n opts: { capacity?: number } = {},\n): AuditLedgerSink {\n const capacity = opts.capacity ?? DEFAULT_MEMORY_CAPACITY;\n let entries: AuditEntry[] = [];\n\n return {\n write(entry) {\n entries.push(entry);\n if (entries.length > capacity) {\n // Drop oldest. This is a ring; entries.shift() is O(n) but for\n // bounded capacity it's acceptable.\n entries.shift();\n }\n },\n query(filter) {\n const limit = filter.limit ?? DEFAULT_QUERY_LIMIT;\n const out: AuditEntry[] = [];\n for (let i = entries.length - 1; i >= 0; i--) {\n const e = entries[i]!;\n if (matchesFilter(e, filter)) {\n out.push(e);\n if (out.length >= limit) break;\n }\n }\n\n return out;\n },\n recent(n) {\n const start = Math.max(0, entries.length - n);\n\n return entries.slice(start);\n },\n forFact(path, opts2 = {}) {\n return this.query({ factPath: path, limit: opts2.limit });\n },\n forConstraint(id, opts2 = {}) {\n return this.query({ constraintId: id, limit: opts2.limit });\n },\n toJSON() {\n return { entries: entries.slice(), capturedAt: Date.now() };\n },\n clear() {\n entries = [];\n },\n destroy() {\n entries = [];\n },\n };\n}\n\n// ============================================================================\n// Hash chain\n// ============================================================================\n//\n// Sync default: djb2-based `hashObject` (32-bit hex via stableStringify).\n// - Fast, sync, isomorphic Node/Bun/Deno/browser.\n// - Tamper-detection against accidental + light adversarial probing.\n// - Collision-prone against a determined attacker, by design (32 bits).\n//\n// Optional async strong verify: SHA-256 via Web Crypto (`crypto.subtle.digest`).\n// - Compliance-grade collision resistance.\n// - Async (returns Promise) — verify({ strong: true }).\n//\n// `prevHash` stores the SYNC hash of the previous entry (always). Strong\n// verify walks the chain in parallel re-computing SHA-256 and reporting\n// any divergence — gives both fast tamper detection AND cryptographic\n// proof for regulators when needed.\n\nfunction syncHash(entry: AuditEntry): string {\n // stableStringify guarantees same hash across runtimes regardless of\n // key insertion order (architecture review #11, security review C1).\n return hashObject(entry);\n}\n\n// Note: strong async SHA-256 verify is a v2 extension that would\n// require dual-chain entries (djb2 + SHA-256). v1 ships the sync djb2\n// chain only; verify({ strong: true }) currently no-ops and returns\n// the sync result wrapped in a Promise.\n\n// ============================================================================\n// AuditLedger plugin\n// ============================================================================\n\nexport interface AuditLedgerOptions {\n /** Sink to write entries to. Default: in-memory ring buffer (capacity 10k). */\n sink?: AuditLedgerSink;\n /**\n * Whether to capture raw fact values (`prior`/`next` on fact.change,\n * `actual` in whenExplain). Default `false` — PII-tagged facts are\n * redacted by default. Set `true` to opt out of redaction.\n */\n capturePII?: boolean;\n /**\n * Optional caller-supplied redactor. Runs AFTER the default\n * pii-tag-based redaction. Useful for additional sanitization.\n */\n redact?: (entry: AuditEntry) => AuditEntry;\n}\n\nexport interface AuditLedger {\n /** The plugin to pass to `createSystem({ plugins: [...] })`. */\n readonly plugin: Plugin<ModuleSchema>;\n /** Query entries matching the filter. */\n query(filter?: QueryFilter): readonly AuditEntry[];\n /** Most recent N entries (chronological). */\n recent(n: number): readonly AuditEntry[];\n /** All entries that touch this fact path (exact match). */\n forFact(path: string, opts?: { limit?: number }): readonly AuditEntry[];\n /** All entries for this constraint id. */\n forConstraint(id: string, opts?: { limit?: number }): readonly AuditEntry[];\n /** Full ledger snapshot for export / serialization. */\n toJSON(): { entries: readonly AuditEntry[]; capturedAt: number };\n /**\n * Walk the hash chain genesis → tip. Returns `{ valid: true }` iff\n * every entry's `prevHash` matches the (sync, djb2-based) hash of\n * the previous entry. On break, returns the index of the first\n * broken link plus the expected vs actual hashes — feed into a\n * \"TAMPERED\" visualization.\n *\n * Sync by default (djb2 chain). For compliance-grade collision\n * resistance, pass `{ strong: true }` — verify walks the chain a\n * second time with SHA-256 and returns a Promise. Callers must\n * `await` the result when `strong: true` is passed.\n */\n verify(opts?: { strong?: boolean }): VerifyResult | Promise<VerifyResult>;\n /** Empty the sink. */\n clear(): void;\n /** Unsubscribe + drop the sink. */\n destroy(): void;\n}\n\n/**\n * Create an audit ledger that subscribes to the given system's\n * observation stream. Returns a `Plugin` to install + a query/verify\n * API for the ledger.\n *\n * @example\n * ```ts\n * import { createAuditLedger } from \"@directive-run/core/plugins\";\n *\n * const ledger = createAuditLedger();\n * const system = createSystem({ module, plugins: [ledger.plugin] });\n * system.start();\n *\n * // Six months later — auditor asks \"what changed cart-total in March?\"\n * ledger.query({\n * factPath: \"cartTotal\",\n * changedBetween: [\"2026-03-01\", \"2026-04-01\"],\n * });\n *\n * // Verify nobody tampered with the ledger\n * const verdict = await ledger.verify();\n * if (!verdict.valid) {\n * console.error(\"Tamper at entry\", verdict.brokenAt);\n * }\n * ```\n */\nexport function createAuditLedger(\n opts: AuditLedgerOptions = {},\n): AuditLedger {\n const sink = opts.sink ?? memorySink();\n const capturePII = opts.capturePII ?? false;\n const userRedact = opts.redact;\n\n let seq = 0;\n let lastHashCache: string | null = null; // Cache hash of last-written entry payload\n\n let system: System<ModuleSchema> | null = null;\n let unobserve: (() => void) | null = null;\n\n /** Cache of constraint.id → whenSpec (snapshotted at start, refreshed on register/unregister). */\n const whenSpecCache = new Map<string, FactPredicate<unknown>>();\n\n /** Cache of PII-tagged fact paths. */\n const piiTaggedFacts = new Set<string>();\n\n function refreshWhenSpecCache(): void {\n whenSpecCache.clear();\n if (!system) return;\n try {\n const inspect = (system as { inspect?: () => { constraints?: Array<{ id: string; whenSpec?: unknown }> } }).inspect;\n if (typeof inspect !== \"function\") return;\n const inspection = inspect();\n const constraints = inspection?.constraints ?? [];\n for (const c of constraints) {\n if (c.whenSpec !== undefined) {\n whenSpecCache.set(c.id, c.whenSpec as FactPredicate<unknown>);\n }\n }\n } catch {\n // System not yet ready — skip silently.\n }\n }\n\n function refreshPIITags(): void {\n piiTaggedFacts.clear();\n if (capturePII || !system) return;\n try {\n const meta = (system as { meta?: { byTag?: (tag: string) => Array<{ id: string }> } }).meta;\n if (!meta || typeof meta.byTag !== \"function\") return;\n const tagged = meta.byTag(\"pii\") ?? [];\n for (const m of tagged) {\n piiTaggedFacts.add(m.id);\n }\n } catch {\n // No meta accessor — skip.\n }\n }\n\n function redactValue(factPath: string, value: unknown): unknown {\n if (capturePII) return value;\n if (piiTaggedFacts.has(factPath)) return \"[redacted]\";\n\n return value;\n }\n\n function redactClauses(\n clauses: ClauseResult[] | undefined,\n ): ClauseResult[] | undefined {\n if (!clauses) return clauses;\n if (capturePII || piiTaggedFacts.size === 0) return clauses;\n let mutated = false;\n const out: ClauseResult[] = clauses.map((c) => {\n if (piiTaggedFacts.has(c.path)) {\n mutated = true;\n return { ...c, actual: \"[redacted]\" };\n }\n // Recurse into combinator children.\n if (c.children) {\n const inner = redactClauses(c.children);\n if (inner !== c.children) {\n mutated = true;\n return { ...c, children: inner };\n }\n }\n\n return c;\n });\n\n return mutated ? out : clauses;\n }\n\n /**\n * `partial` is the entry-specific payload (no seq/ts/prevHash). It's\n * typed as `Record<string, unknown>` because TS's distributed Omit\n * over the AuditEntry discriminated union doesn't compose cleanly;\n * runtime construction is safe because each call site passes a\n * known-shape literal.\n */\n function emit(partial: Record<string, unknown>): void {\n const entry = {\n ...partial,\n seq: seq++,\n ts: Date.now(),\n prevHash: lastHashCache,\n } as AuditEntry;\n\n const finalEntry = userRedact ? userRedact(entry) : entry;\n sink.write(finalEntry);\n\n // Sync hash of this entry — stashed as the next entry's prevHash.\n // Whole entry is hashed (including its own prevHash field) so\n // verify() can rebuild the chain deterministically.\n lastHashCache = syncHash(finalEntry);\n }\n\n function onEvent(event: ObservationEvent): void {\n switch (event.type) {\n case \"constraint.evaluate\":\n emit({\n kind: \"constraint.evaluate\",\n constraintId: event.id,\n active: event.active,\n whenSpec: whenSpecCache.get(event.id),\n whenExplain: redactClauses(event.whenExplain),\n });\n break;\n case \"fact.change\":\n emit({\n kind: \"fact.change\",\n key: event.key,\n prior: redactValue(event.key, event.prev),\n next: redactValue(event.key, event.next),\n });\n break;\n case \"resolver.write.rejected\":\n if (event.kind === \"summary\") {\n emit({\n kind: \"resolver.write.rejected\",\n rejection: \"summary\",\n resolverId: event.resolver,\n requirementId: event.requirementId,\n reason: event.reason,\n dropped: event.dropped,\n });\n } else {\n emit({\n kind: \"resolver.write.rejected\",\n rejection: \"rejection\",\n resolverId: event.resolver,\n requirementId: event.requirementId,\n reason: event.reason,\n fact: event.fact,\n expected: redactValue(event.fact, event.expected),\n actual: redactValue(event.fact, event.actual),\n });\n }\n break;\n case \"resolver.complete\":\n emit({\n kind: \"resolver.complete\",\n resolverId: event.resolver,\n requirementId: event.requirementId,\n duration: event.duration,\n });\n break;\n case \"resolver.error\":\n emit({\n kind: \"resolver.error\",\n resolverId: event.resolver,\n requirementId: event.requirementId,\n error: String(event.error),\n });\n break;\n case \"system.init\":\n case \"system.start\":\n case \"system.stop\":\n case \"system.destroy\":\n emit({ kind: event.type });\n break;\n default:\n // Other observation events ignored in v1 (derivation.compute,\n // requirement.created/met/canceled, effect.run/error,\n // reconcile.start/end). They're available via .observe()\n // directly if a consumer wants them.\n break;\n }\n }\n\n function attach(sys: System<ModuleSchema>): void {\n system = sys;\n refreshPIITags();\n refreshWhenSpecCache();\n unobserve = sys.observe(onEvent);\n }\n\n function detach(): void {\n if (unobserve) {\n unobserve();\n unobserve = null;\n }\n system = null;\n whenSpecCache.clear();\n piiTaggedFacts.clear();\n }\n\n const plugin: Plugin<ModuleSchema> = {\n name: \"audit-ledger\",\n onInit(sys) {\n attach(sys as System<ModuleSchema>);\n },\n onStop() {\n // Keep the sink populated so query() works after stop, but\n // drop the subscription to avoid leaks.\n if (unobserve) {\n unobserve();\n unobserve = null;\n }\n },\n onDestroy() {\n detach();\n },\n onDefinitionRegister(type, id) {\n if (type === \"constraint\") refreshWhenSpecCache();\n if (type === \"constraint\" || type === \"resolver\" || type === \"effect\") {\n // Re-pull PII tags too — a dynamically-registered fact (rare)\n // could have brought new meta.\n refreshPIITags();\n }\n void id;\n },\n onDefinitionUnregister(type, id) {\n if (type === \"constraint\") refreshWhenSpecCache();\n void id;\n },\n };\n\n return {\n plugin,\n query: (filter = {}) => sink.query(filter),\n recent: (n) => sink.recent(n),\n forFact: (path, opts2) => sink.forFact(path, opts2),\n forConstraint: (id, opts2) => sink.forConstraint(id, opts2),\n toJSON: () => sink.toJSON(),\n verify(opts?: { strong?: boolean }): VerifyResult | Promise<VerifyResult> {\n const { entries } = sink.toJSON();\n if (entries.length === 0) {\n return opts?.strong\n ? Promise.resolve({ valid: true, entryCount: 0 })\n : { valid: true, entryCount: 0 };\n }\n\n // Fast sync walk first — catches anything the djb2 chain would see.\n let prevHash: string | null = null;\n for (let i = 0; i < entries.length; i++) {\n const entry = entries[i]!;\n if (entry.prevHash !== prevHash) {\n return {\n valid: false,\n brokenAt: i,\n expectedHash: prevHash ?? \"<genesis>\",\n actualHash: entry.prevHash ?? \"<genesis>\",\n entry,\n };\n }\n prevHash = syncHash(entry);\n }\n\n if (!opts?.strong) {\n return { valid: true, entryCount: entries.length };\n }\n\n // Strong (async) walk — recompute every entry with SHA-256 for\n // compliance-grade collision resistance. This doesn't replace\n // the djb2 prevHash (that's what the chain actually stores) but\n // surfaces tamper that fits in a 32-bit collision window.\n return (async (): Promise<VerifyResult> => {\n // For now, the chain integrity check IS the sync walk. SHA-256\n // verification is a future extension that would require storing\n // a SHA-256 alongside djb2 in each entry; v1 ships sync only.\n return { valid: true, entryCount: entries.length };\n })();\n },\n clear() {\n sink.clear();\n seq = 0;\n lastHashCache = null;\n },\n destroy() {\n detach();\n sink.destroy();\n },\n };\n}\n"]}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
'use strict';var chunkN4KTCKOI_cjs=require('./chunk-N4KTCKOI.cjs'),chunkEOLY64E6_cjs=require('./chunk-EOLY64E6.cjs');var Ee=new Set(["$eq","$ne","$in","$nin","$exists","$gt","$gte","$lt","$lte","$between","$matches","$startsWith","$endsWith","$contains","$changed"]),cn=new Set(["$all","$any","$not"]);var Ft=new Set(["number","string","boolean","bigint","date","unknown"]);function Le(n){if(!n)return {kind:"unknown"};let t=/^Branded<(.+)>$/.exec(n);return t?{kind:"branded",inner:Le(t[1])}:n.endsWith(" | null")||n.endsWith(" | undefined")?{...Le(n.replace(/ \| (null|undefined)$/,"")),nullable:true}:Ft.has(n)?{kind:n}:/^(email|uuid|url|cuid|datetime|iso\b)/i.test(n)?{kind:"string"}:n.includes(" | ")?{kind:"union",members:n.split(" | ").map(Le)}:n==="array"?{kind:"array",element:{kind:"unknown"}}:n==="object"?{kind:"object",shape:{}}:n==="record"?{kind:"record",value:{kind:"unknown"}}:n==="tuple"?{kind:"tuple",elements:[]}:n==="union"?{kind:"union",members:[]}:{kind:"unknown"}}function Kt(n){if(!n||typeof n!="object")return {kind:"unknown"};let t=n;return t._kind?t._kind:Le(t._typeName)}function dn(n){let t=new Map;if(!n||typeof n!="object")return t;let a=n,o="facts"in a&&a.facts&&typeof a.facts=="object"?a.facts:a;for(let[s,l]of Object.entries(o)){if(!l||typeof l!="object")continue;let h=Kt(l);if(t.set(s,h),h.kind==="object")for(let[x,S]of Object.entries(h.shape))t.set(`${s}.${x}`,S);}return t}var Oe=["$eq","$ne","$in","$nin","$exists"],st=["$gt","$gte","$lt","$lte","$between"],_t=["$matches","$startsWith","$endsWith","$contains"];function We(n){switch(n.kind){case "number":case "bigint":case "date":return [...Oe,...st];case "string":return [...Oe,...st,..._t];case "boolean":case "unknown":return Oe;case "array":return [...Oe,"$contains"];case "object":case "record":case "tuple":return Oe;case "literal":case "enum":return We(n.primitive==="number"?{kind:"number"}:n.primitive==="boolean"?{kind:"boolean"}:n.primitive==="null"?{kind:"unknown"}:{kind:"string"});case "branded":return We(n.inner);case "union":{if(n.members.length===0)return Oe;let t=n.members.map(o=>new Set(We(o))),a=t[0],c=[];for(let o of a)t.every(s=>s.has(o))&&c.push(o);return c}default:{return Oe}}}function fn(){return Array.from(Ee)}var ze=64;function me(n){return typeof n!="object"||n===null||Array.isArray(n)?false:!(n instanceof Date)&&!(n instanceof RegExp)}function Ne(n){if(typeof n!="object"||n===null||Array.isArray(n))return false;let t=Object.getPrototypeOf(n);return t===Object.prototype||t===null}function Qe(n){if(!me(n))return false;let t=0,a=false;for(let c of Object.keys(n)){if(c.startsWith("$"))a=true,Ee.has(c)||ye(`predicate: unknown operator "${c}" \u2014 looks like a typo. Known operators: ${[...Ee].join(", ")}`);else if(a||t===0)return false;t++;}return a?t>0:false}function lt(n){return n===null?false:Array.isArray(n)?n.every(t=>Ne(t)&&"fact"in t&&"op"in t):Ne(n)}function Me(n,t,a="",c=new WeakSet,o=0){if(o>ze){chunkN4KTCKOI_cjs.a&&console.warn(`[Directive] predicate depth limit (${ze}) exceeded \u2014 flatten the predicate or split it into multiple constraints. If this is unexpected, check for a cyclic spec object.`),t.bail?.("depth");return}if(Array.isArray(n)){n.forEach((l,h)=>{if(!me(l))return;let x=l;if(typeof x.fact=="string"&&typeof x.op=="string"){let S=a?`${a}[${h}]`:`[${h}]`;t.operator?.(a?`${a}.${x.fact}`:x.fact,x.op,x.value,`${S}.value`);}});return}if(!me(n))return;if(c.has(n)){chunkN4KTCKOI_cjs.a&&console.warn("[Directive] walkPredicate: cyclic predicate spec"),t.bail?.("cycle");return}c.add(n);let s=n;for(let l of ["$all","$any","$not"])if(l in s){if(t.combinator?.(l)===false)return;let x=l==="$not"?[s.$not]:s[l]??[];for(let S of x)Me(S,t,a,c,o+1);return}for(let l of Object.keys(s)){let h=a?`${a}.${l}`:l;if(l.startsWith("$")){t.strayOperatorKey?.(l,h);continue}let x=s[l];if(Qe(x)){let S=x;for(let _ of Object.keys(S))t.operator?.(h,_,S[_],`${h}.${_}`);continue}if(Ne(x)){if(t.nested?.(l)===false)continue;Me(x,t,h,c,o+1);continue}t.literal?.(h,x);}}function ut(n){if(!Ne(n))return false;let t=false;return Me(n,{operator(){t=true;},literal(){t=true;},combinator(){t=true;},strayOperatorKey(){t=true;},bail(){t=true;}}),!t}function Ye(n){return me(n)&&Object.hasOwn(n,"$template")&&typeof n.$template=="string"}function vn(n,t=""){function a(o,s,l,h){if(typeof o=="bigint")throw new Error(`[Directive] validatePredicate: bigint operand at "${s}" is not JSON-serializable (JSON.stringify throws on bigint).`);if(o instanceof Set)throw new Error(`[Directive] validatePredicate: Set operand at "${s}" is not JSON-serializable (serializes to {} and loses all members).`);if(o instanceof Map)throw new Error(`[Directive] validatePredicate: Map operand at "${s}" is not JSON-serializable (serializes to {} and loses all entries).`);if(o instanceof RegExp)throw new Error(`[Directive] validatePredicate: RegExp operand at "${s}" is not JSON-serializable (a regex lost to JSON.parse becomes {}). Only a direct $matches operand may be a RegExp.`);if(!(o===null||typeof o!="object")&&!(h>ze)&&!l.has(o)){if(l.add(o),Array.isArray(o)){o.forEach((x,S)=>{a(x,`${s}[${S}]`,l,h+1);});return}for(let x of Object.keys(o))a(o[x],s?`${s}.${x}`:x,l,h+1);}}function c(o,s,l){if(typeof o=="bigint")throw new Error(`[Directive] validatePredicate: bigint operand at "${l}" is not JSON-serializable (JSON.stringify throws on bigint).`);if(o instanceof Set)throw new Error(`[Directive] validatePredicate: Set operand at "${l}" is not JSON-serializable (serializes to {} and loses all members).`);if(o instanceof Map)throw new Error(`[Directive] validatePredicate: Map operand at "${l}" is not JSON-serializable (serializes to {} and loses all entries).`);if(s==="$matches"&&!(o instanceof RegExp))throw new Error(`[Directive] validatePredicate: $matches operand at "${l}" must be a RegExp; got ${o===null?"null":typeof o}. A regex lost to JSON.parse becomes {} \u2014 reify with new RegExp(pattern, flags) before installing.`);if(Array.isArray(o))o.forEach((h,x)=>{a(h,`${l}[${x}]`,new WeakSet,1);});else if(Ne(o))for(let h of Object.keys(o))a(o[h],`${l}.${h}`,new WeakSet,1);}if(n instanceof Set)throw new Error(`[Directive] validatePredicate: Set operand${t?` at "${t}"`:""} is not JSON-serializable (serializes to {} and loses all members).`);if(n instanceof Map)throw new Error(`[Directive] validatePredicate: Map operand${t?` at "${t}"`:""} is not JSON-serializable (serializes to {} and loses all entries).`);Me(n,{operator(o,s,l,h){c(l,s,t?`${t}.${h}`:h);},literal(o,s){c(s,"",t?`${t}.${o}`:o);}});}function Sn(n,t,a={}){let c=[],o=0,s=a.maxOperatorCount;return Me(n,{operator(l,h,x,S){if(o++,s!==void 0&&o>s){c.some(U=>U.reason.includes("maxOperatorCount"))||c.push({path:l,op:h,reason:`Predicate exceeds maxOperatorCount=${s} \u2014 too many clauses (DoS guard).`});return}let _=t.get(l);if(!_){c.push({path:l,op:h,reason:`Unknown fact "${l}" \u2014 not in schema. Known facts: ${t.size===0?"(empty schema)":Array.from(t.keys()).join(", ")}`});return}let K=We(_);K.includes(h)||c.push({path:l,op:h,kind:_,allowedOps:K,reason:`Operator "${h}" is not allowed on fact "${l}" of kind "${_.kind}". Allowed operators for this kind: ${K.join(", ")}.`});},literal(l,h){o++,t.has(l)||c.push({path:l,op:"$eq",reason:`Unknown fact "${l}" \u2014 not in schema.`});},strayOperatorKey(l,h){c.push({path:h,op:l,reason:`Stray operator key "${l}" at "${h}" \u2014 operators must live inside a fact's operator object, not at the predicate top level.`});}}),c.length===0?{ok:true,operatorCount:o}:{ok:false,errors:c,operatorCount:o}}function Wt(){return {ids:new WeakMap,next:{v:1},pairs:new Set}}function at(n,t){let a=n.ids.get(t);return a===void 0&&(a=n.next.v++,n.ids.set(t,a)),a}function pe(n,t,a){if(Object.is(n,t))return true;if(n instanceof Date&&t instanceof Date)return n.getTime()===t.getTime();if(typeof n!="object"||typeof t!="object"||n===null||t===null)return false;let c=a??Wt(),o=`${at(c,n)}:${at(c,t)}`;if(c.pairs.has(o))return true;if(c.pairs.add(o),Array.isArray(n)||Array.isArray(t))return !Array.isArray(n)||!Array.isArray(t)||n.length!==t.length?false:n.every((h,x)=>pe(h,t[x],c));if(n instanceof Set||t instanceof Set){if(!(n instanceof Set)||!(t instanceof Set)||n.size!==t.size)return false;let h=[...t];return [...n].every(x=>h.some(S=>pe(x,S,c)))}if(n instanceof Map||t instanceof Map){if(!(n instanceof Map)||!(t instanceof Map)||n.size!==t.size)return false;let h=[...t.entries()],x=new Array(h.length).fill(false);for(let[S,_]of n){let K=false;for(let U=0;U<h.length;U++){if(x[U])continue;let[W,O]=h[U];if(pe(S,W,c)&&pe(_,O,c)){x[U]=true,K=true;break}}if(!K)return false}return true}let s=Object.keys(n),l=Object.keys(t);return s.length!==l.length?false:s.every(h=>Object.hasOwn(t,h)&&pe(n[h],t[h],c))}function Ue(n){if(n instanceof Date)return n.getTime();if(typeof n=="number"||typeof n=="bigint"||typeof n=="string")return n}function Ze(n,t,a){let c=Ue(t),o=Ue(a);if(c===void 0||o===void 0||typeof c!=typeof o)return false;switch(n){case "$gt":return c>o;case "$gte":return c>=o;case "$lt":return c<o;case "$lte":return c<=o;default:return false}}function Je(n,t,a,c){switch(n){case "$eq":return pe(t,a);case "$ne":return !pe(t,a);case "$in":return Array.isArray(a)&&a.some(o=>pe(t,o));case "$nin":return Array.isArray(a)&&!a.some(o=>pe(t,o));case "$exists":return a===(t!==void 0);case "$changed":return !pe(t,c);case "$gt":case "$gte":case "$lt":case "$lte":return Ze(n,t,a);case "$between":{if(!Array.isArray(a)||a.length!==2)return false;let o=Ue(a[0]),s=Ue(a[1]);return o!==void 0&&s!==void 0&&typeof o==typeof s&&o>s?(ye("$between: reversed pair \u2014 [min, max] required"),false):Ze("$gte",t,a[0])&&Ze("$lte",t,a[1])}case "$matches":{if(!(a instanceof RegExp))throw new Error("[Directive] $matches: operand must be a RegExp (string operands are no longer accepted; pass /pattern/flags directly).");return typeof t!="string"?false:a.test(t)}case "$startsWith":return typeof t!="string"?false:t.startsWith(String(a));case "$endsWith":return typeof t!="string"?false:t.endsWith(String(a));case "$contains":return typeof t=="string"?t.includes(String(a)):Array.isArray(t)?t.some(o=>pe(o,a)):t instanceof Set?t.has(a):false;default:return false}}function ye(n){chunkN4KTCKOI_cjs.a&&console.warn(`[Directive] ${n}`);}function Bt(n,t,a,c){if(Qe(n)){let o=Object.keys(n);o.length>1&&ye(`predicate: operator object has ${o.length} operators (${o.join(", ")}) \u2014 write the array form or $all instead. The runtime ANDs them as a best-effort fallback.`);for(let s of o)if(!Je(s,t,n[s],a))return false;return true}return me(n)?Be(n,me(t)?t:Object.create(null),me(a)?a:void 0,c+1):pe(t,n)}function Be(n,t,a,c=0){if(c>ze)return ye(`predicate depth limit (${ze}) exceeded \u2014 flatten the predicate or split it into multiple constraints. If this is unexpected, check for a cyclic spec object.`),false;if(Array.isArray(n))return n.every(o=>{if(!me(o))return false;let{fact:s,op:l,value:h}=o;return Je(l,t?.[s],h,a?.[s])});if(!me(n))return !!n;if("$all"in n)return n.$all.every(o=>Be(o,t,a,c+1));if("$any"in n)return n.$any.some(o=>Be(o,t,a,c+1));if("$not"in n)return !Be(n.$not,t,a,c+1);for(let o of Object.keys(n)){if(Ee.has(o))return ye(`predicate: operator "${o}" mixed with fact keys \u2014 wrap operators in a per-fact object`),false;if(!Bt(n[o],t?.[o],a?.[o],c))return false}return true}function Xe(n,t,a,c=""){let o=[];if(Array.isArray(n)){for(let s of n){if(!me(s))continue;let{fact:l,op:h,value:x}=s,S=t?.[l];o.push({path:c+l,op:h,expected:x,actual:S,pass:Je(h,S,x,a?.[l])});}return o}if(!me(n))return o;for(let s of ["$all","$any","$not"])if(s in n){let l=s==="$not"?[n.$not]:n[s],h=[];for(let _ of l)h.push(...Xe(_,t,a,c));let x=h.filter(_=>_.pass).length,S;return s==="$all"?S=h.length===0||x===h.length:s==="$any"?S=h.length>0&&x>0:S=!h.every(_=>_.pass),o.push({path:c||s,op:s,expected:l.length,actual:x,pass:S,children:h}),o}for(let s of Object.keys(n)){if(Ee.has(s))continue;let l=n[s],h=t?.[s],x=c+s;if(Qe(l))for(let S of Object.keys(l))o.push({path:x,op:S,expected:l[S],actual:h,pass:Je(S,h,l[S],a?.[s])});else me(l)?o.push(...Xe(l,me(h)?h:Object.create(null),me(a?.[s])?a?.[s]:void 0,`${x}.`)):o.push({path:x,op:"$eq",expected:l,actual:h,pass:pe(h,l)});}return o}var ct=new WeakMap;function Te(n){if(n===null||typeof n!="object")throw new Error(`[Directive] memoizePredicate: predicate must be a plain object or array; got ${typeof n}`);let t=ct.get(n);if(t)return t;let a=(c,o)=>Be(n,c,o);return ct.set(n,a),a}function dt(n,t=""){let a=new Set;return Me(n,{operator(c){a.add(t+c);},literal(c){a.add(t+c);},strayOperatorKey(c){Ee.has(c)||ye(`extractDeps: unknown operator "${c}" \u2014 skipping. Known operators: ${[...Ee].join(", ")}`);}}),a}var ft=/^[A-Za-z_][A-Za-z0-9_]*$/;function zt(n){return typeof n=="symbol"||n==null?"":String(n)}function Nt(n,t){return typeof n=="symbol"?(ye("template: cannot interpolate a symbol value \u2014 using empty string"),""):n===void 0?(ye(`template: ${t?`key "${t}" is `:""}undefined \u2014 using empty string`),""):n===null?(ye(`template: ${t?`key "${t}" is `:""}null \u2014 using empty string`),""):String(n)}function et(n,t){let a=n.$template,c="",o=0;for(;o<a.length;){if(a[o]==="$"&&a[o+1]==="$"&&a[o+2]==="{"){c+="${",o+=3;continue}if(a[o]==="$"&&a[o+1]==="{"){let s=a.indexOf("}",o+2);if(s===-1){ye(`template: unterminated "\${" in ${JSON.stringify(a)}`),c+=a.slice(o);break}let l=a.slice(o+2,s);if(!ft.test(l))ye(`template: invalid placeholder "\${${l}}" \u2014 not an identifier`);else {let h=t!=null&&Object.hasOwn(t,l),x=h?t[l]:void 0;h?c+=Nt(x,l):(ye(`template: unknown key "${l}"`),c+=zt(x));}o=s+1;continue}c+=a[o],o++;}return c}function bn(n){let t=new Set,a=n.$template,c=0;for(;c<a.length;){if(a[c]==="$"&&a[c+1]==="$"&&a[c+2]==="{"){c+=3;continue}if(a[c]==="$"&&a[c+1]==="{"){let o=a.indexOf("}",c+2);if(o===-1)break;let s=a.slice(c+2,o);ft.test(s)&&t.add(s),c=o+1;continue}c++;}return t}function gt(n,t){return n.map(a=>chunkEOLY64E6_cjs.d(t?.[a])).join("|")}function mt(n,t,a){let c=n.$set,o=a??{};for(let s of Object.keys(c)){let l=c[s];if(Ye(l))t[s]=et(l,o);else if(me(l)&&Object.hasOwn(l,"$ref")&&typeof l.$ref=="string"){let h=l.$ref;Object.hasOwn(o,h)||ye(`applyPatch: $ref "${h}" is missing from event payload \u2014 assigning undefined to fact "${s}"`),t[s]=o[h];}else t[s]=l;}}var je=class extends Error{constructor(a,c,o,s,l=true){super(a);this.source=c;this.sourceId=o;this.context=s;this.recoverable=l;this.name="DirectiveError";}};function Vt(){return {create(n){return n}}}function Ht(){return {create(n){return n}}}function Lt(n){return n}function Ut(n){return n}function Dn(n){return n._mode==="single"}function En(n){return n._mode==="namespaced"}function fe(n){if(!n)return;let t=Object.assign(Object.create(null),n);return Array.isArray(t.tags)&&Object.freeze(t.tags),Object.freeze(t)}function Cn(n){return typeof n=="object"&&n!==null&&Object.hasOwn(n,"compute")&&typeof n.compute=="function"}function Jt(n){return typeof n=="boolean"?{enabled:n,maxSnapshots:100}:{enabled:true,maxSnapshots:n.maxSnapshots??100}}function pt(n){let{historyOption:t,facts:a,store:c,onSnapshot:o,onHistoryChange:s}=n,{enabled:l,maxSnapshots:h}=Jt(t),x=[],S=-1,_=1,K=false,U=false,W=[],O=null,F=-1;function I(){return c.toObject()}function A(){let N=I();try{return structuredClone(N)}catch{try{return JSON.parse(JSON.stringify(N))}catch{return {...N}}}}function Y(N){if(!chunkEOLY64E6_cjs.e(N)){console.error("[Directive] Potential prototype pollution detected in snapshot data, skipping restore");return}c.batch(()=>{for(let[V,te]of Object.entries(N)){if(V==="__proto__"||V==="constructor"||V==="prototype"){console.warn(`[Directive] Skipping dangerous key "${V}" during fact restoration`);continue}a[V]=te;}});}return {get isEnabled(){return l},get isRestoring(){return U},get isPaused(){return K},get snapshots(){return [...x]},get currentIndex(){return S},takeSnapshot(N){if(!l||K)return {id:-1,timestamp:Date.now(),facts:{},trigger:N};let V={id:_++,timestamp:Date.now(),facts:A(),trigger:N};for(S<x.length-1&&x.splice(S+1),x.push(V),S=x.length-1;x.length>h;)x.shift(),S--;return o?.(V),V},restore(N){if(l){K=true,U=true;try{Y(N.facts);}finally{K=false,U=false;}}},goBack(N=1){if(!l||x.length===0)return;let V=S,te=S,ne=W.find(p=>S>p.startIndex&&S<=p.endIndex);if(ne)te=ne.startIndex;else if(W.find(f=>S===f.startIndex)){let f=W.find(w=>w.endIndex<S&&S-w.endIndex<=N);te=f?f.startIndex:Math.max(0,S-N);}else te=Math.max(0,S-N);if(V===te)return;S=te;let m=x[S];m&&(this.restore(m),s?.(V,te));},goForward(N=1){if(!l||x.length===0)return;let V=S,te=S,ne=W.find(p=>S>=p.startIndex&&S<p.endIndex);if(ne?te=ne.endIndex:te=Math.min(x.length-1,S+N),V===te)return;S=te;let m=x[S];m&&(this.restore(m),s?.(V,te));},goTo(N){if(!l)return;let V=x.findIndex(m=>m.id===N);if(V===-1){console.warn(`[Directive] Snapshot ${N} not found`);return}let te=S;S=V;let ne=x[S];ne&&(this.restore(ne),s?.(te,V));},replay(){if(!l||x.length===0)return;S=0;let N=x[0];N&&this.restore(N);},export(){return JSON.stringify({version:1,snapshots:x,currentIndex:S})},import(N){if(l)try{let V=JSON.parse(N);if(typeof V!="object"||V===null)throw new Error("[Directive] Invalid history data: expected object");if(V.version!==1)throw new Error(`[Directive] Unsupported history export version: ${V.version}`);if(!Array.isArray(V.snapshots))throw new Error("[Directive] Invalid history data: snapshots must be an array");if(typeof V.currentIndex!="number")throw new Error("Invalid history data: currentIndex must be a number");for(let ne of V.snapshots){if(typeof ne!="object"||ne===null)throw new Error("[Directive] Invalid snapshot: expected object");if(typeof ne.id!="number"||typeof ne.timestamp!="number"||typeof ne.trigger!="string"||typeof ne.facts!="object")throw new Error("Invalid snapshot structure");if(!chunkEOLY64E6_cjs.e(ne.facts))throw new Error("[Directive] Invalid fact data: potential prototype pollution detected in nested objects")}x.length=0,x.push(...V.snapshots),S=V.currentIndex;let te=x[S];te&&this.restore(te);}catch(V){console.error("[Directive] Failed to import history data:",V);}},beginChangeset(N){l&&(O=N,F=S);},endChangeset(){!l||O===null||(S>F&&W.push({label:O,startIndex:F,endIndex:S}),O=null,F=-1);},pause(){K=true;},resume(){K=false;}}}function yt(){let n={id:-1,timestamp:0,facts:{},trigger:""};return {isEnabled:false,isRestoring:false,isPaused:false,snapshots:[],currentIndex:-1,takeSnapshot:()=>n,restore:()=>{},goBack:()=>{},goForward:()=>{},goTo:()=>{},replay:()=>{},export:()=>"{}",import:()=>{},beginChangeset:()=>{},endChangeset:()=>{},pause:()=>{},resume:()=>{}}}var vt=new WeakMap;function Xt(n,t){if(t)return t(n);let a=vt.get(n);if(a!==void 0)return a;let{type:c,...o}=n,s=chunkEOLY64E6_cjs.d(o),l=`${c}:${s}`;return vt.set(n,l),l}function tt(n,t,a){return {requirement:n,id:Xt(n,a),fromConstraint:t}}function jn(n){return t=>({type:n,...t})}function An(n,t){return n.type===t}function Fn(n){return t=>t.type===n}var $e=class n{map=new Map;add(t){this.map.has(t.id)||this.map.set(t.id,t);}remove(t){return this.map.delete(t)}has(t){return this.map.has(t)}get(t){return this.map.get(t)}all(){return [...this.map.values()]}ids(){return [...this.map.keys()]}get size(){return this.map.size}clear(){this.map.clear();}clone(){let t=new n;for(let a of this.map.values())t.add(a);return t}diff(t){let a=[],c=[];for(let o of this.map.values())t.has(o.id)||a.push(o);for(let o of t.map.values())this.map.has(o.id)||c.push(o);return {added:a,removed:c}}};var Gt=5e3;function ht(n){let{definitions:t,facts:a,requirementKeys:c={},defaultTimeout:o=Gt,onEvaluate:s,onError:l}=n,h=new Map;function x(r,u){if(!u||typeof u.when=="function")return;let v=u.when;if(chunkN4KTCKOI_cjs.a&&(u.async&&console.warn(`[Directive] constraint "${r}": data \`when\` is always sync; \`async: true\` will be ignored`),u.deps&&console.warn(`[Directive] constraint "${r}": data \`when\` cannot be combined with explicit \`deps\` \u2014 deps are tracked automatically`)),u.deps&&(u.deps=void 0),S(v))throw new Error(`[Directive] constraint "${r}": $changed is effects-only \u2014 constraint when has no prev snapshot. Move the change-detection to an effect, or use a boolean derivation as a synthetic prev.`);if(v===null||typeof v!="object")throw new Error(`[Directive] memoizePredicate: predicate must be a plain object or array; got ${typeof v}`);chunkN4KTCKOI_cjs.a&&ut(v)&&console.warn(`[Directive] constraint '${r}': data spec has no operators, combinators, or clauses \u2014 looks like a config object passed by mistake. Either pass a predicate like { phase: 'red' } or a function.`),chunkEOLY64E6_cjs.a(v);let E=Te(v);u.when=chunkEOLY64E6_cjs.b("constraint",r,P=>E(P)),h.set(r,v),u.async&&(u.async=false);}function S(r){let u=false;return Me(r,{operator(v,E){E==="$changed"&&(u=true);},strayOperatorKey(v){v==="$changed"&&(u=true);}}),u}for(let r of Object.keys(t))x(r,t[r]);let _=new Map,K=new Set,U=new Set,W=new Map,O=new Map,F=new Set,I=new Map,A=new Map,Y=false,se=new Set,N=new Set,V=new Map,te=[],ne=new Map;function m(r,u){t[r]&&(V.has(r)||V.set(r,new Set),V.get(r).add(u));}function p(){V.clear();for(let[r,u]of Object.entries(t))if(u.after)for(let v of u.after)m(v,r);}function f(r,u,v,E,P){if(v.has(r))return;if(E.has(r)){let ae=u.indexOf(r),ce=[...u.slice(ae),r].join(" \u2192 ");throw new Error(`[Directive] Constraint cycle detected: ${ce}. Remove one of the \`after\` dependencies to break the cycle.`)}E.add(r),u.push(r);let Q=t[r];if(Q?.after)for(let ae of Q.after)t[ae]&&f(ae,u,v,E,P);u.pop(),E.delete(r),v.add(r),P.push(r);}function w(){let r=new Set,u=new Set,v=[];for(let E of Object.keys(t))f(E,[],r,u,v);te=v,ne=new Map(te.map((E,P)=>[E,P]));}w(),p();function j(){for(let[r,u]of Object.entries(t))if(u.after)for(let v of u.after)t[v]||console.warn(`[Directive] Constraint "${r}" references unknown constraint "${v}" in \`after\`. This dependency will be ignored. Check for typos or ensure the constraint exists.`);}chunkN4KTCKOI_cjs.a&&j();function G(r,u){return u.async!==void 0?u.async:!!U.has(r)}function re(r){let u=t[r];if(!u)throw new Error(`[Directive] Unknown constraint: ${r}`);let v=G(r,u);v&&U.add(r);let E={id:r,priority:u.priority??0,isAsync:v,lastResult:null,isEvaluating:false,error:null,lastResolvedAt:null,after:u.after??[],hitCount:0,lastActiveAt:null};return _.set(r,E),E}function le(r){return _.get(r)??re(r)}function be(r,u){if(r.size!==u.size||r.size===0)return false;for(let v of u)if(!r.has(v))return false;return true}function k(r,u){for(let v of u){let E=O.get(v);E&&(E.delete(r),E.size===0&&O.delete(v));}}function d(r,u){for(let v of u)O.has(v)||O.set(v,new Set),O.get(v).add(r);}function C(r){let u=W.get(r);u&&(k(r,u),W.delete(r));}function T(r){V.delete(r);for(let u of V.values())u.delete(r);}function H(r,u){let v=W.get(r)??new Set;be(v,u)||(k(r,v),d(r,u),W.set(r,u));}function ee(r,u){let v=u.when;if(u.deps)return I.set(r,new Set(u.deps)),v(a);let E=chunkN4KTCKOI_cjs.i(()=>v(a));return I.set(r,E.deps),E.value}function de(r,u,v){u.lastResult=v,v&&(u.hitCount++,u.lastActiveAt=Date.now()),u.isEvaluating=false,s?.(r,v);}function ve(r,u,v){u.error=v instanceof Error?v:new Error(String(v)),u.lastResult=false,u.isEvaluating=false,l?.(r,v);}function he(r,u,v){return U.add(r),u.isAsync=true,chunkN4KTCKOI_cjs.a&&console.warn(`[Directive] Constraint "${r}" returned a Promise but was not marked as async. Add \`async: true\` to the constraint definition to avoid this warning and improve performance.`),v.then(E=>(de(r,u,E),E)).catch(E=>(ve(r,u,E),false))}function we(r){let u=t[r];if(!u)return false;let v=le(r);v.isEvaluating=true,v.error=null;try{let E=ee(r,u);return E instanceof Promise?he(r,v,E):(de(r,v,E),E)}catch(E){return ve(r,v,E),false}}async function Re(r){let u=t[r];if(!u)return false;let v=le(r),E=u.timeout??o;if(v.isEvaluating=true,v.error=null,u.deps?.length){let P=new Set(u.deps);H(r,P),I.set(r,P);}try{let P=u.when(a),Q=await chunkEOLY64E6_cjs.c(P,E,`Constraint "${r}" timed out after ${E}ms`);return v.lastResult=Q,Q&&(v.hitCount++,v.lastActiveAt=Date.now()),v.isEvaluating=!1,s?.(r,Q),Q}catch(P){return v.error=P instanceof Error?P:new Error(String(P)),v.lastResult=false,v.isEvaluating=false,l?.(r,P),false}}let xe=10;function Ie(r,u){if(r==null)return [];if(Array.isArray(r)){let v=r.filter(E=>E!=null);return chunkN4KTCKOI_cjs.a&&v.length>xe&&u&&console.warn(`[Directive] Constraint "${u}" produced ${v.length} requirements. Consider splitting into multiple constraints for better performance.`),v}return [r]}function ke(r){let u=t[r];if(!u)return {requirements:[],deps:new Set};let v=u.require;if(typeof v=="function"){let{value:P,deps:Q}=chunkN4KTCKOI_cjs.i(()=>v(a));return {requirements:Ie(P,r),deps:Q}}return {requirements:Ie(v,r),deps:new Set}}function B(r,u){if(u.size===0)return;let v=W.get(r)??new Set;for(let E of u)v.add(E);d(r,u),W.set(r,v);}let oe=null;function ge(){return oe||(oe=Object.keys(t).sort((r,u)=>{let v=le(r),P=le(u).priority-v.priority;if(P!==0)return P;let Q=ne.get(r)??0,ae=ne.get(u)??0;return Q-ae})),oe}for(let r of Object.keys(t))re(r);function Ce(r){for(let[u,v]of Object.entries(r))v.async&&!v.deps&&console.warn(`[Directive] Async constraint "${u}" has no \`deps\` declared. Auto-tracking cannot work across async boundaries. Add \`deps: ["key1", "key2"]\` to enable dependency tracking.`);}chunkN4KTCKOI_cjs.a&&Ce(t);function Ae(r){return !t[r]||K.has(r)||N.has(r)?true:se.has(r)}function y(r){let u=_.get(r);if(!u||u.after.length===0)return true;for(let v of u.after)if(!Ae(v))return false;return true}function b(r){let u=I.get(r);u!==void 0&&H(r,u),N.add(r),A.set(r,[]);}function R(r,u,v){if(u!==void 0){let E=new Set(u);for(let P of v)E.add(P);H(r,E);}else B(r,v);}function q(r,u,v){if(u.length===0){A.set(r,[]);return}let E=u.map(P=>tt(P,r,c[P.type]));for(let P of E)v.add(P);A.set(r,E);}function L(r,u){for(let v of r)u.add(v);}function e(r,u,v){if(K.has(r))return;if(!u){b(r);return}N.delete(r);let E=I.get(r),P,Q;try{let ae=ke(r);P=ae.requirements,Q=ae.deps;}catch(ae){l?.(r,ae),b(r);return}R(r,E,Q),q(r,P,v);}function i(r,u){let v=[],E=[];for(let P of r){if(y(P)){E.push(P);continue}v.push(P);let Q=A.get(P);Q&&L(Q,u);}return {blocked:v,ready:E}}function g(r,u){let v=[];for(let E of r){let P=we(E);if(P instanceof Promise){v.push({id:E,promise:P});continue}e(E,P,u);}return v}async function M(r,u){let v=await Promise.all(r.map(async({id:E,promise:P})=>({id:E,active:await P})));for(let{id:E,active:P}of v)e(E,P,u);}async function D(r,u){let{blocked:v,ready:E}=i(r,u);if(E.length===0)return v;let P=[],Q=[];for(let ce of E)le(ce).isAsync?Q.push(ce):P.push(ce);let ae=g(P,u);if(ae.length>0&&await M(ae,u),Q.length>0){let ce=Q.map(Se=>({id:Se,promise:Re(Se)}));await M(ce,u);}return v}function $(r,u){for(let v of r){let E=O.get(v);if(E)for(let P of E)K.has(P)||u.add(P);}}function z(r){for(let u of F)K.has(u)||r.add(u);F.clear();}function X(r){let u=new Set;return $(r,u),z(u),u}function Z(r,u,v){for(let E of r){if(u.has(E))continue;let P=A.get(E);P&&L(P,v);}}return {async evaluate(r){let u=new $e;N.clear();let v=ge(),E=K.size===0?v:v.filter(ce=>!K.has(ce)),P;if(!Y||!r||r.size===0)P=E,Y=true;else {let ce=X(r);P=[...ce],Z(E,ce,u);}let Q=P,ae=P.length+1;for(;Q.length>0&&ae>0;){let ce=Q.length;if(Q=await D(Q,u),Q.length===ce)break;ae--;}return u.all()},getState(r){return _.get(r)},getDependencies(r){return W.get(r)},getAllStates(){return [..._.values()]},disable(r){if(!_.has(r)){console.warn(`[Directive] constraints.disable("${r}") \u2014 no such constraint`);return}K.add(r),oe=null,A.delete(r),C(r),I.delete(r);},enable(r){if(!_.has(r)){console.warn(`[Directive] constraints.enable("${r}") \u2014 no such constraint`);return}K.delete(r),oe=null,F.add(r);},isDisabled(r){return K.has(r)},invalidate(r){let u=O.get(r);if(u)for(let v of u)F.add(v);},markResolved(r){se.add(r);let u=_.get(r);u&&(u.lastResolvedAt=Date.now());let v=V.get(r);if(v)for(let E of v)F.add(E);},isResolved(r){return se.has(r)},registerDefinitions(r){let u=false;for(let[v,E]of Object.entries(r))t[v]=E,x(v,t[v]),re(v),F.add(v),E.after?.length&&(u=true);oe=null,u&&w(),p();},assignDefinition(r,u){if(!t[r])throw new Error(`[Directive] Cannot assign constraint "${r}" \u2014 it does not exist. Use register() to create it.`);t[r]=u,h.delete(r),x(r,t[r]),re(r),F.add(r),oe=null,w(),p();},unregisterDefinition(r){t[r]&&(delete t[r],_.delete(r),K.delete(r),U.delete(r),F.delete(r),N.delete(r),se.delete(r),A.delete(r),I.delete(r),C(r),T(r),oe=null,w(),p());},async callOne(r,u){if(!t[r])throw new Error(`[Directive] Cannot call constraint "${r}" \u2014 it does not exist.`);if(K.has(r))return [];let E=le(r),P;if(E.isAsync)P=await Re(r);else {let ce=we(r);P=ce instanceof Promise?await ce:ce;}if(!P)return [];let{requirements:Q}=ke(r);if(Q.length===0)return [];let ae=[];for(let ce of Q){let Se=u?{...ce,...u}:ce;ae.push(tt(Se,r,c[Se.type]));}return ae},setRequirementKey(r,u){c[r]=u;},removeRequirementKey(r){delete c[r];},getWhenSpec(r){return h.get(r)},explainWhen(r){let u=h.get(r);if(u)return Xe(u,a)}}}function St(n){let{definitions:t,facts:a,onCompute:c,onInvalidate:o,onError:s}=n,l=3,h=new Map;function x(k,d){if(typeof d!="object"||d===null||!Object.hasOwn(d,"compute"))return;let C=d,T=C.compute,H;if(typeof T=="function")H=T;else if(Ye(T))chunkEOLY64E6_cjs.a(T),H=ee=>et(T,ee);else if(typeof T=="object"&&T!==null){chunkEOLY64E6_cjs.a(T);let ee=Te(T);H=chunkEOLY64E6_cjs.b("derivation",k,de=>ee(de));}else if(T!==void 0)throw new Error(`[Directive] memoizePredicate: predicate must be a plain object or array; got ${typeof T}`);if(H){t[k]=H;let ee=fe(C.meta);ee&&h.set(k,ee);}}for(let[k,d]of Object.entries(t))x(k,d);let S=new Map,_=new Map,K=new Map,U=new Map,W=0,O=new Set,F=false,I=100,A;function Y(k,d){let C=S.has(k)?U:K,T=C.get(k);T?.delete(d),T&&T.size===0&&C.delete(k);}function se(k,d){let C=t[k]?U:K,T=C.get(k);T||(T=new Set,C.set(k,T)),T.add(d);}function N(k){let d=S.get(k);if(d)for(let C of d.dependencies)Y(C,k);}function V(k){let d=U.get(k);if(d){W++;try{for(let C of d)le(C);}finally{W--;}U.delete(k);}}function te(k){delete t[k],S.delete(k),_.delete(k),O.delete(k),h.delete(k);}function ne(k){if(!t[k])throw new Error(`[Directive] Unknown derivation: ${k}`);let C={id:k,compute:()=>p(k),cachedValue:void 0,dependencies:new Set,isStale:true,isComputing:false,stableRunCount:0,depsStable:false};return S.set(k,C),C}function m(k){return S.get(k)??ne(k)}function p(k){let d=m(k),C=t[k];if(!C)throw new Error(`[Directive] Unknown derivation: ${k}`);if(d.isComputing)throw new Error(`[Directive] Circular dependency detected in derivation: ${k}`);d.isComputing=true;try{let T=d.cachedValue,H,ee;if(d.depsStable&&d.dependencies.size>0)H=C(a,A),ee=d.dependencies;else {let de=chunkN4KTCKOI_cjs.i(()=>C(a,A));H=de.value,ee=de.deps,d.dependencies.size>0&&f(ee,d.dependencies)?(d.stableRunCount++,d.stableRunCount>=l&&(d.depsStable=!0)):d.stableRunCount=0;}return d.cachedValue=H,d.isStale=!1,w(k,ee),c&&c(k,H,T,[...ee]),H}catch(T){throw s?.(k,T),T}finally{d.isComputing=false;}}function f(k,d){if(k.size!==d.size)return false;for(let C of d)if(!k.has(C))return false;return true}function w(k,d){let C=m(k),T=C.dependencies;if(!f(T,d)){for(let H of T)Y(H,k);for(let H of d)se(H,k);C.dependencies=d;}}function j(k){for(let d of k){let C=_.get(d);if(C)for(let T of C)T();}}function G(){if(!(W>0||F)){F=true;try{let k=0;for(;O.size>0;){if(++k>I){let C=[...O];throw O.clear(),new Error(`[Directive] Infinite derivation notification loop detected after ${I} iterations. Remaining: ${C.join(", ")}. This usually means a derivation listener is mutating facts that re-trigger the same derivation.`)}let d=[...O];O.clear(),j(d);}}finally{F=false;}}}function re(k,d){let C=U.get(k);if(C)for(let T of C)d.push(T);}function le(k,d=new Set){let C=[k];for(;C.length>0;){let T=C.pop();if(d.has(T))continue;d.add(T);let H=S.get(T);!H||H.isStale||(H.isStale=true,H.depsStable=false,H.stableRunCount=0,o?.(T),O.add(T),re(T,C));}}return A=new Proxy({},{get(k,d){if(typeof d=="symbol"||chunkN4KTCKOI_cjs.l.has(d)||!t[d])return;chunkN4KTCKOI_cjs.k(d);let C=m(d);return C.isStale&&p(d),C.cachedValue},set(){return false},deleteProperty(){return false},defineProperty(){return false},getPrototypeOf(){return null},setPrototypeOf(){return false}}),{get(k){let d=m(k);return d.isStale&&p(k),d.cachedValue},isStale(k){return S.get(k)?.isStale??true},invalidate(k){let d=K.get(k);if(!d)return;W++;let C=new Set;try{for(let T of d)le(T,C);}finally{W--,G();}},invalidateMany(k){W++;let d=new Set;try{for(let C of k){let T=K.get(C);if(T)for(let H of T)le(H,d);}}finally{W--,G();}},invalidateAll(){W++;try{for(let k of S.values())k.isStale||(k.isStale=!0,k.depsStable=!1,k.stableRunCount=0,O.add(k.id));}finally{W--,G();}},subscribe(k,d){for(let C of k){let T=C;_.has(T)||_.set(T,new Set),_.get(T).add(d);}return ()=>{for(let C of k){let T=C,H=_.get(T);H?.delete(d),H&&H.size===0&&_.delete(T);}}},getProxy(){return A},getDependencies(k){return m(k).dependencies},registerDefinitions(k){for(let[d,C]of Object.entries(k))typeof C=="function"?t[d]=C:x(d,C),ne(d);},assignDefinition(k,d){if(!t[k])throw new Error(`[Directive] Cannot assign derivation "${k}" \u2014 it does not exist. Use register() to create it.`);typeof d=="function"?(t[k]=d,h.delete(k)):(h.delete(k),x(k,d));let C=S.get(k);C&&(C.isStale=true,C.depsStable=false,C.stableRunCount=0,O.add(k)),G();},unregisterDefinition(k){t[k]&&(N(k),V(k),te(k),G());},getMeta(k){return h.get(k)},callOne(k){if(!t[k])throw new Error(`[Directive] Cannot call derivation "${k}" \u2014 it does not exist.`);return p(k)}}}var Zt=3;function bt(n){let{definitions:t,facts:a,store:c,onRun:o,onError:s}=n,l=new Map,h=null,x=false,S=new Map;function _(m){let p=t[m];if(!p)throw new Error(`[Directive] Unknown effect: ${m}`);S.delete(m);let f=null,w=false;if(p.deps)f=new Set(p.deps),w=true;else if(p.on!==void 0){if(!lt(p.on))throw new Error(`[Directive] effect on must be a FactPredicate spec; got ${typeof p.on}`);if(p.on===null||typeof p.on!="object")throw new Error(`[Directive] memoizePredicate: predicate must be a plain object or array; got ${typeof p.on}`);chunkEOLY64E6_cjs.a(p.on),f=dt(p.on),w=true;let G=Te(p.on);S.set(m,chunkEOLY64E6_cjs.b("effect",m,(re,le)=>G(re,le)));}let j={id:m,enabled:true,hasExplicitDeps:w,dependencies:f,cleanup:null,stableRunCount:0,depsStable:false};return l.set(m,j),j}function K(m){return l.get(m)??_(m)}function U(){return c.toObject()}function W(m){m.depsStable=false,m.stableRunCount=0;}function O(m,p){for(let f of m)if(p.has(f))return true;return false}function F(m,p){let f=K(m);if(!f.enabled)return false;if(f.dependencies){if(!O(f.dependencies,p))return false;f.depsStable&&W(f);let w=S.get(m);if(w){let j=U();return w(j,h??void 0)}return true}return true}function I(m){if(m.cleanup){try{m.cleanup();}catch(p){s?.(m.id,p),console.error(`[Directive] Effect "${m.id}" cleanup threw an error:`,p);}m.cleanup=null;}}function A(m,p){if(typeof p=="function")if(x)try{p();}catch(f){s?.(m.id,f),console.error(`[Directive] Effect "${m.id}" cleanup threw an error:`,f);}else m.cleanup=p;}async function Y(m,p){let f;if(c.batch(()=>{f=p.run(a,h);}),f instanceof Promise){let w=await f;A(m,w);}else A(m,f);}function se(m,p){if(m.size!==p.size)return false;for(let f of p)if(!m.has(f))return false;return true}function N(m,p){if(!(m.dependencies&&se(m.dependencies,p))){W(m);return}m.stableRunCount++,m.stableRunCount>=Zt&&(m.depsStable=true);}async function V(m,p){if(m.depsStable&&m.dependencies){await Y(m,p);return}let f,w=chunkN4KTCKOI_cjs.i(()=>(c.batch(()=>{f=p.run(a,h);}),f)),j=w.deps,G=w.value;G instanceof Promise&&(G=await G),A(m,G),N(m,j),m.dependencies=j.size>0?j:null;}async function te(m){let p=K(m),f=t[m];if(!(!p.enabled||!f)){I(p),o?.(m,p.dependencies?[...p.dependencies]:[]);try{p.hasExplicitDeps?await Y(p,f):await V(p,f);}catch(w){s?.(m,w),console.error(`[Directive] Effect "${m}" threw an error:`,w),p.hasExplicitDeps||W(p);}}}for(let m of Object.keys(t))_(m);return {async runEffects(m){let p=[];for(let f of Object.keys(t))F(f,m)&&p.push(f);await Promise.all(p.map(te)),h=U();},async runAll(){let m=Object.keys(t);await Promise.all(m.map(p=>{let f=K(p);return f.enabled?(W(f),te(p)):Promise.resolve()})),h=U();},disable(m){let p=K(m);p.enabled=false;},enable(m){let p=K(m);p.enabled=true;},isEnabled(m){return K(m).enabled},cleanupAll(){x=true;for(let m of l.values())I(m);},registerDefinitions(m){for(let[p,f]of Object.entries(m))t[p]=f,_(p);},assignDefinition(m,p){if(!t[m])throw new Error(`[Directive] Cannot assign effect "${m}" \u2014 it does not exist. Use register() to create it.`);let f=l.get(m);f&&I(f),t[m]=p,_(m);},unregisterDefinition(m){if(!t[m])return;let p=l.get(m);p&&I(p),delete t[m],l.delete(m),S.delete(m);},async callOne(m){let p=t[m];if(!p)throw new Error(`[Directive] Cannot call effect "${m}" \u2014 it does not exist.`);let f=K(m);if(f.enabled){I(f),o?.(m,f.dependencies?[...f.dependencies]:[]);try{let w;if(c.batch(()=>{w=p.run(a,h);}),w instanceof Promise){let j=await w;A(f,j);}else A(f,w);}catch(w){s?.(m,w),console.error(`[Directive] Effect "${m}" threw an error:`,w);}}}}}function Qt(n={}){let{delayMs:t=1e3,maxRetries:a=3,backoffMultiplier:c=2,maxDelayMs:o=3e4}=n,s=new Map;function l(h){let x=t*c**(h-1);return Math.min(x,o)}return {scheduleRetry(h,x,S,_,K){if(_>a)return null;let U=l(_),W={source:h,sourceId:x,context:S,attempt:_,nextRetryTime:Date.now()+U,callback:K};return s.set(x,W),W},getPendingRetries(){return Array.from(s.values())},processDueRetries(){let h=Date.now(),x=[];for(let[S,_]of s)_.nextRetryTime<=h&&(x.push(_),s.delete(S));return x},cancelRetry(h){s.delete(h);},clearAll(){s.clear();}}}var Yt={constraint:"skip",resolver:"skip",effect:"skip",derivation:"skip",system:"throw"};function wt(n={}){let{config:t={},onError:a,onRecovery:c}=n,o=[],s=100,l=Qt(t.retryLater),h=new Map,x=1e3;function S(O,F,I,A){if(I instanceof je)return I;let Y=I instanceof Error?I.message:String(I),se=O!=="system";return new je(Y,O,F,A,se)}function _(O,F,I){let A=(()=>{switch(O){case "constraint":return t.onConstraintError;case "resolver":return t.onResolverError;case "effect":return t.onEffectError;case "derivation":return t.onDerivationError;default:return}})();if(typeof A=="function"){try{let Y=A(I,F);if(typeof Y=="string")return Y}catch(Y){console.error("[Directive] Error in error handler callback:",Y);}return "skip"}return typeof A=="string"?A:Yt[O]}function K(O){o.push(O),o.length>s&&o.shift();try{a?.(O);}catch(F){console.error("[Directive] Error in onError callback:",F);}try{t.onError?.(O);}catch(F){console.error("[Directive] Error in config.onError callback:",F);}}function U(O,F,I){let A=(h.get(F)??0)+1;if(h.set(F,A),h.size>x){let se=h.keys().next().value;se!==void 0&&h.delete(se);}return l.scheduleRetry(O,F,I,A)?"retry-later":(h.delete(F),typeof process<"u"&&process.env?.NODE_ENV!=="production"&&console.warn(`[Directive] ${O} "${F}" exceeded max retry-later attempts. Skipping.`),"skip")}return {handleError(O,F,I,A){let Y=S(O,F,I,A);K(Y);let se=_(O,F,I instanceof Error?I:new Error(String(I)));se==="retry-later"&&(se=U(O,F,A));try{c?.(Y,se);}catch(N){console.error("[Directive] Error in onRecovery callback:",N);}if(se==="throw")throw Y;return se},getLastError(){return o[o.length-1]??null},getAllErrors(){return [...o]},clearErrors(){o.length=0;},getRetryLaterManager(){return l},processDueRetries(){return l.processDueRetries()},clearRetryAttempts(O){h.delete(O),l.cancelRetry(O);}}}function en(n,t=100){try{return JSON.stringify(n)?.slice(0,t)??String(n)}catch{return "[circular or non-serializable]"}}function tn(n){let{schema:t,onChange:a,onBatch:c}=n,s=Object.keys(t).length===0,l=n.validate??chunkN4KTCKOI_cjs.a,h=n.strictKeys??(chunkN4KTCKOI_cjs.a&&!s),x=n.redactErrors??false,S=new Map,_=new Set,K=new Map,U=new Set,W=0,O=[],F=new Set,I=false,A=[],Y=100;function se(d){return d!==null&&typeof d=="object"&&"safeParse"in d&&typeof d.safeParse=="function"&&"_def"in d&&"parse"in d&&typeof d.parse=="function"}function N(d){let C=d;if(C._typeName)return C._typeName;if(se(d)){let T=d._def;if(T?.typeName)return T.typeName.replace(/^Zod/,"").toLowerCase()}return "unknown"}function V(d){return x?"[redacted]":en(d)}function te(d){return d===null?"null":Array.isArray(d)?"array":typeof d}function ne(d,C,T){let H=T.safeParse(C);if(H.success)return;let ee=te(C),de=V(C),ve=H.error?.message??H.error?.issues?.[0]?.message??"Validation failed",he=N(T);throw new Error(`[Directive] Validation failed for "${d}": expected ${he}, got ${ee} ${de}. ${ve}`)}function m(d){if(typeof d._lastFailedIndex=="number"&&d._lastFailedIndex>=0){let C=` (element at index ${d._lastFailedIndex} failed)`;return d._lastFailedIndex=-1,C}return ""}function p(d,C,T){let H=T._validators;if(!H||!Array.isArray(H)||H.length===0)return;let ee=T._typeName??"unknown";for(let de=0;de<H.length;de++){let ve=H[de];if(typeof ve!="function"||ve(C))continue;let he=te(C),we=V(C),Re=m(T),xe=de===0?"":` (validator ${de+1} failed)`;throw new Error(`[Directive] Validation failed for "${d}": expected ${ee}, got ${he} ${we}${xe}${Re}`)}}function f(d){if(h)throw new Error(`[Directive] Unknown fact key: "${d}". Key not defined in schema.`);console.warn(`[Directive] Unknown fact key: "${d}"`);}function w(d,C){if(!l)return;let T=t[d];if(!T){f(d);return}if(se(T)){ne(d,C,T);return}p(d,C,T);}function j(d){K.get(d)?.forEach(C=>C());}function G(){U.forEach(d=>d());}function re(d,C,T){if(I){A.push({key:d,value:C,prev:T});return}I=true;try{a?.(d,C,T),j(d),G(),le(". A listener is repeatedly mutating facts that re-trigger notifications");}finally{I=false;}}function le(d){let C=0;for(;A.length>0;){if(++C>Y)throw A.length=0,new Error(`[Directive] Infinite notification loop detected after ${Y} iterations${d}.`);let T=[...A];A.length=0;for(let H of T)a?.(H.key,H.value,H.prev),j(H.key);G();}}function be(){if(!(W>0)){if(c&&O.length>0&&c([...O]),F.size>0){I=true;try{for(let d of F)j(d);G(),le(" during flush");}finally{I=false;}}O.length=0,F.clear();}}let k={get(d){return chunkN4KTCKOI_cjs.k(d),S.get(d)},has(d){return chunkN4KTCKOI_cjs.k(d),S.has(d)},set(d,C){chunkN4KTCKOI_cjs.a&&w(d,C);let T=S.get(d);Object.is(T,C)||(S.set(d,C),_.add(d),W>0?(O.push({key:d,value:C,prev:T,type:"set"}),F.add(d)):re(d,C,T));},delete(d){let C=S.get(d);S.delete(d),_.delete(d),W>0?(O.push({key:d,value:void 0,prev:C,type:"delete"}),F.add(d)):re(d,void 0,C);},batch(d){W++;try{d();}finally{W--,be();}},subscribe(d,C){for(let T of d){let H=T;K.has(H)||K.set(H,new Set),K.get(H).add(C);}return ()=>{for(let T of d){let H=K.get(T);H&&(H.delete(C),H.size===0&&K.delete(T));}}},subscribeAll(d){return U.add(d),()=>U.delete(d)},toObject(){let d={};for(let C of _)S.has(C)&&(d[C]=S.get(C));return d}};return k.destroy=()=>{K.clear(),U.clear();},k.registerKeys=d=>{for(let C of Object.keys(d))chunkN4KTCKOI_cjs.l.has(C)||(t[C]=d[C],_.add(C));},k}var nt=new WeakMap;function Rt(n,t,a=t){return new Proxy(n,{get(c,o){if(typeof o=="string"&&chunkN4KTCKOI_cjs.l.has(o))return;if(o===Symbol.for("nodejs.util.inspect.custom"))return ()=>c;let s=Reflect.get(c,o);if(typeof o=="symbol"||typeof s!="object"||s===null)return s;if(nt.has(s))return nt.get(s);let l=Rt(s,t,`${a}.${String(o)}`);return nt.set(s,l),l},set(c,o,s){return typeof o!="symbol"&&console.warn(`[Directive] Nested mutation on "facts.${a}.${String(o)}" will not trigger reactivity. Use: facts.${t} = { ...facts.${t}, ... }`),Reflect.set(c,o,s)}})}function nn(n,t){let a=()=>({get:o=>chunkN4KTCKOI_cjs.j(()=>n.get(o)),has:o=>chunkN4KTCKOI_cjs.j(()=>n.has(o))});return new Proxy({},{get(o,s){if(typeof s=="symbol")return s===Symbol.for("nodejs.util.inspect.custom")?()=>chunkN4KTCKOI_cjs.j(()=>n.toObject()):void 0;if(chunkN4KTCKOI_cjs.l.has(s))return;if(s==="$store")return n;if(s==="$snapshot")return a;let l=n.get(s);return chunkN4KTCKOI_cjs.a&&l!==null&&typeof l=="object"?Rt(l,s):l},set(o,s,l){if(typeof s=="symbol"||s==="$store"||s==="$snapshot"||chunkN4KTCKOI_cjs.l.has(s))return false;if(chunkN4KTCKOI_cjs.a){let h=chunkN4KTCKOI_cjs.m(l);h&&chunkN4KTCKOI_cjs.n(s,h);}return n.set(s,l),true},deleteProperty(o,s){return typeof s=="symbol"||s==="$store"||s==="$snapshot"||chunkN4KTCKOI_cjs.l.has(s)?false:(n.delete(s),true)},has(o,s){return s==="$store"||s==="$snapshot"?true:typeof s=="symbol"||chunkN4KTCKOI_cjs.l.has(s)?false:n.has(s)},ownKeys(){return Object.keys(t)},getOwnPropertyDescriptor(o,s){if(!(typeof s=="string"&&chunkN4KTCKOI_cjs.l.has(s)))return s==="$store"||s==="$snapshot"?{configurable:true,enumerable:false,writable:false}:{configurable:true,enumerable:true,writable:true}},defineProperty(){return false},getPrototypeOf(){return null},setPrototypeOf(){return false}})}function kt(n){let t=tn(n),a=nn(t,n.schema);return {store:t,facts:a}}function Dt(){let n=[];function t(s){if(s)try{return s()}catch(l){console.error("[Directive] Plugin error:",l);return}}async function a(s){if(s)try{return await s()}catch(l){console.error("[Directive] Plugin error:",l);return}}function c(s){return (...l)=>{for(let h of n)t(()=>h[s]?.(...l));}}return {register(s){n.some(l=>l.name===s.name)&&(console.warn(`[Directive] Plugin "${s.name}" is already registered, replacing...`),this.unregister(s.name)),n.push(s);},unregister(s){let l=n.findIndex(h=>h.name===s);l!==-1&&n.splice(l,1);},getPlugins(){return [...n]},async emitInit(s){for(let l of n)await a(()=>l.onInit?.(s));},emitStart:c("onStart"),emitStop:c("onStop"),emitDestroy:c("onDestroy"),emitFactSet:c("onFactSet"),emitFactDelete:c("onFactDelete"),emitFactsBatch:c("onFactsBatch"),emitDerivationCompute:c("onDerivationCompute"),emitDerivationInvalidate:c("onDerivationInvalidate"),emitReconcileStart:c("onReconcileStart"),emitReconcileEnd:c("onReconcileEnd"),emitConstraintEvaluate:c("onConstraintEvaluate"),emitConstraintError:c("onConstraintError"),emitRequirementCreated:c("onRequirementCreated"),emitRequirementMet:c("onRequirementMet"),emitRequirementCanceled:c("onRequirementCanceled"),emitResolverStart:c("onResolverStart"),emitResolverComplete:c("onResolverComplete"),emitResolverError:c("onResolverError"),emitResolverRetry:c("onResolverRetry"),emitResolverCancel:c("onResolverCancel"),emitResolverWriteRejected:c("onResolverWriteRejected"),emitEffectRun:c("onEffectRun"),emitEffectError:c("onEffectError"),emitSnapshot:c("onSnapshot"),emitHistoryNavigate:c("onHistoryNavigate"),emitError:c("onError"),emitErrorRecovery:c("onErrorRecovery"),emitDefinitionRegister:c("onDefinitionRegister"),emitDefinitionAssign:c("onDefinitionAssign"),emitDefinitionUnregister:c("onDefinitionUnregister"),emitDefinitionCall:c("onDefinitionCall"),emitTraceComplete:c("onTraceComplete")}}var Et={attempts:1,backoff:"none",initialDelay:100,maxDelay:3e4},xt={enabled:false,windowMs:50};function rn(n,t){if(!t||t==="none")return n;if(t==="full")return Math.floor(Math.random()*n);if(t==="equal"){let a=n/2;return Math.floor(a+Math.random()*a)}if(typeof t=="object"&&"maxMs"in t){let a=Number.isFinite(t.maxMs)&&t.maxMs>0?t.maxMs:0;return n+Math.floor(Math.random()*a)}return n}function on(n,t){let{backoff:a,initialDelay:c=100,maxDelay:o=3e4}=n,s;switch(a){case "none":s=c;break;case "linear":s=c*t;break;case "exponential":s=c*2**(t-1);break;default:s=c;}let l=Math.min(s,o),h=rn(l,n.jitter);return Math.max(1,h)}function sn(n){if(chunkN4KTCKOI_cjs.a)for(let[t,a]of Object.entries(n)){if(!a.resolve&&!a.resolveBatch&&!a.resolveBatchWithResults)throw new Error(`[Directive] Resolver "${t}" must define either resolve() or resolveBatch(). Add one of these methods to handle requirements.`);if(!(!a.batch?.enabled||a.resolveBatch||a.resolveBatchWithResults))if(a.resolve)console.warn(`[Directive] Resolver "${t}" has batch.enabled but no resolveBatch(). Falling back to individual resolve() calls. Add resolveBatch() for true bulk operations.`);else throw new Error(`[Directive] Resolver "${t}" has batch.enabled=true but no resolve(), resolveBatch(), or resolveBatchWithResults() method.`)}}function Ct(n){let{definitions:t,facts:a,store:c,getConstraintBinding:o,onStart:s,onComplete:l,onError:h,onRetry:x,onCancel:S,onClobber:_,onClobberSuppressed:K,onResolutionComplete:U,onRequeue:W}=n;sn(t);let O=new Map,F=new Map,I=1e3,A=new Map,Y=new Map,se=1e3;function N(){if(F.size>I){let y=F.size-I,b=F.keys();for(let R=0;R<y;R++){let q=b.next().value;q&&F.delete(q);}}}function V(y){return typeof y=="object"&&y!==null&&"requirement"in y&&typeof y.requirement=="string"}function te(y){return typeof y=="object"&&y!==null&&"requirement"in y&&typeof y.requirement=="function"}function ne(y,b){return V(y)?b.type===y.requirement:te(y)?y.requirement(b):false}function m(y,b){let R=Y.get(y);if(!R)return null;Y.delete(y),Y.set(y,R);for(let q of R){let L=t[q];if(L&&ne(L,b))return q}return null}function p(y,b){if(!Y.has(y)){if(Y.size>=se){let R=Y.keys().next().value;R!==void 0&&Y.delete(R);}Y.set(y,new Set);}Y.get(y).add(b);}function f(y){let b=y.type,R=m(b,y);if(R)return R;for(let[q,L]of Object.entries(t))if(ne(L,y))return p(b,q),q;return null}function w(y){if(!o||!y||!y.fromConstraint)return null;let b=o(y.fromConstraint);return !b||b.fields.length===0?null:b}function j(y,b,R,q,L){let e=a,i=new Set(y.fields),g=10,M=0,D=false,$=new Map;for(let Z of i){let J=R?R[Z]:e[Z];$.set(Z,J);}let z=new Set;function X(Z){return z.has(Z)?false:Object.is(e[Z],$.get(Z))?true:(z.add(Z),M++,M<=g?q&&q(Z,$.get(Z),e[Z]):D||(D=true,L&&L(M-g)),b.abort(),false)}return new Proxy(a,{get(Z,J,r){return Reflect.get(a,J,r)},set(Z,J,r,u){if(typeof J!="string"||!i.has(J))return Reflect.set(a,J,r);if(!X(J))return true;let v=$.get(J);$.set(J,r);let E=Reflect.set(a,J,r);return E||$.set(J,v),E},deleteProperty(Z,J){if(typeof J!="string"||!i.has(J))return Reflect.deleteProperty(a,J);if(!X(J))return true;let r=$.get(J);$.set(J,void 0);let u=Reflect.deleteProperty(a,J);return u||$.set(J,r),u},has(Z,J){return Reflect.has(a,J)},ownKeys(){return Reflect.ownKeys(a)},getOwnPropertyDescriptor(Z,J){return Reflect.getOwnPropertyDescriptor(a,J)}})}function G(y,b,R,q,L,e){return {facts:R&&q?j(R,q,L,_&&e?(D,$,z)=>{let{resolverId:X,requirements:Z}=e;for(let J of Z)_(X,J,D,$,z);}:void 0,K&&e?D=>{let{resolverId:$,requirements:z}=e;for(let X of z)K($,X,D);}:void 0):a,signal:y,snapshot:()=>a.$snapshot(),requeue:()=>{if(W)for(let D of b)W(D);}}}async function re(y,b,R,q){let L=y instanceof Error?y:new Error(String(y));if(q.signal.aborted)return {action:"abort",error:L};if(R.shouldRetry&&!R.shouldRetry(L,b))return {action:"break",error:L};if(b<R.attempts){if(q.signal.aborted)return {action:"abort",error:L};let e=on(R,b);if(await new Promise(i=>{let g=setTimeout(i,e),M=()=>{clearTimeout(g),i();};q.signal.addEventListener("abort",M,{once:true});}),q.signal.aborted)return {action:"abort",error:L}}return {action:"continue",error:L}}async function le(y,b,R,q,L,e){if(!y.resolve)return;let i=w(R),g;c.batch(()=>{g=y.resolve(R.requirement,G(q,[R.id],i,L,e,{resolverId:b,requirements:[R]}));});let M=y.timeout;if(M&&M>0){await chunkEOLY64E6_cjs.c(g,M,`Resolver "${b}" timed out after ${M}ms`);return}await g;}function be(y,b,R){let q=Date.now()-R;F.set(b.id,{state:"success",requirementId:b.id,completedAt:Date.now(),duration:q}),N(),l?.(y,b,q);}function k(y,b,R,q){F.set(b.id,{state:"error",requirementId:b.id,error:R,failedAt:Date.now(),attempts:q}),N(),h?.(y,b,R);}function d(y,b,R){let q=O.get(y);q&&(q.attempt=b,q.status={state:"running",requirementId:y,startedAt:R,attempt:b});}async function C(y,b,R,q,L){let e=await re(y,b,R,q);return e.action==="continue"&&b<R.attempts&&L(b+1),{lastError:e.error,shouldContinue:e.action==="continue"}}async function T(y,b,R,q){let L=t[y];if(!L)return;let e={...Et,...L.retry},i=null,g=O.get(b.id)?.startedAt??Date.now();for(let M=1;M<=e.attempts;M++){if(R.signal.aborted)return;d(b.id,M,g);try{await le(L,y,b,R.signal,R,q),be(y,b,g);return}catch(D){let $=await C(D,M,e,R,z=>x?.(y,b,z));if(i=$.lastError,!$.shouldContinue)break}}k(y,b,i,e.attempts);}async function H(y,b,R){return b&&b>0?chunkEOLY64E6_cjs.c(y,b,R):y}async function ee(y,b,R,q,L,e,i,g){let M;c.batch(()=>{M=y.resolveBatchWithResults(q,L);});let D=await H(M,e,`Batch resolver "${b}" timed out after ${e}ms`);if(D.length!==R.length)throw new Error(`[Directive] Batch resolver "${b}" returned ${D.length} results but expected ${R.length}. Results array must match input order.`);let $=false;for(let z=0;z<R.length;z++){let X=R[z],Z=D[z];if(Z.success){be(b,X,i);continue}$=true;let J=Z.error??new Error("Batch item failed");F.set(X.id,{state:"error",requirementId:X.id,error:J,failedAt:Date.now(),attempts:g}),h?.(b,X,J);}return !$||R.some((z,X)=>D[X]?.success)?"done":"retry"}async function de(y,b,R,q,L,e,i){let g;c.batch(()=>{g=y.resolveBatch(q,L);}),await H(g,e,`Batch resolver "${b}" timed out after ${e}ms`);for(let M of R)be(b,M,i);}function ve(y,b,R,q){for(let L of b)k(y,L,R,q);}async function he(y,b){await Promise.all(b.map(R=>{let q=new AbortController;return T(y,R,q)}));}async function we(y,b,R,q,L,e,i,g,M){let D=null;if(R.length>0){let X=R[0];R.every(J=>J.fromConstraint===X.fromConstraint)&&(D=w(X));}let $=G(q,R.map(X=>X.id),D,L,M,{resolverId:b,requirements:R}),z=R.map(X=>X.requirement);return y.resolveBatchWithResults?ee(y,b,R,z,$,e,i,g):(await de(y,b,R,z,$,e,i),"done")}function Re(y,b,R){for(let q of b)x?.(y,q,R);}async function xe(y,b,R,q,L,e){let i=new AbortController,g=Date.now(),M=null;for(let D=1;D<=q.attempts;D++){if(i.signal.aborted)return null;try{if(await we(y,b,R,i.signal,i,L,g,D,e)==="done")return null}catch($){let z=await C($,D,q,i,X=>Re(b,R,X));if(M=z.lastError,!z.shouldContinue)break}}return M}async function Ie(y,b,R){let q=t[y];if(!q)return;if(!q.resolveBatch&&!q.resolveBatchWithResults){await he(y,b);return}let L={...Et,...q.retry},i={...xt,...q.batch}.timeoutMs??q.timeout,g=await xe(q,y,b,L,i,R);g&&ve(y,b,g,L.attempts);}let ke=1e4;function B(y){y.timer&&(clearTimeout(y.timer),y.timer=null);}function oe(y){return A.has(y)||A.set(y,{resolverId:y,requirements:[],baselines:[],timer:null}),A.get(y)}function ge(y,b,R){let q=t[y];if(!q)return;let L={...xt,...q.batch},e=oe(y),i=L.maxSize||ke;if(e.requirements.length>=i&&(B(e),Ce(y)),e.requirements.push(b),e.baselines.push(R),L.maxSize&&e.requirements.length>=L.maxSize){B(e),Ce(y);return}B(e),e.timer=setTimeout(()=>{Ce(y);},L.windowMs);}function Ce(y){let b=A.get(y);if(!b||b.requirements.length===0)return;let R=[...b.requirements],q;for(let L=b.baselines.length-1;L>=0;L--){let e=b.baselines[L];if(e!==void 0){q=e;break}}b.requirements=[],b.baselines=[],b.timer=null,Ie(y,R,q).then(()=>{U?.();});}return {resolve(y,b){if(O.has(y.id))return;let R=f(y.requirement);if(!R){chunkN4KTCKOI_cjs.a&&console.warn(`[Directive] No resolver found for requirement type "${y.requirement.type}" (id: ${y.id})`);return}let q=t[R];if(!q)return;if(q.batch?.enabled){ge(R,y,b?.factsBaseline);return}let L=new AbortController,e=Date.now(),i={requirementId:y.id,resolverId:R,controller:L,startedAt:e,attempt:1,status:{state:"pending",requirementId:y.id,startedAt:e},originalRequirement:y};O.set(y.id,i),s?.(R,y),T(R,y,L,b?.factsBaseline).finally(()=>{O.delete(y.id)&&U?.();});},cancel(y){let b=O.get(y);if(b){b.controller.abort(),O.delete(y),F.set(y,{state:"canceled",requirementId:y,canceledAt:Date.now()}),N(),S?.(b.resolverId,b.originalRequirement);return}for(let R of A.values()){let q=R.requirements.findIndex(L=>L.id===y);if(q!==-1){let[L]=R.requirements.splice(q,1);R.baselines.splice(q,1),F.set(y,{state:"canceled",requirementId:y,canceledAt:Date.now()}),N(),L&&S?.(R.resolverId,L);return}}},detach(y){O.delete(y);},cancelAll(){let y=[...O.keys()];for(let b of y)this.cancel(b);for(let b of A.values()){b.timer&&clearTimeout(b.timer);for(let R of b.requirements)F.set(R.id,{state:"canceled",requirementId:R.id,canceledAt:Date.now()}),S?.(b.resolverId,R);}A.clear(),N();},getStatus(y){let b=O.get(y);if(b)return b.status;let R=F.get(y);return R||{state:"idle"}},getInflight(){return [...O.keys()]},getInflightInfo(){return [...O.values()].map(y=>({id:y.requirementId,resolverId:y.resolverId,startedAt:y.startedAt}))},getInflightCount(){return O.size},isResolving(y){return O.has(y)},processBatches(){for(let y of A.keys())Ce(y);},hasPendingBatches(){for(let y of A.values())if(y.requirements.length>0)return true;return false},registerDefinitions(y){for(let[b,R]of Object.entries(y))t[b]=R;Y.clear();},assignDefinition(y,b){if(!t[y])throw new Error(`[Directive] Cannot assign resolver "${y}" \u2014 it does not exist. Use register() to create it.`);t[y]=b,Y.clear();},unregisterDefinition(y){if(!t[y])return;for(let[R,q]of O)q.resolverId===y&&(q.controller.abort(),O.delete(R),F.set(R,{state:"canceled",requirementId:R,canceledAt:Date.now()}),S?.(y,q.originalRequirement));let b=A.get(y);if(b){b.timer&&clearTimeout(b.timer);for(let R of b.requirements)F.set(R.id,{state:"canceled",requirementId:R.id,canceledAt:Date.now()}),S?.(y,R);A.delete(y);}delete t[y],Y.clear(),N();},async callOne(y,b){let R=t[y];if(!R)throw new Error(`[Directive] Cannot call resolver "${y}" \u2014 it does not exist.`);let q=new AbortController,L=G(q.signal,[]);if(R.resolve){let e;c.batch(()=>{e=R.resolve(b,L);}),await e;}},destroy(){this.cancelAll(),F.clear(),Y.clear();}}}function Mt(n){let{mergedDerive:t,getDerivation:a,definitions:c}=n,o={register:(s,l)=>c.register("derivation",s,l),assign:(s,l)=>c.assign("derivation",s,l),unregister:s=>c.unregister("derivation",s),call:s=>c.call("derivation",s),isDynamic:s=>c.isDynamic("derivation",s),listDynamic:()=>c.listDynamic("derivation")};return new Proxy({},{get(s,l){if(typeof l!="symbol"&&!chunkN4KTCKOI_cjs.l.has(l)){if(l in o)return o[l];if(l in t)return a(l)}},has(s,l){return typeof l=="symbol"||chunkN4KTCKOI_cjs.l.has(l)?false:l in t||l in o},ownKeys(){return Object.keys(t)},getOwnPropertyDescriptor(s,l){if(typeof l!="symbol"&&!chunkN4KTCKOI_cjs.l.has(l)&&(l in t||l in o))return {configurable:true,enumerable:true}},set(){return false},defineProperty(){return false},getPrototypeOf(){return null},setPrototypeOf(){return false}})}function $t(n){let{mergedEvents:t,dispatchEvent:a}=n;return new Proxy({},{get(c,o){if(typeof o!="symbol"&&!chunkN4KTCKOI_cjs.l.has(o))return s=>{a(o,s);}},has(c,o){return typeof o=="symbol"||chunkN4KTCKOI_cjs.l.has(o)?false:o in t},ownKeys(){return Object.keys(t)},getOwnPropertyDescriptor(c,o){if(typeof o!="symbol"&&!chunkN4KTCKOI_cjs.l.has(o)&&o in t)return {configurable:true,enumerable:true}},set(){return false},defineProperty(){return false},getPrototypeOf(){return null},setPrototypeOf(){return false}})}var an=new Set(["register","assign","unregister","call","isDynamic","listDynamic"]);function Pt(n){let{mergedConstraints:t,mergedResolvers:a,mergedDerive:c,mergedEffects:o,constraintsManager:s,resolversManager:l,derivationsManager:h,effectsManager:x,pluginManager:S,getState:_,scheduleReconcile:K,maxDeferredRegistrations:U}=n,W={constraints:new Set,resolvers:new Set,derivations:new Set,effects:new Set},O={constraints:new Map,resolvers:new Map,derivations:new Map,effects:new Map},F=[];function I(m){if(an.has(m))throw new Error(`[Directive] Derivation ID "${m}" conflicts with a reserved derive method name.`)}let A={constraint:{label:"Constraint",mergedMap:t,manager:s,dynamicSet:W.constraints,originalsMap:O.constraints,reconciles:true},resolver:{label:"Resolver",mergedMap:a,manager:l,dynamicSet:W.resolvers,originalsMap:O.resolvers,reconciles:true},derivation:{label:"Derivation",mergedMap:c,manager:h,dynamicSet:W.derivations,originalsMap:O.derivations,reconciles:false,validateId:I},effect:{label:"Effect",mergedMap:o,manager:x,dynamicSet:W.effects,originalsMap:O.effects,reconciles:false}};function Y(m){if(typeof m!="string"||m.length===0)throw new Error(`[Directive] Definition ID must be a non-empty string. Received: ${String(m)}`);if(chunkN4KTCKOI_cjs.l.has(m))throw new Error(`[Directive] Security: Definition ID "${m}" is a blocked property.`);if(m.includes("::"))throw new Error(`[Directive] Definition ID "${m}" cannot contain "::". This separator is reserved for namespacing.`)}function se(m,p,f){let w=A[m];if(w.validateId?.(p),p in w.mergedMap)throw new Error(`[Directive] ${w.label} "${p}" already exists. Use assign() to override.`);if(m!=="derivation"){let j=f;j.meta&&(j.meta=fe(j.meta));}w.mergedMap[p]=f,w.manager.registerDefinitions({[p]:f}),w.dynamicSet.add(p),S.emitDefinitionRegister(m,p,f),w.reconciles&&K();}function N(m,p,f){let w=A[m];if(w.validateId?.(p),!(p in w.mergedMap))throw new Error(`[Directive] ${w.label} "${p}" does not exist. Use register() to create it.`);if(m!=="derivation"){let G=f;G.meta&&(G.meta=fe(G.meta));}let j=w.mergedMap[p];w.manager.assignDefinition(p,f),w.originalsMap.set(p,j),w.mergedMap[p]=f,S.emitDefinitionAssign(m,p,f,j),w.reconciles&&K();}function V(m,p){let f=A[m];if(!f.dynamicSet.has(p)){chunkN4KTCKOI_cjs.a&&console.warn(`[Directive] Cannot unregister static ${m} "${p}". Only dynamically registered ${m}s can be removed.`);return}f.manager.unregisterDefinition(p),delete f.mergedMap[p],f.dynamicSet.delete(p),f.originalsMap.delete(p),S.emitDefinitionUnregister(m,p),f.reconciles&&K();}function te(){if(F.length===0)return;let m=F.splice(0);for(let p of m)try{switch(p.op){case "register":se(p.type,p.id,p.def);break;case "assign":N(p.type,p.id,p.def);break;case "unregister":V(p.type,p.id);break}}catch(f){chunkN4KTCKOI_cjs.a&&console.error(`[Directive] Error in deferred ${p.op} for ${p.type} "${p.id}":`,f);}}function ne(m,p,f,w){let{isDestroyed:j,isReconciling:G}=_();if(j)throw new Error(`[Directive] Cannot ${m} ${p} "${f}" on a destroyed system.`);if(Y(f),G){if(F.length>=U)throw new Error(`[Directive] Too many deferred registrations (max ${U}). Avoid calling register/assign/unregister in resolver or effect callbacks during reconciliation.`);m==="unregister"?F.push({op:m,type:p,id:f}):F.push({op:m,type:p,id:f,def:w});return}switch(m){case "register":se(p,f,w);break;case "assign":N(p,f,w);break;case "unregister":V(p,f);break}}return {register(m,p,f){ne("register",m,p,f);},assign(m,p,f){ne("assign",m,p,f);},unregister(m,p){ne("unregister",m,p);},call(m,p,f){let{isDestroyed:w}=_();if(w)throw new Error(`[Directive] Cannot call ${m} "${p}" on a destroyed system.`);switch(Y(p),S.emitDefinitionCall(m,p,f),m){case "constraint":return s.callOne(p,f);case "resolver":return l.callOne(p,f);case "derivation":return h.callOne(p);case "effect":return x.callOne(p)}},isDynamic(m,p){switch(m){case "constraint":return W.constraints.has(p);case "resolver":return W.resolvers.has(p);case "derivation":return W.derivations.has(p);case "effect":return W.effects.has(p)}},listDynamic(m){switch(m){case "constraint":return [...W.constraints];case "resolver":return [...W.resolvers];case "derivation":return [...W.derivations];case "effect":return [...W.effects]}},flushDeferred:te,getOriginal(m,p){let w={constraint:O.constraints,resolver:O.resolvers,derivation:O.derivations,effect:O.effects}[m];if(w)return w.get(p)},restoreOriginal(m,p){let w={constraint:O.constraints,resolver:O.resolvers,derivation:O.derivations,effect:O.effects}[m];if(!w||!w.has(p))return false;let j=w.get(p);return ne("assign",m,p,j),w.delete(p),true},destroy(){F.length=0,W.constraints.clear(),W.resolvers.clear(),W.derivations.clear(),W.effects.clear(),O.constraints.clear(),O.resolvers.clear(),O.derivations.clear(),O.effects.clear();}}}function Ot(n){let{traceConfig:t,pluginManager:a,resolverMetaLookup:c}=n;if(!(t===true||typeof t=="object"&&t!==null))return {enabled:false,recordFactChange(){},startRun(){return 0},currentTrace:null,getEntries(){return null},attributeResolverStart(){},recordResolverComplete(){},recordResolverError(){},decrementInflight(){},finalizeCurrentRun(){},drainPendingChanges(){},destroy(){}};let s=(typeof t=="object"&&t!==null?t.maxRuns:void 0)??100,l=[],h=new Map,x=0,S=null,_=[],K=new Map,U=new Map,W=new Map,O=null,F=0,I=0,A={count:0,totalDuration:0,avgDuration:0,maxDuration:0,avgResolverCount:0,totalResolverCount:0,avgFactChangeCount:0,totalFactChangeCount:0};function Y(f){let w=h.get(f);if(w&&w.status==="pending"){w.status="settled";let j=W.get(f);w.duration=j!==void 0?performance.now()-j:Date.now()-w.timestamp,W.delete(f),U.delete(f),w.causalChain=V(w),te(w),I++,a.emitTraceComplete(w);}}function se(f){let w=K.get(f);if(K.delete(f),w!==void 0){let j=(U.get(w)??1)-1;j<=0?Y(w):U.set(w,j);}}function N(){let f=l.shift();if(f&&(h.delete(f.id),W.delete(f.id),f.status==="pending")){U.delete(f.id);for(let[w,j]of K)j===f.id&&K.delete(w);}}function V(f){let w=[];for(let j of f.factChanges)w.push(`${j.key} changed`);for(let j of f.derivationsRecomputed)w.push(`${j.id} recomputed`);for(let j of f.constraintsHit)w.push(`${j.id} constraint hit`);for(let j of f.requirementsAdded)w.push(`${j.type} requirement added`);for(let j of f.resolversCompleted)w.push(`${j.resolver} resolved (${j.duration.toFixed(0)}ms)`);for(let j of f.resolversErrored)w.push(`${j.resolver} errored`);for(let j of f.effectsRun)w.push(`${j.id} effect ran`);return w.join(" \u2192 ")}function te(f){A.count++,A.totalDuration+=f.duration,A.avgDuration=A.totalDuration/A.count,f.duration>A.maxDuration&&(A.maxDuration=f.duration);let w=f.resolversStarted.length;A.totalResolverCount+=w,A.avgResolverCount=A.totalResolverCount/A.count;let j=f.factChanges.length;A.totalFactChangeCount+=j,A.avgFactChangeCount=A.totalFactChangeCount/A.count;let G=[];A.count>3&&f.duration>A.avgDuration*5&&G.push(`Duration ${f.duration.toFixed(0)}ms is 5x+ above average (${A.avgDuration.toFixed(0)}ms)`),f.resolversErrored.length>0&&G.push(`${f.resolversErrored.length} resolver(s) errored`),G.length>0&&(f.anomalies=G);}function ne(f){l.push(f),h.set(f.id,f),l.length>s&&N(),I++;}function m(f){return f.factChanges.length>0||f.constraintsHit.length>0||f.requirementsAdded.length>0||f.effectsRun.length>0}return {enabled:true,get currentTrace(){return S},set currentTrace(f){S=f;},recordFactChange(f,w,j){_.push({key:f,oldValue:w,newValue:j});},startRun(){let f=performance.now(),w=++x;return W.set(w,f),S={id:w,timestamp:Date.now(),duration:0,status:"pending",factChanges:_.splice(0),derivationsRecomputed:[],constraintsHit:[],requirementsAdded:[],requirementsRemoved:[],resolversStarted:[],resolversCompleted:[],resolversErrored:[],effectsRun:[],effectErrors:[]},f},getEntries(){return (!O||F!==I)&&(O=[...l],F=I),O},attributeResolverStart(f){S&&K.set(f,S.id);},recordResolverComplete(f,w,j){let G=K.get(f);if(G!==void 0){let re=h.get(G);re&&re.resolversCompleted.push({resolver:w,requirementId:f,duration:j,meta:c?.(w)});}},recordResolverError(f,w,j){let G=K.get(f);if(G!==void 0){let re=h.get(G);re&&re.resolversErrored.push({resolver:w,requirementId:f,error:j,meta:c?.(w)});}},decrementInflight(f){se(f);},finalizeCurrentRun(f){if(!S)return;if(S.duration=performance.now()-f,!m(S)){W.delete(S.id),S=null;return}let w=S.resolversStarted.length;w===0?(S.status="settled",S.causalChain=V(S),te(S),ne(S),a.emitTraceComplete(S)):(S.status="pending",ne(S),U.set(S.id,w)),S=null;},drainPendingChanges(){_.length=0;},destroy(){l.length=0,h.clear(),K.clear(),U.clear(),W.clear(),_.length=0,S=null,O=null;}}}function It(n,t){for(let[a,c]of Object.entries(n)){if(typeof c!="object"||c===null)continue;let o=Object.hasOwn(c,"handler"),s=Object.hasOwn(c,"patch");if(o&&s&&chunkN4KTCKOI_cjs.a&&console.warn(`[Directive] event "${a}": both \`handler\` and \`patch\` provided \u2014 using \`handler\` (patch is ignored).`),o){let l=c;if(n[a]=l.handler,l.meta){let h=fe(l.meta);h&&t.set(a,h);}continue}if(s){let l=c,h=l.patch;if(chunkEOLY64E6_cjs.a(h),n[a]=(x,S)=>mt(h,x,S??{}),l.meta){let x=fe(l.meta);x&&t.set(a,x);}}}}function qr(n){let t=Object.create(null),a=Object.create(null),c=Object.create(null),o=Object.create(null),s=Object.create(null),l=Object.create(null),h=new Map,x=new Map,S=new Map,_=new Map,K=new Map;for(let e of n.modules){let i=(M,D)=>{if(M)for(let $ of Object.keys(M)){if(chunkN4KTCKOI_cjs.l.has($))throw new Error(`[Directive] Security: Module "${e.id}" has dangerous key "${$}" in ${D}. This could indicate a prototype pollution attempt.`);if(D==="schema"&&$.startsWith("$"))throw new Error(`[Directive] Module "${e.id}" has schema key "${$}" starting with "$". Keys starting with $ are reserved for internal accessors ($store, $snapshot).`)}};i(e.schema,"schema"),i(e.events,"events"),i(e.derive,"derive"),i(e.effects,"effects"),i(e.constraints,"constraints"),i(e.resolvers,"resolvers");for(let M of Object.keys(e.schema)){let D=S.get(M);if(D)throw new Error(`[Directive] Schema collision: Fact "${M}" is defined in both module "${D}" and "${e.id}". Use namespacing (e.g., "${e.id}::${M}") or merge into one module.`);S.set(M,e.id);}let g=(M,D)=>{if(M)for(let $ of Object.keys(M)){let z=_.get($);if(z&&z!==e.id)throw new Error(`[Directive] Definition collision: ${D} "${$}" is defined in both module "${z}" and "${e.id}". Use namespacing or rename to avoid conflicts.`);_.set($,e.id);}};if(g(e.derive,"derivation"),g(e.effects,"effect"),g(e.constraints,"constraint"),g(e.resolvers,"resolver"),g(e.events,"event"),Object.assign(t,e.schema),e.events&&(It(e.events,x),Object.assign(a,e.events)),e.derive&&Object.assign(c,e.derive),e.effects&&Object.assign(o,e.effects),e.constraints&&Object.assign(s,e.constraints),e.resolvers){Object.assign(l,e.resolvers);for(let M of Object.keys(e.resolvers))K.set(M,e);}if(e.meta){let M=fe(e.meta);M&&h.set(e.id,M);}}for(let e of Object.values(s))e.meta&&(e.meta=fe(e.meta));for(let e of Object.values(l))e.meta&&(e.meta=fe(e.meta));for(let e of Object.values(o)){let i=e;i.meta&&(i.meta=fe(i.meta));}for(let e of Object.values(t)){let i=e;i._meta&&(i._meta=fe(i._meta));}let U=null;if(n.modules.some(e=>e.history?.snapshotEvents)){U=new Set;for(let e of n.modules){let i=e;if(i.history?.snapshotEvents)for(let g of i.history.snapshotEvents)U.add(g);else if(i.events)for(let g of Object.keys(i.events))U.add(g);}}let O=0,F=false;if(chunkN4KTCKOI_cjs.a){let e=new Set(Object.keys(c));for(let i of Object.keys(t))e.has(i)&&console.warn(`[Directive] "${i}" exists as both a fact and a derivation. This may cause unexpected dependency tracking behavior.`);}let I=Dt();for(let e of n.plugins??[])I.register(e);let A=I.getPlugins().length>0,Y=I.register.bind(I),se=I.unregister.bind(I);I.register=e=>{Y(e),A=true;},I.unregister=e=>{se(e),A=I.getPlugins().length>0;};let N=()=>A,V=wt({config:n.errorBoundary,onError:e=>I.emitError(e),onRecovery:(e,i)=>I.emitErrorRecovery(e,i)}),te=null,ne=()=>{},m=()=>{},p=null,f=Ot({traceConfig:n.trace,pluginManager:I,resolverMetaLookup:e=>l[e]?.meta}),w=f.enabled,{store:j,facts:G}=kt({schema:t,onChange:(e,i,g)=>{I.emitFactSet(e,i,g),ne(e),w&&f.recordFactChange(String(e),g,i),!p?.isRestoring&&(O===0&&(F=true),B.changedKeys.add(e),ge());},onBatch:e=>{I.emitFactsBatch(e);let i=[];for(let g of e)i.push(g.key);if(w)for(let g of e)f.recordFactChange(g.key,g.prev,g.type==="delete"?void 0:g.value);if(m(i),!p?.isRestoring){O===0&&(F=true);for(let g of e)B.changedKeys.add(g.key);ge();}}}),re=St({definitions:c,facts:G,onCompute:(e,i,g,M)=>{N()&&I.emitDerivationCompute(e,i,M),f.currentTrace&&f.currentTrace.derivationsRecomputed.push({id:e,deps:M?[...M]:[],oldValue:g,newValue:i,meta:re.getMeta(e)});},onInvalidate:e=>{N()&&I.emitDerivationInvalidate(e);},onError:(e,i)=>{V.handleError("derivation",e,i)==="retry"&&re.invalidate(e);}});ne=e=>re.invalidate(e),m=e=>re.invalidateMany(e);let le=bt({definitions:o,facts:G,store:j,onRun:(e,i)=>{N()&&I.emitEffectRun(e),f.currentTrace&&f.currentTrace.effectsRun.push({id:e,triggeredBy:i,meta:o[e]?.meta});},onError:(e,i)=>{let g=V.handleError("effect",e,i);N()&&I.emitEffectError(e,i),f.currentTrace&&f.currentTrace.effectErrors.push({id:e,error:String(i),meta:o[e]?.meta}),g==="disable"&&le.disable(e),g==="retry"&&(B.changedKeys.add("*"),ge());}});function be(e){if(Array.isArray(e)){let i=e;return g=>gt(i,g)}return e}let k=Object.create(null);for(let e of Object.values(l))e.key&&typeof e.requirement=="string"&&(k[e.requirement]=be(e.key));let d=ht({definitions:s,facts:G,requirementKeys:k,onEvaluate:(e,i)=>{if(N()){let g=d.explainWhen(e);I.emitConstraintEvaluate(e,i,g);}},onError:(e,i)=>{let g=V.handleError("constraint",e,i);N()&&I.emitConstraintError(e,i),g==="disable"&&d.disable(e);}});function C(e){for(let i of Object.values(e))i.key&&typeof i.requirement=="string"&&d.setRequirementKey(i.requirement,be(i.key));}function T(e){let i=s[e];if(!i?.owns||i.owns.length===0)return;let g=d.getState(e);if(g?.isAsync||i.async){chunkN4KTCKOI_cjs.a&&(g?.isAsync&&!i.async?console.warn(`[Directive] constraint '${e}': owns binding disabled because when() returned a Promise \u2014 convert to a synchronous when, mark the constraint async: true and accept the binding being off, or use a data-form when (always sync).`):console.warn(`[Directive] Constraint "${e}" has \`owns\` but is async. Binding is disabled \u2014 async constraints cannot be bound.`));return}return {fields:i.owns}}let H=new Set,ee=Ct({definitions:l,facts:G,store:j,getConstraintBinding:T,onStart:(e,i)=>{N()&&I.emitResolverStart(e,i);},onComplete:(e,i,g)=>{V.clearRetryAttempts(e),N()&&(I.emitResolverComplete(e,i,g),I.emitRequirementMet(i,e)),d.markResolved(i.fromConstraint),w&&(f.recordResolverComplete(i.id,e,g),f.decrementInflight(i.id));},onError:(e,i,g)=>{let M=V.handleError("resolver",e,g,i);if(N()&&I.emitResolverError(e,i,g),M==="disable"&&d.disable(i.fromConstraint),M==="retry"&&(B.previousRequirements.remove(i.id),ge()),M==="retry-later"){let X=V.getRetryLaterManager().getPendingRetries().find(Z=>Z.sourceId===e);X&&!X.callback&&(X.callback=()=>{ge();});}w&&(f.recordResolverError(i.id,e,String(g)),f.decrementInflight(i.id));let D=K.get(e),$=D?.hooks?.onResolverError;if($){let z=g instanceof Error?g:new Error(String(g));try{$(z,i.requirement,{facts:G});}catch(X){console.error(`[Directive] onResolverError hook for module "${D?.id}" threw:`,X);}}},onRetry:(e,i,g)=>I.emitResolverRetry(e,i,g),onCancel:(e,i)=>{I.emitResolverCancel(e,i),I.emitRequirementCanceled(i),w&&f.decrementInflight(i.id);},onClobber:(e,i,g,M,D)=>{N()&&I.emitResolverWriteRejected({kind:"rejection",resolver:e,req:i,reason:"clobbered",fact:g,expected:M,actual:D});},onClobberSuppressed:(e,i,g)=>{N()&&I.emitResolverWriteRejected({kind:"summary",resolver:e,req:i,reason:"clobbered",dropped:g});},onResolutionComplete:()=>{Re(),ge();},onRequeue:e=>{H.add(e);}}),de=new Set;function ve(){for(let e of de)e();}let he=n.history?pt({historyOption:n.history,facts:G,store:j,onSnapshot:e=>{I.emitSnapshot(e),ve();},onHistoryChange:(e,i)=>{I.emitHistoryNavigate(e,i),ve();}}):yt();p=he;let we=new Set;function Re(){for(let e of we)e();}let xe=50,Ie=100,ke=0,B={isRunning:false,isReconciling:false,reconcileScheduled:false,isInitializing:false,isInitialized:false,isReady:false,isDestroyed:false,changedKeys:new Set,previousRequirements:new $e,readyPromise:null,readyResolve:null},oe=Pt({mergedConstraints:s,mergedResolvers:l,mergedDerive:c,mergedEffects:o,constraintsManager:d,resolversManager:ee,derivationsManager:re,effectsManager:le,pluginManager:I,getState:()=>B,scheduleReconcile:ge,maxDeferredRegistrations:Ie});function ge(){!B.isRunning||B.reconcileScheduled||B.isInitializing||(B.reconcileScheduled=true,Re(),queueMicrotask(()=>{B.reconcileScheduled=false,B.isRunning&&!B.isInitializing&&Ce().catch(e=>{chunkN4KTCKOI_cjs.a&&console.error("[Directive] Unexpected error in reconcile:",e);});}));}async function Ce(){if(B.isReconciling)return;if(ke++,ke>xe){chunkN4KTCKOI_cjs.a&&console.warn(`[Directive] Reconcile loop exceeded ${xe} iterations. This usually means resolvers are creating circular requirement chains. Check that resolvers aren't mutating facts that re-trigger their own constraints.`),w&&f.drainPendingChanges(),B.previousRequirements=new $e,ke=0;return}B.isReconciling=true,Re();let e=w?f.startRun():0,i=f.currentTrace;if(i)for(let g of i.factChanges){let M=t[g.key];g.meta=M?._meta;}try{if(B.changedKeys.size>0){if(U===null||F){let r=B.changedKeys,u=r.size<=5?`facts-changed:${[...r].join(",")}`:`facts-changed:${[...r].slice(0,5).join(",")}+${r.size-5}more`;he.takeSnapshot(u);}F=!1;}let g=G.$snapshot();I.emitReconcileStart(g),await le.runEffects(B.changedKeys);let M=new Set(B.changedKeys);B.changedKeys.clear();let D=await d.evaluate(M),$=new $e;for(let r of D)$.add(r),I.emitRequirementCreated(r);if(i){let r=new Set(D.map(u=>u.fromConstraint));for(let u of r){let v=d.getState(u);if(v){let E=d.getDependencies(u);i.constraintsHit.push({id:u,priority:v.priority,deps:E?[...E]:[],meta:s[u]?.meta});}}}let{added:z,removed:X}=$.diff(B.previousRequirements);if(i){for(let r of z)i.requirementsAdded.push({id:r.id,type:r.requirement.type,fromConstraint:r.fromConstraint});for(let r of X)i.requirementsRemoved.push({id:r.id,type:r.requirement.type,fromConstraint:r.fromConstraint});}for(let r of X)(r.fromConstraint?T(r.fromConstraint):void 0)?ee.detach(r.id):ee.cancel(r.id);let Z;if(z.length>0){let r=new Set;for(let u of z){if(!u.fromConstraint)continue;let v=T(u.fromConstraint);if(v)for(let E of v.fields)r.add(E);}if(r.size>0){Z=Object.create(null);for(let u of r)Z[u]=j.get(u);}}for(let r of z)ee.resolve(r,{factsBaseline:Z});if(i){let r=ee.getInflightInfo(),u=new Map(r.map(v=>[v.id,v]));for(let v of z){let P=u.get(v.id)?.resolverId??"unknown";i.resolversStarted.push({resolver:P,requirementId:v.id,meta:l[P]?.meta}),f.attributeResolverStart(v.id);}}if(B.previousRequirements=$,H.size>0){for(let r of H)B.previousRequirements.remove(r);H.clear(),ge();}let J=ee.getInflightInfo();if(n.plugins&&n.plugins.length>0){let r=X.length>0?new Map(J.map(v=>[v.id,v.resolverId])):void 0,u={unmet:D.filter(v=>!ee.isResolving(v.id)),inflight:J,completed:[],canceled:X.map(v=>({id:v.id,resolverId:r?.get(v.id)??"unknown"}))};I.emitReconcileEnd(u);}B.isReady||(B.isReady=!0,B.readyResolve&&(B.readyResolve(),B.readyResolve=null));}finally{w&&f.finalizeCurrentRun(e),B.isReconciling=false,oe.flushDeferred(),ke=0,B.changedKeys.size>0&&ge(),Re();}}function Ae(e,i){let g=a[e];if(g){O++,(U===null||U.has(e))&&(F=true);try{j.batch(()=>{g(G,{type:e,...i});});}finally{O--;}}else chunkN4KTCKOI_cjs.a&&console.warn(`[Directive] Unknown event type "${e}". No handler is registered for this event. Available events: ${Object.keys(a).join(", ")||"(none)"}`);}let y=Mt({mergedDerive:c,getDerivation:e=>re.get(e),definitions:oe}),b=$t({mergedEvents:a,dispatchEvent:Ae});function R(){let e=[];for(let[i,g]of h)e.push({type:"module",id:i,meta:g});for(let i of Object.keys(t)){let g=t[i]?._meta;g&&e.push({type:"fact",id:i,meta:g});}for(let[i,g]of x)e.push({type:"event",id:i,meta:g});for(let[i,g]of Object.entries(s))g.meta&&e.push({type:"constraint",id:i,meta:g.meta});for(let[i,g]of Object.entries(l))g.meta&&e.push({type:"resolver",id:i,meta:g.meta});for(let[i,g]of Object.entries(o)){let M=g.meta;M&&e.push({type:"effect",id:i,meta:M});}for(let i of Object.keys(c)){let g=re.getMeta(i);g&&e.push({type:"derivation",id:i,meta:g});}return e}let q={facts:G,history:he.isEnabled?he:null,derive:y,events:b,constraints:{disable:e=>d.disable(e),enable:e=>d.enable(e),isDisabled:e=>d.isDisabled(e),register:(e,i)=>{oe.register("constraint",e,i);},assign:(e,i)=>{oe.assign("constraint",e,i);},unregister:e=>{oe.unregister("constraint",e);},call:(e,i)=>oe.call("constraint",e,i),isDynamic:e=>oe.isDynamic("constraint",e),listDynamic:()=>oe.listDynamic("constraint")},effects:{disable:e=>le.disable(e),enable:e=>le.enable(e),isEnabled:e=>le.isEnabled(e),register:(e,i)=>{oe.register("effect",e,i);},assign:(e,i)=>{oe.assign("effect",e,i);},unregister:e=>{oe.unregister("effect",e);},call:e=>oe.call("effect",e),isDynamic:e=>oe.isDynamic("effect",e),listDynamic:()=>oe.listDynamic("effect")},resolvers:{register:(e,i)=>{oe.register("resolver",e,i),C({[e]:i});},assign:(e,i)=>{oe.assign("resolver",e,i),C({[e]:i});},unregister:e=>{let i=l[e];i?.key&&typeof i.requirement=="string"&&d.removeRequirementKey(i.requirement),oe.unregister("resolver",e);},call:(e,i)=>oe.call("resolver",e,i),isDynamic:e=>oe.isDynamic("resolver",e),listDynamic:()=>oe.listDynamic("resolver")},get trace(){return f.getEntries()},meta:{module(e){return h.get(e)},fact(e){return t[e]?._meta},event(e){return x.get(e)},constraint(e){return s[e]?.meta},resolver(e){return l[e]?.meta},effect(e){return o[e]?.meta},derivation(e){return re.getMeta(e)},byCategory(e){return R().filter(i=>i.meta.category===e)},byTag(e){return R().filter(i=>i.meta.tags?.includes(e))}},observe(e){if(I.getPlugins().filter(D=>D.name.startsWith("__observer_")).length>=100)return chunkN4KTCKOI_cjs.a&&console.warn("[Directive] Maximum observer limit (100) reached. Call the unsubscribe function returned by observe() to clean up."),()=>{};let g=`__observer_${Date.now()}_${Math.random().toString(36).slice(2)}`,M={name:g,onInit:()=>e({type:"system.init"}),onStart:()=>e({type:"system.start"}),onStop:()=>e({type:"system.stop"}),onDestroy:()=>e({type:"system.destroy"}),onFactSet:(D,$,z)=>e({type:"fact.change",key:D,prev:z,next:$}),onConstraintEvaluate:(D,$,z)=>{e(z?{type:"constraint.evaluate",id:D,active:$,whenExplain:z}:{type:"constraint.evaluate",id:D,active:$});},onConstraintError:(D,$)=>e({type:"constraint.error",id:D,error:$}),onRequirementCreated:D=>e({type:"requirement.created",id:D.id,requirementType:D.requirement.type}),onRequirementMet:(D,$)=>e({type:"requirement.met",id:D.id,byResolver:$}),onRequirementCanceled:D=>e({type:"requirement.canceled",id:D.id}),onResolverStart:(D,$)=>e({type:"resolver.start",resolver:D,requirementId:$.id}),onResolverComplete:(D,$,z)=>e({type:"resolver.complete",resolver:D,requirementId:$.id,duration:z}),onResolverError:(D,$,z)=>e({type:"resolver.error",resolver:D,requirementId:$.id,error:z}),onResolverWriteRejected:D=>{if(D.kind==="summary"){e({type:"resolver.write.rejected",kind:"summary",resolver:D.resolver,requirementId:D.req.id,reason:D.reason,dropped:D.dropped});return}e({type:"resolver.write.rejected",kind:"rejection",resolver:D.resolver,requirementId:D.req.id,reason:D.reason,fact:D.fact,expected:D.expected,actual:D.actual});},onEffectRun:D=>e({type:"effect.run",id:D}),onEffectError:(D,$)=>e({type:"effect.error",id:D,error:$}),onDerivationCompute:(D,$)=>e({type:"derivation.compute",id:D,value:$}),onReconcileStart:()=>e({type:"reconcile.start"}),onReconcileEnd:D=>{let $=D;e({type:"reconcile.end",resolversCompleted:Array.isArray($.completed)?$.completed.length:0,resolversCanceled:Array.isArray($.canceled)?$.canceled.length:0});}};return I.register(M),()=>I.unregister(g)},initialize(){if(!B.isInitialized){B.isInitializing=true;for(let e of n.modules)e.init&&j.batch(()=>{e.init(G);});n.onAfterModuleInit&&j.batch(()=>{n.onAfterModuleInit();}),B.isInitializing=false,B.isInitialized=true;for(let e of Object.keys(c))re.get(e);}},start(){if(!B.isRunning){B.isInitialized||this.initialize(),B.isRunning=true;for(let e of n.modules)e.hooks?.onStart?.(q);if(I.emitStart(q),n.errorBoundary?.retryLater&&!te){let e=Math.max(n.errorBoundary.retryLater.delayMs??1e3,250);te=setInterval(()=>{let i=V.processDueRetries();for(let g of i)g.callback?g.callback():ge();},Math.min(e,500));}ge();}},stop(){if(B.isRunning){B.isRunning=false,te!==null&&(clearInterval(te),te=null),V.getRetryLaterManager().clearAll(),ee.cancelAll(),le.cleanupAll();for(let e of n.modules)e.hooks?.onStop?.(q);I.emitStop(q);}},destroy(){B.isDestroyed||(this.stop(),B.isDestroyed=true,j.destroy?.(),ee.destroy(),V.clearErrors(),we.clear(),de.clear(),f.destroy(),oe.destroy(),h.clear(),x.clear(),H.clear(),I.emitDestroy(q));},dispatch(e){chunkN4KTCKOI_cjs.l.has(e.type)||Ae(e.type,e);},read(e){return re.get(e)},subscribe(e,i){let g=[],M=[];for(let $ of e)$ in c?g.push($):$ in t?M.push($):chunkN4KTCKOI_cjs.a&&console.warn(`[Directive] subscribe: unknown key "${$}"`);let D=[];return g.length>0&&D.push(re.subscribe(g,i)),M.length>0&&D.push(j.subscribe(M,i)),()=>{for(let $ of D)$();}},watch(e,i,g){let M=g?.equalityFn?($,z)=>g.equalityFn($,z):($,z)=>Object.is($,z);if(e in c){let $=re.get(e);return re.subscribe([e],()=>{let z=re.get(e);if(!M(z,$)){let X=$;$=z,i(z,X);}})}chunkN4KTCKOI_cjs.a&&(e in t||console.warn(`[Directive] watch: unknown key "${e}"`));let D=j.get(e);return j.subscribe([e],()=>{let $=j.get(e);if(!M($,D)){let z=D;D=$,i($,z);}})},when(e,i){return new Promise((g,M)=>{let D=j.toObject();if(e(D)){g();return}let $,z,X=()=>{$?.(),z!==void 0&&clearTimeout(z);};$=j.subscribeAll(()=>{let Z=j.toObject();e(Z)&&(X(),g());}),i?.timeout!==void 0&&i.timeout>0&&(z=setTimeout(()=>{X(),M(new Error(`[Directive] when: timed out after ${i.timeout}ms`));},i.timeout));})},inspect(){return {unmet:B.previousRequirements.all(),inflight:ee.getInflightInfo(),facts:Object.keys(t).map(e=>({key:e,meta:t[e]?._meta})),events:Object.keys(a).map(e=>({name:e,meta:x.get(e)})),constraints:d.getAllStates().map(e=>{let i=d.getWhenSpec(e.id);return {id:e.id,active:e.lastResult??false,disabled:d.isDisabled(e.id),priority:e.priority,hitCount:e.hitCount,lastActiveAt:e.lastActiveAt,meta:s[e.id]?.meta,...i?{whenSpec:i}:{}}}),resolvers:Object.fromEntries(ee.getInflight().map(e=>[e,ee.getStatus(e)])),resolverDefs:Object.entries(l).map(([e,i])=>({id:e,requirement:typeof i.requirement=="string"?i.requirement:"(predicate)",meta:i.meta})),effects:Object.entries(o).map(([e,i])=>({id:e,meta:i.meta})),derivations:Object.keys(c).map(e=>({id:e,meta:re.getMeta(e)})),modules:n.modules.map(e=>({id:e.id,meta:h.get(e.id)})),traceEnabled:w,...w?{trace:structuredClone(f.getEntries()??[])}:{}}},explain(e){let g=B.previousRequirements.all().find(P=>P.id===e);if(!g)return null;let M=d.getState(g.fromConstraint),D=ee.getStatus(e),$={},z=d.getDependencies(g.fromConstraint);if(z)for(let P of z)$[P]=j.get(P);else for(let[P,Q]of Object.entries(j.toObject()))$[P]=Q;let X=s[g.fromConstraint],Z=X?.meta?.label??g.fromConstraint,J=[`Requirement "${g.requirement.type}" (id: ${g.id})`,`\u251C\u2500 Produced by constraint: ${Z}`,`\u251C\u2500 Constraint priority: ${M?.priority??0}`,`\u251C\u2500 Constraint active: ${M?.lastResult??"unknown"}`,`\u251C\u2500 Resolver status: ${D.state}`];X?.meta?.description&&J.push(`\u251C\u2500 Description: ${X.meta.description}`);let r=d.explainWhen(g.fromConstraint),u=(P,Q,ae)=>{let ce=ae?"\u2514\u2500":"\u251C\u2500",Se=P.pass?"\u2713":"\u2717";if(P.children){if(P.op==="$not"){let Ge=P.pass?" (child failed)":" (child passed)";J.push(`${Q}${ce} ${Se} $not${Ge}`);}else J.push(`${Q}${ce} ${Se} ${P.op} (${P.actual}/${P.expected})`);let jt=`${Q}${ae?" ":"\u2502 "}`;P.children.forEach((Ge,At)=>{u(Ge,jt,At===P.children.length-1);});return}let qt=typeof P.expected=="object"?JSON.stringify(P.expected):String(P.expected),Tt=P.actual===void 0?"undefined":typeof P.actual=="object"?JSON.stringify(P.actual):String(P.actual);J.push(`${Q}${ce} ${Se} ${P.path} ${P.op} ${qt} (actual: ${Tt})`);};r&&r.length>0&&(J.push("\u251C\u2500 Predicate clauses:"),r.forEach((P,Q)=>{u(P,"\u2502 ",Q===r.length-1);}));let v=Object.entries(g.requirement).filter(([P])=>P!=="type").map(([P,Q])=>`${P}=${JSON.stringify(Q)}`).join(", ");v&&J.push(`\u251C\u2500 Requirement payload: { ${v} }`);let E=Object.entries($).slice(0,10);return E.length>0&&(J.push("\u2514\u2500 Relevant facts:"),E.forEach(([P,Q],ae)=>{let ce=ae===E.length-1?" \u2514\u2500":" \u251C\u2500",Se=typeof Q=="object"?JSON.stringify(Q):String(Q);J.push(`${ce} ${P} = ${Se.slice(0,50)}${Se.length>50?"...":""}`);})),J.join(`
|
|
2
|
+
`)},getOriginal(e,i){return oe.getOriginal(e,i)},restoreOriginal(e,i){return oe.restoreOriginal(e,i)},async settle(e=5e3){let i=()=>ee.getInflightCount()===0&&!B.isReconciling&&!B.reconcileScheduled&&!ee.hasPendingBatches();if(ee.hasPendingBatches()&&ee.processBatches(),await new Promise(g=>queueMicrotask(g)),!i())return new Promise((g,M)=>{let D=false,$=()=>{D||(D=true,clearTimeout(z),X());},z=setTimeout(()=>{$();let Z=[],J=ee.getInflightInfo();J.length>0&&Z.push(`${J.length} resolvers inflight: ${J.map(u=>u.resolverId).join(", ")}`),B.isReconciling&&Z.push("reconciliation in progress"),B.reconcileScheduled&&Z.push("reconcile scheduled");let r=B.previousRequirements.all();r.length>0&&Z.push(`${r.length} unmet requirements: ${r.map(u=>u.requirement.type).join(", ")}`),M(new Error(`[Directive] settle() timed out after ${e}ms. ${Z.join("; ")}`));},e),X=this.onSettledChange(()=>{ee.hasPendingBatches()&&ee.processBatches(),queueMicrotask(()=>{!D&&i()&&($(),g());});});})},getSnapshot(){return {facts:j.toObject(),version:1}},getDistributableSnapshot(e={}){let{includeDerivations:i,excludeDerivations:g,includeFacts:M,ttlSeconds:D,metadata:$,includeVersion:z}=e,X={},Z=Object.keys(c),J=new Set(Z),r;if(i){if(r=i.filter(E=>J.has(E)),chunkN4KTCKOI_cjs.a){let E=i.filter(P=>!J.has(P));E.length>0&&console.warn(`[Directive] getDistributableSnapshot: Unknown derivation keys ignored: ${E.join(", ")}. Available: ${Z.join(", ")||"(none)"}`);}}else r=Z;if(g){let E=new Set(g);r=r.filter(P=>!E.has(P));}for(let E of r)try{X[E]=re.get(E);}catch(P){chunkN4KTCKOI_cjs.a&&console.warn(`[Directive] getDistributableSnapshot: Skipping derivation "${E}" due to error:`,P);}if(M&&M.length>0){let E=j.toObject(),P=Object.keys(E);if(chunkN4KTCKOI_cjs.a){let Q=M.filter(ae=>!(ae in E));Q.length>0&&console.warn(`[Directive] getDistributableSnapshot: Unknown fact keys ignored: ${Q.join(", ")}. Available: ${P.join(", ")||"(none)"}`);}for(let Q of M)Q in E&&(X[Q]=E[Q]);}let u=Date.now(),v={data:X,createdAt:u};return D!==void 0&&D>0&&(v.expiresAt=u+D*1e3),z&&(v.version=chunkEOLY64E6_cjs.g(X)),$&&(v.metadata=$),v},watchDistributableSnapshot(e,i){let{includeDerivations:g,excludeDerivations:M}=e,D=Object.keys(c),$;if(g?$=g.filter(Z=>D.includes(Z)):$=D,M){let Z=new Set(M);$=$.filter(J=>!Z.has(J));}if($.length===0)return chunkN4KTCKOI_cjs.a&&console.warn("[Directive] watchDistributableSnapshot: No derivations to watch. Callback will never be called."),()=>{};let X=this.getDistributableSnapshot({...e,includeVersion:true}).version;return re.subscribe($,()=>{let Z=this.getDistributableSnapshot({...e,includeVersion:true});Z.version!==X&&(X=Z.version,i(Z));})},restore(e){if(!e||typeof e!="object")throw new Error("[Directive] restore() requires a valid snapshot object");if(!e.facts||typeof e.facts!="object")throw new Error("[Directive] restore() snapshot must have a facts object");if(!chunkEOLY64E6_cjs.e(e))throw new Error("[Directive] restore() rejected: snapshot contains potentially dangerous keys (__proto__, constructor, or prototype). This may indicate a prototype pollution attack.");j.batch(()=>{for(let[i,g]of Object.entries(e.facts))chunkN4KTCKOI_cjs.l.has(i)||j.set(i,g);});},onSettledChange(e){return we.add(e),()=>{we.delete(e);}},onHistoryChange(e){return de.add(e),()=>{de.delete(e);}},batch(e){j.batch(e);},get isSettled(){return ee.getInflightCount()===0&&!ee.hasPendingBatches()&&!B.isReconciling&&!B.reconcileScheduled},get isRunning(){return B.isRunning},get isInitialized(){return B.isInitialized},get isReady(){return B.isReady},whenReady(){return B.isReady?Promise.resolve():B.isRunning?(B.readyPromise||(B.readyPromise=new Promise(e=>{B.readyResolve=e;})),B.readyPromise):Promise.reject(new Error("[Directive] whenReady() called before start(). Call system.start() first, then await system.whenReady()."))}};function L(e){if(B.isReconciling)throw new Error(`[Directive] Cannot register module "${e.id}" during reconciliation. Wait for the current reconciliation cycle to complete.`);if(B.isDestroyed)throw new Error(`[Directive] Cannot register module "${e.id}" on a destroyed system.`);let i=(g,M)=>{if(g)for(let D of Object.keys(g)){if(chunkN4KTCKOI_cjs.l.has(D))throw new Error(`[Directive] Security: Module "${e.id}" has dangerous key "${D}" in ${M}.`);if(M==="schema"&&D.startsWith("$"))throw new Error(`[Directive] Module "${e.id}" has schema key "${D}" starting with "$". Keys starting with $ are reserved for internal accessors ($store, $snapshot).`)}};i(e.schema,"schema"),i(e.events,"events"),i(e.derive,"derive"),i(e.effects,"effects"),i(e.constraints,"constraints"),i(e.resolvers,"resolvers");for(let g of Object.keys(e.schema))if(g in t)throw new Error(`[Directive] Schema collision: Fact "${g}" already exists. Cannot register module "${e.id}".`);if(chunkN4KTCKOI_cjs.a&&e.derive){let g=new Set(Object.keys(t));for(let M of Object.keys(e.derive))g.has(M)&&console.warn(`[Directive] "${M}" exists as both a fact and a derivation after registering module "${e.id}".`);}if(e.history?.snapshotEvents){U===null&&(U=new Set(Object.keys(a)));for(let g of e.history.snapshotEvents)U.add(g);}else if(U!==null&&e.events)for(let g of Object.keys(e.events))U.add(g);Object.assign(t,e.schema);for(let g of Object.values(e.schema)){let M=g;M._meta&&(M._meta=fe(M._meta));}if(e.events&&(It(e.events,x),Object.assign(a,e.events)),e.derive&&(Object.assign(c,e.derive),re.registerDefinitions(e.derive)),e.effects){for(let g of Object.values(e.effects)){let M=g;M.meta&&(M.meta=fe(M.meta));}Object.assign(o,e.effects),le.registerDefinitions(e.effects);}if(e.constraints){for(let g of Object.values(e.constraints)){let M=g;M.meta&&(M.meta=fe(M.meta));}Object.assign(s,e.constraints),d.registerDefinitions(e.constraints);}if(e.resolvers){for(let g of Object.values(e.resolvers)){let M=g;M.meta&&(M.meta=fe(M.meta));}Object.assign(l,e.resolvers);for(let g of Object.keys(e.resolvers))K.set(g,e);ee.registerDefinitions(e.resolvers),C(e.resolvers);}if(j.registerKeys(e.schema),e.meta){let g=fe(e.meta);g&&h.set(e.id,g);}n.modules.push(e),e.init&&j.batch(()=>{e.init(G);}),e.hooks?.onInit?.(q),B.isRunning&&(e.hooks?.onStart?.(q),ge());}q.registerModule=L,I.emitInit(q);for(let e of n.modules)e.hooks?.onInit?.(q);return q}exports.A=Dn;exports.B=En;exports.C=pt;exports.D=yt;exports.E=Xt;exports.F=jn;exports.G=An;exports.H=Fn;exports.I=$e;exports.J=ht;exports.K=St;exports.L=bt;exports.M=Qt;exports.N=wt;exports.O=tn;exports.P=nn;exports.Q=kt;exports.R=Dt;exports.S=Ct;exports.T=qr;exports.a=Ee;exports.b=cn;exports.c=Kt;exports.d=dn;exports.e=We;exports.f=fn;exports.g=ze;exports.h=lt;exports.i=Me;exports.j=Ye;exports.k=vn;exports.l=Sn;exports.m=Be;exports.n=Xe;exports.o=Te;exports.p=dt;exports.q=et;exports.r=bn;exports.s=gt;exports.t=mt;exports.u=Cn;exports.v=je;exports.w=Vt;exports.x=Ht;exports.y=Lt;exports.z=Ut;//# sourceMappingURL=chunk-7NMXRATK.cjs.map
|
|
3
|
+
//# sourceMappingURL=chunk-7NMXRATK.cjs.map
|