@libp2p/floodsub 10.1.18-7a1665cd8 → 10.1.18-d72b51184

Sign up to get free protection for your applications and to get access to all the features.
package/dist/index.min.js CHANGED
@@ -1,9 +1,9 @@
1
1
  (function (root, factory) {(typeof module === 'object' && module.exports) ? module.exports = factory() : root.Libp2PFloodsub = factory()}(typeof self !== 'undefined' ? self : this, function () {
2
- "use strict";var Libp2PFloodsub=(()=>{var pu=Object.create;var Wr=Object.defineProperty;var gu=Object.getOwnPropertyDescriptor;var mu=Object.getOwnPropertyNames;var bu=Object.getPrototypeOf,yu=Object.prototype.hasOwnProperty;var vo=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),bt=(r,t)=>{for(var e in t)Wr(r,e,{get:t[e],enumerable:!0})},Eo=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of mu(t))!yu.call(r,s)&&s!==e&&Wr(r,s,{get:()=>t[s],enumerable:!(n=gu(t,s))||n.enumerable});return r};var Bo=(r,t,e)=>(e=r!=null?pu(bu(r)):{},Eo(t||!r||!r.__esModule?Wr(e,"default",{value:r,enumerable:!0}):e,r)),wu=r=>Eo(Wr({},"__esModule",{value:!0}),r);var Ta=vo(rr=>{"use strict";var zf="[object ArrayBuffer]",te=class r{static isArrayBuffer(t){return Object.prototype.toString.call(t)===zf}static toArrayBuffer(t){return this.isArrayBuffer(t)?t:t.byteLength===t.buffer.byteLength||t.byteOffset===0&&t.byteLength===t.buffer.byteLength?t.buffer:this.toUint8Array(t.buffer).slice(t.byteOffset,t.byteOffset+t.byteLength).buffer}static toUint8Array(t){return this.toView(t,Uint8Array)}static toView(t,e){if(t.constructor===e)return t;if(this.isArrayBuffer(t))return new e(t);if(this.isArrayBufferView(t))return new e(t.buffer,t.byteOffset,t.byteLength);throw new TypeError("The provided value is not of type '(ArrayBuffer or ArrayBufferView)'")}static isBufferSource(t){return this.isArrayBufferView(t)||this.isArrayBuffer(t)}static isArrayBufferView(t){return ArrayBuffer.isView(t)||t&&this.isArrayBuffer(t.buffer)}static isEqual(t,e){let n=r.toUint8Array(t),s=r.toUint8Array(e);if(n.length!==s.byteLength)return!1;for(let i=0;i<n.length;i++)if(n[i]!==s[i])return!1;return!0}static concat(...t){let e;Array.isArray(t[0])&&!(t[1]instanceof Function)||Array.isArray(t[0])&&t[1]instanceof Function?e=t[0]:t[t.length-1]instanceof Function?e=t.slice(0,t.length-1):e=t;let n=0;for(let o of e)n+=o.byteLength;let s=new Uint8Array(n),i=0;for(let o of e){let a=this.toUint8Array(o);s.set(a,i),i+=a.length}return t[t.length-1]instanceof Function?this.toView(s,t[t.length-1]):s.buffer}},Fi="string",$f=/^[0-9a-f\s]+$/i,Gf=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,Zf=/^[a-zA-Z0-9-_]+$/,mn=class{static fromString(t){let e=unescape(encodeURIComponent(t)),n=new Uint8Array(e.length);for(let s=0;s<e.length;s++)n[s]=e.charCodeAt(s);return n.buffer}static toString(t){let e=te.toUint8Array(t),n="";for(let i=0;i<e.length;i++)n+=String.fromCharCode(e[i]);return decodeURIComponent(escape(n))}},Ut=class{static toString(t,e=!1){let n=te.toArrayBuffer(t),s=new DataView(n),i="";for(let o=0;o<n.byteLength;o+=2){let a=s.getUint16(o,e);i+=String.fromCharCode(a)}return i}static fromString(t,e=!1){let n=new ArrayBuffer(t.length*2),s=new DataView(n);for(let i=0;i<t.length;i++)s.setUint16(i*2,t.charCodeAt(i),e);return n}},bn=class r{static isHex(t){return typeof t===Fi&&$f.test(t)}static isBase64(t){return typeof t===Fi&&Gf.test(t)}static isBase64Url(t){return typeof t===Fi&&Zf.test(t)}static ToString(t,e="utf8"){let n=te.toUint8Array(t);switch(e.toLowerCase()){case"utf8":return this.ToUtf8String(n);case"binary":return this.ToBinary(n);case"hex":return this.ToHex(n);case"base64":return this.ToBase64(n);case"base64url":return this.ToBase64Url(n);case"utf16le":return Ut.toString(n,!0);case"utf16":case"utf16be":return Ut.toString(n);default:throw new Error(`Unknown type of encoding '${e}'`)}}static FromString(t,e="utf8"){if(!t)return new ArrayBuffer(0);switch(e.toLowerCase()){case"utf8":return this.FromUtf8String(t);case"binary":return this.FromBinary(t);case"hex":return this.FromHex(t);case"base64":return this.FromBase64(t);case"base64url":return this.FromBase64Url(t);case"utf16le":return Ut.fromString(t,!0);case"utf16":case"utf16be":return Ut.fromString(t);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToBase64(t){let e=te.toUint8Array(t);if(typeof btoa<"u"){let n=this.ToString(e,"binary");return btoa(n)}else return Buffer.from(e).toString("base64")}static FromBase64(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isBase64(e))throw new TypeError("Argument 'base64Text' is not Base64 encoded");return typeof atob<"u"?this.FromBinary(atob(e)):new Uint8Array(Buffer.from(e,"base64")).buffer}static FromBase64Url(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isBase64Url(e))throw new TypeError("Argument 'base64url' is not Base64Url encoded");return this.FromBase64(this.Base64Padding(e.replace(/\-/g,"+").replace(/\_/g,"/")))}static ToBase64Url(t){return this.ToBase64(t).replace(/\+/g,"-").replace(/\//g,"_").replace(/\=/g,"")}static FromUtf8String(t,e=r.DEFAULT_UTF8_ENCODING){switch(e){case"ascii":return this.FromBinary(t);case"utf8":return mn.fromString(t);case"utf16":case"utf16be":return Ut.fromString(t);case"utf16le":case"usc2":return Ut.fromString(t,!0);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToUtf8String(t,e=r.DEFAULT_UTF8_ENCODING){switch(e){case"ascii":return this.ToBinary(t);case"utf8":return mn.toString(t);case"utf16":case"utf16be":return Ut.toString(t);case"utf16le":case"usc2":return Ut.toString(t,!0);default:throw new Error(`Unknown type of encoding '${e}'`)}}static FromBinary(t){let e=t.length,n=new Uint8Array(e);for(let s=0;s<e;s++)n[s]=t.charCodeAt(s);return n.buffer}static ToBinary(t){let e=te.toUint8Array(t),n="";for(let s=0;s<e.length;s++)n+=String.fromCharCode(e[s]);return n}static ToHex(t){let e=te.toUint8Array(t),n="",s=e.length;for(let i=0;i<s;i++){let o=e[i];o<16&&(n+="0"),n+=o.toString(16)}return n}static FromHex(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isHex(e))throw new TypeError("Argument 'hexString' is not HEX encoded");e.length%2&&(e=`0${e}`);let n=new Uint8Array(e.length/2);for(let s=0;s<e.length;s=s+2){let i=e.slice(s,s+2);n[s/2]=parseInt(i,16)}return n.buffer}static ToUtf16String(t,e=!1){return Ut.toString(t,e)}static FromUtf16String(t,e=!1){return Ut.fromString(t,e)}static Base64Padding(t){let e=4-t.length%4;if(e<4)for(let n=0;n<e;n++)t+="=";return t}static formatString(t){return t?.replace(/[\n\r\t ]/g,"")||""}};bn.DEFAULT_UTF8_ENCODING="utf8";function Wf(r,...t){let e=arguments[0];for(let n=1;n<arguments.length;n++){let s=arguments[n];for(let i in s)e[i]=s[i]}return e}function jf(...r){let t=r.map(s=>s.byteLength).reduce((s,i)=>s+i),e=new Uint8Array(t),n=0;return r.map(s=>new Uint8Array(s)).forEach(s=>{for(let i of s)e[n++]=i}),e.buffer}function Yf(r,t){if(!(r&&t)||r.byteLength!==t.byteLength)return!1;let e=new Uint8Array(r),n=new Uint8Array(t);for(let s=0;s<r.byteLength;s++)if(e[s]!==n[s])return!1;return!0}rr.BufferSourceConverter=te;rr.Convert=bn;rr.assign=Wf;rr.combine=jf;rr.isEqual=Yf});var Gc=vo((rb,io)=>{"use strict";var Eh=Object.prototype.hasOwnProperty,wt="~";function Fr(){}Object.create&&(Fr.prototype=Object.create(null),new Fr().__proto__||(wt=!1));function Bh(r,t,e){this.fn=r,this.context=t,this.once=e||!1}function $c(r,t,e,n,s){if(typeof e!="function")throw new TypeError("The listener must be a function");var i=new Bh(e,n||r,s),o=wt?wt+t:t;return r._events[o]?r._events[o].fn?r._events[o]=[r._events[o],i]:r._events[o].push(i):(r._events[o]=i,r._eventsCount++),r}function gs(r,t){--r._eventsCount===0?r._events=new Fr:delete r._events[t]}function gt(){this._events=new Fr,this._eventsCount=0}gt.prototype.eventNames=function(){var t=[],e,n;if(this._eventsCount===0)return t;for(n in e=this._events)Eh.call(e,n)&&t.push(wt?n.slice(1):n);return Object.getOwnPropertySymbols?t.concat(Object.getOwnPropertySymbols(e)):t};gt.prototype.listeners=function(t){var e=wt?wt+t:t,n=this._events[e];if(!n)return[];if(n.fn)return[n.fn];for(var s=0,i=n.length,o=new Array(i);s<i;s++)o[s]=n[s].fn;return o};gt.prototype.listenerCount=function(t){var e=wt?wt+t:t,n=this._events[e];return n?n.fn?1:n.length:0};gt.prototype.emit=function(t,e,n,s,i,o){var a=wt?wt+t:t;if(!this._events[a])return!1;var c=this._events[a],l=arguments.length,f,u;if(c.fn){switch(c.once&&this.removeListener(t,c.fn,void 0,!0),l){case 1:return c.fn.call(c.context),!0;case 2:return c.fn.call(c.context,e),!0;case 3:return c.fn.call(c.context,e,n),!0;case 4:return c.fn.call(c.context,e,n,s),!0;case 5:return c.fn.call(c.context,e,n,s,i),!0;case 6:return c.fn.call(c.context,e,n,s,i,o),!0}for(u=1,f=new Array(l-1);u<l;u++)f[u-1]=arguments[u];c.fn.apply(c.context,f)}else{var d=c.length,m;for(u=0;u<d;u++)switch(c[u].once&&this.removeListener(t,c[u].fn,void 0,!0),l){case 1:c[u].fn.call(c[u].context);break;case 2:c[u].fn.call(c[u].context,e);break;case 3:c[u].fn.call(c[u].context,e,n);break;case 4:c[u].fn.call(c[u].context,e,n,s);break;default:if(!f)for(m=1,f=new Array(l-1);m<l;m++)f[m-1]=arguments[m];c[u].fn.apply(c[u].context,f)}}return!0};gt.prototype.on=function(t,e,n){return $c(this,t,e,n,!1)};gt.prototype.once=function(t,e,n){return $c(this,t,e,n,!0)};gt.prototype.removeListener=function(t,e,n,s){var i=wt?wt+t:t;if(!this._events[i])return this;if(!e)return gs(this,i),this;var o=this._events[i];if(o.fn)o.fn===e&&(!s||o.once)&&(!n||o.context===n)&&gs(this,i);else{for(var a=0,c=[],l=o.length;a<l;a++)(o[a].fn!==e||s&&!o[a].once||n&&o[a].context!==n)&&c.push(o[a]);c.length?this._events[i]=c.length===1?c[0]:c:gs(this,i)}return this};gt.prototype.removeAllListeners=function(t){var e;return t?(e=wt?wt+t:t,this._events[e]&&gs(this,e)):(this._events=new Fr,this._eventsCount=0),this};gt.prototype.off=gt.prototype.removeListener;gt.prototype.addListener=gt.prototype.on;gt.prefixed=wt;gt.EventEmitter=gt;typeof io<"u"&&(io.exports=gt)});var Lh={};bt(Lh,{floodsub:()=>Uh,multicodec:()=>fo});var Ls=Symbol.for("@libp2p/peer-id");var fr;(function(r){r.Accept="accept",r.Ignore="ignore",r.Reject="reject"})(fr||(fr={}));var So=Symbol.for("@libp2p/pubsub");var et=class extends Error{static name="InvalidParametersError";constructor(t="Invalid parameters"){super(t),this.name="InvalidParametersError"}},Fe=class extends Error{static name="InvalidPublicKeyError";constructor(t="Invalid public key"){super(t),this.name="InvalidPublicKeyError"}};var jr=class extends Error{static name="InvalidMultihashError";constructor(t="Invalid Multihash"){super(t),this.name="InvalidMultihashError"}};var X=class extends Error{static name="InvalidMessageError";constructor(t="Invalid message"){super(t),this.name="InvalidMessageError"}};var Yr=class extends Error{static name="NotStartedError";constructor(t="Not started"){super(t),this.name="NotStartedError"}};var Se=class extends Error{static name="UnsupportedKeyTypeError";constructor(t="Unsupported key type"){super(t),this.name="UnsupportedKeyTypeError"}};var Ke=class extends EventTarget{#t=new Map;constructor(){super()}listenerCount(t){let e=this.#t.get(t);return e==null?0:e.length}addEventListener(t,e,n){super.addEventListener(t,e,n);let s=this.#t.get(t);s==null&&(s=[],this.#t.set(t,s)),s.push({callback:e,once:(n!==!0&&n!==!1&&n?.once)??!1})}removeEventListener(t,e,n){super.removeEventListener(t.toString(),e??null,n);let s=this.#t.get(t);s!=null&&(s=s.filter(({callback:i})=>i!==e),this.#t.set(t,s))}dispatchEvent(t){let e=super.dispatchEvent(t),n=this.#t.get(t.type);return n==null||(n=n.filter(({once:s})=>!s),this.#t.set(t.type,n)),e}safeDispatchEvent(t,e={}){return this.dispatchEvent(new CustomEvent(t,e))}};var Ao=Symbol.for("@libp2p/service-capabilities"),ko=Symbol.for("@libp2p/service-dependencies");var Vs={};bt(Vs,{base58btc:()=>Q,base58flickr:()=>Au});var od=new Uint8Array(0);function Io(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function Zt(r){if(r instanceof Uint8Array&&r.constructor.name==="Uint8Array")return r;if(r instanceof ArrayBuffer)return new Uint8Array(r);if(ArrayBuffer.isView(r))return new Uint8Array(r.buffer,r.byteOffset,r.byteLength);throw new Error("Unknown type, must be binary type")}function No(r){return new TextEncoder().encode(r)}function To(r){return new TextDecoder().decode(r)}function xu(r,t){if(r.length>=255)throw new TypeError("Alphabet too long");for(var e=new Uint8Array(256),n=0;n<e.length;n++)e[n]=255;for(var s=0;s<r.length;s++){var i=r.charAt(s),o=i.charCodeAt(0);if(e[o]!==255)throw new TypeError(i+" is ambiguous");e[o]=s}var a=r.length,c=r.charAt(0),l=Math.log(a)/Math.log(256),f=Math.log(256)/Math.log(a);function u(x){if(x instanceof Uint8Array||(ArrayBuffer.isView(x)?x=new Uint8Array(x.buffer,x.byteOffset,x.byteLength):Array.isArray(x)&&(x=Uint8Array.from(x))),!(x instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(x.length===0)return"";for(var y=0,h=0,w=0,E=x.length;w!==E&&x[w]===0;)w++,y++;for(var g=(E-w)*f+1>>>0,k=new Uint8Array(g);w!==E;){for(var U=x[w],L=0,I=g-1;(U!==0||L<h)&&I!==-1;I--,L++)U+=256*k[I]>>>0,k[I]=U%a>>>0,U=U/a>>>0;if(U!==0)throw new Error("Non-zero carry");h=L,w++}for(var C=g-h;C!==g&&k[C]===0;)C++;for(var N=c.repeat(y);C<g;++C)N+=r.charAt(k[C]);return N}function d(x){if(typeof x!="string")throw new TypeError("Expected String");if(x.length===0)return new Uint8Array;var y=0;if(x[y]!==" "){for(var h=0,w=0;x[y]===c;)h++,y++;for(var E=(x.length-y)*l+1>>>0,g=new Uint8Array(E);x[y];){var k=e[x.charCodeAt(y)];if(k===255)return;for(var U=0,L=E-1;(k!==0||U<w)&&L!==-1;L--,U++)k+=a*g[L]>>>0,g[L]=k%256>>>0,k=k/256>>>0;if(k!==0)throw new Error("Non-zero carry");w=U,y++}if(x[y]!==" "){for(var I=E-w;I!==E&&g[I]===0;)I++;for(var C=new Uint8Array(h+(E-I)),N=h;I!==E;)C[N++]=g[I++];return C}}}function m(x){var y=d(x);if(y)return y;throw new Error(`Non-${t} character`)}return{encode:u,decodeUnsafe:d,decode:m}}var vu=xu,Eu=vu,Uo=Eu;var Rs=class{name;prefix;baseEncode;constructor(t,e,n){this.name=t,this.prefix=e,this.baseEncode=n}encode(t){if(t instanceof Uint8Array)return`${this.prefix}${this.baseEncode(t)}`;throw Error("Unknown type, must be binary type")}},_s=class{name;prefix;baseDecode;prefixCodePoint;constructor(t,e,n){this.name=t,this.prefix=e;let s=e.codePointAt(0);if(s===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=s,this.baseDecode=n}decode(t){if(typeof t=="string"){if(t.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(t)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(t.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(t){return Lo(this,t)}},Ds=class{decoders;constructor(t){this.decoders=t}or(t){return Lo(this,t)}decode(t){let e=t[0],n=this.decoders[e];if(n!=null)return n.decode(t);throw RangeError(`Unable to decode multibase string ${JSON.stringify(t)}, only inputs prefixed with ${Object.keys(this.decoders)} are supported`)}};function Lo(r,t){return new Ds({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var Ms=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(t,e,n,s){this.name=t,this.prefix=e,this.baseEncode=n,this.baseDecode=s,this.encoder=new Rs(t,e,n),this.decoder=new _s(t,e,s)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function qe({name:r,prefix:t,encode:e,decode:n}){return new Ms(r,t,e,n)}function ce({name:r,prefix:t,alphabet:e}){let{encode:n,decode:s}=Uo(e,r);return qe({prefix:t,name:r,encode:n,decode:i=>Zt(s(i))})}function Bu(r,t,e,n){let s={};for(let f=0;f<t.length;++f)s[t[f]]=f;let i=r.length;for(;r[i-1]==="=";)--i;let o=new Uint8Array(i*e/8|0),a=0,c=0,l=0;for(let f=0;f<i;++f){let u=s[r[f]];if(u===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<e|u,a+=e,a>=8&&(a-=8,o[l++]=255&c>>a)}if(a>=e||255&c<<8-a)throw new SyntaxError("Unexpected end of data");return o}function Su(r,t,e){let n=t[t.length-1]==="=",s=(1<<e)-1,i="",o=0,a=0;for(let c=0;c<r.length;++c)for(a=a<<8|r[c],o+=8;o>e;)o-=e,i+=t[s&a>>o];if(o!==0&&(i+=t[s&a<<e-o]),n)for(;i.length*e&7;)i+="=";return i}function J({name:r,prefix:t,bitsPerChar:e,alphabet:n}){return qe({prefix:t,name:r,encode(s){return Su(s,n,e)},decode(s){return Bu(s,n,e,r)}})}var Q=ce({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),Au=ce({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Hs={};bt(Hs,{base32:()=>ze,base32hex:()=>Tu,base32hexpad:()=>Uu,base32hexpadupper:()=>Lu,base32hexupper:()=>Cu,base32pad:()=>Iu,base32padupper:()=>Nu,base32upper:()=>ku,base32z:()=>Ru});var ze=J({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),ku=J({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Iu=J({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),Nu=J({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),Tu=J({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),Cu=J({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),Uu=J({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),Lu=J({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),Ru=J({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Os={};bt(Os,{base36:()=>hr,base36upper:()=>_u});var hr=ce({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),_u=ce({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Du=Do,Ro=128,Mu=127,Vu=~Mu,Hu=Math.pow(2,31);function Do(r,t,e){t=t||[],e=e||0;for(var n=e;r>=Hu;)t[e++]=r&255|Ro,r/=128;for(;r&Vu;)t[e++]=r&255|Ro,r>>>=7;return t[e]=r|0,Do.bytes=e-n+1,t}var Ou=Ps,Pu=128,_o=127;function Ps(r,n){var e=0,n=n||0,s=0,i=n,o,a=r.length;do{if(i>=a)throw Ps.bytes=0,new RangeError("Could not decode varint");o=r[i++],e+=s<28?(o&_o)<<s:(o&_o)*Math.pow(2,s),s+=7}while(o>=Pu);return Ps.bytes=i-n,e}var Fu=Math.pow(2,7),Ku=Math.pow(2,14),qu=Math.pow(2,21),zu=Math.pow(2,28),$u=Math.pow(2,35),Gu=Math.pow(2,42),Zu=Math.pow(2,49),Wu=Math.pow(2,56),ju=Math.pow(2,63),Yu=function(r){return r<Fu?1:r<Ku?2:r<qu?3:r<zu?4:r<$u?5:r<Gu?6:r<Zu?7:r<Wu?8:r<ju?9:10},Ju={encode:Du,decode:Ou,encodingLength:Yu},Xu=Ju,dr=Xu;function pr(r,t=0){return[dr.decode(r,t),dr.decode.bytes]}function $e(r,t,e=0){return dr.encode(r,t,e),t}function Ge(r){return dr.encodingLength(r)}function Lt(r,t){let e=t.byteLength,n=Ge(r),s=n+Ge(e),i=new Uint8Array(s+e);return $e(r,i,0),$e(e,i,n),i.set(t,s),new Ze(r,e,t,i)}function ue(r){let t=Zt(r),[e,n]=pr(t),[s,i]=pr(t.subarray(n)),o=t.subarray(n+i);if(o.byteLength!==s)throw new Error("Incorrect length");return new Ze(e,s,o,t)}function Mo(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&Io(r.bytes,e.bytes)}}var Ze=class{code;size;digest;bytes;constructor(t,e,n,s){this.code=t,this.size=e,this.digest=n,this.bytes=s}};function Vo(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return tl(e,Fs(r),t??Q.encoder);default:return el(e,Fs(r),t??ze.encoder)}}var Ho=new WeakMap;function Fs(r){let t=Ho.get(r);if(t==null){let e=new Map;return Ho.set(r,e),e}return t}var It=class r{code;version;multihash;bytes;"/";constructor(t,e,n,s){this.code=e,this.version=t,this.multihash=n,this.bytes=s,this["/"]=s}get asCID(){return this}get byteOffset(){return this.bytes.byteOffset}get byteLength(){return this.bytes.byteLength}toV0(){switch(this.version){case 0:return this;case 1:{let{code:t,multihash:e}=this;if(t!==gr)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==rl)throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");return r.createV0(e)}default:throw Error(`Can not convert CID version ${this.version} to version 0. This is a bug please report`)}}toV1(){switch(this.version){case 0:{let{code:t,digest:e}=this.multihash,n=Lt(t,e);return r.createV1(this.code,n)}case 1:return this;default:throw Error(`Can not convert CID version ${this.version} to version 1. This is a bug please report`)}}equals(t){return r.equals(this,t)}static equals(t,e){let n=e;return n!=null&&t.code===n.code&&t.version===n.version&&Mo(t.multihash,n.multihash)}toString(t){return Vo(this,t)}toJSON(){return{"/":Vo(this)}}link(){return this}[Symbol.toStringTag]="CID";[Symbol.for("nodejs.util.inspect.custom")](){return`CID(${this.toString()})`}static asCID(t){if(t==null)return null;let e=t;if(e instanceof r)return e;if(e["/"]!=null&&e["/"]===e.bytes||e.asCID===e){let{version:n,code:s,multihash:i,bytes:o}=e;return new r(n,s,i,o??Oo(n,s,i.bytes))}else if(e[nl]===!0){let{version:n,multihash:s,code:i}=e,o=ue(s);return r.create(n,i,o)}else return null}static create(t,e,n){if(typeof e!="number")throw new Error("String codecs are no longer supported");if(!(n.bytes instanceof Uint8Array))throw new Error("Invalid digest");switch(t){case 0:{if(e!==gr)throw new Error(`Version 0 CID must use dag-pb (code: ${gr}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let s=Oo(t,e,n.bytes);return new r(t,e,n,s)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,gr,t)}static createV1(t,e){return r.create(1,t,e)}static decode(t){let[e,n]=r.decodeFirst(t);if(n.length!==0)throw new Error("Incorrect length");return e}static decodeFirst(t){let e=r.inspectBytes(t),n=e.size-e.multihashSize,s=Zt(t.subarray(n,n+e.multihashSize));if(s.byteLength!==e.multihashSize)throw new Error("Incorrect length");let i=s.subarray(e.multihashSize-e.digestSize),o=new Ze(e.multihashCode,e.digestSize,i,s);return[e.version===0?r.createV0(o):r.createV1(e.codec,o),t.subarray(e.size)]}static inspectBytes(t){let e=0,n=()=>{let[u,d]=pr(t.subarray(e));return e+=d,u},s=n(),i=gr;if(s===18?(s=0,e=0):i=n(),s!==0&&s!==1)throw new RangeError(`Invalid CID version ${s}`);let o=e,a=n(),c=n(),l=e+c,f=l-o;return{version:s,codec:i,multihashCode:a,digestSize:c,multihashSize:f,size:l}}static parse(t,e){let[n,s]=Qu(t,e),i=r.decode(s);if(i.version===0&&t[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return Fs(i).set(n,t),i}};function Qu(r,t){switch(r[0]){case"Q":{let e=t??Q;return[Q.prefix,e.decode(`${Q.prefix}${r}`)]}case Q.prefix:{let e=t??Q;return[Q.prefix,e.decode(r)]}case ze.prefix:{let e=t??ze;return[ze.prefix,e.decode(r)]}case hr.prefix:{let e=t??hr;return[hr.prefix,e.decode(r)]}default:{if(t==null)throw Error("To parse non base32, base36 or base58btc encoded CID multibase decoder must be provided");return[r[0],t.decode(r)]}}}function tl(r,t,e){let{prefix:n}=e;if(n!==Q.prefix)throw Error(`Cannot string encode V0 in ${e.name} encoding`);let s=t.get(n);if(s==null){let i=e.encode(r).slice(1);return t.set(n,i),i}else return s}function el(r,t,e){let{prefix:n}=e,s=t.get(n);if(s==null){let i=e.encode(r);return t.set(n,i),i}else return s}var gr=112,rl=18;function Oo(r,t,e){let n=Ge(r),s=n+Ge(t),i=new Uint8Array(s+e.byteLength);return $e(r,i,0),$e(t,i,n),i.set(e,s),i}var nl=Symbol.for("@ipld/js-cid/CID");var Ks={};bt(Ks,{identity:()=>Wt});var Po=0,sl="identity",Fo=Zt;function il(r){return Lt(Po,Fo(r))}var Wt={code:Po,name:sl,encode:Fo,digest:il};function Tt(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function Ko(r){if(!Number.isSafeInteger(r)||r<0)throw new Error("positive integer expected, got "+r)}function ol(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function We(r,...t){if(!ol(r))throw new Error("Uint8Array expected");if(t.length>0&&!t.includes(r.length))throw new Error("Uint8Array expected of length "+t+", got length="+r.length)}function qo(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");Ko(r.outputLen),Ko(r.blockLen)}function je(r,t=!0){if(r.destroyed)throw new Error("Hash instance has been destroyed");if(t&&r.finished)throw new Error("Hash#digest() has already been called")}function zo(r,t){We(r);let e=t.outputLen;if(r.length<e)throw new Error("digestInto() expects output buffer of length at least "+e)}var Ae=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;function Xr(r){return new DataView(r.buffer,r.byteOffset,r.byteLength)}function Rt(r,t){return r<<32-t|r>>>t}function $o(r){if(typeof r!="string")throw new Error("utf8ToBytes expected string, got "+typeof r);return new Uint8Array(new TextEncoder().encode(r))}function mr(r){return typeof r=="string"&&(r=$o(r)),We(r),r}function qs(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];We(s),t+=s.length}let e=new Uint8Array(t);for(let n=0,s=0;n<r.length;n++){let i=r[n];e.set(i,s),s+=i.length}return e}var Ye=class{clone(){return this._cloneInto()}};function Qr(r){let t=n=>r().update(mr(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function Je(r=32){if(Ae&&typeof Ae.getRandomValues=="function")return Ae.getRandomValues(new Uint8Array(r));if(Ae&&typeof Ae.randomBytes=="function")return Ae.randomBytes(r);throw new Error("crypto.getRandomValues must be defined")}function al(r,t,e,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(t,e,n);let s=BigInt(32),i=BigInt(4294967295),o=Number(e>>s&i),a=Number(e&i),c=n?4:0,l=n?0:4;r.setUint32(t+c,o,n),r.setUint32(t+l,a,n)}function Go(r,t,e){return r&t^~r&e}function Zo(r,t,e){return r&t^r&e^t&e}var Xe=class extends Ye{constructor(t,e,n,s){super(),this.blockLen=t,this.outputLen=e,this.padOffset=n,this.isLE=s,this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.buffer=new Uint8Array(t),this.view=Xr(this.buffer)}update(t){je(this);let{view:e,buffer:n,blockLen:s}=this;t=mr(t);let i=t.length;for(let o=0;o<i;){let a=Math.min(s-this.pos,i-o);if(a===s){let c=Xr(t);for(;s<=i-o;o+=s)this.process(c,o);continue}n.set(t.subarray(o,o+a),this.pos),this.pos+=a,o+=a,this.pos===s&&(this.process(e,0),this.pos=0)}return this.length+=t.length,this.roundClean(),this}digestInto(t){je(this),zo(t,this),this.finished=!0;let{buffer:e,view:n,blockLen:s,isLE:i}=this,{pos:o}=this;e[o++]=128,this.buffer.subarray(o).fill(0),this.padOffset>s-o&&(this.process(n,0),o=0);for(let u=o;u<s;u++)e[u]=0;al(n,s-8,BigInt(this.length*8),i),this.process(n,0);let a=Xr(t),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let l=c/4,f=this.get();if(l>f.length)throw new Error("_sha2: outputLen bigger than state");for(let u=0;u<l;u++)a.setUint32(4*u,f[u],i)}digest(){let{buffer:t,outputLen:e}=this;this.digestInto(t);let n=t.slice(0,e);return this.destroy(),n}_cloneInto(t){t||(t=new this.constructor),t.set(...this.get());let{blockLen:e,buffer:n,length:s,finished:i,destroyed:o,pos:a}=this;return t.length=s,t.pos=a,t.finished=i,t.destroyed=o,s%e&&t.buffer.set(n),t}};var tn=BigInt(4294967295),zs=BigInt(32);function Wo(r,t=!1){return t?{h:Number(r&tn),l:Number(r>>zs&tn)}:{h:Number(r>>zs&tn)|0,l:Number(r&tn)|0}}function cl(r,t=!1){let e=new Uint32Array(r.length),n=new Uint32Array(r.length);for(let s=0;s<r.length;s++){let{h:i,l:o}=Wo(r[s],t);[e[s],n[s]]=[i,o]}return[e,n]}var ul=(r,t)=>BigInt(r>>>0)<<zs|BigInt(t>>>0),ll=(r,t,e)=>r>>>e,fl=(r,t,e)=>r<<32-e|t>>>e,hl=(r,t,e)=>r>>>e|t<<32-e,dl=(r,t,e)=>r<<32-e|t>>>e,pl=(r,t,e)=>r<<64-e|t>>>e-32,gl=(r,t,e)=>r>>>e-32|t<<64-e,ml=(r,t)=>t,bl=(r,t)=>r,yl=(r,t,e)=>r<<e|t>>>32-e,wl=(r,t,e)=>t<<e|r>>>32-e,xl=(r,t,e)=>t<<e-32|r>>>64-e,vl=(r,t,e)=>r<<e-32|t>>>64-e;function El(r,t,e,n){let s=(t>>>0)+(n>>>0);return{h:r+e+(s/2**32|0)|0,l:s|0}}var Bl=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),Sl=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,Al=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),kl=(r,t,e,n,s)=>t+e+n+s+(r/2**32|0)|0,Il=(r,t,e,n,s)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(s>>>0),Nl=(r,t,e,n,s,i)=>t+e+n+s+i+(r/2**32|0)|0;var Tl={fromBig:Wo,split:cl,toBig:ul,shrSH:ll,shrSL:fl,rotrSH:hl,rotrSL:dl,rotrBH:pl,rotrBL:gl,rotr32H:ml,rotr32L:bl,rotlSH:yl,rotlSL:wl,rotlBH:xl,rotlBL:vl,add:El,add3L:Bl,add3H:Sl,add4L:Al,add4H:kl,add5H:Nl,add5L:Il},M=Tl;var[Cl,Ul]=M.split(["0x428a2f98d728ae22","0x7137449123ef65cd","0xb5c0fbcfec4d3b2f","0xe9b5dba58189dbbc","0x3956c25bf348b538","0x59f111f1b605d019","0x923f82a4af194f9b","0xab1c5ed5da6d8118","0xd807aa98a3030242","0x12835b0145706fbe","0x243185be4ee4b28c","0x550c7dc3d5ffb4e2","0x72be5d74f27b896f","0x80deb1fe3b1696b1","0x9bdc06a725c71235","0xc19bf174cf692694","0xe49b69c19ef14ad2","0xefbe4786384f25e3","0x0fc19dc68b8cd5b5","0x240ca1cc77ac9c65","0x2de92c6f592b0275","0x4a7484aa6ea6e483","0x5cb0a9dcbd41fbd4","0x76f988da831153b5","0x983e5152ee66dfab","0xa831c66d2db43210","0xb00327c898fb213f","0xbf597fc7beef0ee4","0xc6e00bf33da88fc2","0xd5a79147930aa725","0x06ca6351e003826f","0x142929670a0e6e70","0x27b70a8546d22ffc","0x2e1b21385c26c926","0x4d2c6dfc5ac42aed","0x53380d139d95b3df","0x650a73548baf63de","0x766a0abb3c77b2a8","0x81c2c92e47edaee6","0x92722c851482353b","0xa2bfe8a14cf10364","0xa81a664bbc423001","0xc24b8b70d0f89791","0xc76c51a30654be30","0xd192e819d6ef5218","0xd69906245565a910","0xf40e35855771202a","0x106aa07032bbd1b8","0x19a4c116b8d2d0c8","0x1e376c085141ab53","0x2748774cdf8eeb99","0x34b0bcb5e19b48a8","0x391c0cb3c5c95a63","0x4ed8aa4ae3418acb","0x5b9cca4f7763e373","0x682e6ff3d6b2b8a3","0x748f82ee5defb2fc","0x78a5636f43172f60","0x84c87814a1f0ab72","0x8cc702081a6439ec","0x90befffa23631e28","0xa4506cebde82bde9","0xbef9a3f7b2c67915","0xc67178f2e372532b","0xca273eceea26619c","0xd186b8c721c0c207","0xeada7dd6cde0eb1e","0xf57d4f7fee6ed178","0x06f067aa72176fba","0x0a637dc5a2c898a6","0x113f9804bef90dae","0x1b710b35131c471b","0x28db77f523047d84","0x32caab7b40c72493","0x3c9ebe0a15c9bebc","0x431d67c49c100d4c","0x4cc5d4becb3e42b6","0x597f299cfc657e2a","0x5fcb6fab3ad6faec","0x6c44198c4a475817"].map(r=>BigInt(r))),fe=new Uint32Array(80),he=new Uint32Array(80),$s=class extends Xe{constructor(){super(128,64,16,!1),this.Ah=1779033703,this.Al=-205731576,this.Bh=-1150833019,this.Bl=-2067093701,this.Ch=1013904242,this.Cl=-23791573,this.Dh=-1521486534,this.Dl=1595750129,this.Eh=1359893119,this.El=-1377402159,this.Fh=-1694144372,this.Fl=725511199,this.Gh=528734635,this.Gl=-79577749,this.Hh=1541459225,this.Hl=327033209}get(){let{Ah:t,Al:e,Bh:n,Bl:s,Ch:i,Cl:o,Dh:a,Dl:c,Eh:l,El:f,Fh:u,Fl:d,Gh:m,Gl:x,Hh:y,Hl:h}=this;return[t,e,n,s,i,o,a,c,l,f,u,d,m,x,y,h]}set(t,e,n,s,i,o,a,c,l,f,u,d,m,x,y,h){this.Ah=t|0,this.Al=e|0,this.Bh=n|0,this.Bl=s|0,this.Ch=i|0,this.Cl=o|0,this.Dh=a|0,this.Dl=c|0,this.Eh=l|0,this.El=f|0,this.Fh=u|0,this.Fl=d|0,this.Gh=m|0,this.Gl=x|0,this.Hh=y|0,this.Hl=h|0}process(t,e){for(let g=0;g<16;g++,e+=4)fe[g]=t.getUint32(e),he[g]=t.getUint32(e+=4);for(let g=16;g<80;g++){let k=fe[g-15]|0,U=he[g-15]|0,L=M.rotrSH(k,U,1)^M.rotrSH(k,U,8)^M.shrSH(k,U,7),I=M.rotrSL(k,U,1)^M.rotrSL(k,U,8)^M.shrSL(k,U,7),C=fe[g-2]|0,N=he[g-2]|0,G=M.rotrSH(C,N,19)^M.rotrBH(C,N,61)^M.shrSH(C,N,6),F=M.rotrSL(C,N,19)^M.rotrBL(C,N,61)^M.shrSL(C,N,6),H=M.add4L(I,F,he[g-7],he[g-16]),tt=M.add4H(H,L,G,fe[g-7],fe[g-16]);fe[g]=tt|0,he[g]=H|0}let{Ah:n,Al:s,Bh:i,Bl:o,Ch:a,Cl:c,Dh:l,Dl:f,Eh:u,El:d,Fh:m,Fl:x,Gh:y,Gl:h,Hh:w,Hl:E}=this;for(let g=0;g<80;g++){let k=M.rotrSH(u,d,14)^M.rotrSH(u,d,18)^M.rotrBH(u,d,41),U=M.rotrSL(u,d,14)^M.rotrSL(u,d,18)^M.rotrBL(u,d,41),L=u&m^~u&y,I=d&x^~d&h,C=M.add5L(E,U,I,Ul[g],he[g]),N=M.add5H(C,w,k,L,Cl[g],fe[g]),G=C|0,F=M.rotrSH(n,s,28)^M.rotrBH(n,s,34)^M.rotrBH(n,s,39),H=M.rotrSL(n,s,28)^M.rotrBL(n,s,34)^M.rotrBL(n,s,39),tt=n&i^n&a^i&a,B=s&o^s&c^o&c;w=y|0,E=h|0,y=m|0,h=x|0,m=u|0,x=d|0,{h:u,l:d}=M.add(l|0,f|0,N|0,G|0),l=a|0,f=c|0,a=i|0,c=o|0,i=n|0,o=s|0;let T=M.add3L(G,H,B);n=M.add3H(T,N,F,tt),s=T|0}({h:n,l:s}=M.add(this.Ah|0,this.Al|0,n|0,s|0)),{h:i,l:o}=M.add(this.Bh|0,this.Bl|0,i|0,o|0),{h:a,l:c}=M.add(this.Ch|0,this.Cl|0,a|0,c|0),{h:l,l:f}=M.add(this.Dh|0,this.Dl|0,l|0,f|0),{h:u,l:d}=M.add(this.Eh|0,this.El|0,u|0,d|0),{h:m,l:x}=M.add(this.Fh|0,this.Fl|0,m|0,x|0),{h:y,l:h}=M.add(this.Gh|0,this.Gl|0,y|0,h|0),{h:w,l:E}=M.add(this.Hh|0,this.Hl|0,w|0,E|0),this.set(n,s,i,o,a,c,l,f,u,d,m,x,y,h,w,E)}roundClean(){fe.fill(0),he.fill(0)}destroy(){this.buffer.fill(0),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}};var jo=Qr(()=>new $s);var nn={};bt(nn,{aInRange:()=>vt,abool:()=>_t,abytes:()=>Qe,bitGet:()=>Vl,bitLen:()=>js,bitMask:()=>yr,bitSet:()=>Hl,bytesToHex:()=>Yt,bytesToNumberBE:()=>Jt,bytesToNumberLE:()=>pe,concatBytes:()=>Xt,createHmacDrbg:()=>Ys,ensureBytes:()=>j,equalBytes:()=>Dl,hexToBytes:()=>Ie,hexToNumber:()=>Ws,inRange:()=>br,isBytes:()=>de,memoized:()=>Te,notImplemented:()=>Pl,numberToBytesBE:()=>ge,numberToBytesLE:()=>Ne,numberToHexUnpadded:()=>ke,numberToVarBytesBE:()=>_l,utf8ToBytes:()=>Ml,validateObject:()=>Ft});var en=BigInt(0),rn=BigInt(1),Ll=BigInt(2);function de(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function Qe(r){if(!de(r))throw new Error("Uint8Array expected")}function _t(r,t){if(typeof t!="boolean")throw new Error(r+" boolean expected, got "+t)}var Rl=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function Yt(r){Qe(r);let t="";for(let e=0;e<r.length;e++)t+=Rl[r[e]];return t}function ke(r){let t=r.toString(16);return t.length&1?"0"+t:t}function Ws(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return r===""?en:BigInt("0x"+r)}var jt={_0:48,_9:57,A:65,F:70,a:97,f:102};function Yo(r){if(r>=jt._0&&r<=jt._9)return r-jt._0;if(r>=jt.A&&r<=jt.F)return r-(jt.A-10);if(r>=jt.a&&r<=jt.f)return r-(jt.a-10)}function Ie(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);let t=r.length,e=t/2;if(t%2)throw new Error("hex string expected, got unpadded hex of length "+t);let n=new Uint8Array(e);for(let s=0,i=0;s<e;s++,i+=2){let o=Yo(r.charCodeAt(i)),a=Yo(r.charCodeAt(i+1));if(o===void 0||a===void 0){let c=r[i]+r[i+1];throw new Error('hex string expected, got non-hex character "'+c+'" at index '+i)}n[s]=o*16+a}return n}function Jt(r){return Ws(Yt(r))}function pe(r){return Qe(r),Ws(Yt(Uint8Array.from(r).reverse()))}function ge(r,t){return Ie(r.toString(16).padStart(t*2,"0"))}function Ne(r,t){return ge(r,t).reverse()}function _l(r){return Ie(ke(r))}function j(r,t,e){let n;if(typeof t=="string")try{n=Ie(t)}catch(i){throw new Error(r+" must be hex string or Uint8Array, cause: "+i)}else if(de(t))n=Uint8Array.from(t);else throw new Error(r+" must be hex string or Uint8Array");let s=n.length;if(typeof e=="number"&&s!==e)throw new Error(r+" of length "+e+" expected, got "+s);return n}function Xt(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];Qe(s),t+=s.length}let e=new Uint8Array(t);for(let n=0,s=0;n<r.length;n++){let i=r[n];e.set(i,s),s+=i.length}return e}function Dl(r,t){if(r.length!==t.length)return!1;let e=0;for(let n=0;n<r.length;n++)e|=r[n]^t[n];return e===0}function Ml(r){if(typeof r!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(r))}var Gs=r=>typeof r=="bigint"&&en<=r;function br(r,t,e){return Gs(r)&&Gs(t)&&Gs(e)&&t<=r&&r<e}function vt(r,t,e,n){if(!br(t,e,n))throw new Error("expected valid "+r+": "+e+" <= n < "+n+", got "+t)}function js(r){let t;for(t=0;r>en;r>>=rn,t+=1);return t}function Vl(r,t){return r>>BigInt(t)&rn}function Hl(r,t,e){return r|(e?rn:en)<<BigInt(t)}var yr=r=>(Ll<<BigInt(r-1))-rn,Zs=r=>new Uint8Array(r),Jo=r=>Uint8Array.from(r);function Ys(r,t,e){if(typeof r!="number"||r<2)throw new Error("hashLen must be a number");if(typeof t!="number"||t<2)throw new Error("qByteLen must be a number");if(typeof e!="function")throw new Error("hmacFn must be a function");let n=Zs(r),s=Zs(r),i=0,o=()=>{n.fill(1),s.fill(0),i=0},a=(...u)=>e(s,n,...u),c=(u=Zs())=>{s=a(Jo([0]),u),n=a(),u.length!==0&&(s=a(Jo([1]),u),n=a())},l=()=>{if(i++>=1e3)throw new Error("drbg: tried 1000 values");let u=0,d=[];for(;u<t;){n=a();let m=n.slice();d.push(m),u+=n.length}return Xt(...d)};return(u,d)=>{o(),c(u);let m;for(;!(m=d(l()));)c();return o(),m}}var Ol={bigint:r=>typeof r=="bigint",function:r=>typeof r=="function",boolean:r=>typeof r=="boolean",string:r=>typeof r=="string",stringOrUint8Array:r=>typeof r=="string"||de(r),isSafeInteger:r=>Number.isSafeInteger(r),array:r=>Array.isArray(r),field:(r,t)=>t.Fp.isValid(r),hash:r=>typeof r=="function"&&Number.isSafeInteger(r.outputLen)};function Ft(r,t,e={}){let n=(s,i,o)=>{let a=Ol[i];if(typeof a!="function")throw new Error("invalid validator function");let c=r[s];if(!(o&&c===void 0)&&!a(c,r))throw new Error("param "+String(s)+" is invalid. Expected "+i+", got "+c)};for(let[s,i]of Object.entries(t))n(s,i,!1);for(let[s,i]of Object.entries(e))n(s,i,!0);return r}var Pl=()=>{throw new Error("not implemented")};function Te(r){let t=new WeakMap;return(e,...n)=>{let s=t.get(e);if(s!==void 0)return s;let i=r(e,...n);return t.set(e,i),i}}var rt=BigInt(0),Z=BigInt(1),Ce=BigInt(2),Fl=BigInt(3),Js=BigInt(4),Xo=BigInt(5),Qo=BigInt(8),Kl=BigInt(9),ql=BigInt(16);function z(r,t){let e=r%t;return e>=rt?e:t+e}function zl(r,t,e){if(t<rt)throw new Error("invalid exponent, negatives unsupported");if(e<=rt)throw new Error("invalid modulus");if(e===Z)return rt;let n=Z;for(;t>rt;)t&Z&&(n=n*r%e),r=r*r%e,t>>=Z;return n}function W(r,t,e){let n=r;for(;t-- >rt;)n*=n,n%=e;return n}function sn(r,t){if(r===rt)throw new Error("invert: expected non-zero number");if(t<=rt)throw new Error("invert: expected positive modulus, got "+t);let e=z(r,t),n=t,s=rt,i=Z,o=Z,a=rt;for(;e!==rt;){let l=n/e,f=n%e,u=s-o*l,d=i-a*l;n=e,e=f,s=o,i=a,o=u,a=d}if(n!==Z)throw new Error("invert: does not exist");return z(s,t)}function $l(r){let t=(r-Z)/Ce,e,n,s;for(e=r-Z,n=0;e%Ce===rt;e/=Ce,n++);for(s=Ce;s<r&&zl(s,t,r)!==r-Z;s++)if(s>1e3)throw new Error("Cannot find square root: likely non-prime P");if(n===1){let o=(r+Z)/Js;return function(c,l){let f=c.pow(l,o);if(!c.eql(c.sqr(f),l))throw new Error("Cannot find square root");return f}}let i=(e+Z)/Ce;return function(a,c){if(a.pow(c,t)===a.neg(a.ONE))throw new Error("Cannot find square root");let l=n,f=a.pow(a.mul(a.ONE,s),e),u=a.pow(c,i),d=a.pow(c,e);for(;!a.eql(d,a.ONE);){if(a.eql(d,a.ZERO))return a.ZERO;let m=1;for(let y=a.sqr(d);m<l&&!a.eql(y,a.ONE);m++)y=a.sqr(y);let x=a.pow(f,Z<<BigInt(l-m-1));f=a.sqr(x),u=a.mul(u,x),d=a.mul(d,f),l=m}return u}}function Gl(r){if(r%Js===Fl){let t=(r+Z)/Js;return function(n,s){let i=n.pow(s,t);if(!n.eql(n.sqr(i),s))throw new Error("Cannot find square root");return i}}if(r%Qo===Xo){let t=(r-Xo)/Qo;return function(n,s){let i=n.mul(s,Ce),o=n.pow(i,t),a=n.mul(s,o),c=n.mul(n.mul(a,Ce),o),l=n.mul(a,n.sub(c,n.ONE));if(!n.eql(n.sqr(l),s))throw new Error("Cannot find square root");return l}}return r%ql,$l(r)}var ta=(r,t)=>(z(r,t)&Z)===Z,Zl=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function Xs(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=Zl.reduce((n,s)=>(n[s]="function",n),t);return Ft(r,e)}function Wl(r,t,e){if(e<rt)throw new Error("invalid exponent, negatives unsupported");if(e===rt)return r.ONE;if(e===Z)return t;let n=r.ONE,s=t;for(;e>rt;)e&Z&&(n=r.mul(n,s)),s=r.sqr(s),e>>=Z;return n}function jl(r,t){let e=new Array(t.length),n=t.reduce((i,o,a)=>r.is0(o)?i:(e[a]=i,r.mul(i,o)),r.ONE),s=r.inv(n);return t.reduceRight((i,o,a)=>r.is0(o)?i:(e[a]=r.mul(i,e[a]),r.mul(i,o)),s),e}function Qs(r,t){let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function me(r,t,e=!1,n={}){if(r<=rt)throw new Error("invalid field: expected ORDER > 0, got "+r);let{nBitLength:s,nByteLength:i}=Qs(r,t);if(i>2048)throw new Error("invalid field: expected ORDER of <= 2048 bytes");let o,a=Object.freeze({ORDER:r,isLE:e,BITS:s,BYTES:i,MASK:yr(s),ZERO:rt,ONE:Z,create:c=>z(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error("invalid field element: expected bigint, got "+typeof c);return rt<=c&&c<r},is0:c=>c===rt,isOdd:c=>(c&Z)===Z,neg:c=>z(-c,r),eql:(c,l)=>c===l,sqr:c=>z(c*c,r),add:(c,l)=>z(c+l,r),sub:(c,l)=>z(c-l,r),mul:(c,l)=>z(c*l,r),pow:(c,l)=>Wl(a,c,l),div:(c,l)=>z(c*sn(l,r),r),sqrN:c=>c*c,addN:(c,l)=>c+l,subN:(c,l)=>c-l,mulN:(c,l)=>c*l,inv:c=>sn(c,r),sqrt:n.sqrt||(c=>(o||(o=Gl(r)),o(a,c))),invertBatch:c=>jl(a,c),cmov:(c,l,f)=>f?l:c,toBytes:c=>e?Ne(c,i):ge(c,i),fromBytes:c=>{if(c.length!==i)throw new Error("Field.fromBytes: expected "+i+" bytes, got "+c.length);return e?pe(c):Jt(c)}});return Object.freeze(a)}function ea(r){if(typeof r!="bigint")throw new Error("field order must be bigint");let t=r.toString(2).length;return Math.ceil(t/8)}function ti(r){let t=ea(r);return t+Math.ceil(t/2)}function ra(r,t,e=!1){let n=r.length,s=ea(t),i=ti(t);if(n<16||n<i||n>1024)throw new Error("expected "+i+"-1024 bytes of input, got "+n);let o=e?pe(r):Jt(r),a=z(o,t-Z)+Z;return e?Ne(a,s):ge(a,s)}var na=BigInt(0),on=BigInt(1);function ei(r,t){let e=t.negate();return r?e:t}function sa(r,t){if(!Number.isSafeInteger(r)||r<=0||r>t)throw new Error("invalid window size, expected [1.."+t+"], got W="+r)}function ri(r,t){sa(r,t);let e=Math.ceil(t/r)+1,n=2**(r-1);return{windows:e,windowSize:n}}function Yl(r,t){if(!Array.isArray(r))throw new Error("array expected");r.forEach((e,n)=>{if(!(e instanceof t))throw new Error("invalid point at index "+n)})}function Jl(r,t){if(!Array.isArray(r))throw new Error("array of scalars expected");r.forEach((e,n)=>{if(!t.isValid(e))throw new Error("invalid scalar at index "+n)})}var ni=new WeakMap,ia=new WeakMap;function si(r){return ia.get(r)||1}function an(r,t){return{constTimeNegate:ei,hasPrecomputes(e){return si(e)!==1},unsafeLadder(e,n,s=r.ZERO){let i=e;for(;n>na;)n&on&&(s=s.add(i)),i=i.double(),n>>=on;return s},precomputeWindow(e,n){let{windows:s,windowSize:i}=ri(n,t),o=[],a=e,c=a;for(let l=0;l<s;l++){c=a,o.push(c);for(let f=1;f<i;f++)c=c.add(a),o.push(c);a=c.double()}return o},wNAF(e,n,s){let{windows:i,windowSize:o}=ri(e,t),a=r.ZERO,c=r.BASE,l=BigInt(2**e-1),f=2**e,u=BigInt(e);for(let d=0;d<i;d++){let m=d*o,x=Number(s&l);s>>=u,x>o&&(x-=f,s+=on);let y=m,h=m+Math.abs(x)-1,w=d%2!==0,E=x<0;x===0?c=c.add(ei(w,n[y])):a=a.add(ei(E,n[h]))}return{p:a,f:c}},wNAFUnsafe(e,n,s,i=r.ZERO){let{windows:o,windowSize:a}=ri(e,t),c=BigInt(2**e-1),l=2**e,f=BigInt(e);for(let u=0;u<o;u++){let d=u*a;if(s===na)break;let m=Number(s&c);if(s>>=f,m>a&&(m-=l,s+=on),m===0)continue;let x=n[d+Math.abs(m)-1];m<0&&(x=x.negate()),i=i.add(x)}return i},getPrecomputes(e,n,s){let i=ni.get(n);return i||(i=this.precomputeWindow(n,e),e!==1&&ni.set(n,s(i))),i},wNAFCached(e,n,s){let i=si(e);return this.wNAF(i,this.getPrecomputes(i,e,s),n)},wNAFCachedUnsafe(e,n,s,i){let o=si(e);return o===1?this.unsafeLadder(e,n,i):this.wNAFUnsafe(o,this.getPrecomputes(o,e,s),n,i)},setWindowSize(e,n){sa(n,t),ia.set(e,n),ni.delete(e)}}}function cn(r,t,e,n){if(Yl(e,r),Jl(n,t),e.length!==n.length)throw new Error("arrays of points and scalars must have equal length");let s=r.ZERO,i=js(BigInt(e.length)),o=i>12?i-3:i>4?i-2:i?2:1,a=(1<<o)-1,c=new Array(a+1).fill(s),l=Math.floor((t.BITS-1)/o)*o,f=s;for(let u=l;u>=0;u-=o){c.fill(s);for(let m=0;m<n.length;m++){let x=n[m],y=Number(x>>BigInt(u)&BigInt(a));c[y]=c[y].add(e[m])}let d=s;for(let m=c.length-1,x=s;m>0;m--)x=x.add(c[m]),d=d.add(x);if(f=f.add(d),u!==0)for(let m=0;m<o;m++)f=f.double()}return f}function wr(r){return Xs(r.Fp),Ft(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...Qs(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Dt=BigInt(0),Et=BigInt(1),un=BigInt(2),Xl=BigInt(8),Ql={zip215:!0};function tf(r){let t=wr(r);return Ft(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function oa(r){let t=tf(r),{Fp:e,n,prehash:s,hash:i,randomBytes:o,nByteLength:a,h:c}=t,l=un<<BigInt(a*8)-Et,f=e.create,u=me(t.n,t.nBitLength),d=t.uvRatio||((b,p)=>{try{return{isValid:!0,value:e.sqrt(b*e.inv(p))}}catch{return{isValid:!1,value:Dt}}}),m=t.adjustScalarBytes||(b=>b),x=t.domain||((b,p,v)=>{if(_t("phflag",v),p.length||v)throw new Error("Contexts/pre-hash are not supported");return b});function y(b,p){vt("coordinate "+b,p,Dt,l)}function h(b){if(!(b instanceof g))throw new Error("ExtendedPoint expected")}let w=Te((b,p)=>{let{ex:v,ey:A,ez:R}=b,_=b.is0();p==null&&(p=_?Xl:e.inv(R));let V=f(v*p),P=f(A*p),D=f(R*p);if(_)return{x:Dt,y:Et};if(D!==Et)throw new Error("invZ was invalid");return{x:V,y:P}}),E=Te(b=>{let{a:p,d:v}=t;if(b.is0())throw new Error("bad point: ZERO");let{ex:A,ey:R,ez:_,et:V}=b,P=f(A*A),D=f(R*R),q=f(_*_),$=f(q*q),st=f(P*p),it=f(q*f(st+D)),at=f($+f(v*f(P*D)));if(it!==at)throw new Error("bad point: equation left != right (1)");let lt=f(A*R),xt=f(_*V);if(lt!==xt)throw new Error("bad point: equation left != right (2)");return!0});class g{constructor(p,v,A,R){this.ex=p,this.ey=v,this.ez=A,this.et=R,y("x",p),y("y",v),y("z",A),y("t",R),Object.freeze(this)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(p){if(p instanceof g)throw new Error("extended point not allowed");let{x:v,y:A}=p||{};return y("x",v),y("y",A),new g(v,A,Et,f(v*A))}static normalizeZ(p){let v=e.invertBatch(p.map(A=>A.ez));return p.map((A,R)=>A.toAffine(v[R])).map(g.fromAffine)}static msm(p,v){return cn(g,u,p,v)}_setWindowSize(p){L.setWindowSize(this,p)}assertValidity(){E(this)}equals(p){h(p);let{ex:v,ey:A,ez:R}=this,{ex:_,ey:V,ez:P}=p,D=f(v*P),q=f(_*R),$=f(A*P),st=f(V*R);return D===q&&$===st}is0(){return this.equals(g.ZERO)}negate(){return new g(f(-this.ex),this.ey,this.ez,f(-this.et))}double(){let{a:p}=t,{ex:v,ey:A,ez:R}=this,_=f(v*v),V=f(A*A),P=f(un*f(R*R)),D=f(p*_),q=v+A,$=f(f(q*q)-_-V),st=D+V,it=st-P,at=D-V,lt=f($*it),xt=f(st*at),mt=f($*at),Pt=f(it*st);return new g(lt,xt,Pt,mt)}add(p){h(p);let{a:v,d:A}=t,{ex:R,ey:_,ez:V,et:P}=this,{ex:D,ey:q,ez:$,et:st}=p;if(v===BigInt(-1)){let po=f((_-R)*(q+D)),go=f((_+R)*(q-D)),Us=f(go-po);if(Us===Dt)return this.double();let mo=f(V*un*st),bo=f(P*un*$),yo=bo+mo,wo=go+po,xo=bo-mo,lu=f(yo*Us),fu=f(wo*xo),hu=f(yo*xo),du=f(Us*wo);return new g(lu,fu,du,hu)}let it=f(R*D),at=f(_*q),lt=f(P*A*st),xt=f(V*$),mt=f((R+_)*(D+q)-it-at),Pt=xt-lt,Gt=xt+lt,lr=f(at-v*it),ou=f(mt*Pt),au=f(Gt*lr),cu=f(mt*lr),uu=f(Pt*Gt);return new g(ou,au,uu,cu)}subtract(p){return this.add(p.negate())}wNAF(p){return L.wNAFCached(this,p,g.normalizeZ)}multiply(p){let v=p;vt("scalar",v,Et,n);let{p:A,f:R}=this.wNAF(v);return g.normalizeZ([A,R])[0]}multiplyUnsafe(p,v=g.ZERO){let A=p;return vt("scalar",A,Dt,n),A===Dt?U:this.is0()||A===Et?this:L.wNAFCachedUnsafe(this,A,g.normalizeZ,v)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return L.unsafeLadder(this,n).is0()}toAffine(p){return w(this,p)}clearCofactor(){let{h:p}=t;return p===Et?this:this.multiplyUnsafe(p)}static fromHex(p,v=!1){let{d:A,a:R}=t,_=e.BYTES;p=j("pointHex",p,_),_t("zip215",v);let V=p.slice(),P=p[_-1];V[_-1]=P&-129;let D=pe(V),q=v?l:e.ORDER;vt("pointHex.y",D,Dt,q);let $=f(D*D),st=f($-Et),it=f(A*$-R),{isValid:at,value:lt}=d(st,it);if(!at)throw new Error("Point.fromHex: invalid y coordinate");let xt=(lt&Et)===Et,mt=(P&128)!==0;if(!v&&lt===Dt&&mt)throw new Error("Point.fromHex: x=0 and x_0=1");return mt!==xt&&(lt=f(-lt)),g.fromAffine({x:lt,y:D})}static fromPrivateKey(p){return N(p).point}toRawBytes(){let{x:p,y:v}=this.toAffine(),A=Ne(v,e.BYTES);return A[A.length-1]|=p&Et?128:0,A}toHex(){return Yt(this.toRawBytes())}}g.BASE=new g(t.Gx,t.Gy,Et,f(t.Gx*t.Gy)),g.ZERO=new g(Dt,Et,Et,Dt);let{BASE:k,ZERO:U}=g,L=an(g,a*8);function I(b){return z(b,n)}function C(b){return I(pe(b))}function N(b){let p=e.BYTES;b=j("private key",b,p);let v=j("hashed private key",i(b),2*p),A=m(v.slice(0,p)),R=v.slice(p,2*p),_=C(A),V=k.multiply(_),P=V.toRawBytes();return{head:A,prefix:R,scalar:_,point:V,pointBytes:P}}function G(b){return N(b).pointBytes}function F(b=new Uint8Array,...p){let v=Xt(...p);return C(i(x(v,j("context",b),!!s)))}function H(b,p,v={}){b=j("message",b),s&&(b=s(b));let{prefix:A,scalar:R,pointBytes:_}=N(p),V=F(v.context,A,b),P=k.multiply(V).toRawBytes(),D=F(v.context,P,_,b),q=I(V+D*R);vt("signature.s",q,Dt,n);let $=Xt(P,Ne(q,e.BYTES));return j("result",$,e.BYTES*2)}let tt=Ql;function B(b,p,v,A=tt){let{context:R,zip215:_}=A,V=e.BYTES;b=j("signature",b,2*V),p=j("message",p),v=j("publicKey",v,V),_!==void 0&&_t("zip215",_),s&&(p=s(p));let P=pe(b.slice(V,2*V)),D,q,$;try{D=g.fromHex(v,_),q=g.fromHex(b.slice(0,V),_),$=k.multiplyUnsafe(P)}catch{return!1}if(!_&&D.isSmallOrder())return!1;let st=F(R,q.toRawBytes(),D.toRawBytes(),p);return q.add(D.multiplyUnsafe(st)).subtract($).clearCofactor().equals(g.ZERO)}return k._setWindowSize(8),{CURVE:t,getPublicKey:G,sign:H,verify:B,ExtendedPoint:g,utils:{getExtendedPublicKey:N,randomPrivateKey:()=>o(e.BYTES),precompute(b=8,p=g.BASE){return p._setWindowSize(b),p.multiply(BigInt(3)),p}}}}var ii=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),aa=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),Xd=BigInt(0),ef=BigInt(1),ca=BigInt(2),Qd=BigInt(3),rf=BigInt(5),nf=BigInt(8);function sf(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),s=BigInt(80),i=ii,a=r*r%i*r%i,c=W(a,ca,i)*a%i,l=W(c,ef,i)*r%i,f=W(l,rf,i)*l%i,u=W(f,t,i)*f%i,d=W(u,e,i)*u%i,m=W(d,n,i)*d%i,x=W(m,s,i)*m%i,y=W(x,s,i)*m%i,h=W(y,t,i)*f%i;return{pow_p_5_8:W(h,ca,i)*r%i,b2:a}}function of(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function af(r,t){let e=ii,n=z(t*t*t,e),s=z(n*n*t,e),i=sf(r*s).pow_p_5_8,o=z(r*n*i,e),a=z(t*o*o,e),c=o,l=z(o*aa,e),f=a===r,u=a===z(-r,e),d=a===z(-r*aa,e);return f&&(o=c),(u||d)&&(o=l),ta(o,e)&&(o=z(-o,e)),{isValid:f||u,value:o}}var cf=me(ii,void 0,!0),uf={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:cf,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:nf,Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:jo,randomBytes:Je,adjustScalarBytes:of,uvRatio:af},ua=oa(uf);var ln=32;function la(r,t,e){return ua.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}var fn=class{type="Ed25519";raw;constructor(t){this.raw=oi(t,ln)}toMultihash(){return Wt.digest(Ue(this))}toCID(){return It.createV1(114,this.toMultihash())}toString(){return Q.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:Tt(this.raw,t.raw)}verify(t,e){return la(this.raw,e,t)}};function ai(r){return r=oi(r,ln),new fn(r)}function oi(r,t){if(r=Uint8Array.from(r??[]),r.length!==t)throw new et(`Key must be a Uint8Array of length ${t}, got ${r.length}`);return r}function Qt(r=0){return new Uint8Array(r)}function ft(r=0){return new Uint8Array(r)}var ff=Math.pow(2,7),hf=Math.pow(2,14),df=Math.pow(2,21),ci=Math.pow(2,28),ui=Math.pow(2,35),li=Math.pow(2,42),fi=Math.pow(2,49),K=128,ht=127;function Mt(r){if(r<ff)return 1;if(r<hf)return 2;if(r<df)return 3;if(r<ci)return 4;if(r<ui)return 5;if(r<li)return 6;if(r<fi)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function hi(r,t,e=0){switch(Mt(r)){case 8:t[e++]=r&255|K,r/=128;case 7:t[e++]=r&255|K,r/=128;case 6:t[e++]=r&255|K,r/=128;case 5:t[e++]=r&255|K,r/=128;case 4:t[e++]=r&255|K,r>>>=7;case 3:t[e++]=r&255|K,r>>>=7;case 2:t[e++]=r&255|K,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function pf(r,t,e=0){switch(Mt(r)){case 8:t.set(e++,r&255|K),r/=128;case 7:t.set(e++,r&255|K),r/=128;case 6:t.set(e++,r&255|K),r/=128;case 5:t.set(e++,r&255|K),r/=128;case 4:t.set(e++,r&255|K),r>>>=7;case 3:t.set(e++,r&255|K),r>>>=7;case 2:t.set(e++,r&255|K),r>>>=7;case 1:{t.set(e++,r&255),r>>>=7;break}default:throw new Error("unreachable")}return t}function di(r,t){let e=r[t],n=0;if(n+=e&ht,e<K||(e=r[t+1],n+=(e&ht)<<7,e<K)||(e=r[t+2],n+=(e&ht)<<14,e<K)||(e=r[t+3],n+=(e&ht)<<21,e<K)||(e=r[t+4],n+=(e&ht)*ci,e<K)||(e=r[t+5],n+=(e&ht)*ui,e<K)||(e=r[t+6],n+=(e&ht)*li,e<K)||(e=r[t+7],n+=(e&ht)*fi,e<K))return n;throw new RangeError("Could not decode varint")}function gf(r,t){let e=r.get(t),n=0;if(n+=e&ht,e<K||(e=r.get(t+1),n+=(e&ht)<<7,e<K)||(e=r.get(t+2),n+=(e&ht)<<14,e<K)||(e=r.get(t+3),n+=(e&ht)<<21,e<K)||(e=r.get(t+4),n+=(e&ht)*ci,e<K)||(e=r.get(t+5),n+=(e&ht)*ui,e<K)||(e=r.get(t+6),n+=(e&ht)*li,e<K)||(e=r.get(t+7),n+=(e&ht)*fi,e<K))return n;throw new RangeError("Could not decode varint")}function ha(r,t,e=0){return t==null&&(t=ft(Mt(r))),t instanceof Uint8Array?hi(r,t,e):pf(r,t,e)}function da(r,t=0){return r instanceof Uint8Array?di(r,t):gf(r,t)}var pi=new Float32Array([-0]),be=new Uint8Array(pi.buffer);function ga(r,t,e){pi[0]=r,t[e]=be[0],t[e+1]=be[1],t[e+2]=be[2],t[e+3]=be[3]}function ma(r,t){return be[0]=r[t],be[1]=r[t+1],be[2]=r[t+2],be[3]=r[t+3],pi[0]}var gi=new Float64Array([-0]),dt=new Uint8Array(gi.buffer);function ba(r,t,e){gi[0]=r,t[e]=dt[0],t[e+1]=dt[1],t[e+2]=dt[2],t[e+3]=dt[3],t[e+4]=dt[4],t[e+5]=dt[5],t[e+6]=dt[6],t[e+7]=dt[7]}function ya(r,t){return dt[0]=r[t],dt[1]=r[t+1],dt[2]=r[t+2],dt[3]=r[t+3],dt[4]=r[t+4],dt[5]=r[t+5],dt[6]=r[t+6],dt[7]=r[t+7],gi[0]}var mf=BigInt(Number.MAX_SAFE_INTEGER),bf=BigInt(Number.MIN_SAFE_INTEGER),Nt=class r{lo;hi;constructor(t,e){this.lo=t|0,this.hi=e|0}toNumber(t=!1){if(!t&&this.hi>>>31>0){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(e+n*4294967296)}return this.lo+this.hi*4294967296}toBigInt(t=!1){if(t)return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n);if(this.hi>>>31){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(BigInt(e)+(BigInt(n)<<32n))}return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n)}toString(t=!1){return this.toBigInt(t).toString()}zzEncode(){let t=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^t)>>>0,this.lo=(this.lo<<1^t)>>>0,this}zzDecode(){let t=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^t)>>>0,this.hi=(this.hi>>>1^t)>>>0,this}length(){let t=this.lo,e=(this.lo>>>28|this.hi<<4)>>>0,n=this.hi>>>24;return n===0?e===0?t<16384?t<128?1:2:t<2097152?3:4:e<16384?e<128?5:6:e<2097152?7:8:n<128?9:10}static fromBigInt(t){if(t===0n)return Le;if(t<mf&&t>bf)return this.fromNumber(Number(t));let e=t<0n;e&&(t=-t);let n=t>>32n,s=t-(n<<32n);return e&&(n=~n|0n,s=~s|0n,++s>wa&&(s=0n,++n>wa&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(t){if(t===0)return Le;let e=t<0;e&&(t=-t);let n=t>>>0,s=(t-n)/4294967296>>>0;return e&&(s=~s>>>0,n=~n>>>0,++n>4294967295&&(n=0,++s>4294967295&&(s=0))),new r(n,s)}static from(t){return typeof t=="number"?r.fromNumber(t):typeof t=="bigint"?r.fromBigInt(t):typeof t=="string"?r.fromBigInt(BigInt(t)):t.low!=null||t.high!=null?new r(t.low>>>0,t.high>>>0):Le}},Le=new Nt(0,0);Le.toBigInt=function(){return 0n};Le.zzEncode=Le.zzDecode=function(){return this};Le.length=function(){return 1};var wa=4294967296n;function xa(r){let t=0,e=0;for(let n=0;n<r.length;++n)e=r.charCodeAt(n),e<128?t+=1:e<2048?t+=2:(e&64512)===55296&&(r.charCodeAt(n+1)&64512)===56320?(++n,t+=4):t+=3;return t}function va(r,t,e){if(e-t<1)return"";let s,i=[],o=0,a;for(;t<e;)a=r[t++],a<128?i[o++]=a:a>191&&a<224?i[o++]=(a&31)<<6|r[t++]&63:a>239&&a<365?(a=((a&7)<<18|(r[t++]&63)<<12|(r[t++]&63)<<6|r[t++]&63)-65536,i[o++]=55296+(a>>10),i[o++]=56320+(a&1023)):i[o++]=(a&15)<<12|(r[t++]&63)<<6|r[t++]&63,o>8191&&((s??(s=[])).push(String.fromCharCode.apply(String,i)),o=0);return s!=null?(o>0&&s.push(String.fromCharCode.apply(String,i.slice(0,o))),s.join("")):String.fromCharCode.apply(String,i.slice(0,o))}function mi(r,t,e){let n=e,s,i;for(let o=0;o<r.length;++o)s=r.charCodeAt(o),s<128?t[e++]=s:s<2048?(t[e++]=s>>6|192,t[e++]=s&63|128):(s&64512)===55296&&((i=r.charCodeAt(o+1))&64512)===56320?(s=65536+((s&1023)<<10)+(i&1023),++o,t[e++]=s>>18|240,t[e++]=s>>12&63|128,t[e++]=s>>6&63|128,t[e++]=s&63|128):(t[e++]=s>>12|224,t[e++]=s>>6&63|128,t[e++]=s&63|128);return e-n}function Vt(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function hn(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var bi=class{buf;pos;len;_slice=Uint8Array.prototype.subarray;constructor(t){this.buf=t,this.pos=0,this.len=t.length}uint32(){let t=4294967295;if(t=(this.buf[this.pos]&127)>>>0,this.buf[this.pos++]<128||(t=(t|(this.buf[this.pos]&127)<<7)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<14)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<21)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&15)<<28)>>>0,this.buf[this.pos++]<128))return t;if((this.pos+=5)>this.len)throw this.pos=this.len,Vt(this,10);return t}int32(){return this.uint32()|0}sint32(){let t=this.uint32();return t>>>1^-(t&1)|0}bool(){return this.uint32()!==0}fixed32(){if(this.pos+4>this.len)throw Vt(this,4);return hn(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Vt(this,4);return hn(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Vt(this,4);let t=ma(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Vt(this,4);let t=ya(this.buf,this.pos);return this.pos+=8,t}bytes(){let t=this.uint32(),e=this.pos,n=this.pos+t;if(n>this.len)throw Vt(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return va(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw Vt(this,t);this.pos+=t}else do if(this.pos>=this.len)throw Vt(this);while(this.buf[this.pos++]&128);return this}skipType(t){switch(t){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;(t=this.uint32()&7)!==4;)this.skipType(t);break;case 5:this.skip(4);break;default:throw Error(`invalid wire type ${t} at offset ${this.pos}`)}return this}readLongVarint(){let t=new Nt(0,0),e=0;if(this.len-this.pos>4){for(;e<4;++e)if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t;if(t.lo=(t.lo|(this.buf[this.pos]&127)<<28)>>>0,t.hi=(t.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return t;e=0}else{for(;e<3;++e){if(this.pos>=this.len)throw Vt(this);if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t}return t.lo=(t.lo|(this.buf[this.pos++]&127)<<e*7)>>>0,t}if(this.len-this.pos>4){for(;e<5;++e)if(t.hi=(t.hi|(this.buf[this.pos]&127)<<e*7+3)>>>0,this.buf[this.pos++]<128)return t}else for(;e<5;++e){if(this.pos>=this.len)throw Vt(this);if(t.hi=(t.hi|(this.buf[this.pos]&127)<<e*7+3)>>>0,this.buf[this.pos++]<128)return t}throw Error("invalid varint encoding")}readFixed64(){if(this.pos+8>this.len)throw Vt(this,8);let t=hn(this.buf,this.pos+=4),e=hn(this.buf,this.pos+=4);return new Nt(t,e)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){let t=di(this.buf,this.pos);return this.pos+=Mt(t),t}uint64String(){return this.readLongVarint().toString(!0)}sint64(){return this.readLongVarint().zzDecode().toBigInt()}sint64Number(){return this.readLongVarint().zzDecode().toNumber()}sint64String(){return this.readLongVarint().zzDecode().toString()}fixed64(){return this.readFixed64().toBigInt()}fixed64Number(){return this.readFixed64().toNumber()}fixed64String(){return this.readFixed64().toString()}sfixed64(){return this.readFixed64().toBigInt()}sfixed64Number(){return this.readFixed64().toNumber()}sfixed64String(){return this.readFixed64().toString()}};function yi(r){return new bi(r instanceof Uint8Array?r:r.subarray())}function Bt(r,t,e){let n=yi(r);return t.decode(n,void 0,e)}var wi={};bt(wi,{base10:()=>yf});var yf=ce({prefix:"9",name:"base10",alphabet:"0123456789"});var xi={};bt(xi,{base16:()=>wf,base16upper:()=>xf});var wf=J({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),xf=J({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var vi={};bt(vi,{base2:()=>vf});var vf=J({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Ei={};bt(Ei,{base256emoji:()=>kf});var Ba=Array.from("\u{1F680}\u{1FA90}\u2604\u{1F6F0}\u{1F30C}\u{1F311}\u{1F312}\u{1F313}\u{1F314}\u{1F315}\u{1F316}\u{1F317}\u{1F318}\u{1F30D}\u{1F30F}\u{1F30E}\u{1F409}\u2600\u{1F4BB}\u{1F5A5}\u{1F4BE}\u{1F4BF}\u{1F602}\u2764\u{1F60D}\u{1F923}\u{1F60A}\u{1F64F}\u{1F495}\u{1F62D}\u{1F618}\u{1F44D}\u{1F605}\u{1F44F}\u{1F601}\u{1F525}\u{1F970}\u{1F494}\u{1F496}\u{1F499}\u{1F622}\u{1F914}\u{1F606}\u{1F644}\u{1F4AA}\u{1F609}\u263A\u{1F44C}\u{1F917}\u{1F49C}\u{1F614}\u{1F60E}\u{1F607}\u{1F339}\u{1F926}\u{1F389}\u{1F49E}\u270C\u2728\u{1F937}\u{1F631}\u{1F60C}\u{1F338}\u{1F64C}\u{1F60B}\u{1F497}\u{1F49A}\u{1F60F}\u{1F49B}\u{1F642}\u{1F493}\u{1F929}\u{1F604}\u{1F600}\u{1F5A4}\u{1F603}\u{1F4AF}\u{1F648}\u{1F447}\u{1F3B6}\u{1F612}\u{1F92D}\u2763\u{1F61C}\u{1F48B}\u{1F440}\u{1F62A}\u{1F611}\u{1F4A5}\u{1F64B}\u{1F61E}\u{1F629}\u{1F621}\u{1F92A}\u{1F44A}\u{1F973}\u{1F625}\u{1F924}\u{1F449}\u{1F483}\u{1F633}\u270B\u{1F61A}\u{1F61D}\u{1F634}\u{1F31F}\u{1F62C}\u{1F643}\u{1F340}\u{1F337}\u{1F63B}\u{1F613}\u2B50\u2705\u{1F97A}\u{1F308}\u{1F608}\u{1F918}\u{1F4A6}\u2714\u{1F623}\u{1F3C3}\u{1F490}\u2639\u{1F38A}\u{1F498}\u{1F620}\u261D\u{1F615}\u{1F33A}\u{1F382}\u{1F33B}\u{1F610}\u{1F595}\u{1F49D}\u{1F64A}\u{1F639}\u{1F5E3}\u{1F4AB}\u{1F480}\u{1F451}\u{1F3B5}\u{1F91E}\u{1F61B}\u{1F534}\u{1F624}\u{1F33C}\u{1F62B}\u26BD\u{1F919}\u2615\u{1F3C6}\u{1F92B}\u{1F448}\u{1F62E}\u{1F646}\u{1F37B}\u{1F343}\u{1F436}\u{1F481}\u{1F632}\u{1F33F}\u{1F9E1}\u{1F381}\u26A1\u{1F31E}\u{1F388}\u274C\u270A\u{1F44B}\u{1F630}\u{1F928}\u{1F636}\u{1F91D}\u{1F6B6}\u{1F4B0}\u{1F353}\u{1F4A2}\u{1F91F}\u{1F641}\u{1F6A8}\u{1F4A8}\u{1F92C}\u2708\u{1F380}\u{1F37A}\u{1F913}\u{1F619}\u{1F49F}\u{1F331}\u{1F616}\u{1F476}\u{1F974}\u25B6\u27A1\u2753\u{1F48E}\u{1F4B8}\u2B07\u{1F628}\u{1F31A}\u{1F98B}\u{1F637}\u{1F57A}\u26A0\u{1F645}\u{1F61F}\u{1F635}\u{1F44E}\u{1F932}\u{1F920}\u{1F927}\u{1F4CC}\u{1F535}\u{1F485}\u{1F9D0}\u{1F43E}\u{1F352}\u{1F617}\u{1F911}\u{1F30A}\u{1F92F}\u{1F437}\u260E\u{1F4A7}\u{1F62F}\u{1F486}\u{1F446}\u{1F3A4}\u{1F647}\u{1F351}\u2744\u{1F334}\u{1F4A3}\u{1F438}\u{1F48C}\u{1F4CD}\u{1F940}\u{1F922}\u{1F445}\u{1F4A1}\u{1F4A9}\u{1F450}\u{1F4F8}\u{1F47B}\u{1F910}\u{1F92E}\u{1F3BC}\u{1F975}\u{1F6A9}\u{1F34E}\u{1F34A}\u{1F47C}\u{1F48D}\u{1F4E3}\u{1F942}"),Ef=Ba.reduce((r,t,e)=>(r[e]=t,r),[]),Bf=Ba.reduce((r,t,e)=>{let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);return r[n]=e,r},[]);function Sf(r){return r.reduce((t,e)=>(t+=Ef[e],t),"")}function Af(r){let t=[];for(let e of r){let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);let s=Bf[n];if(s==null)throw new Error(`Non-base256emoji character: ${e}`);t.push(s)}return new Uint8Array(t)}var kf=qe({prefix:"\u{1F680}",name:"base256emoji",encode:Sf,decode:Af});var Bi={};bt(Bi,{base64:()=>If,base64pad:()=>Nf,base64url:()=>Tf,base64urlpad:()=>Cf});var If=J({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),Nf=J({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Tf=J({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Cf=J({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Si={};bt(Si,{base8:()=>Uf});var Uf=J({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Ai={};bt(Ai,{identity:()=>Lf});var Lf=qe({prefix:"\0",name:"identity",encode:r=>To(r),decode:r=>No(r)});var D0=new TextEncoder,M0=new TextDecoder;var Ni={};bt(Ni,{sha256:()=>Re,sha512:()=>Df});function Ii({name:r,code:t,encode:e}){return new ki(r,t,e)}var ki=class{name;code;encode;constructor(t,e,n){this.name=t,this.code=e,this.encode=n}digest(t){if(t instanceof Uint8Array){let e=this.encode(t);return e instanceof Uint8Array?Lt(this.code,e):e.then(n=>Lt(this.code,n))}else throw Error("Unknown type, must be binary type")}};function Aa(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var Re=Ii({name:"sha2-256",code:18,encode:Aa("SHA-256")}),Df=Ii({name:"sha2-512",code:19,encode:Aa("SHA-512")});var Ti={...Ai,...vi,...Si,...wi,...xi,...Hs,...Os,...Vs,...Bi,...Ei},W0={...Ni,...Ks};function Ia(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var ka=Ia("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),Ci=Ia("ascii","a",r=>{let t="a";for(let e=0;e<r.length;e++)t+=String.fromCharCode(r[e]);return t},r=>{r=r.substring(1);let t=ft(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),Mf={utf8:ka,"utf-8":ka,hex:Ti.base16,latin1:Ci,ascii:Ci,binary:Ci,...Ti},dn=Mf;function Y(r,t="utf8"){let e=dn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function Ui(r){let t=r??8192,e=t>>>1,n,s=t;return function(o){if(o<1||o>e)return ft(o);s+o>t&&(n=ft(t),s=0);let a=n.subarray(s,s+=o);return s&7&&(s=(s|7)+1),a}}var _e=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function Li(){}var _i=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},Vf=Ui();function Hf(r){return globalThis.Buffer!=null?ft(r):Vf(r)}var vr=class{len;head;tail;states;constructor(){this.len=0,this.head=new _e(Li,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new _e(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new Di((t=t>>>0)<128?1:t<16384?2:t<2097152?3:t<268435456?4:5,t)).len,this}int32(t){return t<0?this._push(pn,10,Nt.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=Nt.fromBigInt(t);return this._push(pn,e.length(),e)}uint64Number(t){return this._push(hi,Mt(t),t)}uint64String(t){return this.uint64(BigInt(t))}int64(t){return this.uint64(t)}int64Number(t){return this.uint64Number(t)}int64String(t){return this.uint64String(t)}sint64(t){let e=Nt.fromBigInt(t).zzEncode();return this._push(pn,e.length(),e)}sint64Number(t){let e=Nt.fromNumber(t).zzEncode();return this._push(pn,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(Ri,1,t?1:0)}fixed32(t){return this._push(xr,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=Nt.fromBigInt(t);return this._push(xr,4,e.lo)._push(xr,4,e.hi)}fixed64Number(t){let e=Nt.fromNumber(t);return this._push(xr,4,e.lo)._push(xr,4,e.hi)}fixed64String(t){return this.fixed64(BigInt(t))}sfixed64(t){return this.fixed64(t)}sfixed64Number(t){return this.fixed64Number(t)}sfixed64String(t){return this.fixed64String(t)}float(t){return this._push(ga,4,t)}double(t){return this._push(ba,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(Ri,1,0):this.uint32(e)._push(Pf,e,t)}string(t){let e=xa(t);return e!==0?this.uint32(e)._push(mi,e,t):this._push(Ri,1,0)}fork(){return this.states=new _i(this),this.head=this.tail=new _e(Li,0,0),this.len=0,this}reset(){return this.states!=null?(this.head=this.states.head,this.tail=this.states.tail,this.len=this.states.len,this.states=this.states.next):(this.head=this.tail=new _e(Li,0,0),this.len=0),this}ldelim(){let t=this.head,e=this.tail,n=this.len;return this.reset().uint32(n),n!==0&&(this.tail.next=t.next,this.tail=e,this.len+=n),this}finish(){let t=this.head.next,e=Hf(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function Ri(r,t,e){t[e]=r&255}function Of(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var Di=class extends _e{next;constructor(t,e){super(Of,t,e),this.next=void 0}};function pn(r,t,e){for(;r.hi!==0;)t[e++]=r.lo&127|128,r.lo=(r.lo>>>7|r.hi<<25)>>>0,r.hi>>>=7;for(;r.lo>127;)t[e++]=r.lo&127|128,r.lo=r.lo>>>7;t[e++]=r.lo}function xr(r,t,e){t[e]=r&255,t[e+1]=r>>>8&255,t[e+2]=r>>>16&255,t[e+3]=r>>>24}function Pf(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(vr.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(Ff,t,r),this},vr.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(Kf,t,r),this});function Ff(r,t,e){t.set(r,e)}function Kf(r,t,e){r.length<40?mi(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(Y(r),e)}function Mi(){return new vr}function St(r,t){let e=Mi();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var tr;(function(r){r[r.VARINT=0]="VARINT",r[r.BIT64=1]="BIT64",r[r.LENGTH_DELIMITED=2]="LENGTH_DELIMITED",r[r.START_GROUP=3]="START_GROUP",r[r.END_GROUP=4]="END_GROUP",r[r.BIT32=5]="BIT32"})(tr||(tr={}));function gn(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function Vi(r){function t(s){if(r[s.toString()]==null)throw new Error("Invalid enum value");return r[s]}let e=function(i,o){let a=t(i);o.int32(a)},n=function(i){let o=i.int32();return t(o)};return gn("enum",tr.VARINT,e,n)}function At(r,t){return gn("message",tr.LENGTH_DELIMITED,r,t)}var Ct=class extends Error{code="ERR_MAX_LENGTH";name="MaxLengthError"};var nt;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.secp256k1="secp256k1"})(nt||(nt={}));var Hi;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1"})(Hi||(Hi={}));(function(r){r.codec=()=>Vi(Hi)})(nt||(nt={}));var Kt;(function(r){let t;r.codec=()=>(t==null&&(t=At((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),nt.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let i={},o=n==null?e.len:e.pos+n;for(;e.pos<o;){let a=e.uint32();switch(a>>>3){case 1:{i.Type=nt.codec().decode(e);break}case 2:{i.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return i})),t),r.encode=e=>St(e,r.codec()),r.decode=(e,n)=>Bt(e,r.codec(),n)})(Kt||(Kt={}));var Oi;(function(r){let t;r.codec=()=>(t==null&&(t=At((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),nt.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let i={},o=n==null?e.len:e.pos+n;for(;e.pos<o;){let a=e.uint32();switch(a>>>3){case 1:{i.Type=nt.codec().decode(e);break}case 2:{i.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return i})),t),r.encode=e=>St(e,r.codec()),r.decode=(e,n)=>Bt(e,r.codec(),n)})(Oi||(Oi={}));var Ur={};bt(Ur,{MAX_RSA_KEY_SIZE:()=>as,generateRSAKeyPair:()=>Sc,jwkToJWKKeyPair:()=>Ac,jwkToPkcs1:()=>sh,jwkToPkix:()=>Wi,jwkToRSAPrivateKey:()=>Bc,pkcs1ToJwk:()=>xc,pkcs1ToRSAPrivateKey:()=>Ec,pkixToJwk:()=>vc,pkixToRSAPublicKey:()=>ji});var qf=new Uint32Array([1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298]),ye=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),we=new Uint32Array(64),Pi=class extends Xe{constructor(){super(64,32,8,!1),this.A=ye[0]|0,this.B=ye[1]|0,this.C=ye[2]|0,this.D=ye[3]|0,this.E=ye[4]|0,this.F=ye[5]|0,this.G=ye[6]|0,this.H=ye[7]|0}get(){let{A:t,B:e,C:n,D:s,E:i,F:o,G:a,H:c}=this;return[t,e,n,s,i,o,a,c]}set(t,e,n,s,i,o,a,c){this.A=t|0,this.B=e|0,this.C=n|0,this.D=s|0,this.E=i|0,this.F=o|0,this.G=a|0,this.H=c|0}process(t,e){for(let u=0;u<16;u++,e+=4)we[u]=t.getUint32(e,!1);for(let u=16;u<64;u++){let d=we[u-15],m=we[u-2],x=Rt(d,7)^Rt(d,18)^d>>>3,y=Rt(m,17)^Rt(m,19)^m>>>10;we[u]=y+we[u-7]+x+we[u-16]|0}let{A:n,B:s,C:i,D:o,E:a,F:c,G:l,H:f}=this;for(let u=0;u<64;u++){let d=Rt(a,6)^Rt(a,11)^Rt(a,25),m=f+d+Go(a,c,l)+qf[u]+we[u]|0,y=(Rt(n,2)^Rt(n,13)^Rt(n,22))+Zo(n,s,i)|0;f=l,l=c,c=a,a=o+m|0,o=i,i=s,s=n,n=m+y|0}n=n+this.A|0,s=s+this.B|0,i=i+this.C|0,o=o+this.D|0,a=a+this.E|0,c=c+this.F|0,l=l+this.G|0,f=f+this.H|0,this.set(n,s,i,o,a,c,l,f)}roundClean(){we.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var er=Qr(()=>new Pi);var O=Bo(Ta());function De(r,t){let e=0;if(r.length===1)return r[0];for(let n=r.length-1;n>=0;n--)e+=r[r.length-1-n]*Math.pow(2,t*n);return e}function xe(r,t,e=-1){let n=e,s=r,i=0,o=Math.pow(2,t);for(let a=1;a<8;a++){if(r<o){let c;if(n<0)c=new ArrayBuffer(a),i=a;else{if(n<a)return new ArrayBuffer(0);c=new ArrayBuffer(n),i=n}let l=new Uint8Array(c);for(let f=a-1;f>=0;f--){let u=Math.pow(2,f*t);l[i-f-1]=Math.floor(s/u),s-=l[i-f-1]*u}return c}o*=Math.pow(2,t)}return new ArrayBuffer(0)}function yn(...r){let t=0,e=0;for(let i of r)t+=i.length;let n=new ArrayBuffer(t),s=new Uint8Array(n);for(let i of r)s.set(i,e),e+=i.length;return s}function Ki(){let r=new Uint8Array(this.valueHex);if(this.valueHex.byteLength>=2){let a=r[0]===255&&r[1]&128,c=r[0]===0&&(r[1]&128)===0;(a||c)&&this.warnings.push("Needlessly long format")}let t=new ArrayBuffer(this.valueHex.byteLength),e=new Uint8Array(t);for(let a=0;a<this.valueHex.byteLength;a++)e[a]=0;e[0]=r[0]&128;let n=De(e,8),s=new ArrayBuffer(this.valueHex.byteLength),i=new Uint8Array(s);for(let a=0;a<this.valueHex.byteLength;a++)i[a]=r[a];return i[0]&=127,De(i,8)-n}function Ca(r){let t=r<0?r*-1:r,e=128;for(let n=1;n<8;n++){if(t<=e){if(r<0){let o=e-t,a=xe(o,8,n),c=new Uint8Array(a);return c[0]|=128,a}let s=xe(t,8,n),i=new Uint8Array(s);if(i[0]&128){let o=s.slice(0),a=new Uint8Array(o);s=new ArrayBuffer(s.byteLength+1),i=new Uint8Array(s);for(let c=0;c<o.byteLength;c++)i[c+1]=a[c];i[0]=0}return s}e*=Math.pow(2,8)}return new ArrayBuffer(0)}function Ua(r,t){if(r.byteLength!==t.byteLength)return!1;let e=new Uint8Array(r),n=new Uint8Array(t);for(let s=0;s<e.length;s++)if(e[s]!==n[s])return!1;return!0}function kt(r,t){let e=r.toString(10);if(t<e.length)return"";let n=t-e.length,s=new Array(n);for(let o=0;o<n;o++)s[o]="0";return s.join("").concat(e)}var Tp=Math.log(2);function wn(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function qi(r){let t=0,e=0;for(let s=0;s<r.length;s++){let i=r[s];t+=i.byteLength}let n=new Uint8Array(t);for(let s=0;s<r.length;s++){let i=r[s];n.set(new Uint8Array(i),e),e+=i.byteLength}return n.buffer}function se(r,t,e,n){return t instanceof Uint8Array?t.byteLength?e<0?(r.error="Wrong parameter: inputOffset less than zero",!1):n<0?(r.error="Wrong parameter: inputLength less than zero",!1):t.byteLength-e-n<0?(r.error="End of input reached before message was fully decoded (inconsistent offset and length values)",!1):!0:(r.error="Wrong parameter: inputBuffer has zero length",!1):(r.error="Wrong parameter: inputBuffer must be 'Uint8Array'",!1)}var Br=class{constructor(){this.items=[]}write(t){this.items.push(t)}final(){return qi(this.items)}},Er=[new Uint8Array([1])],La="0123456789";var or="",Ht=new ArrayBuffer(0),zi=new Uint8Array(0),Sr="EndOfContent",_a="OCTET STRING",Da="BIT STRING";function ie(r){var t;return t=class extends r{constructor(...n){var s;super(...n);let i=n[0]||{};this.isHexOnly=(s=i.isHexOnly)!==null&&s!==void 0?s:!1,this.valueHexView=i.valueHex?O.BufferSourceConverter.toUint8Array(i.valueHex):zi}get valueHex(){return this.valueHexView.slice().buffer}set valueHex(n){this.valueHexView=new Uint8Array(n)}fromBER(n,s,i){let o=n instanceof ArrayBuffer?new Uint8Array(n):n;if(!se(this,o,s,i))return-1;let a=s+i;return this.valueHexView=o.subarray(s,a),this.valueHexView.length?(this.blockLength=i,a):(this.warnings.push("Zero buffer length"),s)}toBER(n=!1){return this.isHexOnly?n?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.byteLength===this.valueHexView.buffer.byteLength?this.valueHexView.buffer:this.valueHexView.slice().buffer:(this.error="Flag 'isHexOnly' is not set, abort",Ht)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:O.Convert.ToHex(this.valueHexView)}}},t.NAME="hexBlock",t}var ee=class{constructor({blockLength:t=0,error:e=or,warnings:n=[],valueBeforeDecode:s=zi}={}){this.blockLength=t,this.error=e,this.warnings=n,this.valueBeforeDecodeView=O.BufferSourceConverter.toUint8Array(s)}static blockName(){return this.NAME}get valueBeforeDecode(){return this.valueBeforeDecodeView.slice().buffer}set valueBeforeDecode(t){this.valueBeforeDecodeView=new Uint8Array(t)}toJSON(){return{blockName:this.constructor.NAME,blockLength:this.blockLength,error:this.error,warnings:this.warnings,valueBeforeDecode:O.Convert.ToHex(this.valueBeforeDecodeView)}}};ee.NAME="baseBlock";var pt=class extends ee{fromBER(t,e,n){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}toBER(t,e){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}};pt.NAME="valueBlock";var xn=class extends ie(ee){constructor({idBlock:t={}}={}){var e,n,s,i;super(),t?(this.isHexOnly=(e=t.isHexOnly)!==null&&e!==void 0?e:!1,this.valueHexView=t.valueHex?O.BufferSourceConverter.toUint8Array(t.valueHex):zi,this.tagClass=(n=t.tagClass)!==null&&n!==void 0?n:-1,this.tagNumber=(s=t.tagNumber)!==null&&s!==void 0?s:-1,this.isConstructed=(i=t.isConstructed)!==null&&i!==void 0?i:!1):(this.tagClass=-1,this.tagNumber=-1,this.isConstructed=!1)}toBER(t=!1){let e=0;switch(this.tagClass){case 1:e|=0;break;case 2:e|=64;break;case 3:e|=128;break;case 4:e|=192;break;default:return this.error="Unknown tag class",Ht}if(this.isConstructed&&(e|=32),this.tagNumber<31&&!this.isHexOnly){let s=new Uint8Array(1);if(!t){let i=this.tagNumber;i&=31,e|=i,s[0]=e}return s.buffer}if(!this.isHexOnly){let s=xe(this.tagNumber,7),i=new Uint8Array(s),o=s.byteLength,a=new Uint8Array(o+1);if(a[0]=e|31,!t){for(let c=0;c<o-1;c++)a[c+1]=i[c]|128;a[o]=i[o-1]}return a.buffer}let n=new Uint8Array(this.valueHexView.byteLength+1);if(n[0]=e|31,!t){let s=this.valueHexView;for(let i=0;i<s.length-1;i++)n[i+1]=s[i]|128;n[this.valueHexView.byteLength]=s[s.length-1]}return n.buffer}fromBER(t,e,n){let s=O.BufferSourceConverter.toUint8Array(t);if(!se(this,s,e,n))return-1;let i=s.subarray(e,e+n);if(i.length===0)return this.error="Zero buffer length",-1;switch(i[0]&192){case 0:this.tagClass=1;break;case 64:this.tagClass=2;break;case 128:this.tagClass=3;break;case 192:this.tagClass=4;break;default:return this.error="Unknown tag class",-1}this.isConstructed=(i[0]&32)===32,this.isHexOnly=!1;let a=i[0]&31;if(a!==31)this.tagNumber=a,this.blockLength=1;else{let c=1,l=this.valueHexView=new Uint8Array(255),f=255;for(;i[c]&128;){if(l[c-1]=i[c]&127,c++,c>=i.length)return this.error="End of input reached before message was fully decoded",-1;if(c===f){f+=255;let d=new Uint8Array(f);for(let m=0;m<l.length;m++)d[m]=l[m];l=this.valueHexView=new Uint8Array(f)}}this.blockLength=c+1,l[c-1]=i[c]&127;let u=new Uint8Array(c);for(let d=0;d<c;d++)u[d]=l[d];l=this.valueHexView=new Uint8Array(c),l.set(u),this.blockLength<=9?this.tagNumber=De(l,7):(this.isHexOnly=!0,this.warnings.push("Tag too long, represented as hex-coded"))}if(this.tagClass===1&&this.isConstructed)switch(this.tagNumber){case 1:case 2:case 5:case 6:case 9:case 13:case 14:case 23:case 24:case 31:case 32:case 33:case 34:return this.error="Constructed encoding used for primitive type",-1}return e+this.blockLength}toJSON(){return{...super.toJSON(),tagClass:this.tagClass,tagNumber:this.tagNumber,isConstructed:this.isConstructed}}};xn.NAME="identificationBlock";var vn=class extends ee{constructor({lenBlock:t={}}={}){var e,n,s;super(),this.isIndefiniteForm=(e=t.isIndefiniteForm)!==null&&e!==void 0?e:!1,this.longFormUsed=(n=t.longFormUsed)!==null&&n!==void 0?n:!1,this.length=(s=t.length)!==null&&s!==void 0?s:0}fromBER(t,e,n){let s=O.BufferSourceConverter.toUint8Array(t);if(!se(this,s,e,n))return-1;let i=s.subarray(e,e+n);if(i.length===0)return this.error="Zero buffer length",-1;if(i[0]===255)return this.error="Length block 0xFF is reserved by standard",-1;if(this.isIndefiniteForm=i[0]===128,this.isIndefiniteForm)return this.blockLength=1,e+this.blockLength;if(this.longFormUsed=!!(i[0]&128),this.longFormUsed===!1)return this.length=i[0],this.blockLength=1,e+this.blockLength;let o=i[0]&127;if(o>8)return this.error="Too big integer",-1;if(o+1>i.length)return this.error="End of input reached before message was fully decoded",-1;let a=e+1,c=s.subarray(a,a+o);return c[o-1]===0&&this.warnings.push("Needlessly long encoded length"),this.length=De(c,8),this.longFormUsed&&this.length<=127&&this.warnings.push("Unnecessary usage of long length form"),this.blockLength=o+1,e+this.blockLength}toBER(t=!1){let e,n;if(this.length>127&&(this.longFormUsed=!0),this.isIndefiniteForm)return e=new ArrayBuffer(1),t===!1&&(n=new Uint8Array(e),n[0]=128),e;if(this.longFormUsed){let s=xe(this.length,8);if(s.byteLength>127)return this.error="Too big length",Ht;if(e=new ArrayBuffer(s.byteLength+1),t)return e;let i=new Uint8Array(s);n=new Uint8Array(e),n[0]=s.byteLength|128;for(let o=0;o<s.byteLength;o++)n[o+1]=i[o];return e}return e=new ArrayBuffer(1),t===!1&&(n=new Uint8Array(e),n[0]=this.length),e}toJSON(){return{...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,longFormUsed:this.longFormUsed,length:this.length}}};vn.NAME="lengthBlock";var S={},ct=class extends ee{constructor({name:t=or,optional:e=!1,primitiveSchema:n,...s}={},i){super(s),this.name=t,this.optional=e,n&&(this.primitiveSchema=n),this.idBlock=new xn(s),this.lenBlock=new vn(s),this.valueBlock=i?new i(s):new pt(s)}fromBER(t,e,n){let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}toBER(t,e){let n=e||new Br;e||Ma(this);let s=this.idBlock.toBER(t);if(n.write(s),this.lenBlock.isIndefiniteForm)n.write(new Uint8Array([128]).buffer),this.valueBlock.toBER(t,n),n.write(new ArrayBuffer(2));else{let i=this.valueBlock.toBER(t);this.lenBlock.length=i.byteLength;let o=this.lenBlock.toBER(t);n.write(o),n.write(i)}return e?Ht:n.final()}toJSON(){let t={...super.toJSON(),idBlock:this.idBlock.toJSON(),lenBlock:this.lenBlock.toJSON(),valueBlock:this.valueBlock.toJSON(),name:this.name,optional:this.optional};return this.primitiveSchema&&(t.primitiveSchema=this.primitiveSchema.toJSON()),t}toString(t="ascii"){return t==="ascii"?this.onAsciiEncoding():O.Convert.ToHex(this.toBER())}onAsciiEncoding(){return`${this.constructor.NAME} : ${O.Convert.ToHex(this.valueBlock.valueBeforeDecodeView)}`}isEqual(t){if(this===t)return!0;if(!(t instanceof this.constructor))return!1;let e=this.toBER(),n=t.toBER();return Ua(e,n)}};ct.NAME="BaseBlock";function Ma(r){if(r instanceof S.Constructed)for(let t of r.valueBlock.value)Ma(t)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var En=class extends ct{constructor({value:t=or,...e}={},n){super(e,n),t&&this.fromString(t)}getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}fromBER(t,e,n){let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.fromBuffer(this.valueBlock.valueHexView),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}onAsciiEncoding(){return`${this.constructor.NAME} : '${this.valueBlock.value}'`}};En.NAME="BaseStringBlock";var Bn=class extends ie(pt){constructor({isHexOnly:t=!0,...e}={}){super(e),this.isHexOnly=t}};Bn.NAME="PrimitiveValueBlock";var Va,Sn=class extends ct{constructor(t={}){super(t,Bn),this.idBlock.isConstructed=!1}};Va=Sn;S.Primitive=Va;Sn.NAME="PRIMITIVE";function Xf(r,t){if(r instanceof t)return r;let e=new t;return e.idBlock=r.idBlock,e.lenBlock=r.lenBlock,e.warnings=r.warnings,e.valueBeforeDecodeView=r.valueBeforeDecodeView,e}function ss(r,t=0,e=r.length){let n=t,s=new ct({},pt),i=new ee;if(!se(i,r,t,e))return s.error=i.error,{offset:-1,result:s};if(!r.subarray(t,t+e).length)return s.error="Zero buffer length",{offset:-1,result:s};let a=s.idBlock.fromBER(r,t,e);if(s.idBlock.warnings.length&&s.warnings.concat(s.idBlock.warnings),a===-1)return s.error=s.idBlock.error,{offset:-1,result:s};if(t=a,e-=s.idBlock.blockLength,a=s.lenBlock.fromBER(r,t,e),s.lenBlock.warnings.length&&s.warnings.concat(s.lenBlock.warnings),a===-1)return s.error=s.lenBlock.error,{offset:-1,result:s};if(t=a,e-=s.lenBlock.blockLength,!s.idBlock.isConstructed&&s.lenBlock.isIndefiniteForm)return s.error="Indefinite length form used for primitive encoding form",{offset:-1,result:s};let c=ct;switch(s.idBlock.tagClass){case 1:if(s.idBlock.tagNumber>=37&&s.idBlock.isHexOnly===!1)return s.error="UNIVERSAL 37 and upper tags are reserved by ASN.1 standard",{offset:-1,result:s};switch(s.idBlock.tagNumber){case 0:if(s.idBlock.isConstructed&&s.lenBlock.length>0)return s.error="Type [UNIVERSAL 0] is reserved",{offset:-1,result:s};c=S.EndOfContent;break;case 1:c=S.Boolean;break;case 2:c=S.Integer;break;case 3:c=S.BitString;break;case 4:c=S.OctetString;break;case 5:c=S.Null;break;case 6:c=S.ObjectIdentifier;break;case 10:c=S.Enumerated;break;case 12:c=S.Utf8String;break;case 13:c=S.RelativeObjectIdentifier;break;case 14:c=S.TIME;break;case 15:return s.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:s};case 16:c=S.Sequence;break;case 17:c=S.Set;break;case 18:c=S.NumericString;break;case 19:c=S.PrintableString;break;case 20:c=S.TeletexString;break;case 21:c=S.VideotexString;break;case 22:c=S.IA5String;break;case 23:c=S.UTCTime;break;case 24:c=S.GeneralizedTime;break;case 25:c=S.GraphicString;break;case 26:c=S.VisibleString;break;case 27:c=S.GeneralString;break;case 28:c=S.UniversalString;break;case 29:c=S.CharacterString;break;case 30:c=S.BmpString;break;case 31:c=S.DATE;break;case 32:c=S.TimeOfDay;break;case 33:c=S.DateTime;break;case 34:c=S.Duration;break;default:{let l=s.idBlock.isConstructed?new S.Constructed:new S.Primitive;l.idBlock=s.idBlock,l.lenBlock=s.lenBlock,l.warnings=s.warnings,s=l}}break;case 2:case 3:case 4:default:c=s.idBlock.isConstructed?S.Constructed:S.Primitive}return s=Xf(s,c),a=s.fromBER(r,t,s.lenBlock.isIndefiniteForm?e:s.lenBlock.length),s.valueBeforeDecodeView=r.subarray(n,n+s.blockLength),{offset:a,result:s}}function $i(r){if(!r.byteLength){let t=new ct({},pt);return t.error="Input buffer has zero length",{offset:-1,result:t}}return ss(O.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function Qf(r,t){return r?1:t}var qt=class extends pt{constructor({value:t=[],isIndefiniteForm:e=!1,...n}={}){super(n),this.value=t,this.isIndefiniteForm=e}fromBER(t,e,n){let s=O.BufferSourceConverter.toUint8Array(t);if(!se(this,s,e,n))return-1;if(this.valueBeforeDecodeView=s.subarray(e,e+n),this.valueBeforeDecodeView.length===0)return this.warnings.push("Zero buffer length"),e;let i=e;for(;Qf(this.isIndefiniteForm,n)>0;){let o=ss(s,i,n);if(o.offset===-1)return this.error=o.result.error,this.warnings.concat(o.result.warnings),-1;if(i=o.offset,this.blockLength+=o.result.blockLength,n-=o.result.blockLength,this.value.push(o.result),this.isIndefiniteForm&&o.result.constructor.NAME===Sr)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===Sr?this.value.pop():this.warnings.push("No EndOfContent block encoded")),i}toBER(t,e){let n=e||new Br;for(let s=0;s<this.value.length;s++)this.value[s].toBER(t,n);return e?Ht:n.final()}toJSON(){let t={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let e of this.value)t.value.push(e.toJSON());return t}};qt.NAME="ConstructedValueBlock";var Ha,ve=class extends ct{constructor(t={}){super(t,qt),this.idBlock.isConstructed=!0}fromBER(t,e,n){this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm;let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}onAsciiEncoding(){let t=[];for(let n of this.valueBlock.value)t.push(n.toString("ascii").split(`
2
+ "use strict";var Libp2PFloodsub=(()=>{var gu=Object.create;var Wr=Object.defineProperty;var mu=Object.getOwnPropertyDescriptor;var bu=Object.getOwnPropertyNames;var yu=Object.getPrototypeOf,wu=Object.prototype.hasOwnProperty;var vo=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),bt=(r,t)=>{for(var e in t)Wr(r,e,{get:t[e],enumerable:!0})},Eo=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of bu(t))!wu.call(r,s)&&s!==e&&Wr(r,s,{get:()=>t[s],enumerable:!(n=mu(t,s))||n.enumerable});return r};var Bo=(r,t,e)=>(e=r!=null?gu(yu(r)):{},Eo(t||!r||!r.__esModule?Wr(e,"default",{value:r,enumerable:!0}):e,r)),xu=r=>Eo(Wr({},"__esModule",{value:!0}),r);var Ca=vo(rr=>{"use strict";var $f="[object ArrayBuffer]",te=class r{static isArrayBuffer(t){return Object.prototype.toString.call(t)===$f}static toArrayBuffer(t){return this.isArrayBuffer(t)?t:t.byteLength===t.buffer.byteLength||t.byteOffset===0&&t.byteLength===t.buffer.byteLength?t.buffer:this.toUint8Array(t.buffer).slice(t.byteOffset,t.byteOffset+t.byteLength).buffer}static toUint8Array(t){return this.toView(t,Uint8Array)}static toView(t,e){if(t.constructor===e)return t;if(this.isArrayBuffer(t))return new e(t);if(this.isArrayBufferView(t))return new e(t.buffer,t.byteOffset,t.byteLength);throw new TypeError("The provided value is not of type '(ArrayBuffer or ArrayBufferView)'")}static isBufferSource(t){return this.isArrayBufferView(t)||this.isArrayBuffer(t)}static isArrayBufferView(t){return ArrayBuffer.isView(t)||t&&this.isArrayBuffer(t.buffer)}static isEqual(t,e){let n=r.toUint8Array(t),s=r.toUint8Array(e);if(n.length!==s.byteLength)return!1;for(let i=0;i<n.length;i++)if(n[i]!==s[i])return!1;return!0}static concat(...t){let e;Array.isArray(t[0])&&!(t[1]instanceof Function)||Array.isArray(t[0])&&t[1]instanceof Function?e=t[0]:t[t.length-1]instanceof Function?e=t.slice(0,t.length-1):e=t;let n=0;for(let o of e)n+=o.byteLength;let s=new Uint8Array(n),i=0;for(let o of e){let a=this.toUint8Array(o);s.set(a,i),i+=a.length}return t[t.length-1]instanceof Function?this.toView(s,t[t.length-1]):s.buffer}},Fi="string",Gf=/^[0-9a-f\s]+$/i,Zf=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,Wf=/^[a-zA-Z0-9-_]+$/,mn=class{static fromString(t){let e=unescape(encodeURIComponent(t)),n=new Uint8Array(e.length);for(let s=0;s<e.length;s++)n[s]=e.charCodeAt(s);return n.buffer}static toString(t){let e=te.toUint8Array(t),n="";for(let i=0;i<e.length;i++)n+=String.fromCharCode(e[i]);return decodeURIComponent(escape(n))}},Ut=class{static toString(t,e=!1){let n=te.toArrayBuffer(t),s=new DataView(n),i="";for(let o=0;o<n.byteLength;o+=2){let a=s.getUint16(o,e);i+=String.fromCharCode(a)}return i}static fromString(t,e=!1){let n=new ArrayBuffer(t.length*2),s=new DataView(n);for(let i=0;i<t.length;i++)s.setUint16(i*2,t.charCodeAt(i),e);return n}},bn=class r{static isHex(t){return typeof t===Fi&&Gf.test(t)}static isBase64(t){return typeof t===Fi&&Zf.test(t)}static isBase64Url(t){return typeof t===Fi&&Wf.test(t)}static ToString(t,e="utf8"){let n=te.toUint8Array(t);switch(e.toLowerCase()){case"utf8":return this.ToUtf8String(n);case"binary":return this.ToBinary(n);case"hex":return this.ToHex(n);case"base64":return this.ToBase64(n);case"base64url":return this.ToBase64Url(n);case"utf16le":return Ut.toString(n,!0);case"utf16":case"utf16be":return Ut.toString(n);default:throw new Error(`Unknown type of encoding '${e}'`)}}static FromString(t,e="utf8"){if(!t)return new ArrayBuffer(0);switch(e.toLowerCase()){case"utf8":return this.FromUtf8String(t);case"binary":return this.FromBinary(t);case"hex":return this.FromHex(t);case"base64":return this.FromBase64(t);case"base64url":return this.FromBase64Url(t);case"utf16le":return Ut.fromString(t,!0);case"utf16":case"utf16be":return Ut.fromString(t);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToBase64(t){let e=te.toUint8Array(t);if(typeof btoa<"u"){let n=this.ToString(e,"binary");return btoa(n)}else return Buffer.from(e).toString("base64")}static FromBase64(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isBase64(e))throw new TypeError("Argument 'base64Text' is not Base64 encoded");return typeof atob<"u"?this.FromBinary(atob(e)):new Uint8Array(Buffer.from(e,"base64")).buffer}static FromBase64Url(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isBase64Url(e))throw new TypeError("Argument 'base64url' is not Base64Url encoded");return this.FromBase64(this.Base64Padding(e.replace(/\-/g,"+").replace(/\_/g,"/")))}static ToBase64Url(t){return this.ToBase64(t).replace(/\+/g,"-").replace(/\//g,"_").replace(/\=/g,"")}static FromUtf8String(t,e=r.DEFAULT_UTF8_ENCODING){switch(e){case"ascii":return this.FromBinary(t);case"utf8":return mn.fromString(t);case"utf16":case"utf16be":return Ut.fromString(t);case"utf16le":case"usc2":return Ut.fromString(t,!0);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToUtf8String(t,e=r.DEFAULT_UTF8_ENCODING){switch(e){case"ascii":return this.ToBinary(t);case"utf8":return mn.toString(t);case"utf16":case"utf16be":return Ut.toString(t);case"utf16le":case"usc2":return Ut.toString(t,!0);default:throw new Error(`Unknown type of encoding '${e}'`)}}static FromBinary(t){let e=t.length,n=new Uint8Array(e);for(let s=0;s<e;s++)n[s]=t.charCodeAt(s);return n.buffer}static ToBinary(t){let e=te.toUint8Array(t),n="";for(let s=0;s<e.length;s++)n+=String.fromCharCode(e[s]);return n}static ToHex(t){let e=te.toUint8Array(t),n="",s=e.length;for(let i=0;i<s;i++){let o=e[i];o<16&&(n+="0"),n+=o.toString(16)}return n}static FromHex(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isHex(e))throw new TypeError("Argument 'hexString' is not HEX encoded");e.length%2&&(e=`0${e}`);let n=new Uint8Array(e.length/2);for(let s=0;s<e.length;s=s+2){let i=e.slice(s,s+2);n[s/2]=parseInt(i,16)}return n.buffer}static ToUtf16String(t,e=!1){return Ut.toString(t,e)}static FromUtf16String(t,e=!1){return Ut.fromString(t,e)}static Base64Padding(t){let e=4-t.length%4;if(e<4)for(let n=0;n<e;n++)t+="=";return t}static formatString(t){return t?.replace(/[\n\r\t ]/g,"")||""}};bn.DEFAULT_UTF8_ENCODING="utf8";function jf(r,...t){let e=arguments[0];for(let n=1;n<arguments.length;n++){let s=arguments[n];for(let i in s)e[i]=s[i]}return e}function Yf(...r){let t=r.map(s=>s.byteLength).reduce((s,i)=>s+i),e=new Uint8Array(t),n=0;return r.map(s=>new Uint8Array(s)).forEach(s=>{for(let i of s)e[n++]=i}),e.buffer}function Jf(r,t){if(!(r&&t)||r.byteLength!==t.byteLength)return!1;let e=new Uint8Array(r),n=new Uint8Array(t);for(let s=0;s<r.byteLength;s++)if(e[s]!==n[s])return!1;return!0}rr.BufferSourceConverter=te;rr.Convert=bn;rr.assign=jf;rr.combine=Yf;rr.isEqual=Jf});var Zc=vo((ob,io)=>{"use strict";var Bh=Object.prototype.hasOwnProperty,wt="~";function Fr(){}Object.create&&(Fr.prototype=Object.create(null),new Fr().__proto__||(wt=!1));function Sh(r,t,e){this.fn=r,this.context=t,this.once=e||!1}function Gc(r,t,e,n,s){if(typeof e!="function")throw new TypeError("The listener must be a function");var i=new Sh(e,n||r,s),o=wt?wt+t:t;return r._events[o]?r._events[o].fn?r._events[o]=[r._events[o],i]:r._events[o].push(i):(r._events[o]=i,r._eventsCount++),r}function gs(r,t){--r._eventsCount===0?r._events=new Fr:delete r._events[t]}function gt(){this._events=new Fr,this._eventsCount=0}gt.prototype.eventNames=function(){var t=[],e,n;if(this._eventsCount===0)return t;for(n in e=this._events)Bh.call(e,n)&&t.push(wt?n.slice(1):n);return Object.getOwnPropertySymbols?t.concat(Object.getOwnPropertySymbols(e)):t};gt.prototype.listeners=function(t){var e=wt?wt+t:t,n=this._events[e];if(!n)return[];if(n.fn)return[n.fn];for(var s=0,i=n.length,o=new Array(i);s<i;s++)o[s]=n[s].fn;return o};gt.prototype.listenerCount=function(t){var e=wt?wt+t:t,n=this._events[e];return n?n.fn?1:n.length:0};gt.prototype.emit=function(t,e,n,s,i,o){var a=wt?wt+t:t;if(!this._events[a])return!1;var c=this._events[a],l=arguments.length,f,u;if(c.fn){switch(c.once&&this.removeListener(t,c.fn,void 0,!0),l){case 1:return c.fn.call(c.context),!0;case 2:return c.fn.call(c.context,e),!0;case 3:return c.fn.call(c.context,e,n),!0;case 4:return c.fn.call(c.context,e,n,s),!0;case 5:return c.fn.call(c.context,e,n,s,i),!0;case 6:return c.fn.call(c.context,e,n,s,i,o),!0}for(u=1,f=new Array(l-1);u<l;u++)f[u-1]=arguments[u];c.fn.apply(c.context,f)}else{var d=c.length,m;for(u=0;u<d;u++)switch(c[u].once&&this.removeListener(t,c[u].fn,void 0,!0),l){case 1:c[u].fn.call(c[u].context);break;case 2:c[u].fn.call(c[u].context,e);break;case 3:c[u].fn.call(c[u].context,e,n);break;case 4:c[u].fn.call(c[u].context,e,n,s);break;default:if(!f)for(m=1,f=new Array(l-1);m<l;m++)f[m-1]=arguments[m];c[u].fn.apply(c[u].context,f)}}return!0};gt.prototype.on=function(t,e,n){return Gc(this,t,e,n,!1)};gt.prototype.once=function(t,e,n){return Gc(this,t,e,n,!0)};gt.prototype.removeListener=function(t,e,n,s){var i=wt?wt+t:t;if(!this._events[i])return this;if(!e)return gs(this,i),this;var o=this._events[i];if(o.fn)o.fn===e&&(!s||o.once)&&(!n||o.context===n)&&gs(this,i);else{for(var a=0,c=[],l=o.length;a<l;a++)(o[a].fn!==e||s&&!o[a].once||n&&o[a].context!==n)&&c.push(o[a]);c.length?this._events[i]=c.length===1?c[0]:c:gs(this,i)}return this};gt.prototype.removeAllListeners=function(t){var e;return t?(e=wt?wt+t:t,this._events[e]&&gs(this,e)):(this._events=new Fr,this._eventsCount=0),this};gt.prototype.off=gt.prototype.removeListener;gt.prototype.addListener=gt.prototype.on;gt.prefixed=wt;gt.EventEmitter=gt;typeof io<"u"&&(io.exports=gt)});var Rh={};bt(Rh,{floodsub:()=>Lh,multicodec:()=>fo});var Ls=Symbol.for("@libp2p/peer-id");var fr;(function(r){r.Accept="accept",r.Ignore="ignore",r.Reject="reject"})(fr||(fr={}));var So=Symbol.for("@libp2p/pubsub");var et=class extends Error{static name="InvalidParametersError";constructor(t="Invalid parameters"){super(t),this.name="InvalidParametersError"}},Fe=class extends Error{static name="InvalidPublicKeyError";constructor(t="Invalid public key"){super(t),this.name="InvalidPublicKeyError"}};var jr=class extends Error{static name="InvalidMultihashError";constructor(t="Invalid Multihash"){super(t),this.name="InvalidMultihashError"}};var X=class extends Error{static name="InvalidMessageError";constructor(t="Invalid message"){super(t),this.name="InvalidMessageError"}};var Yr=class extends Error{static name="NotStartedError";constructor(t="Not started"){super(t),this.name="NotStartedError"}};var Se=class extends Error{static name="UnsupportedKeyTypeError";constructor(t="Unsupported key type"){super(t),this.name="UnsupportedKeyTypeError"}};var Ao=(r,...t)=>{try{[...t]}catch{}};var Ke=class extends EventTarget{#t=new Map;constructor(){super(),Ao(1/0,this)}listenerCount(t){let e=this.#t.get(t);return e==null?0:e.length}addEventListener(t,e,n){super.addEventListener(t,e,n);let s=this.#t.get(t);s==null&&(s=[],this.#t.set(t,s)),s.push({callback:e,once:(n!==!0&&n!==!1&&n?.once)??!1})}removeEventListener(t,e,n){super.removeEventListener(t.toString(),e??null,n);let s=this.#t.get(t);s!=null&&(s=s.filter(({callback:i})=>i!==e),this.#t.set(t,s))}dispatchEvent(t){let e=super.dispatchEvent(t),n=this.#t.get(t.type);return n==null||(n=n.filter(({once:s})=>!s),this.#t.set(t.type,n)),e}safeDispatchEvent(t,e={}){return this.dispatchEvent(new CustomEvent(t,e))}};var ko=Symbol.for("@libp2p/service-capabilities"),Io=Symbol.for("@libp2p/service-dependencies");var Vs={};bt(Vs,{base58btc:()=>Q,base58flickr:()=>ku});var ld=new Uint8Array(0);function No(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function Zt(r){if(r instanceof Uint8Array&&r.constructor.name==="Uint8Array")return r;if(r instanceof ArrayBuffer)return new Uint8Array(r);if(ArrayBuffer.isView(r))return new Uint8Array(r.buffer,r.byteOffset,r.byteLength);throw new Error("Unknown type, must be binary type")}function To(r){return new TextEncoder().encode(r)}function Co(r){return new TextDecoder().decode(r)}function vu(r,t){if(r.length>=255)throw new TypeError("Alphabet too long");for(var e=new Uint8Array(256),n=0;n<e.length;n++)e[n]=255;for(var s=0;s<r.length;s++){var i=r.charAt(s),o=i.charCodeAt(0);if(e[o]!==255)throw new TypeError(i+" is ambiguous");e[o]=s}var a=r.length,c=r.charAt(0),l=Math.log(a)/Math.log(256),f=Math.log(256)/Math.log(a);function u(x){if(x instanceof Uint8Array||(ArrayBuffer.isView(x)?x=new Uint8Array(x.buffer,x.byteOffset,x.byteLength):Array.isArray(x)&&(x=Uint8Array.from(x))),!(x instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(x.length===0)return"";for(var y=0,h=0,w=0,E=x.length;w!==E&&x[w]===0;)w++,y++;for(var g=(E-w)*f+1>>>0,k=new Uint8Array(g);w!==E;){for(var U=x[w],L=0,I=g-1;(U!==0||L<h)&&I!==-1;I--,L++)U+=256*k[I]>>>0,k[I]=U%a>>>0,U=U/a>>>0;if(U!==0)throw new Error("Non-zero carry");h=L,w++}for(var C=g-h;C!==g&&k[C]===0;)C++;for(var N=c.repeat(y);C<g;++C)N+=r.charAt(k[C]);return N}function d(x){if(typeof x!="string")throw new TypeError("Expected String");if(x.length===0)return new Uint8Array;var y=0;if(x[y]!==" "){for(var h=0,w=0;x[y]===c;)h++,y++;for(var E=(x.length-y)*l+1>>>0,g=new Uint8Array(E);x[y];){var k=e[x.charCodeAt(y)];if(k===255)return;for(var U=0,L=E-1;(k!==0||U<w)&&L!==-1;L--,U++)k+=a*g[L]>>>0,g[L]=k%256>>>0,k=k/256>>>0;if(k!==0)throw new Error("Non-zero carry");w=U,y++}if(x[y]!==" "){for(var I=E-w;I!==E&&g[I]===0;)I++;for(var C=new Uint8Array(h+(E-I)),N=h;I!==E;)C[N++]=g[I++];return C}}}function m(x){var y=d(x);if(y)return y;throw new Error(`Non-${t} character`)}return{encode:u,decodeUnsafe:d,decode:m}}var Eu=vu,Bu=Eu,Lo=Bu;var Rs=class{name;prefix;baseEncode;constructor(t,e,n){this.name=t,this.prefix=e,this.baseEncode=n}encode(t){if(t instanceof Uint8Array)return`${this.prefix}${this.baseEncode(t)}`;throw Error("Unknown type, must be binary type")}},_s=class{name;prefix;baseDecode;prefixCodePoint;constructor(t,e,n){this.name=t,this.prefix=e;let s=e.codePointAt(0);if(s===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=s,this.baseDecode=n}decode(t){if(typeof t=="string"){if(t.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(t)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(t.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(t){return Ro(this,t)}},Ds=class{decoders;constructor(t){this.decoders=t}or(t){return Ro(this,t)}decode(t){let e=t[0],n=this.decoders[e];if(n!=null)return n.decode(t);throw RangeError(`Unable to decode multibase string ${JSON.stringify(t)}, only inputs prefixed with ${Object.keys(this.decoders)} are supported`)}};function Ro(r,t){return new Ds({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var Ms=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(t,e,n,s){this.name=t,this.prefix=e,this.baseEncode=n,this.baseDecode=s,this.encoder=new Rs(t,e,n),this.decoder=new _s(t,e,s)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function qe({name:r,prefix:t,encode:e,decode:n}){return new Ms(r,t,e,n)}function ce({name:r,prefix:t,alphabet:e}){let{encode:n,decode:s}=Lo(e,r);return qe({prefix:t,name:r,encode:n,decode:i=>Zt(s(i))})}function Su(r,t,e,n){let s={};for(let f=0;f<t.length;++f)s[t[f]]=f;let i=r.length;for(;r[i-1]==="=";)--i;let o=new Uint8Array(i*e/8|0),a=0,c=0,l=0;for(let f=0;f<i;++f){let u=s[r[f]];if(u===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<e|u,a+=e,a>=8&&(a-=8,o[l++]=255&c>>a)}if(a>=e||255&c<<8-a)throw new SyntaxError("Unexpected end of data");return o}function Au(r,t,e){let n=t[t.length-1]==="=",s=(1<<e)-1,i="",o=0,a=0;for(let c=0;c<r.length;++c)for(a=a<<8|r[c],o+=8;o>e;)o-=e,i+=t[s&a>>o];if(o!==0&&(i+=t[s&a<<e-o]),n)for(;i.length*e&7;)i+="=";return i}function J({name:r,prefix:t,bitsPerChar:e,alphabet:n}){return qe({prefix:t,name:r,encode(s){return Au(s,n,e)},decode(s){return Su(s,n,e,r)}})}var Q=ce({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),ku=ce({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Hs={};bt(Hs,{base32:()=>ze,base32hex:()=>Cu,base32hexpad:()=>Lu,base32hexpadupper:()=>Ru,base32hexupper:()=>Uu,base32pad:()=>Nu,base32padupper:()=>Tu,base32upper:()=>Iu,base32z:()=>_u});var ze=J({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),Iu=J({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Nu=J({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),Tu=J({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),Cu=J({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),Uu=J({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),Lu=J({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),Ru=J({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),_u=J({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Os={};bt(Os,{base36:()=>hr,base36upper:()=>Du});var hr=ce({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),Du=ce({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Mu=Mo,_o=128,Vu=127,Hu=~Vu,Ou=Math.pow(2,31);function Mo(r,t,e){t=t||[],e=e||0;for(var n=e;r>=Ou;)t[e++]=r&255|_o,r/=128;for(;r&Hu;)t[e++]=r&255|_o,r>>>=7;return t[e]=r|0,Mo.bytes=e-n+1,t}var Pu=Ps,Fu=128,Do=127;function Ps(r,n){var e=0,n=n||0,s=0,i=n,o,a=r.length;do{if(i>=a)throw Ps.bytes=0,new RangeError("Could not decode varint");o=r[i++],e+=s<28?(o&Do)<<s:(o&Do)*Math.pow(2,s),s+=7}while(o>=Fu);return Ps.bytes=i-n,e}var Ku=Math.pow(2,7),qu=Math.pow(2,14),zu=Math.pow(2,21),$u=Math.pow(2,28),Gu=Math.pow(2,35),Zu=Math.pow(2,42),Wu=Math.pow(2,49),ju=Math.pow(2,56),Yu=Math.pow(2,63),Ju=function(r){return r<Ku?1:r<qu?2:r<zu?3:r<$u?4:r<Gu?5:r<Zu?6:r<Wu?7:r<ju?8:r<Yu?9:10},Xu={encode:Mu,decode:Pu,encodingLength:Ju},Qu=Xu,dr=Qu;function pr(r,t=0){return[dr.decode(r,t),dr.decode.bytes]}function $e(r,t,e=0){return dr.encode(r,t,e),t}function Ge(r){return dr.encodingLength(r)}function Lt(r,t){let e=t.byteLength,n=Ge(r),s=n+Ge(e),i=new Uint8Array(s+e);return $e(r,i,0),$e(e,i,n),i.set(t,s),new Ze(r,e,t,i)}function ue(r){let t=Zt(r),[e,n]=pr(t),[s,i]=pr(t.subarray(n)),o=t.subarray(n+i);if(o.byteLength!==s)throw new Error("Incorrect length");return new Ze(e,s,o,t)}function Vo(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&No(r.bytes,e.bytes)}}var Ze=class{code;size;digest;bytes;constructor(t,e,n,s){this.code=t,this.size=e,this.digest=n,this.bytes=s}};function Ho(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return el(e,Fs(r),t??Q.encoder);default:return rl(e,Fs(r),t??ze.encoder)}}var Oo=new WeakMap;function Fs(r){let t=Oo.get(r);if(t==null){let e=new Map;return Oo.set(r,e),e}return t}var It=class r{code;version;multihash;bytes;"/";constructor(t,e,n,s){this.code=e,this.version=t,this.multihash=n,this.bytes=s,this["/"]=s}get asCID(){return this}get byteOffset(){return this.bytes.byteOffset}get byteLength(){return this.bytes.byteLength}toV0(){switch(this.version){case 0:return this;case 1:{let{code:t,multihash:e}=this;if(t!==gr)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==nl)throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");return r.createV0(e)}default:throw Error(`Can not convert CID version ${this.version} to version 0. This is a bug please report`)}}toV1(){switch(this.version){case 0:{let{code:t,digest:e}=this.multihash,n=Lt(t,e);return r.createV1(this.code,n)}case 1:return this;default:throw Error(`Can not convert CID version ${this.version} to version 1. This is a bug please report`)}}equals(t){return r.equals(this,t)}static equals(t,e){let n=e;return n!=null&&t.code===n.code&&t.version===n.version&&Vo(t.multihash,n.multihash)}toString(t){return Ho(this,t)}toJSON(){return{"/":Ho(this)}}link(){return this}[Symbol.toStringTag]="CID";[Symbol.for("nodejs.util.inspect.custom")](){return`CID(${this.toString()})`}static asCID(t){if(t==null)return null;let e=t;if(e instanceof r)return e;if(e["/"]!=null&&e["/"]===e.bytes||e.asCID===e){let{version:n,code:s,multihash:i,bytes:o}=e;return new r(n,s,i,o??Po(n,s,i.bytes))}else if(e[sl]===!0){let{version:n,multihash:s,code:i}=e,o=ue(s);return r.create(n,i,o)}else return null}static create(t,e,n){if(typeof e!="number")throw new Error("String codecs are no longer supported");if(!(n.bytes instanceof Uint8Array))throw new Error("Invalid digest");switch(t){case 0:{if(e!==gr)throw new Error(`Version 0 CID must use dag-pb (code: ${gr}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let s=Po(t,e,n.bytes);return new r(t,e,n,s)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,gr,t)}static createV1(t,e){return r.create(1,t,e)}static decode(t){let[e,n]=r.decodeFirst(t);if(n.length!==0)throw new Error("Incorrect length");return e}static decodeFirst(t){let e=r.inspectBytes(t),n=e.size-e.multihashSize,s=Zt(t.subarray(n,n+e.multihashSize));if(s.byteLength!==e.multihashSize)throw new Error("Incorrect length");let i=s.subarray(e.multihashSize-e.digestSize),o=new Ze(e.multihashCode,e.digestSize,i,s);return[e.version===0?r.createV0(o):r.createV1(e.codec,o),t.subarray(e.size)]}static inspectBytes(t){let e=0,n=()=>{let[u,d]=pr(t.subarray(e));return e+=d,u},s=n(),i=gr;if(s===18?(s=0,e=0):i=n(),s!==0&&s!==1)throw new RangeError(`Invalid CID version ${s}`);let o=e,a=n(),c=n(),l=e+c,f=l-o;return{version:s,codec:i,multihashCode:a,digestSize:c,multihashSize:f,size:l}}static parse(t,e){let[n,s]=tl(t,e),i=r.decode(s);if(i.version===0&&t[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return Fs(i).set(n,t),i}};function tl(r,t){switch(r[0]){case"Q":{let e=t??Q;return[Q.prefix,e.decode(`${Q.prefix}${r}`)]}case Q.prefix:{let e=t??Q;return[Q.prefix,e.decode(r)]}case ze.prefix:{let e=t??ze;return[ze.prefix,e.decode(r)]}case hr.prefix:{let e=t??hr;return[hr.prefix,e.decode(r)]}default:{if(t==null)throw Error("To parse non base32, base36 or base58btc encoded CID multibase decoder must be provided");return[r[0],t.decode(r)]}}}function el(r,t,e){let{prefix:n}=e;if(n!==Q.prefix)throw Error(`Cannot string encode V0 in ${e.name} encoding`);let s=t.get(n);if(s==null){let i=e.encode(r).slice(1);return t.set(n,i),i}else return s}function rl(r,t,e){let{prefix:n}=e,s=t.get(n);if(s==null){let i=e.encode(r);return t.set(n,i),i}else return s}var gr=112,nl=18;function Po(r,t,e){let n=Ge(r),s=n+Ge(t),i=new Uint8Array(s+e.byteLength);return $e(r,i,0),$e(t,i,n),i.set(e,s),i}var sl=Symbol.for("@ipld/js-cid/CID");var Ks={};bt(Ks,{identity:()=>Wt});var Fo=0,il="identity",Ko=Zt;function ol(r){return Lt(Fo,Ko(r))}var Wt={code:Fo,name:il,encode:Ko,digest:ol};function Tt(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function qo(r){if(!Number.isSafeInteger(r)||r<0)throw new Error("positive integer expected, got "+r)}function al(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function We(r,...t){if(!al(r))throw new Error("Uint8Array expected");if(t.length>0&&!t.includes(r.length))throw new Error("Uint8Array expected of length "+t+", got length="+r.length)}function zo(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");qo(r.outputLen),qo(r.blockLen)}function je(r,t=!0){if(r.destroyed)throw new Error("Hash instance has been destroyed");if(t&&r.finished)throw new Error("Hash#digest() has already been called")}function $o(r,t){We(r);let e=t.outputLen;if(r.length<e)throw new Error("digestInto() expects output buffer of length at least "+e)}var Ae=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;function Xr(r){return new DataView(r.buffer,r.byteOffset,r.byteLength)}function Rt(r,t){return r<<32-t|r>>>t}function Go(r){if(typeof r!="string")throw new Error("utf8ToBytes expected string, got "+typeof r);return new Uint8Array(new TextEncoder().encode(r))}function mr(r){return typeof r=="string"&&(r=Go(r)),We(r),r}function qs(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];We(s),t+=s.length}let e=new Uint8Array(t);for(let n=0,s=0;n<r.length;n++){let i=r[n];e.set(i,s),s+=i.length}return e}var Ye=class{clone(){return this._cloneInto()}};function Qr(r){let t=n=>r().update(mr(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function Je(r=32){if(Ae&&typeof Ae.getRandomValues=="function")return Ae.getRandomValues(new Uint8Array(r));if(Ae&&typeof Ae.randomBytes=="function")return Ae.randomBytes(r);throw new Error("crypto.getRandomValues must be defined")}function cl(r,t,e,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(t,e,n);let s=BigInt(32),i=BigInt(4294967295),o=Number(e>>s&i),a=Number(e&i),c=n?4:0,l=n?0:4;r.setUint32(t+c,o,n),r.setUint32(t+l,a,n)}function Zo(r,t,e){return r&t^~r&e}function Wo(r,t,e){return r&t^r&e^t&e}var Xe=class extends Ye{constructor(t,e,n,s){super(),this.blockLen=t,this.outputLen=e,this.padOffset=n,this.isLE=s,this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.buffer=new Uint8Array(t),this.view=Xr(this.buffer)}update(t){je(this);let{view:e,buffer:n,blockLen:s}=this;t=mr(t);let i=t.length;for(let o=0;o<i;){let a=Math.min(s-this.pos,i-o);if(a===s){let c=Xr(t);for(;s<=i-o;o+=s)this.process(c,o);continue}n.set(t.subarray(o,o+a),this.pos),this.pos+=a,o+=a,this.pos===s&&(this.process(e,0),this.pos=0)}return this.length+=t.length,this.roundClean(),this}digestInto(t){je(this),$o(t,this),this.finished=!0;let{buffer:e,view:n,blockLen:s,isLE:i}=this,{pos:o}=this;e[o++]=128,this.buffer.subarray(o).fill(0),this.padOffset>s-o&&(this.process(n,0),o=0);for(let u=o;u<s;u++)e[u]=0;cl(n,s-8,BigInt(this.length*8),i),this.process(n,0);let a=Xr(t),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let l=c/4,f=this.get();if(l>f.length)throw new Error("_sha2: outputLen bigger than state");for(let u=0;u<l;u++)a.setUint32(4*u,f[u],i)}digest(){let{buffer:t,outputLen:e}=this;this.digestInto(t);let n=t.slice(0,e);return this.destroy(),n}_cloneInto(t){t||(t=new this.constructor),t.set(...this.get());let{blockLen:e,buffer:n,length:s,finished:i,destroyed:o,pos:a}=this;return t.length=s,t.pos=a,t.finished=i,t.destroyed=o,s%e&&t.buffer.set(n),t}};var tn=BigInt(4294967295),zs=BigInt(32);function jo(r,t=!1){return t?{h:Number(r&tn),l:Number(r>>zs&tn)}:{h:Number(r>>zs&tn)|0,l:Number(r&tn)|0}}function ul(r,t=!1){let e=new Uint32Array(r.length),n=new Uint32Array(r.length);for(let s=0;s<r.length;s++){let{h:i,l:o}=jo(r[s],t);[e[s],n[s]]=[i,o]}return[e,n]}var ll=(r,t)=>BigInt(r>>>0)<<zs|BigInt(t>>>0),fl=(r,t,e)=>r>>>e,hl=(r,t,e)=>r<<32-e|t>>>e,dl=(r,t,e)=>r>>>e|t<<32-e,pl=(r,t,e)=>r<<32-e|t>>>e,gl=(r,t,e)=>r<<64-e|t>>>e-32,ml=(r,t,e)=>r>>>e-32|t<<64-e,bl=(r,t)=>t,yl=(r,t)=>r,wl=(r,t,e)=>r<<e|t>>>32-e,xl=(r,t,e)=>t<<e|r>>>32-e,vl=(r,t,e)=>t<<e-32|r>>>64-e,El=(r,t,e)=>r<<e-32|t>>>64-e;function Bl(r,t,e,n){let s=(t>>>0)+(n>>>0);return{h:r+e+(s/2**32|0)|0,l:s|0}}var Sl=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),Al=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,kl=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),Il=(r,t,e,n,s)=>t+e+n+s+(r/2**32|0)|0,Nl=(r,t,e,n,s)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(s>>>0),Tl=(r,t,e,n,s,i)=>t+e+n+s+i+(r/2**32|0)|0;var Cl={fromBig:jo,split:ul,toBig:ll,shrSH:fl,shrSL:hl,rotrSH:dl,rotrSL:pl,rotrBH:gl,rotrBL:ml,rotr32H:bl,rotr32L:yl,rotlSH:wl,rotlSL:xl,rotlBH:vl,rotlBL:El,add:Bl,add3L:Sl,add3H:Al,add4L:kl,add4H:Il,add5H:Tl,add5L:Nl},M=Cl;var[Ul,Ll]=M.split(["0x428a2f98d728ae22","0x7137449123ef65cd","0xb5c0fbcfec4d3b2f","0xe9b5dba58189dbbc","0x3956c25bf348b538","0x59f111f1b605d019","0x923f82a4af194f9b","0xab1c5ed5da6d8118","0xd807aa98a3030242","0x12835b0145706fbe","0x243185be4ee4b28c","0x550c7dc3d5ffb4e2","0x72be5d74f27b896f","0x80deb1fe3b1696b1","0x9bdc06a725c71235","0xc19bf174cf692694","0xe49b69c19ef14ad2","0xefbe4786384f25e3","0x0fc19dc68b8cd5b5","0x240ca1cc77ac9c65","0x2de92c6f592b0275","0x4a7484aa6ea6e483","0x5cb0a9dcbd41fbd4","0x76f988da831153b5","0x983e5152ee66dfab","0xa831c66d2db43210","0xb00327c898fb213f","0xbf597fc7beef0ee4","0xc6e00bf33da88fc2","0xd5a79147930aa725","0x06ca6351e003826f","0x142929670a0e6e70","0x27b70a8546d22ffc","0x2e1b21385c26c926","0x4d2c6dfc5ac42aed","0x53380d139d95b3df","0x650a73548baf63de","0x766a0abb3c77b2a8","0x81c2c92e47edaee6","0x92722c851482353b","0xa2bfe8a14cf10364","0xa81a664bbc423001","0xc24b8b70d0f89791","0xc76c51a30654be30","0xd192e819d6ef5218","0xd69906245565a910","0xf40e35855771202a","0x106aa07032bbd1b8","0x19a4c116b8d2d0c8","0x1e376c085141ab53","0x2748774cdf8eeb99","0x34b0bcb5e19b48a8","0x391c0cb3c5c95a63","0x4ed8aa4ae3418acb","0x5b9cca4f7763e373","0x682e6ff3d6b2b8a3","0x748f82ee5defb2fc","0x78a5636f43172f60","0x84c87814a1f0ab72","0x8cc702081a6439ec","0x90befffa23631e28","0xa4506cebde82bde9","0xbef9a3f7b2c67915","0xc67178f2e372532b","0xca273eceea26619c","0xd186b8c721c0c207","0xeada7dd6cde0eb1e","0xf57d4f7fee6ed178","0x06f067aa72176fba","0x0a637dc5a2c898a6","0x113f9804bef90dae","0x1b710b35131c471b","0x28db77f523047d84","0x32caab7b40c72493","0x3c9ebe0a15c9bebc","0x431d67c49c100d4c","0x4cc5d4becb3e42b6","0x597f299cfc657e2a","0x5fcb6fab3ad6faec","0x6c44198c4a475817"].map(r=>BigInt(r))),fe=new Uint32Array(80),he=new Uint32Array(80),$s=class extends Xe{constructor(){super(128,64,16,!1),this.Ah=1779033703,this.Al=-205731576,this.Bh=-1150833019,this.Bl=-2067093701,this.Ch=1013904242,this.Cl=-23791573,this.Dh=-1521486534,this.Dl=1595750129,this.Eh=1359893119,this.El=-1377402159,this.Fh=-1694144372,this.Fl=725511199,this.Gh=528734635,this.Gl=-79577749,this.Hh=1541459225,this.Hl=327033209}get(){let{Ah:t,Al:e,Bh:n,Bl:s,Ch:i,Cl:o,Dh:a,Dl:c,Eh:l,El:f,Fh:u,Fl:d,Gh:m,Gl:x,Hh:y,Hl:h}=this;return[t,e,n,s,i,o,a,c,l,f,u,d,m,x,y,h]}set(t,e,n,s,i,o,a,c,l,f,u,d,m,x,y,h){this.Ah=t|0,this.Al=e|0,this.Bh=n|0,this.Bl=s|0,this.Ch=i|0,this.Cl=o|0,this.Dh=a|0,this.Dl=c|0,this.Eh=l|0,this.El=f|0,this.Fh=u|0,this.Fl=d|0,this.Gh=m|0,this.Gl=x|0,this.Hh=y|0,this.Hl=h|0}process(t,e){for(let g=0;g<16;g++,e+=4)fe[g]=t.getUint32(e),he[g]=t.getUint32(e+=4);for(let g=16;g<80;g++){let k=fe[g-15]|0,U=he[g-15]|0,L=M.rotrSH(k,U,1)^M.rotrSH(k,U,8)^M.shrSH(k,U,7),I=M.rotrSL(k,U,1)^M.rotrSL(k,U,8)^M.shrSL(k,U,7),C=fe[g-2]|0,N=he[g-2]|0,G=M.rotrSH(C,N,19)^M.rotrBH(C,N,61)^M.shrSH(C,N,6),F=M.rotrSL(C,N,19)^M.rotrBL(C,N,61)^M.shrSL(C,N,6),H=M.add4L(I,F,he[g-7],he[g-16]),tt=M.add4H(H,L,G,fe[g-7],fe[g-16]);fe[g]=tt|0,he[g]=H|0}let{Ah:n,Al:s,Bh:i,Bl:o,Ch:a,Cl:c,Dh:l,Dl:f,Eh:u,El:d,Fh:m,Fl:x,Gh:y,Gl:h,Hh:w,Hl:E}=this;for(let g=0;g<80;g++){let k=M.rotrSH(u,d,14)^M.rotrSH(u,d,18)^M.rotrBH(u,d,41),U=M.rotrSL(u,d,14)^M.rotrSL(u,d,18)^M.rotrBL(u,d,41),L=u&m^~u&y,I=d&x^~d&h,C=M.add5L(E,U,I,Ll[g],he[g]),N=M.add5H(C,w,k,L,Ul[g],fe[g]),G=C|0,F=M.rotrSH(n,s,28)^M.rotrBH(n,s,34)^M.rotrBH(n,s,39),H=M.rotrSL(n,s,28)^M.rotrBL(n,s,34)^M.rotrBL(n,s,39),tt=n&i^n&a^i&a,B=s&o^s&c^o&c;w=y|0,E=h|0,y=m|0,h=x|0,m=u|0,x=d|0,{h:u,l:d}=M.add(l|0,f|0,N|0,G|0),l=a|0,f=c|0,a=i|0,c=o|0,i=n|0,o=s|0;let T=M.add3L(G,H,B);n=M.add3H(T,N,F,tt),s=T|0}({h:n,l:s}=M.add(this.Ah|0,this.Al|0,n|0,s|0)),{h:i,l:o}=M.add(this.Bh|0,this.Bl|0,i|0,o|0),{h:a,l:c}=M.add(this.Ch|0,this.Cl|0,a|0,c|0),{h:l,l:f}=M.add(this.Dh|0,this.Dl|0,l|0,f|0),{h:u,l:d}=M.add(this.Eh|0,this.El|0,u|0,d|0),{h:m,l:x}=M.add(this.Fh|0,this.Fl|0,m|0,x|0),{h:y,l:h}=M.add(this.Gh|0,this.Gl|0,y|0,h|0),{h:w,l:E}=M.add(this.Hh|0,this.Hl|0,w|0,E|0),this.set(n,s,i,o,a,c,l,f,u,d,m,x,y,h,w,E)}roundClean(){fe.fill(0),he.fill(0)}destroy(){this.buffer.fill(0),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}};var Yo=Qr(()=>new $s);var nn={};bt(nn,{aInRange:()=>vt,abool:()=>_t,abytes:()=>Qe,bitGet:()=>Hl,bitLen:()=>js,bitMask:()=>yr,bitSet:()=>Ol,bytesToHex:()=>Yt,bytesToNumberBE:()=>Jt,bytesToNumberLE:()=>pe,concatBytes:()=>Xt,createHmacDrbg:()=>Ys,ensureBytes:()=>j,equalBytes:()=>Ml,hexToBytes:()=>Ie,hexToNumber:()=>Ws,inRange:()=>br,isBytes:()=>de,memoized:()=>Te,notImplemented:()=>Fl,numberToBytesBE:()=>ge,numberToBytesLE:()=>Ne,numberToHexUnpadded:()=>ke,numberToVarBytesBE:()=>Dl,utf8ToBytes:()=>Vl,validateObject:()=>Ft});var en=BigInt(0),rn=BigInt(1),Rl=BigInt(2);function de(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function Qe(r){if(!de(r))throw new Error("Uint8Array expected")}function _t(r,t){if(typeof t!="boolean")throw new Error(r+" boolean expected, got "+t)}var _l=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function Yt(r){Qe(r);let t="";for(let e=0;e<r.length;e++)t+=_l[r[e]];return t}function ke(r){let t=r.toString(16);return t.length&1?"0"+t:t}function Ws(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return r===""?en:BigInt("0x"+r)}var jt={_0:48,_9:57,A:65,F:70,a:97,f:102};function Jo(r){if(r>=jt._0&&r<=jt._9)return r-jt._0;if(r>=jt.A&&r<=jt.F)return r-(jt.A-10);if(r>=jt.a&&r<=jt.f)return r-(jt.a-10)}function Ie(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);let t=r.length,e=t/2;if(t%2)throw new Error("hex string expected, got unpadded hex of length "+t);let n=new Uint8Array(e);for(let s=0,i=0;s<e;s++,i+=2){let o=Jo(r.charCodeAt(i)),a=Jo(r.charCodeAt(i+1));if(o===void 0||a===void 0){let c=r[i]+r[i+1];throw new Error('hex string expected, got non-hex character "'+c+'" at index '+i)}n[s]=o*16+a}return n}function Jt(r){return Ws(Yt(r))}function pe(r){return Qe(r),Ws(Yt(Uint8Array.from(r).reverse()))}function ge(r,t){return Ie(r.toString(16).padStart(t*2,"0"))}function Ne(r,t){return ge(r,t).reverse()}function Dl(r){return Ie(ke(r))}function j(r,t,e){let n;if(typeof t=="string")try{n=Ie(t)}catch(i){throw new Error(r+" must be hex string or Uint8Array, cause: "+i)}else if(de(t))n=Uint8Array.from(t);else throw new Error(r+" must be hex string or Uint8Array");let s=n.length;if(typeof e=="number"&&s!==e)throw new Error(r+" of length "+e+" expected, got "+s);return n}function Xt(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];Qe(s),t+=s.length}let e=new Uint8Array(t);for(let n=0,s=0;n<r.length;n++){let i=r[n];e.set(i,s),s+=i.length}return e}function Ml(r,t){if(r.length!==t.length)return!1;let e=0;for(let n=0;n<r.length;n++)e|=r[n]^t[n];return e===0}function Vl(r){if(typeof r!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(r))}var Gs=r=>typeof r=="bigint"&&en<=r;function br(r,t,e){return Gs(r)&&Gs(t)&&Gs(e)&&t<=r&&r<e}function vt(r,t,e,n){if(!br(t,e,n))throw new Error("expected valid "+r+": "+e+" <= n < "+n+", got "+t)}function js(r){let t;for(t=0;r>en;r>>=rn,t+=1);return t}function Hl(r,t){return r>>BigInt(t)&rn}function Ol(r,t,e){return r|(e?rn:en)<<BigInt(t)}var yr=r=>(Rl<<BigInt(r-1))-rn,Zs=r=>new Uint8Array(r),Xo=r=>Uint8Array.from(r);function Ys(r,t,e){if(typeof r!="number"||r<2)throw new Error("hashLen must be a number");if(typeof t!="number"||t<2)throw new Error("qByteLen must be a number");if(typeof e!="function")throw new Error("hmacFn must be a function");let n=Zs(r),s=Zs(r),i=0,o=()=>{n.fill(1),s.fill(0),i=0},a=(...u)=>e(s,n,...u),c=(u=Zs())=>{s=a(Xo([0]),u),n=a(),u.length!==0&&(s=a(Xo([1]),u),n=a())},l=()=>{if(i++>=1e3)throw new Error("drbg: tried 1000 values");let u=0,d=[];for(;u<t;){n=a();let m=n.slice();d.push(m),u+=n.length}return Xt(...d)};return(u,d)=>{o(),c(u);let m;for(;!(m=d(l()));)c();return o(),m}}var Pl={bigint:r=>typeof r=="bigint",function:r=>typeof r=="function",boolean:r=>typeof r=="boolean",string:r=>typeof r=="string",stringOrUint8Array:r=>typeof r=="string"||de(r),isSafeInteger:r=>Number.isSafeInteger(r),array:r=>Array.isArray(r),field:(r,t)=>t.Fp.isValid(r),hash:r=>typeof r=="function"&&Number.isSafeInteger(r.outputLen)};function Ft(r,t,e={}){let n=(s,i,o)=>{let a=Pl[i];if(typeof a!="function")throw new Error("invalid validator function");let c=r[s];if(!(o&&c===void 0)&&!a(c,r))throw new Error("param "+String(s)+" is invalid. Expected "+i+", got "+c)};for(let[s,i]of Object.entries(t))n(s,i,!1);for(let[s,i]of Object.entries(e))n(s,i,!0);return r}var Fl=()=>{throw new Error("not implemented")};function Te(r){let t=new WeakMap;return(e,...n)=>{let s=t.get(e);if(s!==void 0)return s;let i=r(e,...n);return t.set(e,i),i}}var rt=BigInt(0),Z=BigInt(1),Ce=BigInt(2),Kl=BigInt(3),Js=BigInt(4),Qo=BigInt(5),ta=BigInt(8),ql=BigInt(9),zl=BigInt(16);function z(r,t){let e=r%t;return e>=rt?e:t+e}function $l(r,t,e){if(t<rt)throw new Error("invalid exponent, negatives unsupported");if(e<=rt)throw new Error("invalid modulus");if(e===Z)return rt;let n=Z;for(;t>rt;)t&Z&&(n=n*r%e),r=r*r%e,t>>=Z;return n}function W(r,t,e){let n=r;for(;t-- >rt;)n*=n,n%=e;return n}function sn(r,t){if(r===rt)throw new Error("invert: expected non-zero number");if(t<=rt)throw new Error("invert: expected positive modulus, got "+t);let e=z(r,t),n=t,s=rt,i=Z,o=Z,a=rt;for(;e!==rt;){let l=n/e,f=n%e,u=s-o*l,d=i-a*l;n=e,e=f,s=o,i=a,o=u,a=d}if(n!==Z)throw new Error("invert: does not exist");return z(s,t)}function Gl(r){let t=(r-Z)/Ce,e,n,s;for(e=r-Z,n=0;e%Ce===rt;e/=Ce,n++);for(s=Ce;s<r&&$l(s,t,r)!==r-Z;s++)if(s>1e3)throw new Error("Cannot find square root: likely non-prime P");if(n===1){let o=(r+Z)/Js;return function(c,l){let f=c.pow(l,o);if(!c.eql(c.sqr(f),l))throw new Error("Cannot find square root");return f}}let i=(e+Z)/Ce;return function(a,c){if(a.pow(c,t)===a.neg(a.ONE))throw new Error("Cannot find square root");let l=n,f=a.pow(a.mul(a.ONE,s),e),u=a.pow(c,i),d=a.pow(c,e);for(;!a.eql(d,a.ONE);){if(a.eql(d,a.ZERO))return a.ZERO;let m=1;for(let y=a.sqr(d);m<l&&!a.eql(y,a.ONE);m++)y=a.sqr(y);let x=a.pow(f,Z<<BigInt(l-m-1));f=a.sqr(x),u=a.mul(u,x),d=a.mul(d,f),l=m}return u}}function Zl(r){if(r%Js===Kl){let t=(r+Z)/Js;return function(n,s){let i=n.pow(s,t);if(!n.eql(n.sqr(i),s))throw new Error("Cannot find square root");return i}}if(r%ta===Qo){let t=(r-Qo)/ta;return function(n,s){let i=n.mul(s,Ce),o=n.pow(i,t),a=n.mul(s,o),c=n.mul(n.mul(a,Ce),o),l=n.mul(a,n.sub(c,n.ONE));if(!n.eql(n.sqr(l),s))throw new Error("Cannot find square root");return l}}return r%zl,Gl(r)}var ea=(r,t)=>(z(r,t)&Z)===Z,Wl=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function Xs(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=Wl.reduce((n,s)=>(n[s]="function",n),t);return Ft(r,e)}function jl(r,t,e){if(e<rt)throw new Error("invalid exponent, negatives unsupported");if(e===rt)return r.ONE;if(e===Z)return t;let n=r.ONE,s=t;for(;e>rt;)e&Z&&(n=r.mul(n,s)),s=r.sqr(s),e>>=Z;return n}function Yl(r,t){let e=new Array(t.length),n=t.reduce((i,o,a)=>r.is0(o)?i:(e[a]=i,r.mul(i,o)),r.ONE),s=r.inv(n);return t.reduceRight((i,o,a)=>r.is0(o)?i:(e[a]=r.mul(i,e[a]),r.mul(i,o)),s),e}function Qs(r,t){let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function me(r,t,e=!1,n={}){if(r<=rt)throw new Error("invalid field: expected ORDER > 0, got "+r);let{nBitLength:s,nByteLength:i}=Qs(r,t);if(i>2048)throw new Error("invalid field: expected ORDER of <= 2048 bytes");let o,a=Object.freeze({ORDER:r,isLE:e,BITS:s,BYTES:i,MASK:yr(s),ZERO:rt,ONE:Z,create:c=>z(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error("invalid field element: expected bigint, got "+typeof c);return rt<=c&&c<r},is0:c=>c===rt,isOdd:c=>(c&Z)===Z,neg:c=>z(-c,r),eql:(c,l)=>c===l,sqr:c=>z(c*c,r),add:(c,l)=>z(c+l,r),sub:(c,l)=>z(c-l,r),mul:(c,l)=>z(c*l,r),pow:(c,l)=>jl(a,c,l),div:(c,l)=>z(c*sn(l,r),r),sqrN:c=>c*c,addN:(c,l)=>c+l,subN:(c,l)=>c-l,mulN:(c,l)=>c*l,inv:c=>sn(c,r),sqrt:n.sqrt||(c=>(o||(o=Zl(r)),o(a,c))),invertBatch:c=>Yl(a,c),cmov:(c,l,f)=>f?l:c,toBytes:c=>e?Ne(c,i):ge(c,i),fromBytes:c=>{if(c.length!==i)throw new Error("Field.fromBytes: expected "+i+" bytes, got "+c.length);return e?pe(c):Jt(c)}});return Object.freeze(a)}function ra(r){if(typeof r!="bigint")throw new Error("field order must be bigint");let t=r.toString(2).length;return Math.ceil(t/8)}function ti(r){let t=ra(r);return t+Math.ceil(t/2)}function na(r,t,e=!1){let n=r.length,s=ra(t),i=ti(t);if(n<16||n<i||n>1024)throw new Error("expected "+i+"-1024 bytes of input, got "+n);let o=e?pe(r):Jt(r),a=z(o,t-Z)+Z;return e?Ne(a,s):ge(a,s)}var sa=BigInt(0),on=BigInt(1);function ei(r,t){let e=t.negate();return r?e:t}function ia(r,t){if(!Number.isSafeInteger(r)||r<=0||r>t)throw new Error("invalid window size, expected [1.."+t+"], got W="+r)}function ri(r,t){ia(r,t);let e=Math.ceil(t/r)+1,n=2**(r-1);return{windows:e,windowSize:n}}function Jl(r,t){if(!Array.isArray(r))throw new Error("array expected");r.forEach((e,n)=>{if(!(e instanceof t))throw new Error("invalid point at index "+n)})}function Xl(r,t){if(!Array.isArray(r))throw new Error("array of scalars expected");r.forEach((e,n)=>{if(!t.isValid(e))throw new Error("invalid scalar at index "+n)})}var ni=new WeakMap,oa=new WeakMap;function si(r){return oa.get(r)||1}function an(r,t){return{constTimeNegate:ei,hasPrecomputes(e){return si(e)!==1},unsafeLadder(e,n,s=r.ZERO){let i=e;for(;n>sa;)n&on&&(s=s.add(i)),i=i.double(),n>>=on;return s},precomputeWindow(e,n){let{windows:s,windowSize:i}=ri(n,t),o=[],a=e,c=a;for(let l=0;l<s;l++){c=a,o.push(c);for(let f=1;f<i;f++)c=c.add(a),o.push(c);a=c.double()}return o},wNAF(e,n,s){let{windows:i,windowSize:o}=ri(e,t),a=r.ZERO,c=r.BASE,l=BigInt(2**e-1),f=2**e,u=BigInt(e);for(let d=0;d<i;d++){let m=d*o,x=Number(s&l);s>>=u,x>o&&(x-=f,s+=on);let y=m,h=m+Math.abs(x)-1,w=d%2!==0,E=x<0;x===0?c=c.add(ei(w,n[y])):a=a.add(ei(E,n[h]))}return{p:a,f:c}},wNAFUnsafe(e,n,s,i=r.ZERO){let{windows:o,windowSize:a}=ri(e,t),c=BigInt(2**e-1),l=2**e,f=BigInt(e);for(let u=0;u<o;u++){let d=u*a;if(s===sa)break;let m=Number(s&c);if(s>>=f,m>a&&(m-=l,s+=on),m===0)continue;let x=n[d+Math.abs(m)-1];m<0&&(x=x.negate()),i=i.add(x)}return i},getPrecomputes(e,n,s){let i=ni.get(n);return i||(i=this.precomputeWindow(n,e),e!==1&&ni.set(n,s(i))),i},wNAFCached(e,n,s){let i=si(e);return this.wNAF(i,this.getPrecomputes(i,e,s),n)},wNAFCachedUnsafe(e,n,s,i){let o=si(e);return o===1?this.unsafeLadder(e,n,i):this.wNAFUnsafe(o,this.getPrecomputes(o,e,s),n,i)},setWindowSize(e,n){ia(n,t),oa.set(e,n),ni.delete(e)}}}function cn(r,t,e,n){if(Jl(e,r),Xl(n,t),e.length!==n.length)throw new Error("arrays of points and scalars must have equal length");let s=r.ZERO,i=js(BigInt(e.length)),o=i>12?i-3:i>4?i-2:i?2:1,a=(1<<o)-1,c=new Array(a+1).fill(s),l=Math.floor((t.BITS-1)/o)*o,f=s;for(let u=l;u>=0;u-=o){c.fill(s);for(let m=0;m<n.length;m++){let x=n[m],y=Number(x>>BigInt(u)&BigInt(a));c[y]=c[y].add(e[m])}let d=s;for(let m=c.length-1,x=s;m>0;m--)x=x.add(c[m]),d=d.add(x);if(f=f.add(d),u!==0)for(let m=0;m<o;m++)f=f.double()}return f}function wr(r){return Xs(r.Fp),Ft(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...Qs(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Dt=BigInt(0),Et=BigInt(1),un=BigInt(2),Ql=BigInt(8),tf={zip215:!0};function ef(r){let t=wr(r);return Ft(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function aa(r){let t=ef(r),{Fp:e,n,prehash:s,hash:i,randomBytes:o,nByteLength:a,h:c}=t,l=un<<BigInt(a*8)-Et,f=e.create,u=me(t.n,t.nBitLength),d=t.uvRatio||((b,p)=>{try{return{isValid:!0,value:e.sqrt(b*e.inv(p))}}catch{return{isValid:!1,value:Dt}}}),m=t.adjustScalarBytes||(b=>b),x=t.domain||((b,p,v)=>{if(_t("phflag",v),p.length||v)throw new Error("Contexts/pre-hash are not supported");return b});function y(b,p){vt("coordinate "+b,p,Dt,l)}function h(b){if(!(b instanceof g))throw new Error("ExtendedPoint expected")}let w=Te((b,p)=>{let{ex:v,ey:A,ez:R}=b,_=b.is0();p==null&&(p=_?Ql:e.inv(R));let V=f(v*p),P=f(A*p),D=f(R*p);if(_)return{x:Dt,y:Et};if(D!==Et)throw new Error("invZ was invalid");return{x:V,y:P}}),E=Te(b=>{let{a:p,d:v}=t;if(b.is0())throw new Error("bad point: ZERO");let{ex:A,ey:R,ez:_,et:V}=b,P=f(A*A),D=f(R*R),q=f(_*_),$=f(q*q),st=f(P*p),it=f(q*f(st+D)),at=f($+f(v*f(P*D)));if(it!==at)throw new Error("bad point: equation left != right (1)");let lt=f(A*R),xt=f(_*V);if(lt!==xt)throw new Error("bad point: equation left != right (2)");return!0});class g{constructor(p,v,A,R){this.ex=p,this.ey=v,this.ez=A,this.et=R,y("x",p),y("y",v),y("z",A),y("t",R),Object.freeze(this)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(p){if(p instanceof g)throw new Error("extended point not allowed");let{x:v,y:A}=p||{};return y("x",v),y("y",A),new g(v,A,Et,f(v*A))}static normalizeZ(p){let v=e.invertBatch(p.map(A=>A.ez));return p.map((A,R)=>A.toAffine(v[R])).map(g.fromAffine)}static msm(p,v){return cn(g,u,p,v)}_setWindowSize(p){L.setWindowSize(this,p)}assertValidity(){E(this)}equals(p){h(p);let{ex:v,ey:A,ez:R}=this,{ex:_,ey:V,ez:P}=p,D=f(v*P),q=f(_*R),$=f(A*P),st=f(V*R);return D===q&&$===st}is0(){return this.equals(g.ZERO)}negate(){return new g(f(-this.ex),this.ey,this.ez,f(-this.et))}double(){let{a:p}=t,{ex:v,ey:A,ez:R}=this,_=f(v*v),V=f(A*A),P=f(un*f(R*R)),D=f(p*_),q=v+A,$=f(f(q*q)-_-V),st=D+V,it=st-P,at=D-V,lt=f($*it),xt=f(st*at),mt=f($*at),Pt=f(it*st);return new g(lt,xt,Pt,mt)}add(p){h(p);let{a:v,d:A}=t,{ex:R,ey:_,ez:V,et:P}=this,{ex:D,ey:q,ez:$,et:st}=p;if(v===BigInt(-1)){let po=f((_-R)*(q+D)),go=f((_+R)*(q-D)),Us=f(go-po);if(Us===Dt)return this.double();let mo=f(V*un*st),bo=f(P*un*$),yo=bo+mo,wo=go+po,xo=bo-mo,fu=f(yo*Us),hu=f(wo*xo),du=f(yo*xo),pu=f(Us*wo);return new g(fu,hu,pu,du)}let it=f(R*D),at=f(_*q),lt=f(P*A*st),xt=f(V*$),mt=f((R+_)*(D+q)-it-at),Pt=xt-lt,Gt=xt+lt,lr=f(at-v*it),au=f(mt*Pt),cu=f(Gt*lr),uu=f(mt*lr),lu=f(Pt*Gt);return new g(au,cu,lu,uu)}subtract(p){return this.add(p.negate())}wNAF(p){return L.wNAFCached(this,p,g.normalizeZ)}multiply(p){let v=p;vt("scalar",v,Et,n);let{p:A,f:R}=this.wNAF(v);return g.normalizeZ([A,R])[0]}multiplyUnsafe(p,v=g.ZERO){let A=p;return vt("scalar",A,Dt,n),A===Dt?U:this.is0()||A===Et?this:L.wNAFCachedUnsafe(this,A,g.normalizeZ,v)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return L.unsafeLadder(this,n).is0()}toAffine(p){return w(this,p)}clearCofactor(){let{h:p}=t;return p===Et?this:this.multiplyUnsafe(p)}static fromHex(p,v=!1){let{d:A,a:R}=t,_=e.BYTES;p=j("pointHex",p,_),_t("zip215",v);let V=p.slice(),P=p[_-1];V[_-1]=P&-129;let D=pe(V),q=v?l:e.ORDER;vt("pointHex.y",D,Dt,q);let $=f(D*D),st=f($-Et),it=f(A*$-R),{isValid:at,value:lt}=d(st,it);if(!at)throw new Error("Point.fromHex: invalid y coordinate");let xt=(lt&Et)===Et,mt=(P&128)!==0;if(!v&&lt===Dt&&mt)throw new Error("Point.fromHex: x=0 and x_0=1");return mt!==xt&&(lt=f(-lt)),g.fromAffine({x:lt,y:D})}static fromPrivateKey(p){return N(p).point}toRawBytes(){let{x:p,y:v}=this.toAffine(),A=Ne(v,e.BYTES);return A[A.length-1]|=p&Et?128:0,A}toHex(){return Yt(this.toRawBytes())}}g.BASE=new g(t.Gx,t.Gy,Et,f(t.Gx*t.Gy)),g.ZERO=new g(Dt,Et,Et,Dt);let{BASE:k,ZERO:U}=g,L=an(g,a*8);function I(b){return z(b,n)}function C(b){return I(pe(b))}function N(b){let p=e.BYTES;b=j("private key",b,p);let v=j("hashed private key",i(b),2*p),A=m(v.slice(0,p)),R=v.slice(p,2*p),_=C(A),V=k.multiply(_),P=V.toRawBytes();return{head:A,prefix:R,scalar:_,point:V,pointBytes:P}}function G(b){return N(b).pointBytes}function F(b=new Uint8Array,...p){let v=Xt(...p);return C(i(x(v,j("context",b),!!s)))}function H(b,p,v={}){b=j("message",b),s&&(b=s(b));let{prefix:A,scalar:R,pointBytes:_}=N(p),V=F(v.context,A,b),P=k.multiply(V).toRawBytes(),D=F(v.context,P,_,b),q=I(V+D*R);vt("signature.s",q,Dt,n);let $=Xt(P,Ne(q,e.BYTES));return j("result",$,e.BYTES*2)}let tt=tf;function B(b,p,v,A=tt){let{context:R,zip215:_}=A,V=e.BYTES;b=j("signature",b,2*V),p=j("message",p),v=j("publicKey",v,V),_!==void 0&&_t("zip215",_),s&&(p=s(p));let P=pe(b.slice(V,2*V)),D,q,$;try{D=g.fromHex(v,_),q=g.fromHex(b.slice(0,V),_),$=k.multiplyUnsafe(P)}catch{return!1}if(!_&&D.isSmallOrder())return!1;let st=F(R,q.toRawBytes(),D.toRawBytes(),p);return q.add(D.multiplyUnsafe(st)).subtract($).clearCofactor().equals(g.ZERO)}return k._setWindowSize(8),{CURVE:t,getPublicKey:G,sign:H,verify:B,ExtendedPoint:g,utils:{getExtendedPublicKey:N,randomPrivateKey:()=>o(e.BYTES),precompute(b=8,p=g.BASE){return p._setWindowSize(b),p.multiply(BigInt(3)),p}}}}var ii=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),ca=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),r0=BigInt(0),rf=BigInt(1),ua=BigInt(2),n0=BigInt(3),nf=BigInt(5),sf=BigInt(8);function of(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),s=BigInt(80),i=ii,a=r*r%i*r%i,c=W(a,ua,i)*a%i,l=W(c,rf,i)*r%i,f=W(l,nf,i)*l%i,u=W(f,t,i)*f%i,d=W(u,e,i)*u%i,m=W(d,n,i)*d%i,x=W(m,s,i)*m%i,y=W(x,s,i)*m%i,h=W(y,t,i)*f%i;return{pow_p_5_8:W(h,ua,i)*r%i,b2:a}}function af(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function cf(r,t){let e=ii,n=z(t*t*t,e),s=z(n*n*t,e),i=of(r*s).pow_p_5_8,o=z(r*n*i,e),a=z(t*o*o,e),c=o,l=z(o*ca,e),f=a===r,u=a===z(-r,e),d=a===z(-r*ca,e);return f&&(o=c),(u||d)&&(o=l),ea(o,e)&&(o=z(-o,e)),{isValid:f||u,value:o}}var uf=me(ii,void 0,!0),lf={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:uf,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:sf,Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:Yo,randomBytes:Je,adjustScalarBytes:af,uvRatio:cf},la=aa(lf);var ln=32;function fa(r,t,e){return la.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}var fn=class{type="Ed25519";raw;constructor(t){this.raw=oi(t,ln)}toMultihash(){return Wt.digest(Ue(this))}toCID(){return It.createV1(114,this.toMultihash())}toString(){return Q.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:Tt(this.raw,t.raw)}verify(t,e){return fa(this.raw,e,t)}};function ai(r){return r=oi(r,ln),new fn(r)}function oi(r,t){if(r=Uint8Array.from(r??[]),r.length!==t)throw new et(`Key must be a Uint8Array of length ${t}, got ${r.length}`);return r}function Qt(r=0){return new Uint8Array(r)}function ft(r=0){return new Uint8Array(r)}var hf=Math.pow(2,7),df=Math.pow(2,14),pf=Math.pow(2,21),ci=Math.pow(2,28),ui=Math.pow(2,35),li=Math.pow(2,42),fi=Math.pow(2,49),K=128,ht=127;function Mt(r){if(r<hf)return 1;if(r<df)return 2;if(r<pf)return 3;if(r<ci)return 4;if(r<ui)return 5;if(r<li)return 6;if(r<fi)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function hi(r,t,e=0){switch(Mt(r)){case 8:t[e++]=r&255|K,r/=128;case 7:t[e++]=r&255|K,r/=128;case 6:t[e++]=r&255|K,r/=128;case 5:t[e++]=r&255|K,r/=128;case 4:t[e++]=r&255|K,r>>>=7;case 3:t[e++]=r&255|K,r>>>=7;case 2:t[e++]=r&255|K,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function gf(r,t,e=0){switch(Mt(r)){case 8:t.set(e++,r&255|K),r/=128;case 7:t.set(e++,r&255|K),r/=128;case 6:t.set(e++,r&255|K),r/=128;case 5:t.set(e++,r&255|K),r/=128;case 4:t.set(e++,r&255|K),r>>>=7;case 3:t.set(e++,r&255|K),r>>>=7;case 2:t.set(e++,r&255|K),r>>>=7;case 1:{t.set(e++,r&255),r>>>=7;break}default:throw new Error("unreachable")}return t}function di(r,t){let e=r[t],n=0;if(n+=e&ht,e<K||(e=r[t+1],n+=(e&ht)<<7,e<K)||(e=r[t+2],n+=(e&ht)<<14,e<K)||(e=r[t+3],n+=(e&ht)<<21,e<K)||(e=r[t+4],n+=(e&ht)*ci,e<K)||(e=r[t+5],n+=(e&ht)*ui,e<K)||(e=r[t+6],n+=(e&ht)*li,e<K)||(e=r[t+7],n+=(e&ht)*fi,e<K))return n;throw new RangeError("Could not decode varint")}function mf(r,t){let e=r.get(t),n=0;if(n+=e&ht,e<K||(e=r.get(t+1),n+=(e&ht)<<7,e<K)||(e=r.get(t+2),n+=(e&ht)<<14,e<K)||(e=r.get(t+3),n+=(e&ht)<<21,e<K)||(e=r.get(t+4),n+=(e&ht)*ci,e<K)||(e=r.get(t+5),n+=(e&ht)*ui,e<K)||(e=r.get(t+6),n+=(e&ht)*li,e<K)||(e=r.get(t+7),n+=(e&ht)*fi,e<K))return n;throw new RangeError("Could not decode varint")}function da(r,t,e=0){return t==null&&(t=ft(Mt(r))),t instanceof Uint8Array?hi(r,t,e):gf(r,t,e)}function pa(r,t=0){return r instanceof Uint8Array?di(r,t):mf(r,t)}var pi=new Float32Array([-0]),be=new Uint8Array(pi.buffer);function ma(r,t,e){pi[0]=r,t[e]=be[0],t[e+1]=be[1],t[e+2]=be[2],t[e+3]=be[3]}function ba(r,t){return be[0]=r[t],be[1]=r[t+1],be[2]=r[t+2],be[3]=r[t+3],pi[0]}var gi=new Float64Array([-0]),dt=new Uint8Array(gi.buffer);function ya(r,t,e){gi[0]=r,t[e]=dt[0],t[e+1]=dt[1],t[e+2]=dt[2],t[e+3]=dt[3],t[e+4]=dt[4],t[e+5]=dt[5],t[e+6]=dt[6],t[e+7]=dt[7]}function wa(r,t){return dt[0]=r[t],dt[1]=r[t+1],dt[2]=r[t+2],dt[3]=r[t+3],dt[4]=r[t+4],dt[5]=r[t+5],dt[6]=r[t+6],dt[7]=r[t+7],gi[0]}var bf=BigInt(Number.MAX_SAFE_INTEGER),yf=BigInt(Number.MIN_SAFE_INTEGER),Nt=class r{lo;hi;constructor(t,e){this.lo=t|0,this.hi=e|0}toNumber(t=!1){if(!t&&this.hi>>>31>0){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(e+n*4294967296)}return this.lo+this.hi*4294967296}toBigInt(t=!1){if(t)return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n);if(this.hi>>>31){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(BigInt(e)+(BigInt(n)<<32n))}return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n)}toString(t=!1){return this.toBigInt(t).toString()}zzEncode(){let t=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^t)>>>0,this.lo=(this.lo<<1^t)>>>0,this}zzDecode(){let t=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^t)>>>0,this.hi=(this.hi>>>1^t)>>>0,this}length(){let t=this.lo,e=(this.lo>>>28|this.hi<<4)>>>0,n=this.hi>>>24;return n===0?e===0?t<16384?t<128?1:2:t<2097152?3:4:e<16384?e<128?5:6:e<2097152?7:8:n<128?9:10}static fromBigInt(t){if(t===0n)return Le;if(t<bf&&t>yf)return this.fromNumber(Number(t));let e=t<0n;e&&(t=-t);let n=t>>32n,s=t-(n<<32n);return e&&(n=~n|0n,s=~s|0n,++s>xa&&(s=0n,++n>xa&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(t){if(t===0)return Le;let e=t<0;e&&(t=-t);let n=t>>>0,s=(t-n)/4294967296>>>0;return e&&(s=~s>>>0,n=~n>>>0,++n>4294967295&&(n=0,++s>4294967295&&(s=0))),new r(n,s)}static from(t){return typeof t=="number"?r.fromNumber(t):typeof t=="bigint"?r.fromBigInt(t):typeof t=="string"?r.fromBigInt(BigInt(t)):t.low!=null||t.high!=null?new r(t.low>>>0,t.high>>>0):Le}},Le=new Nt(0,0);Le.toBigInt=function(){return 0n};Le.zzEncode=Le.zzDecode=function(){return this};Le.length=function(){return 1};var xa=4294967296n;function va(r){let t=0,e=0;for(let n=0;n<r.length;++n)e=r.charCodeAt(n),e<128?t+=1:e<2048?t+=2:(e&64512)===55296&&(r.charCodeAt(n+1)&64512)===56320?(++n,t+=4):t+=3;return t}function Ea(r,t,e){if(e-t<1)return"";let s,i=[],o=0,a;for(;t<e;)a=r[t++],a<128?i[o++]=a:a>191&&a<224?i[o++]=(a&31)<<6|r[t++]&63:a>239&&a<365?(a=((a&7)<<18|(r[t++]&63)<<12|(r[t++]&63)<<6|r[t++]&63)-65536,i[o++]=55296+(a>>10),i[o++]=56320+(a&1023)):i[o++]=(a&15)<<12|(r[t++]&63)<<6|r[t++]&63,o>8191&&((s??(s=[])).push(String.fromCharCode.apply(String,i)),o=0);return s!=null?(o>0&&s.push(String.fromCharCode.apply(String,i.slice(0,o))),s.join("")):String.fromCharCode.apply(String,i.slice(0,o))}function mi(r,t,e){let n=e,s,i;for(let o=0;o<r.length;++o)s=r.charCodeAt(o),s<128?t[e++]=s:s<2048?(t[e++]=s>>6|192,t[e++]=s&63|128):(s&64512)===55296&&((i=r.charCodeAt(o+1))&64512)===56320?(s=65536+((s&1023)<<10)+(i&1023),++o,t[e++]=s>>18|240,t[e++]=s>>12&63|128,t[e++]=s>>6&63|128,t[e++]=s&63|128):(t[e++]=s>>12|224,t[e++]=s>>6&63|128,t[e++]=s&63|128);return e-n}function Vt(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function hn(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var bi=class{buf;pos;len;_slice=Uint8Array.prototype.subarray;constructor(t){this.buf=t,this.pos=0,this.len=t.length}uint32(){let t=4294967295;if(t=(this.buf[this.pos]&127)>>>0,this.buf[this.pos++]<128||(t=(t|(this.buf[this.pos]&127)<<7)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<14)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<21)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&15)<<28)>>>0,this.buf[this.pos++]<128))return t;if((this.pos+=5)>this.len)throw this.pos=this.len,Vt(this,10);return t}int32(){return this.uint32()|0}sint32(){let t=this.uint32();return t>>>1^-(t&1)|0}bool(){return this.uint32()!==0}fixed32(){if(this.pos+4>this.len)throw Vt(this,4);return hn(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Vt(this,4);return hn(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Vt(this,4);let t=ba(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Vt(this,4);let t=wa(this.buf,this.pos);return this.pos+=8,t}bytes(){let t=this.uint32(),e=this.pos,n=this.pos+t;if(n>this.len)throw Vt(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return Ea(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw Vt(this,t);this.pos+=t}else do if(this.pos>=this.len)throw Vt(this);while(this.buf[this.pos++]&128);return this}skipType(t){switch(t){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;(t=this.uint32()&7)!==4;)this.skipType(t);break;case 5:this.skip(4);break;default:throw Error(`invalid wire type ${t} at offset ${this.pos}`)}return this}readLongVarint(){let t=new Nt(0,0),e=0;if(this.len-this.pos>4){for(;e<4;++e)if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t;if(t.lo=(t.lo|(this.buf[this.pos]&127)<<28)>>>0,t.hi=(t.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return t;e=0}else{for(;e<3;++e){if(this.pos>=this.len)throw Vt(this);if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t}return t.lo=(t.lo|(this.buf[this.pos++]&127)<<e*7)>>>0,t}if(this.len-this.pos>4){for(;e<5;++e)if(t.hi=(t.hi|(this.buf[this.pos]&127)<<e*7+3)>>>0,this.buf[this.pos++]<128)return t}else for(;e<5;++e){if(this.pos>=this.len)throw Vt(this);if(t.hi=(t.hi|(this.buf[this.pos]&127)<<e*7+3)>>>0,this.buf[this.pos++]<128)return t}throw Error("invalid varint encoding")}readFixed64(){if(this.pos+8>this.len)throw Vt(this,8);let t=hn(this.buf,this.pos+=4),e=hn(this.buf,this.pos+=4);return new Nt(t,e)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){let t=di(this.buf,this.pos);return this.pos+=Mt(t),t}uint64String(){return this.readLongVarint().toString(!0)}sint64(){return this.readLongVarint().zzDecode().toBigInt()}sint64Number(){return this.readLongVarint().zzDecode().toNumber()}sint64String(){return this.readLongVarint().zzDecode().toString()}fixed64(){return this.readFixed64().toBigInt()}fixed64Number(){return this.readFixed64().toNumber()}fixed64String(){return this.readFixed64().toString()}sfixed64(){return this.readFixed64().toBigInt()}sfixed64Number(){return this.readFixed64().toNumber()}sfixed64String(){return this.readFixed64().toString()}};function yi(r){return new bi(r instanceof Uint8Array?r:r.subarray())}function Bt(r,t,e){let n=yi(r);return t.decode(n,void 0,e)}var wi={};bt(wi,{base10:()=>wf});var wf=ce({prefix:"9",name:"base10",alphabet:"0123456789"});var xi={};bt(xi,{base16:()=>xf,base16upper:()=>vf});var xf=J({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),vf=J({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var vi={};bt(vi,{base2:()=>Ef});var Ef=J({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Ei={};bt(Ei,{base256emoji:()=>If});var Sa=Array.from("\u{1F680}\u{1FA90}\u2604\u{1F6F0}\u{1F30C}\u{1F311}\u{1F312}\u{1F313}\u{1F314}\u{1F315}\u{1F316}\u{1F317}\u{1F318}\u{1F30D}\u{1F30F}\u{1F30E}\u{1F409}\u2600\u{1F4BB}\u{1F5A5}\u{1F4BE}\u{1F4BF}\u{1F602}\u2764\u{1F60D}\u{1F923}\u{1F60A}\u{1F64F}\u{1F495}\u{1F62D}\u{1F618}\u{1F44D}\u{1F605}\u{1F44F}\u{1F601}\u{1F525}\u{1F970}\u{1F494}\u{1F496}\u{1F499}\u{1F622}\u{1F914}\u{1F606}\u{1F644}\u{1F4AA}\u{1F609}\u263A\u{1F44C}\u{1F917}\u{1F49C}\u{1F614}\u{1F60E}\u{1F607}\u{1F339}\u{1F926}\u{1F389}\u{1F49E}\u270C\u2728\u{1F937}\u{1F631}\u{1F60C}\u{1F338}\u{1F64C}\u{1F60B}\u{1F497}\u{1F49A}\u{1F60F}\u{1F49B}\u{1F642}\u{1F493}\u{1F929}\u{1F604}\u{1F600}\u{1F5A4}\u{1F603}\u{1F4AF}\u{1F648}\u{1F447}\u{1F3B6}\u{1F612}\u{1F92D}\u2763\u{1F61C}\u{1F48B}\u{1F440}\u{1F62A}\u{1F611}\u{1F4A5}\u{1F64B}\u{1F61E}\u{1F629}\u{1F621}\u{1F92A}\u{1F44A}\u{1F973}\u{1F625}\u{1F924}\u{1F449}\u{1F483}\u{1F633}\u270B\u{1F61A}\u{1F61D}\u{1F634}\u{1F31F}\u{1F62C}\u{1F643}\u{1F340}\u{1F337}\u{1F63B}\u{1F613}\u2B50\u2705\u{1F97A}\u{1F308}\u{1F608}\u{1F918}\u{1F4A6}\u2714\u{1F623}\u{1F3C3}\u{1F490}\u2639\u{1F38A}\u{1F498}\u{1F620}\u261D\u{1F615}\u{1F33A}\u{1F382}\u{1F33B}\u{1F610}\u{1F595}\u{1F49D}\u{1F64A}\u{1F639}\u{1F5E3}\u{1F4AB}\u{1F480}\u{1F451}\u{1F3B5}\u{1F91E}\u{1F61B}\u{1F534}\u{1F624}\u{1F33C}\u{1F62B}\u26BD\u{1F919}\u2615\u{1F3C6}\u{1F92B}\u{1F448}\u{1F62E}\u{1F646}\u{1F37B}\u{1F343}\u{1F436}\u{1F481}\u{1F632}\u{1F33F}\u{1F9E1}\u{1F381}\u26A1\u{1F31E}\u{1F388}\u274C\u270A\u{1F44B}\u{1F630}\u{1F928}\u{1F636}\u{1F91D}\u{1F6B6}\u{1F4B0}\u{1F353}\u{1F4A2}\u{1F91F}\u{1F641}\u{1F6A8}\u{1F4A8}\u{1F92C}\u2708\u{1F380}\u{1F37A}\u{1F913}\u{1F619}\u{1F49F}\u{1F331}\u{1F616}\u{1F476}\u{1F974}\u25B6\u27A1\u2753\u{1F48E}\u{1F4B8}\u2B07\u{1F628}\u{1F31A}\u{1F98B}\u{1F637}\u{1F57A}\u26A0\u{1F645}\u{1F61F}\u{1F635}\u{1F44E}\u{1F932}\u{1F920}\u{1F927}\u{1F4CC}\u{1F535}\u{1F485}\u{1F9D0}\u{1F43E}\u{1F352}\u{1F617}\u{1F911}\u{1F30A}\u{1F92F}\u{1F437}\u260E\u{1F4A7}\u{1F62F}\u{1F486}\u{1F446}\u{1F3A4}\u{1F647}\u{1F351}\u2744\u{1F334}\u{1F4A3}\u{1F438}\u{1F48C}\u{1F4CD}\u{1F940}\u{1F922}\u{1F445}\u{1F4A1}\u{1F4A9}\u{1F450}\u{1F4F8}\u{1F47B}\u{1F910}\u{1F92E}\u{1F3BC}\u{1F975}\u{1F6A9}\u{1F34E}\u{1F34A}\u{1F47C}\u{1F48D}\u{1F4E3}\u{1F942}"),Bf=Sa.reduce((r,t,e)=>(r[e]=t,r),[]),Sf=Sa.reduce((r,t,e)=>{let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);return r[n]=e,r},[]);function Af(r){return r.reduce((t,e)=>(t+=Bf[e],t),"")}function kf(r){let t=[];for(let e of r){let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);let s=Sf[n];if(s==null)throw new Error(`Non-base256emoji character: ${e}`);t.push(s)}return new Uint8Array(t)}var If=qe({prefix:"\u{1F680}",name:"base256emoji",encode:Af,decode:kf});var Bi={};bt(Bi,{base64:()=>Nf,base64pad:()=>Tf,base64url:()=>Cf,base64urlpad:()=>Uf});var Nf=J({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),Tf=J({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Cf=J({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Uf=J({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Si={};bt(Si,{base8:()=>Lf});var Lf=J({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Ai={};bt(Ai,{identity:()=>Rf});var Rf=qe({prefix:"\0",name:"identity",encode:r=>Co(r),decode:r=>To(r)});var O0=new TextEncoder,P0=new TextDecoder;var Ni={};bt(Ni,{sha256:()=>Re,sha512:()=>Mf});function Ii({name:r,code:t,encode:e}){return new ki(r,t,e)}var ki=class{name;code;encode;constructor(t,e,n){this.name=t,this.code=e,this.encode=n}digest(t){if(t instanceof Uint8Array){let e=this.encode(t);return e instanceof Uint8Array?Lt(this.code,e):e.then(n=>Lt(this.code,n))}else throw Error("Unknown type, must be binary type")}};function ka(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var Re=Ii({name:"sha2-256",code:18,encode:ka("SHA-256")}),Mf=Ii({name:"sha2-512",code:19,encode:ka("SHA-512")});var Ti={...Ai,...vi,...Si,...wi,...xi,...Hs,...Os,...Vs,...Bi,...Ei},X0={...Ni,...Ks};function Na(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var Ia=Na("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),Ci=Na("ascii","a",r=>{let t="a";for(let e=0;e<r.length;e++)t+=String.fromCharCode(r[e]);return t},r=>{r=r.substring(1);let t=ft(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),Vf={utf8:Ia,"utf-8":Ia,hex:Ti.base16,latin1:Ci,ascii:Ci,binary:Ci,...Ti},dn=Vf;function Y(r,t="utf8"){let e=dn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function Ui(r){let t=r??8192,e=t>>>1,n,s=t;return function(o){if(o<1||o>e)return ft(o);s+o>t&&(n=ft(t),s=0);let a=n.subarray(s,s+=o);return s&7&&(s=(s|7)+1),a}}var _e=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function Li(){}var _i=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},Hf=Ui();function Of(r){return globalThis.Buffer!=null?ft(r):Hf(r)}var vr=class{len;head;tail;states;constructor(){this.len=0,this.head=new _e(Li,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new _e(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new Di((t=t>>>0)<128?1:t<16384?2:t<2097152?3:t<268435456?4:5,t)).len,this}int32(t){return t<0?this._push(pn,10,Nt.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=Nt.fromBigInt(t);return this._push(pn,e.length(),e)}uint64Number(t){return this._push(hi,Mt(t),t)}uint64String(t){return this.uint64(BigInt(t))}int64(t){return this.uint64(t)}int64Number(t){return this.uint64Number(t)}int64String(t){return this.uint64String(t)}sint64(t){let e=Nt.fromBigInt(t).zzEncode();return this._push(pn,e.length(),e)}sint64Number(t){let e=Nt.fromNumber(t).zzEncode();return this._push(pn,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(Ri,1,t?1:0)}fixed32(t){return this._push(xr,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=Nt.fromBigInt(t);return this._push(xr,4,e.lo)._push(xr,4,e.hi)}fixed64Number(t){let e=Nt.fromNumber(t);return this._push(xr,4,e.lo)._push(xr,4,e.hi)}fixed64String(t){return this.fixed64(BigInt(t))}sfixed64(t){return this.fixed64(t)}sfixed64Number(t){return this.fixed64Number(t)}sfixed64String(t){return this.fixed64String(t)}float(t){return this._push(ma,4,t)}double(t){return this._push(ya,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(Ri,1,0):this.uint32(e)._push(Ff,e,t)}string(t){let e=va(t);return e!==0?this.uint32(e)._push(mi,e,t):this._push(Ri,1,0)}fork(){return this.states=new _i(this),this.head=this.tail=new _e(Li,0,0),this.len=0,this}reset(){return this.states!=null?(this.head=this.states.head,this.tail=this.states.tail,this.len=this.states.len,this.states=this.states.next):(this.head=this.tail=new _e(Li,0,0),this.len=0),this}ldelim(){let t=this.head,e=this.tail,n=this.len;return this.reset().uint32(n),n!==0&&(this.tail.next=t.next,this.tail=e,this.len+=n),this}finish(){let t=this.head.next,e=Of(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function Ri(r,t,e){t[e]=r&255}function Pf(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var Di=class extends _e{next;constructor(t,e){super(Pf,t,e),this.next=void 0}};function pn(r,t,e){for(;r.hi!==0;)t[e++]=r.lo&127|128,r.lo=(r.lo>>>7|r.hi<<25)>>>0,r.hi>>>=7;for(;r.lo>127;)t[e++]=r.lo&127|128,r.lo=r.lo>>>7;t[e++]=r.lo}function xr(r,t,e){t[e]=r&255,t[e+1]=r>>>8&255,t[e+2]=r>>>16&255,t[e+3]=r>>>24}function Ff(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(vr.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(Kf,t,r),this},vr.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(qf,t,r),this});function Kf(r,t,e){t.set(r,e)}function qf(r,t,e){r.length<40?mi(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(Y(r),e)}function Mi(){return new vr}function St(r,t){let e=Mi();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var tr;(function(r){r[r.VARINT=0]="VARINT",r[r.BIT64=1]="BIT64",r[r.LENGTH_DELIMITED=2]="LENGTH_DELIMITED",r[r.START_GROUP=3]="START_GROUP",r[r.END_GROUP=4]="END_GROUP",r[r.BIT32=5]="BIT32"})(tr||(tr={}));function gn(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function Vi(r){function t(s){if(r[s.toString()]==null)throw new Error("Invalid enum value");return r[s]}let e=function(i,o){let a=t(i);o.int32(a)},n=function(i){let o=i.int32();return t(o)};return gn("enum",tr.VARINT,e,n)}function At(r,t){return gn("message",tr.LENGTH_DELIMITED,r,t)}var Ct=class extends Error{code="ERR_MAX_LENGTH";name="MaxLengthError"};var nt;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.secp256k1="secp256k1"})(nt||(nt={}));var Hi;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1"})(Hi||(Hi={}));(function(r){r.codec=()=>Vi(Hi)})(nt||(nt={}));var Kt;(function(r){let t;r.codec=()=>(t==null&&(t=At((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),nt.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let i={},o=n==null?e.len:e.pos+n;for(;e.pos<o;){let a=e.uint32();switch(a>>>3){case 1:{i.Type=nt.codec().decode(e);break}case 2:{i.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return i})),t),r.encode=e=>St(e,r.codec()),r.decode=(e,n)=>Bt(e,r.codec(),n)})(Kt||(Kt={}));var Oi;(function(r){let t;r.codec=()=>(t==null&&(t=At((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),nt.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let i={},o=n==null?e.len:e.pos+n;for(;e.pos<o;){let a=e.uint32();switch(a>>>3){case 1:{i.Type=nt.codec().decode(e);break}case 2:{i.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return i})),t),r.encode=e=>St(e,r.codec()),r.decode=(e,n)=>Bt(e,r.codec(),n)})(Oi||(Oi={}));var Ur={};bt(Ur,{MAX_RSA_KEY_SIZE:()=>as,generateRSAKeyPair:()=>Ac,jwkToJWKKeyPair:()=>kc,jwkToPkcs1:()=>ih,jwkToPkix:()=>Wi,jwkToRSAPrivateKey:()=>Sc,pkcs1ToJwk:()=>vc,pkcs1ToRSAPrivateKey:()=>Bc,pkixToJwk:()=>Ec,pkixToRSAPublicKey:()=>ji});var zf=new Uint32Array([1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298]),ye=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),we=new Uint32Array(64),Pi=class extends Xe{constructor(){super(64,32,8,!1),this.A=ye[0]|0,this.B=ye[1]|0,this.C=ye[2]|0,this.D=ye[3]|0,this.E=ye[4]|0,this.F=ye[5]|0,this.G=ye[6]|0,this.H=ye[7]|0}get(){let{A:t,B:e,C:n,D:s,E:i,F:o,G:a,H:c}=this;return[t,e,n,s,i,o,a,c]}set(t,e,n,s,i,o,a,c){this.A=t|0,this.B=e|0,this.C=n|0,this.D=s|0,this.E=i|0,this.F=o|0,this.G=a|0,this.H=c|0}process(t,e){for(let u=0;u<16;u++,e+=4)we[u]=t.getUint32(e,!1);for(let u=16;u<64;u++){let d=we[u-15],m=we[u-2],x=Rt(d,7)^Rt(d,18)^d>>>3,y=Rt(m,17)^Rt(m,19)^m>>>10;we[u]=y+we[u-7]+x+we[u-16]|0}let{A:n,B:s,C:i,D:o,E:a,F:c,G:l,H:f}=this;for(let u=0;u<64;u++){let d=Rt(a,6)^Rt(a,11)^Rt(a,25),m=f+d+Zo(a,c,l)+zf[u]+we[u]|0,y=(Rt(n,2)^Rt(n,13)^Rt(n,22))+Wo(n,s,i)|0;f=l,l=c,c=a,a=o+m|0,o=i,i=s,s=n,n=m+y|0}n=n+this.A|0,s=s+this.B|0,i=i+this.C|0,o=o+this.D|0,a=a+this.E|0,c=c+this.F|0,l=l+this.G|0,f=f+this.H|0,this.set(n,s,i,o,a,c,l,f)}roundClean(){we.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var er=Qr(()=>new Pi);var O=Bo(Ca());function De(r,t){let e=0;if(r.length===1)return r[0];for(let n=r.length-1;n>=0;n--)e+=r[r.length-1-n]*Math.pow(2,t*n);return e}function xe(r,t,e=-1){let n=e,s=r,i=0,o=Math.pow(2,t);for(let a=1;a<8;a++){if(r<o){let c;if(n<0)c=new ArrayBuffer(a),i=a;else{if(n<a)return new ArrayBuffer(0);c=new ArrayBuffer(n),i=n}let l=new Uint8Array(c);for(let f=a-1;f>=0;f--){let u=Math.pow(2,f*t);l[i-f-1]=Math.floor(s/u),s-=l[i-f-1]*u}return c}o*=Math.pow(2,t)}return new ArrayBuffer(0)}function yn(...r){let t=0,e=0;for(let i of r)t+=i.length;let n=new ArrayBuffer(t),s=new Uint8Array(n);for(let i of r)s.set(i,e),e+=i.length;return s}function Ki(){let r=new Uint8Array(this.valueHex);if(this.valueHex.byteLength>=2){let a=r[0]===255&&r[1]&128,c=r[0]===0&&(r[1]&128)===0;(a||c)&&this.warnings.push("Needlessly long format")}let t=new ArrayBuffer(this.valueHex.byteLength),e=new Uint8Array(t);for(let a=0;a<this.valueHex.byteLength;a++)e[a]=0;e[0]=r[0]&128;let n=De(e,8),s=new ArrayBuffer(this.valueHex.byteLength),i=new Uint8Array(s);for(let a=0;a<this.valueHex.byteLength;a++)i[a]=r[a];return i[0]&=127,De(i,8)-n}function Ua(r){let t=r<0?r*-1:r,e=128;for(let n=1;n<8;n++){if(t<=e){if(r<0){let o=e-t,a=xe(o,8,n),c=new Uint8Array(a);return c[0]|=128,a}let s=xe(t,8,n),i=new Uint8Array(s);if(i[0]&128){let o=s.slice(0),a=new Uint8Array(o);s=new ArrayBuffer(s.byteLength+1),i=new Uint8Array(s);for(let c=0;c<o.byteLength;c++)i[c+1]=a[c];i[0]=0}return s}e*=Math.pow(2,8)}return new ArrayBuffer(0)}function La(r,t){if(r.byteLength!==t.byteLength)return!1;let e=new Uint8Array(r),n=new Uint8Array(t);for(let s=0;s<e.length;s++)if(e[s]!==n[s])return!1;return!0}function kt(r,t){let e=r.toString(10);if(t<e.length)return"";let n=t-e.length,s=new Array(n);for(let o=0;o<n;o++)s[o]="0";return s.join("").concat(e)}var Rp=Math.log(2);function wn(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function qi(r){let t=0,e=0;for(let s=0;s<r.length;s++){let i=r[s];t+=i.byteLength}let n=new Uint8Array(t);for(let s=0;s<r.length;s++){let i=r[s];n.set(new Uint8Array(i),e),e+=i.byteLength}return n.buffer}function se(r,t,e,n){return t instanceof Uint8Array?t.byteLength?e<0?(r.error="Wrong parameter: inputOffset less than zero",!1):n<0?(r.error="Wrong parameter: inputLength less than zero",!1):t.byteLength-e-n<0?(r.error="End of input reached before message was fully decoded (inconsistent offset and length values)",!1):!0:(r.error="Wrong parameter: inputBuffer has zero length",!1):(r.error="Wrong parameter: inputBuffer must be 'Uint8Array'",!1)}var Br=class{constructor(){this.items=[]}write(t){this.items.push(t)}final(){return qi(this.items)}},Er=[new Uint8Array([1])],Ra="0123456789";var or="",Ht=new ArrayBuffer(0),zi=new Uint8Array(0),Sr="EndOfContent",Da="OCTET STRING",Ma="BIT STRING";function ie(r){var t;return t=class extends r{constructor(...n){var s;super(...n);let i=n[0]||{};this.isHexOnly=(s=i.isHexOnly)!==null&&s!==void 0?s:!1,this.valueHexView=i.valueHex?O.BufferSourceConverter.toUint8Array(i.valueHex):zi}get valueHex(){return this.valueHexView.slice().buffer}set valueHex(n){this.valueHexView=new Uint8Array(n)}fromBER(n,s,i){let o=n instanceof ArrayBuffer?new Uint8Array(n):n;if(!se(this,o,s,i))return-1;let a=s+i;return this.valueHexView=o.subarray(s,a),this.valueHexView.length?(this.blockLength=i,a):(this.warnings.push("Zero buffer length"),s)}toBER(n=!1){return this.isHexOnly?n?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.byteLength===this.valueHexView.buffer.byteLength?this.valueHexView.buffer:this.valueHexView.slice().buffer:(this.error="Flag 'isHexOnly' is not set, abort",Ht)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:O.Convert.ToHex(this.valueHexView)}}},t.NAME="hexBlock",t}var ee=class{constructor({blockLength:t=0,error:e=or,warnings:n=[],valueBeforeDecode:s=zi}={}){this.blockLength=t,this.error=e,this.warnings=n,this.valueBeforeDecodeView=O.BufferSourceConverter.toUint8Array(s)}static blockName(){return this.NAME}get valueBeforeDecode(){return this.valueBeforeDecodeView.slice().buffer}set valueBeforeDecode(t){this.valueBeforeDecodeView=new Uint8Array(t)}toJSON(){return{blockName:this.constructor.NAME,blockLength:this.blockLength,error:this.error,warnings:this.warnings,valueBeforeDecode:O.Convert.ToHex(this.valueBeforeDecodeView)}}};ee.NAME="baseBlock";var pt=class extends ee{fromBER(t,e,n){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}toBER(t,e){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}};pt.NAME="valueBlock";var xn=class extends ie(ee){constructor({idBlock:t={}}={}){var e,n,s,i;super(),t?(this.isHexOnly=(e=t.isHexOnly)!==null&&e!==void 0?e:!1,this.valueHexView=t.valueHex?O.BufferSourceConverter.toUint8Array(t.valueHex):zi,this.tagClass=(n=t.tagClass)!==null&&n!==void 0?n:-1,this.tagNumber=(s=t.tagNumber)!==null&&s!==void 0?s:-1,this.isConstructed=(i=t.isConstructed)!==null&&i!==void 0?i:!1):(this.tagClass=-1,this.tagNumber=-1,this.isConstructed=!1)}toBER(t=!1){let e=0;switch(this.tagClass){case 1:e|=0;break;case 2:e|=64;break;case 3:e|=128;break;case 4:e|=192;break;default:return this.error="Unknown tag class",Ht}if(this.isConstructed&&(e|=32),this.tagNumber<31&&!this.isHexOnly){let s=new Uint8Array(1);if(!t){let i=this.tagNumber;i&=31,e|=i,s[0]=e}return s.buffer}if(!this.isHexOnly){let s=xe(this.tagNumber,7),i=new Uint8Array(s),o=s.byteLength,a=new Uint8Array(o+1);if(a[0]=e|31,!t){for(let c=0;c<o-1;c++)a[c+1]=i[c]|128;a[o]=i[o-1]}return a.buffer}let n=new Uint8Array(this.valueHexView.byteLength+1);if(n[0]=e|31,!t){let s=this.valueHexView;for(let i=0;i<s.length-1;i++)n[i+1]=s[i]|128;n[this.valueHexView.byteLength]=s[s.length-1]}return n.buffer}fromBER(t,e,n){let s=O.BufferSourceConverter.toUint8Array(t);if(!se(this,s,e,n))return-1;let i=s.subarray(e,e+n);if(i.length===0)return this.error="Zero buffer length",-1;switch(i[0]&192){case 0:this.tagClass=1;break;case 64:this.tagClass=2;break;case 128:this.tagClass=3;break;case 192:this.tagClass=4;break;default:return this.error="Unknown tag class",-1}this.isConstructed=(i[0]&32)===32,this.isHexOnly=!1;let a=i[0]&31;if(a!==31)this.tagNumber=a,this.blockLength=1;else{let c=1,l=this.valueHexView=new Uint8Array(255),f=255;for(;i[c]&128;){if(l[c-1]=i[c]&127,c++,c>=i.length)return this.error="End of input reached before message was fully decoded",-1;if(c===f){f+=255;let d=new Uint8Array(f);for(let m=0;m<l.length;m++)d[m]=l[m];l=this.valueHexView=new Uint8Array(f)}}this.blockLength=c+1,l[c-1]=i[c]&127;let u=new Uint8Array(c);for(let d=0;d<c;d++)u[d]=l[d];l=this.valueHexView=new Uint8Array(c),l.set(u),this.blockLength<=9?this.tagNumber=De(l,7):(this.isHexOnly=!0,this.warnings.push("Tag too long, represented as hex-coded"))}if(this.tagClass===1&&this.isConstructed)switch(this.tagNumber){case 1:case 2:case 5:case 6:case 9:case 13:case 14:case 23:case 24:case 31:case 32:case 33:case 34:return this.error="Constructed encoding used for primitive type",-1}return e+this.blockLength}toJSON(){return{...super.toJSON(),tagClass:this.tagClass,tagNumber:this.tagNumber,isConstructed:this.isConstructed}}};xn.NAME="identificationBlock";var vn=class extends ee{constructor({lenBlock:t={}}={}){var e,n,s;super(),this.isIndefiniteForm=(e=t.isIndefiniteForm)!==null&&e!==void 0?e:!1,this.longFormUsed=(n=t.longFormUsed)!==null&&n!==void 0?n:!1,this.length=(s=t.length)!==null&&s!==void 0?s:0}fromBER(t,e,n){let s=O.BufferSourceConverter.toUint8Array(t);if(!se(this,s,e,n))return-1;let i=s.subarray(e,e+n);if(i.length===0)return this.error="Zero buffer length",-1;if(i[0]===255)return this.error="Length block 0xFF is reserved by standard",-1;if(this.isIndefiniteForm=i[0]===128,this.isIndefiniteForm)return this.blockLength=1,e+this.blockLength;if(this.longFormUsed=!!(i[0]&128),this.longFormUsed===!1)return this.length=i[0],this.blockLength=1,e+this.blockLength;let o=i[0]&127;if(o>8)return this.error="Too big integer",-1;if(o+1>i.length)return this.error="End of input reached before message was fully decoded",-1;let a=e+1,c=s.subarray(a,a+o);return c[o-1]===0&&this.warnings.push("Needlessly long encoded length"),this.length=De(c,8),this.longFormUsed&&this.length<=127&&this.warnings.push("Unnecessary usage of long length form"),this.blockLength=o+1,e+this.blockLength}toBER(t=!1){let e,n;if(this.length>127&&(this.longFormUsed=!0),this.isIndefiniteForm)return e=new ArrayBuffer(1),t===!1&&(n=new Uint8Array(e),n[0]=128),e;if(this.longFormUsed){let s=xe(this.length,8);if(s.byteLength>127)return this.error="Too big length",Ht;if(e=new ArrayBuffer(s.byteLength+1),t)return e;let i=new Uint8Array(s);n=new Uint8Array(e),n[0]=s.byteLength|128;for(let o=0;o<s.byteLength;o++)n[o+1]=i[o];return e}return e=new ArrayBuffer(1),t===!1&&(n=new Uint8Array(e),n[0]=this.length),e}toJSON(){return{...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,longFormUsed:this.longFormUsed,length:this.length}}};vn.NAME="lengthBlock";var S={},ct=class extends ee{constructor({name:t=or,optional:e=!1,primitiveSchema:n,...s}={},i){super(s),this.name=t,this.optional=e,n&&(this.primitiveSchema=n),this.idBlock=new xn(s),this.lenBlock=new vn(s),this.valueBlock=i?new i(s):new pt(s)}fromBER(t,e,n){let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}toBER(t,e){let n=e||new Br;e||Va(this);let s=this.idBlock.toBER(t);if(n.write(s),this.lenBlock.isIndefiniteForm)n.write(new Uint8Array([128]).buffer),this.valueBlock.toBER(t,n),n.write(new ArrayBuffer(2));else{let i=this.valueBlock.toBER(t);this.lenBlock.length=i.byteLength;let o=this.lenBlock.toBER(t);n.write(o),n.write(i)}return e?Ht:n.final()}toJSON(){let t={...super.toJSON(),idBlock:this.idBlock.toJSON(),lenBlock:this.lenBlock.toJSON(),valueBlock:this.valueBlock.toJSON(),name:this.name,optional:this.optional};return this.primitiveSchema&&(t.primitiveSchema=this.primitiveSchema.toJSON()),t}toString(t="ascii"){return t==="ascii"?this.onAsciiEncoding():O.Convert.ToHex(this.toBER())}onAsciiEncoding(){return`${this.constructor.NAME} : ${O.Convert.ToHex(this.valueBlock.valueBeforeDecodeView)}`}isEqual(t){if(this===t)return!0;if(!(t instanceof this.constructor))return!1;let e=this.toBER(),n=t.toBER();return La(e,n)}};ct.NAME="BaseBlock";function Va(r){if(r instanceof S.Constructed)for(let t of r.valueBlock.value)Va(t)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var En=class extends ct{constructor({value:t=or,...e}={},n){super(e,n),t&&this.fromString(t)}getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}fromBER(t,e,n){let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.fromBuffer(this.valueBlock.valueHexView),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}onAsciiEncoding(){return`${this.constructor.NAME} : '${this.valueBlock.value}'`}};En.NAME="BaseStringBlock";var Bn=class extends ie(pt){constructor({isHexOnly:t=!0,...e}={}){super(e),this.isHexOnly=t}};Bn.NAME="PrimitiveValueBlock";var Ha,Sn=class extends ct{constructor(t={}){super(t,Bn),this.idBlock.isConstructed=!1}};Ha=Sn;S.Primitive=Ha;Sn.NAME="PRIMITIVE";function Qf(r,t){if(r instanceof t)return r;let e=new t;return e.idBlock=r.idBlock,e.lenBlock=r.lenBlock,e.warnings=r.warnings,e.valueBeforeDecodeView=r.valueBeforeDecodeView,e}function ss(r,t=0,e=r.length){let n=t,s=new ct({},pt),i=new ee;if(!se(i,r,t,e))return s.error=i.error,{offset:-1,result:s};if(!r.subarray(t,t+e).length)return s.error="Zero buffer length",{offset:-1,result:s};let a=s.idBlock.fromBER(r,t,e);if(s.idBlock.warnings.length&&s.warnings.concat(s.idBlock.warnings),a===-1)return s.error=s.idBlock.error,{offset:-1,result:s};if(t=a,e-=s.idBlock.blockLength,a=s.lenBlock.fromBER(r,t,e),s.lenBlock.warnings.length&&s.warnings.concat(s.lenBlock.warnings),a===-1)return s.error=s.lenBlock.error,{offset:-1,result:s};if(t=a,e-=s.lenBlock.blockLength,!s.idBlock.isConstructed&&s.lenBlock.isIndefiniteForm)return s.error="Indefinite length form used for primitive encoding form",{offset:-1,result:s};let c=ct;switch(s.idBlock.tagClass){case 1:if(s.idBlock.tagNumber>=37&&s.idBlock.isHexOnly===!1)return s.error="UNIVERSAL 37 and upper tags are reserved by ASN.1 standard",{offset:-1,result:s};switch(s.idBlock.tagNumber){case 0:if(s.idBlock.isConstructed&&s.lenBlock.length>0)return s.error="Type [UNIVERSAL 0] is reserved",{offset:-1,result:s};c=S.EndOfContent;break;case 1:c=S.Boolean;break;case 2:c=S.Integer;break;case 3:c=S.BitString;break;case 4:c=S.OctetString;break;case 5:c=S.Null;break;case 6:c=S.ObjectIdentifier;break;case 10:c=S.Enumerated;break;case 12:c=S.Utf8String;break;case 13:c=S.RelativeObjectIdentifier;break;case 14:c=S.TIME;break;case 15:return s.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:s};case 16:c=S.Sequence;break;case 17:c=S.Set;break;case 18:c=S.NumericString;break;case 19:c=S.PrintableString;break;case 20:c=S.TeletexString;break;case 21:c=S.VideotexString;break;case 22:c=S.IA5String;break;case 23:c=S.UTCTime;break;case 24:c=S.GeneralizedTime;break;case 25:c=S.GraphicString;break;case 26:c=S.VisibleString;break;case 27:c=S.GeneralString;break;case 28:c=S.UniversalString;break;case 29:c=S.CharacterString;break;case 30:c=S.BmpString;break;case 31:c=S.DATE;break;case 32:c=S.TimeOfDay;break;case 33:c=S.DateTime;break;case 34:c=S.Duration;break;default:{let l=s.idBlock.isConstructed?new S.Constructed:new S.Primitive;l.idBlock=s.idBlock,l.lenBlock=s.lenBlock,l.warnings=s.warnings,s=l}}break;case 2:case 3:case 4:default:c=s.idBlock.isConstructed?S.Constructed:S.Primitive}return s=Qf(s,c),a=s.fromBER(r,t,s.lenBlock.isIndefiniteForm?e:s.lenBlock.length),s.valueBeforeDecodeView=r.subarray(n,n+s.blockLength),{offset:a,result:s}}function $i(r){if(!r.byteLength){let t=new ct({},pt);return t.error="Input buffer has zero length",{offset:-1,result:t}}return ss(O.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function th(r,t){return r?1:t}var qt=class extends pt{constructor({value:t=[],isIndefiniteForm:e=!1,...n}={}){super(n),this.value=t,this.isIndefiniteForm=e}fromBER(t,e,n){let s=O.BufferSourceConverter.toUint8Array(t);if(!se(this,s,e,n))return-1;if(this.valueBeforeDecodeView=s.subarray(e,e+n),this.valueBeforeDecodeView.length===0)return this.warnings.push("Zero buffer length"),e;let i=e;for(;th(this.isIndefiniteForm,n)>0;){let o=ss(s,i,n);if(o.offset===-1)return this.error=o.result.error,this.warnings.concat(o.result.warnings),-1;if(i=o.offset,this.blockLength+=o.result.blockLength,n-=o.result.blockLength,this.value.push(o.result),this.isIndefiniteForm&&o.result.constructor.NAME===Sr)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===Sr?this.value.pop():this.warnings.push("No EndOfContent block encoded")),i}toBER(t,e){let n=e||new Br;for(let s=0;s<this.value.length;s++)this.value[s].toBER(t,n);return e?Ht:n.final()}toJSON(){let t={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let e of this.value)t.value.push(e.toJSON());return t}};qt.NAME="ConstructedValueBlock";var Oa,ve=class extends ct{constructor(t={}){super(t,qt),this.idBlock.isConstructed=!0}fromBER(t,e,n){this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm;let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}onAsciiEncoding(){let t=[];for(let n of this.valueBlock.value)t.push(n.toString("ascii").split(`
3
3
  `).map(s=>` ${s}`).join(`
4
4
  `));let e=this.idBlock.tagClass===3?`[${this.idBlock.tagNumber}]`:this.constructor.NAME;return t.length?`${e} :
5
5
  ${t.join(`
6
- `)}`:`${e} :`}};Ha=ve;S.Constructed=Ha;ve.NAME="CONSTRUCTED";var An=class extends pt{fromBER(t,e,n){return e}toBER(t){return Ht}};An.override="EndOfContentValueBlock";var Oa,kn=class extends ct{constructor(t={}){super(t,An),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};Oa=kn;S.EndOfContent=Oa;kn.NAME=Sr;var Pa,nr=class extends ct{constructor(t={}){super(t,pt),this.idBlock.tagClass=1,this.idBlock.tagNumber=5}fromBER(t,e,n){return this.lenBlock.length>0&&this.warnings.push("Non-zero length of value block for Null type"),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.blockLength+=n,e+n>t.byteLength?(this.error="End of input reached before message was fully decoded (inconsistent offset and length values)",-1):e+n}toBER(t,e){let n=new ArrayBuffer(2);if(!t){let s=new Uint8Array(n);s[0]=5,s[1]=0}return e&&e.write(n),n}onAsciiEncoding(){return`${this.constructor.NAME}`}};Pa=nr;S.Null=Pa;nr.NAME="NULL";var In=class extends ie(pt){constructor({value:t,...e}={}){super(e),e.valueHex?this.valueHexView=O.BufferSourceConverter.toUint8Array(e.valueHex):this.valueHexView=new Uint8Array(1),t&&(this.value=t)}get value(){for(let t of this.valueHexView)if(t>0)return!0;return!1}set value(t){this.valueHexView[0]=t?255:0}fromBER(t,e,n){let s=O.BufferSourceConverter.toUint8Array(t);return se(this,s,e,n)?(this.valueHexView=s.subarray(e,e+n),n>1&&this.warnings.push("Boolean value encoded in more then 1 octet"),this.isHexOnly=!0,Ki.call(this),this.blockLength=n,e+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};In.NAME="BooleanValueBlock";var Fa,Nn=class extends ct{constructor(t={}){super(t,In),this.idBlock.tagClass=1,this.idBlock.tagNumber=1}getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.getValue}`}};Fa=Nn;S.Boolean=Fa;Nn.NAME="BOOLEAN";var Tn=class extends ie(qt){constructor({isConstructed:t=!1,...e}={}){super(e),this.isConstructed=t}fromBER(t,e,n){let s=0;if(this.isConstructed){if(this.isHexOnly=!1,s=qt.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let i=0;i<this.value.length;i++){let o=this.value[i].constructor.NAME;if(o===Sr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(o!==_a)return this.error="OCTET STRING may consists of OCTET STRINGs only",-1}}else this.isHexOnly=!0,s=super.fromBER(t,e,n),this.blockLength=n;return s}toBER(t,e){return this.isConstructed?qt.prototype.toBER.call(this,t,e):t?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};Tn.NAME="OctetStringValueBlock";var Ka,Cn=class r extends ct{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,i;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((i=n.value)===null||i===void 0)&&i.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},Tn),this.idBlock.tagClass=1,this.idBlock.tagNumber=4}fromBER(t,e,n){if(this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,n===0)return this.idBlock.error.length===0&&(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length===0&&(this.blockLength+=this.lenBlock.blockLength),e;if(!this.valueBlock.isConstructed){let i=(t instanceof ArrayBuffer?new Uint8Array(t):t).subarray(e,e+n);try{if(i.byteLength){let o=ss(i,0,i.byteLength);o.offset!==-1&&o.offset===n&&(this.valueBlock.value=[o.result])}}catch{}}return super.fromBER(t,e,n)}onAsciiEncoding(){return this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length?ve.prototype.onAsciiEncoding.call(this):`${this.constructor.NAME} : ${O.Convert.ToHex(this.valueBlock.valueHexView)}`}getValue(){if(!this.idBlock.isConstructed)return this.valueBlock.valueHexView.slice().buffer;let t=[];for(let e of this.valueBlock.value)e instanceof r&&t.push(e.valueBlock.valueHexView);return O.BufferSourceConverter.concat(t)}};Ka=Cn;S.OctetString=Ka;Cn.NAME=_a;var Un=class extends ie(qt){constructor({unusedBits:t=0,isConstructed:e=!1,...n}={}){super(n),this.unusedBits=t,this.isConstructed=e,this.blockLength=this.valueHexView.byteLength}fromBER(t,e,n){if(!n)return e;let s=-1;if(this.isConstructed){if(s=qt.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let a of this.value){let c=a.constructor.NAME;if(c===Sr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==Da)return this.error="BIT STRING may consists of BIT STRINGs only",-1;let l=a.valueBlock;if(this.unusedBits>0&&l.unusedBits>0)return this.error='Using of "unused bits" inside constructive BIT STRING allowed for least one only',-1;this.unusedBits=l.unusedBits}return s}let i=O.BufferSourceConverter.toUint8Array(t);if(!se(this,i,e,n))return-1;let o=i.subarray(e,e+n);if(this.unusedBits=o[0],this.unusedBits>7)return this.error="Unused bits for BitString must be in range 0-7",-1;if(!this.unusedBits){let a=o.subarray(1);try{if(a.byteLength){let c=ss(a,0,a.byteLength);c.offset!==-1&&c.offset===n-1&&(this.value=[c.result])}}catch{}}return this.valueHexView=o.subarray(1),this.blockLength=o.length,e+n}toBER(t,e){if(this.isConstructed)return qt.prototype.toBER.call(this,t,e);if(t)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return Ht;let n=new Uint8Array(this.valueHexView.length+1);return n[0]=this.unusedBits,n.set(this.valueHexView,1),n.buffer}toJSON(){return{...super.toJSON(),unusedBits:this.unusedBits,isConstructed:this.isConstructed}}};Un.NAME="BitStringValueBlock";var qa,sr=class extends ct{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,i;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((i=n.value)===null||i===void 0)&&i.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},Un),this.idBlock.tagClass=1,this.idBlock.tagNumber=3}fromBER(t,e,n){return this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,super.fromBER(t,e,n)}onAsciiEncoding(){if(this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length)return ve.prototype.onAsciiEncoding.call(this);{let t=[],e=this.valueBlock.valueHexView;for(let s of e)t.push(s.toString(2).padStart(8,"0"));let n=t.join("");return`${this.constructor.NAME} : ${n.substring(0,n.length-this.valueBlock.unusedBits)}`}}};qa=sr;S.BitString=qa;sr.NAME=Da;var za;function th(r,t){let e=new Uint8Array([0]),n=new Uint8Array(r),s=new Uint8Array(t),i=n.slice(0),o=i.length-1,a=s.slice(0),c=a.length-1,l=0,f=c<o?o:c,u=0;for(let d=f;d>=0;d--,u++){switch(!0){case u<a.length:l=i[o-u]+a[c-u]+e[0];break;default:l=i[o-u]+e[0]}switch(e[0]=l/10,!0){case u>=i.length:i=yn(new Uint8Array([l%10]),i);break;default:i[o-u]=l%10}}return e[0]>0&&(i=yn(e,i)),i}function Ra(r){if(r>=Er.length)for(let t=Er.length;t<=r;t++){let e=new Uint8Array([0]),n=Er[t-1].slice(0);for(let s=n.length-1;s>=0;s--){let i=new Uint8Array([(n[s]<<1)+e[0]]);e[0]=i[0]/10,n[s]=i[0]%10}e[0]>0&&(n=yn(e,n)),Er.push(n)}return Er[r]}function eh(r,t){let e=0,n=new Uint8Array(r),s=new Uint8Array(t),i=n.slice(0),o=i.length-1,a=s.slice(0),c=a.length-1,l,f=0;for(let u=c;u>=0;u--,f++)switch(l=i[o-f]-a[c-f]-e,!0){case l<0:e=1,i[o-f]=l+10;break;default:e=0,i[o-f]=l}if(e>0)for(let u=o-c+1;u>=0;u--,f++)if(l=i[o-f]-e,l<0)e=1,i[o-f]=l+10;else{e=0,i[o-f]=l;break}return i.slice()}var Ar=class extends ie(pt){constructor({value:t,...e}={}){super(e),this._valueDec=0,e.valueHex&&this.setValueHex(),t!==void 0&&(this.valueDec=t)}setValueHex(){this.valueHexView.length>=4?(this.warnings.push("Too big Integer for decoding, hex only"),this.isHexOnly=!0,this._valueDec=0):(this.isHexOnly=!1,this.valueHexView.length>0&&(this._valueDec=Ki.call(this)))}set valueDec(t){this._valueDec=t,this.isHexOnly=!1,this.valueHexView=new Uint8Array(Ca(t))}get valueDec(){return this._valueDec}fromDER(t,e,n,s=0){let i=this.fromBER(t,e,n);if(i===-1)return i;let o=this.valueHexView;return o[0]===0&&o[1]&128?this.valueHexView=o.subarray(1):s!==0&&o.length<s&&(s-o.length>1&&(s=o.length+1),this.valueHexView=o.subarray(s-o.length)),i}toDER(t=!1){let e=this.valueHexView;switch(!0){case(e[0]&128)!==0:{let n=new Uint8Array(this.valueHexView.length+1);n[0]=0,n.set(e,1),this.valueHexView=n}break;case(e[0]===0&&(e[1]&128)===0):this.valueHexView=this.valueHexView.subarray(1);break}return this.toBER(t)}fromBER(t,e,n){let s=super.fromBER(t,e,n);return s===-1||this.setValueHex(),s}toBER(t){return t?new ArrayBuffer(this.valueHexView.length):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}toString(){let t=this.valueHexView.length*8-1,e=new Uint8Array(this.valueHexView.length*8/3),n=0,s,i=this.valueHexView,o="",a=!1;for(let c=i.byteLength-1;c>=0;c--){s=i[c];for(let l=0;l<8;l++){if((s&1)===1)switch(n){case t:e=eh(Ra(n),e),o="-";break;default:e=th(e,Ra(n))}n++,s>>=1}}for(let c=0;c<e.length;c++)e[c]&&(a=!0),a&&(o+=La.charAt(e[c]));return a===!1&&(o+=La.charAt(0)),o}};za=Ar;Ar.NAME="IntegerValueBlock";Object.defineProperty(za.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var $a,ut=class r extends ct{constructor(t={}){super(t,Ar),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return wn(),BigInt(this.valueBlock.toString())}static fromBigInt(t){wn();let e=BigInt(t),n=new Br,s=e.toString(16).replace(/^-/,""),i=new Uint8Array(O.Convert.FromHex(s));if(e<0){let a=new Uint8Array(i.length+(i[0]&128?1:0));a[0]|=128;let l=BigInt(`0x${O.Convert.ToHex(a)}`)+e,f=O.BufferSourceConverter.toUint8Array(O.Convert.FromHex(l.toString(16)));f[0]|=128,n.write(f)}else i[0]&128&&n.write(new Uint8Array([0])),n.write(i);return new r({valueHex:n.final()})}convertToDER(){let t=new r({valueHex:this.valueBlock.valueHexView});return t.valueBlock.toDER(),t}convertFromDER(){return new r({valueHex:this.valueBlock.valueHexView[0]===0?this.valueBlock.valueHexView.subarray(1):this.valueBlock.valueHexView})}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()}`}};$a=ut;S.Integer=$a;ut.NAME="INTEGER";var Ga,Ln=class extends ut{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};Ga=Ln;S.Enumerated=Ga;Ln.NAME="ENUMERATED";var kr=class extends ie(pt){constructor({valueDec:t=-1,isFirstSid:e=!1,...n}={}){super(n),this.valueDec=t,this.isFirstSid=e}fromBER(t,e,n){if(!n)return e;let s=O.BufferSourceConverter.toUint8Array(t);if(!se(this,s,e,n))return-1;let i=s.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=i[a]&127,this.blockLength++,!!(i[a]&128));a++);let o=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)o[a]=this.valueHexView[a];return this.valueHexView=o,i[this.blockLength-1]&128?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=De(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}set valueBigInt(t){wn();let e=BigInt(t).toString(2);for(;e.length%7;)e="0"+e;let n=new Uint8Array(e.length/7);for(let s=0;s<n.length;s++)n[s]=parseInt(e.slice(s*7,s*7+7),2)+(s+1<n.length?128:0);this.fromBER(n.buffer,0,n.length)}toBER(t){if(this.isHexOnly){if(t)return new ArrayBuffer(this.valueHexView.byteLength);let s=this.valueHexView,i=new Uint8Array(this.blockLength);for(let o=0;o<this.blockLength-1;o++)i[o]=s[o]|128;return i[this.blockLength-1]=s[this.blockLength-1],i.buffer}let e=xe(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Ht;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),i=e.byteLength-1;for(let o=0;o<i;o++)n[o]=s[o]|128;n[i]=s[i]}return n}toString(){let t="";if(this.isHexOnly)t=O.Convert.ToHex(this.valueHexView);else if(this.isFirstSid){let e=this.valueDec;this.valueDec<=39?t="0.":this.valueDec<=79?(t="1.",e-=40):(t="2.",e-=80),t+=e.toString()}else t=this.valueDec.toString();return t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec,isFirstSid:this.isFirstSid}}};kr.NAME="sidBlock";var Rn=class extends pt{constructor({value:t=or,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let i=new kr;if(s=i.fromBER(t,s,n),s===-1)return this.blockLength=0,this.error=i.error,s;this.value.length===0&&(i.isFirstSid=!0),this.blockLength+=i.blockLength,n-=i.blockLength,this.value.push(i)}return s}toBER(t){let e=[];for(let n=0;n<this.value.length;n++){let s=this.value[n].toBER(t);if(s.byteLength===0)return this.error=this.value[n].error,Ht;e.push(s)}return qi(e)}fromString(t){this.value=[];let e=0,n=0,s="",i=!1;do if(n=t.indexOf(".",e),n===-1?s=t.substring(e):s=t.substring(e,n),e=n+1,i){let o=this.value[0],a=0;switch(o.valueDec){case 0:break;case 1:a=40;break;case 2:a=80;break;default:this.value=[];return}let c=parseInt(s,10);if(isNaN(c))return;o.valueDec=c+a,i=!1}else{let o=new kr;if(s>Number.MAX_SAFE_INTEGER){wn();let a=BigInt(s);o.valueBigInt=a}else if(o.valueDec=parseInt(s,10),isNaN(o.valueDec))return;this.value.length||(o.isFirstSid=!0,i=!0),this.value.push(o)}while(n!==-1)}toString(){let t="",e=!1;for(let n=0;n<this.value.length;n++){e=this.value[n].isHexOnly;let s=this.value[n].toString();n!==0&&(t=`${t}.`),e?(s=`{${s}}`,this.value[n].isFirstSid?t=`2.{${s} - 80}`:t+=s):t+=s}return t}toJSON(){let t={...super.toJSON(),value:this.toString(),sidArray:[]};for(let e=0;e<this.value.length;e++)t.sidArray.push(this.value[e].toJSON());return t}};Rn.NAME="ObjectIdentifierValueBlock";var Za,ir=class extends ct{constructor(t={}){super(t,Rn),this.idBlock.tagClass=1,this.idBlock.tagNumber=6}getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};Za=ir;S.ObjectIdentifier=Za;ir.NAME="OBJECT IDENTIFIER";var Ir=class extends ie(ee){constructor({valueDec:t=0,...e}={}){super(e),this.valueDec=t}fromBER(t,e,n){if(n===0)return e;let s=O.BufferSourceConverter.toUint8Array(t);if(!se(this,s,e,n))return-1;let i=s.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=i[a]&127,this.blockLength++,!!(i[a]&128));a++);let o=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)o[a]=this.valueHexView[a];return this.valueHexView=o,i[this.blockLength-1]&128?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=De(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}toBER(t){if(this.isHexOnly){if(t)return new ArrayBuffer(this.valueHexView.byteLength);let s=this.valueHexView,i=new Uint8Array(this.blockLength);for(let o=0;o<this.blockLength-1;o++)i[o]=s[o]|128;return i[this.blockLength-1]=s[this.blockLength-1],i.buffer}let e=xe(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Ht;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),i=e.byteLength-1;for(let o=0;o<i;o++)n[o]=s[o]|128;n[i]=s[i]}return n.buffer}toString(){let t="";return this.isHexOnly?t=O.Convert.ToHex(this.valueHexView):t=this.valueDec.toString(),t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};Ir.NAME="relativeSidBlock";var _n=class extends pt{constructor({value:t=or,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let i=new Ir;if(s=i.fromBER(t,s,n),s===-1)return this.blockLength=0,this.error=i.error,s;this.blockLength+=i.blockLength,n-=i.blockLength,this.value.push(i)}return s}toBER(t,e){let n=[];for(let s=0;s<this.value.length;s++){let i=this.value[s].toBER(t);if(i.byteLength===0)return this.error=this.value[s].error,Ht;n.push(i)}return qi(n)}fromString(t){this.value=[];let e=0,n=0,s="";do{n=t.indexOf(".",e),n===-1?s=t.substring(e):s=t.substring(e,n),e=n+1;let i=new Ir;if(i.valueDec=parseInt(s,10),isNaN(i.valueDec))return!0;this.value.push(i)}while(n!==-1);return!0}toString(){let t="",e=!1;for(let n=0;n<this.value.length;n++){e=this.value[n].isHexOnly;let s=this.value[n].toString();n!==0&&(t=`${t}.`),e&&(s=`{${s}}`),t+=s}return t}toJSON(){let t={...super.toJSON(),value:this.toString(),sidArray:[]};for(let e=0;e<this.value.length;e++)t.sidArray.push(this.value[e].toJSON());return t}};_n.NAME="RelativeObjectIdentifierValueBlock";var Wa,Dn=class extends ct{constructor(t={}){super(t,_n),this.idBlock.tagClass=1,this.idBlock.tagNumber=13}getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};Wa=Dn;S.RelativeObjectIdentifier=Wa;Dn.NAME="RelativeObjectIdentifier";var ja,re=class extends ve{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};ja=re;S.Sequence=ja;re.NAME="SEQUENCE";var Ya,Mn=class extends ve{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};Ya=Mn;S.Set=Ya;Mn.NAME="SET";var Vn=class extends ie(pt){constructor({...t}={}){super(t),this.isHexOnly=!0,this.value=or}toJSON(){return{...super.toJSON(),value:this.value}}};Vn.NAME="StringValueBlock";var Hn=class extends Vn{};Hn.NAME="SimpleStringValueBlock";var yt=class extends En{constructor({...t}={}){super(t,Hn)}fromBuffer(t){this.valueBlock.value=String.fromCharCode.apply(null,O.BufferSourceConverter.toUint8Array(t))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e);for(let s=0;s<e;s++)n[s]=t.charCodeAt(s);this.valueBlock.value=t}};yt.NAME="SIMPLE STRING";var On=class extends yt{fromBuffer(t){this.valueBlock.valueHexView=O.BufferSourceConverter.toUint8Array(t);try{this.valueBlock.value=O.Convert.ToUtf8String(t)}catch(e){this.warnings.push(`Error during "decodeURIComponent": ${e}, using raw string`),this.valueBlock.value=O.Convert.ToBinary(t)}}fromString(t){this.valueBlock.valueHexView=new Uint8Array(O.Convert.FromUtf8String(t)),this.valueBlock.value=t}};On.NAME="Utf8StringValueBlock";var Ja,ne=class extends On{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};Ja=ne;S.Utf8String=Ja;ne.NAME="UTF8String";var Pn=class extends yt{fromBuffer(t){this.valueBlock.value=O.Convert.ToUtf16String(t),this.valueBlock.valueHexView=O.BufferSourceConverter.toUint8Array(t)}fromString(t){this.valueBlock.value=t,this.valueBlock.valueHexView=new Uint8Array(O.Convert.FromUtf16String(t))}};Pn.NAME="BmpStringValueBlock";var Xa,Fn=class extends Pn{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};Xa=Fn;S.BmpString=Xa;Fn.NAME="BMPString";var Kn=class extends yt{fromBuffer(t){let e=ArrayBuffer.isView(t)?t.slice().buffer:t.slice(0),n=new Uint8Array(e);for(let s=0;s<n.length;s+=4)n[s]=n[s+3],n[s+1]=n[s+2],n[s+2]=0,n[s+3]=0;this.valueBlock.value=String.fromCharCode.apply(null,new Uint32Array(e))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e*4);for(let s=0;s<e;s++){let i=xe(t.charCodeAt(s),8),o=new Uint8Array(i);if(o.length>4)continue;let a=4-o.length;for(let c=o.length-1;c>=0;c--)n[s*4+c+a]=o[c]}this.valueBlock.value=t}};Kn.NAME="UniversalStringValueBlock";var Qa,qn=class extends Kn{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};Qa=qn;S.UniversalString=Qa;qn.NAME="UniversalString";var tc,zn=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};tc=zn;S.NumericString=tc;zn.NAME="NumericString";var ec,$n=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};ec=$n;S.PrintableString=ec;$n.NAME="PrintableString";var rc,Gn=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};rc=Gn;S.TeletexString=rc;Gn.NAME="TeletexString";var nc,Zn=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};nc=Zn;S.VideotexString=nc;Zn.NAME="VideotexString";var sc,Wn=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};sc=Wn;S.IA5String=sc;Wn.NAME="IA5String";var ic,jn=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};ic=jn;S.GraphicString=ic;jn.NAME="GraphicString";var oc,Nr=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};oc=Nr;S.VisibleString=oc;Nr.NAME="VisibleString";var ac,Yn=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};ac=Yn;S.GeneralString=ac;Yn.NAME="GeneralString";var cc,Jn=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};cc=Jn;S.CharacterString=cc;Jn.NAME="CharacterString";var uc,Tr=class extends Nr{constructor({value:t,valueDate:e,...n}={}){if(super(n),this.year=0,this.month=0,this.day=0,this.hour=0,this.minute=0,this.second=0,t){this.fromString(t),this.valueBlock.valueHexView=new Uint8Array(t.length);for(let s=0;s<t.length;s++)this.valueBlock.valueHexView[s]=t.charCodeAt(s)}e&&(this.fromDate(e),this.valueBlock.valueHexView=new Uint8Array(this.toBuffer())),this.idBlock.tagClass=1,this.idBlock.tagNumber=23}fromBuffer(t){this.fromString(String.fromCharCode.apply(null,O.BufferSourceConverter.toUint8Array(t)))}toBuffer(){let t=this.toString(),e=new ArrayBuffer(t.length),n=new Uint8Array(e);for(let s=0;s<t.length;s++)n[s]=t.charCodeAt(s);return e}fromDate(t){this.year=t.getUTCFullYear(),this.month=t.getUTCMonth()+1,this.day=t.getUTCDate(),this.hour=t.getUTCHours(),this.minute=t.getUTCMinutes(),this.second=t.getUTCSeconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second))}fromString(t){let n=/(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})Z/ig.exec(t);if(n===null){this.error="Wrong input string for conversion";return}let s=parseInt(n[1],10);s>=50?this.year=1900+s:this.year=2e3+s,this.month=parseInt(n[2],10),this.day=parseInt(n[3],10),this.hour=parseInt(n[4],10),this.minute=parseInt(n[5],10),this.second=parseInt(n[6],10)}toString(t="iso"){if(t==="iso"){let e=new Array(7);return e[0]=kt(this.year<2e3?this.year-1900:this.year-2e3,2),e[1]=kt(this.month,2),e[2]=kt(this.day,2),e[3]=kt(this.hour,2),e[4]=kt(this.minute,2),e[5]=kt(this.second,2),e[6]="Z",e.join("")}return super.toString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.toDate().toISOString()}`}toJSON(){return{...super.toJSON(),year:this.year,month:this.month,day:this.day,hour:this.hour,minute:this.minute,second:this.second}}};uc=Tr;S.UTCTime=uc;Tr.NAME="UTCTime";var lc,Xn=class extends Tr{constructor(t={}){var e;super(t),(e=this.millisecond)!==null&&e!==void 0||(this.millisecond=0),this.idBlock.tagClass=1,this.idBlock.tagNumber=24}fromDate(t){super.fromDate(t),this.millisecond=t.getUTCMilliseconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second,this.millisecond))}fromString(t){let e=!1,n="",s="",i=0,o,a=0,c=0;if(t[t.length-1]==="Z")n=t.substring(0,t.length-1),e=!0;else{let u=new Number(t[t.length-1]);if(isNaN(u.valueOf()))throw new Error("Wrong input string for conversion");n=t}if(e){if(n.indexOf("+")!==-1)throw new Error("Wrong input string for conversion");if(n.indexOf("-")!==-1)throw new Error("Wrong input string for conversion")}else{let u=1,d=n.indexOf("+"),m="";if(d===-1&&(d=n.indexOf("-"),u=-1),d!==-1){if(m=n.substring(d+1),n=n.substring(0,d),m.length!==2&&m.length!==4)throw new Error("Wrong input string for conversion");let x=parseInt(m.substring(0,2),10);if(isNaN(x.valueOf()))throw new Error("Wrong input string for conversion");if(a=u*x,m.length===4){if(x=parseInt(m.substring(2,4),10),isNaN(x.valueOf()))throw new Error("Wrong input string for conversion");c=u*x}}}let l=n.indexOf(".");if(l===-1&&(l=n.indexOf(",")),l!==-1){let u=new Number(`0${n.substring(l)}`);if(isNaN(u.valueOf()))throw new Error("Wrong input string for conversion");i=u.valueOf(),s=n.substring(0,l)}else s=n;switch(!0){case s.length===8:if(o=/(\d{4})(\d{2})(\d{2})/ig,l!==-1)throw new Error("Wrong input string for conversion");break;case s.length===10:if(o=/(\d{4})(\d{2})(\d{2})(\d{2})/ig,l!==-1){let u=60*i;this.minute=Math.floor(u),u=60*(u-this.minute),this.second=Math.floor(u),u=1e3*(u-this.second),this.millisecond=Math.floor(u)}break;case s.length===12:if(o=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})/ig,l!==-1){let u=60*i;this.second=Math.floor(u),u=1e3*(u-this.second),this.millisecond=Math.floor(u)}break;case s.length===14:if(o=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})/ig,l!==-1){let u=1e3*i;this.millisecond=Math.floor(u)}break;default:throw new Error("Wrong input string for conversion")}let f=o.exec(s);if(f===null)throw new Error("Wrong input string for conversion");for(let u=1;u<f.length;u++)switch(u){case 1:this.year=parseInt(f[u],10);break;case 2:this.month=parseInt(f[u],10);break;case 3:this.day=parseInt(f[u],10);break;case 4:this.hour=parseInt(f[u],10)+a;break;case 5:this.minute=parseInt(f[u],10)+c;break;case 6:this.second=parseInt(f[u],10);break;default:throw new Error("Wrong input string for conversion")}if(e===!1){let u=new Date(this.year,this.month,this.day,this.hour,this.minute,this.second,this.millisecond);this.year=u.getUTCFullYear(),this.month=u.getUTCMonth(),this.day=u.getUTCDay(),this.hour=u.getUTCHours(),this.minute=u.getUTCMinutes(),this.second=u.getUTCSeconds(),this.millisecond=u.getUTCMilliseconds()}}toString(t="iso"){if(t==="iso"){let e=[];return e.push(kt(this.year,4)),e.push(kt(this.month,2)),e.push(kt(this.day,2)),e.push(kt(this.hour,2)),e.push(kt(this.minute,2)),e.push(kt(this.second,2)),this.millisecond!==0&&(e.push("."),e.push(kt(this.millisecond,3))),e.push("Z"),e.join("")}return super.toString(t)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};lc=Xn;S.GeneralizedTime=lc;Xn.NAME="GeneralizedTime";var fc,Qn=class extends ne{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};fc=Qn;S.DATE=fc;Qn.NAME="DATE";var hc,ts=class extends ne{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};hc=ts;S.TimeOfDay=hc;ts.NAME="TimeOfDay";var dc,es=class extends ne{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};dc=es;S.DateTime=dc;es.NAME="DateTime";var pc,rs=class extends ne{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};pc=rs;S.Duration=pc;rs.NAME="Duration";var gc,ns=class extends ne{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};gc=ns;S.TIME=gc;ns.NAME="TIME";function Ot(r,t="utf8"){let e=dn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}function is(r){if(isNaN(r)||r<=0)throw new et("random bytes length must be a Number bigger than 0");return Je(r)}var Cr=class extends Error{constructor(t="An error occurred while verifying a message"){super(t),this.name="VerificationError"}},os=class extends Error{constructor(t="Missing Web Crypto API"){super(t),this.name="WebCryptoMissingError"}};var mc={get(r=globalThis){let t=r.crypto;if(t?.subtle==null)throw new os("Missing Web Crypto API. The most likely cause of this error is that this page is being accessed from an insecure context (i.e. not HTTPS). For more information and possible resolutions see https://github.com/libp2p/js-libp2p/blob/main/packages/crypto/README.md#web-crypto-api");return t}};var Ee=mc;async function bc(r){let t=await Ee.get().subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:r,publicExponent:new Uint8Array([1,0,1]),hash:{name:"SHA-256"}},!0,["sign","verify"]),e=await nh(t);return{privateKey:e[0],publicKey:e[1]}}async function yc(r,t){let e=await Ee.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await Ee.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},e,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(n,0,n.byteLength)}async function wc(r,t,e){let n=await Ee.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return Ee.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,t,e instanceof Uint8Array?e:e.subarray())}async function nh(r){if(r.privateKey==null||r.publicKey==null)throw new et("Private and public key are required");return Promise.all([Ee.get().subtle.exportKey("jwk",r.privateKey),Ee.get().subtle.exportKey("jwk",r.publicKey)])}function Gi(r){if(r.kty!=="RSA")throw new et("invalid key type");if(r.n==null)throw new et("invalid key modulus");return Y(r.n,"base64url").length*8}var ar=class{type="RSA";_key;_raw;_multihash;constructor(t,e){this._key=t,this._multihash=e}get raw(){return this._raw==null&&(this._raw=Ur.jwkToPkix(this._key)),this._raw}toMultihash(){return this._multihash}toCID(){return It.createV1(114,this._multihash)}toString(){return Q.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:Tt(this.raw,t.raw)}verify(t,e){return wc(this._key,e,t)}},Lr=class{type="RSA";_key;_raw;publicKey;constructor(t,e){this._key=t,this.publicKey=e}get raw(){return this._raw==null&&(this._raw=Ur.jwkToPkcs1(this._key)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:Tt(this.raw,t.raw)}sign(t){return yc(this._key,t)}};var as=8192,Zi=18;function xc(r){let{result:t}=$i(r),e=t.valueBlock.value;return{n:zt(e[1]),e:zt(e[2]),d:zt(e[3]),p:zt(e[4]),q:zt(e[5]),dp:zt(e[6]),dq:zt(e[7]),qi:zt(e[8]),kty:"RSA",alg:"RS256"}}function sh(r){if(r.n==null||r.e==null||r.d==null||r.p==null||r.q==null||r.dp==null||r.dq==null||r.qi==null)throw new et("JWK was missing components");let e=new re({value:[new ut({value:0}),ut.fromBigInt($t(Y(r.n,"base64url"))),ut.fromBigInt($t(Y(r.e,"base64url"))),ut.fromBigInt($t(Y(r.d,"base64url"))),ut.fromBigInt($t(Y(r.p,"base64url"))),ut.fromBigInt($t(Y(r.q,"base64url"))),ut.fromBigInt($t(Y(r.dp,"base64url"))),ut.fromBigInt($t(Y(r.dq,"base64url"))),ut.fromBigInt($t(Y(r.qi,"base64url")))]}).toBER();return new Uint8Array(e,0,e.byteLength)}function vc(r){let{result:t}=$i(r),e=t.valueBlock.value[1].valueBlock.value[0].valueBlock.value;return{kty:"RSA",n:zt(e[0]),e:zt(e[1])}}function Wi(r){if(r.n==null||r.e==null)throw new et("JWK was missing components");let e=new re({value:[new re({value:[new ir({value:"1.2.840.113549.1.1.1"}),new nr]}),new sr({valueHex:new re({value:[ut.fromBigInt($t(Y(r.n,"base64url"))),ut.fromBigInt($t(Y(r.e,"base64url")))]}).toBER()})]}).toBER();return new Uint8Array(e,0,e.byteLength)}function zt(r){let t=r.valueBlock.valueHexView;for(;t[0]===0;)t=t.subarray(1);return Ot(t,"base64url")}function $t(r){let t=[];return r.forEach(function(e){let n=e.toString(16);n.length%2>0&&(n=`0${n}`),t.push(n)}),BigInt("0x"+t.join(""))}function Ec(r){let t=xc(r);return Bc(t)}function ji(r){let t=vc(r);if(Gi(t)>as)throw new Fe("Key size is too large");let e=er(Kt.encode({Type:nt.RSA,Data:r})),n=Lt(Zi,e);return new ar(t,n)}function Bc(r){if(Gi(r)>as)throw new et("Key size is too large");let t=Ac(r),e=er(Kt.encode({Type:nt.RSA,Data:Wi(t.publicKey)})),n=Lt(Zi,e);return new Lr(t.privateKey,new ar(t.publicKey,n))}async function Sc(r){if(r>as)throw new et("Key size is too large");let t=await bc(r),e=er(Kt.encode({Type:nt.RSA,Data:Wi(t.publicKey)})),n=Lt(Zi,e);return new Lr(t.privateKey,new ar(t.publicKey,n))}function Ac(r){if(r==null)throw new et("Missing key parameter");return{privateKey:r,publicKey:{kty:r.kty,n:r.n,e:r.e}}}var cs=class extends Ye{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,qo(t);let n=mr(e);if(this.iHash=t.create(),typeof this.iHash.update!="function")throw new Error("Expected instance of class which extends utils.Hash");this.blockLen=this.iHash.blockLen,this.outputLen=this.iHash.outputLen;let s=this.blockLen,i=new Uint8Array(s);i.set(n.length>s?t.create().update(n).digest():n);for(let o=0;o<i.length;o++)i[o]^=54;this.iHash.update(i),this.oHash=t.create();for(let o=0;o<i.length;o++)i[o]^=106;this.oHash.update(i),i.fill(0)}update(t){return je(this),this.iHash.update(t),this}digestInto(t){je(this),We(t,this.outputLen),this.finished=!0,this.iHash.digestInto(t),this.oHash.update(t),this.oHash.digestInto(t),this.destroy()}digest(){let t=new Uint8Array(this.oHash.outputLen);return this.digestInto(t),t}_cloneInto(t){t||(t=Object.create(Object.getPrototypeOf(this),{}));let{oHash:e,iHash:n,finished:s,destroyed:i,blockLen:o,outputLen:a}=this;return t=t,t.finished=s,t.destroyed=i,t.blockLen=o,t.outputLen=a,t.oHash=e._cloneInto(t.oHash),t.iHash=n._cloneInto(t.iHash),t}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},Yi=(r,t,e)=>new cs(r,t).update(e).digest();Yi.create=(r,t)=>new cs(r,t);function kc(r){r.lowS!==void 0&&_t("lowS",r.lowS),r.prehash!==void 0&&_t("prehash",r.prehash)}function ih(r){let t=wr(r);Ft(t,{a:"field",b:"field"},{allowedPrivateKeyLengths:"array",wrapPrivateKey:"boolean",isTorsionFree:"function",clearCofactor:"function",allowInfinityPoint:"boolean",fromBytes:"function",toBytes:"function"});let{endo:e,Fp:n,a:s}=t;if(e){if(!n.eql(s,n.ZERO))throw new Error("invalid endomorphism, can only be defined for Koblitz curves that have a=0");if(typeof e!="object"||typeof e.beta!="bigint"||typeof e.splitScalar!="function")throw new Error("invalid endomorphism, expected beta: bigint and splitScalar: function")}return Object.freeze({...t})}var{bytesToNumberBE:oh,hexToBytes:ah}=nn,Ji=class extends Error{constructor(t=""){super(t)}},oe={Err:Ji,_tlv:{encode:(r,t)=>{let{Err:e}=oe;if(r<0||r>256)throw new e("tlv.encode: wrong tag");if(t.length&1)throw new e("tlv.encode: unpadded data");let n=t.length/2,s=ke(n);if(s.length/2&128)throw new e("tlv.encode: long form length too big");let i=n>127?ke(s.length/2|128):"";return ke(r)+i+s+t},decode(r,t){let{Err:e}=oe,n=0;if(r<0||r>256)throw new e("tlv.encode: wrong tag");if(t.length<2||t[n++]!==r)throw new e("tlv.decode: wrong tlv");let s=t[n++],i=!!(s&128),o=0;if(!i)o=s;else{let c=s&127;if(!c)throw new e("tlv.decode(long): indefinite length not supported");if(c>4)throw new e("tlv.decode(long): byte length is too big");let l=t.subarray(n,n+c);if(l.length!==c)throw new e("tlv.decode: length bytes not complete");if(l[0]===0)throw new e("tlv.decode(long): zero leftmost byte");for(let f of l)o=o<<8|f;if(n+=c,o<128)throw new e("tlv.decode(long): not minimal encoding")}let a=t.subarray(n,n+o);if(a.length!==o)throw new e("tlv.decode: wrong value length");return{v:a,l:t.subarray(n+o)}}},_int:{encode(r){let{Err:t}=oe;if(r<ae)throw new t("integer: negative integers are not allowed");let e=ke(r);if(Number.parseInt(e[0],16)&8&&(e="00"+e),e.length&1)throw new t("unexpected DER parsing assertion: unpadded hex");return e},decode(r){let{Err:t}=oe;if(r[0]&128)throw new t("invalid signature integer: negative");if(r[0]===0&&!(r[1]&128))throw new t("invalid signature integer: unnecessary leading zero");return oh(r)}},toSig(r){let{Err:t,_int:e,_tlv:n}=oe,s=typeof r=="string"?ah(r):r;Qe(s);let{v:i,l:o}=n.decode(48,s);if(o.length)throw new t("invalid signature: left bytes after parsing");let{v:a,l:c}=n.decode(2,i),{v:l,l:f}=n.decode(2,c);if(f.length)throw new t("invalid signature: left bytes after parsing");return{r:e.decode(a),s:e.decode(l)}},hexFromSig(r){let{_tlv:t,_int:e}=oe,n=t.encode(2,e.encode(r.r)),s=t.encode(2,e.encode(r.s)),i=n+s;return t.encode(48,i)}},ae=BigInt(0),ot=BigInt(1),lg=BigInt(2),Ic=BigInt(3),fg=BigInt(4);function ch(r){let t=ih(r),{Fp:e}=t,n=me(t.n,t.nBitLength),s=t.toBytes||((y,h,w)=>{let E=h.toAffine();return Xt(Uint8Array.from([4]),e.toBytes(E.x),e.toBytes(E.y))}),i=t.fromBytes||(y=>{let h=y.subarray(1),w=e.fromBytes(h.subarray(0,e.BYTES)),E=e.fromBytes(h.subarray(e.BYTES,2*e.BYTES));return{x:w,y:E}});function o(y){let{a:h,b:w}=t,E=e.sqr(y),g=e.mul(E,y);return e.add(e.add(g,e.mul(y,h)),w)}if(!e.eql(e.sqr(t.Gy),o(t.Gx)))throw new Error("bad generator point: equation left != right");function a(y){return br(y,ot,t.n)}function c(y){let{allowedPrivateKeyLengths:h,nByteLength:w,wrapPrivateKey:E,n:g}=t;if(h&&typeof y!="bigint"){if(de(y)&&(y=Yt(y)),typeof y!="string"||!h.includes(y.length))throw new Error("invalid private key");y=y.padStart(w*2,"0")}let k;try{k=typeof y=="bigint"?y:Jt(j("private key",y,w))}catch{throw new Error("invalid private key, expected hex or "+w+" bytes, got "+typeof y)}return E&&(k=z(k,g)),vt("private key",k,ot,g),k}function l(y){if(!(y instanceof d))throw new Error("ProjectivePoint expected")}let f=Te((y,h)=>{let{px:w,py:E,pz:g}=y;if(e.eql(g,e.ONE))return{x:w,y:E};let k=y.is0();h==null&&(h=k?e.ONE:e.inv(g));let U=e.mul(w,h),L=e.mul(E,h),I=e.mul(g,h);if(k)return{x:e.ZERO,y:e.ZERO};if(!e.eql(I,e.ONE))throw new Error("invZ was invalid");return{x:U,y:L}}),u=Te(y=>{if(y.is0()){if(t.allowInfinityPoint&&!e.is0(y.py))return;throw new Error("bad point: ZERO")}let{x:h,y:w}=y.toAffine();if(!e.isValid(h)||!e.isValid(w))throw new Error("bad point: x or y not FE");let E=e.sqr(w),g=o(h);if(!e.eql(E,g))throw new Error("bad point: equation left != right");if(!y.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});class d{constructor(h,w,E){if(this.px=h,this.py=w,this.pz=E,h==null||!e.isValid(h))throw new Error("x required");if(w==null||!e.isValid(w))throw new Error("y required");if(E==null||!e.isValid(E))throw new Error("z required");Object.freeze(this)}static fromAffine(h){let{x:w,y:E}=h||{};if(!h||!e.isValid(w)||!e.isValid(E))throw new Error("invalid affine point");if(h instanceof d)throw new Error("projective point not allowed");let g=k=>e.eql(k,e.ZERO);return g(w)&&g(E)?d.ZERO:new d(w,E,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(h){let w=e.invertBatch(h.map(E=>E.pz));return h.map((E,g)=>E.toAffine(w[g])).map(d.fromAffine)}static fromHex(h){let w=d.fromAffine(i(j("pointHex",h)));return w.assertValidity(),w}static fromPrivateKey(h){return d.BASE.multiply(c(h))}static msm(h,w){return cn(d,n,h,w)}_setWindowSize(h){x.setWindowSize(this,h)}assertValidity(){u(this)}hasEvenY(){let{y:h}=this.toAffine();if(e.isOdd)return!e.isOdd(h);throw new Error("Field doesn't support isOdd")}equals(h){l(h);let{px:w,py:E,pz:g}=this,{px:k,py:U,pz:L}=h,I=e.eql(e.mul(w,L),e.mul(k,g)),C=e.eql(e.mul(E,L),e.mul(U,g));return I&&C}negate(){return new d(this.px,e.neg(this.py),this.pz)}double(){let{a:h,b:w}=t,E=e.mul(w,Ic),{px:g,py:k,pz:U}=this,L=e.ZERO,I=e.ZERO,C=e.ZERO,N=e.mul(g,g),G=e.mul(k,k),F=e.mul(U,U),H=e.mul(g,k);return H=e.add(H,H),C=e.mul(g,U),C=e.add(C,C),L=e.mul(h,C),I=e.mul(E,F),I=e.add(L,I),L=e.sub(G,I),I=e.add(G,I),I=e.mul(L,I),L=e.mul(H,L),C=e.mul(E,C),F=e.mul(h,F),H=e.sub(N,F),H=e.mul(h,H),H=e.add(H,C),C=e.add(N,N),N=e.add(C,N),N=e.add(N,F),N=e.mul(N,H),I=e.add(I,N),F=e.mul(k,U),F=e.add(F,F),N=e.mul(F,H),L=e.sub(L,N),C=e.mul(F,G),C=e.add(C,C),C=e.add(C,C),new d(L,I,C)}add(h){l(h);let{px:w,py:E,pz:g}=this,{px:k,py:U,pz:L}=h,I=e.ZERO,C=e.ZERO,N=e.ZERO,G=t.a,F=e.mul(t.b,Ic),H=e.mul(w,k),tt=e.mul(E,U),B=e.mul(g,L),T=e.add(w,E),b=e.add(k,U);T=e.mul(T,b),b=e.add(H,tt),T=e.sub(T,b),b=e.add(w,g);let p=e.add(k,L);return b=e.mul(b,p),p=e.add(H,B),b=e.sub(b,p),p=e.add(E,g),I=e.add(U,L),p=e.mul(p,I),I=e.add(tt,B),p=e.sub(p,I),N=e.mul(G,b),I=e.mul(F,B),N=e.add(I,N),I=e.sub(tt,N),N=e.add(tt,N),C=e.mul(I,N),tt=e.add(H,H),tt=e.add(tt,H),B=e.mul(G,B),b=e.mul(F,b),tt=e.add(tt,B),B=e.sub(H,B),B=e.mul(G,B),b=e.add(b,B),H=e.mul(tt,b),C=e.add(C,H),H=e.mul(p,b),I=e.mul(T,I),I=e.sub(I,H),H=e.mul(T,tt),N=e.mul(p,N),N=e.add(N,H),new d(I,C,N)}subtract(h){return this.add(h.negate())}is0(){return this.equals(d.ZERO)}wNAF(h){return x.wNAFCached(this,h,d.normalizeZ)}multiplyUnsafe(h){let{endo:w,n:E}=t;vt("scalar",h,ae,E);let g=d.ZERO;if(h===ae)return g;if(this.is0()||h===ot)return this;if(!w||x.hasPrecomputes(this))return x.wNAFCachedUnsafe(this,h,d.normalizeZ);let{k1neg:k,k1:U,k2neg:L,k2:I}=w.splitScalar(h),C=g,N=g,G=this;for(;U>ae||I>ae;)U&ot&&(C=C.add(G)),I&ot&&(N=N.add(G)),G=G.double(),U>>=ot,I>>=ot;return k&&(C=C.negate()),L&&(N=N.negate()),N=new d(e.mul(N.px,w.beta),N.py,N.pz),C.add(N)}multiply(h){let{endo:w,n:E}=t;vt("scalar",h,ot,E);let g,k;if(w){let{k1neg:U,k1:L,k2neg:I,k2:C}=w.splitScalar(h),{p:N,f:G}=this.wNAF(L),{p:F,f:H}=this.wNAF(C);N=x.constTimeNegate(U,N),F=x.constTimeNegate(I,F),F=new d(e.mul(F.px,w.beta),F.py,F.pz),g=N.add(F),k=G.add(H)}else{let{p:U,f:L}=this.wNAF(h);g=U,k=L}return d.normalizeZ([g,k])[0]}multiplyAndAddUnsafe(h,w,E){let g=d.BASE,k=(L,I)=>I===ae||I===ot||!L.equals(g)?L.multiplyUnsafe(I):L.multiply(I),U=k(this,w).add(k(h,E));return U.is0()?void 0:U}toAffine(h){return f(this,h)}isTorsionFree(){let{h,isTorsionFree:w}=t;if(h===ot)return!0;if(w)return w(d,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h,clearCofactor:w}=t;return h===ot?this:w?w(d,this):this.multiplyUnsafe(t.h)}toRawBytes(h=!0){return _t("isCompressed",h),this.assertValidity(),s(d,this,h)}toHex(h=!0){return _t("isCompressed",h),Yt(this.toRawBytes(h))}}d.BASE=new d(t.Gx,t.Gy,e.ONE),d.ZERO=new d(e.ZERO,e.ONE,e.ZERO);let m=t.nBitLength,x=an(d,t.endo?Math.ceil(m/2):m);return{CURVE:t,ProjectivePoint:d,normPrivateKeyToScalar:c,weierstrassEquation:o,isWithinCurveOrder:a}}function uh(r){let t=wr(r);return Ft(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function Nc(r){let t=uh(r),{Fp:e,n}=t,s=e.BYTES+1,i=2*e.BYTES+1;function o(B){return z(B,n)}function a(B){return sn(B,n)}let{ProjectivePoint:c,normPrivateKeyToScalar:l,weierstrassEquation:f,isWithinCurveOrder:u}=ch({...t,toBytes(B,T,b){let p=T.toAffine(),v=e.toBytes(p.x),A=Xt;return _t("isCompressed",b),b?A(Uint8Array.from([T.hasEvenY()?2:3]),v):A(Uint8Array.from([4]),v,e.toBytes(p.y))},fromBytes(B){let T=B.length,b=B[0],p=B.subarray(1);if(T===s&&(b===2||b===3)){let v=Jt(p);if(!br(v,ot,e.ORDER))throw new Error("Point is not on curve");let A=f(v),R;try{R=e.sqrt(A)}catch(P){let D=P instanceof Error?": "+P.message:"";throw new Error("Point is not on curve"+D)}let _=(R&ot)===ot;return(b&1)===1!==_&&(R=e.neg(R)),{x:v,y:R}}else if(T===i&&b===4){let v=e.fromBytes(p.subarray(0,e.BYTES)),A=e.fromBytes(p.subarray(e.BYTES,2*e.BYTES));return{x:v,y:A}}else{let v=s,A=i;throw new Error("invalid Point, expected length of "+v+", or uncompressed "+A+", got "+T)}}}),d=B=>Yt(ge(B,t.nByteLength));function m(B){let T=n>>ot;return B>T}function x(B){return m(B)?o(-B):B}let y=(B,T,b)=>Jt(B.slice(T,b));class h{constructor(T,b,p){this.r=T,this.s=b,this.recovery=p,this.assertValidity()}static fromCompact(T){let b=t.nByteLength;return T=j("compactSignature",T,b*2),new h(y(T,0,b),y(T,b,2*b))}static fromDER(T){let{r:b,s:p}=oe.toSig(j("DER",T));return new h(b,p)}assertValidity(){vt("r",this.r,ot,n),vt("s",this.s,ot,n)}addRecoveryBit(T){return new h(this.r,this.s,T)}recoverPublicKey(T){let{r:b,s:p,recovery:v}=this,A=L(j("msgHash",T));if(v==null||![0,1,2,3].includes(v))throw new Error("recovery id invalid");let R=v===2||v===3?b+t.n:b;if(R>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let _=v&1?"03":"02",V=c.fromHex(_+d(R)),P=a(R),D=o(-A*P),q=o(p*P),$=c.BASE.multiplyAndAddUnsafe(V,D,q);if(!$)throw new Error("point at infinify");return $.assertValidity(),$}hasHighS(){return m(this.s)}normalizeS(){return this.hasHighS()?new h(this.r,o(-this.s),this.recovery):this}toDERRawBytes(){return Ie(this.toDERHex())}toDERHex(){return oe.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return Ie(this.toCompactHex())}toCompactHex(){return d(this.r)+d(this.s)}}let w={isValidPrivateKey(B){try{return l(B),!0}catch{return!1}},normPrivateKeyToScalar:l,randomPrivateKey:()=>{let B=ti(t.n);return ra(t.randomBytes(B),t.n)},precompute(B=8,T=c.BASE){return T._setWindowSize(B),T.multiply(BigInt(3)),T}};function E(B,T=!0){return c.fromPrivateKey(B).toRawBytes(T)}function g(B){let T=de(B),b=typeof B=="string",p=(T||b)&&B.length;return T?p===s||p===i:b?p===2*s||p===2*i:B instanceof c}function k(B,T,b=!0){if(g(B))throw new Error("first arg must be private key");if(!g(T))throw new Error("second arg must be public key");return c.fromHex(T).multiply(l(B)).toRawBytes(b)}let U=t.bits2int||function(B){if(B.length>8192)throw new Error("input is too large");let T=Jt(B),b=B.length*8-t.nBitLength;return b>0?T>>BigInt(b):T},L=t.bits2int_modN||function(B){return o(U(B))},I=yr(t.nBitLength);function C(B){return vt("num < 2^"+t.nBitLength,B,ae,I),ge(B,t.nByteLength)}function N(B,T,b=G){if(["recovered","canonical"].some(it=>it in b))throw new Error("sign() legacy options not supported");let{hash:p,randomBytes:v}=t,{lowS:A,prehash:R,extraEntropy:_}=b;A==null&&(A=!0),B=j("msgHash",B),kc(b),R&&(B=j("prehashed msgHash",p(B)));let V=L(B),P=l(T),D=[C(P),C(V)];if(_!=null&&_!==!1){let it=_===!0?v(e.BYTES):_;D.push(j("extraEntropy",it))}let q=Xt(...D),$=V;function st(it){let at=U(it);if(!u(at))return;let lt=a(at),xt=c.BASE.multiply(at).toAffine(),mt=o(xt.x);if(mt===ae)return;let Pt=o(lt*o($+mt*P));if(Pt===ae)return;let Gt=(xt.x===mt?0:2)|Number(xt.y&ot),lr=Pt;return A&&m(Pt)&&(lr=x(Pt),Gt^=1),new h(mt,lr,Gt)}return{seed:q,k2sig:st}}let G={lowS:t.lowS,prehash:!1},F={lowS:t.lowS,prehash:!1};function H(B,T,b=G){let{seed:p,k2sig:v}=N(B,T,b),A=t;return Ys(A.hash.outputLen,A.nByteLength,A.hmac)(p,v)}c.BASE._setWindowSize(8);function tt(B,T,b,p=F){let v=B;T=j("msgHash",T),b=j("publicKey",b);let{lowS:A,prehash:R,format:_}=p;if(kc(p),"strict"in p)throw new Error("options.strict was renamed to lowS");if(_!==void 0&&_!=="compact"&&_!=="der")throw new Error("format must be compact or der");let V=typeof v=="string"||de(v),P=!V&&!_&&typeof v=="object"&&v!==null&&typeof v.r=="bigint"&&typeof v.s=="bigint";if(!V&&!P)throw new Error("invalid signature, expected Uint8Array, hex string or Signature instance");let D,q;try{if(P&&(D=new h(v.r,v.s)),V){try{_!=="compact"&&(D=h.fromDER(v))}catch(Gt){if(!(Gt instanceof oe.Err))throw Gt}!D&&_!=="der"&&(D=h.fromCompact(v))}q=c.fromHex(b)}catch{return!1}if(!D||A&&D.hasHighS())return!1;R&&(T=t.hash(T));let{r:$,s:st}=D,it=L(T),at=a(st),lt=o(it*at),xt=o($*at),mt=c.BASE.multiplyAndAddUnsafe(q,lt,xt)?.toAffine();return mt?o(mt.x)===$:!1}return{CURVE:t,getPublicKey:E,getSharedSecret:k,sign:H,verify:tt,ProjectivePoint:c,Signature:h,utils:w}}function lh(r){return{hash:r,hmac:(t,...e)=>Yi(r,t,qs(...e)),randomBytes:Je}}function Tc(r,t){let e=n=>Nc({...r,...lh(n)});return{...e(t),create:e}}var Lc=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),Cc=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),fh=BigInt(1),Xi=BigInt(2),Uc=(r,t)=>(r+t/Xi)/t;function hh(r){let t=Lc,e=BigInt(3),n=BigInt(6),s=BigInt(11),i=BigInt(22),o=BigInt(23),a=BigInt(44),c=BigInt(88),l=r*r*r%t,f=l*l*r%t,u=W(f,e,t)*f%t,d=W(u,e,t)*f%t,m=W(d,Xi,t)*l%t,x=W(m,s,t)*m%t,y=W(x,i,t)*x%t,h=W(y,a,t)*y%t,w=W(h,c,t)*h%t,E=W(w,a,t)*y%t,g=W(E,e,t)*f%t,k=W(g,o,t)*x%t,U=W(k,n,t)*l%t,L=W(U,Xi,t);if(!Qi.eql(Qi.sqr(L),r))throw new Error("Cannot find square root");return L}var Qi=me(Lc,void 0,void 0,{sqrt:hh}),Me=Tc({a:BigInt(0),b:BigInt(7),Fp:Qi,n:Cc,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=Cc,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-fh*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),s=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),i=e,o=BigInt("0x100000000000000000000000000000000"),a=Uc(i*r,t),c=Uc(-n*r,t),l=z(r-a*e-c*s,t),f=z(-a*n-c*i,t),u=l>o,d=f>o;if(u&&(l=t-l),d&&(f=t-f),l>o||f>o)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:u,k1:l,k2neg:d,k2:f}}}},er),xg=BigInt(0);var vg=Me.ProjectivePoint;function Ve(r,t){t==null&&(t=r.reduce((s,i)=>s+i.length,0));let e=ft(t),n=0;for(let s of r)e.set(s,n),n+=s.length;return e}function Rc(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function _c(r,t,e){let n=Re.digest(e instanceof Uint8Array?e:e.subarray());if(Rc(n))return n.then(({digest:s})=>Me.verify(t,s,r)).catch(s=>{throw new Cr(String(s))});try{return Me.verify(t,n.digest,r)}catch(s){throw new Cr(String(s))}}var us=class{type="secp256k1";raw;_key;constructor(t){this._key=Mc(t),this.raw=Dc(this._key)}toMultihash(){return Wt.digest(Ue(this))}toCID(){return It.createV1(114,this.toMultihash())}toString(){return Q.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:Tt(this.raw,t.raw)}verify(t,e){return _c(this._key,e,t)}};function to(r){return new us(r)}function Dc(r){return Me.ProjectivePoint.fromHex(r).toRawBytes(!0)}function Mc(r){try{return Me.ProjectivePoint.fromHex(r),r}catch(t){throw new Fe(String(t))}}function eo(r){let{Type:t,Data:e}=Kt.decode(r),n=e??new Uint8Array;switch(t){case nt.RSA:return ji(n);case nt.Ed25519:return ai(n);case nt.secp256k1:return to(n);default:throw new Se}}function Vc(r){let{Type:t,Data:e}=Kt.decode(r.digest),n=e??new Uint8Array;switch(t){case nt.Ed25519:return ai(n);case nt.secp256k1:return to(n);default:throw new Se}}function Ue(r){return Kt.encode({Type:nt[r.type],Data:r.raw})}var Hc=Symbol.for("nodejs.util.inspect.custom"),dh=114,Rr=class{type;multihash;publicKey;string;constructor(t){this.type=t.type,this.multihash=t.multihash,Object.defineProperty(this,"string",{enumerable:!1,writable:!0})}get[Symbol.toStringTag](){return`PeerId(${this.toString()})`}[Ls]=!0;toString(){return this.string==null&&(this.string=Q.encode(this.multihash.bytes).slice(1)),this.string}toMultihash(){return this.multihash}toCID(){return It.createV1(dh,this.multihash)}toJSON(){return this.toString()}equals(t){if(t==null)return!1;if(t instanceof Uint8Array)return Tt(this.multihash.bytes,t);if(typeof t=="string")return this.toString()===t;if(t?.toMultihash()?.bytes!=null)return Tt(this.multihash.bytes,t.toMultihash().bytes);throw new Error("not valid Id")}[Hc](){return`PeerId(${this.toString()})`}},_r=class extends Rr{type="RSA";publicKey;constructor(t){super({...t,type:"RSA"}),this.publicKey=t.publicKey}},Dr=class extends Rr{type="Ed25519";publicKey;constructor(t){super({...t,type:"Ed25519"}),this.publicKey=t.publicKey}},Mr=class extends Rr{type="secp256k1";publicKey;constructor(t){super({...t,type:"secp256k1"}),this.publicKey=t.publicKey}},ph=2336,ls=class{type="url";multihash;publicKey;url;constructor(t){this.url=t.toString(),this.multihash=Wt.digest(Y(this.url))}[Hc](){return`PeerId(${this.url})`}[Ls]=!0;toString(){return this.toCID().toString()}toMultihash(){return this.multihash}toCID(){return It.createV1(ph,this.toMultihash())}toJSON(){return this.toString()}equals(t){return t==null?!1:(t instanceof Uint8Array&&(t=Ot(t)),t.toString()===this.toString())}};function ro(r){if(r.type==="Ed25519")return new Dr({multihash:r.toCID().multihash,publicKey:r});if(r.type==="secp256k1")return new Mr({multihash:r.toCID().multihash,publicKey:r});if(r.type==="RSA")return new _r({multihash:r.toCID().multihash,publicKey:r});throw new Se}function Oc(r){return ro(r.publicKey)}function Vr(r){if(mh(r))return new _r({multihash:r});if(gh(r))try{let t=Vc(r);if(t.type==="Ed25519")return new Dr({multihash:r,publicKey:t});if(t.type==="secp256k1")return new Mr({multihash:r,publicKey:t})}catch{let e=Ot(r.digest);return new ls(new URL(e))}throw new jr("Supplied PeerID Multihash is invalid")}function gh(r){return r.code===Wt.code}function mh(r){return r.code===Re.code}function He(r,t){let e={[Symbol.iterator]:()=>e,next:()=>{let n=r.next(),s=n.value;return n.done===!0||s==null?{done:!0,value:void 0}:{done:!1,value:t(s)}}};return e}function fs(r){let t=ue(Q.decode(`z${r}`));return Vr(t)}var Hr=class{map;constructor(t){if(this.map=new Map,t!=null)for(let[e,n]of t.entries())this.map.set(e.toString(),{key:e,value:n})}[Symbol.iterator](){return this.entries()}clear(){this.map.clear()}delete(t){return this.map.delete(t.toString())}entries(){return He(this.map.entries(),t=>[t[1].key,t[1].value])}forEach(t){this.map.forEach((e,n)=>{t(e.value,e.key,this)})}get(t){return this.map.get(t.toString())?.value}has(t){return this.map.has(t.toString())}set(t,e){this.map.set(t.toString(),{key:t,value:e})}keys(){return He(this.map.values(),t=>t.key)}values(){return He(this.map.values(),t=>t.value)}get size(){return this.map.size}};var Or=class r{set;constructor(t){if(this.set=new Set,t!=null)for(let e of t)this.set.add(e.toString())}get size(){return this.set.size}[Symbol.iterator](){return this.values()}add(t){this.set.add(t.toString())}clear(){this.set.clear()}delete(t){this.set.delete(t.toString())}entries(){return He(this.set.entries(),t=>{let e=fs(t[0]);return[e,e]})}forEach(t){this.set.forEach(e=>{let n=fs(e);t(n,n,this)})}has(t){return this.set.has(t.toString())}values(){return He(this.set.values(),t=>fs(t))}intersection(t){let e=new r;for(let n of t)this.has(n)&&e.add(n);return e}difference(t){let e=new r;for(let n of this)t.has(n)||e.add(n);return e}union(t){let e=new r;for(let n of t)e.add(n);for(let n of this)e.add(n);return e}};var Fc=Symbol.for("@achingbrain/uint8arraylist");function Pc(r,t){if(t==null||t<0)throw new RangeError("index is out of bounds");let e=0;for(let n of r){let s=e+n.byteLength;if(t<s)return{buf:n,index:t-e};e=s}throw new RangeError("index is out of bounds")}function hs(r){return!!r?.[Fc]}var Be=class r{bufs;length;[Fc]=!0;constructor(...t){this.bufs=[],this.length=0,t.length>0&&this.appendAll(t)}*[Symbol.iterator](){yield*this.bufs}get byteLength(){return this.length}append(...t){this.appendAll(t)}appendAll(t){let e=0;for(let n of t)if(n instanceof Uint8Array)e+=n.byteLength,this.bufs.push(n);else if(hs(n))e+=n.byteLength,this.bufs.push(...n.bufs);else throw new Error("Could not append value, must be an Uint8Array or a Uint8ArrayList");this.length+=e}prepend(...t){this.prependAll(t)}prependAll(t){let e=0;for(let n of t.reverse())if(n instanceof Uint8Array)e+=n.byteLength,this.bufs.unshift(n);else if(hs(n))e+=n.byteLength,this.bufs.unshift(...n.bufs);else throw new Error("Could not prepend value, must be an Uint8Array or a Uint8ArrayList");this.length+=e}get(t){let e=Pc(this.bufs,t);return e.buf[e.index]}set(t,e){let n=Pc(this.bufs,t);n.buf[n.index]=e}write(t,e=0){if(t instanceof Uint8Array)for(let n=0;n<t.length;n++)this.set(e+n,t[n]);else if(hs(t))for(let n=0;n<t.length;n++)this.set(e+n,t.get(n));else throw new Error("Could not write value, must be an Uint8Array or a Uint8ArrayList")}consume(t){if(t=Math.trunc(t),!(Number.isNaN(t)||t<=0)){if(t===this.byteLength){this.bufs=[],this.length=0;return}for(;this.bufs.length>0;)if(t>=this.bufs[0].byteLength)t-=this.bufs[0].byteLength,this.length-=this.bufs[0].byteLength,this.bufs.shift();else{this.bufs[0]=this.bufs[0].subarray(t),this.length-=t;break}}}slice(t,e){let{bufs:n,length:s}=this._subList(t,e);return Ve(n,s)}subarray(t,e){let{bufs:n,length:s}=this._subList(t,e);return n.length===1?n[0]:Ve(n,s)}sublist(t,e){let{bufs:n,length:s}=this._subList(t,e),i=new r;return i.length=s,i.bufs=[...n],i}_subList(t,e){if(t=t??0,e=e??this.length,t<0&&(t=this.length+t),e<0&&(e=this.length+e),t<0||e>this.length)throw new RangeError("index is out of bounds");if(t===e)return{bufs:[],length:0};if(t===0&&e===this.length)return{bufs:this.bufs,length:this.length};let n=[],s=0;for(let i=0;i<this.bufs.length;i++){let o=this.bufs[i],a=s,c=a+o.byteLength;if(s=c,t>=c)continue;let l=t>=a&&t<c,f=e>a&&e<=c;if(l&&f){if(t===a&&e===c){n.push(o);break}let u=t-a;n.push(o.subarray(u,u+(e-t)));break}if(l){if(t===0){n.push(o);continue}n.push(o.subarray(t-a));continue}if(f){if(e===c){n.push(o);break}n.push(o.subarray(0,e-a));break}n.push(o)}return{bufs:n,length:e-t}}indexOf(t,e=0){if(!hs(t)&&!(t instanceof Uint8Array))throw new TypeError('The "value" argument must be a Uint8ArrayList or Uint8Array');let n=t instanceof Uint8Array?t:t.subarray();if(e=Number(e??0),isNaN(e)&&(e=0),e<0&&(e=this.length+e),e<0&&(e=0),t.length===0)return e>this.length?this.length:e;let s=n.byteLength;if(s===0)throw new TypeError("search must be at least 1 byte long");let i=256,o=new Int32Array(i);for(let u=0;u<i;u++)o[u]=-1;for(let u=0;u<s;u++)o[n[u]]=u;let a=o,c=this.byteLength-n.byteLength,l=n.byteLength-1,f;for(let u=e;u<=c;u+=f){f=0;for(let d=l;d>=0;d--){let m=this.get(u+d);if(n[d]!==m){f=Math.max(1,d-a[m]);break}}if(f===0)return u}return-1}getInt8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getInt8(0)}setInt8(t,e){let n=ft(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setInt8(0,e),this.write(n,t)}getInt16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt16(0,e)}setInt16(t,e,n){let s=Qt(2);new DataView(s.buffer,s.byteOffset,s.byteLength).setInt16(0,e,n),this.write(s,t)}getInt32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt32(0,e)}setInt32(t,e,n){let s=Qt(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setInt32(0,e,n),this.write(s,t)}getBigInt64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigInt64(0,e)}setBigInt64(t,e,n){let s=Qt(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigInt64(0,e,n),this.write(s,t)}getUint8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getUint8(0)}setUint8(t,e){let n=ft(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setUint8(0,e),this.write(n,t)}getUint16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint16(0,e)}setUint16(t,e,n){let s=Qt(2);new DataView(s.buffer,s.byteOffset,s.byteLength).setUint16(0,e,n),this.write(s,t)}getUint32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint32(0,e)}setUint32(t,e,n){let s=Qt(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setUint32(0,e,n),this.write(s,t)}getBigUint64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigUint64(0,e)}setBigUint64(t,e,n){let s=Qt(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigUint64(0,e,n),this.write(s,t)}getFloat32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat32(0,e)}setFloat32(t,e,n){let s=Qt(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setFloat32(0,e,n),this.write(s,t)}getFloat64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat64(0,e)}setFloat64(t,e,n){let s=Qt(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setFloat64(0,e,n),this.write(s,t)}equals(t){if(t==null||!(t instanceof r)||t.bufs.length!==this.bufs.length)return!1;for(let e=0;e<this.bufs.length;e++)if(!Tt(this.bufs[e],t.bufs[e]))return!1;return!0}static fromUint8Arrays(t,e){let n=new r;return n.bufs=t,e==null&&(e=t.reduce((s,i)=>s+i.byteLength,0)),n.length=e,n}};function ds(){let r={};return r.promise=new Promise((t,e)=>{r.resolve=t,r.reject=e}),r}var ps=class{buffer;mask;top;btm;next;constructor(t){if(!(t>0)||t-1&t)throw new Error("Max size for a FixedFIFO should be a power of two");this.buffer=new Array(t),this.mask=t-1,this.top=0,this.btm=0,this.next=null}push(t){return this.buffer[this.top]!==void 0?!1:(this.buffer[this.top]=t,this.top=this.top+1&this.mask,!0)}shift(){let t=this.buffer[this.btm];if(t!==void 0)return this.buffer[this.btm]=void 0,this.btm=this.btm+1&this.mask,t}isEmpty(){return this.buffer[this.btm]===void 0}},cr=class{size;hwm;head;tail;constructor(t={}){this.hwm=t.splitLimit??16,this.head=new ps(this.hwm),this.tail=this.head,this.size=0}calculateSize(t){return t?.byteLength!=null?t.byteLength:1}push(t){if(t?.value!=null&&(this.size+=this.calculateSize(t.value)),!this.head.push(t)){let e=this.head;this.head=e.next=new ps(2*this.head.buffer.length),this.head.push(t)}}shift(){let t=this.tail.shift();if(t===void 0&&this.tail.next!=null){let e=this.tail.next;this.tail.next=null,this.tail=e,t=this.tail.shift()}return t?.value!=null&&(this.size-=this.calculateSize(t.value)),t}isEmpty(){return this.head.isEmpty()}};var no=class extends Error{type;code;constructor(t,e){super(t??"The operation was aborted"),this.type="aborted",this.code=e??"ABORT_ERR"}};function ur(r={}){return bh(e=>{let n=e.shift();if(n==null)return{done:!0};if(n.error!=null)throw n.error;return{done:n.done===!0,value:n.value}},r)}function bh(r,t){t=t??{};let e=t.onEnd,n=new cr,s,i,o,a=ds(),c=async()=>{try{return n.isEmpty()?o?{done:!0}:await new Promise((h,w)=>{i=E=>{i=null,n.push(E);try{h(r(n))}catch(g){w(g)}return s}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{a.resolve(),a=ds()})}},l=h=>i!=null?i(h):(n.push(h),s),f=h=>(n=new cr,i!=null?i({error:h}):(n.push({error:h}),s)),u=h=>{if(o)return s;if(t?.objectMode!==!0&&h?.byteLength==null)throw new Error("objectMode was not true but tried to push non-Uint8Array value");return l({done:!1,value:h})},d=h=>o?s:(o=!0,h!=null?f(h):l({done:!0})),m=()=>(n=new cr,d(),{done:!0}),x=h=>(d(h),{done:!0});if(s={[Symbol.asyncIterator](){return this},next:c,return:m,throw:x,push:u,end:d,get readableLength(){return n.size},onEmpty:async h=>{let w=h?.signal;if(w?.throwIfAborted(),n.isEmpty())return;let E,g;w!=null&&(E=new Promise((k,U)=>{g=()=>{U(new no)},w.addEventListener("abort",g)}));try{await Promise.race([a.promise,E])}finally{g!=null&&w!=null&&w?.removeEventListener("abort",g)}}},e==null)return s;let y=s;return s={[Symbol.asyncIterator](){return this},next(){return y.next()},throw(h){return y.throw(h),e!=null&&(e(h),e=void 0),{done:!0}},return(){return y.return(),e!=null&&(e(),e=void 0),{done:!0}},push:u,end(h){return y.end(h),e!=null&&(e(h),e=void 0),s},get readableLength(){return y.readableLength},onEmpty:h=>y.onEmpty(h)},s}function yh(r){return r[Symbol.asyncIterator]!=null}function wh(...r){let t=[];for(let e of r)yh(e)||t.push(e);return t.length===r.length?function*(){for(let e of t)yield*e}():async function*(){let e=ur({objectMode:!0});Promise.resolve().then(async()=>{try{await Promise.all(r.map(async n=>{for await(let s of n)e.push(s)})),e.end()}catch(n){e.end(n)}}),yield*e}()}var Kc=wh;function Pr(r,...t){if(r==null)throw new Error("Empty pipeline");if(so(r)){let n=r;r=()=>n.source}else if(zc(r)||qc(r)){let n=r;r=()=>n}let e=[r,...t];if(e.length>1&&so(e[e.length-1])&&(e[e.length-1]=e[e.length-1].sink),e.length>2)for(let n=1;n<e.length-1;n++)so(e[n])&&(e[n]=vh(e[n]));return xh(...e)}var xh=(...r)=>{let t;for(;r.length>0;)t=r.shift()(t);return t},qc=r=>r?.[Symbol.asyncIterator]!=null,zc=r=>r?.[Symbol.iterator]!=null,so=r=>r==null?!1:r.sink!=null&&r.source!=null,vh=r=>t=>{let e=r.sink(t);if(e?.then!=null){let n=ur({objectMode:!0});e.then(()=>{n.end()},o=>{n.end(o)});let s,i=r.source;if(qc(i))s=async function*(){yield*i,n.end()};else if(zc(i))s=function*(){yield*i,n.end()};else throw new Error("Unknown duplex source type - must be Iterable or AsyncIterable");return Kc(n,s())}return r.source};var oo=Bo(Gc(),1);var Kr=class extends Error{constructor(t){super(t),this.name="TimeoutError"}},ao=class extends Error{constructor(t){super(),this.name="AbortError",this.message=t}},Zc=r=>globalThis.DOMException===void 0?new ao(r):new DOMException(r),Wc=r=>{let t=r.reason===void 0?Zc("This operation was aborted."):r.reason;return t instanceof Error?t:Zc(t)};function co(r,t){let{milliseconds:e,fallback:n,message:s,customTimers:i={setTimeout,clearTimeout}}=t,o,a,l=new Promise((f,u)=>{if(typeof e!="number"||Math.sign(e)!==1)throw new TypeError(`Expected \`milliseconds\` to be a positive number, got \`${e}\``);if(t.signal){let{signal:m}=t;m.aborted&&u(Wc(m)),a=()=>{u(Wc(m))},m.addEventListener("abort",a,{once:!0})}if(e===Number.POSITIVE_INFINITY){r.then(f,u);return}let d=new Kr;o=i.setTimeout.call(void 0,()=>{if(n){try{f(n())}catch(m){u(m)}return}typeof r.cancel=="function"&&r.cancel(),s===!1?f():s instanceof Error?u(s):(d.message=s??`Promise timed out after ${e} milliseconds`,u(d))},e),(async()=>{try{f(await r)}catch(m){u(m)}})()}).finally(()=>{l.clear(),a&&t.signal&&t.signal.removeEventListener("abort",a)});return l.clear=()=>{i.clearTimeout.call(void 0,o),o=void 0},l}function uo(r,t,e){let n=0,s=r.length;for(;s>0;){let i=Math.trunc(s/2),o=n+i;e(r[o],t)<=0?(n=++o,s-=i+1):s=i}return n}var qr=class{#t=[];enqueue(t,e){e={priority:0,...e};let n={priority:e.priority,id:e.id,run:t};if(this.size===0||this.#t[this.size-1].priority>=e.priority){this.#t.push(n);return}let s=uo(this.#t,n,(i,o)=>o.priority-i.priority);this.#t.splice(s,0,n)}setPriority(t,e){let n=this.#t.findIndex(i=>i.id===t);if(n===-1)throw new ReferenceError(`No promise function with the id "${t}" exists in the queue.`);let[s]=this.#t.splice(n,1);this.enqueue(s.run,{priority:e,id:t})}dequeue(){return this.#t.shift()?.run}filter(t){return this.#t.filter(e=>e.priority===t.priority).map(e=>e.run)}get size(){return this.#t.length}};var zr=class extends oo.default{#t;#o;#i=0;#d;#a;#p=0;#r;#c;#e;#g;#n=0;#u;#s;#m;#w=1n;timeout;constructor(t){if(super(),t={carryoverConcurrencyCount:!1,intervalCap:Number.POSITIVE_INFINITY,interval:0,concurrency:Number.POSITIVE_INFINITY,autoStart:!0,queueClass:qr,...t},!(typeof t.intervalCap=="number"&&t.intervalCap>=1))throw new TypeError(`Expected \`intervalCap\` to be a number from 1 and up, got \`${t.intervalCap?.toString()??""}\` (${typeof t.intervalCap})`);if(t.interval===void 0||!(Number.isFinite(t.interval)&&t.interval>=0))throw new TypeError(`Expected \`interval\` to be a finite number >= 0, got \`${t.interval?.toString()??""}\` (${typeof t.interval})`);this.#t=t.carryoverConcurrencyCount,this.#o=t.intervalCap===Number.POSITIVE_INFINITY||t.interval===0,this.#d=t.intervalCap,this.#a=t.interval,this.#e=new t.queueClass,this.#g=t.queueClass,this.concurrency=t.concurrency,this.timeout=t.timeout,this.#m=t.throwOnTimeout===!0,this.#s=t.autoStart===!1}get#x(){return this.#o||this.#i<this.#d}get#v(){return this.#n<this.#u}#E(){this.#n--,this.#l(),this.emit("next")}#B(){this.#y(),this.#b(),this.#c=void 0}get#S(){let t=Date.now();if(this.#r===void 0){let e=this.#p-t;if(e<0)this.#i=this.#t?this.#n:0;else return this.#c===void 0&&(this.#c=setTimeout(()=>{this.#B()},e)),!0}return!1}#l(){if(this.#e.size===0)return this.#r&&clearInterval(this.#r),this.#r=void 0,this.emit("empty"),this.#n===0&&this.emit("idle"),!1;if(!this.#s){let t=!this.#S;if(this.#x&&this.#v){let e=this.#e.dequeue();return e?(this.emit("active"),e(),t&&this.#b(),!0):!1}}return!1}#b(){this.#o||this.#r!==void 0||(this.#r=setInterval(()=>{this.#y()},this.#a),this.#p=Date.now()+this.#a)}#y(){this.#i===0&&this.#n===0&&this.#r&&(clearInterval(this.#r),this.#r=void 0),this.#i=this.#t?this.#n:0,this.#f()}#f(){for(;this.#l(););}get concurrency(){return this.#u}set concurrency(t){if(!(typeof t=="number"&&t>=1))throw new TypeError(`Expected \`concurrency\` to be a number from 1 and up, got \`${t}\` (${typeof t})`);this.#u=t,this.#f()}async#A(t){return new Promise((e,n)=>{t.addEventListener("abort",()=>{n(t.reason)},{once:!0})})}setPriority(t,e){this.#e.setPriority(t,e)}async add(t,e={}){return e.id??=(this.#w++).toString(),e={timeout:this.timeout,throwOnTimeout:this.#m,...e},new Promise((n,s)=>{this.#e.enqueue(async()=>{this.#n++,this.#i++;try{e.signal?.throwIfAborted();let i=t({signal:e.signal});e.timeout&&(i=co(Promise.resolve(i),{milliseconds:e.timeout})),e.signal&&(i=Promise.race([i,this.#A(e.signal)]));let o=await i;n(o),this.emit("completed",o)}catch(i){if(i instanceof Kr&&!e.throwOnTimeout){n();return}s(i),this.emit("error",i)}finally{this.#E()}},e),this.emit("add"),this.#l()})}async addAll(t,e){return Promise.all(t.map(async n=>this.add(n,e)))}start(){return this.#s?(this.#s=!1,this.#f(),this):this}pause(){this.#s=!0}clear(){this.#e=new this.#g}async onEmpty(){this.#e.size!==0&&await this.#h("empty")}async onSizeLessThan(t){this.#e.size<t||await this.#h("next",()=>this.#e.size<t)}async onIdle(){this.#n===0&&this.#e.size===0||await this.#h("idle")}async#h(t,e){return new Promise(n=>{let s=()=>{e&&!e()||(this.off(t,s),n())};this.on(t,s)})}get size(){return this.#e.size}sizeBy(t){return this.#e.filter(t).length}get pending(){return this.#n}get isPaused(){return this.#s}};function jc(r){if(r!=null){if(typeof r[Symbol.iterator]=="function")return r[Symbol.iterator]();if(typeof r[Symbol.asyncIterator]=="function")return r[Symbol.asyncIterator]();if(typeof r.next=="function")return r}throw new Error("argument is not an iterator or iterable")}function Yc(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function Jc(r,t){let e=jc(r).return?.();Yc(e)&&e.catch(n=>{t.error("could not cause iterator to return",n)})}function ms(r){return r[Symbol.asyncIterator]!=null}var bs=r=>{let t=Mt(r),e=ft(t);return ha(r,e),bs.bytes=t,e};bs.bytes=0;function ys(r,t){t=t??{};let e=t.lengthEncoder??bs;function*n(s){let i=e(s.byteLength);i instanceof Uint8Array?yield i:yield*i,s instanceof Uint8Array?yield s:yield*s}return ms(r)?async function*(){for await(let s of r)yield*n(s)}():function*(){for(let s of r)yield*n(s)}()}ys.single=(r,t)=>{t=t??{};let e=t.lengthEncoder??bs;return new Be(e(r.byteLength),r)};var ws=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},xs=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},vs=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"},$r=class extends Error{name="UnexpectedEOFError";code="ERR_UNEXPECTED_EOF"};var Sh=8,Ah=1024*1024*4,Oe;(function(r){r[r.LENGTH=0]="LENGTH",r[r.DATA=1]="DATA"})(Oe||(Oe={}));var lo=r=>{let t=da(r);return lo.bytes=Mt(t),t};lo.bytes=0;function Gr(r,t){let e=new Be,n=Oe.LENGTH,s=-1,i=t?.lengthDecoder??lo,o=t?.maxLengthLength??Sh,a=t?.maxDataLength??Ah;function*c(){for(;e.byteLength>0;){if(n===Oe.LENGTH)try{if(s=i(e),s<0)throw new ws("Invalid message length");if(s>a)throw new xs("Message length too long");let l=i.bytes;e.consume(l),t?.onLength!=null&&t.onLength(s),n=Oe.DATA}catch(l){if(l instanceof RangeError){if(e.byteLength>o)throw new vs("Message length length too long");break}throw l}if(n===Oe.DATA){if(e.byteLength<s)break;let l=e.sublist(0,s);e.consume(s),t?.onData!=null&&t.onData(l),yield l,n=Oe.LENGTH}}}return ms(r)?async function*(){for await(let l of r)e.append(l),yield*c();if(e.byteLength>0)throw new $r("Unexpected end of input")}():function*(){for(let l of r)e.append(l),yield*c();if(e.byteLength>0)throw new $r("Unexpected end of input")}()}Gr.fromReader=(r,t)=>{let e=1,n=async function*(){for(;;)try{let{done:i,value:o}=await r.next(e);if(i===!0)return;o!=null&&(yield o)}catch(i){if(i.code==="ERR_UNDER_READ")return{done:!0,value:null};throw i}finally{e=1}}();return Gr(n,{...t??{},onLength:i=>{e=i}})};var Es=class extends Ke{id;protocol;outboundStream;inboundStream;_rawOutboundStream;_rawInboundStream;_inboundAbortController;closed;log;constructor(t,e){super(),this.log=t.logger.forComponent("libp2p-pubsub:peer-streams"),this.id=e.id,this.protocol=e.protocol,this._inboundAbortController=new AbortController,this.closed=!1}get isReadable(){return!!this.inboundStream}get isWritable(){return!!this.outboundStream}write(t){if(this.outboundStream==null){let e=this.id.toString();throw new Error("No writable connection to "+e)}this.outboundStream.push(t instanceof Uint8Array?new Be(t):t)}attachInboundStream(t){let e=()=>{Jc(t.source,this.log)};return this._inboundAbortController.signal.addEventListener("abort",e,{once:!0}),this._rawInboundStream=t,this.inboundStream=Pr(this._rawInboundStream,n=>Gr(n)),this.dispatchEvent(new CustomEvent("stream:inbound")),this.inboundStream}async attachOutboundStream(t){let e=this.outboundStream;return this.outboundStream!=null&&this.outboundStream.end(),this._rawOutboundStream=t,this.outboundStream=ur({onEnd:n=>{this._rawOutboundStream!=null&&this._rawOutboundStream.closeWrite().catch(s=>{this.log("error closing outbound stream",s)}),this._rawOutboundStream=void 0,this.outboundStream=void 0,n!=null&&this.dispatchEvent(new CustomEvent("close"))}}),Pr(this.outboundStream,n=>ys(n),this._rawOutboundStream).catch(n=>{this.log.error(n)}),e==null&&this.dispatchEvent(new CustomEvent("stream:outbound")),this.outboundStream}close(){this.closed||(this.closed=!0,this.outboundStream!=null&&this.outboundStream.end(),this.inboundStream!=null&&this._inboundAbortController.abort(),this._rawOutboundStream=void 0,this.outboundStream=void 0,this._rawInboundStream=void 0,this.inboundStream=void 0,this.dispatchEvent(new CustomEvent("close")))}};function Xc(){return BigInt(`0x${Ot(is(8),"base16")}`)}var Qc=(r,t)=>{let e=Y(t.toString(16).padStart(16,"0"),"base16"),n=Ue(r),s=new Uint8Array(n.byteLength+e.length);return s.set(n,0),s.set(e,n.byteLength),s},tu=r=>Re.encode(r);var eu=function(r){return Array.isArray(r)?r:[r]},Ih=async r=>{if(r.sequenceNumber==null||r.from==null||r.signature==null)return!1;let t=Vr(ue(r.from));if(t.publicKey!=null)return!0;if(r.key!=null){let e=r.key;return ro(eo(e)).equals(t)}return!1},ru=async r=>{if(r.from==null)throw new X("RPC message was missing from");if(!await Ih(r))return{type:"unsigned",topic:r.topic??"",data:r.data??new Uint8Array(0)};let t=Vr(ue(r.from)),e=r.key??t.publicKey;if(e==null)throw new X("RPC message was missing public key");return{type:"signed",from:t,topic:r.topic??"",sequenceNumber:Th(r.sequenceNumber??new Uint8Array(0)),data:r.data??new Uint8Array(0),signature:r.signature??new Uint8Array(0),key:e instanceof Uint8Array?eo(e):e}},Zr=r=>r.type==="signed"?{from:r.from.toMultihash().bytes,data:r.data,sequenceNumber:Nh(r.sequenceNumber),topic:r.topic,signature:r.signature,key:r.key?Ue(r.key):void 0}:{data:r.data,topic:r.topic},Nh=r=>{let t=r.toString(16);return t.length%2!==0&&(t=`0${t}`),Y(t,"base16")},Th=r=>BigInt(`0x${Ot(r,"base16")}`);var nu=Y("libp2p-pubsub:");async function su(r,t,e){let n={type:"signed",topic:t.topic,data:t.data,sequenceNumber:t.sequenceNumber,from:Oc(r)},s=Ve([nu,e(Zr(n)).subarray()]);return n.signature=await r.sign(s),n.key=r.publicKey,n}async function iu(r,t){if(r.type!=="signed")throw new Error('Message type must be "signed" to be verified');if(r.signature==null)throw new Error("Message must contain a signature to be verified");if(r.from==null)throw new Error("Message must contain a from property to be verified");let e=Ve([nu,t({...Zr(r),signature:void 0,key:void 0}).subarray()]);return Ch(r).verify(e,r.signature)}function Ch(r){if(r.type!=="signed")throw new Error('Message type must be "signed" to have a public key');if(r.from==null)throw new Error("Could not get the public key from the originator id");if(r.key!=null)return r.key;if(r.from.publicKey!=null)return r.from.publicKey;throw new Error("Could not get the public key from the originator id")}var Bs=class extends Ke{log;started;topics;subscriptions;peers;globalSignaturePolicy;canRelayMessage;emitSelf;topicValidators;queue;multicodecs;components;_registrarTopologyIds;enabled;maxInboundStreams;maxOutboundStreams;constructor(t,e){super();let{multicodecs:n=[],globalSignaturePolicy:s="StrictSign",canRelayMessage:i=!1,emitSelf:o=!1,messageProcessingConcurrency:a=10,maxInboundStreams:c=1,maxOutboundStreams:l=1}=e;this.log=t.logger.forComponent("libp2p:pubsub"),this.components=t,this.multicodecs=eu(n),this.enabled=e.enabled!==!1,this.started=!1,this.topics=new Map,this.subscriptions=new Set,this.peers=new Hr,this.globalSignaturePolicy=s==="StrictNoSign"?"StrictNoSign":"StrictSign",this.canRelayMessage=i,this.emitSelf=o,this.topicValidators=new Map,this.queue=new zr({concurrency:a}),this.maxInboundStreams=c,this.maxOutboundStreams=l,this._onIncomingStream=this._onIncomingStream.bind(this),this._onPeerConnected=this._onPeerConnected.bind(this),this._onPeerDisconnected=this._onPeerDisconnected.bind(this)}async start(){if(this.started||!this.enabled)return;this.log("starting");let t=this.components.registrar;await Promise.all(this.multicodecs.map(async n=>{await t.handle(n,this._onIncomingStream,{maxInboundStreams:this.maxInboundStreams,maxOutboundStreams:this.maxOutboundStreams})}));let e={onConnect:this._onPeerConnected,onDisconnect:this._onPeerDisconnected};this._registrarTopologyIds=await Promise.all(this.multicodecs.map(async n=>t.register(n,e))),this.log("started"),this.started=!0}async stop(){if(!this.started||!this.enabled)return;let t=this.components.registrar;this._registrarTopologyIds!=null&&this._registrarTopologyIds?.forEach(e=>{t.unregister(e)}),await Promise.all(this.multicodecs.map(async e=>{await t.unhandle(e)})),this.log("stopping");for(let e of this.peers.values())e.close();this.peers.clear(),this.subscriptions=new Set,this.started=!1,this.log("stopped")}isStarted(){return this.started}_onIncomingStream(t){let{stream:e,connection:n}=t,s=n.remotePeer;if(e.protocol==null){e.abort(new Error("Stream was not multiplexed"));return}let i=this.addPeer(s,e.protocol),o=i.attachInboundStream(e);this.processMessages(s,o,i).catch(a=>{this.log(a)})}_onPeerConnected(t,e){if(this.log("connected %p",t),e.streams.find(n=>n.direction==="outbound"&&n.protocol!=null&&this.multicodecs.includes(n.protocol))!=null){this.log("outbound pubsub streams already present on connection from %p",t);return}Promise.resolve().then(async()=>{try{let n=await e.newStream(this.multicodecs);if(n.protocol==null){n.abort(new Error("Stream was not multiplexed"));return}await this.addPeer(t,n.protocol).attachOutboundStream(n)}catch(n){this.log.error(n)}this.send(t,{subscriptions:Array.from(this.subscriptions).map(n=>n.toString()),subscribe:!0})}).catch(n=>{this.log.error(n)})}_onPeerDisconnected(t,e){this.log("connection ended %p",t),this._removePeer(t)}addPeer(t,e){let n=this.peers.get(t);if(n!=null)return n;this.log("new peer %p",t);let s=new Es(this.components,{id:t,protocol:e});return this.peers.set(t,s),s.addEventListener("close",()=>this._removePeer(t),{once:!0}),s}_removePeer(t){let e=this.peers.get(t);if(e!=null){e.close(),this.log("delete peer %p",t),this.peers.delete(t);for(let n of this.topics.values())n.delete(t);return e}}async processMessages(t,e,n){try{await Pr(e,async s=>{for await(let i of s){let o=this.decodeRpc(i),a=[];for(let c of o.messages??[]){if(c.from==null||c.data==null||c.topic==null){this.log("message from %p was missing from, data or topic fields, dropping",t);continue}a.push({from:c.from,data:c.data,topic:c.topic,sequenceNumber:c.sequenceNumber??void 0,signature:c.signature??void 0,key:c.key??void 0})}this.processRpc(t,n,{subscriptions:(o.subscriptions??[]).map(c=>({subscribe:!!c.subscribe,topic:c.topic??""})),messages:a}).catch(c=>{this.log(c)})}})}catch(s){this._onPeerDisconnected(n.id,s)}}async processRpc(t,e,n){if(!this.acceptFrom(t))return this.log("received message from unacceptable peer %p",t),!1;this.log("rpc from %p",t);let{subscriptions:s,messages:i}=n;return s!=null&&s.length>0&&(this.log("subscription update from %p",t),s.forEach(o=>{this.processRpcSubOpt(t,o)}),super.dispatchEvent(new CustomEvent("subscription-change",{detail:{peerId:e.id,subscriptions:s.map(({topic:o,subscribe:a})=>({topic:`${o??""}`,subscribe:!!a}))}}))),i!=null&&i.length>0&&(this.log("messages from %p",t),this.queue.addAll(i.map(o=>async()=>{if(o.topic==null||!this.subscriptions.has(o.topic)&&!this.canRelayMessage)return this.log("received message we didn't subscribe to. Dropping."),!1;try{let a=await ru(o);await this.processMessage(t,a)}catch(a){this.log.error(a)}})).catch(o=>{this.log(o)})),!0}processRpcSubOpt(t,e){let n=e.topic;if(n==null)return;let s=this.topics.get(n);s==null&&(s=new Or,this.topics.set(n,s)),e.subscribe===!0?s.add(t):s.delete(t)}async processMessage(t,e){if(!(this.components.peerId.equals(t)&&!this.emitSelf)){try{await this.validate(t,e)}catch(n){this.log("Message is invalid, dropping it. %O",n);return}this.subscriptions.has(e.topic)&&(!this.components.peerId.equals(t)||this.emitSelf)&&super.dispatchEvent(new CustomEvent("message",{detail:e})),await this.publishMessage(t,e)}}getMsgId(t){switch(this.globalSignaturePolicy){case"StrictSign":if(t.type!=="signed")throw new X('Message type should be "signed" when signature policy is StrictSign but it was not');if(t.sequenceNumber==null)throw new X("Need seqno when signature policy is StrictSign but it was missing");if(t.key==null)throw new X("Need key when signature policy is StrictSign but it was missing");return Qc(t.key,t.sequenceNumber);case"StrictNoSign":return tu(t.data);default:throw new X("Cannot get message id: unhandled signature policy")}}acceptFrom(t){return!0}send(t,e){let{messages:n,subscriptions:s,subscribe:i}=e;this.sendRpc(t,{subscriptions:(s??[]).map(o=>({topic:o,subscribe:!!i})),messages:(n??[]).map(Zr)})}sendRpc(t,e){let n=this.peers.get(t);if(n==null){this.log.error("Cannot send RPC to %p as there are no streams to it available",t);return}if(!n.isWritable){this.log.error("Cannot send RPC to %p as there is no outbound stream to it available",t);return}n.write(this.encodeRpc(e))}async validate(t,e){switch(this.globalSignaturePolicy){case"StrictNoSign":if(e.type!=="unsigned")throw new X('Message type should be "unsigned" when signature policy is StrictNoSign but it was not');if(e.signature!=null)throw new X("StrictNoSigning: signature should not be present");if(e.key!=null)throw new X("StrictNoSigning: key should not be present");if(e.sequenceNumber!=null)throw new X("StrictNoSigning: seqno should not be present");break;case"StrictSign":if(e.type!=="signed")throw new X('Message type should be "signed" when signature policy is StrictSign but it was not');if(e.signature==null)throw new X("StrictSigning: Signing required and no signature was present");if(e.sequenceNumber==null)throw new X("StrictSigning: Signing required and no sequenceNumber was present");if(!await iu(e,this.encodeMessage.bind(this)))throw new X("StrictSigning: Invalid message signature");break;default:throw new X("Cannot validate message: unhandled signature policy")}let s=this.topicValidators.get(e.topic);if(s!=null){let i=await s(t,e);if(i===fr.Reject||i===fr.Ignore)throw new X("Message validation failed")}}async buildMessage(t){switch(this.globalSignaturePolicy){case"StrictSign":return su(this.components.privateKey,t,this.encodeMessage.bind(this));case"StrictNoSign":return Promise.resolve({type:"unsigned",...t});default:throw new X("Cannot build message: unhandled signature policy")}}getSubscribers(t){if(!this.started)throw new Yr("not started yet");if(t==null)throw new et("Topic is required");let e=this.topics.get(t.toString());return e==null?[]:Array.from(e.values())}async publish(t,e){if(!this.started)throw new Error("Pubsub has not started");let n={from:this.components.peerId,topic:t,data:e??new Uint8Array(0),sequenceNumber:Xc()};this.log("publish topic: %s from: %p data: %m",t,n.from,n.data);let s=await this.buildMessage(n),i=!1;this.emitSelf&&this.subscriptions.has(t)&&(i=!0,super.dispatchEvent(new CustomEvent("message",{detail:s})));let o=await this.publishMessage(this.components.peerId,s);return i&&(o.recipients=[...o.recipients,this.components.peerId]),o}subscribe(t){if(!this.started)throw new Error("Pubsub has not started");if(this.log("subscribe to topic: %s",t),!this.subscriptions.has(t)){this.subscriptions.add(t);for(let e of this.peers.keys())this.send(e,{subscriptions:[t],subscribe:!0})}}unsubscribe(t){if(!this.started)throw new Error("Pubsub is not started");super.removeEventListener(t);let e=this.subscriptions.has(t);if(this.log("unsubscribe from %s - am subscribed %s",t,e),e){this.subscriptions.delete(t);for(let n of this.peers.keys())this.send(n,{subscriptions:[t],subscribe:!1})}}getTopics(){if(!this.started)throw new Error("Pubsub is not started");return Array.from(this.subscriptions)}getPeers(){if(!this.started)throw new Error("Pubsub is not started");return Array.from(this.peers.keys())}};var Ss=class{entries;validityMs;lastPruneTime=0;constructor(t){this.entries=new Map,this.validityMs=t.validityMs}put(t,e){this.entries.set(t,{value:e,validUntilMs:Date.now()+this.validityMs}),this.prune()}prune(){let t=Date.now();if(!(t-this.lastPruneTime<200)){this.lastPruneTime=t;for(let[e,n]of this.entries.entries())if(n.validUntilMs<t)this.entries.delete(e);else break}}has(t){return this.entries.has(t)}get(t){let e=this.entries.get(t);return e!=null&&e.validUntilMs>=Date.now()?e.value:void 0}clear(){this.entries=new Map,this.lastPruneTime=0}};var fo="/floodsub/1.0.0";var Pe;(function(r){let t;(function(s){let i;s.codec=()=>(i==null&&(i=At((o,a,c={})=>{c.lengthDelimited!==!1&&a.fork(),o.subscribe!=null&&(a.uint32(8),a.bool(o.subscribe)),o.topic!=null&&(a.uint32(18),a.string(o.topic)),c.lengthDelimited!==!1&&a.ldelim()},(o,a,c={})=>{let l={},f=a==null?o.len:o.pos+a;for(;o.pos<f;){let u=o.uint32();switch(u>>>3){case 1:{l.subscribe=o.bool();break}case 2:{l.topic=o.string();break}default:{o.skipType(u&7);break}}}return l})),i),s.encode=o=>St(o,s.codec()),s.decode=(o,a)=>Bt(o,s.codec(),a)})(t=r.SubOpts||(r.SubOpts={}));let e;(function(s){let i;s.codec=()=>(i==null&&(i=At((o,a,c={})=>{c.lengthDelimited!==!1&&a.fork(),o.from!=null&&(a.uint32(10),a.bytes(o.from)),o.data!=null&&(a.uint32(18),a.bytes(o.data)),o.sequenceNumber!=null&&(a.uint32(26),a.bytes(o.sequenceNumber)),o.topic!=null&&(a.uint32(34),a.string(o.topic)),o.signature!=null&&(a.uint32(42),a.bytes(o.signature)),o.key!=null&&(a.uint32(50),a.bytes(o.key)),c.lengthDelimited!==!1&&a.ldelim()},(o,a,c={})=>{let l={},f=a==null?o.len:o.pos+a;for(;o.pos<f;){let u=o.uint32();switch(u>>>3){case 1:{l.from=o.bytes();break}case 2:{l.data=o.bytes();break}case 3:{l.sequenceNumber=o.bytes();break}case 4:{l.topic=o.string();break}case 5:{l.signature=o.bytes();break}case 6:{l.key=o.bytes();break}default:{o.skipType(u&7);break}}}return l})),i),s.encode=o=>St(o,s.codec()),s.decode=(o,a)=>Bt(o,s.codec(),a)})(e=r.Message||(r.Message={}));let n;r.codec=()=>(n==null&&(n=At((s,i,o={})=>{if(o.lengthDelimited!==!1&&i.fork(),s.subscriptions!=null)for(let a of s.subscriptions)i.uint32(10),r.SubOpts.codec().encode(a,i);if(s.messages!=null)for(let a of s.messages)i.uint32(18),r.Message.codec().encode(a,i);s.control!=null&&(i.uint32(26),As.codec().encode(s.control,i)),o.lengthDelimited!==!1&&i.ldelim()},(s,i,o={})=>{let a={subscriptions:[],messages:[]},c=i==null?s.len:s.pos+i;for(;s.pos<c;){let l=s.uint32();switch(l>>>3){case 1:{if(o.limits?.subscriptions!=null&&a.subscriptions.length===o.limits.subscriptions)throw new Ct('Decode error - map field "subscriptions" had too many elements');a.subscriptions.push(r.SubOpts.codec().decode(s,s.uint32(),{limits:o.limits?.subscriptions$}));break}case 2:{if(o.limits?.messages!=null&&a.messages.length===o.limits.messages)throw new Ct('Decode error - map field "messages" had too many elements');a.messages.push(r.Message.codec().decode(s,s.uint32(),{limits:o.limits?.messages$}));break}case 3:{a.control=As.codec().decode(s,s.uint32(),{limits:o.limits?.control});break}default:{s.skipType(l&7);break}}}return a})),n),r.encode=s=>St(s,r.codec()),r.decode=(s,i)=>Bt(s,r.codec(),i)})(Pe||(Pe={}));var As;(function(r){let t;r.codec=()=>(t==null&&(t=At((e,n,s={})=>{if(s.lengthDelimited!==!1&&n.fork(),e.ihave!=null)for(let i of e.ihave)n.uint32(10),ks.codec().encode(i,n);if(e.iwant!=null)for(let i of e.iwant)n.uint32(18),Is.codec().encode(i,n);if(e.graft!=null)for(let i of e.graft)n.uint32(26),Ns.codec().encode(i,n);if(e.prune!=null)for(let i of e.prune)n.uint32(34),Ts.codec().encode(i,n);s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let i={ihave:[],iwant:[],graft:[],prune:[]},o=n==null?e.len:e.pos+n;for(;e.pos<o;){let a=e.uint32();switch(a>>>3){case 1:{if(s.limits?.ihave!=null&&i.ihave.length===s.limits.ihave)throw new Ct('Decode error - map field "ihave" had too many elements');i.ihave.push(ks.codec().decode(e,e.uint32(),{limits:s.limits?.ihave$}));break}case 2:{if(s.limits?.iwant!=null&&i.iwant.length===s.limits.iwant)throw new Ct('Decode error - map field "iwant" had too many elements');i.iwant.push(Is.codec().decode(e,e.uint32(),{limits:s.limits?.iwant$}));break}case 3:{if(s.limits?.graft!=null&&i.graft.length===s.limits.graft)throw new Ct('Decode error - map field "graft" had too many elements');i.graft.push(Ns.codec().decode(e,e.uint32(),{limits:s.limits?.graft$}));break}case 4:{if(s.limits?.prune!=null&&i.prune.length===s.limits.prune)throw new Ct('Decode error - map field "prune" had too many elements');i.prune.push(Ts.codec().decode(e,e.uint32(),{limits:s.limits?.prune$}));break}default:{e.skipType(a&7);break}}}return i})),t),r.encode=e=>St(e,r.codec()),r.decode=(e,n)=>Bt(e,r.codec(),n)})(As||(As={}));var ks;(function(r){let t;r.codec=()=>(t==null&&(t=At((e,n,s={})=>{if(s.lengthDelimited!==!1&&n.fork(),e.topic!=null&&(n.uint32(10),n.string(e.topic)),e.messageIDs!=null)for(let i of e.messageIDs)n.uint32(18),n.bytes(i);s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let i={messageIDs:[]},o=n==null?e.len:e.pos+n;for(;e.pos<o;){let a=e.uint32();switch(a>>>3){case 1:{i.topic=e.string();break}case 2:{if(s.limits?.messageIDs!=null&&i.messageIDs.length===s.limits.messageIDs)throw new Ct('Decode error - map field "messageIDs" had too many elements');i.messageIDs.push(e.bytes());break}default:{e.skipType(a&7);break}}}return i})),t),r.encode=e=>St(e,r.codec()),r.decode=(e,n)=>Bt(e,r.codec(),n)})(ks||(ks={}));var Is;(function(r){let t;r.codec=()=>(t==null&&(t=At((e,n,s={})=>{if(s.lengthDelimited!==!1&&n.fork(),e.messageIDs!=null)for(let i of e.messageIDs)n.uint32(10),n.bytes(i);s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let i={messageIDs:[]},o=n==null?e.len:e.pos+n;for(;e.pos<o;){let a=e.uint32();switch(a>>>3){case 1:{if(s.limits?.messageIDs!=null&&i.messageIDs.length===s.limits.messageIDs)throw new Ct('Decode error - map field "messageIDs" had too many elements');i.messageIDs.push(e.bytes());break}default:{e.skipType(a&7);break}}}return i})),t),r.encode=e=>St(e,r.codec()),r.decode=(e,n)=>Bt(e,r.codec(),n)})(Is||(Is={}));var Ns;(function(r){let t;r.codec=()=>(t==null&&(t=At((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.topic!=null&&(n.uint32(10),n.string(e.topic)),s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let i={},o=n==null?e.len:e.pos+n;for(;e.pos<o;){let a=e.uint32();switch(a>>>3){case 1:{i.topic=e.string();break}default:{e.skipType(a&7);break}}}return i})),t),r.encode=e=>St(e,r.codec()),r.decode=(e,n)=>Bt(e,r.codec(),n)})(Ns||(Ns={}));var Ts;(function(r){let t;r.codec=()=>(t==null&&(t=At((e,n,s={})=>{if(s.lengthDelimited!==!1&&n.fork(),e.topic!=null&&(n.uint32(10),n.string(e.topic)),e.peers!=null)for(let i of e.peers)n.uint32(18),Cs.codec().encode(i,n);e.backoff!=null&&(n.uint32(24),n.uint64(e.backoff)),s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let i={peers:[]},o=n==null?e.len:e.pos+n;for(;e.pos<o;){let a=e.uint32();switch(a>>>3){case 1:{i.topic=e.string();break}case 2:{if(s.limits?.peers!=null&&i.peers.length===s.limits.peers)throw new Ct('Decode error - map field "peers" had too many elements');i.peers.push(Cs.codec().decode(e,e.uint32(),{limits:s.limits?.peers$}));break}case 3:{i.backoff=e.uint64();break}default:{e.skipType(a&7);break}}}return i})),t),r.encode=e=>St(e,r.codec()),r.decode=(e,n)=>Bt(e,r.codec(),n)})(Ts||(Ts={}));var Cs;(function(r){let t;r.codec=()=>(t==null&&(t=At((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.peerID!=null&&(n.uint32(10),n.bytes(e.peerID)),e.signedPeerRecord!=null&&(n.uint32(18),n.bytes(e.signedPeerRecord)),s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let i={},o=n==null?e.len:e.pos+n;for(;e.pos<o;){let a=e.uint32();switch(a>>>3){case 1:{i.peerID=e.bytes();break}case 2:{i.signedPeerRecord=e.bytes();break}default:{e.skipType(a&7);break}}}return i})),t),r.encode=e=>St(e,r.codec()),r.decode=(e,n)=>Bt(e,r.codec(),n)})(Cs||(Cs={}));var ho=class extends Bs{seenCache;constructor(t,e){super(t,{...e,canRelayMessage:!0,multicodecs:[fo]}),this.log=t.logger.forComponent("libp2p:floodsub"),this.seenCache=new Ss({validityMs:e?.seenTTL??3e4})}[So]=!0;[Symbol.toStringTag]="@libp2p/floodsub";[Ao]=["@libp2p/pubsub"];[ko]=["@libp2p/identify"];decodeRpc(t){return Pe.decode(t)}encodeRpc(t){return Pe.encode(t)}decodeMessage(t){return Pe.Message.decode(t)}encodeMessage(t){return Pe.Message.encode(t)}async processMessage(t,e){let n=await super.getMsgId(e),s=Ot(n,"base64");this.seenCache.has(s)||(this.seenCache.put(s,!0),await super.processMessage(t,e))}async publishMessage(t,e){let n=this.getSubscribers(e.topic),s=[];return n==null||n.length===0?(this.log("no peers are subscribed to topic %s",e.topic),{recipients:s}):(n.forEach(i=>{if(this.components.peerId.equals(i)){this.log("not sending message on topic %s to myself",e.topic);return}if(i.equals(t)){this.log("not sending message on topic %s to sender %p",e.topic,i);return}this.log("publish msgs on topics %s %p",e.topic,i),s.push(i),this.send(i,{messages:[e]})}),{recipients:s})}};function Uh(r={}){return t=>new ho(t,r)}return wu(Lh);})();
6
+ `)}`:`${e} :`}};Oa=ve;S.Constructed=Oa;ve.NAME="CONSTRUCTED";var An=class extends pt{fromBER(t,e,n){return e}toBER(t){return Ht}};An.override="EndOfContentValueBlock";var Pa,kn=class extends ct{constructor(t={}){super(t,An),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};Pa=kn;S.EndOfContent=Pa;kn.NAME=Sr;var Fa,nr=class extends ct{constructor(t={}){super(t,pt),this.idBlock.tagClass=1,this.idBlock.tagNumber=5}fromBER(t,e,n){return this.lenBlock.length>0&&this.warnings.push("Non-zero length of value block for Null type"),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.blockLength+=n,e+n>t.byteLength?(this.error="End of input reached before message was fully decoded (inconsistent offset and length values)",-1):e+n}toBER(t,e){let n=new ArrayBuffer(2);if(!t){let s=new Uint8Array(n);s[0]=5,s[1]=0}return e&&e.write(n),n}onAsciiEncoding(){return`${this.constructor.NAME}`}};Fa=nr;S.Null=Fa;nr.NAME="NULL";var In=class extends ie(pt){constructor({value:t,...e}={}){super(e),e.valueHex?this.valueHexView=O.BufferSourceConverter.toUint8Array(e.valueHex):this.valueHexView=new Uint8Array(1),t&&(this.value=t)}get value(){for(let t of this.valueHexView)if(t>0)return!0;return!1}set value(t){this.valueHexView[0]=t?255:0}fromBER(t,e,n){let s=O.BufferSourceConverter.toUint8Array(t);return se(this,s,e,n)?(this.valueHexView=s.subarray(e,e+n),n>1&&this.warnings.push("Boolean value encoded in more then 1 octet"),this.isHexOnly=!0,Ki.call(this),this.blockLength=n,e+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};In.NAME="BooleanValueBlock";var Ka,Nn=class extends ct{constructor(t={}){super(t,In),this.idBlock.tagClass=1,this.idBlock.tagNumber=1}getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.getValue}`}};Ka=Nn;S.Boolean=Ka;Nn.NAME="BOOLEAN";var Tn=class extends ie(qt){constructor({isConstructed:t=!1,...e}={}){super(e),this.isConstructed=t}fromBER(t,e,n){let s=0;if(this.isConstructed){if(this.isHexOnly=!1,s=qt.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let i=0;i<this.value.length;i++){let o=this.value[i].constructor.NAME;if(o===Sr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(o!==Da)return this.error="OCTET STRING may consists of OCTET STRINGs only",-1}}else this.isHexOnly=!0,s=super.fromBER(t,e,n),this.blockLength=n;return s}toBER(t,e){return this.isConstructed?qt.prototype.toBER.call(this,t,e):t?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};Tn.NAME="OctetStringValueBlock";var qa,Cn=class r extends ct{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,i;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((i=n.value)===null||i===void 0)&&i.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},Tn),this.idBlock.tagClass=1,this.idBlock.tagNumber=4}fromBER(t,e,n){if(this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,n===0)return this.idBlock.error.length===0&&(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length===0&&(this.blockLength+=this.lenBlock.blockLength),e;if(!this.valueBlock.isConstructed){let i=(t instanceof ArrayBuffer?new Uint8Array(t):t).subarray(e,e+n);try{if(i.byteLength){let o=ss(i,0,i.byteLength);o.offset!==-1&&o.offset===n&&(this.valueBlock.value=[o.result])}}catch{}}return super.fromBER(t,e,n)}onAsciiEncoding(){return this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length?ve.prototype.onAsciiEncoding.call(this):`${this.constructor.NAME} : ${O.Convert.ToHex(this.valueBlock.valueHexView)}`}getValue(){if(!this.idBlock.isConstructed)return this.valueBlock.valueHexView.slice().buffer;let t=[];for(let e of this.valueBlock.value)e instanceof r&&t.push(e.valueBlock.valueHexView);return O.BufferSourceConverter.concat(t)}};qa=Cn;S.OctetString=qa;Cn.NAME=Da;var Un=class extends ie(qt){constructor({unusedBits:t=0,isConstructed:e=!1,...n}={}){super(n),this.unusedBits=t,this.isConstructed=e,this.blockLength=this.valueHexView.byteLength}fromBER(t,e,n){if(!n)return e;let s=-1;if(this.isConstructed){if(s=qt.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let a of this.value){let c=a.constructor.NAME;if(c===Sr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==Ma)return this.error="BIT STRING may consists of BIT STRINGs only",-1;let l=a.valueBlock;if(this.unusedBits>0&&l.unusedBits>0)return this.error='Using of "unused bits" inside constructive BIT STRING allowed for least one only',-1;this.unusedBits=l.unusedBits}return s}let i=O.BufferSourceConverter.toUint8Array(t);if(!se(this,i,e,n))return-1;let o=i.subarray(e,e+n);if(this.unusedBits=o[0],this.unusedBits>7)return this.error="Unused bits for BitString must be in range 0-7",-1;if(!this.unusedBits){let a=o.subarray(1);try{if(a.byteLength){let c=ss(a,0,a.byteLength);c.offset!==-1&&c.offset===n-1&&(this.value=[c.result])}}catch{}}return this.valueHexView=o.subarray(1),this.blockLength=o.length,e+n}toBER(t,e){if(this.isConstructed)return qt.prototype.toBER.call(this,t,e);if(t)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return Ht;let n=new Uint8Array(this.valueHexView.length+1);return n[0]=this.unusedBits,n.set(this.valueHexView,1),n.buffer}toJSON(){return{...super.toJSON(),unusedBits:this.unusedBits,isConstructed:this.isConstructed}}};Un.NAME="BitStringValueBlock";var za,sr=class extends ct{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,i;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((i=n.value)===null||i===void 0)&&i.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},Un),this.idBlock.tagClass=1,this.idBlock.tagNumber=3}fromBER(t,e,n){return this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,super.fromBER(t,e,n)}onAsciiEncoding(){if(this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length)return ve.prototype.onAsciiEncoding.call(this);{let t=[],e=this.valueBlock.valueHexView;for(let s of e)t.push(s.toString(2).padStart(8,"0"));let n=t.join("");return`${this.constructor.NAME} : ${n.substring(0,n.length-this.valueBlock.unusedBits)}`}}};za=sr;S.BitString=za;sr.NAME=Ma;var $a;function eh(r,t){let e=new Uint8Array([0]),n=new Uint8Array(r),s=new Uint8Array(t),i=n.slice(0),o=i.length-1,a=s.slice(0),c=a.length-1,l=0,f=c<o?o:c,u=0;for(let d=f;d>=0;d--,u++){switch(!0){case u<a.length:l=i[o-u]+a[c-u]+e[0];break;default:l=i[o-u]+e[0]}switch(e[0]=l/10,!0){case u>=i.length:i=yn(new Uint8Array([l%10]),i);break;default:i[o-u]=l%10}}return e[0]>0&&(i=yn(e,i)),i}function _a(r){if(r>=Er.length)for(let t=Er.length;t<=r;t++){let e=new Uint8Array([0]),n=Er[t-1].slice(0);for(let s=n.length-1;s>=0;s--){let i=new Uint8Array([(n[s]<<1)+e[0]]);e[0]=i[0]/10,n[s]=i[0]%10}e[0]>0&&(n=yn(e,n)),Er.push(n)}return Er[r]}function rh(r,t){let e=0,n=new Uint8Array(r),s=new Uint8Array(t),i=n.slice(0),o=i.length-1,a=s.slice(0),c=a.length-1,l,f=0;for(let u=c;u>=0;u--,f++)switch(l=i[o-f]-a[c-f]-e,!0){case l<0:e=1,i[o-f]=l+10;break;default:e=0,i[o-f]=l}if(e>0)for(let u=o-c+1;u>=0;u--,f++)if(l=i[o-f]-e,l<0)e=1,i[o-f]=l+10;else{e=0,i[o-f]=l;break}return i.slice()}var Ar=class extends ie(pt){constructor({value:t,...e}={}){super(e),this._valueDec=0,e.valueHex&&this.setValueHex(),t!==void 0&&(this.valueDec=t)}setValueHex(){this.valueHexView.length>=4?(this.warnings.push("Too big Integer for decoding, hex only"),this.isHexOnly=!0,this._valueDec=0):(this.isHexOnly=!1,this.valueHexView.length>0&&(this._valueDec=Ki.call(this)))}set valueDec(t){this._valueDec=t,this.isHexOnly=!1,this.valueHexView=new Uint8Array(Ua(t))}get valueDec(){return this._valueDec}fromDER(t,e,n,s=0){let i=this.fromBER(t,e,n);if(i===-1)return i;let o=this.valueHexView;return o[0]===0&&o[1]&128?this.valueHexView=o.subarray(1):s!==0&&o.length<s&&(s-o.length>1&&(s=o.length+1),this.valueHexView=o.subarray(s-o.length)),i}toDER(t=!1){let e=this.valueHexView;switch(!0){case(e[0]&128)!==0:{let n=new Uint8Array(this.valueHexView.length+1);n[0]=0,n.set(e,1),this.valueHexView=n}break;case(e[0]===0&&(e[1]&128)===0):this.valueHexView=this.valueHexView.subarray(1);break}return this.toBER(t)}fromBER(t,e,n){let s=super.fromBER(t,e,n);return s===-1||this.setValueHex(),s}toBER(t){return t?new ArrayBuffer(this.valueHexView.length):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}toString(){let t=this.valueHexView.length*8-1,e=new Uint8Array(this.valueHexView.length*8/3),n=0,s,i=this.valueHexView,o="",a=!1;for(let c=i.byteLength-1;c>=0;c--){s=i[c];for(let l=0;l<8;l++){if((s&1)===1)switch(n){case t:e=rh(_a(n),e),o="-";break;default:e=eh(e,_a(n))}n++,s>>=1}}for(let c=0;c<e.length;c++)e[c]&&(a=!0),a&&(o+=Ra.charAt(e[c]));return a===!1&&(o+=Ra.charAt(0)),o}};$a=Ar;Ar.NAME="IntegerValueBlock";Object.defineProperty($a.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var Ga,ut=class r extends ct{constructor(t={}){super(t,Ar),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return wn(),BigInt(this.valueBlock.toString())}static fromBigInt(t){wn();let e=BigInt(t),n=new Br,s=e.toString(16).replace(/^-/,""),i=new Uint8Array(O.Convert.FromHex(s));if(e<0){let a=new Uint8Array(i.length+(i[0]&128?1:0));a[0]|=128;let l=BigInt(`0x${O.Convert.ToHex(a)}`)+e,f=O.BufferSourceConverter.toUint8Array(O.Convert.FromHex(l.toString(16)));f[0]|=128,n.write(f)}else i[0]&128&&n.write(new Uint8Array([0])),n.write(i);return new r({valueHex:n.final()})}convertToDER(){let t=new r({valueHex:this.valueBlock.valueHexView});return t.valueBlock.toDER(),t}convertFromDER(){return new r({valueHex:this.valueBlock.valueHexView[0]===0?this.valueBlock.valueHexView.subarray(1):this.valueBlock.valueHexView})}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()}`}};Ga=ut;S.Integer=Ga;ut.NAME="INTEGER";var Za,Ln=class extends ut{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};Za=Ln;S.Enumerated=Za;Ln.NAME="ENUMERATED";var kr=class extends ie(pt){constructor({valueDec:t=-1,isFirstSid:e=!1,...n}={}){super(n),this.valueDec=t,this.isFirstSid=e}fromBER(t,e,n){if(!n)return e;let s=O.BufferSourceConverter.toUint8Array(t);if(!se(this,s,e,n))return-1;let i=s.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=i[a]&127,this.blockLength++,!!(i[a]&128));a++);let o=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)o[a]=this.valueHexView[a];return this.valueHexView=o,i[this.blockLength-1]&128?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=De(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}set valueBigInt(t){wn();let e=BigInt(t).toString(2);for(;e.length%7;)e="0"+e;let n=new Uint8Array(e.length/7);for(let s=0;s<n.length;s++)n[s]=parseInt(e.slice(s*7,s*7+7),2)+(s+1<n.length?128:0);this.fromBER(n.buffer,0,n.length)}toBER(t){if(this.isHexOnly){if(t)return new ArrayBuffer(this.valueHexView.byteLength);let s=this.valueHexView,i=new Uint8Array(this.blockLength);for(let o=0;o<this.blockLength-1;o++)i[o]=s[o]|128;return i[this.blockLength-1]=s[this.blockLength-1],i.buffer}let e=xe(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Ht;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),i=e.byteLength-1;for(let o=0;o<i;o++)n[o]=s[o]|128;n[i]=s[i]}return n}toString(){let t="";if(this.isHexOnly)t=O.Convert.ToHex(this.valueHexView);else if(this.isFirstSid){let e=this.valueDec;this.valueDec<=39?t="0.":this.valueDec<=79?(t="1.",e-=40):(t="2.",e-=80),t+=e.toString()}else t=this.valueDec.toString();return t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec,isFirstSid:this.isFirstSid}}};kr.NAME="sidBlock";var Rn=class extends pt{constructor({value:t=or,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let i=new kr;if(s=i.fromBER(t,s,n),s===-1)return this.blockLength=0,this.error=i.error,s;this.value.length===0&&(i.isFirstSid=!0),this.blockLength+=i.blockLength,n-=i.blockLength,this.value.push(i)}return s}toBER(t){let e=[];for(let n=0;n<this.value.length;n++){let s=this.value[n].toBER(t);if(s.byteLength===0)return this.error=this.value[n].error,Ht;e.push(s)}return qi(e)}fromString(t){this.value=[];let e=0,n=0,s="",i=!1;do if(n=t.indexOf(".",e),n===-1?s=t.substring(e):s=t.substring(e,n),e=n+1,i){let o=this.value[0],a=0;switch(o.valueDec){case 0:break;case 1:a=40;break;case 2:a=80;break;default:this.value=[];return}let c=parseInt(s,10);if(isNaN(c))return;o.valueDec=c+a,i=!1}else{let o=new kr;if(s>Number.MAX_SAFE_INTEGER){wn();let a=BigInt(s);o.valueBigInt=a}else if(o.valueDec=parseInt(s,10),isNaN(o.valueDec))return;this.value.length||(o.isFirstSid=!0,i=!0),this.value.push(o)}while(n!==-1)}toString(){let t="",e=!1;for(let n=0;n<this.value.length;n++){e=this.value[n].isHexOnly;let s=this.value[n].toString();n!==0&&(t=`${t}.`),e?(s=`{${s}}`,this.value[n].isFirstSid?t=`2.{${s} - 80}`:t+=s):t+=s}return t}toJSON(){let t={...super.toJSON(),value:this.toString(),sidArray:[]};for(let e=0;e<this.value.length;e++)t.sidArray.push(this.value[e].toJSON());return t}};Rn.NAME="ObjectIdentifierValueBlock";var Wa,ir=class extends ct{constructor(t={}){super(t,Rn),this.idBlock.tagClass=1,this.idBlock.tagNumber=6}getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};Wa=ir;S.ObjectIdentifier=Wa;ir.NAME="OBJECT IDENTIFIER";var Ir=class extends ie(ee){constructor({valueDec:t=0,...e}={}){super(e),this.valueDec=t}fromBER(t,e,n){if(n===0)return e;let s=O.BufferSourceConverter.toUint8Array(t);if(!se(this,s,e,n))return-1;let i=s.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=i[a]&127,this.blockLength++,!!(i[a]&128));a++);let o=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)o[a]=this.valueHexView[a];return this.valueHexView=o,i[this.blockLength-1]&128?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=De(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}toBER(t){if(this.isHexOnly){if(t)return new ArrayBuffer(this.valueHexView.byteLength);let s=this.valueHexView,i=new Uint8Array(this.blockLength);for(let o=0;o<this.blockLength-1;o++)i[o]=s[o]|128;return i[this.blockLength-1]=s[this.blockLength-1],i.buffer}let e=xe(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Ht;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),i=e.byteLength-1;for(let o=0;o<i;o++)n[o]=s[o]|128;n[i]=s[i]}return n.buffer}toString(){let t="";return this.isHexOnly?t=O.Convert.ToHex(this.valueHexView):t=this.valueDec.toString(),t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};Ir.NAME="relativeSidBlock";var _n=class extends pt{constructor({value:t=or,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let i=new Ir;if(s=i.fromBER(t,s,n),s===-1)return this.blockLength=0,this.error=i.error,s;this.blockLength+=i.blockLength,n-=i.blockLength,this.value.push(i)}return s}toBER(t,e){let n=[];for(let s=0;s<this.value.length;s++){let i=this.value[s].toBER(t);if(i.byteLength===0)return this.error=this.value[s].error,Ht;n.push(i)}return qi(n)}fromString(t){this.value=[];let e=0,n=0,s="";do{n=t.indexOf(".",e),n===-1?s=t.substring(e):s=t.substring(e,n),e=n+1;let i=new Ir;if(i.valueDec=parseInt(s,10),isNaN(i.valueDec))return!0;this.value.push(i)}while(n!==-1);return!0}toString(){let t="",e=!1;for(let n=0;n<this.value.length;n++){e=this.value[n].isHexOnly;let s=this.value[n].toString();n!==0&&(t=`${t}.`),e&&(s=`{${s}}`),t+=s}return t}toJSON(){let t={...super.toJSON(),value:this.toString(),sidArray:[]};for(let e=0;e<this.value.length;e++)t.sidArray.push(this.value[e].toJSON());return t}};_n.NAME="RelativeObjectIdentifierValueBlock";var ja,Dn=class extends ct{constructor(t={}){super(t,_n),this.idBlock.tagClass=1,this.idBlock.tagNumber=13}getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};ja=Dn;S.RelativeObjectIdentifier=ja;Dn.NAME="RelativeObjectIdentifier";var Ya,re=class extends ve{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};Ya=re;S.Sequence=Ya;re.NAME="SEQUENCE";var Ja,Mn=class extends ve{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};Ja=Mn;S.Set=Ja;Mn.NAME="SET";var Vn=class extends ie(pt){constructor({...t}={}){super(t),this.isHexOnly=!0,this.value=or}toJSON(){return{...super.toJSON(),value:this.value}}};Vn.NAME="StringValueBlock";var Hn=class extends Vn{};Hn.NAME="SimpleStringValueBlock";var yt=class extends En{constructor({...t}={}){super(t,Hn)}fromBuffer(t){this.valueBlock.value=String.fromCharCode.apply(null,O.BufferSourceConverter.toUint8Array(t))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e);for(let s=0;s<e;s++)n[s]=t.charCodeAt(s);this.valueBlock.value=t}};yt.NAME="SIMPLE STRING";var On=class extends yt{fromBuffer(t){this.valueBlock.valueHexView=O.BufferSourceConverter.toUint8Array(t);try{this.valueBlock.value=O.Convert.ToUtf8String(t)}catch(e){this.warnings.push(`Error during "decodeURIComponent": ${e}, using raw string`),this.valueBlock.value=O.Convert.ToBinary(t)}}fromString(t){this.valueBlock.valueHexView=new Uint8Array(O.Convert.FromUtf8String(t)),this.valueBlock.value=t}};On.NAME="Utf8StringValueBlock";var Xa,ne=class extends On{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};Xa=ne;S.Utf8String=Xa;ne.NAME="UTF8String";var Pn=class extends yt{fromBuffer(t){this.valueBlock.value=O.Convert.ToUtf16String(t),this.valueBlock.valueHexView=O.BufferSourceConverter.toUint8Array(t)}fromString(t){this.valueBlock.value=t,this.valueBlock.valueHexView=new Uint8Array(O.Convert.FromUtf16String(t))}};Pn.NAME="BmpStringValueBlock";var Qa,Fn=class extends Pn{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};Qa=Fn;S.BmpString=Qa;Fn.NAME="BMPString";var Kn=class extends yt{fromBuffer(t){let e=ArrayBuffer.isView(t)?t.slice().buffer:t.slice(0),n=new Uint8Array(e);for(let s=0;s<n.length;s+=4)n[s]=n[s+3],n[s+1]=n[s+2],n[s+2]=0,n[s+3]=0;this.valueBlock.value=String.fromCharCode.apply(null,new Uint32Array(e))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e*4);for(let s=0;s<e;s++){let i=xe(t.charCodeAt(s),8),o=new Uint8Array(i);if(o.length>4)continue;let a=4-o.length;for(let c=o.length-1;c>=0;c--)n[s*4+c+a]=o[c]}this.valueBlock.value=t}};Kn.NAME="UniversalStringValueBlock";var tc,qn=class extends Kn{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};tc=qn;S.UniversalString=tc;qn.NAME="UniversalString";var ec,zn=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};ec=zn;S.NumericString=ec;zn.NAME="NumericString";var rc,$n=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};rc=$n;S.PrintableString=rc;$n.NAME="PrintableString";var nc,Gn=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};nc=Gn;S.TeletexString=nc;Gn.NAME="TeletexString";var sc,Zn=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};sc=Zn;S.VideotexString=sc;Zn.NAME="VideotexString";var ic,Wn=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};ic=Wn;S.IA5String=ic;Wn.NAME="IA5String";var oc,jn=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};oc=jn;S.GraphicString=oc;jn.NAME="GraphicString";var ac,Nr=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};ac=Nr;S.VisibleString=ac;Nr.NAME="VisibleString";var cc,Yn=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};cc=Yn;S.GeneralString=cc;Yn.NAME="GeneralString";var uc,Jn=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};uc=Jn;S.CharacterString=uc;Jn.NAME="CharacterString";var lc,Tr=class extends Nr{constructor({value:t,valueDate:e,...n}={}){if(super(n),this.year=0,this.month=0,this.day=0,this.hour=0,this.minute=0,this.second=0,t){this.fromString(t),this.valueBlock.valueHexView=new Uint8Array(t.length);for(let s=0;s<t.length;s++)this.valueBlock.valueHexView[s]=t.charCodeAt(s)}e&&(this.fromDate(e),this.valueBlock.valueHexView=new Uint8Array(this.toBuffer())),this.idBlock.tagClass=1,this.idBlock.tagNumber=23}fromBuffer(t){this.fromString(String.fromCharCode.apply(null,O.BufferSourceConverter.toUint8Array(t)))}toBuffer(){let t=this.toString(),e=new ArrayBuffer(t.length),n=new Uint8Array(e);for(let s=0;s<t.length;s++)n[s]=t.charCodeAt(s);return e}fromDate(t){this.year=t.getUTCFullYear(),this.month=t.getUTCMonth()+1,this.day=t.getUTCDate(),this.hour=t.getUTCHours(),this.minute=t.getUTCMinutes(),this.second=t.getUTCSeconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second))}fromString(t){let n=/(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})Z/ig.exec(t);if(n===null){this.error="Wrong input string for conversion";return}let s=parseInt(n[1],10);s>=50?this.year=1900+s:this.year=2e3+s,this.month=parseInt(n[2],10),this.day=parseInt(n[3],10),this.hour=parseInt(n[4],10),this.minute=parseInt(n[5],10),this.second=parseInt(n[6],10)}toString(t="iso"){if(t==="iso"){let e=new Array(7);return e[0]=kt(this.year<2e3?this.year-1900:this.year-2e3,2),e[1]=kt(this.month,2),e[2]=kt(this.day,2),e[3]=kt(this.hour,2),e[4]=kt(this.minute,2),e[5]=kt(this.second,2),e[6]="Z",e.join("")}return super.toString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.toDate().toISOString()}`}toJSON(){return{...super.toJSON(),year:this.year,month:this.month,day:this.day,hour:this.hour,minute:this.minute,second:this.second}}};lc=Tr;S.UTCTime=lc;Tr.NAME="UTCTime";var fc,Xn=class extends Tr{constructor(t={}){var e;super(t),(e=this.millisecond)!==null&&e!==void 0||(this.millisecond=0),this.idBlock.tagClass=1,this.idBlock.tagNumber=24}fromDate(t){super.fromDate(t),this.millisecond=t.getUTCMilliseconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second,this.millisecond))}fromString(t){let e=!1,n="",s="",i=0,o,a=0,c=0;if(t[t.length-1]==="Z")n=t.substring(0,t.length-1),e=!0;else{let u=new Number(t[t.length-1]);if(isNaN(u.valueOf()))throw new Error("Wrong input string for conversion");n=t}if(e){if(n.indexOf("+")!==-1)throw new Error("Wrong input string for conversion");if(n.indexOf("-")!==-1)throw new Error("Wrong input string for conversion")}else{let u=1,d=n.indexOf("+"),m="";if(d===-1&&(d=n.indexOf("-"),u=-1),d!==-1){if(m=n.substring(d+1),n=n.substring(0,d),m.length!==2&&m.length!==4)throw new Error("Wrong input string for conversion");let x=parseInt(m.substring(0,2),10);if(isNaN(x.valueOf()))throw new Error("Wrong input string for conversion");if(a=u*x,m.length===4){if(x=parseInt(m.substring(2,4),10),isNaN(x.valueOf()))throw new Error("Wrong input string for conversion");c=u*x}}}let l=n.indexOf(".");if(l===-1&&(l=n.indexOf(",")),l!==-1){let u=new Number(`0${n.substring(l)}`);if(isNaN(u.valueOf()))throw new Error("Wrong input string for conversion");i=u.valueOf(),s=n.substring(0,l)}else s=n;switch(!0){case s.length===8:if(o=/(\d{4})(\d{2})(\d{2})/ig,l!==-1)throw new Error("Wrong input string for conversion");break;case s.length===10:if(o=/(\d{4})(\d{2})(\d{2})(\d{2})/ig,l!==-1){let u=60*i;this.minute=Math.floor(u),u=60*(u-this.minute),this.second=Math.floor(u),u=1e3*(u-this.second),this.millisecond=Math.floor(u)}break;case s.length===12:if(o=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})/ig,l!==-1){let u=60*i;this.second=Math.floor(u),u=1e3*(u-this.second),this.millisecond=Math.floor(u)}break;case s.length===14:if(o=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})/ig,l!==-1){let u=1e3*i;this.millisecond=Math.floor(u)}break;default:throw new Error("Wrong input string for conversion")}let f=o.exec(s);if(f===null)throw new Error("Wrong input string for conversion");for(let u=1;u<f.length;u++)switch(u){case 1:this.year=parseInt(f[u],10);break;case 2:this.month=parseInt(f[u],10);break;case 3:this.day=parseInt(f[u],10);break;case 4:this.hour=parseInt(f[u],10)+a;break;case 5:this.minute=parseInt(f[u],10)+c;break;case 6:this.second=parseInt(f[u],10);break;default:throw new Error("Wrong input string for conversion")}if(e===!1){let u=new Date(this.year,this.month,this.day,this.hour,this.minute,this.second,this.millisecond);this.year=u.getUTCFullYear(),this.month=u.getUTCMonth(),this.day=u.getUTCDay(),this.hour=u.getUTCHours(),this.minute=u.getUTCMinutes(),this.second=u.getUTCSeconds(),this.millisecond=u.getUTCMilliseconds()}}toString(t="iso"){if(t==="iso"){let e=[];return e.push(kt(this.year,4)),e.push(kt(this.month,2)),e.push(kt(this.day,2)),e.push(kt(this.hour,2)),e.push(kt(this.minute,2)),e.push(kt(this.second,2)),this.millisecond!==0&&(e.push("."),e.push(kt(this.millisecond,3))),e.push("Z"),e.join("")}return super.toString(t)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};fc=Xn;S.GeneralizedTime=fc;Xn.NAME="GeneralizedTime";var hc,Qn=class extends ne{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};hc=Qn;S.DATE=hc;Qn.NAME="DATE";var dc,ts=class extends ne{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};dc=ts;S.TimeOfDay=dc;ts.NAME="TimeOfDay";var pc,es=class extends ne{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};pc=es;S.DateTime=pc;es.NAME="DateTime";var gc,rs=class extends ne{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};gc=rs;S.Duration=gc;rs.NAME="Duration";var mc,ns=class extends ne{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};mc=ns;S.TIME=mc;ns.NAME="TIME";function Ot(r,t="utf8"){let e=dn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}function is(r){if(isNaN(r)||r<=0)throw new et("random bytes length must be a Number bigger than 0");return Je(r)}var Cr=class extends Error{constructor(t="An error occurred while verifying a message"){super(t),this.name="VerificationError"}},os=class extends Error{constructor(t="Missing Web Crypto API"){super(t),this.name="WebCryptoMissingError"}};var bc={get(r=globalThis){let t=r.crypto;if(t?.subtle==null)throw new os("Missing Web Crypto API. The most likely cause of this error is that this page is being accessed from an insecure context (i.e. not HTTPS). For more information and possible resolutions see https://github.com/libp2p/js-libp2p/blob/main/packages/crypto/README.md#web-crypto-api");return t}};var Ee=bc;async function yc(r){let t=await Ee.get().subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:r,publicExponent:new Uint8Array([1,0,1]),hash:{name:"SHA-256"}},!0,["sign","verify"]),e=await sh(t);return{privateKey:e[0],publicKey:e[1]}}async function wc(r,t){let e=await Ee.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await Ee.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},e,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(n,0,n.byteLength)}async function xc(r,t,e){let n=await Ee.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return Ee.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,t,e instanceof Uint8Array?e:e.subarray())}async function sh(r){if(r.privateKey==null||r.publicKey==null)throw new et("Private and public key are required");return Promise.all([Ee.get().subtle.exportKey("jwk",r.privateKey),Ee.get().subtle.exportKey("jwk",r.publicKey)])}function Gi(r){if(r.kty!=="RSA")throw new et("invalid key type");if(r.n==null)throw new et("invalid key modulus");return Y(r.n,"base64url").length*8}var ar=class{type="RSA";_key;_raw;_multihash;constructor(t,e){this._key=t,this._multihash=e}get raw(){return this._raw==null&&(this._raw=Ur.jwkToPkix(this._key)),this._raw}toMultihash(){return this._multihash}toCID(){return It.createV1(114,this._multihash)}toString(){return Q.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:Tt(this.raw,t.raw)}verify(t,e){return xc(this._key,e,t)}},Lr=class{type="RSA";_key;_raw;publicKey;constructor(t,e){this._key=t,this.publicKey=e}get raw(){return this._raw==null&&(this._raw=Ur.jwkToPkcs1(this._key)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:Tt(this.raw,t.raw)}sign(t){return wc(this._key,t)}};var as=8192,Zi=18;function vc(r){let{result:t}=$i(r),e=t.valueBlock.value;return{n:zt(e[1]),e:zt(e[2]),d:zt(e[3]),p:zt(e[4]),q:zt(e[5]),dp:zt(e[6]),dq:zt(e[7]),qi:zt(e[8]),kty:"RSA",alg:"RS256"}}function ih(r){if(r.n==null||r.e==null||r.d==null||r.p==null||r.q==null||r.dp==null||r.dq==null||r.qi==null)throw new et("JWK was missing components");let e=new re({value:[new ut({value:0}),ut.fromBigInt($t(Y(r.n,"base64url"))),ut.fromBigInt($t(Y(r.e,"base64url"))),ut.fromBigInt($t(Y(r.d,"base64url"))),ut.fromBigInt($t(Y(r.p,"base64url"))),ut.fromBigInt($t(Y(r.q,"base64url"))),ut.fromBigInt($t(Y(r.dp,"base64url"))),ut.fromBigInt($t(Y(r.dq,"base64url"))),ut.fromBigInt($t(Y(r.qi,"base64url")))]}).toBER();return new Uint8Array(e,0,e.byteLength)}function Ec(r){let{result:t}=$i(r),e=t.valueBlock.value[1].valueBlock.value[0].valueBlock.value;return{kty:"RSA",n:zt(e[0]),e:zt(e[1])}}function Wi(r){if(r.n==null||r.e==null)throw new et("JWK was missing components");let e=new re({value:[new re({value:[new ir({value:"1.2.840.113549.1.1.1"}),new nr]}),new sr({valueHex:new re({value:[ut.fromBigInt($t(Y(r.n,"base64url"))),ut.fromBigInt($t(Y(r.e,"base64url")))]}).toBER()})]}).toBER();return new Uint8Array(e,0,e.byteLength)}function zt(r){let t=r.valueBlock.valueHexView;for(;t[0]===0;)t=t.subarray(1);return Ot(t,"base64url")}function $t(r){let t=[];return r.forEach(function(e){let n=e.toString(16);n.length%2>0&&(n=`0${n}`),t.push(n)}),BigInt("0x"+t.join(""))}function Bc(r){let t=vc(r);return Sc(t)}function ji(r){let t=Ec(r);if(Gi(t)>as)throw new Fe("Key size is too large");let e=er(Kt.encode({Type:nt.RSA,Data:r})),n=Lt(Zi,e);return new ar(t,n)}function Sc(r){if(Gi(r)>as)throw new et("Key size is too large");let t=kc(r),e=er(Kt.encode({Type:nt.RSA,Data:Wi(t.publicKey)})),n=Lt(Zi,e);return new Lr(t.privateKey,new ar(t.publicKey,n))}async function Ac(r){if(r>as)throw new et("Key size is too large");let t=await yc(r),e=er(Kt.encode({Type:nt.RSA,Data:Wi(t.publicKey)})),n=Lt(Zi,e);return new Lr(t.privateKey,new ar(t.publicKey,n))}function kc(r){if(r==null)throw new et("Missing key parameter");return{privateKey:r,publicKey:{kty:r.kty,n:r.n,e:r.e}}}var cs=class extends Ye{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,zo(t);let n=mr(e);if(this.iHash=t.create(),typeof this.iHash.update!="function")throw new Error("Expected instance of class which extends utils.Hash");this.blockLen=this.iHash.blockLen,this.outputLen=this.iHash.outputLen;let s=this.blockLen,i=new Uint8Array(s);i.set(n.length>s?t.create().update(n).digest():n);for(let o=0;o<i.length;o++)i[o]^=54;this.iHash.update(i),this.oHash=t.create();for(let o=0;o<i.length;o++)i[o]^=106;this.oHash.update(i),i.fill(0)}update(t){return je(this),this.iHash.update(t),this}digestInto(t){je(this),We(t,this.outputLen),this.finished=!0,this.iHash.digestInto(t),this.oHash.update(t),this.oHash.digestInto(t),this.destroy()}digest(){let t=new Uint8Array(this.oHash.outputLen);return this.digestInto(t),t}_cloneInto(t){t||(t=Object.create(Object.getPrototypeOf(this),{}));let{oHash:e,iHash:n,finished:s,destroyed:i,blockLen:o,outputLen:a}=this;return t=t,t.finished=s,t.destroyed=i,t.blockLen=o,t.outputLen=a,t.oHash=e._cloneInto(t.oHash),t.iHash=n._cloneInto(t.iHash),t}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},Yi=(r,t,e)=>new cs(r,t).update(e).digest();Yi.create=(r,t)=>new cs(r,t);function Ic(r){r.lowS!==void 0&&_t("lowS",r.lowS),r.prehash!==void 0&&_t("prehash",r.prehash)}function oh(r){let t=wr(r);Ft(t,{a:"field",b:"field"},{allowedPrivateKeyLengths:"array",wrapPrivateKey:"boolean",isTorsionFree:"function",clearCofactor:"function",allowInfinityPoint:"boolean",fromBytes:"function",toBytes:"function"});let{endo:e,Fp:n,a:s}=t;if(e){if(!n.eql(s,n.ZERO))throw new Error("invalid endomorphism, can only be defined for Koblitz curves that have a=0");if(typeof e!="object"||typeof e.beta!="bigint"||typeof e.splitScalar!="function")throw new Error("invalid endomorphism, expected beta: bigint and splitScalar: function")}return Object.freeze({...t})}var{bytesToNumberBE:ah,hexToBytes:ch}=nn,Ji=class extends Error{constructor(t=""){super(t)}},oe={Err:Ji,_tlv:{encode:(r,t)=>{let{Err:e}=oe;if(r<0||r>256)throw new e("tlv.encode: wrong tag");if(t.length&1)throw new e("tlv.encode: unpadded data");let n=t.length/2,s=ke(n);if(s.length/2&128)throw new e("tlv.encode: long form length too big");let i=n>127?ke(s.length/2|128):"";return ke(r)+i+s+t},decode(r,t){let{Err:e}=oe,n=0;if(r<0||r>256)throw new e("tlv.encode: wrong tag");if(t.length<2||t[n++]!==r)throw new e("tlv.decode: wrong tlv");let s=t[n++],i=!!(s&128),o=0;if(!i)o=s;else{let c=s&127;if(!c)throw new e("tlv.decode(long): indefinite length not supported");if(c>4)throw new e("tlv.decode(long): byte length is too big");let l=t.subarray(n,n+c);if(l.length!==c)throw new e("tlv.decode: length bytes not complete");if(l[0]===0)throw new e("tlv.decode(long): zero leftmost byte");for(let f of l)o=o<<8|f;if(n+=c,o<128)throw new e("tlv.decode(long): not minimal encoding")}let a=t.subarray(n,n+o);if(a.length!==o)throw new e("tlv.decode: wrong value length");return{v:a,l:t.subarray(n+o)}}},_int:{encode(r){let{Err:t}=oe;if(r<ae)throw new t("integer: negative integers are not allowed");let e=ke(r);if(Number.parseInt(e[0],16)&8&&(e="00"+e),e.length&1)throw new t("unexpected DER parsing assertion: unpadded hex");return e},decode(r){let{Err:t}=oe;if(r[0]&128)throw new t("invalid signature integer: negative");if(r[0]===0&&!(r[1]&128))throw new t("invalid signature integer: unnecessary leading zero");return ah(r)}},toSig(r){let{Err:t,_int:e,_tlv:n}=oe,s=typeof r=="string"?ch(r):r;Qe(s);let{v:i,l:o}=n.decode(48,s);if(o.length)throw new t("invalid signature: left bytes after parsing");let{v:a,l:c}=n.decode(2,i),{v:l,l:f}=n.decode(2,c);if(f.length)throw new t("invalid signature: left bytes after parsing");return{r:e.decode(a),s:e.decode(l)}},hexFromSig(r){let{_tlv:t,_int:e}=oe,n=t.encode(2,e.encode(r.r)),s=t.encode(2,e.encode(r.s)),i=n+s;return t.encode(48,i)}},ae=BigInt(0),ot=BigInt(1),pg=BigInt(2),Nc=BigInt(3),gg=BigInt(4);function uh(r){let t=oh(r),{Fp:e}=t,n=me(t.n,t.nBitLength),s=t.toBytes||((y,h,w)=>{let E=h.toAffine();return Xt(Uint8Array.from([4]),e.toBytes(E.x),e.toBytes(E.y))}),i=t.fromBytes||(y=>{let h=y.subarray(1),w=e.fromBytes(h.subarray(0,e.BYTES)),E=e.fromBytes(h.subarray(e.BYTES,2*e.BYTES));return{x:w,y:E}});function o(y){let{a:h,b:w}=t,E=e.sqr(y),g=e.mul(E,y);return e.add(e.add(g,e.mul(y,h)),w)}if(!e.eql(e.sqr(t.Gy),o(t.Gx)))throw new Error("bad generator point: equation left != right");function a(y){return br(y,ot,t.n)}function c(y){let{allowedPrivateKeyLengths:h,nByteLength:w,wrapPrivateKey:E,n:g}=t;if(h&&typeof y!="bigint"){if(de(y)&&(y=Yt(y)),typeof y!="string"||!h.includes(y.length))throw new Error("invalid private key");y=y.padStart(w*2,"0")}let k;try{k=typeof y=="bigint"?y:Jt(j("private key",y,w))}catch{throw new Error("invalid private key, expected hex or "+w+" bytes, got "+typeof y)}return E&&(k=z(k,g)),vt("private key",k,ot,g),k}function l(y){if(!(y instanceof d))throw new Error("ProjectivePoint expected")}let f=Te((y,h)=>{let{px:w,py:E,pz:g}=y;if(e.eql(g,e.ONE))return{x:w,y:E};let k=y.is0();h==null&&(h=k?e.ONE:e.inv(g));let U=e.mul(w,h),L=e.mul(E,h),I=e.mul(g,h);if(k)return{x:e.ZERO,y:e.ZERO};if(!e.eql(I,e.ONE))throw new Error("invZ was invalid");return{x:U,y:L}}),u=Te(y=>{if(y.is0()){if(t.allowInfinityPoint&&!e.is0(y.py))return;throw new Error("bad point: ZERO")}let{x:h,y:w}=y.toAffine();if(!e.isValid(h)||!e.isValid(w))throw new Error("bad point: x or y not FE");let E=e.sqr(w),g=o(h);if(!e.eql(E,g))throw new Error("bad point: equation left != right");if(!y.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});class d{constructor(h,w,E){if(this.px=h,this.py=w,this.pz=E,h==null||!e.isValid(h))throw new Error("x required");if(w==null||!e.isValid(w))throw new Error("y required");if(E==null||!e.isValid(E))throw new Error("z required");Object.freeze(this)}static fromAffine(h){let{x:w,y:E}=h||{};if(!h||!e.isValid(w)||!e.isValid(E))throw new Error("invalid affine point");if(h instanceof d)throw new Error("projective point not allowed");let g=k=>e.eql(k,e.ZERO);return g(w)&&g(E)?d.ZERO:new d(w,E,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(h){let w=e.invertBatch(h.map(E=>E.pz));return h.map((E,g)=>E.toAffine(w[g])).map(d.fromAffine)}static fromHex(h){let w=d.fromAffine(i(j("pointHex",h)));return w.assertValidity(),w}static fromPrivateKey(h){return d.BASE.multiply(c(h))}static msm(h,w){return cn(d,n,h,w)}_setWindowSize(h){x.setWindowSize(this,h)}assertValidity(){u(this)}hasEvenY(){let{y:h}=this.toAffine();if(e.isOdd)return!e.isOdd(h);throw new Error("Field doesn't support isOdd")}equals(h){l(h);let{px:w,py:E,pz:g}=this,{px:k,py:U,pz:L}=h,I=e.eql(e.mul(w,L),e.mul(k,g)),C=e.eql(e.mul(E,L),e.mul(U,g));return I&&C}negate(){return new d(this.px,e.neg(this.py),this.pz)}double(){let{a:h,b:w}=t,E=e.mul(w,Nc),{px:g,py:k,pz:U}=this,L=e.ZERO,I=e.ZERO,C=e.ZERO,N=e.mul(g,g),G=e.mul(k,k),F=e.mul(U,U),H=e.mul(g,k);return H=e.add(H,H),C=e.mul(g,U),C=e.add(C,C),L=e.mul(h,C),I=e.mul(E,F),I=e.add(L,I),L=e.sub(G,I),I=e.add(G,I),I=e.mul(L,I),L=e.mul(H,L),C=e.mul(E,C),F=e.mul(h,F),H=e.sub(N,F),H=e.mul(h,H),H=e.add(H,C),C=e.add(N,N),N=e.add(C,N),N=e.add(N,F),N=e.mul(N,H),I=e.add(I,N),F=e.mul(k,U),F=e.add(F,F),N=e.mul(F,H),L=e.sub(L,N),C=e.mul(F,G),C=e.add(C,C),C=e.add(C,C),new d(L,I,C)}add(h){l(h);let{px:w,py:E,pz:g}=this,{px:k,py:U,pz:L}=h,I=e.ZERO,C=e.ZERO,N=e.ZERO,G=t.a,F=e.mul(t.b,Nc),H=e.mul(w,k),tt=e.mul(E,U),B=e.mul(g,L),T=e.add(w,E),b=e.add(k,U);T=e.mul(T,b),b=e.add(H,tt),T=e.sub(T,b),b=e.add(w,g);let p=e.add(k,L);return b=e.mul(b,p),p=e.add(H,B),b=e.sub(b,p),p=e.add(E,g),I=e.add(U,L),p=e.mul(p,I),I=e.add(tt,B),p=e.sub(p,I),N=e.mul(G,b),I=e.mul(F,B),N=e.add(I,N),I=e.sub(tt,N),N=e.add(tt,N),C=e.mul(I,N),tt=e.add(H,H),tt=e.add(tt,H),B=e.mul(G,B),b=e.mul(F,b),tt=e.add(tt,B),B=e.sub(H,B),B=e.mul(G,B),b=e.add(b,B),H=e.mul(tt,b),C=e.add(C,H),H=e.mul(p,b),I=e.mul(T,I),I=e.sub(I,H),H=e.mul(T,tt),N=e.mul(p,N),N=e.add(N,H),new d(I,C,N)}subtract(h){return this.add(h.negate())}is0(){return this.equals(d.ZERO)}wNAF(h){return x.wNAFCached(this,h,d.normalizeZ)}multiplyUnsafe(h){let{endo:w,n:E}=t;vt("scalar",h,ae,E);let g=d.ZERO;if(h===ae)return g;if(this.is0()||h===ot)return this;if(!w||x.hasPrecomputes(this))return x.wNAFCachedUnsafe(this,h,d.normalizeZ);let{k1neg:k,k1:U,k2neg:L,k2:I}=w.splitScalar(h),C=g,N=g,G=this;for(;U>ae||I>ae;)U&ot&&(C=C.add(G)),I&ot&&(N=N.add(G)),G=G.double(),U>>=ot,I>>=ot;return k&&(C=C.negate()),L&&(N=N.negate()),N=new d(e.mul(N.px,w.beta),N.py,N.pz),C.add(N)}multiply(h){let{endo:w,n:E}=t;vt("scalar",h,ot,E);let g,k;if(w){let{k1neg:U,k1:L,k2neg:I,k2:C}=w.splitScalar(h),{p:N,f:G}=this.wNAF(L),{p:F,f:H}=this.wNAF(C);N=x.constTimeNegate(U,N),F=x.constTimeNegate(I,F),F=new d(e.mul(F.px,w.beta),F.py,F.pz),g=N.add(F),k=G.add(H)}else{let{p:U,f:L}=this.wNAF(h);g=U,k=L}return d.normalizeZ([g,k])[0]}multiplyAndAddUnsafe(h,w,E){let g=d.BASE,k=(L,I)=>I===ae||I===ot||!L.equals(g)?L.multiplyUnsafe(I):L.multiply(I),U=k(this,w).add(k(h,E));return U.is0()?void 0:U}toAffine(h){return f(this,h)}isTorsionFree(){let{h,isTorsionFree:w}=t;if(h===ot)return!0;if(w)return w(d,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h,clearCofactor:w}=t;return h===ot?this:w?w(d,this):this.multiplyUnsafe(t.h)}toRawBytes(h=!0){return _t("isCompressed",h),this.assertValidity(),s(d,this,h)}toHex(h=!0){return _t("isCompressed",h),Yt(this.toRawBytes(h))}}d.BASE=new d(t.Gx,t.Gy,e.ONE),d.ZERO=new d(e.ZERO,e.ONE,e.ZERO);let m=t.nBitLength,x=an(d,t.endo?Math.ceil(m/2):m);return{CURVE:t,ProjectivePoint:d,normPrivateKeyToScalar:c,weierstrassEquation:o,isWithinCurveOrder:a}}function lh(r){let t=wr(r);return Ft(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function Tc(r){let t=lh(r),{Fp:e,n}=t,s=e.BYTES+1,i=2*e.BYTES+1;function o(B){return z(B,n)}function a(B){return sn(B,n)}let{ProjectivePoint:c,normPrivateKeyToScalar:l,weierstrassEquation:f,isWithinCurveOrder:u}=uh({...t,toBytes(B,T,b){let p=T.toAffine(),v=e.toBytes(p.x),A=Xt;return _t("isCompressed",b),b?A(Uint8Array.from([T.hasEvenY()?2:3]),v):A(Uint8Array.from([4]),v,e.toBytes(p.y))},fromBytes(B){let T=B.length,b=B[0],p=B.subarray(1);if(T===s&&(b===2||b===3)){let v=Jt(p);if(!br(v,ot,e.ORDER))throw new Error("Point is not on curve");let A=f(v),R;try{R=e.sqrt(A)}catch(P){let D=P instanceof Error?": "+P.message:"";throw new Error("Point is not on curve"+D)}let _=(R&ot)===ot;return(b&1)===1!==_&&(R=e.neg(R)),{x:v,y:R}}else if(T===i&&b===4){let v=e.fromBytes(p.subarray(0,e.BYTES)),A=e.fromBytes(p.subarray(e.BYTES,2*e.BYTES));return{x:v,y:A}}else{let v=s,A=i;throw new Error("invalid Point, expected length of "+v+", or uncompressed "+A+", got "+T)}}}),d=B=>Yt(ge(B,t.nByteLength));function m(B){let T=n>>ot;return B>T}function x(B){return m(B)?o(-B):B}let y=(B,T,b)=>Jt(B.slice(T,b));class h{constructor(T,b,p){this.r=T,this.s=b,this.recovery=p,this.assertValidity()}static fromCompact(T){let b=t.nByteLength;return T=j("compactSignature",T,b*2),new h(y(T,0,b),y(T,b,2*b))}static fromDER(T){let{r:b,s:p}=oe.toSig(j("DER",T));return new h(b,p)}assertValidity(){vt("r",this.r,ot,n),vt("s",this.s,ot,n)}addRecoveryBit(T){return new h(this.r,this.s,T)}recoverPublicKey(T){let{r:b,s:p,recovery:v}=this,A=L(j("msgHash",T));if(v==null||![0,1,2,3].includes(v))throw new Error("recovery id invalid");let R=v===2||v===3?b+t.n:b;if(R>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let _=v&1?"03":"02",V=c.fromHex(_+d(R)),P=a(R),D=o(-A*P),q=o(p*P),$=c.BASE.multiplyAndAddUnsafe(V,D,q);if(!$)throw new Error("point at infinify");return $.assertValidity(),$}hasHighS(){return m(this.s)}normalizeS(){return this.hasHighS()?new h(this.r,o(-this.s),this.recovery):this}toDERRawBytes(){return Ie(this.toDERHex())}toDERHex(){return oe.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return Ie(this.toCompactHex())}toCompactHex(){return d(this.r)+d(this.s)}}let w={isValidPrivateKey(B){try{return l(B),!0}catch{return!1}},normPrivateKeyToScalar:l,randomPrivateKey:()=>{let B=ti(t.n);return na(t.randomBytes(B),t.n)},precompute(B=8,T=c.BASE){return T._setWindowSize(B),T.multiply(BigInt(3)),T}};function E(B,T=!0){return c.fromPrivateKey(B).toRawBytes(T)}function g(B){let T=de(B),b=typeof B=="string",p=(T||b)&&B.length;return T?p===s||p===i:b?p===2*s||p===2*i:B instanceof c}function k(B,T,b=!0){if(g(B))throw new Error("first arg must be private key");if(!g(T))throw new Error("second arg must be public key");return c.fromHex(T).multiply(l(B)).toRawBytes(b)}let U=t.bits2int||function(B){if(B.length>8192)throw new Error("input is too large");let T=Jt(B),b=B.length*8-t.nBitLength;return b>0?T>>BigInt(b):T},L=t.bits2int_modN||function(B){return o(U(B))},I=yr(t.nBitLength);function C(B){return vt("num < 2^"+t.nBitLength,B,ae,I),ge(B,t.nByteLength)}function N(B,T,b=G){if(["recovered","canonical"].some(it=>it in b))throw new Error("sign() legacy options not supported");let{hash:p,randomBytes:v}=t,{lowS:A,prehash:R,extraEntropy:_}=b;A==null&&(A=!0),B=j("msgHash",B),Ic(b),R&&(B=j("prehashed msgHash",p(B)));let V=L(B),P=l(T),D=[C(P),C(V)];if(_!=null&&_!==!1){let it=_===!0?v(e.BYTES):_;D.push(j("extraEntropy",it))}let q=Xt(...D),$=V;function st(it){let at=U(it);if(!u(at))return;let lt=a(at),xt=c.BASE.multiply(at).toAffine(),mt=o(xt.x);if(mt===ae)return;let Pt=o(lt*o($+mt*P));if(Pt===ae)return;let Gt=(xt.x===mt?0:2)|Number(xt.y&ot),lr=Pt;return A&&m(Pt)&&(lr=x(Pt),Gt^=1),new h(mt,lr,Gt)}return{seed:q,k2sig:st}}let G={lowS:t.lowS,prehash:!1},F={lowS:t.lowS,prehash:!1};function H(B,T,b=G){let{seed:p,k2sig:v}=N(B,T,b),A=t;return Ys(A.hash.outputLen,A.nByteLength,A.hmac)(p,v)}c.BASE._setWindowSize(8);function tt(B,T,b,p=F){let v=B;T=j("msgHash",T),b=j("publicKey",b);let{lowS:A,prehash:R,format:_}=p;if(Ic(p),"strict"in p)throw new Error("options.strict was renamed to lowS");if(_!==void 0&&_!=="compact"&&_!=="der")throw new Error("format must be compact or der");let V=typeof v=="string"||de(v),P=!V&&!_&&typeof v=="object"&&v!==null&&typeof v.r=="bigint"&&typeof v.s=="bigint";if(!V&&!P)throw new Error("invalid signature, expected Uint8Array, hex string or Signature instance");let D,q;try{if(P&&(D=new h(v.r,v.s)),V){try{_!=="compact"&&(D=h.fromDER(v))}catch(Gt){if(!(Gt instanceof oe.Err))throw Gt}!D&&_!=="der"&&(D=h.fromCompact(v))}q=c.fromHex(b)}catch{return!1}if(!D||A&&D.hasHighS())return!1;R&&(T=t.hash(T));let{r:$,s:st}=D,it=L(T),at=a(st),lt=o(it*at),xt=o($*at),mt=c.BASE.multiplyAndAddUnsafe(q,lt,xt)?.toAffine();return mt?o(mt.x)===$:!1}return{CURVE:t,getPublicKey:E,getSharedSecret:k,sign:H,verify:tt,ProjectivePoint:c,Signature:h,utils:w}}function fh(r){return{hash:r,hmac:(t,...e)=>Yi(r,t,qs(...e)),randomBytes:Je}}function Cc(r,t){let e=n=>Tc({...r,...fh(n)});return{...e(t),create:e}}var Rc=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),Uc=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),hh=BigInt(1),Xi=BigInt(2),Lc=(r,t)=>(r+t/Xi)/t;function dh(r){let t=Rc,e=BigInt(3),n=BigInt(6),s=BigInt(11),i=BigInt(22),o=BigInt(23),a=BigInt(44),c=BigInt(88),l=r*r*r%t,f=l*l*r%t,u=W(f,e,t)*f%t,d=W(u,e,t)*f%t,m=W(d,Xi,t)*l%t,x=W(m,s,t)*m%t,y=W(x,i,t)*x%t,h=W(y,a,t)*y%t,w=W(h,c,t)*h%t,E=W(w,a,t)*y%t,g=W(E,e,t)*f%t,k=W(g,o,t)*x%t,U=W(k,n,t)*l%t,L=W(U,Xi,t);if(!Qi.eql(Qi.sqr(L),r))throw new Error("Cannot find square root");return L}var Qi=me(Rc,void 0,void 0,{sqrt:dh}),Me=Cc({a:BigInt(0),b:BigInt(7),Fp:Qi,n:Uc,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=Uc,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-hh*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),s=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),i=e,o=BigInt("0x100000000000000000000000000000000"),a=Lc(i*r,t),c=Lc(-n*r,t),l=z(r-a*e-c*s,t),f=z(-a*n-c*i,t),u=l>o,d=f>o;if(u&&(l=t-l),d&&(f=t-f),l>o||f>o)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:u,k1:l,k2neg:d,k2:f}}}},er),Sg=BigInt(0);var Ag=Me.ProjectivePoint;function Ve(r,t){t==null&&(t=r.reduce((s,i)=>s+i.length,0));let e=ft(t),n=0;for(let s of r)e.set(s,n),n+=s.length;return e}function _c(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function Dc(r,t,e){let n=Re.digest(e instanceof Uint8Array?e:e.subarray());if(_c(n))return n.then(({digest:s})=>Me.verify(t,s,r)).catch(s=>{throw new Cr(String(s))});try{return Me.verify(t,n.digest,r)}catch(s){throw new Cr(String(s))}}var us=class{type="secp256k1";raw;_key;constructor(t){this._key=Vc(t),this.raw=Mc(this._key)}toMultihash(){return Wt.digest(Ue(this))}toCID(){return It.createV1(114,this.toMultihash())}toString(){return Q.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:Tt(this.raw,t.raw)}verify(t,e){return Dc(this._key,e,t)}};function to(r){return new us(r)}function Mc(r){return Me.ProjectivePoint.fromHex(r).toRawBytes(!0)}function Vc(r){try{return Me.ProjectivePoint.fromHex(r),r}catch(t){throw new Fe(String(t))}}function eo(r){let{Type:t,Data:e}=Kt.decode(r),n=e??new Uint8Array;switch(t){case nt.RSA:return ji(n);case nt.Ed25519:return ai(n);case nt.secp256k1:return to(n);default:throw new Se}}function Hc(r){let{Type:t,Data:e}=Kt.decode(r.digest),n=e??new Uint8Array;switch(t){case nt.Ed25519:return ai(n);case nt.secp256k1:return to(n);default:throw new Se}}function Ue(r){return Kt.encode({Type:nt[r.type],Data:r.raw})}var Oc=Symbol.for("nodejs.util.inspect.custom"),ph=114,Rr=class{type;multihash;publicKey;string;constructor(t){this.type=t.type,this.multihash=t.multihash,Object.defineProperty(this,"string",{enumerable:!1,writable:!0})}get[Symbol.toStringTag](){return`PeerId(${this.toString()})`}[Ls]=!0;toString(){return this.string==null&&(this.string=Q.encode(this.multihash.bytes).slice(1)),this.string}toMultihash(){return this.multihash}toCID(){return It.createV1(ph,this.multihash)}toJSON(){return this.toString()}equals(t){if(t==null)return!1;if(t instanceof Uint8Array)return Tt(this.multihash.bytes,t);if(typeof t=="string")return this.toString()===t;if(t?.toMultihash()?.bytes!=null)return Tt(this.multihash.bytes,t.toMultihash().bytes);throw new Error("not valid Id")}[Oc](){return`PeerId(${this.toString()})`}},_r=class extends Rr{type="RSA";publicKey;constructor(t){super({...t,type:"RSA"}),this.publicKey=t.publicKey}},Dr=class extends Rr{type="Ed25519";publicKey;constructor(t){super({...t,type:"Ed25519"}),this.publicKey=t.publicKey}},Mr=class extends Rr{type="secp256k1";publicKey;constructor(t){super({...t,type:"secp256k1"}),this.publicKey=t.publicKey}},gh=2336,ls=class{type="url";multihash;publicKey;url;constructor(t){this.url=t.toString(),this.multihash=Wt.digest(Y(this.url))}[Oc](){return`PeerId(${this.url})`}[Ls]=!0;toString(){return this.toCID().toString()}toMultihash(){return this.multihash}toCID(){return It.createV1(gh,this.toMultihash())}toJSON(){return this.toString()}equals(t){return t==null?!1:(t instanceof Uint8Array&&(t=Ot(t)),t.toString()===this.toString())}};function ro(r){if(r.type==="Ed25519")return new Dr({multihash:r.toCID().multihash,publicKey:r});if(r.type==="secp256k1")return new Mr({multihash:r.toCID().multihash,publicKey:r});if(r.type==="RSA")return new _r({multihash:r.toCID().multihash,publicKey:r});throw new Se}function Pc(r){return ro(r.publicKey)}function Vr(r){if(bh(r))return new _r({multihash:r});if(mh(r))try{let t=Hc(r);if(t.type==="Ed25519")return new Dr({multihash:r,publicKey:t});if(t.type==="secp256k1")return new Mr({multihash:r,publicKey:t})}catch{let e=Ot(r.digest);return new ls(new URL(e))}throw new jr("Supplied PeerID Multihash is invalid")}function mh(r){return r.code===Wt.code}function bh(r){return r.code===Re.code}function He(r,t){let e={[Symbol.iterator]:()=>e,next:()=>{let n=r.next(),s=n.value;return n.done===!0||s==null?{done:!0,value:void 0}:{done:!1,value:t(s)}}};return e}function fs(r){let t=ue(Q.decode(`z${r}`));return Vr(t)}var Hr=class{map;constructor(t){if(this.map=new Map,t!=null)for(let[e,n]of t.entries())this.map.set(e.toString(),{key:e,value:n})}[Symbol.iterator](){return this.entries()}clear(){this.map.clear()}delete(t){return this.map.delete(t.toString())}entries(){return He(this.map.entries(),t=>[t[1].key,t[1].value])}forEach(t){this.map.forEach((e,n)=>{t(e.value,e.key,this)})}get(t){return this.map.get(t.toString())?.value}has(t){return this.map.has(t.toString())}set(t,e){this.map.set(t.toString(),{key:t,value:e})}keys(){return He(this.map.values(),t=>t.key)}values(){return He(this.map.values(),t=>t.value)}get size(){return this.map.size}};var Or=class r{set;constructor(t){if(this.set=new Set,t!=null)for(let e of t)this.set.add(e.toString())}get size(){return this.set.size}[Symbol.iterator](){return this.values()}add(t){this.set.add(t.toString())}clear(){this.set.clear()}delete(t){this.set.delete(t.toString())}entries(){return He(this.set.entries(),t=>{let e=fs(t[0]);return[e,e]})}forEach(t){this.set.forEach(e=>{let n=fs(e);t(n,n,this)})}has(t){return this.set.has(t.toString())}values(){return He(this.set.values(),t=>fs(t))}intersection(t){let e=new r;for(let n of t)this.has(n)&&e.add(n);return e}difference(t){let e=new r;for(let n of this)t.has(n)||e.add(n);return e}union(t){let e=new r;for(let n of t)e.add(n);for(let n of this)e.add(n);return e}};var Kc=Symbol.for("@achingbrain/uint8arraylist");function Fc(r,t){if(t==null||t<0)throw new RangeError("index is out of bounds");let e=0;for(let n of r){let s=e+n.byteLength;if(t<s)return{buf:n,index:t-e};e=s}throw new RangeError("index is out of bounds")}function hs(r){return!!r?.[Kc]}var Be=class r{bufs;length;[Kc]=!0;constructor(...t){this.bufs=[],this.length=0,t.length>0&&this.appendAll(t)}*[Symbol.iterator](){yield*this.bufs}get byteLength(){return this.length}append(...t){this.appendAll(t)}appendAll(t){let e=0;for(let n of t)if(n instanceof Uint8Array)e+=n.byteLength,this.bufs.push(n);else if(hs(n))e+=n.byteLength,this.bufs.push(...n.bufs);else throw new Error("Could not append value, must be an Uint8Array or a Uint8ArrayList");this.length+=e}prepend(...t){this.prependAll(t)}prependAll(t){let e=0;for(let n of t.reverse())if(n instanceof Uint8Array)e+=n.byteLength,this.bufs.unshift(n);else if(hs(n))e+=n.byteLength,this.bufs.unshift(...n.bufs);else throw new Error("Could not prepend value, must be an Uint8Array or a Uint8ArrayList");this.length+=e}get(t){let e=Fc(this.bufs,t);return e.buf[e.index]}set(t,e){let n=Fc(this.bufs,t);n.buf[n.index]=e}write(t,e=0){if(t instanceof Uint8Array)for(let n=0;n<t.length;n++)this.set(e+n,t[n]);else if(hs(t))for(let n=0;n<t.length;n++)this.set(e+n,t.get(n));else throw new Error("Could not write value, must be an Uint8Array or a Uint8ArrayList")}consume(t){if(t=Math.trunc(t),!(Number.isNaN(t)||t<=0)){if(t===this.byteLength){this.bufs=[],this.length=0;return}for(;this.bufs.length>0;)if(t>=this.bufs[0].byteLength)t-=this.bufs[0].byteLength,this.length-=this.bufs[0].byteLength,this.bufs.shift();else{this.bufs[0]=this.bufs[0].subarray(t),this.length-=t;break}}}slice(t,e){let{bufs:n,length:s}=this._subList(t,e);return Ve(n,s)}subarray(t,e){let{bufs:n,length:s}=this._subList(t,e);return n.length===1?n[0]:Ve(n,s)}sublist(t,e){let{bufs:n,length:s}=this._subList(t,e),i=new r;return i.length=s,i.bufs=[...n],i}_subList(t,e){if(t=t??0,e=e??this.length,t<0&&(t=this.length+t),e<0&&(e=this.length+e),t<0||e>this.length)throw new RangeError("index is out of bounds");if(t===e)return{bufs:[],length:0};if(t===0&&e===this.length)return{bufs:this.bufs,length:this.length};let n=[],s=0;for(let i=0;i<this.bufs.length;i++){let o=this.bufs[i],a=s,c=a+o.byteLength;if(s=c,t>=c)continue;let l=t>=a&&t<c,f=e>a&&e<=c;if(l&&f){if(t===a&&e===c){n.push(o);break}let u=t-a;n.push(o.subarray(u,u+(e-t)));break}if(l){if(t===0){n.push(o);continue}n.push(o.subarray(t-a));continue}if(f){if(e===c){n.push(o);break}n.push(o.subarray(0,e-a));break}n.push(o)}return{bufs:n,length:e-t}}indexOf(t,e=0){if(!hs(t)&&!(t instanceof Uint8Array))throw new TypeError('The "value" argument must be a Uint8ArrayList or Uint8Array');let n=t instanceof Uint8Array?t:t.subarray();if(e=Number(e??0),isNaN(e)&&(e=0),e<0&&(e=this.length+e),e<0&&(e=0),t.length===0)return e>this.length?this.length:e;let s=n.byteLength;if(s===0)throw new TypeError("search must be at least 1 byte long");let i=256,o=new Int32Array(i);for(let u=0;u<i;u++)o[u]=-1;for(let u=0;u<s;u++)o[n[u]]=u;let a=o,c=this.byteLength-n.byteLength,l=n.byteLength-1,f;for(let u=e;u<=c;u+=f){f=0;for(let d=l;d>=0;d--){let m=this.get(u+d);if(n[d]!==m){f=Math.max(1,d-a[m]);break}}if(f===0)return u}return-1}getInt8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getInt8(0)}setInt8(t,e){let n=ft(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setInt8(0,e),this.write(n,t)}getInt16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt16(0,e)}setInt16(t,e,n){let s=Qt(2);new DataView(s.buffer,s.byteOffset,s.byteLength).setInt16(0,e,n),this.write(s,t)}getInt32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt32(0,e)}setInt32(t,e,n){let s=Qt(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setInt32(0,e,n),this.write(s,t)}getBigInt64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigInt64(0,e)}setBigInt64(t,e,n){let s=Qt(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigInt64(0,e,n),this.write(s,t)}getUint8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getUint8(0)}setUint8(t,e){let n=ft(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setUint8(0,e),this.write(n,t)}getUint16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint16(0,e)}setUint16(t,e,n){let s=Qt(2);new DataView(s.buffer,s.byteOffset,s.byteLength).setUint16(0,e,n),this.write(s,t)}getUint32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint32(0,e)}setUint32(t,e,n){let s=Qt(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setUint32(0,e,n),this.write(s,t)}getBigUint64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigUint64(0,e)}setBigUint64(t,e,n){let s=Qt(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigUint64(0,e,n),this.write(s,t)}getFloat32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat32(0,e)}setFloat32(t,e,n){let s=Qt(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setFloat32(0,e,n),this.write(s,t)}getFloat64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat64(0,e)}setFloat64(t,e,n){let s=Qt(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setFloat64(0,e,n),this.write(s,t)}equals(t){if(t==null||!(t instanceof r)||t.bufs.length!==this.bufs.length)return!1;for(let e=0;e<this.bufs.length;e++)if(!Tt(this.bufs[e],t.bufs[e]))return!1;return!0}static fromUint8Arrays(t,e){let n=new r;return n.bufs=t,e==null&&(e=t.reduce((s,i)=>s+i.byteLength,0)),n.length=e,n}};function ds(){let r={};return r.promise=new Promise((t,e)=>{r.resolve=t,r.reject=e}),r}var ps=class{buffer;mask;top;btm;next;constructor(t){if(!(t>0)||t-1&t)throw new Error("Max size for a FixedFIFO should be a power of two");this.buffer=new Array(t),this.mask=t-1,this.top=0,this.btm=0,this.next=null}push(t){return this.buffer[this.top]!==void 0?!1:(this.buffer[this.top]=t,this.top=this.top+1&this.mask,!0)}shift(){let t=this.buffer[this.btm];if(t!==void 0)return this.buffer[this.btm]=void 0,this.btm=this.btm+1&this.mask,t}isEmpty(){return this.buffer[this.btm]===void 0}},cr=class{size;hwm;head;tail;constructor(t={}){this.hwm=t.splitLimit??16,this.head=new ps(this.hwm),this.tail=this.head,this.size=0}calculateSize(t){return t?.byteLength!=null?t.byteLength:1}push(t){if(t?.value!=null&&(this.size+=this.calculateSize(t.value)),!this.head.push(t)){let e=this.head;this.head=e.next=new ps(2*this.head.buffer.length),this.head.push(t)}}shift(){let t=this.tail.shift();if(t===void 0&&this.tail.next!=null){let e=this.tail.next;this.tail.next=null,this.tail=e,t=this.tail.shift()}return t?.value!=null&&(this.size-=this.calculateSize(t.value)),t}isEmpty(){return this.head.isEmpty()}};var no=class extends Error{type;code;constructor(t,e){super(t??"The operation was aborted"),this.type="aborted",this.code=e??"ABORT_ERR"}};function ur(r={}){return yh(e=>{let n=e.shift();if(n==null)return{done:!0};if(n.error!=null)throw n.error;return{done:n.done===!0,value:n.value}},r)}function yh(r,t){t=t??{};let e=t.onEnd,n=new cr,s,i,o,a=ds(),c=async()=>{try{return n.isEmpty()?o?{done:!0}:await new Promise((h,w)=>{i=E=>{i=null,n.push(E);try{h(r(n))}catch(g){w(g)}return s}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{a.resolve(),a=ds()})}},l=h=>i!=null?i(h):(n.push(h),s),f=h=>(n=new cr,i!=null?i({error:h}):(n.push({error:h}),s)),u=h=>{if(o)return s;if(t?.objectMode!==!0&&h?.byteLength==null)throw new Error("objectMode was not true but tried to push non-Uint8Array value");return l({done:!1,value:h})},d=h=>o?s:(o=!0,h!=null?f(h):l({done:!0})),m=()=>(n=new cr,d(),{done:!0}),x=h=>(d(h),{done:!0});if(s={[Symbol.asyncIterator](){return this},next:c,return:m,throw:x,push:u,end:d,get readableLength(){return n.size},onEmpty:async h=>{let w=h?.signal;if(w?.throwIfAborted(),n.isEmpty())return;let E,g;w!=null&&(E=new Promise((k,U)=>{g=()=>{U(new no)},w.addEventListener("abort",g)}));try{await Promise.race([a.promise,E])}finally{g!=null&&w!=null&&w?.removeEventListener("abort",g)}}},e==null)return s;let y=s;return s={[Symbol.asyncIterator](){return this},next(){return y.next()},throw(h){return y.throw(h),e!=null&&(e(h),e=void 0),{done:!0}},return(){return y.return(),e!=null&&(e(),e=void 0),{done:!0}},push:u,end(h){return y.end(h),e!=null&&(e(h),e=void 0),s},get readableLength(){return y.readableLength},onEmpty:h=>y.onEmpty(h)},s}function wh(r){return r[Symbol.asyncIterator]!=null}function xh(...r){let t=[];for(let e of r)wh(e)||t.push(e);return t.length===r.length?function*(){for(let e of t)yield*e}():async function*(){let e=ur({objectMode:!0});Promise.resolve().then(async()=>{try{await Promise.all(r.map(async n=>{for await(let s of n)e.push(s)})),e.end()}catch(n){e.end(n)}}),yield*e}()}var qc=xh;function Pr(r,...t){if(r==null)throw new Error("Empty pipeline");if(so(r)){let n=r;r=()=>n.source}else if($c(r)||zc(r)){let n=r;r=()=>n}let e=[r,...t];if(e.length>1&&so(e[e.length-1])&&(e[e.length-1]=e[e.length-1].sink),e.length>2)for(let n=1;n<e.length-1;n++)so(e[n])&&(e[n]=Eh(e[n]));return vh(...e)}var vh=(...r)=>{let t;for(;r.length>0;)t=r.shift()(t);return t},zc=r=>r?.[Symbol.asyncIterator]!=null,$c=r=>r?.[Symbol.iterator]!=null,so=r=>r==null?!1:r.sink!=null&&r.source!=null,Eh=r=>t=>{let e=r.sink(t);if(e?.then!=null){let n=ur({objectMode:!0});e.then(()=>{n.end()},o=>{n.end(o)});let s,i=r.source;if(zc(i))s=async function*(){yield*i,n.end()};else if($c(i))s=function*(){yield*i,n.end()};else throw new Error("Unknown duplex source type - must be Iterable or AsyncIterable");return qc(n,s())}return r.source};var oo=Bo(Zc(),1);var Kr=class extends Error{constructor(t){super(t),this.name="TimeoutError"}},ao=class extends Error{constructor(t){super(),this.name="AbortError",this.message=t}},Wc=r=>globalThis.DOMException===void 0?new ao(r):new DOMException(r),jc=r=>{let t=r.reason===void 0?Wc("This operation was aborted."):r.reason;return t instanceof Error?t:Wc(t)};function co(r,t){let{milliseconds:e,fallback:n,message:s,customTimers:i={setTimeout,clearTimeout}}=t,o,a,l=new Promise((f,u)=>{if(typeof e!="number"||Math.sign(e)!==1)throw new TypeError(`Expected \`milliseconds\` to be a positive number, got \`${e}\``);if(t.signal){let{signal:m}=t;m.aborted&&u(jc(m)),a=()=>{u(jc(m))},m.addEventListener("abort",a,{once:!0})}if(e===Number.POSITIVE_INFINITY){r.then(f,u);return}let d=new Kr;o=i.setTimeout.call(void 0,()=>{if(n){try{f(n())}catch(m){u(m)}return}typeof r.cancel=="function"&&r.cancel(),s===!1?f():s instanceof Error?u(s):(d.message=s??`Promise timed out after ${e} milliseconds`,u(d))},e),(async()=>{try{f(await r)}catch(m){u(m)}})()}).finally(()=>{l.clear(),a&&t.signal&&t.signal.removeEventListener("abort",a)});return l.clear=()=>{i.clearTimeout.call(void 0,o),o=void 0},l}function uo(r,t,e){let n=0,s=r.length;for(;s>0;){let i=Math.trunc(s/2),o=n+i;e(r[o],t)<=0?(n=++o,s-=i+1):s=i}return n}var qr=class{#t=[];enqueue(t,e){e={priority:0,...e};let n={priority:e.priority,id:e.id,run:t};if(this.size===0||this.#t[this.size-1].priority>=e.priority){this.#t.push(n);return}let s=uo(this.#t,n,(i,o)=>o.priority-i.priority);this.#t.splice(s,0,n)}setPriority(t,e){let n=this.#t.findIndex(i=>i.id===t);if(n===-1)throw new ReferenceError(`No promise function with the id "${t}" exists in the queue.`);let[s]=this.#t.splice(n,1);this.enqueue(s.run,{priority:e,id:t})}dequeue(){return this.#t.shift()?.run}filter(t){return this.#t.filter(e=>e.priority===t.priority).map(e=>e.run)}get size(){return this.#t.length}};var zr=class extends oo.default{#t;#o;#i=0;#d;#a;#p=0;#r;#c;#e;#g;#n=0;#u;#s;#m;#w=1n;timeout;constructor(t){if(super(),t={carryoverConcurrencyCount:!1,intervalCap:Number.POSITIVE_INFINITY,interval:0,concurrency:Number.POSITIVE_INFINITY,autoStart:!0,queueClass:qr,...t},!(typeof t.intervalCap=="number"&&t.intervalCap>=1))throw new TypeError(`Expected \`intervalCap\` to be a number from 1 and up, got \`${t.intervalCap?.toString()??""}\` (${typeof t.intervalCap})`);if(t.interval===void 0||!(Number.isFinite(t.interval)&&t.interval>=0))throw new TypeError(`Expected \`interval\` to be a finite number >= 0, got \`${t.interval?.toString()??""}\` (${typeof t.interval})`);this.#t=t.carryoverConcurrencyCount,this.#o=t.intervalCap===Number.POSITIVE_INFINITY||t.interval===0,this.#d=t.intervalCap,this.#a=t.interval,this.#e=new t.queueClass,this.#g=t.queueClass,this.concurrency=t.concurrency,this.timeout=t.timeout,this.#m=t.throwOnTimeout===!0,this.#s=t.autoStart===!1}get#x(){return this.#o||this.#i<this.#d}get#v(){return this.#n<this.#u}#E(){this.#n--,this.#l(),this.emit("next")}#B(){this.#y(),this.#b(),this.#c=void 0}get#S(){let t=Date.now();if(this.#r===void 0){let e=this.#p-t;if(e<0)this.#i=this.#t?this.#n:0;else return this.#c===void 0&&(this.#c=setTimeout(()=>{this.#B()},e)),!0}return!1}#l(){if(this.#e.size===0)return this.#r&&clearInterval(this.#r),this.#r=void 0,this.emit("empty"),this.#n===0&&this.emit("idle"),!1;if(!this.#s){let t=!this.#S;if(this.#x&&this.#v){let e=this.#e.dequeue();return e?(this.emit("active"),e(),t&&this.#b(),!0):!1}}return!1}#b(){this.#o||this.#r!==void 0||(this.#r=setInterval(()=>{this.#y()},this.#a),this.#p=Date.now()+this.#a)}#y(){this.#i===0&&this.#n===0&&this.#r&&(clearInterval(this.#r),this.#r=void 0),this.#i=this.#t?this.#n:0,this.#f()}#f(){for(;this.#l(););}get concurrency(){return this.#u}set concurrency(t){if(!(typeof t=="number"&&t>=1))throw new TypeError(`Expected \`concurrency\` to be a number from 1 and up, got \`${t}\` (${typeof t})`);this.#u=t,this.#f()}async#A(t){return new Promise((e,n)=>{t.addEventListener("abort",()=>{n(t.reason)},{once:!0})})}setPriority(t,e){this.#e.setPriority(t,e)}async add(t,e={}){return e.id??=(this.#w++).toString(),e={timeout:this.timeout,throwOnTimeout:this.#m,...e},new Promise((n,s)=>{this.#e.enqueue(async()=>{this.#n++,this.#i++;try{e.signal?.throwIfAborted();let i=t({signal:e.signal});e.timeout&&(i=co(Promise.resolve(i),{milliseconds:e.timeout})),e.signal&&(i=Promise.race([i,this.#A(e.signal)]));let o=await i;n(o),this.emit("completed",o)}catch(i){if(i instanceof Kr&&!e.throwOnTimeout){n();return}s(i),this.emit("error",i)}finally{this.#E()}},e),this.emit("add"),this.#l()})}async addAll(t,e){return Promise.all(t.map(async n=>this.add(n,e)))}start(){return this.#s?(this.#s=!1,this.#f(),this):this}pause(){this.#s=!0}clear(){this.#e=new this.#g}async onEmpty(){this.#e.size!==0&&await this.#h("empty")}async onSizeLessThan(t){this.#e.size<t||await this.#h("next",()=>this.#e.size<t)}async onIdle(){this.#n===0&&this.#e.size===0||await this.#h("idle")}async#h(t,e){return new Promise(n=>{let s=()=>{e&&!e()||(this.off(t,s),n())};this.on(t,s)})}get size(){return this.#e.size}sizeBy(t){return this.#e.filter(t).length}get pending(){return this.#n}get isPaused(){return this.#s}};function Yc(r){if(r!=null){if(typeof r[Symbol.iterator]=="function")return r[Symbol.iterator]();if(typeof r[Symbol.asyncIterator]=="function")return r[Symbol.asyncIterator]();if(typeof r.next=="function")return r}throw new Error("argument is not an iterator or iterable")}function Jc(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function Xc(r,t){let e=Yc(r).return?.();Jc(e)&&e.catch(n=>{t.error("could not cause iterator to return",n)})}function ms(r){return r[Symbol.asyncIterator]!=null}var bs=r=>{let t=Mt(r),e=ft(t);return da(r,e),bs.bytes=t,e};bs.bytes=0;function ys(r,t){t=t??{};let e=t.lengthEncoder??bs;function*n(s){let i=e(s.byteLength);i instanceof Uint8Array?yield i:yield*i,s instanceof Uint8Array?yield s:yield*s}return ms(r)?async function*(){for await(let s of r)yield*n(s)}():function*(){for(let s of r)yield*n(s)}()}ys.single=(r,t)=>{t=t??{};let e=t.lengthEncoder??bs;return new Be(e(r.byteLength),r)};var ws=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},xs=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},vs=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"},$r=class extends Error{name="UnexpectedEOFError";code="ERR_UNEXPECTED_EOF"};var Ah=8,kh=1024*1024*4,Oe;(function(r){r[r.LENGTH=0]="LENGTH",r[r.DATA=1]="DATA"})(Oe||(Oe={}));var lo=r=>{let t=pa(r);return lo.bytes=Mt(t),t};lo.bytes=0;function Gr(r,t){let e=new Be,n=Oe.LENGTH,s=-1,i=t?.lengthDecoder??lo,o=t?.maxLengthLength??Ah,a=t?.maxDataLength??kh;function*c(){for(;e.byteLength>0;){if(n===Oe.LENGTH)try{if(s=i(e),s<0)throw new ws("Invalid message length");if(s>a)throw new xs("Message length too long");let l=i.bytes;e.consume(l),t?.onLength!=null&&t.onLength(s),n=Oe.DATA}catch(l){if(l instanceof RangeError){if(e.byteLength>o)throw new vs("Message length length too long");break}throw l}if(n===Oe.DATA){if(e.byteLength<s)break;let l=e.sublist(0,s);e.consume(s),t?.onData!=null&&t.onData(l),yield l,n=Oe.LENGTH}}}return ms(r)?async function*(){for await(let l of r)e.append(l),yield*c();if(e.byteLength>0)throw new $r("Unexpected end of input")}():function*(){for(let l of r)e.append(l),yield*c();if(e.byteLength>0)throw new $r("Unexpected end of input")}()}Gr.fromReader=(r,t)=>{let e=1,n=async function*(){for(;;)try{let{done:i,value:o}=await r.next(e);if(i===!0)return;o!=null&&(yield o)}catch(i){if(i.code==="ERR_UNDER_READ")return{done:!0,value:null};throw i}finally{e=1}}();return Gr(n,{...t??{},onLength:i=>{e=i}})};var Es=class extends Ke{id;protocol;outboundStream;inboundStream;_rawOutboundStream;_rawInboundStream;_inboundAbortController;closed;log;constructor(t,e){super(),this.log=t.logger.forComponent("libp2p-pubsub:peer-streams"),this.id=e.id,this.protocol=e.protocol,this._inboundAbortController=new AbortController,this.closed=!1}get isReadable(){return!!this.inboundStream}get isWritable(){return!!this.outboundStream}write(t){if(this.outboundStream==null){let e=this.id.toString();throw new Error("No writable connection to "+e)}this.outboundStream.push(t instanceof Uint8Array?new Be(t):t)}attachInboundStream(t){let e=()=>{Xc(t.source,this.log)};return this._inboundAbortController.signal.addEventListener("abort",e,{once:!0}),this._rawInboundStream=t,this.inboundStream=Pr(this._rawInboundStream,n=>Gr(n)),this.dispatchEvent(new CustomEvent("stream:inbound")),this.inboundStream}async attachOutboundStream(t){let e=this.outboundStream;return this.outboundStream!=null&&this.outboundStream.end(),this._rawOutboundStream=t,this.outboundStream=ur({onEnd:n=>{this._rawOutboundStream!=null&&this._rawOutboundStream.closeWrite().catch(s=>{this.log("error closing outbound stream",s)}),this._rawOutboundStream=void 0,this.outboundStream=void 0,n!=null&&this.dispatchEvent(new CustomEvent("close"))}}),Pr(this.outboundStream,n=>ys(n),this._rawOutboundStream).catch(n=>{this.log.error(n)}),e==null&&this.dispatchEvent(new CustomEvent("stream:outbound")),this.outboundStream}close(){this.closed||(this.closed=!0,this.outboundStream!=null&&this.outboundStream.end(),this.inboundStream!=null&&this._inboundAbortController.abort(),this._rawOutboundStream=void 0,this.outboundStream=void 0,this._rawInboundStream=void 0,this.inboundStream=void 0,this.dispatchEvent(new CustomEvent("close")))}};function Qc(){return BigInt(`0x${Ot(is(8),"base16")}`)}var tu=(r,t)=>{let e=Y(t.toString(16).padStart(16,"0"),"base16"),n=Ue(r),s=new Uint8Array(n.byteLength+e.length);return s.set(n,0),s.set(e,n.byteLength),s},eu=r=>Re.encode(r);var ru=function(r){return Array.isArray(r)?r:[r]},Nh=async r=>{if(r.sequenceNumber==null||r.from==null||r.signature==null)return!1;let t=Vr(ue(r.from));if(t.publicKey!=null)return!0;if(r.key!=null){let e=r.key;return ro(eo(e)).equals(t)}return!1},nu=async r=>{if(r.from==null)throw new X("RPC message was missing from");if(!await Nh(r))return{type:"unsigned",topic:r.topic??"",data:r.data??new Uint8Array(0)};let t=Vr(ue(r.from)),e=r.key??t.publicKey;if(e==null)throw new X("RPC message was missing public key");return{type:"signed",from:t,topic:r.topic??"",sequenceNumber:Ch(r.sequenceNumber??new Uint8Array(0)),data:r.data??new Uint8Array(0),signature:r.signature??new Uint8Array(0),key:e instanceof Uint8Array?eo(e):e}},Zr=r=>r.type==="signed"?{from:r.from.toMultihash().bytes,data:r.data,sequenceNumber:Th(r.sequenceNumber),topic:r.topic,signature:r.signature,key:r.key?Ue(r.key):void 0}:{data:r.data,topic:r.topic},Th=r=>{let t=r.toString(16);return t.length%2!==0&&(t=`0${t}`),Y(t,"base16")},Ch=r=>BigInt(`0x${Ot(r,"base16")}`);var su=Y("libp2p-pubsub:");async function iu(r,t,e){let n={type:"signed",topic:t.topic,data:t.data,sequenceNumber:t.sequenceNumber,from:Pc(r)},s=Ve([su,e(Zr(n)).subarray()]);return n.signature=await r.sign(s),n.key=r.publicKey,n}async function ou(r,t){if(r.type!=="signed")throw new Error('Message type must be "signed" to be verified');if(r.signature==null)throw new Error("Message must contain a signature to be verified");if(r.from==null)throw new Error("Message must contain a from property to be verified");let e=Ve([su,t({...Zr(r),signature:void 0,key:void 0}).subarray()]);return Uh(r).verify(e,r.signature)}function Uh(r){if(r.type!=="signed")throw new Error('Message type must be "signed" to have a public key');if(r.from==null)throw new Error("Could not get the public key from the originator id");if(r.key!=null)return r.key;if(r.from.publicKey!=null)return r.from.publicKey;throw new Error("Could not get the public key from the originator id")}var Bs=class extends Ke{log;started;topics;subscriptions;peers;globalSignaturePolicy;canRelayMessage;emitSelf;topicValidators;queue;multicodecs;components;_registrarTopologyIds;enabled;maxInboundStreams;maxOutboundStreams;constructor(t,e){super();let{multicodecs:n=[],globalSignaturePolicy:s="StrictSign",canRelayMessage:i=!1,emitSelf:o=!1,messageProcessingConcurrency:a=10,maxInboundStreams:c=1,maxOutboundStreams:l=1}=e;this.log=t.logger.forComponent("libp2p:pubsub"),this.components=t,this.multicodecs=ru(n),this.enabled=e.enabled!==!1,this.started=!1,this.topics=new Map,this.subscriptions=new Set,this.peers=new Hr,this.globalSignaturePolicy=s==="StrictNoSign"?"StrictNoSign":"StrictSign",this.canRelayMessage=i,this.emitSelf=o,this.topicValidators=new Map,this.queue=new zr({concurrency:a}),this.maxInboundStreams=c,this.maxOutboundStreams=l,this._onIncomingStream=this._onIncomingStream.bind(this),this._onPeerConnected=this._onPeerConnected.bind(this),this._onPeerDisconnected=this._onPeerDisconnected.bind(this)}async start(){if(this.started||!this.enabled)return;this.log("starting");let t=this.components.registrar;await Promise.all(this.multicodecs.map(async n=>{await t.handle(n,this._onIncomingStream,{maxInboundStreams:this.maxInboundStreams,maxOutboundStreams:this.maxOutboundStreams})}));let e={onConnect:this._onPeerConnected,onDisconnect:this._onPeerDisconnected};this._registrarTopologyIds=await Promise.all(this.multicodecs.map(async n=>t.register(n,e))),this.log("started"),this.started=!0}async stop(){if(!this.started||!this.enabled)return;let t=this.components.registrar;this._registrarTopologyIds!=null&&this._registrarTopologyIds?.forEach(e=>{t.unregister(e)}),await Promise.all(this.multicodecs.map(async e=>{await t.unhandle(e)})),this.log("stopping");for(let e of this.peers.values())e.close();this.peers.clear(),this.subscriptions=new Set,this.started=!1,this.log("stopped")}isStarted(){return this.started}_onIncomingStream(t){let{stream:e,connection:n}=t,s=n.remotePeer;if(e.protocol==null){e.abort(new Error("Stream was not multiplexed"));return}let i=this.addPeer(s,e.protocol),o=i.attachInboundStream(e);this.processMessages(s,o,i).catch(a=>{this.log(a)})}_onPeerConnected(t,e){if(this.log("connected %p",t),e.streams.find(n=>n.direction==="outbound"&&n.protocol!=null&&this.multicodecs.includes(n.protocol))!=null){this.log("outbound pubsub streams already present on connection from %p",t);return}Promise.resolve().then(async()=>{try{let n=await e.newStream(this.multicodecs);if(n.protocol==null){n.abort(new Error("Stream was not multiplexed"));return}await this.addPeer(t,n.protocol).attachOutboundStream(n)}catch(n){this.log.error(n)}this.send(t,{subscriptions:Array.from(this.subscriptions).map(n=>n.toString()),subscribe:!0})}).catch(n=>{this.log.error(n)})}_onPeerDisconnected(t,e){this.log("connection ended %p",t),this._removePeer(t)}addPeer(t,e){let n=this.peers.get(t);if(n!=null)return n;this.log("new peer %p",t);let s=new Es(this.components,{id:t,protocol:e});return this.peers.set(t,s),s.addEventListener("close",()=>this._removePeer(t),{once:!0}),s}_removePeer(t){let e=this.peers.get(t);if(e!=null){e.close(),this.log("delete peer %p",t),this.peers.delete(t);for(let n of this.topics.values())n.delete(t);return e}}async processMessages(t,e,n){try{await Pr(e,async s=>{for await(let i of s){let o=this.decodeRpc(i),a=[];for(let c of o.messages??[]){if(c.from==null||c.data==null||c.topic==null){this.log("message from %p was missing from, data or topic fields, dropping",t);continue}a.push({from:c.from,data:c.data,topic:c.topic,sequenceNumber:c.sequenceNumber??void 0,signature:c.signature??void 0,key:c.key??void 0})}this.processRpc(t,n,{subscriptions:(o.subscriptions??[]).map(c=>({subscribe:!!c.subscribe,topic:c.topic??""})),messages:a}).catch(c=>{this.log(c)})}})}catch(s){this._onPeerDisconnected(n.id,s)}}async processRpc(t,e,n){if(!this.acceptFrom(t))return this.log("received message from unacceptable peer %p",t),!1;this.log("rpc from %p",t);let{subscriptions:s,messages:i}=n;return s!=null&&s.length>0&&(this.log("subscription update from %p",t),s.forEach(o=>{this.processRpcSubOpt(t,o)}),super.dispatchEvent(new CustomEvent("subscription-change",{detail:{peerId:e.id,subscriptions:s.map(({topic:o,subscribe:a})=>({topic:`${o??""}`,subscribe:!!a}))}}))),i!=null&&i.length>0&&(this.log("messages from %p",t),this.queue.addAll(i.map(o=>async()=>{if(o.topic==null||!this.subscriptions.has(o.topic)&&!this.canRelayMessage)return this.log("received message we didn't subscribe to. Dropping."),!1;try{let a=await nu(o);await this.processMessage(t,a)}catch(a){this.log.error(a)}})).catch(o=>{this.log(o)})),!0}processRpcSubOpt(t,e){let n=e.topic;if(n==null)return;let s=this.topics.get(n);s==null&&(s=new Or,this.topics.set(n,s)),e.subscribe===!0?s.add(t):s.delete(t)}async processMessage(t,e){if(!(this.components.peerId.equals(t)&&!this.emitSelf)){try{await this.validate(t,e)}catch(n){this.log("Message is invalid, dropping it. %O",n);return}this.subscriptions.has(e.topic)&&(!this.components.peerId.equals(t)||this.emitSelf)&&super.dispatchEvent(new CustomEvent("message",{detail:e})),await this.publishMessage(t,e)}}getMsgId(t){switch(this.globalSignaturePolicy){case"StrictSign":if(t.type!=="signed")throw new X('Message type should be "signed" when signature policy is StrictSign but it was not');if(t.sequenceNumber==null)throw new X("Need seqno when signature policy is StrictSign but it was missing");if(t.key==null)throw new X("Need key when signature policy is StrictSign but it was missing");return tu(t.key,t.sequenceNumber);case"StrictNoSign":return eu(t.data);default:throw new X("Cannot get message id: unhandled signature policy")}}acceptFrom(t){return!0}send(t,e){let{messages:n,subscriptions:s,subscribe:i}=e;this.sendRpc(t,{subscriptions:(s??[]).map(o=>({topic:o,subscribe:!!i})),messages:(n??[]).map(Zr)})}sendRpc(t,e){let n=this.peers.get(t);if(n==null){this.log.error("Cannot send RPC to %p as there are no streams to it available",t);return}if(!n.isWritable){this.log.error("Cannot send RPC to %p as there is no outbound stream to it available",t);return}n.write(this.encodeRpc(e))}async validate(t,e){switch(this.globalSignaturePolicy){case"StrictNoSign":if(e.type!=="unsigned")throw new X('Message type should be "unsigned" when signature policy is StrictNoSign but it was not');if(e.signature!=null)throw new X("StrictNoSigning: signature should not be present");if(e.key!=null)throw new X("StrictNoSigning: key should not be present");if(e.sequenceNumber!=null)throw new X("StrictNoSigning: seqno should not be present");break;case"StrictSign":if(e.type!=="signed")throw new X('Message type should be "signed" when signature policy is StrictSign but it was not');if(e.signature==null)throw new X("StrictSigning: Signing required and no signature was present");if(e.sequenceNumber==null)throw new X("StrictSigning: Signing required and no sequenceNumber was present");if(!await ou(e,this.encodeMessage.bind(this)))throw new X("StrictSigning: Invalid message signature");break;default:throw new X("Cannot validate message: unhandled signature policy")}let s=this.topicValidators.get(e.topic);if(s!=null){let i=await s(t,e);if(i===fr.Reject||i===fr.Ignore)throw new X("Message validation failed")}}async buildMessage(t){switch(this.globalSignaturePolicy){case"StrictSign":return iu(this.components.privateKey,t,this.encodeMessage.bind(this));case"StrictNoSign":return Promise.resolve({type:"unsigned",...t});default:throw new X("Cannot build message: unhandled signature policy")}}getSubscribers(t){if(!this.started)throw new Yr("not started yet");if(t==null)throw new et("Topic is required");let e=this.topics.get(t.toString());return e==null?[]:Array.from(e.values())}async publish(t,e){if(!this.started)throw new Error("Pubsub has not started");let n={from:this.components.peerId,topic:t,data:e??new Uint8Array(0),sequenceNumber:Qc()};this.log("publish topic: %s from: %p data: %m",t,n.from,n.data);let s=await this.buildMessage(n),i=!1;this.emitSelf&&this.subscriptions.has(t)&&(i=!0,super.dispatchEvent(new CustomEvent("message",{detail:s})));let o=await this.publishMessage(this.components.peerId,s);return i&&(o.recipients=[...o.recipients,this.components.peerId]),o}subscribe(t){if(!this.started)throw new Error("Pubsub has not started");if(this.log("subscribe to topic: %s",t),!this.subscriptions.has(t)){this.subscriptions.add(t);for(let e of this.peers.keys())this.send(e,{subscriptions:[t],subscribe:!0})}}unsubscribe(t){if(!this.started)throw new Error("Pubsub is not started");super.removeEventListener(t);let e=this.subscriptions.has(t);if(this.log("unsubscribe from %s - am subscribed %s",t,e),e){this.subscriptions.delete(t);for(let n of this.peers.keys())this.send(n,{subscriptions:[t],subscribe:!1})}}getTopics(){if(!this.started)throw new Error("Pubsub is not started");return Array.from(this.subscriptions)}getPeers(){if(!this.started)throw new Error("Pubsub is not started");return Array.from(this.peers.keys())}};var Ss=class{entries;validityMs;lastPruneTime=0;constructor(t){this.entries=new Map,this.validityMs=t.validityMs}put(t,e){this.entries.set(t,{value:e,validUntilMs:Date.now()+this.validityMs}),this.prune()}prune(){let t=Date.now();if(!(t-this.lastPruneTime<200)){this.lastPruneTime=t;for(let[e,n]of this.entries.entries())if(n.validUntilMs<t)this.entries.delete(e);else break}}has(t){return this.entries.has(t)}get(t){let e=this.entries.get(t);return e!=null&&e.validUntilMs>=Date.now()?e.value:void 0}clear(){this.entries=new Map,this.lastPruneTime=0}};var fo="/floodsub/1.0.0";var Pe;(function(r){let t;(function(s){let i;s.codec=()=>(i==null&&(i=At((o,a,c={})=>{c.lengthDelimited!==!1&&a.fork(),o.subscribe!=null&&(a.uint32(8),a.bool(o.subscribe)),o.topic!=null&&(a.uint32(18),a.string(o.topic)),c.lengthDelimited!==!1&&a.ldelim()},(o,a,c={})=>{let l={},f=a==null?o.len:o.pos+a;for(;o.pos<f;){let u=o.uint32();switch(u>>>3){case 1:{l.subscribe=o.bool();break}case 2:{l.topic=o.string();break}default:{o.skipType(u&7);break}}}return l})),i),s.encode=o=>St(o,s.codec()),s.decode=(o,a)=>Bt(o,s.codec(),a)})(t=r.SubOpts||(r.SubOpts={}));let e;(function(s){let i;s.codec=()=>(i==null&&(i=At((o,a,c={})=>{c.lengthDelimited!==!1&&a.fork(),o.from!=null&&(a.uint32(10),a.bytes(o.from)),o.data!=null&&(a.uint32(18),a.bytes(o.data)),o.sequenceNumber!=null&&(a.uint32(26),a.bytes(o.sequenceNumber)),o.topic!=null&&(a.uint32(34),a.string(o.topic)),o.signature!=null&&(a.uint32(42),a.bytes(o.signature)),o.key!=null&&(a.uint32(50),a.bytes(o.key)),c.lengthDelimited!==!1&&a.ldelim()},(o,a,c={})=>{let l={},f=a==null?o.len:o.pos+a;for(;o.pos<f;){let u=o.uint32();switch(u>>>3){case 1:{l.from=o.bytes();break}case 2:{l.data=o.bytes();break}case 3:{l.sequenceNumber=o.bytes();break}case 4:{l.topic=o.string();break}case 5:{l.signature=o.bytes();break}case 6:{l.key=o.bytes();break}default:{o.skipType(u&7);break}}}return l})),i),s.encode=o=>St(o,s.codec()),s.decode=(o,a)=>Bt(o,s.codec(),a)})(e=r.Message||(r.Message={}));let n;r.codec=()=>(n==null&&(n=At((s,i,o={})=>{if(o.lengthDelimited!==!1&&i.fork(),s.subscriptions!=null)for(let a of s.subscriptions)i.uint32(10),r.SubOpts.codec().encode(a,i);if(s.messages!=null)for(let a of s.messages)i.uint32(18),r.Message.codec().encode(a,i);s.control!=null&&(i.uint32(26),As.codec().encode(s.control,i)),o.lengthDelimited!==!1&&i.ldelim()},(s,i,o={})=>{let a={subscriptions:[],messages:[]},c=i==null?s.len:s.pos+i;for(;s.pos<c;){let l=s.uint32();switch(l>>>3){case 1:{if(o.limits?.subscriptions!=null&&a.subscriptions.length===o.limits.subscriptions)throw new Ct('Decode error - map field "subscriptions" had too many elements');a.subscriptions.push(r.SubOpts.codec().decode(s,s.uint32(),{limits:o.limits?.subscriptions$}));break}case 2:{if(o.limits?.messages!=null&&a.messages.length===o.limits.messages)throw new Ct('Decode error - map field "messages" had too many elements');a.messages.push(r.Message.codec().decode(s,s.uint32(),{limits:o.limits?.messages$}));break}case 3:{a.control=As.codec().decode(s,s.uint32(),{limits:o.limits?.control});break}default:{s.skipType(l&7);break}}}return a})),n),r.encode=s=>St(s,r.codec()),r.decode=(s,i)=>Bt(s,r.codec(),i)})(Pe||(Pe={}));var As;(function(r){let t;r.codec=()=>(t==null&&(t=At((e,n,s={})=>{if(s.lengthDelimited!==!1&&n.fork(),e.ihave!=null)for(let i of e.ihave)n.uint32(10),ks.codec().encode(i,n);if(e.iwant!=null)for(let i of e.iwant)n.uint32(18),Is.codec().encode(i,n);if(e.graft!=null)for(let i of e.graft)n.uint32(26),Ns.codec().encode(i,n);if(e.prune!=null)for(let i of e.prune)n.uint32(34),Ts.codec().encode(i,n);s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let i={ihave:[],iwant:[],graft:[],prune:[]},o=n==null?e.len:e.pos+n;for(;e.pos<o;){let a=e.uint32();switch(a>>>3){case 1:{if(s.limits?.ihave!=null&&i.ihave.length===s.limits.ihave)throw new Ct('Decode error - map field "ihave" had too many elements');i.ihave.push(ks.codec().decode(e,e.uint32(),{limits:s.limits?.ihave$}));break}case 2:{if(s.limits?.iwant!=null&&i.iwant.length===s.limits.iwant)throw new Ct('Decode error - map field "iwant" had too many elements');i.iwant.push(Is.codec().decode(e,e.uint32(),{limits:s.limits?.iwant$}));break}case 3:{if(s.limits?.graft!=null&&i.graft.length===s.limits.graft)throw new Ct('Decode error - map field "graft" had too many elements');i.graft.push(Ns.codec().decode(e,e.uint32(),{limits:s.limits?.graft$}));break}case 4:{if(s.limits?.prune!=null&&i.prune.length===s.limits.prune)throw new Ct('Decode error - map field "prune" had too many elements');i.prune.push(Ts.codec().decode(e,e.uint32(),{limits:s.limits?.prune$}));break}default:{e.skipType(a&7);break}}}return i})),t),r.encode=e=>St(e,r.codec()),r.decode=(e,n)=>Bt(e,r.codec(),n)})(As||(As={}));var ks;(function(r){let t;r.codec=()=>(t==null&&(t=At((e,n,s={})=>{if(s.lengthDelimited!==!1&&n.fork(),e.topic!=null&&(n.uint32(10),n.string(e.topic)),e.messageIDs!=null)for(let i of e.messageIDs)n.uint32(18),n.bytes(i);s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let i={messageIDs:[]},o=n==null?e.len:e.pos+n;for(;e.pos<o;){let a=e.uint32();switch(a>>>3){case 1:{i.topic=e.string();break}case 2:{if(s.limits?.messageIDs!=null&&i.messageIDs.length===s.limits.messageIDs)throw new Ct('Decode error - map field "messageIDs" had too many elements');i.messageIDs.push(e.bytes());break}default:{e.skipType(a&7);break}}}return i})),t),r.encode=e=>St(e,r.codec()),r.decode=(e,n)=>Bt(e,r.codec(),n)})(ks||(ks={}));var Is;(function(r){let t;r.codec=()=>(t==null&&(t=At((e,n,s={})=>{if(s.lengthDelimited!==!1&&n.fork(),e.messageIDs!=null)for(let i of e.messageIDs)n.uint32(10),n.bytes(i);s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let i={messageIDs:[]},o=n==null?e.len:e.pos+n;for(;e.pos<o;){let a=e.uint32();switch(a>>>3){case 1:{if(s.limits?.messageIDs!=null&&i.messageIDs.length===s.limits.messageIDs)throw new Ct('Decode error - map field "messageIDs" had too many elements');i.messageIDs.push(e.bytes());break}default:{e.skipType(a&7);break}}}return i})),t),r.encode=e=>St(e,r.codec()),r.decode=(e,n)=>Bt(e,r.codec(),n)})(Is||(Is={}));var Ns;(function(r){let t;r.codec=()=>(t==null&&(t=At((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.topic!=null&&(n.uint32(10),n.string(e.topic)),s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let i={},o=n==null?e.len:e.pos+n;for(;e.pos<o;){let a=e.uint32();switch(a>>>3){case 1:{i.topic=e.string();break}default:{e.skipType(a&7);break}}}return i})),t),r.encode=e=>St(e,r.codec()),r.decode=(e,n)=>Bt(e,r.codec(),n)})(Ns||(Ns={}));var Ts;(function(r){let t;r.codec=()=>(t==null&&(t=At((e,n,s={})=>{if(s.lengthDelimited!==!1&&n.fork(),e.topic!=null&&(n.uint32(10),n.string(e.topic)),e.peers!=null)for(let i of e.peers)n.uint32(18),Cs.codec().encode(i,n);e.backoff!=null&&(n.uint32(24),n.uint64(e.backoff)),s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let i={peers:[]},o=n==null?e.len:e.pos+n;for(;e.pos<o;){let a=e.uint32();switch(a>>>3){case 1:{i.topic=e.string();break}case 2:{if(s.limits?.peers!=null&&i.peers.length===s.limits.peers)throw new Ct('Decode error - map field "peers" had too many elements');i.peers.push(Cs.codec().decode(e,e.uint32(),{limits:s.limits?.peers$}));break}case 3:{i.backoff=e.uint64();break}default:{e.skipType(a&7);break}}}return i})),t),r.encode=e=>St(e,r.codec()),r.decode=(e,n)=>Bt(e,r.codec(),n)})(Ts||(Ts={}));var Cs;(function(r){let t;r.codec=()=>(t==null&&(t=At((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.peerID!=null&&(n.uint32(10),n.bytes(e.peerID)),e.signedPeerRecord!=null&&(n.uint32(18),n.bytes(e.signedPeerRecord)),s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let i={},o=n==null?e.len:e.pos+n;for(;e.pos<o;){let a=e.uint32();switch(a>>>3){case 1:{i.peerID=e.bytes();break}case 2:{i.signedPeerRecord=e.bytes();break}default:{e.skipType(a&7);break}}}return i})),t),r.encode=e=>St(e,r.codec()),r.decode=(e,n)=>Bt(e,r.codec(),n)})(Cs||(Cs={}));var ho=class extends Bs{seenCache;constructor(t,e){super(t,{...e,canRelayMessage:!0,multicodecs:[fo]}),this.log=t.logger.forComponent("libp2p:floodsub"),this.seenCache=new Ss({validityMs:e?.seenTTL??3e4})}[So]=!0;[Symbol.toStringTag]="@libp2p/floodsub";[ko]=["@libp2p/pubsub"];[Io]=["@libp2p/identify"];decodeRpc(t){return Pe.decode(t)}encodeRpc(t){return Pe.encode(t)}decodeMessage(t){return Pe.Message.decode(t)}encodeMessage(t){return Pe.Message.encode(t)}async processMessage(t,e){let n=await super.getMsgId(e),s=Ot(n,"base64");this.seenCache.has(s)||(this.seenCache.put(s,!0),await super.processMessage(t,e))}async publishMessage(t,e){let n=this.getSubscribers(e.topic),s=[];return n==null||n.length===0?(this.log("no peers are subscribed to topic %s",e.topic),{recipients:s}):(n.forEach(i=>{if(this.components.peerId.equals(i)){this.log("not sending message on topic %s to myself",e.topic);return}if(i.equals(t)){this.log("not sending message on topic %s to sender %p",e.topic,i);return}this.log("publish msgs on topics %s %p",e.topic,i),s.push(i),this.send(i,{messages:[e]})}),{recipients:s})}};function Lh(r={}){return t=>new ho(t,r)}return xu(Rh);})();
7
7
  /*! Bundled license information:
8
8
 
9
9
  pvtsutils/build/index.js:
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@libp2p/floodsub",
3
- "version": "10.1.18-7a1665cd8",
3
+ "version": "10.1.18-d72b51184",
4
4
  "description": "libp2p-floodsub, also known as pubsub-flood or just dumbsub, this implementation of pubsub focused on delivering an API for Publish/Subscribe, but with no CastTree Forming (it just floods the network).",
5
5
  "license": "Apache-2.0 OR MIT",
6
6
  "homepage": "https://github.com/libp2p/js-libp2p/tree/main/packages/pubsub-floodsub#readme",
@@ -60,18 +60,18 @@
60
60
  "test:electron-main": "aegir test -t electron-main"
61
61
  },
62
62
  "dependencies": {
63
- "@libp2p/interface": "2.4.1-7a1665cd8",
64
- "@libp2p/pubsub": "10.0.17-7a1665cd8",
63
+ "@libp2p/interface": "2.4.1-d72b51184",
64
+ "@libp2p/pubsub": "10.0.17-d72b51184",
65
65
  "protons-runtime": "^5.5.0",
66
66
  "uint8arraylist": "^2.4.8",
67
67
  "uint8arrays": "^5.1.0"
68
68
  },
69
69
  "devDependencies": {
70
- "@libp2p/crypto": "5.0.10-7a1665cd8",
71
- "@libp2p/interface-compliance-tests": "6.2.5-7a1665cd8",
72
- "@libp2p/logger": "5.1.7-7a1665cd8",
73
- "@libp2p/peer-collections": "6.0.16-7a1665cd8",
74
- "@libp2p/peer-id": "5.0.11-7a1665cd8",
70
+ "@libp2p/crypto": "5.0.10-d72b51184",
71
+ "@libp2p/interface-compliance-tests": "6.2.5-d72b51184",
72
+ "@libp2p/logger": "5.1.7-d72b51184",
73
+ "@libp2p/peer-collections": "6.0.16-d72b51184",
74
+ "@libp2p/peer-id": "5.0.11-d72b51184",
75
75
  "@multiformats/multiaddr": "^12.3.3",
76
76
  "@types/sinon": "^17.0.3",
77
77
  "aegir": "^45.0.5",