@ibgib/space-gib 0.0.2 → 0.0.3
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/client/bootstrap.mjs +1 -1
- package/dist/client/chunk-2KJC5XKE.mjs +31 -0
- package/dist/client/{chunk-RE7XSMHH.mjs.map → chunk-2KJC5XKE.mjs.map} +4 -4
- package/dist/client/{chunk-RDTAT5G4.mjs → chunk-QNIXTRFO.mjs} +2 -2
- package/dist/client/index.html +7 -5
- package/dist/client/index.mjs +1 -1
- package/dist/client/script.mjs +1 -1
- package/dist/server/server.mjs +537 -107
- package/dist/server/server.mjs.map +4 -4
- package/package.json +1 -1
- package/src/client/AUTO-GENERATED-version.mts +1 -1
- package/src/client/api/space-gib-api-bridge.mts +35 -0
- package/src/client/dev-tools.mts +396 -295
- package/src/client/index.html +7 -5
- package/src/common/keystone-policies.mts +1 -1
- package/src/server/serve-gib/handlers/api/keystone/keystone-evolve.handler.mts +1 -1
- package/src/server/serve-gib/handlers/api/keystone/keystone-get.respec.mts +3 -3
- package/src/server/serve-gib/handlers/api/keystone/keystone-post.handler.mts +1 -1
- package/src/server/serve-gib/handlers/ws/sync-upgrade-handler-base.mts +7 -3
- package/dist/client/chunk-BL2SGXS4.mjs +0 -18994
- package/dist/client/chunk-RE7XSMHH.mjs +0 -31
- package/dist/client/chunk-YUSGN3J4.mjs +0 -23119
- /package/dist/client/{chunk-RDTAT5G4.mjs.map → chunk-QNIXTRFO.mjs.map} +0 -0
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
var ol=Object.defineProperty;var f=(o,t)=>ol(o,"name",{value:t,configurable:!0});var ce=/^[a-zA-Z0-9_\-.]{1,256}$/,Ot=/^[a-zA-Z0-9_]{1,255}$/,Ta=/^(\[.+\])?\s?(\(UNEXPECTED\)|\(unexpected\))?(.+)(\([EIWeiw]: [a-fA-F\d]{32}\))(\(UNEXPECTED\)|\(unexpected\))?$/,Aa=/^(\[.+\]).+$/,Sa=/^[0-9a-fA-F]{32}$/,Ga=/^[0-9a-fA-F]{64}$/;var ar="/",Ca="_nonalphanumerics_";var ir=!1,xa=globalThis.crypto,{subtle:sl}=xa,Oe={sha_256:"SHA-256",sha_512:"SHA-512"};function L(o){return JSON.parse(JSON.stringify(o))}f(L,"clone");function Ge(o){return(o??new Date).toUTCString()}f(Ge,"getTimestamp");async function ke({s:o,algorithm:t="SHA-256"}){if(!o)return"";try{let e=Object.values(Oe);if(!e.includes(t))throw new Error(`Only ${e} implemented (E: 73cb52cd4d7f70c3415fdf695ba6ba23)`);let r=new TextEncoder().encode(o),n=await sl.digest(t,r);return Array.from(new Uint8Array(n)).map(a=>a.toString(16).padStart(2,"0")).join("")}catch(e){throw console.error(E(e.message)),e}}f(ke,"hash");async function j(o=64){let t="";if(o<32)throw new Error("Seed size must be at least 32");if(!globalThis.crypto)throw new Error("Cannot create UUID, as unknown crypto library version. If using node.js, v19+ is required. (E: c02cee3fd8a94f678d3f4ebe9dc49797)");let e=xa.getRandomValues(new Uint8Array(16));if(t=await ke({s:e.join("")}),!t)throw new Error("Did not create UUID...hmm...");return t}f(j,"getUUID");function P(o){return JSON.stringify(o,null,2)}f(P,"pretty");async function pe(o){return new Promise(t=>{setTimeout(()=>{t()},o)})}f(pe,"delay");function E(o){return!o&&o!==0?"[error is falsy]":typeof o=="string"?o:typeof o.message=="string"?o.message:typeof o=="number"?JSON.stringify(o):o.error?(console.warn(`[${E.name}] this fn takes the raw error object. no destructure required. change your call from extractErrorMsg({error}) to extractErrorMsg(error). (W: ea49af5fd76d4b80a55a108d73a3e9b4)`),E(o.error)):`[error is not a string and error.message is not a string. typeof error: ${typeof o} (E: d5a7723ca59646838308bc9e53a43134)]`}f(E,"extractErrorMsg");function An({items:o,keyFn:t}){let e=`[${An.name}]`;try{let r={};for(let n=0;n<o.length;n++){let s=o[n],a=t(s);r[a]=[...r[a]??[],s]}return r}catch(r){throw console.error(`${e} ${r.message}`),r}}f(An,"groupBy");function Zr({min:o,max:t,chars:e,noSpaces:r}){return o=o??1,t=t??999999999999,e=e??"",r?new RegExp(`^[\\w${e}]{${o},${t}}$`):new RegExp(`^[\\w\\s${e}]{${o},${t}}$`)}f(Zr,"getRegExp");function Me(o){let t;if(o){if(t=new Date(o),t.toString()==="Invalid Date")throw new Error(`invalid date created by timestamp (${o}) (E: cbd6aeefe00708184e276ea3c2532b22)`)}else t=new Date;return t.getTime().toString()}f(Me,"getTimestampInTicks");function Sn({startDate:o,years:t,months:e,days:r,hours:n,seconds:s}){let a=`[${Sn.name}]`;try{return Wt({startDate:o,years:t,months:e,days:r,hours:n,seconds:s}).toUTCString()}catch(i){throw console.log(`${a} ${i.message}`),i}}f(Sn,"getExpirationUTCString");function Wt({startDate:o,years:t,months:e,days:r,hours:n,seconds:s}){let a=`[${Wt.name}]`;try{if(!o&&!t&&!e&&!r&&!n&&!s)throw new Error("either startDate or a time interval required. (E: 30248f8b306f443ab036fa8c313c50d8)");o=o?new Date(o):new Date;let i,c;return t?(i=o.getFullYear()+t,c=o.setFullYear(i),Wt({startDate:new Date(c),months:e,days:r,hours:n,seconds:s})):e?(i=o.getMonth()+e,c=o.setMonth(i),Wt({startDate:new Date(c),years:t,days:r,hours:n,seconds:s})):r?(i=o.getDate()+r,c=o.setDate(i),Wt({startDate:new Date(c),years:t,months:e,hours:n,seconds:s})):n?(i=o.getHours()+n,c=o.setHours(i),Wt({startDate:new Date(c),years:t,months:e,days:r,seconds:s})):s?(i=o.getSeconds()+s,c=o.setSeconds(i),Wt({startDate:new Date(c),years:t,months:e,days:r,hours:n})):o}catch(i){throw console.log(`${a} ${i.message}`),i}}f(Wt,"addTimeToDate");function Gn({expirationTimestampUTC:o}){let t=`[${Gn.name}]`;try{if(!o)throw new Error("expirationTimestampUTC required (E: 5eeb1e29f93d64f70c71a8112080a222)");let e=new Date(o);if(e.toUTCString()==="Invalid Date")throw new Error(`invalid expirationTimestampUTC: ${o} (E: 66a1a165bcf1f9336fe78856ab777822)`);return e<new Date}catch(e){throw console.error(`${t} ${e.message}`),e}}f(Gn,"isExpired");function Qr(o){return Array.from(new Set(o))}f(Qr,"unique");function Cn({obj:o,value:t,path:e,pathDelimiter:r,logalot:n}){let s=`[${Cn.name}]`;try{if(n&&console.log(`${s} starting...`),!o)throw new Error("obj required (E: 6a9dd32a361476e80b1bf7b91ec50522)");if(typeof o!="object")throw new Error("obj must be type 'object' (E: 66fdc289b32c06492bd95f5d266e6a22)");if(!e)throw new Error("path required (at the very least should be the key in the root obj.) (E: fc779e7794ead8a0b44e5f2e776b0e22)");r=r||ar;let a=o,i=e.split(r).filter(l=>!!l),c=i.pop();i.forEach(l=>{let d=a[l];if(d){if(typeof d!="object")throw new Error(`invalid path into object. Each step along the path must be typeof === 'object', but typeof targetObj["${l}"] === ${typeof d}. (value: ${d}) (E: 38cf29c5f624a40b4b56502c2ec39d22)`)}else a[l]={};a=a[l]}),a[c]=t}catch(a){throw console.error(`${s} ${a.message}`),a}finally{n&&console.log(`${s} complete.`)}}f(Cn,"patchObject");async function Sr({n:o}){let t=`[${Sr.name}]`;try{ir&&console.log(`${t} starting...`);let e=[];for(let r=0;r<o;r++){let n=await j();e.push(n.substring(0,16))}return e}catch(e){throw console.error(`${t} ${e.message}`),e}finally{ir&&console.log(`${t} complete.`)}}f(Sr,"getIdPool");function al({text:o,length:t,keepLiterals:e=["-"],replaceMap:r}){let n=`[${al.name}]`;try{if(ir&&console.log(`${n} starting... (I: 27437e312e5aa621adfebb84e059c822)`),!o)throw new Error("text required (E: 87e0493613c8b30dfade83e1d2862a22)");let s=o,a={};e=e??[];for(let c=0;c<e.length;c++){let l=e[c],d;do d=Na({count:10});while(d.includes(l)||l.includes(d)||o.includes(d));if(s.includes(l))for(a[d]=l;s.includes(l);)s=s.replace(l,d)}if(r&&Object.keys(r).length>0)for(let c=0;c<Object.keys(r).length;c++){let l=Object.keys(r)[c],d=r[l];for(;s.includes(l);)s=s.replace(l,d)}s=s.replace(/\W/g,"");let i=Object.keys(a);for(let c=0;c<i.length;c++){let l=i[c];for(;s.includes(l);)s=s.replace(l,a[l])}return t&&t>0&&s.length>t&&(ir&&console.log(`${n} curtailing length (I: d7a28e05daa5979c7686b4c1cf519b23)`),s=s.substring(0,t)),s.length===0&&(s=Ca),s}catch(s){throw console.error(`${n} ${s.message}`),s}finally{ir&&console.log(`${n} complete.`)}}f(al,"getSaferSubstring");function il({x:o}){if((o??[]).length===0)return;let t=Math.floor(Math.random()*o.length);return o[t]}f(il,"pickRandom");function Na({count:o}){let t=`${Na.name}]`;try{if(!Number.isInteger(o))throw new Error("count required to be a number. (E: c0a21d884ebd9afc4b2e8025207e0522)");let e="";for(let r=0;r<o;r++)e+=il({x:"a b c d e f g h i j k l m n o p q r s t u v w x y z".split(" ")});if(e.length!==o)throw new Error(`${t} (UNEXPECTED) result.length !== count ? (E: 9bec4ec8f78610d8055e565415392a22)`);return e}catch(e){throw console.error(`${t} ${e.message}`),e}finally{ir&&console.log(`${t} complete.`)}}f(Na,"pickRandom_Letters");function cr({dominant:o,recessive:t}){let e=`[${cr.name}]`;try{if(Array.isArray(o)&&Array.isArray(t)){let r=L(o),n=!1;return t.forEach(s=>{if(typeof s=="string")r.includes(s)||r.push(s);else{n||(console.warn(`${e} merging arrays of non-string elements. (W: d8ab113064834abc8eb5fe6c4cf87ba3)`),n=!0);let a=JSON.stringify(s);r.some(i=>JSON.stringify(i)===a)||r.push(s)}}),r}else if(typeof o=="object"&&typeof t=="object"){let r={...t},n=Object.keys(o),s=Object.keys(t);return n.forEach(a=>{s.includes(a)?Array.isArray(o[a])&&Array.isArray(t[a])?r[a]=cr({dominant:o[a],recessive:t[a]}):o[a]&&!Array.isArray(o[a])&&typeof o[a]=="object"&&t[a]&&!Array.isArray(t[a])&&typeof t[a]=="object"?r[a]=cr({dominant:o[a],recessive:t[a]}):r[a]=o[a]:r[a]=o[a]}),r}else return console.warn(`${e} unknown values or value types do not match. Both should either be an array or map. Dominant one wins categorically without any merging. (W: 3690ea19b81a4b89b98c1940637df62c)`),o}catch(r){throw console.error(`${e} ${r.message}`),r}}f(cr,"mergeMapsOrArrays_Naive");function w({ib:o,gib:t,ibGib:e,delimiter:r="^"}){return o=o||e?.ib||"",t=t||e?.gib||"",o+r+t}f(w,"getIbGibAddr");function H({ibGib:o,ibGibAddr:t,delimiter:e="^"}){let r="[getIbAndGib]";if(!t)if(o)t=w({ibGib:o});else throw new Error(`${r} We need either an address or an ibGib object`);if(!t)throw new Error(`${r} Couldn't get ibGibAddr. ibGib invalid?`);e||(e="^");let n=t.split(e);return n.length===2?{ib:n[0],gib:n[1]}:n.length===1&&t.endsWith(e)?{ib:n[0],gib:""}:n.length===1&&t.startsWith(e)?{ib:"",gib:n[0]}:n.length===2&&n[0]===""&&n[1]===""?{ib:e,gib:""}:(console.warn(`${r} multiple delimiters found in ibGibAddr. Considering last delimiter as the demarcation of gib hash`),{ib:n.slice(0,n.length-1).join(e),gib:n.slice(n.length-1)[0]})}f(H,"getIbAndGib");var cl=globalThis.crypto,{subtle:va}=cl;function Dt(o,t=""){t||(t="");let e=f(async a=>{if(!a)return"";let i=new TextEncoder().encode(a),c=await va.digest("SHA-256",i);return Array.from(new Uint8Array(c)).map(d=>d.toString(16).padStart(2,"0")).join("")},"hashToHex"),r=f(async(a,i)=>{let c;if(a){let b=new TextEncoder().encode(a);c=new Uint8Array(b.length+i.length),c.set(b),c.set(i,b.length)}else c=i;let l=await va.digest("SHA-256",c);return Array.from(new Uint8Array(l)).map(b=>b.toString(16).padStart(2,"0")).join("")},"hashToHex_Uint8Array"),n=f(a=>{if(a===null||typeof a!="object")return a;if(Array.isArray(a))return a.map(l=>n(l));let i={},c=Object.keys(a).sort();for(let l of c){let d=a[l];d!==void 0&&(i[l]=n(d))}return i},"toNormalizedForHashing"),s;return t?s=f(async(a,i,c)=>{let l=Object.keys(c||{}).length>0&&Object.keys(c||{}).some(g=>c[g]&&c[g].length>0),d=!!i;d&&(typeof i=="string"?d=i.length>0:i instanceof Uint8Array?d=!0:typeof i=="object"?d=Object.keys(i||{}).length>0:d=!0);let b=(await e(t+a)).toUpperCase(),h=l?(await e(t+JSON.stringify(n(c)))).toUpperCase():"",p="";return d&&(i instanceof Uint8Array?p=(await r(t,i)).toUpperCase():p=(await e(t+JSON.stringify(n(i)))).toUpperCase()),l||d?(await e(t+b+h+p)).toUpperCase():(await e(t+b)).toUpperCase()},"hashFields"):s=f(async(a,i,c)=>{let l=Object.keys(c||{}).length>0&&Object.keys(c||{}).some(g=>c[g]&&c[g].length>0),d=!!i;d&&(typeof i=="string"?d=i.length>0:i instanceof Uint8Array?d=!0:typeof i=="object"?d=Object.keys(i||{}).length>0:d=!0);let b=(await e(a)).toUpperCase(),h=l?(await e(JSON.stringify(n(c)))).toUpperCase():"",p="";return d&&(i instanceof Uint8Array?p=(await r("",i)).toUpperCase():p=(await e(JSON.stringify(n(i)))).toUpperCase()),l||d?(await e(b+h+p)).toUpperCase():(await e(b)).toUpperCase()},"hashFields"),s(o.ib,o?.data,o?.rel8ns)}f(Dt,"sha256v1");var te;(function(o){o.past="past",o.ancestor="ancestor",o.dna="dna",o.identity="identity",o.tjp="tjp",o.secret="secret",o.encryption="encryption"})(te||(te={}));var lr="ib",M="gib",z={ib:lr,gib:M},le="^",lt=".",Oa="ib^gib",Vt=["past","ancestor","dna","tjp"],ll=155,Da=new RegExp(`^[\\w\\t\\-|=+.&%$#@!~\` \\[\\]\\(\\)\\{\\}]{1,${ll}}$`);async function zt(o){let t=L(o),e=`[${zt.name}]`;t.srcAddr&&delete t.srcAddr,delete t.src;let r={ib:t.type,data:t,rel8ns:{ancestor:[`${t.type.toString()}${le}${M}`]}};return r.gib=await Dt(r),r}f(zt,"buildDna");function xn({ibGib:o}){let t=`[${xn.name}]`;try{if(!o)throw new Error("ibGib required.");let e=["fork","mut8","rel8","plan"].map(n=>`${n}^${M}`);return o.rel8ns&&o.rel8ns.ancestor&&Array.isArray(o.rel8ns.ancestor)&&o.rel8ns.ancestor.some(n=>e.includes(n))||!1}catch(e){throw console.error(`${t} ${E(e)}`),e}}f(xn,"isDna");function ie({ibGib:o,gib:t}){return o?ie({gib:o.gib}):t?t===M:!0}f(ie,"isPrimitive");async function J({ibGib:o,hasTjp:t,tjpAddr:e,gibDelimiter:r,isPrimitive:n,hashAlgorithm:s}){let a=`[${J.name}]`;try{if(!o)throw new Error("ibGib required. (E: 17d073226b9d42fd841e5a94b065ef21)");if(n)return M;let i=await Dt(o,""),c=o.rel8ns??{},l=o.data??{};if(r=r||lt,t||(t=(c.tjp??[]).length>0||l.isTjp||!1),t){let d;if(c.tjp)if(c.tjp.length===1)if(c.tjp[0])e=c.tjp[0];else throw new Error("rel8ns.tjp[0] is falsy. (E: ed879d2b039543f8b1902e8b7b5a5a7b)");else if(c.tjp.length>1)if(c.tjp[c.tjp.length-1])console.warn(`${a} found more than one tjp addr...only expecting 1 ATOW. (W: 10ed43f716e743e0afd1954f1ab46789)`),e=c.tjp[c.tjp.length-1];else throw new Error("multiple tjp addrs, and the last (most recent) one is falsy. (E: bc835dc89be24075bba8b2b6616ea069)");else throw new Error("hasTjp is true but rel8ns.tjp is empty array. (E: d08b2f9e86494814b5e7d7b4602b2ab7)");else if(l.isTjp)e=w({ib:o.ib,gib:i});else throw new Error("hasTjp is true, but both ibGib.rel8ns.tjp and ibGib.data.isTjp are falsy. (E: 4e246897e52044789594d853bb5b66ee)");if(d=e?H({ibGibAddr:e}).gib:void 0,d)return l.isTjp?i:`${i}${lt}${d}`;throw new Error("hasTjp is true but could not find tjpAddrGib. (E: 1863df626b754744a1d431a683cb0ba0)")}else return i}catch(i){throw console.error(`${a} ${E(i)}`),i}}f(J,"getGib");function ue({ibGibAddr:o,gib:t,gibDelimiter:e}){let r=`[${ue.name}]`;try{if(!o&&!t)throw new Error("Either ibGibAddr or gib required. (E: 25e3dcbe63cd44909032df12af9df75e)");if(t=t||H({ibGibAddr:o}).gib,t===M)return{isPrimitive:!0};if(e=e??lt,t.includes(e)){let n=t.split(e);if(n.some(i=>i===""))throw new Error(`unexpected gib that contains gibDelimiter (${e}) but has at least one piece with empty string. (E: 75a94280045541009ee68182d12d3449)`);let s=n.length;return s>2&&console.warn(`${r} gib only expected to have two pieces ATOW. re-examine please. (W: aa4283ac5a5747a386a69966ecdad39d)`),{punctiliarHash:n.splice(0,1)[0],tjpGib:n.join(e),piecesCount:s,delimiter:e}}else return{punctiliarHash:t,piecesCount:1,delimiter:e}}catch(n){throw console.error(`${r} ${E(n)}`),n}}f(ue,"getGibInfo");async function eo(o){let{noTimestamp:t,dna:e,linkedRel8ns:r,destIb:n,uuid:s,tjp:a,cloneRel8ns:i,cloneData:c,type:l="fork"}=o,d=o.src,b="[fork_v1]";if(l!=="fork")throw new Error(`${b} not a fork transform.`);if(o.type||(o.type="fork"),!d)throw new Error(`${b} src required to fork.`);if(!d.ib)throw new Error(`${b} src.ib required.`);if(n&&n.includes(le))throw new Error(`${b} destIb can't contain (hardcoded) delimiter right now.`);if(!d.gib)throw new Error(`${b} src.gib required.`);let h={ib:d.ib,gib:d.gib};d.data&&Object.keys(d.data).length>0&&(h.data=d.data),d.rel8ns&&Object.keys(d.rel8ns).length>0&&(h.rel8ns=d.rel8ns),d=h;let p=w({ib:d.ib,gib:d.gib});o.srcAddr=p;let u=i&&d.rel8ns&&Object.keys(d.rel8ns).length>0?L(d.rel8ns):{};delete u.past;let g=c&&d?.data?L(d.data):{};o.nCounter&&(g.n=0);let m=r?.includes(te.ancestor)?[p]:(u.ancestor||[]).concat([p]);u.ancestor=m,u.tjp&&delete u.tjp;let $=L(d);if(t&&a?.timestamp)throw new Error(`${b} both noTimestamp and tjp.timestamp selected.`);if(!t||a?.timestamp){let y=new Date;g.timestamp=Ge(y),g.timestampMs=y.getMilliseconds()}(a?.uuid||s)&&(g.uuid=await j()),a?.uuid||a?.timestamp?g.isTjp=!0:g.isTjp&&delete g.isTjp,$.ib=n||"ib",p!==Oa&&($.rel8ns=u),Object.keys(g).length>0&&($.data=g);let T=null;if(e){T=await zt(o);let y=w({ibGib:T});u.dna=r?.includes(te.dna)?u.dna=[y]:u.dna=(u.dna||[]).concat(y)}$.gib=await Dt($,"");let I={newIbGib:$};return T&&(I.dnas=[T]),I}f(eo,"fork");async function Fe(o){let{noTimestamp:t,dna:e,linkedRel8ns:r,dataToRename:n,dataToRemove:s,dataToAddOrPatch:a,mut8Ib:i,type:c="mut8"}=o,l=o.src,d="[mut8_v1]";if(c!=="mut8")throw new Error(`${d} not a mut8 transform.`);if(o.type||(o.type="mut8"),!l)throw new Error(`${d} src required to mut8.`);if(!l.ib)throw new Error(`${d} src.ib required.`);if(l.ib.includes(le))throw new Error(`${d} ib can't contain hardcoded delimiter (${le}) right now.`);if(!l.gib)throw new Error(`${d} src.gib required.`);if(!i&&!n&&!s&&!a)throw new Error(`${d} gotta provide either a mut8Ib or some data to change.`);let b=w({ib:l.ib,gib:l.gib});if(o.srcAddr&&b!==o.srcAddr)throw new Error(`${d} srcAddr from src does not equal opts.srcAddr`);if(o.srcAddr=b,ie({ibGib:l}))throw new Error(`${d} cannot mutate primitive ibgib`);let h={ib:l.ib,gib:l.gib};l.data&&Object.keys(l.data).length>0&&(h.data=l.data),l.rel8ns&&Object.keys(l.rel8ns).length>0&&(h.rel8ns=l.rel8ns),l=h;let p=L(l),u=l.rel8ns?l.rel8ns:{},g=L(u);g.past=r?.includes(te.past)?[b]:(g.past||[]).concat([b]);let m=l?.data?L(l.data):{};if(n&&(m=Nn(m,n,"rename")),s&&(m=Nn(m,s,"remove")),a&&(m=La(m,a)),!t){let A=new Date;m.timestamp=Ge(A),m.timestampMs=A.getMilliseconds()}if(o.nCounter||Object.keys(m).includes("n"))if(Object.keys(m).includes("n"))if(Number.isInteger(m.n))m.n>=0?m.n=m.n+1:(console.warn(`${d} data.n is less than 0, which is unexpected. Resetting data.n to 0.`),m.n=0);else throw new Error("cannot increment nCounter because data.n is not a number.");else m.n=0;if(m.isTjp){let A=g.tjp??[];A.push(b),g.tjp=A,delete m.isTjp}let T=null;if(e){T=await zt(o);let A=w({ibGib:T});g.dna=r?.includes(te.dna)?g.dna=[A]:g.dna=(g.dna||[]).concat(A)}p.ib=i||p.ib,p.rel8ns=g,Object.keys(m).length>0?p.data=m:delete p.data;let I=(g.tjp?.length??0)>0;p.gib=await J({ibGib:p,hasTjp:I});let y={newIbGib:p};return T&&(y.dnas=[T]),y}f(Fe,"mut8");function Nn(o,t,e){let r="[renameOrRemove]",n=["timestamp"];return Object.keys(t).forEach(s=>{if(n.includes(s))throw new Error(`${r} Cannot rename to ${s}.`);if(Object.keys(o).includes(s)){let a=t[s];if(typeof a=="string"){if(n.includes(a))throw new Error(`${r} Cannot rename to ${a}.`);e==="rename"&&(o[a]=o[s]),delete o[s]}else o[s]=Nn(o[s],a,e)}else console.log(`${r} key to ${e} does not exist`)}),o}f(Nn,"renameOrRemove");function La(o,t){return Object.keys(t).forEach(e=>{let r=t[e],n=o[e];n?Array.isArray(r)||Array.isArray(n)?o[e]=r:typeof r=="object"&&typeof n=="object"?o[e]=La(n,r):o[e]=r:o[e]=r}),o}f(La,"patch");async function Ce(o){let{noTimestamp:t,dna:e,linkedRel8ns:r,rel8nsToAddByAddr:n,rel8nsToRemoveByAddr:s,type:a="rel8"}=o,i=o.src,c="[rel8_v1]";if(a!=="rel8")throw new Error(`${c} not a rel8 transform.`);if(o.type||(o.type="rel8"),a!=="rel8")throw new Error(`${c} not a rel8 transform.`);if(o.type||(o.type="rel8"),!i)throw new Error(`${c} src required.`);if(!i.ib)throw new Error(`${c} src.ib required.`);if(i.ib.includes(le))throw new Error(`${c} ib can't contain hardcoded delimiter (${le}) right now.`);if(!i.gib)throw new Error(`${c} src.gib required.`);if(ie({ibGib:i}))throw new Error(`${c} cannot relate/unrelate primitive ibgib`);let l=n&&Object.keys(n).length>0,d=s&&Object.keys(s).length>0;if(!(l||d))throw new Error(`${c} gotta provide relations to either add or remove.`);let b=w({ib:i.ib,gib:i.gib});if(o.srcAddr&&b!==o.srcAddr)throw new Error(`${c} srcAddr from src does not equal opts.srcAddr`);o.srcAddr=b;let h=f(y=>y&&typeof y=="string"&&y.length>=2&&y.includes("^")&&y.split("^")[0].length>=1,"fnValidIbGibAddr");Object.keys(n||{}).map(y=>(n||{})[y]).forEach(y=>{if(!(y&&y.every(A=>h(A))))throw new Error(`${c} Invalid rel8n attempt. Must be valid ibGibs. Did you include a delimiter (^)?`)}),Object.keys(s||{}).map(y=>(s||{})[y]).forEach(y=>{if(!(y&&y.every(A=>h(A))))throw new Error(`${c} Invalid remove rel8n attempt. Must be valid ibGibs. Did you include a delimiter (^)?`)});let p={ib:i.ib,gib:i.gib};i.data&&Object.keys(i.data).length>0&&(p.data=i.data),i.rel8ns&&Object.keys(i.rel8ns).length>0&&(p.rel8ns=i.rel8ns),i=p;let u=L(i),g=L(i.data||{});if(o.nCounter||Object.keys(g).includes("n"))if(Object.keys(g).includes("n"))if(Number.isInteger(g.n))g.n>=0?g.n=g.n+1:(console.warn(`${c} data.n is less than 0, which is unexpected. Resetting data.n to 0.`),g.n=0);else throw new Error("cannot increment nCounter because data.n is not a number.");else g.n=0;if(!t){let y=new Date;g.timestamp=Ge(y),g.timestampMs=y.getMilliseconds()}let m=L(i.rel8ns||{});if(Object.keys(n||{}).forEach(y=>{if(Vt.includes(y))throw new Error(`${c} Cannot manually add relationship: ${y}.`);let A=m[y]||[],S=n[y].filter(N=>!A.includes(N));m[y]=A.concat(S)}),Object.keys(s||{}).forEach(y=>{if(Vt.includes(y))throw new Error(`${c} Cannot manually remove relationship: ${y}.`);let A=m[y]||[],_=s[y]||[],S=A.filter(N=>!_.includes(N));S.length>0?m[y]=S:delete m[y]}),m.past=(m.past||[]).concat([b]),(r||[]).filter(y=>Object.keys(m).includes(y)).filter(y=>(m[y]||[]).length>1).forEach(y=>{let A=m[y].length;m[y]=[m[y][A-1]]}),g.isTjp){let y=m.tjp||[];y.push(b),m.tjp=y,delete g.isTjp}u.data=g,u.rel8ns=m;let $=(m.tjp?.length??0)>0,T=null;if(e){T=await zt(o);let y=w({ibGib:T});m.dna=r?.includes(te.dna)?m.dna=[y]:m.dna=(m.dna||[]).concat(y)}u.gib=await J({ibGib:u,hasTjp:$});let I={newIbGib:u};return T&&(I.dnas=[T]),I}f(Ce,"rel8");function to({ibGib:o}){let t=`[${to.name}]`;if(!o)return console.warn(`${t} ibGib falsy. (W: 884178562f5b4f15933ac4d98db74cc6)`),!1;if(o.data?.isTjp||o.rel8ns?.tjp?.length>0)return!0;let e=["fork^gib","mut8^gib","rel8^gib"];return(o.rel8ns?.ancestor??[]).some(n=>e.includes(n))?!1:o.gib?o.gib.includes(lt)?!0:o.gib===M?!1:!!ue({ibGibAddr:w({ibGib:o})}).tjpGib:(console.warn(`${t} ibGib.gib falsy. (W: 6400d780822b44d992846f1196509be3)`),!1)}f(to,"hasTjp");function ro({ibGib:o}){let t=`[${ro.name}]`;o.ib||console.warn(`${t} ibGib.ib is falsy. (W: e60e41c2a1fc48268379d88ce13cb77b)`),o.gib||console.warn(`${t} ibGib.gib is falsy. (W: fb3889cbf0684ae4ac51e48f28570377)`);let e={ib:(o.ib||"").slice()};return o.gib&&(e.gib=o.gib.slice()),o.data&&(e.data=o.data instanceof Uint8Array?o.data:L(o.data)),o.rel8ns&&(e.rel8ns=L(o.rel8ns)),e}f(ro,"toDto");var vn=!1;async function Z({ibGib:o}){let t=`[${Z.name}]`;try{let e=[];if(o){let r=w({ibGib:o});if(e=fr({addr:r})??[],e.length>0)return console.error(`${t} errors found in addr: ${r}`),e;if(ie({gib:o.gib}))return null;let n=await J({ibGib:ro({ibGib:o}),hasTjp:to({ibGib:o})});return n!==o.gib&&(o.data?.src&&o.data.srcAddr&&o.ib==="rel8"?(delete o.data.src,delete o.data.srcAddr,n=await J({ibGib:ro({ibGib:o}),hasTjp:to({ibGib:o})}),n!==o.gib&&e.push(`Ibgib invalid intrinsically - gottenGib (${n}) does not equal ibGib.gib (${o.gib}). (E: 020b71479e944b2198fe436e7e137786)`)):e.push(`Ibgib invalid intrinsically - gottenGib (${n}) does not equal ibGib.gib (${o.gib}). (E: 7416db016878430ca3c5b20697f164ed)`)),e.length>0?e:null}else return e.push("ibGib is itself falsy. (E: 4fb98caf6ed24ef7b35a19cef56e2d7e)"),e}catch(e){throw console.error(`${t} ${E(e)}`),e}}f(Z,"validateIbGibIntrinsically");function fr({addr:o,delimiter:t,version:e}){let r=`[${fr.name}]`;try{let n=[];if(e&&console.warn(`${r} version not implemented yet. Ignoring. (W: 2d19db16ec0c4766b5d35248787671f3)`),!o)return n.push("addr required. (E: e9a54041aa0b41c1bb2324d9d2d42c7f)"),n;t=t||le,o.includes(t)||n.push(`No delimiter (${t}) found. (E: 05e28dcb70ff44019edc53ed508bd1e8)`),o.startsWith(t)&&n.push("addr starts with delim. (E: d29f808c5a47452f9bb3ea684694c6eb)");let{ib:s,gib:a}=H({ibGibAddr:o,delimiter:t}),i=br({ib:s,ibGibAddrDelimiter:t,version:e});i&&(n=n.concat(i));let c=dr({gib:a,ibGibAddrDelimiter:t,version:e});return c&&(n=n.concat(c)),n.length>0&&vn&&console.log(`${r} errors.length > 0. errors: ${n.join("|")} (I: 9c18f993e138f15613e4c6a340d41722)`),n.length>0?n:null}catch(n){throw console.error(`${r} ${E(n)}`),n}}f(fr,"validateIbGibAddr");function br({ib:o,ibGibAddrDelimiter:t,version:e}){let r=`[${br.name}]`;try{let n=[];return e&&console.warn(`${r} version not implemented yet. Ignoring. (W: 71228ba4ed994aaa8149910e295ab087)`),o?o===lr?null:(t=t||le,o.includes(t)&&n.push(`ib contains ibGibAddrDelimiter (${t}) (E: 09e61b46c3e84874bc02b6918f1f2c39)`),n.length>0?n:null):(n.push("ib required. (E: a76d06c7b9c24db3a731a91dbe46acd5)"),n)}catch(n){throw console.error(`${r} ${E(n)}`),n}}f(br,"validateIb");function dr({gib:o,gibDelimiter:t,ibGibAddrDelimiter:e,version:r}){let n=`[${dr.name}]`;try{let s=[];if(r&&console.warn(`${n} version not implemented yet. Ignoring. (E: 90ced1db69774702b92acb261bdaee23)`),!o)return s.push("gib required. (E: e217de4035b04086827199f4bace189c)"),s;e=e||le;let a=[e],i=[];a.forEach(p=>{o.includes(p)&&i.push(p)}),i.length>0&&s.push(`gib (${o}}) contains invalid characters: (${JSON.stringify(i.join(","))}) (E: 1e584258d9e049ba9ce7e516f3ab97f1)`);let{punctiliarHash:c,tjpGib:l,isPrimitive:d}=ue({gib:o,gibDelimiter:t||lt});if(d)return null;if(!c)throw new Error(`${n} punctiliarHash is falsy on a non-primitive gib. (E: 72835394918241bdb2632bf0510bdae5)`);let b=c.match(Sa),h=c.match(Ga);if(!b&&!h&&s.push("gib punctiliar hash is neither a 32- or 64-char hash string. (E: d47ff6d6e14b4c02a62107090c8dad39)"),l){let p=dr({gib:l});(p??[]).length>0&&s.push(`tjpGib has errors (E: d6b79228d4a64c0b967cdb0efcea4d0d). tjpGibValidationErrors: ${p.join(". ")}`)}return s.length>0?s:null}catch(s){throw console.error(`${n} ${E(s)}`),s}}f(dr,"validateGib");function On({rel8ns:o}){let t=`[${On.name}]`;try{vn&&console.log(`${t} starting... (I: 62b4722599798dd8ab95fcebf42c0e23)`);let e=[],r=Object.keys(o);for(let n=0;n<r.length;n++){let s=Object.keys(o)[n];typeof s!="string"&&e.push("non-string rel8nName found. all keys of rel8ns must be of type string. (E: 3b2e4582b638421681951f5475c85178)");let a=o[s]??[];for(let i=0;i<a.length;i++){let c=a[i],l=fr({addr:c})??[];l.length>0&&e.push(`invalid addr found for rel8nName (${s}). addr errors: ${l.join("|")} (E: 56809a746c4f462db426e90395b80364)`)}}return e.length>0?e:null}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{vn&&console.log(`${t} complete.`)}}f(On,"validateRel8nsIntrinsically");var Pa=!1,F=class o{static{f(this,"Factory_V1")}static root(){return o.primitive({ib:lr})}static primitive({ib:t}){return{ib:t,gib:M}}static primitives({ibs:t}){return t.map(e=>o.primitive({ib:e}))}static async firstGen({ib:t=lr,parentIbGib:e=o.root(),data:r,rel8ns:n,dna:s,tjp:a,linkedRel8ns:i,noTimestamp:c,nCounter:l,squash:d}){let b=`[${o.name}][${o.firstGen.name}]`;try{if(Pa&&console.log(`${b} starting... (I: b7152fbd94382516d9f7c591bcf4c326)`),s&&d)throw new Error("both dna and squash cannot be true. Squash requires that no dna exist. (E: abfc58b4a4c8654924aa5428d0831826)");let h=[],p=e||z,u=await eo({src:p,destIb:t,tjp:a,dna:s,linkedRel8ns:i,noTimestamp:c,nCounter:l});if(h.push(u),p=u.newIbGib,r){let g=await Fe({src:p,dataToAddOrPatch:r,dna:s,linkedRel8ns:i,noTimestamp:c,nCounter:l});h.push(g),p=g.newIbGib}if(n){let g=await Ce({src:p,rel8nsToAddByAddr:n,dna:s,linkedRel8ns:i,noTimestamp:c,nCounter:l});h.push(g)}if(h.length>1){let g=h.slice(h.length-1)[0].newIbGib,m={newIbGib:g,intermediateIbGibs:h.slice(0,h.length-1).map($=>$.newIbGib)};if(s){d&&`${b}`;let $=[];return h.forEach(T=>{$=$.concat(T.dnas)}),m.dnas=$,m}else if(d){if(!g.rel8ns)throw new Error("(UNEXPECTED) newIbGib.rel8ns is falsy? (E: 6b09e8057fc5b00c6cfd13be60e97f26)");return delete g.rel8ns.past,g.rel8ns.tjp&&(delete g.rel8ns.tjp,g.data??={},g.data.isTjp=!0),l&&(g.data??={},g.data.n=0),g.gib=await J({ibGib:g}),{newIbGib:g}}else return m}else{if(h.length===1)return h[0];throw new Error("(UNEXPECTED) interimResults.length is not 1 and not greater than 1? 0? But we had to fork? (E: a256c88c56916a46a888796f76ef4826)")}}catch(h){throw console.error(`${b} ${E(h)}`),h}finally{Pa&&console.log(`${b} complete.`)}}static async stone({parentPrimitiveIb:t,ib:e,ibRegExpPattern:r,data:n,rel8ns:s,noTimestamp:a,uuid:i}){let c=`[${o.name}][${o.stone.name}]`;try{if(!t)throw new Error("parentPrimitiveIb required. (E: genuuid)");if(br({ib:t})!==null)throw new Error(`Invalid parentPrimitiveIb: ${t}. (E: genuuid)`);if(!e)throw new Error("ib required. (E: genuuid)");let l=r?new RegExp(r):Da;if(!e.match(l))throw new Error(`invalid ib. does not match regexp (${l}) (E: genuuid)`);let d=Object.keys(s??{}),b=[...Vt,"tjp"];if(d.some(g=>b.includes(g)))throw new Error(`Invalid rel8ns. forbiddenRel8nNames: ${b}. rel8ns keys: ${Object.keys(s??{})}. (E: genuuid)`);let u=(await o.firstGen({ib:e,parentIbGib:o.primitive({ib:t}),data:n,rel8ns:s,dna:!1,noTimestamp:a,nCounter:!1})).newIbGib;return i&&(u.data||(u.data={}),u.data.uuid=await j()),u.rel8ns?.past&&delete u.rel8ns.past,u.rel8ns?.tjp&&delete u.rel8ns.tjp,u.gib=await J({ibGib:{ib:u.ib,data:u.data,rel8ns:u.rel8ns},hasTjp:!1}),u}catch(l){throw console.error(`${c} ${l.message}`),l}}static async constant({parentPrimitiveIb:t,ib:e,ibRegExpPattern:r,data:n,rel8ns:s}){let a=`[${o.name}][${o.constant.name}]`;try{return await o.stone({parentPrimitiveIb:t,ib:e,ibRegExpPattern:r,data:n,rel8ns:s,noTimestamp:!0,uuid:!1})}catch(i){throw console.error(`${a} ${i.message}`),i}}};var Nb="[core^gib timer]";var Dn=`.'",!?-`;var Ra=new RegExp("^[\\w\\t\\-|=+.&%$#@!~` \\[\\]\\(\\)\\{\\}]{1,155}$");var vb=/^[a-zA-Z0-9_\-.]{1,255}$/,Ob=/^[a-zA-Z0-9_\-.\s👀🤖:;&]{1,64}$/;var oo={tags:"tags",aliases:"aliases",roots:"roots",outerspaces:"outerspaces",secrets:"secrets",encryptions:"encryptions",autosyncs:"autosyncs",robbots:"robbots",apps:"apps",history:"history"};var dl="robbot";var Ua="zero",ka="zerospace";var Wb=!1,Vb="This is a local space. There are many like it, but this one is mine.";var zb=/^[a-zA-Z][\w\-]{0,62}[a-zA-Z]$/,fl="syncSpace";var Jb=3e4;var no="space";var Ma="space_lock",Fa=100,Ba=100,Zb=60*2,Ln=30;var Pn="root",Rn="x",ja="root",Un="analytics-outline",kn='This is a root ibgib, which is basically like a root folder that is primarily responsible for "containing" other ibgibs.';var Mn="tag",bl="target";var Xa="pricetag-outline",Ha="This is a tag used for organizing data.";var ah="always",qa="archive",Ka="trash";var Fn=/^\w{1,32}$/,so="Invalid Date";var Bn={ib:"true",gib:M};var Ya={ib:"false",gib:M};var Wa="config_key";var Gr=/^[a-zA-Z0-9_\-.]{1,32}$/,ao="app";var Jt=`bootstrap^${M}`,dt="defaultSpaceId",Va="spaceIds";var ft={prependPerHash:"prependPerHash",appendPerHash:"appendPerHash",initialPrepend:"initialPrepend",initialAppend:"initialAppend"},Lt=Object.values(ft),Be={sha_256:"SHA-256",sha_512:"SHA-512"},hh=Object.values(Be),hl={indexOf:"indexOf",lastIndexOf:"lastIndexOf"},yt=Object.values(hl);function Cr(o){let t=`[${Cr.name}]`;return new Promise((e,r)=>{try{let n=za(o),s=Ja(n);e(s)}catch(n){console.error(`${t} ${E(n)}`),r(n)}})}f(Cr,"encodeStringToHexString");function za(o){let t=`[${za.name}]`;try{return new TextEncoder().encode(o)}catch(e){throw console.error(`${t} ${E(e)}`),e}}f(za,"stringToUTF8Bytes");function Ja(o){let t=`[${Ja.name}]`;try{return Array.from(o,e=>e.toString(16).padStart(2,"0")).join("")}catch(e){throw console.error(`${t} ${E(e)}`),e}}f(Ja,"bytesToHexString");function $t(o){let t=`[${$t.name}]`;return new Promise((e,r)=>{try{let n=Za(o),s=Qa(n);e(s)}catch(n){console.error(`${t} ${E(n)}`),r(n)}})}f($t,"decodeHexStringToString");function Za(o){let t=`[${Za.name}]`;try{if(o.length%2!==0)throw new Error("invalid hex string. length %2 !== 0");let e=o.length/2,r=new Uint8Array(e);for(let n=0;n<e;n++)r[n]=parseInt(o.substr(n*2,2),16);return r}catch(e){throw console.error(`${t} ${E(e)}`),e}}f(Za,"hexStringToBytes");function Qa(o){let t=`[${Qa.name}]`;try{return new TextDecoder().decode(o)}catch(e){throw console.error(`${t} ${E(e)}`),e}}f(Qa,"utf8BytesToString");var It=ft.appendPerHash,_t="SHA-512",Tt=1024,bt=2e4,At=1,ei="indexOf",io="lastIndexOf",co=5e6,lo=4,Pt=",";function pl({secret:o,prevHash:t,salt:e,saltStrategy:r}){if(!(t||o))throw new Error("Either secret or prevHash is required, but both are falsy (E: bee2849729ff410081d963777dcedb49))");switch(r){case ft.prependPerHash:return e+(t||o);case ft.appendPerHash:return(t||o)+e;case ft.initialPrepend:return t||e+o;case ft.initialAppend:return t||o+e;default:throw new Error(`Unknown saltStrategy: ${r} (E: 235136af1a6c40eb9c17b2ca41c08a01)`)}}f(pl,"getPreHash");async function We({secret:o,prevHash:t,count:e,salt:r,saltStrategy:n,hashAlgorithm:s}){let a=`[${We.name}]`;try{let i=t||void 0;for(let c=0;c<e;c++){let l=pl({secret:o,prevHash:i,salt:r,saltStrategy:n});i=await ke({s:l,algorithm:s})}if(!i)throw new Error("hash was not created (E: 09dfdfd644734727a34a1bc0bd8e93b9)");return i}catch(i){throw console.error(`${a} ${E(i)}`),i}}f(We,"execRound_getNextHash");async function St({secret:o,initialRecursions:t,salt:e,saltStrategy:r,hashAlgorithm:n}){let s=`[${St.name}]`;try{return await We({secret:o,count:t,salt:e,saltStrategy:r,hashAlgorithm:n})}catch(a){throw console.error(`${s} ${E(a)}`),a}}f(St,"doInitialRecursions_keystretch");async function jn({hexEncodedData:o,initialRecursions:t,recursionsPerHash:e,salt:r,saltStrategy:n,secret:s,hashAlgorithm:a,encryptedDataDelimiter:i,indexingMode:c}){let l=`[${jn.name}]`;try{let d=await St({secret:s,initialRecursions:t,salt:r,saltStrategy:n,hashAlgorithm:a}),b=c==="indexOf"?(u,g)=>u.indexOf(g):(u,g)=>u.lastIndexOf(g),h=[];for(let u=0;u<o.length;u++){let g=o[u],m="",$;for(;!m.includes(g);)$=await We({count:e,prevHash:d,salt:r,saltStrategy:n,hashAlgorithm:a}),m+=$,d=$;let T=b(m,g);h.push(T)}return h.join(i)}catch(d){throw console.error(`${l} ${E(d)}`),d}}f(jn,"encryptFromHex_stream");async function Xn({encryptedData:o,initialRecursions:t,recursionsPerHash:e,salt:r,saltStrategy:n,secret:s,hashAlgorithm:a,encryptedDataDelimiter:i}){let c=`[${Xn.name}]`;try{let l=await St({secret:s,initialRecursions:t,salt:r,saltStrategy:n,hashAlgorithm:a}),d=o.split(i).map(p=>parseInt(p)),b=[];for(let p=0;p<d.length;p++){let u=d[p],g="",m;for(;u>=g.length;)m=await We({count:e,prevHash:l,salt:r,saltStrategy:n,hashAlgorithm:a}),g+=m,l=m;let $=g[u];b.push($)}return b.join("")}catch(l){throw console.error(`${c} ${E(l)}`),l}}f(Xn,"decryptToHex_stream");async function xr({encryptedData:o,initialRecursions:t,recursionsPerHash:e,salt:r,saltStrategy:n,secret:s,hashAlgorithm:a,encryptedDataDelimiter:i}){let c=`[${xr.name}]`,l=[],d=[];t=t||bt,e=e||At,n=n||It,a=a||_t,r=r||await j(Tt),i=i||Pt;let b="[validation]";if(!t||t<1){let u=`${b} initialRecursions required, and greater than 0`;console.error(u),l.push(u)}if(!e||e<1){let u=`${b} recursionsPerHash required, and greater than 0`;console.error(u),l.push(u)}if(!o){let u=`${b} encryptedData required`;console.error(u),l.push(u)}if(!r){let u=`${b} salt required`;console.error(u),l.push(u)}if(!n){let u=`${b} saltStrategy required`;console.error(u),l.push(u)}if(!s){let u=`${b} secret required`;console.error(u),l.push(u)}if(!i){let u=`${b} encryptedDataDelimiter required`;console.error(u),l.push(u)}if(!Object.values(Be).includes(a)){let u=`${b} only ${Object.values(Be)} hash algorithms implemented`;console.error(u),l.push(u)}if(n&&!Lt.includes(n)){let u=`${b} unknown saltStrategy: ${n}`;console.error(u),l.push(u)}if(l.length>0)return{errors:l,initialRecursions:t,recursionsPerHash:e,salt:r,saltStrategy:n,hashAlgorithm:a,encryptedDataDelimiter:i};let h=await Xn({encryptedData:o,initialRecursions:t,recursionsPerHash:e,salt:r,saltStrategy:n,secret:s,hashAlgorithm:a,encryptedDataDelimiter:i});return{decryptedData:await $t(h),initialRecursions:t,recursionsPerHash:e,salt:r,saltStrategy:n,hashAlgorithm:a,encryptedDataDelimiter:i,warnings:d.length>0?d:void 0}}f(xr,"decryptImpl_stream");async function Hn({dataToEncrypt:o,initialRecursions:t,recursionsPerHash:e,salt:r,saltStrategy:n,secret:s,hashAlgorithm:a,encryptedDataDelimiter:i,confirm:c,indexingMode:l}){let d=`[${Hn.name}]`,b=[],h=[];t||(console.warn(`${d} initial recursions required. defaulting to ${bt}`),t=bt),e=e||At,n=n||It,a=a||_t,r=r||await j(Tt),i=i||Pt,l=l||ei;let p="[validation]";if(!t||t<1){let m=`${p} initialRecursions required, and greater than 0`;console.error(m),b.push(m)}if(!e||e<1){let m=`${p} recursionsPerHash required, and greater than 0`;console.error(m),b.push(m)}if(!o){let m=`${p} dataToEncrypt required`;console.error(m),b.push(m)}if(!r){let m=`${p} salt required`;console.error(m),b.push(m)}if(!n){let m=`${p} saltStrategy required`;console.error(m),b.push(m)}if(!s){let m=`${p} secret required`;console.error(m),b.push(m)}if(!i){let m=`${p} encryptedDataDelimiter required`;console.error(m),b.push(m)}if(!yt.includes(l)){let m=`${p} invalid indexingMode (${l}). Must be one of ${yt} (E: 5955c46755434982982823c97adcf076)`;console.error(m),b.push(m)}if(!Object.values(Be).includes(a)){let m=`${p} only ${Object.values(Be)} hash algorithms implemented`;console.error(m),b.push(m)}if(n&&!Lt.includes(n)){let m=`${p} unknown saltStrategy: ${n}`;console.error(m),b.push(m)}if(b.length>0)return{errors:b,initialRecursions:t,recursionsPerHash:e,salt:r,saltStrategy:n,hashAlgorithm:a,encryptedDataDelimiter:i};let u=await Cr(o);if(c&&await $t(u)!==o)throw new Error("decoding encoded hex failed for this data: The encoded hex did not reverse to the original data.");let g=await jn({hexEncodedData:u,initialRecursions:t,recursionsPerHash:e,salt:r,saltStrategy:n,secret:s,hashAlgorithm:a,encryptedDataDelimiter:i,indexingMode:"indexOf"});if(c){let m=await xr({encryptedData:g,initialRecursions:t,recursionsPerHash:e,salt:r,saltStrategy:n,secret:s,hashAlgorithm:a,encryptedDataDelimiter:i});if((m.errors||[]).length>0)return{errors:["Confirm check found that decrypt had errors.",...m.errors],initialRecursions:t,recursionsPerHash:e,salt:r,saltStrategy:n,hashAlgorithm:a,encryptedDataDelimiter:i};if(m.decryptedData){if(m.decryptedData!==o)throw new Error("The ENCRYPTED data did not decrypt back to the original data.")}else throw new Error("Confirm check call to decrypt produced falsy decryptedData");(m.warnings||[]).length>0&&(h=h.concat(["Confirm check call to decrypt had warnings.",...m.warnings]))}return{encryptedData:g,initialRecursions:t,recursionsPerHash:e,salt:r,saltStrategy:n,hashAlgorithm:a,encryptedDataDelimiter:i,warnings:h.length>0?h:void 0}}f(Hn,"encryptImpl_stream");async function qn({hexEncodedData:o,initialRecursions:t,recursionsPerHash:e,salt:r,saltStrategy:n,secret:s,hashAlgorithm:a,encryptedDataDelimiter:i,indexingMode:c,maxBlockSize:l,numOfPasses:d}){let b=`[${qn.name}]`;try{let h=await St({secret:s,initialRecursions:t,salt:r,saltStrategy:n,hashAlgorithm:a}),p=c==="indexOf"?(A,_)=>A.indexOf(_):(A,_)=>A.lastIndexOf(_),u=[],g=o.length,m=l;m>g&&(m=g);let $=Math.ceil(g/m),T=g%m||m,I=0;for(let A=0;A<$;A++){A===$-1&&(m=T);let S=await ti({blockSize:m,indexHexEncodedDataAtStartOfPass:I,numOfPasses:d,hexEncodedData:o,recursionsPerHash:e,salt:r,saltStrategy:n,prevHash:h,hashAlgorithm:a}),N=S.alphabetsThisBlock;h=S.prevHash;let O=await ri({alphabetsThisBlock:N,blockSize:m,indexHexEncodedDataAtStartOfPass:I,hexEncodedData:o,getIndexOfCharInAlphabet:p});u=u.concat(O),I+=m}return u.join(i)}catch(h){throw console.error(`${b} ${E(h)}`),h}}f(qn,"encryptFromHex_blockMode");async function ti({blockSize:o,numOfPasses:t,indexHexEncodedDataAtStartOfPass:e,hexEncodedData:r,recursionsPerHash:n,salt:s,saltStrategy:a,prevHash:i,hashAlgorithm:c}){let l=`[${ti.name}]`;try{let d=[],b,h;for(let p=0;p<t;p++)for(let u=0;u<o;u++){b=e+u;let g=d[u]??"";h=await We({count:n,prevHash:i,salt:s,saltStrategy:a,hashAlgorithm:c}),g+=h,i=h,d[u]=g}for(let p=0;p<o;p++){b=e+p;let u=r[b],g=d[p];for(;!g.includes(u);)h=await We({count:n,prevHash:i,salt:s,saltStrategy:a,hashAlgorithm:c}),g+=h,i=h;d[p]=g}return{alphabetsThisBlock:d,prevHash:i}}catch(d){throw console.error(`${l} error: ${E(d)}`),d}}f(ti,"getAlphabetsThisBlock");async function ri({alphabetsThisBlock:o,blockSize:t,indexHexEncodedDataAtStartOfPass:e,hexEncodedData:r,getIndexOfCharInAlphabet:n}){let s=`[${ri.name}]`;try{let a=[];for(let i=0;i<t;i++){let c=e+i,l=o[i],d=n(l,r[c]);a.push(d)}return a}catch(a){throw console.error(`${s} ${E(a)}`),a}}f(ri,"getEncryptedIndexesThisBlock");async function Kn({encryptedData:o,initialRecursions:t,recursionsPerHash:e,salt:r,saltStrategy:n,secret:s,hashAlgorithm:a,encryptedDataDelimiter:i,maxBlockSize:c,numOfPasses:l}){let d=`[${Kn.name}]`;try{let b=await St({secret:s,initialRecursions:t,salt:r,saltStrategy:n,hashAlgorithm:a}),h=o.split(i).map(y=>parseInt(y)),p=[],u=h.length,g=c;g>u&&(g=u);let m=Math.ceil(u/g),$=u%g||g,T=0;for(let y=0;y<m;y++){y===m-1&&(g=$);let _=await oi({blockSize:g,indexEncryptedDataIndexesAtStartOfPass:T,numOfPasses:l,encryptedDataIndexes:h,recursionsPerHash:e,salt:r,saltStrategy:n,prevHash:b,hashAlgorithm:a}),S=_.alphabetsThisBlock;b=_.prevHash;let N=await ni({alphabetsThisBlock:S,blockSize:g,indexEncryptedDataIndexesAtStartOfPass:T,encryptedDataIndexes:h});p=p.concat(N),T+=g}return p.join("")}catch(b){throw console.error(`${d} ${E(b)}`),b}}f(Kn,"decryptToHex_blockMode");async function oi({blockSize:o,numOfPasses:t,indexEncryptedDataIndexesAtStartOfPass:e,encryptedDataIndexes:r,recursionsPerHash:n,salt:s,saltStrategy:a,prevHash:i,hashAlgorithm:c}){let l=`[${oi.name}]`;try{let d=[],b,h;for(let p=0;p<t;p++)for(let u=0;u<o;u++){b=e+u;let g=d[u]??"";h=await We({count:n,prevHash:i,salt:s,saltStrategy:a,hashAlgorithm:c}),g+=h,i=h,d[u]=g}for(let p=0;p<o;p++){b=e+p;let u=r[b],g=d[p];for(;g.at(u)===void 0;)h=await We({count:n,prevHash:i,salt:s,saltStrategy:a,hashAlgorithm:c}),g+=h,i=h;d[p]=g}return{alphabetsThisBlock:d,prevHash:i}}catch(d){throw console.error(`${l} error: ${E(d)}`),d}}f(oi,"getAlphabetsThisBlock");async function ni({alphabetsThisBlock:o,blockSize:t,indexEncryptedDataIndexesAtStartOfPass:e,encryptedDataIndexes:r}){let n=`[${ni.name}]`;try{let s=[];for(let a=0;a<t;a++){let i=e+a,c=r[i],d=o[a][c];s.push(d)}return s}catch(s){throw console.error(`${n} ${E(s)}`),s}}f(ni,"getDecryptedDataArrayThisBlock");async function Nr(o){let t=`[${Nr.name}]`,{encryptedData:e,initialRecursions:r,recursionsPerHash:n,salt:s,saltStrategy:a,secret:i,hashAlgorithm:c,encryptedDataDelimiter:l,indexingMode:d,blockMode:b,multipass:h}=o,p=[],u=[];if(b&&h)throw new Error("blockMode and multipass set. blockMode was a refactored name of multipass, so these should not both be present. multipass is deprecated. (E: b9b3cd1f701c700835c0419260278223)");if(!b&&h&&(console.warn(`${t}[WARNING] "multipass" option is deprecated. this has been refactored to "blockMode". This will use multipass as blockMode. (W: b77c9773e30549cbb389ce61f31eb6d3)`),b=h),!b)throw new Error("(UNEXPECTED) blockMode required. This should be truthy in order to get to this impl fn. (E: 306bce36afd64b7182ca2b46ac04a261)");r=r||bt,n=n||At,a=a||It,c=c||_t,s=s||await j(Tt),l=l||Pt,d=d||io;let{maxBlockSize:g,maxPassSectionLength:m,numOfPasses:$}=b;!g&&m&&(console.warn(`${t}[WARNING] "maxPassSectionLength" option is deprecated. this has been refactored to "maxBlockSize". This will use maxPassSectioLength as maxBlockSize. (W: e2c83d78a3464704a6067e0f767f20b0)`),g=m),g=g||co,$=$||lo;let T="[validation]";if(!r||r<1){let _=`${T} initialRecursions required, and greater than 0`;console.error(_),p.push(_)}if(!n||n<1){let _=`${T} recursionsPerHash required, and greater than 0`;console.error(_),p.push(_)}if(!e){let _=`${T} encryptedData required`;console.error(_),p.push(_)}if(!s){let _=`${T} salt required`;console.error(_),p.push(_)}if(!a){let _=`${T} saltStrategy required`;console.error(_),p.push(_)}if(!i){let _=`${T} secret required`;console.error(_),p.push(_)}if(!l){let _=`${T} encryptedDataDelimiter required`;console.error(_),p.push(_)}if(!d){let _=`${T} indexingMode required (E: a6fe15f8ba414e21b5355d23e808b976)`;console.error(_),p.push(_)}if(!yt.includes(d)){let _=`${T} invalid indexingMode (${d}). Must be one of ${yt} (E: 17435268651444e0b7a594135635fc58)`;console.error(_),p.push(_)}if(g<1){let _=`${T} maxBlockSize must be greater than 0 (E: 0870831aa86b4bfa939aeee9f252326a)`;console.error(_),p.push(_)}if($<1){let _=`${T} numOfPasses must be greater than 0 (E: 691d3c3765584c6f8c9aba1ee378df00)`;console.error(_),p.push(_)}if(!Object.values(Be).includes(c)){let _=`${T} only ${Object.values(Be)} hash algorithms implemented`;console.error(_),p.push(_)}if(a&&!Lt.includes(a)){let _=`${T} unknown saltStrategy: ${a}`;console.error(_),p.push(_)}if(p.length>0){let _={...o,errors:p};return delete _.encryptedData,delete _.secret,_}let I=await Kn({encryptedData:e,initialRecursions:r,recursionsPerHash:n,salt:s,saltStrategy:a,secret:i,hashAlgorithm:c,encryptedDataDelimiter:l,maxBlockSize:g,numOfPasses:$}),y=await $t(I),A={...o,decryptedData:y,warnings:u.length>0?u:void 0};return delete A.encryptedData,delete A.secret,A}f(Nr,"decryptImpl_blockMode");async function Yn(o){let t=`[${Yn.name}]`,{dataToEncrypt:e,initialRecursions:r,recursionsPerHash:n,salt:s,saltStrategy:a,secret:i,hashAlgorithm:c,encryptedDataDelimiter:l,confirm:d,indexingMode:b,blockMode:h,multipass:p}=o,u=[],g=[];if(h&&p)throw new Error("blockMode and multipass set. blockMode was a refactored name of multipass, so these should not both be present. multipass is deprecated. (E: bde5efd1a3e449dca549c5bff147f09b)");if(!h&&p&&(console.warn(`${t}[WARNING] "multipass" option is deprecated. this has been refactored to "blockMode". This will use multipass as blockMode. (W: 046b55a6d1304155b2e5352a9e6140b0)`),h=p),!h)throw new Error("(UNEXPECTED) blockMode required. This should be truthy in order to get to this impl fn. (E: 0b87871f81d849ef8f0263b7775bd3e3)");r||(console.warn(`${t} initial recursions required. defaulting to ${bt}`),r=bt),l=l||Pt,b=b||io;let{maxBlockSize:m,maxPassSectionLength:$,numOfPasses:T}=h;!m&&$&&(console.warn(`${t}[WARNING] "maxPassSectionLength" option is deprecated. this has been refactored to "maxBlockSize". This will use maxPassSectioLength as maxBlockSize. (W: c28fe476105643e184d0ddd5d2aa8a5d)`),m=$),m=m||co,T=T||lo;let I="[validation]";if(!r||r<1){let S=`${I} initialRecursions required, and greater than 0 (E: dd96a75f0c504f34b1f9f2f32e011c50)`;console.error(S),u.push(S)}if(!n||n<1){let S=`${I} recursionsPerHash required, and greater than 0 (E: 64cf53e0bf9f4963be6b165ca4e6566d)`;console.error(S),u.push(S)}if(!s){let S=`${I} salt required (E: 136a5d237e0f4b1d89f8c87ac12a1507)`;console.error(S),u.push(S)}if(!a){let S=`${I} saltStrategy required (E: 457ed117bf224b9f86fe81ab6bc35381)`;console.error(S),u.push(S)}if(!i){let S=`${I} secret required (E: 5c363255055a45cfb07656e2f4854ed7)`;console.error(S),u.push(S)}if(!l){let S=`${I} encryptedDataDelimiter required (E: 1bbeb4dce19e4ac2bbe7d1e373739298)`;console.error(S),u.push(S)}if(!b){let S=`${I} indexingMode required (E: 693ebd2be64a438aa3b075d0cb0d92bf)`;console.error(S),u.push(S)}if(!yt.includes(b)){let S=`${I} invalid indexingMode (${b}). Must be one of ${yt} (E: 17435268651444e0b7a594135635fc58)`;console.error(S),u.push(S)}if(m<1){let S=`${I} maxBlockSize must be greater than 0 (E: 9f268207ae274b958fb91855331be259)`;console.error(S),u.push(S)}if(T<1){let S=`${I} numOfPasses must be greater than 0 (E: c3bcab79bb024d65b84947806290a7d4)`;console.error(S),u.push(S)}if(!Object.values(Be).includes(c)){let S=`${I} only ${Object.values(Be)} hash algorithms implemented`;console.error(S),u.push(S)}if(a&&!Lt.includes(a)){let S=`${I} unknown saltStrategy: ${a}`;console.error(S),u.push(S)}if(u.length>0){let S={...o,errors:u};return delete S.dataToEncrypt,delete S.secret,S}let y=await Cr(e);if(d&&await $t(y)!==e)throw new Error("decoding encoded hex failed for this data: The encoded hex did not reverse to the original data.");let A=await qn({hexEncodedData:y,initialRecursions:r,recursionsPerHash:n,salt:s,saltStrategy:a,secret:i,hashAlgorithm:c,encryptedDataDelimiter:l,indexingMode:b,maxBlockSize:m,numOfPasses:T});if(d)try{let S=await Nr({encryptedData:A,initialRecursions:r,recursionsPerHash:n,salt:s,saltStrategy:a,secret:i,hashAlgorithm:c,encryptedDataDelimiter:l,indexingMode:b,blockMode:h});if(S.decryptedData){if(S.decryptedData!==e)throw new Error("The ENCRYPTED data did not decrypt back to the original data. (E: 16b5f1a11e4f438ab38a7f124178a7b8)")}else throw new Error("Confirm check call to decrypt produced falsy decryptedData (E: a4fe82dee61f497e9dea188ea9c287a4)");(S.warnings||[]).length>0&&(g=g.concat(["Confirm check call to decrypt had warnings.",...S.warnings]))}catch(S){throw new Error(`${t} confirm failed. decrypt error: ${E(S)} (E: 782a84d9dc294ce9a6a325e3ab293adf)`)}let _={...o,encryptedData:A,warnings:g.length>0?g:void 0};return delete _.dataToEncrypt,delete _.secret,_}f(Yn,"encryptImpl_blockMode");async function ul(o){let t=`[${ul.name}]`;try{if(!o)throw new Error("args required (E: 22e58e03c78f4c27bf18295b8d2cdd3a)");if(!o.dataToEncrypt)throw new Error("dataToEncrypt required (E: 168c9076e5434c83ba81e3485ee6f3e4)");o.salt=o.salt||await j(Tt),o.saltStrategy=o.saltStrategy||It,o.hashAlgorithm=o.hashAlgorithm||_t,o.recursionsPerHash=o.recursionsPerHash||At;let e;return o.blockMode?e=await Yn(o):e=await Hn(o),(e.errors??[]).length>0&&e.errors.forEach(r=>console.warn(`${t} ${r}`)),(e.warnings??[]).length>0&&e.warnings.forEach(r=>console.warn(`${t} ${r}`)),e}catch(e){throw console.error(`${t}${e.message}`),e}}f(ul,"encrypt");async function gl(o){let t=`[${gl.name}]`;try{if(!o)throw new Error("args required (E: fcd9b4aad85c4deba5fe5fde0b9ecb30)");if(!o.encryptedData)throw new Error("encryptedData required (E: f879f612428b4283bae089acee929a58)");o.salt=o.salt||await j(Tt),o.saltStrategy=o.saltStrategy||It,o.hashAlgorithm=o.hashAlgorithm||_t,o.recursionsPerHash=o.recursionsPerHash||At;let e;return o.blockMode||o.multipass?e=await Nr(o):e=await xr(o),(e.warnings??[]).length>0&&e.warnings.forEach(r=>console.warn(`${t} ${r}`)),(e.errors??[]).length>0&&e.errors.forEach(r=>console.warn(`${t} ${r}`)),e}catch(e){throw console.error(`${t}${e.message}`),e}}f(gl,"decrypt");var Tp=5e4;var Ap=ft.appendPerHash,Sp=10,Gp="SHA-256";var Cp="encryption",xp="ciphertext";var El={local:"local",outerspace:"outerspace",innerspace:"innerspace"},Dp=Object.values(El).concat(),ml={user:"user",sync:"sync"},Wn=Object.values(ml).concat(),wl={node_filesystem:"node-filesystem"},yl={aws_dynamodb:"aws-dynamodb"},$l={...wl,...yl},Vn=Object.values($l).concat(),Il={get:"get",put:"put",delete:"delete"},_l={can:"can",addrs:"addrs",latest:"latest",watch:"watch",unwatch:"unwatch",tjps:"tjps",dependencyGraph:"dependency-graph"};var Tl=!1,bo=class o{static{f(this,"DynamicFormBuilder")}lc=`[${o.name}]`;items=[];what="";idPool=[];getNewId(){let t=`${this.lc}[${this.getNewId.name}]`;if(this.idPool?.length>0)return this.idPool.pop()??"";{let e=[],r="ABCDEFGHIJKLMNOPQRSTUVWXYZ",n=r.length;for(let a=0;a<32;a++){let i=Math.floor(Math.random()*n);e.push(r[i])}let s=e.join("");return Tl&&console.log(`${t} id: ${s} (I: c6591ffee6d5bbea79ed19cfa6630422)`),s}}forA({what:t}){return this.what=t||"thingy",this}addItem(t){t.uuid||(t.uuid=this.getNewId()),this.items.push(t)}with({idPool:t}){return t&&(this.idPool=t),this}and(){return this}name({of:t,required:e=!0,defaultValue:r}){return this.addItem({name:"name",description:`What to call this ${this.what}. Doesn't have to be unique, no spaces, up to 32 alphanumerics/underscores in length.`,label:"Name",placeholder:'e.g. "bob_the_cool"',regexp:Zr({min:1,max:32,noSpaces:!0}),regexpErrorMsg:"1 to 32 characters, no spaces, underscores allowed.",required:e,dataType:"text",value:t,defaultValue:r}),this}description({of:t,required:e,defaultValue:r}){return this.addItem({name:"description",description:`Description/notes for this ${this.what}.`,label:"Description",placeholder:`Describe these ${this.what} settings here...`,regexp:Zr({min:0,max:155,chars:Dn}),regexpErrorMsg:`0 to 155 alphanumerics or any of ${Dn}`,dataType:"textarea",required:e,value:t,defaultValue:r}),this}classname({of:t,required:e=!0}){return this.addItem({name:"classname",description:`Technical setting that is the name of the ${this.what}'s class in computer code.`,label:"Classname",regexp:Zr({min:1,max:128,noSpaces:!0}),regexpErrorMsg:"1 to 128 alphanumerics or underscores without spaces",dataType:"text",value:t,readonly:!0,required:e}),this}uuid({of:t,label:e,required:r}){return this.addItem({name:"uuid",description:`Unique(ish) id of the ${this.what}.`,label:e??"ID",dataType:"text",value:t,regexp:ce,regexpErrorMsg:"1 to 256 alphanumerics, underscores, dots, hyphens allowed.",readonly:!0,required:r}),this}version({of:t,required:e}){return this.addItem({name:"version",description:`Technical setting indicating the version of the ${this.what}.`,label:"Version",dataType:"text",value:t||"",readonly:!0,required:e}),this}customItem(t){return this.addItem(t),this}outputItems(){return this.items}outputForm({formName:t,label:e}){return{name:t,description:`This is a form for a ${this.what}`,label:e??this.what,items:this.items}}};var Rt=class o extends bo{static{f(this,"WitnessFormBuilder")}lc=`[${o.name}]`;allowPrimitiveArgs({of:t,required:e=!0}){return this.addItem({name:"allowPrimitiveArgs",description:`Technical setting on if this ${this.what} accepts primitive incoming ibgibs`,label:"Allow Primitive Args",dataType:"toggle",value:t??!0,readonly:!0,required:e}),this}catchAllErrors({of:t,required:e=!0}){return this.addItem({name:"catchAllErrors",description:`Technical setting on what the ${this.what} does when it encounters an internal error.`,label:"Catch All Errors",dataType:"toggle",value:t??!0,readonly:!0,required:e}),this}persistOptsAndResultIbGibs({of:t,required:e=!0}){return this.addItem({name:"persistOptsAndResultIbGibs",description:`Technical setting on if the ${this.what} maintains an audit trail of all of its inputs/outputs.`,label:"Persist Opts and Result IbGibs",dataType:"toggle",value:t??!1,readonly:!0,required:e}),this}trace({of:t,required:e}){return this.addItem({name:"trace",description:`Technical setting on if the ${this.what}'s activity should be traced (logged to the console).`,label:"Trace",dataType:"toggle",value:t??!1,readonly:!0,required:e}),this}commonWitnessFields({data:t,allowPrimitiveArgs:e=!0,catchAllErrors:r=!0,persistOptsAndResultIbGibs:n=!0,trace:s=!0,version:a=!0}){return e&&this.allowPrimitiveArgs({of:t.allowPrimitiveArgs}),r&&this.catchAllErrors({of:t.catchAllErrors}),n&&this.persistOptsAndResultIbGibs({of:t.persistOptsAndResultIbGibs}),s&&this.trace({of:t.trace}),a&&this.version({of:t.version}),this}};var ho=!1;function si({appData:o}){let t=`[${si.name}]`;try{if(ho&&console.log(`${t} starting...`),!o)throw new Error("appData required (E: 3df782b29bc4406a87e4895cfcea28ed)");let e=[],{name:r,uuid:n,classname:s}=o;return r?r.match(Gr)||e.push(`name must match regexp: ${Gr}`):e.push("name required."),n?n.match(ce)||e.push(`uuid must match regexp: ${ce}`):e.push("uuid required."),s&&(s.match(Gr)||e.push(`classname must match regexp: ${Gr}`)),e}catch(e){throw console.error(`${t} ${e.message}`),e}finally{ho&&console.log(`${t} complete.`)}}f(si,"validateCommonAppData");function zn({appData:o,classname:t}){let e=`[${zn.name}]`;try{let r=si({appData:o});if(r.length>0)throw new Error(`invalid appData: ${r} (E: 9aff04f0cfc54a5188ca8bc40764160d)`);if(t){if(o.classname&&o.classname!==t)throw new Error("classname does not match appData.classname (E: 66f1447eef97485fba521c40980f5eb5)")}else if(t=o.classname,!t)throw new Error("classname required (E: 5f6ffb4317044125b94f662070e1f40b)");let{name:n,uuid:s}=o;return`app ${t} ${n} ${s}`}catch(r){throw console.error(`${e} ${r.message}`),r}}f(zn,"getAppIb");function Al({appIb:o}){let t=`[${Al.name}]`;try{if(!o)throw new Error("appIb required (E: 6b065aee67e641ba9f9c6db367ebb0fb)");let e=o.split(" ");return{appClassname:e[1],appName:e[2],appId:e[3]}}catch(e){throw console.error(`${t} ${e.message}`),e}}f(Al,"getInfoFromAppIb");async function Sl({fnPromptApp:o,ibgibs:t,space:e}){let r=`[${Sl.name}]`;try{if(ho&&console.log(`${r} starting...`),!t)throw new Error("ibgibs all powerful service required. (E: b24e78de0d204dc78909022bee296b30)");e=e??await t.getLocalUserSpace({lock:!0});let n=await o(e,null);if(!n)throw new Error("resApp falsy after prompt for app. (E: 2225a567abcd680a5e957e81fbb64123)");let s=n.newIbGib,a=[];a.push(s),n.intermediateIbGibs?.forEach(d=>a.push(d)),n.dnas?.forEach(d=>a.push(d));for(let d=0;d<a.length;d++){let b=a[d],h=await Z({ibGib:b});if((h??[]).length>0)throw new Error(`(UNEXPECTED) invalid app ibgib created. validationErrors: ${h}. app: ${P(s.toIbGibDto())} (E: 54cfc2f6bc284ed79be91d2da5e4bd2f)`)}await se({resTransform:n,space:e});let{zeroSpace:i,fnBroadcast:c,fnUpdateBootstrap:l}=t;return await de({ibGib:s,space:e,fnBroadcast:f(d=>c(d),"fnBroadcast")}),await hr({type:"apps",rel8nName:ao,ibGibsToRel8:[s],space:e,zeroSpace:i,fnUpdateBootstrap:l,fnBroadcast:c}),s}catch(n){debugger;console.error(`${r} ${n.message}`);return}finally{ho&&console.log(`${r} complete.`)}}f(Sl,"createNewApp");var Gl="0",Cl="chat_gib",xl="A chat app done ibgib style, enabling infinitely nesting comments, pics and links. It's ibgibs all the way down...",ai={version:"1",uuid:Gl,name:Cl,description:xl,classname:"ChatApp_V1",icon:"chatbubbles",persistOptsAndResultIbGibs:!1,allowPrimitiveArgs:!0,catchAllErrors:!0,trace:!1},ii=void 0;var Nl="0",vl="raw_gib",Ol="Explorer app for navigating raw ibgib data.",ci={version:"1",uuid:Nl,name:vl,description:Ol,classname:"RawApp_V1",icon:"paper-plane",persistOptsAndResultIbGibs:!1,allowPrimitiveArgs:!0,catchAllErrors:!0,trace:!1},li=void 0;var Jn="0",Dl="todo_gib",Ll="Todo app for viewing and interacting with ibgibs like they're checklists.",di={version:"1",uuid:Jn,name:Dl,description:Ll,classname:"TodoApp_V1",icon:"checkbox",persistOptsAndResultIbGibs:!1,allowPrimitiveArgs:!0,catchAllErrors:!0,trace:!1},fi=void 0;async function Zn(o){let t=`[${Zn.name}]`,e=[];try{w({ibGib:o})!==Jt&&e.push(`invalid bootstrapSpace addr. Should equal "${Jt}" (E: ecfdbed719284db7a1aa3f867f706fe9)`);let n=await Z({ibGib:o});(n?.length??!1)&&n.forEach(i=>e.push(i));let s=o.data,a=o.rel8ns;return Object.keys(s||{}).length===0&&e.push("invalid bootstrapSpace data. data required (E: 5a9bd15dd0644f9b93cafbbba660cfdf)"),(s.spaceIds??[]).length===0&&e.push("invalid bootstrapSpace, data.spaceIds required. (E: 6b91ddc12cfd41e59ded7d7502c1909f)"),Object.keys(o.rel8ns||{}).length===0&&e.push("invalid bootstrapSpace rel8ns (empty). Should have at least one rel8n, with rel8nName corresponding to the spaceId (E: b188ce4ae25e49f794f35e141bc2ecde)"),s.spaceIds.forEach(i=>{(a[i]??[]).length===0&&e.push(`invalid bootstrap. Each spaceId listed in data should have a corresponding address in rel8ns. spaceId (${i}) missing. (E: 62dd0d76e29a415a98b4b27deb8db17e)`)}),s[dt]?(a[s[dt]]??[]).length===0&&e.push(`invalid bootstrap. data.${dt} (${s[dt]}) not found in rel8ns. (E: 44d0799d232f4a51a0b0019ebebe019f)`):e.push(`invalid bootstrap. data.${dt} required. (E: f763af2e275f445cbf1db5801bacafad)`),e.length===0?!0:(console.error(`${t} errors: ${e.join("|")}`),!1)}catch(r){return console.error(`${t} ${r.message}`),!1}}f(Zn,"validateBootstrapIbGib");var pr="meta_stone";var Qn="undefined",vr="target",po="targetTjp";var Ve=!1;function hi({ib:o}){let t=`[${hi.name}]`;try{Ve&&console.log(`${t} starting...`);let e=[],r=o.split(" ");r[0]!==pr&&e.push(`${t} invalid ib. atom is expected to be META_STONE_ATOM: ${pr} (E: a9812bffc18f44418aa091fb0ed260bd)`);let s=r[1],a=dr({gib:s})??[];a.length>0&&e.push(`invalid ib. pieces[1] should be a valid tjpGib. validation errors: ${a} (E: 233db2babfbe4d28a80f98261f1c0e01)`);let i=r[2],c=Number.parseInt(i);isNaN(c)&&e.push("invalid ib. space-delimited pieces[2] should be valid integer (E: 71df0d6abd7b4cf4b11621e6bfb556cd)");let l=r[3];if(l!=="undefined"){let d=Ut({timestamp:l});d.valid||e.push(`invalid ib. pieces[3] should be valid timestampInTicks. emsg: (${d.emsg}) (E: 06dae01d66f54f54b71d9c920c730840)`)}return e}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{Ve&&console.log(`${t} complete.`)}}f(hi,"validateCommonMetaStoneIb");function es({data:o}){let t=`[${es.name}]`;try{if(Ve&&console.log(`${t} starting...`),!o)throw new Error("data required (E: c50ac422af4501b72af12481fbd4961e)");let e=[],{targetData:r,timestamp:n}=o;Ut({timestamp:n}).valid||e.push("invalid timestampInTicks. should be valid ticks number. (E: 7e381ed5b0c8486b90cfd37676da3626)");let{tjpGib:a,n:i,timestamp:c}=r;if(a&&a!=="undefined"){let d=dr({gib:a})??[];d.length>0&&e.push(`invalid data (targetTjpGib). validation errors: ${d} (E: d216b12eb75544ef8c5ffb27cd132e2e)`)}if(typeof i!="number"&&e.push("invalid n. should be valid integer. if target.data.n is falsy, targetN should be -1 (E: 8f234967b388ad80776c8054d71fbc23)"),c&&c!=="undefined"){let d=Ut({timestamp:c});d.valid||e.push(`invalid targetTimestamp. emsg: ${d.emsg} (E: c15d4fd2a2b74a0fab3223e83d954379)`)}let l=new Date(n);return e}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{Ve&&console.log(`${t} complete.`)}}f(es,"validateCommonMetaStoneData");function pi({rel8ns:o}){let t=`[${pi.name}]`;try{if(Ve&&console.log(`${t} starting...`),!o)throw new Error("rel8ns required (E: 7737ae550e2347e68c67b715c1221393)");let e=[],r=On({rel8ns:o??{}})??[];r.length>0&&e.push(`invalid rel8ns intrinsically. errors: ${r.join("|")}. (E: abc91753f0f946afa0a3ea2c1917960f)`);let n=o[vr]??[];n.length===0?e.push(`invalid metastone rel8ns. should have exactly 1 rel8nName ${vr}. has 0. (E: 8181652da9e89613e204d245db12d723)`):n.length>1&&e.push(`invalid metastone rel8ns. should have exactly 1 rel8nName ${vr}. has ${n.length}. (E: 2318047c6fea482d9f53febe02cf8912)`);let s=o[po]??[];return s.length>1&&e.push(`invalid metastone rel8ns. should have 0 or 1 rel8nName ${po}. has ${s.length}. (E: 34a8ae53825f46caa7ad024a64400db2)`),e}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{Ve&&console.log(`${t} complete.`)}}f(pi,"validateCommonMetaStoneRel8ns");async function Pl({ibGib:o}){let t=`[${Pl.name}]`;try{Ve&&console.log(`${t} starting... (I: f32249d08105b997871a06cdee006311)`);let e=await Z({ibGib:o})??[];if(!o.data)throw new Error("MetaStoneIbGib.data required (E: 96432cf4f919d339277d9a1c61ea4264)");let r=[];try{let{atom:i,tjpGib:c,n:l,timestampInTicks:d}=gi({ib:o.ib})}catch(i){r.push(E(i))}let n=es({data:o.data}),s=pi({rel8ns:o.rel8ns}),a=[...e??[],...r??[],...n??[],...s??[]];return a.length>0?a:void 0}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{Ve&&console.log(`${t} complete.`)}}f(Pl,"validateCommonMetaStoneIbGib");function ui({data:o,classname:t}){let e=`[${ui.name}]`;try{let r=es({data:o});if(r.length>0)throw new Error(`invalid MetaStone data: ${r} (E: ac642cc5915f0fc0508cb2fb728c86fa)`);t&&Ve&&console.log(`${e} classname not required. no big deal that it is provided here. (I: db4d41471cb976795afd3fa89f8cb823)`);let n=o.targetData.timestamp,s=n&&n!=="undefined"?Me(n):Qn;return`${pr} ${o.targetData.tjpGib} ${o.targetData.n} ${s}`}catch(r){throw console.error(`${e} ${E(r)}`),r}}f(ui,"getMetaStoneIb");function gi({ib:o}){let t=`[${gi.name}]`;try{if(!o)throw new Error("MetaStone ib required (E: 8e74e098d7aeef52d3952e35150d83ed)");let e=hi({ib:o});if(e.length>0)throw new Error(`invalid ib. validationErrors: ${e} (E: a6107f62200eb943e523f70f51300623)`);let r=o.split(" ");return{atom:r[0],tjpGib:r[1],n:Number.parseInt(r[2]),timestampInTicks:r[3]}}catch(e){throw console.error(`${t} ${E(e)}`),e}}f(gi,"parseMetaStoneIb");function gu({addr:o,ibGib:t}){if(o||=w({ibGib:t}),!o)throw new Error("either addr or ibGib required. (E: 372b2574d5a9fac298119beed9f6e223)");return o.startsWith(`${pr} `)}f(gu,"isMetaStone");async function ts({targetIbGib:o}){let t=`[${ts.name}]`;try{Ve&&console.log(`${t} starting... (I: d846313065c89c89e4b5afa2df2b7123)`);let e=w({ibGib:o}),r=Ie({ibGib:o,defaultIfNone:"incomingAddr"}),n,s={[vr]:[e],[po]:[r]};if(!o.gib)throw new Error("(UNEXPECTED) targetIbGib.gib falsy? (E: 28eaa8a799021dadd87b043711aee826)");let a=o.data?.isTjp?o.gib:ue({ibGibAddr:e}).tjpGib??o.gib;if(a===M)throw new Error("cannot create metastone for primitive ibgib (E: 2887e8ef83381a0698256b7bc7531826)");let i=new Date,c=Ge(i),l=i.getMilliseconds();o.data?Or({ibGib:o})?n={targetData:{n:-1,tjpGib:a},timestamp:c,timestampMs:l}:(n={targetData:{n:o.data.n??-1,tjpGib:a,timestamp:o.data.timestamp??Qn},timestamp:c,timestampMs:l},o.data?.isTjp&&(n.targetData.isTjp=!0)):n={targetData:{n:-1,tjpGib:a},timestamp:c,timestampMs:l};let d=ui({data:n}),b=await et({parentPrimitiveIb:pr,ib:d,data:n,rel8ns:s});return Ve&&(console.log(`${t} metaStoneIbGib... (I: 2b16197478488b329246d22d2dc41423)`),console.dir(b)),b}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{Ve&&console.log(`${t} complete.`)}}f(ts,"newUpMetaStone");var uo="witness",Dr="witness_arg",go="witness_result",wu="context";var C=!1;async function B({addr:o,addrs:t,isDna:e,space:r,force:n}){let s=`[${B.name}]`;try{if(C&&console.log(`${s} starting...`),!r)throw new Error("space required. (E: 4d188d6c863246f28aa575753a052304)");if(!o&&(t??[]).length===0)throw new Error("addr or addrs required. (E: 1a0b92564ba942f1ba91a089ac1a2125)");o&&(t?.length??0)>0&&(console.warn(`${s} both addr and addrs provided, but supposed to be used one or the other. (W: 87226c2ac50e4ea28211334a7b58782f)`),t.includes(o)||t.push(o)),t=(t??[]).length>0?t:[o];let a=await r.argy({ibMetadata:Gt({space:r}),argData:{cmd:"get",ibGibAddrs:t,isDna:e}}),i=await r.witness(a);return i?.data?.success?(C&&console.log(`${s} got.`),{success:!0,ibGibs:i.ibGibs,rawResultIbGib:i}):(C&&console.log(`${s} didn't get.`),{success:!1,errorMsg:i.data?.errors?.join("|")||`${s} something went wrong. addrs: ${t.join(`
|
|
2
|
+
`)} (E: b9e9d5ce0cde4122bfb74f7688db85e0)`,rawResultIbGib:i})}catch(a){return console.error(`${s} ${a.message}`),{errorMsg:a.message}}}f(B,"getFromSpace");async function xe({ibGib:o,ibGibs:t,isDna:e,force:r,space:n}){let s=`[${xe.name}]`;try{if(!o&&(t??[]).length===0)throw new Error("ibGib or ibGibs required. (E: e59c4de3695f4dd28c8fe82dbb9c4e90)");if(!n)throw new Error("space required. (E: dd0b7189c67c43c586b905a8ed6f51c9)");o&&(t??[]).length>0&&(console.warn(`${s} Both ibGib and ibGibs is assigned, whereas this is intended to be exclusive one or the other. (W: 4c797835b620445f88e4cba6b5aa3460)`),t.some(c=>c.gib===o.gib)||(t=t.concat([o]))),t=t??[o],C&&console.log(`${s} ibGibs.length: ${t.length}`);let a=await n.argy({ibMetadata:Gt({space:n}),argData:{cmd:"put",force:r,isDna:e,ibGibAddrs:t.map(c=>w({ibGib:c}))},ibGibs:t.concat()}),i=await n.witness(a);if(i.data?.success)return(i.data.warnings??[]).length>0&&i.data.warnings.forEach(c=>console.warn(`${s} ${c}`)),{success:!0};{let c=i?.data?.errors?.length>0?`Error(s) putting in local space:
|
|
3
|
+
${i.data.errors.join(`
|
|
4
|
+
`)}`:"(UNEXPECTED) unknown error putting ibGibs (E: 3d7426d4527243b79c5e55eb25f3fa73)";throw new Error(c)}}catch(a){return console.error(`${s} ${a.message}`),{errorMsg:a.message}}}f(xe,"putInSpace");async function os({addr:o,isDna:t,space:e}){let r=`[${os.name}]`;try{if(!e)throw new Error("space required. (E: 40ab3b51e91c4b5eb4f215baeefbcef0)");if(!e.data)throw new Error("space.data required. (E: 0d02c8e85ee143b8bd6a1a1db0d9af1b)");r=`${r}[${e.data.name||"noname?"}][${e.data.uuid||"nouuid?"}]`;let n=await e.argy({ibMetadata:Gt({space:e}),argData:{cmd:"delete",ibGibAddrs:[o],isDna:t}}),s=await e.witness(n);if(s.data?.success)return{success:!0};{s.data?.warnings?.length>0&&console.warn(`${r} warnings with delete (${o}): ${s.data.warnings.join("|")}`),s.data?.addrs?.length>0&&console.warn(`${r} partial addrs deleted: ${s.data.addrs.join("|")}`);let a=s.data?.errors?.join("|")||`${r} something went wrong (E: e397fd09b4a746a3ba3305d6ea0893cb)`;return a.includes("File does not exist")&&C&&console.log(`${r} tried to delete file that does not exist. (I: cb5d1348ccbc58bf0bfc95f3006f1e22)`),{errorMsg:a}}}catch(n){return console.error(`${r} ${n.message}`),{errorMsg:n.message}}}f(os,"deleteFromSpace");async function se({resTransform:o,space:t,force:e}){let r=`[${se.name}]`;try{if(C&&console.log(`${r} starting... (I: dc6835614ff1a1b82b179225023ae823)`),!t)throw new Error("space required. (E: cf94f1d74f1c4561bb88025a2095965b)");let{newIbGib:n,intermediateIbGibs:s,dnas:a}=o,i=[n,...s||[]],c=await t.argy({ibMetadata:Gt({space:t}),argData:{cmd:"put",force:e,ibGibAddrs:i.map(d=>w({ibGib:d}))},ibGibs:i.concat()}),l=await t.witness(c);if(l.data?.success)l.data.warnings?.length>0&&l.data.warnings.forEach(d=>console.warn(`${r} ${d}`));else{let d=l?.data?.errors?.length>0?l.data.errors.join(`
|
|
5
|
+
`):"unknown error putting ibGibs";throw new Error(d)}if(a?.length??!1){let d=await t.argy({ibMetadata:Gt({space:t}),argData:{cmd:"put",isDna:!0,force:e,ibGibAddrs:a.map(h=>w({ibGib:h}))},ibGibs:a.concat()}),b=await t.witness(d);if(b.data?.success)b.data.warnings?.length>0&&b.data.warnings.forEach(h=>console.warn(`${r} ${h}`));else{let h=b?.data?.errors?.length>0?b.data.errors.join(`
|
|
6
|
+
`):"unknown error putting dna ibGibs";throw new Error(h)}}}catch(n){throw console.error(`${r} ${n.message}`),n}finally{C&&console.log(`${r} complete. (I: dc6835614ff1a1b82b179225023ae823)`)}}f(se,"persistTransformResult");async function Rl({type:o,rel8nName:t,space:e}){let r=`[${Rl.name}]`;try{if(!e)throw new Error("space required. (E: f73868a952ac4181a4f90ee6d86cacf3)");let n=await wo({type:o,space:e});if(!n)throw new Error(`couldn't get special (${o}) (E: a65bef190416479697605be486846731)`);let s=n.rel8ns?n.rel8ns[t]||[]:[],a=[];for(let i=0;i<s.length;i++){let c=s[i],l=await B({addr:c,space:e});if(l.success&&l.ibGibs?.length===1)a.push(l.ibGibs[0]);else throw new Error(`couldn't get addr: ${c} (E: 76ef256ee80149ab860c5786484b0e89)`)}return a}catch(n){throw console.error(`${r} ${n.message}`),n}}f(Rl,"getSpecialRel8dIbGibs");async function wo({type:o,initialize:t,space:e,zeroSpace:r,fnUpdateBootstrap:n,fnBroadcast:s,fnGetInitializing:a,fnSetInitializing:i,dontWarnIfNotExist:c}){let l=`[${wo.name}]`;try{if(!e)throw new Error("space required. (E: d454b31d58764a9bb9c4e47fb5ef38b5)");let d=fe({type:o}),b=await yo({key:d,space:e,dontWarn:c||!!t});if(!b){if(t&&(!a||!i))throw new Error("if initialize, you must provide fnGetInitializeLock & fnSetInitializeLock. (E: 8eb322625d0c4538be089800882487de)");if(t&&!a()){i(!0);try{if(!r)throw new Error("zeroSpace required when 'initialize' truthy (E: 8582c92c637f90c9b2dbe0ec8355b523)");b=await wi({type:o,space:e,zeroSpace:r,fnBroadcast:s,fnUpdateBootstrap:n})??void 0}catch(g){console.error(`${l} error initializing: ${g.message}`)}finally{i(!1)}}if(!b){if(a&&a())return console.warn(`${l} couldn't get addr, but we're still initializing...`),null;throw new Error("Special address not in config and couldn't initialize it either. (E: d8ebdc9eaaa640b99cd206f132962c93)")}}C&&console.log(`${l} getting addr: ${b}`);let h=await B({addr:b,space:e});if(h.success||(h=await B({addr:b,space:e}),h.success&&(console.warn(`${l} special ibgib was not stored in meta folder...putting in meta folder now for the future (W: e6f5571fd98c449bb2809359be5057cc)`),(await xe({ibGib:h.ibGibs[0],space:e})).success||console.warn(`${l} (UNEXPECTED) tried to put special in meta but success was false? (W: b934b53571c24057af172c790e6a7240)`))),!h.success)throw new Error(h.errorMsg);if(h.ibGibs?.length!==1)throw new Error("no ibGib in result (E: 3a42abdddc3648e292d63dc45c560064)");let p=h.ibGibs[0],u=await je({ibGibs:[p],space:e});if(u?.data?.success&&u.data.addrs?.length===1){let g=w({ibGib:p}),m=u.data.addrs[0];m!==g&&console.warn(`${l} latest addr is not the one associated with the local space.
|
|
7
|
+
specialAddr: ${g}
|
|
8
|
+
latestAddr: ${m} (W: 141b69dc3c414efc9645bb76fcf12df9)`)}return p}catch(d){let b=`${l} ${d.message}`;return b.includes("d8ebdc9eaaa640b99cd206f132962c93")&&c||console.error(b),null}}f(wo,"getSpecialIbGib");async function yo({key:o,space:t,dontWarn:e}){let r=`[${yo.name}](${o})`;try{if(C&&console.log(`${r} getting... (I: 43e7bfc2515d45e5af8767b9a85b248e)`),!t)throw new Error("space required. (E: 4f135d4276e64054ba21aeb9c304ecec)");if(!t.rel8ns){(C||!e)&&console.warn(`${r} space.rel8ns falsy. (W: 7c642259fbf547dbaa1b2fdf0115f6ef)`);return}if(!t.rel8ns[o]){(C||!e)&&console.warn(`${r} space.rel8ns[${o}] falsy. (W: 3c1c49b9987b45cc96dd78b808f98e91)`);return}if(t.rel8ns[o].length===1)return C&&console.log(`${r} got (I: f13e71b693d5404c9535bda8ff0cc6a9)`),t.rel8ns[o][0];if(t.rel8ns[o].length>1)return(C||!e)&&console.warn(`${r} more than one config addr with ${o} rel8n. (W: 102f63eb74904bcfaac2eaf778043205)`),t.rel8ns[o][0];C&&console.log(`${r} didn't find (I: 1163e6ac60194d25b3f24881650edfad)`);return}catch(n){console.error(`${r} ${n.message}`);return}}f(yo,"getConfigAddr");async function _e({key:o,addr:t,space:e,zeroSpace:r,fnUpdateBootstrap:n}){let s=`[${_e.name}]`;try{if(!e)throw new Error("space required. (E: c28b663c991d44419aef1026cc689636)");if(!r)throw new Error("zeroSpace required. (E: d3707ae5265d464891ad216f64be6184)");let a={[o]:[t]},i=await Ce({src:e.toIbGibDto(),dna:!1,linkedRel8ns:["past","ancestor",o],rel8nsToAddByAddr:a,nCounter:!0});if(!i.newIbGib)throw new Error("create new space failed.");await se({resTransform:i,space:r}),await se({resTransform:i,space:e});let c=i.newIbGib;return await e.loadIbGibDto(c),n?await n(c):console.warn(`${s} fnUpdateBootstrap is falsy. (W: 9fb874de2b19454dac18645e61ac463f)`),c}catch(a){throw console.error(`${s} ${a.message}`),a}}f(_e,"setConfigAddr");async function Ei({space:o}){let t=`[${Ei.name}]`;try{if(!o)throw new Error("space required. (E: f0d546101fba4c169256158114ab3c56)");let e=await wo({type:"roots",space:o});if(!e)throw new Error("Roots not initialized. (E: 89b1ba12ed12416aac41cef9fdaf1fc2)");if(!e.rel8ns)throw new Error("Roots not initialized properly. No rel8ns. (E: 8513a07cf530484db9521a2a3a27b7f6)");if(!e.rel8ns.current)throw new Error("Roots not initialized properly. No current root. (E: 459c3a007a30486d96fb8d83f696e239)");if(e.rel8ns.current.length===0)throw new Error("Invalid Roots: empty current root rel8n. (E: bede5864090440bca01ea7ab7fd107d6)");if(e.rel8ns.current.length>1)throw new Error("Invalid Roots: multiple current roots selected. (E: 97561acbf63a48ecaa037697bd26555a)");let r=e.rel8ns.current[0],n=await B({addr:r,space:o});if(n.ibGibs?.length===1)return n.ibGibs[0];throw new Error(`could not get current root. addr: ${r}`)}catch(e){console.error(`${t} ${e.message}`);return}}f(Ei,"getCurrentRoot");async function ns({root:o,space:t,zeroSpace:e,fnUpdateBootstrap:r,fnBroadcast:n}){let s=`[${ns.name}]`;try{if(C&&console.log(`${s} starting... (I: 7f16e845a80fe95d28923e4170f0c825)`),!o)throw new Error("root required.");if(!t)throw new Error("space required. (E: 186af2731c5342a78b063a0a4346f3db)");let a=w({ibGib:o}),i=await wo({type:"roots",space:t});if(!i)throw new Error("Roots not initialized. (E: a8232b9afac89d0d189534480b7a9825)");let l=await Ce({src:i,dna:!1,linkedRel8ns:["past","ancestor","current"],rel8nsToAddByAddr:{current:[a]},nCounter:!0});await se({resTransform:l,space:t});let d=fe({type:"roots"}),b=l.newIbGib,h=w({ibGib:b});await _e({key:d,addr:h,space:t,zeroSpace:e,fnUpdateBootstrap:r}),await de({ibGib:b,space:t,fnBroadcast:n})}catch(a){throw console.error(`${s} ${a.message}`),a}finally{C&&console.log(`${s} complete. (I: 7f16e845a80fe95d28923e4170f0c825)`)}}f(ns,"setCurrentRoot");async function mi({ibGib:o,linked:t,rel8nName:e,space:r,fnBroadcast:n,zeroSpace:s,fnUpdateBootstrap:a}){let i=`[${mi.name}]`;try{if(!r)throw new Error("space required. (E: f2758eab3bb844d2b749515672d9e392)");if(!o)throw new Error("ibGib required (E: f1bfd67754a7271553f4af544d30bc22)");let c=await Ei({space:r});if(!c)throw new Error("currentRoot undefined (E: 5c2d84dafc664808866008f6eb535750");let l=Ie({ibGib:o,defaultIfNone:"incomingAddr"}),d=w({ibGib:o});if(e&&l&&c.rel8ns&&c.rel8ns[e]&&c.rel8ns[e].includes(l))return;e=e||Rn;let b=await Ce({src:c,dna:!1,linkedRel8ns:t?["past","ancestor",e]:["past","ancestor"],rel8nsToAddByAddr:{[e]:[d]},nCounter:!0});await se({resTransform:b,space:r});let h=b.newIbGib,p=w({ibGib:h});C&&console.log(`${i} updating _currentRoot root. newRootAddr: ${p}`),await de({ibGib:h,space:r,fnBroadcast:n}),await ns({root:h,space:r,zeroSpace:s,fnUpdateBootstrap:a,fnBroadcast:n})}catch(c){console.error(`${i} ${c.message}`);return}}f(mi,"rel8ToCurrentRoot");async function rs({targetIbGib:o,space:t}){let e=`[${rs.name}]`;try{C&&console.log(`${e} starting... (I: 291638372117dbc983b4b7cbd8f52123)`);let r=await ts({targetIbGib:o}),n=await xe({ibGib:r,space:t});if(!n.success)throw new Error(`error putting metaStone in space. error: ${n.errorMsg??"[unknown error (E: 45f700f4f1ff463ca8f5353c8e796ac7)]"} (E: 4c25379e66365055e3e423561a7d6123)`)}catch(r){throw console.error(`${e} ${E(r)}`),r}finally{C&&console.log(`${e} complete.`)}}f(rs,"createAndSaveNewMetaStone");async function de({ibGib:o,space:t,fnBroadcast:e}){let r=`[${de.name}]`,n=C;try{let s=w({ibGib:o});if(r=`${r}[${s}]`,!t)throw new Error("space required. (E: ea0c03256f8a4062b460aa4de11f1e3e)");if(C&&console.log(`${r} starting...`),!ue({ibGibAddr:s}).tjpGib&&!o.data?.isTjp){C&&console.log(`${r} incoming ibGib has no timeline, so no broadcast. still going to create a metastone for it and return early. (I: 649752e3b1be0e0ceb078e0ec2a84f23)`),await rs({targetIbGib:o,space:t});return}let i=Ie({ibGib:o,defaultIfNone:"undefined"});if(!i){let u=o.data?.isTjp?o:await Lr({ibGib:o,space:t});u||(console.warn(`${r} tjp not found for ${s}? Should at least just be the ibGib's address itself. (W: d9b570e5bf6d4312bc7d9249ed3bbaad)`),u=o),i=w({ibGib:u})}if(!i)throw new Error("(UNEXPECTED) tjpAddr falsy? should be guaranteed at this point. (E: 39aafb70bc3c6d70b6d2cf8882311223)");let c=f(async()=>{C&&console.log(`${r} adding/replacing latest. tjp: ${i} (I: 7f848da003a2436089fd6f044d96bb42)`),await rs({targetIbGib:o,space:t}),e&&(C&&console.log(`${r} fnBroadcast is true...(I: 0e3b561fb5474a0598b5c6d698df5e1f)`),setTimeout(()=>{C&&console.log(`${r} broadcasting... (I: 61785937be0346f0959d476d7267ab24)`),e({ib:"IbGibTimelineUpdateInfo",tjpAddr:i,latestAddr:s,latestIbGib:o})}))},"replaceLatest");if(o.data?.isTjp){C&&console.log(`${r} ibGib.data?.isTjp true. replacingLatest and returning early. (I: 02c626e006668291550e278b461bcb23)`),await c();return}C&&console.log(`${r} ibGib.data?.isTjp is falsy. (I: 84940e3a9eff869c9474b7b92b864b23)`);let l=await je({ibGibs:[o],space:t});if(!l.data)throw new Error("(UNEXPECTED) resLatest.data falsy? (E: af3d3914d96adcc5525e4db83cc5d223)");let{success:d,latestAddrsMap:b}=l.data;if(!d){let{errors:u}=l.data;throw u??=["[unknown error (E: 344857f1853641aa842cea3931f90428)]"],new Error(`resLatest.success falsy. errors: ${P(u)}. addr: ${s} (E: b66721da6e1ef9ac4f4089e86c059323)`)}if(!b)throw new Error("(UNEXPECTED) latestAddrsMap falsy but success truthy? (E: c34caff7a256503575ff3ff491dec823)");let h=Object.keys(b);if(h.length!==1)throw new Error("(UNEXPECTED) latestAddrsMap size isn't 1? (E: e11ffc2c18d473745b5bbfc3fe5e3a23)");if(h[0]!==s)throw new Error(`(UNEXPECTED) latestAddrsMap has 1 key (correct) but the key isn't the incoming ibGibAddr? (incorrect). incoming ibGibAddr: ${s}. key found: ${h[0]} (E: 82d79a95d2d7de90eae9db571a360f23)`);C&&(console.log(`${r} valid latestAddrsMap. console.dir(latestAddrsMap)... (I: e24de41622cabbef375172c3017cfd23)`),console.dir(b));let p=b[s];if(p)if(p===s){C&&console.log(`${r} no other found. possible idempotent replacement. addr: ${s} (I: 7f5bd5d3391be95919240f0e97976e22)`),await c();return}else{C&&console.log(`${r} different addr found. incoming ibgib addr is newer. existingLatestAddr: ${p}. incoming addr: ${s} (I: 6cadf13f82aabeb71d76babf1813e623)`);let u=await B({addr:p,space:t});if(!u.success||u.ibGibs?.length!==1){console.error(`Didn't find existing latest ibGib (${p}). I haven't implemented more robust multi-node/distributed strategies for this scenario yet. so we are going ahead with setting the incoming ibgib as the latest in the timeline. (E: 10f6cca6e5ef45bfacbfe48f652e2102)`),await c();return}let g=u.ibGibs[0];if(typeof o.data?.n=="number"&&o.data.n>=0){C&&console.log(`found ibGib.data.n (version counter), using this to determine latest ibGib: ${o.data.n}`);let $=o.data.n;if(typeof g.data?.n=="number"&&g.data.n>=0){let I=g.data.n;if($>I)C&&console.log(`${r} is newer (I: 040d05ac2032f08c7fd0c4d8b2887323)`),await c();else{C&&console.log("is not newer, so we don't need to do anything else. (I: 14c25dc3314748dc909d61b77eb64354)"),console.warn(`${r} incoming ibGib (${s}) is NOT NEWER than existing latest (${p}). multiple branches for the same timeline? ignoring incoming ibGibAddr. n_ibGib: ${$}. n_existingLatest: ${I}. space.ib: ${t.ib} (W: 057baadca494473dabb26fb4fb879774)`);return}}else g.data?.isTjp&&o.data.n===0?await c():(console.warn(`${r} (UNEXPECTED) only existingLatestIbGib (isTjp: ${g.data?.isTjp}) has a data.n counter? ibGib.data.n: ${o.data.n}. usually this only happens when existing latest is a tjp and the new ibGib we are registering is n === 0. This is falsy in this instance though. We will go ahead and replace the latest with the new one, but this is an anomalous state. (W: 73d08aea17ad4e1481a5f97e2556a878)`),console.log(`${r} console.dir(existingLatestIbGib)... (I: 9ef7962d9cc74f1eb0409e5caf98e915)`),console.dir(g),console.log(`${r} console.dir(ibGib)... (I: 9ef7962d9cc74f1eb0409e5caf98e915)`),console.dir(o),await c())}else if(C&&console.log(`${r} no nCounter found. Trying brute force method.`),await vi({ibGib:o,ibGibAddr:s,existingLatest:g,existingLatestAddr:p,tjpAddr:i,space:t})===s)await c();else return}else if(p===null){C&&console.log(`${r} no existing tjp mapping so incoming ibgib is considered new to this space. ibGib addr: ${s} (I: 4f2bbc32b31e4fa982d95b3a785db82f)`),await c();return}else throw new Error("(UNEXPECTED) latestAddr is falsy but not null? the getLatestAddrs impl in the space should be guaranteed to provide either the incoming ibgib addr, the latest addr (if exists), or null if not found. (E: 3159dd531c0bc0efc1ece116adf28923)")}catch(s){throw console.error(`${r} ${s.message}`),s}finally{C&&console.log(`${r} complete.`),C=n}}f(de,"registerNewIbGib");async function hr({type:o,rel8nName:t,ibGibsToRel8:e,ibGibsToUnRel8:r,addrsToUnRel8:n,linked:s,severPast:a,deletePreviousSpecialIbGib:i,space:c,zeroSpace:l,fnUpdateBootstrap:d,fnBroadcast:b}){let h=`[${hr.name}](type:${o},rel8nName:${t})`;try{if(!c)throw new Error("space required. (E: 956192eea28047eba6dad81620bb96fb)");if((e??[]).length===0&&(r??[]).length===0&&(n??[]).length===0)throw new Error("either ibGibsToRel8 or ibGibsToUnRel8 required. (E: 5add49c8e46a54e2c6b057c22646a822)");if((r??[]).length>0&&(n??[]).length>0)throw new Error("can't provide both ibGibsToUnRel8 and addrsToUnRel8. There isn't a technical reason but I'm too tired right now to implement the overhead to enable this atow (05/2025). (E: 31ef66be26349cfe1b1f352389b99425)");let p=e?.map(_=>w({ibGib:_}));n??=r?.map(_=>w({ibGib:_}));let u=fe({type:o}),g=await yo({key:u,space:c});if(!g)throw new Error("specialAddr not found (E: 680dfd1caa3e4d7cb0f593b893a10f0d)");let m=await B({addr:g,space:c});if(!m.success)throw new Error("couldn't get special (E: 897f7671d2184515866c5a675d33b3dc)");if(!m.ibGibs)throw new Error("resGetSpecial.ibGibs falsy (E: 2405dd295b2444d88503f7731796a5a0)");if(m.ibGibs.length!==1)throw new Error(`resGetSpecial.ibGibs count is not 1 (${m.ibGibs.length}) (E: b4547789016a4729af30cd972a4ca4ab)`);let $=m.ibGibs[0],T=await Ce({src:$,rel8nsToAddByAddr:p?{[t]:p}:void 0,rel8nsToRemoveByAddr:n?{[t]:n}:void 0,dna:!1,linkedRel8ns:s?[te.past,t]:[te.past],nCounter:!0}),I=T.newIbGib;if(a){if(T.intermediateIbGibs)throw new Error("new special creates intermediate ibgibs. so severing past is harder. (E: b580c0c56253494192e9c62212ee187d)");I.rel8ns.past=[],I.gib=await J({ibGib:I})}await se({resTransform:T,space:c});let y=w({ibGib:I}),A=Ie({ibGib:I});return await _e({key:u,addr:y,space:c,zeroSpace:l,fnUpdateBootstrap:d}),i&&await os({addr:g,space:c}),await de({ibGib:I,fnBroadcast:b,space:c}),y}catch(p){throw console.error(`${h} ${p.message}`),p}}f(hr,"rel8ToSpecialIbGib");async function Lr({ibGib:o,naive:t=!0,space:e}){let r=`[${Lr.name}]`;try{if(!e)throw new Error("space required. (E: 941f973d50e84415b58724af173f52c2)");if(!o)throw new Error("ibGib required.");let n=w({ibGib:o}),{gib:s}=H({ibGibAddr:n});if(s===M||await ls({ibGib:o,naive:t}))return o;if(!o.rel8ns){C&&console.log(`${r} ibgib not tjp in data, and rel8ns is falsy. so tjp is undefined (I: acdadb76a7568807db7a68f6f866de22)`);return}if(o.rel8ns.tjp&&o.rel8ns.tjp.length>0){let b=o.rel8ns.tjp[0],h=await B({addr:b,space:e});if(h.success&&h.ibGibs?.length===1)return h.ibGibs[0];{let p=h.errorMsg??"[unspecified error in get result]";throw new Error(`ibGib references tjp but could not retrieve from space. res error: ${p} (E: 94f0340706ad48c794c6a62c1b235a22)`)}}let i=o.rel8ns.past||[];if(i.length===0){console.warn(`${r} past.length === 0, so there is no tjp.`),C&&console.log(`${r} ibgib is not tjp in data, not in tjp rel8n, and past is empty. so tjp is undefined (I: bf06f664917dcf4492fb9c4c106a6222)`);return}let c=i[i.length-1],l=await B({addr:c,space:e});if(!l.success||l.ibGibs?.length!==1)throw new Error(`get past failed. addr: ${c}`);let d=l.ibGibs[0];return await Lr({ibGib:d,naive:t,space:e})}catch(n){throw console.error(`${r} ${n.message}`),n}}f(Lr,"getTjpIbGib");async function wi({type:o,space:t,zeroSpace:e,fnUpdateBootstrap:r,fnBroadcast:n}){let s=`[${wi.name}]`;try{if(!t)throw new Error("space falsy and localUserSpace not initialized. (E: 66e7d3ff098248f0a5ddda51853c92e6)");switch(o){case"roots":return Ii({space:t,zeroSpace:e,fnBroadcast:n,fnUpdateBootstrap:r});case"tags":return yi({space:t,zeroSpace:e,fnBroadcast:n,fnUpdateBootstrap:r});case"secrets":return Ti({space:t,zeroSpace:e,fnBroadcast:n,fnUpdateBootstrap:r});case"encryptions":return Ai({space:t,zeroSpace:e,fnBroadcast:n,fnUpdateBootstrap:r});case"outerspaces":return Si({space:t,zeroSpace:e,fnBroadcast:n,fnUpdateBootstrap:r});case"autosyncs":return Gi({space:t,zeroSpace:e,fnBroadcast:n,fnUpdateBootstrap:r});case"robbots":return Ci({space:t,zeroSpace:e,fnBroadcast:n,fnUpdateBootstrap:r});case"apps":return xi({space:t,zeroSpace:e,fnBroadcast:n,fnUpdateBootstrap:r});default:return Ni({type:o,space:t,zeroSpace:e,fnBroadcast:n,fnUpdateBootstrap:r})}}catch(a){throw console.error(`${s} ${a.message}`),a}}f(wi,"createSpecial");async function pt({type:o,skipRel8ToRoot:t,space:e,zeroSpace:r,fnUpdateBootstrap:n,fnBroadcast:s}){let a=`[${pt.name}][${o||"falsy type?"}]`;try{C&&console.log(`${a} starting...`);let i=is({type:o}),c=F.primitive({ib:i}),l=await eo({src:c,destIb:i,linkedRel8ns:[te.past,te.ancestor],tjp:{uuid:!0,timestamp:!0},dna:!0,nCounter:!0});return await se({resTransform:l,space:e}),o!=="roots"&&o!=="latest"&&!t&&await mi({ibGib:l.newIbGib,linked:!0,space:e,zeroSpace:r,fnBroadcast:s,fnUpdateBootstrap:n}),C&&console.log(`${a} complete.`),l.newIbGib}catch(i){throw console.error(`${a} ${i.message}`),i}}f(pt,"createSpecialIbGib");async function yi({space:o,zeroSpace:t,fnUpdateBootstrap:e,fnBroadcast:r}){let n=`[${yi.name}]`;try{if(!o)throw new Error("space required. (E: 9c05b9bd355943a39ca47afef67a50eb)");let s=fe({type:"tags"}),a=await pt({type:"tags",space:o,zeroSpace:t,fnBroadcast:r,fnUpdateBootstrap:e}),i=w({ibGib:a});await _e({key:s,addr:i,space:o,zeroSpace:t,fnUpdateBootstrap:e});let c=[{text:"home",icon:"home-outline"},{text:"favorite",icon:"heart-outline"}];for(let l of c)i=(await $i({...l,space:o,zeroSpace:t,fnBroadcast:r,fnUpdateBootstrap:e})).newTagsAddr,await _e({key:s,addr:i,space:o,zeroSpace:t,fnUpdateBootstrap:e});return i}catch(s){return console.error(`${n} ${s.message}`),null}}f(yi,"createSpecial_Tags");async function $i({text:o,icon:t,description:e,space:r,zeroSpace:n,fnUpdateBootstrap:s,fnBroadcast:a}){let i=`[${$i.name}]`;try{if(C&&console.log(`${i} starting...`),!r)throw new Error("space required. (E: 5def0b1afab74b0c9286e3ac5060cb8f)");if(!o)throw new Error(`${i} text required`);t=t||Xa,e=e||Ha;let c=Zt(o),l=F.primitive({ib:"tag"}),d=await F.firstGen({parentIbGib:l,ib:c,data:{text:o,icon:t,description:e},tjp:{uuid:!0,timestamp:!0},dna:!0,nCounter:!0}),b=d.newIbGib;await se({resTransform:d,space:r}),await de({ibGib:b,space:r,fnBroadcast:a});let h=await Ul({tagIbGib:b,space:r,zeroSpace:n,fnUpdateBootstrap:s,fnBroadcast:a});return{newTagIbGib:b,newTagsAddr:h}}catch(c){throw console.error(`${i} ${c.message}`),c}finally{C&&console.log(`${i} complete.`)}}f($i,"createTagIbGibAndSundry");async function Ii({space:o,zeroSpace:t,fnUpdateBootstrap:e,fnBroadcast:r}){let n=`[${Ii.name}]`;try{if(!o)throw new Error("space required. (E: d12a8ea31163429fb6e53ff8e7579c57)");let s=fe({type:"roots"}),a=await pt({type:"roots",space:o,zeroSpace:t,fnBroadcast:r,fnUpdateBootstrap:e}),i=w({ibGib:a});await _e({key:s,addr:i,space:o,zeroSpace:t,fnUpdateBootstrap:e});let l=["A","B","C","D","E","F","G"].map(b=>({text:`${b}root`,icon:Un,description:kn})),d;for(let b=0;b<l.length;b++){let h=l[b],p=await _i({...h,space:o,zeroSpace:t,fnUpdateBootstrap:e,fnBroadcast:r});if(d||(d=p.newRootIbGib),!p.newRootIbGib)throw new Error("(UNEXPECTED) resCreate.newRootIbGib falsy? (E: c9fb2c94a9c1d762c1699b41a4d5ad23)");i=p.newRootsAddr,await _e({key:s,addr:i,space:o,zeroSpace:t,fnUpdateBootstrap:e})}if(!d)throw new Error("(UNEXPECTED) firstRoot still falsy? (E: b2e2c926d242966e7ed7159e4b129e23)");if(await ns({root:d,space:o,zeroSpace:t,fnUpdateBootstrap:e,fnBroadcast:r}),i=await yo({key:s,space:o}),!i)throw new Error("(UNEXPECTED) no roots address in config? (E: 76345340699a4738a195e48803ef0d31)");return i}catch(s){return console.error(`${n} ${s.message}`),null}}f(Ii,"createSpecial_Roots");async function _i({text:o,icon:t,description:e,space:r,zeroSpace:n,fnUpdateBootstrap:s,fnBroadcast:a}){let i=`[${_i.name}]`;try{if(!r)throw new Error("space required. (E: cfa876e5c8c64a53a463ca7a645571c8)");o=o||ja,t=t||Un,e=e||kn;let c=cs(o),l=F.primitive({ib:"root"}),d=await F.firstGen({parentIbGib:l,ib:c,data:{text:o,icon:t,description:e},linkedRel8ns:[te.past,te.ancestor],tjp:{uuid:!0,timestamp:!0},dna:!0,nCounter:!0}),{newIbGib:b}=d;await se({resTransform:d,space:r});let h=await hr({type:"roots",rel8nName:Pn,ibGibsToRel8:[b],space:r,zeroSpace:n,fnUpdateBootstrap:s,fnBroadcast:a});return{newRootIbGib:b,newRootsAddr:h}}catch(c){throw console.error(`${i} ${c.message}`),c}}f(_i,"createRootIbGib");async function Ti({space:o,zeroSpace:t,fnUpdateBootstrap:e,fnBroadcast:r}){let n=`[${Ti.name}]`;try{if(!o)throw new Error("space required. (E: 340960cd5ad24addb300b23d9722e30a)");let s,a=fe({type:"secrets"}),i=await pt({type:"secrets",space:o,zeroSpace:t,fnBroadcast:r,fnUpdateBootstrap:e});return s=w({ibGib:i}),await _e({key:a,addr:s,space:o,zeroSpace:t,fnUpdateBootstrap:e}),s}catch(s){return console.error(`${n} ${s.message}`),null}}f(Ti,"createSpecial_Secrets");async function Ai({space:o,zeroSpace:t,fnUpdateBootstrap:e,fnBroadcast:r}){let n=`[${Ai.name}]`;try{if(!o)throw new Error("space required. (E: 5084e698b6924e7090697ca50075ca59)");let s,a=fe({type:"encryptions"}),i=await pt({type:"encryptions",space:o,zeroSpace:t,fnBroadcast:r,fnUpdateBootstrap:e});return s=w({ibGib:i}),await _e({key:a,addr:s,space:o,zeroSpace:t,fnUpdateBootstrap:e}),s}catch(s){return console.error(`${n} ${s.message}`),null}}f(Ai,"createSpecial_Encryptions");async function Si({space:o,zeroSpace:t,fnUpdateBootstrap:e,fnBroadcast:r}){let n=`[${Si.name}]`;try{if(!o)throw new Error("space required. (E: 99dd9e92535c470482eb9f6625a33831)");let s,a=fe({type:"outerspaces"}),i=await pt({type:"outerspaces",space:o,zeroSpace:t,fnBroadcast:r,fnUpdateBootstrap:e});return s=w({ibGib:i}),await _e({key:a,addr:s,space:o,zeroSpace:t,fnUpdateBootstrap:e}),s}catch(s){return console.error(`${n} ${s.message}`),null}}f(Si,"createSpecial_OuterSpaces");async function Gi({space:o,zeroSpace:t,fnUpdateBootstrap:e,fnBroadcast:r}){let n=`[${Gi.name}]`;try{if(!o)throw new Error("space required. (E: f01cf6a4a460486796e16d505d629522)");let s,a=fe({type:"autosyncs"}),i=await pt({type:"autosyncs",space:o,zeroSpace:t,fnBroadcast:r,fnUpdateBootstrap:e});return s=w({ibGib:i}),await _e({key:a,addr:s,space:o,zeroSpace:t,fnUpdateBootstrap:e}),s}catch(s){return console.error(`${n} ${s.message}`),null}}f(Gi,"createSpecial_Autosyncs");async function Ci({space:o,zeroSpace:t,fnUpdateBootstrap:e,fnBroadcast:r}){let n=`[${Ci.name}]`;try{if(!o)throw new Error("space required. (E: f01cf6a4a460486796e16d505d629522)");let s,a=fe({type:"robbots"}),i=await pt({type:"robbots",space:o,zeroSpace:t,fnBroadcast:r,fnUpdateBootstrap:e});return s=w({ibGib:i}),await _e({key:a,addr:s,space:o,zeroSpace:t,fnUpdateBootstrap:e}),s}catch(s){return console.error(`${n} ${s.message}`),null}}f(Ci,"createSpecial_Robbots");async function xi({space:o,zeroSpace:t,fnUpdateBootstrap:e,fnBroadcast:r}){let n=`[${xi.name}]`;try{if(!o)throw new Error("space required. (E: f01cf6a4a460486796e16d505d629522)");let s,a=fe({type:"apps"}),i=await pt({type:"apps",space:o,zeroSpace:t,fnBroadcast:r,fnUpdateBootstrap:e});return s=w({ibGib:i}),await _e({key:a,addr:s,space:o,zeroSpace:t,fnUpdateBootstrap:e}),s=await Eo({defaultAppData:ai,defaultAppRel8ns:ii,space:o,zeroSpace:t,fnUpdateBootstrap:e,fnBroadcast:r}),s=await Eo({defaultAppData:ci,defaultAppRel8ns:li,space:o,zeroSpace:t,fnUpdateBootstrap:e,fnBroadcast:r}),s=await Eo({defaultAppData:di,defaultAppRel8ns:fi,space:o,zeroSpace:t,fnUpdateBootstrap:e,fnBroadcast:r}),s}catch(s){return console.error(`${n} ${s.message}`),null}}f(xi,"createSpecial_Apps");async function Eo({defaultAppData:o,defaultAppRel8ns:t,space:e,zeroSpace:r,fnUpdateBootstrap:n,fnBroadcast:s}){let a=`[${Eo.name}]`;try{C&&console.log(`${a} starting... (I: 677f68789abdc7316887e8f38c764e22)`),C&&console.log(`${a} starting...`);let i=L(o),c=t?L(t):void 0;i.uuid=!i.uuid||i.uuid===Jn?await j():i.uuid;let{classname:l}=i,d=zn({appData:i,classname:l}),b=await F.firstGen({ib:d,parentIbGib:F.primitive({ib:`app ${l}`}),data:i,rel8ns:c,dna:!0,linkedRel8ns:[te.ancestor,te.past],nCounter:!0,tjp:{timestamp:!0}});return await se({resTransform:b,space:e}),await de({ibGib:b.newIbGib,fnBroadcast:s,space:e}),await hr({type:"apps",rel8nName:ao,ibGibsToRel8:[b.newIbGib],fnBroadcast:s,fnUpdateBootstrap:n,space:e,zeroSpace:r})}catch(i){throw console.error(`${a} ${i.message}`),i}finally{C&&console.log(`${a} complete.`)}}f(Eo,"createApp");async function Ni({type:o,space:t,zeroSpace:e,fnUpdateBootstrap:r,fnBroadcast:n}){let s=`[${Ni.name}]`;try{if(!t)throw new Error("space required. (E: c7bbafcbe901418db4c6048f17f53091)");C&&console.log(`${s} creating special of type: ${o} (I: 283c8bb30ed6f9698b74b886c6078622)`);let a,i=fe({type:o}),c=await pt({type:o,space:t,zeroSpace:e,fnBroadcast:n,fnUpdateBootstrap:r});return a=w({ibGib:c}),await _e({key:i,addr:a,space:t,zeroSpace:e,fnUpdateBootstrap:r}),a}catch(a){return console.error(`${s} ${a.message}`),null}}f(Ni,"createSpecial_Default");async function vi({ibGib:o,ibGibAddr:t,existingLatest:e,existingLatestAddr:r,tjpAddr:n,space:s}){let a=`[${vi.name}][${t}]`;try{if(C&&console.log(`${a} starting...`),!s)throw new Error("space required. (E: 64eb9a271f5d43deadec30b9638746c8)");let i=o.rel8ns?.past||[],c=e.rel8ns?.past||[];if(i.length===1&&c.length===0)return C&&console.log(`prospective has a past, so it "must" be newer. (won't quote "must" anymore)`),t;if(c.length===1&&i.length===0)return C&&console.log("existing has a past, so it must be newer."),r;if(c.length===0&&i.length===0)return console.warn(`${a} neither existing latest nor prospective new ibGib has a past, so keeping existing.`),r;if(c.includes(t))return C&&console.log("existing by definition is newer"),r;if(i.includes(r))return C&&console.log("ibGib by definition is newer"),t;if(r===t)return C&&console.log("they're the same!"),r;if(r===n&&e.rel8ns?.tjp?.length===1)return C&&console.log("ibGib must be newer because the existingLatestAddr is the tjp, which is by definition first in unique past."),t;if(t===n&&o.rel8ns?.tjp?.length===1)return C&&console.log("existing must be newer because the ibGibAddr is the tjp, which is by definition first in unique past."),r;C&&console.log(`${a} brute forcing through iterating the pasts.`);let l,d=-1,b=f(async(u,g,m)=>{let $=u.rel8ns?.past||[];if($.includes(m))return l=w({ibGib:u}),-1;if($.length===0)return g;let T=g+$.length;if(d!==-1&&T>d)return l=w({ibGib:u}),-1;let I=await B({addr:$[0],space:s});if(!I.success||I.ibGibs?.length!==1)throw new Error(`Couldn't load past addr (xPast[0]): ${$[0]}`);return b(I.ibGibs[0],g+$.length,m)},"getPastCount");C&&console.log(`${a} doing ibGibPastCount`);let h=await b(o,0,r);if(l)return l;C&&console.log(`${a} Doing existingPastCount`),d=h;let p=await b(e,0,t);return l||(h>p?(C&&console.log(`${a} ibGibPastCount (${h}) is longer than existingPastCount (${p}), so ibGib is newer.`),l=t):(C&&console.log(`${a} existingPastCount (${p}) is longer than ibGibPastCount (${h}), so ibGib is newer.`),l=r),l)}catch(i){throw console.error(`${a} ${i.message}`),i}finally{C&&console.log(`${a} complete.`)}}f(vi,"getLatestAddr_Brute");function Ul({tagIbGib:o,space:t,zeroSpace:e,fnUpdateBootstrap:r,fnBroadcast:n}){return hr({type:"tags",rel8nName:Mn,ibGibsToRel8:[o],space:t,zeroSpace:e,fnUpdateBootstrap:r,fnBroadcast:n})}f(Ul,"rel8TagToTagsIbGib");function ss({space:o,scope:t}){let e=`[${ss.name}]`;try{if(C&&console.log(`${e} starting...`),!o)throw new Error("space required. (E: 3ba16e6c3e5e47948b0e63448da11752)");if(!o.data?.uuid)throw new Error("invalid space (space.data.uuid falsy) (E: 273262b32f2ef27b2e690bc699f33822)");if(!t)throw new Error("scope required. (E: f47801d6c45e2247b42a53d9b604b522)");for(;t.includes(le);)C&&console.log(`${e} scope contains ibgib delimiter...replacing... (I: 0f456fd7cc6552a799673a0c5b4a7d22)`),t=t.replace(le,"_");let r=o.data.uuid,n=`${Ma} ${r} ${t}`;return w({ib:n,gib:M})}catch(r){throw console.error(`${e} ${r.message}`),r}finally{C&&console.log(`${e} complete.`)}}f(ss,"getSpaceLockAddr");async function ht({space:o,scope:t,secondsValid:e,maxDelayMs:r,fn:n,callerInstanceId:s,maxLockAttempts:a}){let i=`[${ht.name}]`;try{if(C&&console.log(`${i} starting...`),!o)throw new Error("space required. (E: 66fd8f21a5b2b572d18cdeb9472a7722)");if(!e)throw new Error("secondsValid required. (E: 92c5610e57ceede5ce83cff86d5c2a22)");if(e<0)throw new Error("secondsValid must be positive. (E: 970a7510c517235d7a355a843d18d222)");if(!n)throw new Error("fn required (E: 7022e280252ec2faf756b6db05c56e22)");let c;C&&console.log(`${i} attempting to acquire lock with scope ${t} (I: fed36d42a975b1c52897a4df804ac722)`);let l;r=(r??0)>0?r:Fa;let d=0;a=a??!1?a:Ba;do{if(l=await Oi({space:o,scope:t,secondsValid:e,instanceId:s}),l?.data?.success)break;let h=Math.ceil(Math.random()*r);await pe(h),d++}while(d<a);if(l?.data?.success)C&&console.log(`${i} lock acquired. (I: d847fa953ee131a57e1a89c537342722)`);else throw new Error(`could not acquire lock after ${d} attempts with intermittent delays of ${r} ms (E: 898c559dbd0c9bf20c14cf87a8f1e222)`);let b=`${i}[fn]`;try{C&&console.log(`${b} starting... (I: c2f7bedf95d3f1dd1f76de34a68d3f22)`),c=await n()}catch(h){throw console.error(`${b} ${h.message}`),h}finally{C&&console.log(`${b} unlocking space with scope: ${t} (I: 21034d9c3395499756e9000e40417d22)`),await Di({space:o,scope:t,instanceId:s}),C&&console.log(`${b} complete. (I: 79d8ac03714a4d429c7e6c2ac6e18d22)`)}return c}catch(c){throw console.error(`${i} ${c.message}`),c}finally{C&&console.log(`${i} complete.`)}}f(ht,"execInSpaceWithLocking");async function mo({zeroSpace:o}){let t=`[${mo.name}]`;try{if(C&&console.log(`${t} starting...`),!o)throw new Error("zeroSpace required. (E: 66fd8f21a5b2b572d18cdeb9472a7722)");let e=Jt;C&&console.log(`${t} getting from zeroSpace...`);let r=await o.argy({ibMetadata:Gt({space:o}),argData:{cmd:"get",ibGibAddrs:[e]}}),n=await o.witness(r);if(n?.data?.success&&n.ibGibs?.length===1){let s=n.ibGibs[0];return C&&console.log(`${t} bootstrapibGib found: ${P(s)}`),await Zn(s)?s:(C&&console.log(`${t} bootstrapIbGib was invalid. (I: cce66b26805404fc85525d565e1f8b22)`),null)}else return C&&console.log(`${t} bootstrapIbGib NOT found. (I: 421562993bf3464eb507d2967d311e22)`),null}catch(e){throw console.error(`${t} ${e.message}`),e}finally{C&&console.log(`${t} complete.`)}}f(mo,"getValidatedBootstrapIbGib");async function kl({zeroSpace:o,bootstrapIbGib:t,localSpaceId:e,lock:r,callerInstanceId:n,fnDtoToSpace:s,localSpaceCacheSvc:a}){let i=`[${kl.name}]`;try{if(!o)throw new Error("zeroSpace required. (E: 0793781a98c456a666cfa9eb960bcd22)");if(!t)if(C&&console.log(`${i} bootstrap falsy, so loading it... (I: f2366e38283495a38b5501297aa34422)`),r){let d=Jt;C&&console.log(`${i} using locked version of loading bootstrap... (I: 52b9b11999674e586d051c2b23f59b22)`),t=await ht({space:o,scope:d,fn:f(async()=>{let b=await mo({zeroSpace:o});if(b)return b;throw new Error("(UNEXPECTED) unable to get bootstrap ibgib? (E: c111dc7627acbfb992134ddf4064ea23)")},"fn"),callerInstanceId:n,secondsValid:Ln})}else C&&console.log(`${i} lock is false, so just getting the bootstrap ibgib (I: 49d55e5a824510bb3ee0ccd9f5ec3322)`),t=await mo({zeroSpace:o})??void 0;if(!t)throw new Error("bootstrapIbGib falsy. not initialized? (E: 91f5c82b5e124178d958701ebcb09822)");if(!t.data)throw new Error("(UNEXPECTED) bootstrapIbGib.data required. invalid bootstrap? (E: 568c6b837c1a39f7a25d188a90167423)");e=e??t.data[dt];let c=t.rel8ns[e][0],l=f(async()=>{let d=await o.argy({ibMetadata:Gt({space:o}),argData:{cmd:"get",ibGibAddrs:[c]}}),b=await o.witness(d);if(b?.data?.success&&b.ibGibs?.length===1){let h=b.ibGibs[0],p=await s(h);return a&&(p.cacheSvc=a),p}else throw new Error(`Could not get local space addr (${c}) specified in bootstrap space (${w({ibGib:t})}). (E: 6d6b45e7eae4472697ddc971438e4922)`)},"fnGet");return r?(C&&console.log(`${i} getting localSpaceId (${e}) WITH locking (I: c48a0e4ac5971cdbc57273dd35f8a522)`),await ht({space:o,scope:e,fn:f(()=>l(),"fn"),callerInstanceId:n,secondsValid:Ln})):(C&&console.log(`${i} getting localSpaceId (${e}) WITHOUT locking (I: 48e504835dee4006839df8820d860b22)`),l())}catch(c){throw console.error(`${i} ${c.message}`),c}}f(kl,"getLocalSpace");async function Oi({space:o,scope:t,secondsValid:e,instanceId:r}){let n=`[${Oi.name}]`;try{if(C&&console.log(`${n} starting...`),!o)throw new Error("space required. (E: 5c0a7197a75f483a82d74e5eea60df37)");if(!t)throw new Error("scope required. (E: c7f1dde9570f4df3b450faa2c2f85122)");if(!e)throw new Error("secondsValid required and positive (E: b42b6733638b46c06c9aff59a6c49822)");if(e<0)throw new Error("secondsValid must be positive (E: bbe3b6d567583bfb35a1c0825eb29622)");let s,a=ss({space:o,scope:t}),i,c=await B({addr:a,space:o,force:!0});if(c.success&&c.ibGibs?.length===1?(i=c.ibGibs[0],i?.data?.expirationUTC?Gn({expirationTimestampUTC:i.data.expirationUTC})&&(console.warn(`${n} ignoring expired existing lock in space at ${a}. Should be overwritten (W: 7421c5b051724b189f88cecbbd449b22)`),i=void 0):(console.error(`${n} (UNEXPECTED) exisingLock.data.expirationUTC falsy? (E: 218dc0e935534a149d0be153c532cf25)`),i=void 0)):C&&console.log(`${n} existing lock not found for ${a} (I: 191af56ec4e2db3d19084e46bf949222)`),i){if(!i.data)throw new Error("(UNEXPECTED) existingLock.data falsy? (E: 00069b4662e5566d971760d15e293723)");s=L(i),s.data.alreadyLocked=!0,s.data.success=!1}else{let{ib:l,gib:d}=H({ibGibAddr:a});s={ib:l,gib:d,data:{scope:t,secondsValid:e,instanceId:r,expirationUTC:Sn({seconds:e})}};let b=await o.argy({ibMetadata:Gt({space:o}),argData:{cmd:"put",force:!0,ibGibAddrs:[a]},ibGibs:[s]}),h=await o.witness(b);if(h.data?.success)if((h.data.addrsAlreadyHave??[]).includes(a)){C&&console.log(`${n} racelost! addrsAlreadyHave includes spaceLockAddr (${a}) (I: 2e8a1562947c40698110b64251141753)`);let p=await B({addr:a,space:o,force:!0});if(p.success&&p.ibGibs?.length===1){let u=p.ibGibs[0];s=L(u),s.data.alreadyLocked=!0,s.data.success=!1}else{let u=`${n} (UNEXPECTED) addrsAlreadyHave true, but couldn't get lock? (E: 8374a2b6628b49369363bc5843105763)`;console.error(u),s.data.success=!1,s.data.errorMsg=u}}else s.data.success=!0;else{let p=`${n} there was an error putting the lock in the space: ${h.data?.errors?.join("|")}`;s.data.success=!1,s.data.errorMsg=p,console.error(p)}}return s}catch(s){throw console.error(`${n} ${s.message}`),s}finally{C&&console.log(`${n} complete.`)}}f(Oi,"lockSpace");async function Di({space:o,scope:t,instanceId:e}){let r=`[${Di.name}]`;try{if(C&&console.log(`${r} starting...`),!o)throw new Error("space required. (E: 5c0a7197a75f483a82d74e5eea60df37)");if(!t)throw new Error("scope required. (E: c7f1dde9570f4df3b450faa2c2f85122)");let n=ss({space:o,scope:t}),s=await os({addr:n,space:o,force:!0});if(s.success){let{ib:a,gib:i}=H({ibGibAddr:n});return{ib:a,gib:i,data:{success:!0,instanceId:e,scope:t}}}else{let a=`Delete lock in space failed. delete errorMsg: ${s.errorMsg}`;if(a.includes("not implemented"))throw new Error(a);if(a.toLowerCase().includes("does not exist")||a.toLowerCase().includes("doesn't exist")||a.toLowerCase().includes("not found")){C&&console.log(`${r} ${a} (I: b647916fd0f3e5366e9387131be21c22)`);let{ib:i,gib:c}=H({ibGibAddr:n});return{ib:i,gib:c,data:{action:"unlock",success:!0,instanceId:e,scope:t}}}else console.warn(`${r} ${a} (W: 14c84fcac15944bd9a417099964d5d9d)`)}}catch(n){throw console.error(`${r} ${n.message}`),n}finally{C&&console.log(`${r} complete.`)}}f(Di,"unlockSpace");async function Ml({space:o,zeroSpace:t,setSpaceAsDefault:e,createIfNotFound:r}){let n=`[${Ml.name}]`;try{if(C&&console.log(`${n} starting...`),!o)throw new Error("space required. (E: 6fc19548fa7d1d5219e19871f280a322)");if(!o.data?.uuid)throw new Error("space.data.uuid required (E: 6483188ca6f2ed2085fd355595f3ab22)");if(!t)throw new Error("zeroSpace required. (E: abbf156e18b1018d96273e22a260f122)");let s=o.data.uuid,a=w({ibGib:o}),i=await mo({zeroSpace:t});if(i){if(C&&console.log(`${n} updating existing bootstrap (I: 977d4aa7ed47bef73b35743c05ce0722)`),i.data.spaceIds.includes(s)){C&&console.log(`${n} space already rel8d to bootstrap, possibly updating its addr (I: b5e2c515ef732d4bbcf02625a9e7c722)`);let d=i.rel8ns[s][0];d===a?C&&console.log(`${n} bootstrap already rel8d to space (I: c1be027b23e7350c64790a631cae2822)`):(C&&console.log(`${n} updating rel8ns[${s}] with newSpaceAddr (${a}). (Old address: ${d})(I: 297a9b0061fd471b8d28a06e04a6ad22)`),i.rel8ns[s]=[a])}else C&&console.log(`${n} new space being rel8d. adding spaceId to data.spaceIds and amending rel8ns (I: 40903d71719aa1d56e498299f5699a22)`),i.data.spaceIds.push(s),i.rel8ns[s]=[a];e&&(C&&console.log(`${n} setting spaceId (${s}) as default space (I: f85eda6c6ad2b0bec9750ce3c7795b22)`),i.data[dt]=s)}else{if(!r){C&&console.log(`${n} bootstrapIbGib not found but createIfNotFound falsy, so returning early. (I: 5c67d85a8599a5ba4a6780f26a66ea22)`);return}C&&console.log(`${n} creating new bootstrap ibgib for spaceId (${s}) with address of (${a}) (I: 651959c27bf2ebc5be1f7f44e2b9e422)`);let{ib:d,gib:b}=H({ibGibAddr:Jt});i=F.primitive({ib:d}),i.gib=b,i.data={[dt]:s,[Va]:[s]},i.rel8ns={[s]:[a]}}if(!i)throw new Error("(UNEXPECTED) bootstrapIbGib still falsy? (E: cf21d7f1756710a66aa0e6a28d762723)");C&&console.log(`${n} saving bootstrapIbGib: ${P(i)} (I: 3cceca0b98dde90e4a58a734be252322)`);let c=await t.argy({ibMetadata:i.ib,argData:{cmd:"put",force:!0,ibGibAddrs:[w({ibGib:i})]},ibGibs:[i]});C&&console.log(`${n} zeroSpace will witness/put... (I: 1be9aca22ffc4951b6690965a7aeae5b)`);let l=await t.witness(c);if(l?.data?.success)C&&console.log(`${n} zero space put complete. (I: ac3056d655e841f1a3c442bcc64942f9)`);else throw new Error(`${l?.data?.errors?.join("|")||"There was a problem with zeroSpace witnessing the bootstrap^gib primitive pointing to the new user space"}`);C&&console.log(`${n} complete.`)}catch(s){throw console.error(`${n} ${s.message}`),s}}f(Ml,"updateBootstrapIbGib");function Gt({space:o}){return`${o.ib} ${Me()}`}f(Gt,"getSpaceArgMetadata");function Ku({space:o}){return`${o.ib} ${Me()}`}f(Ku,"getSpaceResultMetadata");function Fl({space:o,spaceData:t,classname:e}){let r=`[${Fl.name}]`;try{if(!o&&!t)throw new Error("either space or spaceData required (E: 4dabec34ee77d67c9cc30ee3c3049622)");if(o&&!o.data)throw new Error("(UNEXPECTED) given space has falsy space.data? (E: 058d298876ebbeada7bbddb9e3da2f23)");if(o&&t){if(o.data.uuid!==t.uuid)throw new Error("(UNEXPECTED) both space and spaceData given, but uuid don't match? (E: efdd4603cba93a17340a76811fe56b24)");if(o.data.n!==t.n)throw new Error("(UNEXPECTED) both space and spaceData given, but n don't match? (E: e51278a707c9bccc57a08a4b86524524)")}if(t??=o.data,!t)throw new Error("(UNEXPECTED) spaceData falsy? (thought this was a compiler problem that this was even possible.) (E: b3c7ffedcae4b1f45b263b3825930b24)");if(e&&t.classname&&e!==t.classname)throw new Error(`both classname arg (${e}) and spaceData.classname (${t.classname}) are different truthy values. (E: f98f012ee876eb8fbe7403f7b53e4624)`);if(e||=t.classname,!e)throw new Error("classname required (E: fa3af4613ad56742dab51d1b0d839322)");if(e.includes(" "))throw new Error(`invalid classname (${e}). cannot contain spaces (E: 243adbf720dcce7904e2665933208b22)`);let n=t?.name||ka;if(n.includes(" "))throw new Error("invalid space name. cannot contain spaces (E: a8450e1651081412c8ac018520182422)");let s=t?.uuid||void 0;if(!s)throw new Error("invalid space, spaceData.uuid falsy (E: 50ae723a9ab24f4fc7132613e65faf23)");if(s.includes(" "))throw new Error("invalid space id. cannot contain spaces (E: 8696830fe7f54bfa85e670a063f3e089)");let a=t.type??void 0,i=t.subtype??void 0;if(a&&!i)throw new Error(`spaceType (${a}) is set but spaceSubtype is falsy. (E: 878ab960d7987ae2331103b4a00d0d24)`);return`${uo} ${no} ${e} ${n} ${s} ${a} ${i}`}catch(n){throw console.error(`${r} ${n.message}`),n}}f(Fl,"getSpaceIb");function Bl({ib:o}){let t=`[${Bl.name}]`;if(!o){let e=`${t} ib required (E: dd5244f62f964359a86e59bb08ee47e6)`;throw console.error(e),new Error(e)}return o.startsWith(`${uo} ${no} `)}f(Bl,"isSpaceIb");function jl({spaceIb:o}){let t=`[${jl.name}]`;try{if(!o)throw new Error("spaceIb required (E: fa5424cfb7e846e2851562f2f417944f)");let[e,r,n,s,a,i,c]=o.split(" ");if(e!==uo)throw new Error(`invalid spaceIb (${o}). witnessAtom !== WITNESS_ATOM (E: 5ae1ca12cf8f30ae341f3e582b025224)`);if(r!==no)throw new Error(`invalid spaceIb (${o}). spaceAtom !== SPACE_ATOM (E: 9cc6b6f30e13455eb29748148a94fa0f)`);if(!n)throw new Error(`invalid spaceIb (${o}). spaceClassname falsy (E: 00d3392da007ca8b2840b16b199d9a24)`);if(!s)throw new Error(`invalid spaceIb (${o}). spaceName falsy (E: b957d8e74ef34d889fa64c60c7a5ea0b)`);if(!a)throw new Error(`invalid spaceIb (${o}). spaceId falsy (E: 7a1773722d8e46a0866d683130b65b89)`);let l;if(i&&i!=="undefined")if(Wn.includes(i))l=i;else throw new Error(`invalid spaceIb (${o}). spaceType (${i}) is set but not a valid type. valid types: ${Wn.join(", ")} (E: 838f4638a88cfbf3545a3a3a38b6dd24)`);let d;if(c&&c!=="undefined")if(Vn.includes(c))d=c;else throw new Error(`invalid spaceIb (${o}). spaceSubtype (${c}) is set but not a valid subtype. valid subtypes: ${Vn.join(", ")} (E: 5bdcf23027f94e73860e4340313b04ab)`);return{spaceClassname:n,spaceName:s,spaceId:a,spaceType:l,spaceSubtype:d}}catch(e){throw console.error(`${t} ${e.message}`),e}}f(jl,"parseSpaceIb");async function je({ibGibs:o,addrs:t,tjps:e,tjpAddrs:r,space:n}){let s=`[${je.name}]`;try{if(C&&console.log(`${s} starting...`),!n)throw new Error("space required. (E: 4d188d6c863246f28aa575753a052304)");if(o=o??[],t=t??[],e=e??[],r=r??[],t.length===0&&o.length===0&&e.length===0&&r.length===0)throw new Error("Either addrs, ibGibs, tjps, or tjpAddrs required. (E: 7c6ebfbab98d4d21a431b144457fd991)");let a=new Set(r.concat(e.map(l=>w({ibGib:l})))),i=Array.from(a).map(l=>H({ibGibAddr:l}).gib);o.map(l=>w({ibGib:l})).concat(t).forEach(l=>{let{gib:d}=H({ibGibAddr:l});i.some(h=>d.includes(h))||a.add(l)}),C&&console.log(`${s}[testing] ${n.data?.name||n.ib} (${n.data?.uuid||"[space.data.uuid falsy]"}) addrsToQuery: ${Array.from(a)} (I: 8a2202912c364238b6d6eb09577bc246)`);let c=await n.argy({ibMetadata:Gt({space:n}),argData:{cmd:"get",cmdModifiers:["latest","addrs"],ibGibAddrs:Array.from(a)}});return await n.witness(c)}catch(a){throw console.error(`${s} ${a.message}`),a}}f(je,"getLatestAddrs");function as({ibGib_Context:o}){let t=`[${as.name}]`;try{if(C&&console.log(`${t} starting... (I: 5f583fd94d27731a65d514e731b8aa22)`),!Pr({ibGib:o}))return;if(["roots","autosyncs"].some(r=>o.ib.includes(r)))throw new Error("cannot perform a modification of this type on this special ibgib (E: b8fb718a7323fc54454464b973412722)")}catch(e){throw console.error(`${t} ${e.message}`),e}finally{C&&console.log(`${t} complete.`)}}f(as,"throwIfContextIsSpecial");async function Xl({ibGib_Context:o,rel8nName_Context:t,addr:e,space:r,zeroSpace:n,fnUpdateBootstrap:s,fnBroadcast:a}){let i=`[${Xl.name}]`;try{if(C&&console.log(`${i} starting... (I: 2dc486bb2d516e4534f437aaf5ec7f22)`),!o)throw new Error("ibGib_Context required (E: 75f7bfa93145d6dffe85d488443ca722)");if(!t)throw new Error("rel8nName_Context required (E: 12aaa43de9e34b68b25dc9a2a68ad6b9)");if(!e)throw new Error("addr required (E: e27df3bdc5a2554697cc9597afc4e422)");if(!r)throw new Error("space required (E: 2e3562486ed2956a770ed9e8d77a3f22)");let c=Pr({ibGib:o});c&&as({ibGib_Context:o});let l=await Ce({src:o,rel8nsToAddByAddr:{[Ka]:[e]},rel8nsToRemoveByAddr:{[t]:[e]},dna:!0,nCounter:!0});if(await se({resTransform:l,space:r}),c){let d=w({ibGib:l.newIbGib}),b=$o({ib:o.ib}),h=fe({type:b});await _e({key:h,addr:d,space:r,zeroSpace:n,fnUpdateBootstrap:s})}await de({ibGib:l.newIbGib,fnBroadcast:a,space:r})}catch(c){throw console.error(`${i} ${c.message}`),c}finally{C&&console.log(`${i} complete.`)}}f(Xl,"trash");async function Hl({ibGib_Context:o,rel8nName_Context:t,addr:e,space:r,zeroSpace:n,fnUpdateBootstrap:s,fnBroadcast:a}){let i=`[${Hl.name}]`;try{if(C&&console.log(`${i} starting... (I: 38098552b830495187299bb24fcddff0)`),!o)throw new Error("ibGib_Context required (E: d819e8c4db5b4c0bb721300ba434cd40)");if(!t)throw new Error("rel8nName_Context required (E: de061adff8c04429a211aa09116a532d)");if(!e)throw new Error("addr required (E: 7059ebb8ef6149ea94e22f961d6b5c81)");if(!r)throw new Error("space required (E: e19566f2d42347798621447edcae312e)");let c=Pr({ibGib:o});c&&as({ibGib_Context:o});let l=await Ce({src:o,rel8nsToAddByAddr:{[qa]:[e]},rel8nsToRemoveByAddr:{[t]:[e]},dna:!0,nCounter:!0});if(await se({resTransform:l,space:r}),c){let d=w({ibGib:l.newIbGib}),b=$o({ib:o.ib}),h=fe({type:b});await _e({key:h,addr:d,space:r,zeroSpace:n,fnUpdateBootstrap:s})}await de({ibGib:l.newIbGib,fnBroadcast:a,space:r})}catch(c){throw console.error(`${i} ${c.message}`),c}finally{C&&console.log(`${i} complete.`)}}f(Hl,"archive");function ql(o){let t=`[${ql.name}]`;try{if(!o)return console.error(`${t} name is falsy`),!1;let e=/[\w-]+/,r=o.match(e);if(r?.length!==1||r[0].length!==o.length)return console.error(`${t} name can only contain letters, numbers, underscores, hyphens`),!1;let n=/[a-zA-Z\d]/;return o[0].match(n)?!0:(console.error(`${t} name must start with a letter or number`),!1)}catch(e){return console.error(`${t} ${e.message}`),!1}}f(ql,"spaceNameIsValid");var Ee=!1;async function ds({ibGib:o,rel8nNames:t,space:e}){let r=`[${ds.name}]`;try{if(!o)throw new Error("ibGib required (E: a3c1b2d4e5f6a7b8c9d0e1f2a3b4c5d6)");if(!e)throw new Error("space required (E: b4d2c3e4f5a6b7c8d9e0f1a2b3c4d5e6)");t||(t=Object.keys(o.rel8ns||{}));let n={};for(let s of t){let a=o.rel8ns?.[s]||[];if(a.length>0){let i=await B({addrs:a,space:e});if(i.success&&i.ibGibs?.length===a.length)n[s]=i.ibGibs.concat();else throw new Error(`Problem getting rel8d ibgibs for rel8nName: ${s}. ${i.errorMsg||"Unknown error"} (E: c5e3d4f5a6b7c8d9e0f1a2b3c4d5e6)`)}else n[s]=[]}return n}catch(n){throw console.error(`${r} ${E(n)}`),n}}f(ds,"getRel8dIbGibs");async function et({parentPrimitiveIb:o,ib:t,ibRegExpPattern:e,data:r,rel8ns:n}){let s=`[${et.name}]`;try{if(!o)throw new Error("parentPrimitiveIb required. (E: 88ddf188cc5a4340b597abefba1481e2)");if(br({ib:o})!==null)throw new Error(`Invalid parentPrimitiveIb: ${o}. (E:5aec0320956d492ebeeaca41eb1fe1c6)`);if(!t)throw new Error("ib required. (E: 7bbc88f4f2e842d6b00126e55b1783e4)");let a=e?new RegExp(e):Ra;if(!t.match(a))throw new Error(`invalid ib. does not match regexp (${a})`);let i=Object.keys(n??{}),c=[...Vt,"tjp"];if(i.some(h=>c.includes(h)))throw new Error(`Invalid rel8ns. forbiddenRel8nNames: ${c}. rel8ns keys: ${Object.keys(n??{})}. (E: 837a993c265c4362b6aa0b1a234ea5f8)`);let b=(await F.firstGen({ib:t,parentIbGib:F.primitive({ib:o}),data:r,rel8ns:n,dna:!1,noTimestamp:!0,nCounter:!1})).newIbGib;return b?.rel8ns?.past&&delete b.rel8ns.past,b?.rel8ns?.tjp&&delete b.rel8ns.tjp,b?.rel8ns?.identity&&delete b.rel8ns.identity,b.gib=await J({ibGib:{ib:b.ib,data:b.data,rel8ns:b.rel8ns},hasTjp:!1}),b}catch(a){throw console.error(`${s} ${a.message}`),a}}f(et,"constantIbGib");function ig({addr:o}){return Li({addr:o})}f(ig,"getBinHashAndExt");function Li({addr:o}){let t=`[${Li.name}]`;try{if(!Or({addr:o}))throw new Error("not a bin address (E: df0804d129bc4888bd6939cb76c5e0f6)");let{ib:e}=H({ibGibAddr:o}),r=e.split(" ");if(r.length===2)return{binHash:r[1],binExt:""};if(r.length===3)return r[2].startsWith("enc=")?{binHash:r[1],binExt:"",binEncoding:r[2].substring(4)}:{binHash:r[1],binExt:r[2]};if(r.length===4){if(!r[3].startsWith("enc="))throw new Error(`bin ib (${e}) has 4 space-delimited pieces. we expect therefore the form to be bin \${binHash} \${binExt} enc=\${binEncoding}. but ibPieces[3] doesn't start with "enc=". (E: 87196d7cdd7c12d982cc8204a1163524)`);return{binHash:r[1],binExt:r[2],binEncoding:r[3].substring(4)}}else throw new Error('(UNEXPECTED) ibPieces.length not 2, 3, or 4? atow (01/2024) the only components of a bin ib are: atom, binHash, binExt, binEncoding. binExt and binEncoding are optional, with binEncoding being prefixed with "enc=". (E: b05df3c1b3949f76464a83c9fd1c4f24)')}catch(e){throw console.error(`${t} ${e.message}`),e}}f(Li,"parseBinIb");function Or({ibGib:o,addr:t}){let e=`[${Or.name}]`;try{if(!o&&!t)throw new Error("either ibGib or addr required. (E: c935b51e773f41a2a547c556e9dc16c6)");if(o&&!o.data)return!1;t=t||w({ibGib:o});let{ib:r,gib:n}=H({ibGibAddr:t});if(!r||!n||!r.startsWith("bin "))return!1;if(n.length!==64)throw new Error('ib starts with "bin " but gib length is not 64, so return false. Two things: 1) bin ibgibs are expected to be stones, i.e., have no temporal junction point and only a single punctiliar hash for the gib. the default hash used atow (01/2024) is sha-256, so the length should be 64. But this may not be true if using another hash algorithm. need to change this function when this becomes the case. (W: 60725d65d13c4b4fbb7b96d7feb19d67)');let s=r.split(" ");if(s.length===2){if(!s[1].match(ce))throw new Error('(UNEXPECTED) ib starts with "bin " but space-delimited !ibPieces[1].match(UUID_REGEXP)? (E: f6baca2ff155f1017b278a5d7597a224)')}else if(s.length===3){if(!s[1].match(ce))throw new Error('(UNEXPECTED) ib starts with "bin " but space-delimited !ibPieces[1].match(UUID_REGEXP)? (E: 8d0443d6cada4b50be79a8390a7a426c)')}else if(s.length===4){if(!s[1].match(ce))throw new Error('(UNEXPECTED) ib starts with "bin " but space-delimited !ibPieces[1].match(UUID_REGEXP)? (E: 3209eacc0a3848a59593d4c3ee956191)');if(!s[3].startsWith("enc="))throw new Error('(UNEXPECTED) ib starts with "bin " but space-delimited !ibPieces[3].startsWith("enc=")? (E: 4c8a0c3b07a90d30e3d1a4373d57d824)')}else throw new Error('(UNEXPECTED) ib starts with "bin " but space-delimited ibPieces length is not 2, 3 or 4? (E: c7eccf88518304997c7e42b32e08d224)');return!0}catch(r){throw console.error(`${e} ${r.message}`),r}}f(Or,"isBinary");function is({type:o}){if(!o.match(Fn))throw new Error(`special ibgib type must not have spaces and just be alphanumerics. regexp: ${Fn.source} (E: 6c1c92521b7f076cc4666e4915593723)`);return`meta special ${o}`}f(is,"getSpecialIbGibIb");function $o({ib:o}){let t=`[${$o.name}]`;try{if(Ee&&console.log(`${t} starting... (I: c82ba222bd345ee6b695df4d63a23322)`),!o)throw new Error("ib required (E: 08897145f7138e644fe01c4a59353322)");if(!Pr({ib:o}))throw new Error("ib is not special (E: 174aff63b992adff3ac2394643735922)");let e=o.split(" ");if(e.length<3)throw new Error('invalid ib. should be space-delimited in form of "meta special [type]" (E: ffd89e2cbe63427f98634ab897aab222)');let r=e[2];return Object.values(oo).some(n=>n===r)||console.warn(`unknown special type (${r}). This may be expected, but atow I am adding special types to the SpecialIbGibType enum-like. (W: f4e26c3ebb57fe49d69014a4ba32a922)`),r}catch(e){throw console.error(`${t} ${e.message}`),e}finally{Ee&&console.log(`${t} complete.`)}}f($o,"getSpecialTypeFromIb");function Kl({type:o}){return`${is({type:o})}^${M}`}f(Kl,"getSpecialIbGibAddr");function fe({type:o}){return`${Wa} ${Kl({type:o})}`}f(fe,"getSpecialConfigKey");function Pr({ib:o,ibGib:t}){if(!o&&!t?.ib)throw new Error("either ib or ibGib.ib required (E: b4cf539638d7966c2e351987f55e1a23)");return(o??t?.ib)?.startsWith("meta special")}f(Pr,"isSpecial");function cs(o){let t=`[${cs.name}]`;if(!o)throw new Error(`${t} text required.`);return`root ${o}`}f(cs,"getRootIb");function Zt(o){let t=`[${Zt.name}]`;if(!o)throw new Error(`${t} tag required.`);return`tag ${o}`}f(Zt,"tagTextToIb");function ut({ibGibs:o,filterPrimitives:t}){let e=`[${ut.name}]`;try{let r={},n={},s={};return(t?o.filter(i=>i.gib??i.gib!==M):o).forEach(i=>{Pi({ibGib:i})?(i.rel8ns?.dna??[]).length>0?r[i.gib]=i:n[i.gib]=i:s[i.gib]=i}),{mapWithTjp_YesDna:r,mapWithTjp_NoDna:n,mapWithoutTjps:s}}catch(r){throw console.error(`${e} ${r.message}`),r}}f(ut,"splitPerTjpAndOrDna");function ze({ibGibs:o}){let t=`[${ze.name}]`;try{Ee&&console.log(`${t} starting...`);let{mapWithTjp_YesDna:e,mapWithTjp_NoDna:r}=ut({ibGibs:o,filterPrimitives:!0}),n={...e,...r},s=Object.values(n),a=An({items:s,keyFn:f(i=>i.data?.isTjp?w({ibGib:i}):i.rel8ns?.tjp?i.rel8ns?.tjp[0]??"":(Ee&&console.log(`${t} neither isTjp nor x.rel8ns.tjp truthy (I: ec9a5597bf53dec1bd3d83350abbf823)`),""),"keyFn")});return Ee&&console.log(`${t} sorting (ascending) ibGibsWithTjpGroupedByTjpAddr: ${P(a)} (I: 9b9fff5ce61444a6cb06d62db9a99422)`),Object.entries(a).forEach(([i,c])=>{c.some(l=>l.data?.n===void 0)&&console.warn(`${t} timeline includes ibgibs with ibGib.data?.n === undefined (W: cab9a6b64a38c4279fe82c3569bbab22)`),c.sort((l,d)=>(l.data?.n??-1)>(d.data?.n??-1)?1:-1)}),Ee&&console.log(`${t} after sort ibGibsWithTjpGroupedByTjpAddr: ${P(a)} (I: 9b9fff5ce61444a6cb06d62db9a99422)`),a}catch(e){throw console.error(`${t} ${e.message}`),e}finally{Ee&&console.log(`${t} complete.`)}}f(ze,"getTimelinesGroupedByTjp");function Pi({ibGib:o}){let t=`[${Pi.name}]`;if(!o)throw new Error("(UNEXPECTED) ibGib falsy? (E: ce3a59f9db14e6158bb2c438ca1a3823)");if((o.rel8ns?.tjp?.length??0)>0||o.data?.isTjp)return!0;let e=["fork^gib","mut8^gib","rel8^gib"];return(o.rel8ns?.ancestor??[]).some(n=>e.includes(n))?!1:o.gib?o.gib.includes(lt)?!0:o.gib===M?!1:!!ue({ibGibAddr:w({ibGib:o})}).tjpGib:(console.warn(`${t} ibGib.gib falsy. (W: 6400d780822b44d992846f1196509be3)`),!1)}f(Pi,"hasTjp");function Ie({ibGib:o,defaultIfNone:t="undefined"}){let e=`[${Ie.name}]`;try{let r=Ri({ibGibs:[o],defaultIfNone:t});return r&&Object.keys(r).length===1?Object.values(r)[0]:void 0}catch(r){throw console.error(`${e} ${r.message}`),r}}f(Ie,"getTjpAddr");function Ri({ibGibs:o,defaultIfNone:t="undefined"}){let e=`[${Ri.name}]`;try{let r={};return o.forEach(n=>{let s=w({ibGib:n}),a;n.rel8ns?.tjp?.length??!1?a=n.rel8ns.tjp[n.rel8ns.tjp.length-1]:n.data?.isTjp||t==="incomingAddr"?a=s:a=void 0,r[s]=a}),r}catch(r){throw console.error(`${e} ${r.message}`),r}}f(Ri,"getTjpAddrs");async function ls({ibGib:o,naive:t=!0}){let e=`[${ls.name}]`;try{if(!o)throw new Error("ibGib required.");if(t){if(o.data)return o.data.isTjp?!0:o.rel8ns?o.rel8ns.past&&o.rel8ns.past.length>0?!1:!!(o.rel8ns.past&&o.rel8ns.past.length===0):(Ee&&console.log(`${e} ibGib.rel8ns falsy (I: c69c9e78b34845311ce7c674d7195622)`),!1);throw new Error("loaded ibGib required (data).")}else throw new Error("only naive implemented right now.")}catch(r){throw console.error(`${e} ${r.message}`),r}}f(ls,"isTjp_Naive");function Ne({ibGib:o}){let t=`[${Ne.name}]`;o.ib||console.warn(`${t} ibGib.ib is falsy. (W: e60e41c2a1fc48268379d88ce13cb77b)`),o.gib||console.warn(`${t} ibGib.gib is falsy. (W: fb3889cbf0684ae4ac51e48f28570377)`);let e={ib:(o.ib||"").slice()};return o.gib&&(e.gib=o.gib.slice()),o.data&&(Or({ibGib:o})?e.data=o.data.slice():e.data=L(o.data)),o.rel8ns&&(e.rel8ns=L(o.rel8ns)),e}f(Ne,"toDto");function Rr(o){let t=`[${Rr.name}]`;try{return Ee&&console.log(`${t} starting... (I: 57aef93fc6cc2309523b5c72a6b11823)`),!!o&&typeof o.ib=="string"}catch(e){throw console.error(`${t} ${e.message}`),e}finally{Ee&&console.log(`${t} complete.`)}}f(Rr,"isIbGib");function Ut({ibGib:o,data:t,timestamp:e}){let r=`[${Ut.name}]`;try{Ee&&console.log(`${r} starting... (I: 35cb68744bcf6139d78e37de644fad23)`),e=e||t?.timestamp||o?.data?.timestamp;let n=o?.data?.timestampMs||t?.timestampMs;if(!e){let s=`${r} timestamp is falsy. (W: 5f1f1182c8804807b886a3d922ac3dcf)`;return console.warn(s),{valid:!1,emsg:s}}if(typeof e=="string")if(Number.isInteger(Number.parseInt(e))){let s=Number.parseInt(e),a=new Date;if(a.setTime(s),a.toString()!==so)return Ee&&console.log(`${r} valid timestampInTicks string (I: 7069a1c3047f3bbc92b78674b20f5b23)`),{valid:!0,date:a,utc:a.toUTCString(),ticks:a.getTime().toString(),ms:n};{let i=`${r} data.timestamp (${e}) is an integer string but not a valid timestampInTicks string. (produces invalid date) (E: f49fbb600fe1426c8805dfc8afbe5cf3)`;return console.error(i),{valid:!1,emsg:i}}}else{let s=new Date(e);if(s.toString()!==so)return{valid:!0,date:s,utc:s.toUTCString(),ticks:s.getTime().toString(),ms:n};{let a=`${r} data.timestamp is a non-integer string but not a valid date timestamp string (new date instantiated produces invalid date). (W: c6c90f7f3bfb49838d2081ba84fdb5fb)`;return console.warn(a),{valid:!1,emsg:a}}}else if(typeof e=="number")if(Number.isInteger(e)){console.warn(`${r} expected data.timestamp to be a string but is a number (W: 9d786f4d4e8d4279b5af7bee19bf721b)`);let s=new Date;if(s.setTime(e),s.toString()!==so)return{valid:!0,date:s,utc:s.toUTCString(),ticks:s.getTime().toString(),ms:n};{let a=`${r} timestamp (${e}) is an integer number but not a valid timestampInTicks (new date setTime produces invalid date). (W: c6c90f7f3bfb49838d2081ba84fdb5fb)`;return console.warn(a),{valid:!1,emsg:a}}}else{let s=`${r} timestamp (${e}) is a non-integer number (supposed to be a string either timestamp string or ticks). (E: 2963d95f8d3b464c992b0bff948b4479)`;return console.error(s),{valid:!1,emsg:s}}else{let s=`${r} unknown typeof timestamp (${typeof e}). (E: 12458a9c16c84e4f859b5771a30dd2ef)`;return console.error(s),{valid:!1,emsg:s}}}catch(n){throw console.error(`${r} ${E(n)}`),n}finally{Ee&&console.log(`${r} complete.`)}}f(Ut,"getTimestampInfo");async function Xe({addrs:o,readCache_graph:t,readCache_array:e,space:r}){let n=`[${Xe.name}]`;try{Ee&&console.log(`${n} starting... (I: 5db66871239dfa05182277f886a20926)`),t??={},e??=[];let s={...t};e.forEach(l=>s[w({ibGib:l})]=l);let a=Object.keys(t),i=o.filter(l=>!a.includes(l));if(i.length>0){Ee&&console.log(`${n} ${i.length} addrsNotFoundInCache: ${i} (I: fccbd18116ffb849f813aaebfc6c0826)`);let l=[r],d=i.concat();for(let b of l){let h=await B({addrs:d,space:b});if(h.success&&h.ibGibs&&h.ibGibs.length===d.length)h.ibGibs.forEach(p=>s[w({ibGib:p})]=p),d=[];else if(h.ibGibs&&h.ibGibs.length>0){if(d=d.filter(p=>!h.ibGibs.some(u=>w({ibGib:u})===p)),d.length===0)break}else Ee&&console.log(`${n} no addrs found in space (${b.ib}). trying next space. (I: 4f99d8bacbb10ab3f8737a752564b326)`)}if(d.length>0)throw new Error(`could not get all addrs from cache or spaces. addrsStillNotFound: ${d}. spaces: ${l.map(b=>b.ib).join("|")} (E: 0c6418f83dd85bda886e56f5b98f3126)`)}let c=[];for(let l of o){let d=s[l];if(!d)throw new Error(`(UNEXPECTED) allIbGibs_graph doesn't have addr? We're expecting logic to preclude this at this point. addr: ${l} (E: f68e1d236ae5e3eb08da9933c8230626)`);c.push(d)}return c}catch(s){throw console.error(`${n} ${E(s)}`),s}finally{Ee&&console.log(`${n} complete.`)}}f(Xe,"getIbGibsFromCache_fallbackToSpaces");var Ur=!1,Yl="space_gib_db",Wl="space_gib_store",Vl="space_gib_api_key";var zl="agent";var bg=Zt(zl);var hg={dbName:Yl,storeName:Wl,additionalStoreNames:[Ua],apiKeyName:Vl};var Ui="0.0.3";var kt=!1,Eg="[web^gib timer]",fs="ibgib";var Jl="agent",mg="body-outline",wg="This tag tracks the active agents for the current local user space.",yg=Zt(Jl),ki="#78f87e88",Mi="#78f87e10",Fi="#ffffff";var $g="AUTOMATED_TEXT";var tt=!1;function Bi(o){return new Promise((t,e)=>{let r=new Blob([o],{type:"application/octet-stream"}),n=new FileReader;n.onload=()=>{let a=n.result.split(",")[1];t(a)},n.onerror=s=>e(s),n.readAsDataURL(r)})}f(Bi,"uint8ArrayToBase64");async function ji(o){let t=`data:application/octet-stream;base64,${o}`,n=await(await(await fetch(t)).blob()).arrayBuffer();return new Uint8Array(n)}f(ji,"base64ToUint8Array");async function Io({graph:o}){let t=`[${Io.name}]`;try{tt&&console.log(`${t} starting... (I: 4ddb8803cf68e1d3d35f60680cb69825)`);let e=JSON.parse(JSON.stringify(o));for(let n in e)o[n].data instanceof Uint8Array&&(e[n].data={_dataType:"Uint8Array_Base64",value:await Bi(o[n].data)});let r=JSON.stringify(e);return tt&&console.log(`${t} jsonString.length: ${r.length} (I: 56dec8ad0931ab8ba9b5ca3d4e66be25)`),r}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{tt&&console.log(`${t} complete.`)}}f(Io,"serializeGraphToString");async function _o({jsonString:o}){let t=`[${_o.name}]`;try{tt&&console.log(`${t} starting... (I: 52e1a1fb1adcc75168fbc6d819868825)`);let r=JSON.parse(o,f((n,s)=>(s&&s._dataType==="Uint8Array_Base64",s),"reviver"));for(let n in r){let s=r[n].data;s&&s._dataType==="Uint8Array_Base64"&&(r[n].data=await ji(s.value))}return r}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{tt&&console.log(`${t} complete.`)}}f(_o,"deserializeStringToGraph");async function Xi(o){let t=`[${Xi.name}]`;try{tt&&console.log(`${t} starting... (I: 8d306868b718596fe8f562bd5118d825)`);let e=await Io({graph:o}),r=new TextEncoder().encode(e),s=new Response(r).body.pipeThrough(new CompressionStream("gzip"));return await new Response(s).blob()}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{tt&&console.log(`${t} complete.`)}}f(Xi,"compressIbGibToBlob");async function Zl(o){let t=o.stream().pipeThrough(new DecompressionStream("gzip")),e=await new Response(t).text();return await _o({jsonString:e})}f(Zl,"decompressIbGibFromBlob");async function bs({graph:o}){let t=`[${bs.name}]`;try{tt&&console.log(`${t} starting... (I: 1352f8540c08f0b725952df8f18c4825)`);let r=await(await Xi(o)).arrayBuffer(),n=new Uint8Array(r);return await Bi(n)}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{tt&&console.log(`${t} complete.`)}}f(bs,"compressIbGibGraphToString");async function hs({compressedBase64:o}){let t=`[${hs.name}]`;try{tt&&console.log(`${t} starting... (I: 5f3fa940a2c8f8d7b877978ae7f87825)`);let e=await ji(o),r=new Blob([e],{type:"application/gzip"});return await Zl(r)}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{tt&&console.log(`${t} complete.`)}}f(hs,"decompressIbGibGraphFromString");var Hi="export";var kr=!1;function qi({data:o}){let t=`[${qi.name}]`;try{kr&&console.log(`${t} starting... (I: 158dfaeb9613a1531be71a9735184624)`);let{graphSize:e,dependencyGraphAsString:r,timestamp:n}=o,s=r.length,a=Me(n),i=o.compression==="gzip"?"gzip":"raw";if(!o.timestamp)throw new Error("(UNEXPECTED) data.timestamp falsy? (E: 2f5bc88488cbf260634239a8a8396825)");let c=new Date(o.timestamp),{ib:l,gib:d}=H({ibGibAddr:o.contextIbGibAddr}),h=ue({gib:d}).tjpGib??d,p=c.toISOString().slice(0,19).replace("T","_").replace(/:/g,"").replace(/ /g,"_");return`${Hi} ${p} ${i} ${e} ${s} ${h}`}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{kr&&console.log(`${t} complete.`)}}f(qi,"getRawExportIb");async function ps({ibGib:o,metaspace:t,space:e,compress:r,live:n,ignoreErrors:s}){let a=`[${ps.name}]`;try{if(kr&&console.log(`${a} starting... (I: 0b6ba8608ba8bde0682a0936b9a01825)`),!o)throw new Error("(UNEXPECTED) ibGib falsy? (E: d2898eea744360865f0da5fb91baae22)");let i=w({ibGib:o}),c=[],l=await Z({ibGib:o})??[];if(l.length>0){let $=`ibGib had validation errors: ${l} (E: 84890bbc0598192498178a98ae299825)`;if(s)c.push({errorMsg:$,ibGibAddr:i});else throw new Error($)}let d=await t.getDependencyGraph({ibGib:o,live:n,space:e}),b=r?await bs({graph:d}):await Io({graph:d}),h=Ie({ibGib:o,defaultIfNone:"incomingAddr"})??i,p=new Date,u={contextIbGibAddr:i,tjpAddr:h,dependencyGraphAsString:b,graphSize:Object.keys(d).length,timestamp:Ge(p),timestampMs:p.getMilliseconds()};r&&(u.compression="gzip");let g={ib:qi({data:u}),data:u},m=await J({ibGib:g,hasTjp:!1});return g.gib=m,console.log(`${a} JSON.stringify(exportIbGib).length: ${JSON.stringify(g).length} (I: db3a8d913a91d8fc5d6e45981e034822)`),{rawExportIbGib:g,manifest:Object.keys(d),errors:c.length>0?c:void 0}}catch(i){throw console.error(`${a} ${E(i)}`),i}finally{kr&&console.log(`${a} complete.`)}}f(ps,"getRawExportIbGib");var Ki=kt;async function ur(o){let t=`[${ur.name}]`;try{Ki&&console.log(`${t} starting... (I: 037b228a2568181cd3eb25dba4e03225)`);let e=document.getElementById("fullscreen-dialog"),r=document.getElementById("fullscreen-dialog-body"),n=document.getElementById("fullscreen-dialog-title"),s=document.getElementById("fullscreen-dialog-message"),a=document.getElementById("fullscreen-dialog-prompt-input"),i=document.getElementById("fullscreen-dialog-ok-button"),c=document.getElementById("fullscreen-dialog-cancel-button");if(!e||!r||!n||!s||!a||!i||!c)throw new Error("(UNEXPECTED) One or more dialog elements not found in DOM (E: 578e37c0271cc57a99e95e780ad18a25)");n.textContent=o.title||"",[...s.childNodes].forEach(b=>s.removeChild(b)),(o.msg||"").split(`
|
|
9
|
+
`).forEach(b=>{let h=document.createElement("p");h.textContent=b,s.appendChild(h)}),a.classList.remove("collapsed"),c.classList.remove("collapsed"),c.style.display="inline-block",i.textContent=o.okButtonTitle||"OK";let d=f(b=>{(b.key==="Enter"||b.key===`
|
|
10
|
+
`)&&b.ctrlKey&&i.click()},"onKeypress");return o.prompt||o.showInput?(a.addEventListener("keypress",d),o.showInput?(a.autofocus=!0,a.value=o.defaultValue??"",a.addEventListener("keypress",b=>{b.key==="Enter"&&i.click()}),o.isPassword?(a.type="password",a.autocomplete="off",a.required=!0):(a.type="text",a.autocomplete="on",a.required=!1,a.attributes["auto-complete"]="on")):(a.autofocus=!1,a.classList.add("collapsed")),c.textContent=o.cancelButtonTitle||"Cancel"):(a.classList.add("collapsed"),c.style.display="none"),new Promise(b=>{let h=f(()=>{(o.prompt||o.showInput)&&a.removeEventListener("keypress",d),i.removeEventListener("click",p),c.removeEventListener("click",u),e.removeEventListener("close",g)},"removeEventListeners"),p=f(()=>{h();let m=o.showInput?a.value??"":"true";a&&(a.value=""),e.close(m),b(m)},"onOK"),u=f(()=>{h(),a&&(a.value=""),e.close(void 0),b(void 0)},"onCancel"),g=f(()=>{h(),a&&(a.value=""),e.close(void 0),b(void 0)},"onClose");i.addEventListener("click",p),c.addEventListener("click",u),e.addEventListener("close",g),e.showModal(),pe(1e3).then(()=>{r.scrollTo({top:0,behavior:"smooth"})})})}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{Ki&&console.log(`${t} complete.`)}}f(ur,"showFullscreenDialog");var ge=kt;async function Ql({metaspace:o,space:t}){let e=`[${Ql.name}]`;try{ge&&console.log(`${e} starting... (I: 2ccb79537a75e7896bace84e6c710d25)`);let r=await o.getSpecialIbGib({type:oo.tags,space:t});if(!r)throw new Error(`tagsIbGib not found in metaspace. space: ${t?t.ib:"default local user space"} (E: 4734c510a411274315c0add8f70e1925)`);return r}catch(r){throw console.error(`${e} ${E(r)}`),r}finally{ge&&console.log(`${e} complete.`)}}f(Ql,"getTagsIbGib");function gs({scope:o,ibGib:t,ibGibAddr:e,defaultNameIfError:r}){let n=`[${gs.name}]`;try{if(!t&&!e)throw new Error(`${n} Must provide either ibGib or ibGibAddr. (E: genuuid)`);o.includes(" ")&&(console.warn(`${n} scope includes one or more spaces. These will be converted to double underscores. (W: 1554a81454e8ae0a6858ea5dd17f8925)`),o=o.replace(/ /g,"__"));let s,a,i;if(t){if(!t.data)throw new Error("(UNEXPECTED) ibGib.data falsy? (E: genuuid)");if(!t.rel8ns)throw new Error("(UNEXPECTED) ibGib.rel8ns falsy? (E: genuuid)");if(!t.rel8ns.ancestor)throw new Error("(UNEXPECTED) ibGib.rel8ns.ancestor falsy? (E: genuuid)");if(t.rel8ns.ancestor.length===0)throw new Error("(UNEXPECTED) ibGib.rel8ns.ancestor.length === 0? there should be at least one ancestor (E: genuuid)");if(t&&e&&w({ibGib:t})!==e)throw new Error("(UNEXPECTED) both ibGib and ibGibAddr provided, but addr of ibGib doesn't equal ibGibAddr? (E: genuuid)");let d=t.rel8ns.ancestor.filter(h=>ie({gib:H({ibGibAddr:h}).gib}));if(d.length===0){debugger;console.error(`${n} ibGib has no primitive ancestor addrs? Still going to work off of the ib then, which should have the atom as the first space-delimited term. (E: genuuid)`)}let b=d.at(-1);s=H({ibGibAddr:b}).ib,i=s}e??=w({ibGib:t});let{ib:c}=H({ibGibAddr:e});if(a=c.split(" ").at(0)??"",a=a.replace(/\W/g,"_"),s??=a,s=s.replace(/\W/g,"_"),!s&&!a)throw new Error("(UNEXPECTED) both primitiveAncestorIb and atom falsy? one should be truthy at this point. (E: genuuid)");i=a.toLowerCase(),ge&&console.log(`${n} ancestorIbOrAtom: ${i} (I: genuuid)`);let l=`${i}_${o}index`;return ge&&console.log(`${n} indexName: ${l} (I: genuuid)`),l}catch(s){if(r)return console.warn(`${n} error happened but defaultNameIfError (${r}) provided. So will return this value. error that was thrown: ${E(s)}`),r;throw console.error(`${n} ${E(s)}`),s}}f(gs,"getIndexNameFromIbGib");async function ed({scope:o,ibGib:t,metaspace:e,space:r,skipGetLatest:n}){let s=`[${ed.name}]`;try{if(ge&&console.log(`${s} starting... (I: f19dc86aab380fe809aef27ccc7a7425)`),!o)throw new Error("scope required to be a non-empty string (E: 73e702495c38c7d8747d1cf8850af825)");if(!t)throw new Error("ibGib required (E: genuuid)");let a=gs({scope:o,ibGib:t}),i=Ie({ibGib:t,defaultIfNone:"incomingAddr"}),c=f(async()=>{let d=await e.getSpecialIbGib({type:a,space:r,initialize:!1,dontWarnIfNotExist:!0,lock:!0});if(!d||!d.data){ge&&console.log(`${s} special ${o} index ibGib not found for indexSpecialIbGibType (${a}). No coupled ibgib registered, returning undefined. (I: genuuid)`);return}let h=(d.data.coupleMap??d.data.agentMap??{})[i];if(!h){ge&&console.log(`${s} No coupled ${o} ibgib address found for domain ${i} in the coupled index map. indexSpecialIbGibType: ${a}. returning undefined. (I: genuuid)`);return}let p=n?h:await e.getLatestAddr({addr:h,space:r})??h,u=await e.get({addrs:[p],space:r});if(u.errorMsg||(u.ibGibs??[]).length!==1)throw new Error(`couldn't get latest coupled ibgib (${p}) for domain ${i}. (E: 8aa7b25f5cd4ebadd8bf2f8807dfe825)`);return u.ibGibs[0]},"fn");return await ht({scope:a,secondsValid:180,maxDelayMs:100,maxLockAttempts:1800,space:r,callerInstanceId:s+Me(),fn:c})}catch(a){throw console.error(`${s} ${E(a)}`),a}finally{ge&&console.log(`${s} complete.`)}}f(ed,"getLocalCoupledIbGibForDomainIbGib");async function td({scope:o,domainIbGib:t,localIbGib:e,metaspace:r,space:n}){let s=`[${td.name}]`;try{ge&&console.log(`${s} starting... (I: 217ae68e0c820e48f4c00409f7f14325)`);let a=gs({scope:o,ibGib:t}),i=Ie({ibGib:t}),c=w({ibGib:e});if(!i)throw new Error(`${s} Could not get TJP address for domain ibGib. (E: 35a4e8ac291b0b85cb958e28dd812f25)`);if(!c)throw new Error(`${s} Could not get address for agent ibGib. (E: 2fce1187630b45934c4155a23204d125)`);await ht({scope:a,secondsValid:60,maxDelayMs:100,maxLockAttempts:600,space:n,fn:f(async()=>{let d=await r.getSpecialIbGib({type:a,space:n,initialize:!0,dontWarnIfNotExist:!0,lock:!1});if(!d)throw new Error(`${s} Could not get or create agent index ibGib.`);if(!d.data)throw new Error("(UNEXPECTED) agentSpecialIndex.data falsy? (E: 74299eed147debf6398ca37e7b8d5c25)");let b=d.data.coupleMap??d.data.agentMap,h=b?L(b):{},p=h[i];if(p)if(p===c){ge&&console.log(`${s} domain ibGib (${i}) already mapped to agent (${c}). returning early (I: cb5d4dcef8cf14de7336120fb8ffef25)`);return}else console.warn(`${s} domainTjpAddr (${i}) already assigned to existingMappedAgentAddr (${p}). We will be changing to new localAddr (${c}). (W: eb993e33f7731e570fa76f24a2d80625)`);h[i]=c;let u=await Fe({src:d,dataToAddOrPatch:{coupleMap:h},dna:!1,linkedRel8ns:[te.past],nCounter:!0}),g=u.newIbGib;await se({resTransform:u,space:n});let m=fe({type:a});await r.setConfigAddr({key:m,addr:w({ibGib:g}),space:n}),await r.registerNewIbGib({ibGib:g,space:n})},"fn")}),ge&&console.log(`${s} Registered domain ${i} with agent ${c}`)}catch(a){throw console.error(`${s} ${E(a)}`),a}finally{ge&&console.log(`${s} complete.`)}}f(td,"coupleDomainIbGibWithLocalIbGibViaIndex");function Qt(){let o=`[${Qt.name}]`;try{ge&&console.log(`${o} starting... (I: 890f53e984d69461d9f4ded8741fcc25)`);let t=globalThis[fs];return t||(console.log(`${o} initializing globalThis.${fs}... (I: 9d9ff1813448d9a1b82b0e5790a74825)`),t={}),t}catch(t){throw console.error(`${o} ${E(t)}`),t}finally{ge&&console.log(`${o} complete.`)}}f(Qt,"getIbGibGlobalThis_IbGib");async function He({delayIntervalMs:o=50}={delayIntervalMs:50}){let t=`[${He.name}]`;try{ge&&console.log(`${t} starting... (I: 4acc22d08dd1100503f9b0423f302925)`);let e;for(;!e;)Qt().metaspace&&(e=Qt().metaspace),e||(console.log(`${t} metaspace still not initialized. delayIntervalMs: ${o} until next retry... (I: 490f77ac4ded1d7d3c0340e460404125)`),await pe(o));return e}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{ge&&console.log(`${t} complete.`)}}f(He,"getGlobalMetaspace_waitIfNeeded");function rd({ibGibAddr:o,gib:t,ibGib:e,translucentAlpha:r=10}){let n=`[${rd.name}]`;try{ge&&console.log(`${n} starting... (I: 3b70af42d1c4f6ae91870f3a15c6c625)`),!o&&!t&&!e&&(t=M),t??=e?.gib??H({ibGibAddr:o}).gib;let s=ue({gib:t});r??=10;let a="";if(s.isPrimitive)return{gib:t,gibInfo:s,punctiliarColor:ki,punctiliarColorTranslucent:Mi,punctiliarColorContrast:Fi};a=s.tjpGib??s.punctiliarHash??t;let[i,c,l]=Yi(r,s.punctiliarHash??t),[d,b,h]=s.tjpGib?Yi(r,s.tjpGib):[void 0,void 0,void 0];return{gib:t,gibInfo:s,punctiliarColor:i,punctiliarColorTranslucent:c,punctiliarColorContrast:l,tjpColor:d,tjpColorTranslucent:b,tjpColorContrast:h}}catch(s){let a=`${n} ${E(s)}`;return console.error(a),{gib:t??M,gibInfo:{isPrimitive:!0},punctiliarColor:"#ff0000",punctiliarColorTranslucent:"#ff000010",punctiliarColorContrast:"#ffffff",errorMsg:a}}finally{ge&&console.log(`${n} complete.`)}}f(rd,"getDeterministicColorInfo");function Yi(o,t){function e(i){let c=i.concat().replace("#","");var l=parseInt(c.substr(0,2),16),d=parseInt(c.substr(2,2),16),b=parseInt(c.substr(4,2),16),h=(l*299+d*587+b*114)/1e3;return h>=128?"#000000":"#FFFFFF"}f(e,"getContrastColor");let r="";if(o||o===0){if(o<0||o>100)throw new Error("alpha must be between 0 and 100 (E: c78faeb1477482c739b03dd32d2e1825)");o===100?r="":o>=0&&o<10?r=`0${o}`:r=o.toString()}let n=`#${t.substring(0,6)}`,s=`#${t.substring(0,6)}${r}`,a=e(n);return[n,s,a]}f(Yi,"getColorStrings");var De=kt;function Vi(o){return new TextDecoder().decode(o)}f(Vi,"uint8ArrayToString");var Wi=class o{static{f(this,"PathUtilsHelper")}lc=`[${o.name}]`;constructor(){}isAbsolute(t){if(!t)throw new Error("(UNEXPECTED) path falsy? (E: dcb92e11770ba06205c0afe3e6560b24)");return t.startsWith("/")}isRelative(t){return!this.isAbsolute(t)}join(...t){let e=`${this.lc}[${this.join.name}]`;if(t.length===0)return console.log(`${e} paths.length === 0. returning '.' per node convention. (I: 153da80765ff6160675fae895ebac225)`),".";if(t.length===1&&t[0]==="..")return console.log(`${e} paths.length === 1 && paths[0] === '..'. returning '..' per node convention. (I: 9af242b7615430a8c6899b1a332e9925)`),"..";let r="";for(let n=0;n<t.length;n++){let s=t[n];s===".."?r=r.split("/").slice(0,-1).join("/"):(s.startsWith("/")&&(s=s.slice(1)),s.endsWith("/")&&(s=s.slice(0,-1)),r+=(n>0?"/":"")+s)}return r}dirname(t){return t.split("/").slice(0,-1).join("/")}basename(t,e){return t.split("/").pop()??""}};async function od({msg:o,title:t,confirm:e,noNewLine:r,rl:n,defaultValue:s,dontCloseRl:a,cancelable:i}){let c=`[${od.name}]`;try{if(!o)throw new Error("msg required (E: 7f4d67bca4cf98ea95fa110aabc98924)");let l,d=0,b=5;do{if(d++,d>=b)throw new Error("max attempts reached (E: 1ef20ae955622d4b39479f3da91a1d25)");await pe(50),l=await ur({title:t||"Prompt for Info",msg:o,prompt:!0,showInput:!0,isPassword:!1,defaultValue:s})}while(l===void 0&&!i);return l??""}catch(l){debugger;throw console.error(`${c} ${E(l)}`),l}}f(od,"promptForText");async function nd({msg:o,confirm:t}){let e=`[${nd.name}]`;try{De&&console.log(`${e} starting... (I: 795a4ce348ddb9a5119770f4c572ac24)`);let r,n=!0,s=0,a=5;do{if(s++,s>=a)throw new Error("max attempts reached (E: d4166b4bf37aff0c6d44567792e9ad25)");if(await pe(50),r=await ur({title:n?"Shh...":"Secrets didn't match, try again...",msg:o||"Enter Your Secret...",prompt:!0,showInput:!0,isPassword:!0,defaultValue:void 0}),r===void 0)throw new Error("user cancelled (E: 91519d04378e84106f3df8eb36d99725)");if(t){await pe(250);let i=await ur({title:"Shh...",msg:"Confirm...",prompt:!0,showInput:!0,isPassword:!0,defaultValue:void 0});i===void 0&&(r=void 0),r!==i&&(r=void 0,n=!1,await pe(250))}}while(r===void 0);return r}catch(r){throw console.error(`${e} ${E(r)}`),r}finally{De&&console.log(`${e} complete.`)}}f(nd,"promptForSecret");async function sd({msg:o,title:t,skipHitEnterToContinue:e}){let r=`[${sd.name}]`;try{if(!o)throw new Error("msg required (E: ffcf7dd00324df7cea2792223d229524)");try{t??="",await pe(50),await ur({title:t,msg:o})}catch(n){throw n}}catch(n){throw console.error(`${r} ${E(n)}`),n}}f(sd,"alertUser");async function ad({exportIbGibJsonString:o,metaspace:t}){let e=`[${ad.name}]`;try{debugger;if(De&&console.log(`${e} starting... (I: genuuid)`),!t)throw new Error("(UNEXPECTED) metaspace falsy? (E: genuuid)");if(!await t.getLocalUserSpace({lock:!1}))throw new Error("(UNEXPECTED) couldn't get default local user space? (E: genuuid)");let n,s;try{n=JSON.parse(o)}catch(l){let d=`Error during parse JSON. error: ${E(l)} (E: genuuid)`,b=new Error(d);throw b.cause=l,b}try{let l=await Z({ibGib:n})??[];if(l.length>0)throw new Error(`validation errors when validating the parsed ibgib that should be a RawExportIbGib_V1: ${l} (E: 8ba178d3b26e8eca28a67c182fe16825)`);if(s=n,!s.data)throw new Error("(UNEXPECTED) rawExportIbGib.data falsy? (E: ef1824d1cca5584ab8e34288346e9825)")}catch(l){let d=`Error during parse JSON. error: ${E(l)} (E: genuuid)`,b=new Error(d);throw b.cause=l,b}let a;if(s.data.compression)switch(s.data.compression){case"gzip":a=await hs({compressedBase64:s.data.dependencyGraphAsString});break;default:throw new Error(`unknown value of rawExportIbGib.data.compression: ${s.data.compression} (E: 784672fae568312d887ddbb841199925)`)}else a=await _o({jsonString:s.data.dependencyGraphAsString});let i={};for(let[l,d]of Object.entries(a)){let b=await Z({ibGib:d})??[];b.length>0&&(i[l]=b)}if(Object.keys(i).length>0)throw new Error(`there were validation errors for the RawExportIbGib_V1.data payload (contained in data.dependencyGraphAsString). Here is the validationErrorMap:
|
|
11
|
+
${P({validationErrorMap:i})} (E: e63f38b182a84122d83a55befb369825)`);return[s,a]}catch(r){throw console.error(`${e} ${E(r)}`),r}finally{De&&console.log(`${e} complete.`)}}f(ad,"getRawExportIbGibAndGraphFromJsonString");async function id({ibGib:o,compress:t,metaspace:e,space:r}){let n=`[${id.name}]`;try{if(De&&console.log(`${n} starting... (I: 623d9463d919683be81f749821a95825)`),ie({ibGib:o}))throw new Error("ibGib is primitive. Can't export primitive. (E: dd42c42e9fda0707e81c692af1a2a225)");let s=await ps({ibGib:o,live:!0,compress:t,metaspace:e,space:r}),{rawExportIbGib:a,errors:i}=s;if((i??[]).length>0)throw new Error(`Export had errors: ${i} (E: 05faf83f25d3449ab809dfd24eeaf825)`);let c=JSON.stringify(a),l="data:text/json;charset=utf-8,"+encodeURIComponent(c),b=`${w({ibGib:a})}.json`,h=document.createElement("a");h.setAttribute("style","none"),h.setAttribute("href",l),h.setAttribute("download",b);let p=document.getElementsByTagName("div")[0];p.appendChild(h),h.click(),p.removeChild(h)}catch(s){throw console.error(`${n} ${E(s)}`),s}finally{De&&console.log(`${n} complete.`)}}f(id,"exportIbGib");function cd(){let o=`[${cd.name}]`;try{De&&console.log(`${o} starting... (I: 62a29f9982b4b5ecd91ff58ca4dd6825)`);let t=Qt();if(!t.storeName_hack)throw new Error("(UNEXPECTED) global store name falsy? (E: 3b9b680f6a980debbb877c9a13fb2625)");return t.storeName_hack}catch(t){throw console.error(`${o} ${E(t)}`),t}finally{De&&console.log(`${o} complete.`)}}f(cd,"getGlobalStoreName");function ld(){let o=`[${ld.name}]`;try{De&&console.log(`${o} starting... (I: 8c8f08728fc7384f87697377358cc825)`);let t=Qt();if(!t.dbName_hack)throw new Error("(UNEXPECTED) global db name falsy? (E: 3aa028d5e4088f3f3841aae94ac02825)");return t.dbName_hack}catch(t){throw console.error(`${o} ${E(t)}`),t}finally{De&&console.log(`${o} complete.`)}}f(ld,"getGlobalDbName");function dd(){let o=`[${dd.name}]`;try{De&&console.log(`${o} starting... (I: 59a2510a85051f97ed15fbc8825b6825)`);let t=Qt();if(!t.apiKeyName_hack)throw new Error("(UNEXPECTED) global api key name falsy? (E: 1782e812f0c87f54b8059468a5b60125)");return t.apiKeyName_hack}catch(t){throw console.error(`${o} ${E(t)}`),t}finally{De&&console.log(`${o} complete.`)}}f(dd,"getGlobalIndexedDbKey_APIKey");async function Es({infos:o}){let t=`[${Es.name}]`;try{De&&console.log(`${t} starting... (I: 4d41880fb748ee2302a624a255665825)`);for(let e of o){let{dbName:r,storeNames:n}=e;await ws({dbName:r})||await Ao({dbName:r});for(let a of n)await ms({dbName:r,storeName:a})}}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{De&&console.log(`${t} complete.`)}}f(Es,"initAppStorage");var Le=kt,zi=0;async function Ao({dbName:o,storeName:t,version:e,logalot:r=!1}){let n=`[${Ao.name}][${o}][${t??"no store name"}]`,s=crypto.randomUUID();r&&console.time(n+s);let a;try{r&&console.log(`${n} starting... (I: f35d4e1ba37252f14c8532fb861b1125)`),await new Promise((c,l)=>{try{r&&console.log(`${n} starting... (I: 0aeddd9376daa0a044677ce4cf8a4c24)`),r&&console.timeLog(n+s,"opening... (I: e748b4ddb445d77cb10a7ba158b49125)");let d=indexedDB.open(o,e);zi++,console.log(`${n} initRequestCount: ${zi} (I: 294d5f0b12ffe5512bacebe891824d25)`);let b;d.onupgradeneeded=h=>{try{a=h.target.result,r&&console.timeLog(n+s,"onupgradeneeded... (I: e748b4ddb445d77cb10a7ba158b49125)"),t&&(a.objectStoreNames.contains(t)?b=!0:(b=!1,a.createObjectStore(t,{keyPath:"key"})))}catch(p){console.error(`${n}[openDBRequest.onupgradeneeded] ${E(p)} (E: 4a5fa1b0850be47e28bee653da287325)`),l(p)}},d.onblocked=h=>{console.log(`${n}[openDBRequest.onblocked] openDBRequest blocked...time wasted a bit here. version change event (old -> new): ${h.oldVersion} -> ${h.newVersion} (I: 9074ebf4afdba54d6f9d41b360b96a25)`),console.dir(h)},d.onsuccess=h=>{try{r&&console.log("init success (I: 297a5a71e405a0b56413af813f248d24)"),r&&console.timeLog(n+s,"onupgradeneeded... (I: e748b4ddb445d77cb10a7ba158b49125)"),a=h.target.result,t&&(b??=a.objectStoreNames.contains(t),r&&console.log(`${n} ${o} store "${t}" ${b?"already exists":"does not exist"}. (I: db64712bc69c5287b1cf77af1fc13d24)`)),c()}catch(p){console.error(`${n}[openDBRequest.onsuccess] ${E(p)}`),l(p)}},d.onerror=h=>{debugger;console.error(`${n}[initRequest.onerror] ${E(d.error)} (E: 74cf09e9fba2dd9e41225e943c331124)`),l(d.error)}}catch(d){console.error(`${n} ${E(d)}`);debugger;l(d)}finally{r&&console.log(`${n} complete.`)}})}catch(i){throw console.error(`${n} ${E(i)}`),i}finally{a&&(r&&console.log(`${n} closing db ${o}... (I: 3f1c18eec567ea63f3927eef0f038925)`),a.close(),r&&(console.log(`${n} closing db ${o} complete. (I: bc3b2f504245d6203dbba6bd65d30325)`),console.timeLog(n+s,"db closed. (I: e748b4ddb445d77cb10a7ba158b49125)"))),r&&(console.log(`${n} complete.`),console.timeEnd(n+s))}}f(Ao,"initializeStorage");async function Ji({dbName:o,logalot:t=!1}){let e=`[${Ji.name}]`,r=crypto.randomUUID();t&&console.time(e+r);try{return t&&console.log(`${e} starting... (I: 8516795b20529d19eb6923defd7a0f24)`),(await indexedDB.databases()).filter(s=>s.name===o).at(0)}catch(n){console.error(`${e} ${E(n)}`)}finally{t&&console.timeEnd(e+r),t&&console.log(`${e} complete.`)}}f(Ji,"storageGetDBInfo");async function ms({dbName:o,storeName:t,logalot:e=!1}){let r=`[${ms.name}]`,n=crypto.randomUUID();e&&console.time(r+n);let s;try{if(e&&console.log(`${r} starting... (I: 029f7caa8ea5ea08a865f3924c82b624)`),!(await indexedDB.databases()).filter(b=>b.name===o).at(0))throw new Error(`db (${o}) does not exist. can't create store (${t}) (E: 5b15f7aed6f7068d077b2c7ebcbe8524)`);let i=!1;if(e&&console.timeLog(r+n),await new Promise((b,h)=>{let p=indexedDB.open(o);p.onsuccess=u=>{s=u.target.result,i=s.objectStoreNames?.contains(t),e&&console.timeLog(r+n,"open db request"),b()},p.onerror=u=>{debugger;console.error(`${r}[openDBRequest.onerror] ${E(p.error)} (E: 63695744e9e59ff8019e04ceeb8e2524)`),h(p.error)}}),e&&console.timeLog(r+n),i){e&&console.log(`${r} store ${t} already existed. (I: a2263b510c18240fc59fca54e3892324)`);return}let c=await Ji({dbName:o,logalot:e});if(e&&console.timeLog(r+n,"storageGetDBInfo complete"),!c)throw new Error(`db (${o}) does not exist. can't create store (${t}) (E: c771db13fa28f67079aad45e1ab7e624)`);let l=c.version;if(!l)throw new Error(`db (${o}) has no version. can't create store (${t}) (E: 3d2ec52853ad99f92b19ac5aa7fbfe24)`);let d=l+1;if(e&&console.log(`${r} creating store ${t} with version ${d} (I: 312b79f28243c650cf38935114f21e24)`),s)s.close(),s=void 0;else throw new Error("(UNEXPECTED) how did we get here with db falsy? (E: b561784879e19bac54b1c4936aff0c25)");await Ao({dbName:o,storeName:t,version:d,logalot:e})}catch(a){throw console.error(`${r} ${E(a)}`),a}finally{s&&(e&&console.log(`${r} closing db ${o}... (I: 3f1c18eec567ea63f3927eef0f038925)`),s.close(),e&&console.log(`${r} closing db ${o} complete. (I: bc3b2f504245d6203dbba6bd65d30325)`)),e&&console.timeLog(r+n),e&&console.log(`${r} complete.`)}}f(ms,"storageCreateStoreIfNotExist");async function us({dbName:o,version:t,storeName:e,key:r,value:n,logalot:s=!1}){let a=`[${us.name}]`,i;try{s&&console.log(`${a} starting... (I: bf7316c244888cb8ead2d3aac1d9f625)`),await new Promise((l,d)=>{try{s&&console.log(`${a} starting... (I: 81df59e3961d711ce5d8f2ae3e2f3824)`);let b=indexedDB.open(o,t);b.onsuccess=h=>{i=h.target.result;try{let p=i.transaction(e,"readwrite").objectStore(e),u={key:r,value:n};p.put(u),l()}catch(p){console.error(`${a}[putRequest.onsuccess] ${E(p)}`),d(p)}},b.onerror=h=>{debugger;console.error(`${a}[putRequest.onerror] ${E(b.error)} (E: 7a946d99ede2b248df4dcfea4ac99724)`),d(b.error)}}catch(b){console.error(`${a} ${E(b)}`),d(b)}finally{s&&console.log(`${a} complete.`)}})}catch(c){throw console.error(`${a} ${E(c)}`),c}finally{i&&(s&&console.log(`${a} closing db ${o}... (I: 438c6edced94b83a3478c71b08c6c325)`),i.close(),s&&console.log(`${a} closing db ${o} complete. (I: 0d081553b1eb53c65ade2cedb802cf25)`)),s&&console.log(`${a} complete.`)}}f(us,"storagePut");async function To({dbName:o,version:t,storeName:e,key:r,logalot:n=!1}){let s=`[${To.name}]`,a;try{return n&&console.log(`${s} starting... (I: f8ba7cd5801918a8580e91b7c90aa525)`),await new Promise((l,d)=>{try{n&&console.log(`${s} starting... (I: 24163c4a11c8712097db45febaf9c724)`);let b=indexedDB.open(o,t);b.onsuccess=h=>{a=h.target.result;let p;try{p=a.transaction(e).objectStore(e)}catch(g){debugger;console.error(`${s}[openDBRequest.onsuccess][objectStore] ${E(g)}`),d(g);return}let u=p.get(r);u.onsuccess=g=>{try{let m=g.target?.result?.value??void 0;if(!m){l(m);return}if(n&&console.log("Retrieved value:",m),m instanceof Uint8Array)l(Vi(m));else{if(typeof m!="string")throw new Error("(UNEXPECTED) truthy, non-Uint8Array value is not a string? (E: 6a4ec24e2e5d9848f8b542bc2661dc24)");l(m)}}catch(m){d(m)}},u.onerror=g=>{debugger;let m=u.error;console.error(`${s}[openDBRequest.onsuccess][getRequest.onerror] ${E(m)}`),d(m)}},b.onerror=h=>{debugger;console.error(`${s}[openDBRequest.onerror] ${E(b.error)} (E: 074963a908fa9a075f01c73cae829224)`),d(b.error)}}catch(b){console.error(`${s} ${E(b)}`),d(b)}finally{n&&console.log(`${s} complete.`)}})}catch(i){throw console.error(`${s} ${E(i)}`),i}finally{a&&(n&&console.log(`${s} closing db ${o}... (I: a938fc22dfdc76b15f6926bc4d458225)`),a.close(),n&&console.log(`${s} closing db ${o} complete. (I: 18f2ec1557bc83ec4e2c5d5e72264525)`)),n&&console.log(`${s} complete.`)}}f(To,"storageGet");async function ws({dbName:o,store:t}){let e=`[${ws.name}]`,r;try{return Le&&console.log(`${e} starting... (I: 2b4373affa3841220f0b7ca690406624)`),(await window.indexedDB.databases()).some(a=>a.name===o)?t?await new Promise((a,i)=>{let c=indexedDB.open(o);c.onsuccess=l=>{r=l.target.result;let d=r.objectStoreNames.contains(t);a(d)},c.onerror=l=>{debugger;r=c.result;let{error:d}=l.target;console.error(`${e}[openDBRequest.onerror] ${E(c.error)} (E: c783fe607451e46c1feae3a81e0f7924)`),i(d)}}):!0:!1}catch(n){throw console.error(`${e} ${E(n)}`),n}finally{r&&(Le&&console.log(`${e} closing db ${o}... (I: 8782d9eea285cf9eb638d493a421a625)`),r.close(),Le&&console.log(`${e} closing db ${o} complete. (I: 76a0c5dea2643e2bb84c82c8446a8125)`)),Le&&console.log(`${e} complete.`)}}f(ws,"storageDBExists");async function fd({dbName:o,storeName:t,pathToRm:e}){let r=`[${fd.name}]`,n=Le;Le&&console.log(`${r} starting... (I: c7e4cb759789ece0a8189d7dfb4d2a24)`);let s;return new Promise((a,i)=>{try{if(!o)throw new Error("(UNEXPECTED) dbName falsy? (E: ed336d88c9c4e8d4916b29356dc58324)");if(!t)throw new Error("(UNEXPECTED) storeName falsy? (E: ad493bb79b63a192524b14c59a706524)");if(!e)throw new Error("(UNEXPECTED) pathToRm falsy? (E: 88c9631d93467e17996946882254af24)");let c=indexedDB.open(o);c.onerror=()=>{debugger;c.result&&c.result.close(),console.error(`${r}[openDBRequest.onerror] ${E(c.error)} (E: 4c5ab71a765e61b4292008fd4fafe324)`),i(c.error)},c.onsuccess=()=>{s=c.result;let d=s.transaction(t,"readwrite").objectStore(t),b=IDBKeyRange.lowerBound(e),h=d.openCursor(b);h.onerror=()=>{debugger;console.error(`${r}[openCursorRequest.onerror] ${E(h.error)} (E: caefdda2bb95f92e9fb8d89ee412b524)`),i(h.error)},h.onsuccess=()=>{try{let p=0,u=h.result;if(u)if(u.key.toString().startsWith(e)){let g=u.delete();p++,g.onerror=()=>{debugger;console.error(`${r}[deleteRequest.onerror] ${E(g.error)} (E: abc031c53e5387322cd8909b3ada9b24)`),i(g.error)},u.continue()}else Le&&console.log(`${r} rmCount: ${p} (I: e4bc613a5514c0942484b79267e16724)`),a();else Le&&console.log(`${r} cursor is falsy, so either we have no more records or had no records to begin with. (I: 9ff3aec6274416501a7baf6dcc5f2624)`),a()}catch(p){console.error(`${r}[openCursorRequest.onsuccess] ${E(p)}`),i(p)}}}}catch(c){debugger;console.error(`${r} ${E(c)}`),i(c)}}).finally(()=>{s&&(Le&&console.log(`${r} closing db ${o}... (I: 39b4ba83de4bdfd541e3384ebab27425)`),s.close(),Le&&console.log(`${r} closing db ${o} complete. (I: e4015b9436c4b2bc0ccf0e11e2037925)`)),Le&&console.log(`${r} complete.`),Le=n})}f(fd,"storageRmRF");async function bd({dbName:o,storeName:t,dirPath:e,withFileTypes:r=!1}){let n=`[${bd.name}]`,s;try{return await new Promise((c,l)=>{let d=indexedDB.open(o);d.onerror=()=>{debugger;l(d.error)},d.onsuccess=()=>{s=d.result;let h=s.transaction(t,"readonly").objectStore(t),p=e.endsWith("/")?e:e+"/",u=IDBKeyRange.lowerBound(p),g=h.openCursor(u),m=new Set,$=[];g.onerror=()=>{debugger;console.error(`${n}[openCursorRequest.onerror] ${E(g.error)}`),l(g.error)},g.onsuccess=()=>{try{let T=g.result;if(T){let I=T.key.toString();if(I.startsWith(p)&&I!==p){let y=I.substring(p.length),A=y.split("/")[0];if(r){let _=y.substring(A.length).startsWith("/");$.push({name:A,isDirectory:f(()=>_,"isDirectory"),isFile:f(()=>!_,"isFile"),isBlockDevice:f(()=>!1,"isBlockDevice"),isCharacterDevice:f(()=>!1,"isCharacterDevice"),isSymbolicLink:f(()=>!1,"isSymbolicLink"),isFIFO:f(()=>!1,"isFIFO"),isSocket:f(()=>!1,"isSocket")})}else m.add(A);T.continue()}else I.startsWith(p)?T.continue():c(r?$:Array.from(m))}else c(r?$:Array.from(m))}catch(T){console.error(`${n}[openCursorRequest.onsuccess] ${E(T)}`),l(T)}}}})}catch(a){throw console.error(`${n} ${E(a)}`),a}finally{s&&(Le&&console.log(`${n} closing db ${o}... (I: 39b4ba83de4bdfd541e3384ebab27425)`),s.close(),Le&&console.log(`${n} closing db ${o} complete. (I: e4015b9436c4b2bc0ccf0e11e2037925)`))}}f(bd,"storageReaddir");var gr=Ur;async function hd(o){let t=`[${hd.name}]`;try{gr&&console.log(`${t} starting... (I: 1905af1827a34ca8a5507fe0c5085b01)`),await Es({infos:[{dbName:o.dbName,storeNames:[o.storeName,...o.additionalStoreNames??[]]}]})}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{gr&&console.log(`${t} complete.`)}}f(hd,"initIbGibStorage");function Zi(o){let t=`[${Zi.name}]`;try{gr&&console.log(`${t} starting... (I: 7be20d161bb14a498c44a42d3193bec1)`),globalThis.ibgib||(globalThis.ibgib={dbName_hack:o.dbName,apiKeyName_hack:o.apiKeyName,storeName_hack:o.storeName}),globalThis.ibgib.spaceGib||(globalThis.ibgib.spaceGib={version:Ui,spaceShim:{},fnDefaultGetAPIKey:f(async()=>await To({dbName:o.dbName,storeName:o.storeName,key:o.apiKeyName})??"","fnDefaultGetAPIKey"),dbName_hack:o.dbName,apiKeyName_hack:o.apiKeyName,storeName_hack:o.storeName})}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{gr&&console.log(`${t} complete.`)}}f(Zi,"initIbGibGlobalThis");function pd(o){if(!globalThis.ibgib?.spaceGib){if(!o)throw new Error("Global context not initialized and config not provided.");Zi(o)}return globalThis.ibgib.spaceGib}f(pd,"getIbGibGlobalThis_SpaceGib");async function ud(o){let t=`[${ud.name}]`;try{gr&&console.log(`${t} starting... (I: 3123b18eb29b480bad056a9a029b9ad4)`),await(await import(o)).bootstrapSpaceGibApp()}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{gr&&console.log(`${t} complete.`)}}f(ud,"dynamicallyLoadBootstrapScript");function NE(){let o=f(async()=>He(),"fnGetMetaspace"),t=new Promise(async(e,r)=>{try{let n=1e5,s=0,a;do{if(a=pd()?.bootstrapPromise,s++,s>n)break;await pe(10)}while(a===void 0);if(!a)throw new Error("Timed out waiting for bootstrapPromise. (E: ceb3ba5261994476900e4a623c0e9d10)");await a,e()}catch(n){r(n)}});return{fnGetMetaspace:o,bootstrapPromise:t}}f(NE,"getComponentCtorArg");var gd="hash-reveal-v1",Je={hash_reveal_v1:gd},Qi=Object.values(Je);var Ed="top-up",md="replace-all",wd="consume",yd="delete-all",be={topUp:Ed,replaceAll:md,consume:wd,deleteAll:yd},ec=Object.values(be);var So=class{static{f(this,"KeystoneStrategy")}config;constructor(t){this.config=t}};var $d="recursive-salt-wrap",Mr={recursive_salt_wrap:$d},tc=Object.values(Mr);var Go=!1;async function ys({masterSecret:o,kdfOpts:t}){let e=`[${ys.name}]`;try{Go&&console.log(`${e} starting... (I: 268e87ec311874ee6822bf459c5a5426)`);let r=t.strategy;switch(r){case Mr.recursive_salt_wrap:return await Co({masterSecret:o,salt:t.salt,rounds:t.rounds,algorithm:t.algorithm});default:throw new Error(`Unknown KDF strategy: ${r}. valid values: ${tc.join(", ")} (E: c81258e9d9481eb0f88385a825193226)`)}}catch(r){throw console.error(`${e} ${E(r)}`),r}finally{Go&&console.log(`${e} complete.`)}}f(ys,"deriveKey");async function Co({masterSecret:o,salt:t,rounds:e,algorithm:r=Oe.sha_256}){let n=`[${Co.name}]`;try{Go&&console.log(`${n} starting... (I: 850868e50aba82ff28c77da8169e4c26)`);let s=o;for(let a=0;a<e;a++)s=await ke({s:`${t}${s}${t}`,algorithm:r});return s}catch(s){throw console.error(`${n} ${E(s)}`),s}finally{Go&&console.log(`${n} complete.`)}}f(Co,"kdf_recursiveSaltWrap");var xo=class o extends So{static{f(this,"KeystoneStrategy_HashRevealV1")}async derivePoolSecret({masterSecret:t}){let e=`[${o.name}.${this.derivePoolSecret.name}]`;try{let{salt:r,rounds:n,algo:s}=this.config;return await Co({masterSecret:t,salt:r,rounds:n,algorithm:s})}catch(r){throw console.error(`${e} Error deriving pool secret: ${r.message}`),r}}async generateSolution({poolSecret:t,poolId:e,challengeId:r}){let n=`[${o.name}.${this.generateSolution.name}]`;try{let{rounds:s,algo:a}=this.config,i=r,c=t;for(let l=0;l<s;l++)c=await ke({s:`${i}${c}${i}`,algorithm:a});return{type:"hash-reveal-v1",poolId:e,challengeId:r,value:c}}catch(s){throw console.error(`${n} ${s.message}`),s}}async generateChallenge({solution:t}){let e=`[${o.name}.${this.generateChallenge.name}]`;try{let{rounds:r,algo:n}=this.config,{challengeId:s,value:a}=t,i=s,c=a;for(let l=0;l<r;l++)c=await ke({s:`${i}${c}${i}`,algorithm:n});return{id:s,type:"hash-reveal-v1",hash:c}}catch(r){throw console.error(`${e} ${r.message}`),r}}async validateSolution({solution:t,challenge:e}){let r=`[${o.name}.${this.validateSolution.name}]`;try{return t.type!=="hash-reveal-v1"||e.type!=="hash-reveal-v1"?(console.warn(`${r} Mismatched types provided.`),!1):(await this.generateChallenge({solution:t})).hash===e.hash}catch(n){return console.error(`${r} ${n.message}`),!1}}};var Ze=class o{static{f(this,"KeystoneStrategyFactory")}static create({config:t}){let e=`[${o.name}.create]`;try{switch(t.type){case"hash-reveal-v1":return new xo(t);default:throw new Error(`Unknown strategy type: ${t.type} (E: 4e3c2f7129a241c1b687555e678c1065)`)}}catch(r){throw console.error(`${e} ${r.message}`),r}}};var $s="keystone",Is=/^\w[\w\-.]*$/,_s=/^[a-zA-Z0-9\-_]{1,64}$/,Ts=1e3,No="revoke",Fr="manage",Id="sign",rt="sync",gt="connect",As={REVOKE:No,MANAGE:Fr,SIGN:Id,SYNC:rt,CONNECT:gt},em=Object.values(As);var Ss=No,rc=Fr;var ot=gt,Er=rt;var Gs=200,Cs=2,xs=2,Ns=5,vs=be.topUp,oc=Oe.sha_256,nc=1,sc=2e3,ac=5,ic=5,cc=16,lc=be.replaceAll,dc=Oe.sha_512,fc=10,vo=50;var W=!1;async function Et({ibGib:o,ibGibs:t,ibGibAddr:e,ibGibAddrs:r,live:n,gotten:s,tjpAddrsAlreadyAnalyzed:a,skipAddrs:i,skipRel8nNames:c,onlyRel8nNames:l,maxRetries:d,msBetweenRetries:b,space:h,timeLogName:p,mapTjpAddrToLatestAddrsInSpace:u}){let g=`[${Et.name}]`;try{W&&console.log(`${g} starting... (I: c2a4426c22e849611ca0cedabe683a22)`);let m=await Br({ibGib:o,ibGibs:t,ibGibAddr:e,ibGibAddrs:r,live:n,gotten:s,tjpAddrsAlreadyAnalyzed:a,skipAddrs:i,skipRel8nNames:c,onlyRel8nNames:l,maxRetries:d,msBetweenRetries:b,space:h,timeLogName:p,mapTjpAddrToLatestAddrsInSpace:u});if(Object.values(m).filter($=>$.ib.startsWith("comment ")).forEach($=>{console.table($)}),W){console.log(`${g} graph size: ${Object.keys(m).length} (I: c6cb5e7e1e2611d35b9006fac6503d22)`);let $=Object.values(m).filter(T=>T.ib.startsWith("comment ")||T.ib.startsWith("pic ")).map(T=>T.ib);Qr($).forEach(T=>console.log(T))}return m}catch(m){throw console.error(`${g} ${m.message}`),m}finally{W&&console.log(`${g} complete.`)}}f(Et,"getDependencyGraph");async function bc({ibGib:o,ibGibs:t,ibGibAddr:e,ibGibAddrs:r,live:n,gotten:s,tjpAddrsAlreadyAnalyzed:a,skipAddrs:i,skipRel8nNames:c,onlyRel8nNames:l,maxRetries:d,msBetweenRetries:b,space:h,timeLogName:p,mapTjpAddrToLatestAddrsInSpace:u}){let g=`[${bc.name}]`;try{if(W&&console.log(`${g} starting... (I: bd6807477f679345df9dddefe0b4e922)`),!h)throw new Error("space required. (E: 9f38166ab70340cb919174f8d26af909)");if(!o&&!e&&(t??[]).length===0&&(r??[]).length===0)throw new Error("either ibGib/s or ibGibAddr/s required. (E: b6d08699651f455697f0d05a41edb039)");return c=c||[],i=i||[],s=s||{},a=a||[],r=(r??[]).filter(m=>!ie({gib:H({ibGibAddr:m}).gib})).filter(m=>!i.includes(m)),t=(t??[]).filter(m=>!ie({ibGib:m})).filter(m=>!i.includes(w({ibGib:m}))),o&&!ie({ibGib:o})&&!t.some(m=>m.gib===o.gib)&&!i.includes(w({ibGib:o}))&&t.push(o),e&&!ie({gib:H({ibGibAddr:e}).gib})&&!r.includes(e)&&!i.includes(e)&&r.push(e),{ibGib:o,ibGibs:t,ibGibAddr:e,ibGibAddrs:r,live:n,gotten:s,tjpAddrsAlreadyAnalyzed:a,skipAddrs:i,skipRel8nNames:c,onlyRel8nNames:l,maxRetries:d,msBetweenRetries:b,space:h,timeLogName:p,mapTjpAddrToLatestAddrsInSpace:u}}catch(m){throw console.error(`${g} ${m.message}`),m}finally{W&&console.log(`${g} complete.`)}}f(bc,"getGraphProjection_initializeOpts");async function hc({ibGibs:o,ibGibAddrs:t,gotten:e,skipAddrs:r,maxRetries:n,msBetweenRetries:s,timeLogName:a,space:i}){let c=`[${hc.name}]`;try{W&&console.log(`${c} starting... (I: 67b2be37ff24393fff56e229304da122)`);let l=[];o??=[],t??=[],r??=[],e??={};let d=[],b=Object.keys(e??{}),h=o.map(p=>w({ibGib:p}));for(let p=0;p<t.length;p++){let u=t[p];r.includes(u)||h.includes(u)||(b.includes(u)?l.push(e[u]):d.push(t[p]))}if(W&&console.log(`${c}[analyze debugging] addrsToGetFromSpace (${d.length}):
|
|
12
|
+
${d.join(`
|
|
13
|
+
`)} (I: b45a2614184b48b694becfd377c789f5)`),d.length>0){let p=d.concat(),u=0;for(n=n??0;u<=n&&p.length>0;){if(a&&u===0&&console.timeLog(a,`${c} FIRST try starting...`),a&&u>0&&console.timeLog(a,`${c} RETRY starting...`),u>0&&s&&(a&&console.timeLog(a,`${c} delaying ${s}ms for retry`),W&&console.log(`${c} retrying. addrsToGet (${p.length}): ${p} (I: 8460694cdd5518472680784c3b96a822)`),await pe(s)),a&&console.timeLog(a,`${c} getFromSpace (${p?.length}) starting...`),!i)throw new Error("(UNEXPECTED) space falsy? (E: aa9f657695717034b3581066932d7d23)");let g=await B({addrs:p,space:i});if(a&&console.timeLog(a,`${c} getFromSpace complete.`),g.success&&(g.ibGibs?.length??0)>0){g.ibGibs.forEach($=>l.push($));let m=g.ibGibs.map($=>w({ibGib:$}));if(m.length===p.length){a&&console.timeLog(a,`${c} got all.`),p=[];break}else a&&console.timeLog(a,`${c} got some.`),p=p.filter($=>!m.includes($))}else{let m=g.rawResultIbGib.ibGibs??[];if(m.length>0){m.forEach(T=>l.push(T));let $=m.map(T=>w({ibGib:T}));a&&console.timeLog(a,`${c} got some.`),p=p.filter(T=>!$.includes(T))}else a&&console.timeLog(a,`${c} failed. addrs: ${p?.join(",")}`)}u++}if(p?.length>0)throw new Error(`unable to retrieve dependency ibgibs from space (ib: ${i?.ib}). addrsToGet: ${p.join(`
|
|
14
|
+
`)} (E: 8413594b6c1b447988781cf3f3e1729d)`)}return l}catch(l){throw console.error(`${c} ${l.message}`),l}finally{W&&console.log(`${c} complete.`)}}f(hc,"getGraphProjection_getIbGibsInIbGibAddrs");async function Br(o){let t=`[${Br.name}]`;try{if(W&&console.log(`${t} starting... (I: 70508d7a5c63eae1f22ae851b32b3d22)`),!o.ibGib&&!o.ibGibAddr&&(o.ibGibs??[]).length===0&&(o.ibGibAddrs??[]).length===0)return{};let{ibGibs:e,ibGibAddrs:r,live:n,gotten:s,tjpAddrsAlreadyAnalyzed:a,skipAddrs:i,skipRel8nNames:c,onlyRel8nNames:l,maxRetries:d,msBetweenRetries:b,space:h,timeLogName:p,mapTjpAddrToLatestAddrsInSpace:u}=await bc(o);if(p&&console.timeLog(p,`${t} starting...`),r?.length??!1){let m=await hc({ibGibs:e,ibGibAddrs:r,gotten:s,skipAddrs:i,maxRetries:d,msBetweenRetries:b,timeLogName:p,space:h});e=e?[...e,...m]:[...m]}r=e.map(m=>w({ibGib:m}));let g=Qr(e.map(m=>m.ib).filter(m=>m.startsWith("comment ")));return W&&console.log(`${t}[analyze debugging] ibGibs commentIbs: ${g.join(`
|
|
15
|
+
`)} (I: c89dc951315f746954f9bddbe8941122)`),n?pc({ibGibs:e,ibGibAddrs:r,gotten:s,tjpAddrsAlreadyAnalyzed:a,skipAddrs:i,skipRel8nNames:c,onlyRel8nNames:l,maxRetries:d,msBetweenRetries:b,space:h,timeLogName:p,mapTjpAddrToLatestAddrsInSpace:u}):uc({ibGibs:e,ibGibAddrs:r,gotten:s,skipAddrs:i,skipRel8nNames:c,onlyRel8nNames:l,maxRetries:d,msBetweenRetries:b,space:h,timeLogName:p})}catch(e){throw console.error(`${t} ${e.message}`),e}finally{W&&console.log(`${t} complete.`)}}f(Br,"getGraphProjection");async function mr({ibGibAddr:o,latestCommonFrameAddr:t,live:e,space:r}){let n=`[${mr.name}]`;try{if(W&&console.log(`${n} starting... (I: 5d225e56dc11e62cd83c5366ea288826)`),o===t)return console.warn(`${n} ibGibAddr === latestCommonFrameAddr. So the delta graph is empty. what are we doing here? (W: e0c8287ae6de8152bf36b6c73ca59a26)`),{};let s=await Et({ibGibAddr:t,live:!1,space:r});return await Et({ibGibAddr:o,live:e,skipAddrs:Object.keys(s),space:r})}catch(s){throw console.error(`${n} ${E(s)}`),s}finally{W&&console.log(`${n} complete.`)}}f(mr,"getDeltaDependencyGraph");async function pc({ibGibs:o,ibGibAddrs:t,gotten:e,tjpAddrsAlreadyAnalyzed:r,mapTjpAddrToLatestAddrsInSpace:n,skipAddrs:s,skipRel8nNames:a,onlyRel8nNames:i,maxRetries:c,msBetweenRetries:l,space:d,timeLogName:b}){let h=`[${pc.name}]`;try{n=n??{},r=r??[];let p={...e};(o??[]).forEach(I=>p[w({ibGib:I})]=I);let u=ze({ibGibs:Object.values(p)});W&&console.log(`${h}[analyze debugging] timeline tjps(${Object.keys(u).length}): ${Object.keys(u)} (I: 509f04ac15ca08c5a3f0777b48934622)`);let g={};Object.keys(u).forEach(I=>{r.includes(I)||(g[I]=u[I])}),W&&console.log(`${h}[analyze debugging] timelinesNotAnalyzed: ${P(g)} (I: a4b67d95fdd6b98d3241c0a7d0a93c22)`);let m={},$={};Object.keys(u).filter(I=>!r.includes(I)).forEach(I=>{let y=u[I],A=y[y.length-1];m[I]=A;let _=w({ibGib:A});$[_]=I});let T=Object.keys(m).length;if(T>0){let I={};Object.keys(n).filter(O=>!r.includes(O)).forEach(O=>{let D=m[O];if(D){let k=w({ibGib:D});I[k]=n[O]}else console.error(`${h} latestIbGibCorrespondingToTjpAddr is falsy`)}),W&&console.log(`${h} latestAddrsMap *before* getLatestAddrs: ${P(I)} (I: 427b4bb78595e9e521ecf2c5e5c80722)`);let y=Object.values(m),A={};if(y.length>0){if(!d)throw new Error("(UNEXPECTED) space falsy? (E: 8e878975e3561df9a8dc4c628b0abc23)");let O=await je({ibGibs:y,space:d});if(!O?.data?.latestAddrsMap)throw new Error("(UNEXPECTED) getLatestAddrs result latestAddrsMap falsy (E: 088caa1fc95fd3b079108ab63ef33422)");if(A=O?.data?.latestAddrsMap,Object.keys(A).length!==T)throw new Error("(UNEXPECTED) latestAddrsMap is not the same size as the incoming map (E: 666af512bbd44534983bb28ee8d43fed)");W&&console.log(`${h} queriedLatestAddrsMap: ${P(A)} (I: 7b39a5f7ce9e9d9fabae4be98ed44522)`),I={...A,...I}}W&&console.log(`${h} combined latestAddrsMap: ${P(I)} (I: e3aedea63f29c5b06a79632f691aa522)`);let _=[],S={};Object.values(m).forEach(O=>{let D=w({ibGib:O}),k=$[D],U=I[D];if(!U)throw new Error("(UNEXPECTED) latestAddrInSpace not found in latestAddrsMap (E: 095d2b3f88e3e8a2c3e7d3de4c6d5622)");U===D?(W&&console.log(`${h} analyzed ${k}(I: afb7960900f04b8a87538f4c7bd903b7)`),r.push(k)):(_.push(U),S[U]=k)});let N=[];for(let O=0;O<(o??[]).length;O++){let k=o[O].rel8ns??{};Object.keys(k).filter(R=>!(a??[]).includes(R)).filter(R=>i?i.includes(R):!0).forEach(R=>{(k[R]??[]).forEach(oe=>{!N.includes(oe)&&!o.some(ye=>w({ibGib:ye})===oe)&&N.push(oe)})})}return t=Qr([...t??[],...N,..._]),await Br({ibGibs:o,ibGibAddrs:t,gotten:e,tjpAddrsAlreadyAnalyzed:r,skipAddrs:s,skipRel8nNames:a,onlyRel8nNames:i,maxRetries:c,msBetweenRetries:l,space:d,timeLogName:b,live:!0,mapTjpAddrToLatestAddrsInSpace:n})}else return o||(o=[]),Object.values(e??{}).forEach(I=>{let y=w({ibGib:I});o.some(A=>w({ibGib:I})===y)||o.push(I)}),await Br({ibGibs:o,ibGibAddrs:t,gotten:e,skipAddrs:s,skipRel8nNames:a,onlyRel8nNames:i,maxRetries:c,msBetweenRetries:l,space:d,timeLogName:b,live:!1})}catch(p){let u=`${h} ${p.message}`;throw console.error(u),b&&console.timeLog(b,`${h} error: ${u}`),p}finally{b&&console.timeLog(b,`${h} complete.`)}}f(pc,"getGraphProjection_Live");async function uc({ibGibs:o,ibGibAddrs:t,gotten:e,skipAddrs:r,skipRel8nNames:n,onlyRel8nNames:s,maxRetries:a,msBetweenRetries:i,space:c,timeLogName:l}){let d=`[${uc.name}]`;try{let b=[];o??=[],e??={},r??=[],n??=[],l&&console.timeLog(l,`${d} analyzing next step starting...`);for(let h=0;h<o.length;h++){let p=o[h],u=w({ibGib:p}),{gib:g}=H({ibGib:p});if(g===M)throw new Error("cannot get dependency graph of primitive.");Object.keys(e).includes(u)||(e[u]=p);let m={},$=p.rel8ns||{},T=(Object.keys($)||[]).filter(y=>!n.includes(y));s&&(T=T.filter(y=>s.includes(y)));let I=Object.keys(e);for(let y=0;y<T.length;y++){let A=T[y],_=$[A]??[],S=_.filter(O=>O===""||O===void 0||O===null||!O.includes(le));S.length>0&&console.warn(`${d} (UNEXPECTED) has falsyAddrs: ${S} (W: da9505cb0a4db68a4aff7f279ad2d322)`),_.filter(O=>!!O).filter(O=>!I.includes(O)).filter(O=>!r.includes(O)).filter(O=>H({ibGibAddr:O}).gib!==M).filter(O=>!b.includes(O)).forEach(O=>{let D=fr({addr:O});(D||[]).length===0?b.push(O):m[O]=D})}if(Object.keys(m).length>0)throw new Error(`invalid addresses found in dependency graph. Errors (clipped to 1kB): ${JSON.stringify(m).substring(0,1024)}`)}if(l&&console.timeLog(l,`${d} analyzing next step complete.`),b.length>0){if(l&&console.timeLog(l,`${d} get addrsWeDontHaveAlready_Rel8dAddrs starting...`),!c)throw new Error("(UNEXPECTED) space falsy? (E: 0ce327cf5d521bd798340333460f3423)");let h=await B({addrs:b,space:c});if(l&&console.timeLog(l,`${d} get addrsWeDontHaveAlready_Rel8dAddrs complete.`),h.success)if(h.ibGibs?.length===b.length){W&&console.log(`${d} got ALL of them (happy path)`),h.ibGibs.forEach(u=>e[w({ibGib:u})]=u),l&&console.timeLog(l,`${d} call getGraphProjection recursively starting...`);let p=await Br({ibGibs:h.ibGibs,live:!1,gotten:e,skipAddrs:r,skipRel8nNames:n,onlyRel8nNames:s,maxRetries:a,msBetweenRetries:i,space:c});return l&&console.timeLog(l,`${d} call getGraphProjection recursively complete.`),p}else throw(h.ibGibs?.length??0)>0&&h.ibGibs.length<b.length?(W&&console.warn(`${d} got SOME of them (happy-ish path?). not sure what to do here... (W: e3458f61a1ae4979af9e6b18ac935c14)`),new Error("trouble getting dependency ibgibs (E: 8156bf65fd084ae4a4e8a0669db28b07)")):(h.ibGibs?.length??!1)&&h.ibGibs.length>b.length?new Error("(UNEXPECTED) got more ibGibs than addrs that we asked for. space not working properly. (E: 352219b3d18543bcbda957f2d60b78f3)"):new Error("couldn't get dependency ibgibs from space. (E: 225f26b7d7f84911bb033753a062209b)");else throw new Error(`failure getting addrs in space ${c?.data?.name||"[no name?]"} (id: ${c?.data?.uuid||"[no uuid?]"}). (E: 60404e6e389249d9bbecf0039cd51878) addrs:
|
|
16
|
+
${b.join(`
|
|
17
|
+
`)} `)}else return e}catch(b){let h=`${d} ${b.message}`;throw console.error(h),l&&console.timeLog(l,`${d} error: ${h}`),b}finally{l&&console.timeLog(l,`${d} complete.`)}}f(uc,"getGraphProjection_NonLive");function Oo({ibGibs:o}){let t=`[${Oo.name}]`;try{if(W&&console.log(`${t} starting... (I: 6019a812cff8597f79c12088e45cc226)`),o){let e={};return o.forEach(r=>{e[w({ibGib:r})]=r}),e}else return}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{W&&console.log(`${t} complete.`)}}f(Oo,"toFlatGraph");function Do({graphA:o,graphB:t,slowButThorough:e}){let r=`[${Do.name}]`;try{if(W&&console.log(`${r} starting... (I: e50a98b659189dece8b4ef581e4ad826)`),!(Object.keys(o).length===Object.keys(t).length))return W&&console.log(`${r} not the same size. false. (I: e1044e52421dbf7e067e0fe850ac6826)`),!1;for(let s of Object.keys(o))if(!t[s])return W&&console.log(`${r} addr (${s}) in graphA not found in graphB (I: 264c68408378ce30b8f6a978f8b86926)`),!1;if(e)for(let s of Object.keys(o)){let a=Ne({ibGib:o[s]}),i=JSON.stringify(a),c=Ne({ibGib:t[s]}),l=JSON.stringify(c);if(i!==l)return W&&console.log(`${r} jsonA !== jsonB for addr (${s}) (I: 98ed9f58ac88dabba83f96582f725926)`),!1}return!0}catch(n){throw console.error(`${r} ${E(n)}`),n}finally{W&&console.log(`${r} complete.`)}}f(Do,"graphsAreEquivalent");var he=!1;async function gc({keystoneData:o}){let t=`[${gc.name}]`;try{return he&&console.log(`${t} starting... (I: c3022a146faac9730154f34d1439a225)`),[$s].join(" ")}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{he&&console.log(`${t} complete.`)}}f(gc,"getKeystoneIb");function Ec({pool:o,requiredChallengeIds:t,targetAddr:e}){let r=o.config.behavior,n=new Set,s=Object.keys(o.challenges);if(t&&t.length>0){for(let a of t){if(!o.challenges[a])throw new Error(`(UNEXPECTED) Required challenge ID not found in pool: ${a} (E: 10c5619d80d8cf6cc84ffbf8be0dbc25)`);s.includes(a)&&n.add(a)}s=s.filter(a=>!n.has(a))}if(r.targetBindingChars>0&&e){let{gib:a}=H({ibGibAddr:e});if(a){let i=a!==M?a.substring(0,r.targetBindingChars).toLowerCase():"abc";for(let c of i){let d=(o.bindingMap[c]||[]).find(b=>s.includes(b));if(!d)throw new Error(`Entropy Exhaustion. Cannot satisfy binding for char '${c}'. (E: 341b95dc3a58be3e083d1d9c4a0c4925)`);n.add(d),s=s.filter(b=>b!==d)}}}if(r.selectSequentially>0){if(s.length<r.selectSequentially)throw console.error(`[getDeterministicRequirements] Entropy Exhaustion! AvailableCount: ${s.length}, Required Seq: ${r.selectSequentially}. Available IDs: ${s.join(",")}`),new Error("Entropy Exhaustion. Insufficient challenges for FIFO requirement. (E: 9efa88003e1d5eccb837c85154ee5625)");s.slice(0,r.selectSequentially).forEach(i=>n.add(i)),s=s.slice(r.selectSequentially)}return{mandatoryIds:n,availableIds:s}}f(Ec,"getDeterministicRequirements");function Lo(o,t){let e=t.charAt(0).toLowerCase();if(/[0-9a-f]/.test(e))o[e]||(o[e]=[]),o[e].push(t);else throw new Error(`invalid challengeId (${t}). Must start with a hex character. (E: c96ed8460de89e28c801370a0f07f826)`)}f(Lo,"addToBindingMap");function _d(o,t){for(let e of Object.keys(o))o[e]=o[e].filter(r=>r!==t)}f(_d,"removeFromBindingMap");function Ro({pools:o,poolId:t,poolFilter:e,verb:r}){let n="[resolveTargetPool]";try{let s;if(t){if(s=o.find(a=>a.id===t),!s)throw new Error(`Pool not found with ID: ${t} (E: 4a2b17428515c1e82813158581898125)`)}else if(e){let a=o.filter(e);if(a.length===0)throw new Error("No pool matched the provided filter. (E: 5b3c27428515c1e82813158581898125)");s=a[0]}else{if(!r)throw new Error("Cannot auto-resolve pool without a verb. (E: 6c4d37428515c1e82813158581898125)");if(s=o.find(a=>a.config.allowedVerbs&&a.config.allowedVerbs.includes(r)),s||(s=o.find(a=>!a.config.allowedVerbs||a.config.allowedVerbs.length===0)),!s)throw new Error(`No suitable pool found for verb: ${r} (E: 7d5e47428515c1e82813158581898125)`)}if(r&&s.config.allowedVerbs&&s.config.allowedVerbs.length>0&&!s.config.allowedVerbs.includes(r))throw new Error(`Pool ${s.id} is not authorized for verb: ${r} (E: 8e6f57428515c1e82813158581898125)`);return s}catch(s){throw console.error(`${n} ${E(s)}`),s}}f(Ro,"resolveTargetPool");function Uo({pool:o,targetAddr:t,requiredChallengeIds:e}){let r="[selectChallengeIds]";try{let{mandatoryIds:n,availableIds:s}=Ec({pool:o,requiredChallengeIds:e,targetAddr:t}),a=o.config.behavior.selectRandomly,i=[];if(a>0){if(s.length<a)throw new Error(`Insufficient challenges for random requirement. Need ${a}, have ${s.length} (E: 9f7a67428515c1e82813158581898125)`);let c=[...s].sort(()=>.5-Math.random());i.push(...c.slice(0,a))}return[...n,...i]}catch(n){throw console.error(`${r} ${E(n)}`),n}}f(Uo,"selectChallengeIds");async function Po({salt:o,timestamp:t,index:e}){return(await ke({s:`${o}${t}${e}`})).substring(0,16)}f(Po,"generateOpaqueChallengeId");async function Td({prevPools:o,targetPoolId:t,consumedIds:e,masterSecret:r,strategy:n,config:s}){let a="[applyReplenishmentStrategy]";try{let i=JSON.parse(JSON.stringify(o)),c=i.findIndex(p=>p.id===t);if(c===-1)throw new Error(`Target pool ${t} not found in keystone data. (E: 75200388d22744838634524233772545)`);let l=i[c],d=await n.derivePoolSecret({masterSecret:r}),b=Date.now().toString(),h=s.behavior.replenish;if(e.forEach(p=>{l.bindingMap&&_d(l.bindingMap,p)}),h===be.topUp){e.forEach(p=>delete l.challenges[p]);for(let p=0;p<e.length;p++){let u=await Po({salt:s.salt,timestamp:b,index:p}),g=await n.generateSolution({poolSecret:d,poolId:l.id,challengeId:u});l.challenges[u]=await n.generateChallenge({solution:g}),l.bindingMap||(l.bindingMap={}),Lo(l.bindingMap,u)}}else if(h===be.replaceAll){l.challenges={},l.bindingMap={};for(let p=0;p<s.behavior.size;p++){let u=await Po({salt:s.salt,timestamp:b,index:p}),g=await n.generateSolution({poolSecret:d,poolId:l.id,challengeId:u});l.challenges[u]=await n.generateChallenge({solution:g}),Lo(l.bindingMap,u)}}else if(h===be.consume)e.forEach(p=>delete l.challenges[p]);else if(h===be.deleteAll)l.challenges={},l.bindingMap={};else throw new Error(`Unknown replenish strategy: ${h}. Valid list: ${P(ec)} (E: 0acf56f1e1486240080e11e8046d0825)`);return i}catch(i){throw console.error(`${a} ${E(i)}`),i}}f(Td,"applyReplenishmentStrategy");async function ko({targetPoolId:o,prevPools:t,masterSecret:e,challengeIds:r,claim:n,requiredChallengeIds:s}){let a="[solveAndReplenish]";try{he&&console.log(`${a} starting... poolId: ${o}, ids: ${r.length}`);let i=t.find(p=>p.id===o);if(!i)throw new Error(`Target pool not found: ${o} (E: a1b2c3d4e5f6a7b8c9d0e1f2a3b4c5d6)`);let c=Ze.create({config:i.config}),l=await c.derivePoolSecret({masterSecret:e}),d=[];for(let p of r){let u=await c.generateSolution({poolSecret:l,poolId:i.id,challengeId:p});d.push(u)}let b={claim:n,solutions:d,requiredChallengeIds:s&&s.length>0?s:void 0},h=await Td({prevPools:t,targetPoolId:i.id,consumedIds:r,masterSecret:e,strategy:c,config:i.config});return{proof:b,nextPools:h}}catch(i){throw console.error(`${a} ${E(i)}`),i}}f(ko,"solveAndReplenish");async function mc({pool:o}){let t=`[${mc.name}]`;try{if(he&&console.log(`${t} starting... (I: e2ffd568b698cc12d8c5e838d73ae726)`),!o.config)throw new Error("(UNEXPECTED) pool.configy falsy? (E: fcde88fe20e8004a58d7e445436bf526)");if(o.config.type!==Je.hash_reveal_v1)throw new Error("(UNEXPECTED) pool.config.type !== KeystoneChallengeType.hash_reveal_v1? (E: e205f8872909c37168a624a9df778c26)");let e=[],{algo:r,rounds:n,salt:s}=o.config,a=[Oe.sha_256,Oe.sha_512];return r?a.includes(r)||e.push(`${t} invalid hash algorithm (${r}). Must be one of ${a}. (E: a22399ca3a68e63ffcc7507699be5826)`):e.push(`${t} algorithm required. (E: 8cd6bfb0590862b9bae24d98d2cf3826)`),n&&typeof n=="number"&&Number.isInteger(n)?n>Ts&&e.push(`${t} rounds too high. max rounds: ${Ts} (E: 31ce082f7fd88d6b58ef08a816458826)`):e.push(`${t} invalid rounds (${n}). must be positive integer. (E: 73c643ccda78afaf28d52a6871a9e826)`),s&&typeof s=="string"?_s.test(s)||e.push(`${t} invalid salt (${s.substring(0,99)}). Must match regexp ${_s}`):e.push(`${t} invalid salt (${s}). must be truthy string value. (E: 564a4844ec88fc1988197ce89c381426)`),e}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{he&&console.log(`${t} complete.`)}}f(mc,"validateChallengePool_typeHashRevealV1");async function wc({pool:o}){let t=`[${wc.name}]`;try{he&&console.log(`${t} starting... (I: 1a0eafc158a83d1ba8fc019d5c979a26)`);let e=[];if(o.config){if(o.config.id?Is.test(o.config.id)||e.push(`${t} pool.config.id is not formatted correctly. must pass regexp: ${Is.source}`):e.push(`${t} pool.config.id falsy (E: 31d7943d95f877326d5f4ea14463d626)`),o.config.behavior){let{size:n}=o.config.behavior;(!n||n===0)&&e.push(`${t} invalid pool.config.behavior.size (${n}). Must be positive integer. (E: b221e36ec102bdc944552248ce8fe626)`)}else e.push(`${t} pool.config.behavior falsy (E: bede081c066c39732eefe2f92e296326)`);let r=o.config.type;switch(r){case Je.hash_reveal_v1:(await mc({pool:o})).forEach(s=>e.push(s));break;default:throw new Error(`(UNEXPECTED) unknown pool.config.type (${r})? We only implement the following at this time: ${Qi} (E: cce5285cf7580b8bc82172488eba2826)`)}}else e.push(`${t} pool.config falsy. (E: 8d05c875a1d2c58018a5eaf803977d26)`);return e}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{he&&console.log(`${t} complete.`)}}f(wc,"validateChallengePool");async function Mo({keystoneIbGib:o}){let t=`[${Mo.name}]`;try{he&&console.log(`${t} starting... (I: ec6ba82ec848b5ac3d8953e89d8d9826)`);let e=[],{data:r,rel8ns:n}=o;r.proofs&&r.proofs.length>0&&e.push(`${t} proofs already exist on genesis keystone. (E: 7a5e15f20918f1bbd8ffb62857dcd526)`);for(let s of r.challengePools)(await wc({pool:s})).forEach(i=>e.push(i)),(!s.challenges||Object.keys(s.challenges).length===0)&&e.push(`${t} invalid pool (${s.id}). pool.challenges is falsy/empty. (E: 8cd16a5416ae62a058342828be465b26)`);return r.revocationInfo&&e.push(`${t} genesis keystone already has revocationInfo. (E: e11408d0c558d0fa948efbce611ec826)`),e}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{he&&console.log(`${t} complete.`)}}f(Mo,"validateGenesisKeystone");async function jr({currentIbGib:o,prevIbGib:t}){let e=`[${jr.name}]`,r=[];try{if(!o)throw new Error("(UNEXPECTED) currentIbGib falsy? (E: 3c0f02655fa8279e386a079ebb604b25)");if(!t)throw new Error("(UNEXPECTED) prevIbGib falsy? (E: 0d07c812634d839c784f31b8848ba825)");let n=await Z({ibGib:o});n&&n.length>0&&r.push(...n);let s=o.data,a=t.data,i=s.n??-2,c=a.n??-2;i<0&&r.push("invalid keystone.currData.n is undefined or null."),c<0&&r.push("invalid keystone.prevData.n is undefined or null."),i!==c+1&&r.push(`keystone data.n values are not sequential. prevData.n: ${c}, currData.n: ${i}. `);for(let l of s.proofs){if(l.solutions.length===0){r.push(`Proof ${l.id||"unknown"} has no solutions.`);continue}let d=l.solutions[0].poolId,b=a.challengePools.find(h=>h.id===d);if(!b){r.push(`Proof references unknown pool: ${d}`);continue}await yc({proof:l,pool:b,errors:r})}if(s.revocationInfo){let l=s.revocationInfo.proof.claim.target,d=w({ibGib:t});l!==d&&r.push(`Revocation target mismatch. Expected ${d}, got ${l}`)}return r}catch(n){throw console.error(`${e} ${E(n)}`),n}finally{he&&console.log(`${e} complete.`)}}f(jr,"validateKeystoneTransition");async function yc({proof:o,pool:t,errors:e}){let r=`[${yc.name}]`;try{he&&console.log(`${r} starting... (I: b8f9b6085888eea2258bf579ecd5e825)`),t.config.allowedVerbs&&t.config.allowedVerbs.length>0&&(!o.claim.verb||!t.config.allowedVerbs.includes(o.claim.verb))&&e.push(`Policy Violation: Pool ${t.id} used for unauthorized verb ${o.claim.verb}`);let{mandatoryIds:n,availableIds:s}=Ec({pool:t,requiredChallengeIds:o.requiredChallengeIds,targetAddr:o.claim.target}),a=new Set(o.solutions.map(d=>d.challengeId));for(let d of n)a.has(d)||e.push(`Policy Violation: Missing mandatory challenge ${d}`);let i=[...a].filter(d=>!n.has(d)),c=t.config.behavior.selectRandomly;i.length<c&&e.push(`Policy Violation: Insufficient random count. Need ${c}, got ${i.length}`);for(let d of i)s.includes(d)||e.push(`Policy Violation: ID ${d} is invalid or double-dipped.`);let l=Ze.create({config:t.config});for(let d of o.solutions){let b=t.challenges[d.challengeId];b?await l.validateSolution({solution:d,challenge:b})||e.push(`Crypto Violation: Solution for ${d.challengeId} is invalid.`):e.push(`Crypto Violation: Challenge ${d.challengeId} not found in pool.`)}}catch(n){throw console.error(`${r} ${E(n)}`),n}finally{he&&console.log(`${r} complete.`)}}f(yc,"verifyProofAgainstPool");async function Xr({prevIbGib:o,newData:t,metaspace:e,space:r}){let n=`[${Xr.name}]`;try{if(he&&console.log(`${n} starting... (I: 8b10e8920f08b7842803665834cf8925)`),!o.data)throw new Error("(UNEXPECTED) prevIbGib.data falsy? (E: 5e84875bf992c585b979e6c8ed5bf225)");if(o.data.revocationInfo)throw new Error(`Keystone has already been revoked (prevIbGib.data.revocationInfo truthy), so we cannot evolve the keystone. Keystone addr: ${w({ibGib:o})} (E: 45d7f846556829de6b2a701838c3f825)`);let s=o.data,a={};s.proofs&&(a.proofs=[]),s.challengePools&&(a.challengePools=[]),s.frameDetails&&(a.frameDetails={}),s.checkpointDetails&&(a.checkpointDetails={}),Object.keys(a).length===0&&(a=void 0);let i=await Fe({src:o,dataToRemove:a,dataToAddOrPatch:t,nCounter:!0});if(i.intermediateIbGibs)throw new Error("(UNEXPECTED) resMut8.intermediateIbGibs truthy? I'm not sure if we expect there to be intermediateIbGibs, but I feel like we shouldn't. Pretty sure we shouldn't, definitely don't *want* them. (E: ba40d55d7c2d36d438c413886f148625)");if(i.dnas)throw new Error("(UNEXPECTED) resMut8.dnas truthy? We do not want dnas with keystones. (E: 49470513d018f97d28024f4e82da3b25)");let c=i.newIbGib,l=await jr({currentIbGib:c,prevIbGib:o});if(l.length>0)throw console.error(`${n} Validation Failed:
|
|
18
|
+
${l.join(`
|
|
19
|
+
`)}`),new Error(`(UNEXPECTED) invalid keystone after we just evolved it? Errors: ${l.join("; ")} (E: ae2c58406c1db7687879dfb89fc1f825)`);return await e.put({ibGib:c,space:r}),await e.registerNewIbGib({ibGib:c,space:r}),c}catch(s){throw console.error(`${n} ${E(s)}`),s}finally{he&&console.log(`${n} complete.`)}}f(Xr,"evolvePersistAndRegisterKeystone");async function Os({data:o,metaspace:t,space:e}){let r=`[${Os.name}]`;try{if(he&&console.log(`${r} starting... (I: 5e32389700e9899e788cbefacef7c825)`),e??=await t.getLocalUserSpace({lock:!1}),!e)throw new Error("(UNEXPECTED) space was falsy and we couldn't get default local user space from metaspace? (E: 9a6498cf16a8801f19ec376749742225)");let s=(await F.firstGen({parentIbGib:F.primitive({ib:$s}),ib:await gc({keystoneData:o}),data:o,dna:!1,nCounter:!0,tjp:{timestamp:!0,uuid:!0}})).newIbGib;if(!s.data)throw new Error("(UNEXPECTED) keystoneIbGib.data falsy? We expect the data to be populated with real keystone data. (E: 38a358facdb89d16d81d48c8520d3d25)");if(!s.rel8ns)throw new Error("(UNEXPECTED) keystoneIbGib.rel8ns falsy? we expect the rel8ns to have ancestor and past. (E: 20cb7723dc33ae1ef808fe76d1bf4b25)");if(!s.rel8ns.past||s.rel8ns.past.length===0)throw new Error("(UNEXPECTED) keystoneIbGib.rel8ns.past falsy or empty? we expect the firstGen call to generate an interstitial ibgib that we will splice out. (E: 0fd8388d045ab9f37834c27d67e78825)");return s.data.n=0,s.data.isTjp=!0,delete s.rel8ns.tjp,delete s.rel8ns.past,s.gib=await J({ibGib:s}),await t.put({ibGib:s,space:e}),await t.registerNewIbGib({ibGib:s,space:e}),s}catch(n){throw console.error(`${r} ${E(n)}`),n}finally{he&&console.log(`${r} complete.`)}}f(Os,"createKeystoneIbGibImpl");async function Ds({keystoneIbGib:o,dependencyGraph:t,getLatest:e,invalidIfMoreRecentKeystoneFoundInSpace:r,space:n}){let s=`[${Ds.name}]`;try{if(he&&console.log(`${s} starting... (I: 22e1ca1d5a08a3f90b7fe9da95df7b26)`),!o)throw new Error("(UNEXPECTED) keystoneIbGib falsy? (E: 26482871d529fff6e8899c5d8a6c3826)");let a=[];if(e){let b=w({ibGib:o}),h=await je({ibGibs:[o],space:n});if(!h.data)throw new Error("(UNEXPECTED) resGetLatestAddrs.data falsy? (E: 3a23b3b420a8da1928219ca8d47b2126)");if(!h.data.latestAddrsMap)throw new Error("(UNEXPECTED) resGetLatestAddrs.data.latestAddrsMap falsy? (E: 93f1180598fb65a4b8d36e08d6c50426)");let{latestAddrsMap:p}=h.data;if(Object.keys(p).length===0)throw new Error("(UNEXPECTED) latestAddrsMap truthy but empty? (E: 7142f8f7625b9186281d08251e407826)");let u=p[b];if(u)if(u!==b)if(r)a.push(`${s} more recent keystone (${u}) found than the one passed in (${b}) in space (${n.ib}). (E: 64bf48de9448ee5c7528bf03bed2a826)`);else{let[g]=await Xe({addrs:[u],space:n});o=g}else he&&console.log(`${s} incoming keystone (${b}) is the latest in the space (${n.ib}) (I: 8ffbd8d6cbc8a461e5e7f1084bd22a26)`);else console.warn(`${s} keystoneIbGib (${b}) not found in space (${n.ib}). I don't know what the implications of this are. (W: 258c88742448db34a585669484771826)`)}t??=await Et({ibGib:o,space:n});let i=Object.values(t),{mapWithTjp_NoDna:c,mapWithTjp_YesDna:l,mapWithoutTjps:d}=ut({ibGibs:i});if(Object.keys(l).length>0&&a.push(`${s} DNA found. Keystones should NOT have DNA. (E: a3ec7827c4284cdea61c2372c0615826)`),Object.keys(d).length>0&&a.push(`${s} Non-tjp ibgibs found? Keystones are expected to have tjps. (E: a3ec7827c4284cdea61c2372c0615826)`),Object.keys(c).length>0){let b=Object.values(c),h=ze({ibGibs:b}),p=Object.keys(h);if(p.length===0)throw new Error("(UNEXPECTED) orderedKeystonesMap empty? (E: d437b80bef58e83a034b28af46278726)");if(p.length>1)throw new Error("(UNEXPECTED) more than one timeline in keystone graph? ATOW (02/19/2026) we are expecting only a single timeline. (E: 66085b14e3887a59c872afd240511f26)");let u=p[0],g=h[u];if(g.length===0)throw new Error("(UNEXPECTED) empty keystoneIbGibs_ordered? (E: 4a6b085aa8a76828a8d65367e7e56526)");if((await Mo({keystoneIbGib:g[0]})).forEach($=>a.push($)),g.length!==1)for(let $=0;$<g.length-1;$++){let T=g[$],I=g[$+1],y=await jr({prevIbGib:T,currentIbGib:I});y.length>0&&(a.push(`${s} keystone has ${y.length} transition errors. i: ${$}. prevIbGib addr: ${w({ibGib:T})}. currentIbGib addr: ${w({ibGib:I})}. (E: 3ac17be916141d0c286ca5a87bb1b426)`),y.forEach(A=>a.push(A)));break}}else if(a.length===0)throw new Error("(UNEXPECTED) mapWithTjp_NoDna empty (which is an error) but errors.length === 0? If we get here, we expect one of the other errors to have been populated. (E: 7bca2866b6f8fca318923de8c88e8826)");return a}catch(a){throw console.error(`${s} ${E(a)}`),a}finally{he&&console.log(`${s} complete.`)}}f(Ds,"validateKeystoneGraph");var Pe=!1,ve=class o{static{f(this,"KeystoneService_V1")}lc=`[${o.name}]`;async genesis({masterSecret:t,frameDetails:e,configs:r,metaspace:n,space:s}){let a=`${this.lc}[${this.genesis.name}]`;try{Pe&&console.log(`${a} starting... (I: c98ae8adbc5888dbf84c5aced7610b25)`);let i=[];for(let d of r){let b=Ze.create({config:d}),h=await b.derivePoolSecret({masterSecret:t}),p={},u={},g=d.behavior.size,m=Date.now().toString();for(let $=0;$<g;$++){let T=await Po({salt:d.salt,timestamp:m,index:$}),I=await b.generateSolution({poolSecret:h,poolId:d.id,challengeId:T}),y=await b.generateChallenge({solution:I});p[T]=y,Lo(u,T)}i.push({id:d.id,config:d,challenges:p,bindingMap:u})}if(i.length===0)throw new Error("No challenge pools created. (E: 38e538530996940e1f16a8b199995825)");let c={challengePools:i,proofs:[]};return e&&(c.frameDetails=e),await Os({data:c,metaspace:n,space:s})}catch(i){throw console.error(`${a} ${E(i)}`),i}finally{Pe&&console.log(`${a} complete.`)}}async sign({latestKeystone:t,masterSecret:e,claim:r,poolId:n,poolFilter:s,requiredChallengeIds:a=[],frameDetails:i,metaspace:c,space:l}){let d=`${this.lc}[${this.sign.name}]`;try{Pe&&console.log(`${d} starting...`);let b=t.data;if(b.revocationInfo)throw new Error("Keystone has been revoked. Cannot sign. (E: 4f2198c39116d15c48ba191940316825)");let h=Ro({pools:b.challengePools,poolId:n,poolFilter:s,verb:r.verb});Pe&&console.log(`${d} Selected pool: ${h.id} (size: ${Object.keys(h.challenges).length}) (I: 6b26d6f4aad18380f2b3a0989b592826)`);let p=Uo({pool:h,targetAddr:r.target,requiredChallengeIds:a}),{proof:u,nextPools:g}=await ko({targetPoolId:h.id,prevPools:b.challengePools,masterSecret:e,challengeIds:p,claim:r,requiredChallengeIds:a}),m=(b.n??0)+1,$;if(m%vo===0){let y={...t,data:{...b,frameDetails:i}};$=await this.getAggregateDetails({latestKeystone:y,metaspace:c,space:l})}return await Xr({prevIbGib:t,newData:{challengePools:g,proofs:[u],frameDetails:i,checkpointDetails:$},metaspace:c,space:l})}catch(b){throw console.error(`${d} ${E(b)}`),b}finally{Pe&&console.log(`${d} complete.`)}}async validate({currentIbGib:t,prevIbGib:e}){return await jr({currentIbGib:t,prevIbGib:e})}async validateGenesisKeystone({keystoneIbGib:t}){return await Mo({keystoneIbGib:t})}async getLatestKeystone({addr:t,metaspace:e,space:r}){let n=`${this.lc}[${this.getLatestKeystone.name}]`;try{Pe&&console.log(`${n} starting...`);let s=await e.getLatestAddr({tjpAddr:t,space:r});if(!s)throw new Error(`could not find latest addr for ${t}`);let a=await e.get({addr:s,space:r});if(a.success&&a.ibGibs&&a.ibGibs.length>0)return a.ibGibs[0];{let c=a.rawResultIbGib?.data?.addrsNotFound??"unknown";throw new Error(`couldn't find latest keystone at ${s}. addrsNotFound: ${c}? resGet.errorMsg: ${a.errorMsg}`)}}catch(s){throw console.error(`${n} ${E(s)}`),s}finally{Pe&&console.log(`${n} complete.`)}}async validateKeystoneGraph({keystoneIbGib:t,dependencyGraph:e,getLatest:r,invalidIfMoreRecentKeystoneFoundInSpace:n,space:s}){let a=`${this.lc}[${this.validateKeystoneGraph.name}]`;try{return Pe&&console.log(`${a} starting... (I: 01c5cd455038c270cbf1effc1704af26)`),await Ds({keystoneIbGib:t,dependencyGraph:e,getLatest:r,invalidIfMoreRecentKeystoneFoundInSpace:n,space:s})}catch(i){throw console.error(`${a} ${E(i)}`),i}finally{Pe&&console.log(`${a} complete.`)}}async revoke({latestKeystone:t,masterSecret:e,reason:r="User initiated revocation",frameDetails:n,metaspace:s,space:a}){let i=`${this.lc}[${this.revoke.name}]`;try{Pe&&console.log(`${i} starting...`);let c=t.data,l=Ro({pools:c.challengePools,poolId:Ss}),d={verb:No,target:w({ibGib:t})},b=Uo({pool:l,targetAddr:d.target,requiredChallengeIds:[]});if(b.length===0)throw new Error(`Revocation policy selected 0 challenges? Check config for pool ${l.id}. Revocation requires proof. (E: 97e5a8356d241ae7b882db791cb1f825)`);let{proof:h,nextPools:p}=await ko({targetPoolId:l.id,prevPools:c.challengePools,masterSecret:e,challengeIds:b,claim:d,requiredChallengeIds:[]});p.find(I=>I.id===l.id&&Object.keys(I.challenges).length>0)&&console.warn(`${i} revocation pool ${l.id} is not empty after revocation. Is the revocation pool replenish strategy set to ${be.deleteAll}? (W: 300c28bc8b98fc3e3c0b0d988344f825)`);let u={reason:r,proof:h},g=(c.n??0)+1,m;if(g%vo===0){let I={...t,data:{...c,frameDetails:n,revocationInfo:u}};m=await this.getAggregateDetails({latestKeystone:I,metaspace:s,space:a})}return await Xr({prevIbGib:t,newData:{challengePools:p,proofs:[h],revocationInfo:u,frameDetails:n,checkpointDetails:m},metaspace:s,space:a})}catch(c){throw console.error(`${i} ${E(c)}`),c}finally{Pe&&console.log(`${i} complete.`)}}async addPools({latestKeystone:t,masterSecret:e,newPools:r,metaspace:n,space:s}){let a=`${this.lc}[${this.addPools.name}]`;try{if(Pe&&console.log(`${a} starting...`),!t.data)throw new Error("(UNEXPECTED) latestKeystone.data falsy? (E: 7334c8faed128166a999d428c7805b25)");let i=t.data;if(i.revocationInfo)throw new Error("Keystone has been revoked. Cannot add pools. (E: 8599f8f51c78d722252ddb2894fdbe25)");if(r.length===0)throw new Error("No new pools provided to add. (E: 6599f8f51c78d722252ddb2894fdbe25)");let c=Ro({pools:i.challengePools,verb:Fr});Pe&&console.log(`${a} Authorized via pool: ${c.id}`);let l=w({ibGib:t}),d={verb:Fr,target:l,scope:JSON.stringify({add:r.map(y=>y.id)})},b=Uo({pool:c,targetAddr:l}),{proof:h,nextPools:p}=await ko({targetPoolId:c.id,prevPools:i.challengePools,masterSecret:e,challengeIds:b,claim:d}),u=new Set(p.map(y=>y.id));for(let y of r)if(u.has(y.id))throw new Error(`Cannot add pool. ID collision: ${y.id} (E: 8a4c2b1d3e5f6a7b8c9d0e1f2a3b4c5d)`);let g=[...p,...r],m=(i.n??0)+1,$;if(m%vo===0){let y={...t,data:{...i,challengePools:g}};$=await this.getAggregateDetails({latestKeystone:y,metaspace:n,space:s})}return await Xr({prevIbGib:t,newData:{challengePools:g,proofs:[h],checkpointDetails:$},metaspace:n,space:s})}catch(i){throw console.error(`${a} ${E(i)}`),i}finally{Pe&&console.log(`${a} complete.`)}}async getAggregateDetails({latestKeystone:t,metaspace:e,space:r}){let n=`${this.lc}[${this.getAggregateDetails.name}]`;try{let s={},a=t;for(;a;){let i=a.data;if(i.checkpointDetails){s=cr({dominant:s,recessive:i.checkpointDetails});break}if(i.frameDetails&&(s=cr({dominant:s,recessive:i.frameDetails})),i.n===0)break;let c=a.rel8ns?.past,l=c&&c.length>0?c[c.length-1]:void 0;if(!l)break;let d=await e.get({addr:l,space:r});if(!d.success||!d.ibGibs||d.ibGibs.length===0)throw new Error(`Could not find previous keystone frame at ${l} (E: e3d069b22e11e550e58844889ddb5325)`);a=d.ibGibs[0]}return s}catch(s){throw console.error(`${n} ${E(s)}`),s}}};var Fo=!1,Ls=class{static{f(this,"KeystoneConfigBuilderBase")}_id;_salt;_size;_replenish;_seq;_rand;_verbs=[];_targetBinding;withId(t){return this._id=t,this}withSalt(t){return this._salt=t,this}withSize(t){return this._size=t,this}withTargetBinding(t){return this._targetBinding=t,this}withFIFO(t){return this._seq=t,this._rand=0,this}withRandom(t){return this._seq=0,this._rand=t,this}withHybrid({seqCount:t,randCount:e}){return this._seq=t,this._rand=e,this}withReplenishStrategy(t){return this._replenish=t,this}buildBehavior(){if(this._size===void 0)throw new Error("size required (E: 68320865d9adb8477836485b20b08826)");if(this._replenish===void 0)throw new Error("replenish strategy required (E: 9f8798d1a568763a282e53c89185b826)");if(this._seq===void 0)throw new Error("sequential required (E: e0da08a24e9790d0a8c1a9322f8eb826)");if(this._rand===void 0)throw new Error("selectRandomly required (E: 7721d84d1a8b7d020d0ab33c3f811426)");if(this._targetBinding===void 0)throw new Error("targetBinding required (E: 9add64d7e8e8cba01d901727a8e9b826)");return{size:this._size,replenish:this._replenish,selectSequentially:this._seq,selectRandomly:this._rand,targetBindingChars:this._targetBinding}}forVerbs(t){return this._verbs=t,this}},Ps=class o extends Ls{static{f(this,"KeystoneConfigBuilder_HashV1")}lc=`[${o}]`;_algo;_rounds;withHash({algo:t,rounds:e}){let r=`${this.lc}[${this.withHash.name}]`;try{return Fo&&console.log(`${r} starting... (I: 15d1b3bd2e98bba33fc6c78228755826)`),this._algo=t,this._rounds=e,this}catch(n){throw console.error(`${r} ${E(n)}`),n}finally{Fo&&console.log(`${r} complete.`)}}build(){let t=`${this.lc}[${this.build.name}]`;try{if(Fo&&console.log(`${t} starting... (I: 5df568c63c4993bb98df0a319ee16826)`),!this._id)throw new Error("id required (E: b50d082adf38bcbf463552f80d2c3226)");if(!this._salt)throw new Error("salt required (E: b0f1926657b8d7d3a88fb9385ead5826)");if(!this._algo)throw new Error("algorithm required (E: cff228f9898fd6383ef752088dae6826)");if(this._rounds===void 0)throw new Error("rounds required (E: eb72580f3b014cda18cba3e399683c26)");return{id:this._id,type:Je.hash_reveal_v1,salt:this._salt,allowedVerbs:this._verbs,behavior:this.buildBehavior(),algo:this._algo,rounds:this._rounds}}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{Fo&&console.log(`${t} complete.`)}}},Hr=class{static{f(this,"KeystoneConfig")}static hash(){return new Ps}};function Rs(o){if(o.type&&o.type!==Je.hash_reveal_v1)throw new Error(`invalid type (${o.type}). Only ${Je.hash_reveal_v1} currently implemented. (E: c38616cd7a459149f670418f88766526)`);let{salt:t,id:e,size:r,sequential:n,random:s,targetBinding:a,replenishStrategy:i,verbs:c,hashAlgorithm:l,hashRounds:d}=o;return Hr.hash().withId(e).withSalt(t).withSize(r??Gs).withHybrid({seqCount:n??Cs,randCount:s??xs}).withTargetBinding(a??Ns).withReplenishStrategy(i??vs).withHash({algo:l??oc,rounds:d??nc}).forVerbs(c??[]).build()}f(Rs,"createStandardPoolConfig");function Ad(o){if(o.type&&o.type!==Je.hash_reveal_v1)throw new Error(`invalid type (${o.type}). Only ${Je.hash_reveal_v1} currently implemented. (E: 09c1f7772bd2a7910f5562b4934d3826)`);let{salt:t,id:e,size:r,sequential:n,random:s,targetBinding:a,replenishStrategy:i,verbs:c,hashAlgorithm:l,hashRounds:d}=o;return Hr.hash().withId(e).withSalt(t).withSize(r??sc).withHybrid({seqCount:n??ac,randCount:s??ic}).withTargetBinding(a??cc).withReplenishStrategy(i??lc).withHash({algo:l??dc,rounds:d??fc}).forVerbs(c??[]).build()}f(Ad,"createHighSecurityPoolConfig");function $c(o){return Ad({...o,id:o.id??rc,verbs:o.verbs??[As.MANAGE]})}f($c,"createManagePoolConfig");function Ic({template:o,behaviorProfiles:t,salt:e}){let r;return o.behaviorProfile&&t&&(r=t[o.behaviorProfile]),r||(r=o.behaviorInline),r||(r={size:Gs,replenish:vs,selectSequentially:Cs,selectRandomly:xs,targetBindingChars:Ns}),Hr.hash().withId(o.id).withSalt(e).withSize(r.size).withHybrid({seqCount:r.selectSequentially,randCount:r.selectRandomly}).withTargetBinding(r.targetBindingChars).withReplenishStrategy(r.replenish).withHash({algo:o.algo,rounds:o.rounds}).forVerbs(o.allowedVerbs).build()}f(Ic,"createPoolConfigFromJson");var Bo="sync",me="syncmsg",Us="@payloadAddrsDomain",Sd="init",Gd="ack",Cd="delta",xd="commit",Q={init:Sd,ack:Gd,delta:Cd,commit:xd},Xm=Object.values(Q),Nd="abort",vd="optimistic-graft-longest-common-subsequence",nt={abort:Nd,optimisticWithLCS:vd},er=Object.values(nt);function jo(o){return er.includes(o)}f(jo,"isValidSyncConflictStrategy");var Od="push",Dd="pull",Ld="sync",ks={push:Od,pull:Dd,sync:Ld},Wm=Object.values(ks);var Pd="sender",Rd="receiver",Xo={sender:Pd,receiver:Rd},Vm=Object.values(Xo);var _c=!1;function Ms({base:o,extended:t,throwIfExtendedDoesntContainBase:e}){let r=`[${Ms.name}]`;try{_c&&console.log(`${r} starting... (I: 00d70d79a0249165c2a230389c962526)`);let n=!0;for(let a=0;a<o.length;a++)if(o[a]!==t[a]){n=!1;break}if(e&&!n)throw new Error(`base addrs do not correspond to extended addrs. We were expecting the base to be the exact start of the extended strand, e.g., base [a, b, c] with extended [a, b, c, d, e]. base: ${o}. extended: ${t}. (E: fb80b40003289bbf1aaedd4829fa1826)`);let s;if(n)s=t.slice(o.length);else{s=[];for(let a of t)o.includes(a)||s.push(a)}return s}catch(n){throw console.error(`${r} ${E(n)}`),n}finally{_c&&console.log(`${r} complete.`)}}f(Ms,"getUniqueDnas");async function Ho({src:o,createdIbGibs_Running:t,dnaAddrsToApplyToStoreVersion_MUTATES_IN_PLACE:e,allLocalIbGibs:r}){let n=`[${Ho.name}]`;try{if(e.length>0){let s=e.splice(0,1)[0],a=r.filter(d=>w({ibGib:d})===s),i;if(a.length===1)i=a[0];else throw a.length===0?new Error(`dna ibGib not found in supplied allLocalIbGibs. dnaAddr: ${s}. (E: 7f56826852cf48a79ab8af16bf27e284)`):new Error(`More than one ibGib in allLocalIbGibs with the dna address of ${s}? (E: a726134f4cc14a4fb2ed2d39d22af17c)(UNEXPECTED)`);let c=L(i.data);c.src=o,c.srcAddr=w({ibGib:o});let l;switch(c.type){case"mut8":l=await Fe(c);break;case"rel8":l=await Ce(c);break;case"fork":throw new Error("fork transform not expected. atow only a single fork is expected at the beginning of the lifetime of a tjp ibgib. This fork defines the uniqueness of the tjp ibgib. When merging another tjp ibgib, we would only expect update transforms to be mut8 or rel8. (E: f8ad6996ac5545edad2d58a293d37d94)");default:throw new Error(`unknown dna argTransform.type (${c.type}) for dna address: ${s}. Expecting either mut8 or rel8. (fork transform is known but not expected either.) (E: 52a98db56e934e4cb42c64e2f45fa552)`)}if((l.intermediateIbGibs??[]).forEach(d=>t.push(d)),(l.dnas??[]).forEach(d=>t.push(d)),t.push(l.newIbGib),(l.dnas??[]).length>0){if(!l.dnas.some(d=>w(d)===s))throw new Error(`${n}(UNEXPECTED) Expected to generate exact dna that we applied in transform. dnaAddr: ${s} (E: 4a364c0b5d8d46c8af6bd540915fd973)`)}else console.warn(`${n}(UNEXPECTED) expected resTransform to include generated dna. dnaAddr: ${s}(W: 9648e2d5c40d42b7b9fb7efb09c5b13a)`);return await Ho({src:l.newIbGib,createdIbGibs_Running:t,dnaAddrsToApplyToStoreVersion_MUTATES_IN_PLACE:e,allLocalIbGibs:r})}else return t.length===0&&console.warn(`${n} no dna transforms to apply but createdIbGibs_Running is empty. Dna is expected to start with at least one transform, otherwise don't call this function. (W: 52c7f2f6bd7e4bd0b31f53611b90268b)(UNEXPECTED)`),o}catch(s){throw console.error(`${n} ${E(s)}`),s}}f(Ho,"applyTransforms");var wr="graftinfo",qr=wr,Tc="latestcommonaddr",Ac="base",qo="orphan",Sc="dnaapplied",Ud="longest-common-subsequence",Fs={lcs:Ud},s8=Object.values(Fs);var Re=!0;async function kd({data:o}){if(!o.conflictStrategy)throw new Error("(UNEXPECTED) data.conflictStrategy required for GraftInfoIb (E: 2c0968a0dac8d0ab3d67da9756d6df26)");if(!jo(o.conflictStrategy))throw new Error(`invalid data.conflictStrategy (${o.conflictStrategy}). valid conflict strategies: ${er} (E: 41e2680089786d4d28046b4c0884bd26)`);return[wr,o.conflictStrategy].join(" ")}f(kd,"getGraftInfoIb");async function Gc({conflictStrategy:o,details:t,addlGraftDetails:e,latestCommonFrameAddr:r,baseAddrsSinceLCA:n,orphanAddrsSinceLCA:s,dnaAddrsApplied:a}){let i=`[${Gc.name}]`;try{if(Re&&console.log(`${i} starting... (I: 0030f62cbae28cf5882f87981edc3826)`),n.length===0)throw new Error("(UNEXPECTED) baseAddrsSinceLCA empty? (E: 005f8449a9236d445902a148f59fc826)");if(s.length===0)throw new Error("(UNEXPECTED) orphanAddrsSinceLCA empty? (E: 19e4082e82c67759c880392aca186826)");let c={conflictStrategy:o,description:t};e&&(c.addlGraftDetails=e);let l={[Tc]:[r],[Ac]:n.concat(),[qo]:s.concat(),[Sc]:a.concat()},d=await kd({data:c});return await F.stone({parentPrimitiveIb:wr,ib:d,data:c,rel8ns:l,uuid:!0})}catch(c){throw console.error(`${i} ${E(c)}`),c}finally{Re&&console.log(`${i} complete.`)}}f(Gc,"createGraftInfo");async function Md({textA:o,textB:t}){if(o===t)return o;if(o==="")return t;if(t==="")return o;function e(l,d){let b=l.length,h=d.length,p=Array(b+1).fill(0).map(()=>Array(h+1).fill(0));for(let $=1;$<=b;$++)for(let T=1;T<=h;T++)l[$-1]===d[T-1]?p[$][T]=p[$-1][T-1]+1:p[$][T]=Math.max(p[$-1][T],p[$][T-1]);let u=b,g=h,m=[];for(;u>0&&g>0;)l[u-1]===d[g-1]?(m.unshift({line:l[u-1],indexA:u-1,indexB:g-1}),u--,g--):p[u-1][g]>p[u][g-1]?u--:g--;return m}f(e,"longestCommonSubsequence");let r=o.split(`
|
|
20
|
+
`),n=t.split(`
|
|
21
|
+
`),s=e(r,n),a=[],i=0,c=0;for(let l of s){for(;i<l.indexA;)a.push(r[i]),i++;for(;c<l.indexB;)a.push(n[c]),c++;a.push(l.line),i++,c++}for(;i<r.length;)a.push(r[i]),i++;for(;c<n.length;)a.push(n[c]),c++;return a.join(`
|
|
22
|
+
`)}f(Md,"mergeTextByLongestCommonSubsequence");async function Bs({timelineAddrsA:o,timelineAddrsB:t,latestCommonFrameAddr:e,conflictStrategy:r,ibGibReadCache:n,space:s}){let a=`[${Bs.name}]`;try{let T=function($e){let Yt=`${a}[${T.name}]`;for(let Ye of $e){if(!Ye.rel8ns)throw new Error(`(UNEXPECTED) ${Yt} someIbGib.rel8ns falsy? All ibgibs with mergeable timelines are expected to have rel8ns. addr: ${w({ibGib:Ye})} (E: 5534a478cd183a5ee27b28487448b226)`);if(!Ye.rel8ns.dna)throw new Error(`(UNEXPECTED) someIbGib.rel8ns.dna falsy? We only have implemented grafting for dna. addr: ${w({ibGib:Ye})} (there should be another route for merging for non-dna timelines) (E: d86b388c627afd613f897e3819d8ab26)`);if(Ye.rel8ns.dna.length===0)throw new Error(`(UNEXPECTED) someIbGib.rel8ns.dna.length === 0? We only have implemented grafting for dna. addr: ${w({ibGib:Ye})} (there should be another route for merging for non-dna timelines) (E: bf973662a0689dd9089912b861af2826)`)}};var i=T;f(T,"throwIfUnexpected"),Re&&console.log(`${a} starting... (I: 3b4c3e8e59c883d9d3c352efd6380826)`);let c=[],l=[];if(o.length===0)throw new Error("timelineAddrsA empty (E: 93a78cd1cd2a4a16ba99bd4820468f26)");if(t.length===0)throw new Error("timelineAddrsB empty (E: 76d53848152a66971b734068c3316826)");if(e){if(!o.includes(e))throw new Error(`timelineAddrsA does not include latestCommonFrameAddr (${e}). timelineAddrsA: ${o} (E: c5a9afe371888da2a79963983426e826)`);if(!t.includes(e))throw new Error(`timelineAddrsB does not include latestCommonFrameAddr (${e}). timelineAddrsB: ${t} (E: 7e641f67c452b67d582d78484a88c826)`)}else if(e=o.findLast($e=>t.includes($e)),!e)throw new Error(`timelines do not share a common frame. A: ${o}. B: ${t} (E: 4c0e78a88a375d8588736668573f1e26)`);if(o.at(-1)===e){debugger;throw new Error("timelineAddrsA.at(-1) === latestCommonFrameAddr. Graft requires a branch BEYOND the LCA (E: 3796fc4074a8c5899d549bb8c2e68826)")}if(t.at(-1)===e)throw new Error("timelineAddrsB.at(-1) === latestCommonFrameAddr. Graft requires a branch BEYOND the LCA (E: 66fbb86e9e98531549888bf10a344f26)");let d=o.lastIndexOf(e),b=o.slice(d+1),h=await Xe({readCache_graph:n,addrs:b,space:s}),p=h.at(-1),u=t.lastIndexOf(e),g=t.slice(u+1),m=await Xe({readCache_graph:n,addrs:g,space:s}),$=m.at(-1);T(h),T(m);let I,y,A,_,S=Ut({ibGib:p}),N=S.valid?Number.parseInt(S.ticks):Number.MAX_SAFE_INTEGER,O=S.valid?S.ms??0:0,D=Ut({ibGib:$}),k=D.valid?Number.parseInt(D.ticks):Number.MAX_SAFE_INTEGER,U=D.valid?D.ms??0:0;N<k?(I=p,y=h,A=$,_=m):N>k?(I=$,y=m,A=p,_=h):O<=U?(I=p,y=h,A=$,_=m):(I=$,y=m,A=p,_=h);let R=w({ibGib:I}),Y=y.map($e=>w({ibGib:$e})),oe=w({ibGib:A}),ye=_.map($e=>w({ibGib:$e}));Re&&console.log(`${a} baseTipAddr: ${R} (I: 93353d9b9b68b17088f57958df85e826)`),Re&&console.log(`${a} orphanTipAddr: ${oe} (I: 14df8867adc5dab97ff3c1e989b40e26)`);let[at]=await Xe({addrs:[e],space:s});if(!at)throw new Error("(UNEXPECTED) latestCommonFrameIbGib falsy? (E: ead2020b7ab8e4c4f824573133e33826)");if(!at.rel8ns)throw new Error("(UNEXPECTED) latestCommonFrameIbGib.rel8ns falsy? (E: b3f338032d19816fc87d3c78af255726)");if(!at.rel8ns.dna||at.rel8ns.dna.length===0)throw new Error("(UNEXPECTED) latestCommonFrameIbGib.rel8ns.dna falsy/empty? It should at least have the first fork transform. (E: 98fd8c725f484d85c8d23ceb181ce826)");let vt=at.rel8ns.dna.concat(),Qe=[];for(let $e of _){if(!$e.rel8ns)throw new Error("(UNEXPECTED) orphanFrame.rel8ns falsy? (E: ed910e3b930b1b5388d87c6f736a4826)");let Yt=Ms({base:vt,extended:$e.rel8ns.dna??[],throwIfExtendedDoesntContainBase:!0});if(Yt.forEach(Ye=>vt.push(Ye)),Yt.length===0)throw new Error("(UNEXPECTED) orphanDnaAddrsToApply empty? (E: d44ed439e538e5b538d12d71063f0826)");Yt.forEach(Ye=>Qe.push(Ye))}let Ae=await Xe({addrs:Qe,readCache_graph:n,space:s}),Ue=[],Se=await Ho({src:I,dnaAddrsToApplyToStoreVersion_MUTATES_IN_PLACE:Qe.concat(),allLocalIbGibs:Ae,createdIbGibs_Running:Ue});if(!Se.data)throw new Error("(UNEXPECTED) graftTip_sansGraftInfo.data falsy? (E: 4792f8e84fc84966e89220fae0657826)");if(!Se.data.n)throw new Error("(UNEXPECTED) graftTip_sansGraftInfo.data.n falsy? (E: a2b3ca4cdec8d01f282dd3e4ff9eab26)");if(Ue.length===0)throw new Error("(UNEXPECTED) applyTransforms called but createdIbGibs_Running is empty? This should contain all of the (E: 5b6c788488f5095b08eb8e31d55b1726)");console.warn(`${a} START...................... Do we get a bunch of "already had addr(s)" messages for dna ibgibs? I'm thinking we will already have the dna ibgibs stored in the space (temp space?) before we do this graft. Maybe it creates new dna, I don't know. remove this later when we decide something to do about it. space.ib: ${s.ib} (W: bb60481ecabaa6f49e14203891824a26)`),await xe({space:s,ibGibs:Ue}),console.warn(`${a} END........................ Do we get a bunch of "already had addr(s)" messages for dna ibgibs? I'm thinking we will already have the dna ibgibs stored in the space (temp space?) before we do this graft. Maybe it creates new dna, I don't know. remove this later when we decide something to do about it. space.ib: ${s.ib} (W: bb60481ecabaa6f49e14203891824a26)`);let{mapWithTjp_NoDna:Tr,mapWithTjp_YesDna:zr,mapWithoutTjps:ne}=ut({ibGibs:Ue});if(Object.keys(Tr).length>0)throw new Error("(UNEXPECTED) mapWithTjp_NoDna is populated? We've just applied the dna from the orphan branch which created ibgibs (and dnas). But we are expected to be executing on an ibgib timeline that has dna. The applyTransforms was not expected to create any other ibgibs than the one in our timeline (with dna) and any corresponding dnas. (E: 236e989fb5e8a4a498a21b98f718c826)");let it=Object.values(zr),mt=ze({ibGibs:it});if(Object.keys(mt).length===0)throw new Error("(UNEXPECTED) newGraftedIbGibsByTjp has 0 timelines? we expect this to have a single timeline: the one we're grafting. (E: 2b7127bd0c6bfeaec8d66038ba208226)");if(Object.keys(mt).length>1)throw new Error("(UNEXPECTED) newGraftedIbGibsByTjp has more than one timeline? we expect this to have a single timeline: the one we're grafting. (E: 076758885b8ea7c89849a76334222326)");Object.values(mt)[0].forEach($e=>c.push($e));for(let $e of c)await de({ibGib:$e,space:s});let Jr;if(r===nt.optimisticWithLCS){if(!I.data)throw new Error("(UNEXPECTED) baseTip.data falsy? (E: 92623857e19b9b4e081e8c8d9eb45526)");if(!A.data)throw new Error("(UNEXPECTED) orphanTip.data falsy? (E: 2e6828a4c9226ac917ab6fe833672826)");if((A.data.text||I.data.text)&&A.data.text!==I.data.text){Re&&console.log(`${a} different data.text found. executing text merge for conflictStrategy ${r} (I: cfb5f9580832040388fc576eb71ac526)`);let $e=A.data.text??"",Yt=oe,Ye=I.data.text??"",tl=R,rl=await Md({textA:$e,textB:Ye}),ct=await Fe({src:Se,dataToAddOrPatch:{text:rl},dna:!0,nCounter:!!Se.data.n});if(ct.intermediateIbGibs&&ct.intermediateIbGibs.length>0)throw new Error("(UNEXPECTED) resMut8Text.intermediateIbGibs truthy/non-empty? This is expected to only create the newIbGib with no intermediates. (E: 7932a8964a3869accadc9b0d93d23826)");if(!ct.dnas||ct.dnas.length===0)throw new Error("(UNEXPECTED) resMut8Text.dnas falsy/empty? We're expected to generate dna from this merge text mut8. (E: fdf03754bf0f8661f80f59ea0701dd26)");if(ct.dnas.length!==1)throw new Error("(UNEXPECTED) resMut8Text.dnas.length !== 1? we're expecting a single mut8 dna. (E: 9574d86a9108095cb454b049bcca5326)");if(l.push(ct.dnas[0]),c.push(ct.newIbGib),await se({resTransform:ct,space:s}),await de({ibGib:ct.newIbGib,space:s}),Jr={mergeTextStrategy:Fs.lcs,textAAddr:Yt,textBAddr:tl},Se=ct.newIbGib,!Se.data)throw new Error("(UNEXPECTED) graftTip_sansGraftInfo.data falsy after mut8 merge text? (E: 6b65d83df6681887686a0098144eea26)")}}let Ar=await Gc({conflictStrategy:r,details:`Replayed ${Qe.length} transforms from orphan (${oe}) onto base (${R}).`,addlGraftDetails:Jr?[Jr]:void 0,latestCommonFrameAddr:e,baseAddrsSinceLCA:Y,orphanAddrsSinceLCA:ye,dnaAddrsApplied:Qe});Re&&console.log(`${a} intrinsic graft complete. graftInfo to be appended to timeline:
|
|
23
|
+
${P(Ar)} (I: ab9d1e73db9a3ff4f8241f38197bb826)`),await xe({ibGib:Ar,space:s});let Tn=w({ibGib:Ar}),wt=await Ce({src:Se,rel8nsToAddByAddr:{[qr]:[Tn]},dna:!0,nCounter:!!Se.data.n});if(wt.intermediateIbGibs&&wt.intermediateIbGibs.length>0)throw new Error("(UNEXPECTED) resRel8GraftInfo.intermediateIbGibs truthy/non-empty? This is expected to only create the newIbGib with no intermediates. (E: 78b928ace4287b4dc82f413fdad60826)");if(!wt.dnas||wt.dnas.length===0)throw new Error("(UNEXPECTED) resRel8GraftInfo.dnas falsy/empty? We're expected to generate dna from this rel8. (E: 4c8fdde70368d643f86732dfa48c5526)");if(wt.dnas.length!==1)throw new Error("(UNEXPECTED) resRel8GraftInfo.dnas.length !== 1? we're expecting a single rel8 dna. (E: c2f5085c1718d7149e04f5c814027926)");l.push(wt.dnas[0]),await se({resTransform:wt,space:s}),await de({ibGib:wt.newIbGib,space:s});let Ia=wt.newIbGib;Re&&console.log(`${a} finalGraftTip: ${P(Ia)} (I: 454e72957be8221b96931c289053fc26)`);let _a={dnasReplayed:Ae,dnasCreatedInGraft:l,intermediateIbGibsCreatedInGraft:c,newGraftTip:Ia,graftInfoCreated:Ar};return Re&&console.log(`${a} result... (I: d6a02f95eb2564c621810ef855434226)`),Re&&console.dir(_a),_a}catch(c){throw console.error(`${a} ${E(c)}`),c}finally{Re&&console.log(`${a} complete.`)}}f(Bs,"graftTimelines");function js(o){let t=`[${js.name}]`;try{if(Re&&console.log(`${t} starting... (I: fe9adfe1a3175d87982507c8851f5826)`),!o)throw new Error("(UNEXPECTED) not a graft info, ibGib falsy? (E: bf06cdd700788e777f72fe5a5bdb0e26)");if(!o.data)throw new Error("not a graft info, ibGib.data falsy (E: 5e1b28843ec8571a7623046a06195826)");if(!o.ib.startsWith(wr))throw new Error(`not graft info, ibgib.ib does not start with ${wr} (E: cec6a8e25ff8746aef813e38cbebce26)`);return!0}catch(e){return Re&&console.error(`${t} ${E(e)}`),!1}finally{Re&&console.log(`${t} complete.`)}}f(js,"isGraftInfo");var ae=!1;async function Xs({data:o}){let t=`[${Xs.name}]`;try{return[Bo,o.uuid].join(" ")}catch(e){throw console.error(`${t} ${E(e)}`),e}}f(Xs,"getSyncIb");async function Cc(){return`tmp_sync_space_${(await j()).substring(0,8)}`}f(Cc,"getTempSpaceName");async function yr({olderAddr:o,newerAddr:t,space:e}){let r=`[${yr.name}]`;try{if(ae&&console.log(`${r} starting... (I: 4b3548cbc9a2eb749f447ed82fdcf826)`),o===t)return!0;let n,s=await B({space:e,addr:t});if(s.success&&s.ibGibs?.length===1)n=s.ibGibs[0];else throw new Error(`couldn't get newerAddr (${t}) from space (${e.ib}). (E: 36c758c22b181b2c89a1cd28937a6826)`);if(!n.rel8ns)return console.warn(`${r} newerIbGib.rel8ns falsy? newerAddr: ${t}. (W: 6f920811f7080281189f767813814826)`),!1;let a=n.rel8ns.past??[];if(a.length===0)return!1;if(a.includes(o))return!0;let i=a[0];return await yr({olderAddr:o,newerAddr:i,space:e})}catch(n){throw console.error(`${r} ${E(n)}`),n}finally{ae&&console.log(`${r} complete.`)}}f(yr,"isPastFrame");async function Ko({sagaIbGib:o,localSpace:t}){let e=`[${Ko.name}]`,r=f(async i=>{let c=await B({space:t,addrs:i});if(c.success&&c.ibGibs?.length===i.length)return c.ibGibs;{let l=c.rawResultIbGib;throw l.data?new Error(`(UNEXPECTED) couldn't find addrs? addrsNotFound: ${l.data.addrsNotFound}? space.ib: ${t.ib} (E: 43b7b5a6ad982715c8f3eed69bfa0d26)`):new Error("(UNEXPECTED) resGet.rawResultIbGib.data falsy? (E: c26c681d2f831fc537ba6f48fee36d26)")}},"fnGet"),n=await Yo({sagaIbGib:o});if(n.length>0)throw new Error(`invalid sync sagaIbGib. validationErrors: ${n} (E: 19f9e8c9643858ff41312b62293d2126)`);if(!o.rel8ns)throw new Error("(UNEXPECTED) validated sagaIbGib.rel8ns falsy? (E: 73af48be8bbf271ec5cf78187ce8c826)");let s=o.rel8ns[me],a=await r(s);return{sagaIbGib:o,msgStones:a}}f(Ko,"getSyncSagaFrameDependencyGraph");async function $r({sagaIbGib:o,space:t}){let e=`[${$r.name}]`;try{if(ae&&console.log(`${e} starting... (I: 1ea3f804dd07d1e917a2afaaad497826)`),!o.data)throw new Error("(UNEXPECTED) sagaIbGib.data falsy? (E: fe0a0d0965e87ac852fe7ba4710cc826)");if(!o.rel8ns)throw new Error("(UNEXPECTED) sagaIbGib.rel8ns falsy? (E: b79ff82a732346bdf8a9e1eb9ac96826)");let r=w({ibGib:o}),n=o.rel8ns.past&&o.rel8ns.past.length>0?[...o.rel8ns.past,r]:[r],s=[];for(let a of n){let i,c=await B({addr:a,space:t});if(c.success&&c.ibGibs&&c.ibGibs.length===1)i=c.ibGibs[0];else throw ae&&console.log(`${e} failed getting full history of sagaIbGib:
|
|
24
|
+
${P(o)} (I: 2a35685bfe038f63182c7db39b44c826)`),new Error(`couldn't get saga addr (${a}) from space (${t.ib}) (E: 865b78ecd918c244158813650bea7d26)`);let l=await Ko({sagaIbGib:i,localSpace:t});s.push(l)}return ae&&console.log(`${e} resGraphs:...
|
|
25
|
+
${P(s).split(`
|
|
26
|
+
`).join(`
|
|
27
|
+
`)}
|
|
28
|
+
...(I: d8e11827d88a3454d887ff05fb4ff526)`),s}catch(r){throw console.error(`${e} ${E(r)}`),r}finally{ae&&console.log(`${e} complete.`)}}f($r,"getFullSyncSagaHistory");async function Yo({sagaIbGib:o}){let t=`[${Yo.name}]`;try{ae&&console.log(`${t} starting... (I: dac978e9ec5820f128fbbff817b82826)`);let e=await Z({ibGib:o})??[];if(e.length>0)return e;if(o.data){let{data:r}=o;r.uuid||e.push("data.uuid required (E: aa24eeda7b88d22e5832a2e8083c0826)"),r.timestamp||e.push("data.timestamp required (E: 9c82a88548f4b63c38687428754b3826)"),r.timestampMs||r.timestampMs===0||e.push("data.timestampMs required (E: 9c82a88548f4b63c38687428754b3826)"),r.conflictStrategy?jo(r.conflictStrategy)||e.push(`data.conflictStrategy (${r.conflictStrategy}) is invalid. Must be one of "${er}". (E: 6223a8813b688fa2c8644fa8a491bf26)`):e.push("data.conflictStrategy required (E: 9c82a88548f4b63c38687428754b3826)"),r.expirationTimestamp,r.errors,r.successCount}else e.push("sagaIbGib.data falsy (E: 4de5e8de589d0af7245600fb4fe30926)");if(o.rel8ns){let r=o.rel8ns[me];r&&r.length>0||e.push("sagaIbGib.rel8ns[SYNC_MSG_REL8N_NAME] required. (E: df648dc18148e718682acb4842ecf826)")}else e.push("sagaIbGib.rel8ns falsy (E: da37aa492a7275b68a5e1912c7a5e126)");return e}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{ae&&console.log(`${t} complete.`)}}f(Yo,"validateSyncSagaFrame");async function Wo({history:o}){let t=`[${Wo.name}]`;try{return ae&&console.log(`${t} starting... (I: df02b802f6989096b8d8f728e2c0a526)`),console.error(`${t} NAG ERROR (NOT THROWN) need to implement more validation on full saga history. (E: 9bfcc9247a1c783fd361a4a8216fef26)`),[]}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{ae&&console.log(`${t} complete.`)}}f(Wo,"validateFullSyncSagaHistory");async function Vo({ibGibs:o,space:t}){let e=`[${Vo.name}]`;try{ae&&console.log(`${e} starting... (I: aa3ab828402836b3914800a8ffa1b826)`);let r=[],n=[];for(let s of o)ie({ibGib:s})||(xn({ibGib:s})?r.push(s):n.push(s));return r.length>0&&await xe({ibGibs:r,isDna:!0,space:t}),n.length>0&&await xe({ibGibs:n,isDna:!1,space:t}),{payload_Dnas:r,payload_NonDnas:n}}catch(r){throw console.error(`${e} ${E(r)}`),r}finally{ae&&console.log(`${e} complete.`)}}f(Vo,"putInSpace_dnasThenNonDnas");function Ir({sagaFrame:o}){let t=`[${Ir.name}]`;try{if(ae&&console.log(`${t} starting... (I: 93521332d0dd2f5e88398b7db95e8126)`),!o)throw new Error("(UNEXPECTED) sagaFrame falsy? (E: 01fb28be6668d88ea49bb298c739c926)");if(!o.data)throw new Error("(UNEXPECTED) sagaFrame.data falsy? (E: 998298eb17685bdb9a85b46488ccd826)");if(!o.data.n&&o.data.n!==0)throw new Error("(UNEXPECTED) sagaFrame.data.n falsy and not 0? (E: 0394919d5b58300ceb09ba6a264ad826)");let e=o.data.n%2;if(e===0)return Xo.sender;if(e===1)return Xo.receiver;throw new Error("(UNEXPECTED) modulo is neither 0 nor 1? my logic sucks! This was way too defensive on my part... (E: 559488a2eef8d17b57079ca8886ee826)")}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{ae&&console.log(`${t} complete.`)}}f(Ir,"getSyncSagaFrameOrigin");async function zo({sagaHistory:o}){let t=`[${zo.name}]`;try{ae&&console.log(`${t} starting... (I: fe93a8f29e5d8ab2c8bd0e08e56f7826)`);let e=o.findLast(s=>s.msgStones.some(a=>a.data.stage===Q.delta));if(!e)throw new Error("(UNEXPECTED) no delta frame? What are we calling this function for? (E: 9b3201207908f79868b93cd893a91626)");let r=e.msgStones.filter(s=>s.data.stage===Q.delta);if(r.length>1)throw new Error("(UNEXPECTED) multiple delta stones in history slice? we're expecting a single delta stone per saga frame. (E: a4bd5860b4aa0743753d4798d3163826)");return r[0].data.conflicts}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{ae&&console.log(`${t} complete.`)}}f(zo,"getFinalConflictsInfo");async function Hs({sagaHistory:o,myTempSpace:t}){let e=`[${Hs.name}]`;try{ae&&console.log(`${e} starting... (I: b755627e99c9a221566d86a81b0da526)`);let r=await zo({sagaHistory:o});if(!r||r.length===0)return ae&&console.log(`${e} no conflicts found. returning empty array (I: 5dce98010128a284c8ec92cd466a3826)`),[];let n=[];for(let s of r){if(!s.resolved)throw new Error("(UNEXPECTED) conflict.resolved falsy? we're expecting all conflicts to be resolved when getting orphaned addresses. (E: 3861e89a18c8ff405eb2117f6d4b9b26)");if(!s.graftInfoAddr)throw new Error("(UNEXPECTED) conflict.graftInfoAddr falsy? we're expecting a resolved conflict whose final ibgib (graft tip) was the graft info and for this addr to be in conflict.graftInfoAddr. (E: 80d86e333028585908f4757bc4d6f826)");let a=await Xe({addrs:[s.graftInfoAddr],space:t});if(a.length!==1)throw new Error(`(UNEXPECTED) couldn't get conflict.graftInfoAddr (${s.graftInfoAddr}) from myTempSpace (${t.ib})? (E: cf1fe87096f8ea22f84f250d7ab30226)`);let i=a[0];if(!js(i))throw new Error(`(UNEXPECTED) graft info from conflict.graftInfoAddr (${s.graftInfoAddr}) does not pass the isGraftInfo guard? We're expecting this addr to point to a valid GraftInfoIbGib_V1 (E: 6aa9ecb9a428d92be8d1bdbe0696f826)`);let c=i.rel8ns[qo];if(!c||c.length===0)throw new Error(`(UNEXPECTED) orphanedAddrs empty for conflict graftInfo (${s.graftInfoAddr})? we're expecting a graft to always necessarily orphan one or other branches, otherwise what are we "grafting"? (E: 3ed1284f6ca84754582801484d751926)`);c.forEach(l=>n.push(l))}return n}catch(r){throw console.error(`${e} ${E(r)}`),r}finally{ae&&console.log(`${e} complete.`)}}f(Hs,"getAllOrphanedAddresses");async function tr({senderSecret:o,sagaId:t}){let e=`[${tr.name}]`;try{if(ae&&console.log(`${e} starting... (I: 0de03f8dcd3e32f1fca244e8f2a8a826)`),!o)throw new Error("(UNEXPECTED) senderSecret falsy? (E: 8ce053fe59825a6678713128953b9d26)");if(!t)throw new Error("(UNEXPECTED) sagaId falsy? (E: 3a17e0c1b2f849de8a42cd15b8ee6826)");return await ys({masterSecret:o,kdfOpts:{strategy:Mr.recursive_salt_wrap,salt:t,rounds:1e4,algorithm:"SHA-256"}})}catch(r){throw console.error(`${e} ${E(r)}`),r}finally{ae&&console.log(`${e} complete.`)}}f(tr,"deriveSessionSecret");var xc=!1,Mt=class o{static{f(this,"LightWitnessBase_V1")}lc=`[${o.name}]`;instanceId="";ib="";gib;data;rel8ns;initialized;_isInitialized=!1;constructor(t,e){t&&(this.data=t),e&&(this.rel8ns=e),this.initialized=this.initialize().then(()=>{this._isInitialized=!0})}async initialize(){this.instanceId=await j(),this.gib=await J({ibGib:this.toIbGibDto()})}toIbGibDto(){return Ne({ibGib:this})}loadIbGibDto(t){let e=`${this.lc}[${this.loadIbGibDto.name}]`;try{return xc&&console.log(`${e} starting...`),t.ib||console.warn(`${e} dto.ib is falsy.`),t.gib||console.warn(`${e} dto.gib is falsy.`),this.ib=L(t.ib),this.gib=L(t.gib),t.data?this.data=L(t.data):delete this.data,t.rel8ns?this.rel8ns=L(t.rel8ns):delete this.rel8ns,Promise.resolve()}catch(r){throw console.error(`${e} ${r.message}`),r}finally{xc&&console.log(`${e} complete.`)}}async validateThis(){let t=`${this.lc}[${this.validateThis.name}]`,e=[];try{this.ib||e.push("this.ib is falsy."),this.gib||e.push("this.gib is falsy.")}catch(r){throw console.error(`${t} ${r.message}`),r}return e}};var Jo="subject",qs=/^[a-zA-Z0-9_\-.]{1,255}$/,Nc="subject",vc="",Zo="subject is a cool ibgib witness that has seriously fascinating behavior.";var Oc="observable";var Ft={subscribe:"subscribe"},Dc=Object.values(Ft);var Lc={next:"next",error:"error",complete:"complete"};var Bt={...Ft,...Lc};var Kr={version:"1",uuid:vc,name:Nc,description:Zo,classname:"Subject_V1",persistOptsAndResultIbGibs:!1,allowPrimitiveArgs:!0,catchAllErrors:!0,trace:!1},Ks=void 0;var jt=!1;function Pc(o){let t=`[${Pc.name}]`;try{let e=o?`${Dr} ${o}`:Dr;return jt&&console.log(`${t} ${e}`),e}catch(e){throw console.error(`${t} ${e.message}`),e}}f(Pc,"getArgIb");function Fd({ib:o,ibGib:t}){let e=`[${Fd.name}]`;try{if(jt&&console.log(`${e} starting...`),!o)if(t)o=t.ib;else throw new Error("either ib or ibGib required (E: c052a9d76df867626f9ba17141cdce22)");return o.startsWith(Dr)}catch(r){throw console.error(`${e} ${r.message}`),r}finally{jt&&console.log(`${e} complete.`)}}f(Fd,"isArg");function Rc(o){let t=`[${Rc.name}]`;try{let e=o?`${go} ${o}`:go;return jt&&console.log(`${t} ${e}`),e}catch(e){throw console.error(`${t} ${e.message}`),e}}f(Rc,"getResultIb");async function rr({argData:o,ibMetadata:t,noTimestamp:e}){let r=`[${rr.name}]`;try{let n=await F.firstGen({ib:Pc(t),parentIbGib:F.primitive({ib:Dr}),data:o,dna:!1,noTimestamp:e});if(n.newIbGib){let{newIbGib:s}=n;return s.rel8ns.past=[],s.gib=await Dt(s),s}else throw new Error("create ibGib failed")}catch(n){throw console.error(`${r} ${n.message}`),n}}f(rr,"argy_");async function or({resultData:o,ibMetadata:t,noTimestamp:e}){let r=`[${or.name}]`;try{let n=await F.firstGen({ib:Rc(t),parentIbGib:F.primitive({ib:go}),data:o,dna:!1,noTimestamp:e});if(n?.newIbGib){let{newIbGib:s}=n;return s.rel8ns.past=[],s.gib=await Dt(s),s}else throw new Error("create ibGib failed")}catch(n){throw console.error(`${r} ${n.message}`),n}}f(or,"resulty_");function Ys({ibGib:o}){let t=`[${Ys.name}]`;try{if(jt&&console.log(`${t} starting...`),!o)throw new Error("ibGib required (E: e11cee2a6c59a5e7a4d39ea55751c423)");if(!o.data)return!1;let e=o.data;return e.cmd&&typeof e.cmd=="string"}catch(e){throw console.error(`${t} ${e.message}`),e}finally{jt&&console.log(`${t} complete.`)}}f(Ys,"isCommand");function Ws({ibGib:o}){let t=`[${Ws.name}]`;try{return jt&&console.log(`${t} starting... (I: aad0a14f4d62061424fc92da4d53d823)`),typeof o.witness=="function"}catch(e){throw console.error(`${t} ${e.message}`),e}finally{jt&&console.log(`${t} complete.`)}}f(Ws,"isWitness");var Uc=/^error (\w+) ([a-fA-F\d]{32}|undefined)$/;var Xt=!1;function Mc({rawMsg:o}){let t=`[${Mc.name}]`;try{Xt&&console.log(`${t} starting...`);let e=Vs({rawMsg:o}),r=e.body.replace(/\s/g,"_").replace(/\W/g,""),n;if(r.length>20)n=r.substring(0,20);else if(r.length>0)n=r;else throw new Error("(UNEXPECTED) error msg should have characters/alphanumerics... (E: a3b9cd11a44cc7892a748819c2885422)");return`error ${n} ${e.uuid??"undefined"}`}catch(e){throw console.error(`${t} ${e.message}`),e}finally{Xt&&console.log(`${t} complete.`)}}f(Mc,"getErrorIb");function Vs({rawMsg:o}){let t=`[${Vs.name}]`;try{if(Xt&&console.log(`${t} starting...`),!o)throw new Error("(UNEXPECTED) rawMsg required (E: e5bd3b433a1781ebe885534cd2495622)");let e,r=o.match(Ta);if(r){let[n,s,a,i,c,l]=r;if(!i)throw new Error("invalid error msg body (E: a675e6855cca96519d33d44ea5400922)");e={success:!1,raw:o,body:i?.trim(),uuid:c.slice(4,36)},s&&(e.location=s),(a||l)&&(e.unexpected=!0)}else{e={success:!1,raw:o,body:o};let n=o.match(Aa);if(n){let[s,a]=n;e.location=a}o.toLowerCase().includes("(unexpected)")&&(e.unexpected=!0)}return e}catch(e){throw console.error(`${t} ${e.message}`),e}finally{Xt&&console.log(`${t} complete.`)}}f(Vs,"parseRawErrorMsg");function nr({rawMsg:o}){let t=`[${nr.name}]`;try{return Xt&&console.log(`${t} starting...`),et({parentPrimitiveIb:"error",ib:Mc({rawMsg:o}),data:Vs({rawMsg:o}),ibRegExpPattern:Uc.source})}catch(e){throw console.error(`${t} ${e.message}`),e}finally{Xt&&console.log(`${t} complete.`)}}f(nr,"getErrorIbGib");function Ct({ibGib:o}){let t=`[${Ct.name}]`;try{if(Xt&&console.log(`${t} starting...`),!o)throw new Error("ibGib required (E: 1d756fbbd96f1734b97ba013537ed522)");return o.ib.startsWith("error ")}catch(e){throw console.error(`${t} ${e.message}`),e}finally{Xt&&console.log(`${t} complete.`)}}f(Ct,"isError");var Qo=class o{static{f(this,"WitnessFactoryBase")}lc=`[${o.name}]`};var zs=!1,_r=class o extends Qo{static{f(this,"DynamicFormFactoryBase")}lc=`[${o.name}]`;patchDataFromItems({data:t,contextPath:e,items:r,pathDelimiter:n}){let s=`${this.lc}[${this.patchDataFromItems.name}]`;try{if(zs&&console.log(`${s} starting...`),!n)throw new Error("pathDelimiter required (E: 958d472a15fb71e45cd2925883f2ec22)");for(let a=0;a<r.length;a++){let i=r[a],c=e?e+n+i.name:i.name;if(!i.items)Cn({obj:t,value:i.value,path:c,logalot:zs,pathDelimiter:n});else if(i.items.length>0)this.patchDataFromItems({data:t,contextPath:c,items:i.items,pathDelimiter:n});else throw new Error("invalid item. items is truthy but with a length of 0. items should either be falsy or have at least one child. (E: ee2765e0b920477f919fcb09e9d951b4)")}}catch(a){throw console.error(`${s} ${a.message}`),a}finally{zs&&console.log(`${s} complete.`)}}};var Fc="subscription",Js=/^[a-zA-Z0-9_\-.]{1,255}$/,Bc="",jc="subscription",en="subscription is a cool ibgib witness that has seriously fascinating behavior.";var Yr={unsubscribe:"unsubscribe",unsubscribed:"unsubscribed"};var Zs={version:"1",uuid:Bc,name:jc,description:en,classname:"Subscription_V1",persistOptsAndResultIbGibs:!1,allowPrimitiveArgs:!0,catchAllErrors:!1,trace:!1},Qs=void 0;var Xc=!1;function ea({ibGib:o}){let t=`[${ea.name}]`;try{Xc&&console.log(`${t} starting... (I: 3aadb634377acbe42984b61c91975323)`);let{ib:e}=o;return[Oc,Jo].some(n=>e.includes(n))}catch(e){throw console.error(`${t} ${e.message}`),e}finally{Xc&&console.log(`${t} complete.`)}}f(ea,"isObservable");var K=!1,tn=class o extends Mt{static{f(this,"Subscription_V1")}lc=`[${o.name}]`;metaspace;_subscribed;_unsubscribed;_srcObservable;constructor(t,e){super(t,e)}async initialize(){let t=`${this.lc}[${this.initialize.name}]`;try{if(K&&console.log(`${t} starting... (I: 8097612cda5f43e5b38249d057b65b1e)`),await super.initialize(),!this.data)throw new Error("this.data required (E: 1af73af2d17a48ada42596ad395fd99c)");this.data.uuid=this.instanceId,this.ib=on({data:this.data,classname:"Subscription_V1"}),this.gib=await J({ibGib:this})}catch(e){throw console.error(`${t} ${e.message}`),e}finally{K&&console.log(`${t} complete.`)}}async witness(t){let e=`${this.lc}[${this.witness.name}]`;try{this._isInitialized||await this.initialized;let{ib:r}=t;if(!r)throw new Error("arg.ib required (E: 1fd9aebef07b4bdaacc0cd323c8ddf76)");if(K&&console.log(`${e} ib: ${r} (I: 4de7771f477dc5b36933343b694ce223)`),r===Yr.unsubscribe)return K&&console.log(`${e} routing unsubscribe cmd (I: 5633b86d467af2aa67388abf559a3c23)`),this.witness_unsubscribe();if(r===Yr.unsubscribed)return K&&console.log(`${e} routing unsubscribed query (I: 6e0ae61d90f1974d76bcdbb47970e723)`),this.witness_unsubscribed();if(ea({ibGib:t}))return K&&console.log(`${e} routing observerable (I: 165b422cda9ec3052312243dc965cf23)`),this.witness_observable({ibGib:t});throw new Error("unknown arg. expect unsubscribe/unsubscribed primitive ibgib or Observable ibgib. (E: 132dc7cd8f7c4afc9ec4651e2c559c74)")}catch(r){throw console.error(`${e} ${E(r)??"unknown error (E: b0bbaab21833404a9420c3d273df7f21)"}`),r}}async witness_unsubscribe(){let t=`${this.lc}[${this.witness_unsubscribe.name}]`;try{if(K&&console.log(`${t} starting... (I: a3d549220ef24604956aaa2c66fff09b)`),!this._subscribed)return console.warn(`${t} tried to unsubscribe but this._subscribed is ${this._subscribed} (W: cdc94f59447d4011b4b4cc12ef9ec074)`),z;if(this._unsubscribed)return console.warn("{lc} this._unsubscribed already true. (W: fa287d76cec040e0978a8add5c758093)"),z;if(!this._srcObservable)throw new Error("(UNEXPECTED) this._subscribed but this._srcObservable falsy? (E: 83687993b7bea299b4ba2438b530a123)");return K&&(console.log(`${t} inspecting srcObservable before src.witness... (I: f15a33d10f1cae3cec6fdbdb32596823)`),console.dir(this._srcObservable)),await this._srcObservable.witness(this),K&&(console.log(`${t} inspecting srcObservable after src.witness... (I: f15a33d10f1cae3cec6fdbdb32596823)`),console.dir(this._srcObservable)),this._subscribed=!1,this._unsubscribed=!0,delete this._srcObservable,K&&console.log(`${t} this._ (I: 7b1bc418a3d32757772391cad7a49523)`),z}catch(e){throw console.error(`${t} ${e.message}`),e}finally{K&&console.log(`${t} complete.`)}}async witness_observable({ibGib:t}){let e=`${this.lc}[${this.witness_observable.name}]`;try{if(K&&console.log(`${e} starting... (I: faf248f372fc44a7bb0e70492e8284f9)`),this._subscribed!==void 0)throw new Error(`(UNEXPECTED) this._subscribed (${this._subscribed} is not undefined? (E: 09a0e926357676c2c93a173ccbe93923)`);if(this._srcObservable)throw new Error("(UNEXPECTED) this subscription isn't subscribed but this._observable is truthy? (E: acdf5198fb2ff3c8b2db95450bd55b23)");return this._srcObservable=t,K&&console.log(`${e} this._srcObservable set to ibgib with ib: ${t.ib} (I: 4b81d17243f60dfdcc2163fbb55e9223)`),this._subscribed=!0,z}catch(r){throw console.error(`${e} ${r.message}`),r}finally{K&&console.log(`${e} complete.`)}}async witness_unsubscribed(){let t=`${this.lc}[${this.witness_unsubscribed.name}]`;try{if(K&&console.log(`${t} starting... (I: 1beac551253e4c5694b63e0d36d5d5c0)`),this._subscribed==null)throw new Error("subscription never subscribed in the first place (this._subscribed === undefined) (E: b2c1b21a0e876a4908339a976924b923)");if(this._subscribed&&this._unsubscribed)throw new Error("(UNEXPECTED) both this._subscribed and this._unsubscribed true (E: a967e49de657a43929a74703c656ad23)");let e=this._unsubscribed===!0?Bn:Ya;return K&&console.log(`${t} result: ${P(e)} (I: b488cf36ce39e006a81d3ad3db5b4a23)`),e}catch(e){throw console.error(`${t} ${e.message}`),e}finally{K&&console.log(`${t} complete.`)}}async unsubscribe(){let t=`${this.lc}[${this.unsubscribe.name}]`;try{K&&console.log(`${t} starting... (I: ef7f3f4787a74fcca65d761880f44594)`);let e=await this.witness(F.primitive({ib:Yr.unsubscribe}));if(!e)throw new Error("(UNEXPECTED) unsubscribe returned undefined? (E: 7013193490b94b6880f1049c36577d6f)");if(Ct({ibGib:e})){let r=e;throw new Error(`${r.data.raw} (E: fca1200dccb14f84968b2462f1b4c29e)`)}}catch(e){throw console.error(`${t} ${e.message}`),e}finally{K&&console.log(`${t} complete.`)}}async unsubscribed(){let t=`${this.lc}[${this.unsubscribed.name}]`;try{K&&console.log(`${t} starting... (I: 8ee9a93be61647d6aef6a4fa03e96dad)`);let e=await this.witness(F.primitive({ib:Yr.unsubscribed}));if(!e)throw new Error("(UNEXPECTED) unsubscribe returned undefined? (E: 5051d7ff4a4d4bf7864c520b53f028d5)");let r=e.ib===Bn.ib;return K&&console.log(`${t} resUnsubscribed: ${r} (I: b4800166c58d5ba2ca1dccaa53de2323)`),r}catch(e){throw console.error(`${t} ${e.message}`),e}finally{K&&console.log(`${t} complete.`)}}async validateThis(){let t=`${this.lc}[${this.validateThis.name}]`;try{return K&&console.log(`${t} starting...`),this.data,[]}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{K&&console.log(`${t} complete.`)}}async argy({argData:t,ibMetadata:e,noTimestamp:r,ibGibs:n}){let s=await rr({argData:t,ibMetadata:e,noTimestamp:r});return n&&(s.ibGibs=n),s}async resulty({resultData:t,ibGibs:e}){let r=await or({resultData:t});return e&&(r.ibGibs=e),r}},rn=class o extends _r{static{f(this,"Subscription_V1_Factory")}lc=`[${o.name}]`;getName(){return tn.name}async newUp({data:t,rel8ns:e}){let r=`${this.lc}[${this.newUp.name}]`;try{K&&console.log(`${r} starting...`),t??=L(Zs),t=t,e=e??Qs?L(Qs):void 0,t.uuid||=await j();let{classname:n}=t,s=on({data:t}),a=await et({parentPrimitiveIb:`witness ${n}`,ib:s,data:t,rel8ns:e}),i=new tn(void 0,void 0);return await i.loadIbGibDto(a),K&&console.log(`${r} witnessDto: ${P(a)} (I: 5e41337176d1441f9a5c7b43664d43ef)`),{newIbGib:i}}catch(n){throw console.error(`${r} ${E({error:n})}`),n}finally{K&&console.log(`${r} complete.`)}}async witnessToForm({witness:t}){let e=`${this.lc}[${this.witnessToForm.name}]`;try{K&&console.log(`${e} starting...`);let{data:r}=t;if(!r)throw new Error("(UNEXPECTED) witness.data falsy? (E: ef44497ff97a4e5bac004d52c4ff40eb)");K&&console.log(`${e} data: ${P(r)} (I: c3f4c3d85386461aaefbe33524ff9cbd)`);let n=await Sr({n:100}),s=new nn().with({idPool:n}).name({of:r.name,required:!1}).description({of:r.description??en}).and().and().uuid({of:r.uuid,required:!0}).classname({of:r.classname}).and().commonWitnessFields({data:r}).outputForm({formName:"form",label:"subscription"});return Promise.resolve(s)}catch(r){throw console.error(`${e} ${E({error:r})}`),r}finally{K&&console.log(`${e} complete.`)}}async formToWitness({form:t}){let e=L(Zs);return this.patchDataFromItems({data:e,items:t.items,pathDelimiter:ar}),await this.newUp({data:e})}};var sn=!1;function Hc({data:o}){let t=`[${Hc.name}]`;try{if(sn&&console.log(`${t} starting...`),!o)throw new Error("Subscription Data required (E: 6d1c97931dcab8ea9f3e9b32c794b90c)");let e=[],{name:r,uuid:n,classname:s}=o;return r?r.match(Js)||e.push(`name must match regexp: ${Js} (E: 21bf77e398d47e9d035376510505eda2)`):e.push("name required."),n?n.match(ce)||e.push(`uuid must match regexp: ${ce} (E: e53fd08ae69e945b37ed895b864b6bd7)`):e.push("uuid required."),s&&(s.match(Ot)||e.push(`classname must match regexp: ${Ot}`)),e}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{sn&&console.log(`${t} complete.`)}}f(Hc,"validateCommonSubscriptionData");function on({data:o,classname:t}){let e=`[${on.name}]`;try{let r=Hc({data:o});if(r.length>0)throw new Error(`invalid Subscription data: ${r} (E: fd6b0b32d8f6c4b97eebd489cdb07a4a)`);if(t){if(o.classname&&o.classname!==t)throw new Error("classname does not match data.classname (E: 354285a56a20b9b65b06abfcd9f2e621)")}else if(t=o.classname,!t)throw new Error("classname required (E: 040c1fd71853fa7874146999afb355c3)");let{uuid:n}=o;return`witness ${Fc} ${t} ${n}`}catch(r){throw console.error(`${e} ${E(r)}`),r}}f(on,"getSubscriptionIb");var nn=class o extends Rt{static{f(this,"SubscriptionFormBuilder")}lc=`[${o.name}]`;constructor(){super(),this.what="subscription"}};function an({ibGib:o}){let t=`[${an.name}]`;try{if(sn&&console.log(`${t} starting... (I: 43df7e7f61f25e65662ce8aa5a105a23)`),!o)return!1;let e=o;return typeof e.witness=="function"&&typeof e.unsubscribe=="function"&&typeof e.unsubscribed=="function"}catch(e){throw console.error(`${t} ${e.message}`),e}finally{sn&&console.log(`${t} complete.`)}}f(an,"isSubscription");async function qc(){return(await new rn().newUp({})).newIbGib}f(qc,"newupSubscription");var ta="observable_event";var Kc=!1;async function ra({eventType:o,srcObservable:t,payload:e}){let r=`[${ra.name}]`;try{if(Kc&&console.log(`${r} starting... (I: e2290f2f46d1993d6893a24c19100823)`),!t)throw new Error("srcObservable required (E: 3470a97bbf3802cbc8dd64339f5ef623)");if(!t.data)throw new Error("srcObservable.data required (E: df1786585ba849c08e7f4f1fddd30a31)");if(!t.data.uuid)throw new Error("srcObservable.data.uuid required (E: 173a1a53f274bc1cef879bad2288ca23)");if(!t.data.uuid.match(ce))throw new Error(`valid srcObservable.data.uuid required. must pass UUID_REGEXP: ${ce.source} (E: 10f4bd1863f18250cc79cd65221da223)`);let n={uuid:await j(),eventType:o,srcObservableId:t.data.uuid,"@srcObservableAddr":w({ibGib:t}),"@payloadAddr":w({ibGib:e})};return await et({parentPrimitiveIb:ta,ib:Yc({data:n}),data:n})}catch(n){throw console.error(`${r} ${n.message}`),n}finally{Kc&&console.log(`${r} complete.`)}}f(ra,"getObservableEventIbGib");function Yc({data:o,classname:t}){let e=`[${Yc.name}]`;try{if(t){if(o.classname&&o.classname!==t)throw new Error("classname does not match data.classname (E: 523aabc53fb944789202a5f468abd338)")}else if(t=o.classname,!t)throw new Error("classname required (E: d4401ea682894c5fa824b38d4989aa76)");if(!o.uuid)throw new Error("data.uuid required (E: 204cc7c20efd8a55263cdea8b1223e23)");return`${ta} ${t} ${o.uuid}`}catch(r){throw console.error(`${e} ${E(r)}`),r}}f(Yc,"getObservableEventIb");var re=!1,cn=class o extends Mt{static{f(this,"ObservableBase_V1")}lc=`[${o.name}]`;metaspace;_subscribers={};_isComplete=!1;_pastPayloads=[];_pastError;get isCompleteOrErrored(){return this._isComplete||!!this._pastError}get isComplete(){return this._isComplete}get isErrored(){return!!this._pastError}constructor(t,e){super(t,e)}async witness(t){let e=`${this.lc}[${this.witness.name}]`;try{this._isInitialized||await this.initialized;let{ib:r}=t;if(!r)throw new Error("arg.ib required (E: 87659d093b82436ce2f7a87e402a5423)");if(Ys({ibGib:t}))return this.witness_cmd({arg:t});if(Ws({ibGib:t}))return this.witness_otherWitness({arg:t});throw new Error("unknown arg. expect observable cmd or ibgib witness (E: dc2667cffac5b8d7b1bf2ea737c81a23)")}catch(r){throw console.error(`${e} ${E(r)??"unknown error (E: 3e22bea4c7fb4668bf13d7146b927869)"}`),r}}async witness_cmd({arg:t}){let e=`${this.lc}[${this.witness_cmd.name}]`;try{if(re&&console.log(`${e} starting... (I: 69257fac8328b9de9755fdd237b92723)`),t.data.cmd===Ft.subscribe)return this.witness_subscribe_cmd({ibGib:t});throw new Error(`unknown command. must be of type ObservableCmd (${Dc}) (E: 5910e5cbafead25ea2917a65a3fc4123)`)}catch(r){throw console.error(`${e} ${r.message}`),r}finally{re&&console.log(`${e} complete.`)}}async witness_otherWitness({arg:t}){let e=`${this.lc}[${this.witness_otherWitness.name}]`;try{return re&&console.log(`${e} starting... (I: 871d0b7a2bef4596bad430f1cbacde02)`),an({ibGib:t})?this.witness_subscriptionIbGib({arg:t}):this.witness_subscribe_nonCmdWitness({arg:t})}catch(r){throw console.error(`${e} ${r.message}`),r}finally{re&&console.log(`${e} complete.`)}}async witness_subscriptionIbGib({arg:t}){let e=`${this.lc}[${this.witness_subscriptionIbGib.name}]`;try{if(re&&console.log(`${e} starting... (I: 4ac764776ef7e3f9074eb95a999ba423)`),!t.data)throw new Error("arg.data required (E: 764ae772727ceba95a18140fdd938323)");let r=this.getSubscriberKey({subscription:t}),[n,s]=this._subscribers[r];if(t===n)delete this._subscribers[r];else throw new Error("(UNEXPECTED) arg and subscription are two different instances? (E: aab5ef9bdc92abb9e816e2c443ab5723)");return z}catch(r){throw console.error(`${e} ${r.message}`),r}finally{re&&console.log(`${e} complete.`)}}async replayPastPayloads({observer:t,subscription:e}){let r=`${this.lc}[${this.replayPastPayloads.name}]`;try{re&&console.log(`${r} starting... (I: b3c8f9c76a4af030cf52fdcf01c3fd23)`);let n=this.getSubscriberKey({subscription:e}),s=f(()=>!!this._subscribers[n],"fnStillSubscribed"),a=-1,i=!0;do if(a++,a<this._pastPayloads.length){if(!s()){re&&console.log(`${r} subscription canceled before past payloads dispatch completed. (I: f1778f868446a518030d1cf7800c8a23)`);return}try{let c=this._pastPayloads[a];await t.next(c)}catch{console.error(`${r} observer errored on payload (i: ${a}). aborting replay (E: 1d7efc7c48e1491da4317ef333031077)`);return}}else i=!1;while(i);if(this.isErrored&&t.error&&s())try{await t.error(this._pastError)}catch{console.error(`${r} observer.error(this._pastError) errored itself (E: 18310e5e032345e7bdc3f2479807866c)`)}else if(this.isComplete&&t.complete&&s())try{await t.complete()}catch{console.error(`${r} observer.complete errored (E: d9d027f5520f4d7eadfc669d66b5b550)`)}}catch(n){throw console.error(`${r} ${n.message}`),n}finally{re&&console.log(`${r} complete.`)}}async witness_subscribe_cmd({ibGib:t}){let e=`${this.lc}[${this.witness_subscribe_cmd.name}]`;try{if(re&&console.log(`${e} starting... (I: 0c4c75c3fae297af6449c1048ce55423)`),(t.ibGibs??[]).length!==1)throw new Error("ibGib.ibGibs required. should contain one ObserverWitness (E: 3ed99b32e22284573c497df788a9f923)");let r=t.ibGibs[0],n=await qc();return re&&console.log(`${e} subscription created (I: 89ccd97803c66292f9d7334e1e2de523)`),await n.witness(this),await n.initialized,re&&console.log(`${e} subscription initialized (after witnessing this observable as its src). (I: 3021483402b21c4df64a9173bd223a23)`),this._subscribers[this.getSubscriberKey({subscription:n})]=[n,r],re&&console.log(`${e} stored subscriber (subscription, observer) (I: fb09660d885e33b80188dd0386ffc723)`),this.data.replay&&this._pastPayloads.length>0&&this.replayPastPayloads({observer:r,subscription:n}),n}catch(r){throw console.error(`${e} ${r.message}`),r}finally{re&&console.log(`${e} complete.`)}}async witness_subscribe_nonCmdWitness({arg:t}){let e=`${this.lc}[${this.witness_subscribe_nonCmdWitness.name}]`;try{throw re&&console.log(`${e} starting... (I: d9571dfcab4247d594c838233971886a)`),new Error("not impl (E: 76219cf238ba4f849480bd7c82eefab9)")}catch(r){throw console.error(`${e} ${r.message}`),r}finally{re&&console.log(`${e} complete.`)}}async subscribe(t){let e=`${this.lc}[${this.subscribe.name}]`;try{re&&console.log(`${e} starting... (I: 0dec9a06c562711e19482d45a7075e23)`);let r;if(sr({ibGib:t})){let n=await this.argy({argData:{cmd:Ft.subscribe,ibGibAddrs:[w({ibGib:t})]},ibGibs:[t]});r=await this.witness(n)}else r=await this.witness(t);if(!an({ibGib:r}))throw new Error("(UNEXPECTED) resSubscription is not a SubscriptionWitness? (E: c29bec4e3a48d6f1299143399ac55a23)");return r}catch(r){throw console.error(`${e} ${r.message}`),r}finally{re&&console.log(`${e} complete.`)}}getSubscriberKey({subscription:t}){if(t.data?.uuid)return t.data.uuid;throw new Error("(UNEXPECTED) subscription.data.uuid falsy? (E: 8d078e6f8155f7567fd9378557e91823)")}async dispatchToEachSubscriber({payload:t,fnForObserver:e,observableEventType:r}){let n=`${this.lc}[${this.dispatchToEachSubscriber.name}]`;try{re&&console.log(`${n} starting... (I: 0b990ce892f689d14458565717e66a23)`);let s=Object.values(this._subscribers);for(let a=0;a<s.length;a++){let[i,c]=s[a];if(sr({ibGib:c})){let l=c;await e(l,t),l.complete?await i.unsubscribed()?console.warn(`${n} (UNEXPECTED) subscriber reference still held but is unsubscribed? skipping for now (i.e. won't remove subscriber) in case that code is in yielded execution and just hasn't gotten around to it with event loop (but that would be weird). (W: 1d98f35d2fdd4345954c947265d9fb85)`):await l.complete():re&&console.log(`${n} no error handler for observer. skipping. (I: 6a8a52c2012c464790eb406d2ae0383f)`)}else{let l=await ra({eventType:r,srcObservable:this,payload:t});await c.witness(l)}}}catch(s){throw console.error(`${n} ${s.message}`),s}finally{re&&console.log(`${n} complete.`)}}async validateThis(){let t=`${this.lc}[${this.validateThis.name}]`;try{return re&&console.log(`${t} starting...`),this.data,[]}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{re&&console.log(`${t} complete.`)}}async argy({argData:t,ibMetadata:e,noTimestamp:r,ibGibs:n}){let s=await rr({argData:t,ibMetadata:e,noTimestamp:r});return n&&(s.ibGibs=n),s}async resulty({resultData:t,ibGibs:e}){let r=await or({resultData:t});return e&&(r.ibGibs=e),r}};var V=!1,ln=class o extends cn{static{f(this,"Subject_V1")}lc=`[${o.name}]`;constructor(t,e){super(t,e)}asObservable(){return this}async subscribe(t){let e=`${this.lc}[${this.subscribe.name}]`;try{V&&console.log(`${e} starting... (I: 8e47b752314870ec78eb14342621f723)`);let r=await this.argy({argData:{cmd:Bt.subscribe,ibGibAddrs:[w({ibGib:t})]},ibGibs:[t]});return await this.witness(r)}catch(r){throw console.error(`${e} ${r.message}`),r}finally{V&&console.log(`${e} complete.`)}}async next(t){let e=`${this.lc}[${this.next.name}]`;try{V&&console.log(`${e} starting... (I: b30363827c56450ca918c69aa15b0046)`);let r=await this.argy({argData:{cmd:Bt.next,ibGibAddrs:[w({ibGib:t})]},ibGibs:[t]});await this.witness(r)}catch(r){throw console.error(`${e} ${r.message}`),r}finally{V&&console.log(`${e} complete.`)}}async error(t){let e=`${this.lc}[${this.error.name}]`;try{V&&console.log(`${e} starting... (I: 7fcc30e3763c429ea8b212491ad9455a)`);let r;if(typeof t=="string")r=await nr({rawMsg:t});else if(t instanceof Error||typeof t.message=="string")r=await nr({rawMsg:E(t)});else if(t.ib&&Ct({ibGib:t}))r=t;else throw new Error("unknown error type. shold either be ErrorIbGib_V1 or an Error instance or have error.message string property. (E: 2cfcab85439c3c845bfe18e8ecde3523)");let n=await this.argy({argData:{cmd:Bt.error,ibGibAddrs:[w({ibGib:r})]},ibGibs:[r]});await this.witness(n)}catch(r){throw console.error(`${e} ${r.message}`),r}finally{V&&console.log(`${e} complete.`)}}async complete(){let t=`${this.lc}[${this.complete.name}]`;try{V&&console.log(`${t} starting... (I: 5faaf13c6b0543d399815c03b9cdf80c)`);let e=await this.argy({argData:{cmd:Bt.complete}});await this.witness(e)}catch(e){throw console.error(`${t} ${e.message}`),e}finally{V&&console.log(`${t} complete.`)}}async witness_cmd({arg:t}){let e=`${this.lc}[${this.witness_cmd.name}]`;try{V&&console.log(`${e} starting... (I: 2bf7cbcadba446fa92cb649906b2b260)`);let{cmd:r}=t.data;switch(r){case Bt.next:return this.witness_next({ibGib:t});case Bt.error:return this.witness_error({ibGib:t});case Bt.complete:return this.witness_complete({ibGib:t});default:return super.witness_cmd({arg:t})}}catch(r){throw console.error(`${e} ${r.message}`),r}finally{V&&console.log(`${e} complete.`)}}async witness_next({ibGib:t}){let e=`${this.lc}[${this.witness_next.name}]`;try{if(V&&console.log(`${e} starting... (I: 600da780f13f5137a2f76aad344b2923)`),this.isCompleteOrErrored)return V&&console.log(`${e} this.isCompleteOrErrored is true. returning early without producing. (I: aa823831853b134b19657c8673838c23)`),z;if((t.ibGibs??[]).length!==1)throw new Error("ibGib.ibGibs required. should contain one payload ibgib (E: 4046802ff96d4adfafcee7a74d96af5e)");let r=t.ibGibs[0];this.data.replay&&this._pastPayloads.push(r);let n=Object.values(this._subscribers);for(let s=0;s<n.length;s++){let[a,i]=n[s];if(V&&console.log(`${e} ensuring subscription not unsubscribed (I: ade3fd6d6ff2b5ec69eb8143e32ce223)`),!await a.unsubscribed())V&&console.log(`${e} subscription still active (I: b9ab83b28acecf0d823fdba46a81dc23)`),await i.next(r);else{debugger;console.warn(`${e} (UNEXPECTED) subscriber reference still held but is unsubscribed? skipping for now (i.e. won't remove subscriber) in case that code is in yielded execution and just hasn't gotten around to it with event loop (but that would be weird). (W: c116e799f6b9483c97fd030eb0dd09ea)`)}}return z}catch(r){throw console.error(`${e} ${r.message}`),r}finally{V&&console.log(`${e} complete.`)}}async witness_error({ibGib:t}){let e=`${this.lc}[${this.witness_error.name}]`;try{if(V&&console.log(`${e} starting... (I: 3367a73bc83c47f98d9ecfe426dc300e)`),(t.ibGibs??[]).length!==1)throw new Error("ibGib.ibGibs required. should contain one error ibgib (E: 905474b45bcb4f0abe7bd4618f08f32c)");let r=t.ibGibs[0];this._pastError=r;let n=Object.values(this._subscribers);for(let s=0;s<n.length;s++){let[a,i]=n[s];if(sr({ibGib:i})){let c=i;c.error?await a.unsubscribed()?console.warn(`${e} (UNEXPECTED) subscriber reference still held but is unsubscribed? skipping for now (i.e. won't remove subscriber) in case that code is in yielded execution and just hasn't gotten around to it with event loop (but that would be weird). (W: 8946e97f00fd4146a470064b490a4c29)`):await c.error(r):V&&console.log(`${e} no error handler for observer. skipping. (I: 59f4a1ee59a3a27d523d60cd761be923)`)}else await i.witness(r)}return z}catch(r){throw console.error(`${e} ${r.message}`),r}finally{V&&console.log(`${e} complete.`)}}async witness_complete({ibGib:t}){let e=`${this.lc}[${this.witness_complete.name}]`;try{V&&console.log(`${e} starting... (I: 4db180f465e24df9a4ded37fbd235558)`),this._isComplete=!0;let r=Object.values(this._subscribers);for(let n=0;n<r.length;n++){let[s,a]=r[n];if(sr({ibGib:a})){let i=a;i.complete?await s.unsubscribed()?console.warn(`${e} (UNEXPECTED) subscriber reference still held but is unsubscribed? skipping for now (i.e. won't remove subscriber) in case that code is in yielded execution and just hasn't gotten around to it with event loop (but that would be weird). (W: 1d98f35d2fdd4345954c947265d9fb85)`):await i.complete():V&&console.log(`${e} no error handler for observer. skipping. (I: 6a8a52c2012c464790eb406d2ae0383f)`)}else await a.witness(t)}return z}catch(r){throw console.error(`${e} ${r.message}`),r}finally{V&&console.log(`${e} complete.`)}}async validateThis(){let t=`${this.lc}[${this.validateThis.name}]`;try{return V&&console.log(`${t} starting...`),this.data,[]}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{V&&console.log(`${t} complete.`)}}async argy({argData:t,ibMetadata:e,noTimestamp:r,ibGibs:n}){if(t.cmd===Ft.subscribe)return super.argy({argData:t,ibMetadata:e,noTimestamp:r,ibGibs:n});{let s=await rr({argData:t,ibMetadata:e,noTimestamp:r});return n&&(s.ibGibs=n),s}}async resulty({resultData:t,ibGibs:e}){let r=await or({resultData:t});return e&&(r.ibGibs=e),r}},dn=class o extends _r{static{f(this,"Subject_V1_Factory")}lc=`[${o.name}]`;getName(){return ln.name}async newUp({data:t,rel8ns:e}){let r=`${this.lc}[${this.newUp.name}]`;try{V&&console.log(`${r} starting...`),t??=L(Kr),t=t,e=e??Ks?L(Ks):void 0,t.uuid||=await j();let{classname:n}=t,s=oa({data:t}),a=await et({parentPrimitiveIb:`witness ${n}`,ib:s,data:t,rel8ns:e}),i=new ln(void 0,void 0);return await i.loadIbGibDto(a),V&&console.log(`${r} witnessDto: ${P(a)} (I: 6736d2b2ddf44fef9a1eb27078dfbf23)`),{newIbGib:i}}catch(n){throw console.error(`${r} ${E({error:n})}`),n}finally{V&&console.log(`${r} complete.`)}}async witnessToForm({witness:t}){let e=`${this.lc}[${this.witnessToForm.name}]`;try{V&&console.log(`${e} starting...`);let{data:r}=t;if(!r)throw new Error("(UNEXPECTED) witness.data falsy? (E: 7b70c96e982d4f81b6ffda54da16b3b8)");V&&console.log(`${e} data: ${P(r)} (I: 75abef56f5004a94b2113e3b1461ac25)`);let n=await Sr({n:100}),s=new fn().with({idPool:n}).name({of:r.name,required:!1}).description({of:r.description??Zo}).and().and().uuid({of:r.uuid,required:!0}).classname({of:r.classname}).and().commonWitnessFields({data:r}).outputForm({formName:"form",label:"observable"});return Promise.resolve(s)}catch(r){throw console.error(`${e} ${E({error:r})}`),r}finally{V&&console.log(`${e} complete.`)}}async formToWitness({form:t}){let e=L(Kr);return this.patchDataFromItems({data:e,items:t.items,pathDelimiter:ar}),await this.newUp({data:e})}};var bn=!1;function Wc({data:o}){let t=`[${Wc.name}]`;try{if(bn&&console.log(`${t} starting...`),!o)throw new Error("Subject Data required (E: 207a82725648e2ef234c8bd3fa1a5312)");let e=[],{name:r,uuid:n,classname:s}=o;return r?r.match(qs)||e.push(`name must match regexp: ${qs} (E: de987eb8fea0b6232f60abf31815095c)`):e.push("name required."),n?n.match(ce)||e.push(`uuid must match regexp: ${ce} (E: 1a6dfda91ad51696f7456bc84dfea60e)`):e.push("uuid required."),s&&(s.match(Ot)||e.push(`classname must match regexp: ${Ot}`)),e}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{bn&&console.log(`${t} complete.`)}}f(Wc,"validateCommonSubjectData");function oa({data:o,classname:t}){let e=`[${oa.name}]`;try{let r=Wc({data:o});if(r.length>0)throw new Error(`invalid Subject data: ${r} (E: 55620ac1f17e30a30a92850219f894ac)`);if(t){if(o.classname&&o.classname!==t)throw new Error("classname does not match data.classname (E: 20e86cca70130839a49ad011c9a7aafa)")}else if(t=o.classname,!t)throw new Error("classname required (E: 74e29ae0f618fee7e7ef72a30c654a6c)");let{name:n,uuid:s}=o;return`witness ${Jo} ${t} ${n} ${s}`}catch(r){throw console.error(`${e} ${E(r)}`),r}}f(oa,"getSubjectIb");var fn=class o extends Rt{static{f(this,"SubjectFormBuilder")}lc=`[${o.name}]`;constructor(){super(),this.what="subject"}};function sr({ibGib:o}){let t=`[${sr.name}]`;try{return bn&&console.log(`${t} starting... (I: b54c252104f710c12951aa43b6ead323)`),typeof o.next=="function"}catch(e){throw console.error(`${t} ${e.message}`),e}finally{bn&&console.log(`${t} complete.`)}}f(sr,"isObserver");async function hn({data:o,replay:t}={}){let e=new dn;return o??=L(Kr),t&&(o.replay=!0),(await e.newUp({data:o})).newIbGib}f(hn,"newupSubject");var pn="sync_sagacontext";var Wr=!1;async function na({data:o}){let t=`[${na.name}]`;try{if(!o)throw new Error("data required (E: 839d82138c234b3e89582855594191fe)");let e=o["@payloadAddrsDomain"]?o["@payloadAddrsDomain"].length:0;return[pn,o.sagaN,e].join(" ")}catch(e){throw console.error(`${t} ${E(e)}`),e}}f(na,"getSyncSagaContextIb");async function Ht({context:o}){let t=`[${Ht.name}]`;try{Wr&&console.log(`${t} starting... (I: 7797f8294bd8f7e5089cb722ad468226)`);let e=[],r=await Z({ibGib:o});if(r&&r.length>0)return r.forEach(n=>e.push(n)),e;if(o.sagaFrame?(await Yo({sagaIbGib:o.sagaFrame})).forEach(s=>e.push(s)):e.push("context.sagaFrame is falsy. (E: b4edd88f4963f493789f83b29ba2df26)"),o.sagaFrameMsg){if((await Z({ibGib:o.sagaFrameMsg})??[]).forEach(s=>e.push(s)),o.sagaFrame){let s=o.sagaFrame.rel8ns?.[me]?.[0];if(s){let a=w({ibGib:o.sagaFrameMsg});a!==s&&e.push(`context.sagaFrameMsg address (${a}) does not match the stone address referenced in sagaFrame relations (${s}). (E: a983b271fcae46bbad7e82098bc24826)`)}else e.push(`context.sagaFrame is missing the message stone relation '${me}'. (E: da872cf3a8d46dbbad89d0a68d712826)`)}}else e.push("context.sagaFrameMsg is falsy. (E: ed405a72ab0d8bbdca7b9605d8f9a26)");return e.length>0?e:(console.error(`${t} NAG ERROR MSG (NOT THROWN): not fully implemented yet (E: d574d85cb578637648ed403857f7a826)`),[])}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{Wr&&console.log(`${t} complete.`)}}f(Ht,"validateContextAndSagaFrame");async function sa({context:o,space:t}){let e=`[${sa.name}]`;try{Wr&&console.log(`${e} starting... (I: 3c34e8f1d6ef965f98725c88459ea926)`);let r=[];if(!o.data)throw new Error("(UNEXPECTED) context.data falsy? (E: 3e4ddd0eb4b828ad489658d88d9a6326)");if(!o.rel8ns)throw new Error("(UNEXPECTED) context.rel8ns falsy? (E: 8026589d4fed69c828334ee842074326)");let{sagaFrame:n,signedSessionIdentity:s}=o;if(!n.data)throw new Error("(UNEXPECTED) sagaFrame.data falsy? (E: b61cc82d25984c92f75db74a5a855b26)");if(!s)return console.error(`${e}[NAG][not thrown] sagaFrame.data.sessionIdentityTjpAddr logic needs to be added in coordinator (E: 4fc47800a1086c917a47381824280826)`),n.data.sessionIdentityTjpAddr?(r.push("Context has no session identity, but sync saga frame shows a session identity (sagaFrame.data.sessionIdentityTjpAddr is truthy). (E: 69dd6cdc2e1859c0f3d62958c4339826)"),r):o.rel8ns.sessionIdentity?(r.push("Context has no signed session identity, but context.rel8ns.sessionIdentity is truthy. (E: 96a04a8a6c88ea8bf88118f89ad8e326)"),r):(Wr&&console.log(`${e} context has no signedSessionIdentity and sync saga frame doesn't state there should be session identity. So nothing further to authenticate - returning early with no authentication errors. (I: d708735f9a2899ee98f762b8a09ed826)`),[]);let a=w({ibGib:s}),i=o.rel8ns?.sessionIdentity??[];if(i.length===0)return r.push("context.rel8ns.sessionIdentity is falsy/empty but context.signedSessionIdentity is present. (E: 66f906421eb2468c0b33f908a3cf2826)"),r;if(i.length>1)return r.push("context.rel8ns.sessionIdentity has multiple identity addrs. (E: 489428bfe6fdaa4cd885b938dc4c5826)"),r;let c=i[0],l=await je({addrs:[c],space:t});if(!l)throw new Error(`(UNEXPECTED) resGetLatestAddr for prevSessionIdentityAddr in space (${t.ib}) falsy? (E: 7b207e5cbcec9037ea5adbe822ead826)`);if(!l.data)throw new Error(`(UNEXPECTED) resGetLatestAddr.data for prevSessionIdentityAddr in space (${t.ib}) falsy? (E: de4eb8d730c8c4dcb59c8b9c79277826)`);if(!l.data.success)throw new Error("(UNEXPECTED) resGetLatestAddr.data.success falsy? (E: c94298dfd9684ad6a87eb748459aa826)");let{latestAddrsMap:d}=l.data;if(!d)throw new Error("(UNEXPECTED) resGetLatestAddr.data.latestAddrsMap falsy? (E: 19f1fd5fe798cf2e5fa923919169d826)");if(Object.keys(d).length!==1)throw new Error("(UNEXPECTED) Object.keys(latestAddrsMap).length !== 1? (E: fe526a0747589c6427a8bcc86da34a26)");let b=d[c];if(!b)return r.push(`prevSessionIdentityAddr (${c}) not found in space (${t.ib}). this should have been the incoming prevSessionIdentityAddr (E: f6d042bd6b54819998653228dee34226)`),r;if(c!==b&&b!==a)return r.push(`context.rel8ns.sessionIdentity does not point to the most recent in the space (${t.ib}). (E: 2f8288f53c87b6aa47bd2178d9df0c26)`),console.log(`context: ${P(Ne({ibGib:o}))}`),console.log(`prevSessionIdentityAddr (context.rel8ns.sessionIdentity): ${c}`),console.log(`prevSessionIdentityAddr_latest: ${b}`),console.log(`currSessionIdentity (context.signedSessionIdentity): ${P(Ne({ibGib:{ib:s.ib,gib:s.gib,rel8ns:s.rel8ns,data:{...s.data,challengePools:s.data.challengePools.map(Y=>({...Y,challenges:{}}))}}}))}`),console.log(`currSessionIdentityAddr: ${a}`),r;let h=await B({addr:c,space:t});if(!h.success||h.ibGibs?.length!==1)return r.push(`could not fetch latest sender identity ${c} from space (${t.ib}). (E: fd48c3e64c9fa4efd8a1f8280af18226)`),r;let p=h.ibGibs[0],u=await Lr({ibGib:p,naive:!0,space:t});if(!u)throw new Error(`(UNEXPECTED) couldn't get sessionIdentityTjp in space (${t.ib})? we have already gotten the identity itself in the space, so we would expect the entire timeline to exist in it. (E: 9be0382ff1c8a0e77645ea38c096f826)`);let g=w({ibGib:u});if(g!==n.data.sessionIdentityTjpAddr)throw new Error("(UNEXPECTED) sessionIdentityTjpAddr !== sagaFrame.data.sessionIdentityTjpAddr? (E: c9a4ad5c2728fe38e86afc58e4abaf26)");let m=u.data.frameDetails;if(!m)return r.push("Invalid session identity tjp: sessionIdentityTjp.data.frameDetails is falsy. (E: 0187f8f804a84256281720586620b826)"),r;let{senderIdentityAddr:$,senderIdentityTjpAddr:T}=m;if(!$)throw new Error("sessionGenesisFrameDetails.senderIdentityAddr falsy (E: 02a0c80a3ead9e3af8af4cf3b156e826)");if(!T)throw new Error("sessionGenesisFrameDetails.senderIdentityTjpAddr falsy (E: 271928090ff5dc56d4bb63d8d5c68826)");let I=await je({addrs:[T,$],space:t});if(!I)throw new Error(`(UNEXPECTED) resGetLatestAddr_senderIdentity for prevSessionIdentityAddr in space (${t.ib}) falsy? (E: 2e4ae8083b6fb7cbb8fae2a519062926)`);if(!I.data)throw new Error(`(UNEXPECTED) resGetLatestAddr_senderIdentity.data for prevSessionIdentityAddr in space (${t.ib}) falsy? (E: 2e231850c2a898cc282b4b2841056826)`);if(!I.data.success)throw new Error("(UNEXPECTED) resGetLatestAddr_senderIdentity.data.success falsy? (E: e93508f03e0475925875b00746ffd826)");let{latestAddrsMap:y}=I.data;if(!y)throw new Error("(UNEXPECTED) resGetLatestAddr_senderIdentity.data.latestAddrsMap falsy? (E: 87a91e3f9968ad9ba79cdfe8cd878326)");if(Object.keys(y).length!==2&&T!==$)throw new Error("(UNEXPECTED) Object.keys(latestAddrsMap_senderIdentity).length !== 2 && senderIdentityTjpAddr !== senderIdentityAddr? (E: fe46bd584853d8e1e8e2d11f52012826)");let A=y[T],_=y[$];if(!_)throw new Error("(UNEXPECTED) senderIdentityAddr_latest falsy? (E: e151798ae2e9241578d09948937c4b26)");if(A!==_)throw new Error("senderIdentityTjpAddr_latest !== senderIdentityAddr_latest (E: 52478a1053589e72665031a853cc1826)");let S=await B({addr:_,space:t});if(!S.success||S.ibGibs?.length!==1)return r.push(`could not fetch latest sender identity ${c} from space (${t.ib}). (E: 3565ff0ed458f5a2384c40b16e849826)`),r;let N=S.ibGibs[0];if(!N.data.proofs)return r.push("Invalid sender identity. Proofs empty/falsy. (E: ebf488853061614d2b5b137828119526)"),r;let O=N.data.proofs.find(Y=>Y.claim.verb===rt)?.claim;if(!O)return r.push(`Most recent senderIdentity has no proof whose claim.verb === ${rt}. (E: b0f488ecccbbfe43d9a0b7c8a29d7826)`),r;if(O.target!==g)return r.push(`Most recent sender identity claim has claim.verb === ${rt} but DOES NOT target expected session identity addr ${c}. (E: 3e7f18d99848969be8586423d5ccb826)`),r;let k=await new ve().validate({currentIbGib:s,prevIbGib:p});k.length>0&&r.push(`Invalid session identity transition: ${k.join(", ")} (E: da1c81c6d3c86aec3254f48fe7514226)`);let U=w({ibGib:o});return s.data?.proofs?.some(Y=>Y.claim.target===U)||r.push(`Session identity signature does not target current context ibgib (${U}). (E: acae68938c287178c878d1b88bebb826)`),r}catch(r){let n=`${e} ${E(r)}`;return console.error(n),[`authentication produced an error: ${n} (E: 45e014b82af81993d936611ca6fc4d26)`]}finally{Wr&&console.log(`${e} complete.`)}}f(sa,"authenticateContextIntrinsically");var we=!1,un=class o extends Mt{static{f(this,"SyncPeer_V1")}lc=`[${o.name}]`;opts;payloadIbGibsDomainReceived$;currentSessionIdentity;get currentSessionIdentityAddr(){return this.currentSessionIdentity?w({ibGib:this.currentSessionIdentity}):void 0}async signContext({contextAddr:t}){let e=`${this.lc}[${this.signContext.name}]`;try{if(!this.currentSessionIdentity)return;if(!this.opts)throw new Error("opts not initialized. (E: bcf5978aed789b0ebcbdc51971ebe826)");let{fnSenderSecret:r,sagaId:n,localMetaspace:s,localSpace:a}=this.opts;if(!r)throw new Error("fnSenderSecret not initialized. (E: 207fd292a2e8c53c05fd0a74a4ae6d26)");if(!n)throw new Error("sagaId not initialized. (E: f2e35cc13ed873b638116188119d1826)");let i=await r(),c=await tr({senderSecret:i,sagaId:n}),d=await new ve().sign({latestKeystone:this.currentSessionIdentity,masterSecret:c,claim:{verb:rt,target:t},metaspace:s,space:a});return this.currentSessionIdentity=d,d}catch(r){throw console.error(`${e} ${E(r)}`),r}}async signContextConnect({challengeUuid:t,demandedIds:e}){let r=`${this.lc}[${this.signContextConnect.name}]`;try{if(!this.currentSessionIdentity)return;if(!this.opts)throw new Error("opts not initialized. (E: bcf5978aed789b0ebcbdc51971ebe826)");let{fnSenderSecret:n,sagaId:s,localMetaspace:a,localSpace:i}=this.opts;if(!n)throw new Error("fnSenderSecret not initialized. (E: 207fd292a2e8c53c05fd0a74a4ae6d26)");if(!s)throw new Error("sagaId not initialized. (E: f2e35cc13ed873b638116188119d1826)");let c=await n(),l=await tr({senderSecret:c,sagaId:s}),b=await new ve().sign({latestKeystone:this.currentSessionIdentity,masterSecret:l,poolId:ot,requiredChallengeIds:e,claim:{verb:gt,target:t},metaspace:a,space:i});return this.currentSessionIdentity=b,b}catch(n){throw console.error(`${r} ${E(n)}`),n}}get classname(){if(!this.data)throw new Error("(UNEXPECTED) this.data falsy? (E: 1ab1841e9338b54f3aa615fa37024826)");if(!this.data.classname)throw new Error("invalid peer. this.data.classname is falsy (E: b0ee28a0abb84a06588d9de7afcef826)");return this.data.classname}constructor(t,e){super(t,e)}async initialize(){this.payloadIbGibsDomainReceived$=await hn()}async connect(t){let e=`${this.lc}[${this.connect.name}]`;try{we&&console.log(`${e} starting... (I: ad89d8137351662fb8a30114a1fa4826)`),await this.preConnectCheck(t),await this.connectImpl(t)}catch(r){throw console.error(`${e} ${E(r)}`),r}finally{we&&console.log(`${e} complete.`)}}async establishSessionIdentity(){let t=`${this.lc}[${this.establishSessionIdentity.name}]`;try{if(we&&console.log(`${t} starting... (I: f2a1b3c4d5e6f7a8b9c0d1e2f3a4b526)`),!this.opts)throw new Error("(UNEXPECTED) this.opts falsy? Call initializeOpts first. (E: a1b2c3d4e5f6a7b8c9d0e1f2a3b4c526)");let{senderIdentity:e,fnSenderSecret:r,sagaId:n,localMetaspace:s,localSpace:a}=this.opts;if(!e||!r){we&&console.log(`${t} no senderIdentity/fnSenderSecret \u2014 skipping establish (I: f29348a77d1542326d14043ea4b69126)`);return}let i=w({ibGib:e}),c=Ie({ibGib:e});if(!c)throw new Error("(UNEXPECTED) senderIdentityTjpAddr falsy? (E: d5d8c3ab25a83a2c127904fe96de1526)");if(!n)throw new Error("(UNEXPECTED) sagaId falsy? Must be set in initializeOpts before calling establishSessionIdentity. (E: c6ba389d51b8af07d82458f875cf9826)");let l=await r();if(!l)throw new Error("senderSecret falsy. senderSecret required. (E: 1a8b0298bf78cbdf284b7988983b9826)");let d=await tr({senderSecret:l,sagaId:n}),b=new ve;if(!this.opts.sessionConnectPoolConfig)throw new Error("(UNEXPECTED) opts.sessionConnectPoolConfig falsy? (E: 3351fd566eb8bbd2f821bb08c4419826)");if(!this.opts.sessionSyncPoolConfig)throw new Error("(UNEXPECTED) opts.sessionSyncPoolConfig falsy? (E: dbffa810d9e7ff6079088deb5b8e7826)");let h={senderIdentityAddr:i,senderIdentityTjpAddr:c};this.opts.targetAddrs&&(h.targetAddrs=this.opts.targetAddrs);let p=await b.genesis({masterSecret:d,configs:[this.opts.sessionConnectPoolConfig,this.opts.sessionSyncPoolConfig],frameDetails:h,metaspace:s,space:a}),u=w({ibGib:p}),g=await b.sign({latestKeystone:e,masterSecret:l,claim:{verb:rt,target:u},metaspace:s,space:a});await this.postEstablishToReceiver({newSenderIdentity:g,sessionIdentity:p}),this.currentSessionIdentity=p}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{we&&console.log(`${t} complete.`)}}async initializeOpts(t){let e=`${this.lc}[${this.initializeOpts.name}]`;try{we&&console.log(`${e} starting... (I: 31bd5fda37c89fa37fbaf14daf5fe726)`),this.opts=t}catch(r){throw console.error(`${e} ${E(r)}`),r}finally{we&&console.log(`${e} complete.`)}}setOptionalOpts(t){let e=`${this.lc}[${this.setOptionalOpts.name}]`;try{if(we&&console.log(`${e} starting... (I: ae5ddbd3577db267f84743175a736626)`),!this.opts)throw new Error("(UNEXPECTED) this.opts falsy? (E: 0dd4d6080a6e2f31d86cf4d86e11b826)");we&&console.log(`${e} updating opts. arg keys: ${Object.keys(t)} (I: 452d78a558f8fc3468c8e2e68c70b226)`),this.opts={...this.opts,...t}}catch(r){throw console.error(`${e} ${E(r)}`),r}finally{we&&console.log(`${e} complete.`)}}async authenticateAndValidate({context:t}){let e=`${this.lc}[${this.authenticateAndValidate.name}]`;try{if(we&&console.log(`${e} starting... (I: add238055cd84a222c5b8c89913af526)`),!this.opts)throw new Error("(UNEXPECTED) opts falsy in authenticateValidateAuthorize (E: b7e5a8ad99d84e1ba8d8f7facd288826)");let{localSpace:r}=this.opts,n=await sa({context:t,space:r});if(n.length>0)throw new Error(`invalid context authentication. authenticationErrors: ${n} (E: da89da5ee1269aeb78952d475d607526)`);let s=await Ht({context:t});if(s.length>0)throw new Error(`invalid context received. validationErrors: ${s} (E: 8b34c875c968af29bc433138e57a7826)`)}catch(r){throw console.error(`${e} ${E(r)}`),r}finally{we&&console.log(`${e} complete.`)}}async witness(t){let e=`${this.lc}[${this.witness.name}]`;try{if(we&&console.log(`${e} starting...`),!this.opts)throw new Error("(UNEXPECTED) this.opts falsy? Concrete class should have initialized sender opts by now. (E: 0b9e28287318fdf8bf9f5a6886a24826)");if(!t.sagaFrame)throw new Error("context.sagaFrame falsy. (E: a33dd88aa108e2bad9e885885731ce26)");await this.authenticateAndValidate({context:t});let r=await this.sendContextRequest(t);if(r){let n=await $r({sagaIbGib:t.sagaFrame,space:this.opts.localSpace});return r}else{we&&console.log(`${e} No response from peer. this may be normal if we just sent the very last commit frame. (I: 1855b7728c8898e1f9c001f8170ba826)`);return}}catch(r){throw console.error(`${e} ${E(r)}`),r}finally{we&&console.log(`${e} complete.`)}}async getLocalIbGib(t){let e=`${this.lc}[${this.getLocalIbGib.name}]`;try{if(we&&console.log(`${e} starting... (I: 27b248cb9801eeb2386b71485389a826)`),console.warn(`${e} possibly a bottleneck here, getLocalIbGib only gets a single ibgib... (W: 2fd448a435480e6b128f6b8bcbef4826)`),!this.opts)throw new Error("(UNEXPECTED) this.opts falsy? (E: cfb9431f2fb851f24a6c88e80c3b3326)");let r=await B({space:this.opts.localSpace,addr:t});if(r.success&&r.ibGibs&&r.ibGibs.length===1)return r.ibGibs[0];throw new Error(`couldn't get addr (${t}) from local space ${this.opts.localSpace}. reason: ${r.errorMsg??"unknown error (E: 926ef8bf4fcc299ab89dba34ea691a26)"} (E: d8a89807e471d3f8b938ab21df44cb26)`)}catch(r){throw console.error(`${e} ${E(r)}`),r}finally{we&&console.log(`${e} complete.`)}}};var Vc=!1,qt={COMMON:{ALGO:Oe.sha_256,TYPE:Je.hash_reveal_v1,ROUNDS:2,REPLENISH:be.topUp},CONNECT_POOL:{ID:ot,VERB:gt,SIZE:10,SELECT_SEQUENTIALLY:2,SELECT_RANDOMLY:2,TARGET_BINDING_CHARS:0,SERVER_DEMAND_COUNT:3}};function Vr(o){let t=`[${Vr.name}]`;try{Vc&&console.log(`${t} starting... (I: 3c791af2f978a00a087dfdde90884826)`);let e=(o.data?.challengePools??[]).find(a=>a.id===qt.CONNECT_POOL.ID);if(!e)throw new Error(`Keystone missing "${qt.CONNECT_POOL.ID}" pool (E: 6382e29260e4ddbac42ed18f49733526)`);let r=Object.keys(e.challenges).sort();if(r.length===0)throw new Error("Connect pool has no challenges (E: 1ef62fdbda182a790835c8c796475226)");let n=r[0],s=e.challenges[n];return{challengeId:n,challenge:s}}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{Vc&&console.log(`${t} complete.`)}}f(Vr,"getConnectChallenge");var Bd="auth-challenge-init",jd="auth-init",Xd="auth-challenge",Hd="auth-proof",qd="auth-ok",Kd="auth-fail",Yd="sync-frame",Wd="sync-frame-response",Vd="sync-frame-authenticated",zd="sync-frame-response-authenticated",Jd="domain-payload",Zd="sync-error",q={auth_challenge_init:Bd,auth_init:jd,auth_challenge:Xd,auth_proof:Hd,auth_ok:qd,auth_fail:Kd,sync_frame:Yd,sync_frame_response:Wd,sync_frame_authenticated:Vd,sync_frame_response_authenticated:zd,domain_payload:Jd,sync_error:Zd},gn=Object.values(q);function aa(o){return gn.includes(o)}f(aa,"isSyncWebSocketMsgType");function zc(o){throw new Error(`Unhandled message type: ${o} (E: e928a3f82cd7469a98ef1bc248a3f826)`)}f(zc,"assertUnreachable");var st=!0,En=class o extends un{static{f(this,"SyncPeerWebSocketSender_V1")}lc=`[${o.name}]`;get classname(){return o.name}get isSocketOpen(){return this.ws!==void 0&&this.ws.readyState===WebSocket.OPEN}ws;activeResolve;activeReject;pendingPayloadsToSend=[];handshakeMessageListener;constructor(t,e){super(t,e)}async preConnectCheck(t){let e=`${this.lc}[${this.preConnectCheck.name}]`;if(!this.data?.wsUrl)throw new Error("Missing wsUrl in peer data (E: a3b2c1d0e9f8e7d6c5b4a3f2e1d0c910)");if(!this.data?.httpEvolveUrl)throw new Error("Missing httpEvolveUrl in peer data (E: a3b2c1d0e9f8e7d6c5b4a3f2e1d0c911)")}async postEstablishToReceiver({newSenderIdentity:t,sessionIdentity:e}){let r=`${this.lc}[${this.postEstablishToReceiver.name}]`;try{if(st&&console.log(`${r} posting evolved keystones to ${this.data.httpEvolveUrl}...`),!this.data)throw new Error("(UNEXPECTED) this.data falsy? (E: d642e8a9af18b532c87c6f581aa53b26)");if(!this.data.httpEvolveUrl)throw new Error("(UNEXPECTED) this.data.httpEvolveUrl falsy? (E: 8589ddbb155914d85c09658881da2c26)");let n=await fetch(this.data.httpEvolveUrl,{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify({keystoneIbGib:t,relatedIbGibs:[e]})});if(!n.ok){let s=await n.json().catch(()=>({})),a=s.message||s.error||"Unknown error";throw new Error(`HTTP ${n.status} evolution post rejected. errorMsg: ${a} (E: e8a478291b88d05c68cf6b385684b826)`)}st&&console.log(`${r} evolve post accepted by server.`)}catch(n){throw console.error(`${r} establish post failed: ${E(n)}`),n}}async connectImpl(t){let e=`${this.lc}[${this.connectImpl.name}]`;try{st&&console.log(`${e} starting...`);let{senderIdentity:r,fnSenderSecret:n,sagaId:s,localMetaspace:a,localSpace:i}=this.opts;if(!r||!n||!s)throw new Error("Missing identity parameters in peer options (E: ed49b6711ac82efcdb42b8a28c5b6826)");let c=await n(),l=await tr({senderSecret:c,sagaId:s}),d=w({ibGib:r}),b=w({ibGib:(r.rel8ns?.past,r)}),h=await a.getLatestAddr({ibGib:r,space:i});if(!h)throw new Error("senderIdentityLatestAddr falsy. we should have a latest addr that is different than the sender identity at this point (done in the peer establish phase) (E: 225607318bef485d7821f82de97b6826)");let g=((await a.get({addrs:[h],space:i})).ibGibs?.[0]).data.proofs.at(0)?.claim.target;if(!g)throw new Error("Could not locate session keystone target from identity (E: 5ec4882f7e5e4c33fbd00ab8b3166726)");let $=(await a.get({addrs:[g],space:i})).ibGibs?.[0];if(!$)throw new Error(`Session keystone not found in local space: ${g} (E: 9ba818e6622808bb4ae749be31f80b26)`);let T=($.data?.challengePools??[]).find(O=>O.id===qt.CONNECT_POOL.ID);if(!T)throw new Error("Session keystone missing connect pool (E: f50968afca04b6d38ec19824ea201826)");let{challengeId:I}=Vr($),y=Ze.create({config:T.config}),A=await y.derivePoolSecret({masterSecret:l}),_=await y.generateSolution({poolSecret:A,poolId:qt.CONNECT_POOL.ID,challengeId:I}),S=`${this.data.wsUrl}?sAddr=${encodeURIComponent(g)}&solution=${encodeURIComponent(_.value)}`;st&&console.log(`${e} connecting to WebSocket: ${S}`);let N=new WebSocket(S);return this.ws=N,new Promise((O,D)=>{let k=!1;N.addEventListener("open",()=>{st&&console.log(`${e} WebSocket opened. Awaiting challenge...`)}),this.handshakeMessageListener=async U=>{try{let R=JSON.parse(U.data);st&&console.log(`${e} received handshake frame: ${R.type}`);let Y=R.type;if(!aa(Y)){let oe=gn.join(", ");throw new Error(`Unknown message type '${Y}' received during connection handshake. Valid types are: ${oe} (E: e983271bc84f46928e4695be2409826)`)}switch(Y){case q.auth_challenge_init:await this.handleHandshakeAuthChallengeInit(N,g);break;case q.auth_challenge:await this.handleHandshakeAuthChallenge(N,R,$,l);break;case q.auth_ok:k=!0,this.handleHandshakeAuthOk(N,O);break;case q.auth_fail:this.handleHandshakeAuthFail(R,D);break;case q.sync_error:this.handleHandshakeSyncError(R,D);break;case q.auth_init:case q.auth_proof:case q.sync_frame:case q.sync_frame_response:case q.sync_frame_authenticated:case q.sync_frame_response_authenticated:case q.domain_payload:throw new Error(`Unexpected message type '${Y}' during connection handshake (E: e3f80c68ab2a46c2b1858c8a1e2f8926)`);default:zc(Y)}}catch(R){console.error(`${e} ${E(R)}`),D(R)}},N.addEventListener("message",this.handshakeMessageListener),N.addEventListener("close",U=>{k||(this.disconnect(),D(new Error(`WebSocket closed before connect completed (code: ${U.code})`)))}),N.addEventListener("error",U=>{k||(this.disconnect(),D(new Error("WebSocket connection error")))})})}catch(r){throw console.error(`${e} connect failed: ${E(r)}`),r}}disconnect(){let t=`${this.lc}[${this.disconnect.name}]`;try{if(st&&console.log(`${t} starting... (I: 35c4b85fca0c6e9d042f5ff87cde3826)`),this.ws){this.handshakeMessageListener&&(this.ws.removeEventListener("message",this.handshakeMessageListener),this.handshakeMessageListener=void 0);try{this.ws.close()}catch(e){console.error(`${t} failed to close websocket: ${E(e)}`)}this.ws=void 0}}catch(e){console.error(`${t} ${E(e)}`)}finally{st&&console.log(`${t} complete.`)}}async handleRuntimeMessage(t){let e=`${this.lc}[${this.handleRuntimeMessage.name}]`;try{let r=JSON.parse(t.data);st&&console.log(`${e} received runtime frame: ${r.type}`);let n=r.type;if(!aa(n)){let s=gn.join(", ");throw new Error(`Unknown message type '${n}' received during active sync saga loop. Valid types are: ${s} (E: e23a8d10b74d47fb90518f8e3f4b826)`)}switch(n){case q.sync_frame_response:await this.handleRuntimeSyncFrameResponse(r);break;case q.sync_frame_authenticated:this.handleRuntimeSyncFrameAuthenticated();break;case q.domain_payload:this.handleRuntimeDomainPayload(r);break;case q.sync_error:this.handleRuntimeSyncError(r);break;case q.auth_challenge_init:case q.auth_init:case q.auth_challenge:case q.auth_proof:case q.auth_ok:case q.auth_fail:case q.sync_frame:case q.sync_frame_response_authenticated:throw new Error(`Unexpected message type '${n}' during active sync saga loop (E: e982b12cf92c448bbad0e84b7263c826)`);default:zc(n)}}catch(r){if(console.error(`${e} failed parsing/handling runtime frame: ${E(r)}`),this.disconnect(),this.activeReject){let n=this.activeReject;this.activeResolve=void 0,this.activeReject=void 0,n(r)}}}async handleHandshakeAuthChallengeInit(t,e){t.send(JSON.stringify({type:q.auth_init,sAddr:e}))}async handleHandshakeAuthChallenge(t,e,r,n){let{challengeUuid:s,demandedIds:a}=e;st&&console.log(`${this.lc} solving demanded challenges: ${a.join(", ")}`);let i=await this.signContextConnect({challengeUuid:s,demandedIds:a});if(!i)throw new Error("Failed to sign connect challenge proof (E: e9807f28ae9248bbadd0a7f1a8e9826)");t.send(JSON.stringify({type:q.auth_proof,proofFrame:i}))}handleHandshakeAuthOk(t,e){st&&console.log(`${this.lc} WebSocket connect SUCCESS!`),this.handshakeMessageListener&&(t.removeEventListener("message",this.handshakeMessageListener),this.handshakeMessageListener=void 0),t.addEventListener("message",r=>this.handleRuntimeMessage(r)),e()}handleHandshakeAuthFail(t,e){this.disconnect(),e(new Error(`Handshake auth failed: ${t.message||"Unknown fail reason"} (E: f380b271a2be498db257bc8209fa8926)`))}handleHandshakeSyncError(t,e){this.disconnect(),e(new Error(`Handshake sync error: ${t.message||t.error||"Unknown sync error"} (E: f9208a01fe434cbbad83f210ea8f3426)`))}async handleRuntimeSyncFrameResponse(t){let e=t.context,r=await Ht({context:e});if(r.length>0)throw new Error(`Invalid response context received: ${r.join(", ")} (E: d7b5a283cf4c43ba8659c803800cf826)`);let n=[Ne({ibGib:e}),e.sagaFrame,e.sagaFrameMsg];e.signedSessionIdentity&&n.push(e.signedSessionIdentity);let{localSpace:s}=this.opts;for(let i of n)await xe({space:s,ibGibs:[i]}),await de({space:s,ibGib:i});if((e.data?.["@payloadAddrsDomain"]||[]).length>0&&this.ws.send(JSON.stringify({type:q.sync_frame_response_authenticated,contextAddr:w({ibGib:e})})),this.activeResolve){let i=this.activeResolve;this.activeResolve=void 0,this.activeReject=void 0,i(e)}}handleRuntimeSyncFrameAuthenticated(){let t=this.pendingPayloadsToSend||[];this.pendingPayloadsToSend=[];for(let e of t)this.ws.send(JSON.stringify({type:q.domain_payload,ibGib:e}))}handleRuntimeDomainPayload(t){let e=t.ibGib;this.payloadIbGibsDomainReceived$.next(e)}handleRuntimeSyncError(t){let e=t.message||t.error||"Unknown sync runtime error",r=new Error(`Sync runtime error from receiver: ${e} (E: e983bc1c828d447fa0581da2b8004f26)`);if(this.activeReject){let n=this.activeReject;this.activeResolve=void 0,this.activeReject=void 0,n(r)}else throw r}async sendContextRequest(t){let e=`${this.lc}[${this.sendContextRequest.name}]`;try{if(!this.ws||this.ws.readyState!==WebSocket.OPEN)throw new Error("WebSocket is not connected or open (E: a3b2c1d0e9f8e7d6c5b4a3f2e1d0c915)");let r=t.payloadIbGibsDomain??[];this.pendingPayloadsToSend=[...r];let n={...t};return delete n.payloadIbGibsDomain,new Promise((s,a)=>{this.activeResolve=s,this.activeReject=a,this.ws.send(JSON.stringify({type:q.sync_frame,context:n}))})}catch(r){throw console.error(`${e} sendContextRequest failed: ${E(r)}`),r}}};var Te=!1;async function ia({timeline:o}){let t=`[${ia.name}]`;try{if(Te&&console.log(`${t} starting...`),ie({ibGib:o}))return console.warn(`${t} getting lock scope on a primitive ibgib can grossly impact performance. (W: 55203e415ae2ac7ddb19c21772b28925)`),w({ibGib:o});{let e=ue({gib:o.gib}),r=e.tjpGib??e.punctiliarHash;if(!r)throw new Error(`${t} (UNEXPECTED) Could not determine tjpGib or punctiliarHash from ibGib. (E: eb3b6472e9b335991a1b0869f772f7d3)`);return r}}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{Te&&console.log(`${t} complete.`)}}f(ia,"getLockScope");async function ca({timeline:o,rel8nInfos:t,rel8nRemovalInfos:e,timelineIndexInfo:r,metaspace:n,space:s,skipLock:a,noDna:i}){let c=`[${ca.name}]`;try{if(Te&&console.log(`${c} starting... (I: fcdff10832215068019355265f4cbc25)`),s??=await n.getLocalUserSpace({lock:!1}),!s)throw new Error("(UNEXPECTED) space falsy? couldn't even get default local user space? (E: 2051b44a052d6a2984b9a22f680e4625)");let l=await ia({timeline:o}),d=f(async()=>{if(!s)throw new Error("(UNEXPECTED) space falsy? couldn't even get default local user space? (E: 845c4181c8c15d7219166ceb3c4dca25)");let h=w({ibGib:o}),p=await n.getLatestAddr({addr:h,space:s});if(!p)throw new Error(`${c} (UNEXPECTED) Could not get latest address for timeline ${w({ibGib:o})}. (E: a4b5c6d7e8f9a0b1c2d3e4f5a6b7c8d9)`);let u=Ne({ibGib:o});if(h!==p){let I=await n.get({addrs:[p],space:s});if(I.errorMsg||(I.ibGibs??[]).length!==1)throw new Error(`${c} (UNEXPECTED) couldn't get latest timeline ibgib (${p}) from space (${s.ib}). errorMsg: ${I.errorMsg??"[unknown error]"} (E: b5c6d7e8f9a0b1c2d3e4f5a6b7c8d9e0)`);u=I.ibGibs.at(0)}let g;if(e&&e.length>0){g={};for(let I of e){let{rel8nName:y,ibGibAddrs:A}=I;if(A.length===0){console.warn(`${c} tried to remove 0 ibGibAddrs in rel8nName ${y}? skipping... (W: 93aeb601be66d680989e72ec70e4c826)`);continue}g[y]||(g[y]=[]),g[y]=g[y].concat(A)}}let m={};for(let I of t){let{rel8nName:y,ibGibs:A}=I;if(A.length===0){console.warn(`${c} tried to add 0 ibGibs to rel8nName ${y}? skipping... (W: 708252dfdeb60757fee4554e769aaa25)`);continue}m[y]||(m[y]=[]),m[y].push(...A.map(_=>w({ibGib:_})))}let $=await Ce({src:u,rel8nsToRemoveByAddr:g,rel8nsToAddByAddr:m,dna:!i,nCounter:!0}),T=$.newIbGib;return await n.persistTransformResult({resTransform:$,space:s}),r&&await la({type:r.type,rel8nInfos:[{rel8nName:r.rel8nName,ibGibs:[T]}],metaspace:n,space:s,skipLock:a}),n.registerNewIbGib({ibGib:T,space:s}),T},"fn");return a?await d():await ht({scope:l,secondsValid:180,maxDelayMs:100,maxLockAttempts:1800,space:s,callerInstanceId:Me(),fn:d})}catch(l){throw console.error(`${c} ${E(l)}`),l}finally{Te&&console.log(`${c} complete.`)}}f(ca,"appendToTimeline");async function la({type:o,rel8nInfos:t,dataToAddOrPatch:e,metaspace:r,space:n,skipLock:s}){let a=`[${la.name}]`;try{if(Te&&console.log(`${a} starting... (I: 6e7d05fe916d813b71766e2eaa747c25)`),o==="latest")throw new Error('cannot update the "latest" special index by this function. The registerNewIbGib will do this automatically. (E: 231eb78a221ccdbcf56cd1899260a425)');if(n??=await r.getLocalUserSpace({lock:!1}),!n)throw new Error("(UNEXPECTED) space falsy? couldn't even get default local user space? (E: 43067821a4749a7648fe2612d25d7f25)");let i=f(async()=>{let c=f(async()=>{let l=await r.getSpecialIbGib({type:o,space:n,initialize:!0});if(!l)throw new Error(`(UNEXPECTED) couldn't initialize/get special ibgib index of type ${o}. (E: a1b2c3d4e5f6a7b8c9d0e1f2a3b4c5d6)`);return l.rel8ns||console.warn(`${a} not sure if this ever hits, but is there ever a scenario where specialIndex.rel8ns is falsy? (W: 06161c366bc7ec858b9b5aa7ee9b6d25)`),l},"fnGetSpecialIndex");for(let l of t??[]){let{rel8nName:d,ibGibs:b}=l;b.length===0&&console.error(`${a} ibGibs empty. skipping rel8nName (${d}). (E: 150d74f73f97aea1b97d173d92c77125)`);let p=(await c()).rel8ns??{},u,g=p[d]??[];if(g.length>0){let m=new Set;b.forEach($=>{let T=w({ibGib:$}),I=$.rel8ns?.past??[];g.filter(y=>[...I,T].includes(y)).forEach(y=>m.add(y))}),m.size>0&&(u=Array.from(m))}await r.rel8ToSpecialIbGib({type:o,rel8nName:d,ibGibsToRel8:b,addrsToUnRel8:u,space:n,linked:!1,severPast:!1,deletePreviousSpecialIbGib:!1})}if(Object.keys(e??{}).length>0){let l=await c(),d=await Fe({src:l,dataToAddOrPatch:e,dna:!1,linkedRel8ns:[te.past],nCounter:!0}),b=d.newIbGib;await se({resTransform:d,space:n});let h=fe({type:o});await r.setConfigAddr({key:h,addr:w({ibGib:b}),space:n}),await r.registerNewIbGib({ibGib:b,space:n})}},"fn");s?await i():await ht({scope:o,secondsValid:60,maxDelayMs:100,maxLockAttempts:600,space:n,fn:i})}catch(i){throw console.error(`${a} ${E(i)}`),i}finally{Te&&console.log(`${a} complete.`)}}f(la,"updateSpecialIndex");async function da({timeline:o,timelineAddr:t,metaspace:e,space:r}){let n=`[${da.name}]`;try{if(Te&&console.log(`${n} starting... (I: f2b605361368e1956f6db878dbfeb825)`),!o&&!t)throw new Error("either timeline or timelineAddr required. (E: 97551b2b18ecd22a18185a783f9a0825)");t??=w({ibGib:o});let s=await e.getLatestAddr({addr:t,space:r})??t;if(!s)throw new Error(`${n} (UNEXPECTED) Could not get latest address for timeline ${w({ibGib:o})}. (E: a4b5c6d7e8f9a0b1c2d3e4f5a6b7c8d9)`);let a;if(t===s){if(!o){let i=await e.get({addrs:[s],space:r});if(i.errorMsg||(i.ibGibs??[]).length!==1)throw new Error(`${n} (UNEXPECTED) couldn't get latest timeline ibgib (${s}) from space (${r.ib}). errorMsg: ${i.errorMsg??"[unknown error]"} (E: 3fc767a594788a43a4ba18c87491a825)`);o=i.ibGibs.at(0)}a=Ne({ibGib:o})}else{let i=await e.get({addrs:[s],space:r});if(i.errorMsg||(i.ibGibs??[]).length!==1)throw new Error(`${n} (UNEXPECTED) couldn't get latest timeline ibgib (${s}) from space (${r.ib}). errorMsg: ${i.errorMsg??"[unknown error]"} (E: b5c6d7e8f9a0b1c2d3e4f5a6b7c8d9e0)`);a=i.ibGibs.at(0)}return a}catch(s){throw console.error(`${n} ${E(s)}`),s}finally{Te&&console.log(`${n} complete.`)}}f(da,"getLatestTimelineIbGibDto_nonLocking");async function Qd({timeline:o,timelineAddr:t,mut8Opts:e,metaspace:r,space:n,skipLock:s,timelineIndexInfo:a,noDna:i}){let c=`[${Qd.name}]`;try{if(Te&&console.log(`${c} starting... (I: genuuid)`),!o&&!t)throw new Error("(UNEXPECTED) both timeline and timelineAddr falsy? either one is required. (E: a19d98c6acb87af3b876c1484f6ac825)");if(n??=await r.getLocalUserSpace({lock:!1}),!n)throw new Error("(UNEXPECTED) space falsy? couldn't even get default local user space? (E: genuuid)");if(!o){let h=await r.get({addrs:[t],space:n});if(!h.success||h.ibGibs?.length!==1)throw new Error(`couldn't get timeline ibGib from timelineAddr (${t}) in space (${n?.ib??"undefined"}) (E: genuuid)`);o=h.ibGibs.at(0)}let l=await ia({timeline:o}),d=f(async()=>{if(!n)throw new Error("(UNEXPECTED) space falsy? couldn't even get default local user space? (E: 845c4181c8c15d7219166ceb3c4dca25)");if(!o)throw new Error("(UNEXPECTED) timeline falsy? we should be ensured that it's truthy at this point. (E: 2e1758b2cc3820531f7ac7f5f6b3a825)");let h=await da({timeline:o,metaspace:r,space:n}),p=await Fe({...e,src:h,dna:!i,nCounter:!0}),u=p.newIbGib;return await r.persistTransformResult({resTransform:p,space:n}),a&&await la({type:a.type,rel8nInfos:[{rel8nName:a.rel8nName,ibGibs:[u]}],metaspace:r,space:n,skipLock:s}),await r.registerNewIbGib({ibGib:u,space:n}),u},"fn");return s?await d():await ht({scope:l,secondsValid:180,maxDelayMs:100,maxLockAttempts:1800,space:n,callerInstanceId:Me(),fn:d})}catch(l){throw console.error(`${c} ${E(l)}`),l}finally{Te&&console.log(`${c} complete.`)}}f(Qd,"mut8Timeline");async function fa({ib:o,data:t,rel8ns:e,noDna:r,parentIb:n,parentIbGib:s,metaspace:a,space:i}){let c=`[${fa.name}]`;try{if(Te&&console.log(`${c} starting...`),i??=await a.getLocalUserSpace({lock:!1}),!i)throw new Error("(UNEXPECTED) space is required, but is falsy. (E: 252994a554224b17aa9816c7a765c925)");s??=n?s=F.primitive({ib:n}):s=z;let l=await F.firstGen({parentIbGib:s,ib:o,data:t,rel8ns:e,dna:!r,nCounter:!0,squash:!!r,tjp:{timestamp:!0,uuid:!t?.uuid}});return await a.persistTransformResult({resTransform:l,space:i}),await a.registerNewIbGib({ibGib:l.newIbGib,space:i}),l}catch(l){throw console.error(`${c} ${E(l)}`),l}}f(fa,"createTimeline");async function Jc({ibGib:o,metaspace:t,space:e}){let r=`[${Jc.name}]`;try{if(Te&&console.log(`${r} starting...`),e??=await t.getLocalUserSpace({lock:!1}),!e)throw new Error("(UNEXPECTED) space is required. (E: c1b9a9b8c7d6e5f4a3b2a1a0b9c8d7e6)");let n=o.rel8ns?.dna??[];if(n.length===0)return[];let s=await t.get({addrs:n,space:e});if(!s.success||(s.ibGibs??[]).length!==n.length){let a=n.filter(i=>!s.ibGibs?.some(c=>w({ibGib:c})===i));throw new Error(`Could not get all dna ibGibs for ${w({ibGib:o})}. Addrs not found: ${a.join(", ")}. Errors: ${s.errorMsg??"[unknown error (E: 92cf95774828d8a978331da859098625)]"} (E: d2c0b1a9a8b7c6d5e4f3a2b1a0b9c8d7)`)}return s.ibGibs}catch(n){throw console.error(`${r} ${E(n)}`),n}}f(Jc,"getDna");async function mn({timeline:o,getLatest:t,includeDna:e,metaspace:r,space:n}){let s=`[${mn.name}]`;try{if(Te&&console.log(`${s} starting... (I: 7fbc442a27e8f9fda8ac4228ded84825)`),n??=await r.getLocalUserSpace({lock:!1}),!n)throw new Error("(UNEXPECTED) space is required. (E: e3d1c0b1a9a8b7c6d5e4f3a2b1a0b9c8)");let a=t?await da({timeline:o,metaspace:r,space:n}):Ne({ibGib:o}),i=w({ibGib:a}),c={},l=e?Oo({ibGibs:await Jc({ibGib:a,metaspace:r,space:n})}):void 0,d=o.rel8ns?.past??[];if(d.length===0)return{headIbGib:a,orderedPastIbGibs:[],pastIbGibMap:c,dnaMap:l};let b=await r.get({addrs:d,space:n});if(!b.success||(b.ibGibs??[]).length!==d.length){let p=d.filter(u=>!b.ibGibs?.some(g=>w({ibGib:g})===u));throw new Error(`Could not get all dna ibGibs for ${i}. Addrs not found: ${p.join(", ")}. Errors: ${b.errorMsg??"[unknown error (E: 887339d8b5580ed1ac9892a554255525)]"} (E: 4ab7a8a58adff4e238171f7c110c6825)`)}c=Oo({ibGibs:b.ibGibs})??{};let h=[];for(let p of d){let u=c[p];if(!u)throw new Error("(UNEXPECTED) pastIbGib falsy? due to our logic, the pastIbGibMap should be complete. (E: 6010d8c14184124008631928e1265525)");h.push(u)}return{headIbGib:a,orderedPastIbGibs:h,pastIbGibMap:c,dnaMap:l}}catch(a){throw console.error(`${s} ${E(a)}`),a}finally{Te&&console.log(`${s} complete.`)}}f(mn,"getHistory");async function ba({timeline:o,getLatest:t,metaspace:e,space:r}){let n=`[${ba.name}]`;try{return Te&&console.log(`${n} starting... (I: c7a328b14018642138ebb47870c15626)`),(await mn({timeline:o,getLatest:t,includeDna:!1,metaspace:e,space:r})).orderedPastIbGibs.map(i=>w({ibGib:i}))}catch(s){throw console.error(`${n} ${E(s)}`),s}finally{Te&&console.log(`${n} complete.`)}}f(ba,"getHistoryAddrs");var wn="sync_sagamsg";async function ha({data:o}){let t=`[${ha.name}]`;try{return[wn,o.sagaId,o.stage].join(" ")}catch(e){throw console.error(`${t} ${E(e)}`),e}}f(ha,"getSyncSagaMessageIb");async function pa({frameIbGib:o,space:t}){let e=`[${pa.name}]`;try{let n=(await ds({ibGib:o,rel8nNames:[me],space:t}))[me];if(!n||n.length===0)throw new Error(`(UNEXPECTED) No sync message stone found found for frame: ${o.ib} (E: 8a4b2c1d3e5f6a9b7c8d9e0f1a2b3c4d)`);if(n.length>1)throw new Error(`(UNEXPECTED) Multiple sync message stones found (${n.length}) for frame: ${o.ib}. logic not currently equipped to handle multiple messages per frame. (E: 1a2b3c4d5e6f7a8b9c0d1e2f3a4b5c6d)`);return n[0]}catch(r){throw console.error(`${e} ${E(r)}`),r}}f(pa,"getSyncSagaMessageFromFrame");var yn="anon_fn",Zc={fnHash:""};var Qc=!1;function ua({data:o}){let t=`[${ua.name}]`;try{if(Qc&&console.log(`${t} starting... (I: 37bb06e0390c5bcadf04501727d64923)`),!o?.fnHash)throw new Error("data.fnHash required (E: 2e560f2c59822bc5ba024d4a8e99d323)");return`witness ${yn} ${o.fnHash}`}catch(e){throw console.error(`${t} ${e.message}`),e}finally{Qc&&console.log(`${t} complete.`)}}f(ua,"getAnonymousFnIb");var Kt=class{static{f(this,"AnonymousFnWitness_V1")}fn;ib=yn.concat();gib=M;data=L(Zc);rel8ns;constructor(t){if(this.fn=t,!t)throw new Error("fn required (E: b1e1478f466a2a347b75e7c336f8d323)")}async witness(t){return this.data.fnHash=await ke({s:this.fn.toString()}),this.ib=ua({data:this.data}),this.gib=await J({ibGib:this}),this.fn(t)}};var $n=!1;function ef({err:o}){let t=`[${ef.name}]`;try{if($n&&console.log(`${t} starting... (I: 96f8b767c50f24768ced7beebb291723)`),Rr(o)){let e=o;if(!o.data)throw new Error("err isIbGib but err.data is false. (E: 151a6bab647c638c454fd277ac468f23)");if(Ct({ibGib:o}))return o.data.raw;throw new Error("(UNEXPECTED) err isIbGib but not ErrorIbGib_V1? (E: 81c2283fad5db3485c6e9acedbda9723)")}else return E(o)}catch(e){throw console.error(`${t} ${e.message}`),e}finally{$n&&console.log(`${t} complete.`)}}f(ef,"extractObsErrMsg");function ga(o){let t=`[${ga.name}]`;try{$n&&console.log(`${t} starting... (I: 3d2c3658a0fda83ece1f2b095a365823)`);let e;if(typeof o=="function"?e={next:o}:e=o,!e.next)throw new Error("observer.next required (typeof observerOrFn !== 'function') (E: da944e93b32ab5918f11751bcd651823)");let r=f(async d=>(await e.next(d),z),"fnNext"),n=f(async d=>(d.ib==="complete"?e.complete&&await e.complete():Ct({ibGib:d})?e.error&&await e.error(d):await e.next(d),z),"fnWitness"),s=new Kt(r),a=new Kt(n),i={ib:"observer",witness:f(async d=>await a.witness(d),"witness"),next:f(async d=>{await s.witness(d)},"next")},c=e.error??(async d=>{let b;if(typeof d=="string")b=E(d);else if(d.ib)if(Ct({ibGib:d}))b=E(d.data.raw);else throw new Error(`${t} (UNEXPECTED) first off, observer.error is falsy. secondly, error came down pipeline and has an "ib" property but is not an ErrorIbGib_V1? (E: 0a2a46b9620b4a6a84c7ba1100da537b)`);else d instanceof Error?b=E(d):typeof d.message=="string"?b=E(d.message):b="[unknown thing came down pipe that ain't an error]";console.error(`Error occurred but observer.error is falsy. error: ${b} (E: 822c60c7c4d542efacd5c2dea7e88062)`)}),l=new Kt(async d=>(c(d),z));if(i.error=async d=>{typeof d=="string"?d=await nr({rawMsg:d}):d instanceof Error&&(d=await nr({rawMsg:d.message}));try{await l.witness(d)}catch{e.error?console.error(`${t} there was another error when executing errorAnonFnWitness.witness (wrapper of caller's observer.error) trapping this. (E: 8fa3c4e633df4491a82951e3b677d9a9)`):console.error(`${t} there was another error when executing errorAnonFnWitness.witness (caller's observer.error was falsy). trapping this. (E: f5ff2db0d762487287139a4175eb7689)`)}},e.complete){let d=e.complete,b=new Kt(async h=>(await d(),z));i.complete=async()=>{try{await b.witness(z)}catch(h){console.error(`${t} there was an error when executing completeAnonFnWitness (wrapper for observer.complete fn) error: ${E(h)} (E: c9e61b08429e42c1b85d2215f735ba2f)`)}}}return i}catch(e){throw console.error(`${t} ${e.message}`),e}finally{$n&&console.log(`${t} complete.`)}}f(ga,"fnObs");var x=!0,In=!0,qe="[ControlDomain]",_n=class o{static{f(this,"SyncSagaCoordinator")}lc=`[${o.name}]`;constructor(){}defaultSessionConnectPoolConfig(){return Rs({id:ot,salt:`session-connect-${Date.now()}`,verbs:[gt],size:20,sequential:2,random:2,targetBinding:0,replenishStrategy:be.deleteAll})}defaultSessionSyncPoolConfig(){return Rs({id:Er,salt:`session-sync-${Date.now()}`,verbs:[rt],size:200,sequential:3,random:3,targetBinding:3,replenishStrategy:be.topUp})}async sync({peer:t,domainIbGibs:e,senderIdentity:r,fnSenderSecret:n,conflictStrategy:s=nt.abort,metaspace:a,localSpace:i}){let c=`${this.lc}[${this.sync.name}]`;if(x&&console.log(`${c} starting...`),!i){debugger;throw new Error(`${c} source (or localSpace) required (E: 25df3761f7686a1099a552f83c95d326)`)}if(r||n){if(!r)throw new Error("(UNEXPECTED) senderIdentity falsy but fnSenderSecret truthy? if either is used, both must be truthy. (E: e366628a4919c7d727d2cbd8e5b75e26)");if(!n)throw new Error("(UNEXPECTED) fnSenderSecret falsy but senderIdentity truthy? if either is used, both must be truthy. (E: 7d55ce37ae482fec48e3398158161926)")}let l=await j(),d=await hn();if(!d.next)throw new Error("(UNEXPECTED) updates$.next falsy? (E: d24cd82184aec130c89a320819b39126)");let b,h,p=new Promise(($,T)=>{b=$,h=T}),u=await Cc(),g=await a.createNewLocalSpace({opts:{allowCancel:!1,spaceName:u,getFnPrompt:a.getFnPrompt,logalot:x}});if(!g)throw new Error("Failed to create temp space (E: 8f4e2f3d6c1b4b1a8f4e2f3d6c1b4b1a)");await g.initialized;let m=f(async()=>{},"cleanup");return(async()=>{try{let $=e?e.map(y=>w({ibGib:y})):void 0;t.setOptionalOpts({sagaId:l,senderIdentity:r,fnSenderSecret:n,sessionConnectPoolConfig:this.defaultSessionConnectPoolConfig(),sessionSyncPoolConfig:this.defaultSessionSyncPoolConfig(),targetAddrs:$}),await t.establishSessionIdentity(),await t.connect({sagaId:l});let{initFrame:T,initDomainGraph:I}=await this.createInitFrame({sagaId:l,domainIbGibs:e,conflictStrategy:s,metaspace:a,localSpace:i,tempSpace:g,peer:t});if(await this.executeSagaLoop({initFrame:T,initDomainGraph:I,peer:t,updates$:d,localSpace:i,tempSpace:g,metaspace:a}),b(),!d.complete)throw new Error("(UNEXPECTED) updates$.complete falsy? (E: d24cd82184aec130c89a320819b39126)");d.complete()}catch($){if(console.error(`${c} ${E($)}`),h($),!d.error)throw new Error("(UNEXPECTED) updates$.error falsy? (E: 392ce77c073272e4c398c3e86583ce26)");d.error($)}finally{await m()}})(),{sagaId:l,updates$:d,done:p}}async continueSync({sagaContext:t,mySpace:e,myTempSpace:r,metaspace:n,peer:s}){let a=`${this.lc}[${this.continueSync.name}]`;try{x&&console.log(`${a} starting... (I: f64e08bf77d1425378601f380384ec26)`);let i=await this.handleResponseSagaContext({sagaContext:t,mySpace:e,myTempSpace:r,metaspace:n});if(i){if(i.nextFrameInfo?.sagaComplete)return null}else return x&&console.log(`${a} Handler returned null (Saga End). (I: 43da8bb6c846b1fe7766332643be0e26)`),null;if(i.errorMsg)throw new Error(`Couldn't handle response saga context. errorMsg: ${i.errorMsg} (E: 7b41a183cf3cb58a5859c803800cf826)`);if(!i.nextFrameInfo)throw new Error("(UNEXPECTED) contextResult.nextFrameInfo falsy? (E: 5740542f5eb8ccb41dfec188d87c1e26)");let{frame:c,payloadIbGibsDomain:l}=i.nextFrameInfo,d=await this.createSyncSagaContext({sagaFrame:c,localSpace:e,payloadIbGibsDomain:l,metaspace:n,sessionIdentityAddr:t.rel8ns?.sessionIdentity?.[0],peer:s,skipSign:!0}),b=await Ht({context:d});if(b.length>0)throw new Error(`(UNEXPECTED) just created sync saga context () and there were immediateValidationErrors? immediateValidationErrors: ${b} (E: c120e8e0aa98673d685267a8a36e5826)`);return d}catch(i){throw console.error(`${a} ${E(i)}`),i}finally{x&&console.log(`${a} complete.`)}}async executeSagaLoop({initFrame:t,initDomainGraph:e,peer:r,updates$:n,localSpace:s,tempSpace:a,metaspace:i}){let c=`${this.lc}[${this.executeSagaLoop.name}]`,l=t,d=[];for(;l;){let b=new Map,h=`${c}[peer.payloadIbGibsDomainReceived$]`,p=await r.payloadIbGibsDomainReceived$.subscribe(ga({next:f(async _=>{x&&console.log(`${h} next fired. (I: 2b4bdf502a38a90ba33d9711e7cb7826)`);let S=w({ibGib:_});In&&console.log(`${c}${qe} DOMAIN STREAM RECEIVED <- observable: ${S} (I: d69ee80fcaece272483ec33b2d289826)`),b.set(S,_)},"next"),error:f(async _=>{Rr(_)?console.error(`${h} error fired. error: ${JSON.stringify(_.data)} (E: 01cc08ba05ad99682831174fd7c31a26)`):(console.dir(_),console.error(`${h} error fired. error: ${E(_)} (E: 73d3d61464e8e4ce4cd6efd8b9675826)`))},"error"),complete:f(async()=>{x&&console.log(`${h} complete fired. (I: a47218aa9e4433fdb97c068880a45826)`),await p.unsubscribe()},"complete")})),u=await this.createSyncSagaContext({sagaFrame:l,payloadIbGibsDomain:d,localSpace:s,metaspace:i,sessionIdentityAddr:r.currentSessionIdentityAddr,peer:r});if(In){let _=d.map(S=>w({ibGib:S}));console.log(`${c}${qe} SENDER TRANSMIT -> peer.witness (I: 5b0081803698770f0bf64992220b312)`),console.log(`${c}${qe} Context: ${w({ibGib:u})}`),console.log(`${c}${qe} Frame: ${w({ibGib:l})}`),console.log(`${c}${qe} DOMAIN Payloads (${_.length}): ${_.join(", ")||"(none)"}`)}n.next(u),r.setOptionalOpts({localSpace:s,localTempSpace:a});let g=await r.witness(u);if(!g)if(l)if((await pa({frameIbGib:l,space:s}))?.data?.stage===Q.commit){x&&console.log(`${c} Sender sent Commit. Peer returned no response. Saga Complete. (I: 26f9ee073858ca78b8284753368b5226)`),l=null;break}else throw new Error("(UNEXPECTED) responseCtx falsy and currentFrame truthy, but we're not in the commit stage? This may be expected ultimately, but atow I am not seeing this as being expected. (E: cc34498962bd370deeff351fac939f26)");else throw new Error("(UNEXPECTED) no response and currentFrame falsy? (E: 8d1085ea2f28cfc3f9c922649864a826)");if(!g.data)throw new Error("(UNEXPECTED) responseCtx.data falsy? (E: a969992bae53ab18a827ec58aec15826)");n.next(g);let m=await Ht({context:g});if(m.length>0)throw new Error(`contextAndSagaFrameValidationErrors: ${m} (E: 6eebe8e7fa437c00a8cde3ada3c66826)`);let $=await this.validateReturnContext({requestCtx:u,responseCtx:g,localSpace:s});if($.length>0)throw new Error(`validateReturnContext errors: ${$.join(", ")} (E: cb8a023b9d0728cceb09fa3da0bb8226)`);let T=g.data[Us]||[];if(T.length>0&&(g.payloadIbGibsDomain=await this.pollForDomainPayloads({expectedAddrs:T,pollIntervalMs:20,domainPayloadsMap:b,tempSpace:a})),!g.sagaFrame)throw new Error("(UNEXPECTED) responseCtx.sagaFrame falsy? the Peer should have set this when it got the response back from the remote. (E: e650adadf9a2063ec6764a1e31d3d826)");if(In){let _=g.data?.["@payloadAddrsControl"]||[];console.log(`${c}${qe} SENDER RECEIVED <- peer.witness (I: 3dc76a9744d89a4fc3e2f076c2be4826)`),console.log(`${c}${qe} Response Context: ${w({ibGib:g})}`),console.log(`${c}${qe} Response Saga Frame: ${w({ibGib:g.sagaFrame})}`),console.log(`${c}${qe} CONTROL Payloads (${_.length}): ${_.join(", ")||"(none)"}`),console.log(`${c}${qe} DOMAIN Payloads (${T.length}): ${T.join(", ")||"(none)"}`)}let I=await this.handleResponseSagaContext({sagaContext:g,initDomainGraph:e,mySpace:s,myTempSpace:a,metaspace:i});if(I){if(I.nextFrameInfo?.sagaComplete){x&&console.log(`${c} Handler returned null (Saga End). (I: 123bf9e7dca8886de72553a8d4f29e26)`);break}}else{console.error(`${c} NAG ERROR (DOES NOT THROW): does this ever hit now? (E: e04d02efc2a8e72a88b79f1f0f95ca26)`);break}if(I.errorMsg)throw new Error(`Couldn't handle response saga context. errorMsg: ${I.errorMsg} (E: c948e81d513b2a0eb8b8afa878edc626)`);if(!I.nextFrameInfo)throw new Error("(UNEXPECTED) contextResult.nextFrameInfo falsy? (E: c287a82e823e662a77923278e2418826)");let{frame:y,payloadIbGibsDomain:A}=I.nextFrameInfo;if(l=y,d=[...A||[]],In){let _=d.map(S=>w({ibGib:S}));console.log(`${c}${qe} HANDLER RESULT -> next iteration (I: 6b0d88c4c28857ccd812381515bd7826)`),console.log(`${c}${qe} Next Frame: ${w({ibGib:l})}`),console.log(`${c}${qe} DOMAIN for next (${_.length}): ${_.join(", ")||"(none)"}`)}}}async createSyncSagaContext({sagaFrame:t,payloadIbGibsDomain:e,metaspace:r,localSpace:n,sessionIdentityAddr:s,peer:a,skipSign:i}){let c=`[${this.createSyncSagaContext.name}]`;try{if(x&&console.log(`${c} starting... (I: 6b87bee313e811d1d2fc90e87fbec826)`),!t.data)throw new Error("(UNEXPECTED) sagaFrame.data falsy? (E: 04c49b4cccba6842a8b52e4c6f570726)");if(!t.data.n&&t.data.n!==0)throw new Error("(UNEXPECTED) sagaFrame.data.n falsy and not 0? (E: 45b508da64a8b28428b11765d684b826)");let l=new Date,d=Ge(l),b=l.getMilliseconds(),h={timestamp:d,timestampMs:b,sagaN:t.data.n},p=e?e?.map(A=>w({ibGib:A})):void 0;p&&p.length>0&&(h[Us]=p);let u={sagaFrame:[w({ibGib:t})]},g;if(s){s=await r.getLatestAddr({addr:s,space:n})??s;let A=await B({addr:s,space:n});if(A.success&&A.ibGibs?.length===1)g=A.ibGibs[0],u.sessionIdentity=[s];else{debugger;throw new Error(`Couldn't get sessionIdentityAddr (${s}) in space: ${n.ib} (E: 5c29e80d68dbd1749866c358be093826)`)}}let m=await na({data:h}),$=await F.stone({parentPrimitiveIb:pn,ib:m,data:h,rel8ns:u}),T=w({ibGib:$}),I;g&&!i&&(I=await a.signContext({contextAddr:T})),await xe({ibGib:$,space:n}),await de({ibGib:$,space:n,fnBroadcast:void 0}),$.sagaFrame=t;let{msgStones:y}=await Ko({sagaIbGib:t,localSpace:n});if(y.length!==1)throw new Error("(UNEXPECTED) msgStones.length !== 1 inside createSyncSagaContext? (E: a98165cf46ab4e82b7bd5e45a273b826)");return $.sagaFrameMsg=y[0],e&&e.length>0&&($.payloadIbGibsDomain=e),I&&($.signedSessionIdentity=I),$}catch(l){throw console.error(`${c} ${E(l)}`),l}finally{x&&console.log(`${c} complete.`)}}async getKnowledgeMap({space:t,metaspace:e,domainIbGibs:r,tjpAddrs:n}){let s=`${this.lc}[${this.getKnowledgeMap.name}]`;try{if(x&&console.log(`${s} starting... (I: e184f8a7818666febfbbd2d841ed3826)`),!(r&&r.length>0)&&!(n&&n.length>0))throw new Error("(UNEXPECTED) domainIbGibs and tjpAddrs falsy/empty? we need one or the other (E: f674285111c8648398cd79d8c08ec826)");if(r&&r.length>0&&n&&n.length>0)throw new Error("(UNEXPECTED) both domainIbGibs and tjpAddrs truthy? only pass in one or the other. (E: f674285111c8648398cd79d8c08ec826)");let a=[];if(n)a=n;else if(r&&r.length>0){let{mapWithTjp_YesDna:c,mapWithTjp_NoDna:l}=ut({ibGibs:r}),d=[...Object.values(c),...Object.values(l)],b=ze({ibGibs:d});a=Object.keys(b)}else return console.warn(`${s} No domainIbGibs or tjpAddrs provided. Returning empty Knowledge. (W: 2b0e115e7578a83d1b26f7c726bf9426)`),{};if(a.length===0)return{};let i=await je({space:t,tjpAddrs:a});if(!i.data||!i.data.latestAddrsMap)throw new Error(`${s} Failed to get latest addrs. (E: 7d395940c0e1419165c5196c39c6c826)`);return i.data.latestAddrsMap}catch(a){throw console.error(`${s} ${E(a)}`),a}finally{x&&console.log(`${s} complete.`)}}async analyzeDomainIbGibs({domainIbGibs:t,space:e}){let r=`${this.lc}[${this.analyzeDomainIbGibs.name}]`;if(t.length===0)throw new Error("invalid domainIbGibs. expected at least one, but array is empty. (E: 820a719bcac5a16878a2af697113b826)");let n=await Et({ibGibs:t,live:!0,space:e}),s=n&&Object.keys(n).length>0;x&&console.log(`${r} graph generated. nodes: ${s?Object.keys(n).length:0}`);let a=s?Object.values(n):[],{mapWithTjp_YesDna:i,mapWithTjp_NoDna:c,mapWithoutTjps:l}=ut({ibGibs:a}),d=Object.values(l),b=[...Object.values(i),...Object.values(c)],h=ze({ibGibs:b}),p=this.sortTimelinesTopologically(h);return{stones:d,timelinesMap:h,topologicallySortedTjpAddrs:p,fullGraph:n}}async createInitFrame({sagaId:t,domainIbGibs:e,conflictStrategy:r,metaspace:n,localSpace:s,tempSpace:a,peer:i}){let c=`${this.lc}[${this.createInitFrame.name}]`;try{x&&console.log(`${c} starting... (I: 551af8b411ae9be712ce3358d43ee726)`);let l=await this.analyzeDomainIbGibs({domainIbGibs:e,space:s}),{timelinesMap:d,fullGraph:b,stones:h}=l;await xe({ibGibs:Object.values(b),space:a});let p={};Object.keys(d).forEach($=>{let I=d[$].at(-1);p[$]=w({ibGib:I})});let u={sagaId:t,stage:Q.init,knowledgeMap:p,mode:ks.sync,stones:h.map($=>w({ibGib:$}))};x&&(console.log(`${c} SyncStage.init: ${Q.init}, SyncStage.commit: ${Q.commit}`),console.log(`${c} initData.stage: ${u.stage}`));let g=await this.createSyncMsgStone({data:u,localSpace:s,metaspace:n}),m=await this.evolveSyncSagaIbGib({msgStones:[g],conflictStrategy:r,metaspace:n,localSpace:s,sessionIdentity:i.currentSessionIdentity});return x&&console.log(`${c} sagaFrame (init): ${P(m)} (I: b3d6a8be69248f18713cc3073cb08626)`),{initFrame:m,initDomainGraph:b}}catch(l){throw console.error(`${c} ${E(l)}`),l}finally{x&&console.log(`${c} complete.`)}}async validateReturnContext({requestCtx:t,responseCtx:e,localSpace:r}){let n=`${this.lc}[${this.validateReturnContext.name}]`,s=[];try{if(t.sagaFrame&&e.sagaFrame){let c=w({ibGib:t.sagaFrame}),l=w({ibGib:e.sagaFrame});await yr({olderAddr:c,newerAddr:l,space:r})||s.push(`Response saga frame (${l}) is not a valid continuation of request saga frame (${c}). (E: 2c85e8d97318ff24ac8a02bd3a068226)`)}else s.push("Missing sagaFrame on requestCtx or responseCtx. (E: b65c68ff891000ddca8d22384a088226)");let a=t.signedSessionIdentity?w({ibGib:t.signedSessionIdentity}):t.rel8ns?.sessionIdentity?.[0],i=e.rel8ns?.sessionIdentity?.[0];a!==i&&s.push(`Session identity mismatch. Expected ${a}, got ${i}. (E: ab98716bca88d2243cc822187768226)`)}catch(a){s.push(`Error during validateReturnContext: ${E(a)} (E: da878e1239aa88ee27bdfca005c28226)`)}return s}async pollForDomainPayloads({expectedAddrs:t,pollIntervalMs:e,domainPayloadsMap:r,tempSpace:n}){let s=`${this.lc}[${this.pollForDomainPayloads.name}]`;try{x&&console.log(`${s} starting... (I: 26dce86bfca572939885798802d6e926)`);let a=[],i=[...t],c=Date.now(),l=5*60*1e3;for(;i.length>0;){if(Date.now()-c>l)throw new Error(`Timeout waiting for payloads: ${i.join(", ")} (E: 46e1683c9578095261aaf798bd5e1826)`);let d=[],b=[];for(let h of i)r.has(h)?(b.push(r.get(h)),r.delete(h)):d.push(h);b.length>0&&(await xe({space:n,ibGibs:b}),b.forEach(h=>a.push(h))),i=d,i.length>0&&await pe(e)}if(t.length!==a.length)throw new Error("(UNEXPECTED) expectedAddrs.length !== resultDomainPayloads.length? at this point, we expect all of the payload ibgibs to have been received. (E: 03749a7478c4b8b28bfc86951887a826)");return a}catch(a){throw console.error(`${s} ${E(a)}`),a}finally{x&&console.log(`${s} complete.`)}}async handleResponseSagaContext({sagaContext:t,initDomainGraph:e,mySpace:r,myTempSpace:n,metaspace:s}){let a=`${this.lc}[${this.handleResponseSagaContext.name}]`;try{x&&console.log(`${a} starting... (I: 5deec8a1f7a6d263c88cd458ad990826)`);let i=t.sagaFrame;if(!i.data)throw new Error("(UNEXPECTED) sagaIbGib.data falsy? (E: 71b938adf1d87c2527bfd4f86dfd0826)");x&&console.log(`${a} sagaIbGib: ${P(i)} (I: 1b99d87d262e9d18d8a607a80b1a0126)`);let{stage:c,messageData:l}=await this.getStageAndPayloadFromFrame({sagaFrame:i,space:r});x&&console.log(`${a} handling frame stage: ${c}`);let d;switch(c){case Q.init:d=await this.handleInitFrame({sagaIbGib:i,messageData:l,metaspace:s,mySpace:r,myTempSpace:n});break;case Q.ack:if(!e)throw new Error("(UNEXPECTED) initDomainGraph falsy on the sender? (E: a3d758ad954829aba88663188eafc826)");d=await this.handleAckFrame({sagaContext:t,sagaIbGib:i,initDomainGraph:e,metaspace:s,mySpace:r,myTempSpace:n});break;case Q.delta:d=await this.handleDeltaFrame({sagaContext:t,sagaIbGib:i,metaspace:s,mySpace:r,myTempSpace:n});break;case Q.commit:x&&console.log(`${a}[${Ir({sagaFrame:i})}] mySpace.ib: ${r.ib} (I: 5b270996d848907238d817fffa64a126)`),d=await this.handleCommitFrame({sagaIbGib:i,metaspace:s,mySpace:r,myTempSpace:n});break;default:throw new Error(`${a} (UNEXPECTED) Unknown sync stage: ${c} (E: 9c2b4c8a6d34469f8263544710183355)`)}return x&&console.log(`${a} nextFrameInfo: ${d?P(d):"undefined"} (I: a8ad281ca8e89385686d18327a105726)`),{errorMsg:void 0,nextFrameInfo:d}}catch(i){let c=`${a} ${E(i)}`;return console.error(c),{errorMsg:c}}finally{x&&console.log(`${a} complete.`)}}async handleInitFrame({sagaIbGib:t,messageData:e,mySpace:r,myTempSpace:n,metaspace:s}){let a=`${this.lc}[${this.handleInitFrame.name}]`;try{x&&console.log(`${a} starting... (I: 9d88dcad0408c029e898a4bcf3b08426)`),x&&console.log(`${a} [TEST DEBUG] Receiver mySpace: ${r.ib}`);let i=e;if(i.stage!==Q.init)throw new Error(`${a} Invalid init frame: initData.stage !== SyncStage.init (E: c91be82970e4decc58f56bf8fc1ffc26)`);if(!i||!i.knowledgeMap)throw new Error(`${a} Invalid init frame: missing knowledgeMap (E: ed02c869e028d2d06841b9c7f80f2826)`);let c=t.data.conflictStrategy||nt.abort,l=[],d=[],b=[],h=i.stones||[];if(h.length>0){x&&console.log(`${a} processing stones: ${h.length}`);let S=(await B({space:r,addrs:h})).rawResultIbGib;if(!S.data)throw new Error("(UNEXPECTED) rawResultIbGib.data falsy? (E: f3c40b492adc02c3f480b998fc7a5926)");let N=S.data.addrsNotFound;N&&N.length>0&&(x&&console.log(`${a} stones missing (requesting): ${N.length}`),N.forEach(O=>{d.some(D=>D.addr===O)||d.push({addr:O})}))}let p=i.knowledgeMap;x&&console.log(`${a} senderKnowledge: ${P(p)} (I: 9f957862356dfeae183c200854e86e26)`);let u=Object.keys(p);x&&console.log(`${a} [TEST DEBUG] senderTjpAddrs: ${JSON.stringify(u)}`),x&&console.log(`${a} senderTjpAddrs: ${P(u)} (I: 86ea4c53db0dc184c8b253386c402126)`);let g={};if(u.length>0){let _=await je({space:r,tjpAddrs:u});if(!_.data)throw new Error("(UNEXPECTED) resGetLatestAddrs.data falsy? (E: b180d813c088042b38e1e02e06a16926)");if(!_.data.latestAddrsMap)throw new Error("(UNEXPECTED) resGetLatestAddrs.data.latestAddrsMap falsy? (E: 16bc386dd51d0ff53a49620b1e641826)");g=_.data.latestAddrsMap,x&&console.log(`${a} [TEST DEBUG] receiverLatestAddrsMap: ${JSON.stringify(g)}`),x&&console.log(`${a} receiverLatestAddrsMap: ${P(g)} (I: 980975642cbccd8018cf0cd808d30826)`)}for(let _ of u){let S=p[_],N=g[_];if(!N){x&&console.log(`${a} [TEST DEBUG] Missing receiver timeline for TJP: ${_}. Requesting remoteAddr: ${S}`),d.push({addr:S,tjpAddr:_});continue}if(N===S){x&&console.log(`${a} [TEST DEBUG] TJP ${_}: Synced (receiverTipAddr === remoteAddr)`);continue}if(x&&console.log(`${a} [TEST DEBUG] TJP ${_}: receiverTipAddr=${N}, remoteAddr=${S} - checking for divergence...`),await yr({olderAddr:S,newerAddr:N,space:r})){x&&console.log(`${a} [TEST DEBUG] TJP ${_}: Remote (sender) is in past - offering push`);let D=await mr({ibGibAddr:N,live:!1,latestCommonFrameAddr:S,space:r});b.push({tjpAddr:_,addrs:Object.keys(D)})}else{let D=!1;try{D=await yr({olderAddr:N,newerAddr:S,space:r})}catch(k){x&&console.log(`${a} expected error if we don't have remote. verbose logging error though: ${E(k)} (I: 47ea08d0b418cf4aa8a502a7bcb80826)`)}if(D)x&&console.log(`${a} [TEST DEBUG] TJP ${_}: receiver is in past - requesting delta`),d.push({addr:S,tjpAddr:_,latestAddrAlreadyHave:N});else if(x&&console.log(`${a} [TEST DEBUG] TJP ${_}: DIVERGENCE DETECTED! conflictStrategy=${c}`),c==="abort")l.push({tjpAddr:_,receiverTipAddr:N,senderTipAddr:S,receiverKnowledgeTimelineAddrs:[],reason:"divergence",terminal:!0});else if(c===nt.optimisticWithLCS){let k=await B({addr:N,space:r});if(!k.success||k.ibGibs?.length!==1)throw new Error(`couldn't get local tip (${N}) from space (${r.ib}). errorMsg: ${k.errorMsg??"[unknown error (E: b3c3d823276300aa384ebdba4a8eb826)]"} (E: 83cb88a767e22bbda99c6788bec50526)`);let U=k.ibGibs[0],R=await ba({timeline:U,space:r,metaspace:s});l.push({tjpAddr:_,receiverTipAddr:N,senderTipAddr:S,receiverKnowledgeTimelineAddrs:[...R,N],reason:"divergence",terminal:!1})}else throw new Error(`${a} Unsupported conflict strategy: ${c}. Only these currently implemented: ${er} (E: 8f12384180f8a718a983a749fe0adf26)`)}}if(l.some(_=>_.terminal))throw x&&console.warn(`${a} ABORTING Sync Saga due to terminal conflicts: ${JSON.stringify(l)}`),new Error(`the saga has terminal conflicts. conflicts: ${JSON.stringify(l)} (E: f2edbe93cc07a63b38bfc013d2213b26)`);if(!t.data)throw new Error("(UNEXPECTED) sagaIbGib.data falsy? (E: 24203af4600fb226ae6c1afbde442826)");let T={sagaId:t.data.uuid,stage:Q.ack,deltaRequestAddrInfos:d,pushOfferInfos:b};l?.length>0&&(T.conflicts=l);let I=await this.createSyncMsgStone({data:T,localSpace:r,metaspace:s});x&&console.log(`${a} ackStone created: ${P(I)} (I: 313708132dd53ff946befb7833657826)`);let y=await this.evolveSyncSagaIbGib({prevSagaIbGib:t,msgStones:[I],localSpace:r,metaspace:s}),A;if(b.length>0){let _=[];A=[];let S=b.flatMap(U=>U.addrs),N=await B({addrs:S,space:r}),O=N.rawResultIbGib?.data;if(!O)throw new Error("(UNEXPECTED) resGet.rawResultIbGib.data falsy? (E: 1a2cc8cb99a1ffa60837e45a8229b826)");let D=O.addrsNotFound??[],k=O.addrsErrored??[];if(N.ibGibs&&N.ibGibs.length===S.length)N.ibGibs.forEach(U=>{A.push(U)});else if(N.ibGibs&&N.ibGibs.length>0)if(N.ibGibs.forEach(R=>{A.push(R)}),A.length+D.length+k.length===S.length)D.forEach(R=>_.push(R)),k.forEach(R=>_.push(R));else throw D.length===0&&k.length===0?new Error("(UNEXPECTED) found some but not all addrs but addrsNotFound and addrsErrored both empty? (E: ef1b2cf5bab8de2298ec507abe04e826)"):new Error("(UNEXPECTED) found some but not all addrs but addrsNotFound and addrsErrored don't contain the addrs not found? (E: ae9e015109f8c3c3a813da584cd98826)");else console.warn(`${a} we were expecting all domainAddrs in mySpace (${r.ib}) but we couldn't get all of them. addrsNotFound: ${D??[]}. addrsErrored: ${k??[]}. Trying temp space (${n.ib}). (W: f61908e264f8dddd2e3fb9084463d826)`),S.forEach(U=>_.push(U));if(_.length>0){x&&console.log(`${a} couldn't get all addrs in mySpace (${r.ib}). searchSecondSpaceAddrs: ${_} (I: 233fd954dbd84e51bca02fa8eed5f826)`);let U=await B({addrs:_,space:n});if(U.success&&U.ibGibs&&U.ibGibs.length===_.length)U.ibGibs.forEach(R=>A.push(R));else{U.ibGibs?.forEach(Y=>A.push(Y));let R=S.filter(Y=>!A.map(oe=>w({ibGib:oe})).includes(Y));throw new Error(`couldn't get some or all of addrs from either mySpace (${r.ib}) or myTempSpace (${n.ib}). addrsFailed: ${R} (E: 1394d412c4ffa4dd085f269b43338826)`)}}}return{frame:y,payloadIbGibsDomain:A}}catch(i){throw console.error(`${a} ${E(i)}`),i}finally{x&&console.log(`${a} complete.`)}}async handleAckFrame({sagaContext:t,sagaIbGib:e,initDomainGraph:r,mySpace:n,myTempSpace:s,metaspace:a}){let i=`${this.lc}[${this.handleAckFrame.name}]`;try{x&&console.log(`${i} starting... (I: 605b6860e898267a5b50c6d85704be26)`);let{messageData:c}=await this.getStageAndPayloadFromFrame({sagaFrame:e,space:n}),l=c,d=!0;if(!l)throw new Error(`${i} ackData falsy (E: 3b8415edc876084c88a25b98e2d55826)`);if(l.stage!==Q.ack)throw new Error(`${i} Invalid ack frame: ackData.stage !== SyncStage.ack (E: 2e8b0a94b5954a66a6a1a7a0b3f5b7a1)`);if(x&&console.log(`${i} ackData: ${P(l)} (I: b817c5571c5e916fe8f90b892b3e8e26)`),!e.data)throw new Error("(UNEXPECTED) sagaIbGib.data falsy? (E: e3f2e8f162484859787651b85c011826)");let b=l.conflicts?L(l.conflicts):[];x&&console.log(`${i} [CONFLICT DEBUG] Received conflicts from Ack: ${b.length}`),x&&b.length>0&&console.log(`${i} [CONFLICT DEBUG] Conflicts detail: ${JSON.stringify(b,null,2)}`);let h=b.filter(A=>A.terminal);if(h.length>0)throw x&&console.warn(`${i} Received terminal conflicts from Ack: ${JSON.stringify(h)}`),new Error(`${i} Peer reported terminal conflicts. (E: 23a0096ee05a2ccfa89334e8f156b426)`);let p=[];if(b.length>0){x&&console.log(`${i} [CONFLICT DEBUG] Processing ${b.length} non-terminal conflicts`),d=!1;for(let A of b){let{receiverTipAddr:_,reason:S,senderTipAddr:N,terminal:O,receiverKnowledgeTimelineAddrs:D,tjpAddr:k}=A;if(O)throw new Error("(UNEXPECTED) conflict.terminal truthy? We expect this to already throw/abort the saga before this point in execution. (E: b42e982edca8b1156765de38f9e74626)");let U=r[N];if(!U)throw new Error(`(UNEXPECTED) senderTipIbGib falsy? initDomainGraph should have had the senderTipAddr (${N}) that was included in the ack frame conflicts. tjpAddr: ${k}. reason: ${S} (E: 3bd80f2054a924be98e6a7421bff4626)`);let{headIbGib:R,orderedPastIbGibs:Y}=await mn({timeline:U,getLatest:!0,metaspace:a,space:n}),oe=Y.map(Ae=>w({ibGib:Ae})),ye=w({ibGib:R});if(A.senderKnowledgeTimelineAddrs=[...oe,ye],R.gib!==U.gib&&(A.senderTipAddr=ye,!Object.keys(r).includes(ye))){let Ae=await Et({ibGibAddr:ye,live:!0,space:n}),Ue=Object.keys(Ae);for(let Se of Ue)r[Se]||(r[Se]=Ae[Se])}let at=D.findLast(Ae=>oe.includes(Ae));if(!at)throw new Error(`(UNEXPECTED) no latestCommonFrameAddr in the conflicts.receiverKnowledgeTimelineAddrs (${D.join(`
|
|
29
|
+
`)})? This would mean that it doesn't even have the tjpAddr (${k}). So what are we doing here? (E: 8931d1bdd6d8e100bf55f7c8a6924826)`);let vt=await mr({ibGibAddr:ye,live:!0,latestCommonFrameAddr:at,space:n}),Qe=[];if(Object.keys(vt).forEach(Ae=>{Qe.push(Ae);let Ue=vt[Ae];p.push(Ue)}),A.accretivePayloadAddrs)throw new Error("(UNEXPECTED) conflict.accretivePayloadAddrs already truthy? This is expected to be falsy at this point in the sync. (E: 6b6b1846779867849cbde208f4374326)");A.accretivePayloadAddrs=Qe}x&&console.log(`${i} [CONFLICT DEBUG] Finished processing ${b.length} conflicts. outgoingPayloadIbGibsDomain_conflicts.length (total outgoing payload ibgibs for ALL conflicts): ${p.length}`)}else x&&console.log(`${i} [CONFLICT DEBUG] No optimistic conflicts to process`);let u=await this.getPayloadsForRequestedInfos({deltaRequestAddrInfos:l.deltaRequestAddrInfos||[],mySpace:n}),g=[...p,...u],m;g.length===0?g=void 0:m=g.map(A=>w({ibGib:A}));let $={sagaId:e.data.uuid,stage:Q.delta,conflicts:b,payloadAddrsDomain:m,deltaRequestAddrInfos:void 0,proposeCommit:d},T;x&&console.log(`${i} Creating Delta Stone. Data stage: ${$.stage}`);let I=await this.createSyncMsgStone({data:$,rel8ns:T,localSpace:n,metaspace:a}),y=await this.evolveSyncSagaIbGib({prevSagaIbGib:e,msgStones:[I],localSpace:n,metaspace:a});return x&&console.log(`${i} Delta Frame created. Rel8ns: ${JSON.stringify(y.rel8ns)}`),{frame:y,payloadIbGibsDomain:g}}catch(c){throw console.error(`${i} ${E(c)}`),c}finally{x&&console.log(`${i} complete.`)}}async handleDeltaFrame({sagaContext:t,sagaIbGib:e,mySpace:r,myTempSpace:n,metaspace:s}){let a=`${this.lc}[${this.handleDeltaFrame.name}]`;try{x&&console.log(`${a} starting... (I: a1d0a85eb4189466f86dfd61e3df2626)`);let{messageData:i}=await this.getStageAndPayloadFromFrame({sagaFrame:e,space:r}),c=i;if(!e.data)throw new Error("(UNEXPECTED) sagaIbGib.data falsy? (E: 8874e83e1a1b307938ee832862ec5826)");if(!e.data.conflictStrategy)throw new Error("(UNEXPECTED) sagaIbGib.data.conflictStrategy falsy? (E: 636205ab5b78fcb31d0cb1880770c826)");if(!c)throw new Error(`${a} deltaData falsy (E: 7c28c8d8f08a4421b8344e6727271421)`);if(c.stage!==Q.delta)throw new Error(`${a} Invalid delta frame: deltaData.stage !== SyncStage.delta (E: 0c28c8d8f08a4421b8344e6727271421)`);x&&console.log(`${a} deltaData: ${P(c)} (I: a76008681df458cfbcdc4848f825a826)`),x&&console.log(`${a} [CONFLICT DEBUG] deltaData.payloadAddrsDomain count: ${c.payloadAddrsDomain?.length||0}`);let{conflictStrategy:l}=e.data,{deltaRequestAddrInfos:d,payloadAddrsDomain:b,proposeCommit:h}=c,p=c.proposeCommit??!1,u=t.payloadIbGibsDomain??[];x&&console.log(`${a} [CONFLICT DEBUG] Fulfilling ${(c.deltaRequestAddrInfos||[]).length} peer requests`);let g=await this.getPayloadsForRequestedInfos({deltaRequestAddrInfos:c.deltaRequestAddrInfos||[],mySpace:r});x&&console.log(`${a} [CONFLICT DEBUG] Outgoing payload size (with deps): ${g.length}`);let m=c.conflicts?L(c.conflicts):[],$=m.filter(A=>!A.resolved);if($.length>0){if(l!==nt.optimisticWithLCS)throw new Error(`(UNEXPECTED) conflictStrategy (${l}) is not ${nt.optimisticWithLCS}? right now, this is the only one we've implemented. (E: ba3e08d92a66b24075016208a0f83226)`);for(let A of $){let _={};for(let ne of A.accretivePayloadAddrs??[]){let it=u.find(mt=>w({ibGib:mt})===ne);if(!it)throw new Error("(UNEXPECTED) conflictPayloadIbGib falsy? At this time in dev (01/27/2026), we're expecting this to be populated because we're only expecting one iteration of conflict resolution. If dev is later, this may no longer be the case. (E: b197417e762639089827aa3edaece826)");_[ne]=it}A.latestCommonFrameAddr;let{receiverKnowledgeTimelineAddrs:S,senderKnowledgeTimelineAddrs:N,reason:O,receiverTipAddr:D,senderTipAddr:k,tjpAddr:U}=A;if(!N)throw new Error("(UNEXPECTED) senderKnowledgeTimelineAddrs falsy? (E: 2a608892d11bd848e8f0c7a8d676d826)");let R=await Et({ibGibAddrs:[D],live:!0,space:r}),Y=Object.values(R);await Vo({ibGibs:Y,space:n});for(let ne of S){let it=R[ne];await de({ibGib:it,space:n})}let oe=N.findLast(ne=>S.includes(ne));if(!oe)throw new Error("(UNEXPECTED) latestCommonFrameAddr falsy? how we can have a conflict without a common point in history? (E: 53de0a181838b3e5bf98d0887994b826)");let ye=await mr({ibGibAddr:A.receiverTipAddr,latestCommonFrameAddr:oe,live:!0,space:r});Object.values(ye).forEach(ne=>g.push(ne));let at=await Bs({conflictStrategy:l,timelineAddrsA:N,timelineAddrsB:S,latestCommonFrameAddr:oe,ibGibReadCache:_,space:n}),{dnasCreatedInGraft:vt,dnasReplayed:Qe,intermediateIbGibsCreatedInGraft:Ae,newGraftTip:Ue,graftInfoCreated:Se}=at;if(A.createdDnaAddrs=vt.map(ne=>w({ibGib:ne})),A.replayedDnaAddrs=Qe.map(ne=>w({ibGib:ne})),A.createdDomainAddrs=[...Ae.map(ne=>w({ibGib:ne})),w({ibGib:Se}),w({ibGib:Ue})],!Ue.rel8ns)throw new Error("(UNEXPECTED) newGraftTip.rel8ns falsy? we expect this to have graftinfo rel8ns, let alone dna (E: 718788f5a44e815618ac1ba621c8a826)");let Tr=Ue.rel8ns[qr];if(!Tr||Tr.length===0)throw new Error(`(UNEXPECTED) newGraftTip.rel8ns.${qr} falsy/empty? we expect to always have graft info attached to timelines that are grafted. (E: 45abf31654c8aa517df4d0882b996826)`);A.graftInfoAddr=Tr.at(-1);let zr=[vt,Qe,Ae,[Se,Ue]];for(let ne of zr.flat())if((await Z({ibGib:ne})??[]).length>0){console.dir(ne);debugger;console.log(P(ne))}A.accretivePayloadAddrs??=[],zr.forEach(ne=>ne.forEach(it=>{let mt=w({ibGib:it});A.accretivePayloadAddrs.includes(mt)||A.accretivePayloadAddrs.push(mt),g.some(Tn=>w({ibGib:Tn})===mt)||g.push(it)})),A.resolved=!0}}let T=[],I=g.length>0,y=T.length>0;if(I||y){let A={sagaId:c.sagaId,stage:Q.delta,payloadAddrsDomain:g.map(N=>w({ibGib:N})),requests:y?T:void 0,conflicts:m},_=await this.createSyncMsgStone({data:A,localSpace:r,metaspace:s});return{frame:await this.evolveSyncSagaIbGib({prevSagaIbGib:e,msgStones:[_],localSpace:r,metaspace:s}),payloadIbGibsDomain:g}}else if(p){let A=await $r({sagaIbGib:e,space:r}),_=await Wo({history:A});return _.length>0?{frame:await this.createCommitFrame({sagaIbGib:e,errors:_,metaspace:s,mySpace:r})}:(await this.executeLocalCommit({sagaHistory:A,deltaFrame:e,localTempSpace:n,localSpace:r,metaspace:s}),{frame:await this.createCommitFrame({sagaIbGib:e,errors:void 0,metaspace:s,mySpace:r})})}else{let A={sagaId:c.sagaId,stage:Q.delta,proposeCommit:!0,conflicts:m},_=await this.createSyncMsgStone({data:A,localSpace:r,metaspace:s}),S=await this.evolveSyncSagaIbGib({prevSagaIbGib:e,msgStones:[_],localSpace:r,metaspace:s});if(c.proposeCommit){x&&console.log(`${a} Peer proposed commit. Accepting & Committing.`);let N={sagaId:c.sagaId,stage:Q.commit,success:!0},O=await this.createSyncMsgStone({data:N,localSpace:r,metaspace:s});return{frame:await this.evolveSyncSagaIbGib({prevSagaIbGib:S,msgStones:[O],localSpace:r,metaspace:s})}}return{frame:S,payloadIbGibsDomain:g}}}catch(i){throw console.error(`${a} ${E(i)}`),i}finally{x&&console.log(`${a} complete.`)}}async executeLocalCommit({deltaFrame:t,commitFrame:e,sagaHistory:r,metaspace:n,localSpace:s,localTempSpace:a}){let i=`${this.lc}[${this.executeLocalCommit.name}]`;try{if(x&&console.log(`${i} starting... (I: 6734980446b86a63c1af6e2e206de826)`),!t&&!e)throw new Error("(UNEXPECTED) !deltaFrame && !commitFrame? we're expecting to execute the commit based off of EITHER a delta OR a commit frame. (E: 10cae319a2685a672866f5583514e326)");if(t&&e)throw new Error("(UNEXPECTED) deltaFrame && commitFrame? we're expecting to execute the commit based off of EITHER a delta OR a commit frame. (E: b9037b1ed6d8684ac8a5d01328bad826)");let l=!!t?t:e;if(!l)throw new Error("(UNEXPECTED) !currentFrame? something wrong with my logic. (E: 4ec0ce6625cc1d677bc902c839ca1a26)");let d=Ir({sagaFrame:l});if(x&&console.log(`${i} currentFrameOrigin: ${d} (I: 3add8f8390c89743ae554bd3cc60b826)`),!l.data)throw new Error("(UNEXPECTED) currentFrame.data falsy? (E: a8be68d48668d93d992d793834823826)");let b=[],h=f(I=>{b.includes(I)||b.push(I)},"fnAddPayloadAddr"),p=r.filter(I=>{let y=Ir({sagaFrame:I.sagaIbGib});return d!==y});r.filter(I=>{let y=Ir({sagaFrame:I.sagaIbGib});return d===y}).forEach(I=>{if(!I.sagaIbGib.data)throw new Error("(UNEXPECTED) sagaIbGib.data falsy? (E: 34d7f8cdee14717ce828878d98f89826)");I.msgStones.forEach(y=>{if(!y.data)throw new Error("(UNEXPECTED) msgStone.data falsy? (E: 21406101f91847514cc759c8a7382f26)");if(y.data.stage===Q.ack){let A=y.data;A.pushOfferInfos&&A.pushOfferInfos.length>0&&A.pushOfferInfos.forEach(_=>{_.addrs.forEach(S=>h(S))})}else if(y.data.stage===Q.delta){let A=y.data;A.payloadAddrsDomain&&A.payloadAddrsDomain.length>0&&A.payloadAddrsDomain.forEach(_=>h(_))}})}),x&&console.log(`${i}[${d}] allPayloadAddrsDomainTransferred: ${b.length>0?b.join(", "):"none"} (I: a1950eb3ca95bdc9ec18a4b8823e9826)`);let g=[];if(b.length>0){let I=await B({addrs:b,space:a});if(I.success&&I.ibGibs&&I.ibGibs.length===b.length)g=I.ibGibs.concat();else{if(!I.rawResultIbGib)throw new Error("(UNEXPECTED) !resGetAllTransferred.rawResultIbGib falsy? (E: dc6cf8729668f4fbe8c024f887d97a26)");let{addrsNotFound:y,addrsErrored:A,errors:_}=I.rawResultIbGib.data;throw new Error(`(UNEXPECTED) we couldn't get all addrs transferred throughout the saga from the tempspace (${a.ib})? addrsNotFound: ${y??[]}. addrsErrored: ${A??[]}. errors: ${_??[]}(E: 222e341e634862b4d88ae7282584d826)`)}}let m=[],$=await zo({sagaHistory:r});if($)for(let I of $){if(!I.resolved)throw new Error("(UNEXPECTED) finalConflict.resolved falsy? right now, we're expecting to resolve all conflicts. (E: a40ca8f1f54665407892ec21123a4f26)");if(!I.graftInfoAddr)throw new Error("(UNEXPECTED) finalConflict resolved but graftInfoAddr falsy? we're expecting all resolved conflicts to have a graftInfoAddr (E: d082488347570947b82008a835200126)");if(!(await Xe({addrs:[I.graftInfoAddr],space:a})).at(0))throw new Error(`(UNEXPECTED) couldn't get finalConflictGraftInfo from localTempSpace (${a})? (E: 35e3c8130608d991e8fb295807812826)`);let{createdDnaAddrs:_,replayedDnaAddrs:S,createdDomainAddrs:N}=I;if(!_||_.length===0)throw new Error("(UNEXPECTED) finalConflict.createdDnaAddrs falsy/empty? (E: 9689f8be5bd19650b8d4a058b65db826)");if(!S||S.length===0)throw new Error("(UNEXPECTED) finalConflict.replayedDnaAddrs falsy/empty? (E: f42878ed1cee3e9828567c5ab8179526)");if(!N||N.length===0)throw new Error("(UNEXPECTED) finalConflict.createdDomainAddrs falsy/empty? (E: cc41251d1acfe91a48d1b6080259ed26)");(await Xe({addrs:[..._,...S,...N],space:a})).forEach(D=>m.push(D))}let T=[];if(g.forEach(I=>T.push(I)),m.forEach(I=>T.push(I)),T.length===0)x&&console.log(`${i}[${d}] no changes on this end (I: fa30d18e83a87ee9e8487fbb5d632b26)`);else{x&&console.log(`${i}[${d}] ${T.length} changes detected (I: fa30d18e83a87ee9e8487fbb5d632b26)`),x&&console.log(`${i} put all into localSpace (${s.ib}) starting... (I: d5e0d9870e380b61e80c729660058826)`);let{payload_Dnas:I,payload_NonDnas:y}=await Vo({ibGibs:T,space:s});x&&console.log(`${i} put all into localSpace (${s.ib}) complete. (I: d5e0d9870e380b61e80c729660058826)`);let A=await Hs({sagaHistory:r,myTempSpace:a}),{mapWithTjp_NoDna:_,mapWithTjp_YesDna:S,mapWithoutTjps:N}=ut({ibGibs:y,filterPrimitives:!0});x&&console.log(`${i} register mapWithoutTjps starting... (I: 2b84d8f8dda85adde88696d8419bf726)`);let O=Object.values(N);for(let Y of O)x&&console.log(`${i} registering ${w({ibGib:Y})} (I: 4647b4f42d27cffe0fbfce8846755826)`),await n.registerNewIbGib({ibGib:Y,space:s});x&&console.log(`${i} mapWithoutTjps complete. (I: 2b84d8f8dda85adde88696d8419bf726)`),x&&console.log(`${i} register mapWithTjp_NoDna starting... (I: 96e648e4db382499b8bfaa1b37c24826)`);let D=ze({ibGibs:Object.values(_)}),k=Object.keys(D);for(let Y of k){let oe=D[Y];for(let ye of oe)await n.registerNewIbGib({ibGib:ye,space:s})}x&&console.log(`${i} register mapWithTjp_NoDna complete. (I: 96e648e4db382499b8bfaa1b37c24826)`),x&&console.log(`${i} register mapWithTjp_YesDna starting... (I: d54a820e9442dee4681f6228a6795926)`);let U=ze({ibGibs:Object.values(S)}),R=Object.keys(U);for(let Y of R){let oe=U[Y];for(let ye of oe)A.includes(w({ibGib:ye}))||await n.registerNewIbGib({ibGib:ye,space:s})}x&&console.log(`${i} register mapWithTjp_YesDna complete. (I: d54a820e9442dee4681f6228a6795926)`)}}catch(c){throw console.error(`${i} ${E(c)}`),c}finally{x&&console.log(`${i} complete.`)}}async createCommitFrame({sagaIbGib:t,errors:e,metaspace:r,mySpace:n}){let s=`[${this.createCommitFrame.name}]`;try{x&&console.log(`${s} starting... (I: 48fc57c023f80122135a284855757526)`);let a=e&&e.length>0?{sagaId:t.data.uuid,stage:Q.commit,success:!1,errors:e}:{sagaId:t.data.uuid,stage:Q.commit,success:!0},i=await this.createSyncMsgStone({data:a,localSpace:n,metaspace:r});return await this.evolveSyncSagaIbGib({prevSagaIbGib:t,msgStones:[i],localSpace:n,metaspace:r})}catch(a){throw console.error(`${s} ${E(a)}`),a}finally{x&&console.log(`${s} complete.`)}}async handleCommitFrame({sagaIbGib:t,mySpace:e,myTempSpace:r,metaspace:n}){let s=`${this.lc}[${this.handleCommitFrame.name}]`;try{if(x&&console.log(`${s} starting... (I: e179573bdd881202f8ba3168da1c3826)`),!t.data)throw new Error("(UNEXPECTED) sagaIbGib.data falsy? (E: cbc31dbb7d28b5b8c8cddb510d7d2826)");if(t.data.errors&&t.data.errors.length>0)throw new Error("not implemented...saga errored out on other end but we've already committed our changes. we need to implement undoing our changes, i.e., rollback commit, which basically is deleting all the payloads that we already put in in our previous commit. (E: e8eb789e0c08f0b3cf93607cb73e9f26)");{let a=await $r({sagaIbGib:t,space:e}),i=await Wo({history:a});return i.length>0?{frame:await this.createCommitFrame({sagaIbGib:t,metaspace:n,mySpace:e,errors:i})}:(await this.executeLocalCommit({commitFrame:t,sagaHistory:a,localSpace:e,localTempSpace:r,metaspace:n}),console.error(`${s} NAG ERROR (NOT THROWN): implement cleanup logic, including add a cleanup method to the peer (E: 3a9a24befb98a981a88fbdbf52920e26)`),x&&console.log(`${s} Peer committed. Finalizing saga locally. Saga Complete.`),{sagaComplete:!0})}}catch(a){let i=`${s} ${E(a)}`;return console.error(i),{frame:await this.createCommitFrame({sagaIbGib:t,errors:[i],metaspace:n,mySpace:e})}}finally{x&&console.log(`${s} complete.`)}}async createSyncMsgStone({data:t,rel8ns:e,localSpace:r,metaspace:n}){let s=`${this.lc}[${this.createSyncMsgStone.name}]`;try{x&&console.log(`${s} starting... (I: 5f7f98e8ff980364f7191fcee4531e26)`);let a=await ha({data:t}),i=await F.stone({ib:a,parentPrimitiveIb:wn,data:t,rel8ns:e,uuid:!0});return x&&console.log(`${s} Created stone: ${w({ibGib:i})}`),await n.put({ibGib:i,space:r}),await n.registerNewIbGib({ibGib:i}),i}catch(a){throw console.error(`${s} ${E(a)}`),a}finally{x&&console.log(`${s} complete.`)}}async getPayloadsForRequestedInfos({deltaRequestAddrInfos:t,mySpace:e}){let r=`${this.lc}[${this.getPayloadsForRequestedInfos.name}]`;try{x&&console.log(`${r} starting... (I: 4fe13d0d80050f20a8b74ba80cee5826)`);let n={};for(let{addr:a,latestAddrAlreadyHave:i}of t){let c;if(i?c=await mr({ibGibAddr:a,latestCommonFrameAddr:i,space:e,live:!0}):c=await Et({ibGibAddr:a,space:e,live:!0}),Object.keys(c).length===0)throw new Error(`(UNEXPECTED) couldn't get requested addrs in mySpace (${e.ib})? How did the receiver know to ask for these addrs if they weren't in our original graph? (E: 281eaebcdf77dd73e8245b2872100826)`);Object.values(c).forEach(d=>{n[w({ibGib:d})]=d})}return Object.values(n)}catch(n){throw console.error(`${r} ${E(n)}`),n}finally{x&&console.log(`${r} complete.`)}}async evolveSyncSagaIbGib({prevSagaIbGib:t,conflictStrategy:e,msgStones:r,localSpace:n,metaspace:s,sessionIdentity:a}){let i=`${this.lc}[${this.evolveSyncSagaIbGib.name}]`;try{if(!r||r.length===0)throw new Error(`${i} msgStones required (E: d13f8afcfb8816aeb26baae7df3ef726)`);let c=r[0].data;if(!c?.sagaId||!c?.stage)throw new Error(`${i} Invalid stone data (missing sagaId or stage) (E: c004f85ce8f8958b11839f8d68c38826)`);let l=c.sagaId,d=c.stage;for(let b of r){let h=b.data;if(h.sagaId!==l)throw new Error(`${i} Mismatched sagaId in stones. Expected ${l}, got ${h.sagaId} (E: 29e02719e426ecbbf8ee66887a2be226)`);if(h.stage!==d)throw new Error(`${i} Mismatched stage in stones. Expected ${d}, got ${h.stage} (E: d12c6571b0882f762921b60880c3f826)`)}if(t){let b=[{rel8nName:me,ibGibs:r}];if(!t.rel8ns)throw new Error("(UNEXPECTED) prevSagaIbGib.rel8ns falsy? (E: 81375841aff85b1e48ea42ca218e6826)");if(!t.rel8ns[me]||t.rel8ns[me].length===0)throw new Error("(UNEXPECTED) prevSagaIbGib.rel8ns[SYNC_MSG_REL8N_NAME] falsy/empty? (E: 15156baad26fcccda80aa3a31718c726)");let h=[{rel8nName:me,ibGibAddrs:t.rel8ns[me]}];return await ca({timeline:t,rel8nInfos:b,rel8nRemovalInfos:h,metaspace:s,space:n,noDna:!0})}else{let b={uuid:l,n:0,isTjp:!0,conflictStrategy:e};if(a){let m=Ie({ibGib:a});if(!m)throw new Error("(UNEXPECTED) sessionIdentity is truthy but sessionIdentityTjpAddr falsy? (E: f52004c10288987a6886f4e8fdf90826)");b.sessionIdentityTjpAddr=m}let h=await Xs({data:b}),p=r.map(m=>w({ibGib:m})),u={[me]:p},g=await fa({space:n,metaspace:s,ib:h,data:b,rel8ns:u,parentIb:Bo,noDna:!0});if(g.intermediateIbGibs)throw new Error("(UNEXPECTED) resNew.intermediateIbGibs? we were assuming we were creating a single frame. (E: 456818147235d991ccb4d10d0bbe4826)");return g.newIbGib}}catch(c){throw console.error(`${i} ${E(c)}`),c}}async getStageAndPayloadFromFrame({sagaFrame:t,space:e}){let r=`${this.lc}[${this.getStageAndPayloadFromFrame.name}]`;try{if(x&&console.log(`${r} starting... (I: fddc287bd4d55253dc50e519fd352226)`),!t.rel8ns)throw new Error("(UNEXPECTED) sagaFrame.rel8ns falsy? (E: 725bc8eb5dfe5c7058907ad8e3063826)");let n=t.rel8ns?.[me];if(n&&n.length>0){let s=n[0],a=await B({addr:s,space:e});if(a.ibGibs&&a.ibGibs.length>0){let i=a.ibGibs[0];if(!i.data)throw new Error("(UNEXPECTED) message stone.data falsy? (E: 4d4abcea90d87ba1328434e83d0d0826)");if(!i.data.stage)throw new Error("(UNEXPECTED) message stone.data.stage falsy? (E: 72c8d22310996644ecdd2b5fdb288c26)");return{stage:i.data.stage,messageData:i.data}}else throw new Error(`couldn't get stoneAddr (${s}) from space (${e.ib}) (E: f3c826e756f8a5c358beb88aa4a65e26)`)}else throw new Error(`(UNEXPECTED) no stone addrs rel8d to sync saga ibgib frame? sagaFrame addr: ${w(t)} (E: 43eae8579e289d016741b5526052f226)`)}catch(n){throw console.error(`${r} ${E(n)}`),n}finally{x&&console.log(`${r} complete.`)}}sortTimelinesTopologically(t){let e=`${this.lc}[${this.sortTimelinesTopologically.name}]`,r=Object.keys(t);if(r.length===0)return[];let n={};r.forEach(d=>{t[d].forEach(b=>{let h=w({ibGib:b});n[h]=d})});let s={};r.forEach(d=>s[d]=new Set),r.forEach(d=>{t[d].forEach(b=>{b.rel8ns&&Object.values(b.rel8ns).flat().forEach(h=>{if(!h)return;let p=n[h];p&&p!==d&&s[d].add(p)})})});let a=new Set,i=new Set,c=[],l=f(d=>{if(i.has(d)){console.warn(`${e} Cycle detected involving ${d}. Ignoring edge to break cycle. (W: 7e7352347102431aa5318db962459929)`);return}a.has(d)||(i.add(d),s[d].forEach(b=>l(b)),a.add(d),i.delete(d),c.push(d))},"visit");return r.forEach(d=>{a.has(d)||l(d)}),c}};var Ea={$schema:"../../../../libs/core-gib/src/keystone/keystone-policy.schema.json",behaviorProfiles:{standard:{size:200,replenish:"top-up",selectSequentially:2,selectRandomly:2,targetBindingChars:5},"high-security":{size:2e3,replenish:"replace-all",selectSequentially:5,selectRandomly:5,targetBindingChars:16},"session-connect":{size:20,replenish:"top-up",selectSequentially:2,selectRandomly:2,targetBindingChars:3}},pools:{sync:{id:"sync",allowedVerbs:["sync"],behaviorProfile:"standard",algo:"SHA-256",rounds:1},manage:{id:"manage",allowedVerbs:["manage"],behaviorProfile:"high-security",algo:"SHA-512",rounds:10},revoke:{id:"revoke",allowedVerbs:["revoke"],behaviorProfile:"high-security",algo:"SHA-512",rounds:10},connect:{id:"connect",allowedVerbs:["connect"],behaviorProfile:"session-connect",algo:"SHA-256",rounds:1}}};var rf=Ea.behaviorProfiles,of=Ea.pools;function ma(o,t){let e=of[o];if(!e)throw new Error(`Pool template not found in space-gib JSON config: ${o}`);return Ic({template:e,behaviorProfiles:rf,salt:t})}f(ma,"getSpaceGibPoolConfig");var ee={COMMON:qt.COMMON,DEFAULT_POOL:{ID:"default",SIZE:20,SELECT_SEQUENTIALLY:2,SELECT_RANDOMLY:2,TARGET_BINDING_CHARS:3},CONNECT_POOL:qt.CONNECT_POOL},A0={MIN_DEFAULT_POOL_SIZE:50,ALLOWED_ALGORITHMS:[Oe.sha_256,Oe.sha_512]},el=Vr;var wa=Ur,xt=class{static{f(this,"SpaceGibApiBridge")}lc="[SpaceGibApiBridge]";async postGenesisKeystone(t){let e=`${this.lc}[${this.postGenesisKeystone.name}]`;try{wa&&console.log(`${e} starting... (I: eecd082fc4a4381c8857928e8b090826)`);let r=await fetch("/api/keystone/genesis",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({keystoneIbGib:t})}),n=await r.json();if(!r.ok){let s=n.message||n.error||"Unknown error";return console.error(`${e} [NAG][ibgib-paradigm] server rejected genesis keystone: ${s}`),{success:!1,message:s,addr:n.addr}}return wa&&console.log(`${e} genesis keystone posted successfully.`),{success:!0,addr:n.addr}}catch(r){let n=E(r);return console.error(`${e} error: ${n}`),{success:!1,message:n}}finally{wa&&console.log(`${e} complete.`)}}async putEvolveKeystone(t,e,r=[]){let n=`${this.lc}[${this.putEvolveKeystone.name}]`;try{console.log(`${n} posting evolved keystone...`);let s=`/api/keystone/evolve/${encodeURIComponent(t)}`,a=await fetch(s,{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify({keystoneIbGib:e,relatedIbGibs:r})}),i=await a.json();if(!a.ok){let c=i.message||i.error||"Unknown error";return console.error(`${n} server rejected keystone evolution: ${c}`),{success:!1,message:c}}return console.log(`${n} keystone evolution accepted by server.`),{success:!0}}catch(s){let a=E(s);return console.error(`${n} fetch error: ${a}`),{success:!1,message:a}}}async getKeystoneGraph(t){let e=`${this.lc}[${this.getKeystoneGraph.name}]`;try{console.log(`${e} fetching keystone graph...`);let r=`/api/keystone/${encodeURIComponent(t)}?getLatest=true&getGraph=true`,n=await fetch(r,{method:"GET",headers:{Accept:"application/json"}}),s=await n.json();if(console.log(`${e} fetch keystone graph complete.`),!n.ok){let a=s.message||s.error||"Unknown error";return console.error(`${e} server rejected keystone graph get: ${a}`),{success:!1,message:a}}return{success:!0,graph:s.domainGraph}}catch(r){let n=E(r);return console.error(`${e} fetch error: ${n}`),{success:!1,message:n}}}async getIbGib(t,e,r=!1){let n=`${this.lc}[${this.getIbGib.name}]`;try{console.log(`${n} fetching single ibGib frame...`);let s=`/api/ibgib/${encodeURIComponent(t)}/${encodeURIComponent(e)}?getLatest=${r}&getGraph=false`,a=await fetch(s,{method:"GET",headers:{Accept:"application/json"}}),i=await a.json();if(console.log(`${n} fetching single ibGib frame complete.`),!a.ok){let c=i.message||i.error||"Unknown error";return console.error(`${n} server rejected ibGib get: ${c}`),{success:!1,message:c}}return{success:!0,ibGib:i}}catch(s){let a=E(s);return console.error(`${n} fetch error: ${a}`),{success:!1,message:a}}}async getIbGibGraph(t,e,r=!1){let n=`${this.lc}[${this.getIbGibGraph.name}]`;try{console.log(`${n} fetching ibGib graph...`);let s=`/api/ibgib/${encodeURIComponent(t)}/${encodeURIComponent(e)}?getLatest=${r}&getGraph=true`,a=await fetch(s,{method:"GET",headers:{Accept:"application/json"}}),i=await a.json();if(console.log(`${n} fetching ibGib graph complete.`),!a.ok){let c=i.message||i.error||"Unknown error";return console.error(`${n} server rejected ibGib graph get: ${c}`),{success:!1,message:c}}return{success:!0,graph:i.graph,addr:i.addr}}catch(s){let a=E(s);return console.error(`${n} fetch error: ${a}`),{success:!1,message:a}}}},N0=new xt;var Ke="[dev-tools]",X={};window.ibgibDebugState=X;function G(o){let t=document.getElementById("dev-panel-log");if(!t)return;let e=new Date().toISOString().slice(11,23);t.textContent=`[${e}] ${o}
|
|
30
|
+
`+t.textContent}f(G,"devLog");var Nt=null;function nf(){let o=`${Ke}[initWsTestButton]`,t=document.getElementById("btn-test-ws");if(!t){console.warn(`${o} btn-test-ws not found \u2014 skipping`);return}t.addEventListener("click",()=>{try{if(Nt&&Nt.readyState===WebSocket.OPEN){Nt.send(JSON.stringify({ping:"hello from client",ts:Date.now()})),G("\u2192 sent ping on existing connection");return}let r=`${location.protocol==="https:"?"wss:":"ws:"}//${location.host}/api/debug/ws-echo`;G(`\u2192 connecting to ${r}`),Nt=new WebSocket(r),Nt.addEventListener("open",()=>{G("\u2713 WebSocket connected"),t.textContent="Send WS Ping"}),Nt.addEventListener("message",n=>{G(`\u2190 ${n.data}`)}),Nt.addEventListener("close",n=>{G(`\u2717 WebSocket closed (code ${n.code})`),t.textContent="Test WebSocket",Nt=null}),Nt.addEventListener("error",n=>{G("\u2717 WebSocket error \u2014 check console"),console.error(`${o} WebSocket error`,n)})}catch(e){G(`\u2717 ${E(e)}`),console.error(`${o} ${E(e)}`)}})}f(nf,"initWsTestButton");function sf(){let o=document.getElementById("btn-print-dev-state");o&&o.addEventListener("click",()=>{G("Printing debug state to console..."),console.dir(X)})}f(sf,"initPrintStateButton");function af(){let o=`${Ke}[initCreateDomainKeystoneButton]`,t=document.getElementById("btn-create-domain-keystone");t&&t.addEventListener("click",async()=>{try{t.disabled=!0,G("Generating dummy Domain Keystone (I)...");let e=await He(),r=await e.getLocalUserSpace({});if(!r)throw new Error("No default space found in metaspace.");let n="password",a=await new ve().genesis({masterSecret:n,configs:[$c({id:"default",salt:await j(),replenishStrategy:be.topUp})],metaspace:e,space:r,frameDetails:{client:"space-gib-web-dev",timestamp:Ge()}}),i=w({ibGib:a});G(`\u2713 Local genesis complete: ${i}`),X.domainI=a,X.domainIMasterSecret=n,G("Posting genesis keystone to server...");let l=await new xt().postGenesisKeystone(a);if(!l.success){G(`\u2717 Server rejected genesis keystone: ${l.message}`),t.disabled=!1;return}G("\u2713 Server accepted Domain Keystone (I)"),t.textContent="\u2713 Domain Keystone Created";let d=document.getElementById("btn-create-test-ibgib");d&&(d.disabled=!1)}catch(e){G(`\u2717 ${E(e)}`),console.error(`${o} ${E(e)}`),t.disabled=!1}})}f(af,"initCreateDomainKeystoneButton");function cf(){let o=`${Ke}[initCreateTestIbGibButton]`,t=document.getElementById("btn-create-test-ibgib");if(!t){console.warn(`${o} btn-create-test-ibgib not found \u2014 skipping`);return}t.addEventListener("click",async()=>{try{G("Generating dummy X^Xtjp ibgib...");let r=(await F.firstGen({parentIbGib:z,ib:"test data",data:{hello:"world",random:Math.random()},dna:!0,nCounter:!0,tjp:{uuid:!0,timestamp:!0}})).newIbGib,n=w({ibGib:r});X.targetX=r,G(`\u2713 Created X: ${n}`),t.textContent="\u2713 Test IbGib (X) Created";let s=document.getElementById("btn-create-session-keystone");s&&(s.disabled=!1)}catch(e){G(`\u2717 ${E(e)}`),console.error(`${o} ${E(e)}`)}})}f(cf,"initCreateTestIbGibButton");function lf(){let o=`${Ke}[initCreateSessionKeystoneButton]`,t=document.getElementById("btn-create-session-keystone");if(!t){console.warn(`${o} btn-create-session-keystone not found \u2014 skipping`);return}t.addEventListener("click",async()=>{try{G("Generating Session Keystone (S^Stjp)...");let e=X.domainI,r=X.targetX;if(!e){G("\u26A0 No domain keystone (I) found in state. Please Create Domain Keystone first.");return}if(!r){G("\u26A0 No target ibgib (X) found in state. Please Create Test IbGib first.");return}let n=await He(),s=await n.getLocalUserSpace({});if(!s)throw new Error("No default space found in metaspace.");let a="ephemeral-"+Math.random().toString(),i=new ve;console.warn(`${Ke}[NAG] placeholder genesis keystone config right now (W: 69b108687cf8bec0f9a8e148bcca8d26)`);let c=await i.genesis({masterSecret:a,configs:[{id:ee.DEFAULT_POOL.ID,salt:await j(),type:ee.COMMON.TYPE,algo:ee.COMMON.ALGO,rounds:ee.COMMON.ROUNDS,behavior:{size:ee.DEFAULT_POOL.SIZE,replenish:ee.COMMON.REPLENISH,selectSequentially:ee.DEFAULT_POOL.SELECT_SEQUENTIALLY,selectRandomly:ee.DEFAULT_POOL.SELECT_RANDOMLY,targetBindingChars:ee.DEFAULT_POOL.TARGET_BINDING_CHARS},allowedVerbs:[]},{id:ee.CONNECT_POOL.ID,salt:await j(),type:ee.COMMON.TYPE,algo:ee.COMMON.ALGO,rounds:ee.COMMON.ROUNDS,behavior:{size:ee.CONNECT_POOL.SIZE,replenish:ee.COMMON.REPLENISH,selectSequentially:ee.CONNECT_POOL.SELECT_SEQUENTIALLY,selectRandomly:ee.CONNECT_POOL.SELECT_RANDOMLY,targetBindingChars:ee.CONNECT_POOL.TARGET_BINDING_CHARS},allowedVerbs:[ee.CONNECT_POOL.VERB]}],metaspace:n,space:s,frameDetails:{client:"space-gib-web-session",target_I:e?w({ibGib:e}):void 0,target_X:r?w({ibGib:r}):void 0}}),l=w({ibGib:c});X.sessionS=c,X.sessionSecret=a,G(`\u2713 Created Session Keystone: ${l}`),t.textContent="\u2713 Session Keystone Created";let d=document.getElementById("btn-evolve-domain-keystone");d&&(d.disabled=!1)}catch(e){G(`\u2717 ${E(e)}`),console.error(`${o} ${E(e)}`)}})}f(lf,"initCreateSessionKeystoneButton");function df(){let o=`${Ke}[initEvolveDomainKeystoneButton]`,t=document.getElementById("btn-evolve-domain-keystone");if(!t){console.warn(`${o} btn-evolve-domain-keystone not found \u2014 skipping`);return}t.addEventListener("click",async()=>{try{t.disabled=!0,G("Evolving Domain Keystone (I^I1) with sync claim...");let e=X.domainI,r=X.domainIMasterSecret,n=X.sessionS;if(!e||!r){G("\u26A0 No domain keystone (I) found. Please Create Domain Keystone first.");return}if(!n){G("\u26A0 No session keystone (S) found. Please Create Session Keystone first.");return}let s=await He(),a=await s.getLocalUserSpace({});if(!a)throw new Error("No default space found in metaspace.");let i=new ve,c=w({ibGib:n});G("Solving challenges to authorize sync...");let l=await i.sign({latestKeystone:e,masterSecret:r,claim:{target:c,verb:"sync"},metaspace:s,space:a}),d=w({ibGib:l});G(`\u2713 Local evolution complete: ${d}`),X.domainI=l,G("Posting evolution to server...");let b=new xt,h=w({ibGib:e}),p=await b.putEvolveKeystone(h,l,[n]);if(!p.success){G(`\u2717 Server rejected evolution: ${p.message}`),t.disabled=!1;return}G("\u2713 Server accepted Domain Keystone evolution!"),t.textContent="\u2713 Domain Keystone Evolved";let u=document.getElementById("btn-perform-sync");u&&(u.disabled=!1)}catch(e){G(`\u2717 ${E(e)}`),console.error(`${o} ${E(e)}`),t.disabled=!1}})}f(df,"initEvolveDomainKeystoneButton");function ff(){let o=`${Ke}[initPerformSyncButton]`,t=document.getElementById("btn-perform-sync");t&&t.addEventListener("click",async()=>{try{debugger;t.disabled=!0,G("Initiating Sync Connect via WebSocket...");let e=X.sessionS,r=X.sessionSecret,n=X.domainI;if(!e||!r||!n){G("\u26A0 Incomplete state. Please complete steps 1-4."),t.disabled=!1;return}let s=await He(),a=await s.getLocalUserSpace({});if(!a)throw new Error("No space.");G("Pre-solving upfront picket-fence challenge...");let i=(e.data?.challengePools??[]).find($=>$.id===ee.CONNECT_POOL.ID);if(!i)throw new Error(`Session keystone missing "${ee.CONNECT_POOL.ID}" pool`);let{challengeId:c}=el(e),l=Ze.create({config:i.config}),d=await l.derivePoolSecret({masterSecret:r}),b=await l.generateSolution({poolSecret:d,poolId:ee.CONNECT_POOL.ID,challengeId:c}),h=w({ibGib:e}),p=w({ibGib:n}),g=`${location.protocol==="https:"?"wss:":"ws:"}//${location.host}/api/sync/ws/${encodeURIComponent(p)}?sAddr=${encodeURIComponent(h)}&solution=${b.value}`;G(`\u2192 connecting to ${g}`);let m=new WebSocket(g);m.addEventListener("open",()=>{G("\u2713 WebSocket connected. Waiting for server challenge...")}),m.addEventListener("message",async $=>{try{let T=JSON.parse($.data);if(G(`\u2190 received: ${T.type??"message"}`),T.type==="auth-challenge-init")G("\u2192 sending auth-init with sAddr..."),m.send(JSON.stringify({type:"auth-init",sAddr:w({ibGib:e})}));else if(T.type==="auth-challenge"){let{challengeUuid:I,demandedIds:y}=T;G(`\u2192 server demanded ${y.length} ids. Signing connect proof...`);let _=await new ve().sign({latestKeystone:e,masterSecret:r,poolId:ot,requiredChallengeIds:y,claim:{verb:gt,target:I},metaspace:s,space:a});G("\u2192 sending auth-proof..."),m.send(JSON.stringify({type:"auth-proof",proofFrame:_}))}else T.type==="auth-ok"?(G("\u2713 Connect SUCCESS! Sync session authorized."),t.textContent="\u2713 Sync Authorized"):T.type==="auth-fail"&&(G(`\u2717 Connect FAILED: ${T.message}`),t.disabled=!1)}catch(T){G(`\u2717 Message handler error: ${E(T)}`),console.error(`${o} Message handler error:`,T),t.disabled=!1}}),m.addEventListener("close",$=>{G(`\u2717 WebSocket closed (code ${$.code})`),t.disabled=!1}),m.addEventListener("error",()=>{G("\u2717 WebSocket error \u2014 check server"),t.disabled=!1})}catch(e){G(`\u2717 ${E(e)}`),console.error(`${o} ${E(e)}`),t.disabled=!1}})}f(ff,"initPerformSyncButton");async function ya(o){let t=`${Ke}[performPhaseSetup(${o.phaseText})]`,e=document.getElementById(o.btnId);if(e)try{e.disabled=!0,G(`${o.phaseText} Setup: Generating Alice's long-lived Domain Keystone (I) and Target (X)...`);let r=await He(),n=await r.getLocalUserSpace({});if(!n)throw new Error("No default space found in metaspace.");let a=await new ve().genesis({masterSecret:o.masterSecret,configs:[ma("sync",o.syncSalt),ma("manage",o.manageSalt)],metaspace:r,space:n,frameDetails:{client:"space-gib-web-dev",timestamp:Ge()}});X.domainI=a,X.domainIMasterSecret=o.masterSecret,G(`${o.phaseText} Setup: \u2713 Domain Keystone (I) created locally: ${w({ibGib:a})}`),G(`${o.phaseText} Setup: Starting postGenesisKeystone...`);let c=await new xt().postGenesisKeystone(a);if(c.success)G(`${o.phaseText} Setup: \u2713 Domain Keystone registered and stored on receiver (server).`);else throw G(`${o.phaseText} Setup: X postGenesisKeystone failed: ${c.message}.`),new Error(`${o.phaseText} Setup: Server rejected genesis domain keystone: ${c.message}`);let l=await F.firstGen({parentIbGib:z,ib:o.ib,data:o.data,dna:!0,nCounter:!0,tjp:{uuid:!0,timestamp:!0}}),d=l.newIbGib;await r.persistTransformResult({resTransform:l,space:n}),await r.registerNewIbGib({ibGib:d}),X.targetX=d,G(`${o.phaseText} Setup: \u2713 Target (X) created and persisted locally: ${w({ibGib:d})}`),G(`\u2713 ${o.phaseText} Setup Complete! Ready for ${o.phaseText} Sync.`),e.textContent=`\u2713 ${o.phaseText} Setup Complete`;let b=document.getElementById(o.nextBtnId);b&&(b.disabled=!1)}catch(r){G(`\u2717 ${o.phaseText} Setup FAILED: ${E(r)}`),console.error(`${t} ${o.phaseText} Setup error:`,r),e.disabled=!1}}f(ya,"performPhaseSetup");async function $a(o){let t=`${Ke}[performPhaseSync(${o.phaseText})]`,e=document.getElementById(o.btnId);if(e)try{e.disabled=!0,G(`${o.phaseText} Sync: Executing senderCoordinator.sync(...) using WebSocket Peer...`);let r=X.domainI,n=X.targetX;if(!r||!n){G(`\u26A0 ${o.phaseText} Sync: Missing setup state. Please run Setup first.`),e.disabled=!1;return}let s=w({ibGib:r}),a=await He(),i=await a.getLocalUserSpace({});if(!i)throw new Error("No default space.");let c=location.protocol==="https:"?"wss:":"ws:",l=new En({classname:"SyncPeerWebSocketSender_V1",httpEvolveUrl:`${location.protocol}//${location.host}/api/keystone/evolve/${encodeURIComponent(s)}`,wsUrl:`${c}//${location.host}/api/sync/ws/${encodeURIComponent(s)}`}),d=new _n,b=await j();X.sagaId=b,X.senderPeer=l,await l.initializeOpts({localMetaspace:a,localSpace:i,senderIdentity:r,fnSenderSecret:f(async()=>X.domainIMasterSecret,"fnSenderSecret"),sagaId:b,sessionConnectPoolConfig:ee.CONNECT_POOL,sessionSyncPoolConfig:ee.DEFAULT_POOL,targetAddrs:[s]});try{await(await d.sync({domainIbGibs:[n],senderIdentity:r,fnSenderSecret:f(async()=>X.domainIMasterSecret,"fnSenderSecret"),peer:l,localSpace:i,metaspace:a,conflictStrategy:nt.optimisticWithLCS})).done}catch(p){if(o.expectSyncFailure)G(`${o.phaseText} Sync: Coordinator sync executed (${o.failureMessageSuffix??"errors expected"}): ${E(p)}`);else throw p}G(`\u2713 ${o.phaseText} Sync Execution Complete! Ready for State Checks.`),e.textContent=`\u2713 ${o.phaseText} Sync Run`;let h=document.getElementById(o.nextBtnId);h&&(h.disabled=!1)}catch(r){G(`\u2717 ${o.phaseText} Sync FAILED: ${E(r)}`),console.error(`${t} ${o.phaseText} Sync error:`,r),e.disabled=!1}}f($a,"performPhaseSync");function bf(){let o=document.getElementById("btn-1b-setup");o&&o.addEventListener("click",()=>{ya({phaseText:"1B",btnId:"btn-1b-setup",nextBtnId:"btn-1b-sync",masterSecret:"test-sender-secret-phase1",syncSalt:"senderidentitysyncsaltphase1",manageSalt:"senderidentitymanagesaltphase1",ib:"test data",data:{hello:"world",random:Math.random()}})})}f(bf,"init1bSetupButton");function hf(){let o=document.getElementById("btn-1b-sync");o&&o.addEventListener("click",()=>{$a({phaseText:"1B",btnId:"btn-1b-sync",nextBtnId:"btn-1b-check",expectSyncFailure:!0,failureMessageSuffix:"establish phase successfully run; connection/sync errors expected in 1B"})})}f(hf,"init1bSyncButton");function pf(){let o=`${Ke}[init1bCheckButton]`,t=document.getElementById("btn-1b-check");t&&t.addEventListener("click",async()=>{try{G("1B Check: Asserting cryptographic and durable state expectations from respec...");debugger;let e=await He(),r=await e.getLocalUserSpace({});if(!r)throw new Error("No default space.");let n=X.domainI,s=X.targetX,a=w({ibGib:s}),i=await e.getLatestAddr({addr:w({ibGib:n}),space:r});if(!i){G("\u2717 Check: Evolved domain keystone tip I1 NOT found in local space!");return}G("\u2713 Check: Evolved Domain Keystone (I1) created and stored locally.");let l=(await e.get({addrs:[i],space:r})).ibGibs?.[0];if(!l){G("\u2717 Check: Failed to load I1 from local space.");return}let d=l.data?.proofs?.find(N=>N.claim?.verb==="sync");G(d?"\u2713 Check: I1 contains valid sync-verb claim proof.":"\u2717 Check: I1 is missing sync-verb claim proof!");let b=d?.claim?.target;if(!b){G("\u2717 Check: I1 sync claim does not target a session keystone.");return}G(`\u2713 Check: Sync claim targets session keystone: ${b}`);let p=(await e.get({addrs:[b],space:r})).ibGibs?.[0];if(!p){G("\u2717 Check: Session Keystone (S) NOT found in local space.");return}G("\u2713 Check: Session Keystone (S) successfully created locally.");let u=p.data?.challengePools??[],g=u.some(N=>N.id===ot),m=u.some(N=>N.id===Er);G(g&&m?"\u2713 Check: S contains both connect and sync challenge pools.":`\u2717 Check: S is missing challenge pools! (connect: ${g}, sync: ${m})`),G("Check: Verifying registrations on server (receiver metaspace)...");let $=new xt,T=!1,I=!1,y=!1,A=w({ibGib:n}),_=await $.getKeystoneGraph(A);if(_.success&&_.graph){let N=_.graph;T=N[A]!==void 0,I=N[i]!==void 0}else G(`\u2717 Check Server: Failed to fetch keystone graph from server: ${_.message}`);let S=await $.getIbGib(A,b);if(S.success&&S.ibGib?y=!0:G(`\u2717 Check Server: Failed to fetch session keystone from server: ${S.message}`),G(T?"\u2713 Check Server: Genesis Domain Keystone (I) registered on server.":"\u2717 Check Server: Genesis Domain Keystone (I) missing on server!"),G(I?"\u2713 Check Server: Evolved Domain Keystone (I1) accepted and stored on server.":"\u2717 Check Server: Evolved Domain Keystone (I1) missing on server!"),G(y?"\u2713 Check Server: Session Keystone (S) accepted and stored on server.":"\u2717 Check Server: Session Keystone (S) missing on server!"),T&&I&&y){G("\u{1F389} ALL PHASE 1B ESTABLISH CHECKS PASSED FLAWLESSLY! \u2713"),t.textContent="\u2713 1B All Passed";let N=document.getElementById("btn-2b-setup");N&&(N.disabled=!1)}}catch(e){G(`\u2717 1B Check FAILED: ${E(e)}`),console.error(`${o} 1B Check error:`,e)}})}f(pf,"init1bCheckButton");function uf(){let o=document.getElementById("btn-2b-setup");o&&o.addEventListener("click",()=>{ya({phaseText:"2B",btnId:"btn-2b-setup",nextBtnId:"btn-2b-sync",masterSecret:"test-sender-secret-phase2",syncSalt:"senderidentitysyncsaltphase2",manageSalt:"senderidentitymanagesaltphase2",ib:"test data",data:{hello:"world2",random:Math.random()}})})}f(uf,"init2bSetupButton");function gf(){let o=document.getElementById("btn-2b-sync");o&&o.addEventListener("click",()=>{$a({phaseText:"2B",btnId:"btn-2b-sync",nextBtnId:"btn-2b-check",expectSyncFailure:!0,failureMessageSuffix:"connect phase successfully run; subsequent sync errors expected in 2B"})})}f(gf,"init2bSyncButton");function Ef(){let o=`${Ke}[init2bCheckButton]`,t=document.getElementById("btn-2b-check");t&&t.addEventListener("click",async()=>{try{debugger;G("2B Check: Asserting cryptographic and WebSocket state expectations...");let e=await He(),r=await e.getLocalUserSpace({});if(!r)throw new Error("No default space.");let n=X.domainI,s=X.targetX,a=w({ibGib:s}),i=w({ibGib:n}),c=await e.getLatestAddr({addr:i,space:r});if(!c){G("\u2717 Check: Evolved domain keystone tip I1 NOT found in local space!");return}G("\u2713 Check: Evolved Domain Keystone (I1) created and stored locally.");let d=(await e.get({addrs:[c],space:r})).ibGibs?.[0];if(!d){G("\u2717 Check: Failed to load I1 from local space.");return}let h=d.data?.proofs?.find(A=>A.claim?.verb==="sync")?.claim?.target;if(!h){G("\u2717 Check: I1 sync claim does not target a session keystone.");return}G(`\u2713 Check: Sync claim targets session keystone: ${h}`);let p=await e.getLatestAddr({addr:h,space:r});if(!p){G("\u2717 Check: Latest Session Keystone (S) NOT found in local space.");return}G("\u2713 Check: Found latest session keystone (S) locally.");let g=(await e.get({addrs:[p],space:r})).ibGibs?.[0];if(!g){G("\u2717 Check: Failed to load latest Session Keystone (S).");return}let m=g.data?.challengePools??[],$=m.find(A=>A.id===ot),T=m.find(A=>A.id===Er);if($&&T)G("\u2713 Check: S contains both connect and sync challenge pools.");else{G(`\u2717 Check: S is missing challenge pools! (connect: ${!!$}, sync: ${!!T})`);return}let I=Object.keys($.challenges).length;if(I===0)G("\u2713 Check: S connect pool successfully depleted (0 challenges remaining).");else{G(`\u2717 Check: S connect pool not depleted! (${I} challenges remaining)`);return}if(X.senderPeer&&X.senderPeer.isSocketOpen)G("\u2713 Check: WebSocket connection is active and OPEN.");else{G("\u2717 Check: WebSocket connection is NOT open or peer is missing!");return}G("\u{1F389} ALL PHASE 2B CONNECT CHECKS PASSED FLAWLESSLY! \u2713"),t.textContent="\u2713 2B All Passed";let y=document.getElementById("btn-3b-setup");y&&(y.disabled=!1)}catch(e){G(`\u2717 2B Check FAILED: ${E(e)}`),console.error(`${o} 2B Check error:`,e)}})}f(Ef,"init2bCheckButton");function mf(){let o=document.getElementById("btn-3b-setup");o&&o.addEventListener("click",()=>{ya({phaseText:"3B",btnId:"btn-3b-setup",nextBtnId:"btn-3b-sync",masterSecret:"test-sender-secret-phase3",syncSalt:"senderidentitysyncsaltphase3",manageSalt:"senderidentitymanagesaltphase3",ib:"test data 3b",data:{hello:"world3",random:Math.random()}})})}f(mf,"init3bSetupButton");function wf(){let o=document.getElementById("btn-3b-sync");o&&o.addEventListener("click",()=>{$a({phaseText:"3B",btnId:"btn-3b-sync",nextBtnId:"btn-3b-check"})})}f(wf,"init3bSyncButton");function yf(){let o=`${Ke}[init3bCheckButton]`,t=document.getElementById("btn-3b-check");t&&t.addEventListener("click",async()=>{try{debugger;G("3B Check: Asserting cryptographic and WebSocket state expectations...");let e=await He(),r=await e.getLocalUserSpace({});if(!r)throw new Error("No default space.");let n=X.domainI,s=X.targetX,a=w({ibGib:s}),i=w({ibGib:n}),c=await e.getLatestAddr({addr:a,space:r});if(!c){G("\u2717 Check: Evolved target X NOT found in local space!");return}G(`\u2713 Check: Evolved target X found locally at: ${c}`);let l=await e.getDependencyGraph({ibGibAddr:c,space:r});if(!l||Object.keys(l).length===0){G("\u2717 Check: Failed to load target X dependency graph locally.");return}G(`\u2713 Check: Target X local graph loaded (${Object.keys(l).length} nodes).`);let d=new xt,b=await d.getIbGibGraph(i,a,!0);if(!b.success||!b.graph){G(`\u2717 Check: Failed to fetch target X graph from server: ${b.message}`);return}let h=b.graph;if(G(`\u2713 Check: Target X server graph loaded (${Object.keys(h).length} nodes).`),Do({graphA:l,graphB:h}))G("\u2713 Check: Target X dependency graphs are equivalent on client and server.");else{G("\u2717 Check: Target X dependency graphs mismatch between client and server!");return}let u=await e.getLatestAddr({addr:i,space:r});if(!u){G("\u2717 Check: Evolved domain keystone tip I1 NOT found in local space!");return}G("\u2713 Check: Evolved Domain Keystone (I1) exists locally.");let m=(await e.get({addrs:[u],space:r})).ibGibs?.[0];if(!m){G("\u2717 Check: Failed to load I1 from local space.");return}let T=m.data?.proofs?.find(R=>R.claim?.verb==="sync")?.claim?.target;if(!T){G("\u2717 Check: I1 sync claim does not target a session keystone.");return}let I=await d.getIbGib(i,u);if(!I.success||!I.ibGib){G("\u2717 Check: Evolved Domain Keystone (I1) NOT found on server!");return}G("\u2713 Check: Evolved Domain Keystone (I1) exists on server.");let y=await e.getLatestAddr({addr:T,space:r});if(!y){G("\u2717 Check: Latest Session Keystone (S) NOT found in local space.");return}G(`\u2713 Check: Found latest session keystone (S) locally: ${y}`);let _=(await e.get({addrs:[y],space:r})).ibGibs?.[0];if(!_){G("\u2717 Check: Failed to load latest Session Keystone (S) locally.");return}let S=_.data?.n;G(`\u2713 Check: S tip evolved to n = ${S}.`),S!==3&&S!==4&&G(`\u26A0 Check: Expected S to evolve to n = 3 or 4, got n = ${S}. Continuing anyway...`);let N=await d.getIbGib(i,y);if(!N.success||!N.ibGib){G("\u2717 Check: Latest Session Keystone (S) NOT found on server!");return}G("\u2713 Check: Latest Session Keystone (S) exists on server.");let O=await e.getDependencyGraph({ibGibAddr:y,space:r}),D=await d.getIbGibGraph(i,T,!0);if(!D.success||!D.graph){G(`\u2717 Check: Failed to fetch session S graph from server: ${D.message}`);return}let k=D.graph;if(Do({graphA:O,graphB:k}))G("\u2713 Check: Session Keystone (S) dependency graphs are equivalent on client and server.");else{G("\u2717 Check: Session Keystone (S) dependency graphs mismatch between client and server!");return}G("\u{1F389} ALL PHASE 3B TRANSACTION SYNC CHECKS PASSED FLAWLESSLY! \u2713"),t.textContent="\u2713 3B All Passed"}catch(e){G(`\u2717 3B Check FAILED: ${E(e)}`),console.error(`${o} 3B Check error:`,e)}})}f(yf,"init3bCheckButton");function J0(){let o=`${Ke}[initDevTools]`;try{sf(),af(),nf(),cf(),lf(),df(),ff(),bf(),hf(),pf(),uf(),gf(),Ef(),mf(),wf(),yf()}catch(t){console.error(`${o} ${E(t)}`)}}f(J0,"initDevTools");export{f as a,ce as b,Oe as c,L as d,Ge as e,ke as f,j as g,P as h,pe as i,E as j,An as k,Me as l,Qr as m,al as n,Na as o,lr as p,M as q,z as r,le as s,lt as t,Oa as u,w as v,H as w,Dt as x,te as y,xn as z,ie as A,J as B,ue as C,Fe as D,Ce as E,Z as F,fr as G,br as H,dr as I,F as J,Nb as K,vb as L,Ob as M,oo as N,dl as O,Ua as P,ka as Q,Wb as R,Vb as S,zb as T,fl as U,Jb as V,Ln as W,Mn as X,bl as Y,ah as Z,ao as _,Jt as $,Va as aa,ei as ba,io as ca,ul as da,gl as ea,Tp as fa,Ap as ga,Sp as ha,Gp as ia,Cp as ja,xp as ka,Il as la,_l as ma,si as na,zn as oa,Al as pa,Sl as qa,pr as ra,vr as sa,hi as ta,Pl as ua,gi as va,gu as wa,wu as xa,B as ya,xe as za,os as Aa,se as Ba,Rl as Ca,wo as Da,yo as Ea,_e as Fa,ns as Ga,mi as Ha,de as Ia,hr as Ja,Lr as Ka,$i as La,ht as Ma,mo as Na,kl as Oa,Ml as Pa,Gt as Qa,Ku as Ra,Fl as Sa,Bl as Ta,jl as Ua,je as Va,Xl as Wa,Hl as Xa,ql as Ya,et as Za,ig as _a,Li as $a,Or as ab,ut as bb,ze as cb,Pi as db,Ie as eb,Ne as fb,kt as gb,Eg as hb,Jl as ib,mg as jb,wg as kb,yg as lb,$g as mb,Ur as nb,hg as ob,Ql as pb,ed as qb,td as rb,Qt as sb,He as tb,rd as ub,Vi as vb,Wi as wb,od as xb,nd as yb,sd as zb,ad as Ab,id as Bb,cd as Cb,ld as Db,dd as Eb,ms as Fb,us as Gb,To as Hb,fd as Ib,bd as Jb,Ui as Kb,hd as Lb,Zi as Mb,pd as Nb,ud as Ob,NE as Pb,Je as Qb,be as Rb,Et as Sb,ve as Tb,nr as Ub,ef as Vb,ga as Wb,ca as Xb,la as Yb,Qd as Zb,Fd as _b,rr as $b,or as ac,Ys as bc,Mt as cc,hn as dc,N0 as ec,G as fc,J0 as gc};
|
|
31
|
+
//# sourceMappingURL=chunk-2KJC5XKE.mjs.map
|