@ibgib/space-gib 0.0.1 → 0.0.2

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.
Files changed (34) hide show
  1. package/dist/client/bootstrap.mjs +1 -1
  2. package/dist/client/bootstrap.mjs.map +1 -1
  3. package/dist/client/chunk-BL2SGXS4.mjs +18994 -0
  4. package/dist/client/chunk-RDTAT5G4.mjs +235 -0
  5. package/dist/client/chunk-RDTAT5G4.mjs.map +7 -0
  6. package/dist/client/chunk-RE7XSMHH.mjs +31 -0
  7. package/dist/client/chunk-RE7XSMHH.mjs.map +7 -0
  8. package/dist/client/chunk-YUSGN3J4.mjs +23119 -0
  9. package/dist/client/index.html +44 -8
  10. package/dist/client/index.mjs +1 -1
  11. package/dist/client/script.mjs +1 -1
  12. package/dist/client/style.css +26 -0
  13. package/dist/server/server.mjs +5323 -1011
  14. package/dist/server/server.mjs.map +4 -4
  15. package/package.json +1 -1
  16. package/src/client/AUTO-GENERATED-version.mts +1 -1
  17. package/src/client/api/space-gib-api-bridge.mts +84 -8
  18. package/src/client/dev-tools.mts +609 -24
  19. package/src/client/index.html +44 -8
  20. package/src/client/style.css +26 -0
  21. package/src/common/keystone-policies.json +64 -0
  22. package/src/common/keystone-policies.mts +39 -86
  23. package/src/server/serve-gib/handlers/api/debug/ws-echo.handler.mts +13 -12
  24. package/src/server/serve-gib/handlers/api/keystone/keystone-evolve.handler.mts +14 -167
  25. package/src/server/serve-gib/handlers/api/keystone/keystone-genesis.handler.mts +6 -6
  26. package/src/server/serve-gib/handlers/api/keystone/keystone-post.handler.mts +10 -25
  27. package/src/server/serve-gib/handlers/ws/sync-upgrade-handler-base.mts +201 -0
  28. package/src/server/serve-gib/handlers/ws/sync-upgrade.handler.mts +13 -487
  29. package/src/server/serve-gib/handlers/ws/ws-helper.mts +80 -3
  30. package/dist/client/chunk-CT47Z5WU.mjs +0 -21
  31. package/dist/client/chunk-CT47Z5WU.mjs.map +0 -7
  32. package/dist/client/chunk-RHEDTRKF.mjs +0 -235
  33. package/dist/client/chunk-RHEDTRKF.mjs.map +0 -7
  34. package/dist/respec-gib.node.mjs +0 -5
@@ -0,0 +1,31 @@
1
+ var Jc=Object.defineProperty;var f=(r,t)=>Jc(r,"name",{value:t,configurable:!0});var ie=/^[a-zA-Z0-9_\-.]{1,256}$/,xt=/^[a-zA-Z0-9_]{1,255}$/,ma=/^(\[.+\])?\s?(\(UNEXPECTED\)|\(unexpected\))?(.+)(\([EIWeiw]: [a-fA-F\d]{32}\))(\(UNEXPECTED\)|\(unexpected\))?$/,wa=/^(\[.+\]).+$/,$a=/^[0-9a-fA-F]{32}$/,ya=/^[0-9a-fA-F]{64}$/;var or="/",Ia="_nonalphanumerics_";var nr=!1,_a=globalThis.crypto,{subtle:Qc}=_a,Se={sha_256:"SHA-256",sha_512:"SHA-512"};function v(r){return JSON.parse(JSON.stringify(r))}f(v,"clone");function $e(r){return(r??new Date).toUTCString()}f($e,"getTimestamp");async function Re({s:r,algorithm:t="SHA-256"}){if(!r)return"";try{let e=Object.values(Se);if(!e.includes(t))throw new Error(`Only ${e} implemented (E: 73cb52cd4d7f70c3415fdf695ba6ba23)`);let o=new TextEncoder().encode(r),n=await Qc.digest(t,o);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(Re,"hash");async function F(r=64){let t="";if(r<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=_a.getRandomValues(new Uint8Array(16));if(t=await Re({s:e.join("")}),!t)throw new Error("Did not create UUID...hmm...");return t}f(F,"getUUID");function P(r){return JSON.stringify(r,null,2)}f(P,"pretty");async function be(r){return new Promise(t=>{setTimeout(()=>{t()},r)})}f(be,"delay");function E(r){return!r&&r!==0?"[error is falsy]":typeof r=="string"?r:typeof r.message=="string"?r.message:typeof r=="number"?JSON.stringify(r):r.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(r.error)):`[error is not a string and error.message is not a string. typeof error: ${typeof r} (E: d5a7723ca59646838308bc9e53a43134)]`}f(E,"extractErrorMsg");function yn({items:r,keyFn:t}){let e=`[${yn.name}]`;try{let o={};for(let n=0;n<r.length;n++){let s=r[n],a=t(s);o[a]=[...o[a]??[],s]}return o}catch(o){throw console.error(`${e} ${o.message}`),o}}f(yn,"groupBy");function Qr({min:r,max:t,chars:e,noSpaces:o}){return r=r??1,t=t??999999999999,e=e??"",o?new RegExp(`^[\\w${e}]{${r},${t}}$`):new RegExp(`^[\\w\\s${e}]{${r},${t}}$`)}f(Qr,"getRegExp");function Ue(r){let t;if(r){if(t=new Date(r),t.toString()==="Invalid Date")throw new Error(`invalid date created by timestamp (${r}) (E: cbd6aeefe00708184e276ea3c2532b22)`)}else t=new Date;return t.getTime().toString()}f(Ue,"getTimestampInTicks");function In({startDate:r,years:t,months:e,days:o,hours:n,seconds:s}){let a=`[${In.name}]`;try{return qt({startDate:r,years:t,months:e,days:o,hours:n,seconds:s}).toUTCString()}catch(i){throw console.log(`${a} ${i.message}`),i}}f(In,"getExpirationUTCString");function qt({startDate:r,years:t,months:e,days:o,hours:n,seconds:s}){let a=`[${qt.name}]`;try{if(!r&&!t&&!e&&!o&&!n&&!s)throw new Error("either startDate or a time interval required. (E: 30248f8b306f443ab036fa8c313c50d8)");r=r?new Date(r):new Date;let i,c;return t?(i=r.getFullYear()+t,c=r.setFullYear(i),qt({startDate:new Date(c),months:e,days:o,hours:n,seconds:s})):e?(i=r.getMonth()+e,c=r.setMonth(i),qt({startDate:new Date(c),years:t,days:o,hours:n,seconds:s})):o?(i=r.getDate()+o,c=r.setDate(i),qt({startDate:new Date(c),years:t,months:e,hours:n,seconds:s})):n?(i=r.getHours()+n,c=r.setHours(i),qt({startDate:new Date(c),years:t,months:e,days:o,seconds:s})):s?(i=r.getSeconds()+s,c=r.setSeconds(i),qt({startDate:new Date(c),years:t,months:e,days:o,hours:n})):r}catch(i){throw console.log(`${a} ${i.message}`),i}}f(qt,"addTimeToDate");function _n({expirationTimestampUTC:r}){let t=`[${_n.name}]`;try{if(!r)throw new Error("expirationTimestampUTC required (E: 5eeb1e29f93d64f70c71a8112080a222)");let e=new Date(r);if(e.toUTCString()==="Invalid Date")throw new Error(`invalid expirationTimestampUTC: ${r} (E: 66a1a165bcf1f9336fe78856ab777822)`);return e<new Date}catch(e){throw console.error(`${t} ${e.message}`),e}}f(_n,"isExpired");function eo(r){return Array.from(new Set(r))}f(eo,"unique");function Tn({obj:r,value:t,path:e,pathDelimiter:o,logalot:n}){let s=`[${Tn.name}]`;try{if(n&&console.log(`${s} starting...`),!r)throw new Error("obj required (E: 6a9dd32a361476e80b1bf7b91ec50522)");if(typeof r!="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)");o=o||or;let a=r,i=e.split(o).filter(d=>!!d),c=i.pop();i.forEach(d=>{let l=a[d];if(l){if(typeof l!="object")throw new Error(`invalid path into object. Each step along the path must be typeof === 'object', but typeof targetObj["${d}"] === ${typeof l}. (value: ${l}) (E: 38cf29c5f624a40b4b56502c2ec39d22)`)}else a[d]={};a=a[d]}),a[c]=t}catch(a){throw console.error(`${s} ${a.message}`),a}finally{n&&console.log(`${s} complete.`)}}f(Tn,"patchObject");async function Tr({n:r}){let t=`[${Tr.name}]`;try{nr&&console.log(`${t} starting...`);let e=[];for(let o=0;o<r;o++){let n=await F();e.push(n.substring(0,16))}return e}catch(e){throw console.error(`${t} ${e.message}`),e}finally{nr&&console.log(`${t} complete.`)}}f(Tr,"getIdPool");function el({text:r,length:t,keepLiterals:e=["-"],replaceMap:o}){let n=`[${el.name}]`;try{if(nr&&console.log(`${n} starting... (I: 27437e312e5aa621adfebb84e059c822)`),!r)throw new Error("text required (E: 87e0493613c8b30dfade83e1d2862a22)");let s=r,a={};e=e??[];for(let c=0;c<e.length;c++){let d=e[c],l;do l=Ta({count:10});while(l.includes(d)||d.includes(l)||r.includes(l));if(s.includes(d))for(a[l]=d;s.includes(d);)s=s.replace(d,l)}if(o&&Object.keys(o).length>0)for(let c=0;c<Object.keys(o).length;c++){let d=Object.keys(o)[c],l=o[d];for(;s.includes(d);)s=s.replace(d,l)}s=s.replace(/\W/g,"");let i=Object.keys(a);for(let c=0;c<i.length;c++){let d=i[c];for(;s.includes(d);)s=s.replace(d,a[d])}return t&&t>0&&s.length>t&&(nr&&console.log(`${n} curtailing length (I: d7a28e05daa5979c7686b4c1cf519b23)`),s=s.substring(0,t)),s.length===0&&(s=Ia),s}catch(s){throw console.error(`${n} ${s.message}`),s}finally{nr&&console.log(`${n} complete.`)}}f(el,"getSaferSubstring");function tl({x:r}){if((r??[]).length===0)return;let t=Math.floor(Math.random()*r.length);return r[t]}f(tl,"pickRandom");function Ta({count:r}){let t=`${Ta.name}]`;try{if(!Number.isInteger(r))throw new Error("count required to be a number. (E: c0a21d884ebd9afc4b2e8025207e0522)");let e="";for(let o=0;o<r;o++)e+=tl({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!==r)throw new Error(`${t} (UNEXPECTED) result.length !== count ? (E: 9bec4ec8f78610d8055e565415392a22)`);return e}catch(e){throw console.error(`${t} ${e.message}`),e}finally{nr&&console.log(`${t} complete.`)}}f(Ta,"pickRandom_Letters");function sr({dominant:r,recessive:t}){let e=`[${sr.name}]`;try{if(Array.isArray(r)&&Array.isArray(t)){let o=v(r),n=!1;return t.forEach(s=>{if(typeof s=="string")o.includes(s)||o.push(s);else{n||(console.warn(`${e} merging arrays of non-string elements. (W: d8ab113064834abc8eb5fe6c4cf87ba3)`),n=!0);let a=JSON.stringify(s);o.some(i=>JSON.stringify(i)===a)||o.push(s)}}),o}else if(typeof r=="object"&&typeof t=="object"){let o={...t},n=Object.keys(r),s=Object.keys(t);return n.forEach(a=>{s.includes(a)?Array.isArray(r[a])&&Array.isArray(t[a])?o[a]=sr({dominant:r[a],recessive:t[a]}):r[a]&&!Array.isArray(r[a])&&typeof r[a]=="object"&&t[a]&&!Array.isArray(t[a])&&typeof t[a]=="object"?o[a]=sr({dominant:r[a],recessive:t[a]}):o[a]=r[a]:o[a]=r[a]}),o}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)`),r}catch(o){throw console.error(`${e} ${o.message}`),o}}f(sr,"mergeMapsOrArrays_Naive");function w({ib:r,gib:t,ibGib:e,delimiter:o="^"}){return r=r||e?.ib||"",t=t||e?.gib||"",r+o+t}f(w,"getIbGibAddr");function H({ibGib:r,ibGibAddr:t,delimiter:e="^"}){let o="[getIbAndGib]";if(!t)if(r)t=w({ibGib:r});else throw new Error(`${o} We need either an address or an ibGib object`);if(!t)throw new Error(`${o} 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(`${o} 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 rl=globalThis.crypto,{subtle:Aa}=rl;function Nt(r,t=""){t||(t="");let e=f(async a=>{if(!a)return"";let i=new TextEncoder().encode(a),c=await Aa.digest("SHA-256",i);return Array.from(new Uint8Array(c)).map(l=>l.toString(16).padStart(2,"0")).join("")},"hashToHex"),o=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 d=await Aa.digest("SHA-256",c);return Array.from(new Uint8Array(d)).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(d=>n(d));let i={},c=Object.keys(a).sort();for(let d of c){let l=a[d];l!==void 0&&(i[d]=n(l))}return i},"toNormalizedForHashing"),s;return t?s=f(async(a,i,c)=>{let d=Object.keys(c||{}).length>0&&Object.keys(c||{}).some(g=>c[g]&&c[g].length>0),l=!!i;l&&(typeof i=="string"?l=i.length>0:i instanceof Uint8Array?l=!0:typeof i=="object"?l=Object.keys(i||{}).length>0:l=!0);let b=(await e(t+a)).toUpperCase(),h=d?(await e(t+JSON.stringify(n(c)))).toUpperCase():"",p="";return l&&(i instanceof Uint8Array?p=(await o(t,i)).toUpperCase():p=(await e(t+JSON.stringify(n(i)))).toUpperCase()),d||l?(await e(t+b+h+p)).toUpperCase():(await e(t+b)).toUpperCase()},"hashFields"):s=f(async(a,i,c)=>{let d=Object.keys(c||{}).length>0&&Object.keys(c||{}).some(g=>c[g]&&c[g].length>0),l=!!i;l&&(typeof i=="string"?l=i.length>0:i instanceof Uint8Array?l=!0:typeof i=="object"?l=Object.keys(i||{}).length>0:l=!0);let b=(await e(a)).toUpperCase(),h=d?(await e(JSON.stringify(n(c)))).toUpperCase():"",p="";return l&&(i instanceof Uint8Array?p=(await o("",i)).toUpperCase():p=(await e(JSON.stringify(n(i)))).toUpperCase()),d||l?(await e(b+h+p)).toUpperCase():(await e(b)).toUpperCase()},"hashFields"),s(r.ib,r?.data,r?.rel8ns)}f(Nt,"sha256v1");var ee;(function(r){r.past="past",r.ancestor="ancestor",r.dna="dna",r.identity="identity",r.tjp="tjp",r.secret="secret",r.encryption="encryption"})(ee||(ee={}));var ar="ib",M="gib",Y={ib:ar,gib:M},ce="^",rt=".",Sa="ib^gib",Kt=["past","ancestor","dna","tjp"],ol=155,Ga=new RegExp(`^[\\w\\t\\-|=+.&%$#@!~\` \\[\\]\\(\\)\\{\\}]{1,${ol}}$`);async function Wt(r){let t=v(r),e=`[${Wt.name}]`;t.srcAddr&&delete t.srcAddr,delete t.src;let o={ib:t.type,data:t,rel8ns:{ancestor:[`${t.type.toString()}${ce}${M}`]}};return o.gib=await Nt(o),o}f(Wt,"buildDna");function An({ibGib:r}){let t=`[${An.name}]`;try{if(!r)throw new Error("ibGib required.");let e=["fork","mut8","rel8","plan"].map(n=>`${n}^${M}`);return r.rel8ns&&r.rel8ns.ancestor&&Array.isArray(r.rel8ns.ancestor)&&r.rel8ns.ancestor.some(n=>e.includes(n))||!1}catch(e){throw console.error(`${t} ${E(e)}`),e}}f(An,"isDna");function ae({ibGib:r,gib:t}){return r?ae({gib:r.gib}):t?t===M:!0}f(ae,"isPrimitive");async function V({ibGib:r,hasTjp:t,tjpAddr:e,gibDelimiter:o,isPrimitive:n,hashAlgorithm:s}){let a=`[${V.name}]`;try{if(!r)throw new Error("ibGib required. (E: 17d073226b9d42fd841e5a94b065ef21)");if(n)return M;let i=await Nt(r,""),c=r.rel8ns??{},d=r.data??{};if(o=o||rt,t||(t=(c.tjp??[]).length>0||d.isTjp||!1),t){let l;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(d.isTjp)e=w({ib:r.ib,gib:i});else throw new Error("hasTjp is true, but both ibGib.rel8ns.tjp and ibGib.data.isTjp are falsy. (E: 4e246897e52044789594d853bb5b66ee)");if(l=e?H({ibGibAddr:e}).gib:void 0,l)return d.isTjp?i:`${i}${rt}${l}`;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(V,"getGib");function he({ibGibAddr:r,gib:t,gibDelimiter:e}){let o=`[${he.name}]`;try{if(!r&&!t)throw new Error("Either ibGibAddr or gib required. (E: 25e3dcbe63cd44909032df12af9df75e)");if(t=t||H({ibGibAddr:r}).gib,t===M)return{isPrimitive:!0};if(e=e??rt,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(`${o} 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(`${o} ${E(n)}`),n}}f(he,"getGibInfo");async function to(r){let{noTimestamp:t,dna:e,linkedRel8ns:o,destIb:n,uuid:s,tjp:a,cloneRel8ns:i,cloneData:c,type:d="fork"}=r,l=r.src,b="[fork_v1]";if(d!=="fork")throw new Error(`${b} not a fork transform.`);if(r.type||(r.type="fork"),!l)throw new Error(`${b} src required to fork.`);if(!l.ib)throw new Error(`${b} src.ib required.`);if(n&&n.includes(ce))throw new Error(`${b} destIb can't contain (hardcoded) delimiter right now.`);if(!l.gib)throw new Error(`${b} src.gib required.`);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=w({ib:l.ib,gib:l.gib});r.srcAddr=p;let u=i&&l.rel8ns&&Object.keys(l.rel8ns).length>0?v(l.rel8ns):{};delete u.past;let g=c&&l?.data?v(l.data):{};r.nCounter&&(g.n=0);let m=o?.includes(ee.ancestor)?[p]:(u.ancestor||[]).concat([p]);u.ancestor=m,u.tjp&&delete u.tjp;let y=v(l);if(t&&a?.timestamp)throw new Error(`${b} both noTimestamp and tjp.timestamp selected.`);if(!t||a?.timestamp){let $=new Date;g.timestamp=$e($),g.timestampMs=$.getMilliseconds()}(a?.uuid||s)&&(g.uuid=await F()),a?.uuid||a?.timestamp?g.isTjp=!0:g.isTjp&&delete g.isTjp,y.ib=n||"ib",p!==Sa&&(y.rel8ns=u),Object.keys(g).length>0&&(y.data=g);let I=null;if(e){I=await Wt(r);let $=w({ibGib:I});u.dna=o?.includes(ee.dna)?u.dna=[$]:u.dna=(u.dna||[]).concat($)}y.gib=await Nt(y,"");let T={newIbGib:y};return I&&(T.dnas=[I]),T}f(to,"fork");async function ke(r){let{noTimestamp:t,dna:e,linkedRel8ns:o,dataToRename:n,dataToRemove:s,dataToAddOrPatch:a,mut8Ib:i,type:c="mut8"}=r,d=r.src,l="[mut8_v1]";if(c!=="mut8")throw new Error(`${l} not a mut8 transform.`);if(r.type||(r.type="mut8"),!d)throw new Error(`${l} src required to mut8.`);if(!d.ib)throw new Error(`${l} src.ib required.`);if(d.ib.includes(ce))throw new Error(`${l} ib can't contain hardcoded delimiter (${ce}) right now.`);if(!d.gib)throw new Error(`${l} src.gib required.`);if(!i&&!n&&!s&&!a)throw new Error(`${l} gotta provide either a mut8Ib or some data to change.`);let b=w({ib:d.ib,gib:d.gib});if(r.srcAddr&&b!==r.srcAddr)throw new Error(`${l} srcAddr from src does not equal opts.srcAddr`);if(r.srcAddr=b,ae({ibGib:d}))throw new Error(`${l} cannot mutate primitive ibgib`);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=v(d),u=d.rel8ns?d.rel8ns:{},g=v(u);g.past=o?.includes(ee.past)?[b]:(g.past||[]).concat([b]);let m=d?.data?v(d.data):{};if(n&&(m=Sn(m,n,"rename")),s&&(m=Sn(m,s,"remove")),a&&(m=Ca(m,a)),!t){let _=new Date;m.timestamp=$e(_),m.timestampMs=_.getMilliseconds()}if(r.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(`${l} 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 _=g.tjp??[];_.push(b),g.tjp=_,delete m.isTjp}let I=null;if(e){I=await Wt(r);let _=w({ibGib:I});g.dna=o?.includes(ee.dna)?g.dna=[_]:g.dna=(g.dna||[]).concat(_)}p.ib=i||p.ib,p.rel8ns=g,Object.keys(m).length>0?p.data=m:delete p.data;let T=(g.tjp?.length??0)>0;p.gib=await V({ibGib:p,hasTjp:T});let $={newIbGib:p};return I&&($.dnas=[I]),$}f(ke,"mut8");function Sn(r,t,e){let o="[renameOrRemove]",n=["timestamp"];return Object.keys(t).forEach(s=>{if(n.includes(s))throw new Error(`${o} Cannot rename to ${s}.`);if(Object.keys(r).includes(s)){let a=t[s];if(typeof a=="string"){if(n.includes(a))throw new Error(`${o} Cannot rename to ${a}.`);e==="rename"&&(r[a]=r[s]),delete r[s]}else r[s]=Sn(r[s],a,e)}else console.log(`${o} key to ${e} does not exist`)}),r}f(Sn,"renameOrRemove");function Ca(r,t){return Object.keys(t).forEach(e=>{let o=t[e],n=r[e];n?Array.isArray(o)||Array.isArray(n)?r[e]=o:typeof o=="object"&&typeof n=="object"?r[e]=Ca(n,o):r[e]=o:r[e]=o}),r}f(Ca,"patch");async function Ae(r){let{noTimestamp:t,dna:e,linkedRel8ns:o,rel8nsToAddByAddr:n,rel8nsToRemoveByAddr:s,type:a="rel8"}=r,i=r.src,c="[rel8_v1]";if(a!=="rel8")throw new Error(`${c} not a rel8 transform.`);if(r.type||(r.type="rel8"),a!=="rel8")throw new Error(`${c} not a rel8 transform.`);if(r.type||(r.type="rel8"),!i)throw new Error(`${c} src required.`);if(!i.ib)throw new Error(`${c} src.ib required.`);if(i.ib.includes(ce))throw new Error(`${c} ib can't contain hardcoded delimiter (${ce}) right now.`);if(!i.gib)throw new Error(`${c} src.gib required.`);if(ae({ibGib:i}))throw new Error(`${c} cannot relate/unrelate primitive ibgib`);let d=n&&Object.keys(n).length>0,l=s&&Object.keys(s).length>0;if(!(d||l))throw new Error(`${c} gotta provide relations to either add or remove.`);let b=w({ib:i.ib,gib:i.gib});if(r.srcAddr&&b!==r.srcAddr)throw new Error(`${c} srcAddr from src does not equal opts.srcAddr`);r.srcAddr=b;let h=f($=>$&&typeof $=="string"&&$.length>=2&&$.includes("^")&&$.split("^")[0].length>=1,"fnValidIbGibAddr");Object.keys(n||{}).map($=>(n||{})[$]).forEach($=>{if(!($&&$.every(_=>h(_))))throw new Error(`${c} Invalid rel8n attempt. Must be valid ibGibs. Did you include a delimiter (^)?`)}),Object.keys(s||{}).map($=>(s||{})[$]).forEach($=>{if(!($&&$.every(_=>h(_))))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=v(i),g=v(i.data||{});if(r.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 $=new Date;g.timestamp=$e($),g.timestampMs=$.getMilliseconds()}let m=v(i.rel8ns||{});if(Object.keys(n||{}).forEach($=>{if(Kt.includes($))throw new Error(`${c} Cannot manually add relationship: ${$}.`);let _=m[$]||[],G=n[$].filter(N=>!_.includes(N));m[$]=_.concat(G)}),Object.keys(s||{}).forEach($=>{if(Kt.includes($))throw new Error(`${c} Cannot manually remove relationship: ${$}.`);let _=m[$]||[],A=s[$]||[],G=_.filter(N=>!A.includes(N));G.length>0?m[$]=G:delete m[$]}),m.past=(m.past||[]).concat([b]),(o||[]).filter($=>Object.keys(m).includes($)).filter($=>(m[$]||[]).length>1).forEach($=>{let _=m[$].length;m[$]=[m[$][_-1]]}),g.isTjp){let $=m.tjp||[];$.push(b),m.tjp=$,delete g.isTjp}u.data=g,u.rel8ns=m;let y=(m.tjp?.length??0)>0,I=null;if(e){I=await Wt(r);let $=w({ibGib:I});m.dna=o?.includes(ee.dna)?m.dna=[$]:m.dna=(m.dna||[]).concat($)}u.gib=await V({ibGib:u,hasTjp:y});let T={newIbGib:u};return I&&(T.dnas=[I]),T}f(Ae,"rel8");function ro({ibGib:r}){let t=`[${ro.name}]`;if(!r)return console.warn(`${t} ibGib falsy. (W: 884178562f5b4f15933ac4d98db74cc6)`),!1;if(r.data?.isTjp||r.rel8ns?.tjp?.length>0)return!0;let e=["fork^gib","mut8^gib","rel8^gib"];return(r.rel8ns?.ancestor??[]).some(n=>e.includes(n))?!1:r.gib?r.gib.includes(rt)?!0:r.gib===M?!1:!!he({ibGibAddr:w({ibGib:r})}).tjpGib:(console.warn(`${t} ibGib.gib falsy. (W: 6400d780822b44d992846f1196509be3)`),!1)}f(ro,"hasTjp");function oo({ibGib:r}){let t=`[${oo.name}]`;r.ib||console.warn(`${t} ibGib.ib is falsy. (W: e60e41c2a1fc48268379d88ce13cb77b)`),r.gib||console.warn(`${t} ibGib.gib is falsy. (W: fb3889cbf0684ae4ac51e48f28570377)`);let e={ib:(r.ib||"").slice()};return r.gib&&(e.gib=r.gib.slice()),r.data&&(e.data=r.data instanceof Uint8Array?r.data:v(r.data)),r.rel8ns&&(e.rel8ns=v(r.rel8ns)),e}f(oo,"toDto");var Gn=!1;async function J({ibGib:r}){let t=`[${J.name}]`;try{let e=[];if(r){let o=w({ibGib:r});if(e=cr({addr:o})??[],e.length>0)return console.error(`${t} errors found in addr: ${o}`),e;if(ae({gib:r.gib}))return null;let n=await V({ibGib:oo({ibGib:r}),hasTjp:ro({ibGib:r})});return n!==r.gib&&(r.data?.src&&r.data.srcAddr&&r.ib==="rel8"?(delete r.data.src,delete r.data.srcAddr,n=await V({ibGib:oo({ibGib:r}),hasTjp:ro({ibGib:r})}),n!==r.gib&&e.push(`Ibgib invalid intrinsically - gottenGib (${n}) does not equal ibGib.gib (${r.gib}). (E: 020b71479e944b2198fe436e7e137786)`)):e.push(`Ibgib invalid intrinsically - gottenGib (${n}) does not equal ibGib.gib (${r.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(J,"validateIbGibIntrinsically");function cr({addr:r,delimiter:t,version:e}){let o=`[${cr.name}]`;try{let n=[];if(e&&console.warn(`${o} version not implemented yet. Ignoring. (W: 2d19db16ec0c4766b5d35248787671f3)`),!r)return n.push("addr required. (E: e9a54041aa0b41c1bb2324d9d2d42c7f)"),n;t=t||ce,r.includes(t)||n.push(`No delimiter (${t}) found. (E: 05e28dcb70ff44019edc53ed508bd1e8)`),r.startsWith(t)&&n.push("addr starts with delim. (E: d29f808c5a47452f9bb3ea684694c6eb)");let{ib:s,gib:a}=H({ibGibAddr:r,delimiter:t}),i=lr({ib:s,ibGibAddrDelimiter:t,version:e});i&&(n=n.concat(i));let c=ir({gib:a,ibGibAddrDelimiter:t,version:e});return c&&(n=n.concat(c)),n.length>0&&Gn&&console.log(`${o} errors.length > 0. errors: ${n.join("|")} (I: 9c18f993e138f15613e4c6a340d41722)`),n.length>0?n:null}catch(n){throw console.error(`${o} ${E(n)}`),n}}f(cr,"validateIbGibAddr");function lr({ib:r,ibGibAddrDelimiter:t,version:e}){let o=`[${lr.name}]`;try{let n=[];return e&&console.warn(`${o} version not implemented yet. Ignoring. (W: 71228ba4ed994aaa8149910e295ab087)`),r?r===ar?null:(t=t||ce,r.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(`${o} ${E(n)}`),n}}f(lr,"validateIb");function ir({gib:r,gibDelimiter:t,ibGibAddrDelimiter:e,version:o}){let n=`[${ir.name}]`;try{let s=[];if(o&&console.warn(`${n} version not implemented yet. Ignoring. (E: 90ced1db69774702b92acb261bdaee23)`),!r)return s.push("gib required. (E: e217de4035b04086827199f4bace189c)"),s;e=e||ce;let a=[e],i=[];a.forEach(p=>{r.includes(p)&&i.push(p)}),i.length>0&&s.push(`gib (${r}}) contains invalid characters: (${JSON.stringify(i.join(","))}) (E: 1e584258d9e049ba9ce7e516f3ab97f1)`);let{punctiliarHash:c,tjpGib:d,isPrimitive:l}=he({gib:r,gibDelimiter:t||rt});if(l)return null;if(!c)throw new Error(`${n} punctiliarHash is falsy on a non-primitive gib. (E: 72835394918241bdb2632bf0510bdae5)`);let b=c.match($a),h=c.match(ya);if(!b&&!h&&s.push("gib punctiliar hash is neither a 32- or 64-char hash string. (E: d47ff6d6e14b4c02a62107090c8dad39)"),d){let p=ir({gib:d});(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(ir,"validateGib");function Cn({rel8ns:r}){let t=`[${Cn.name}]`;try{Gn&&console.log(`${t} starting... (I: 62b4722599798dd8ab95fcebf42c0e23)`);let e=[],o=Object.keys(r);for(let n=0;n<o.length;n++){let s=Object.keys(r)[n];typeof s!="string"&&e.push("non-string rel8nName found. all keys of rel8ns must be of type string. (E: 3b2e4582b638421681951f5475c85178)");let a=r[s]??[];for(let i=0;i<a.length;i++){let c=a[i],d=cr({addr:c})??[];d.length>0&&e.push(`invalid addr found for rel8nName (${s}). addr errors: ${d.join("|")} (E: 56809a746c4f462db426e90395b80364)`)}}return e.length>0?e:null}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{Gn&&console.log(`${t} complete.`)}}f(Cn,"validateRel8nsIntrinsically");var xa=!1,k=class r{static{f(this,"Factory_V1")}static root(){return r.primitive({ib:ar})}static primitive({ib:t}){return{ib:t,gib:M}}static primitives({ibs:t}){return t.map(e=>r.primitive({ib:e}))}static async firstGen({ib:t=ar,parentIbGib:e=r.root(),data:o,rel8ns:n,dna:s,tjp:a,linkedRel8ns:i,noTimestamp:c,nCounter:d,squash:l}){let b=`[${r.name}][${r.firstGen.name}]`;try{if(xa&&console.log(`${b} starting... (I: b7152fbd94382516d9f7c591bcf4c326)`),s&&l)throw new Error("both dna and squash cannot be true. Squash requires that no dna exist. (E: abfc58b4a4c8654924aa5428d0831826)");let h=[],p=e||Y,u=await to({src:p,destIb:t,tjp:a,dna:s,linkedRel8ns:i,noTimestamp:c,nCounter:d});if(h.push(u),p=u.newIbGib,o){let g=await ke({src:p,dataToAddOrPatch:o,dna:s,linkedRel8ns:i,noTimestamp:c,nCounter:d});h.push(g),p=g.newIbGib}if(n){let g=await Ae({src:p,rel8nsToAddByAddr:n,dna:s,linkedRel8ns:i,noTimestamp:c,nCounter:d});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(y=>y.newIbGib)};if(s){l&&`${b}`;let y=[];return h.forEach(I=>{y=y.concat(I.dnas)}),m.dnas=y,m}else if(l){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),d&&(g.data??={},g.data.n=0),g.gib=await V({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{xa&&console.log(`${b} complete.`)}}static async stone({parentPrimitiveIb:t,ib:e,ibRegExpPattern:o,data:n,rel8ns:s,noTimestamp:a,uuid:i}){let c=`[${r.name}][${r.stone.name}]`;try{if(!t)throw new Error("parentPrimitiveIb required. (E: genuuid)");if(lr({ib:t})!==null)throw new Error(`Invalid parentPrimitiveIb: ${t}. (E: genuuid)`);if(!e)throw new Error("ib required. (E: genuuid)");let d=o?new RegExp(o):Ga;if(!e.match(d))throw new Error(`invalid ib. does not match regexp (${d}) (E: genuuid)`);let l=Object.keys(s??{}),b=[...Kt,"tjp"];if(l.some(g=>b.includes(g)))throw new Error(`Invalid rel8ns. forbiddenRel8nNames: ${b}. rel8ns keys: ${Object.keys(s??{})}. (E: genuuid)`);let u=(await r.firstGen({ib:e,parentIbGib:r.primitive({ib:t}),data:n,rel8ns:s,dna:!1,noTimestamp:a,nCounter:!1})).newIbGib;return i&&(u.data||(u.data={}),u.data.uuid=await F()),u.rel8ns?.past&&delete u.rel8ns.past,u.rel8ns?.tjp&&delete u.rel8ns.tjp,u.gib=await V({ibGib:{ib:u.ib,data:u.data,rel8ns:u.rel8ns},hasTjp:!1}),u}catch(d){throw console.error(`${c} ${d.message}`),d}}static async constant({parentPrimitiveIb:t,ib:e,ibRegExpPattern:o,data:n,rel8ns:s}){let a=`[${r.name}][${r.constant.name}]`;try{return await r.stone({parentPrimitiveIb:t,ib:e,ibRegExpPattern:o,data:n,rel8ns:s,noTimestamp:!0,uuid:!1})}catch(i){throw console.error(`${a} ${i.message}`),i}}};var db="[core^gib timer]";var xn=`.'",!?-`;var Na=new RegExp("^[\\w\\t\\-|=+.&%$#@!~` \\[\\]\\(\\)\\{\\}]{1,155}$");var fb=/^[a-zA-Z0-9_\-.]{1,255}$/,bb=/^[a-zA-Z0-9_\-.\s👀🤖:;&]{1,64}$/;var no={tags:"tags",aliases:"aliases",roots:"roots",outerspaces:"outerspaces",secrets:"secrets",encryptions:"encryptions",autosyncs:"autosyncs",robbots:"robbots",apps:"apps",history:"history"};var nl="robbot";var Oa="zero",Da="zerospace";var Cb=!1,xb="This is a local space. There are many like it, but this one is mine.";var Nb=/^[a-zA-Z][\w\-]{0,62}[a-zA-Z]$/,sl="syncSpace";var Ob=3e4;var so="space";var va="space_lock",La=100,Pa=100,Db=60*2,Nn=30;var On="root",Dn="x",Ra="root",vn="analytics-outline",Ln='This is a root ibgib, which is basically like a root folder that is primarily responsible for "containing" other ibgibs.';var Pn="tag",al="target";var Ua="pricetag-outline",ka="This is a tag used for organizing data.";var Bb="always",Ma="archive",Ba="trash";var Rn=/^\w{1,32}$/,ao="Invalid Date";var Un={ib:"true",gib:M};var Fa={ib:"false",gib:M};var ja="config_key";var Ar=/^[a-zA-Z0-9_\-.]{1,32}$/,io="app";var Yt=`bootstrap^${M}`,ot="defaultSpaceId",Ha="spaceIds";var nt={prependPerHash:"prependPerHash",appendPerHash:"appendPerHash",initialPrepend:"initialPrepend",initialAppend:"initialAppend"},Ot=Object.values(nt),Me={sha_256:"SHA-256",sha_512:"SHA-512"},Wb=Object.values(Me),il={indexOf:"indexOf",lastIndexOf:"lastIndexOf"},pt=Object.values(il);function Sr(r){let t=`[${Sr.name}]`;return new Promise((e,o)=>{try{let n=Xa(r),s=qa(n);e(s)}catch(n){console.error(`${t} ${E(n)}`),o(n)}})}f(Sr,"encodeStringToHexString");function Xa(r){let t=`[${Xa.name}]`;try{return new TextEncoder().encode(r)}catch(e){throw console.error(`${t} ${E(e)}`),e}}f(Xa,"stringToUTF8Bytes");function qa(r){let t=`[${qa.name}]`;try{return Array.from(r,e=>e.toString(16).padStart(2,"0")).join("")}catch(e){throw console.error(`${t} ${E(e)}`),e}}f(qa,"bytesToHexString");function ut(r){let t=`[${ut.name}]`;return new Promise((e,o)=>{try{let n=Ka(r),s=Wa(n);e(s)}catch(n){console.error(`${t} ${E(n)}`),o(n)}})}f(ut,"decodeHexStringToString");function Ka(r){let t=`[${Ka.name}]`;try{if(r.length%2!==0)throw new Error("invalid hex string. length %2 !== 0");let e=r.length/2,o=new Uint8Array(e);for(let n=0;n<e;n++)o[n]=parseInt(r.substr(n*2,2),16);return o}catch(e){throw console.error(`${t} ${E(e)}`),e}}f(Ka,"hexStringToBytes");function Wa(r){let t=`[${Wa.name}]`;try{return new TextDecoder().decode(r)}catch(e){throw console.error(`${t} ${E(e)}`),e}}f(Wa,"utf8BytesToString");var gt=nt.appendPerHash,Et="SHA-512",mt=1024,st=2e4,wt=1,Ya="indexOf",co="lastIndexOf",lo=5e6,fo=4,Dt=",";function cl({secret:r,prevHash:t,salt:e,saltStrategy:o}){if(!(t||r))throw new Error("Either secret or prevHash is required, but both are falsy (E: bee2849729ff410081d963777dcedb49))");switch(o){case nt.prependPerHash:return e+(t||r);case nt.appendPerHash:return(t||r)+e;case nt.initialPrepend:return t||e+r;case nt.initialAppend:return t||r+e;default:throw new Error(`Unknown saltStrategy: ${o} (E: 235136af1a6c40eb9c17b2ca41c08a01)`)}}f(cl,"getPreHash");async function qe({secret:r,prevHash:t,count:e,salt:o,saltStrategy:n,hashAlgorithm:s}){let a=`[${qe.name}]`;try{let i=t||void 0;for(let c=0;c<e;c++){let d=cl({secret:r,prevHash:i,salt:o,saltStrategy:n});i=await Re({s:d,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(qe,"execRound_getNextHash");async function $t({secret:r,initialRecursions:t,salt:e,saltStrategy:o,hashAlgorithm:n}){let s=`[${$t.name}]`;try{return await qe({secret:r,count:t,salt:e,saltStrategy:o,hashAlgorithm:n})}catch(a){throw console.error(`${s} ${E(a)}`),a}}f($t,"doInitialRecursions_keystretch");async function kn({hexEncodedData:r,initialRecursions:t,recursionsPerHash:e,salt:o,saltStrategy:n,secret:s,hashAlgorithm:a,encryptedDataDelimiter:i,indexingMode:c}){let d=`[${kn.name}]`;try{let l=await $t({secret:s,initialRecursions:t,salt:o,saltStrategy:n,hashAlgorithm:a}),b=c==="indexOf"?(u,g)=>u.indexOf(g):(u,g)=>u.lastIndexOf(g),h=[];for(let u=0;u<r.length;u++){let g=r[u],m="",y;for(;!m.includes(g);)y=await qe({count:e,prevHash:l,salt:o,saltStrategy:n,hashAlgorithm:a}),m+=y,l=y;let I=b(m,g);h.push(I)}return h.join(i)}catch(l){throw console.error(`${d} ${E(l)}`),l}}f(kn,"encryptFromHex_stream");async function Mn({encryptedData:r,initialRecursions:t,recursionsPerHash:e,salt:o,saltStrategy:n,secret:s,hashAlgorithm:a,encryptedDataDelimiter:i}){let c=`[${Mn.name}]`;try{let d=await $t({secret:s,initialRecursions:t,salt:o,saltStrategy:n,hashAlgorithm:a}),l=r.split(i).map(p=>parseInt(p)),b=[];for(let p=0;p<l.length;p++){let u=l[p],g="",m;for(;u>=g.length;)m=await qe({count:e,prevHash:d,salt:o,saltStrategy:n,hashAlgorithm:a}),g+=m,d=m;let y=g[u];b.push(y)}return b.join("")}catch(d){throw console.error(`${c} ${E(d)}`),d}}f(Mn,"decryptToHex_stream");async function Gr({encryptedData:r,initialRecursions:t,recursionsPerHash:e,salt:o,saltStrategy:n,secret:s,hashAlgorithm:a,encryptedDataDelimiter:i}){let c=`[${Gr.name}]`,d=[],l=[];t=t||st,e=e||wt,n=n||gt,a=a||Et,o=o||await F(mt),i=i||Dt;let b="[validation]";if(!t||t<1){let u=`${b} initialRecursions required, and greater than 0`;console.error(u),d.push(u)}if(!e||e<1){let u=`${b} recursionsPerHash required, and greater than 0`;console.error(u),d.push(u)}if(!r){let u=`${b} encryptedData required`;console.error(u),d.push(u)}if(!o){let u=`${b} salt required`;console.error(u),d.push(u)}if(!n){let u=`${b} saltStrategy required`;console.error(u),d.push(u)}if(!s){let u=`${b} secret required`;console.error(u),d.push(u)}if(!i){let u=`${b} encryptedDataDelimiter required`;console.error(u),d.push(u)}if(!Object.values(Me).includes(a)){let u=`${b} only ${Object.values(Me)} hash algorithms implemented`;console.error(u),d.push(u)}if(n&&!Ot.includes(n)){let u=`${b} unknown saltStrategy: ${n}`;console.error(u),d.push(u)}if(d.length>0)return{errors:d,initialRecursions:t,recursionsPerHash:e,salt:o,saltStrategy:n,hashAlgorithm:a,encryptedDataDelimiter:i};let h=await Mn({encryptedData:r,initialRecursions:t,recursionsPerHash:e,salt:o,saltStrategy:n,secret:s,hashAlgorithm:a,encryptedDataDelimiter:i});return{decryptedData:await ut(h),initialRecursions:t,recursionsPerHash:e,salt:o,saltStrategy:n,hashAlgorithm:a,encryptedDataDelimiter:i,warnings:l.length>0?l:void 0}}f(Gr,"decryptImpl_stream");async function Bn({dataToEncrypt:r,initialRecursions:t,recursionsPerHash:e,salt:o,saltStrategy:n,secret:s,hashAlgorithm:a,encryptedDataDelimiter:i,confirm:c,indexingMode:d}){let l=`[${Bn.name}]`,b=[],h=[];t||(console.warn(`${l} initial recursions required. defaulting to ${st}`),t=st),e=e||wt,n=n||gt,a=a||Et,o=o||await F(mt),i=i||Dt,d=d||Ya;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(!r){let m=`${p} dataToEncrypt required`;console.error(m),b.push(m)}if(!o){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(!pt.includes(d)){let m=`${p} invalid indexingMode (${d}). Must be one of ${pt} (E: 5955c46755434982982823c97adcf076)`;console.error(m),b.push(m)}if(!Object.values(Me).includes(a)){let m=`${p} only ${Object.values(Me)} hash algorithms implemented`;console.error(m),b.push(m)}if(n&&!Ot.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:o,saltStrategy:n,hashAlgorithm:a,encryptedDataDelimiter:i};let u=await Sr(r);if(c&&await ut(u)!==r)throw new Error("decoding encoded hex failed for this data: The encoded hex did not reverse to the original data.");let g=await kn({hexEncodedData:u,initialRecursions:t,recursionsPerHash:e,salt:o,saltStrategy:n,secret:s,hashAlgorithm:a,encryptedDataDelimiter:i,indexingMode:"indexOf"});if(c){let m=await Gr({encryptedData:g,initialRecursions:t,recursionsPerHash:e,salt:o,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:o,saltStrategy:n,hashAlgorithm:a,encryptedDataDelimiter:i};if(m.decryptedData){if(m.decryptedData!==r)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:o,saltStrategy:n,hashAlgorithm:a,encryptedDataDelimiter:i,warnings:h.length>0?h:void 0}}f(Bn,"encryptImpl_stream");async function Fn({hexEncodedData:r,initialRecursions:t,recursionsPerHash:e,salt:o,saltStrategy:n,secret:s,hashAlgorithm:a,encryptedDataDelimiter:i,indexingMode:c,maxBlockSize:d,numOfPasses:l}){let b=`[${Fn.name}]`;try{let h=await $t({secret:s,initialRecursions:t,salt:o,saltStrategy:n,hashAlgorithm:a}),p=c==="indexOf"?(_,A)=>_.indexOf(A):(_,A)=>_.lastIndexOf(A),u=[],g=r.length,m=d;m>g&&(m=g);let y=Math.ceil(g/m),I=g%m||m,T=0;for(let _=0;_<y;_++){_===y-1&&(m=I);let G=await Va({blockSize:m,indexHexEncodedDataAtStartOfPass:T,numOfPasses:l,hexEncodedData:r,recursionsPerHash:e,salt:o,saltStrategy:n,prevHash:h,hashAlgorithm:a}),N=G.alphabetsThisBlock;h=G.prevHash;let D=await za({alphabetsThisBlock:N,blockSize:m,indexHexEncodedDataAtStartOfPass:T,hexEncodedData:r,getIndexOfCharInAlphabet:p});u=u.concat(D),T+=m}return u.join(i)}catch(h){throw console.error(`${b} ${E(h)}`),h}}f(Fn,"encryptFromHex_blockMode");async function Va({blockSize:r,numOfPasses:t,indexHexEncodedDataAtStartOfPass:e,hexEncodedData:o,recursionsPerHash:n,salt:s,saltStrategy:a,prevHash:i,hashAlgorithm:c}){let d=`[${Va.name}]`;try{let l=[],b,h;for(let p=0;p<t;p++)for(let u=0;u<r;u++){b=e+u;let g=l[u]??"";h=await qe({count:n,prevHash:i,salt:s,saltStrategy:a,hashAlgorithm:c}),g+=h,i=h,l[u]=g}for(let p=0;p<r;p++){b=e+p;let u=o[b],g=l[p];for(;!g.includes(u);)h=await qe({count:n,prevHash:i,salt:s,saltStrategy:a,hashAlgorithm:c}),g+=h,i=h;l[p]=g}return{alphabetsThisBlock:l,prevHash:i}}catch(l){throw console.error(`${d} error: ${E(l)}`),l}}f(Va,"getAlphabetsThisBlock");async function za({alphabetsThisBlock:r,blockSize:t,indexHexEncodedDataAtStartOfPass:e,hexEncodedData:o,getIndexOfCharInAlphabet:n}){let s=`[${za.name}]`;try{let a=[];for(let i=0;i<t;i++){let c=e+i,d=r[i],l=n(d,o[c]);a.push(l)}return a}catch(a){throw console.error(`${s} ${E(a)}`),a}}f(za,"getEncryptedIndexesThisBlock");async function jn({encryptedData:r,initialRecursions:t,recursionsPerHash:e,salt:o,saltStrategy:n,secret:s,hashAlgorithm:a,encryptedDataDelimiter:i,maxBlockSize:c,numOfPasses:d}){let l=`[${jn.name}]`;try{let b=await $t({secret:s,initialRecursions:t,salt:o,saltStrategy:n,hashAlgorithm:a}),h=r.split(i).map($=>parseInt($)),p=[],u=h.length,g=c;g>u&&(g=u);let m=Math.ceil(u/g),y=u%g||g,I=0;for(let $=0;$<m;$++){$===m-1&&(g=y);let A=await Ja({blockSize:g,indexEncryptedDataIndexesAtStartOfPass:I,numOfPasses:d,encryptedDataIndexes:h,recursionsPerHash:e,salt:o,saltStrategy:n,prevHash:b,hashAlgorithm:a}),G=A.alphabetsThisBlock;b=A.prevHash;let N=await Za({alphabetsThisBlock:G,blockSize:g,indexEncryptedDataIndexesAtStartOfPass:I,encryptedDataIndexes:h});p=p.concat(N),I+=g}return p.join("")}catch(b){throw console.error(`${l} ${E(b)}`),b}}f(jn,"decryptToHex_blockMode");async function Ja({blockSize:r,numOfPasses:t,indexEncryptedDataIndexesAtStartOfPass:e,encryptedDataIndexes:o,recursionsPerHash:n,salt:s,saltStrategy:a,prevHash:i,hashAlgorithm:c}){let d=`[${Ja.name}]`;try{let l=[],b,h;for(let p=0;p<t;p++)for(let u=0;u<r;u++){b=e+u;let g=l[u]??"";h=await qe({count:n,prevHash:i,salt:s,saltStrategy:a,hashAlgorithm:c}),g+=h,i=h,l[u]=g}for(let p=0;p<r;p++){b=e+p;let u=o[b],g=l[p];for(;g.at(u)===void 0;)h=await qe({count:n,prevHash:i,salt:s,saltStrategy:a,hashAlgorithm:c}),g+=h,i=h;l[p]=g}return{alphabetsThisBlock:l,prevHash:i}}catch(l){throw console.error(`${d} error: ${E(l)}`),l}}f(Ja,"getAlphabetsThisBlock");async function Za({alphabetsThisBlock:r,blockSize:t,indexEncryptedDataIndexesAtStartOfPass:e,encryptedDataIndexes:o}){let n=`[${Za.name}]`;try{let s=[];for(let a=0;a<t;a++){let i=e+a,c=o[i],l=r[a][c];s.push(l)}return s}catch(s){throw console.error(`${n} ${E(s)}`),s}}f(Za,"getDecryptedDataArrayThisBlock");async function Cr(r){let t=`[${Cr.name}]`,{encryptedData:e,initialRecursions:o,recursionsPerHash:n,salt:s,saltStrategy:a,secret:i,hashAlgorithm:c,encryptedDataDelimiter:d,indexingMode:l,blockMode:b,multipass:h}=r,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)");o=o||st,n=n||wt,a=a||gt,c=c||Et,s=s||await F(mt),d=d||Dt,l=l||co;let{maxBlockSize:g,maxPassSectionLength:m,numOfPasses:y}=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||lo,y=y||fo;let I="[validation]";if(!o||o<1){let A=`${I} initialRecursions required, and greater than 0`;console.error(A),p.push(A)}if(!n||n<1){let A=`${I} recursionsPerHash required, and greater than 0`;console.error(A),p.push(A)}if(!e){let A=`${I} encryptedData required`;console.error(A),p.push(A)}if(!s){let A=`${I} salt required`;console.error(A),p.push(A)}if(!a){let A=`${I} saltStrategy required`;console.error(A),p.push(A)}if(!i){let A=`${I} secret required`;console.error(A),p.push(A)}if(!d){let A=`${I} encryptedDataDelimiter required`;console.error(A),p.push(A)}if(!l){let A=`${I} indexingMode required (E: a6fe15f8ba414e21b5355d23e808b976)`;console.error(A),p.push(A)}if(!pt.includes(l)){let A=`${I} invalid indexingMode (${l}). Must be one of ${pt} (E: 17435268651444e0b7a594135635fc58)`;console.error(A),p.push(A)}if(g<1){let A=`${I} maxBlockSize must be greater than 0 (E: 0870831aa86b4bfa939aeee9f252326a)`;console.error(A),p.push(A)}if(y<1){let A=`${I} numOfPasses must be greater than 0 (E: 691d3c3765584c6f8c9aba1ee378df00)`;console.error(A),p.push(A)}if(!Object.values(Me).includes(c)){let A=`${I} only ${Object.values(Me)} hash algorithms implemented`;console.error(A),p.push(A)}if(a&&!Ot.includes(a)){let A=`${I} unknown saltStrategy: ${a}`;console.error(A),p.push(A)}if(p.length>0){let A={...r,errors:p};return delete A.encryptedData,delete A.secret,A}let T=await jn({encryptedData:e,initialRecursions:o,recursionsPerHash:n,salt:s,saltStrategy:a,secret:i,hashAlgorithm:c,encryptedDataDelimiter:d,maxBlockSize:g,numOfPasses:y}),$=await ut(T),_={...r,decryptedData:$,warnings:u.length>0?u:void 0};return delete _.encryptedData,delete _.secret,_}f(Cr,"decryptImpl_blockMode");async function Hn(r){let t=`[${Hn.name}]`,{dataToEncrypt:e,initialRecursions:o,recursionsPerHash:n,salt:s,saltStrategy:a,secret:i,hashAlgorithm:c,encryptedDataDelimiter:d,confirm:l,indexingMode:b,blockMode:h,multipass:p}=r,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)");o||(console.warn(`${t} initial recursions required. defaulting to ${st}`),o=st),d=d||Dt,b=b||co;let{maxBlockSize:m,maxPassSectionLength:y,numOfPasses:I}=h;!m&&y&&(console.warn(`${t}[WARNING] "maxPassSectionLength" option is deprecated. this has been refactored to "maxBlockSize". This will use maxPassSectioLength as maxBlockSize. (W: c28fe476105643e184d0ddd5d2aa8a5d)`),m=y),m=m||lo,I=I||fo;let T="[validation]";if(!o||o<1){let G=`${T} initialRecursions required, and greater than 0 (E: dd96a75f0c504f34b1f9f2f32e011c50)`;console.error(G),u.push(G)}if(!n||n<1){let G=`${T} recursionsPerHash required, and greater than 0 (E: 64cf53e0bf9f4963be6b165ca4e6566d)`;console.error(G),u.push(G)}if(!s){let G=`${T} salt required (E: 136a5d237e0f4b1d89f8c87ac12a1507)`;console.error(G),u.push(G)}if(!a){let G=`${T} saltStrategy required (E: 457ed117bf224b9f86fe81ab6bc35381)`;console.error(G),u.push(G)}if(!i){let G=`${T} secret required (E: 5c363255055a45cfb07656e2f4854ed7)`;console.error(G),u.push(G)}if(!d){let G=`${T} encryptedDataDelimiter required (E: 1bbeb4dce19e4ac2bbe7d1e373739298)`;console.error(G),u.push(G)}if(!b){let G=`${T} indexingMode required (E: 693ebd2be64a438aa3b075d0cb0d92bf)`;console.error(G),u.push(G)}if(!pt.includes(b)){let G=`${T} invalid indexingMode (${b}). Must be one of ${pt} (E: 17435268651444e0b7a594135635fc58)`;console.error(G),u.push(G)}if(m<1){let G=`${T} maxBlockSize must be greater than 0 (E: 9f268207ae274b958fb91855331be259)`;console.error(G),u.push(G)}if(I<1){let G=`${T} numOfPasses must be greater than 0 (E: c3bcab79bb024d65b84947806290a7d4)`;console.error(G),u.push(G)}if(!Object.values(Me).includes(c)){let G=`${T} only ${Object.values(Me)} hash algorithms implemented`;console.error(G),u.push(G)}if(a&&!Ot.includes(a)){let G=`${T} unknown saltStrategy: ${a}`;console.error(G),u.push(G)}if(u.length>0){let G={...r,errors:u};return delete G.dataToEncrypt,delete G.secret,G}let $=await Sr(e);if(l&&await ut($)!==e)throw new Error("decoding encoded hex failed for this data: The encoded hex did not reverse to the original data.");let _=await Fn({hexEncodedData:$,initialRecursions:o,recursionsPerHash:n,salt:s,saltStrategy:a,secret:i,hashAlgorithm:c,encryptedDataDelimiter:d,indexingMode:b,maxBlockSize:m,numOfPasses:I});if(l)try{let G=await Cr({encryptedData:_,initialRecursions:o,recursionsPerHash:n,salt:s,saltStrategy:a,secret:i,hashAlgorithm:c,encryptedDataDelimiter:d,indexingMode:b,blockMode:h});if(G.decryptedData){if(G.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)");(G.warnings||[]).length>0&&(g=g.concat(["Confirm check call to decrypt had warnings.",...G.warnings]))}catch(G){throw new Error(`${t} confirm failed. decrypt error: ${E(G)} (E: 782a84d9dc294ce9a6a325e3ab293adf)`)}let A={...r,encryptedData:_,warnings:g.length>0?g:void 0};return delete A.dataToEncrypt,delete A.secret,A}f(Hn,"encryptImpl_blockMode");async function ll(r){let t=`[${ll.name}]`;try{if(!r)throw new Error("args required (E: 22e58e03c78f4c27bf18295b8d2cdd3a)");if(!r.dataToEncrypt)throw new Error("dataToEncrypt required (E: 168c9076e5434c83ba81e3485ee6f3e4)");r.salt=r.salt||await F(mt),r.saltStrategy=r.saltStrategy||gt,r.hashAlgorithm=r.hashAlgorithm||Et,r.recursionsPerHash=r.recursionsPerHash||wt;let e;return r.blockMode?e=await Hn(r):e=await Bn(r),(e.errors??[]).length>0&&e.errors.forEach(o=>console.warn(`${t} ${o}`)),(e.warnings??[]).length>0&&e.warnings.forEach(o=>console.warn(`${t} ${o}`)),e}catch(e){throw console.error(`${t}${e.message}`),e}}f(ll,"encrypt");async function dl(r){let t=`[${dl.name}]`;try{if(!r)throw new Error("args required (E: fcd9b4aad85c4deba5fe5fde0b9ecb30)");if(!r.encryptedData)throw new Error("encryptedData required (E: f879f612428b4283bae089acee929a58)");r.salt=r.salt||await F(mt),r.saltStrategy=r.saltStrategy||gt,r.hashAlgorithm=r.hashAlgorithm||Et,r.recursionsPerHash=r.recursionsPerHash||wt;let e;return r.blockMode||r.multipass?e=await Cr(r):e=await Gr(r),(e.warnings??[]).length>0&&e.warnings.forEach(o=>console.warn(`${t} ${o}`)),(e.errors??[]).length>0&&e.errors.forEach(o=>console.warn(`${t} ${o}`)),e}catch(e){throw console.error(`${t}${e.message}`),e}}f(dl,"decrypt");var np=5e4;var sp=nt.appendPerHash,ap=10,ip="SHA-256";var cp="encryption",lp="ciphertext";var fl={local:"local",outerspace:"outerspace",innerspace:"innerspace"},hp=Object.values(fl).concat(),bl={user:"user",sync:"sync"},Xn=Object.values(bl).concat(),hl={node_filesystem:"node-filesystem"},pl={aws_dynamodb:"aws-dynamodb"},ul={...hl,...pl},qn=Object.values(ul).concat(),gl={get:"get",put:"put",delete:"delete"},El={can:"can",addrs:"addrs",latest:"latest",watch:"watch",unwatch:"unwatch",tjps:"tjps",dependencyGraph:"dependency-graph"};var ml=!1,ho=class r{static{f(this,"DynamicFormBuilder")}lc=`[${r.name}]`;items=[];what="";idPool=[];getNewId(){let t=`${this.lc}[${this.getNewId.name}]`;if(this.idPool?.length>0)return this.idPool.pop()??"";{let e=[],o="ABCDEFGHIJKLMNOPQRSTUVWXYZ",n=o.length;for(let a=0;a<32;a++){let i=Math.floor(Math.random()*n);e.push(o[i])}let s=e.join("");return ml&&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:o}){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:Qr({min:1,max:32,noSpaces:!0}),regexpErrorMsg:"1 to 32 characters, no spaces, underscores allowed.",required:e,dataType:"text",value:t,defaultValue:o}),this}description({of:t,required:e,defaultValue:o}){return this.addItem({name:"description",description:`Description/notes for this ${this.what}.`,label:"Description",placeholder:`Describe these ${this.what} settings here...`,regexp:Qr({min:0,max:155,chars:xn}),regexpErrorMsg:`0 to 155 alphanumerics or any of ${xn}`,dataType:"textarea",required:e,value:t,defaultValue:o}),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:Qr({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:o}){return this.addItem({name:"uuid",description:`Unique(ish) id of the ${this.what}.`,label:e??"ID",dataType:"text",value:t,regexp:ie,regexpErrorMsg:"1 to 256 alphanumerics, underscores, dots, hyphens allowed.",readonly:!0,required:o}),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 vt=class r extends ho{static{f(this,"WitnessFormBuilder")}lc=`[${r.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:o=!0,persistOptsAndResultIbGibs:n=!0,trace:s=!0,version:a=!0}){return e&&this.allowPrimitiveArgs({of:t.allowPrimitiveArgs}),o&&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 po=!1;function Qa({appData:r}){let t=`[${Qa.name}]`;try{if(po&&console.log(`${t} starting...`),!r)throw new Error("appData required (E: 3df782b29bc4406a87e4895cfcea28ed)");let e=[],{name:o,uuid:n,classname:s}=r;return o?o.match(Ar)||e.push(`name must match regexp: ${Ar}`):e.push("name required."),n?n.match(ie)||e.push(`uuid must match regexp: ${ie}`):e.push("uuid required."),s&&(s.match(Ar)||e.push(`classname must match regexp: ${Ar}`)),e}catch(e){throw console.error(`${t} ${e.message}`),e}finally{po&&console.log(`${t} complete.`)}}f(Qa,"validateCommonAppData");function Kn({appData:r,classname:t}){let e=`[${Kn.name}]`;try{let o=Qa({appData:r});if(o.length>0)throw new Error(`invalid appData: ${o} (E: 9aff04f0cfc54a5188ca8bc40764160d)`);if(t){if(r.classname&&r.classname!==t)throw new Error("classname does not match appData.classname (E: 66f1447eef97485fba521c40980f5eb5)")}else if(t=r.classname,!t)throw new Error("classname required (E: 5f6ffb4317044125b94f662070e1f40b)");let{name:n,uuid:s}=r;return`app ${t} ${n} ${s}`}catch(o){throw console.error(`${e} ${o.message}`),o}}f(Kn,"getAppIb");function wl({appIb:r}){let t=`[${wl.name}]`;try{if(!r)throw new Error("appIb required (E: 6b065aee67e641ba9f9c6db367ebb0fb)");let e=r.split(" ");return{appClassname:e[1],appName:e[2],appId:e[3]}}catch(e){throw console.error(`${t} ${e.message}`),e}}f(wl,"getInfoFromAppIb");async function $l({fnPromptApp:r,ibgibs:t,space:e}){let o=`[${$l.name}]`;try{if(po&&console.log(`${o} starting...`),!t)throw new Error("ibgibs all powerful service required. (E: b24e78de0d204dc78909022bee296b30)");e=e??await t.getLocalUserSpace({lock:!0});let n=await r(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(l=>a.push(l)),n.dnas?.forEach(l=>a.push(l));for(let l=0;l<a.length;l++){let b=a[l],h=await J({ibGib:b});if((h??[]).length>0)throw new Error(`(UNEXPECTED) invalid app ibgib created. validationErrors: ${h}. app: ${P(s.toIbGibDto())} (E: 54cfc2f6bc284ed79be91d2da5e4bd2f)`)}await ne({resTransform:n,space:e});let{zeroSpace:i,fnBroadcast:c,fnUpdateBootstrap:d}=t;return await ge({ibGib:s,space:e,fnBroadcast:f(l=>c(l),"fnBroadcast")}),await dr({type:"apps",rel8nName:io,ibGibsToRel8:[s],space:e,zeroSpace:i,fnUpdateBootstrap:d,fnBroadcast:c}),s}catch(n){debugger;console.error(`${o} ${n.message}`);return}finally{po&&console.log(`${o} complete.`)}}f($l,"createNewApp");var yl="0",Il="chat_gib",_l="A chat app done ibgib style, enabling infinitely nesting comments, pics and links. It's ibgibs all the way down...",ei={version:"1",uuid:yl,name:Il,description:_l,classname:"ChatApp_V1",icon:"chatbubbles",persistOptsAndResultIbGibs:!1,allowPrimitiveArgs:!0,catchAllErrors:!0,trace:!1},ti=void 0;var Tl="0",Al="raw_gib",Sl="Explorer app for navigating raw ibgib data.",ri={version:"1",uuid:Tl,name:Al,description:Sl,classname:"RawApp_V1",icon:"paper-plane",persistOptsAndResultIbGibs:!1,allowPrimitiveArgs:!0,catchAllErrors:!0,trace:!1},oi=void 0;var Wn="0",Gl="todo_gib",Cl="Todo app for viewing and interacting with ibgibs like they're checklists.",ni={version:"1",uuid:Wn,name:Gl,description:Cl,classname:"TodoApp_V1",icon:"checkbox",persistOptsAndResultIbGibs:!1,allowPrimitiveArgs:!0,catchAllErrors:!0,trace:!1},si=void 0;async function Yn(r){let t=`[${Yn.name}]`,e=[];try{w({ibGib:r})!==Yt&&e.push(`invalid bootstrapSpace addr. Should equal "${Yt}" (E: ecfdbed719284db7a1aa3f867f706fe9)`);let n=await J({ibGib:r});(n?.length??!1)&&n.forEach(i=>e.push(i));let s=r.data,a=r.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(r.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[ot]?(a[s[ot]]??[]).length===0&&e.push(`invalid bootstrap. data.${ot} (${s[ot]}) not found in rel8ns. (E: 44d0799d232f4a51a0b0019ebebe019f)`):e.push(`invalid bootstrap. data.${ot} required. (E: f763af2e275f445cbf1db5801bacafad)`),e.length===0?!0:(console.error(`${t} errors: ${e.join("|")}`),!1)}catch(o){return console.error(`${t} ${o.message}`),!1}}f(Yn,"validateBootstrapIbGib");var fr="meta_stone";var Vn="undefined",xr="target",uo="targetTjp";var Ke=!1;function ii({ib:r}){let t=`[${ii.name}]`;try{Ke&&console.log(`${t} starting...`);let e=[],o=r.split(" ");o[0]!==fr&&e.push(`${t} invalid ib. atom is expected to be META_STONE_ATOM: ${fr} (E: a9812bffc18f44418aa091fb0ed260bd)`);let s=o[1],a=ir({gib:s})??[];a.length>0&&e.push(`invalid ib. pieces[1] should be a valid tjpGib. validation errors: ${a} (E: 233db2babfbe4d28a80f98261f1c0e01)`);let i=o[2],c=Number.parseInt(i);isNaN(c)&&e.push("invalid ib. space-delimited pieces[2] should be valid integer (E: 71df0d6abd7b4cf4b11621e6bfb556cd)");let d=o[3];if(d!=="undefined"){let l=Lt({timestamp:d});l.valid||e.push(`invalid ib. pieces[3] should be valid timestampInTicks. emsg: (${l.emsg}) (E: 06dae01d66f54f54b71d9c920c730840)`)}return e}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{Ke&&console.log(`${t} complete.`)}}f(ii,"validateCommonMetaStoneIb");function zn({data:r}){let t=`[${zn.name}]`;try{if(Ke&&console.log(`${t} starting...`),!r)throw new Error("data required (E: c50ac422af4501b72af12481fbd4961e)");let e=[],{targetData:o,timestamp:n}=r;Lt({timestamp:n}).valid||e.push("invalid timestampInTicks. should be valid ticks number. (E: 7e381ed5b0c8486b90cfd37676da3626)");let{tjpGib:a,n:i,timestamp:c}=o;if(a&&a!=="undefined"){let l=ir({gib:a})??[];l.length>0&&e.push(`invalid data (targetTjpGib). validation errors: ${l} (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 l=Lt({timestamp:c});l.valid||e.push(`invalid targetTimestamp. emsg: ${l.emsg} (E: c15d4fd2a2b74a0fab3223e83d954379)`)}let d=new Date(n);return e}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{Ke&&console.log(`${t} complete.`)}}f(zn,"validateCommonMetaStoneData");function ci({rel8ns:r}){let t=`[${ci.name}]`;try{if(Ke&&console.log(`${t} starting...`),!r)throw new Error("rel8ns required (E: 7737ae550e2347e68c67b715c1221393)");let e=[],o=Cn({rel8ns:r??{}})??[];o.length>0&&e.push(`invalid rel8ns intrinsically. errors: ${o.join("|")}. (E: abc91753f0f946afa0a3ea2c1917960f)`);let n=r[xr]??[];n.length===0?e.push(`invalid metastone rel8ns. should have exactly 1 rel8nName ${xr}. has 0. (E: 8181652da9e89613e204d245db12d723)`):n.length>1&&e.push(`invalid metastone rel8ns. should have exactly 1 rel8nName ${xr}. has ${n.length}. (E: 2318047c6fea482d9f53febe02cf8912)`);let s=r[uo]??[];return s.length>1&&e.push(`invalid metastone rel8ns. should have 0 or 1 rel8nName ${uo}. has ${s.length}. (E: 34a8ae53825f46caa7ad024a64400db2)`),e}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{Ke&&console.log(`${t} complete.`)}}f(ci,"validateCommonMetaStoneRel8ns");async function xl({ibGib:r}){let t=`[${xl.name}]`;try{Ke&&console.log(`${t} starting... (I: f32249d08105b997871a06cdee006311)`);let e=await J({ibGib:r})??[];if(!r.data)throw new Error("MetaStoneIbGib.data required (E: 96432cf4f919d339277d9a1c61ea4264)");let o=[];try{let{atom:i,tjpGib:c,n:d,timestampInTicks:l}=di({ib:r.ib})}catch(i){o.push(E(i))}let n=zn({data:r.data}),s=ci({rel8ns:r.rel8ns}),a=[...e??[],...o??[],...n??[],...s??[]];return a.length>0?a:void 0}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{Ke&&console.log(`${t} complete.`)}}f(xl,"validateCommonMetaStoneIbGib");function li({data:r,classname:t}){let e=`[${li.name}]`;try{let o=zn({data:r});if(o.length>0)throw new Error(`invalid MetaStone data: ${o} (E: ac642cc5915f0fc0508cb2fb728c86fa)`);t&&Ke&&console.log(`${e} classname not required. no big deal that it is provided here. (I: db4d41471cb976795afd3fa89f8cb823)`);let n=r.targetData.timestamp,s=n&&n!=="undefined"?Ue(n):Vn;return`${fr} ${r.targetData.tjpGib} ${r.targetData.n} ${s}`}catch(o){throw console.error(`${e} ${E(o)}`),o}}f(li,"getMetaStoneIb");function di({ib:r}){let t=`[${di.name}]`;try{if(!r)throw new Error("MetaStone ib required (E: 8e74e098d7aeef52d3952e35150d83ed)");let e=ii({ib:r});if(e.length>0)throw new Error(`invalid ib. validationErrors: ${e} (E: a6107f62200eb943e523f70f51300623)`);let o=r.split(" ");return{atom:o[0],tjpGib:o[1],n:Number.parseInt(o[2]),timestampInTicks:o[3]}}catch(e){throw console.error(`${t} ${E(e)}`),e}}f(di,"parseMetaStoneIb");function zp({addr:r,ibGib:t}){if(r||=w({ibGib:t}),!r)throw new Error("either addr or ibGib required. (E: 372b2574d5a9fac298119beed9f6e223)");return r.startsWith(`${fr} `)}f(zp,"isMetaStone");async function Jn({targetIbGib:r}){let t=`[${Jn.name}]`;try{Ke&&console.log(`${t} starting... (I: d846313065c89c89e4b5afa2df2b7123)`);let e=w({ibGib:r}),o=We({ibGib:r,defaultIfNone:"incomingAddr"}),n,s={[xr]:[e],[uo]:[o]};if(!r.gib)throw new Error("(UNEXPECTED) targetIbGib.gib falsy? (E: 28eaa8a799021dadd87b043711aee826)");let a=r.data?.isTjp?r.gib:he({ibGibAddr:e}).tjpGib??r.gib;if(a===M)throw new Error("cannot create metastone for primitive ibgib (E: 2887e8ef83381a0698256b7bc7531826)");let i=new Date,c=$e(i),d=i.getMilliseconds();r.data?Nr({ibGib:r})?n={targetData:{n:-1,tjpGib:a},timestamp:c,timestampMs:d}:(n={targetData:{n:r.data.n??-1,tjpGib:a,timestamp:r.data.timestamp??Vn},timestamp:c,timestampMs:d},r.data?.isTjp&&(n.targetData.isTjp=!0)):n={targetData:{n:-1,tjpGib:a},timestamp:c,timestampMs:d};let l=li({data:n}),b=await Ze({parentPrimitiveIb:fr,ib:l,data:n,rel8ns:s});return Ke&&(console.log(`${t} metaStoneIbGib... (I: 2b16197478488b329246d22d2dc41423)`),console.dir(b)),b}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{Ke&&console.log(`${t} complete.`)}}f(Jn,"newUpMetaStone");var go="witness",Or="witness_arg",Eo="witness_result",Qp="context";var C=!1;async function X({addr:r,addrs:t,isDna:e,space:o,force:n}){let s=`[${X.name}]`;try{if(C&&console.log(`${s} starting...`),!o)throw new Error("space required. (E: 4d188d6c863246f28aa575753a052304)");if(!r&&(t??[]).length===0)throw new Error("addr or addrs required. (E: 1a0b92564ba942f1ba91a089ac1a2125)");r&&(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(r)||t.push(r)),t=(t??[]).length>0?t:[r];let a=await o.argy({ibMetadata:yt({space:o}),argData:{cmd:"get",ibGibAddrs:t,isDna:e}}),i=await o.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(X,"getFromSpace");async function Be({ibGib:r,ibGibs:t,isDna:e,force:o,space:n}){let s=`[${Be.name}]`;try{if(!r&&(t??[]).length===0)throw new Error("ibGib or ibGibs required. (E: e59c4de3695f4dd28c8fe82dbb9c4e90)");if(!n)throw new Error("space required. (E: dd0b7189c67c43c586b905a8ed6f51c9)");r&&(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===r.gib)||(t=t.concat([r]))),t=t??[r],C&&console.log(`${s} ibGibs.length: ${t.length}`);let a=await n.argy({ibMetadata:yt({space:n}),argData:{cmd:"put",force:o,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(Be,"putInSpace");async function es({addr:r,isDna:t,space:e}){let o=`[${es.name}]`;try{if(!e)throw new Error("space required. (E: 40ab3b51e91c4b5eb4f215baeefbcef0)");if(!e.data)throw new Error("space.data required. (E: 0d02c8e85ee143b8bd6a1a1db0d9af1b)");o=`${o}[${e.data.name||"noname?"}][${e.data.uuid||"nouuid?"}]`;let n=await e.argy({ibMetadata:yt({space:e}),argData:{cmd:"delete",ibGibAddrs:[r],isDna:t}}),s=await e.witness(n);if(s.data?.success)return{success:!0};{s.data?.warnings?.length>0&&console.warn(`${o} warnings with delete (${r}): ${s.data.warnings.join("|")}`),s.data?.addrs?.length>0&&console.warn(`${o} partial addrs deleted: ${s.data.addrs.join("|")}`);let a=s.data?.errors?.join("|")||`${o} something went wrong (E: e397fd09b4a746a3ba3305d6ea0893cb)`;return a.includes("File does not exist")&&C&&console.log(`${o} tried to delete file that does not exist. (I: cb5d1348ccbc58bf0bfc95f3006f1e22)`),{errorMsg:a}}}catch(n){return console.error(`${o} ${n.message}`),{errorMsg:n.message}}}f(es,"deleteFromSpace");async function ne({resTransform:r,space:t,force:e}){let o=`[${ne.name}]`;try{if(C&&console.log(`${o} starting... (I: dc6835614ff1a1b82b179225023ae823)`),!t)throw new Error("space required. (E: cf94f1d74f1c4561bb88025a2095965b)");let{newIbGib:n,intermediateIbGibs:s,dnas:a}=r,i=[n,...s||[]],c=await t.argy({ibMetadata:yt({space:t}),argData:{cmd:"put",force:e,ibGibAddrs:i.map(l=>w({ibGib:l}))},ibGibs:i.concat()}),d=await t.witness(c);if(d.data?.success)d.data.warnings?.length>0&&d.data.warnings.forEach(l=>console.warn(`${o} ${l}`));else{let l=d?.data?.errors?.length>0?d.data.errors.join(`
5
+ `):"unknown error putting ibGibs";throw new Error(l)}if(a?.length??!1){let l=await t.argy({ibMetadata:yt({space:t}),argData:{cmd:"put",isDna:!0,force:e,ibGibAddrs:a.map(h=>w({ibGib:h}))},ibGibs:a.concat()}),b=await t.witness(l);if(b.data?.success)b.data.warnings?.length>0&&b.data.warnings.forEach(h=>console.warn(`${o} ${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(`${o} ${n.message}`),n}finally{C&&console.log(`${o} complete. (I: dc6835614ff1a1b82b179225023ae823)`)}}f(ne,"persistTransformResult");async function Nl({type:r,rel8nName:t,space:e}){let o=`[${Nl.name}]`;try{if(!e)throw new Error("space required. (E: f73868a952ac4181a4f90ee6d86cacf3)");let n=await $o({type:r,space:e});if(!n)throw new Error(`couldn't get special (${r}) (E: a65bef190416479697605be486846731)`);let s=n.rel8ns?n.rel8ns[t]||[]:[],a=[];for(let i=0;i<s.length;i++){let c=s[i],d=await X({addr:c,space:e});if(d.success&&d.ibGibs?.length===1)a.push(d.ibGibs[0]);else throw new Error(`couldn't get addr: ${c} (E: 76ef256ee80149ab860c5786484b0e89)`)}return a}catch(n){throw console.error(`${o} ${n.message}`),n}}f(Nl,"getSpecialRel8dIbGibs");async function $o({type:r,initialize:t,space:e,zeroSpace:o,fnUpdateBootstrap:n,fnBroadcast:s,fnGetInitializing:a,fnSetInitializing:i,dontWarnIfNotExist:c}){let d=`[${$o.name}]`;try{if(!e)throw new Error("space required. (E: d454b31d58764a9bb9c4e47fb5ef38b5)");let l=le({type:r}),b=await yo({key:l,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(!o)throw new Error("zeroSpace required when 'initialize' truthy (E: 8582c92c637f90c9b2dbe0ec8355b523)");b=await hi({type:r,space:e,zeroSpace:o,fnBroadcast:s,fnUpdateBootstrap:n})??void 0}catch(g){console.error(`${d} error initializing: ${g.message}`)}finally{i(!1)}}if(!b){if(a&&a())return console.warn(`${d} 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(`${d} getting addr: ${b}`);let h=await X({addr:b,space:e});if(h.success||(h=await X({addr:b,space:e}),h.success&&(console.warn(`${d} special ibgib was not stored in meta folder...putting in meta folder now for the future (W: e6f5571fd98c449bb2809359be5057cc)`),(await Be({ibGib:h.ibGibs[0],space:e})).success||console.warn(`${d} (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 ct({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(`${d} latest addr is not the one associated with the local space.
7
+ specialAddr: ${g}
8
+ latestAddr: ${m} (W: 141b69dc3c414efc9645bb76fcf12df9)`)}return p}catch(l){let b=`${d} ${l.message}`;return b.includes("d8ebdc9eaaa640b99cd206f132962c93")&&c||console.error(b),null}}f($o,"getSpecialIbGib");async function yo({key:r,space:t,dontWarn:e}){let o=`[${yo.name}](${r})`;try{if(C&&console.log(`${o} getting... (I: 43e7bfc2515d45e5af8767b9a85b248e)`),!t)throw new Error("space required. (E: 4f135d4276e64054ba21aeb9c304ecec)");if(!t.rel8ns){(C||!e)&&console.warn(`${o} space.rel8ns falsy. (W: 7c642259fbf547dbaa1b2fdf0115f6ef)`);return}if(!t.rel8ns[r]){(C||!e)&&console.warn(`${o} space.rel8ns[${r}] falsy. (W: 3c1c49b9987b45cc96dd78b808f98e91)`);return}if(t.rel8ns[r].length===1)return C&&console.log(`${o} got (I: f13e71b693d5404c9535bda8ff0cc6a9)`),t.rel8ns[r][0];if(t.rel8ns[r].length>1)return(C||!e)&&console.warn(`${o} more than one config addr with ${r} rel8n. (W: 102f63eb74904bcfaac2eaf778043205)`),t.rel8ns[r][0];C&&console.log(`${o} didn't find (I: 1163e6ac60194d25b3f24881650edfad)`);return}catch(n){console.error(`${o} ${n.message}`);return}}f(yo,"getConfigAddr");async function ye({key:r,addr:t,space:e,zeroSpace:o,fnUpdateBootstrap:n}){let s=`[${ye.name}]`;try{if(!e)throw new Error("space required. (E: c28b663c991d44419aef1026cc689636)");if(!o)throw new Error("zeroSpace required. (E: d3707ae5265d464891ad216f64be6184)");let a={[r]:[t]},i=await Ae({src:e.toIbGibDto(),dna:!1,linkedRel8ns:["past","ancestor",r],rel8nsToAddByAddr:a,nCounter:!0});if(!i.newIbGib)throw new Error("create new space failed.");await ne({resTransform:i,space:o}),await ne({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(ye,"setConfigAddr");async function fi({space:r}){let t=`[${fi.name}]`;try{if(!r)throw new Error("space required. (E: f0d546101fba4c169256158114ab3c56)");let e=await $o({type:"roots",space:r});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 o=e.rel8ns.current[0],n=await X({addr:o,space:r});if(n.ibGibs?.length===1)return n.ibGibs[0];throw new Error(`could not get current root. addr: ${o}`)}catch(e){console.error(`${t} ${e.message}`);return}}f(fi,"getCurrentRoot");async function ts({root:r,space:t,zeroSpace:e,fnUpdateBootstrap:o,fnBroadcast:n}){let s=`[${ts.name}]`;try{if(C&&console.log(`${s} starting... (I: 7f16e845a80fe95d28923e4170f0c825)`),!r)throw new Error("root required.");if(!t)throw new Error("space required. (E: 186af2731c5342a78b063a0a4346f3db)");let a=w({ibGib:r}),i=await $o({type:"roots",space:t});if(!i)throw new Error("Roots not initialized. (E: a8232b9afac89d0d189534480b7a9825)");let d=await Ae({src:i,dna:!1,linkedRel8ns:["past","ancestor","current"],rel8nsToAddByAddr:{current:[a]},nCounter:!0});await ne({resTransform:d,space:t});let l=le({type:"roots"}),b=d.newIbGib,h=w({ibGib:b});await ye({key:l,addr:h,space:t,zeroSpace:e,fnUpdateBootstrap:o}),await ge({ibGib:b,space:t,fnBroadcast:n})}catch(a){throw console.error(`${s} ${a.message}`),a}finally{C&&console.log(`${s} complete. (I: 7f16e845a80fe95d28923e4170f0c825)`)}}f(ts,"setCurrentRoot");async function bi({ibGib:r,linked:t,rel8nName:e,space:o,fnBroadcast:n,zeroSpace:s,fnUpdateBootstrap:a}){let i=`[${bi.name}]`;try{if(!o)throw new Error("space required. (E: f2758eab3bb844d2b749515672d9e392)");if(!r)throw new Error("ibGib required (E: f1bfd67754a7271553f4af544d30bc22)");let c=await fi({space:o});if(!c)throw new Error("currentRoot undefined (E: 5c2d84dafc664808866008f6eb535750");let d=We({ibGib:r,defaultIfNone:"incomingAddr"}),l=w({ibGib:r});if(e&&d&&c.rel8ns&&c.rel8ns[e]&&c.rel8ns[e].includes(d))return;e=e||Dn;let b=await Ae({src:c,dna:!1,linkedRel8ns:t?["past","ancestor",e]:["past","ancestor"],rel8nsToAddByAddr:{[e]:[l]},nCounter:!0});await ne({resTransform:b,space:o});let h=b.newIbGib,p=w({ibGib:h});C&&console.log(`${i} updating _currentRoot root. newRootAddr: ${p}`),await ge({ibGib:h,space:o,fnBroadcast:n}),await ts({root:h,space:o,zeroSpace:s,fnUpdateBootstrap:a,fnBroadcast:n})}catch(c){console.error(`${i} ${c.message}`);return}}f(bi,"rel8ToCurrentRoot");async function Zn({targetIbGib:r,space:t}){let e=`[${Zn.name}]`;try{C&&console.log(`${e} starting... (I: 291638372117dbc983b4b7cbd8f52123)`);let o=await Jn({targetIbGib:r}),n=await Be({ibGib:o,space:t});if(!n.success)throw new Error(`error putting metaStone in space. error: ${n.errorMsg??"[unknown error (E: 45f700f4f1ff463ca8f5353c8e796ac7)]"} (E: 4c25379e66365055e3e423561a7d6123)`)}catch(o){throw console.error(`${e} ${E(o)}`),o}finally{C&&console.log(`${e} complete.`)}}f(Zn,"createAndSaveNewMetaStone");async function ge({ibGib:r,space:t,fnBroadcast:e}){let o=`[${ge.name}]`,n=C;try{let s=w({ibGib:r});if(o=`${o}[${s}]`,!t)throw new Error("space required. (E: ea0c03256f8a4062b460aa4de11f1e3e)");if(C&&console.log(`${o} starting...`),!he({ibGibAddr:s}).tjpGib&&!r.data?.isTjp){C&&console.log(`${o} incoming ibGib has no timeline, so no broadcast. still going to create a metastone for it and return early. (I: 649752e3b1be0e0ceb078e0ec2a84f23)`),await Zn({targetIbGib:r,space:t});return}let i=We({ibGib:r,defaultIfNone:"undefined"});if(!i){let u=r.data?.isTjp?r:await Qn({ibGib:r,space:t});u||(console.warn(`${o} tjp not found for ${s}? Should at least just be the ibGib's address itself. (W: d9b570e5bf6d4312bc7d9249ed3bbaad)`),u=r),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(`${o} adding/replacing latest. tjp: ${i} (I: 7f848da003a2436089fd6f044d96bb42)`),await Zn({targetIbGib:r,space:t}),e&&(C&&console.log(`${o} fnBroadcast is true...(I: 0e3b561fb5474a0598b5c6d698df5e1f)`),setTimeout(()=>{C&&console.log(`${o} broadcasting... (I: 61785937be0346f0959d476d7267ab24)`),e({ib:"IbGibTimelineUpdateInfo",tjpAddr:i,latestAddr:s,latestIbGib:r})}))},"replaceLatest");if(r.data?.isTjp){C&&console.log(`${o} ibGib.data?.isTjp true. replacingLatest and returning early. (I: 02c626e006668291550e278b461bcb23)`),await c();return}C&&console.log(`${o} ibGib.data?.isTjp is falsy. (I: 84940e3a9eff869c9474b7b92b864b23)`);let d=await ct({ibGibs:[r],space:t});if(!d.data)throw new Error("(UNEXPECTED) resLatest.data falsy? (E: af3d3914d96adcc5525e4db83cc5d223)");let{success:l,latestAddrsMap:b}=d.data;if(!l){let{errors:u}=d.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(`${o} valid latestAddrsMap. console.dir(latestAddrsMap)... (I: e24de41622cabbef375172c3017cfd23)`),console.dir(b));let p=b[s];if(p)if(p===s){C&&console.log(`${o} no other found. possible idempotent replacement. addr: ${s} (I: 7f5bd5d3391be95919240f0e97976e22)`),await c();return}else{C&&console.log(`${o} different addr found. incoming ibgib addr is newer. existingLatestAddr: ${p}. incoming addr: ${s} (I: 6cadf13f82aabeb71d76babf1813e623)`);let u=await X({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 r.data?.n=="number"&&r.data.n>=0){C&&console.log(`found ibGib.data.n (version counter), using this to determine latest ibGib: ${r.data.n}`);let y=r.data.n;if(typeof g.data?.n=="number"&&g.data.n>=0){let T=g.data.n;if(y>T)C&&console.log(`${o} 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(`${o} incoming ibGib (${s}) is NOT NEWER than existing latest (${p}). multiple branches for the same timeline? ignoring incoming ibGibAddr. n_ibGib: ${y}. n_existingLatest: ${T}. space.ib: ${t.ib} (W: 057baadca494473dabb26fb4fb879774)`);return}}else g.data?.isTjp&&r.data.n===0?await c():(console.warn(`${o} (UNEXPECTED) only existingLatestIbGib (isTjp: ${g.data?.isTjp}) has a data.n counter? ibGib.data.n: ${r.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(`${o} console.dir(existingLatestIbGib)... (I: 9ef7962d9cc74f1eb0409e5caf98e915)`),console.dir(g),console.log(`${o} console.dir(ibGib)... (I: 9ef7962d9cc74f1eb0409e5caf98e915)`),console.dir(r),await c())}else if(C&&console.log(`${o} no nCounter found. Trying brute force method.`),await Ai({ibGib:r,ibGibAddr:s,existingLatest:g,existingLatestAddr:p,tjpAddr:i,space:t})===s)await c();else return}else if(p===null){C&&console.log(`${o} 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(`${o} ${s.message}`),s}finally{C&&console.log(`${o} complete.`),C=n}}f(ge,"registerNewIbGib");async function dr({type:r,rel8nName:t,ibGibsToRel8:e,ibGibsToUnRel8:o,addrsToUnRel8:n,linked:s,severPast:a,deletePreviousSpecialIbGib:i,space:c,zeroSpace:d,fnUpdateBootstrap:l,fnBroadcast:b}){let h=`[${dr.name}](type:${r},rel8nName:${t})`;try{if(!c)throw new Error("space required. (E: 956192eea28047eba6dad81620bb96fb)");if((e??[]).length===0&&(o??[]).length===0&&(n??[]).length===0)throw new Error("either ibGibsToRel8 or ibGibsToUnRel8 required. (E: 5add49c8e46a54e2c6b057c22646a822)");if((o??[]).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(A=>w({ibGib:A}));n??=o?.map(A=>w({ibGib:A}));let u=le({type:r}),g=await yo({key:u,space:c});if(!g)throw new Error("specialAddr not found (E: 680dfd1caa3e4d7cb0f593b893a10f0d)");let m=await X({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 y=m.ibGibs[0],I=await Ae({src:y,rel8nsToAddByAddr:p?{[t]:p}:void 0,rel8nsToRemoveByAddr:n?{[t]:n}:void 0,dna:!1,linkedRel8ns:s?[ee.past,t]:[ee.past],nCounter:!0}),T=I.newIbGib;if(a){if(I.intermediateIbGibs)throw new Error("new special creates intermediate ibgibs. so severing past is harder. (E: b580c0c56253494192e9c62212ee187d)");T.rel8ns.past=[],T.gib=await V({ibGib:T})}await ne({resTransform:I,space:c});let $=w({ibGib:T}),_=We({ibGib:T});return await ye({key:u,addr:$,space:c,zeroSpace:d,fnUpdateBootstrap:l}),i&&await es({addr:g,space:c}),await ge({ibGib:T,fnBroadcast:b,space:c}),$}catch(p){throw console.error(`${h} ${p.message}`),p}}f(dr,"rel8ToSpecialIbGib");async function Qn({ibGib:r,naive:t=!0,space:e}){let o=`[${Qn.name}]`;try{if(!e)throw new Error("space required. (E: 941f973d50e84415b58724af173f52c2)");if(!r)throw new Error("ibGib required.");let n=w({ibGib:r}),{gib:s}=H({ibGibAddr:n});if(s===M||await as({ibGib:r,naive:t}))return r;if(!r.rel8ns){C&&console.log(`${o} ibgib not tjp in data, and rel8ns is falsy. so tjp is undefined (I: acdadb76a7568807db7a68f6f866de22)`);return}if(r.rel8ns.tjp&&r.rel8ns.tjp.length>0){let b=r.rel8ns.tjp[0],h=await X({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=r.rel8ns.past||[];if(i.length===0){console.warn(`${o} past.length === 0, so there is no tjp.`),C&&console.log(`${o} 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],d=await X({addr:c,space:e});if(!d.success||d.ibGibs?.length!==1)throw new Error(`get past failed. addr: ${c}`);let l=d.ibGibs[0];return await Qn({ibGib:l,naive:t,space:e})}catch(n){throw console.error(`${o} ${n.message}`),n}}f(Qn,"getTjpIbGib");async function hi({type:r,space:t,zeroSpace:e,fnUpdateBootstrap:o,fnBroadcast:n}){let s=`[${hi.name}]`;try{if(!t)throw new Error("space falsy and localUserSpace not initialized. (E: 66e7d3ff098248f0a5ddda51853c92e6)");switch(r){case"roots":return gi({space:t,zeroSpace:e,fnBroadcast:n,fnUpdateBootstrap:o});case"tags":return pi({space:t,zeroSpace:e,fnBroadcast:n,fnUpdateBootstrap:o});case"secrets":return mi({space:t,zeroSpace:e,fnBroadcast:n,fnUpdateBootstrap:o});case"encryptions":return wi({space:t,zeroSpace:e,fnBroadcast:n,fnUpdateBootstrap:o});case"outerspaces":return $i({space:t,zeroSpace:e,fnBroadcast:n,fnUpdateBootstrap:o});case"autosyncs":return yi({space:t,zeroSpace:e,fnBroadcast:n,fnUpdateBootstrap:o});case"robbots":return Ii({space:t,zeroSpace:e,fnBroadcast:n,fnUpdateBootstrap:o});case"apps":return _i({space:t,zeroSpace:e,fnBroadcast:n,fnUpdateBootstrap:o});default:return Ti({type:r,space:t,zeroSpace:e,fnBroadcast:n,fnUpdateBootstrap:o})}}catch(a){throw console.error(`${s} ${a.message}`),a}}f(hi,"createSpecial");async function it({type:r,skipRel8ToRoot:t,space:e,zeroSpace:o,fnUpdateBootstrap:n,fnBroadcast:s}){let a=`[${it.name}][${r||"falsy type?"}]`;try{C&&console.log(`${a} starting...`);let i=ns({type:r}),c=k.primitive({ib:i}),d=await to({src:c,destIb:i,linkedRel8ns:[ee.past,ee.ancestor],tjp:{uuid:!0,timestamp:!0},dna:!0,nCounter:!0});return await ne({resTransform:d,space:e}),r!=="roots"&&r!=="latest"&&!t&&await bi({ibGib:d.newIbGib,linked:!0,space:e,zeroSpace:o,fnBroadcast:s,fnUpdateBootstrap:n}),C&&console.log(`${a} complete.`),d.newIbGib}catch(i){throw console.error(`${a} ${i.message}`),i}}f(it,"createSpecialIbGib");async function pi({space:r,zeroSpace:t,fnUpdateBootstrap:e,fnBroadcast:o}){let n=`[${pi.name}]`;try{if(!r)throw new Error("space required. (E: 9c05b9bd355943a39ca47afef67a50eb)");let s=le({type:"tags"}),a=await it({type:"tags",space:r,zeroSpace:t,fnBroadcast:o,fnUpdateBootstrap:e}),i=w({ibGib:a});await ye({key:s,addr:i,space:r,zeroSpace:t,fnUpdateBootstrap:e});let c=[{text:"home",icon:"home-outline"},{text:"favorite",icon:"heart-outline"}];for(let d of c)i=(await ui({...d,space:r,zeroSpace:t,fnBroadcast:o,fnUpdateBootstrap:e})).newTagsAddr,await ye({key:s,addr:i,space:r,zeroSpace:t,fnUpdateBootstrap:e});return i}catch(s){return console.error(`${n} ${s.message}`),null}}f(pi,"createSpecial_Tags");async function ui({text:r,icon:t,description:e,space:o,zeroSpace:n,fnUpdateBootstrap:s,fnBroadcast:a}){let i=`[${ui.name}]`;try{if(C&&console.log(`${i} starting...`),!o)throw new Error("space required. (E: 5def0b1afab74b0c9286e3ac5060cb8f)");if(!r)throw new Error(`${i} text required`);t=t||Ua,e=e||ka;let c=Vt(r),d=k.primitive({ib:"tag"}),l=await k.firstGen({parentIbGib:d,ib:c,data:{text:r,icon:t,description:e},tjp:{uuid:!0,timestamp:!0},dna:!0,nCounter:!0}),b=l.newIbGib;await ne({resTransform:l,space:o}),await ge({ibGib:b,space:o,fnBroadcast:a});let h=await Ol({tagIbGib:b,space:o,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(ui,"createTagIbGibAndSundry");async function gi({space:r,zeroSpace:t,fnUpdateBootstrap:e,fnBroadcast:o}){let n=`[${gi.name}]`;try{if(!r)throw new Error("space required. (E: d12a8ea31163429fb6e53ff8e7579c57)");let s=le({type:"roots"}),a=await it({type:"roots",space:r,zeroSpace:t,fnBroadcast:o,fnUpdateBootstrap:e}),i=w({ibGib:a});await ye({key:s,addr:i,space:r,zeroSpace:t,fnUpdateBootstrap:e});let d=["A","B","C","D","E","F","G"].map(b=>({text:`${b}root`,icon:vn,description:Ln})),l;for(let b=0;b<d.length;b++){let h=d[b],p=await Ei({...h,space:r,zeroSpace:t,fnUpdateBootstrap:e,fnBroadcast:o});if(l||(l=p.newRootIbGib),!p.newRootIbGib)throw new Error("(UNEXPECTED) resCreate.newRootIbGib falsy? (E: c9fb2c94a9c1d762c1699b41a4d5ad23)");i=p.newRootsAddr,await ye({key:s,addr:i,space:r,zeroSpace:t,fnUpdateBootstrap:e})}if(!l)throw new Error("(UNEXPECTED) firstRoot still falsy? (E: b2e2c926d242966e7ed7159e4b129e23)");if(await ts({root:l,space:r,zeroSpace:t,fnUpdateBootstrap:e,fnBroadcast:o}),i=await yo({key:s,space:r}),!i)throw new Error("(UNEXPECTED) no roots address in config? (E: 76345340699a4738a195e48803ef0d31)");return i}catch(s){return console.error(`${n} ${s.message}`),null}}f(gi,"createSpecial_Roots");async function Ei({text:r,icon:t,description:e,space:o,zeroSpace:n,fnUpdateBootstrap:s,fnBroadcast:a}){let i=`[${Ei.name}]`;try{if(!o)throw new Error("space required. (E: cfa876e5c8c64a53a463ca7a645571c8)");r=r||Ra,t=t||vn,e=e||Ln;let c=ss(r),d=k.primitive({ib:"root"}),l=await k.firstGen({parentIbGib:d,ib:c,data:{text:r,icon:t,description:e},linkedRel8ns:[ee.past,ee.ancestor],tjp:{uuid:!0,timestamp:!0},dna:!0,nCounter:!0}),{newIbGib:b}=l;await ne({resTransform:l,space:o});let h=await dr({type:"roots",rel8nName:On,ibGibsToRel8:[b],space:o,zeroSpace:n,fnUpdateBootstrap:s,fnBroadcast:a});return{newRootIbGib:b,newRootsAddr:h}}catch(c){throw console.error(`${i} ${c.message}`),c}}f(Ei,"createRootIbGib");async function mi({space:r,zeroSpace:t,fnUpdateBootstrap:e,fnBroadcast:o}){let n=`[${mi.name}]`;try{if(!r)throw new Error("space required. (E: 340960cd5ad24addb300b23d9722e30a)");let s,a=le({type:"secrets"}),i=await it({type:"secrets",space:r,zeroSpace:t,fnBroadcast:o,fnUpdateBootstrap:e});return s=w({ibGib:i}),await ye({key:a,addr:s,space:r,zeroSpace:t,fnUpdateBootstrap:e}),s}catch(s){return console.error(`${n} ${s.message}`),null}}f(mi,"createSpecial_Secrets");async function wi({space:r,zeroSpace:t,fnUpdateBootstrap:e,fnBroadcast:o}){let n=`[${wi.name}]`;try{if(!r)throw new Error("space required. (E: 5084e698b6924e7090697ca50075ca59)");let s,a=le({type:"encryptions"}),i=await it({type:"encryptions",space:r,zeroSpace:t,fnBroadcast:o,fnUpdateBootstrap:e});return s=w({ibGib:i}),await ye({key:a,addr:s,space:r,zeroSpace:t,fnUpdateBootstrap:e}),s}catch(s){return console.error(`${n} ${s.message}`),null}}f(wi,"createSpecial_Encryptions");async function $i({space:r,zeroSpace:t,fnUpdateBootstrap:e,fnBroadcast:o}){let n=`[${$i.name}]`;try{if(!r)throw new Error("space required. (E: 99dd9e92535c470482eb9f6625a33831)");let s,a=le({type:"outerspaces"}),i=await it({type:"outerspaces",space:r,zeroSpace:t,fnBroadcast:o,fnUpdateBootstrap:e});return s=w({ibGib:i}),await ye({key:a,addr:s,space:r,zeroSpace:t,fnUpdateBootstrap:e}),s}catch(s){return console.error(`${n} ${s.message}`),null}}f($i,"createSpecial_OuterSpaces");async function yi({space:r,zeroSpace:t,fnUpdateBootstrap:e,fnBroadcast:o}){let n=`[${yi.name}]`;try{if(!r)throw new Error("space required. (E: f01cf6a4a460486796e16d505d629522)");let s,a=le({type:"autosyncs"}),i=await it({type:"autosyncs",space:r,zeroSpace:t,fnBroadcast:o,fnUpdateBootstrap:e});return s=w({ibGib:i}),await ye({key:a,addr:s,space:r,zeroSpace:t,fnUpdateBootstrap:e}),s}catch(s){return console.error(`${n} ${s.message}`),null}}f(yi,"createSpecial_Autosyncs");async function Ii({space:r,zeroSpace:t,fnUpdateBootstrap:e,fnBroadcast:o}){let n=`[${Ii.name}]`;try{if(!r)throw new Error("space required. (E: f01cf6a4a460486796e16d505d629522)");let s,a=le({type:"robbots"}),i=await it({type:"robbots",space:r,zeroSpace:t,fnBroadcast:o,fnUpdateBootstrap:e});return s=w({ibGib:i}),await ye({key:a,addr:s,space:r,zeroSpace:t,fnUpdateBootstrap:e}),s}catch(s){return console.error(`${n} ${s.message}`),null}}f(Ii,"createSpecial_Robbots");async function _i({space:r,zeroSpace:t,fnUpdateBootstrap:e,fnBroadcast:o}){let n=`[${_i.name}]`;try{if(!r)throw new Error("space required. (E: f01cf6a4a460486796e16d505d629522)");let s,a=le({type:"apps"}),i=await it({type:"apps",space:r,zeroSpace:t,fnBroadcast:o,fnUpdateBootstrap:e});return s=w({ibGib:i}),await ye({key:a,addr:s,space:r,zeroSpace:t,fnUpdateBootstrap:e}),s=await mo({defaultAppData:ei,defaultAppRel8ns:ti,space:r,zeroSpace:t,fnUpdateBootstrap:e,fnBroadcast:o}),s=await mo({defaultAppData:ri,defaultAppRel8ns:oi,space:r,zeroSpace:t,fnUpdateBootstrap:e,fnBroadcast:o}),s=await mo({defaultAppData:ni,defaultAppRel8ns:si,space:r,zeroSpace:t,fnUpdateBootstrap:e,fnBroadcast:o}),s}catch(s){return console.error(`${n} ${s.message}`),null}}f(_i,"createSpecial_Apps");async function mo({defaultAppData:r,defaultAppRel8ns:t,space:e,zeroSpace:o,fnUpdateBootstrap:n,fnBroadcast:s}){let a=`[${mo.name}]`;try{C&&console.log(`${a} starting... (I: 677f68789abdc7316887e8f38c764e22)`),C&&console.log(`${a} starting...`);let i=v(r),c=t?v(t):void 0;i.uuid=!i.uuid||i.uuid===Wn?await F():i.uuid;let{classname:d}=i,l=Kn({appData:i,classname:d}),b=await k.firstGen({ib:l,parentIbGib:k.primitive({ib:`app ${d}`}),data:i,rel8ns:c,dna:!0,linkedRel8ns:[ee.ancestor,ee.past],nCounter:!0,tjp:{timestamp:!0}});return await ne({resTransform:b,space:e}),await ge({ibGib:b.newIbGib,fnBroadcast:s,space:e}),await dr({type:"apps",rel8nName:io,ibGibsToRel8:[b.newIbGib],fnBroadcast:s,fnUpdateBootstrap:n,space:e,zeroSpace:o})}catch(i){throw console.error(`${a} ${i.message}`),i}finally{C&&console.log(`${a} complete.`)}}f(mo,"createApp");async function Ti({type:r,space:t,zeroSpace:e,fnUpdateBootstrap:o,fnBroadcast:n}){let s=`[${Ti.name}]`;try{if(!t)throw new Error("space required. (E: c7bbafcbe901418db4c6048f17f53091)");C&&console.log(`${s} creating special of type: ${r} (I: 283c8bb30ed6f9698b74b886c6078622)`);let a,i=le({type:r}),c=await it({type:r,space:t,zeroSpace:e,fnBroadcast:n,fnUpdateBootstrap:o});return a=w({ibGib:c}),await ye({key:i,addr:a,space:t,zeroSpace:e,fnUpdateBootstrap:o}),a}catch(a){return console.error(`${s} ${a.message}`),null}}f(Ti,"createSpecial_Default");async function Ai({ibGib:r,ibGibAddr:t,existingLatest:e,existingLatestAddr:o,tjpAddr:n,space:s}){let a=`[${Ai.name}][${t}]`;try{if(C&&console.log(`${a} starting...`),!s)throw new Error("space required. (E: 64eb9a271f5d43deadec30b9638746c8)");let i=r.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."),o;if(c.length===0&&i.length===0)return console.warn(`${a} neither existing latest nor prospective new ibGib has a past, so keeping existing.`),o;if(c.includes(t))return C&&console.log("existing by definition is newer"),o;if(i.includes(o))return C&&console.log("ibGib by definition is newer"),t;if(o===t)return C&&console.log("they're the same!"),o;if(o===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&&r.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."),o;C&&console.log(`${a} brute forcing through iterating the pasts.`);let d,l=-1,b=f(async(u,g,m)=>{let y=u.rel8ns?.past||[];if(y.includes(m))return d=w({ibGib:u}),-1;if(y.length===0)return g;let I=g+y.length;if(l!==-1&&I>l)return d=w({ibGib:u}),-1;let T=await X({addr:y[0],space:s});if(!T.success||T.ibGibs?.length!==1)throw new Error(`Couldn't load past addr (xPast[0]): ${y[0]}`);return b(T.ibGibs[0],g+y.length,m)},"getPastCount");C&&console.log(`${a} doing ibGibPastCount`);let h=await b(r,0,o);if(d)return d;C&&console.log(`${a} Doing existingPastCount`),l=h;let p=await b(e,0,t);return d||(h>p?(C&&console.log(`${a} ibGibPastCount (${h}) is longer than existingPastCount (${p}), so ibGib is newer.`),d=t):(C&&console.log(`${a} existingPastCount (${p}) is longer than ibGibPastCount (${h}), so ibGib is newer.`),d=o),d)}catch(i){throw console.error(`${a} ${i.message}`),i}finally{C&&console.log(`${a} complete.`)}}f(Ai,"getLatestAddr_Brute");function Ol({tagIbGib:r,space:t,zeroSpace:e,fnUpdateBootstrap:o,fnBroadcast:n}){return dr({type:"tags",rel8nName:Pn,ibGibsToRel8:[r],space:t,zeroSpace:e,fnUpdateBootstrap:o,fnBroadcast:n})}f(Ol,"rel8TagToTagsIbGib");function rs({space:r,scope:t}){let e=`[${rs.name}]`;try{if(C&&console.log(`${e} starting...`),!r)throw new Error("space required. (E: 3ba16e6c3e5e47948b0e63448da11752)");if(!r.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(ce);)C&&console.log(`${e} scope contains ibgib delimiter...replacing... (I: 0f456fd7cc6552a799673a0c5b4a7d22)`),t=t.replace(ce,"_");let o=r.data.uuid,n=`${va} ${o} ${t}`;return w({ib:n,gib:M})}catch(o){throw console.error(`${e} ${o.message}`),o}finally{C&&console.log(`${e} complete.`)}}f(rs,"getSpaceLockAddr");async function at({space:r,scope:t,secondsValid:e,maxDelayMs:o,fn:n,callerInstanceId:s,maxLockAttempts:a}){let i=`[${at.name}]`;try{if(C&&console.log(`${i} starting...`),!r)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 d;o=(o??0)>0?o:La;let l=0;a=a??!1?a:Pa;do{if(d=await Si({space:r,scope:t,secondsValid:e,instanceId:s}),d?.data?.success)break;let h=Math.ceil(Math.random()*o);await be(h),l++}while(l<a);if(d?.data?.success)C&&console.log(`${i} lock acquired. (I: d847fa953ee131a57e1a89c537342722)`);else throw new Error(`could not acquire lock after ${l} attempts with intermittent delays of ${o} 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 Gi({space:r,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(at,"execInSpaceWithLocking");async function wo({zeroSpace:r}){let t=`[${wo.name}]`;try{if(C&&console.log(`${t} starting...`),!r)throw new Error("zeroSpace required. (E: 66fd8f21a5b2b572d18cdeb9472a7722)");let e=Yt;C&&console.log(`${t} getting from zeroSpace...`);let o=await r.argy({ibMetadata:yt({space:r}),argData:{cmd:"get",ibGibAddrs:[e]}}),n=await r.witness(o);if(n?.data?.success&&n.ibGibs?.length===1){let s=n.ibGibs[0];return C&&console.log(`${t} bootstrapibGib found: ${P(s)}`),await Yn(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(wo,"getValidatedBootstrapIbGib");async function Dl({zeroSpace:r,bootstrapIbGib:t,localSpaceId:e,lock:o,callerInstanceId:n,fnDtoToSpace:s,localSpaceCacheSvc:a}){let i=`[${Dl.name}]`;try{if(!r)throw new Error("zeroSpace required. (E: 0793781a98c456a666cfa9eb960bcd22)");if(!t)if(C&&console.log(`${i} bootstrap falsy, so loading it... (I: f2366e38283495a38b5501297aa34422)`),o){let l=Yt;C&&console.log(`${i} using locked version of loading bootstrap... (I: 52b9b11999674e586d051c2b23f59b22)`),t=await at({space:r,scope:l,fn:f(async()=>{let b=await wo({zeroSpace:r});if(b)return b;throw new Error("(UNEXPECTED) unable to get bootstrap ibgib? (E: c111dc7627acbfb992134ddf4064ea23)")},"fn"),callerInstanceId:n,secondsValid:Nn})}else C&&console.log(`${i} lock is false, so just getting the bootstrap ibgib (I: 49d55e5a824510bb3ee0ccd9f5ec3322)`),t=await wo({zeroSpace:r})??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[ot];let c=t.rel8ns[e][0],d=f(async()=>{let l=await r.argy({ibMetadata:yt({space:r}),argData:{cmd:"get",ibGibAddrs:[c]}}),b=await r.witness(l);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 o?(C&&console.log(`${i} getting localSpaceId (${e}) WITH locking (I: c48a0e4ac5971cdbc57273dd35f8a522)`),await at({space:r,scope:e,fn:f(()=>d(),"fn"),callerInstanceId:n,secondsValid:Nn})):(C&&console.log(`${i} getting localSpaceId (${e}) WITHOUT locking (I: 48e504835dee4006839df8820d860b22)`),d())}catch(c){throw console.error(`${i} ${c.message}`),c}}f(Dl,"getLocalSpace");async function Si({space:r,scope:t,secondsValid:e,instanceId:o}){let n=`[${Si.name}]`;try{if(C&&console.log(`${n} starting...`),!r)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=rs({space:r,scope:t}),i,c=await X({addr:a,space:r,force:!0});if(c.success&&c.ibGibs?.length===1?(i=c.ibGibs[0],i?.data?.expirationUTC?_n({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=v(i),s.data.alreadyLocked=!0,s.data.success=!1}else{let{ib:d,gib:l}=H({ibGibAddr:a});s={ib:d,gib:l,data:{scope:t,secondsValid:e,instanceId:o,expirationUTC:In({seconds:e})}};let b=await r.argy({ibMetadata:yt({space:r}),argData:{cmd:"put",force:!0,ibGibAddrs:[a]},ibGibs:[s]}),h=await r.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 X({addr:a,space:r,force:!0});if(p.success&&p.ibGibs?.length===1){let u=p.ibGibs[0];s=v(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(Si,"lockSpace");async function Gi({space:r,scope:t,instanceId:e}){let o=`[${Gi.name}]`;try{if(C&&console.log(`${o} starting...`),!r)throw new Error("space required. (E: 5c0a7197a75f483a82d74e5eea60df37)");if(!t)throw new Error("scope required. (E: c7f1dde9570f4df3b450faa2c2f85122)");let n=rs({space:r,scope:t}),s=await es({addr:n,space:r,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(`${o} ${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(`${o} ${a} (W: 14c84fcac15944bd9a417099964d5d9d)`)}}catch(n){throw console.error(`${o} ${n.message}`),n}finally{C&&console.log(`${o} complete.`)}}f(Gi,"unlockSpace");async function vl({space:r,zeroSpace:t,setSpaceAsDefault:e,createIfNotFound:o}){let n=`[${vl.name}]`;try{if(C&&console.log(`${n} starting...`),!r)throw new Error("space required. (E: 6fc19548fa7d1d5219e19871f280a322)");if(!r.data?.uuid)throw new Error("space.data.uuid required (E: 6483188ca6f2ed2085fd355595f3ab22)");if(!t)throw new Error("zeroSpace required. (E: abbf156e18b1018d96273e22a260f122)");let s=r.data.uuid,a=w({ibGib:r}),i=await wo({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 l=i.rel8ns[s][0];l===a?C&&console.log(`${n} bootstrap already rel8d to space (I: c1be027b23e7350c64790a631cae2822)`):(C&&console.log(`${n} updating rel8ns[${s}] with newSpaceAddr (${a}). (Old address: ${l})(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[ot]=s)}else{if(!o){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:l,gib:b}=H({ibGibAddr:Yt});i=k.primitive({ib:l}),i.gib=b,i.data={[ot]:s,[Ha]:[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 d=await t.witness(c);if(d?.data?.success)C&&console.log(`${n} zero space put complete. (I: ac3056d655e841f1a3c442bcc64942f9)`);else throw new Error(`${d?.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(vl,"updateBootstrapIbGib");function yt({space:r}){return`${r.ib} ${Ue()}`}f(yt,"getSpaceArgMetadata");function Su({space:r}){return`${r.ib} ${Ue()}`}f(Su,"getSpaceResultMetadata");function Ll({space:r,spaceData:t,classname:e}){let o=`[${Ll.name}]`;try{if(!r&&!t)throw new Error("either space or spaceData required (E: 4dabec34ee77d67c9cc30ee3c3049622)");if(r&&!r.data)throw new Error("(UNEXPECTED) given space has falsy space.data? (E: 058d298876ebbeada7bbddb9e3da2f23)");if(r&&t){if(r.data.uuid!==t.uuid)throw new Error("(UNEXPECTED) both space and spaceData given, but uuid don't match? (E: efdd4603cba93a17340a76811fe56b24)");if(r.data.n!==t.n)throw new Error("(UNEXPECTED) both space and spaceData given, but n don't match? (E: e51278a707c9bccc57a08a4b86524524)")}if(t??=r.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||Da;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`${go} ${so} ${e} ${n} ${s} ${a} ${i}`}catch(n){throw console.error(`${o} ${n.message}`),n}}f(Ll,"getSpaceIb");function Pl({ib:r}){let t=`[${Pl.name}]`;if(!r){let e=`${t} ib required (E: dd5244f62f964359a86e59bb08ee47e6)`;throw console.error(e),new Error(e)}return r.startsWith(`${go} ${so} `)}f(Pl,"isSpaceIb");function Rl({spaceIb:r}){let t=`[${Rl.name}]`;try{if(!r)throw new Error("spaceIb required (E: fa5424cfb7e846e2851562f2f417944f)");let[e,o,n,s,a,i,c]=r.split(" ");if(e!==go)throw new Error(`invalid spaceIb (${r}). witnessAtom !== WITNESS_ATOM (E: 5ae1ca12cf8f30ae341f3e582b025224)`);if(o!==so)throw new Error(`invalid spaceIb (${r}). spaceAtom !== SPACE_ATOM (E: 9cc6b6f30e13455eb29748148a94fa0f)`);if(!n)throw new Error(`invalid spaceIb (${r}). spaceClassname falsy (E: 00d3392da007ca8b2840b16b199d9a24)`);if(!s)throw new Error(`invalid spaceIb (${r}). spaceName falsy (E: b957d8e74ef34d889fa64c60c7a5ea0b)`);if(!a)throw new Error(`invalid spaceIb (${r}). spaceId falsy (E: 7a1773722d8e46a0866d683130b65b89)`);let d;if(i&&i!=="undefined")if(Xn.includes(i))d=i;else throw new Error(`invalid spaceIb (${r}). spaceType (${i}) is set but not a valid type. valid types: ${Xn.join(", ")} (E: 838f4638a88cfbf3545a3a3a38b6dd24)`);let l;if(c&&c!=="undefined")if(qn.includes(c))l=c;else throw new Error(`invalid spaceIb (${r}). spaceSubtype (${c}) is set but not a valid subtype. valid subtypes: ${qn.join(", ")} (E: 5bdcf23027f94e73860e4340313b04ab)`);return{spaceClassname:n,spaceName:s,spaceId:a,spaceType:d,spaceSubtype:l}}catch(e){throw console.error(`${t} ${e.message}`),e}}f(Rl,"parseSpaceIb");async function ct({ibGibs:r,addrs:t,tjps:e,tjpAddrs:o,space:n}){let s=`[${ct.name}]`;try{if(C&&console.log(`${s} starting...`),!n)throw new Error("space required. (E: 4d188d6c863246f28aa575753a052304)");if(r=r??[],t=t??[],e=e??[],o=o??[],t.length===0&&r.length===0&&e.length===0&&o.length===0)throw new Error("Either addrs, ibGibs, tjps, or tjpAddrs required. (E: 7c6ebfbab98d4d21a431b144457fd991)");let a=new Set(o.concat(e.map(d=>w({ibGib:d})))),i=Array.from(a).map(d=>H({ibGibAddr:d}).gib);r.map(d=>w({ibGib:d})).concat(t).forEach(d=>{let{gib:l}=H({ibGibAddr:d});i.some(h=>l.includes(h))||a.add(d)}),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:yt({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(ct,"getLatestAddrs");function os({ibGib_Context:r}){let t=`[${os.name}]`;try{if(C&&console.log(`${t} starting... (I: 5f583fd94d27731a65d514e731b8aa22)`),!Dr({ibGib:r}))return;if(["roots","autosyncs"].some(o=>r.ib.includes(o)))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(os,"throwIfContextIsSpecial");async function Ul({ibGib_Context:r,rel8nName_Context:t,addr:e,space:o,zeroSpace:n,fnUpdateBootstrap:s,fnBroadcast:a}){let i=`[${Ul.name}]`;try{if(C&&console.log(`${i} starting... (I: 2dc486bb2d516e4534f437aaf5ec7f22)`),!r)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(!o)throw new Error("space required (E: 2e3562486ed2956a770ed9e8d77a3f22)");let c=Dr({ibGib:r});c&&os({ibGib_Context:r});let d=await Ae({src:r,rel8nsToAddByAddr:{[Ba]:[e]},rel8nsToRemoveByAddr:{[t]:[e]},dna:!0,nCounter:!0});if(await ne({resTransform:d,space:o}),c){let l=w({ibGib:d.newIbGib}),b=Io({ib:r.ib}),h=le({type:b});await ye({key:h,addr:l,space:o,zeroSpace:n,fnUpdateBootstrap:s})}await ge({ibGib:d.newIbGib,fnBroadcast:a,space:o})}catch(c){throw console.error(`${i} ${c.message}`),c}finally{C&&console.log(`${i} complete.`)}}f(Ul,"trash");async function kl({ibGib_Context:r,rel8nName_Context:t,addr:e,space:o,zeroSpace:n,fnUpdateBootstrap:s,fnBroadcast:a}){let i=`[${kl.name}]`;try{if(C&&console.log(`${i} starting... (I: 38098552b830495187299bb24fcddff0)`),!r)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(!o)throw new Error("space required (E: e19566f2d42347798621447edcae312e)");let c=Dr({ibGib:r});c&&os({ibGib_Context:r});let d=await Ae({src:r,rel8nsToAddByAddr:{[Ma]:[e]},rel8nsToRemoveByAddr:{[t]:[e]},dna:!0,nCounter:!0});if(await ne({resTransform:d,space:o}),c){let l=w({ibGib:d.newIbGib}),b=Io({ib:r.ib}),h=le({type:b});await ye({key:h,addr:l,space:o,zeroSpace:n,fnUpdateBootstrap:s})}await ge({ibGib:d.newIbGib,fnBroadcast:a,space:o})}catch(c){throw console.error(`${i} ${c.message}`),c}finally{C&&console.log(`${i} complete.`)}}f(kl,"archive");function Ml(r){let t=`[${Ml.name}]`;try{if(!r)return console.error(`${t} name is falsy`),!1;let e=/[\w-]+/,o=r.match(e);if(o?.length!==1||o[0].length!==r.length)return console.error(`${t} name can only contain letters, numbers, underscores, hyphens`),!1;let n=/[a-zA-Z\d]/;return r[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(Ml,"spaceNameIsValid");var Ee=!1;async function is({ibGib:r,rel8nNames:t,space:e}){let o=`[${is.name}]`;try{if(!r)throw new Error("ibGib required (E: a3c1b2d4e5f6a7b8c9d0e1f2a3b4c5d6)");if(!e)throw new Error("space required (E: b4d2c3e4f5a6b7c8d9e0f1a2b3c4d5e6)");t||(t=Object.keys(r.rel8ns||{}));let n={};for(let s of t){let a=r.rel8ns?.[s]||[];if(a.length>0){let i=await X({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(`${o} ${E(n)}`),n}}f(is,"getRel8dIbGibs");async function Ze({parentPrimitiveIb:r,ib:t,ibRegExpPattern:e,data:o,rel8ns:n}){let s=`[${Ze.name}]`;try{if(!r)throw new Error("parentPrimitiveIb required. (E: 88ddf188cc5a4340b597abefba1481e2)");if(lr({ib:r})!==null)throw new Error(`Invalid parentPrimitiveIb: ${r}. (E:5aec0320956d492ebeeaca41eb1fe1c6)`);if(!t)throw new Error("ib required. (E: 7bbc88f4f2e842d6b00126e55b1783e4)");let a=e?new RegExp(e):Na;if(!t.match(a))throw new Error(`invalid ib. does not match regexp (${a})`);let i=Object.keys(n??{}),c=[...Kt,"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 k.firstGen({ib:t,parentIbGib:k.primitive({ib:r}),data:o,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 V({ibGib:{ib:b.ib,data:b.data,rel8ns:b.rel8ns},hasTjp:!1}),b}catch(a){throw console.error(`${s} ${a.message}`),a}}f(Ze,"constantIbGib");function Fu({addr:r}){return Ci({addr:r})}f(Fu,"getBinHashAndExt");function Ci({addr:r}){let t=`[${Ci.name}]`;try{if(!Nr({addr:r}))throw new Error("not a bin address (E: df0804d129bc4888bd6939cb76c5e0f6)");let{ib:e}=H({ibGibAddr:r}),o=e.split(" ");if(o.length===2)return{binHash:o[1],binExt:""};if(o.length===3)return o[2].startsWith("enc=")?{binHash:o[1],binExt:"",binEncoding:o[2].substring(4)}:{binHash:o[1],binExt:o[2]};if(o.length===4){if(!o[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:o[1],binExt:o[2],binEncoding:o[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(Ci,"parseBinIb");function Nr({ibGib:r,addr:t}){let e=`[${Nr.name}]`;try{if(!r&&!t)throw new Error("either ibGib or addr required. (E: c935b51e773f41a2a547c556e9dc16c6)");if(r&&!r.data)return!1;t=t||w({ibGib:r});let{ib:o,gib:n}=H({ibGibAddr:t});if(!o||!n||!o.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=o.split(" ");if(s.length===2){if(!s[1].match(ie))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(ie))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(ie))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(o){throw console.error(`${e} ${o.message}`),o}}f(Nr,"isBinary");function ns({type:r}){if(!r.match(Rn))throw new Error(`special ibgib type must not have spaces and just be alphanumerics. regexp: ${Rn.source} (E: 6c1c92521b7f076cc4666e4915593723)`);return`meta special ${r}`}f(ns,"getSpecialIbGibIb");function Io({ib:r}){let t=`[${Io.name}]`;try{if(Ee&&console.log(`${t} starting... (I: c82ba222bd345ee6b695df4d63a23322)`),!r)throw new Error("ib required (E: 08897145f7138e644fe01c4a59353322)");if(!Dr({ib:r}))throw new Error("ib is not special (E: 174aff63b992adff3ac2394643735922)");let e=r.split(" ");if(e.length<3)throw new Error('invalid ib. should be space-delimited in form of "meta special [type]" (E: ffd89e2cbe63427f98634ab897aab222)');let o=e[2];return Object.values(no).some(n=>n===o)||console.warn(`unknown special type (${o}). This may be expected, but atow I am adding special types to the SpecialIbGibType enum-like. (W: f4e26c3ebb57fe49d69014a4ba32a922)`),o}catch(e){throw console.error(`${t} ${e.message}`),e}finally{Ee&&console.log(`${t} complete.`)}}f(Io,"getSpecialTypeFromIb");function Bl({type:r}){return`${ns({type:r})}^${M}`}f(Bl,"getSpecialIbGibAddr");function le({type:r}){return`${ja} ${Bl({type:r})}`}f(le,"getSpecialConfigKey");function Dr({ib:r,ibGib:t}){if(!r&&!t?.ib)throw new Error("either ib or ibGib.ib required (E: b4cf539638d7966c2e351987f55e1a23)");return(r??t?.ib)?.startsWith("meta special")}f(Dr,"isSpecial");function ss(r){let t=`[${ss.name}]`;if(!r)throw new Error(`${t} text required.`);return`root ${r}`}f(ss,"getRootIb");function Vt(r){let t=`[${Vt.name}]`;if(!r)throw new Error(`${t} tag required.`);return`tag ${r}`}f(Vt,"tagTextToIb");function lt({ibGibs:r,filterPrimitives:t}){let e=`[${lt.name}]`;try{let o={},n={},s={};return(t?r.filter(i=>i.gib??i.gib!==M):r).forEach(i=>{xi({ibGib:i})?(i.rel8ns?.dna??[]).length>0?o[i.gib]=i:n[i.gib]=i:s[i.gib]=i}),{mapWithTjp_YesDna:o,mapWithTjp_NoDna:n,mapWithoutTjps:s}}catch(o){throw console.error(`${e} ${o.message}`),o}}f(lt,"splitPerTjpAndOrDna");function Ye({ibGibs:r}){let t=`[${Ye.name}]`;try{Ee&&console.log(`${t} starting...`);let{mapWithTjp_YesDna:e,mapWithTjp_NoDna:o}=lt({ibGibs:r,filterPrimitives:!0}),n={...e,...o},s=Object.values(n),a=yn({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(d=>d.data?.n===void 0)&&console.warn(`${t} timeline includes ibgibs with ibGib.data?.n === undefined (W: cab9a6b64a38c4279fe82c3569bbab22)`),c.sort((d,l)=>(d.data?.n??-1)>(l.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(Ye,"getTimelinesGroupedByTjp");function xi({ibGib:r}){let t=`[${xi.name}]`;if(!r)throw new Error("(UNEXPECTED) ibGib falsy? (E: ce3a59f9db14e6158bb2c438ca1a3823)");if((r.rel8ns?.tjp?.length??0)>0||r.data?.isTjp)return!0;let e=["fork^gib","mut8^gib","rel8^gib"];return(r.rel8ns?.ancestor??[]).some(n=>e.includes(n))?!1:r.gib?r.gib.includes(rt)?!0:r.gib===M?!1:!!he({ibGibAddr:w({ibGib:r})}).tjpGib:(console.warn(`${t} ibGib.gib falsy. (W: 6400d780822b44d992846f1196509be3)`),!1)}f(xi,"hasTjp");function We({ibGib:r,defaultIfNone:t="undefined"}){let e=`[${We.name}]`;try{let o=Ni({ibGibs:[r],defaultIfNone:t});return o&&Object.keys(o).length===1?Object.values(o)[0]:void 0}catch(o){throw console.error(`${e} ${o.message}`),o}}f(We,"getTjpAddr");function Ni({ibGibs:r,defaultIfNone:t="undefined"}){let e=`[${Ni.name}]`;try{let o={};return r.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,o[s]=a}),o}catch(o){throw console.error(`${e} ${o.message}`),o}}f(Ni,"getTjpAddrs");async function as({ibGib:r,naive:t=!0}){let e=`[${as.name}]`;try{if(!r)throw new Error("ibGib required.");if(t){if(r.data)return r.data.isTjp?!0:r.rel8ns?r.rel8ns.past&&r.rel8ns.past.length>0?!1:!!(r.rel8ns.past&&r.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(o){throw console.error(`${e} ${o.message}`),o}}f(as,"isTjp_Naive");function Pt({ibGib:r}){let t=`[${Pt.name}]`;r.ib||console.warn(`${t} ibGib.ib is falsy. (W: e60e41c2a1fc48268379d88ce13cb77b)`),r.gib||console.warn(`${t} ibGib.gib is falsy. (W: fb3889cbf0684ae4ac51e48f28570377)`);let e={ib:(r.ib||"").slice()};return r.gib&&(e.gib=r.gib.slice()),r.data&&(Nr({ibGib:r})?e.data=r.data.slice():e.data=v(r.data)),r.rel8ns&&(e.rel8ns=v(r.rel8ns)),e}f(Pt,"toDto");function vr(r){let t=`[${vr.name}]`;try{return Ee&&console.log(`${t} starting... (I: 57aef93fc6cc2309523b5c72a6b11823)`),!!r&&typeof r.ib=="string"}catch(e){throw console.error(`${t} ${e.message}`),e}finally{Ee&&console.log(`${t} complete.`)}}f(vr,"isIbGib");function Lt({ibGib:r,data:t,timestamp:e}){let o=`[${Lt.name}]`;try{Ee&&console.log(`${o} starting... (I: 35cb68744bcf6139d78e37de644fad23)`),e=e||t?.timestamp||r?.data?.timestamp;let n=r?.data?.timestampMs||t?.timestampMs;if(!e){let s=`${o} 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()!==ao)return Ee&&console.log(`${o} valid timestampInTicks string (I: 7069a1c3047f3bbc92b78674b20f5b23)`),{valid:!0,date:a,utc:a.toUTCString(),ticks:a.getTime().toString(),ms:n};{let i=`${o} 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()!==ao)return{valid:!0,date:s,utc:s.toUTCString(),ticks:s.getTime().toString(),ms:n};{let a=`${o} 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(`${o} expected data.timestamp to be a string but is a number (W: 9d786f4d4e8d4279b5af7bee19bf721b)`);let s=new Date;if(s.setTime(e),s.toString()!==ao)return{valid:!0,date:s,utc:s.toUTCString(),ticks:s.getTime().toString(),ms:n};{let a=`${o} 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=`${o} 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=`${o} unknown typeof timestamp (${typeof e}). (E: 12458a9c16c84e4f859b5771a30dd2ef)`;return console.error(s),{valid:!1,emsg:s}}}catch(n){throw console.error(`${o} ${E(n)}`),n}finally{Ee&&console.log(`${o} complete.`)}}f(Lt,"getTimestampInfo");async function Fe({addrs:r,readCache_graph:t,readCache_array:e,space:o}){let n=`[${Fe.name}]`;try{Ee&&console.log(`${n} starting... (I: 5db66871239dfa05182277f886a20926)`),t??={},e??=[];let s={...t};e.forEach(d=>s[w({ibGib:d})]=d);let a=Object.keys(t),i=r.filter(d=>!a.includes(d));if(i.length>0){Ee&&console.log(`${n} ${i.length} addrsNotFoundInCache: ${i} (I: fccbd18116ffb849f813aaebfc6c0826)`);let d=[o],l=i.concat();for(let b of d){let h=await X({addrs:l,space:b});if(h.success&&h.ibGibs&&h.ibGibs.length===l.length)h.ibGibs.forEach(p=>s[w({ibGib:p})]=p),l=[];else if(h.ibGibs&&h.ibGibs.length>0){if(l=l.filter(p=>!h.ibGibs.some(u=>w({ibGib:u})===p)),l.length===0)break}else Ee&&console.log(`${n} no addrs found in space (${b.ib}). trying next space. (I: 4f99d8bacbb10ab3f8737a752564b326)`)}if(l.length>0)throw new Error(`could not get all addrs from cache or spaces. addrsStillNotFound: ${l}. spaces: ${d.map(b=>b.ib).join("|")} (E: 0c6418f83dd85bda886e56f5b98f3126)`)}let c=[];for(let d of r){let l=s[d];if(!l)throw new Error(`(UNEXPECTED) allIbGibs_graph doesn't have addr? We're expecting logic to preclude this at this point. addr: ${d} (E: f68e1d236ae5e3eb08da9933c8230626)`);c.push(l)}return c}catch(s){throw console.error(`${n} ${E(s)}`),s}finally{Ee&&console.log(`${n} complete.`)}}f(Fe,"getIbGibsFromCache_fallbackToSpaces");var Lr=!1,Fl="space_gib_db",jl="space_gib_store",Hl="space_gib_api_key";var Xl="agent";var Ku=Vt(Xl);var Wu={dbName:Fl,storeName:jl,additionalStoreNames:[Oa],apiKeyName:Hl};var Oi="0.0.2";var Rt=!1,Ju="[web^gib timer]",cs="ibgib";var ql="agent",Zu="body-outline",Qu="This tag tracks the active agents for the current local user space.",eg=Vt(ql),Di="#78f87e88",vi="#78f87e10",Li="#ffffff";var tg="AUTOMATED_TEXT";var Qe=!1;function Pi(r){return new Promise((t,e)=>{let o=new Blob([r],{type:"application/octet-stream"}),n=new FileReader;n.onload=()=>{let a=n.result.split(",")[1];t(a)},n.onerror=s=>e(s),n.readAsDataURL(o)})}f(Pi,"uint8ArrayToBase64");async function Ri(r){let t=`data:application/octet-stream;base64,${r}`,n=await(await(await fetch(t)).blob()).arrayBuffer();return new Uint8Array(n)}f(Ri,"base64ToUint8Array");async function _o({graph:r}){let t=`[${_o.name}]`;try{Qe&&console.log(`${t} starting... (I: 4ddb8803cf68e1d3d35f60680cb69825)`);let e=JSON.parse(JSON.stringify(r));for(let n in e)r[n].data instanceof Uint8Array&&(e[n].data={_dataType:"Uint8Array_Base64",value:await Pi(r[n].data)});let o=JSON.stringify(e);return Qe&&console.log(`${t} jsonString.length: ${o.length} (I: 56dec8ad0931ab8ba9b5ca3d4e66be25)`),o}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{Qe&&console.log(`${t} complete.`)}}f(_o,"serializeGraphToString");async function To({jsonString:r}){let t=`[${To.name}]`;try{Qe&&console.log(`${t} starting... (I: 52e1a1fb1adcc75168fbc6d819868825)`);let o=JSON.parse(r,f((n,s)=>(s&&s._dataType==="Uint8Array_Base64",s),"reviver"));for(let n in o){let s=o[n].data;s&&s._dataType==="Uint8Array_Base64"&&(o[n].data=await Ri(s.value))}return o}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{Qe&&console.log(`${t} complete.`)}}f(To,"deserializeStringToGraph");async function Ui(r){let t=`[${Ui.name}]`;try{Qe&&console.log(`${t} starting... (I: 8d306868b718596fe8f562bd5118d825)`);let e=await _o({graph:r}),o=new TextEncoder().encode(e),s=new Response(o).body.pipeThrough(new CompressionStream("gzip"));return await new Response(s).blob()}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{Qe&&console.log(`${t} complete.`)}}f(Ui,"compressIbGibToBlob");async function Kl(r){let t=r.stream().pipeThrough(new DecompressionStream("gzip")),e=await new Response(t).text();return await To({jsonString:e})}f(Kl,"decompressIbGibFromBlob");async function ls({graph:r}){let t=`[${ls.name}]`;try{Qe&&console.log(`${t} starting... (I: 1352f8540c08f0b725952df8f18c4825)`);let o=await(await Ui(r)).arrayBuffer(),n=new Uint8Array(o);return await Pi(n)}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{Qe&&console.log(`${t} complete.`)}}f(ls,"compressIbGibGraphToString");async function ds({compressedBase64:r}){let t=`[${ds.name}]`;try{Qe&&console.log(`${t} starting... (I: 5f3fa940a2c8f8d7b877978ae7f87825)`);let e=await Ri(r),o=new Blob([e],{type:"application/gzip"});return await Kl(o)}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{Qe&&console.log(`${t} complete.`)}}f(ds,"decompressIbGibGraphFromString");var ki="export";var Pr=!1;function Mi({data:r}){let t=`[${Mi.name}]`;try{Pr&&console.log(`${t} starting... (I: 158dfaeb9613a1531be71a9735184624)`);let{graphSize:e,dependencyGraphAsString:o,timestamp:n}=r,s=o.length,a=Ue(n),i=r.compression==="gzip"?"gzip":"raw";if(!r.timestamp)throw new Error("(UNEXPECTED) data.timestamp falsy? (E: 2f5bc88488cbf260634239a8a8396825)");let c=new Date(r.timestamp),{ib:d,gib:l}=H({ibGibAddr:r.contextIbGibAddr}),h=he({gib:l}).tjpGib??l,p=c.toISOString().slice(0,19).replace("T","_").replace(/:/g,"").replace(/ /g,"_");return`${ki} ${p} ${i} ${e} ${s} ${h}`}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{Pr&&console.log(`${t} complete.`)}}f(Mi,"getRawExportIb");async function fs({ibGib:r,metaspace:t,space:e,compress:o,live:n,ignoreErrors:s}){let a=`[${fs.name}]`;try{if(Pr&&console.log(`${a} starting... (I: 0b6ba8608ba8bde0682a0936b9a01825)`),!r)throw new Error("(UNEXPECTED) ibGib falsy? (E: d2898eea744360865f0da5fb91baae22)");let i=w({ibGib:r}),c=[],d=await J({ibGib:r})??[];if(d.length>0){let y=`ibGib had validation errors: ${d} (E: 84890bbc0598192498178a98ae299825)`;if(s)c.push({errorMsg:y,ibGibAddr:i});else throw new Error(y)}let l=await t.getDependencyGraph({ibGib:r,live:n,space:e}),b=o?await ls({graph:l}):await _o({graph:l}),h=We({ibGib:r,defaultIfNone:"incomingAddr"})??i,p=new Date,u={contextIbGibAddr:i,tjpAddr:h,dependencyGraphAsString:b,graphSize:Object.keys(l).length,timestamp:$e(p),timestampMs:p.getMilliseconds()};o&&(u.compression="gzip");let g={ib:Mi({data:u}),data:u},m=await V({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(l),errors:c.length>0?c:void 0}}catch(i){throw console.error(`${a} ${E(i)}`),i}finally{Pr&&console.log(`${a} complete.`)}}f(fs,"getRawExportIbGib");var Bi=Rt;async function br(r){let t=`[${br.name}]`;try{Bi&&console.log(`${t} starting... (I: 037b228a2568181cd3eb25dba4e03225)`);let e=document.getElementById("fullscreen-dialog"),o=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||!o||!n||!s||!a||!i||!c)throw new Error("(UNEXPECTED) One or more dialog elements not found in DOM (E: 578e37c0271cc57a99e95e780ad18a25)");n.textContent=r.title||"",[...s.childNodes].forEach(b=>s.removeChild(b)),(r.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=r.okButtonTitle||"OK";let l=f(b=>{(b.key==="Enter"||b.key===`
10
+ `)&&b.ctrlKey&&i.click()},"onKeypress");return r.prompt||r.showInput?(a.addEventListener("keypress",l),r.showInput?(a.autofocus=!0,a.value=r.defaultValue??"",a.addEventListener("keypress",b=>{b.key==="Enter"&&i.click()}),r.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=r.cancelButtonTitle||"Cancel"):(a.classList.add("collapsed"),c.style.display="none"),new Promise(b=>{let h=f(()=>{(r.prompt||r.showInput)&&a.removeEventListener("keypress",l),i.removeEventListener("click",p),c.removeEventListener("click",u),e.removeEventListener("close",g)},"removeEventListeners"),p=f(()=>{h();let m=r.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(),be(1e3).then(()=>{o.scrollTo({top:0,behavior:"smooth"})})})}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{Bi&&console.log(`${t} complete.`)}}f(br,"showFullscreenDialog");var pe=Rt;async function Wl({metaspace:r,space:t}){let e=`[${Wl.name}]`;try{pe&&console.log(`${e} starting... (I: 2ccb79537a75e7896bace84e6c710d25)`);let o=await r.getSpecialIbGib({type:no.tags,space:t});if(!o)throw new Error(`tagsIbGib not found in metaspace. space: ${t?t.ib:"default local user space"} (E: 4734c510a411274315c0add8f70e1925)`);return o}catch(o){throw console.error(`${e} ${E(o)}`),o}finally{pe&&console.log(`${e} complete.`)}}f(Wl,"getTagsIbGib");function hs({scope:r,ibGib:t,ibGibAddr:e,defaultNameIfError:o}){let n=`[${hs.name}]`;try{if(!t&&!e)throw new Error(`${n} Must provide either ibGib or ibGibAddr. (E: genuuid)`);r.includes(" ")&&(console.warn(`${n} scope includes one or more spaces. These will be converted to double underscores. (W: 1554a81454e8ae0a6858ea5dd17f8925)`),r=r.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 l=t.rel8ns.ancestor.filter(h=>ae({gib:H({ibGibAddr:h}).gib}));if(l.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=l.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(),pe&&console.log(`${n} ancestorIbOrAtom: ${i} (I: genuuid)`);let d=`${i}_${r}index`;return pe&&console.log(`${n} indexName: ${d} (I: genuuid)`),d}catch(s){if(o)return console.warn(`${n} error happened but defaultNameIfError (${o}) provided. So will return this value. error that was thrown: ${E(s)}`),o;throw console.error(`${n} ${E(s)}`),s}}f(hs,"getIndexNameFromIbGib");async function Yl({scope:r,ibGib:t,metaspace:e,space:o,skipGetLatest:n}){let s=`[${Yl.name}]`;try{if(pe&&console.log(`${s} starting... (I: f19dc86aab380fe809aef27ccc7a7425)`),!r)throw new Error("scope required to be a non-empty string (E: 73e702495c38c7d8747d1cf8850af825)");if(!t)throw new Error("ibGib required (E: genuuid)");let a=hs({scope:r,ibGib:t}),i=We({ibGib:t,defaultIfNone:"incomingAddr"}),c=f(async()=>{let l=await e.getSpecialIbGib({type:a,space:o,initialize:!1,dontWarnIfNotExist:!0,lock:!0});if(!l||!l.data){pe&&console.log(`${s} special ${r} index ibGib not found for indexSpecialIbGibType (${a}). No coupled ibgib registered, returning undefined. (I: genuuid)`);return}let h=(l.data.coupleMap??l.data.agentMap??{})[i];if(!h){pe&&console.log(`${s} No coupled ${r} 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:o})??h,u=await e.get({addrs:[p],space:o});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 at({scope:a,secondsValid:180,maxDelayMs:100,maxLockAttempts:1800,space:o,callerInstanceId:s+Ue(),fn:c})}catch(a){throw console.error(`${s} ${E(a)}`),a}finally{pe&&console.log(`${s} complete.`)}}f(Yl,"getLocalCoupledIbGibForDomainIbGib");async function Vl({scope:r,domainIbGib:t,localIbGib:e,metaspace:o,space:n}){let s=`[${Vl.name}]`;try{pe&&console.log(`${s} starting... (I: 217ae68e0c820e48f4c00409f7f14325)`);let a=hs({scope:r,ibGib:t}),i=We({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 at({scope:a,secondsValid:60,maxDelayMs:100,maxLockAttempts:600,space:n,fn:f(async()=>{let l=await o.getSpecialIbGib({type:a,space:n,initialize:!0,dontWarnIfNotExist:!0,lock:!1});if(!l)throw new Error(`${s} Could not get or create agent index ibGib.`);if(!l.data)throw new Error("(UNEXPECTED) agentSpecialIndex.data falsy? (E: 74299eed147debf6398ca37e7b8d5c25)");let b=l.data.coupleMap??l.data.agentMap,h=b?v(b):{},p=h[i];if(p)if(p===c){pe&&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 ke({src:l,dataToAddOrPatch:{coupleMap:h},dna:!1,linkedRel8ns:[ee.past],nCounter:!0}),g=u.newIbGib;await ne({resTransform:u,space:n});let m=le({type:a});await o.setConfigAddr({key:m,addr:w({ibGib:g}),space:n}),await o.registerNewIbGib({ibGib:g,space:n})},"fn")}),pe&&console.log(`${s} Registered domain ${i} with agent ${c}`)}catch(a){throw console.error(`${s} ${E(a)}`),a}finally{pe&&console.log(`${s} complete.`)}}f(Vl,"coupleDomainIbGibWithLocalIbGibViaIndex");function zt(){let r=`[${zt.name}]`;try{pe&&console.log(`${r} starting... (I: 890f53e984d69461d9f4ded8741fcc25)`);let t=globalThis[cs];return t||(console.log(`${r} initializing globalThis.${cs}... (I: 9d9ff1813448d9a1b82b0e5790a74825)`),t={}),t}catch(t){throw console.error(`${r} ${E(t)}`),t}finally{pe&&console.log(`${r} complete.`)}}f(zt,"getIbGibGlobalThis_IbGib");async function Ge({delayIntervalMs:r=50}={delayIntervalMs:50}){let t=`[${Ge.name}]`;try{pe&&console.log(`${t} starting... (I: 4acc22d08dd1100503f9b0423f302925)`);let e;for(;!e;)zt().metaspace&&(e=zt().metaspace),e||(console.log(`${t} metaspace still not initialized. delayIntervalMs: ${r} until next retry... (I: 490f77ac4ded1d7d3c0340e460404125)`),await be(r));return e}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{pe&&console.log(`${t} complete.`)}}f(Ge,"getGlobalMetaspace_waitIfNeeded");function zl({ibGibAddr:r,gib:t,ibGib:e,translucentAlpha:o=10}){let n=`[${zl.name}]`;try{pe&&console.log(`${n} starting... (I: 3b70af42d1c4f6ae91870f3a15c6c625)`),!r&&!t&&!e&&(t=M),t??=e?.gib??H({ibGibAddr:r}).gib;let s=he({gib:t});o??=10;let a="";if(s.isPrimitive)return{gib:t,gibInfo:s,punctiliarColor:Di,punctiliarColorTranslucent:vi,punctiliarColorContrast:Li};a=s.tjpGib??s.punctiliarHash??t;let[i,c,d]=Fi(o,s.punctiliarHash??t),[l,b,h]=s.tjpGib?Fi(o,s.tjpGib):[void 0,void 0,void 0];return{gib:t,gibInfo:s,punctiliarColor:i,punctiliarColorTranslucent:c,punctiliarColorContrast:d,tjpColor:l,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{pe&&console.log(`${n} complete.`)}}f(zl,"getDeterministicColorInfo");function Fi(r,t){function e(i){let c=i.concat().replace("#","");var d=parseInt(c.substr(0,2),16),l=parseInt(c.substr(2,2),16),b=parseInt(c.substr(4,2),16),h=(d*299+l*587+b*114)/1e3;return h>=128?"#000000":"#FFFFFF"}f(e,"getContrastColor");let o="";if(r||r===0){if(r<0||r>100)throw new Error("alpha must be between 0 and 100 (E: c78faeb1477482c739b03dd32d2e1825)");r===100?o="":r>=0&&r<10?o=`0${r}`:o=r.toString()}let n=`#${t.substring(0,6)}`,s=`#${t.substring(0,6)}${o}`,a=e(n);return[n,s,a]}f(Fi,"getColorStrings");var Ce=Rt;function Hi(r){return new TextDecoder().decode(r)}f(Hi,"uint8ArrayToString");var ji=class r{static{f(this,"PathUtilsHelper")}lc=`[${r.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 o="";for(let n=0;n<t.length;n++){let s=t[n];s===".."?o=o.split("/").slice(0,-1).join("/"):(s.startsWith("/")&&(s=s.slice(1)),s.endsWith("/")&&(s=s.slice(0,-1)),o+=(n>0?"/":"")+s)}return o}dirname(t){return t.split("/").slice(0,-1).join("/")}basename(t,e){return t.split("/").pop()??""}};async function Jl({msg:r,title:t,confirm:e,noNewLine:o,rl:n,defaultValue:s,dontCloseRl:a,cancelable:i}){let c=`[${Jl.name}]`;try{if(!r)throw new Error("msg required (E: 7f4d67bca4cf98ea95fa110aabc98924)");let d,l=0,b=5;do{if(l++,l>=b)throw new Error("max attempts reached (E: 1ef20ae955622d4b39479f3da91a1d25)");await be(50),d=await br({title:t||"Prompt for Info",msg:r,prompt:!0,showInput:!0,isPassword:!1,defaultValue:s})}while(d===void 0&&!i);return d??""}catch(d){debugger;throw console.error(`${c} ${E(d)}`),d}}f(Jl,"promptForText");async function Zl({msg:r,confirm:t}){let e=`[${Zl.name}]`;try{Ce&&console.log(`${e} starting... (I: 795a4ce348ddb9a5119770f4c572ac24)`);let o,n=!0,s=0,a=5;do{if(s++,s>=a)throw new Error("max attempts reached (E: d4166b4bf37aff0c6d44567792e9ad25)");if(await be(50),o=await br({title:n?"Shh...":"Secrets didn't match, try again...",msg:r||"Enter Your Secret...",prompt:!0,showInput:!0,isPassword:!0,defaultValue:void 0}),o===void 0)throw new Error("user cancelled (E: 91519d04378e84106f3df8eb36d99725)");if(t){await be(250);let i=await br({title:"Shh...",msg:"Confirm...",prompt:!0,showInput:!0,isPassword:!0,defaultValue:void 0});i===void 0&&(o=void 0),o!==i&&(o=void 0,n=!1,await be(250))}}while(o===void 0);return o}catch(o){throw console.error(`${e} ${E(o)}`),o}finally{Ce&&console.log(`${e} complete.`)}}f(Zl,"promptForSecret");async function Ql({msg:r,title:t,skipHitEnterToContinue:e}){let o=`[${Ql.name}]`;try{if(!r)throw new Error("msg required (E: ffcf7dd00324df7cea2792223d229524)");try{t??="",await be(50),await br({title:t,msg:r})}catch(n){throw n}}catch(n){throw console.error(`${o} ${E(n)}`),n}}f(Ql,"alertUser");async function ed({exportIbGibJsonString:r,metaspace:t}){let e=`[${ed.name}]`;try{debugger;if(Ce&&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(r)}catch(d){let l=`Error during parse JSON. error: ${E(d)} (E: genuuid)`,b=new Error(l);throw b.cause=d,b}try{let d=await J({ibGib:n})??[];if(d.length>0)throw new Error(`validation errors when validating the parsed ibgib that should be a RawExportIbGib_V1: ${d} (E: 8ba178d3b26e8eca28a67c182fe16825)`);if(s=n,!s.data)throw new Error("(UNEXPECTED) rawExportIbGib.data falsy? (E: ef1824d1cca5584ab8e34288346e9825)")}catch(d){let l=`Error during parse JSON. error: ${E(d)} (E: genuuid)`,b=new Error(l);throw b.cause=d,b}let a;if(s.data.compression)switch(s.data.compression){case"gzip":a=await ds({compressedBase64:s.data.dependencyGraphAsString});break;default:throw new Error(`unknown value of rawExportIbGib.data.compression: ${s.data.compression} (E: 784672fae568312d887ddbb841199925)`)}else a=await To({jsonString:s.data.dependencyGraphAsString});let i={};for(let[d,l]of Object.entries(a)){let b=await J({ibGib:l})??[];b.length>0&&(i[d]=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(o){throw console.error(`${e} ${E(o)}`),o}finally{Ce&&console.log(`${e} complete.`)}}f(ed,"getRawExportIbGibAndGraphFromJsonString");async function td({ibGib:r,compress:t,metaspace:e,space:o}){let n=`[${td.name}]`;try{if(Ce&&console.log(`${n} starting... (I: 623d9463d919683be81f749821a95825)`),ae({ibGib:r}))throw new Error("ibGib is primitive. Can't export primitive. (E: dd42c42e9fda0707e81c692af1a2a225)");let s=await fs({ibGib:r,live:!0,compress:t,metaspace:e,space:o}),{rawExportIbGib:a,errors:i}=s;if((i??[]).length>0)throw new Error(`Export had errors: ${i} (E: 05faf83f25d3449ab809dfd24eeaf825)`);let c=JSON.stringify(a),d="data:text/json;charset=utf-8,"+encodeURIComponent(c),b=`${w({ibGib:a})}.json`,h=document.createElement("a");h.setAttribute("style","none"),h.setAttribute("href",d),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{Ce&&console.log(`${n} complete.`)}}f(td,"exportIbGib");function rd(){let r=`[${rd.name}]`;try{Ce&&console.log(`${r} starting... (I: 62a29f9982b4b5ecd91ff58ca4dd6825)`);let t=zt();if(!t.storeName_hack)throw new Error("(UNEXPECTED) global store name falsy? (E: 3b9b680f6a980debbb877c9a13fb2625)");return t.storeName_hack}catch(t){throw console.error(`${r} ${E(t)}`),t}finally{Ce&&console.log(`${r} complete.`)}}f(rd,"getGlobalStoreName");function od(){let r=`[${od.name}]`;try{Ce&&console.log(`${r} starting... (I: 8c8f08728fc7384f87697377358cc825)`);let t=zt();if(!t.dbName_hack)throw new Error("(UNEXPECTED) global db name falsy? (E: 3aa028d5e4088f3f3841aae94ac02825)");return t.dbName_hack}catch(t){throw console.error(`${r} ${E(t)}`),t}finally{Ce&&console.log(`${r} complete.`)}}f(od,"getGlobalDbName");function nd(){let r=`[${nd.name}]`;try{Ce&&console.log(`${r} starting... (I: 59a2510a85051f97ed15fbc8825b6825)`);let t=zt();if(!t.apiKeyName_hack)throw new Error("(UNEXPECTED) global api key name falsy? (E: 1782e812f0c87f54b8059468a5b60125)");return t.apiKeyName_hack}catch(t){throw console.error(`${r} ${E(t)}`),t}finally{Ce&&console.log(`${r} complete.`)}}f(nd,"getGlobalIndexedDbKey_APIKey");async function ps({infos:r}){let t=`[${ps.name}]`;try{Ce&&console.log(`${t} starting... (I: 4d41880fb748ee2302a624a255665825)`);for(let e of r){let{dbName:o,storeNames:n}=e;await gs({dbName:o})||await So({dbName:o});for(let a of n)await us({dbName:o,storeName:a})}}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{Ce&&console.log(`${t} complete.`)}}f(ps,"initAppStorage");var xe=Rt,Xi=0;async function So({dbName:r,storeName:t,version:e,logalot:o=!1}){let n=`[${So.name}][${r}][${t??"no store name"}]`,s=crypto.randomUUID();o&&console.time(n+s);let a;try{o&&console.log(`${n} starting... (I: f35d4e1ba37252f14c8532fb861b1125)`),await new Promise((c,d)=>{try{o&&console.log(`${n} starting... (I: 0aeddd9376daa0a044677ce4cf8a4c24)`),o&&console.timeLog(n+s,"opening... (I: e748b4ddb445d77cb10a7ba158b49125)");let l=indexedDB.open(r,e);Xi++,console.log(`${n} initRequestCount: ${Xi} (I: 294d5f0b12ffe5512bacebe891824d25)`);let b;l.onupgradeneeded=h=>{try{a=h.target.result,o&&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)`),d(p)}},l.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)},l.onsuccess=h=>{try{o&&console.log("init success (I: 297a5a71e405a0b56413af813f248d24)"),o&&console.timeLog(n+s,"onupgradeneeded... (I: e748b4ddb445d77cb10a7ba158b49125)"),a=h.target.result,t&&(b??=a.objectStoreNames.contains(t),o&&console.log(`${n} ${r} store "${t}" ${b?"already exists":"does not exist"}. (I: db64712bc69c5287b1cf77af1fc13d24)`)),c()}catch(p){console.error(`${n}[openDBRequest.onsuccess] ${E(p)}`),d(p)}},l.onerror=h=>{debugger;console.error(`${n}[initRequest.onerror] ${E(l.error)} (E: 74cf09e9fba2dd9e41225e943c331124)`),d(l.error)}}catch(l){console.error(`${n} ${E(l)}`);debugger;d(l)}finally{o&&console.log(`${n} complete.`)}})}catch(i){throw console.error(`${n} ${E(i)}`),i}finally{a&&(o&&console.log(`${n} closing db ${r}... (I: 3f1c18eec567ea63f3927eef0f038925)`),a.close(),o&&(console.log(`${n} closing db ${r} complete. (I: bc3b2f504245d6203dbba6bd65d30325)`),console.timeLog(n+s,"db closed. (I: e748b4ddb445d77cb10a7ba158b49125)"))),o&&(console.log(`${n} complete.`),console.timeEnd(n+s))}}f(So,"initializeStorage");async function qi({dbName:r,logalot:t=!1}){let e=`[${qi.name}]`,o=crypto.randomUUID();t&&console.time(e+o);try{return t&&console.log(`${e} starting... (I: 8516795b20529d19eb6923defd7a0f24)`),(await indexedDB.databases()).filter(s=>s.name===r).at(0)}catch(n){console.error(`${e} ${E(n)}`)}finally{t&&console.timeEnd(e+o),t&&console.log(`${e} complete.`)}}f(qi,"storageGetDBInfo");async function us({dbName:r,storeName:t,logalot:e=!1}){let o=`[${us.name}]`,n=crypto.randomUUID();e&&console.time(o+n);let s;try{if(e&&console.log(`${o} starting... (I: 029f7caa8ea5ea08a865f3924c82b624)`),!(await indexedDB.databases()).filter(b=>b.name===r).at(0))throw new Error(`db (${r}) does not exist. can't create store (${t}) (E: 5b15f7aed6f7068d077b2c7ebcbe8524)`);let i=!1;if(e&&console.timeLog(o+n),await new Promise((b,h)=>{let p=indexedDB.open(r);p.onsuccess=u=>{s=u.target.result,i=s.objectStoreNames?.contains(t),e&&console.timeLog(o+n,"open db request"),b()},p.onerror=u=>{debugger;console.error(`${o}[openDBRequest.onerror] ${E(p.error)} (E: 63695744e9e59ff8019e04ceeb8e2524)`),h(p.error)}}),e&&console.timeLog(o+n),i){e&&console.log(`${o} store ${t} already existed. (I: a2263b510c18240fc59fca54e3892324)`);return}let c=await qi({dbName:r,logalot:e});if(e&&console.timeLog(o+n,"storageGetDBInfo complete"),!c)throw new Error(`db (${r}) does not exist. can't create store (${t}) (E: c771db13fa28f67079aad45e1ab7e624)`);let d=c.version;if(!d)throw new Error(`db (${r}) has no version. can't create store (${t}) (E: 3d2ec52853ad99f92b19ac5aa7fbfe24)`);let l=d+1;if(e&&console.log(`${o} creating store ${t} with version ${l} (I: 312b79f28243c650cf38935114f21e24)`),s)s.close(),s=void 0;else throw new Error("(UNEXPECTED) how did we get here with db falsy? (E: b561784879e19bac54b1c4936aff0c25)");await So({dbName:r,storeName:t,version:l,logalot:e})}catch(a){throw console.error(`${o} ${E(a)}`),a}finally{s&&(e&&console.log(`${o} closing db ${r}... (I: 3f1c18eec567ea63f3927eef0f038925)`),s.close(),e&&console.log(`${o} closing db ${r} complete. (I: bc3b2f504245d6203dbba6bd65d30325)`)),e&&console.timeLog(o+n),e&&console.log(`${o} complete.`)}}f(us,"storageCreateStoreIfNotExist");async function bs({dbName:r,version:t,storeName:e,key:o,value:n,logalot:s=!1}){let a=`[${bs.name}]`,i;try{s&&console.log(`${a} starting... (I: bf7316c244888cb8ead2d3aac1d9f625)`),await new Promise((d,l)=>{try{s&&console.log(`${a} starting... (I: 81df59e3961d711ce5d8f2ae3e2f3824)`);let b=indexedDB.open(r,t);b.onsuccess=h=>{i=h.target.result;try{let p=i.transaction(e,"readwrite").objectStore(e),u={key:o,value:n};p.put(u),d()}catch(p){console.error(`${a}[putRequest.onsuccess] ${E(p)}`),l(p)}},b.onerror=h=>{debugger;console.error(`${a}[putRequest.onerror] ${E(b.error)} (E: 7a946d99ede2b248df4dcfea4ac99724)`),l(b.error)}}catch(b){console.error(`${a} ${E(b)}`),l(b)}finally{s&&console.log(`${a} complete.`)}})}catch(c){throw console.error(`${a} ${E(c)}`),c}finally{i&&(s&&console.log(`${a} closing db ${r}... (I: 438c6edced94b83a3478c71b08c6c325)`),i.close(),s&&console.log(`${a} closing db ${r} complete. (I: 0d081553b1eb53c65ade2cedb802cf25)`)),s&&console.log(`${a} complete.`)}}f(bs,"storagePut");async function Ao({dbName:r,version:t,storeName:e,key:o,logalot:n=!1}){let s=`[${Ao.name}]`,a;try{return n&&console.log(`${s} starting... (I: f8ba7cd5801918a8580e91b7c90aa525)`),await new Promise((d,l)=>{try{n&&console.log(`${s} starting... (I: 24163c4a11c8712097db45febaf9c724)`);let b=indexedDB.open(r,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)}`),l(g);return}let u=p.get(o);u.onsuccess=g=>{try{let m=g.target?.result?.value??void 0;if(!m){d(m);return}if(n&&console.log("Retrieved value:",m),m instanceof Uint8Array)d(Hi(m));else{if(typeof m!="string")throw new Error("(UNEXPECTED) truthy, non-Uint8Array value is not a string? (E: 6a4ec24e2e5d9848f8b542bc2661dc24)");d(m)}}catch(m){l(m)}},u.onerror=g=>{debugger;let m=u.error;console.error(`${s}[openDBRequest.onsuccess][getRequest.onerror] ${E(m)}`),l(m)}},b.onerror=h=>{debugger;console.error(`${s}[openDBRequest.onerror] ${E(b.error)} (E: 074963a908fa9a075f01c73cae829224)`),l(b.error)}}catch(b){console.error(`${s} ${E(b)}`),l(b)}finally{n&&console.log(`${s} complete.`)}})}catch(i){throw console.error(`${s} ${E(i)}`),i}finally{a&&(n&&console.log(`${s} closing db ${r}... (I: a938fc22dfdc76b15f6926bc4d458225)`),a.close(),n&&console.log(`${s} closing db ${r} complete. (I: 18f2ec1557bc83ec4e2c5d5e72264525)`)),n&&console.log(`${s} complete.`)}}f(Ao,"storageGet");async function gs({dbName:r,store:t}){let e=`[${gs.name}]`,o;try{return xe&&console.log(`${e} starting... (I: 2b4373affa3841220f0b7ca690406624)`),(await window.indexedDB.databases()).some(a=>a.name===r)?t?await new Promise((a,i)=>{let c=indexedDB.open(r);c.onsuccess=d=>{o=d.target.result;let l=o.objectStoreNames.contains(t);a(l)},c.onerror=d=>{debugger;o=c.result;let{error:l}=d.target;console.error(`${e}[openDBRequest.onerror] ${E(c.error)} (E: c783fe607451e46c1feae3a81e0f7924)`),i(l)}}):!0:!1}catch(n){throw console.error(`${e} ${E(n)}`),n}finally{o&&(xe&&console.log(`${e} closing db ${r}... (I: 8782d9eea285cf9eb638d493a421a625)`),o.close(),xe&&console.log(`${e} closing db ${r} complete. (I: 76a0c5dea2643e2bb84c82c8446a8125)`)),xe&&console.log(`${e} complete.`)}}f(gs,"storageDBExists");async function sd({dbName:r,storeName:t,pathToRm:e}){let o=`[${sd.name}]`,n=xe;xe&&console.log(`${o} starting... (I: c7e4cb759789ece0a8189d7dfb4d2a24)`);let s;return new Promise((a,i)=>{try{if(!r)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(r);c.onerror=()=>{debugger;c.result&&c.result.close(),console.error(`${o}[openDBRequest.onerror] ${E(c.error)} (E: 4c5ab71a765e61b4292008fd4fafe324)`),i(c.error)},c.onsuccess=()=>{s=c.result;let l=s.transaction(t,"readwrite").objectStore(t),b=IDBKeyRange.lowerBound(e),h=l.openCursor(b);h.onerror=()=>{debugger;console.error(`${o}[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(`${o}[deleteRequest.onerror] ${E(g.error)} (E: abc031c53e5387322cd8909b3ada9b24)`),i(g.error)},u.continue()}else xe&&console.log(`${o} rmCount: ${p} (I: e4bc613a5514c0942484b79267e16724)`),a();else xe&&console.log(`${o} cursor is falsy, so either we have no more records or had no records to begin with. (I: 9ff3aec6274416501a7baf6dcc5f2624)`),a()}catch(p){console.error(`${o}[openCursorRequest.onsuccess] ${E(p)}`),i(p)}}}}catch(c){debugger;console.error(`${o} ${E(c)}`),i(c)}}).finally(()=>{s&&(xe&&console.log(`${o} closing db ${r}... (I: 39b4ba83de4bdfd541e3384ebab27425)`),s.close(),xe&&console.log(`${o} closing db ${r} complete. (I: e4015b9436c4b2bc0ccf0e11e2037925)`)),xe&&console.log(`${o} complete.`),xe=n})}f(sd,"storageRmRF");async function ad({dbName:r,storeName:t,dirPath:e,withFileTypes:o=!1}){let n=`[${ad.name}]`,s;try{return await new Promise((c,d)=>{let l=indexedDB.open(r);l.onerror=()=>{debugger;d(l.error)},l.onsuccess=()=>{s=l.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,y=[];g.onerror=()=>{debugger;console.error(`${n}[openCursorRequest.onerror] ${E(g.error)}`),d(g.error)},g.onsuccess=()=>{try{let I=g.result;if(I){let T=I.key.toString();if(T.startsWith(p)&&T!==p){let $=T.substring(p.length),_=$.split("/")[0];if(o){let A=$.substring(_.length).startsWith("/");y.push({name:_,isDirectory:f(()=>A,"isDirectory"),isFile:f(()=>!A,"isFile"),isBlockDevice:f(()=>!1,"isBlockDevice"),isCharacterDevice:f(()=>!1,"isCharacterDevice"),isSymbolicLink:f(()=>!1,"isSymbolicLink"),isFIFO:f(()=>!1,"isFIFO"),isSocket:f(()=>!1,"isSocket")})}else m.add(_);I.continue()}else T.startsWith(p)?I.continue():c(o?y:Array.from(m))}else c(o?y:Array.from(m))}catch(I){console.error(`${n}[openCursorRequest.onsuccess] ${E(I)}`),d(I)}}}})}catch(a){throw console.error(`${n} ${E(a)}`),a}finally{s&&(xe&&console.log(`${n} closing db ${r}... (I: 39b4ba83de4bdfd541e3384ebab27425)`),s.close(),xe&&console.log(`${n} closing db ${r} complete. (I: e4015b9436c4b2bc0ccf0e11e2037925)`))}}f(ad,"storageReaddir");var hr=Lr;async function id(r){let t=`[${id.name}]`;try{hr&&console.log(`${t} starting... (I: 1905af1827a34ca8a5507fe0c5085b01)`),await ps({infos:[{dbName:r.dbName,storeNames:[r.storeName,...r.additionalStoreNames??[]]}]})}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{hr&&console.log(`${t} complete.`)}}f(id,"initIbGibStorage");function Ki(r){let t=`[${Ki.name}]`;try{hr&&console.log(`${t} starting... (I: 7be20d161bb14a498c44a42d3193bec1)`),globalThis.ibgib||(globalThis.ibgib={dbName_hack:r.dbName,apiKeyName_hack:r.apiKeyName,storeName_hack:r.storeName}),globalThis.ibgib.spaceGib||(globalThis.ibgib.spaceGib={version:Oi,spaceShim:{},fnDefaultGetAPIKey:f(async()=>await Ao({dbName:r.dbName,storeName:r.storeName,key:r.apiKeyName})??"","fnDefaultGetAPIKey"),dbName_hack:r.dbName,apiKeyName_hack:r.apiKeyName,storeName_hack:r.storeName})}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{hr&&console.log(`${t} complete.`)}}f(Ki,"initIbGibGlobalThis");function cd(r){if(!globalThis.ibgib?.spaceGib){if(!r)throw new Error("Global context not initialized and config not provided.");Ki(r)}return globalThis.ibgib.spaceGib}f(cd,"getIbGibGlobalThis_SpaceGib");async function ld(r){let t=`[${ld.name}]`;try{hr&&console.log(`${t} starting... (I: 3123b18eb29b480bad056a9a029b9ad4)`),await(await import(r)).bootstrapSpaceGibApp()}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{hr&&console.log(`${t} complete.`)}}f(ld,"dynamicallyLoadBootstrapScript");function dE(){let r=f(async()=>Ge(),"fnGetMetaspace"),t=new Promise(async(e,o)=>{try{let n=1e5,s=0,a;do{if(a=cd()?.bootstrapPromise,s++,s>n)break;await be(10)}while(a===void 0);if(!a)throw new Error("Timed out waiting for bootstrapPromise. (E: ceb3ba5261994476900e4a623c0e9d10)");await a,e()}catch(n){o(n)}});return{fnGetMetaspace:r,bootstrapPromise:t}}f(dE,"getComponentCtorArg");var dd="hash-reveal-v1",Ve={hash_reveal_v1:dd},Wi=Object.values(Ve);var fd="top-up",bd="replace-all",hd="consume",pd="delete-all",de={topUp:fd,replaceAll:bd,consume:hd,deleteAll:pd},Yi=Object.values(de);var Go=class{static{f(this,"KeystoneStrategy")}config;constructor(t){this.config=t}};var ud="recursive-salt-wrap",Rr={recursive_salt_wrap:ud},Vi=Object.values(Rr);var Co=!1;async function Es({masterSecret:r,kdfOpts:t}){let e=`[${Es.name}]`;try{Co&&console.log(`${e} starting... (I: 268e87ec311874ee6822bf459c5a5426)`);let o=t.strategy;switch(o){case Rr.recursive_salt_wrap:return await xo({masterSecret:r,salt:t.salt,rounds:t.rounds,algorithm:t.algorithm});default:throw new Error(`Unknown KDF strategy: ${o}. valid values: ${Vi.join(", ")} (E: c81258e9d9481eb0f88385a825193226)`)}}catch(o){throw console.error(`${e} ${E(o)}`),o}finally{Co&&console.log(`${e} complete.`)}}f(Es,"deriveKey");async function xo({masterSecret:r,salt:t,rounds:e,algorithm:o=Se.sha_256}){let n=`[${xo.name}]`;try{Co&&console.log(`${n} starting... (I: 850868e50aba82ff28c77da8169e4c26)`);let s=r;for(let a=0;a<e;a++)s=await Re({s:`${t}${s}${t}`,algorithm:o});return s}catch(s){throw console.error(`${n} ${E(s)}`),s}finally{Co&&console.log(`${n} complete.`)}}f(xo,"kdf_recursiveSaltWrap");var No=class r extends Go{static{f(this,"KeystoneStrategy_HashRevealV1")}async derivePoolSecret({masterSecret:t}){let e=`[${r.name}.${this.derivePoolSecret.name}]`;try{let{salt:o,rounds:n,algo:s}=this.config;return await xo({masterSecret:t,salt:o,rounds:n,algorithm:s})}catch(o){throw console.error(`${e} Error deriving pool secret: ${o.message}`),o}}async generateSolution({poolSecret:t,poolId:e,challengeId:o}){let n=`[${r.name}.${this.generateSolution.name}]`;try{let{rounds:s,algo:a}=this.config,i=o,c=t;for(let d=0;d<s;d++)c=await Re({s:`${i}${c}${i}`,algorithm:a});return{type:"hash-reveal-v1",poolId:e,challengeId:o,value:c}}catch(s){throw console.error(`${n} ${s.message}`),s}}async generateChallenge({solution:t}){let e=`[${r.name}.${this.generateChallenge.name}]`;try{let{rounds:o,algo:n}=this.config,{challengeId:s,value:a}=t,i=s,c=a;for(let d=0;d<o;d++)c=await Re({s:`${i}${c}${i}`,algorithm:n});return{id:s,type:"hash-reveal-v1",hash:c}}catch(o){throw console.error(`${e} ${o.message}`),o}}async validateSolution({solution:t,challenge:e}){let o=`[${r.name}.${this.validateSolution.name}]`;try{return t.type!=="hash-reveal-v1"||e.type!=="hash-reveal-v1"?(console.warn(`${o} Mismatched types provided.`),!1):(await this.generateChallenge({solution:t})).hash===e.hash}catch(n){return console.error(`${o} ${n.message}`),!1}}};var ze=class r{static{f(this,"KeystoneStrategyFactory")}static create({config:t}){let e=`[${r.name}.create]`;try{switch(t.type){case"hash-reveal-v1":return new No(t);default:throw new Error(`Unknown strategy type: ${t.type} (E: 4e3c2f7129a241c1b687555e678c1065)`)}}catch(o){throw console.error(`${e} ${o.message}`),o}}};var ms="keystone",ws=/^\w[\w\-.]*$/,$s=/^[a-zA-Z0-9\-_]{1,64}$/,ys=1e3,Oo="revoke",Ur="manage",gd="sign",pr="sync",Ut="connect",Is={REVOKE:Oo,MANAGE:Ur,SIGN:gd,SYNC:pr,CONNECT:Ut},LE=Object.values(Is);var _s=Oo,zi=Ur;var It=Ut,ur=pr;var Ts=200,As=2,Ss=2,Gs=5,Cs=de.topUp,Ji=Se.sha_256,Zi=1,Qi=2e3,ec=5,tc=5,rc=16,oc=de.replaceAll,nc=Se.sha_512,sc=10,Do=50;var Z=!1;async function dt({ibGib:r,ibGibs:t,ibGibAddr:e,ibGibAddrs:o,live:n,gotten:s,tjpAddrsAlreadyAnalyzed:a,skipAddrs:i,skipRel8nNames:c,onlyRel8nNames:d,maxRetries:l,msBetweenRetries:b,space:h,timeLogName:p,mapTjpAddrToLatestAddrsInSpace:u}){let g=`[${dt.name}]`;try{Z&&console.log(`${g} starting... (I: c2a4426c22e849611ca0cedabe683a22)`);let m=await kr({ibGib:r,ibGibs:t,ibGibAddr:e,ibGibAddrs:o,live:n,gotten:s,tjpAddrsAlreadyAnalyzed:a,skipAddrs:i,skipRel8nNames:c,onlyRel8nNames:d,maxRetries:l,msBetweenRetries:b,space:h,timeLogName:p,mapTjpAddrToLatestAddrsInSpace:u});if(Object.values(m).filter(y=>y.ib.startsWith("comment ")).forEach(y=>{console.table(y)}),Z){console.log(`${g} graph size: ${Object.keys(m).length} (I: c6cb5e7e1e2611d35b9006fac6503d22)`);let y=Object.values(m).filter(I=>I.ib.startsWith("comment ")||I.ib.startsWith("pic ")).map(I=>I.ib);eo(y).forEach(I=>console.log(I))}return m}catch(m){throw console.error(`${g} ${m.message}`),m}finally{Z&&console.log(`${g} complete.`)}}f(dt,"getDependencyGraph");async function ac({ibGib:r,ibGibs:t,ibGibAddr:e,ibGibAddrs:o,live:n,gotten:s,tjpAddrsAlreadyAnalyzed:a,skipAddrs:i,skipRel8nNames:c,onlyRel8nNames:d,maxRetries:l,msBetweenRetries:b,space:h,timeLogName:p,mapTjpAddrToLatestAddrsInSpace:u}){let g=`[${ac.name}]`;try{if(Z&&console.log(`${g} starting... (I: bd6807477f679345df9dddefe0b4e922)`),!h)throw new Error("space required. (E: 9f38166ab70340cb919174f8d26af909)");if(!r&&!e&&(t??[]).length===0&&(o??[]).length===0)throw new Error("either ibGib/s or ibGibAddr/s required. (E: b6d08699651f455697f0d05a41edb039)");return c=c||[],i=i||[],s=s||{},a=a||[],o=(o??[]).filter(m=>!ae({gib:H({ibGibAddr:m}).gib})).filter(m=>!i.includes(m)),t=(t??[]).filter(m=>!ae({ibGib:m})).filter(m=>!i.includes(w({ibGib:m}))),r&&!ae({ibGib:r})&&!t.some(m=>m.gib===r.gib)&&!i.includes(w({ibGib:r}))&&t.push(r),e&&!ae({gib:H({ibGibAddr:e}).gib})&&!o.includes(e)&&!i.includes(e)&&o.push(e),{ibGib:r,ibGibs:t,ibGibAddr:e,ibGibAddrs:o,live:n,gotten:s,tjpAddrsAlreadyAnalyzed:a,skipAddrs:i,skipRel8nNames:c,onlyRel8nNames:d,maxRetries:l,msBetweenRetries:b,space:h,timeLogName:p,mapTjpAddrToLatestAddrsInSpace:u}}catch(m){throw console.error(`${g} ${m.message}`),m}finally{Z&&console.log(`${g} complete.`)}}f(ac,"getGraphProjection_initializeOpts");async function ic({ibGibs:r,ibGibAddrs:t,gotten:e,skipAddrs:o,maxRetries:n,msBetweenRetries:s,timeLogName:a,space:i}){let c=`[${ic.name}]`;try{Z&&console.log(`${c} starting... (I: 67b2be37ff24393fff56e229304da122)`);let d=[];r??=[],t??=[],o??=[],e??={};let l=[],b=Object.keys(e??{}),h=r.map(p=>w({ibGib:p}));for(let p=0;p<t.length;p++){let u=t[p];o.includes(u)||h.includes(u)||(b.includes(u)?d.push(e[u]):l.push(t[p]))}if(Z&&console.log(`${c}[analyze debugging] addrsToGetFromSpace (${l.length}):
12
+ ${l.join(`
13
+ `)} (I: b45a2614184b48b694becfd377c789f5)`),l.length>0){let p=l.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`),Z&&console.log(`${c} retrying. addrsToGet (${p.length}): ${p} (I: 8460694cdd5518472680784c3b96a822)`),await be(s)),a&&console.timeLog(a,`${c} getFromSpace (${p?.length}) starting...`),!i)throw new Error("(UNEXPECTED) space falsy? (E: aa9f657695717034b3581066932d7d23)");let g=await X({addrs:p,space:i});if(a&&console.timeLog(a,`${c} getFromSpace complete.`),g.success&&(g.ibGibs?.length??0)>0){g.ibGibs.forEach(y=>d.push(y));let m=g.ibGibs.map(y=>w({ibGib:y}));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(y=>!m.includes(y))}else{let m=g.rawResultIbGib.ibGibs??[];if(m.length>0){m.forEach(I=>d.push(I));let y=m.map(I=>w({ibGib:I}));a&&console.timeLog(a,`${c} got some.`),p=p.filter(I=>!y.includes(I))}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 d}catch(d){throw console.error(`${c} ${d.message}`),d}finally{Z&&console.log(`${c} complete.`)}}f(ic,"getGraphProjection_getIbGibsInIbGibAddrs");async function kr(r){let t=`[${kr.name}]`;try{if(Z&&console.log(`${t} starting... (I: 70508d7a5c63eae1f22ae851b32b3d22)`),!r.ibGib&&!r.ibGibAddr&&(r.ibGibs??[]).length===0&&(r.ibGibAddrs??[]).length===0)return{};let{ibGibs:e,ibGibAddrs:o,live:n,gotten:s,tjpAddrsAlreadyAnalyzed:a,skipAddrs:i,skipRel8nNames:c,onlyRel8nNames:d,maxRetries:l,msBetweenRetries:b,space:h,timeLogName:p,mapTjpAddrToLatestAddrsInSpace:u}=await ac(r);if(p&&console.timeLog(p,`${t} starting...`),o?.length??!1){let m=await ic({ibGibs:e,ibGibAddrs:o,gotten:s,skipAddrs:i,maxRetries:l,msBetweenRetries:b,timeLogName:p,space:h});e=e?[...e,...m]:[...m]}o=e.map(m=>w({ibGib:m}));let g=eo(e.map(m=>m.ib).filter(m=>m.startsWith("comment ")));return Z&&console.log(`${t}[analyze debugging] ibGibs commentIbs: ${g.join(`
15
+ `)} (I: c89dc951315f746954f9bddbe8941122)`),n?cc({ibGibs:e,ibGibAddrs:o,gotten:s,tjpAddrsAlreadyAnalyzed:a,skipAddrs:i,skipRel8nNames:c,onlyRel8nNames:d,maxRetries:l,msBetweenRetries:b,space:h,timeLogName:p,mapTjpAddrToLatestAddrsInSpace:u}):lc({ibGibs:e,ibGibAddrs:o,gotten:s,skipAddrs:i,skipRel8nNames:c,onlyRel8nNames:d,maxRetries:l,msBetweenRetries:b,space:h,timeLogName:p})}catch(e){throw console.error(`${t} ${e.message}`),e}finally{Z&&console.log(`${t} complete.`)}}f(kr,"getGraphProjection");async function gr({ibGibAddr:r,latestCommonFrameAddr:t,live:e,space:o}){let n=`[${gr.name}]`;try{if(Z&&console.log(`${n} starting... (I: 5d225e56dc11e62cd83c5366ea288826)`),r===t)return console.warn(`${n} ibGibAddr === latestCommonFrameAddr. So the delta graph is empty. what are we doing here? (W: e0c8287ae6de8152bf36b6c73ca59a26)`),{};let s=await dt({ibGibAddr:t,live:!1,space:o});return await dt({ibGibAddr:r,live:e,skipAddrs:Object.keys(s),space:o})}catch(s){throw console.error(`${n} ${E(s)}`),s}finally{Z&&console.log(`${n} complete.`)}}f(gr,"getDeltaDependencyGraph");async function cc({ibGibs:r,ibGibAddrs:t,gotten:e,tjpAddrsAlreadyAnalyzed:o,mapTjpAddrToLatestAddrsInSpace:n,skipAddrs:s,skipRel8nNames:a,onlyRel8nNames:i,maxRetries:c,msBetweenRetries:d,space:l,timeLogName:b}){let h=`[${cc.name}]`;try{n=n??{},o=o??[];let p={...e};(r??[]).forEach(T=>p[w({ibGib:T})]=T);let u=Ye({ibGibs:Object.values(p)});Z&&console.log(`${h}[analyze debugging] timeline tjps(${Object.keys(u).length}): ${Object.keys(u)} (I: 509f04ac15ca08c5a3f0777b48934622)`);let g={};Object.keys(u).forEach(T=>{o.includes(T)||(g[T]=u[T])}),Z&&console.log(`${h}[analyze debugging] timelinesNotAnalyzed: ${P(g)} (I: a4b67d95fdd6b98d3241c0a7d0a93c22)`);let m={},y={};Object.keys(u).filter(T=>!o.includes(T)).forEach(T=>{let $=u[T],_=$[$.length-1];m[T]=_;let A=w({ibGib:_});y[A]=T});let I=Object.keys(m).length;if(I>0){let T={};Object.keys(n).filter(D=>!o.includes(D)).forEach(D=>{let L=m[D];if(L){let j=w({ibGib:L});T[j]=n[D]}else console.error(`${h} latestIbGibCorrespondingToTjpAddr is falsy`)}),Z&&console.log(`${h} latestAddrsMap *before* getLatestAddrs: ${P(T)} (I: 427b4bb78595e9e521ecf2c5e5c80722)`);let $=Object.values(m),_={};if($.length>0){if(!l)throw new Error("(UNEXPECTED) space falsy? (E: 8e878975e3561df9a8dc4c628b0abc23)");let D=await ct({ibGibs:$,space:l});if(!D?.data?.latestAddrsMap)throw new Error("(UNEXPECTED) getLatestAddrs result latestAddrsMap falsy (E: 088caa1fc95fd3b079108ab63ef33422)");if(_=D?.data?.latestAddrsMap,Object.keys(_).length!==I)throw new Error("(UNEXPECTED) latestAddrsMap is not the same size as the incoming map (E: 666af512bbd44534983bb28ee8d43fed)");Z&&console.log(`${h} queriedLatestAddrsMap: ${P(_)} (I: 7b39a5f7ce9e9d9fabae4be98ed44522)`),T={..._,...T}}Z&&console.log(`${h} combined latestAddrsMap: ${P(T)} (I: e3aedea63f29c5b06a79632f691aa522)`);let A=[],G={};Object.values(m).forEach(D=>{let L=w({ibGib:D}),j=y[L],B=T[L];if(!B)throw new Error("(UNEXPECTED) latestAddrInSpace not found in latestAddrsMap (E: 095d2b3f88e3e8a2c3e7d3de4c6d5622)");B===L?(Z&&console.log(`${h} analyzed ${j}(I: afb7960900f04b8a87538f4c7bd903b7)`),o.push(j)):(A.push(B),G[B]=j)});let N=[];for(let D=0;D<(r??[]).length;D++){let j=r[D].rel8ns??{};Object.keys(j).filter(U=>!(a??[]).includes(U)).filter(U=>i?i.includes(U):!0).forEach(U=>{(j[U]??[]).forEach(Q=>{!N.includes(Q)&&!r.some(ue=>w({ibGib:ue})===Q)&&N.push(Q)})})}return t=eo([...t??[],...N,...A]),await kr({ibGibs:r,ibGibAddrs:t,gotten:e,tjpAddrsAlreadyAnalyzed:o,skipAddrs:s,skipRel8nNames:a,onlyRel8nNames:i,maxRetries:c,msBetweenRetries:d,space:l,timeLogName:b,live:!0,mapTjpAddrToLatestAddrsInSpace:n})}else return r||(r=[]),Object.values(e??{}).forEach(T=>{let $=w({ibGib:T});r.some(_=>w({ibGib:T})===$)||r.push(T)}),await kr({ibGibs:r,ibGibAddrs:t,gotten:e,skipAddrs:s,skipRel8nNames:a,onlyRel8nNames:i,maxRetries:c,msBetweenRetries:d,space:l,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(cc,"getGraphProjection_Live");async function lc({ibGibs:r,ibGibAddrs:t,gotten:e,skipAddrs:o,skipRel8nNames:n,onlyRel8nNames:s,maxRetries:a,msBetweenRetries:i,space:c,timeLogName:d}){let l=`[${lc.name}]`;try{let b=[];r??=[],e??={},o??=[],n??=[],d&&console.timeLog(d,`${l} analyzing next step starting...`);for(let h=0;h<r.length;h++){let p=r[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={},y=p.rel8ns||{},I=(Object.keys(y)||[]).filter($=>!n.includes($));s&&(I=I.filter($=>s.includes($)));let T=Object.keys(e);for(let $=0;$<I.length;$++){let _=I[$],A=y[_]??[],G=A.filter(D=>D===""||D===void 0||D===null||!D.includes(ce));G.length>0&&console.warn(`${l} (UNEXPECTED) has falsyAddrs: ${G} (W: da9505cb0a4db68a4aff7f279ad2d322)`),A.filter(D=>!!D).filter(D=>!T.includes(D)).filter(D=>!o.includes(D)).filter(D=>H({ibGibAddr:D}).gib!==M).filter(D=>!b.includes(D)).forEach(D=>{let L=cr({addr:D});(L||[]).length===0?b.push(D):m[D]=L})}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(d&&console.timeLog(d,`${l} analyzing next step complete.`),b.length>0){if(d&&console.timeLog(d,`${l} get addrsWeDontHaveAlready_Rel8dAddrs starting...`),!c)throw new Error("(UNEXPECTED) space falsy? (E: 0ce327cf5d521bd798340333460f3423)");let h=await X({addrs:b,space:c});if(d&&console.timeLog(d,`${l} get addrsWeDontHaveAlready_Rel8dAddrs complete.`),h.success)if(h.ibGibs?.length===b.length){Z&&console.log(`${l} got ALL of them (happy path)`),h.ibGibs.forEach(u=>e[w({ibGib:u})]=u),d&&console.timeLog(d,`${l} call getGraphProjection recursively starting...`);let p=await kr({ibGibs:h.ibGibs,live:!1,gotten:e,skipAddrs:o,skipRel8nNames:n,onlyRel8nNames:s,maxRetries:a,msBetweenRetries:i,space:c});return d&&console.timeLog(d,`${l} call getGraphProjection recursively complete.`),p}else throw(h.ibGibs?.length??0)>0&&h.ibGibs.length<b.length?(Z&&console.warn(`${l} 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=`${l} ${b.message}`;throw console.error(h),d&&console.timeLog(d,`${l} error: ${h}`),b}finally{d&&console.timeLog(d,`${l} complete.`)}}f(lc,"getGraphProjection_NonLive");function vo({ibGibs:r}){let t=`[${vo.name}]`;try{if(Z&&console.log(`${t} starting... (I: 6019a812cff8597f79c12088e45cc226)`),r){let e={};return r.forEach(o=>{e[w({ibGib:o})]=o}),e}else return}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{Z&&console.log(`${t} complete.`)}}f(vo,"toFlatGraph");var fe=!1;async function dc({keystoneData:r}){let t=`[${dc.name}]`;try{return fe&&console.log(`${t} starting... (I: c3022a146faac9730154f34d1439a225)`),[ms].join(" ")}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{fe&&console.log(`${t} complete.`)}}f(dc,"getKeystoneIb");function fc({pool:r,requiredChallengeIds:t,targetAddr:e}){let o=r.config.behavior,n=new Set,s=Object.keys(r.challenges);if(t&&t.length>0){for(let a of t){if(!r.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(o.targetBindingChars>0&&e){let{gib:a}=H({ibGibAddr:e});if(a){let i=a!==M?a.substring(0,o.targetBindingChars).toLowerCase():"abc";for(let c of i){let l=(r.bindingMap[c]||[]).find(b=>s.includes(b));if(!l)throw new Error(`Entropy Exhaustion. Cannot satisfy binding for char '${c}'. (E: 341b95dc3a58be3e083d1d9c4a0c4925)`);n.add(l),s=s.filter(b=>b!==l)}}}if(o.selectSequentially>0){if(s.length<o.selectSequentially)throw console.error(`[getDeterministicRequirements] Entropy Exhaustion! AvailableCount: ${s.length}, Required Seq: ${o.selectSequentially}. Available IDs: ${s.join(",")}`),new Error("Entropy Exhaustion. Insufficient challenges for FIFO requirement. (E: 9efa88003e1d5eccb837c85154ee5625)");s.slice(0,o.selectSequentially).forEach(i=>n.add(i)),s=s.slice(o.selectSequentially)}return{mandatoryIds:n,availableIds:s}}f(fc,"getDeterministicRequirements");function Lo(r,t){let e=t.charAt(0).toLowerCase();if(/[0-9a-f]/.test(e))r[e]||(r[e]=[]),r[e].push(t);else throw new Error(`invalid challengeId (${t}). Must start with a hex character. (E: c96ed8460de89e28c801370a0f07f826)`)}f(Lo,"addToBindingMap");function Ed(r,t){for(let e of Object.keys(r))r[e]=r[e].filter(o=>o!==t)}f(Ed,"removeFromBindingMap");function Ro({pools:r,poolId:t,poolFilter:e,verb:o}){let n="[resolveTargetPool]";try{let s;if(t){if(s=r.find(a=>a.id===t),!s)throw new Error(`Pool not found with ID: ${t} (E: 4a2b17428515c1e82813158581898125)`)}else if(e){let a=r.filter(e);if(a.length===0)throw new Error("No pool matched the provided filter. (E: 5b3c27428515c1e82813158581898125)");s=a[0]}else{if(!o)throw new Error("Cannot auto-resolve pool without a verb. (E: 6c4d37428515c1e82813158581898125)");if(s=r.find(a=>a.config.allowedVerbs&&a.config.allowedVerbs.includes(o)),s||(s=r.find(a=>!a.config.allowedVerbs||a.config.allowedVerbs.length===0)),!s)throw new Error(`No suitable pool found for verb: ${o} (E: 7d5e47428515c1e82813158581898125)`)}if(o&&s.config.allowedVerbs&&s.config.allowedVerbs.length>0&&!s.config.allowedVerbs.includes(o))throw new Error(`Pool ${s.id} is not authorized for verb: ${o} (E: 8e6f57428515c1e82813158581898125)`);return s}catch(s){throw console.error(`${n} ${E(s)}`),s}}f(Ro,"resolveTargetPool");function Uo({pool:r,targetAddr:t,requiredChallengeIds:e}){let o="[selectChallengeIds]";try{let{mandatoryIds:n,availableIds:s}=fc({pool:r,requiredChallengeIds:e,targetAddr:t}),a=r.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(`${o} ${E(n)}`),n}}f(Uo,"selectChallengeIds");async function Po({salt:r,timestamp:t,index:e}){return(await Re({s:`${r}${t}${e}`})).substring(0,16)}f(Po,"generateOpaqueChallengeId");async function md({prevPools:r,targetPoolId:t,consumedIds:e,masterSecret:o,strategy:n,config:s}){let a="[applyReplenishmentStrategy]";try{let i=JSON.parse(JSON.stringify(r)),c=i.findIndex(p=>p.id===t);if(c===-1)throw new Error(`Target pool ${t} not found in keystone data. (E: 75200388d22744838634524233772545)`);let d=i[c],l=await n.derivePoolSecret({masterSecret:o}),b=Date.now().toString(),h=s.behavior.replenish;if(e.forEach(p=>{d.bindingMap&&Ed(d.bindingMap,p)}),h===de.topUp){e.forEach(p=>delete d.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:l,poolId:d.id,challengeId:u});d.challenges[u]=await n.generateChallenge({solution:g}),d.bindingMap||(d.bindingMap={}),Lo(d.bindingMap,u)}}else if(h===de.replaceAll){d.challenges={},d.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:l,poolId:d.id,challengeId:u});d.challenges[u]=await n.generateChallenge({solution:g}),Lo(d.bindingMap,u)}}else if(h===de.consume)e.forEach(p=>delete d.challenges[p]);else if(h===de.deleteAll)d.challenges={},d.bindingMap={};else throw new Error(`Unknown replenish strategy: ${h}. Valid list: ${P(Yi)} (E: 0acf56f1e1486240080e11e8046d0825)`);return i}catch(i){throw console.error(`${a} ${E(i)}`),i}}f(md,"applyReplenishmentStrategy");async function ko({targetPoolId:r,prevPools:t,masterSecret:e,challengeIds:o,claim:n,requiredChallengeIds:s}){let a="[solveAndReplenish]";try{fe&&console.log(`${a} starting... poolId: ${r}, ids: ${o.length}`);let i=t.find(p=>p.id===r);if(!i)throw new Error(`Target pool not found: ${r} (E: a1b2c3d4e5f6a7b8c9d0e1f2a3b4c5d6)`);let c=ze.create({config:i.config}),d=await c.derivePoolSecret({masterSecret:e}),l=[];for(let p of o){let u=await c.generateSolution({poolSecret:d,poolId:i.id,challengeId:p});l.push(u)}let b={claim:n,solutions:l,requiredChallengeIds:s&&s.length>0?s:void 0},h=await md({prevPools:t,targetPoolId:i.id,consumedIds:o,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 bc({pool:r}){let t=`[${bc.name}]`;try{if(fe&&console.log(`${t} starting... (I: e2ffd568b698cc12d8c5e838d73ae726)`),!r.config)throw new Error("(UNEXPECTED) pool.configy falsy? (E: fcde88fe20e8004a58d7e445436bf526)");if(r.config.type!==Ve.hash_reveal_v1)throw new Error("(UNEXPECTED) pool.config.type !== KeystoneChallengeType.hash_reveal_v1? (E: e205f8872909c37168a624a9df778c26)");let e=[],{algo:o,rounds:n,salt:s}=r.config,a=[Se.sha_256,Se.sha_512];return o?a.includes(o)||e.push(`${t} invalid hash algorithm (${o}). Must be one of ${a}. (E: a22399ca3a68e63ffcc7507699be5826)`):e.push(`${t} algorithm required. (E: 8cd6bfb0590862b9bae24d98d2cf3826)`),n&&typeof n=="number"&&Number.isInteger(n)?n>ys&&e.push(`${t} rounds too high. max rounds: ${ys} (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{fe&&console.log(`${t} complete.`)}}f(bc,"validateChallengePool_typeHashRevealV1");async function hc({pool:r}){let t=`[${hc.name}]`;try{fe&&console.log(`${t} starting... (I: 1a0eafc158a83d1ba8fc019d5c979a26)`);let e=[];if(r.config){if(r.config.id?ws.test(r.config.id)||e.push(`${t} pool.config.id is not formatted correctly. must pass regexp: ${ws.source}`):e.push(`${t} pool.config.id falsy (E: 31d7943d95f877326d5f4ea14463d626)`),r.config.behavior){let{size:n}=r.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 o=r.config.type;switch(o){case Ve.hash_reveal_v1:(await bc({pool:r})).forEach(s=>e.push(s));break;default:throw new Error(`(UNEXPECTED) unknown pool.config.type (${o})? We only implement the following at this time: ${Wi} (E: cce5285cf7580b8bc82172488eba2826)`)}}else e.push(`${t} pool.config falsy. (E: 8d05c875a1d2c58018a5eaf803977d26)`);return e}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{fe&&console.log(`${t} complete.`)}}f(hc,"validateChallengePool");async function Mo({keystoneIbGib:r}){let t=`[${Mo.name}]`;try{fe&&console.log(`${t} starting... (I: ec6ba82ec848b5ac3d8953e89d8d9826)`);let e=[],{data:o,rel8ns:n}=r;o.proofs&&o.proofs.length>0&&e.push(`${t} proofs already exist on genesis keystone. (E: 7a5e15f20918f1bbd8ffb62857dcd526)`);for(let s of o.challengePools)(await hc({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 o.revocationInfo&&e.push(`${t} genesis keystone already has revocationInfo. (E: e11408d0c558d0fa948efbce611ec826)`),e}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{fe&&console.log(`${t} complete.`)}}f(Mo,"validateGenesisKeystone");async function Mr({currentIbGib:r,prevIbGib:t}){let e=`[${Mr.name}]`,o=[];try{if(!r)throw new Error("(UNEXPECTED) currentIbGib falsy? (E: 3c0f02655fa8279e386a079ebb604b25)");if(!t)throw new Error("(UNEXPECTED) prevIbGib falsy? (E: 0d07c812634d839c784f31b8848ba825)");let n=await J({ibGib:r});n&&n.length>0&&o.push(...n);let s=r.data,a=t.data,i=s.n??-2,c=a.n??-2;i<0&&o.push("invalid keystone.currData.n is undefined or null."),c<0&&o.push("invalid keystone.prevData.n is undefined or null."),i!==c+1&&o.push(`keystone data.n values are not sequential. prevData.n: ${c}, currData.n: ${i}. `);for(let d of s.proofs){if(d.solutions.length===0){o.push(`Proof ${d.id||"unknown"} has no solutions.`);continue}let l=d.solutions[0].poolId,b=a.challengePools.find(h=>h.id===l);if(!b){o.push(`Proof references unknown pool: ${l}`);continue}await pc({proof:d,pool:b,errors:o})}if(s.revocationInfo){let d=s.revocationInfo.proof.claim.target,l=w({ibGib:t});d!==l&&o.push(`Revocation target mismatch. Expected ${l}, got ${d}`)}return o}catch(n){throw console.error(`${e} ${E(n)}`),n}finally{fe&&console.log(`${e} complete.`)}}f(Mr,"validateKeystoneTransition");async function pc({proof:r,pool:t,errors:e}){let o=`[${pc.name}]`;try{fe&&console.log(`${o} starting... (I: b8f9b6085888eea2258bf579ecd5e825)`),t.config.allowedVerbs&&t.config.allowedVerbs.length>0&&(!r.claim.verb||!t.config.allowedVerbs.includes(r.claim.verb))&&e.push(`Policy Violation: Pool ${t.id} used for unauthorized verb ${r.claim.verb}`);let{mandatoryIds:n,availableIds:s}=fc({pool:t,requiredChallengeIds:r.requiredChallengeIds,targetAddr:r.claim.target}),a=new Set(r.solutions.map(l=>l.challengeId));for(let l of n)a.has(l)||e.push(`Policy Violation: Missing mandatory challenge ${l}`);let i=[...a].filter(l=>!n.has(l)),c=t.config.behavior.selectRandomly;i.length<c&&e.push(`Policy Violation: Insufficient random count. Need ${c}, got ${i.length}`);for(let l of i)s.includes(l)||e.push(`Policy Violation: ID ${l} is invalid or double-dipped.`);let d=ze.create({config:t.config});for(let l of r.solutions){let b=t.challenges[l.challengeId];b?await d.validateSolution({solution:l,challenge:b})||e.push(`Crypto Violation: Solution for ${l.challengeId} is invalid.`):e.push(`Crypto Violation: Challenge ${l.challengeId} not found in pool.`)}}catch(n){throw console.error(`${o} ${E(n)}`),n}finally{fe&&console.log(`${o} complete.`)}}f(pc,"verifyProofAgainstPool");async function Br({prevIbGib:r,newData:t,metaspace:e,space:o}){let n=`[${Br.name}]`;try{if(fe&&console.log(`${n} starting... (I: 8b10e8920f08b7842803665834cf8925)`),!r.data)throw new Error("(UNEXPECTED) prevIbGib.data falsy? (E: 5e84875bf992c585b979e6c8ed5bf225)");if(r.data.revocationInfo)throw new Error(`Keystone has already been revoked (prevIbGib.data.revocationInfo truthy), so we cannot evolve the keystone. Keystone addr: ${w({ibGib:r})} (E: 45d7f846556829de6b2a701838c3f825)`);let s=r.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 ke({src:r,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,d=await Mr({currentIbGib:c,prevIbGib:r});if(d.length>0)throw console.error(`${n} Validation Failed:
18
+ ${d.join(`
19
+ `)}`),new Error(`(UNEXPECTED) invalid keystone after we just evolved it? Errors: ${d.join("; ")} (E: ae2c58406c1db7687879dfb89fc1f825)`);return await e.put({ibGib:c,space:o}),await e.registerNewIbGib({ibGib:c,space:o}),c}catch(s){throw console.error(`${n} ${E(s)}`),s}finally{fe&&console.log(`${n} complete.`)}}f(Br,"evolvePersistAndRegisterKeystone");async function xs({data:r,metaspace:t,space:e}){let o=`[${xs.name}]`;try{if(fe&&console.log(`${o} 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 k.firstGen({parentIbGib:k.primitive({ib:ms}),ib:await dc({keystoneData:r}),data:r,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 V({ibGib:s}),await t.put({ibGib:s,space:e}),await t.registerNewIbGib({ibGib:s,space:e}),s}catch(n){throw console.error(`${o} ${E(n)}`),n}finally{fe&&console.log(`${o} complete.`)}}f(xs,"createKeystoneIbGibImpl");async function Ns({keystoneIbGib:r,dependencyGraph:t,getLatest:e,invalidIfMoreRecentKeystoneFoundInSpace:o,space:n}){let s=`[${Ns.name}]`;try{if(fe&&console.log(`${s} starting... (I: 22e1ca1d5a08a3f90b7fe9da95df7b26)`),!r)throw new Error("(UNEXPECTED) keystoneIbGib falsy? (E: 26482871d529fff6e8899c5d8a6c3826)");let a=[];if(e){let b=w({ibGib:r}),h=await ct({ibGibs:[r],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(o)a.push(`${s} more recent keystone (${u}) found than the one passed in (${b}) in space (${n.ib}). (E: 64bf48de9448ee5c7528bf03bed2a826)`);else{let[g]=await Fe({addrs:[u],space:n});r=g}else fe&&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 dt({ibGib:r,space:n});let i=Object.values(t),{mapWithTjp_NoDna:c,mapWithTjp_YesDna:d,mapWithoutTjps:l}=lt({ibGibs:i});if(Object.keys(d).length>0&&a.push(`${s} DNA found. Keystones should NOT have DNA. (E: a3ec7827c4284cdea61c2372c0615826)`),Object.keys(l).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=Ye({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(y=>a.push(y)),g.length!==1)for(let y=0;y<g.length-1;y++){let I=g[y],T=g[y+1],$=await Mr({prevIbGib:I,currentIbGib:T});$.length>0&&(a.push(`${s} keystone has ${$.length} transition errors. i: ${y}. prevIbGib addr: ${w({ibGib:I})}. currentIbGib addr: ${w({ibGib:T})}. (E: 3ac17be916141d0c286ca5a87bb1b426)`),$.forEach(_=>a.push(_)));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{fe&&console.log(`${s} complete.`)}}f(Ns,"validateKeystoneGraph");var Ne=!1,Oe=class r{static{f(this,"KeystoneService_V1")}lc=`[${r.name}]`;async genesis({masterSecret:t,frameDetails:e,configs:o,metaspace:n,space:s}){let a=`${this.lc}[${this.genesis.name}]`;try{Ne&&console.log(`${a} starting... (I: c98ae8adbc5888dbf84c5aced7610b25)`);let i=[];for(let l of o){let b=ze.create({config:l}),h=await b.derivePoolSecret({masterSecret:t}),p={},u={},g=l.behavior.size,m=Date.now().toString();for(let y=0;y<g;y++){let I=await Po({salt:l.salt,timestamp:m,index:y}),T=await b.generateSolution({poolSecret:h,poolId:l.id,challengeId:I}),$=await b.generateChallenge({solution:T});p[I]=$,Lo(u,I)}i.push({id:l.id,config:l,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 xs({data:c,metaspace:n,space:s})}catch(i){throw console.error(`${a} ${E(i)}`),i}finally{Ne&&console.log(`${a} complete.`)}}async sign({latestKeystone:t,masterSecret:e,claim:o,poolId:n,poolFilter:s,requiredChallengeIds:a=[],frameDetails:i,metaspace:c,space:d}){let l=`${this.lc}[${this.sign.name}]`;try{Ne&&console.log(`${l} 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:o.verb});Ne&&console.log(`${l} Selected pool: ${h.id} (size: ${Object.keys(h.challenges).length}) (I: 6b26d6f4aad18380f2b3a0989b592826)`);let p=Uo({pool:h,targetAddr:o.target,requiredChallengeIds:a}),{proof:u,nextPools:g}=await ko({targetPoolId:h.id,prevPools:b.challengePools,masterSecret:e,challengeIds:p,claim:o,requiredChallengeIds:a}),m=(b.n??0)+1,y;if(m%Do===0){let $={...t,data:{...b,frameDetails:i}};y=await this.getAggregateDetails({latestKeystone:$,metaspace:c,space:d})}return await Br({prevIbGib:t,newData:{challengePools:g,proofs:[u],frameDetails:i,checkpointDetails:y},metaspace:c,space:d})}catch(b){throw console.error(`${l} ${E(b)}`),b}finally{Ne&&console.log(`${l} complete.`)}}async validate({currentIbGib:t,prevIbGib:e}){return await Mr({currentIbGib:t,prevIbGib:e})}async validateGenesisKeystone({keystoneIbGib:t}){return await Mo({keystoneIbGib:t})}async getLatestKeystone({addr:t,metaspace:e,space:o}){let n=`${this.lc}[${this.getLatestKeystone.name}]`;try{Ne&&console.log(`${n} starting...`);let s=await e.getLatestAddr({tjpAddr:t,space:o});if(!s)throw new Error(`could not find latest addr for ${t}`);let a=await e.get({addr:s,space:o});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{Ne&&console.log(`${n} complete.`)}}async validateKeystoneGraph({keystoneIbGib:t,dependencyGraph:e,getLatest:o,invalidIfMoreRecentKeystoneFoundInSpace:n,space:s}){let a=`${this.lc}[${this.validateKeystoneGraph.name}]`;try{return Ne&&console.log(`${a} starting... (I: 01c5cd455038c270cbf1effc1704af26)`),await Ns({keystoneIbGib:t,dependencyGraph:e,getLatest:o,invalidIfMoreRecentKeystoneFoundInSpace:n,space:s})}catch(i){throw console.error(`${a} ${E(i)}`),i}finally{Ne&&console.log(`${a} complete.`)}}async revoke({latestKeystone:t,masterSecret:e,reason:o="User initiated revocation",frameDetails:n,metaspace:s,space:a}){let i=`${this.lc}[${this.revoke.name}]`;try{Ne&&console.log(`${i} starting...`);let c=t.data,d=Ro({pools:c.challengePools,poolId:_s}),l={verb:Oo,target:w({ibGib:t})},b=Uo({pool:d,targetAddr:l.target,requiredChallengeIds:[]});if(b.length===0)throw new Error(`Revocation policy selected 0 challenges? Check config for pool ${d.id}. Revocation requires proof. (E: 97e5a8356d241ae7b882db791cb1f825)`);let{proof:h,nextPools:p}=await ko({targetPoolId:d.id,prevPools:c.challengePools,masterSecret:e,challengeIds:b,claim:l,requiredChallengeIds:[]});p.find(T=>T.id===d.id&&Object.keys(T.challenges).length>0)&&console.warn(`${i} revocation pool ${d.id} is not empty after revocation. Is the revocation pool replenish strategy set to ${de.deleteAll}? (W: 300c28bc8b98fc3e3c0b0d988344f825)`);let u={reason:o,proof:h},g=(c.n??0)+1,m;if(g%Do===0){let T={...t,data:{...c,frameDetails:n,revocationInfo:u}};m=await this.getAggregateDetails({latestKeystone:T,metaspace:s,space:a})}return await Br({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{Ne&&console.log(`${i} complete.`)}}async addPools({latestKeystone:t,masterSecret:e,newPools:o,metaspace:n,space:s}){let a=`${this.lc}[${this.addPools.name}]`;try{if(Ne&&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(o.length===0)throw new Error("No new pools provided to add. (E: 6599f8f51c78d722252ddb2894fdbe25)");let c=Ro({pools:i.challengePools,verb:Ur});Ne&&console.log(`${a} Authorized via pool: ${c.id}`);let d=w({ibGib:t}),l={verb:Ur,target:d,scope:JSON.stringify({add:o.map($=>$.id)})},b=Uo({pool:c,targetAddr:d}),{proof:h,nextPools:p}=await ko({targetPoolId:c.id,prevPools:i.challengePools,masterSecret:e,challengeIds:b,claim:l}),u=new Set(p.map($=>$.id));for(let $ of o)if(u.has($.id))throw new Error(`Cannot add pool. ID collision: ${$.id} (E: 8a4c2b1d3e5f6a7b8c9d0e1f2a3b4c5d)`);let g=[...p,...o],m=(i.n??0)+1,y;if(m%Do===0){let $={...t,data:{...i,challengePools:g}};y=await this.getAggregateDetails({latestKeystone:$,metaspace:n,space:s})}return await Br({prevIbGib:t,newData:{challengePools:g,proofs:[h],checkpointDetails:y},metaspace:n,space:s})}catch(i){throw console.error(`${a} ${E(i)}`),i}finally{Ne&&console.log(`${a} complete.`)}}async getAggregateDetails({latestKeystone:t,metaspace:e,space:o}){let n=`${this.lc}[${this.getAggregateDetails.name}]`;try{let s={},a=t;for(;a;){let i=a.data;if(i.checkpointDetails){s=sr({dominant:s,recessive:i.checkpointDetails});break}if(i.frameDetails&&(s=sr({dominant:s,recessive:i.frameDetails})),i.n===0)break;let c=a.rel8ns?.past,d=c&&c.length>0?c[c.length-1]:void 0;if(!d)break;let l=await e.get({addr:d,space:o});if(!l.success||!l.ibGibs||l.ibGibs.length===0)throw new Error(`Could not find previous keystone frame at ${d} (E: e3d069b22e11e550e58844889ddb5325)`);a=l.ibGibs[0]}return s}catch(s){throw console.error(`${n} ${E(s)}`),s}}};var Bo=!1,Os=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}},Ds=class r extends Os{static{f(this,"KeystoneConfigBuilder_HashV1")}lc=`[${r}]`;_algo;_rounds;withHash({algo:t,rounds:e}){let o=`${this.lc}[${this.withHash.name}]`;try{return Bo&&console.log(`${o} starting... (I: 15d1b3bd2e98bba33fc6c78228755826)`),this._algo=t,this._rounds=e,this}catch(n){throw console.error(`${o} ${E(n)}`),n}finally{Bo&&console.log(`${o} complete.`)}}build(){let t=`${this.lc}[${this.build.name}]`;try{if(Bo&&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:Ve.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{Bo&&console.log(`${t} complete.`)}}},Fr=class{static{f(this,"KeystoneConfig")}static hash(){return new Ds}};function vs(r){if(r.type&&r.type!==Ve.hash_reveal_v1)throw new Error(`invalid type (${r.type}). Only ${Ve.hash_reveal_v1} currently implemented. (E: c38616cd7a459149f670418f88766526)`);let{salt:t,id:e,size:o,sequential:n,random:s,targetBinding:a,replenishStrategy:i,verbs:c,hashAlgorithm:d,hashRounds:l}=r;return Fr.hash().withId(e).withSalt(t).withSize(o??Ts).withHybrid({seqCount:n??As,randCount:s??Ss}).withTargetBinding(a??Gs).withReplenishStrategy(i??Cs).withHash({algo:d??Ji,rounds:l??Zi}).forVerbs(c??[]).build()}f(vs,"createStandardPoolConfig");function wd(r){if(r.type&&r.type!==Ve.hash_reveal_v1)throw new Error(`invalid type (${r.type}). Only ${Ve.hash_reveal_v1} currently implemented. (E: 09c1f7772bd2a7910f5562b4934d3826)`);let{salt:t,id:e,size:o,sequential:n,random:s,targetBinding:a,replenishStrategy:i,verbs:c,hashAlgorithm:d,hashRounds:l}=r;return Fr.hash().withId(e).withSalt(t).withSize(o??Qi).withHybrid({seqCount:n??ec,randCount:s??tc}).withTargetBinding(a??rc).withReplenishStrategy(i??oc).withHash({algo:d??nc,rounds:l??sc}).forVerbs(c??[]).build()}f(wd,"createHighSecurityPoolConfig");function uc(r){return wd({...r,id:r.id??zi,verbs:r.verbs??[Is.MANAGE]})}f(uc,"createManagePoolConfig");function gc({template:r,behaviorProfiles:t,salt:e}){let o;return r.behaviorProfile&&t&&(o=t[r.behaviorProfile]),o||(o=r.behaviorInline),o||(o={size:Ts,replenish:Cs,selectSequentially:As,selectRandomly:Ss,targetBindingChars:Gs}),Fr.hash().withId(r.id).withSalt(e).withSize(o.size).withHybrid({seqCount:o.selectSequentially,randCount:o.selectRandomly}).withTargetBinding(o.targetBindingChars).withReplenishStrategy(o.replenish).withHash({algo:r.algo,rounds:r.rounds}).forVerbs(r.allowedVerbs).build()}f(gc,"createPoolConfigFromJson");var Fo="sync",De="syncmsg",Ls="@payloadAddrsDomain",$d="init",yd="ack",Id="delta",_d="commit",z={init:$d,ack:yd,delta:Id,commit:_d},_m=Object.values(z),Td="abort",Ad="optimistic-graft-longest-common-subsequence",_t={abort:Td,optimisticWithLCS:Ad},Jt=Object.values(_t);function jo(r){return Jt.includes(r)}f(jo,"isValidSyncConflictStrategy");var Sd="push",Gd="pull",Cd="sync",Ps={push:Sd,pull:Gd,sync:Cd},Cm=Object.values(Ps);var xd="sender",Nd="receiver",Ho={sender:xd,receiver:Nd},xm=Object.values(Ho);var Ec=!1;function Rs({base:r,extended:t,throwIfExtendedDoesntContainBase:e}){let o=`[${Rs.name}]`;try{Ec&&console.log(`${o} starting... (I: 00d70d79a0249165c2a230389c962526)`);let n=!0;for(let a=0;a<r.length;a++)if(r[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: ${r}. extended: ${t}. (E: fb80b40003289bbf1aaedd4829fa1826)`);let s;if(n)s=t.slice(r.length);else{s=[];for(let a of t)r.includes(a)||s.push(a)}return s}catch(n){throw console.error(`${o} ${E(n)}`),n}finally{Ec&&console.log(`${o} complete.`)}}f(Rs,"getUniqueDnas");async function Xo({src:r,createdIbGibs_Running:t,dnaAddrsToApplyToStoreVersion_MUTATES_IN_PLACE:e,allLocalIbGibs:o}){let n=`[${Xo.name}]`;try{if(e.length>0){let s=e.splice(0,1)[0],a=o.filter(l=>w({ibGib:l})===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=v(i.data);c.src=r,c.srcAddr=w({ibGib:r});let d;switch(c.type){case"mut8":d=await ke(c);break;case"rel8":d=await Ae(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((d.intermediateIbGibs??[]).forEach(l=>t.push(l)),(d.dnas??[]).forEach(l=>t.push(l)),t.push(d.newIbGib),(d.dnas??[]).length>0){if(!d.dnas.some(l=>w(l)===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 Xo({src:d.newIbGib,createdIbGibs_Running:t,dnaAddrsToApplyToStoreVersion_MUTATES_IN_PLACE:e,allLocalIbGibs:o})}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)`),r}catch(s){throw console.error(`${n} ${E(s)}`),s}}f(Xo,"applyTransforms");var Er="graftinfo",jr=Er,mc="latestcommonaddr",wc="base",qo="orphan",$c="dnaapplied",Od="longest-common-subsequence",Us={lcs:Od},Mm=Object.values(Us);var ve=!0;async function Dd({data:r}){if(!r.conflictStrategy)throw new Error("(UNEXPECTED) data.conflictStrategy required for GraftInfoIb (E: 2c0968a0dac8d0ab3d67da9756d6df26)");if(!jo(r.conflictStrategy))throw new Error(`invalid data.conflictStrategy (${r.conflictStrategy}). valid conflict strategies: ${Jt} (E: 41e2680089786d4d28046b4c0884bd26)`);return[Er,r.conflictStrategy].join(" ")}f(Dd,"getGraftInfoIb");async function yc({conflictStrategy:r,details:t,addlGraftDetails:e,latestCommonFrameAddr:o,baseAddrsSinceLCA:n,orphanAddrsSinceLCA:s,dnaAddrsApplied:a}){let i=`[${yc.name}]`;try{if(ve&&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:r,description:t};e&&(c.addlGraftDetails=e);let d={[mc]:[o],[wc]:n.concat(),[qo]:s.concat(),[$c]:a.concat()},l=await Dd({data:c});return await k.stone({parentPrimitiveIb:Er,ib:l,data:c,rel8ns:d,uuid:!0})}catch(c){throw console.error(`${i} ${E(c)}`),c}finally{ve&&console.log(`${i} complete.`)}}f(yc,"createGraftInfo");async function vd({textA:r,textB:t}){if(r===t)return r;if(r==="")return t;if(t==="")return r;function e(d,l){let b=d.length,h=l.length,p=Array(b+1).fill(0).map(()=>Array(h+1).fill(0));for(let y=1;y<=b;y++)for(let I=1;I<=h;I++)d[y-1]===l[I-1]?p[y][I]=p[y-1][I-1]+1:p[y][I]=Math.max(p[y-1][I],p[y][I-1]);let u=b,g=h,m=[];for(;u>0&&g>0;)d[u-1]===l[g-1]?(m.unshift({line:d[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 o=r.split(`
20
+ `),n=t.split(`
21
+ `),s=e(o,n),a=[],i=0,c=0;for(let d of s){for(;i<d.indexA;)a.push(o[i]),i++;for(;c<d.indexB;)a.push(n[c]),c++;a.push(d.line),i++,c++}for(;i<o.length;)a.push(o[i]),i++;for(;c<n.length;)a.push(n[c]),c++;return a.join(`
22
+ `)}f(vd,"mergeTextByLongestCommonSubsequence");async function ks({timelineAddrsA:r,timelineAddrsB:t,latestCommonFrameAddr:e,conflictStrategy:o,ibGibReadCache:n,space:s}){let a=`[${ks.name}]`;try{let I=function(we){let Xt=`${a}[${I.name}]`;for(let Xe of we){if(!Xe.rel8ns)throw new Error(`(UNEXPECTED) ${Xt} someIbGib.rel8ns falsy? All ibgibs with mergeable timelines are expected to have rel8ns. addr: ${w({ibGib:Xe})} (E: 5534a478cd183a5ee27b28487448b226)`);if(!Xe.rel8ns.dna)throw new Error(`(UNEXPECTED) someIbGib.rel8ns.dna falsy? We only have implemented grafting for dna. addr: ${w({ibGib:Xe})} (there should be another route for merging for non-dna timelines) (E: d86b388c627afd613f897e3819d8ab26)`);if(Xe.rel8ns.dna.length===0)throw new Error(`(UNEXPECTED) someIbGib.rel8ns.dna.length === 0? We only have implemented grafting for dna. addr: ${w({ibGib:Xe})} (there should be another route for merging for non-dna timelines) (E: bf973662a0689dd9089912b861af2826)`)}};var i=I;f(I,"throwIfUnexpected"),ve&&console.log(`${a} starting... (I: 3b4c3e8e59c883d9d3c352efd6380826)`);let c=[],d=[];if(r.length===0)throw new Error("timelineAddrsA empty (E: 93a78cd1cd2a4a16ba99bd4820468f26)");if(t.length===0)throw new Error("timelineAddrsB empty (E: 76d53848152a66971b734068c3316826)");if(e){if(!r.includes(e))throw new Error(`timelineAddrsA does not include latestCommonFrameAddr (${e}). timelineAddrsA: ${r} (E: c5a9afe371888da2a79963983426e826)`);if(!t.includes(e))throw new Error(`timelineAddrsB does not include latestCommonFrameAddr (${e}). timelineAddrsB: ${t} (E: 7e641f67c452b67d582d78484a88c826)`)}else if(e=r.findLast(we=>t.includes(we)),!e)throw new Error(`timelines do not share a common frame. A: ${r}. B: ${t} (E: 4c0e78a88a375d8588736668573f1e26)`);if(r.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 l=r.lastIndexOf(e),b=r.slice(l+1),h=await Fe({readCache_graph:n,addrs:b,space:s}),p=h.at(-1),u=t.lastIndexOf(e),g=t.slice(u+1),m=await Fe({readCache_graph:n,addrs:g,space:s}),y=m.at(-1);I(h),I(m);let T,$,_,A,G=Lt({ibGib:p}),N=G.valid?Number.parseInt(G.ticks):Number.MAX_SAFE_INTEGER,D=G.valid?G.ms??0:0,L=Lt({ibGib:y}),j=L.valid?Number.parseInt(L.ticks):Number.MAX_SAFE_INTEGER,B=L.valid?L.ms??0:0;N<j?(T=p,$=h,_=y,A=m):N>j?(T=y,$=m,_=p,A=h):D<=B?(T=p,$=h,_=y,A=m):(T=y,$=m,_=p,A=h);let U=w({ibGib:T}),re=$.map(we=>w({ibGib:we})),Q=w({ibGib:_}),ue=A.map(we=>w({ibGib:we}));ve&&console.log(`${a} baseTipAddr: ${U} (I: 93353d9b9b68b17088f57958df85e826)`),ve&&console.log(`${a} orphanTipAddr: ${Q} (I: 14df8867adc5dab97ff3c1e989b40e26)`);let[He]=await Fe({addrs:[e],space:s});if(!He)throw new Error("(UNEXPECTED) latestCommonFrameIbGib falsy? (E: ead2020b7ab8e4c4f824573133e33826)");if(!He.rel8ns)throw new Error("(UNEXPECTED) latestCommonFrameIbGib.rel8ns falsy? (E: b3f338032d19816fc87d3c78af255726)");if(!He.rel8ns.dna||He.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 Ct=He.rel8ns.dna.concat(),Je=[];for(let we of A){if(!we.rel8ns)throw new Error("(UNEXPECTED) orphanFrame.rel8ns falsy? (E: ed910e3b930b1b5388d87c6f736a4826)");let Xt=Rs({base:Ct,extended:we.rel8ns.dna??[],throwIfExtendedDoesntContainBase:!0});if(Xt.forEach(Xe=>Ct.push(Xe)),Xt.length===0)throw new Error("(UNEXPECTED) orphanDnaAddrsToApply empty? (E: d44ed439e538e5b538d12d71063f0826)");Xt.forEach(Xe=>Je.push(Xe))}let _e=await Fe({addrs:Je,readCache_graph:n,space:s}),Pe=[],Te=await Xo({src:T,dnaAddrsToApplyToStoreVersion_MUTATES_IN_PLACE:Je.concat(),allLocalIbGibs:_e,createdIbGibs_Running:Pe});if(!Te.data)throw new Error("(UNEXPECTED) graftTip_sansGraftInfo.data falsy? (E: 4792f8e84fc84966e89220fae0657826)");if(!Te.data.n)throw new Error("(UNEXPECTED) graftTip_sansGraftInfo.data.n falsy? (E: a2b3ca4cdec8d01f282dd3e4ff9eab26)");if(Pe.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 Be({space:s,ibGibs:Pe}),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:Ir,mapWithTjp_YesDna:Jr,mapWithoutTjps:oe}=lt({ibGibs:Pe});if(Object.keys(Ir).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 et=Object.values(Jr),bt=Ye({ibGibs:et});if(Object.keys(bt).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(bt).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(bt)[0].forEach(we=>c.push(we));for(let we of c)await ge({ibGib:we,space:s});let Zr;if(o===_t.optimisticWithLCS){if(!T.data)throw new Error("(UNEXPECTED) baseTip.data falsy? (E: 92623857e19b9b4e081e8c8d9eb45526)");if(!_.data)throw new Error("(UNEXPECTED) orphanTip.data falsy? (E: 2e6828a4c9226ac917ab6fe833672826)");if((_.data.text||T.data.text)&&_.data.text!==T.data.text){ve&&console.log(`${a} different data.text found. executing text merge for conflictStrategy ${o} (I: cfb5f9580832040388fc576eb71ac526)`);let we=_.data.text??"",Xt=Q,Xe=T.data.text??"",Vc=U,zc=await vd({textA:we,textB:Xe}),tt=await ke({src:Te,dataToAddOrPatch:{text:zc},dna:!0,nCounter:!!Te.data.n});if(tt.intermediateIbGibs&&tt.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(!tt.dnas||tt.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(tt.dnas.length!==1)throw new Error("(UNEXPECTED) resMut8Text.dnas.length !== 1? we're expecting a single mut8 dna. (E: 9574d86a9108095cb454b049bcca5326)");if(d.push(tt.dnas[0]),c.push(tt.newIbGib),await ne({resTransform:tt,space:s}),await ge({ibGib:tt.newIbGib,space:s}),Zr={mergeTextStrategy:Us.lcs,textAAddr:Xt,textBAddr:Vc},Te=tt.newIbGib,!Te.data)throw new Error("(UNEXPECTED) graftTip_sansGraftInfo.data falsy after mut8 merge text? (E: 6b65d83df6681887686a0098144eea26)")}}let _r=await yc({conflictStrategy:o,details:`Replayed ${Je.length} transforms from orphan (${Q}) onto base (${U}).`,addlGraftDetails:Zr?[Zr]:void 0,latestCommonFrameAddr:e,baseAddrsSinceLCA:re,orphanAddrsSinceLCA:ue,dnaAddrsApplied:Je});ve&&console.log(`${a} intrinsic graft complete. graftInfo to be appended to timeline:
23
+ ${P(_r)} (I: ab9d1e73db9a3ff4f8241f38197bb826)`),await Be({ibGib:_r,space:s});let $n=w({ibGib:_r}),ht=await Ae({src:Te,rel8nsToAddByAddr:{[jr]:[$n]},dna:!0,nCounter:!!Te.data.n});if(ht.intermediateIbGibs&&ht.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(!ht.dnas||ht.dnas.length===0)throw new Error("(UNEXPECTED) resRel8GraftInfo.dnas falsy/empty? We're expected to generate dna from this rel8. (E: 4c8fdde70368d643f86732dfa48c5526)");if(ht.dnas.length!==1)throw new Error("(UNEXPECTED) resRel8GraftInfo.dnas.length !== 1? we're expecting a single rel8 dna. (E: c2f5085c1718d7149e04f5c814027926)");d.push(ht.dnas[0]),await ne({resTransform:ht,space:s}),await ge({ibGib:ht.newIbGib,space:s});let ga=ht.newIbGib;ve&&console.log(`${a} finalGraftTip: ${P(ga)} (I: 454e72957be8221b96931c289053fc26)`);let Ea={dnasReplayed:_e,dnasCreatedInGraft:d,intermediateIbGibsCreatedInGraft:c,newGraftTip:ga,graftInfoCreated:_r};return ve&&console.log(`${a} result... (I: d6a02f95eb2564c621810ef855434226)`),ve&&console.dir(Ea),Ea}catch(c){throw console.error(`${a} ${E(c)}`),c}finally{ve&&console.log(`${a} complete.`)}}f(ks,"graftTimelines");function Ms(r){let t=`[${Ms.name}]`;try{if(ve&&console.log(`${t} starting... (I: fe9adfe1a3175d87982507c8851f5826)`),!r)throw new Error("(UNEXPECTED) not a graft info, ibGib falsy? (E: bf06cdd700788e777f72fe5a5bdb0e26)");if(!r.data)throw new Error("not a graft info, ibGib.data falsy (E: 5e1b28843ec8571a7623046a06195826)");if(!r.ib.startsWith(Er))throw new Error(`not graft info, ibgib.ib does not start with ${Er} (E: cec6a8e25ff8746aef813e38cbebce26)`);return!0}catch(e){return ve&&console.error(`${t} ${E(e)}`),!1}finally{ve&&console.log(`${t} complete.`)}}f(Ms,"isGraftInfo");var se=!1;async function Bs({data:r}){let t=`[${Bs.name}]`;try{return[Fo,r.uuid].join(" ")}catch(e){throw console.error(`${t} ${E(e)}`),e}}f(Bs,"getSyncIb");async function Ic(){return`tmp_sync_space_${(await F()).substring(0,8)}`}f(Ic,"getTempSpaceName");async function Hr({olderAddr:r,newerAddr:t,space:e}){let o=`[${Hr.name}]`;try{if(se&&console.log(`${o} starting... (I: 4b3548cbc9a2eb749f447ed82fdcf826)`),r===t)return!0;let n,s=await X({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(`${o} newerIbGib.rel8ns falsy? newerAddr: ${t}. (W: 6f920811f7080281189f767813814826)`),!1;let a=n.rel8ns.past??[];if(a.length===0)return!1;if(a.includes(r))return!0;let i=a[0];return await Hr({olderAddr:r,newerAddr:i,space:e})}catch(n){throw console.error(`${o} ${E(n)}`),n}finally{se&&console.log(`${o} complete.`)}}f(Hr,"isPastFrame");async function _c({sagaIbGib:r,localSpace:t}){let e=`[${_c.name}]`,o=f(async i=>{let c=await X({space:t,addrs:i});if(c.success&&c.ibGibs?.length===i.length)return c.ibGibs;{let d=c.rawResultIbGib;throw d.data?new Error(`(UNEXPECTED) couldn't find addrs? addrsNotFound: ${d.data.addrsNotFound}? space.ib: ${t.ib} (E: 43b7b5a6ad982715c8f3eed69bfa0d26)`):new Error("(UNEXPECTED) resGet.rawResultIbGib.data falsy? (E: c26c681d2f831fc537ba6f48fee36d26)")}},"fnGet"),n=await Ko({sagaIbGib:r});if(n.length>0)throw new Error(`invalid sync sagaIbGib. validationErrors: ${n} (E: 19f9e8c9643858ff41312b62293d2126)`);if(!r.rel8ns)throw new Error("(UNEXPECTED) validated sagaIbGib.rel8ns falsy? (E: 73af48be8bbf271ec5cf78187ce8c826)");let s=r.rel8ns[De],a=await o(s);return{sagaIbGib:r,msgStones:a}}f(_c,"getSyncSagaFrameDependencyGraph");async function Zt({sagaIbGib:r,space:t}){let e=`[${Zt.name}]`;try{if(se&&console.log(`${e} starting... (I: 1ea3f804dd07d1e917a2afaaad497826)`),!r.data)throw new Error("(UNEXPECTED) sagaIbGib.data falsy? (E: fe0a0d0965e87ac852fe7ba4710cc826)");if(!r.rel8ns)throw new Error("(UNEXPECTED) sagaIbGib.rel8ns falsy? (E: b79ff82a732346bdf8a9e1eb9ac96826)");let o=w({ibGib:r}),n=r.rel8ns.past&&r.rel8ns.past.length>0?[...r.rel8ns.past,o]:[o],s=[];for(let a of n){let i,c=await X({addr:a,space:t});if(c.success&&c.ibGibs&&c.ibGibs.length===1)i=c.ibGibs[0];else throw se&&console.log(`${e} failed getting full history of sagaIbGib:
24
+ ${P(r)} (I: 2a35685bfe038f63182c7db39b44c826)`),new Error(`couldn't get saga addr (${a}) from space (${t.ib}) (E: 865b78ecd918c244158813650bea7d26)`);let d=await _c({sagaIbGib:i,localSpace:t});s.push(d)}return se&&console.log(`${e} resGraphs:...
25
+ ${P(s).split(`
26
+ `).join(`
27
+ `)}
28
+ ...(I: d8e11827d88a3454d887ff05fb4ff526)`),s}catch(o){throw console.error(`${e} ${E(o)}`),o}finally{se&&console.log(`${e} complete.`)}}f(Zt,"getFullSyncSagaHistory");async function Ko({sagaIbGib:r}){let t=`[${Ko.name}]`;try{se&&console.log(`${t} starting... (I: dac978e9ec5820f128fbbff817b82826)`);let e=await J({ibGib:r})??[];if(e.length>0)return e;if(r.data){let{data:o}=r;o.uuid||e.push("data.uuid required (E: aa24eeda7b88d22e5832a2e8083c0826)"),o.timestamp||e.push("data.timestamp required (E: 9c82a88548f4b63c38687428754b3826)"),o.timestampMs||o.timestampMs===0||e.push("data.timestampMs required (E: 9c82a88548f4b63c38687428754b3826)"),o.conflictStrategy?jo(o.conflictStrategy)||e.push(`data.conflictStrategy (${o.conflictStrategy}) is invalid. Must be one of "${Jt}". (E: 6223a8813b688fa2c8644fa8a491bf26)`):e.push("data.conflictStrategy required (E: 9c82a88548f4b63c38687428754b3826)"),o.expirationTimestamp,o.errors,o.successCount}else e.push("sagaIbGib.data falsy (E: 4de5e8de589d0af7245600fb4fe30926)");if(r.rel8ns){let o=r.rel8ns[De];o&&o.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{se&&console.log(`${t} complete.`)}}f(Ko,"validateSyncSagaFrame");async function Wo({history:r}){let t=`[${Wo.name}]`;try{return se&&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{se&&console.log(`${t} complete.`)}}f(Wo,"validateFullSyncSagaHistory");async function Yo({ibGibs:r,space:t}){let e=`[${Yo.name}]`;try{se&&console.log(`${e} starting... (I: aa3ab828402836b3914800a8ffa1b826)`);let o=[],n=[];for(let s of r)ae({ibGib:s})||(An({ibGib:s})?o.push(s):n.push(s));return o.length>0&&await Be({ibGibs:o,isDna:!0,space:t}),n.length>0&&await Be({ibGibs:n,isDna:!1,space:t}),{payload_Dnas:o,payload_NonDnas:n}}catch(o){throw console.error(`${e} ${E(o)}`),o}finally{se&&console.log(`${e} complete.`)}}f(Yo,"putInSpace_dnasThenNonDnas");function mr({sagaFrame:r}){let t=`[${mr.name}]`;try{if(se&&console.log(`${t} starting... (I: 93521332d0dd2f5e88398b7db95e8126)`),!r)throw new Error("(UNEXPECTED) sagaFrame falsy? (E: 01fb28be6668d88ea49bb298c739c926)");if(!r.data)throw new Error("(UNEXPECTED) sagaFrame.data falsy? (E: 998298eb17685bdb9a85b46488ccd826)");if(!r.data.n&&r.data.n!==0)throw new Error("(UNEXPECTED) sagaFrame.data.n falsy and not 0? (E: 0394919d5b58300ceb09ba6a264ad826)");let e=r.data.n%2;if(e===0)return Ho.sender;if(e===1)return Ho.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{se&&console.log(`${t} complete.`)}}f(mr,"getSyncSagaFrameOrigin");async function Vo({sagaHistory:r}){let t=`[${Vo.name}]`;try{se&&console.log(`${t} starting... (I: fe93a8f29e5d8ab2c8bd0e08e56f7826)`);let e=r.findLast(s=>s.msgStones.some(a=>a.data.stage===z.delta));if(!e)throw new Error("(UNEXPECTED) no delta frame? What are we calling this function for? (E: 9b3201207908f79868b93cd893a91626)");let o=e.msgStones.filter(s=>s.data.stage===z.delta);if(o.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 o[0].data.conflicts}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{se&&console.log(`${t} complete.`)}}f(Vo,"getFinalConflictsInfo");async function Fs({sagaHistory:r,myTempSpace:t}){let e=`[${Fs.name}]`;try{se&&console.log(`${e} starting... (I: b755627e99c9a221566d86a81b0da526)`);let o=await Vo({sagaHistory:r});if(!o||o.length===0)return se&&console.log(`${e} no conflicts found. returning empty array (I: 5dce98010128a284c8ec92cd466a3826)`),[];let n=[];for(let s of o){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 Fe({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(!Ms(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(d=>n.push(d))}return n}catch(o){throw console.error(`${e} ${E(o)}`),o}finally{se&&console.log(`${e} complete.`)}}f(Fs,"getAllOrphanedAddresses");async function Xr({senderSecret:r,sagaId:t}){let e=`[${Xr.name}]`;try{if(se&&console.log(`${e} starting... (I: 0de03f8dcd3e32f1fca244e8f2a8a826)`),!r)throw new Error("(UNEXPECTED) senderSecret falsy? (E: 8ce053fe59825a6678713128953b9d26)");if(!t)throw new Error("(UNEXPECTED) sagaId falsy? (E: 3a17e0c1b2f849de8a42cd15b8ee6826)");return await Es({masterSecret:r,kdfOpts:{strategy:Rr.recursive_salt_wrap,salt:t,rounds:1e4,algorithm:"SHA-256"}})}catch(o){throw console.error(`${e} ${E(o)}`),o}finally{se&&console.log(`${e} complete.`)}}f(Xr,"deriveSessionSecret");var Tc=!1,kt=class r{static{f(this,"LightWitnessBase_V1")}lc=`[${r.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 F(),this.gib=await V({ibGib:this.toIbGibDto()})}toIbGibDto(){return Pt({ibGib:this})}loadIbGibDto(t){let e=`${this.lc}[${this.loadIbGibDto.name}]`;try{return Tc&&console.log(`${e} starting...`),t.ib||console.warn(`${e} dto.ib is falsy.`),t.gib||console.warn(`${e} dto.gib is falsy.`),this.ib=v(t.ib),this.gib=v(t.gib),t.data?this.data=v(t.data):delete this.data,t.rel8ns?this.rel8ns=v(t.rel8ns):delete this.rel8ns,Promise.resolve()}catch(o){throw console.error(`${e} ${o.message}`),o}finally{Tc&&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(o){throw console.error(`${t} ${o.message}`),o}return e}};var zo="subject",js=/^[a-zA-Z0-9_\-.]{1,255}$/,Ac="subject",Sc="",Jo="subject is a cool ibgib witness that has seriously fascinating behavior.";var Gc="observable";var Mt={subscribe:"subscribe"},Cc=Object.values(Mt);var xc={next:"next",error:"error",complete:"complete"};var Bt={...Mt,...xc};var qr={version:"1",uuid:Sc,name:Ac,description:Jo,classname:"Subject_V1",persistOptsAndResultIbGibs:!1,allowPrimitiveArgs:!0,catchAllErrors:!0,trace:!1},Hs=void 0;var Ft=!1;function Nc(r){let t=`[${Nc.name}]`;try{let e=r?`${Or} ${r}`:Or;return Ft&&console.log(`${t} ${e}`),e}catch(e){throw console.error(`${t} ${e.message}`),e}}f(Nc,"getArgIb");function Ld({ib:r,ibGib:t}){let e=`[${Ld.name}]`;try{if(Ft&&console.log(`${e} starting...`),!r)if(t)r=t.ib;else throw new Error("either ib or ibGib required (E: c052a9d76df867626f9ba17141cdce22)");return r.startsWith(Or)}catch(o){throw console.error(`${e} ${o.message}`),o}finally{Ft&&console.log(`${e} complete.`)}}f(Ld,"isArg");function Oc(r){let t=`[${Oc.name}]`;try{let e=r?`${Eo} ${r}`:Eo;return Ft&&console.log(`${t} ${e}`),e}catch(e){throw console.error(`${t} ${e.message}`),e}}f(Oc,"getResultIb");async function Qt({argData:r,ibMetadata:t,noTimestamp:e}){let o=`[${Qt.name}]`;try{let n=await k.firstGen({ib:Nc(t),parentIbGib:k.primitive({ib:Or}),data:r,dna:!1,noTimestamp:e});if(n.newIbGib){let{newIbGib:s}=n;return s.rel8ns.past=[],s.gib=await Nt(s),s}else throw new Error("create ibGib failed")}catch(n){throw console.error(`${o} ${n.message}`),n}}f(Qt,"argy_");async function er({resultData:r,ibMetadata:t,noTimestamp:e}){let o=`[${er.name}]`;try{let n=await k.firstGen({ib:Oc(t),parentIbGib:k.primitive({ib:Eo}),data:r,dna:!1,noTimestamp:e});if(n?.newIbGib){let{newIbGib:s}=n;return s.rel8ns.past=[],s.gib=await Nt(s),s}else throw new Error("create ibGib failed")}catch(n){throw console.error(`${o} ${n.message}`),n}}f(er,"resulty_");function Xs({ibGib:r}){let t=`[${Xs.name}]`;try{if(Ft&&console.log(`${t} starting...`),!r)throw new Error("ibGib required (E: e11cee2a6c59a5e7a4d39ea55751c423)");if(!r.data)return!1;let e=r.data;return e.cmd&&typeof e.cmd=="string"}catch(e){throw console.error(`${t} ${e.message}`),e}finally{Ft&&console.log(`${t} complete.`)}}f(Xs,"isCommand");function qs({ibGib:r}){let t=`[${qs.name}]`;try{return Ft&&console.log(`${t} starting... (I: aad0a14f4d62061424fc92da4d53d823)`),typeof r.witness=="function"}catch(e){throw console.error(`${t} ${e.message}`),e}finally{Ft&&console.log(`${t} complete.`)}}f(qs,"isWitness");var Dc=/^error (\w+) ([a-fA-F\d]{32}|undefined)$/;var jt=!1;function Lc({rawMsg:r}){let t=`[${Lc.name}]`;try{jt&&console.log(`${t} starting...`);let e=Ks({rawMsg:r}),o=e.body.replace(/\s/g,"_").replace(/\W/g,""),n;if(o.length>20)n=o.substring(0,20);else if(o.length>0)n=o;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{jt&&console.log(`${t} complete.`)}}f(Lc,"getErrorIb");function Ks({rawMsg:r}){let t=`[${Ks.name}]`;try{if(jt&&console.log(`${t} starting...`),!r)throw new Error("(UNEXPECTED) rawMsg required (E: e5bd3b433a1781ebe885534cd2495622)");let e,o=r.match(ma);if(o){let[n,s,a,i,c,d]=o;if(!i)throw new Error("invalid error msg body (E: a675e6855cca96519d33d44ea5400922)");e={success:!1,raw:r,body:i?.trim(),uuid:c.slice(4,36)},s&&(e.location=s),(a||d)&&(e.unexpected=!0)}else{e={success:!1,raw:r,body:r};let n=r.match(wa);if(n){let[s,a]=n;e.location=a}r.toLowerCase().includes("(unexpected)")&&(e.unexpected=!0)}return e}catch(e){throw console.error(`${t} ${e.message}`),e}finally{jt&&console.log(`${t} complete.`)}}f(Ks,"parseRawErrorMsg");function tr({rawMsg:r}){let t=`[${tr.name}]`;try{return jt&&console.log(`${t} starting...`),Ze({parentPrimitiveIb:"error",ib:Lc({rawMsg:r}),data:Ks({rawMsg:r}),ibRegExpPattern:Dc.source})}catch(e){throw console.error(`${t} ${e.message}`),e}finally{jt&&console.log(`${t} complete.`)}}f(tr,"getErrorIbGib");function Tt({ibGib:r}){let t=`[${Tt.name}]`;try{if(jt&&console.log(`${t} starting...`),!r)throw new Error("ibGib required (E: 1d756fbbd96f1734b97ba013537ed522)");return r.ib.startsWith("error ")}catch(e){throw console.error(`${t} ${e.message}`),e}finally{jt&&console.log(`${t} complete.`)}}f(Tt,"isError");var Zo=class r{static{f(this,"WitnessFactoryBase")}lc=`[${r.name}]`};var Ws=!1,wr=class r extends Zo{static{f(this,"DynamicFormFactoryBase")}lc=`[${r.name}]`;patchDataFromItems({data:t,contextPath:e,items:o,pathDelimiter:n}){let s=`${this.lc}[${this.patchDataFromItems.name}]`;try{if(Ws&&console.log(`${s} starting...`),!n)throw new Error("pathDelimiter required (E: 958d472a15fb71e45cd2925883f2ec22)");for(let a=0;a<o.length;a++){let i=o[a],c=e?e+n+i.name:i.name;if(!i.items)Tn({obj:t,value:i.value,path:c,logalot:Ws,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{Ws&&console.log(`${s} complete.`)}}};var Pc="subscription",Ys=/^[a-zA-Z0-9_\-.]{1,255}$/,Rc="",Uc="subscription",Qo="subscription is a cool ibgib witness that has seriously fascinating behavior.";var Kr={unsubscribe:"unsubscribe",unsubscribed:"unsubscribed"};var Vs={version:"1",uuid:Rc,name:Uc,description:Qo,classname:"Subscription_V1",persistOptsAndResultIbGibs:!1,allowPrimitiveArgs:!0,catchAllErrors:!1,trace:!1},zs=void 0;var kc=!1;function Js({ibGib:r}){let t=`[${Js.name}]`;try{kc&&console.log(`${t} starting... (I: 3aadb634377acbe42984b61c91975323)`);let{ib:e}=r;return[Gc,zo].some(n=>e.includes(n))}catch(e){throw console.error(`${t} ${e.message}`),e}finally{kc&&console.log(`${t} complete.`)}}f(Js,"isObservable");var q=!1,en=class r extends kt{static{f(this,"Subscription_V1")}lc=`[${r.name}]`;metaspace;_subscribed;_unsubscribed;_srcObservable;constructor(t,e){super(t,e)}async initialize(){let t=`${this.lc}[${this.initialize.name}]`;try{if(q&&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=rn({data:this.data,classname:"Subscription_V1"}),this.gib=await V({ibGib:this})}catch(e){throw console.error(`${t} ${e.message}`),e}finally{q&&console.log(`${t} complete.`)}}async witness(t){let e=`${this.lc}[${this.witness.name}]`;try{this._isInitialized||await this.initialized;let{ib:o}=t;if(!o)throw new Error("arg.ib required (E: 1fd9aebef07b4bdaacc0cd323c8ddf76)");if(q&&console.log(`${e} ib: ${o} (I: 4de7771f477dc5b36933343b694ce223)`),o===Kr.unsubscribe)return q&&console.log(`${e} routing unsubscribe cmd (I: 5633b86d467af2aa67388abf559a3c23)`),this.witness_unsubscribe();if(o===Kr.unsubscribed)return q&&console.log(`${e} routing unsubscribed query (I: 6e0ae61d90f1974d76bcdbb47970e723)`),this.witness_unsubscribed();if(Js({ibGib:t}))return q&&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(o){throw console.error(`${e} ${E(o)??"unknown error (E: b0bbaab21833404a9420c3d273df7f21)"}`),o}}async witness_unsubscribe(){let t=`${this.lc}[${this.witness_unsubscribe.name}]`;try{if(q&&console.log(`${t} starting... (I: a3d549220ef24604956aaa2c66fff09b)`),!this._subscribed)return console.warn(`${t} tried to unsubscribe but this._subscribed is ${this._subscribed} (W: cdc94f59447d4011b4b4cc12ef9ec074)`),Y;if(this._unsubscribed)return console.warn("{lc} this._unsubscribed already true. (W: fa287d76cec040e0978a8add5c758093)"),Y;if(!this._srcObservable)throw new Error("(UNEXPECTED) this._subscribed but this._srcObservable falsy? (E: 83687993b7bea299b4ba2438b530a123)");return q&&(console.log(`${t} inspecting srcObservable before src.witness... (I: f15a33d10f1cae3cec6fdbdb32596823)`),console.dir(this._srcObservable)),await this._srcObservable.witness(this),q&&(console.log(`${t} inspecting srcObservable after src.witness... (I: f15a33d10f1cae3cec6fdbdb32596823)`),console.dir(this._srcObservable)),this._subscribed=!1,this._unsubscribed=!0,delete this._srcObservable,q&&console.log(`${t} this._ (I: 7b1bc418a3d32757772391cad7a49523)`),Y}catch(e){throw console.error(`${t} ${e.message}`),e}finally{q&&console.log(`${t} complete.`)}}async witness_observable({ibGib:t}){let e=`${this.lc}[${this.witness_observable.name}]`;try{if(q&&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,q&&console.log(`${e} this._srcObservable set to ibgib with ib: ${t.ib} (I: 4b81d17243f60dfdcc2163fbb55e9223)`),this._subscribed=!0,Y}catch(o){throw console.error(`${e} ${o.message}`),o}finally{q&&console.log(`${e} complete.`)}}async witness_unsubscribed(){let t=`${this.lc}[${this.witness_unsubscribed.name}]`;try{if(q&&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?Un:Fa;return q&&console.log(`${t} result: ${P(e)} (I: b488cf36ce39e006a81d3ad3db5b4a23)`),e}catch(e){throw console.error(`${t} ${e.message}`),e}finally{q&&console.log(`${t} complete.`)}}async unsubscribe(){let t=`${this.lc}[${this.unsubscribe.name}]`;try{q&&console.log(`${t} starting... (I: ef7f3f4787a74fcca65d761880f44594)`);let e=await this.witness(k.primitive({ib:Kr.unsubscribe}));if(!e)throw new Error("(UNEXPECTED) unsubscribe returned undefined? (E: 7013193490b94b6880f1049c36577d6f)");if(Tt({ibGib:e})){let o=e;throw new Error(`${o.data.raw} (E: fca1200dccb14f84968b2462f1b4c29e)`)}}catch(e){throw console.error(`${t} ${e.message}`),e}finally{q&&console.log(`${t} complete.`)}}async unsubscribed(){let t=`${this.lc}[${this.unsubscribed.name}]`;try{q&&console.log(`${t} starting... (I: 8ee9a93be61647d6aef6a4fa03e96dad)`);let e=await this.witness(k.primitive({ib:Kr.unsubscribed}));if(!e)throw new Error("(UNEXPECTED) unsubscribe returned undefined? (E: 5051d7ff4a4d4bf7864c520b53f028d5)");let o=e.ib===Un.ib;return q&&console.log(`${t} resUnsubscribed: ${o} (I: b4800166c58d5ba2ca1dccaa53de2323)`),o}catch(e){throw console.error(`${t} ${e.message}`),e}finally{q&&console.log(`${t} complete.`)}}async validateThis(){let t=`${this.lc}[${this.validateThis.name}]`;try{return q&&console.log(`${t} starting...`),this.data,[]}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{q&&console.log(`${t} complete.`)}}async argy({argData:t,ibMetadata:e,noTimestamp:o,ibGibs:n}){let s=await Qt({argData:t,ibMetadata:e,noTimestamp:o});return n&&(s.ibGibs=n),s}async resulty({resultData:t,ibGibs:e}){let o=await er({resultData:t});return e&&(o.ibGibs=e),o}},tn=class r extends wr{static{f(this,"Subscription_V1_Factory")}lc=`[${r.name}]`;getName(){return en.name}async newUp({data:t,rel8ns:e}){let o=`${this.lc}[${this.newUp.name}]`;try{q&&console.log(`${o} starting...`),t??=v(Vs),t=t,e=e??zs?v(zs):void 0,t.uuid||=await F();let{classname:n}=t,s=rn({data:t}),a=await Ze({parentPrimitiveIb:`witness ${n}`,ib:s,data:t,rel8ns:e}),i=new en(void 0,void 0);return await i.loadIbGibDto(a),q&&console.log(`${o} witnessDto: ${P(a)} (I: 5e41337176d1441f9a5c7b43664d43ef)`),{newIbGib:i}}catch(n){throw console.error(`${o} ${E({error:n})}`),n}finally{q&&console.log(`${o} complete.`)}}async witnessToForm({witness:t}){let e=`${this.lc}[${this.witnessToForm.name}]`;try{q&&console.log(`${e} starting...`);let{data:o}=t;if(!o)throw new Error("(UNEXPECTED) witness.data falsy? (E: ef44497ff97a4e5bac004d52c4ff40eb)");q&&console.log(`${e} data: ${P(o)} (I: c3f4c3d85386461aaefbe33524ff9cbd)`);let n=await Tr({n:100}),s=new on().with({idPool:n}).name({of:o.name,required:!1}).description({of:o.description??Qo}).and().and().uuid({of:o.uuid,required:!0}).classname({of:o.classname}).and().commonWitnessFields({data:o}).outputForm({formName:"form",label:"subscription"});return Promise.resolve(s)}catch(o){throw console.error(`${e} ${E({error:o})}`),o}finally{q&&console.log(`${e} complete.`)}}async formToWitness({form:t}){let e=v(Vs);return this.patchDataFromItems({data:e,items:t.items,pathDelimiter:or}),await this.newUp({data:e})}};var nn=!1;function Mc({data:r}){let t=`[${Mc.name}]`;try{if(nn&&console.log(`${t} starting...`),!r)throw new Error("Subscription Data required (E: 6d1c97931dcab8ea9f3e9b32c794b90c)");let e=[],{name:o,uuid:n,classname:s}=r;return o?o.match(Ys)||e.push(`name must match regexp: ${Ys} (E: 21bf77e398d47e9d035376510505eda2)`):e.push("name required."),n?n.match(ie)||e.push(`uuid must match regexp: ${ie} (E: e53fd08ae69e945b37ed895b864b6bd7)`):e.push("uuid required."),s&&(s.match(xt)||e.push(`classname must match regexp: ${xt}`)),e}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{nn&&console.log(`${t} complete.`)}}f(Mc,"validateCommonSubscriptionData");function rn({data:r,classname:t}){let e=`[${rn.name}]`;try{let o=Mc({data:r});if(o.length>0)throw new Error(`invalid Subscription data: ${o} (E: fd6b0b32d8f6c4b97eebd489cdb07a4a)`);if(t){if(r.classname&&r.classname!==t)throw new Error("classname does not match data.classname (E: 354285a56a20b9b65b06abfcd9f2e621)")}else if(t=r.classname,!t)throw new Error("classname required (E: 040c1fd71853fa7874146999afb355c3)");let{uuid:n}=r;return`witness ${Pc} ${t} ${n}`}catch(o){throw console.error(`${e} ${E(o)}`),o}}f(rn,"getSubscriptionIb");var on=class r extends vt{static{f(this,"SubscriptionFormBuilder")}lc=`[${r.name}]`;constructor(){super(),this.what="subscription"}};function sn({ibGib:r}){let t=`[${sn.name}]`;try{if(nn&&console.log(`${t} starting... (I: 43df7e7f61f25e65662ce8aa5a105a23)`),!r)return!1;let e=r;return typeof e.witness=="function"&&typeof e.unsubscribe=="function"&&typeof e.unsubscribed=="function"}catch(e){throw console.error(`${t} ${e.message}`),e}finally{nn&&console.log(`${t} complete.`)}}f(sn,"isSubscription");async function Bc(){return(await new tn().newUp({})).newIbGib}f(Bc,"newupSubscription");var Zs="observable_event";var Fc=!1;async function Qs({eventType:r,srcObservable:t,payload:e}){let o=`[${Qs.name}]`;try{if(Fc&&console.log(`${o} 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(ie))throw new Error(`valid srcObservable.data.uuid required. must pass UUID_REGEXP: ${ie.source} (E: 10f4bd1863f18250cc79cd65221da223)`);let n={uuid:await F(),eventType:r,srcObservableId:t.data.uuid,"@srcObservableAddr":w({ibGib:t}),"@payloadAddr":w({ibGib:e})};return await Ze({parentPrimitiveIb:Zs,ib:jc({data:n}),data:n})}catch(n){throw console.error(`${o} ${n.message}`),n}finally{Fc&&console.log(`${o} complete.`)}}f(Qs,"getObservableEventIbGib");function jc({data:r,classname:t}){let e=`[${jc.name}]`;try{if(t){if(r.classname&&r.classname!==t)throw new Error("classname does not match data.classname (E: 523aabc53fb944789202a5f468abd338)")}else if(t=r.classname,!t)throw new Error("classname required (E: d4401ea682894c5fa824b38d4989aa76)");if(!r.uuid)throw new Error("data.uuid required (E: 204cc7c20efd8a55263cdea8b1223e23)");return`${Zs} ${t} ${r.uuid}`}catch(o){throw console.error(`${e} ${E(o)}`),o}}f(jc,"getObservableEventIb");var te=!1,an=class r extends kt{static{f(this,"ObservableBase_V1")}lc=`[${r.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:o}=t;if(!o)throw new Error("arg.ib required (E: 87659d093b82436ce2f7a87e402a5423)");if(Xs({ibGib:t}))return this.witness_cmd({arg:t});if(qs({ibGib:t}))return this.witness_otherWitness({arg:t});throw new Error("unknown arg. expect observable cmd or ibgib witness (E: dc2667cffac5b8d7b1bf2ea737c81a23)")}catch(o){throw console.error(`${e} ${E(o)??"unknown error (E: 3e22bea4c7fb4668bf13d7146b927869)"}`),o}}async witness_cmd({arg:t}){let e=`${this.lc}[${this.witness_cmd.name}]`;try{if(te&&console.log(`${e} starting... (I: 69257fac8328b9de9755fdd237b92723)`),t.data.cmd===Mt.subscribe)return this.witness_subscribe_cmd({ibGib:t});throw new Error(`unknown command. must be of type ObservableCmd (${Cc}) (E: 5910e5cbafead25ea2917a65a3fc4123)`)}catch(o){throw console.error(`${e} ${o.message}`),o}finally{te&&console.log(`${e} complete.`)}}async witness_otherWitness({arg:t}){let e=`${this.lc}[${this.witness_otherWitness.name}]`;try{return te&&console.log(`${e} starting... (I: 871d0b7a2bef4596bad430f1cbacde02)`),sn({ibGib:t})?this.witness_subscriptionIbGib({arg:t}):this.witness_subscribe_nonCmdWitness({arg:t})}catch(o){throw console.error(`${e} ${o.message}`),o}finally{te&&console.log(`${e} complete.`)}}async witness_subscriptionIbGib({arg:t}){let e=`${this.lc}[${this.witness_subscriptionIbGib.name}]`;try{if(te&&console.log(`${e} starting... (I: 4ac764776ef7e3f9074eb95a999ba423)`),!t.data)throw new Error("arg.data required (E: 764ae772727ceba95a18140fdd938323)");let o=this.getSubscriberKey({subscription:t}),[n,s]=this._subscribers[o];if(t===n)delete this._subscribers[o];else throw new Error("(UNEXPECTED) arg and subscription are two different instances? (E: aab5ef9bdc92abb9e816e2c443ab5723)");return Y}catch(o){throw console.error(`${e} ${o.message}`),o}finally{te&&console.log(`${e} complete.`)}}async replayPastPayloads({observer:t,subscription:e}){let o=`${this.lc}[${this.replayPastPayloads.name}]`;try{te&&console.log(`${o} 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()){te&&console.log(`${o} subscription canceled before past payloads dispatch completed. (I: f1778f868446a518030d1cf7800c8a23)`);return}try{let c=this._pastPayloads[a];await t.next(c)}catch{console.error(`${o} 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(`${o} observer.error(this._pastError) errored itself (E: 18310e5e032345e7bdc3f2479807866c)`)}else if(this.isComplete&&t.complete&&s())try{await t.complete()}catch{console.error(`${o} observer.complete errored (E: d9d027f5520f4d7eadfc669d66b5b550)`)}}catch(n){throw console.error(`${o} ${n.message}`),n}finally{te&&console.log(`${o} complete.`)}}async witness_subscribe_cmd({ibGib:t}){let e=`${this.lc}[${this.witness_subscribe_cmd.name}]`;try{if(te&&console.log(`${e} starting... (I: 0c4c75c3fae297af6449c1048ce55423)`),(t.ibGibs??[]).length!==1)throw new Error("ibGib.ibGibs required. should contain one ObserverWitness (E: 3ed99b32e22284573c497df788a9f923)");let o=t.ibGibs[0],n=await Bc();return te&&console.log(`${e} subscription created (I: 89ccd97803c66292f9d7334e1e2de523)`),await n.witness(this),await n.initialized,te&&console.log(`${e} subscription initialized (after witnessing this observable as its src). (I: 3021483402b21c4df64a9173bd223a23)`),this._subscribers[this.getSubscriberKey({subscription:n})]=[n,o],te&&console.log(`${e} stored subscriber (subscription, observer) (I: fb09660d885e33b80188dd0386ffc723)`),this.data.replay&&this._pastPayloads.length>0&&this.replayPastPayloads({observer:o,subscription:n}),n}catch(o){throw console.error(`${e} ${o.message}`),o}finally{te&&console.log(`${e} complete.`)}}async witness_subscribe_nonCmdWitness({arg:t}){let e=`${this.lc}[${this.witness_subscribe_nonCmdWitness.name}]`;try{throw te&&console.log(`${e} starting... (I: d9571dfcab4247d594c838233971886a)`),new Error("not impl (E: 76219cf238ba4f849480bd7c82eefab9)")}catch(o){throw console.error(`${e} ${o.message}`),o}finally{te&&console.log(`${e} complete.`)}}async subscribe(t){let e=`${this.lc}[${this.subscribe.name}]`;try{te&&console.log(`${e} starting... (I: 0dec9a06c562711e19482d45a7075e23)`);let o;if(rr({ibGib:t})){let n=await this.argy({argData:{cmd:Mt.subscribe,ibGibAddrs:[w({ibGib:t})]},ibGibs:[t]});o=await this.witness(n)}else o=await this.witness(t);if(!sn({ibGib:o}))throw new Error("(UNEXPECTED) resSubscription is not a SubscriptionWitness? (E: c29bec4e3a48d6f1299143399ac55a23)");return o}catch(o){throw console.error(`${e} ${o.message}`),o}finally{te&&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:o}){let n=`${this.lc}[${this.dispatchToEachSubscriber.name}]`;try{te&&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(rr({ibGib:c})){let d=c;await e(d,t),d.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 d.complete():te&&console.log(`${n} no error handler for observer. skipping. (I: 6a8a52c2012c464790eb406d2ae0383f)`)}else{let d=await Qs({eventType:o,srcObservable:this,payload:t});await c.witness(d)}}}catch(s){throw console.error(`${n} ${s.message}`),s}finally{te&&console.log(`${n} complete.`)}}async validateThis(){let t=`${this.lc}[${this.validateThis.name}]`;try{return te&&console.log(`${t} starting...`),this.data,[]}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{te&&console.log(`${t} complete.`)}}async argy({argData:t,ibMetadata:e,noTimestamp:o,ibGibs:n}){let s=await Qt({argData:t,ibMetadata:e,noTimestamp:o});return n&&(s.ibGibs=n),s}async resulty({resultData:t,ibGibs:e}){let o=await er({resultData:t});return e&&(o.ibGibs=e),o}};var K=!1,cn=class r extends an{static{f(this,"Subject_V1")}lc=`[${r.name}]`;constructor(t,e){super(t,e)}asObservable(){return this}async subscribe(t){let e=`${this.lc}[${this.subscribe.name}]`;try{K&&console.log(`${e} starting... (I: 8e47b752314870ec78eb14342621f723)`);let o=await this.argy({argData:{cmd:Bt.subscribe,ibGibAddrs:[w({ibGib:t})]},ibGibs:[t]});return await this.witness(o)}catch(o){throw console.error(`${e} ${o.message}`),o}finally{K&&console.log(`${e} complete.`)}}async next(t){let e=`${this.lc}[${this.next.name}]`;try{K&&console.log(`${e} starting... (I: b30363827c56450ca918c69aa15b0046)`);let o=await this.argy({argData:{cmd:Bt.next,ibGibAddrs:[w({ibGib:t})]},ibGibs:[t]});await this.witness(o)}catch(o){throw console.error(`${e} ${o.message}`),o}finally{K&&console.log(`${e} complete.`)}}async error(t){let e=`${this.lc}[${this.error.name}]`;try{K&&console.log(`${e} starting... (I: 7fcc30e3763c429ea8b212491ad9455a)`);let o;if(typeof t=="string")o=await tr({rawMsg:t});else if(t instanceof Error||typeof t.message=="string")o=await tr({rawMsg:E(t)});else if(t.ib&&Tt({ibGib:t}))o=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:o})]},ibGibs:[o]});await this.witness(n)}catch(o){throw console.error(`${e} ${o.message}`),o}finally{K&&console.log(`${e} complete.`)}}async complete(){let t=`${this.lc}[${this.complete.name}]`;try{K&&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{K&&console.log(`${t} complete.`)}}async witness_cmd({arg:t}){let e=`${this.lc}[${this.witness_cmd.name}]`;try{K&&console.log(`${e} starting... (I: 2bf7cbcadba446fa92cb649906b2b260)`);let{cmd:o}=t.data;switch(o){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(o){throw console.error(`${e} ${o.message}`),o}finally{K&&console.log(`${e} complete.`)}}async witness_next({ibGib:t}){let e=`${this.lc}[${this.witness_next.name}]`;try{if(K&&console.log(`${e} starting... (I: 600da780f13f5137a2f76aad344b2923)`),this.isCompleteOrErrored)return K&&console.log(`${e} this.isCompleteOrErrored is true. returning early without producing. (I: aa823831853b134b19657c8673838c23)`),Y;if((t.ibGibs??[]).length!==1)throw new Error("ibGib.ibGibs required. should contain one payload ibgib (E: 4046802ff96d4adfafcee7a74d96af5e)");let o=t.ibGibs[0];this.data.replay&&this._pastPayloads.push(o);let n=Object.values(this._subscribers);for(let s=0;s<n.length;s++){let[a,i]=n[s];if(K&&console.log(`${e} ensuring subscription not unsubscribed (I: ade3fd6d6ff2b5ec69eb8143e32ce223)`),!await a.unsubscribed())K&&console.log(`${e} subscription still active (I: b9ab83b28acecf0d823fdba46a81dc23)`),await i.next(o);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 Y}catch(o){throw console.error(`${e} ${o.message}`),o}finally{K&&console.log(`${e} complete.`)}}async witness_error({ibGib:t}){let e=`${this.lc}[${this.witness_error.name}]`;try{if(K&&console.log(`${e} starting... (I: 3367a73bc83c47f98d9ecfe426dc300e)`),(t.ibGibs??[]).length!==1)throw new Error("ibGib.ibGibs required. should contain one error ibgib (E: 905474b45bcb4f0abe7bd4618f08f32c)");let o=t.ibGibs[0];this._pastError=o;let n=Object.values(this._subscribers);for(let s=0;s<n.length;s++){let[a,i]=n[s];if(rr({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(o):K&&console.log(`${e} no error handler for observer. skipping. (I: 59f4a1ee59a3a27d523d60cd761be923)`)}else await i.witness(o)}return Y}catch(o){throw console.error(`${e} ${o.message}`),o}finally{K&&console.log(`${e} complete.`)}}async witness_complete({ibGib:t}){let e=`${this.lc}[${this.witness_complete.name}]`;try{K&&console.log(`${e} starting... (I: 4db180f465e24df9a4ded37fbd235558)`),this._isComplete=!0;let o=Object.values(this._subscribers);for(let n=0;n<o.length;n++){let[s,a]=o[n];if(rr({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():K&&console.log(`${e} no error handler for observer. skipping. (I: 6a8a52c2012c464790eb406d2ae0383f)`)}else await a.witness(t)}return Y}catch(o){throw console.error(`${e} ${o.message}`),o}finally{K&&console.log(`${e} 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:o,ibGibs:n}){if(t.cmd===Mt.subscribe)return super.argy({argData:t,ibMetadata:e,noTimestamp:o,ibGibs:n});{let s=await Qt({argData:t,ibMetadata:e,noTimestamp:o});return n&&(s.ibGibs=n),s}}async resulty({resultData:t,ibGibs:e}){let o=await er({resultData:t});return e&&(o.ibGibs=e),o}},ln=class r extends wr{static{f(this,"Subject_V1_Factory")}lc=`[${r.name}]`;getName(){return cn.name}async newUp({data:t,rel8ns:e}){let o=`${this.lc}[${this.newUp.name}]`;try{K&&console.log(`${o} starting...`),t??=v(qr),t=t,e=e??Hs?v(Hs):void 0,t.uuid||=await F();let{classname:n}=t,s=ea({data:t}),a=await Ze({parentPrimitiveIb:`witness ${n}`,ib:s,data:t,rel8ns:e}),i=new cn(void 0,void 0);return await i.loadIbGibDto(a),K&&console.log(`${o} witnessDto: ${P(a)} (I: 6736d2b2ddf44fef9a1eb27078dfbf23)`),{newIbGib:i}}catch(n){throw console.error(`${o} ${E({error:n})}`),n}finally{K&&console.log(`${o} complete.`)}}async witnessToForm({witness:t}){let e=`${this.lc}[${this.witnessToForm.name}]`;try{K&&console.log(`${e} starting...`);let{data:o}=t;if(!o)throw new Error("(UNEXPECTED) witness.data falsy? (E: 7b70c96e982d4f81b6ffda54da16b3b8)");K&&console.log(`${e} data: ${P(o)} (I: 75abef56f5004a94b2113e3b1461ac25)`);let n=await Tr({n:100}),s=new dn().with({idPool:n}).name({of:o.name,required:!1}).description({of:o.description??Jo}).and().and().uuid({of:o.uuid,required:!0}).classname({of:o.classname}).and().commonWitnessFields({data:o}).outputForm({formName:"form",label:"observable"});return Promise.resolve(s)}catch(o){throw console.error(`${e} ${E({error:o})}`),o}finally{K&&console.log(`${e} complete.`)}}async formToWitness({form:t}){let e=v(qr);return this.patchDataFromItems({data:e,items:t.items,pathDelimiter:or}),await this.newUp({data:e})}};var fn=!1;function Hc({data:r}){let t=`[${Hc.name}]`;try{if(fn&&console.log(`${t} starting...`),!r)throw new Error("Subject Data required (E: 207a82725648e2ef234c8bd3fa1a5312)");let e=[],{name:o,uuid:n,classname:s}=r;return o?o.match(js)||e.push(`name must match regexp: ${js} (E: de987eb8fea0b6232f60abf31815095c)`):e.push("name required."),n?n.match(ie)||e.push(`uuid must match regexp: ${ie} (E: 1a6dfda91ad51696f7456bc84dfea60e)`):e.push("uuid required."),s&&(s.match(xt)||e.push(`classname must match regexp: ${xt}`)),e}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{fn&&console.log(`${t} complete.`)}}f(Hc,"validateCommonSubjectData");function ea({data:r,classname:t}){let e=`[${ea.name}]`;try{let o=Hc({data:r});if(o.length>0)throw new Error(`invalid Subject data: ${o} (E: 55620ac1f17e30a30a92850219f894ac)`);if(t){if(r.classname&&r.classname!==t)throw new Error("classname does not match data.classname (E: 20e86cca70130839a49ad011c9a7aafa)")}else if(t=r.classname,!t)throw new Error("classname required (E: 74e29ae0f618fee7e7ef72a30c654a6c)");let{name:n,uuid:s}=r;return`witness ${zo} ${t} ${n} ${s}`}catch(o){throw console.error(`${e} ${E(o)}`),o}}f(ea,"getSubjectIb");var dn=class r extends vt{static{f(this,"SubjectFormBuilder")}lc=`[${r.name}]`;constructor(){super(),this.what="subject"}};function rr({ibGib:r}){let t=`[${rr.name}]`;try{return fn&&console.log(`${t} starting... (I: b54c252104f710c12951aa43b6ead323)`),typeof r.next=="function"}catch(e){throw console.error(`${t} ${e.message}`),e}finally{fn&&console.log(`${t} complete.`)}}f(rr,"isObserver");async function bn({data:r,replay:t}={}){let e=new ln;return r??=v(qr),t&&(r.replay=!0),(await e.newUp({data:r})).newIbGib}f(bn,"newupSubject");var hn="sync_sagacontext";var $r=!1;async function ta({data:r}){let t=`[${ta.name}]`;try{if(!r)throw new Error("data required (E: 839d82138c234b3e89582855594191fe)");let e=r["@payloadAddrsDomain"]?r["@payloadAddrsDomain"].length:0;return[hn,r.sagaN,e].join(" ")}catch(e){throw console.error(`${t} ${E(e)}`),e}}f(ta,"getSyncSagaContextIb");async function yr({context:r}){let t=`[${yr.name}]`;try{$r&&console.log(`${t} starting... (I: 7797f8294bd8f7e5089cb722ad468226)`);let e=[],o=await J({ibGib:r});return o&&o.length>0?(o.forEach(n=>e.push(n)),e):(r.sagaFrame?(await Ko({sagaIbGib:r.sagaFrame})).forEach(s=>e.push(s)):e.push("context.sagaFrame is falsy. (E: b4edd88f4963f493789f83b29ba2df26)"),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{$r&&console.log(`${t} complete.`)}}f(yr,"validateContextAndSagaFrame");async function ra({}){let r=`[${ra.name}]`;try{return $r&&console.log(`${r} starting... (I: 3c34e8f1d6ef965f98725c88459ea926)`),console.warn(`${r}[NAG] not thrown. not implemented right now after removing all identity-related code. (W: e5fad31cfb49eef198a189a82dbcf726)`),[]}catch(t){throw console.error(`${r} ${E(t)}`),t}finally{$r&&console.log(`${r} complete.`)}}f(ra,"authenticateContext");async function oa({context:r,fullSagaHistory:t}){let e=`[${oa.name}]`;try{return $r&&console.log(`${e} starting... (I: 48c918b41ceec0cd489ca3b8819e6826)`),console.error(`${e} NAG ERROR (NOT THROWN): not implemented. authorize business logic (v1 must have this, but later when we are working on admin vs. student)(E: bc3a78f2dab18ab64c36d055a4b50526)`),[]}catch(o){throw console.error(`${e} ${E(o)}`),o}finally{$r&&console.log(`${e} complete.`)}}f(oa,"authorizeContext");var me=!1;var pn=class r extends kt{static{f(this,"SyncPeer_V1")}lc=`[${r.name}]`;opts;payloadIbGibsDomainReceived$;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 bn()}async connect(t){let e=`${this.lc}[${this.connect.name}]`;try{me&&console.log(`${e} starting... (I: ad89d8137351662fb8a30114a1fa4826)`),await this.preConnectCheck(t),await this.connectImpl(t)}catch(o){throw console.error(`${e} ${E(o)}`),o}finally{me&&console.log(`${e} complete.`)}}async establishSessionIdentity(){let t=`${this.lc}[${this.establishSessionIdentity.name}]`;try{if(me&&console.log(`${t} starting... (I: f2a1b3c4d5e6f7a8b9c0d1e2f3a4b526)`),!this.opts)throw new Error("(UNEXPECTED) this.opts falsy? Call initializeOpts first. (E: a1b2c3d4e5f6a7b8c9d0e1f2a3b4c526)");let{senderIdentity:e,fnSenderSecret:o,sagaId:n,localMetaspace:s,localSpace:a}=this.opts;if(!e||!o){me&&console.log(`${t} no senderIdentity/fnSenderSecret \u2014 skipping establish (I: f29348a77d1542326d14043ea4b69126)`);return}if(!n)throw new Error("(UNEXPECTED) sagaId falsy? Must be set in initializeOpts before calling establishSessionIdentity. (E: c6ba389d51b8af07d82458f875cf9826)");let i=await o();if(!i)throw new Error("senderSecret falsy. senderSecret required. (E: 1a8b0298bf78cbdf284b7988983b9826)");let c=await Xr({senderSecret:i,sagaId:n}),d=new Oe;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 l=await d.genesis({masterSecret:c,configs:[this.opts.sessionConnectPoolConfig,this.opts.sessionSyncPoolConfig],frameDetails:this.opts.targetAddrs?{targetAddrs:this.opts.targetAddrs}:void 0,metaspace:s,space:a}),b=w({ibGib:l}),h=await d.sign({latestKeystone:e,masterSecret:i,claim:{verb:pr,target:b},metaspace:s,space:a});return await this.postEstablishToReceiver({newSenderIdentity:h,sessionIdentity:l}),l}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{me&&console.log(`${t} complete.`)}}async initializeOpts(t){let e=`${this.lc}[${this.initializeOpts.name}]`;try{me&&console.log(`${e} starting... (I: 31bd5fda37c89fa37fbaf14daf5fe726)`),this.opts=t}catch(o){throw console.error(`${e} ${E(o)}`),o}finally{me&&console.log(`${e} complete.`)}}setOptionalOpts(t){let e=`${this.lc}[${this.setOptionalOpts.name}]`;try{if(me&&console.log(`${e} starting... (I: ae5ddbd3577db267f84743175a736626)`),!this.opts)throw new Error("(UNEXPECTED) this.opts falsy? (E: 0dd4d6080a6e2f31d86cf4d86e11b826)");me&&console.log(`${e} updating opts. arg keys: ${Object.keys(t)} (I: 452d78a558f8fc3468c8e2e68c70b226)`),this.opts={...this.opts,...t}}catch(o){throw console.error(`${e} ${E(o)}`),o}finally{me&&console.log(`${e} complete.`)}}async authenticateValidateAuthorize({context:t,fullSagaHistory:e}){let o=`${this.lc}[${this.authenticateValidateAuthorize.name}]`;try{if(me&&console.log(`${o} starting... (I: add238055cd84a222c5b8c89913af526)`),!this.opts)throw new Error("(UNEXPECTED) opts falsy in authenticateValidateAuthorize (E: b7e5a8ad99d84e1ba8d8f7facd288826)");let{localSpace:n}=this.opts,s=await ra({context:t,space:n});if(s.length>0)throw new Error(`invalid context authentication. authenticationErrors: ${s} (E: da89da5ee1269aeb78952d475d607526)`);let a=await yr({context:t});if(a.length>0)throw new Error(`invalid context received. validationErrors: ${a} (E: 8b34c875c968af29bc433138e57a7826)`);let i=await oa({context:t,fullSagaHistory:e});if(i.length>0)throw new Error(`invalid context authorization. authorizationErrors: ${i} (E: 8ddc284a758cf10ba829334c1babb826)`)}catch(n){throw console.error(`${o} ${E(n)}`),n}finally{me&&console.log(`${o} complete.`)}}async witness(t){let e=`${this.lc}[${this.witness.name}]`;try{if(me&&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)");let o=await Zt({sagaIbGib:t.sagaFrame,space:this.opts.localSpace});await this.authenticateValidateAuthorize({context:t,fullSagaHistory:o});let n=await this.sendContextRequest(t);if(n){let s=await Zt({sagaIbGib:t.sagaFrame,space:this.opts.localSpace});return await this.authenticateValidateAuthorize({context:t,fullSagaHistory:s}),n}else{me&&console.log(`${e} No response from peer. this may be normal if we just sent the very last commit frame. (I: 1855b7728c8898e1f9c001f8170ba826)`);return}}catch(o){throw console.error(`${e} ${E(o)}`),o}finally{me&&console.log(`${e} complete.`)}}async getLocalIbGib(t){let e=`${this.lc}[${this.getLocalIbGib.name}]`;try{if(me&&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 o=await X({space:this.opts.localSpace,addr:t});if(o.success&&o.ibGibs&&o.ibGibs.length===1)return o.ibGibs[0];throw new Error(`couldn't get addr (${t}) from local space ${this.opts.localSpace}. reason: ${o.errorMsg??"unknown error (E: 926ef8bf4fcc299ab89dba34ea691a26)"} (E: d8a89807e471d3f8b938ab21df44cb26)`)}catch(o){throw console.error(`${e} ${E(o)}`),o}finally{me&&console.log(`${e} complete.`)}}};var Xc=!1,ft={COMMON:{ALGO:Se.sha_256,TYPE:Ve.hash_reveal_v1,ROUNDS:2,REPLENISH:de.topUp},CONNECT_POOL:{ID:It,VERB:Ut,SIZE:10,SELECT_SEQUENTIALLY:2,SELECT_RANDOMLY:2,TARGET_BINDING_CHARS:0,SERVER_DEMAND_COUNT:3}};function Wr(r){let t=`[${Wr.name}]`;try{Xc&&console.log(`${t} starting... (I: 3c791af2f978a00a087dfdde90884826)`);let e=(r.data?.challengePools??[]).find(a=>a.id===ft.CONNECT_POOL.ID);if(!e)throw new Error(`Keystone missing "${ft.CONNECT_POOL.ID}" pool (E: 6382e29260e4ddbac42ed18f49733526)`);let o=Object.keys(e.challenges).sort();if(o.length===0)throw new Error("Connect pool has no challenges (E: 1ef62fdbda182a790835c8c796475226)");let n=o[0],s=e.challenges[n];return{challengeId:n,challenge:s}}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{Xc&&console.log(`${t} complete.`)}}f(Wr,"getConnectChallenge");var At=!0,Yr=class r extends pn{static{f(this,"SyncPeerWebSocketSender_V1")}lc=`[${r.name}]`;get classname(){return r.name}get isSocketOpen(){return this.ws!==void 0&&this.ws.readyState===WebSocket.OPEN}ws;activeResolve;activeReject;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 o=`${this.lc}[${this.postEstablishToReceiver.name}]`;try{if(At&&console.log(`${o} 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)`)}At&&console.log(`${o} evolve post accepted by server.`)}catch(n){throw console.error(`${o} establish post failed: ${E(n)}`),n}}async connectImpl(t){let e=`${this.lc}[${this.connectImpl.name}]`;try{At&&console.log(`${e} starting...`);let{senderIdentity:o,fnSenderSecret:n,sagaId:s,localMetaspace:a,localSpace:i}=this.opts;if(!o||!n||!s)throw new Error("Missing identity parameters in peer options (E: ed49b6711ac82efcdb42b8a28c5b6826)");let c=await n(),d=await Xr({senderSecret:c,sagaId:s}),l=w({ibGib:o}),b=w({ibGib:(o.rel8ns?.past,o)}),h=await a.getLatestAddr({ibGib:o,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 y=(await a.get({addrs:[g],space:i})).ibGibs?.[0];if(!y)throw new Error(`Session keystone not found in local space: ${g} (E: 9ba818e6622808bb4ae749be31f80b26)`);let I=(y.data?.challengePools??[]).find(D=>D.id===ft.CONNECT_POOL.ID);if(!I)throw new Error("Session keystone missing connect pool (E: f50968afca04b6d38ec19824ea201826)");let{challengeId:T}=Wr(y),$=ze.create({config:I.config}),_=await $.derivePoolSecret({masterSecret:d}),A=await $.generateSolution({poolSecret:_,poolId:ft.CONNECT_POOL.ID,challengeId:T}),G=`${this.data.wsUrl}?sAddr=${encodeURIComponent(g)}&solution=${encodeURIComponent(A.value)}`;At&&console.log(`${e} connecting to WebSocket: ${G}`);let N=new WebSocket(G);return this.ws=N,new Promise((D,L)=>{let j=!1;N.addEventListener("open",()=>{At&&console.log(`${e} WebSocket opened. Awaiting challenge...`)}),N.addEventListener("message",async B=>{try{let U=JSON.parse(B.data);if(At&&console.log(`${e} received frame: ${U.type}`),U.type==="auth-challenge-init")N.send(JSON.stringify({type:"auth-init",sAddr:g}));else if(U.type==="auth-challenge"){let{challengeUuid:re,demandedIds:Q}=U;At&&console.log(`${e} solving demanded challenges: ${Q.join(", ")}`);let He=await new Oe().sign({latestKeystone:y,masterSecret:d,poolId:ft.CONNECT_POOL.ID,requiredChallengeIds:Q,claim:{verb:ft.CONNECT_POOL.VERB,target:re},metaspace:a,space:i});N.send(JSON.stringify({type:"auth-proof",proofFrame:He}))}else U.type==="auth-ok"?(At&&console.log(`${e} WebSocket connect SUCCESS!`),j=!0,N.removeEventListener("message",()=>{}),N.addEventListener("message",re=>this.handleRuntimeMessage(re)),D()):U.type==="auth-fail"&&L(new Error(`Connect failed: ${U.message}`))}catch(U){L(U)}}),N.addEventListener("close",B=>{j||L(new Error(`WebSocket closed before connect completed (code: ${B.code})`))}),N.addEventListener("error",B=>{j||L(new Error("WebSocket connection error"))})})}catch(o){throw console.error(`${e} connect failed: ${E(o)}`),o}}handleRuntimeMessage(t){let e=`${this.lc}[${this.handleRuntimeMessage.name}]`;try{let o=JSON.parse(t.data);if(At&&console.log(`${e} received runtime frame: ${o.type}`),o.type==="sync-frame-response"){if(this.activeResolve){let n=o.context,s=this.activeResolve;this.activeResolve=void 0,this.activeReject=void 0,s(n)}}else if(o.type==="domain-payload"){let n=o.ibGib;this.payloadIbGibsDomainReceived$.next(n)}}catch(o){console.error(`${e} failed parsing runtime frame: ${E(o)}`),this.activeReject&&this.activeReject(o)}}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 o=t.payloadIbGibsDomain??[];for(let n of o)this.ws.send(JSON.stringify({type:"domain-payload",ibGib:n}));return new Promise((n,s)=>{this.activeResolve=n,this.activeReject=s,this.ws.send(JSON.stringify({type:"sync-frame",context:t}))})}catch(o){throw console.error(`${e} sendContextRequest failed: ${E(o)}`),o}}};var Ie=!1;async function na({timeline:r}){let t=`[${na.name}]`;try{if(Ie&&console.log(`${t} starting...`),ae({ibGib:r}))return console.warn(`${t} getting lock scope on a primitive ibgib can grossly impact performance. (W: 55203e415ae2ac7ddb19c21772b28925)`),w({ibGib:r});{let e=he({gib:r.gib}),o=e.tjpGib??e.punctiliarHash;if(!o)throw new Error(`${t} (UNEXPECTED) Could not determine tjpGib or punctiliarHash from ibGib. (E: eb3b6472e9b335991a1b0869f772f7d3)`);return o}}catch(e){throw console.error(`${t} ${E(e)}`),e}finally{Ie&&console.log(`${t} complete.`)}}f(na,"getLockScope");async function sa({timeline:r,rel8nInfos:t,rel8nRemovalInfos:e,timelineIndexInfo:o,metaspace:n,space:s,skipLock:a,noDna:i}){let c=`[${sa.name}]`;try{if(Ie&&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 d=await na({timeline:r}),l=f(async()=>{if(!s)throw new Error("(UNEXPECTED) space falsy? couldn't even get default local user space? (E: 845c4181c8c15d7219166ceb3c4dca25)");let h=w({ibGib:r}),p=await n.getLatestAddr({addr:h,space:s});if(!p)throw new Error(`${c} (UNEXPECTED) Could not get latest address for timeline ${w({ibGib:r})}. (E: a4b5c6d7e8f9a0b1c2d3e4f5a6b7c8d9)`);let u=Pt({ibGib:r});if(h!==p){let T=await n.get({addrs:[p],space:s});if(T.errorMsg||(T.ibGibs??[]).length!==1)throw new Error(`${c} (UNEXPECTED) couldn't get latest timeline ibgib (${p}) from space (${s.ib}). errorMsg: ${T.errorMsg??"[unknown error]"} (E: b5c6d7e8f9a0b1c2d3e4f5a6b7c8d9e0)`);u=T.ibGibs.at(0)}let g;if(e&&e.length>0){g={};for(let T of e){let{rel8nName:$,ibGibAddrs:_}=T;if(_.length===0){console.warn(`${c} tried to remove 0 ibGibAddrs in rel8nName ${$}? skipping... (W: 93aeb601be66d680989e72ec70e4c826)`);continue}g[$]||(g[$]=[]),g[$]=g[$].concat(_)}}let m={};for(let T of t){let{rel8nName:$,ibGibs:_}=T;if(_.length===0){console.warn(`${c} tried to add 0 ibGibs to rel8nName ${$}? skipping... (W: 708252dfdeb60757fee4554e769aaa25)`);continue}m[$]||(m[$]=[]),m[$].push(..._.map(A=>w({ibGib:A})))}let y=await Ae({src:u,rel8nsToRemoveByAddr:g,rel8nsToAddByAddr:m,dna:!i,nCounter:!0}),I=y.newIbGib;return await n.persistTransformResult({resTransform:y,space:s}),o&&await aa({type:o.type,rel8nInfos:[{rel8nName:o.rel8nName,ibGibs:[I]}],metaspace:n,space:s,skipLock:a}),n.registerNewIbGib({ibGib:I,space:s}),I},"fn");return a?await l():await at({scope:d,secondsValid:180,maxDelayMs:100,maxLockAttempts:1800,space:s,callerInstanceId:Ue(),fn:l})}catch(d){throw console.error(`${c} ${E(d)}`),d}finally{Ie&&console.log(`${c} complete.`)}}f(sa,"appendToTimeline");async function aa({type:r,rel8nInfos:t,dataToAddOrPatch:e,metaspace:o,space:n,skipLock:s}){let a=`[${aa.name}]`;try{if(Ie&&console.log(`${a} starting... (I: 6e7d05fe916d813b71766e2eaa747c25)`),r==="latest")throw new Error('cannot update the "latest" special index by this function. The registerNewIbGib will do this automatically. (E: 231eb78a221ccdbcf56cd1899260a425)');if(n??=await o.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 d=await o.getSpecialIbGib({type:r,space:n,initialize:!0});if(!d)throw new Error(`(UNEXPECTED) couldn't initialize/get special ibgib index of type ${r}. (E: a1b2c3d4e5f6a7b8c9d0e1f2a3b4c5d6)`);return d.rel8ns||console.warn(`${a} not sure if this ever hits, but is there ever a scenario where specialIndex.rel8ns is falsy? (W: 06161c366bc7ec858b9b5aa7ee9b6d25)`),d},"fnGetSpecialIndex");for(let d of t??[]){let{rel8nName:l,ibGibs:b}=d;b.length===0&&console.error(`${a} ibGibs empty. skipping rel8nName (${l}). (E: 150d74f73f97aea1b97d173d92c77125)`);let p=(await c()).rel8ns??{},u,g=p[l]??[];if(g.length>0){let m=new Set;b.forEach(y=>{let I=w({ibGib:y}),T=y.rel8ns?.past??[];g.filter($=>[...T,I].includes($)).forEach($=>m.add($))}),m.size>0&&(u=Array.from(m))}await o.rel8ToSpecialIbGib({type:r,rel8nName:l,ibGibsToRel8:b,addrsToUnRel8:u,space:n,linked:!1,severPast:!1,deletePreviousSpecialIbGib:!1})}if(Object.keys(e??{}).length>0){let d=await c(),l=await ke({src:d,dataToAddOrPatch:e,dna:!1,linkedRel8ns:[ee.past],nCounter:!0}),b=l.newIbGib;await ne({resTransform:l,space:n});let h=le({type:r});await o.setConfigAddr({key:h,addr:w({ibGib:b}),space:n}),await o.registerNewIbGib({ibGib:b,space:n})}},"fn");s?await i():await at({scope:r,secondsValid:60,maxDelayMs:100,maxLockAttempts:600,space:n,fn:i})}catch(i){throw console.error(`${a} ${E(i)}`),i}finally{Ie&&console.log(`${a} complete.`)}}f(aa,"updateSpecialIndex");async function ia({timeline:r,timelineAddr:t,metaspace:e,space:o}){let n=`[${ia.name}]`;try{if(Ie&&console.log(`${n} starting... (I: f2b605361368e1956f6db878dbfeb825)`),!r&&!t)throw new Error("either timeline or timelineAddr required. (E: 97551b2b18ecd22a18185a783f9a0825)");t??=w({ibGib:r});let s=await e.getLatestAddr({addr:t,space:o})??t;if(!s)throw new Error(`${n} (UNEXPECTED) Could not get latest address for timeline ${w({ibGib:r})}. (E: a4b5c6d7e8f9a0b1c2d3e4f5a6b7c8d9)`);let a;if(t===s){if(!r){let i=await e.get({addrs:[s],space:o});if(i.errorMsg||(i.ibGibs??[]).length!==1)throw new Error(`${n} (UNEXPECTED) couldn't get latest timeline ibgib (${s}) from space (${o.ib}). errorMsg: ${i.errorMsg??"[unknown error]"} (E: 3fc767a594788a43a4ba18c87491a825)`);r=i.ibGibs.at(0)}a=Pt({ibGib:r})}else{let i=await e.get({addrs:[s],space:o});if(i.errorMsg||(i.ibGibs??[]).length!==1)throw new Error(`${n} (UNEXPECTED) couldn't get latest timeline ibgib (${s}) from space (${o.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{Ie&&console.log(`${n} complete.`)}}f(ia,"getLatestTimelineIbGibDto_nonLocking");async function Pd({timeline:r,timelineAddr:t,mut8Opts:e,metaspace:o,space:n,skipLock:s,timelineIndexInfo:a,noDna:i}){let c=`[${Pd.name}]`;try{if(Ie&&console.log(`${c} starting... (I: genuuid)`),!r&&!t)throw new Error("(UNEXPECTED) both timeline and timelineAddr falsy? either one is required. (E: a19d98c6acb87af3b876c1484f6ac825)");if(n??=await o.getLocalUserSpace({lock:!1}),!n)throw new Error("(UNEXPECTED) space falsy? couldn't even get default local user space? (E: genuuid)");if(!r){let h=await o.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)`);r=h.ibGibs.at(0)}let d=await na({timeline:r}),l=f(async()=>{if(!n)throw new Error("(UNEXPECTED) space falsy? couldn't even get default local user space? (E: 845c4181c8c15d7219166ceb3c4dca25)");if(!r)throw new Error("(UNEXPECTED) timeline falsy? we should be ensured that it's truthy at this point. (E: 2e1758b2cc3820531f7ac7f5f6b3a825)");let h=await ia({timeline:r,metaspace:o,space:n}),p=await ke({...e,src:h,dna:!i,nCounter:!0}),u=p.newIbGib;return await o.persistTransformResult({resTransform:p,space:n}),a&&await aa({type:a.type,rel8nInfos:[{rel8nName:a.rel8nName,ibGibs:[u]}],metaspace:o,space:n,skipLock:s}),await o.registerNewIbGib({ibGib:u,space:n}),u},"fn");return s?await l():await at({scope:d,secondsValid:180,maxDelayMs:100,maxLockAttempts:1800,space:n,callerInstanceId:Ue(),fn:l})}catch(d){throw console.error(`${c} ${E(d)}`),d}finally{Ie&&console.log(`${c} complete.`)}}f(Pd,"mut8Timeline");async function ca({ib:r,data:t,rel8ns:e,noDna:o,parentIb:n,parentIbGib:s,metaspace:a,space:i}){let c=`[${ca.name}]`;try{if(Ie&&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=k.primitive({ib:n}):s=Y;let d=await k.firstGen({parentIbGib:s,ib:r,data:t,rel8ns:e,dna:!o,nCounter:!0,squash:!!o,tjp:{timestamp:!0,uuid:!t?.uuid}});return await a.persistTransformResult({resTransform:d,space:i}),await a.registerNewIbGib({ibGib:d.newIbGib,space:i}),d}catch(d){throw console.error(`${c} ${E(d)}`),d}}f(ca,"createTimeline");async function qc({ibGib:r,metaspace:t,space:e}){let o=`[${qc.name}]`;try{if(Ie&&console.log(`${o} starting...`),e??=await t.getLocalUserSpace({lock:!1}),!e)throw new Error("(UNEXPECTED) space is required. (E: c1b9a9b8c7d6e5f4a3b2a1a0b9c8d7e6)");let n=r.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:r})}. Addrs not found: ${a.join(", ")}. Errors: ${s.errorMsg??"[unknown error (E: 92cf95774828d8a978331da859098625)]"} (E: d2c0b1a9a8b7c6d5e4f3a2b1a0b9c8d7)`)}return s.ibGibs}catch(n){throw console.error(`${o} ${E(n)}`),n}}f(qc,"getDna");async function un({timeline:r,getLatest:t,includeDna:e,metaspace:o,space:n}){let s=`[${un.name}]`;try{if(Ie&&console.log(`${s} starting... (I: 7fbc442a27e8f9fda8ac4228ded84825)`),n??=await o.getLocalUserSpace({lock:!1}),!n)throw new Error("(UNEXPECTED) space is required. (E: e3d1c0b1a9a8b7c6d5e4f3a2b1a0b9c8)");let a=t?await ia({timeline:r,metaspace:o,space:n}):Pt({ibGib:r}),i=w({ibGib:a}),c={},d=e?vo({ibGibs:await qc({ibGib:a,metaspace:o,space:n})}):void 0,l=r.rel8ns?.past??[];if(l.length===0)return{headIbGib:a,orderedPastIbGibs:[],pastIbGibMap:c,dnaMap:d};let b=await o.get({addrs:l,space:n});if(!b.success||(b.ibGibs??[]).length!==l.length){let p=l.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=vo({ibGibs:b.ibGibs})??{};let h=[];for(let p of l){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:d}}catch(a){throw console.error(`${s} ${E(a)}`),a}finally{Ie&&console.log(`${s} complete.`)}}f(un,"getHistory");async function la({timeline:r,getLatest:t,metaspace:e,space:o}){let n=`[${la.name}]`;try{return Ie&&console.log(`${n} starting... (I: c7a328b14018642138ebb47870c15626)`),(await un({timeline:r,getLatest:t,includeDna:!1,metaspace:e,space:o})).orderedPastIbGibs.map(i=>w({ibGib:i}))}catch(s){throw console.error(`${n} ${E(s)}`),s}finally{Ie&&console.log(`${n} complete.`)}}f(la,"getHistoryAddrs");var gn="sync_sagamsg";async function da({data:r}){let t=`[${da.name}]`;try{return[gn,r.sagaId,r.stage].join(" ")}catch(e){throw console.error(`${t} ${E(e)}`),e}}f(da,"getSyncSagaMessageIb");async function fa({frameIbGib:r,space:t}){let e=`[${fa.name}]`;try{let n=(await is({ibGib:r,rel8nNames:[De],space:t}))[De];if(!n||n.length===0)throw new Error(`(UNEXPECTED) No sync message stone found found for frame: ${r.ib} (E: 8a4b2c1d3e5f6a9b7c8d9e0f1a2b3c4d)`);if(n.length>1)throw new Error(`(UNEXPECTED) Multiple sync message stones found (${n.length}) for frame: ${r.ib}. logic not currently equipped to handle multiple messages per frame. (E: 1a2b3c4d5e6f7a8b9c0d1e2f3a4b5c6d)`);return n[0]}catch(o){throw console.error(`${e} ${E(o)}`),o}}f(fa,"getSyncSagaMessageFromFrame");var En="anon_fn",Kc={fnHash:""};var Wc=!1;function ba({data:r}){let t=`[${ba.name}]`;try{if(Wc&&console.log(`${t} starting... (I: 37bb06e0390c5bcadf04501727d64923)`),!r?.fnHash)throw new Error("data.fnHash required (E: 2e560f2c59822bc5ba024d4a8e99d323)");return`witness ${En} ${r.fnHash}`}catch(e){throw console.error(`${t} ${e.message}`),e}finally{Wc&&console.log(`${t} complete.`)}}f(ba,"getAnonymousFnIb");var Ht=class{static{f(this,"AnonymousFnWitness_V1")}fn;ib=En.concat();gib=M;data=v(Kc);rel8ns;constructor(t){if(this.fn=t,!t)throw new Error("fn required (E: b1e1478f466a2a347b75e7c336f8d323)")}async witness(t){return this.data.fnHash=await Re({s:this.fn.toString()}),this.ib=ba({data:this.data}),this.gib=await V({ibGib:this}),this.fn(t)}};var mn=!1;function Rd({err:r}){let t=`[${Rd.name}]`;try{if(mn&&console.log(`${t} starting... (I: 96f8b767c50f24768ced7beebb291723)`),vr(r)){let e=r;if(!r.data)throw new Error("err isIbGib but err.data is false. (E: 151a6bab647c638c454fd277ac468f23)");if(Tt({ibGib:r}))return r.data.raw;throw new Error("(UNEXPECTED) err isIbGib but not ErrorIbGib_V1? (E: 81c2283fad5db3485c6e9acedbda9723)")}else return E(r)}catch(e){throw console.error(`${t} ${e.message}`),e}finally{mn&&console.log(`${t} complete.`)}}f(Rd,"extractObsErrMsg");function ha(r){let t=`[${ha.name}]`;try{mn&&console.log(`${t} starting... (I: 3d2c3658a0fda83ece1f2b095a365823)`);let e;if(typeof r=="function"?e={next:r}:e=r,!e.next)throw new Error("observer.next required (typeof observerOrFn !== 'function') (E: da944e93b32ab5918f11751bcd651823)");let o=f(async l=>(await e.next(l),Y),"fnNext"),n=f(async l=>(l.ib==="complete"?e.complete&&await e.complete():Tt({ibGib:l})?e.error&&await e.error(l):await e.next(l),Y),"fnWitness"),s=new Ht(o),a=new Ht(n),i={ib:"observer",witness:f(async l=>await a.witness(l),"witness"),next:f(async l=>{await s.witness(l)},"next")},c=e.error??(async l=>{let b;if(typeof l=="string")b=E(l);else if(l.ib)if(Tt({ibGib:l}))b=E(l.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 l instanceof Error?b=E(l):typeof l.message=="string"?b=E(l.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)`)}),d=new Ht(async l=>(c(l),Y));if(i.error=async l=>{typeof l=="string"?l=await tr({rawMsg:l}):l instanceof Error&&(l=await tr({rawMsg:l.message}));try{await d.witness(l)}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 l=e.complete,b=new Ht(async h=>(await l(),Y));i.complete=async()=>{try{await b.witness(Y)}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{mn&&console.log(`${t} complete.`)}}f(ha,"fnObs");var x=!1,wn=!1,je="[ControlDomain]",Vr=class r{static{f(this,"SyncSagaCoordinator")}lc=`[${r.name}]`;constructor(){}defaultSessionConnectPoolConfig(){return vs({id:It,salt:`session-connect-${Date.now()}`,verbs:[Ut],size:20,sequential:2,random:2,targetBinding:0,replenishStrategy:de.deleteAll})}defaultSessionSyncPoolConfig(){return vs({id:ur,salt:`session-sync-${Date.now()}`,verbs:[pr],size:200,sequential:3,random:3,targetBinding:3,replenishStrategy:de.topUp})}async sync({peer:t,domainIbGibs:e,senderIdentity:o,fnSenderSecret:n,conflictStrategy:s=_t.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(o||n){if(!o)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 d=await F(),l=await bn();if(!l.next)throw new Error("(UNEXPECTED) updates$.next falsy? (E: d24cd82184aec130c89a320819b39126)");let b,h,p=new Promise((y,I)=>{b=y,h=I}),u=await Ic(),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 y=e?e.map(_=>w({ibGib:_})):void 0;t.setOptionalOpts({sagaId:d,senderIdentity:o,fnSenderSecret:n,sessionConnectPoolConfig:this.defaultSessionConnectPoolConfig(),sessionSyncPoolConfig:this.defaultSessionSyncPoolConfig(),targetAddrs:y});let I=await t.establishSessionIdentity();await t.connect({sagaId:d});let{initFrame:T,initDomainGraph:$}=await this.createInitFrame({sagaId:d,domainIbGibs:e,conflictStrategy:s,metaspace:a,localSpace:i,tempSpace:g});if(await this.executeSagaLoop({initFrame:T,initDomainGraph:$,peer:t,updates$:l,localSpace:i,tempSpace:g,metaspace:a}),b(),!l.complete)throw new Error("(UNEXPECTED) updates$.complete falsy? (E: d24cd82184aec130c89a320819b39126)");l.complete()}catch(y){if(console.error(`${c} ${E(y)}`),h(y),!l.error)throw new Error("(UNEXPECTED) updates$.error falsy? (E: 392ce77c073272e4c398c3e86583ce26)");l.error(y)}finally{await m()}})(),{sagaId:d,updates$:l,done:p}}async continueSync({sagaContext:t,mySpace:e,myTempSpace:o,metaspace:n}){let s=`${this.lc}[${this.continueSync.name}]`;try{x&&console.log(`${s} starting... (I: f64e08bf77d1425378601f380384ec26)`);let a=await this.handleResponseSagaContext({sagaContext:t,mySpace:e,myTempSpace:o,metaspace:n});if(a){if(a.nextFrameInfo?.sagaComplete)return null}else return x&&console.log(`${s} Handler returned null (Saga End). (I: 43da8bb6c846b1fe7766332643be0e26)`),null;if(a.errorMsg)throw new Error(`Couldn't handle response saga context. errorMsg: ${a.errorMsg} (E: 7b41a183cf3cb58a5859c803800cf826)`);if(!a.nextFrameInfo)throw new Error("(UNEXPECTED) contextResult.nextFrameInfo falsy? (E: 5740542f5eb8ccb41dfec188d87c1e26)");let{frame:i,payloadIbGibsDomain:c}=a.nextFrameInfo,d=await this.createSyncSagaContext({sagaFrame:i,localSpace:e,payloadIbGibsDomain:c,metaspace:n}),l=await yr({context:d});if(l.length>0)throw new Error(`(UNEXPECTED) just created sync saga context () and there were immediateValidationErrors? immediateValidationErrors: ${l} (E: c120e8e0aa98673d685267a8a36e5826)`);return d}catch(a){throw console.error(`${s} ${E(a)}`),a}finally{x&&console.log(`${s} complete.`)}}async executeSagaLoop({initFrame:t,initDomainGraph:e,peer:o,updates$:n,localSpace:s,tempSpace:a,metaspace:i}){let c=`${this.lc}[${this.executeSagaLoop.name}]`,d=t,l=[];for(;d;){let b=new Map,h=`${c}[peer.payloadIbGibsDomainReceived$]`,p=await o.payloadIbGibsDomainReceived$.subscribe(ha({next:f(async _=>{x&&console.log(`${h} next fired. (I: 2b4bdf502a38a90ba33d9711e7cb7826)`);let A=w({ibGib:_});wn&&console.log(`${c}${je} DOMAIN STREAM RECEIVED <- observable: ${A} (I: d69ee80fcaece272483ec33b2d289826)`),b.set(A,_)},"next"),error:f(async _=>{vr(_)?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:d,payloadIbGibsDomain:l,localSpace:s,metaspace:i});if(wn){let _=l.map(A=>w({ibGib:A}));console.log(`${c}${je} SENDER TRANSMIT -> peer.witness (I: 5b0081803698770f0bf64992220b312)`),console.log(`${c}${je} Context: ${w({ibGib:u})}`),console.log(`${c}${je} Frame: ${w({ibGib:d})}`),console.log(`${c}${je} DOMAIN Payloads (${_.length}): ${_.join(", ")||"(none)"}`)}n.next(u),o.setOptionalOpts({localSpace:s,localTempSpace:a});let g=await o.witness(u);if(!g)if(d)if((await fa({frameIbGib:d,space:s}))?.data?.stage===z.commit){x&&console.log(`${c} Sender sent Commit. Peer returned no response. Saga Complete. (I: 26f9ee073858ca78b8284753368b5226)`),d=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 yr({context:g});if(m.length>0)throw new Error(`contextAndSagaFrameValidationErrors: ${m} (E: 6eebe8e7fa437c00a8cde3ada3c66826)`);let y=g.data[Ls]||[];if(y.length>0&&(g.payloadIbGibsDomain=await this.pollForDomainPayloads({expectedAddrs:y,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(wn){let _=g.data?.["@payloadAddrsControl"]||[];console.log(`${c}${je} SENDER RECEIVED <- peer.witness (I: 3dc76a9744d89a4fc3e2f076c2be4826)`),console.log(`${c}${je} Response Context: ${w({ibGib:g})}`),console.log(`${c}${je} Response Saga Frame: ${w({ibGib:g.sagaFrame})}`),console.log(`${c}${je} CONTROL Payloads (${_.length}): ${_.join(", ")||"(none)"}`),console.log(`${c}${je} DOMAIN Payloads (${y.length}): ${y.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:T,payloadIbGibsDomain:$}=I.nextFrameInfo;if(d=T,l=[...$||[]],wn){let _=l.map(A=>w({ibGib:A}));console.log(`${c}${je} HANDLER RESULT -> next iteration (I: 6b0d88c4c28857ccd812381515bd7826)`),console.log(`${c}${je} Next Frame: ${w({ibGib:d})}`),console.log(`${c}${je} DOMAIN for next (${_.length}): ${_.join(", ")||"(none)"}`)}}}async createSyncSagaContext({sagaFrame:t,payloadIbGibsDomain:e,metaspace:o,localSpace:n}){let s=`[${this.createSyncSagaContext.name}]`;try{if(x&&console.log(`${s} 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 a=new Date,i=$e(a),c=a.getMilliseconds(),d={timestamp:i,timestampMs:c,sagaN:t.data.n},l=e?e?.map(u=>w({ibGib:u})):void 0;l&&l.length>0&&(d[Ls]=l);let b={sagaFrame:[w({ibGib:t})]},h=await ta({data:d}),p=await k.stone({parentPrimitiveIb:hn,ib:h,data:d,rel8ns:b});return await Be({ibGib:p,space:n}),await ge({ibGib:p,space:n,fnBroadcast:void 0}),p.sagaFrame=t,e&&e.length>0&&(p.payloadIbGibsDomain=e),p}catch(a){throw console.error(`${s} ${E(a)}`),a}finally{x&&console.log(`${s} complete.`)}}async getKnowledgeMap({space:t,metaspace:e,domainIbGibs:o,tjpAddrs:n}){let s=`${this.lc}[${this.getKnowledgeMap.name}]`;try{if(x&&console.log(`${s} starting... (I: e184f8a7818666febfbbd2d841ed3826)`),!(o&&o.length>0)&&!(n&&n.length>0))throw new Error("(UNEXPECTED) domainIbGibs and tjpAddrs falsy/empty? we need one or the other (E: f674285111c8648398cd79d8c08ec826)");if(o&&o.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(o&&o.length>0){let{mapWithTjp_YesDna:c,mapWithTjp_NoDna:d}=lt({ibGibs:o}),l=[...Object.values(c),...Object.values(d)],b=Ye({ibGibs:l});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 ct({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 o=`${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 dt({ibGibs:t,live:!0,space:e}),s=n&&Object.keys(n).length>0;x&&console.log(`${o} graph generated. nodes: ${s?Object.keys(n).length:0}`);let a=s?Object.values(n):[],{mapWithTjp_YesDna:i,mapWithTjp_NoDna:c,mapWithoutTjps:d}=lt({ibGibs:a}),l=Object.values(d),b=[...Object.values(i),...Object.values(c)],h=Ye({ibGibs:b}),p=this.sortTimelinesTopologically(h);return{stones:l,timelinesMap:h,topologicallySortedTjpAddrs:p,fullGraph:n}}async createInitFrame({sagaId:t,domainIbGibs:e,conflictStrategy:o,metaspace:n,localSpace:s,tempSpace:a}){let i=`${this.lc}[${this.createInitFrame.name}]`;try{x&&console.log(`${i} starting... (I: 551af8b411ae9be712ce3358d43ee726)`);let c=await this.analyzeDomainIbGibs({domainIbGibs:e,space:s}),{timelinesMap:d,fullGraph:l,stones:b}=c;await Be({ibGibs:Object.values(l),space:a});let h={};Object.keys(d).forEach(m=>{let I=d[m].at(-1);h[m]=w({ibGib:I})});let p={sagaId:t,stage:z.init,knowledgeMap:h,mode:Ps.sync,stones:b.map(m=>w({ibGib:m}))};x&&(console.log(`${i} SyncStage.init: ${z.init}, SyncStage.commit: ${z.commit}`),console.log(`${i} initData.stage: ${p.stage}`));let u=await this.createSyncMsgStone({data:p,localSpace:s,metaspace:n}),g=await this.evolveSyncSagaIbGib({msgStones:[u],conflictStrategy:o,metaspace:n,localSpace:s});return x&&console.log(`${i} sagaFrame (init): ${P(g)} (I: b3d6a8be69248f18713cc3073cb08626)`),{initFrame:g,initDomainGraph:l}}catch(c){throw console.error(`${i} ${E(c)}`),c}finally{x&&console.log(`${i} complete.`)}}async pollForDomainPayloads({expectedAddrs:t,pollIntervalMs:e,domainPayloadsMap:o,tempSpace:n}){let s=`${this.lc}[${this.pollForDomainPayloads.name}]`;try{x&&console.log(`${s} starting... (I: 26dce86bfca572939885798802d6e926)`);let a=[],i=[...t],c=Date.now(),d=5*60*1e3;for(;i.length>0;){if(Date.now()-c>d)throw new Error(`Timeout waiting for payloads: ${i.join(", ")} (E: 46e1683c9578095261aaf798bd5e1826)`);let l=[],b=[];for(let h of i)o.has(h)?(b.push(o.get(h)),o.delete(h)):l.push(h);b.length>0&&(await Be({space:n,ibGibs:b}),b.forEach(h=>a.push(h))),i=l,i.length>0&&await be(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:o,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:d}=await this.getStageAndPayloadFromFrame({sagaFrame:i,space:o});x&&console.log(`${a} handling frame stage: ${c}`);let l;switch(c){case z.init:l=await this.handleInitFrame({sagaIbGib:i,messageData:d,metaspace:s,mySpace:o,myTempSpace:n});break;case z.ack:if(!e)throw new Error("(UNEXPECTED) initDomainGraph falsy on the sender? (E: a3d758ad954829aba88663188eafc826)");l=await this.handleAckFrame({sagaContext:t,sagaIbGib:i,initDomainGraph:e,metaspace:s,mySpace:o,myTempSpace:n});break;case z.delta:l=await this.handleDeltaFrame({sagaContext:t,sagaIbGib:i,metaspace:s,mySpace:o,myTempSpace:n});break;case z.commit:x&&console.log(`${a}[${mr({sagaFrame:i})}] mySpace.ib: ${o.ib} (I: 5b270996d848907238d817fffa64a126)`),l=await this.handleCommitFrame({sagaIbGib:i,metaspace:s,mySpace:o,myTempSpace:n});break;default:throw new Error(`${a} (UNEXPECTED) Unknown sync stage: ${c} (E: 9c2b4c8a6d34469f8263544710183355)`)}return x&&console.log(`${a} nextFrameInfo: ${l?P(l):"undefined"} (I: a8ad281ca8e89385686d18327a105726)`),{errorMsg:void 0,nextFrameInfo:l}}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:o,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: ${o.ib}`);let i=e;if(i.stage!==z.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||_t.abort,d=[],l=[],b=[],h=i.stones||[];if(h.length>0){x&&console.log(`${a} processing stones: ${h.length}`);let G=(await X({space:o,addrs:h})).rawResultIbGib;if(!G.data)throw new Error("(UNEXPECTED) rawResultIbGib.data falsy? (E: f3c40b492adc02c3f480b998fc7a5926)");let N=G.data.addrsNotFound;N&&N.length>0&&(x&&console.log(`${a} stones missing (requesting): ${N.length}`),N.forEach(D=>{l.some(L=>L.addr===D)||l.push({addr:D})}))}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 A=await ct({space:o,tjpAddrs:u});if(!A.data)throw new Error("(UNEXPECTED) resGetLatestAddrs.data falsy? (E: b180d813c088042b38e1e02e06a16926)");if(!A.data.latestAddrsMap)throw new Error("(UNEXPECTED) resGetLatestAddrs.data.latestAddrsMap falsy? (E: 16bc386dd51d0ff53a49620b1e641826)");g=A.data.latestAddrsMap,x&&console.log(`${a} [TEST DEBUG] receiverLatestAddrsMap: ${JSON.stringify(g)}`),x&&console.log(`${a} receiverLatestAddrsMap: ${P(g)} (I: 980975642cbccd8018cf0cd808d30826)`)}for(let A of u){let G=p[A],N=g[A];if(!N){x&&console.log(`${a} [TEST DEBUG] Missing receiver timeline for TJP: ${A}. Requesting remoteAddr: ${G}`),l.push({addr:G,tjpAddr:A});continue}if(N===G){x&&console.log(`${a} [TEST DEBUG] TJP ${A}: Synced (receiverTipAddr === remoteAddr)`);continue}if(x&&console.log(`${a} [TEST DEBUG] TJP ${A}: receiverTipAddr=${N}, remoteAddr=${G} - checking for divergence...`),await Hr({olderAddr:G,newerAddr:N,space:o})){x&&console.log(`${a} [TEST DEBUG] TJP ${A}: Remote (sender) is in past - offering push`);let L=await gr({ibGibAddr:N,live:!1,latestCommonFrameAddr:G,space:o});b.push({tjpAddr:A,addrs:Object.keys(L)})}else{let L=!1;try{L=await Hr({olderAddr:N,newerAddr:G,space:o})}catch(j){x&&console.log(`${a} expected error if we don't have remote. verbose logging error though: ${E(j)} (I: 47ea08d0b418cf4aa8a502a7bcb80826)`)}if(L)x&&console.log(`${a} [TEST DEBUG] TJP ${A}: receiver is in past - requesting delta`),l.push({addr:G,tjpAddr:A,latestAddrAlreadyHave:N});else if(x&&console.log(`${a} [TEST DEBUG] TJP ${A}: DIVERGENCE DETECTED! conflictStrategy=${c}`),c==="abort")d.push({tjpAddr:A,receiverTipAddr:N,senderTipAddr:G,receiverKnowledgeTimelineAddrs:[],reason:"divergence",terminal:!0});else if(c===_t.optimisticWithLCS){let j=await X({addr:N,space:o});if(!j.success||j.ibGibs?.length!==1)throw new Error(`couldn't get local tip (${N}) from space (${o.ib}). errorMsg: ${j.errorMsg??"[unknown error (E: b3c3d823276300aa384ebdba4a8eb826)]"} (E: 83cb88a767e22bbda99c6788bec50526)`);let B=j.ibGibs[0],U=await la({timeline:B,space:o,metaspace:s});d.push({tjpAddr:A,receiverTipAddr:N,senderTipAddr:G,receiverKnowledgeTimelineAddrs:[...U,N],reason:"divergence",terminal:!1})}else throw new Error(`${a} Unsupported conflict strategy: ${c}. Only these currently implemented: ${Jt} (E: 8f12384180f8a718a983a749fe0adf26)`)}}if(d.some(A=>A.terminal))throw x&&console.warn(`${a} ABORTING Sync Saga due to terminal conflicts: ${JSON.stringify(d)}`),new Error(`the saga has terminal conflicts. conflicts: ${JSON.stringify(d)} (E: f2edbe93cc07a63b38bfc013d2213b26)`);if(!t.data)throw new Error("(UNEXPECTED) sagaIbGib.data falsy? (E: 24203af4600fb226ae6c1afbde442826)");let I={sagaId:t.data.uuid,stage:z.ack,deltaRequestAddrInfos:l,pushOfferInfos:b};d?.length>0&&(I.conflicts=d);let T=await this.createSyncMsgStone({data:I,localSpace:o,metaspace:s});x&&console.log(`${a} ackStone created: ${P(T)} (I: 313708132dd53ff946befb7833657826)`);let $=await this.evolveSyncSagaIbGib({prevSagaIbGib:t,msgStones:[T],localSpace:o,metaspace:s}),_;if(b.length>0){let A=[];_=[];let G=b.flatMap(B=>B.addrs),N=await X({addrs:G,space:o}),D=N.rawResultIbGib?.data;if(!D)throw new Error("(UNEXPECTED) resGet.rawResultIbGib.data falsy? (E: 1a2cc8cb99a1ffa60837e45a8229b826)");let L=D.addrsNotFound??[],j=D.addrsErrored??[];if(N.ibGibs&&N.ibGibs.length===G.length)N.ibGibs.forEach(B=>{_.push(B)});else if(N.ibGibs&&N.ibGibs.length>0)if(N.ibGibs.forEach(U=>{_.push(U)}),_.length+L.length+j.length===G.length)L.forEach(U=>A.push(U)),j.forEach(U=>A.push(U));else throw L.length===0&&j.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 (${o.ib}) but we couldn't get all of them. addrsNotFound: ${L??[]}. addrsErrored: ${j??[]}. Trying temp space (${n.ib}). (W: f61908e264f8dddd2e3fb9084463d826)`),G.forEach(B=>A.push(B));if(A.length>0){x&&console.log(`${a} couldn't get all addrs in mySpace (${o.ib}). searchSecondSpaceAddrs: ${A} (I: 233fd954dbd84e51bca02fa8eed5f826)`);let B=await X({addrs:A,space:n});if(B.success&&B.ibGibs&&B.ibGibs.length===A.length)B.ibGibs.forEach(U=>_.push(U));else{B.ibGibs?.forEach(re=>_.push(re));let U=G.filter(re=>!_.map(Q=>w({ibGib:Q})).includes(re));throw new Error(`couldn't get some or all of addrs from either mySpace (${o.ib}) or myTempSpace (${n.ib}). addrsFailed: ${U} (E: 1394d412c4ffa4dd085f269b43338826)`)}}}return{frame:$,payloadIbGibsDomain:_}}catch(i){throw console.error(`${a} ${E(i)}`),i}finally{x&&console.log(`${a} complete.`)}}async handleAckFrame({sagaContext:t,sagaIbGib:e,initDomainGraph:o,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}),d=c,l=!0;if(!d)throw new Error(`${i} ackData falsy (E: 3b8415edc876084c88a25b98e2d55826)`);if(d.stage!==z.ack)throw new Error(`${i} Invalid ack frame: ackData.stage !== SyncStage.ack (E: 2e8b0a94b5954a66a6a1a7a0b3f5b7a1)`);if(x&&console.log(`${i} ackData: ${P(d)} (I: b817c5571c5e916fe8f90b892b3e8e26)`),!e.data)throw new Error("(UNEXPECTED) sagaIbGib.data falsy? (E: e3f2e8f162484859787651b85c011826)");let b=d.conflicts?v(d.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(_=>_.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`),l=!1;for(let _ of b){let{receiverTipAddr:A,reason:G,senderTipAddr:N,terminal:D,receiverKnowledgeTimelineAddrs:L,tjpAddr:j}=_;if(D)throw new Error("(UNEXPECTED) conflict.terminal truthy? We expect this to already throw/abort the saga before this point in execution. (E: b42e982edca8b1156765de38f9e74626)");let B=o[N];if(!B)throw new Error(`(UNEXPECTED) senderTipIbGib falsy? initDomainGraph should have had the senderTipAddr (${N}) that was included in the ack frame conflicts. tjpAddr: ${j}. reason: ${G} (E: 3bd80f2054a924be98e6a7421bff4626)`);let{headIbGib:U,orderedPastIbGibs:re}=await un({timeline:B,getLatest:!0,metaspace:a,space:n}),Q=re.map(_e=>w({ibGib:_e})),ue=w({ibGib:U});if(_.senderKnowledgeTimelineAddrs=[...Q,ue],U.gib!==B.gib&&(_.senderTipAddr=ue,!Object.keys(o).includes(ue))){let _e=await dt({ibGibAddr:ue,live:!0,space:n}),Pe=Object.keys(_e);for(let Te of Pe)o[Te]||(o[Te]=_e[Te])}let He=L.findLast(_e=>Q.includes(_e));if(!He)throw new Error(`(UNEXPECTED) no latestCommonFrameAddr in the conflicts.receiverKnowledgeTimelineAddrs (${L.join(`
29
+ `)})? This would mean that it doesn't even have the tjpAddr (${j}). So what are we doing here? (E: 8931d1bdd6d8e100bf55f7c8a6924826)`);let Ct=await gr({ibGibAddr:ue,live:!0,latestCommonFrameAddr:He,space:n}),Je=[];if(Object.keys(Ct).forEach(_e=>{Je.push(_e);let Pe=Ct[_e];p.push(Pe)}),_.accretivePayloadAddrs)throw new Error("(UNEXPECTED) conflict.accretivePayloadAddrs already truthy? This is expected to be falsy at this point in the sync. (E: 6b6b1846779867849cbde208f4374326)");_.accretivePayloadAddrs=Je}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:d.deltaRequestAddrInfos||[],mySpace:n}),g=[...p,...u],m;g.length===0?g=void 0:m=g.map(_=>w({ibGib:_}));let y={sagaId:e.data.uuid,stage:z.delta,conflicts:b,payloadAddrsDomain:m,deltaRequestAddrInfos:void 0,proposeCommit:l},I;x&&console.log(`${i} Creating Delta Stone. Data stage: ${y.stage}`);let T=await this.createSyncMsgStone({data:y,rel8ns:I,localSpace:n,metaspace:a}),$=await this.evolveSyncSagaIbGib({prevSagaIbGib:e,msgStones:[T],localSpace:n,metaspace:a});return x&&console.log(`${i} Delta Frame created. Rel8ns: ${JSON.stringify($.rel8ns)}`),{frame:$,payloadIbGibsDomain:g}}catch(c){throw console.error(`${i} ${E(c)}`),c}finally{x&&console.log(`${i} complete.`)}}async handleDeltaFrame({sagaContext:t,sagaIbGib:e,mySpace:o,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:o}),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!==z.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:d}=e.data,{deltaRequestAddrInfos:l,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:o});x&&console.log(`${a} [CONFLICT DEBUG] Outgoing payload size (with deps): ${g.length}`);let m=c.conflicts?v(c.conflicts):[],y=m.filter(_=>!_.resolved);if(y.length>0){if(d!==_t.optimisticWithLCS)throw new Error(`(UNEXPECTED) conflictStrategy (${d}) is not ${_t.optimisticWithLCS}? right now, this is the only one we've implemented. (E: ba3e08d92a66b24075016208a0f83226)`);for(let _ of y){let A={};for(let oe of _.accretivePayloadAddrs??[]){let et=u.find(bt=>w({ibGib:bt})===oe);if(!et)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)");A[oe]=et}_.latestCommonFrameAddr;let{receiverKnowledgeTimelineAddrs:G,senderKnowledgeTimelineAddrs:N,reason:D,receiverTipAddr:L,senderTipAddr:j,tjpAddr:B}=_;if(!N)throw new Error("(UNEXPECTED) senderKnowledgeTimelineAddrs falsy? (E: 2a608892d11bd848e8f0c7a8d676d826)");let U=await dt({ibGibAddrs:[L],live:!0,space:o}),re=Object.values(U);await Yo({ibGibs:re,space:n});for(let oe of G){let et=U[oe];await ge({ibGib:et,space:n})}let Q=N.findLast(oe=>G.includes(oe));if(!Q)throw new Error("(UNEXPECTED) latestCommonFrameAddr falsy? how we can have a conflict without a common point in history? (E: 53de0a181838b3e5bf98d0887994b826)");let ue=await gr({ibGibAddr:_.receiverTipAddr,latestCommonFrameAddr:Q,live:!0,space:o});Object.values(ue).forEach(oe=>g.push(oe));let He=await ks({conflictStrategy:d,timelineAddrsA:N,timelineAddrsB:G,latestCommonFrameAddr:Q,ibGibReadCache:A,space:n}),{dnasCreatedInGraft:Ct,dnasReplayed:Je,intermediateIbGibsCreatedInGraft:_e,newGraftTip:Pe,graftInfoCreated:Te}=He;if(_.createdDnaAddrs=Ct.map(oe=>w({ibGib:oe})),_.replayedDnaAddrs=Je.map(oe=>w({ibGib:oe})),_.createdDomainAddrs=[..._e.map(oe=>w({ibGib:oe})),w({ibGib:Te}),w({ibGib:Pe})],!Pe.rel8ns)throw new Error("(UNEXPECTED) newGraftTip.rel8ns falsy? we expect this to have graftinfo rel8ns, let alone dna (E: 718788f5a44e815618ac1ba621c8a826)");let Ir=Pe.rel8ns[jr];if(!Ir||Ir.length===0)throw new Error(`(UNEXPECTED) newGraftTip.rel8ns.${jr} falsy/empty? we expect to always have graft info attached to timelines that are grafted. (E: 45abf31654c8aa517df4d0882b996826)`);_.graftInfoAddr=Ir.at(-1);let Jr=[Ct,Je,_e,[Te,Pe]];for(let oe of Jr.flat())if((await J({ibGib:oe})??[]).length>0){console.dir(oe);debugger;console.log(P(oe))}_.accretivePayloadAddrs??=[],Jr.forEach(oe=>oe.forEach(et=>{let bt=w({ibGib:et});_.accretivePayloadAddrs.includes(bt)||_.accretivePayloadAddrs.push(bt),g.some($n=>w({ibGib:$n})===bt)||g.push(et)})),_.resolved=!0}}let I=[],T=g.length>0,$=I.length>0;if(T||$){let _={sagaId:c.sagaId,stage:z.delta,payloadAddrsDomain:g.map(N=>w({ibGib:N})),requests:$?I:void 0,conflicts:m},A=await this.createSyncMsgStone({data:_,localSpace:o,metaspace:s});return{frame:await this.evolveSyncSagaIbGib({prevSagaIbGib:e,msgStones:[A],localSpace:o,metaspace:s}),payloadIbGibsDomain:g}}else if(p){let _=await Zt({sagaIbGib:e,space:o}),A=await Wo({history:_});return A.length>0?{frame:await this.createCommitFrame({sagaIbGib:e,errors:A,metaspace:s,mySpace:o})}:(await this.executeLocalCommit({sagaHistory:_,deltaFrame:e,localTempSpace:n,localSpace:o,metaspace:s}),{frame:await this.createCommitFrame({sagaIbGib:e,errors:void 0,metaspace:s,mySpace:o})})}else{let _={sagaId:c.sagaId,stage:z.delta,proposeCommit:!0,conflicts:m},A=await this.createSyncMsgStone({data:_,localSpace:o,metaspace:s}),G=await this.evolveSyncSagaIbGib({prevSagaIbGib:e,msgStones:[A],localSpace:o,metaspace:s});if(c.proposeCommit){x&&console.log(`${a} Peer proposed commit. Accepting & Committing.`);let N={sagaId:c.sagaId,stage:z.commit,success:!0},D=await this.createSyncMsgStone({data:N,localSpace:o,metaspace:s});return{frame:await this.evolveSyncSagaIbGib({prevSagaIbGib:G,msgStones:[D],localSpace:o,metaspace:s})}}return{frame:G,payloadIbGibsDomain:g}}}catch(i){throw console.error(`${a} ${E(i)}`),i}finally{x&&console.log(`${a} complete.`)}}async executeLocalCommit({deltaFrame:t,commitFrame:e,sagaHistory:o,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 d=!!t?t:e;if(!d)throw new Error("(UNEXPECTED) !currentFrame? something wrong with my logic. (E: 4ec0ce6625cc1d677bc902c839ca1a26)");let l=mr({sagaFrame:d});if(x&&console.log(`${i} currentFrameOrigin: ${l} (I: 3add8f8390c89743ae554bd3cc60b826)`),!d.data)throw new Error("(UNEXPECTED) currentFrame.data falsy? (E: a8be68d48668d93d992d793834823826)");let b=[],h=f(T=>{b.includes(T)||b.push(T)},"fnAddPayloadAddr"),p=o.filter(T=>{let $=mr({sagaFrame:T.sagaIbGib});return l!==$});o.filter(T=>{let $=mr({sagaFrame:T.sagaIbGib});return l===$}).forEach(T=>{if(!T.sagaIbGib.data)throw new Error("(UNEXPECTED) sagaIbGib.data falsy? (E: 34d7f8cdee14717ce828878d98f89826)");T.msgStones.forEach($=>{if(!$.data)throw new Error("(UNEXPECTED) msgStone.data falsy? (E: 21406101f91847514cc759c8a7382f26)");if($.data.stage===z.ack){let _=$.data;_.pushOfferInfos&&_.pushOfferInfos.length>0&&_.pushOfferInfos.forEach(A=>{A.addrs.forEach(G=>h(G))})}else if($.data.stage===z.delta){let _=$.data;_.payloadAddrsDomain&&_.payloadAddrsDomain.length>0&&_.payloadAddrsDomain.forEach(A=>h(A))}})}),x&&console.log(`${i}[${l}] allPayloadAddrsDomainTransferred: ${b.length>0?b.join(", "):"none"} (I: a1950eb3ca95bdc9ec18a4b8823e9826)`);let g=[];if(b.length>0){let T=await X({addrs:b,space:a});if(T.success&&T.ibGibs&&T.ibGibs.length===b.length)g=T.ibGibs.concat();else{if(!T.rawResultIbGib)throw new Error("(UNEXPECTED) !resGetAllTransferred.rawResultIbGib falsy? (E: dc6cf8729668f4fbe8c024f887d97a26)");let{addrsNotFound:$,addrsErrored:_,errors:A}=T.rawResultIbGib.data;throw new Error(`(UNEXPECTED) we couldn't get all addrs transferred throughout the saga from the tempspace (${a.ib})? addrsNotFound: ${$??[]}. addrsErrored: ${_??[]}. errors: ${A??[]}(E: 222e341e634862b4d88ae7282584d826)`)}}let m=[],y=await Vo({sagaHistory:o});if(y)for(let T of y){if(!T.resolved)throw new Error("(UNEXPECTED) finalConflict.resolved falsy? right now, we're expecting to resolve all conflicts. (E: a40ca8f1f54665407892ec21123a4f26)");if(!T.graftInfoAddr)throw new Error("(UNEXPECTED) finalConflict resolved but graftInfoAddr falsy? we're expecting all resolved conflicts to have a graftInfoAddr (E: d082488347570947b82008a835200126)");if(!(await Fe({addrs:[T.graftInfoAddr],space:a})).at(0))throw new Error(`(UNEXPECTED) couldn't get finalConflictGraftInfo from localTempSpace (${a})? (E: 35e3c8130608d991e8fb295807812826)`);let{createdDnaAddrs:A,replayedDnaAddrs:G,createdDomainAddrs:N}=T;if(!A||A.length===0)throw new Error("(UNEXPECTED) finalConflict.createdDnaAddrs falsy/empty? (E: 9689f8be5bd19650b8d4a058b65db826)");if(!G||G.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 Fe({addrs:[...A,...G,...N],space:a})).forEach(L=>m.push(L))}let I=[];if(g.forEach(T=>I.push(T)),m.forEach(T=>I.push(T)),I.length===0)x&&console.log(`${i}[${l}] no changes on this end (I: fa30d18e83a87ee9e8487fbb5d632b26)`);else{x&&console.log(`${i}[${l}] ${I.length} changes detected (I: fa30d18e83a87ee9e8487fbb5d632b26)`),x&&console.log(`${i} put all into localSpace (${s.ib}) starting... (I: d5e0d9870e380b61e80c729660058826)`);let{payload_Dnas:T,payload_NonDnas:$}=await Yo({ibGibs:I,space:s});x&&console.log(`${i} put all into localSpace (${s.ib}) complete. (I: d5e0d9870e380b61e80c729660058826)`);let _=await Fs({sagaHistory:o,myTempSpace:a}),{mapWithTjp_NoDna:A,mapWithTjp_YesDna:G,mapWithoutTjps:N}=lt({ibGibs:$,filterPrimitives:!0});x&&console.log(`${i} register mapWithoutTjps starting... (I: 2b84d8f8dda85adde88696d8419bf726)`);let D=Object.values(N);for(let re of D)x&&console.log(`${i} registering ${w({ibGib:re})} (I: 4647b4f42d27cffe0fbfce8846755826)`),await n.registerNewIbGib({ibGib:re,space:s});x&&console.log(`${i} mapWithoutTjps complete. (I: 2b84d8f8dda85adde88696d8419bf726)`),x&&console.log(`${i} register mapWithTjp_NoDna starting... (I: 96e648e4db382499b8bfaa1b37c24826)`);let L=Ye({ibGibs:Object.values(A)}),j=Object.keys(L);for(let re of j){let Q=L[re];for(let ue of Q)await n.registerNewIbGib({ibGib:ue,space:s})}x&&console.log(`${i} register mapWithTjp_NoDna complete. (I: 96e648e4db382499b8bfaa1b37c24826)`),x&&console.log(`${i} register mapWithTjp_YesDna starting... (I: d54a820e9442dee4681f6228a6795926)`);let B=Ye({ibGibs:Object.values(G)}),U=Object.keys(B);for(let re of U){let Q=B[re];for(let ue of Q)_.includes(w({ibGib:ue}))||await n.registerNewIbGib({ibGib:ue,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:o,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:z.commit,success:!1,errors:e}:{sagaId:t.data.uuid,stage:z.commit,success:!0},i=await this.createSyncMsgStone({data:a,localSpace:n,metaspace:o});return await this.evolveSyncSagaIbGib({prevSagaIbGib:t,msgStones:[i],localSpace:n,metaspace:o})}catch(a){throw console.error(`${s} ${E(a)}`),a}finally{x&&console.log(`${s} complete.`)}}async handleCommitFrame({sagaIbGib:t,mySpace:e,myTempSpace:o,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 Zt({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:o,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:o,metaspace:n}){let s=`${this.lc}[${this.createSyncMsgStone.name}]`;try{x&&console.log(`${s} starting... (I: 5f7f98e8ff980364f7191fcee4531e26)`);let a=await da({data:t}),i=await k.stone({ib:a,parentPrimitiveIb:gn,data:t,rel8ns:e,uuid:!0});return x&&console.log(`${s} Created stone: ${w({ibGib:i})}`),await n.put({ibGib:i,space:o}),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 o=`${this.lc}[${this.getPayloadsForRequestedInfos.name}]`;try{x&&console.log(`${o} starting... (I: 4fe13d0d80050f20a8b74ba80cee5826)`);let n={};for(let{addr:a,latestAddrAlreadyHave:i}of t){let c;if(i?c=await gr({ibGibAddr:a,latestCommonFrameAddr:i,space:e,live:!0}):c=await dt({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(l=>{n[w({ibGib:l})]=l})}return Object.values(n)}catch(n){throw console.error(`${o} ${E(n)}`),n}finally{x&&console.log(`${o} complete.`)}}async evolveSyncSagaIbGib({prevSagaIbGib:t,conflictStrategy:e,msgStones:o,localSpace:n,metaspace:s}){let a=`${this.lc}[${this.evolveSyncSagaIbGib.name}]`;try{if(!o||o.length===0)throw new Error(`${a} msgStones required (E: d13f8afcfb8816aeb26baae7df3ef726)`);let i=o[0].data;if(!i?.sagaId||!i?.stage)throw new Error(`${a} Invalid stone data (missing sagaId or stage) (E: c004f85ce8f8958b11839f8d68c38826)`);let c=i.sagaId,d=i.stage;for(let l of o){let b=l.data;if(b.sagaId!==c)throw new Error(`${a} Mismatched sagaId in stones. Expected ${c}, got ${b.sagaId} (E: 29e02719e426ecbbf8ee66887a2be226)`);if(b.stage!==d)throw new Error(`${a} Mismatched stage in stones. Expected ${d}, got ${b.stage} (E: d12c6571b0882f762921b60880c3f826)`)}if(t){let l=[{rel8nName:De,ibGibs:o}];if(!t.rel8ns)throw new Error("(UNEXPECTED) prevSagaIbGib.rel8ns falsy? (E: 81375841aff85b1e48ea42ca218e6826)");if(!t.rel8ns[De]||t.rel8ns[De].length===0)throw new Error("(UNEXPECTED) prevSagaIbGib.rel8ns[SYNC_MSG_REL8N_NAME] falsy/empty? (E: 15156baad26fcccda80aa3a31718c726)");let b=[{rel8nName:De,ibGibAddrs:t.rel8ns[De]}];return await sa({timeline:t,rel8nInfos:l,rel8nRemovalInfos:b,metaspace:s,space:n,noDna:!0})}else{let l={uuid:c,n:0,isTjp:!0,conflictStrategy:e},b=await Bs({data:l}),h=o.map(g=>w({ibGib:g})),p={[De]:h},u=await ca({space:n,metaspace:s,ib:b,data:l,rel8ns:p,parentIb:Fo,noDna:!0});if(u.intermediateIbGibs)throw new Error("(UNEXPECTED) resNew.intermediateIbGibs? we were assuming we were creating a single frame. (E: 456818147235d991ccb4d10d0bbe4826)");return u.newIbGib}}catch(i){throw console.error(`${a} ${E(i)}`),i}}async getStageAndPayloadFromFrame({sagaFrame:t,space:e}){let o=`${this.lc}[${this.getStageAndPayloadFromFrame.name}]`;try{if(x&&console.log(`${o} starting... (I: fddc287bd4d55253dc50e519fd352226)`),!t.rel8ns)throw new Error("(UNEXPECTED) sagaFrame.rel8ns falsy? (E: 725bc8eb5dfe5c7058907ad8e3063826)");let n=t.rel8ns?.[De];if(n&&n.length>0){let s=n[0],a=await X({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(`${o} ${E(n)}`),n}finally{x&&console.log(`${o} complete.`)}}sortTimelinesTopologically(t){let e=`${this.lc}[${this.sortTimelinesTopologically.name}]`,o=Object.keys(t);if(o.length===0)return[];let n={};o.forEach(l=>{t[l].forEach(b=>{let h=w({ibGib:b});n[h]=l})});let s={};o.forEach(l=>s[l]=new Set),o.forEach(l=>{t[l].forEach(b=>{b.rel8ns&&Object.values(b.rel8ns).flat().forEach(h=>{if(!h)return;let p=n[h];p&&p!==l&&s[l].add(p)})})});let a=new Set,i=new Set,c=[],d=f(l=>{if(i.has(l)){console.warn(`${e} Cycle detected involving ${l}. Ignoring edge to break cycle. (W: 7e7352347102431aa5318db962459929)`);return}a.has(l)||(i.add(l),s[l].forEach(b=>d(b)),a.add(l),i.delete(l),c.push(l))},"visit");return o.forEach(l=>{a.has(l)||d(l)}),c}};var pa={$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 kd=pa.behaviorProfiles,Md=pa.pools;function zr(r,t){let e=Md[r];if(!e)throw new Error(`Pool template not found in space-gib JSON config: ${r}`);return gc({template:e,behaviorProfiles:kd,salt:t})}f(zr,"getSpaceGibPoolConfig");var W={COMMON:ft.COMMON,DEFAULT_POOL:{ID:"default",SIZE:20,SELECT_SEQUENTIALLY:2,SELECT_RANDOMLY:2,TARGET_BINDING_CHARS:3},CONNECT_POOL:ft.CONNECT_POOL},Yy={MIN_DEFAULT_POOL_SIZE:50,ALLOWED_ALGORITHMS:[Se.sha_256,Se.sha_512]},Yc=Wr;var ua=Lr,St=class{static{f(this,"SpaceGibApiBridge")}lc="[SpaceGibApiBridge]";async postGenesisKeystone(t){let e=`${this.lc}[${this.postGenesisKeystone.name}]`;try{ua&&console.log(`${e} starting... (I: eecd082fc4a4381c8857928e8b090826)`);let o=await fetch("/api/keystone/genesis",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({keystoneIbGib:t})}),n=await o.json();if(!o.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 ua&&console.log(`${e} genesis keystone posted successfully.`),{success:!0,addr:n.addr}}catch(o){let n=E(o);return console.error(`${e} error: ${n}`),{success:!1,message:n}}finally{ua&&console.log(`${e} complete.`)}}async putEvolveKeystone(t,e,o=[]){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:o})}),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 o=`/api/keystone/${encodeURIComponent(t)}?getLatest=true&getGraph=true`,n=await fetch(o,{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(o){let n=E(o);return console.error(`${e} fetch error: ${n}`),{success:!1,message:n}}}async getIbGib(t,e,o=!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=${o}&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}}}},Qy=new St;var Le="[dev-tools]",R={};window.ibgibDebugState=R;function S(r){let t=document.getElementById("dev-panel-log");if(!t)return;let e=new Date().toISOString().slice(11,23);t.textContent=`[${e}] ${r}
30
+ `+t.textContent}f(S,"devLog");var Gt=null;function Bd(){let r=`${Le}[initWsTestButton]`,t=document.getElementById("btn-test-ws");if(!t){console.warn(`${r} btn-test-ws not found \u2014 skipping`);return}t.addEventListener("click",()=>{try{if(Gt&&Gt.readyState===WebSocket.OPEN){Gt.send(JSON.stringify({ping:"hello from client",ts:Date.now()})),S("\u2192 sent ping on existing connection");return}let o=`${location.protocol==="https:"?"wss:":"ws:"}//${location.host}/api/debug/ws-echo`;S(`\u2192 connecting to ${o}`),Gt=new WebSocket(o),Gt.addEventListener("open",()=>{S("\u2713 WebSocket connected"),t.textContent="Send WS Ping"}),Gt.addEventListener("message",n=>{S(`\u2190 ${n.data}`)}),Gt.addEventListener("close",n=>{S(`\u2717 WebSocket closed (code ${n.code})`),t.textContent="Test WebSocket",Gt=null}),Gt.addEventListener("error",n=>{S("\u2717 WebSocket error \u2014 check console"),console.error(`${r} WebSocket error`,n)})}catch(e){S(`\u2717 ${E(e)}`),console.error(`${r} ${E(e)}`)}})}f(Bd,"initWsTestButton");function Fd(){let r=document.getElementById("btn-print-dev-state");r&&r.addEventListener("click",()=>{S("Printing debug state to console..."),console.dir(R)})}f(Fd,"initPrintStateButton");function jd(){let r=`${Le}[initCreateDomainKeystoneButton]`,t=document.getElementById("btn-create-domain-keystone");t&&t.addEventListener("click",async()=>{try{t.disabled=!0,S("Generating dummy Domain Keystone (I)...");let e=await Ge(),o=await e.getLocalUserSpace({});if(!o)throw new Error("No default space found in metaspace.");let n="password",a=await new Oe().genesis({masterSecret:n,configs:[uc({id:"default",salt:await F(),replenishStrategy:de.topUp})],metaspace:e,space:o,frameDetails:{client:"space-gib-web-dev",timestamp:$e()}}),i=w({ibGib:a});S(`\u2713 Local genesis complete: ${i}`),R.domainI=a,R.domainIMasterSecret=n,S("Posting genesis keystone to server...");let d=await new St().postGenesisKeystone(a);if(!d.success){S(`\u2717 Server rejected genesis keystone: ${d.message}`),t.disabled=!1;return}S("\u2713 Server accepted Domain Keystone (I)"),t.textContent="\u2713 Domain Keystone Created";let l=document.getElementById("btn-create-test-ibgib");l&&(l.disabled=!1)}catch(e){S(`\u2717 ${E(e)}`),console.error(`${r} ${E(e)}`),t.disabled=!1}})}f(jd,"initCreateDomainKeystoneButton");function Hd(){let r=`${Le}[initCreateTestIbGibButton]`,t=document.getElementById("btn-create-test-ibgib");if(!t){console.warn(`${r} btn-create-test-ibgib not found \u2014 skipping`);return}t.addEventListener("click",async()=>{try{S("Generating dummy X^Xtjp ibgib...");let o=(await k.firstGen({parentIbGib:Y,ib:"test data",data:{hello:"world",random:Math.random()},dna:!0,nCounter:!0,tjp:{uuid:!0,timestamp:!0}})).newIbGib,n=w({ibGib:o});R.targetX=o,S(`\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){S(`\u2717 ${E(e)}`),console.error(`${r} ${E(e)}`)}})}f(Hd,"initCreateTestIbGibButton");function Xd(){let r=`${Le}[initCreateSessionKeystoneButton]`,t=document.getElementById("btn-create-session-keystone");if(!t){console.warn(`${r} btn-create-session-keystone not found \u2014 skipping`);return}t.addEventListener("click",async()=>{try{S("Generating Session Keystone (S^Stjp)...");let e=R.domainI,o=R.targetX;if(!e){S("\u26A0 No domain keystone (I) found in state. Please Create Domain Keystone first.");return}if(!o){S("\u26A0 No target ibgib (X) found in state. Please Create Test IbGib first.");return}let n=await Ge(),s=await n.getLocalUserSpace({});if(!s)throw new Error("No default space found in metaspace.");let a="ephemeral-"+Math.random().toString(),i=new Oe;console.warn(`${Le}[NAG] placeholder genesis keystone config right now (W: 69b108687cf8bec0f9a8e148bcca8d26)`);let c=await i.genesis({masterSecret:a,configs:[{id:W.DEFAULT_POOL.ID,salt:await F(),type:W.COMMON.TYPE,algo:W.COMMON.ALGO,rounds:W.COMMON.ROUNDS,behavior:{size:W.DEFAULT_POOL.SIZE,replenish:W.COMMON.REPLENISH,selectSequentially:W.DEFAULT_POOL.SELECT_SEQUENTIALLY,selectRandomly:W.DEFAULT_POOL.SELECT_RANDOMLY,targetBindingChars:W.DEFAULT_POOL.TARGET_BINDING_CHARS},allowedVerbs:[]},{id:W.CONNECT_POOL.ID,salt:await F(),type:W.COMMON.TYPE,algo:W.COMMON.ALGO,rounds:W.COMMON.ROUNDS,behavior:{size:W.CONNECT_POOL.SIZE,replenish:W.COMMON.REPLENISH,selectSequentially:W.CONNECT_POOL.SELECT_SEQUENTIALLY,selectRandomly:W.CONNECT_POOL.SELECT_RANDOMLY,targetBindingChars:W.CONNECT_POOL.TARGET_BINDING_CHARS},allowedVerbs:[W.CONNECT_POOL.VERB]}],metaspace:n,space:s,frameDetails:{client:"space-gib-web-session",target_I:e?w({ibGib:e}):void 0,target_X:o?w({ibGib:o}):void 0}}),d=w({ibGib:c});R.sessionS=c,R.sessionSecret=a,S(`\u2713 Created Session Keystone: ${d}`),t.textContent="\u2713 Session Keystone Created";let l=document.getElementById("btn-evolve-domain-keystone");l&&(l.disabled=!1)}catch(e){S(`\u2717 ${E(e)}`),console.error(`${r} ${E(e)}`)}})}f(Xd,"initCreateSessionKeystoneButton");function qd(){let r=`${Le}[initEvolveDomainKeystoneButton]`,t=document.getElementById("btn-evolve-domain-keystone");if(!t){console.warn(`${r} btn-evolve-domain-keystone not found \u2014 skipping`);return}t.addEventListener("click",async()=>{try{t.disabled=!0,S("Evolving Domain Keystone (I^I1) with sync claim...");let e=R.domainI,o=R.domainIMasterSecret,n=R.sessionS;if(!e||!o){S("\u26A0 No domain keystone (I) found. Please Create Domain Keystone first.");return}if(!n){S("\u26A0 No session keystone (S) found. Please Create Session Keystone first.");return}let s=await Ge(),a=await s.getLocalUserSpace({});if(!a)throw new Error("No default space found in metaspace.");let i=new Oe,c=w({ibGib:n});S("Solving challenges to authorize sync...");let d=await i.sign({latestKeystone:e,masterSecret:o,claim:{target:c,verb:"sync"},metaspace:s,space:a}),l=w({ibGib:d});S(`\u2713 Local evolution complete: ${l}`),R.domainI=d,S("Posting evolution to server...");let b=new St,h=w({ibGib:e}),p=await b.putEvolveKeystone(h,d,[n]);if(!p.success){S(`\u2717 Server rejected evolution: ${p.message}`),t.disabled=!1;return}S("\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){S(`\u2717 ${E(e)}`),console.error(`${r} ${E(e)}`),t.disabled=!1}})}f(qd,"initEvolveDomainKeystoneButton");function Kd(){let r=`${Le}[initPerformSyncButton]`,t=document.getElementById("btn-perform-sync");t&&t.addEventListener("click",async()=>{try{debugger;t.disabled=!0,S("Initiating Sync Connect via WebSocket...");let e=R.sessionS,o=R.sessionSecret,n=R.domainI;if(!e||!o||!n){S("\u26A0 Incomplete state. Please complete steps 1-4."),t.disabled=!1;return}let s=await Ge(),a=await s.getLocalUserSpace({});if(!a)throw new Error("No space.");S("Pre-solving upfront picket-fence challenge...");let i=(e.data?.challengePools??[]).find(y=>y.id===W.CONNECT_POOL.ID);if(!i)throw new Error(`Session keystone missing "${W.CONNECT_POOL.ID}" pool`);let{challengeId:c}=Yc(e),d=ze.create({config:i.config}),l=await d.derivePoolSecret({masterSecret:o}),b=await d.generateSolution({poolSecret:l,poolId:W.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}`;S(`\u2192 connecting to ${g}`);let m=new WebSocket(g);m.addEventListener("open",()=>{S("\u2713 WebSocket connected. Waiting for server challenge...")}),m.addEventListener("message",async y=>{try{let I=JSON.parse(y.data);if(S(`\u2190 received: ${I.type??"message"}`),I.type==="auth-challenge-init")S("\u2192 sending auth-init with sAddr..."),m.send(JSON.stringify({type:"auth-init",sAddr:w({ibGib:e})}));else if(I.type==="auth-challenge"){let{challengeUuid:T,demandedIds:$}=I;S(`\u2192 server demanded ${$.length} ids. Signing connect proof...`);let A=await new Oe().sign({latestKeystone:e,masterSecret:o,poolId:It,requiredChallengeIds:$,claim:{verb:Ut,target:T},metaspace:s,space:a});S("\u2192 sending auth-proof..."),m.send(JSON.stringify({type:"auth-proof",proofFrame:A}))}else I.type==="auth-ok"?(S("\u2713 Connect SUCCESS! Sync session authorized."),t.textContent="\u2713 Sync Authorized"):I.type==="auth-fail"&&(S(`\u2717 Connect FAILED: ${I.message}`),t.disabled=!1)}catch(I){S(`\u2717 Message handler error: ${E(I)}`),console.error(`${r} Message handler error:`,I),t.disabled=!1}}),m.addEventListener("close",y=>{S(`\u2717 WebSocket closed (code ${y.code})`),t.disabled=!1}),m.addEventListener("error",()=>{S("\u2717 WebSocket error \u2014 check server"),t.disabled=!1})}catch(e){S(`\u2717 ${E(e)}`),console.error(`${r} ${E(e)}`),t.disabled=!1}})}f(Kd,"initPerformSyncButton");function Wd(){let r=`${Le}[init1bSetupButton]`,t=document.getElementById("btn-1b-setup");t&&t.addEventListener("click",async()=>{try{t.disabled=!0,S("1B Setup: Generating Alice's long-lived Domain Keystone (I) and Target (X)...");let e=await Ge(),o=await e.getLocalUserSpace({});if(!o)throw new Error("No default space.");let n="test-sender-secret-phase1",a=await new Oe().genesis({masterSecret:n,configs:[zr("sync","senderidentitysyncsaltphase1"),zr("manage","senderidentitymanagesaltphase1")],metaspace:e,space:o,frameDetails:{client:"space-gib-web-dev",timestamp:$e()}});R.domainI=a,R.domainIMasterSecret=n,S(`1B Setup: \u2713 Domain Keystone (I) created locally: ${w({ibGib:a})}`),S("1B Setup: Starting postGenesisKeystone...");let c=await new St().postGenesisKeystone(a);if(c.success)S("1B Setup: \u2713 Domain Keystone registered and stored on receiver (server).");else throw S(`1B Setup: X postGenesisKeystone failed: ${c.message}.`),new Error(`1B Setup: Server rejected genesis domain keystone: ${c.message}`);let d=await k.firstGen({parentIbGib:Y,ib:"test data",data:{hello:"world",random:Math.random()},dna:!0,nCounter:!0,tjp:{uuid:!0,timestamp:!0}});R.targetX=d.newIbGib,S(`1B Setup: \u2713 Target (X) created locally: ${w({ibGib:d.newIbGib})}`),S("\u2713 1B Setup Complete! Ready for 1B Sync."),t.textContent="\u2713 1B Setup Complete";let l=document.getElementById("btn-1b-sync");l&&(l.disabled=!1)}catch(e){S(`\u2717 1B Setup FAILED: ${E(e)}`),console.error(`${r} 1B Setup error:`,e),t.disabled=!1}})}f(Wd,"init1bSetupButton");function Yd(){let r=`${Le}[init1bSyncButton]`,t=document.getElementById("btn-1b-sync");t&&t.addEventListener("click",async()=>{try{t.disabled=!0,S("1B Sync: Executing senderCoordinator.sync(...) using WebSocket Peer...");let e=R.domainI,o=R.targetX;if(!e||!o){S("\u26A0 1B Sync: Missing setup state. Please run Setup first."),t.disabled=!1;return}let n=w({ibGib:e}),s=await Ge(),a=await s.getLocalUserSpace({});if(!a)throw new Error("No default space.");let i=location.protocol==="https:"?"wss:":"ws:",c=new Yr({classname:"SyncPeerWebSocketSender_V1",httpEvolveUrl:`${location.protocol}//${location.host}/api/keystone/evolve/${encodeURIComponent(n)}`,wsUrl:`${i}//${location.host}/api/sync/ws/${encodeURIComponent(n)}`}),d=new Vr,l=await F();R.sagaId=l,R.senderPeer=c,await c.initializeOpts({localMetaspace:s,localSpace:a,senderIdentity:e,fnSenderSecret:f(async()=>R.domainIMasterSecret,"fnSenderSecret"),sagaId:l,sessionConnectPoolConfig:W.CONNECT_POOL,sessionSyncPoolConfig:W.DEFAULT_POOL,targetAddrs:[n]});try{await(await d.sync({domainIbGibs:[o],senderIdentity:e,fnSenderSecret:f(async()=>R.domainIMasterSecret,"fnSenderSecret"),peer:c,localSpace:a,metaspace:s,conflictStrategy:"optimisticWithLCS"})).done}catch(h){S(`1B Sync: Coordinator sync executed (establish phase successfully run; connection/sync errors expected in 1B): ${E(h)}`)}S("\u2713 1B Sync Execution Complete! Ready for State Checks."),t.textContent="\u2713 1B Sync Run";let b=document.getElementById("btn-1b-check");b&&(b.disabled=!1)}catch(e){S(`\u2717 1B Sync FAILED: ${E(e)}`),console.error(`${r} 1B Sync error:`,e),t.disabled=!1}})}f(Yd,"init1bSyncButton");function Vd(){let r=`${Le}[init1bCheckButton]`,t=document.getElementById("btn-1b-check");t&&t.addEventListener("click",async()=>{try{S("1B Check: Asserting cryptographic and durable state expectations from respec...");debugger;let e=await Ge(),o=await e.getLocalUserSpace({});if(!o)throw new Error("No default space.");let n=R.domainI,s=R.targetX,a=w({ibGib:s}),i=await e.getLatestAddr({addr:w({ibGib:n}),space:o});if(!i){S("\u2717 Check: Evolved domain keystone tip I1 NOT found in local space!");return}S("\u2713 Check: Evolved Domain Keystone (I1) created and stored locally.");let d=(await e.get({addrs:[i],space:o})).ibGibs?.[0];if(!d){S("\u2717 Check: Failed to load I1 from local space.");return}let l=d.data?.proofs?.find(N=>N.claim?.verb==="sync");S(l?"\u2713 Check: I1 contains valid sync-verb claim proof.":"\u2717 Check: I1 is missing sync-verb claim proof!");let b=l?.claim?.target;if(!b){S("\u2717 Check: I1 sync claim does not target a session keystone.");return}S(`\u2713 Check: Sync claim targets session keystone: ${b}`);let p=(await e.get({addrs:[b],space:o})).ibGibs?.[0];if(!p){S("\u2717 Check: Session Keystone (S) NOT found in local space.");return}S("\u2713 Check: Session Keystone (S) successfully created locally.");let u=p.data?.challengePools??[],g=u.some(N=>N.id===It),m=u.some(N=>N.id===ur);S(g&&m?"\u2713 Check: S contains both connect and sync challenge pools.":`\u2717 Check: S is missing challenge pools! (connect: ${g}, sync: ${m})`),S("Check: Verifying registrations on server (receiver metaspace)...");let y=new St,I=!1,T=!1,$=!1,_=w({ibGib:n}),A=await y.getKeystoneGraph(_);if(A.success&&A.graph){let N=A.graph;I=N[_]!==void 0,T=N[i]!==void 0}else S(`\u2717 Check Server: Failed to fetch keystone graph from server: ${A.message}`);let G=await y.getIbGib(_,b);if(G.success&&G.ibGib?$=!0:S(`\u2717 Check Server: Failed to fetch session keystone from server: ${G.message}`),S(I?"\u2713 Check Server: Genesis Domain Keystone (I) registered on server.":"\u2717 Check Server: Genesis Domain Keystone (I) missing on server!"),S(T?"\u2713 Check Server: Evolved Domain Keystone (I1) accepted and stored on server.":"\u2717 Check Server: Evolved Domain Keystone (I1) missing on server!"),S($?"\u2713 Check Server: Session Keystone (S) accepted and stored on server.":"\u2717 Check Server: Session Keystone (S) missing on server!"),I&&T&&$){S("\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){S(`\u2717 1B Check FAILED: ${E(e)}`),console.error(`${r} 1B Check error:`,e)}})}f(Vd,"init1bCheckButton");function zd(){let r=`${Le}[init2bSetupButton]`,t=document.getElementById("btn-2b-setup");t&&t.addEventListener("click",async()=>{try{t.disabled=!0,S("2B Setup: Generating Alice's long-lived Domain Keystone (I) and Target (X)...");let e=await Ge(),o=await e.getLocalUserSpace({});if(!o)throw new Error("No default space.");let n="test-sender-secret-phase2",a=await new Oe().genesis({masterSecret:n,configs:[zr("sync","senderidentitysyncsaltphase2"),zr("manage","senderidentitymanagesaltphase2")],metaspace:e,space:o,frameDetails:{client:"space-gib-web-dev",timestamp:$e()}});R.domainI=a,R.domainIMasterSecret=n,S(`2B Setup: \u2713 Domain Keystone (I) created locally: ${w({ibGib:a})}`),S("2B Setup: Starting postGenesisKeystone...");let c=await new St().postGenesisKeystone(a);if(c.success)S("2B Setup: \u2713 Domain Keystone registered and stored on receiver (server).");else throw S(`2B Setup: X postGenesisKeystone failed: ${c.message}.`),new Error(`2B Setup: Server rejected genesis domain keystone: ${c.message}`);let d=await k.firstGen({parentIbGib:Y,ib:"test data",data:{hello:"world2",random:Math.random()},dna:!0,nCounter:!0,tjp:{uuid:!0,timestamp:!0}});R.targetX=d.newIbGib,S(`2B Setup: \u2713 Target (X) created locally: ${w({ibGib:d.newIbGib})}`),S("\u2713 2B Setup Complete! Ready for 2B Sync."),t.textContent="\u2713 2B Setup Complete";let l=document.getElementById("btn-2b-sync");l&&(l.disabled=!1)}catch(e){S(`\u2717 2B Setup FAILED: ${E(e)}`),console.error(`${r} 2B Setup error:`,e),t.disabled=!1}})}f(zd,"init2bSetupButton");function Jd(){let r=`${Le}[init2bSyncButton]`,t=document.getElementById("btn-2b-sync");t&&t.addEventListener("click",async()=>{try{t.disabled=!0,S("2B Sync: Executing senderCoordinator.sync(...) using WebSocket Peer...");let e=R.domainI,o=R.targetX;if(!e||!o){S("\u26A0 2B Sync: Missing setup state. Please run Setup first."),t.disabled=!1;return}let n=w({ibGib:e}),s=await Ge(),a=await s.getLocalUserSpace({});if(!a)throw new Error("No default space.");let i=location.protocol==="https:"?"wss:":"ws:",c=new Yr({classname:"SyncPeerWebSocketSender_V1",httpEvolveUrl:`${location.protocol}//${location.host}/api/keystone/evolve/${encodeURIComponent(n)}`,wsUrl:`${i}//${location.host}/api/sync/ws/${encodeURIComponent(n)}`}),d=new Vr,l=await F();R.sagaId=l,R.senderPeer=c,await c.initializeOpts({localMetaspace:s,localSpace:a,senderIdentity:e,fnSenderSecret:f(async()=>R.domainIMasterSecret,"fnSenderSecret"),sagaId:l,sessionConnectPoolConfig:W.CONNECT_POOL,sessionSyncPoolConfig:W.DEFAULT_POOL,targetAddrs:[n]});try{await(await d.sync({domainIbGibs:[o],senderIdentity:e,fnSenderSecret:f(async()=>R.domainIMasterSecret,"fnSenderSecret"),peer:c,localSpace:a,metaspace:s,conflictStrategy:"optimisticWithLCS"})).done}catch(h){S(`2B Sync: Coordinator sync executed (connect phase successfully run; subsequent sync errors expected in 2B): ${E(h)}`)}S("\u2713 2B Sync Execution Complete! Ready for State Checks."),t.textContent="\u2713 2B Sync Run";let b=document.getElementById("btn-2b-check");b&&(b.disabled=!1)}catch(e){S(`\u2717 2B Sync FAILED: ${E(e)}`),console.error(`${r} 2B Sync error:`,e),t.disabled=!1}})}f(Jd,"init2bSyncButton");function Zd(){let r=`${Le}[init2bCheckButton]`,t=document.getElementById("btn-2b-check");t&&t.addEventListener("click",async()=>{try{debugger;S("2B Check: Asserting cryptographic and WebSocket state expectations...");let e=await Ge(),o=await e.getLocalUserSpace({});if(!o)throw new Error("No default space.");let n=R.domainI,s=R.targetX,a=w({ibGib:s}),i=w({ibGib:n}),c=await e.getLatestAddr({addr:i,space:o});if(!c){S("\u2717 Check: Evolved domain keystone tip I1 NOT found in local space!");return}S("\u2713 Check: Evolved Domain Keystone (I1) created and stored locally.");let l=(await e.get({addrs:[c],space:o})).ibGibs?.[0];if(!l){S("\u2717 Check: Failed to load I1 from local space.");return}let h=l.data?.proofs?.find(_=>_.claim?.verb==="sync")?.claim?.target;if(!h){S("\u2717 Check: I1 sync claim does not target a session keystone.");return}S(`\u2713 Check: Sync claim targets session keystone: ${h}`);let p=await e.getLatestAddr({addr:h,space:o});if(!p){S("\u2717 Check: Latest Session Keystone (S) NOT found in local space.");return}S("\u2713 Check: Found latest session keystone (S) locally.");let g=(await e.get({addrs:[p],space:o})).ibGibs?.[0];if(!g){S("\u2717 Check: Failed to load latest Session Keystone (S).");return}let m=g.data?.challengePools??[],y=m.find(_=>_.id===It),I=m.find(_=>_.id===ur);if(y&&I)S("\u2713 Check: S contains both connect and sync challenge pools.");else{S(`\u2717 Check: S is missing challenge pools! (connect: ${!!y}, sync: ${!!I})`);return}let T=Object.keys(y.challenges).length;if(T===0)S("\u2713 Check: S connect pool successfully depleted (0 challenges remaining).");else{S(`\u2717 Check: S connect pool not depleted! (${T} challenges remaining)`);return}if(R.senderPeer&&R.senderPeer.isSocketOpen)S("\u2713 Check: WebSocket connection is active and OPEN.");else{S("\u2717 Check: WebSocket connection is NOT open or peer is missing!");return}S("\u{1F389} ALL PHASE 2B CONNECT CHECKS PASSED FLAWLESSLY! \u2713"),t.textContent="\u2713 2B All Passed";let $=document.getElementById("btn-3b-setup");$&&($.disabled=!1)}catch(e){S(`\u2717 2B Check FAILED: ${E(e)}`),console.error(`${r} 2B Check error:`,e)}})}f(Zd,"init2bCheckButton");function Qd(){let r=document.getElementById("btn-3b-setup"),t=document.getElementById("btn-3b-sync"),e=document.getElementById("btn-3b-check");r&&r.addEventListener("click",()=>S("3B Setup: Placeholders ready for Phase 3B (Transactional Sync).")),t&&t.addEventListener("click",()=>S("3B Sync: Placeholders ready for Phase 3B (Transactional Sync).")),e&&e.addEventListener("click",()=>S("3B Check: Placeholders ready for Phase 3B (Transactional Sync)."))}f(Qd,"init3bPlaceholder");function m0(){let r=`${Le}[initDevTools]`;try{Fd(),jd(),Bd(),Hd(),Xd(),qd(),Kd(),Wd(),Yd(),Vd(),zd(),Jd(),Zd(),Qd()}catch(t){console.error(`${r} ${E(t)}`)}}f(m0,"initDevTools");export{f as a,ie as b,Se as c,v as d,$e as e,Re as f,F as g,P as h,be as i,E as j,yn as k,Ue as l,eo as m,el as n,Ta as o,ar as p,M as q,Y as r,ce as s,rt as t,Sa as u,w as v,H as w,Nt as x,ee as y,An as z,ae as A,V as B,he as C,ke as D,Ae as E,J as F,cr as G,lr as H,ir as I,k as J,db as K,fb as L,bb as M,no as N,nl as O,Oa as P,Da as Q,Cb as R,xb as S,Nb as T,sl as U,Ob as V,Nn as W,Pn as X,al as Y,Bb as Z,io as _,Yt as $,Ha as aa,Ya as ba,co as ca,ll as da,dl as ea,np as fa,sp as ga,ap as ha,ip as ia,cp as ja,lp as ka,gl as la,El as ma,Qa as na,Kn as oa,wl as pa,$l as qa,fr as ra,xr as sa,ii as ta,xl as ua,di as va,zp as wa,Qp as xa,X as ya,Be as za,es as Aa,ne as Ba,Nl as Ca,$o as Da,yo as Ea,ye as Fa,ts as Ga,bi as Ha,ge as Ia,dr as Ja,Qn as Ka,ui as La,at as Ma,wo as Na,Dl as Oa,vl as Pa,yt as Qa,Su as Ra,Ll as Sa,Pl as Ta,Rl as Ua,ct as Va,Ul as Wa,kl as Xa,Ml as Ya,Ze as Za,Fu as _a,Ci as $a,Nr as ab,lt as bb,Ye as cb,xi as db,We as eb,Pt as fb,Rt as gb,Ju as hb,ql as ib,Zu as jb,Qu as kb,eg as lb,tg as mb,Lr as nb,Wu as ob,Wl as pb,Yl as qb,Vl as rb,zt as sb,Ge as tb,zl as ub,Hi as vb,ji as wb,Jl as xb,Zl as yb,Ql as zb,ed as Ab,td as Bb,rd as Cb,od as Db,nd as Eb,us as Fb,bs as Gb,Ao as Hb,sd as Ib,ad as Jb,Oi as Kb,id as Lb,Ki as Mb,cd as Nb,ld as Ob,dE as Pb,Ve as Qb,de as Rb,dt as Sb,Oe as Tb,tr as Ub,Rd as Vb,ha as Wb,sa as Xb,aa as Yb,Pd as Zb,Ld as _b,Qt as $b,er as ac,Xs as bc,kt as cc,bn as dc,Qy as ec,S as fc,m0 as gc};
31
+ //# sourceMappingURL=chunk-RE7XSMHH.mjs.map