@libp2p/gossipsub 15.0.16 → 15.0.17-2151144c3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.min.js CHANGED
@@ -1,5 +1,5 @@
1
1
  (function (root, factory) {(typeof module === 'object' && module.exports) ? module.exports = factory() : root.Libp2PGossipsub = factory()}(typeof self !== 'undefined' ? self : this, function () {
2
- "use strict";var Libp2PGossipsub=(()=>{var Qa=Object.create;var ks=Object.defineProperty;var ec=Object.getOwnPropertyDescriptor;var tc=Object.getOwnPropertyNames;var sc=Object.getPrototypeOf,rc=Object.prototype.hasOwnProperty;var nc=(s,e)=>()=>(e||s((e={exports:{}}).exports,e),e.exports),_e=(s,e)=>{for(var t in e)ks(s,t,{get:e[t],enumerable:!0})},Si=(s,e,t,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let n of tc(e))!rc.call(s,n)&&n!==t&&ks(s,n,{get:()=>e[n],enumerable:!(r=ec(e,n))||r.enumerable});return s};var ic=(s,e,t)=>(t=s!=null?Qa(sc(s)):{},Si(e||!s||!s.__esModule?ks(t,"default",{value:s,enumerable:!0}):t,s)),oc=s=>Si(ks({},"__esModule",{value:!0}),s);var Oa=nc((G0,Na)=>{"use strict";function Y(s,t){var t=t||{};this._capacity=t.capacity,this._head=0,this._tail=0,Array.isArray(s)?this._fromArray(s):(this._capacityMask=3,this._list=new Array(4))}Y.prototype.peekAt=function(e){var t=e;if(t===(t|0)){var r=this.size();if(!(t>=r||t<-r))return t<0&&(t+=r),t=this._head+t&this._capacityMask,this._list[t]}};Y.prototype.get=function(e){return this.peekAt(e)};Y.prototype.peek=function(){if(this._head!==this._tail)return this._list[this._head]};Y.prototype.peekFront=function(){return this.peek()};Y.prototype.peekBack=function(){return this.peekAt(-1)};Object.defineProperty(Y.prototype,"length",{get:function(){return this.size()}});Y.prototype.size=function(){return this._head===this._tail?0:this._head<this._tail?this._tail-this._head:this._capacityMask+1-(this._head-this._tail)};Y.prototype.unshift=function(e){if(arguments.length===0)return this.size();var t=this._list.length;return this._head=this._head-1+t&this._capacityMask,this._list[this._head]=e,this._tail===this._head&&this._growArray(),this._capacity&&this.size()>this._capacity&&this.pop(),this._head<this._tail?this._tail-this._head:this._capacityMask+1-(this._head-this._tail)};Y.prototype.shift=function(){var e=this._head;if(e!==this._tail){var t=this._list[e];return this._list[e]=void 0,this._head=e+1&this._capacityMask,e<2&&this._tail>1e4&&this._tail<=this._list.length>>>2&&this._shrinkArray(),t}};Y.prototype.push=function(e){if(arguments.length===0)return this.size();var t=this._tail;return this._list[t]=e,this._tail=t+1&this._capacityMask,this._tail===this._head&&this._growArray(),this._capacity&&this.size()>this._capacity&&this.shift(),this._head<this._tail?this._tail-this._head:this._capacityMask+1-(this._head-this._tail)};Y.prototype.pop=function(){var e=this._tail;if(e!==this._head){var t=this._list.length;this._tail=e-1+t&this._capacityMask;var r=this._list[this._tail];return this._list[this._tail]=void 0,this._head<2&&e>1e4&&e<=t>>>2&&this._shrinkArray(),r}};Y.prototype.removeOne=function(e){var t=e;if(t===(t|0)&&this._head!==this._tail){var r=this.size(),n=this._list.length;if(!(t>=r||t<-r)){t<0&&(t+=r),t=this._head+t&this._capacityMask;var i=this._list[t],o;if(e<r/2){for(o=e;o>0;o--)this._list[t]=this._list[t=t-1+n&this._capacityMask];this._list[t]=void 0,this._head=this._head+1+n&this._capacityMask}else{for(o=r-1-e;o>0;o--)this._list[t]=this._list[t=t+1+n&this._capacityMask];this._list[t]=void 0,this._tail=this._tail-1+n&this._capacityMask}return i}}};Y.prototype.remove=function(e,t){var r=e,n,i=t;if(r===(r|0)&&this._head!==this._tail){var o=this.size(),a=this._list.length;if(!(r>=o||r<-o||t<1)){if(r<0&&(r+=o),t===1||!t)return n=new Array(1),n[0]=this.removeOne(r),n;if(r===0&&r+t>=o)return n=this.toArray(),this.clear(),n;r+t>o&&(t=o-r);var c;for(n=new Array(t),c=0;c<t;c++)n[c]=this._list[this._head+r+c&this._capacityMask];if(r=this._head+r&this._capacityMask,e+t===o){for(this._tail=this._tail-t+a&this._capacityMask,c=t;c>0;c--)this._list[r=r+1+a&this._capacityMask]=void 0;return n}if(e===0){for(this._head=this._head+t+a&this._capacityMask,c=t-1;c>0;c--)this._list[r=r+1+a&this._capacityMask]=void 0;return n}if(r<o/2){for(this._head=this._head+e+t+a&this._capacityMask,c=e;c>0;c--)this.unshift(this._list[r=r-1+a&this._capacityMask]);for(r=this._head-1+a&this._capacityMask;i>0;)this._list[r=r-1+a&this._capacityMask]=void 0,i--;e<0&&(this._tail=r)}else{for(this._tail=r,r=r+t+a&this._capacityMask,c=o-(t+e);c>0;c--)this.push(this._list[r++]);for(r=this._tail;i>0;)this._list[r=r+1+a&this._capacityMask]=void 0,i--}return this._head<2&&this._tail>1e4&&this._tail<=a>>>2&&this._shrinkArray(),n}}};Y.prototype.splice=function(e,t){var r=e;if(r===(r|0)){var n=this.size();if(r<0&&(r+=n),!(r>n))if(arguments.length>2){var i,o,a,c=arguments.length,f=this._list.length,p=2;if(!n||r<n/2){for(o=new Array(r),i=0;i<r;i++)o[i]=this._list[this._head+i&this._capacityMask];for(t===0?(a=[],r>0&&(this._head=this._head+r+f&this._capacityMask)):(a=this.remove(r,t),this._head=this._head+r+f&this._capacityMask);c>p;)this.unshift(arguments[--c]);for(i=r;i>0;i--)this.unshift(o[i-1])}else{o=new Array(n-(r+t));var m=o.length;for(i=0;i<m;i++)o[i]=this._list[this._head+r+t+i&this._capacityMask];for(t===0?(a=[],r!=n&&(this._tail=this._head+r+f&this._capacityMask)):(a=this.remove(r,t),this._tail=this._tail-m+f&this._capacityMask);p<c;)this.push(arguments[p++]);for(i=0;i<m;i++)this.push(o[i])}return a}else return this.remove(r,t)}};Y.prototype.clear=function(){this._list=new Array(this._list.length),this._head=0,this._tail=0};Y.prototype.isEmpty=function(){return this._head===this._tail};Y.prototype.toArray=function(){return this._copyArray(!1)};Y.prototype._fromArray=function(e){var t=e.length,r=this._nextPowerOf2(t);this._list=new Array(r),this._capacityMask=r-1,this._tail=t;for(var n=0;n<t;n++)this._list[n]=e[n]};Y.prototype._copyArray=function(e,t){var r=this._list,n=r.length,i=this.length;if(t=t|i,t==i&&this._head<this._tail)return this._list.slice(this._head,this._tail);var o=new Array(t),a=0,c;if(e||this._head>this._tail){for(c=this._head;c<n;c++)o[a++]=r[c];for(c=0;c<this._tail;c++)o[a++]=r[c]}else for(c=this._head;c<this._tail;c++)o[a++]=r[c];return o};Y.prototype._growArray=function(){if(this._head!=0){var e=this._copyArray(!0,this._list.length<<1);this._tail=this._list.length,this._head=0,this._list=e}else this._tail=this._list.length,this._list.length<<=1;this._capacityMask=this._capacityMask<<1|1};Y.prototype._shrinkArray=function(){this._list.length>>>=1,this._capacityMask>>>=1};Y.prototype._nextPowerOf2=function(e){var t=Math.log(e)/Math.log(2),r=1<<t+1;return Math.max(r,4)};Na.exports=Y});var Lh={};_e(Lh,{StrictNoSign:()=>Pt,StrictSign:()=>mt,TopicValidatorResult:()=>me,gossipsub:()=>kh,multicodec:()=>Ph});var Ir="/floodsub/1.0.0",Tr="/meshsub/1.0.0",_i="/meshsub/1.1.0",kt="/meshsub/1.2.0";var Ii="ERR_TOPIC_VALIDATOR_REJECT",Ti="ERR_TOPIC_VALIDATOR_IGNORE";var $=class extends Error{static name="InvalidParametersError";constructor(e="Invalid parameters"){super(e),this.name="InvalidParametersError"}},Lt=class extends Error{static name="InvalidPublicKeyError";constructor(e="Invalid public key"){super(e),this.name="InvalidPublicKeyError"}};var Ls=class extends Error{static name="InvalidCIDError";constructor(e="Invalid CID"){super(e),this.name="InvalidCIDError"}},Bs=class extends Error{static name="InvalidMultihashError";constructor(e="Invalid Multihash"){super(e),this.name="InvalidMultihashError"}};var Bt=class extends Error{static name="UnsupportedKeyTypeError";constructor(e="Unsupported key type"){super(e),this.name="UnsupportedKeyTypeError"}};var Dr=Symbol.for("@libp2p/peer-id");var Rs=class extends EventTarget{#e=new Map;constructor(){super()}listenerCount(e){let t=this.#e.get(e);return t==null?0:t.length}addEventListener(e,t,r){super.addEventListener(e,t,r);let n=this.#e.get(e);n==null&&(n=[],this.#e.set(e,n)),n.push({callback:t,once:(r!==!0&&r!==!1&&r?.once)??!1})}removeEventListener(e,t,r){super.removeEventListener(e.toString(),t??null,r);let n=this.#e.get(e);n!=null&&(n=n.filter(({callback:i})=>i!==t),this.#e.set(e,n))}dispatchEvent(e){let t=super.dispatchEvent(e),r=this.#e.get(e.type);return r==null||(r=r.filter(({once:n})=>!n),this.#e.set(e.type,r)),t}safeDispatchEvent(e,t={}){return this.dispatchEvent(new CustomEvent(e,t))}};var Ai=Symbol.for("@libp2p/service-capabilities"),Mi=Symbol.for("@libp2p/service-dependencies");var Lr={};_e(Lr,{base58btc:()=>te,base58flickr:()=>dc});var lf=new Uint8Array(0);function Pi(s,e){if(s===e)return!0;if(s.byteLength!==e.byteLength)return!1;for(let t=0;t<s.byteLength;t++)if(s[t]!==e[t])return!1;return!0}function ze(s){if(s instanceof Uint8Array&&s.constructor.name==="Uint8Array")return s;if(s instanceof ArrayBuffer)return new Uint8Array(s);if(ArrayBuffer.isView(s))return new Uint8Array(s.buffer,s.byteOffset,s.byteLength);throw new Error("Unknown type, must be binary type")}function ki(s){return new TextEncoder().encode(s)}function Li(s){return new TextDecoder().decode(s)}function ac(s,e){if(s.length>=255)throw new TypeError("Alphabet too long");for(var t=new Uint8Array(256),r=0;r<t.length;r++)t[r]=255;for(var n=0;n<s.length;n++){var i=s.charAt(n),o=i.charCodeAt(0);if(t[o]!==255)throw new TypeError(i+" is ambiguous");t[o]=n}var a=s.length,c=s.charAt(0),f=Math.log(a)/Math.log(256),p=Math.log(256)/Math.log(a);function m(u){if(u instanceof Uint8Array||(ArrayBuffer.isView(u)?u=new Uint8Array(u.buffer,u.byteOffset,u.byteLength):Array.isArray(u)&&(u=Uint8Array.from(u))),!(u instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(u.length===0)return"";for(var g=0,w=0,y=0,I=u.length;y!==I&&u[y]===0;)y++,g++;for(var l=(I-y)*p+1>>>0,h=new Uint8Array(l);y!==I;){for(var d=u[y],b=0,E=l-1;(d!==0||b<w)&&E!==-1;E--,b++)d+=256*h[E]>>>0,h[E]=d%a>>>0,d=d/a>>>0;if(d!==0)throw new Error("Non-zero carry");w=b,y++}for(var x=l-w;x!==l&&h[x]===0;)x++;for(var S=c.repeat(g);x<l;++x)S+=s.charAt(h[x]);return S}function _(u){if(typeof u!="string")throw new TypeError("Expected String");if(u.length===0)return new Uint8Array;var g=0;if(u[g]!==" "){for(var w=0,y=0;u[g]===c;)w++,g++;for(var I=(u.length-g)*f+1>>>0,l=new Uint8Array(I);u[g];){var h=t[u.charCodeAt(g)];if(h===255)return;for(var d=0,b=I-1;(h!==0||d<y)&&b!==-1;b--,d++)h+=a*l[b]>>>0,l[b]=h%256>>>0,h=h/256>>>0;if(h!==0)throw new Error("Non-zero carry");y=d,g++}if(u[g]!==" "){for(var E=I-y;E!==I&&l[E]===0;)E++;for(var x=new Uint8Array(w+(I-E)),S=w;E!==I;)x[S++]=l[E++];return x}}}function v(u){var g=_(u);if(g)return g;throw new Error(`Non-${e} character`)}return{encode:m,decodeUnsafe:_,decode:v}}var cc=ac,lc=cc,Ri=lc;var Ar=class{name;prefix;baseEncode;constructor(e,t,r){this.name=e,this.prefix=t,this.baseEncode=r}encode(e){if(e instanceof Uint8Array)return`${this.prefix}${this.baseEncode(e)}`;throw Error("Unknown type, must be binary type")}},Mr=class{name;prefix;baseDecode;prefixCodePoint;constructor(e,t,r){this.name=e,this.prefix=t;let n=t.codePointAt(0);if(n===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=n,this.baseDecode=r}decode(e){if(typeof e=="string"){if(e.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(e)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(e.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(e){return Ci(this,e)}},Pr=class{decoders;constructor(e){this.decoders=e}or(e){return Ci(this,e)}decode(e){let t=e[0],r=this.decoders[t];if(r!=null)return r.decode(e);throw RangeError(`Unable to decode multibase string ${JSON.stringify(e)}, only inputs prefixed with ${Object.keys(this.decoders)} are supported`)}};function Ci(s,e){return new Pr({...s.decoders??{[s.prefix]:s},...e.decoders??{[e.prefix]:e}})}var kr=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(e,t,r,n){this.name=e,this.prefix=t,this.baseEncode=r,this.baseDecode=n,this.encoder=new Ar(e,t,r),this.decoder=new Mr(e,t,n)}encode(e){return this.encoder.encode(e)}decode(e){return this.decoder.decode(e)}};function Rt({name:s,prefix:e,encode:t,decode:r}){return new kr(s,e,t,r)}function rt({name:s,prefix:e,alphabet:t}){let{encode:r,decode:n}=Ri(t,s);return Rt({prefix:e,name:s,encode:r,decode:i=>ze(n(i))})}function uc(s,e,t,r){let n=s.length;for(;s[n-1]==="=";)--n;let i=new Uint8Array(n*t/8|0),o=0,a=0,c=0;for(let f=0;f<n;++f){let p=e[s[f]];if(p===void 0)throw new SyntaxError(`Non-${r} character`);a=a<<t|p,o+=t,o>=8&&(o-=8,i[c++]=255&a>>o)}if(o>=t||(255&a<<8-o)!==0)throw new SyntaxError("Unexpected end of data");return i}function hc(s,e,t){let r=e[e.length-1]==="=",n=(1<<t)-1,i="",o=0,a=0;for(let c=0;c<s.length;++c)for(a=a<<8|s[c],o+=8;o>t;)o-=t,i+=e[n&a>>o];if(o!==0&&(i+=e[n&a<<t-o]),r)for(;(i.length*t&7)!==0;)i+="=";return i}function fc(s){let e={};for(let t=0;t<s.length;++t)e[s[t]]=t;return e}function ee({name:s,prefix:e,bitsPerChar:t,alphabet:r}){let n=fc(r);return Rt({prefix:e,name:s,encode(i){return hc(i,r,t)},decode(i){return uc(i,n,t,s)}})}var te=rt({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),dc=rt({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Br={};_e(Br,{base32:()=>Ct,base32hex:()=>bc,base32hexpad:()=>wc,base32hexpadupper:()=>xc,base32hexupper:()=>yc,base32pad:()=>mc,base32padupper:()=>gc,base32upper:()=>pc,base32z:()=>vc});var Ct=ee({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),pc=ee({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),mc=ee({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),gc=ee({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),bc=ee({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),yc=ee({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),wc=ee({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),xc=ee({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),vc=ee({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Rr={};_e(Rr,{base36:()=>is,base36upper:()=>Ec});var is=rt({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),Ec=rt({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Sc=Ui,Ni=128,_c=127,Ic=~_c,Tc=Math.pow(2,31);function Ui(s,e,t){e=e||[],t=t||0;for(var r=t;s>=Tc;)e[t++]=s&255|Ni,s/=128;for(;s&Ic;)e[t++]=s&255|Ni,s>>>=7;return e[t]=s|0,Ui.bytes=t-r+1,e}var Dc=Cr,Ac=128,Oi=127;function Cr(s,r){var t=0,r=r||0,n=0,i=r,o,a=s.length;do{if(i>=a)throw Cr.bytes=0,new RangeError("Could not decode varint");o=s[i++],t+=n<28?(o&Oi)<<n:(o&Oi)*Math.pow(2,n),n+=7}while(o>=Ac);return Cr.bytes=i-r,t}var Mc=Math.pow(2,7),Pc=Math.pow(2,14),kc=Math.pow(2,21),Lc=Math.pow(2,28),Bc=Math.pow(2,35),Rc=Math.pow(2,42),Cc=Math.pow(2,49),Nc=Math.pow(2,56),Oc=Math.pow(2,63),Uc=function(s){return s<Mc?1:s<Pc?2:s<kc?3:s<Lc?4:s<Bc?5:s<Rc?6:s<Cc?7:s<Nc?8:s<Oc?9:10},Kc={encode:Sc,decode:Dc,encodingLength:Uc},Fc=Kc,os=Fc;function as(s,e=0){return[os.decode(s,e),os.decode.bytes]}function Nt(s,e,t=0){return os.encode(s,e,t),e}function Ot(s){return os.encodingLength(s)}function Ue(s,e){let t=e.byteLength,r=Ot(s),n=r+Ot(t),i=new Uint8Array(n+t);return Nt(s,i,0),Nt(t,i,r),i.set(e,n),new Ut(s,t,e,i)}function Ve(s){let e=ze(s),[t,r]=as(e),[n,i]=as(e.subarray(r)),o=e.subarray(r+i);if(o.byteLength!==n)throw new Error("Incorrect length");return new Ut(t,n,o,e)}function Ki(s,e){if(s===e)return!0;{let t=e;return s.code===t.code&&s.size===t.size&&t.bytes instanceof Uint8Array&&Pi(s.bytes,t.bytes)}}var Ut=class{code;size;digest;bytes;constructor(e,t,r,n){this.code=e,this.size=t,this.digest=r,this.bytes=n}};function Fi(s,e){let{bytes:t,version:r}=s;switch(r){case 0:return Hc(t,Nr(s),e??te.encoder);default:return qc(t,Nr(s),e??Ct.encoder)}}var Gi=new WeakMap;function Nr(s){let e=Gi.get(s);if(e==null){let t=new Map;return Gi.set(s,t),t}return e}var ae=class s{code;version;multihash;bytes;"/";constructor(e,t,r,n){this.code=t,this.version=e,this.multihash=r,this.bytes=n,this["/"]=n}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:e,multihash:t}=this;if(e!==cs)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(t.code!==zc)throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");return s.createV0(t)}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:e,digest:t}=this.multihash,r=Ue(e,t);return s.createV1(this.code,r)}case 1:return this;default:throw Error(`Can not convert CID version ${this.version} to version 1. This is a bug please report`)}}equals(e){return s.equals(this,e)}static equals(e,t){let r=t;return r!=null&&e.code===r.code&&e.version===r.version&&Ki(e.multihash,r.multihash)}toString(e){return Fi(this,e)}toJSON(){return{"/":Fi(this)}}link(){return this}[Symbol.toStringTag]="CID";[Symbol.for("nodejs.util.inspect.custom")](){return`CID(${this.toString()})`}static asCID(e){if(e==null)return null;let t=e;if(t instanceof s)return t;if(t["/"]!=null&&t["/"]===t.bytes||t.asCID===t){let{version:r,code:n,multihash:i,bytes:o}=t;return new s(r,n,i,o??Hi(r,n,i.bytes))}else if(t[Vc]===!0){let{version:r,multihash:n,code:i}=t,o=Ve(n);return s.create(r,i,o)}else return null}static create(e,t,r){if(typeof t!="number")throw new Error("String codecs are no longer supported");if(!(r.bytes instanceof Uint8Array))throw new Error("Invalid digest");switch(e){case 0:{if(t!==cs)throw new Error(`Version 0 CID must use dag-pb (code: ${cs}) block encoding`);return new s(e,t,r,r.bytes)}case 1:{let n=Hi(e,t,r.bytes);return new s(e,t,r,n)}default:throw new Error("Invalid version")}}static createV0(e){return s.create(0,cs,e)}static createV1(e,t){return s.create(1,e,t)}static decode(e){let[t,r]=s.decodeFirst(e);if(r.length!==0)throw new Error("Incorrect length");return t}static decodeFirst(e){let t=s.inspectBytes(e),r=t.size-t.multihashSize,n=ze(e.subarray(r,r+t.multihashSize));if(n.byteLength!==t.multihashSize)throw new Error("Incorrect length");let i=n.subarray(t.multihashSize-t.digestSize),o=new Ut(t.multihashCode,t.digestSize,i,n);return[t.version===0?s.createV0(o):s.createV1(t.codec,o),e.subarray(t.size)]}static inspectBytes(e){let t=0,r=()=>{let[m,_]=as(e.subarray(t));return t+=_,m},n=r(),i=cs;if(n===18?(n=0,t=0):i=r(),n!==0&&n!==1)throw new RangeError(`Invalid CID version ${n}`);let o=t,a=r(),c=r(),f=t+c,p=f-o;return{version:n,codec:i,multihashCode:a,digestSize:c,multihashSize:p,size:f}}static parse(e,t){let[r,n]=Gc(e,t),i=s.decode(n);if(i.version===0&&e[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return Nr(i).set(r,e),i}};function Gc(s,e){switch(s[0]){case"Q":{let t=e??te;return[te.prefix,t.decode(`${te.prefix}${s}`)]}case te.prefix:{let t=e??te;return[te.prefix,t.decode(s)]}case Ct.prefix:{let t=e??Ct;return[Ct.prefix,t.decode(s)]}case is.prefix:{let t=e??is;return[is.prefix,t.decode(s)]}default:{if(e==null)throw Error("To parse non base32, base36 or base58btc encoded CID multibase decoder must be provided");return[s[0],e.decode(s)]}}}function Hc(s,e,t){let{prefix:r}=t;if(r!==te.prefix)throw Error(`Cannot string encode V0 in ${t.name} encoding`);let n=e.get(r);if(n==null){let i=t.encode(s).slice(1);return e.set(r,i),i}else return n}function qc(s,e,t){let{prefix:r}=t,n=e.get(r);if(n==null){let i=t.encode(s);return e.set(r,i),i}else return n}var cs=112,zc=18;function Hi(s,e,t){let r=Ot(s),n=r+Ot(e),i=new Uint8Array(n+t.byteLength);return Nt(s,i,0),Nt(e,i,r),i.set(t,n),i}var Vc=Symbol.for("@ipld/js-cid/CID");var Or={};_e(Or,{identity:()=>Le});var qi=0,Wc="identity",zi=ze;function $c(s,e){if(e?.truncate!=null&&e.truncate!==s.byteLength){if(e.truncate<0||e.truncate>s.byteLength)throw new Error(`Invalid truncate option, must be less than or equal to ${s.byteLength}`);s=s.subarray(0,e.truncate)}return Ue(qi,zi(s))}var Le={code:qi,name:Wc,encode:zi,digest:$c};function Ie(s,e){if(s===e)return!0;if(s.byteLength!==e.byteLength)return!1;for(let t=0;t<s.byteLength;t++)if(s[t]!==e[t])return!1;return!0}function We(s=0){return new Uint8Array(s)}function ue(s=0){return new Uint8Array(s)}function gt(s,e){e==null&&(e=s.reduce((n,i)=>n+i.length,0));let t=ue(e),r=0;for(let n of s)t.set(n,r),r+=n.length;return t}var Wi=Symbol.for("@achingbrain/uint8arraylist");function Vi(s,e){if(e==null||e<0)throw new RangeError("index is out of bounds");let t=0;for(let r of s){let n=t+r.byteLength;if(e<n)return{buf:r,index:e-t};t=n}throw new RangeError("index is out of bounds")}function Ns(s){return!!s?.[Wi]}var re=class s{bufs;length;[Wi]=!0;constructor(...e){this.bufs=[],this.length=0,e.length>0&&this.appendAll(e)}*[Symbol.iterator](){yield*this.bufs}get byteLength(){return this.length}append(...e){this.appendAll(e)}appendAll(e){let t=0;for(let r of e)if(r instanceof Uint8Array)t+=r.byteLength,this.bufs.push(r);else if(Ns(r))t+=r.byteLength,this.bufs.push(...r.bufs);else throw new Error("Could not append value, must be an Uint8Array or a Uint8ArrayList");this.length+=t}prepend(...e){this.prependAll(e)}prependAll(e){let t=0;for(let r of e.reverse())if(r instanceof Uint8Array)t+=r.byteLength,this.bufs.unshift(r);else if(Ns(r))t+=r.byteLength,this.bufs.unshift(...r.bufs);else throw new Error("Could not prepend value, must be an Uint8Array or a Uint8ArrayList");this.length+=t}get(e){let t=Vi(this.bufs,e);return t.buf[t.index]}set(e,t){let r=Vi(this.bufs,e);r.buf[r.index]=t}write(e,t=0){if(e instanceof Uint8Array)for(let r=0;r<e.length;r++)this.set(t+r,e[r]);else if(Ns(e))for(let r=0;r<e.length;r++)this.set(t+r,e.get(r));else throw new Error("Could not write value, must be an Uint8Array or a Uint8ArrayList")}consume(e){if(e=Math.trunc(e),!(Number.isNaN(e)||e<=0)){if(e===this.byteLength){this.bufs=[],this.length=0;return}for(;this.bufs.length>0;)if(e>=this.bufs[0].byteLength)e-=this.bufs[0].byteLength,this.length-=this.bufs[0].byteLength,this.bufs.shift();else{this.bufs[0]=this.bufs[0].subarray(e),this.length-=e;break}}}slice(e,t){let{bufs:r,length:n}=this._subList(e,t);return gt(r,n)}subarray(e,t){let{bufs:r,length:n}=this._subList(e,t);return r.length===1?r[0]:gt(r,n)}sublist(e,t){let{bufs:r,length:n}=this._subList(e,t),i=new s;return i.length=n,i.bufs=[...r],i}_subList(e,t){if(e=e??0,t=t??this.length,e<0&&(e=this.length+e),t<0&&(t=this.length+t),e<0||t>this.length)throw new RangeError("index is out of bounds");if(e===t)return{bufs:[],length:0};if(e===0&&t===this.length)return{bufs:this.bufs,length:this.length};let r=[],n=0;for(let i=0;i<this.bufs.length;i++){let o=this.bufs[i],a=n,c=a+o.byteLength;if(n=c,e>=c)continue;let f=e>=a&&e<c,p=t>a&&t<=c;if(f&&p){if(e===a&&t===c){r.push(o);break}let m=e-a;r.push(o.subarray(m,m+(t-e)));break}if(f){if(e===0){r.push(o);continue}r.push(o.subarray(e-a));continue}if(p){if(t===c){r.push(o);break}r.push(o.subarray(0,t-a));break}r.push(o)}return{bufs:r,length:t-e}}indexOf(e,t=0){if(!Ns(e)&&!(e instanceof Uint8Array))throw new TypeError('The "value" argument must be a Uint8ArrayList or Uint8Array');let r=e instanceof Uint8Array?e:e.subarray();if(t=Number(t??0),isNaN(t)&&(t=0),t<0&&(t=this.length+t),t<0&&(t=0),e.length===0)return t>this.length?this.length:t;let n=r.byteLength;if(n===0)throw new TypeError("search must be at least 1 byte long");let i=256,o=new Int32Array(i);for(let m=0;m<i;m++)o[m]=-1;for(let m=0;m<n;m++)o[r[m]]=m;let a=o,c=this.byteLength-r.byteLength,f=r.byteLength-1,p;for(let m=t;m<=c;m+=p){p=0;for(let _=f;_>=0;_--){let v=this.get(m+_);if(r[_]!==v){p=Math.max(1,_-a[v]);break}}if(p===0)return m}return-1}getInt8(e){let t=this.subarray(e,e+1);return new DataView(t.buffer,t.byteOffset,t.byteLength).getInt8(0)}setInt8(e,t){let r=ue(1);new DataView(r.buffer,r.byteOffset,r.byteLength).setInt8(0,t),this.write(r,e)}getInt16(e,t){let r=this.subarray(e,e+2);return new DataView(r.buffer,r.byteOffset,r.byteLength).getInt16(0,t)}setInt16(e,t,r){let n=We(2);new DataView(n.buffer,n.byteOffset,n.byteLength).setInt16(0,t,r),this.write(n,e)}getInt32(e,t){let r=this.subarray(e,e+4);return new DataView(r.buffer,r.byteOffset,r.byteLength).getInt32(0,t)}setInt32(e,t,r){let n=We(4);new DataView(n.buffer,n.byteOffset,n.byteLength).setInt32(0,t,r),this.write(n,e)}getBigInt64(e,t){let r=this.subarray(e,e+8);return new DataView(r.buffer,r.byteOffset,r.byteLength).getBigInt64(0,t)}setBigInt64(e,t,r){let n=We(8);new DataView(n.buffer,n.byteOffset,n.byteLength).setBigInt64(0,t,r),this.write(n,e)}getUint8(e){let t=this.subarray(e,e+1);return new DataView(t.buffer,t.byteOffset,t.byteLength).getUint8(0)}setUint8(e,t){let r=ue(1);new DataView(r.buffer,r.byteOffset,r.byteLength).setUint8(0,t),this.write(r,e)}getUint16(e,t){let r=this.subarray(e,e+2);return new DataView(r.buffer,r.byteOffset,r.byteLength).getUint16(0,t)}setUint16(e,t,r){let n=We(2);new DataView(n.buffer,n.byteOffset,n.byteLength).setUint16(0,t,r),this.write(n,e)}getUint32(e,t){let r=this.subarray(e,e+4);return new DataView(r.buffer,r.byteOffset,r.byteLength).getUint32(0,t)}setUint32(e,t,r){let n=We(4);new DataView(n.buffer,n.byteOffset,n.byteLength).setUint32(0,t,r),this.write(n,e)}getBigUint64(e,t){let r=this.subarray(e,e+8);return new DataView(r.buffer,r.byteOffset,r.byteLength).getBigUint64(0,t)}setBigUint64(e,t,r){let n=We(8);new DataView(n.buffer,n.byteOffset,n.byteLength).setBigUint64(0,t,r),this.write(n,e)}getFloat32(e,t){let r=this.subarray(e,e+4);return new DataView(r.buffer,r.byteOffset,r.byteLength).getFloat32(0,t)}setFloat32(e,t,r){let n=We(4);new DataView(n.buffer,n.byteOffset,n.byteLength).setFloat32(0,t,r),this.write(n,e)}getFloat64(e,t){let r=this.subarray(e,e+8);return new DataView(r.buffer,r.byteOffset,r.byteLength).getFloat64(0,t)}setFloat64(e,t,r){let n=We(8);new DataView(n.buffer,n.byteOffset,n.byteLength).setFloat64(0,t,r),this.write(n,e)}equals(e){if(e==null||!(e instanceof s)||e.bufs.length!==this.bufs.length)return!1;for(let t=0;t<this.bufs.length;t++)if(!Ie(this.bufs[t],e.bufs[t]))return!1;return!0}static fromUint8Arrays(e,t){let r=new s;return r.bufs=e,t==null&&(t=e.reduce((n,i)=>n+i.byteLength,0)),r.length=t,r}};var Ur={};_e(Ur,{base10:()=>Zc});var Zc=rt({prefix:"9",name:"base10",alphabet:"0123456789"});var Kr={};_e(Kr,{base16:()=>jc,base16upper:()=>Yc});var jc=ee({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Yc=ee({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Fr={};_e(Fr,{base2:()=>Xc});var Xc=ee({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Gr={};_e(Gr,{base256emoji:()=>sl});var $i=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}"),Jc=$i.reduce((s,e,t)=>(s[t]=e,s),[]),Qc=$i.reduce((s,e,t)=>{let r=e.codePointAt(0);if(r==null)throw new Error(`Invalid character: ${e}`);return s[r]=t,s},[]);function el(s){return s.reduce((e,t)=>(e+=Jc[t],e),"")}function tl(s){let e=[];for(let t of s){let r=t.codePointAt(0);if(r==null)throw new Error(`Invalid character: ${t}`);let n=Qc[r];if(n==null)throw new Error(`Non-base256emoji character: ${t}`);e.push(n)}return new Uint8Array(e)}var sl=Rt({prefix:"\u{1F680}",name:"base256emoji",encode:el,decode:tl});var Hr={};_e(Hr,{base64:()=>rl,base64pad:()=>nl,base64url:()=>il,base64urlpad:()=>ol});var rl=ee({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),nl=ee({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),il=ee({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),ol=ee({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var qr={};_e(qr,{base8:()=>al});var al=ee({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var zr={};_e(zr,{identity:()=>cl});var cl=Rt({prefix:"\0",name:"identity",encode:s=>Li(s),decode:s=>ki(s)});var Wf=new TextEncoder,$f=new TextDecoder;var $r={};_e($r,{sha256:()=>bt,sha512:()=>fl});var hl=20;function Wr({name:s,code:e,encode:t,minDigestLength:r,maxDigestLength:n}){return new Vr(s,e,t,r,n)}var Vr=class{name;code;encode;minDigestLength;maxDigestLength;constructor(e,t,r,n,i){this.name=e,this.code=t,this.encode=r,this.minDigestLength=n??hl,this.maxDigestLength=i}digest(e,t){if(t?.truncate!=null){if(t.truncate<this.minDigestLength)throw new Error(`Invalid truncate option, must be greater than or equal to ${this.minDigestLength}`);if(this.maxDigestLength!=null&&t.truncate>this.maxDigestLength)throw new Error(`Invalid truncate option, must be less than or equal to ${this.maxDigestLength}`)}if(e instanceof Uint8Array){let r=this.encode(e);return r instanceof Uint8Array?Zi(r,this.code,t?.truncate):r.then(n=>Zi(n,this.code,t?.truncate))}else throw Error("Unknown type, must be binary type")}};function Zi(s,e,t){if(t!=null&&t!==s.byteLength){if(t>s.byteLength)throw new Error(`Invalid truncate option, must be less than or equal to ${s.byteLength}`);s=s.subarray(0,t)}return Ue(e,s)}function Yi(s){return async e=>new Uint8Array(await crypto.subtle.digest(s,e))}var bt=Wr({name:"sha2-256",code:18,encode:Yi("SHA-256")}),fl=Wr({name:"sha2-512",code:19,encode:Yi("SHA-512")});var Zr={...zr,...Fr,...qr,...Ur,...Kr,...Br,...Rr,...Lr,...Hr,...Gr},id={...$r,...Or};function Ji(s,e,t,r){return{name:s,prefix:e,encoder:{name:s,prefix:e,encode:t},decoder:{decode:r}}}var Xi=Ji("utf8","u",s=>"u"+new TextDecoder("utf8").decode(s),s=>new TextEncoder().encode(s.substring(1))),jr=Ji("ascii","a",s=>{let e="a";for(let t=0;t<s.length;t++)e+=String.fromCharCode(s[t]);return e},s=>{s=s.substring(1);let e=ue(s.length);for(let t=0;t<s.length;t++)e[t]=s.charCodeAt(t);return e}),dl={utf8:Xi,"utf-8":Xi,hex:Zr.base16,latin1:jr,ascii:jr,binary:jr,...Zr},Os=dl;function z(s,e="utf8"){let t=Os[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return t.decoder.decode(`${t.prefix}${s}`)}function q(s,e="utf8"){let t=Os[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return t.encoder.encode(s).substring(1)}var pl=parseInt("11111",2),Yr=parseInt("10000000",2),ml=parseInt("01111111",2),Qi={0:ls,1:ls,2:gl,3:wl,4:xl,5:yl,6:bl,16:ls,22:ls,48:ls};function $e(s,e={offset:0}){let t=s[e.offset]&pl;if(e.offset++,Qi[t]!=null)return Qi[t](s,e);throw new Error("No decoder for tag "+t)}function us(s,e){let t=0;if((s[e.offset]&Yr)===Yr){let r=s[e.offset]&ml,n="0x";e.offset++;for(let i=0;i<r;i++,e.offset++)n+=s[e.offset].toString(16).padStart(2,"0");t=parseInt(n,16)}else t=s[e.offset],e.offset++;return t}function ls(s,e){us(s,e);let t=[];for(;!(e.offset>=s.byteLength);){let r=$e(s,e);if(r===null)break;t.push(r)}return t}function gl(s,e){let t=us(s,e),r=e.offset,n=e.offset+t,i=[];for(let o=r;o<n;o++)o===r&&s[o]===0||i.push(s[o]);return e.offset+=t,Uint8Array.from(i)}function bl(s,e){let t=us(s,e),r=e.offset+t,n=s[e.offset];e.offset++;let i=0,o=0;n<40?(i=0,o=n):n<80?(i=1,o=n-40):(i=2,o=n-80);let a=`${i}.${o}`,c=[];for(;e.offset<r;){let f=s[e.offset];if(e.offset++,c.push(f&127),f<128){c.reverse();let p=0;for(let m=0;m<c.length;m++)p+=c[m]<<m*7;a+=`.${p}`,c=[]}}return a}function yl(s,e){return e.offset++,null}function wl(s,e){let t=us(s,e),r=s[e.offset];e.offset++;let n=s.subarray(e.offset,e.offset+t-1);if(e.offset+=t,r!==0)throw new Error("Unused bits in bit string is unimplemented");return n}function xl(s,e){let t=us(s,e),r=s.subarray(e.offset,e.offset+t);return e.offset+=t,r}function vl(s){let e=s.toString(16);e.length%2===1&&(e="0"+e);let t=new re;for(let r=0;r<e.length;r+=2)t.append(Uint8Array.from([parseInt(`${e[r]}${e[r+1]}`,16)]));return t}function Xr(s){if(s.byteLength<128)return Uint8Array.from([s.byteLength]);let e=vl(s.byteLength);return new re(Uint8Array.from([e.byteLength|Yr]),e)}function Te(s){let e=new re,t=128;return(s.subarray()[0]&t)===t&&e.append(Uint8Array.from([0])),e.append(s),new re(Uint8Array.from([2]),Xr(e),e)}function Us(s){let e=Uint8Array.from([0]),t=new re(e,s);return new re(Uint8Array.from([3]),Xr(t),t)}function it(s,e=48){let t=new re;for(let r of s)t.append(r);return new re(Uint8Array.from([e]),Xr(t),t)}async function eo(s,e,t,r){let n=await crypto.subtle.importKey("jwk",s,{name:"ECDSA",namedCurve:s.crv??"P-256"},!1,["verify"]);r?.signal?.throwIfAborted();let i=await crypto.subtle.verify({name:"ECDSA",hash:{name:"SHA-256"}},n,e,t.subarray());return r?.signal?.throwIfAborted(),i}var El=Uint8Array.from([6,8,42,134,72,206,61,3,1,7]),Sl=Uint8Array.from([6,5,43,129,4,0,34]),_l=Uint8Array.from([6,5,43,129,4,0,35]),Il={ext:!0,kty:"EC",crv:"P-256"},Tl={ext:!0,kty:"EC",crv:"P-384"},Dl={ext:!0,kty:"EC",crv:"P-521"},Jr=32,Qr=48,en=66;function tn(s){let e=$e(s);return to(e)}function to(s){let e=s[1][1][0],t=1,r,n;if(e.byteLength===Jr*2+1)return r=q(e.subarray(t,t+Jr),"base64url"),n=q(e.subarray(t+Jr),"base64url"),new Kt({...Il,key_ops:["verify"],x:r,y:n});if(e.byteLength===Qr*2+1)return r=q(e.subarray(t,t+Qr),"base64url"),n=q(e.subarray(t+Qr),"base64url"),new Kt({...Tl,key_ops:["verify"],x:r,y:n});if(e.byteLength===en*2+1)return r=q(e.subarray(t,t+en),"base64url"),n=q(e.subarray(t+en),"base64url"),new Kt({...Dl,key_ops:["verify"],x:r,y:n});throw new $(`coordinates were wrong length, got ${e.byteLength}, expected 65, 97 or 133`)}function so(s){return it([Te(Uint8Array.from([1])),it([Al(s.crv)],160),it([Us(new re(Uint8Array.from([4]),z(s.x??"","base64url"),z(s.y??"","base64url")))],161)]).subarray()}function Al(s){if(s==="P-256")return El;if(s==="P-384")return Sl;if(s==="P-521")return _l;throw new $(`Invalid curve ${s}`)}var Kt=class{type="ECDSA";jwk;_raw;constructor(e){this.jwk=e}get raw(){return this._raw==null&&(this._raw=so(this.jwk)),this._raw}toMultihash(){return Le.digest(Ke(this))}toCID(){return ae.createV1(114,this.toMultihash())}toString(){return te.encode(this.toMultihash().bytes).substring(1)}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:Ie(this.raw,e.raw)}async verify(e,t,r){return eo(this.jwk,t,e,r)}};function yt(s){return s instanceof Uint8Array||ArrayBuffer.isView(s)&&s.constructor.name==="Uint8Array"}function Fe(s,e=""){if(!Number.isSafeInteger(s)||s<0){let t=e&&`"${e}" `;throw new Error(`${t}expected integer >= 0, got ${s}`)}}function K(s,e,t=""){let r=yt(s),n=s?.length,i=e!==void 0;if(!r||i&&n!==e){let o=t&&`"${t}" `,a=i?` of length ${e}`:"",c=r?`length=${n}`:`type=${typeof s}`;throw new Error(o+"expected Uint8Array"+a+", got "+c)}return s}function Ks(s){if(typeof s!="function"||typeof s.create!="function")throw new Error("Hash must wrapped by utils.createHasher");Fe(s.outputLen),Fe(s.blockLen)}function Ft(s,e=!0){if(s.destroyed)throw new Error("Hash instance has been destroyed");if(e&&s.finished)throw new Error("Hash#digest() has already been called")}function no(s,e){K(s,void 0,"digestInto() output");let t=e.outputLen;if(s.length<t)throw new Error('"digestInto() output" expected to be of length >='+t)}function je(...s){for(let e=0;e<s.length;e++)s[e].fill(0)}function Fs(s){return new DataView(s.buffer,s.byteOffset,s.byteLength)}function Be(s,e){return s<<32-e|s>>>e}var io=typeof Uint8Array.from([]).toHex=="function"&&typeof Uint8Array.fromHex=="function",Ml=Array.from({length:256},(s,e)=>e.toString(16).padStart(2,"0"));function Ye(s){if(K(s),io)return s.toHex();let e="";for(let t=0;t<s.length;t++)e+=Ml[s[t]];return e}var Ze={_0:48,_9:57,A:65,F:70,a:97,f:102};function ro(s){if(s>=Ze._0&&s<=Ze._9)return s-Ze._0;if(s>=Ze.A&&s<=Ze.F)return s-(Ze.A-10);if(s>=Ze.a&&s<=Ze.f)return s-(Ze.a-10)}function Xe(s){if(typeof s!="string")throw new Error("hex string expected, got "+typeof s);if(io)return Uint8Array.fromHex(s);let e=s.length,t=e/2;if(e%2)throw new Error("hex string expected, got unpadded hex of length "+e);let r=new Uint8Array(t);for(let n=0,i=0;n<t;n++,i+=2){let o=ro(s.charCodeAt(i)),a=ro(s.charCodeAt(i+1));if(o===void 0||a===void 0){let c=s[i]+s[i+1];throw new Error('hex string expected, got non-hex character "'+c+'" at index '+i)}r[n]=o*16+a}return r}function De(...s){let e=0;for(let r=0;r<s.length;r++){let n=s[r];K(n),e+=n.length}let t=new Uint8Array(e);for(let r=0,n=0;r<s.length;r++){let i=s[r];t.set(i,n),n+=i.length}return t}function sn(s,e={}){let t=(n,i)=>s(i).update(n).digest(),r=s(void 0);return t.outputLen=r.outputLen,t.blockLen=r.blockLen,t.create=n=>s(n),Object.assign(t,e),Object.freeze(t)}function ot(s=32){let e=typeof globalThis=="object"?globalThis.crypto:null;if(typeof e?.getRandomValues!="function")throw new Error("crypto.getRandomValues must be defined");return e.getRandomValues(new Uint8Array(s))}var rn=s=>({oid:Uint8Array.from([6,9,96,134,72,1,101,3,4,2,s])});function oo(s,e,t){return s&e^~s&t}function ao(s,e,t){return s&e^s&t^e&t}var hs=class{blockLen;outputLen;padOffset;isLE;buffer;view;finished=!1;length=0;pos=0;destroyed=!1;constructor(e,t,r,n){this.blockLen=e,this.outputLen=t,this.padOffset=r,this.isLE=n,this.buffer=new Uint8Array(e),this.view=Fs(this.buffer)}update(e){Ft(this),K(e);let{view:t,buffer:r,blockLen:n}=this,i=e.length;for(let o=0;o<i;){let a=Math.min(n-this.pos,i-o);if(a===n){let c=Fs(e);for(;n<=i-o;o+=n)this.process(c,o);continue}r.set(e.subarray(o,o+a),this.pos),this.pos+=a,o+=a,this.pos===n&&(this.process(t,0),this.pos=0)}return this.length+=e.length,this.roundClean(),this}digestInto(e){Ft(this),no(e,this),this.finished=!0;let{buffer:t,view:r,blockLen:n,isLE:i}=this,{pos:o}=this;t[o++]=128,je(this.buffer.subarray(o)),this.padOffset>n-o&&(this.process(r,0),o=0);for(let m=o;m<n;m++)t[m]=0;r.setBigUint64(n-8,BigInt(this.length*8),i),this.process(r,0);let a=Fs(e),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen must be aligned to 32bit");let f=c/4,p=this.get();if(f>p.length)throw new Error("_sha2: outputLen bigger than state");for(let m=0;m<f;m++)a.setUint32(4*m,p[m],i)}digest(){let{buffer:e,outputLen:t}=this;this.digestInto(e);let r=e.slice(0,t);return this.destroy(),r}_cloneInto(e){e||=new this.constructor,e.set(...this.get());let{blockLen:t,buffer:r,length:n,finished:i,destroyed:o,pos:a}=this;return e.destroyed=o,e.finished=i,e.length=n,e.pos=a,n%t&&e.buffer.set(r),e}clone(){return this._cloneInto()}},Je=Uint32Array.from([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]);var ce=Uint32Array.from([1779033703,4089235720,3144134277,2227873595,1013904242,4271175723,2773480762,1595750129,1359893119,2917565137,2600822924,725511199,528734635,4215389547,1541459225,327033209]);var Gs=BigInt(4294967295),co=BigInt(32);function Pl(s,e=!1){return e?{h:Number(s&Gs),l:Number(s>>co&Gs)}:{h:Number(s>>co&Gs)|0,l:Number(s&Gs)|0}}function lo(s,e=!1){let t=s.length,r=new Uint32Array(t),n=new Uint32Array(t);for(let i=0;i<t;i++){let{h:o,l:a}=Pl(s[i],e);[r[i],n[i]]=[o,a]}return[r,n]}var nn=(s,e,t)=>s>>>t,on=(s,e,t)=>s<<32-t|e>>>t,wt=(s,e,t)=>s>>>t|e<<32-t,xt=(s,e,t)=>s<<32-t|e>>>t,fs=(s,e,t)=>s<<64-t|e>>>t-32,ds=(s,e,t)=>s>>>t-32|e<<64-t;function Ge(s,e,t,r){let n=(e>>>0)+(r>>>0);return{h:s+t+(n/2**32|0)|0,l:n|0}}var uo=(s,e,t)=>(s>>>0)+(e>>>0)+(t>>>0),ho=(s,e,t,r)=>e+t+r+(s/2**32|0)|0,fo=(s,e,t,r)=>(s>>>0)+(e>>>0)+(t>>>0)+(r>>>0),po=(s,e,t,r,n)=>e+t+r+n+(s/2**32|0)|0,mo=(s,e,t,r,n)=>(s>>>0)+(e>>>0)+(t>>>0)+(r>>>0)+(n>>>0),go=(s,e,t,r,n,i)=>e+t+r+n+i+(s/2**32|0)|0;var Ll=Uint32Array.from([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]),at=new Uint32Array(64),an=class extends hs{constructor(e){super(64,e,8,!1)}get(){let{A:e,B:t,C:r,D:n,E:i,F:o,G:a,H:c}=this;return[e,t,r,n,i,o,a,c]}set(e,t,r,n,i,o,a,c){this.A=e|0,this.B=t|0,this.C=r|0,this.D=n|0,this.E=i|0,this.F=o|0,this.G=a|0,this.H=c|0}process(e,t){for(let m=0;m<16;m++,t+=4)at[m]=e.getUint32(t,!1);for(let m=16;m<64;m++){let _=at[m-15],v=at[m-2],u=Be(_,7)^Be(_,18)^_>>>3,g=Be(v,17)^Be(v,19)^v>>>10;at[m]=g+at[m-7]+u+at[m-16]|0}let{A:r,B:n,C:i,D:o,E:a,F:c,G:f,H:p}=this;for(let m=0;m<64;m++){let _=Be(a,6)^Be(a,11)^Be(a,25),v=p+_+oo(a,c,f)+Ll[m]+at[m]|0,g=(Be(r,2)^Be(r,13)^Be(r,22))+ao(r,n,i)|0;p=f,f=c,c=a,a=o+v|0,o=i,i=n,n=r,r=v+g|0}r=r+this.A|0,n=n+this.B|0,i=i+this.C|0,o=o+this.D|0,a=a+this.E|0,c=c+this.F|0,f=f+this.G|0,p=p+this.H|0,this.set(r,n,i,o,a,c,f,p)}roundClean(){je(at)}destroy(){this.set(0,0,0,0,0,0,0,0),je(this.buffer)}},cn=class extends an{A=Je[0]|0;B=Je[1]|0;C=Je[2]|0;D=Je[3]|0;E=Je[4]|0;F=Je[5]|0;G=Je[6]|0;H=Je[7]|0;constructor(){super(32)}};var bo=lo(["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(s=>BigInt(s))),Bl=bo[0],Rl=bo[1],ct=new Uint32Array(80),lt=new Uint32Array(80),ln=class extends hs{constructor(e){super(128,e,16,!1)}get(){let{Ah:e,Al:t,Bh:r,Bl:n,Ch:i,Cl:o,Dh:a,Dl:c,Eh:f,El:p,Fh:m,Fl:_,Gh:v,Gl:u,Hh:g,Hl:w}=this;return[e,t,r,n,i,o,a,c,f,p,m,_,v,u,g,w]}set(e,t,r,n,i,o,a,c,f,p,m,_,v,u,g,w){this.Ah=e|0,this.Al=t|0,this.Bh=r|0,this.Bl=n|0,this.Ch=i|0,this.Cl=o|0,this.Dh=a|0,this.Dl=c|0,this.Eh=f|0,this.El=p|0,this.Fh=m|0,this.Fl=_|0,this.Gh=v|0,this.Gl=u|0,this.Hh=g|0,this.Hl=w|0}process(e,t){for(let l=0;l<16;l++,t+=4)ct[l]=e.getUint32(t),lt[l]=e.getUint32(t+=4);for(let l=16;l<80;l++){let h=ct[l-15]|0,d=lt[l-15]|0,b=wt(h,d,1)^wt(h,d,8)^nn(h,d,7),E=xt(h,d,1)^xt(h,d,8)^on(h,d,7),x=ct[l-2]|0,S=lt[l-2]|0,P=wt(x,S,19)^fs(x,S,61)^nn(x,S,6),O=xt(x,S,19)^ds(x,S,61)^on(x,S,6),R=fo(E,O,lt[l-7],lt[l-16]),D=po(R,b,P,ct[l-7],ct[l-16]);ct[l]=D|0,lt[l]=R|0}let{Ah:r,Al:n,Bh:i,Bl:o,Ch:a,Cl:c,Dh:f,Dl:p,Eh:m,El:_,Fh:v,Fl:u,Gh:g,Gl:w,Hh:y,Hl:I}=this;for(let l=0;l<80;l++){let h=wt(m,_,14)^wt(m,_,18)^fs(m,_,41),d=xt(m,_,14)^xt(m,_,18)^ds(m,_,41),b=m&v^~m&g,E=_&u^~_&w,x=mo(I,d,E,Rl[l],lt[l]),S=go(x,y,h,b,Bl[l],ct[l]),P=x|0,O=wt(r,n,28)^fs(r,n,34)^fs(r,n,39),R=xt(r,n,28)^ds(r,n,34)^ds(r,n,39),D=r&i^r&a^i&a,A=n&o^n&c^o&c;y=g|0,I=w|0,g=v|0,w=u|0,v=m|0,u=_|0,{h:m,l:_}=Ge(f|0,p|0,S|0,P|0),f=a|0,p=c|0,a=i|0,c=o|0,i=r|0,o=n|0;let T=uo(P,R,A);r=ho(T,S,O,D),n=T|0}({h:r,l:n}=Ge(this.Ah|0,this.Al|0,r|0,n|0)),{h:i,l:o}=Ge(this.Bh|0,this.Bl|0,i|0,o|0),{h:a,l:c}=Ge(this.Ch|0,this.Cl|0,a|0,c|0),{h:f,l:p}=Ge(this.Dh|0,this.Dl|0,f|0,p|0),{h:m,l:_}=Ge(this.Eh|0,this.El|0,m|0,_|0),{h:v,l:u}=Ge(this.Fh|0,this.Fl|0,v|0,u|0),{h:g,l:w}=Ge(this.Gh|0,this.Gl|0,g|0,w|0),{h:y,l:I}=Ge(this.Hh|0,this.Hl|0,y|0,I|0),this.set(r,n,i,o,a,c,f,p,m,_,v,u,g,w,y,I)}roundClean(){je(ct,lt)}destroy(){je(this.buffer),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}},un=class extends ln{Ah=ce[0]|0;Al=ce[1]|0;Bh=ce[2]|0;Bl=ce[3]|0;Ch=ce[4]|0;Cl=ce[5]|0;Dh=ce[6]|0;Dl=ce[7]|0;Eh=ce[8]|0;El=ce[9]|0;Fh=ce[10]|0;Fl=ce[11]|0;Gh=ce[12]|0;Gl=ce[13]|0;Hh=ce[14]|0;Hl=ce[15]|0;constructor(){super(64)}};var Gt=sn(()=>new cn,rn(1));var yo=sn(()=>new un,rn(3));var fn=BigInt(0),hn=BigInt(1);function Qe(s,e=""){if(typeof s!="boolean"){let t=e&&`"${e}" `;throw new Error(t+"expected boolean, got type="+typeof s)}return s}function wo(s){if(typeof s=="bigint"){if(!Hs(s))throw new Error("positive bigint expected, got "+s)}else Fe(s);return s}function ps(s){let e=wo(s).toString(16);return e.length&1?"0"+e:e}function xo(s){if(typeof s!="string")throw new Error("hex string expected, got "+typeof s);return s===""?fn:BigInt("0x"+s)}function Ht(s){return xo(Ye(s))}function vt(s){return xo(Ye(zs(K(s)).reverse()))}function qs(s,e){Fe(e),s=wo(s);let t=Xe(s.toString(16).padStart(e*2,"0"));if(t.length!==e)throw new Error("number too large");return t}function dn(s,e){return qs(s,e).reverse()}function zs(s){return Uint8Array.from(s)}var Hs=s=>typeof s=="bigint"&&fn<=s;function Cl(s,e,t){return Hs(s)&&Hs(e)&&Hs(t)&&e<=s&&s<t}function ms(s,e,t,r){if(!Cl(e,t,r))throw new Error("expected valid "+s+": "+t+" <= n < "+r+", got "+e)}function pn(s){let e;for(e=0;s>fn;s>>=hn,e+=1);return e}var gs=s=>(hn<<BigInt(s))-hn;function vo(s,e,t){if(Fe(s,"hashLen"),Fe(e,"qByteLen"),typeof t!="function")throw new Error("hmacFn must be a function");let r=w=>new Uint8Array(w),n=Uint8Array.of(),i=Uint8Array.of(0),o=Uint8Array.of(1),a=1e3,c=r(s),f=r(s),p=0,m=()=>{c.fill(1),f.fill(0),p=0},_=(...w)=>t(f,De(c,...w)),v=(w=n)=>{f=_(i,w),c=_(),w.length!==0&&(f=_(o,w),c=_())},u=()=>{if(p++>=a)throw new Error("drbg: tried max amount of iterations");let w=0,y=[];for(;w<e;){c=_();let I=c.slice();y.push(I),w+=c.length}return De(...y)};return(w,y)=>{m(),v(w);let I;for(;!(I=y(u()));)v();return m(),I}}function ut(s,e={},t={}){if(!s||typeof s!="object")throw new Error("expected valid options object");function r(i,o,a){let c=s[i];if(a&&c===void 0)return;let f=typeof c;if(f!==o||c===null)throw new Error(`param "${i}" is invalid: expected ${o}, got ${f}`)}let n=(i,o)=>Object.entries(i).forEach(([a,c])=>r(a,c,o));n(e,!1),n(t,!0)}function qt(s){let e=new WeakMap;return(t,...r)=>{let n=e.get(t);if(n!==void 0)return n;let i=s(t,...r);return e.set(t,i),i}}var ge=BigInt(0),ne=BigInt(1),Et=BigInt(2),_o=BigInt(3),Io=BigInt(4),To=BigInt(5),Nl=BigInt(7),Do=BigInt(8),Ol=BigInt(9),Ao=BigInt(16);function se(s,e){let t=s%e;return t>=ge?t:e+t}function Z(s,e,t){let r=s;for(;e-- >ge;)r*=r,r%=t;return r}function Eo(s,e){if(s===ge)throw new Error("invert: expected non-zero number");if(e<=ge)throw new Error("invert: expected positive modulus, got "+e);let t=se(s,e),r=e,n=ge,i=ne,o=ne,a=ge;for(;t!==ge;){let f=r/t,p=r%t,m=n-o*f,_=i-a*f;r=t,t=p,n=o,i=a,o=m,a=_}if(r!==ne)throw new Error("invert: does not exist");return se(n,e)}function gn(s,e,t){if(!s.eql(s.sqr(e),t))throw new Error("Cannot find square root")}function Mo(s,e){let t=(s.ORDER+ne)/Io,r=s.pow(e,t);return gn(s,r,e),r}function Ul(s,e){let t=(s.ORDER-To)/Do,r=s.mul(e,Et),n=s.pow(r,t),i=s.mul(e,n),o=s.mul(s.mul(i,Et),n),a=s.mul(i,s.sub(o,s.ONE));return gn(s,a,e),a}function Kl(s){let e=zt(s),t=Po(s),r=t(e,e.neg(e.ONE)),n=t(e,r),i=t(e,e.neg(r)),o=(s+Nl)/Ao;return(a,c)=>{let f=a.pow(c,o),p=a.mul(f,r),m=a.mul(f,n),_=a.mul(f,i),v=a.eql(a.sqr(p),c),u=a.eql(a.sqr(m),c);f=a.cmov(f,p,v),p=a.cmov(_,m,u);let g=a.eql(a.sqr(p),c),w=a.cmov(f,p,g);return gn(a,w,c),w}}function Po(s){if(s<_o)throw new Error("sqrt is not defined for small field");let e=s-ne,t=0;for(;e%Et===ge;)e/=Et,t++;let r=Et,n=zt(s);for(;So(n,r)===1;)if(r++>1e3)throw new Error("Cannot find square root: probably non-prime P");if(t===1)return Mo;let i=n.pow(r,e),o=(e+ne)/Et;return function(c,f){if(c.is0(f))return f;if(So(c,f)!==1)throw new Error("Cannot find square root");let p=t,m=c.mul(c.ONE,i),_=c.pow(f,e),v=c.pow(f,o);for(;!c.eql(_,c.ONE);){if(c.is0(_))return c.ZERO;let u=1,g=c.sqr(_);for(;!c.eql(g,c.ONE);)if(u++,g=c.sqr(g),u===p)throw new Error("Cannot find square root");let w=ne<<BigInt(p-u-1),y=c.pow(m,w);p=u,m=c.sqr(y),_=c.mul(_,m),v=c.mul(v,y)}return v}}function Fl(s){return s%Io===_o?Mo:s%Do===To?Ul:s%Ao===Ol?Kl(s):Po(s)}var ko=(s,e)=>(se(s,e)&ne)===ne,Gl=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function bn(s){let e={ORDER:"bigint",BYTES:"number",BITS:"number"},t=Gl.reduce((r,n)=>(r[n]="function",r),e);return ut(s,t),s}function Hl(s,e,t){if(t<ge)throw new Error("invalid exponent, negatives unsupported");if(t===ge)return s.ONE;if(t===ne)return e;let r=s.ONE,n=e;for(;t>ge;)t&ne&&(r=s.mul(r,n)),n=s.sqr(n),t>>=ne;return r}function bs(s,e,t=!1){let r=new Array(e.length).fill(t?s.ZERO:void 0),n=e.reduce((o,a,c)=>s.is0(a)?o:(r[c]=o,s.mul(o,a)),s.ONE),i=s.inv(n);return e.reduceRight((o,a,c)=>s.is0(a)?o:(r[c]=s.mul(o,r[c]),s.mul(o,a)),i),r}function So(s,e){let t=(s.ORDER-ne)/Et,r=s.pow(e,t),n=s.eql(r,s.ONE),i=s.eql(r,s.ZERO),o=s.eql(r,s.neg(s.ONE));if(!n&&!i&&!o)throw new Error("invalid Legendre symbol result");return n?1:i?0:-1}function ql(s,e){e!==void 0&&Fe(e);let t=e!==void 0?e:s.toString(2).length,r=Math.ceil(t/8);return{nBitLength:t,nByteLength:r}}var mn=class{ORDER;BITS;BYTES;isLE;ZERO=ge;ONE=ne;_lengths;_sqrt;_mod;constructor(e,t={}){if(e<=ge)throw new Error("invalid field: expected ORDER > 0, got "+e);let r;this.isLE=!1,t!=null&&typeof t=="object"&&(typeof t.BITS=="number"&&(r=t.BITS),typeof t.sqrt=="function"&&(this.sqrt=t.sqrt),typeof t.isLE=="boolean"&&(this.isLE=t.isLE),t.allowedLengths&&(this._lengths=t.allowedLengths?.slice()),typeof t.modFromBytes=="boolean"&&(this._mod=t.modFromBytes));let{nBitLength:n,nByteLength:i}=ql(e,r);if(i>2048)throw new Error("invalid field: expected ORDER of <= 2048 bytes");this.ORDER=e,this.BITS=n,this.BYTES=i,this._sqrt=void 0,Object.preventExtensions(this)}create(e){return se(e,this.ORDER)}isValid(e){if(typeof e!="bigint")throw new Error("invalid field element: expected bigint, got "+typeof e);return ge<=e&&e<this.ORDER}is0(e){return e===ge}isValidNot0(e){return!this.is0(e)&&this.isValid(e)}isOdd(e){return(e&ne)===ne}neg(e){return se(-e,this.ORDER)}eql(e,t){return e===t}sqr(e){return se(e*e,this.ORDER)}add(e,t){return se(e+t,this.ORDER)}sub(e,t){return se(e-t,this.ORDER)}mul(e,t){return se(e*t,this.ORDER)}pow(e,t){return Hl(this,e,t)}div(e,t){return se(e*Eo(t,this.ORDER),this.ORDER)}sqrN(e){return e*e}addN(e,t){return e+t}subN(e,t){return e-t}mulN(e,t){return e*t}inv(e){return Eo(e,this.ORDER)}sqrt(e){return this._sqrt||(this._sqrt=Fl(this.ORDER)),this._sqrt(this,e)}toBytes(e){return this.isLE?dn(e,this.BYTES):qs(e,this.BYTES)}fromBytes(e,t=!1){K(e);let{_lengths:r,BYTES:n,isLE:i,ORDER:o,_mod:a}=this;if(r){if(!r.includes(e.length)||e.length>n)throw new Error("Field.fromBytes: expected "+r+" bytes, got "+e.length);let f=new Uint8Array(n);f.set(e,i?0:f.length-e.length),e=f}if(e.length!==n)throw new Error("Field.fromBytes: expected "+n+" bytes, got "+e.length);let c=i?vt(e):Ht(e);if(a&&(c=se(c,o)),!t&&!this.isValid(c))throw new Error("invalid field element: outside of range 0..ORDER");return c}invertBatch(e){return bs(this,e)}cmov(e,t,r){return r?t:e}};function zt(s,e={}){return new mn(s,e)}function Lo(s){if(typeof s!="bigint")throw new Error("field order must be bigint");let e=s.toString(2).length;return Math.ceil(e/8)}function yn(s){let e=Lo(s);return e+Math.ceil(e/2)}function wn(s,e,t=!1){K(s);let r=s.length,n=Lo(e),i=yn(e);if(r<16||r<i||r>1024)throw new Error("expected "+i+"-1024 bytes of input, got "+r);let o=t?vt(s):Ht(s),a=se(o,e-ne)+ne;return t?dn(a,n):qs(a,n)}var Vt=BigInt(0),St=BigInt(1);function ys(s,e){let t=e.negate();return s?t:e}function _t(s,e){let t=bs(s.Fp,e.map(r=>r.Z));return e.map((r,n)=>s.fromAffine(r.toAffine(t[n])))}function No(s,e){if(!Number.isSafeInteger(s)||s<=0||s>e)throw new Error("invalid window size, expected [1.."+e+"], got W="+s)}function xn(s,e){No(s,e);let t=Math.ceil(e/s)+1,r=2**(s-1),n=2**s,i=gs(s),o=BigInt(s);return{windows:t,windowSize:r,mask:i,maxNumber:n,shiftBy:o}}function Bo(s,e,t){let{windowSize:r,mask:n,maxNumber:i,shiftBy:o}=t,a=Number(s&n),c=s>>o;a>r&&(a-=i,c+=St);let f=e*r,p=f+Math.abs(a)-1,m=a===0,_=a<0,v=e%2!==0;return{nextN:c,offset:p,isZero:m,isNeg:_,isNegF:v,offsetF:f}}var vn=new WeakMap,Oo=new WeakMap;function En(s){return Oo.get(s)||1}function Ro(s){if(s!==Vt)throw new Error("invalid wNAF")}var Wt=class{BASE;ZERO;Fn;bits;constructor(e,t){this.BASE=e.BASE,this.ZERO=e.ZERO,this.Fn=e.Fn,this.bits=t}_unsafeLadder(e,t,r=this.ZERO){let n=e;for(;t>Vt;)t&St&&(r=r.add(n)),n=n.double(),t>>=St;return r}precomputeWindow(e,t){let{windows:r,windowSize:n}=xn(t,this.bits),i=[],o=e,a=o;for(let c=0;c<r;c++){a=o,i.push(a);for(let f=1;f<n;f++)a=a.add(o),i.push(a);o=a.double()}return i}wNAF(e,t,r){if(!this.Fn.isValid(r))throw new Error("invalid scalar");let n=this.ZERO,i=this.BASE,o=xn(e,this.bits);for(let a=0;a<o.windows;a++){let{nextN:c,offset:f,isZero:p,isNeg:m,isNegF:_,offsetF:v}=Bo(r,a,o);r=c,p?i=i.add(ys(_,t[v])):n=n.add(ys(m,t[f]))}return Ro(r),{p:n,f:i}}wNAFUnsafe(e,t,r,n=this.ZERO){let i=xn(e,this.bits);for(let o=0;o<i.windows&&r!==Vt;o++){let{nextN:a,offset:c,isZero:f,isNeg:p}=Bo(r,o,i);if(r=a,!f){let m=t[c];n=n.add(p?m.negate():m)}}return Ro(r),n}getPrecomputes(e,t,r){let n=vn.get(t);return n||(n=this.precomputeWindow(t,e),e!==1&&(typeof r=="function"&&(n=r(n)),vn.set(t,n))),n}cached(e,t,r){let n=En(e);return this.wNAF(n,this.getPrecomputes(n,e,r),t)}unsafe(e,t,r,n){let i=En(e);return i===1?this._unsafeLadder(e,t,n):this.wNAFUnsafe(i,this.getPrecomputes(i,e,r),t,n)}createCache(e,t){No(t,this.bits),Oo.set(e,t),vn.delete(e)}hasCache(e){return En(e)!==1}};function Uo(s,e,t,r){let n=e,i=s.ZERO,o=s.ZERO;for(;t>Vt||r>Vt;)t&St&&(i=i.add(n)),r&St&&(o=o.add(n)),n=n.double(),t>>=St,r>>=St;return{p1:i,p2:o}}function Co(s,e,t){if(e){if(e.ORDER!==s)throw new Error("Field.ORDER must match order: Fp == p, Fn == n");return bn(e),e}else return zt(s,{isLE:t})}function Vs(s,e,t={},r){if(r===void 0&&(r=s==="edwards"),!e||typeof e!="object")throw new Error(`expected valid ${s} CURVE object`);for(let c of["p","n","h"]){let f=e[c];if(!(typeof f=="bigint"&&f>Vt))throw new Error(`CURVE.${c} must be positive bigint`)}let n=Co(e.p,t.Fp,r),i=Co(e.n,t.Fn,r),a=["Gx","Gy","a",s==="weierstrass"?"b":"d"];for(let c of a)if(!n.isValid(e[c]))throw new Error(`CURVE.${c} must be valid field element of CURVE.Fp`);return e=Object.freeze(Object.assign({},e)),{CURVE:e,Fp:n,Fn:i}}function Ws(s,e){return function(r){let n=s(r);return{secretKey:n,publicKey:e(n)}}}var ht=BigInt(0),ie=BigInt(1),Sn=BigInt(2),zl=BigInt(8);function Vl(s,e,t,r){let n=s.sqr(t),i=s.sqr(r),o=s.add(s.mul(e.a,n),i),a=s.add(s.ONE,s.mul(e.d,s.mul(n,i)));return s.eql(o,a)}function Ko(s,e={}){let t=Vs("edwards",s,e,e.FpFnLE),{Fp:r,Fn:n}=t,i=t.CURVE,{h:o}=i;ut(e,{},{uvRatio:"function"});let a=Sn<<BigInt(n.BYTES*8)-ie,c=w=>r.create(w),f=e.uvRatio||((w,y)=>{try{return{isValid:!0,value:r.sqrt(r.div(w,y))}}catch{return{isValid:!1,value:ht}}});if(!Vl(r,i,i.Gx,i.Gy))throw new Error("bad curve params: generator point");function p(w,y,I=!1){let l=I?ie:ht;return ms("coordinate "+w,y,l,a),y}function m(w){if(!(w instanceof u))throw new Error("EdwardsPoint expected")}let _=qt((w,y)=>{let{X:I,Y:l,Z:h}=w,d=w.is0();y==null&&(y=d?zl:r.inv(h));let b=c(I*y),E=c(l*y),x=r.mul(h,y);if(d)return{x:ht,y:ie};if(x!==ie)throw new Error("invZ was invalid");return{x:b,y:E}}),v=qt(w=>{let{a:y,d:I}=i;if(w.is0())throw new Error("bad point: ZERO");let{X:l,Y:h,Z:d,T:b}=w,E=c(l*l),x=c(h*h),S=c(d*d),P=c(S*S),O=c(E*y),R=c(S*c(O+x)),D=c(P+c(I*c(E*x)));if(R!==D)throw new Error("bad point: equation left != right (1)");let A=c(l*h),T=c(d*b);if(A!==T)throw new Error("bad point: equation left != right (2)");return!0});class u{static BASE=new u(i.Gx,i.Gy,ie,c(i.Gx*i.Gy));static ZERO=new u(ht,ie,ie,ht);static Fp=r;static Fn=n;X;Y;Z;T;constructor(y,I,l,h){this.X=p("x",y),this.Y=p("y",I),this.Z=p("z",l,!0),this.T=p("t",h),Object.freeze(this)}static CURVE(){return i}static fromAffine(y){if(y instanceof u)throw new Error("extended point not allowed");let{x:I,y:l}=y||{};return p("x",I),p("y",l),new u(I,l,ie,c(I*l))}static fromBytes(y,I=!1){let l=r.BYTES,{a:h,d}=i;y=zs(K(y,l,"point")),Qe(I,"zip215");let b=zs(y),E=y[l-1];b[l-1]=E&-129;let x=vt(b),S=I?a:r.ORDER;ms("point.y",x,ht,S);let P=c(x*x),O=c(P-ie),R=c(d*P-h),{isValid:D,value:A}=f(O,R);if(!D)throw new Error("bad point: invalid y coordinate");let T=(A&ie)===ie,M=(E&128)!==0;if(!I&&A===ht&&M)throw new Error("bad point: x=0 and x_0=1");return M!==T&&(A=c(-A)),u.fromAffine({x:A,y:x})}static fromHex(y,I=!1){return u.fromBytes(Xe(y),I)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}precompute(y=8,I=!0){return g.createCache(this,y),I||this.multiply(Sn),this}assertValidity(){v(this)}equals(y){m(y);let{X:I,Y:l,Z:h}=this,{X:d,Y:b,Z:E}=y,x=c(I*E),S=c(d*h),P=c(l*E),O=c(b*h);return x===S&&P===O}is0(){return this.equals(u.ZERO)}negate(){return new u(c(-this.X),this.Y,this.Z,c(-this.T))}double(){let{a:y}=i,{X:I,Y:l,Z:h}=this,d=c(I*I),b=c(l*l),E=c(Sn*c(h*h)),x=c(y*d),S=I+l,P=c(c(S*S)-d-b),O=x+b,R=O-E,D=x-b,A=c(P*R),T=c(O*D),M=c(P*D),k=c(R*O);return new u(A,T,k,M)}add(y){m(y);let{a:I,d:l}=i,{X:h,Y:d,Z:b,T:E}=this,{X:x,Y:S,Z:P,T:O}=y,R=c(h*x),D=c(d*S),A=c(E*l*O),T=c(b*P),M=c((h+d)*(x+S)-R-D),k=T-A,B=T+A,C=c(D-I*R),L=c(M*k),N=c(B*C),U=c(M*C),X=c(k*B);return new u(L,N,X,U)}subtract(y){return this.add(y.negate())}multiply(y){if(!n.isValidNot0(y))throw new Error("invalid scalar: expected 1 <= sc < curve.n");let{p:I,f:l}=g.cached(this,y,h=>_t(u,h));return _t(u,[I,l])[0]}multiplyUnsafe(y,I=u.ZERO){if(!n.isValid(y))throw new Error("invalid scalar: expected 0 <= sc < curve.n");return y===ht?u.ZERO:this.is0()||y===ie?this:g.unsafe(this,y,l=>_t(u,l),I)}isSmallOrder(){return this.multiplyUnsafe(o).is0()}isTorsionFree(){return g.unsafe(this,i.n).is0()}toAffine(y){return _(this,y)}clearCofactor(){return o===ie?this:this.multiplyUnsafe(o)}toBytes(){let{x:y,y:I}=this.toAffine(),l=r.toBytes(I);return l[l.length-1]|=y&ie?128:0,l}toHex(){return Ye(this.toBytes())}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}}let g=new Wt(u,n.BITS);return u.BASE.precompute(8),u}function Fo(s,e,t={}){if(typeof e!="function")throw new Error('"hash" function param is required');ut(t,{},{adjustScalarBytes:"function",randomBytes:"function",domain:"function",prehash:"function",mapToCurve:"function"});let{prehash:r}=t,{BASE:n,Fp:i,Fn:o}=s,a=t.randomBytes||ot,c=t.adjustScalarBytes||(x=>x),f=t.domain||((x,S,P)=>{if(Qe(P,"phflag"),S.length||P)throw new Error("Contexts/pre-hash are not supported");return x});function p(x){return o.create(vt(x))}function m(x){let S=l.secretKey;K(x,l.secretKey,"secretKey");let P=K(e(x),2*S,"hashedSecretKey"),O=c(P.slice(0,S)),R=P.slice(S,2*S),D=p(O);return{head:O,prefix:R,scalar:D}}function _(x){let{head:S,prefix:P,scalar:O}=m(x),R=n.multiply(O),D=R.toBytes();return{head:S,prefix:P,scalar:O,point:R,pointBytes:D}}function v(x){return _(x).pointBytes}function u(x=Uint8Array.of(),...S){let P=De(...S);return p(e(f(P,K(x,void 0,"context"),!!r)))}function g(x,S,P={}){x=K(x,void 0,"message"),r&&(x=r(x));let{prefix:O,scalar:R,pointBytes:D}=_(S),A=u(P.context,O,x),T=n.multiply(A).toBytes(),M=u(P.context,T,D,x),k=o.create(A+M*R);if(!o.isValid(k))throw new Error("sign failed: invalid s");let B=De(T,o.toBytes(k));return K(B,l.signature,"result")}let w={zip215:!0};function y(x,S,P,O=w){let{context:R,zip215:D}=O,A=l.signature;x=K(x,A,"signature"),S=K(S,void 0,"message"),P=K(P,l.publicKey,"publicKey"),D!==void 0&&Qe(D,"zip215"),r&&(S=r(S));let T=A/2,M=x.subarray(0,T),k=vt(x.subarray(T,A)),B,C,L;try{B=s.fromBytes(P,D),C=s.fromBytes(M,D),L=n.multiplyUnsafe(k)}catch{return!1}if(!D&&B.isSmallOrder())return!1;let N=u(R,C.toBytes(),B.toBytes(),S);return C.add(B.multiplyUnsafe(N)).subtract(L).clearCofactor().is0()}let I=i.BYTES,l={secretKey:I,publicKey:I,signature:2*I,seed:I};function h(x=a(l.seed)){return K(x,l.seed,"seed")}function d(x){return yt(x)&&x.length===o.BYTES}function b(x,S){try{return!!s.fromBytes(x,S)}catch{return!1}}let E={getExtendedPublicKey:_,randomSecretKey:h,isValidSecretKey:d,isValidPublicKey:b,toMontgomery(x){let{y:S}=s.fromBytes(x),P=l.publicKey,O=P===32;if(!O&&P!==57)throw new Error("only defined for 25519 and 448");let R=O?i.div(ie+S,ie-S):i.div(S-ie,S+ie);return i.toBytes(R)},toMontgomerySecret(x){let S=l.secretKey;K(x,S);let P=e(x.subarray(0,S));return c(P).subarray(0,S)}};return Object.freeze({keygen:Ws(h,v),getPublicKey:v,sign:g,verify:y,utils:E,Point:s,lengths:l})}var Wl=BigInt(1),Go=BigInt(2);var $l=BigInt(5),Zl=BigInt(8),_n=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffed"),jl={p:_n,n:BigInt("0x1000000000000000000000000000000014def9dea2f79cd65812631a5cf5d3ed"),h:Zl,a:BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffec"),d:BigInt("0x52036cee2b6ffe738cc740797779e89800700a4d4141d8ab75eb4dca135978a3"),Gx:BigInt("0x216936d3cd6e53fec0a4e231fdd6dc5c692cc7609525a7b2c9562d608f25d51a"),Gy:BigInt("0x6666666666666666666666666666666666666666666666666666666666666658")};function Yl(s){let e=BigInt(10),t=BigInt(20),r=BigInt(40),n=BigInt(80),i=_n,a=s*s%i*s%i,c=Z(a,Go,i)*a%i,f=Z(c,Wl,i)*s%i,p=Z(f,$l,i)*f%i,m=Z(p,e,i)*p%i,_=Z(m,t,i)*m%i,v=Z(_,r,i)*_%i,u=Z(v,n,i)*v%i,g=Z(u,n,i)*v%i,w=Z(g,e,i)*p%i;return{pow_p_5_8:Z(w,Go,i)*s%i,b2:a}}function Xl(s){return s[0]&=248,s[31]&=127,s[31]|=64,s}var Ho=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752");function Jl(s,e){let t=_n,r=se(e*e*e,t),n=se(r*r*e,t),i=Yl(s*n).pow_p_5_8,o=se(s*r*i,t),a=se(e*o*o,t),c=o,f=se(o*Ho,t),p=a===s,m=a===se(-s,t),_=a===se(-s*Ho,t);return p&&(o=c),(m||_)&&(o=f),ko(o,t)&&(o=se(-o,t)),{isValid:p||m,value:o}}var Ql=Ko(jl,{uvRatio:Jl});function eu(s){return Fo(Ql,yo,Object.assign({adjustScalarBytes:Xl},s))}var qo=eu({});var ws=class extends Error{constructor(e="An error occurred while verifying a message"){super(e),this.name="VerificationError"}},$s=class extends Error{constructor(e="Missing Web Crypto API"){super(e),this.name="WebCryptoMissingError"}};var zo={get(s=globalThis){let e=s.crypto;if(e?.subtle==null)throw new $s("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 e}};var Pe=zo;var Zs=32;var In,tu=(async()=>{try{return await Pe.get().subtle.generateKey({name:"Ed25519"},!0,["sign","verify"]),!0}catch{return!1}})();async function su(s,e,t){if(s.buffer instanceof ArrayBuffer){let r=await Pe.get().subtle.importKey("raw",s.buffer,{name:"Ed25519"},!1,["verify"]);return await Pe.get().subtle.verify({name:"Ed25519"},r,e,t instanceof Uint8Array?t:t.subarray())}throw new TypeError("WebCrypto does not support SharedArrayBuffer for Ed25519 keys")}function ru(s,e,t){return qo.verify(e,t instanceof Uint8Array?t:t.subarray(),s)}async function Vo(s,e,t){return In==null&&(In=await tu),In?su(s,e,t):ru(s,e,t)}function js(s){return s==null?!1:typeof s.then=="function"&&typeof s.catch=="function"&&typeof s.finally=="function"}var Ys=class{type="Ed25519";raw;constructor(e){this.raw=Tn(e,Zs)}toMultihash(){return Le.digest(Ke(this))}toCID(){return ae.createV1(114,this.toMultihash())}toString(){return te.encode(this.toMultihash().bytes).substring(1)}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:Ie(this.raw,e.raw)}verify(e,t,r){r?.signal?.throwIfAborted();let n=Vo(this.raw,t,e);return js(n)?n.then(i=>(r?.signal?.throwIfAborted(),i)):n}};function Dn(s){return s=Tn(s,Zs),new Ys(s)}function Tn(s,e){if(s=Uint8Array.from(s??[]),s.length!==e)throw new $(`Key must be a Uint8Array of length ${e}, got ${s.length}`);return s}var iu=Math.pow(2,7),ou=Math.pow(2,14),au=Math.pow(2,21),An=Math.pow(2,28),Mn=Math.pow(2,35),Pn=Math.pow(2,42),kn=Math.pow(2,49),G=128,he=127;function ke(s){if(s<iu)return 1;if(s<ou)return 2;if(s<au)return 3;if(s<An)return 4;if(s<Mn)return 5;if(s<Pn)return 6;if(s<kn)return 7;if(Number.MAX_SAFE_INTEGER!=null&&s>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function Ln(s,e,t=0){switch(ke(s)){case 8:e[t++]=s&255|G,s/=128;case 7:e[t++]=s&255|G,s/=128;case 6:e[t++]=s&255|G,s/=128;case 5:e[t++]=s&255|G,s/=128;case 4:e[t++]=s&255|G,s>>>=7;case 3:e[t++]=s&255|G,s>>>=7;case 2:e[t++]=s&255|G,s>>>=7;case 1:{e[t++]=s&255,s>>>=7;break}default:throw new Error("unreachable")}return e}function cu(s,e,t=0){switch(ke(s)){case 8:e.set(t++,s&255|G),s/=128;case 7:e.set(t++,s&255|G),s/=128;case 6:e.set(t++,s&255|G),s/=128;case 5:e.set(t++,s&255|G),s/=128;case 4:e.set(t++,s&255|G),s>>>=7;case 3:e.set(t++,s&255|G),s>>>=7;case 2:e.set(t++,s&255|G),s>>>=7;case 1:{e.set(t++,s&255),s>>>=7;break}default:throw new Error("unreachable")}return e}function Bn(s,e){let t=s[e],r=0;if(r+=t&he,t<G||(t=s[e+1],r+=(t&he)<<7,t<G)||(t=s[e+2],r+=(t&he)<<14,t<G)||(t=s[e+3],r+=(t&he)<<21,t<G)||(t=s[e+4],r+=(t&he)*An,t<G)||(t=s[e+5],r+=(t&he)*Mn,t<G)||(t=s[e+6],r+=(t&he)*Pn,t<G)||(t=s[e+7],r+=(t&he)*kn,t<G))return r;throw new RangeError("Could not decode varint")}function lu(s,e){let t=s.get(e),r=0;if(r+=t&he,t<G||(t=s.get(e+1),r+=(t&he)<<7,t<G)||(t=s.get(e+2),r+=(t&he)<<14,t<G)||(t=s.get(e+3),r+=(t&he)<<21,t<G)||(t=s.get(e+4),r+=(t&he)*An,t<G)||(t=s.get(e+5),r+=(t&he)*Mn,t<G)||(t=s.get(e+6),r+=(t&he)*Pn,t<G)||(t=s.get(e+7),r+=(t&he)*kn,t<G))return r;throw new RangeError("Could not decode varint")}function Rn(s,e,t=0){return e==null&&(e=ue(ke(s))),e instanceof Uint8Array?Ln(s,e,t):cu(s,e,t)}function Cn(s,e=0){return s instanceof Uint8Array?Bn(s,e):lu(s,e)}var On=new Float32Array([-0]),ft=new Uint8Array(On.buffer);function $o(s,e,t){On[0]=s,e[t]=ft[0],e[t+1]=ft[1],e[t+2]=ft[2],e[t+3]=ft[3]}function Zo(s,e){return ft[0]=s[e],ft[1]=s[e+1],ft[2]=s[e+2],ft[3]=s[e+3],On[0]}var Un=new Float64Array([-0]),fe=new Uint8Array(Un.buffer);function jo(s,e,t){Un[0]=s,e[t]=fe[0],e[t+1]=fe[1],e[t+2]=fe[2],e[t+3]=fe[3],e[t+4]=fe[4],e[t+5]=fe[5],e[t+6]=fe[6],e[t+7]=fe[7]}function Yo(s,e){return fe[0]=s[e],fe[1]=s[e+1],fe[2]=s[e+2],fe[3]=s[e+3],fe[4]=s[e+4],fe[5]=s[e+5],fe[6]=s[e+6],fe[7]=s[e+7],Un[0]}var uu=BigInt(Number.MAX_SAFE_INTEGER),hu=BigInt(Number.MIN_SAFE_INTEGER),Ae=class s{lo;hi;constructor(e,t){this.lo=e|0,this.hi=t|0}toNumber(e=!1){if(!e&&this.hi>>>31>0){let t=~this.lo+1>>>0,r=~this.hi>>>0;return t===0&&(r=r+1>>>0),-(t+r*4294967296)}return this.lo+this.hi*4294967296}toBigInt(e=!1){if(e)return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n);if(this.hi>>>31){let t=~this.lo+1>>>0,r=~this.hi>>>0;return t===0&&(r=r+1>>>0),-(BigInt(t)+(BigInt(r)<<32n))}return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n)}toString(e=!1){return this.toBigInt(e).toString()}zzEncode(){let e=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^e)>>>0,this.lo=(this.lo<<1^e)>>>0,this}zzDecode(){let e=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^e)>>>0,this.hi=(this.hi>>>1^e)>>>0,this}length(){let e=this.lo,t=(this.lo>>>28|this.hi<<4)>>>0,r=this.hi>>>24;return r===0?t===0?e<16384?e<128?1:2:e<2097152?3:4:t<16384?t<128?5:6:t<2097152?7:8:r<128?9:10}static fromBigInt(e){if(e===0n)return It;if(e<uu&&e>hu)return this.fromNumber(Number(e));let t=e<0n;t&&(e=-e);let r=e>>32n,n=e-(r<<32n);return t&&(r=~r|0n,n=~n|0n,++n>Xo&&(n=0n,++r>Xo&&(r=0n))),new s(Number(n),Number(r))}static fromNumber(e){if(e===0)return It;let t=e<0;t&&(e=-e);let r=e>>>0,n=(e-r)/4294967296>>>0;return t&&(n=~n>>>0,r=~r>>>0,++r>4294967295&&(r=0,++n>4294967295&&(n=0))),new s(r,n)}static from(e){return typeof e=="number"?s.fromNumber(e):typeof e=="bigint"?s.fromBigInt(e):typeof e=="string"?s.fromBigInt(BigInt(e)):e.low!=null||e.high!=null?new s(e.low>>>0,e.high>>>0):It}},It=new Ae(0,0);It.toBigInt=function(){return 0n};It.zzEncode=It.zzDecode=function(){return this};It.length=function(){return 1};var Xo=4294967296n;function Jo(s){let e=0,t=0;for(let r=0;r<s.length;++r)t=s.charCodeAt(r),t<128?e+=1:t<2048?e+=2:(t&64512)===55296&&(s.charCodeAt(r+1)&64512)===56320?(++r,e+=4):e+=3;return e}function Qo(s,e,t){if(t-e<1)return"";let n,i=[],o=0,a;for(;e<t;)a=s[e++],a<128?i[o++]=a:a>191&&a<224?i[o++]=(a&31)<<6|s[e++]&63:a>239&&a<365?(a=((a&7)<<18|(s[e++]&63)<<12|(s[e++]&63)<<6|s[e++]&63)-65536,i[o++]=55296+(a>>10),i[o++]=56320+(a&1023)):i[o++]=(a&15)<<12|(s[e++]&63)<<6|s[e++]&63,o>8191&&((n??(n=[])).push(String.fromCharCode.apply(String,i)),o=0);return n!=null?(o>0&&n.push(String.fromCharCode.apply(String,i.slice(0,o))),n.join("")):String.fromCharCode.apply(String,i.slice(0,o))}function Kn(s,e,t){let r=t,n,i;for(let o=0;o<s.length;++o)n=s.charCodeAt(o),n<128?e[t++]=n:n<2048?(e[t++]=n>>6|192,e[t++]=n&63|128):(n&64512)===55296&&((i=s.charCodeAt(o+1))&64512)===56320?(n=65536+((n&1023)<<10)+(i&1023),++o,e[t++]=n>>18|240,e[t++]=n>>12&63|128,e[t++]=n>>6&63|128,e[t++]=n&63|128):(e[t++]=n>>12|224,e[t++]=n>>6&63|128,e[t++]=n&63|128);return t-r}function Re(s,e){return RangeError(`index out of range: ${s.pos} + ${e??1} > ${s.len}`)}function Xs(s,e){return(s[e-4]|s[e-3]<<8|s[e-2]<<16|s[e-1]<<24)>>>0}var Fn=class{buf;pos;len;_slice=Uint8Array.prototype.subarray;constructor(e){this.buf=e,this.pos=0,this.len=e.length}uint32(){let e=4294967295;if(e=(this.buf[this.pos]&127)>>>0,this.buf[this.pos++]<128||(e=(e|(this.buf[this.pos]&127)<<7)>>>0,this.buf[this.pos++]<128)||(e=(e|(this.buf[this.pos]&127)<<14)>>>0,this.buf[this.pos++]<128)||(e=(e|(this.buf[this.pos]&127)<<21)>>>0,this.buf[this.pos++]<128)||(e=(e|(this.buf[this.pos]&15)<<28)>>>0,this.buf[this.pos++]<128))return e;if((this.pos+=5)>this.len)throw this.pos=this.len,Re(this,10);return e}int32(){return this.uint32()|0}sint32(){let e=this.uint32();return e>>>1^-(e&1)|0}bool(){return this.uint32()!==0}fixed32(){if(this.pos+4>this.len)throw Re(this,4);return Xs(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Re(this,4);return Xs(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Re(this,4);let e=Zo(this.buf,this.pos);return this.pos+=4,e}double(){if(this.pos+8>this.len)throw Re(this,4);let e=Yo(this.buf,this.pos);return this.pos+=8,e}bytes(){let e=this.uint32(),t=this.pos,r=this.pos+e;if(r>this.len)throw Re(this,e);return this.pos+=e,t===r?new Uint8Array(0):this.buf.subarray(t,r)}string(){let e=this.bytes();return Qo(e,0,e.length)}skip(e){if(typeof e=="number"){if(this.pos+e>this.len)throw Re(this,e);this.pos+=e}else do if(this.pos>=this.len)throw Re(this);while((this.buf[this.pos++]&128)!==0);return this}skipType(e){switch(e){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;(e=this.uint32()&7)!==4;)this.skipType(e);break;case 5:this.skip(4);break;default:throw Error(`invalid wire type ${e} at offset ${this.pos}`)}return this}readLongVarint(){let e=new Ae(0,0),t=0;if(this.len-this.pos>4){for(;t<4;++t)if(e.lo=(e.lo|(this.buf[this.pos]&127)<<t*7)>>>0,this.buf[this.pos++]<128)return e;if(e.lo=(e.lo|(this.buf[this.pos]&127)<<28)>>>0,e.hi=(e.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return e;t=0}else{for(;t<3;++t){if(this.pos>=this.len)throw Re(this);if(e.lo=(e.lo|(this.buf[this.pos]&127)<<t*7)>>>0,this.buf[this.pos++]<128)return e}return e.lo=(e.lo|(this.buf[this.pos++]&127)<<t*7)>>>0,e}if(this.len-this.pos>4){for(;t<5;++t)if(e.hi=(e.hi|(this.buf[this.pos]&127)<<t*7+3)>>>0,this.buf[this.pos++]<128)return e}else for(;t<5;++t){if(this.pos>=this.len)throw Re(this);if(e.hi=(e.hi|(this.buf[this.pos]&127)<<t*7+3)>>>0,this.buf[this.pos++]<128)return e}throw Error("invalid varint encoding")}readFixed64(){if(this.pos+8>this.len)throw Re(this,8);let e=Xs(this.buf,this.pos+=4),t=Xs(this.buf,this.pos+=4);return new Ae(e,t)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){let e=Bn(this.buf,this.pos);return this.pos+=ke(e),e}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 xs(s){return new Fn(s instanceof Uint8Array?s:s.subarray())}function be(s,e,t){let r=xs(s);return e.decode(r,void 0,t)}function Gn(s){let e=s??8192,t=e>>>1,r,n=e;return function(o){if(o<1||o>t)return ue(o);n+o>e&&(r=ue(e),n=0);let a=r.subarray(n,n+=o);return(n&7)!==0&&(n=(n|7)+1),a}}var Tt=class{fn;len;next;val;constructor(e,t,r){this.fn=e,this.len=t,this.next=void 0,this.val=r}};function Hn(){}var zn=class{head;tail;len;next;constructor(e){this.head=e.head,this.tail=e.tail,this.len=e.len,this.next=e.states}},fu=Gn();function du(s){return globalThis.Buffer!=null?ue(s):fu(s)}var Es=class{len;head;tail;states;constructor(){this.len=0,this.head=new Tt(Hn,0,0),this.tail=this.head,this.states=null}_push(e,t,r){return this.tail=this.tail.next=new Tt(e,t,r),this.len+=t,this}uint32(e){return this.len+=(this.tail=this.tail.next=new Vn((e=e>>>0)<128?1:e<16384?2:e<2097152?3:e<268435456?4:5,e)).len,this}int32(e){return e<0?this._push(Js,10,Ae.fromNumber(e)):this.uint32(e)}sint32(e){return this.uint32((e<<1^e>>31)>>>0)}uint64(e){let t=Ae.fromBigInt(e);return this._push(Js,t.length(),t)}uint64Number(e){return this._push(Ln,ke(e),e)}uint64String(e){return this.uint64(BigInt(e))}int64(e){return this.uint64(e)}int64Number(e){return this.uint64Number(e)}int64String(e){return this.uint64String(e)}sint64(e){let t=Ae.fromBigInt(e).zzEncode();return this._push(Js,t.length(),t)}sint64Number(e){let t=Ae.fromNumber(e).zzEncode();return this._push(Js,t.length(),t)}sint64String(e){return this.sint64(BigInt(e))}bool(e){return this._push(qn,1,e?1:0)}fixed32(e){return this._push(vs,4,e>>>0)}sfixed32(e){return this.fixed32(e)}fixed64(e){let t=Ae.fromBigInt(e);return this._push(vs,4,t.lo)._push(vs,4,t.hi)}fixed64Number(e){let t=Ae.fromNumber(e);return this._push(vs,4,t.lo)._push(vs,4,t.hi)}fixed64String(e){return this.fixed64(BigInt(e))}sfixed64(e){return this.fixed64(e)}sfixed64Number(e){return this.fixed64Number(e)}sfixed64String(e){return this.fixed64String(e)}float(e){return this._push($o,4,e)}double(e){return this._push(jo,8,e)}bytes(e){let t=e.length>>>0;return t===0?this._push(qn,1,0):this.uint32(t)._push(mu,t,e)}string(e){let t=Jo(e);return t!==0?this.uint32(t)._push(Kn,t,e):this._push(qn,1,0)}fork(){return this.states=new zn(this),this.head=this.tail=new Tt(Hn,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 Tt(Hn,0,0),this.len=0),this}ldelim(){let e=this.head,t=this.tail,r=this.len;return this.reset().uint32(r),r!==0&&(this.tail.next=e.next,this.tail=t,this.len+=r),this}finish(){let e=this.head.next,t=du(this.len),r=0;for(;e!=null;)e.fn(e.val,t,r),r+=e.len,e=e.next;return t}};function qn(s,e,t){e[t]=s&255}function pu(s,e,t){for(;s>127;)e[t++]=s&127|128,s>>>=7;e[t]=s}var Vn=class extends Tt{next;constructor(e,t){super(pu,e,t),this.next=void 0}};function Js(s,e,t){for(;s.hi!==0;)e[t++]=s.lo&127|128,s.lo=(s.lo>>>7|s.hi<<25)>>>0,s.hi>>>=7;for(;s.lo>127;)e[t++]=s.lo&127|128,s.lo=s.lo>>>7;e[t++]=s.lo}function vs(s,e,t){e[t]=s&255,e[t+1]=s>>>8&255,e[t+2]=s>>>16&255,e[t+3]=s>>>24}function mu(s,e,t){e.set(s,t)}globalThis.Buffer!=null&&(Es.prototype.bytes=function(s){let e=s.length>>>0;return this.uint32(e),e>0&&this._push(gu,e,s),this},Es.prototype.string=function(s){let e=globalThis.Buffer.byteLength(s);return this.uint32(e),e>0&&this._push(bu,e,s),this});function gu(s,e,t){e.set(s,t)}function bu(s,e,t){s.length<40?Kn(s,e,t):e.utf8Write!=null?e.utf8Write(s,t):e.set(z(s),t)}function Wn(){return new Es}function ye(s,e){let t=Wn();return e.encode(s,t,{lengthDelimited:!1}),t.finish()}function*we(s,e,t){let r=xs(s);yield*e.stream(r,void 0,"$",t)}var Qs={VARINT:0,BIT64:1,LENGTH_DELIMITED:2,START_GROUP:3,END_GROUP:4,BIT32:5};function er(s,e,t,r,n){return{name:s,type:e,encode:t,decode:r,stream:n}}function $n(s){function e(i){if(s[i.toString()]==null)throw new Error("Invalid enum value");return s[i]}let t=function(o,a){let c=e(o);a.int32(c)},r=function(o){let a=o.int32();return e(a)},n=function*(o){let a=o.int32();yield e(a)};return er("enum",Qs.VARINT,t,r,n)}function xe(s,e,t){return er("message",Qs.LENGTH_DELIMITED,s,e,t)}var V=class extends Error{code="ERR_MAX_LENGTH";name="MaxLengthError"};var j;(function(s){s.RSA="RSA",s.Ed25519="Ed25519",s.secp256k1="secp256k1",s.ECDSA="ECDSA"})(j||(j={}));var Zn;(function(s){s[s.RSA=0]="RSA",s[s.Ed25519=1]="Ed25519",s[s.secp256k1=2]="secp256k1",s[s.ECDSA=3]="ECDSA"})(Zn||(Zn={}));(function(s){s.codec=()=>$n(Zn)})(j||(j={}));var He;(function(s){let e;s.codec=()=>(e==null&&(e=xe((i,o,a={})=>{a.lengthDelimited!==!1&&o.fork(),i.Type!=null&&(o.uint32(8),j.codec().encode(i.Type,o)),i.Data!=null&&(o.uint32(18),o.bytes(i.Data)),a.lengthDelimited!==!1&&o.ldelim()},(i,o,a={})=>{let c={},f=o==null?i.len:i.pos+o;for(;i.pos<f;){let p=i.uint32();switch(p>>>3){case 1:{c.Type=j.codec().decode(i);break}case 2:{c.Data=i.bytes();break}default:{i.skipType(p&7);break}}}return c},function*(i,o,a,c={}){let f=o==null?i.len:i.pos+o;for(;i.pos<f;){let p=i.uint32();switch(p>>>3){case 1:{yield{field:`${a}.Type`,value:j.codec().decode(i)};break}case 2:{yield{field:`${a}.Data`,value:i.bytes()};break}default:{i.skipType(p&7);break}}}})),e);function t(i){return ye(i,s.codec())}s.encode=t;function r(i,o){return be(i,s.codec(),o)}s.decode=r;function n(i,o){return we(i,s.codec(),o)}s.stream=n})(He||(He={}));var jn;(function(s){let e;s.codec=()=>(e==null&&(e=xe((i,o,a={})=>{a.lengthDelimited!==!1&&o.fork(),i.Type!=null&&(o.uint32(8),j.codec().encode(i.Type,o)),i.Data!=null&&(o.uint32(18),o.bytes(i.Data)),a.lengthDelimited!==!1&&o.ldelim()},(i,o,a={})=>{let c={},f=o==null?i.len:i.pos+o;for(;i.pos<f;){let p=i.uint32();switch(p>>>3){case 1:{c.Type=j.codec().decode(i);break}case 2:{c.Data=i.bytes();break}default:{i.skipType(p&7);break}}}return c},function*(i,o,a,c={}){let f=o==null?i.len:i.pos+o;for(;i.pos<f;){let p=i.uint32();switch(p>>>3){case 1:{yield{field:`${a}.Type`,value:j.codec().decode(i)};break}case 2:{yield{field:`${a}.Data`,value:i.bytes()};break}default:{i.skipType(p&7);break}}}})),e);function t(i){return ye(i,s.codec())}s.encode=t;function r(i,o){return be(i,s.codec(),o)}s.decode=r;function n(i,o){return we(i,s.codec(),o)}s.stream=n})(jn||(jn={}));function tr(s){if(isNaN(s)||s<=0)throw new $("random bytes length must be a Number bigger than 0");return ot(s)}var _s={};_e(_s,{MAX_RSA_KEY_SIZE:()=>Yn,generateRSAKeyPair:()=>ia,jwkToJWKKeyPair:()=>oa,jwkToPkcs1:()=>vu,jwkToPkix:()=>ei,jwkToRSAPrivateKey:()=>ni,pkcs1MessageToJwk:()=>Jn,pkcs1MessageToRSAPrivateKey:()=>ti,pkcs1ToJwk:()=>xu,pkcs1ToRSAPrivateKey:()=>na,pkixMessageToJwk:()=>Qn,pkixMessageToRSAPublicKey:()=>ri,pkixToJwk:()=>Eu,pkixToRSAPublicKey:()=>si});var $t=class{type="RSA";jwk;_raw;_multihash;constructor(e,t){this.jwk=e,this._multihash=t}get raw(){return this._raw==null&&(this._raw=_s.jwkToPkix(this.jwk)),this._raw}toMultihash(){return this._multihash}toCID(){return ae.createV1(114,this._multihash)}toString(){return te.encode(this.toMultihash().bytes).substring(1)}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:Ie(this.raw,e.raw)}verify(e,t,r){return ra(this.jwk,t,e,r)}},Ss=class{type="RSA";jwk;_raw;publicKey;constructor(e,t){this.jwk=e,this.publicKey=t}get raw(){return this._raw==null&&(this._raw=_s.jwkToPkcs1(this.jwk)),this._raw}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:Ie(this.raw,e.raw)}sign(e,t){return sa(this.jwk,e,t)}};var Yn=8192,Xn=18,yu=1062,wu=Uint8Array.from([48,13,6,9,42,134,72,134,247,13,1,1,1,5,0]);function xu(s){let e=$e(s);return Jn(e)}function Jn(s){return{n:q(s[1],"base64url"),e:q(s[2],"base64url"),d:q(s[3],"base64url"),p:q(s[4],"base64url"),q:q(s[5],"base64url"),dp:q(s[6],"base64url"),dq:q(s[7],"base64url"),qi:q(s[8],"base64url"),kty:"RSA"}}function vu(s){if(s.n==null||s.e==null||s.d==null||s.p==null||s.q==null||s.dp==null||s.dq==null||s.qi==null)throw new $("JWK was missing components");return it([Te(Uint8Array.from([0])),Te(z(s.n,"base64url")),Te(z(s.e,"base64url")),Te(z(s.d,"base64url")),Te(z(s.p,"base64url")),Te(z(s.q,"base64url")),Te(z(s.dp,"base64url")),Te(z(s.dq,"base64url")),Te(z(s.qi,"base64url"))]).subarray()}function Eu(s){let e=$e(s,{offset:0});return Qn(e)}function Qn(s){let e=$e(s[1],{offset:0});return{kty:"RSA",n:q(e[0],"base64url"),e:q(e[1],"base64url")}}function ei(s){if(s.n==null||s.e==null)throw new $("JWK was missing components");return it([wu,Us(it([Te(z(s.n,"base64url")),Te(z(s.e,"base64url"))]))]).subarray()}function na(s){let e=$e(s);return ti(e)}function ti(s){let e=Jn(s);return ni(e)}function si(s,e){if(s.byteLength>=yu)throw new Lt("Key size is too large");let t=$e(s,{offset:0});return ri(t,s,e)}function ri(s,e,t){let r=Qn(s);if(t==null){let n=Gt(He.encode({Type:j.RSA,Data:e}));t=Ue(Xn,n)}return new $t(r,t)}function ni(s){if(ca(s)>Yn)throw new $("Key size is too large");let e=oa(s),t=Gt(He.encode({Type:j.RSA,Data:ei(e.publicKey)})),r=Ue(Xn,t);return new Ss(e.privateKey,new $t(e.publicKey,r))}async function ia(s){if(s>Yn)throw new $("Key size is too large");let e=await aa(s),t=Gt(He.encode({Type:j.RSA,Data:ei(e.publicKey)})),r=Ue(Xn,t);return new Ss(e.privateKey,new $t(e.publicKey,r))}function oa(s){if(s==null)throw new $("Missing key parameter");return{privateKey:s,publicKey:{kty:s.kty,n:s.n,e:s.e}}}async function aa(s,e){let t=await Pe.get().subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:s,publicExponent:new Uint8Array([1,0,1]),hash:{name:"SHA-256"}},!0,["sign","verify"]);e?.signal?.throwIfAborted();let r=await Su(t,e);return{privateKey:r[0],publicKey:r[1]}}async function sa(s,e,t){let r=await Pe.get().subtle.importKey("jwk",s,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]);t?.signal?.throwIfAborted();let n=await Pe.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},r,e instanceof Uint8Array?e:e.subarray());return t?.signal?.throwIfAborted(),new Uint8Array(n,0,n.byteLength)}async function ra(s,e,t,r){let n=await Pe.get().subtle.importKey("jwk",s,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);r?.signal?.throwIfAborted();let i=await Pe.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,e,t instanceof Uint8Array?t:t.subarray());return r?.signal?.throwIfAborted(),i}async function Su(s,e){if(s.privateKey==null||s.publicKey==null)throw new $("Private and public key are required");let t=await Promise.all([Pe.get().subtle.exportKey("jwk",s.privateKey),Pe.get().subtle.exportKey("jwk",s.publicKey)]);return e?.signal?.throwIfAborted(),t}function ca(s){if(s.kty!=="RSA")throw new $("invalid key type");if(s.n==null)throw new $("invalid key modulus");return z(s.n,"base64url").length*8}var sr=class{oHash;iHash;blockLen;outputLen;finished=!1;destroyed=!1;constructor(e,t){if(Ks(e),K(t,void 0,"key"),this.iHash=e.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 r=this.blockLen,n=new Uint8Array(r);n.set(t.length>r?e.create().update(t).digest():t);for(let i=0;i<n.length;i++)n[i]^=54;this.iHash.update(n),this.oHash=e.create();for(let i=0;i<n.length;i++)n[i]^=106;this.oHash.update(n),je(n)}update(e){return Ft(this),this.iHash.update(e),this}digestInto(e){Ft(this),K(e,this.outputLen,"output"),this.finished=!0,this.iHash.digestInto(e),this.oHash.update(e),this.oHash.digestInto(e),this.destroy()}digest(){let e=new Uint8Array(this.oHash.outputLen);return this.digestInto(e),e}_cloneInto(e){e||=Object.create(Object.getPrototypeOf(this),{});let{oHash:t,iHash:r,finished:n,destroyed:i,blockLen:o,outputLen:a}=this;return e=e,e.finished=n,e.destroyed=i,e.blockLen=o,e.outputLen=a,e.oHash=t._cloneInto(e.oHash),e.iHash=r._cloneInto(e.iHash),e}clone(){return this._cloneInto()}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},ii=(s,e,t)=>new sr(s,e).update(t).digest();ii.create=(s,e)=>new sr(s,e);var la=(s,e)=>(s+(s>=0?e:-e)/ua)/e;function _u(s,e,t){let[[r,n],[i,o]]=e,a=la(o*s,t),c=la(-n*s,t),f=s-a*r-c*i,p=-a*n-c*o,m=f<et,_=p<et;m&&(f=-f),_&&(p=-p);let v=gs(Math.ceil(pn(t)/2))+Zt;if(f<et||f>=v||p<et||p>=v)throw new Error("splitScalar (endomorphism): failed, k="+s);return{k1neg:m,k1:f,k2neg:_,k2:p}}function ai(s){if(!["compact","recovered","der"].includes(s))throw new Error('Signature format must be "compact", "recovered", or "der"');return s}function oi(s,e){let t={};for(let r of Object.keys(e))t[r]=s[r]===void 0?e[r]:s[r];return Qe(t.lowS,"lowS"),Qe(t.prehash,"prehash"),t.format!==void 0&&ai(t.format),t}var ci=class extends Error{constructor(e=""){super(e)}},dt={Err:ci,_tlv:{encode:(s,e)=>{let{Err:t}=dt;if(s<0||s>256)throw new t("tlv.encode: wrong tag");if(e.length&1)throw new t("tlv.encode: unpadded data");let r=e.length/2,n=ps(r);if(n.length/2&128)throw new t("tlv.encode: long form length too big");let i=r>127?ps(n.length/2|128):"";return ps(s)+i+n+e},decode(s,e){let{Err:t}=dt,r=0;if(s<0||s>256)throw new t("tlv.encode: wrong tag");if(e.length<2||e[r++]!==s)throw new t("tlv.decode: wrong tlv");let n=e[r++],i=!!(n&128),o=0;if(!i)o=n;else{let c=n&127;if(!c)throw new t("tlv.decode(long): indefinite length not supported");if(c>4)throw new t("tlv.decode(long): byte length is too big");let f=e.subarray(r,r+c);if(f.length!==c)throw new t("tlv.decode: length bytes not complete");if(f[0]===0)throw new t("tlv.decode(long): zero leftmost byte");for(let p of f)o=o<<8|p;if(r+=c,o<128)throw new t("tlv.decode(long): not minimal encoding")}let a=e.subarray(r,r+o);if(a.length!==o)throw new t("tlv.decode: wrong value length");return{v:a,l:e.subarray(r+o)}}},_int:{encode(s){let{Err:e}=dt;if(s<et)throw new e("integer: negative integers are not allowed");let t=ps(s);if(Number.parseInt(t[0],16)&8&&(t="00"+t),t.length&1)throw new e("unexpected DER parsing assertion: unpadded hex");return t},decode(s){let{Err:e}=dt;if(s[0]&128)throw new e("invalid signature integer: negative");if(s[0]===0&&!(s[1]&128))throw new e("invalid signature integer: unnecessary leading zero");return Ht(s)}},toSig(s){let{Err:e,_int:t,_tlv:r}=dt,n=K(s,void 0,"signature"),{v:i,l:o}=r.decode(48,n);if(o.length)throw new e("invalid signature: left bytes after parsing");let{v:a,l:c}=r.decode(2,i),{v:f,l:p}=r.decode(2,c);if(p.length)throw new e("invalid signature: left bytes after parsing");return{r:t.decode(a),s:t.decode(f)}},hexFromSig(s){let{_tlv:e,_int:t}=dt,r=e.encode(2,t.encode(s.r)),n=e.encode(2,t.encode(s.s)),i=r+n;return e.encode(48,i)}},et=BigInt(0),Zt=BigInt(1),ua=BigInt(2),rr=BigInt(3),Iu=BigInt(4);function ha(s,e={}){let t=Vs("weierstrass",s,e),{Fp:r,Fn:n}=t,i=t.CURVE,{h:o,n:a}=i;ut(e,{},{allowInfinityPoint:"boolean",clearCofactor:"function",isTorsionFree:"function",fromBytes:"function",toBytes:"function",endo:"object"});let{endo:c}=e;if(c&&(!r.is0(i.a)||typeof c.beta!="bigint"||!Array.isArray(c.basises)))throw new Error('invalid endo: expected "beta": bigint and "basises": array');let f=da(r,n);function p(){if(!r.isOdd)throw new Error("compression is not supported: Field does not have .isOdd()")}function m(R,D,A){let{x:T,y:M}=D.toAffine(),k=r.toBytes(T);if(Qe(A,"isCompressed"),A){p();let B=!r.isOdd(M);return De(fa(B),k)}else return De(Uint8Array.of(4),k,r.toBytes(M))}function _(R){K(R,void 0,"Point");let{publicKey:D,publicKeyUncompressed:A}=f,T=R.length,M=R[0],k=R.subarray(1);if(T===D&&(M===2||M===3)){let B=r.fromBytes(k);if(!r.isValid(B))throw new Error("bad point: is not on curve, wrong x");let C=g(B),L;try{L=r.sqrt(C)}catch(X){let W=X instanceof Error?": "+X.message:"";throw new Error("bad point: is not on curve, sqrt error"+W)}p();let N=r.isOdd(L);return(M&1)===1!==N&&(L=r.neg(L)),{x:B,y:L}}else if(T===A&&M===4){let B=r.BYTES,C=r.fromBytes(k.subarray(0,B)),L=r.fromBytes(k.subarray(B,B*2));if(!w(C,L))throw new Error("bad point: is not on curve");return{x:C,y:L}}else throw new Error(`bad point: got length ${T}, expected compressed=${D} or uncompressed=${A}`)}let v=e.toBytes||m,u=e.fromBytes||_;function g(R){let D=r.sqr(R),A=r.mul(D,R);return r.add(r.add(A,r.mul(R,i.a)),i.b)}function w(R,D){let A=r.sqr(D),T=g(R);return r.eql(A,T)}if(!w(i.Gx,i.Gy))throw new Error("bad curve params: generator point");let y=r.mul(r.pow(i.a,rr),Iu),I=r.mul(r.sqr(i.b),BigInt(27));if(r.is0(r.add(y,I)))throw new Error("bad curve params: a or b");function l(R,D,A=!1){if(!r.isValid(D)||A&&r.is0(D))throw new Error(`bad point coordinate ${R}`);return D}function h(R){if(!(R instanceof S))throw new Error("Weierstrass Point expected")}function d(R){if(!c||!c.basises)throw new Error("no endo");return _u(R,c.basises,n.ORDER)}let b=qt((R,D)=>{let{X:A,Y:T,Z:M}=R;if(r.eql(M,r.ONE))return{x:A,y:T};let k=R.is0();D==null&&(D=k?r.ONE:r.inv(M));let B=r.mul(A,D),C=r.mul(T,D),L=r.mul(M,D);if(k)return{x:r.ZERO,y:r.ZERO};if(!r.eql(L,r.ONE))throw new Error("invZ was invalid");return{x:B,y:C}}),E=qt(R=>{if(R.is0()){if(e.allowInfinityPoint&&!r.is0(R.Y))return;throw new Error("bad point: ZERO")}let{x:D,y:A}=R.toAffine();if(!r.isValid(D)||!r.isValid(A))throw new Error("bad point: x or y not field elements");if(!w(D,A))throw new Error("bad point: equation left != right");if(!R.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});function x(R,D,A,T,M){return A=new S(r.mul(A.X,R),A.Y,A.Z),D=ys(T,D),A=ys(M,A),D.add(A)}class S{static BASE=new S(i.Gx,i.Gy,r.ONE);static ZERO=new S(r.ZERO,r.ONE,r.ZERO);static Fp=r;static Fn=n;X;Y;Z;constructor(D,A,T){this.X=l("x",D),this.Y=l("y",A,!0),this.Z=l("z",T),Object.freeze(this)}static CURVE(){return i}static fromAffine(D){let{x:A,y:T}=D||{};if(!D||!r.isValid(A)||!r.isValid(T))throw new Error("invalid affine point");if(D instanceof S)throw new Error("projective point not allowed");return r.is0(A)&&r.is0(T)?S.ZERO:new S(A,T,r.ONE)}static fromBytes(D){let A=S.fromAffine(u(K(D,void 0,"point")));return A.assertValidity(),A}static fromHex(D){return S.fromBytes(Xe(D))}get x(){return this.toAffine().x}get y(){return this.toAffine().y}precompute(D=8,A=!0){return O.createCache(this,D),A||this.multiply(rr),this}assertValidity(){E(this)}hasEvenY(){let{y:D}=this.toAffine();if(!r.isOdd)throw new Error("Field doesn't support isOdd");return!r.isOdd(D)}equals(D){h(D);let{X:A,Y:T,Z:M}=this,{X:k,Y:B,Z:C}=D,L=r.eql(r.mul(A,C),r.mul(k,M)),N=r.eql(r.mul(T,C),r.mul(B,M));return L&&N}negate(){return new S(this.X,r.neg(this.Y),this.Z)}double(){let{a:D,b:A}=i,T=r.mul(A,rr),{X:M,Y:k,Z:B}=this,C=r.ZERO,L=r.ZERO,N=r.ZERO,U=r.mul(M,M),X=r.mul(k,k),W=r.mul(B,B),F=r.mul(M,k);return F=r.add(F,F),N=r.mul(M,B),N=r.add(N,N),C=r.mul(D,N),L=r.mul(T,W),L=r.add(C,L),C=r.sub(X,L),L=r.add(X,L),L=r.mul(C,L),C=r.mul(F,C),N=r.mul(T,N),W=r.mul(D,W),F=r.sub(U,W),F=r.mul(D,F),F=r.add(F,N),N=r.add(U,U),U=r.add(N,U),U=r.add(U,W),U=r.mul(U,F),L=r.add(L,U),W=r.mul(k,B),W=r.add(W,W),U=r.mul(W,F),C=r.sub(C,U),N=r.mul(W,X),N=r.add(N,N),N=r.add(N,N),new S(C,L,N)}add(D){h(D);let{X:A,Y:T,Z:M}=this,{X:k,Y:B,Z:C}=D,L=r.ZERO,N=r.ZERO,U=r.ZERO,X=i.a,W=r.mul(i.b,rr),F=r.mul(A,k),J=r.mul(T,B),oe=r.mul(M,C),Oe=r.add(A,T),Q=r.add(k,B);Oe=r.mul(Oe,Q),Q=r.add(F,J),Oe=r.sub(Oe,Q),Q=r.add(A,M);let le=r.add(k,C);return Q=r.mul(Q,le),le=r.add(F,oe),Q=r.sub(Q,le),le=r.add(T,M),L=r.add(B,C),le=r.mul(le,L),L=r.add(J,oe),le=r.sub(le,L),U=r.mul(X,Q),L=r.mul(W,oe),U=r.add(L,U),L=r.sub(J,U),U=r.add(J,U),N=r.mul(L,U),J=r.add(F,F),J=r.add(J,F),oe=r.mul(X,oe),Q=r.mul(W,Q),J=r.add(J,oe),oe=r.sub(F,oe),oe=r.mul(X,oe),Q=r.add(Q,oe),F=r.mul(J,Q),N=r.add(N,F),F=r.mul(le,Q),L=r.mul(Oe,L),L=r.sub(L,F),F=r.mul(Oe,J),U=r.mul(le,U),U=r.add(U,F),new S(L,N,U)}subtract(D){return this.add(D.negate())}is0(){return this.equals(S.ZERO)}multiply(D){let{endo:A}=e;if(!n.isValidNot0(D))throw new Error("invalid scalar: out of range");let T,M,k=B=>O.cached(this,B,C=>_t(S,C));if(A){let{k1neg:B,k1:C,k2neg:L,k2:N}=d(D),{p:U,f:X}=k(C),{p:W,f:F}=k(N);M=X.add(F),T=x(A.beta,U,W,B,L)}else{let{p:B,f:C}=k(D);T=B,M=C}return _t(S,[T,M])[0]}multiplyUnsafe(D){let{endo:A}=e,T=this;if(!n.isValid(D))throw new Error("invalid scalar: out of range");if(D===et||T.is0())return S.ZERO;if(D===Zt)return T;if(O.hasCache(this))return this.multiply(D);if(A){let{k1neg:M,k1:k,k2neg:B,k2:C}=d(D),{p1:L,p2:N}=Uo(S,T,k,C);return x(A.beta,L,N,M,B)}else return O.unsafe(T,D)}toAffine(D){return b(this,D)}isTorsionFree(){let{isTorsionFree:D}=e;return o===Zt?!0:D?D(S,this):O.unsafe(this,a).is0()}clearCofactor(){let{clearCofactor:D}=e;return o===Zt?this:D?D(S,this):this.multiplyUnsafe(o)}isSmallOrder(){return this.multiplyUnsafe(o).is0()}toBytes(D=!0){return Qe(D,"isCompressed"),this.assertValidity(),v(S,this,D)}toHex(D=!0){return Ye(this.toBytes(D))}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}}let P=n.BITS,O=new Wt(S,e.endo?Math.ceil(P/2):P);return S.BASE.precompute(8),S}function fa(s){return Uint8Array.of(s?2:3)}function da(s,e){return{secretKey:e.BYTES,publicKey:1+s.BYTES,publicKeyUncompressed:1+2*s.BYTES,publicKeyHasPrefix:!0,signature:2*e.BYTES}}function Tu(s,e={}){let{Fn:t}=s,r=e.randomBytes||ot,n=Object.assign(da(s.Fp,t),{seed:yn(t.ORDER)});function i(v){try{let u=t.fromBytes(v);return t.isValidNot0(u)}catch{return!1}}function o(v,u){let{publicKey:g,publicKeyUncompressed:w}=n;try{let y=v.length;return u===!0&&y!==g||u===!1&&y!==w?!1:!!s.fromBytes(v)}catch{return!1}}function a(v=r(n.seed)){return wn(K(v,n.seed,"seed"),t.ORDER)}function c(v,u=!0){return s.BASE.multiply(t.fromBytes(v)).toBytes(u)}function f(v){let{secretKey:u,publicKey:g,publicKeyUncompressed:w}=n;if(!yt(v)||"_lengths"in t&&t._lengths||u===g)return;let y=K(v,void 0,"key").length;return y===g||y===w}function p(v,u,g=!0){if(f(v)===!0)throw new Error("first arg must be private key");if(f(u)===!1)throw new Error("second arg must be public key");let w=t.fromBytes(v);return s.fromBytes(u).multiply(w).toBytes(g)}let m={isValidSecretKey:i,isValidPublicKey:o,randomSecretKey:a},_=Ws(a,c);return Object.freeze({getPublicKey:c,getSharedSecret:p,keygen:_,Point:s,utils:m,lengths:n})}function pa(s,e,t={}){Ks(e),ut(t,{},{hmac:"function",lowS:"boolean",randomBytes:"function",bits2int:"function",bits2int_modN:"function"}),t=Object.assign({},t);let r=t.randomBytes||ot,n=t.hmac||((A,T)=>ii(e,A,T)),{Fp:i,Fn:o}=s,{ORDER:a,BITS:c}=o,{keygen:f,getPublicKey:p,getSharedSecret:m,utils:_,lengths:v}=Tu(s,t),u={prehash:!0,lowS:typeof t.lowS=="boolean"?t.lowS:!0,format:"compact",extraEntropy:!1},g=a*ua<i.ORDER;function w(A){let T=a>>Zt;return A>T}function y(A,T){if(!o.isValidNot0(T))throw new Error(`invalid signature ${A}: out of range 1..Point.Fn.ORDER`);return T}function I(){if(g)throw new Error('"recovered" sig type is not supported for cofactor >2 curves')}function l(A,T){ai(T);let M=v.signature,k=T==="compact"?M:T==="recovered"?M+1:void 0;return K(A,k)}class h{r;s;recovery;constructor(T,M,k){if(this.r=y("r",T),this.s=y("s",M),k!=null){if(I(),![0,1,2,3].includes(k))throw new Error("invalid recovery id");this.recovery=k}Object.freeze(this)}static fromBytes(T,M=u.format){l(T,M);let k;if(M==="der"){let{r:N,s:U}=dt.toSig(K(T));return new h(N,U)}M==="recovered"&&(k=T[0],M="compact",T=T.subarray(1));let B=v.signature/2,C=T.subarray(0,B),L=T.subarray(B,B*2);return new h(o.fromBytes(C),o.fromBytes(L),k)}static fromHex(T,M){return this.fromBytes(Xe(T),M)}assertRecovery(){let{recovery:T}=this;if(T==null)throw new Error("invalid recovery id: must be present");return T}addRecoveryBit(T){return new h(this.r,this.s,T)}recoverPublicKey(T){let{r:M,s:k}=this,B=this.assertRecovery(),C=B===2||B===3?M+a:M;if(!i.isValid(C))throw new Error("invalid recovery id: sig.r+curve.n != R.x");let L=i.toBytes(C),N=s.fromBytes(De(fa((B&1)===0),L)),U=o.inv(C),X=b(K(T,void 0,"msgHash")),W=o.create(-X*U),F=o.create(k*U),J=s.BASE.multiplyUnsafe(W).add(N.multiplyUnsafe(F));if(J.is0())throw new Error("invalid recovery: point at infinify");return J.assertValidity(),J}hasHighS(){return w(this.s)}toBytes(T=u.format){if(ai(T),T==="der")return Xe(dt.hexFromSig(this));let{r:M,s:k}=this,B=o.toBytes(M),C=o.toBytes(k);return T==="recovered"?(I(),De(Uint8Array.of(this.assertRecovery()),B,C)):De(B,C)}toHex(T){return Ye(this.toBytes(T))}}let d=t.bits2int||function(T){if(T.length>8192)throw new Error("input is too large");let M=Ht(T),k=T.length*8-c;return k>0?M>>BigInt(k):M},b=t.bits2int_modN||function(T){return o.create(d(T))},E=gs(c);function x(A){return ms("num < 2^"+c,A,et,E),o.toBytes(A)}function S(A,T){return K(A,void 0,"message"),T?K(e(A),void 0,"prehashed message"):A}function P(A,T,M){let{lowS:k,prehash:B,extraEntropy:C}=oi(M,u);A=S(A,B);let L=b(A),N=o.fromBytes(T);if(!o.isValidNot0(N))throw new Error("invalid private key");let U=[x(N),x(L)];if(C!=null&&C!==!1){let J=C===!0?r(v.secretKey):C;U.push(K(J,void 0,"extraEntropy"))}let X=De(...U),W=L;function F(J){let oe=d(J);if(!o.isValidNot0(oe))return;let Oe=o.inv(oe),Q=s.BASE.multiply(oe).toAffine(),le=o.create(Q.x);if(le===et)return;let Ps=o.create(Oe*o.create(W+le*N));if(Ps===et)return;let vi=(Q.x===le?0:2)|Number(Q.y&Zt),Ei=Ps;return k&&w(Ps)&&(Ei=o.neg(Ps),vi^=1),new h(le,Ei,g?void 0:vi)}return{seed:X,k2sig:F}}function O(A,T,M={}){let{seed:k,k2sig:B}=P(A,T,M);return vo(e.outputLen,o.BYTES,n)(k,B).toBytes(M.format)}function R(A,T,M,k={}){let{lowS:B,prehash:C,format:L}=oi(k,u);if(M=K(M,void 0,"publicKey"),T=S(T,C),!yt(A)){let N=A instanceof h?", use sig.toBytes()":"";throw new Error("verify expects Uint8Array signature"+N)}l(A,L);try{let N=h.fromBytes(A,L),U=s.fromBytes(M);if(B&&N.hasHighS())return!1;let{r:X,s:W}=N,F=b(T),J=o.inv(W),oe=o.create(F*J),Oe=o.create(X*J),Q=s.BASE.multiplyUnsafe(oe).add(U.multiplyUnsafe(Oe));return Q.is0()?!1:o.create(Q.x)===X}catch{return!1}}function D(A,T,M={}){let{prehash:k}=oi(M,u);return T=S(T,k),h.fromBytes(A,"recovered").recoverPublicKey(T).toBytes()}return Object.freeze({keygen:f,getPublicKey:p,getSharedSecret:m,utils:_,lengths:v,Point:s,sign:O,verify:R,recoverPublicKey:D,Signature:h,hash:e})}var ui={p:BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),n:BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),h:BigInt(1),a:BigInt(0),b:BigInt(7),Gx:BigInt("0x79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798"),Gy:BigInt("0x483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8")},Du={beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),basises:[[BigInt("0x3086d221a7d46bcde86c90e49284eb15"),-BigInt("0xe4437ed6010e88286f547fa90abfe4c3")],[BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),BigInt("0x3086d221a7d46bcde86c90e49284eb15")]]};var ma=BigInt(2);function Au(s){let e=ui.p,t=BigInt(3),r=BigInt(6),n=BigInt(11),i=BigInt(22),o=BigInt(23),a=BigInt(44),c=BigInt(88),f=s*s*s%e,p=f*f*s%e,m=Z(p,t,e)*p%e,_=Z(m,t,e)*p%e,v=Z(_,ma,e)*f%e,u=Z(v,n,e)*v%e,g=Z(u,i,e)*u%e,w=Z(g,a,e)*g%e,y=Z(w,c,e)*w%e,I=Z(y,a,e)*g%e,l=Z(I,t,e)*p%e,h=Z(l,o,e)*u%e,d=Z(h,r,e)*f%e,b=Z(d,ma,e);if(!li.eql(li.sqr(b),s))throw new Error("Cannot find square root");return b}var li=zt(ui.p,{sqrt:Au}),Mu=ha(ui,{Fp:li,endo:Du}),jt=pa(Mu,Gt);function ga(s,e,t,r){let n=bt.digest(t instanceof Uint8Array?t:t.subarray());if(js(n))return n.then(({digest:i})=>(r?.signal?.throwIfAborted(),jt.verify(e,i,s,{prehash:!1,format:"der"}))).catch(i=>{throw i.name==="AbortError"?i:new ws(String(i))});try{return r?.signal?.throwIfAborted(),jt.verify(e,n.digest,s,{prehash:!1,format:"der"})}catch(i){throw new ws(String(i))}}var nr=class{type="secp256k1";raw;_key;constructor(e){this._key=ya(e),this.raw=ba(this._key)}toMultihash(){return Le.digest(Ke(this))}toCID(){return ae.createV1(114,this.toMultihash())}toString(){return te.encode(this.toMultihash().bytes).substring(1)}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:Ie(this.raw,e.raw)}verify(e,t,r){return ga(this._key,t,e,r)}};function hi(s){return new nr(s)}function ba(s){return jt.Point.fromBytes(s).toBytes()}function ya(s){try{return jt.Point.fromBytes(s),s}catch(e){throw new Lt(String(e))}}function ir(s,e){let{Type:t,Data:r}=He.decode(s),n=r??new Uint8Array;switch(t){case j.RSA:return si(n,e);case j.Ed25519:return Dn(n);case j.secp256k1:return hi(n);case j.ECDSA:return tn(n);default:throw new Bt}}function wa(s){let{Type:e,Data:t}=He.decode(s.digest),r=t??new Uint8Array;switch(e){case j.Ed25519:return Dn(r);case j.secp256k1:return hi(r);case j.ECDSA:return tn(r);default:throw new Bt}}function Ke(s){return He.encode({Type:j[s.type],Data:s.raw})}var xa=Symbol.for("nodejs.util.inspect.custom"),Pu=114,Is=class{type;multihash;publicKey;string;constructor(e){this.type=e.type,this.multihash=e.multihash,Object.defineProperty(this,"string",{enumerable:!1,writable:!0})}get[Symbol.toStringTag](){return`PeerId(${this.toString()})`}[Dr]=!0;toString(){return this.string==null&&(this.string=te.encode(this.multihash.bytes).slice(1)),this.string}toMultihash(){return this.multihash}toCID(){return ae.createV1(Pu,this.multihash)}toJSON(){return this.toString()}equals(e){if(e==null)return!1;if(e instanceof Uint8Array)return Ie(this.multihash.bytes,e);if(typeof e=="string")return this.toString()===e;if(e?.toMultihash()?.bytes!=null)return Ie(this.multihash.bytes,e.toMultihash().bytes);throw new Error("not valid Id")}[xa](){return`PeerId(${this.toString()})`}},or=class extends Is{type="RSA";publicKey;constructor(e){super({...e,type:"RSA"}),this.publicKey=e.publicKey}},ar=class extends Is{type="Ed25519";publicKey;constructor(e){super({...e,type:"Ed25519"}),this.publicKey=e.publicKey}},cr=class extends Is{type="secp256k1";publicKey;constructor(e){super({...e,type:"secp256k1"}),this.publicKey=e.publicKey}},ku=2336,Ts=class{type="url";multihash;publicKey;url;constructor(e){this.url=e.toString(),this.multihash=Le.digest(z(this.url))}[xa](){return`PeerId(${this.url})`}[Dr]=!0;toString(){return this.toCID().toString()}toMultihash(){return this.multihash}toCID(){return ae.createV1(ku,this.toMultihash())}toJSON(){return this.toString()}equals(e){return e==null?!1:(e instanceof Uint8Array&&(e=q(e)),e.toString()===this.toString())}};var Lu=114,va=2336;function Dt(s,e){let t;if(s.charAt(0)==="1"||s.charAt(0)==="Q")t=Ve(te.decode(`z${s}`));else{if(s.startsWith("k51qzi5uqu5")||s.startsWith("kzwfwjn5ji4")||s.startsWith("k2k4r8")||s.startsWith("bafz"))return Bu(ae.parse(s));if(e==null)throw new $('Please pass a multibase decoder for strings that do not start with "1" or "Q"');t=Ve(e.decode(s))}return Yt(t)}function Yt(s){if(Cu(s))return new or({multihash:s});if(Ru(s))try{let e=wa(s);if(e.type==="Ed25519")return new ar({multihash:s,publicKey:e});if(e.type==="secp256k1")return new cr({multihash:s,publicKey:e})}catch{let t=q(s.digest);return new Ts(new URL(t))}throw new Bs("Supplied PeerID Multihash is invalid")}function Bu(s){if(s?.multihash==null||s.version==null||s.version===1&&s.code!==Lu&&s.code!==va)throw new Ls("Supplied PeerID CID is invalid");if(s.code===va){let e=q(s.multihash.digest);return new Ts(new URL(e))}return Yt(s.multihash)}function Ru(s){return s.code===Le.code}function Cu(s){return s.code===bt.code}var lr=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},Xt=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},ur=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"},Ds=class extends Error{name="UnexpectedEOFError";code="ERR_UNEXPECTED_EOF"};function hr(s){return s[Symbol.asyncIterator]!=null}function Ea(s,e){if(s.byteLength>e)throw new Xt("Message length too long")}var dr=s=>{let e=ke(s),t=ue(e);return Rn(s,t),dr.bytes=e,t};dr.bytes=0;function Jt(s,e){e=e??{};let t=e.lengthEncoder??dr,r=e?.maxDataLength??4194304;function*n(i){Ea(i,r);let o=t(i.byteLength);o instanceof Uint8Array?yield o:yield*o,i instanceof Uint8Array?yield i:yield*i}return hr(s)?(async function*(){for await(let i of s)yield*n(i)})():(function*(){for(let i of s)yield*n(i)})()}Jt.single=(s,e)=>{e=e??{};let t=e.lengthEncoder??dr,r=e?.maxDataLength??4194304;return Ea(s,r),new re(t(s.byteLength),s)};var At;(function(s){s[s.LENGTH=0]="LENGTH",s[s.DATA=1]="DATA"})(At||(At={}));var fi=s=>{let e=Cn(s);return fi.bytes=ke(e),e};fi.bytes=0;function As(s,e){let t=new re,r=At.LENGTH,n=-1,i=e?.lengthDecoder??fi,o=e?.maxLengthLength??8,a=e?.maxDataLength??4194304;function*c(){for(;t.byteLength>0;){if(r===At.LENGTH)try{if(n=i(t),n<0)throw new lr("Invalid message length");if(n>a)throw new Xt("Message length too long");let f=i.bytes;t.consume(f),e?.onLength!=null&&e.onLength(n),r=At.DATA}catch(f){if(f instanceof RangeError){if(t.byteLength>o)throw new ur("Message length length too long");break}throw f}if(r===At.DATA){if(t.byteLength<n)break;let f=t.sublist(0,n);t.consume(n),e?.onData!=null&&e.onData(f),yield f,r=At.LENGTH}}}return hr(s)?(async function*(){for await(let f of s)t.append(f),yield*c();if(t.byteLength>0)throw new Ds("Unexpected end of input")})():(function*(){for(let f of s)t.append(f),yield*c();if(t.byteLength>0)throw new Ds("Unexpected end of input")})()}As.fromReader=(s,e)=>{let t=1,r=(async function*(){for(;;)try{let{done:i,value:o}=await s.next(t);if(i===!0)return;o!=null&&(yield o)}catch(i){if(i.code==="ERR_UNDER_READ")return{done:!0,value:null};throw i}finally{t=1}})();return As(r,{...e??{},onLength:i=>{t=i}})};function tt(){let s={};return s.promise=new Promise((e,t)=>{s.resolve=e,s.reject=t}),s}var pr=class{buffer;mask;top;btm;next;constructor(e){if(!(e>0)||(e-1&e)!==0)throw new Error("Max size for a FixedFIFO should be a power of two");this.buffer=new Array(e),this.mask=e-1,this.top=0,this.btm=0,this.next=null}push(e){return this.buffer[this.top]!==void 0?!1:(this.buffer[this.top]=e,this.top=this.top+1&this.mask,!0)}shift(){let e=this.buffer[this.btm];if(e!==void 0)return this.buffer[this.btm]=void 0,this.btm=this.btm+1&this.mask,e}isEmpty(){return this.buffer[this.btm]===void 0}},Qt=class{size;hwm;head;tail;constructor(e={}){this.hwm=e.splitLimit??16,this.head=new pr(this.hwm),this.tail=this.head,this.size=0}calculateSize(e){return e?.byteLength!=null?e.byteLength:1}push(e){if(e?.value!=null&&(this.size+=this.calculateSize(e.value)),!this.head.push(e)){let t=this.head;this.head=t.next=new pr(2*this.head.buffer.length),this.head.push(e)}}shift(){let e=this.tail.shift();if(e===void 0&&this.tail.next!=null){let t=this.tail.next;this.tail.next=null,this.tail=t,e=this.tail.shift()}return e?.value!=null&&(this.size-=this.calculateSize(e.value)),e}isEmpty(){return this.head.isEmpty()}};var di=class extends Error{type;code;constructor(e,t){super(e??"The operation was aborted"),this.type="aborted",this.code=t??"ABORT_ERR"}};function Mt(s={}){return Ou(t=>{let r=t.shift();if(r==null)return{done:!0};if(r.error!=null)throw r.error;return{done:r.done===!0,value:r.value}},s)}function Ou(s,e){e=e??{};let t=e.onEnd,r=new Qt,n,i,o,a=tt(),c=async()=>{try{return r.isEmpty()?o?{done:!0}:await new Promise((w,y)=>{i=I=>{i=null,r.push(I);try{w(s(r))}catch(l){y(l)}return n}}):s(r)}finally{r.isEmpty()&&queueMicrotask(()=>{a.resolve(),a=tt()})}},f=w=>i!=null?i(w):(r.push(w),n),p=w=>(r=new Qt,i!=null?i({error:w}):(r.push({error:w}),n)),m=w=>{if(o)return n;if(e?.objectMode!==!0&&w?.byteLength==null)throw new Error("objectMode was not true but tried to push non-Uint8Array value");return f({done:!1,value:w})},_=w=>o?n:(o=!0,w!=null?p(w):f({done:!0})),v=()=>(r=new Qt,_(),{done:!0}),u=w=>(_(w),{done:!0});if(n={[Symbol.asyncIterator](){return this},next:c,return:v,throw:u,push:m,end:_,get readableLength(){return r.size},onEmpty:async w=>{let y=w?.signal;if(y?.throwIfAborted(),r.isEmpty())return;let I,l;y!=null&&(I=new Promise((h,d)=>{l=()=>{d(new di)},y.addEventListener("abort",l)}));try{await Promise.race([a.promise,I])}finally{l!=null&&y!=null&&y?.removeEventListener("abort",l)}}},t==null)return n;let g=n;return n={[Symbol.asyncIterator](){return this},next(){return g.next()},throw(w){return g.throw(w),t!=null&&(t(w),t=void 0),{done:!0}},return(){return g.return(),t!=null&&(t(),t=void 0),{done:!0}},push:m,end(w){return g.end(w),t!=null&&(t(w),t=void 0),n},get readableLength(){return g.readableLength},onEmpty:w=>g.onEmpty(w)},n}function Uu(s){return s.reason}async function pi(s,e,t){if(e==null)return s;let r=t?.translateError??Uu;if(e.aborted)return s.catch(()=>{}),Promise.reject(r(e));let n;try{return await Promise.race([s,new Promise((i,o)=>{n=()=>{o(r(e))},e.addEventListener("abort",n)})])}finally{n!=null&&e.removeEventListener("abort",n)}}var mi=class{readNext;haveNext;ended;nextResult;error;constructor(){this.ended=!1,this.readNext=tt(),this.haveNext=tt()}[Symbol.asyncIterator](){return this}async next(){if(this.nextResult==null&&await this.haveNext.promise,this.nextResult==null)throw new Error("HaveNext promise resolved but nextResult was undefined");let e=this.nextResult;return this.nextResult=void 0,this.readNext.resolve(),this.readNext=tt(),e}async throw(e){return this.ended=!0,this.error=e,e!=null&&(this.haveNext.promise.catch(()=>{}),this.haveNext.reject(e)),{done:!0,value:void 0}}async return(){let e={done:!0,value:void 0};return this.ended=!0,this.nextResult=e,this.haveNext.resolve(),e}async push(e,t){await this._push(e,t)}async end(e,t){e!=null?await this.throw(e):await this._push(void 0,t)}async _push(e,t){if(e!=null&&this.ended)throw this.error??new Error("Cannot push value onto an ended pushable");for(;this.nextResult!=null;)await this.readNext.promise;e!=null?this.nextResult={done:!1,value:e}:(this.ended=!0,this.nextResult={done:!0,value:void 0}),this.haveNext.resolve(),this.haveNext=tt(),await pi(this.readNext.promise,t?.signal,t)}};function Sa(){return new mi}function Ku(s){return s[Symbol.asyncIterator]!=null}async function Fu(s,e,t){try{await Promise.all(s.map(async r=>{for await(let n of r)await e.push(n,{signal:t}),t.throwIfAborted()})),await e.end(void 0,{signal:t})}catch(r){await e.end(r,{signal:t}).catch(()=>{})}}async function*Gu(s){let e=new AbortController,t=Sa();Fu(s,t,e.signal).catch(()=>{});try{yield*t}finally{e.abort()}}function*Hu(s){for(let e of s)yield*e}function qu(...s){let e=[];for(let t of s)Ku(t)||e.push(t);return e.length===s.length?Hu(e):Gu(s)}var _a=qu;function Ms(s,...e){if(s==null)throw new Error("Empty pipeline");if(gi(s)){let r=s;s=()=>r.source}else if(Ta(s)||Ia(s)){let r=s;s=()=>r}let t=[s,...e];if(t.length>1&&gi(t[t.length-1])&&(t[t.length-1]=t[t.length-1].sink),t.length>2)for(let r=1;r<t.length-1;r++)gi(t[r])&&(t[r]=Vu(t[r]));return zu(...t)}var zu=(...s)=>{let e;for(;s.length>0;)e=s.shift()(e);return e},Ia=s=>s?.[Symbol.asyncIterator]!=null,Ta=s=>s?.[Symbol.iterator]!=null,gi=s=>s==null?!1:s.sink!=null&&s.source!=null,Vu=s=>e=>{let t=s.sink(e);if(t?.then!=null){let r=Mt({objectMode:!0});t.then(()=>{r.end()},o=>{r.end(o)});let n,i=s.source;if(Ia(i))n=async function*(){yield*i,r.end()};else if(Ta(i))n=function*(){yield*i,r.end()};else throw new Error("Unknown duplex source type - must be Iterable or AsyncIterable");return _a(r,n())}return s.source};var Da={maxSubscriptions:1/0,maxMessages:1/0,maxIhaveMessageIDs:1/0,maxIwantMessageIDs:1/0,maxIdontwantMessageIDs:1/0,maxControlMessages:1/0,maxPeerInfos:1/0};var st;(function(s){let e;(function(u){let g;u.codec=()=>(g==null&&(g=xe((l,h,d={})=>{d.lengthDelimited!==!1&&h.fork(),l.subscribe!=null&&(h.uint32(8),h.bool(l.subscribe)),l.topic!=null&&(h.uint32(18),h.string(l.topic)),d.lengthDelimited!==!1&&h.ldelim()},(l,h,d={})=>{let b={},E=h==null?l.len:l.pos+h;for(;l.pos<E;){let x=l.uint32();switch(x>>>3){case 1:{b.subscribe=l.bool();break}case 2:{b.topic=l.string();break}default:{l.skipType(x&7);break}}}return b},function*(l,h,d,b={}){let E=h==null?l.len:l.pos+h;for(;l.pos<E;){let x=l.uint32();switch(x>>>3){case 1:{yield{field:`${d}.subscribe`,value:l.bool()};break}case 2:{yield{field:`${d}.topic`,value:l.string()};break}default:{l.skipType(x&7);break}}}})),g);function w(l){return ye(l,u.codec())}u.encode=w;function y(l,h){return be(l,u.codec(),h)}u.decode=y;function I(l,h){return we(l,u.codec(),h)}u.stream=I})(e=s.SubOpts||(s.SubOpts={}));let t;(function(u){let g;u.codec=()=>(g==null&&(g=xe((l,h,d={})=>{d.lengthDelimited!==!1&&h.fork(),l.from!=null&&(h.uint32(10),h.bytes(l.from)),l.data!=null&&(h.uint32(18),h.bytes(l.data)),l.seqno!=null&&(h.uint32(26),h.bytes(l.seqno)),l.topic!=null&&l.topic!==""&&(h.uint32(34),h.string(l.topic)),l.signature!=null&&(h.uint32(42),h.bytes(l.signature)),l.key!=null&&(h.uint32(50),h.bytes(l.key)),d.lengthDelimited!==!1&&h.ldelim()},(l,h,d={})=>{let b={topic:""},E=h==null?l.len:l.pos+h;for(;l.pos<E;){let x=l.uint32();switch(x>>>3){case 1:{b.from=l.bytes();break}case 2:{b.data=l.bytes();break}case 3:{b.seqno=l.bytes();break}case 4:{b.topic=l.string();break}case 5:{b.signature=l.bytes();break}case 6:{b.key=l.bytes();break}default:{l.skipType(x&7);break}}}return b},function*(l,h,d,b={}){let E=h==null?l.len:l.pos+h;for(;l.pos<E;){let x=l.uint32();switch(x>>>3){case 1:{yield{field:`${d}.from`,value:l.bytes()};break}case 2:{yield{field:`${d}.data`,value:l.bytes()};break}case 3:{yield{field:`${d}.seqno`,value:l.bytes()};break}case 4:{yield{field:`${d}.topic`,value:l.string()};break}case 5:{yield{field:`${d}.signature`,value:l.bytes()};break}case 6:{yield{field:`${d}.key`,value:l.bytes()};break}default:{l.skipType(x&7);break}}}})),g);function w(l){return ye(l,u.codec())}u.encode=w;function y(l,h){return be(l,u.codec(),h)}u.decode=y;function I(l,h){return we(l,u.codec(),h)}u.stream=I})(t=s.Message||(s.Message={}));let r;(function(u){let g;u.codec=()=>(g==null&&(g=xe((l,h,d={})=>{if(d.lengthDelimited!==!1&&h.fork(),l.ihave!=null&&l.ihave.length>0)for(let b of l.ihave)h.uint32(10),s.ControlIHave.codec().encode(b,h);if(l.iwant!=null&&l.iwant.length>0)for(let b of l.iwant)h.uint32(18),s.ControlIWant.codec().encode(b,h);if(l.graft!=null&&l.graft.length>0)for(let b of l.graft)h.uint32(26),s.ControlGraft.codec().encode(b,h);if(l.prune!=null&&l.prune.length>0)for(let b of l.prune)h.uint32(34),s.ControlPrune.codec().encode(b,h);if(l.idontwant!=null&&l.idontwant.length>0)for(let b of l.idontwant)h.uint32(42),s.ControlIDontWant.codec().encode(b,h);d.lengthDelimited!==!1&&h.ldelim()},(l,h,d={})=>{let b={ihave:[],iwant:[],graft:[],prune:[],idontwant:[]},E=h==null?l.len:l.pos+h;for(;l.pos<E;){let x=l.uint32();switch(x>>>3){case 1:{if(d.limits?.ihave!=null&&b.ihave.length===d.limits.ihave)throw new V('Decode error - repeated field "ihave" had too many elements');b.ihave.push(s.ControlIHave.codec().decode(l,l.uint32(),{limits:d.limits?.ihave$}));break}case 2:{if(d.limits?.iwant!=null&&b.iwant.length===d.limits.iwant)throw new V('Decode error - repeated field "iwant" had too many elements');b.iwant.push(s.ControlIWant.codec().decode(l,l.uint32(),{limits:d.limits?.iwant$}));break}case 3:{if(d.limits?.graft!=null&&b.graft.length===d.limits.graft)throw new V('Decode error - repeated field "graft" had too many elements');b.graft.push(s.ControlGraft.codec().decode(l,l.uint32(),{limits:d.limits?.graft$}));break}case 4:{if(d.limits?.prune!=null&&b.prune.length===d.limits.prune)throw new V('Decode error - repeated field "prune" had too many elements');b.prune.push(s.ControlPrune.codec().decode(l,l.uint32(),{limits:d.limits?.prune$}));break}case 5:{if(d.limits?.idontwant!=null&&b.idontwant.length===d.limits.idontwant)throw new V('Decode error - repeated field "idontwant" had too many elements');b.idontwant.push(s.ControlIDontWant.codec().decode(l,l.uint32(),{limits:d.limits?.idontwant$}));break}default:{l.skipType(x&7);break}}}return b},function*(l,h,d,b={}){let E={ihave:0,iwant:0,graft:0,prune:0,idontwant:0},x=h==null?l.len:l.pos+h;for(;l.pos<x;){let S=l.uint32();switch(S>>>3){case 1:{if(b.limits?.ihave!=null&&E.ihave===b.limits.ihave)throw new V('Streaming decode error - repeated field "ihave" had too many elements');for(let P of s.ControlIHave.codec().stream(l,l.uint32(),`${d}.ihave[]`,{limits:b.limits?.ihave$}))yield{...P,index:E.ihave};E.ihave++;break}case 2:{if(b.limits?.iwant!=null&&E.iwant===b.limits.iwant)throw new V('Streaming decode error - repeated field "iwant" had too many elements');for(let P of s.ControlIWant.codec().stream(l,l.uint32(),`${d}.iwant[]`,{limits:b.limits?.iwant$}))yield{...P,index:E.iwant};E.iwant++;break}case 3:{if(b.limits?.graft!=null&&E.graft===b.limits.graft)throw new V('Streaming decode error - repeated field "graft" had too many elements');for(let P of s.ControlGraft.codec().stream(l,l.uint32(),`${d}.graft[]`,{limits:b.limits?.graft$}))yield{...P,index:E.graft};E.graft++;break}case 4:{if(b.limits?.prune!=null&&E.prune===b.limits.prune)throw new V('Streaming decode error - repeated field "prune" had too many elements');for(let P of s.ControlPrune.codec().stream(l,l.uint32(),`${d}.prune[]`,{limits:b.limits?.prune$}))yield{...P,index:E.prune};E.prune++;break}case 5:{if(b.limits?.idontwant!=null&&E.idontwant===b.limits.idontwant)throw new V('Streaming decode error - repeated field "idontwant" had too many elements');for(let P of s.ControlIDontWant.codec().stream(l,l.uint32(),`${d}.idontwant[]`,{limits:b.limits?.idontwant$}))yield{...P,index:E.idontwant};E.idontwant++;break}default:{l.skipType(S&7);break}}}})),g);function w(l){return ye(l,u.codec())}u.encode=w;function y(l,h){return be(l,u.codec(),h)}u.decode=y;function I(l,h){return we(l,u.codec(),h)}u.stream=I})(r=s.ControlMessage||(s.ControlMessage={}));let n;(function(u){let g;u.codec=()=>(g==null&&(g=xe((l,h,d={})=>{if(d.lengthDelimited!==!1&&h.fork(),l.topicID!=null&&(h.uint32(10),h.string(l.topicID)),l.messageIDs!=null&&l.messageIDs.length>0)for(let b of l.messageIDs)h.uint32(18),h.bytes(b);d.lengthDelimited!==!1&&h.ldelim()},(l,h,d={})=>{let b={messageIDs:[]},E=h==null?l.len:l.pos+h;for(;l.pos<E;){let x=l.uint32();switch(x>>>3){case 1:{b.topicID=l.string();break}case 2:{if(d.limits?.messageIDs!=null&&b.messageIDs.length===d.limits.messageIDs)throw new V('Decode error - repeated field "messageIDs" had too many elements');b.messageIDs.push(l.bytes());break}default:{l.skipType(x&7);break}}}return b},function*(l,h,d,b={}){let E={messageIDs:0},x=h==null?l.len:l.pos+h;for(;l.pos<x;){let S=l.uint32();switch(S>>>3){case 1:{yield{field:`${d}.topicID`,value:l.string()};break}case 2:{if(b.limits?.messageIDs!=null&&E.messageIDs===b.limits.messageIDs)throw new V('Streaming decode error - repeated field "messageIDs" had too many elements');yield{field:`${d}.messageIDs[]`,index:E.messageIDs,value:l.bytes()},E.messageIDs++;break}default:{l.skipType(S&7);break}}}})),g);function w(l){return ye(l,u.codec())}u.encode=w;function y(l,h){return be(l,u.codec(),h)}u.decode=y;function I(l,h){return we(l,u.codec(),h)}u.stream=I})(n=s.ControlIHave||(s.ControlIHave={}));let i;(function(u){let g;u.codec=()=>(g==null&&(g=xe((l,h,d={})=>{if(d.lengthDelimited!==!1&&h.fork(),l.messageIDs!=null&&l.messageIDs.length>0)for(let b of l.messageIDs)h.uint32(10),h.bytes(b);d.lengthDelimited!==!1&&h.ldelim()},(l,h,d={})=>{let b={messageIDs:[]},E=h==null?l.len:l.pos+h;for(;l.pos<E;){let x=l.uint32();switch(x>>>3){case 1:{if(d.limits?.messageIDs!=null&&b.messageIDs.length===d.limits.messageIDs)throw new V('Decode error - repeated field "messageIDs" had too many elements');b.messageIDs.push(l.bytes());break}default:{l.skipType(x&7);break}}}return b},function*(l,h,d,b={}){let E={messageIDs:0},x=h==null?l.len:l.pos+h;for(;l.pos<x;){let S=l.uint32();switch(S>>>3){case 1:{if(b.limits?.messageIDs!=null&&E.messageIDs===b.limits.messageIDs)throw new V('Streaming decode error - repeated field "messageIDs" had too many elements');yield{field:`${d}.messageIDs[]`,index:E.messageIDs,value:l.bytes()},E.messageIDs++;break}default:{l.skipType(S&7);break}}}})),g);function w(l){return ye(l,u.codec())}u.encode=w;function y(l,h){return be(l,u.codec(),h)}u.decode=y;function I(l,h){return we(l,u.codec(),h)}u.stream=I})(i=s.ControlIWant||(s.ControlIWant={}));let o;(function(u){let g;u.codec=()=>(g==null&&(g=xe((l,h,d={})=>{d.lengthDelimited!==!1&&h.fork(),l.topicID!=null&&(h.uint32(10),h.string(l.topicID)),d.lengthDelimited!==!1&&h.ldelim()},(l,h,d={})=>{let b={},E=h==null?l.len:l.pos+h;for(;l.pos<E;){let x=l.uint32();switch(x>>>3){case 1:{b.topicID=l.string();break}default:{l.skipType(x&7);break}}}return b},function*(l,h,d,b={}){let E=h==null?l.len:l.pos+h;for(;l.pos<E;){let x=l.uint32();switch(x>>>3){case 1:{yield{field:`${d}.topicID`,value:l.string()};break}default:{l.skipType(x&7);break}}}})),g);function w(l){return ye(l,u.codec())}u.encode=w;function y(l,h){return be(l,u.codec(),h)}u.decode=y;function I(l,h){return we(l,u.codec(),h)}u.stream=I})(o=s.ControlGraft||(s.ControlGraft={}));let a;(function(u){let g;u.codec=()=>(g==null&&(g=xe((l,h,d={})=>{if(d.lengthDelimited!==!1&&h.fork(),l.topicID!=null&&(h.uint32(10),h.string(l.topicID)),l.peers!=null&&l.peers.length>0)for(let b of l.peers)h.uint32(18),s.PeerInfo.codec().encode(b,h);l.backoff!=null&&(h.uint32(24),h.uint64Number(l.backoff)),d.lengthDelimited!==!1&&h.ldelim()},(l,h,d={})=>{let b={peers:[]},E=h==null?l.len:l.pos+h;for(;l.pos<E;){let x=l.uint32();switch(x>>>3){case 1:{b.topicID=l.string();break}case 2:{if(d.limits?.peers!=null&&b.peers.length===d.limits.peers)throw new V('Decode error - repeated field "peers" had too many elements');b.peers.push(s.PeerInfo.codec().decode(l,l.uint32(),{limits:d.limits?.peers$}));break}case 3:{b.backoff=l.uint64Number();break}default:{l.skipType(x&7);break}}}return b},function*(l,h,d,b={}){let E={peers:0},x=h==null?l.len:l.pos+h;for(;l.pos<x;){let S=l.uint32();switch(S>>>3){case 1:{yield{field:`${d}.topicID`,value:l.string()};break}case 2:{if(b.limits?.peers!=null&&E.peers===b.limits.peers)throw new V('Streaming decode error - repeated field "peers" had too many elements');for(let P of s.PeerInfo.codec().stream(l,l.uint32(),`${d}.peers[]`,{limits:b.limits?.peers$}))yield{...P,index:E.peers};E.peers++;break}case 3:{yield{field:`${d}.backoff`,value:l.uint64Number()};break}default:{l.skipType(S&7);break}}}})),g);function w(l){return ye(l,u.codec())}u.encode=w;function y(l,h){return be(l,u.codec(),h)}u.decode=y;function I(l,h){return we(l,u.codec(),h)}u.stream=I})(a=s.ControlPrune||(s.ControlPrune={}));let c;(function(u){let g;u.codec=()=>(g==null&&(g=xe((l,h,d={})=>{d.lengthDelimited!==!1&&h.fork(),l.peerID!=null&&(h.uint32(10),h.bytes(l.peerID)),l.signedPeerRecord!=null&&(h.uint32(18),h.bytes(l.signedPeerRecord)),d.lengthDelimited!==!1&&h.ldelim()},(l,h,d={})=>{let b={},E=h==null?l.len:l.pos+h;for(;l.pos<E;){let x=l.uint32();switch(x>>>3){case 1:{b.peerID=l.bytes();break}case 2:{b.signedPeerRecord=l.bytes();break}default:{l.skipType(x&7);break}}}return b},function*(l,h,d,b={}){let E=h==null?l.len:l.pos+h;for(;l.pos<E;){let x=l.uint32();switch(x>>>3){case 1:{yield{field:`${d}.peerID`,value:l.bytes()};break}case 2:{yield{field:`${d}.signedPeerRecord`,value:l.bytes()};break}default:{l.skipType(x&7);break}}}})),g);function w(l){return ye(l,u.codec())}u.encode=w;function y(l,h){return be(l,u.codec(),h)}u.decode=y;function I(l,h){return we(l,u.codec(),h)}u.stream=I})(c=s.PeerInfo||(s.PeerInfo={}));let f;(function(u){let g;u.codec=()=>(g==null&&(g=xe((l,h,d={})=>{if(d.lengthDelimited!==!1&&h.fork(),l.messageIDs!=null&&l.messageIDs.length>0)for(let b of l.messageIDs)h.uint32(10),h.bytes(b);d.lengthDelimited!==!1&&h.ldelim()},(l,h,d={})=>{let b={messageIDs:[]},E=h==null?l.len:l.pos+h;for(;l.pos<E;){let x=l.uint32();switch(x>>>3){case 1:{if(d.limits?.messageIDs!=null&&b.messageIDs.length===d.limits.messageIDs)throw new V('Decode error - repeated field "messageIDs" had too many elements');b.messageIDs.push(l.bytes());break}default:{l.skipType(x&7);break}}}return b},function*(l,h,d,b={}){let E={messageIDs:0},x=h==null?l.len:l.pos+h;for(;l.pos<x;){let S=l.uint32();switch(S>>>3){case 1:{if(b.limits?.messageIDs!=null&&E.messageIDs===b.limits.messageIDs)throw new V('Streaming decode error - repeated field "messageIDs" had too many elements');yield{field:`${d}.messageIDs[]`,index:E.messageIDs,value:l.bytes()},E.messageIDs++;break}default:{l.skipType(S&7);break}}}})),g);function w(l){return ye(l,u.codec())}u.encode=w;function y(l,h){return be(l,u.codec(),h)}u.decode=y;function I(l,h){return we(l,u.codec(),h)}u.stream=I})(f=s.ControlIDontWant||(s.ControlIDontWant={}));let p;s.codec=()=>(p==null&&(p=xe((u,g,w={})=>{if(w.lengthDelimited!==!1&&g.fork(),u.subscriptions!=null&&u.subscriptions.length>0)for(let y of u.subscriptions)g.uint32(10),s.SubOpts.codec().encode(y,g);if(u.messages!=null&&u.messages.length>0)for(let y of u.messages)g.uint32(18),s.Message.codec().encode(y,g);u.control!=null&&(g.uint32(26),s.ControlMessage.codec().encode(u.control,g)),w.lengthDelimited!==!1&&g.ldelim()},(u,g,w={})=>{let y={subscriptions:[],messages:[]},I=g==null?u.len:u.pos+g;for(;u.pos<I;){let l=u.uint32();switch(l>>>3){case 1:{if(w.limits?.subscriptions!=null&&y.subscriptions.length===w.limits.subscriptions)throw new V('Decode error - repeated field "subscriptions" had too many elements');y.subscriptions.push(s.SubOpts.codec().decode(u,u.uint32(),{limits:w.limits?.subscriptions$}));break}case 2:{if(w.limits?.messages!=null&&y.messages.length===w.limits.messages)throw new V('Decode error - repeated field "messages" had too many elements');y.messages.push(s.Message.codec().decode(u,u.uint32(),{limits:w.limits?.messages$}));break}case 3:{y.control=s.ControlMessage.codec().decode(u,u.uint32(),{limits:w.limits?.control});break}default:{u.skipType(l&7);break}}}return y},function*(u,g,w,y={}){let I={subscriptions:0,messages:0},l=g==null?u.len:u.pos+g;for(;u.pos<l;){let h=u.uint32();switch(h>>>3){case 1:{if(y.limits?.subscriptions!=null&&I.subscriptions===y.limits.subscriptions)throw new V('Streaming decode error - repeated field "subscriptions" had too many elements');for(let d of s.SubOpts.codec().stream(u,u.uint32(),`${w}.subscriptions[]`,{limits:y.limits?.subscriptions$}))yield{...d,index:I.subscriptions};I.subscriptions++;break}case 2:{if(y.limits?.messages!=null&&I.messages===y.limits.messages)throw new V('Streaming decode error - repeated field "messages" had too many elements');for(let d of s.Message.codec().stream(u,u.uint32(),`${w}.messages[]`,{limits:y.limits?.messages$}))yield{...d,index:I.messages};I.messages++;break}case 3:{yield*s.ControlMessage.codec().stream(u,u.uint32(),`${w}.control`,{limits:y.limits?.control});break}default:{u.skipType(h&7);break}}}})),p);function m(u){return ye(u,s.codec())}s.encode=m;function _(u,g){return be(u,s.codec(),g)}s.decode=_;function v(u,g){return we(u,s.codec(),g)}s.stream=v})(st||(st={}));var mr=class{gossip;msgs=new Map;msgIdToStrFn;history=[];notValidatedCount=0;constructor(e,t,r){this.gossip=e,this.msgIdToStrFn=r;for(let n=0;n<t;n++)this.history[n]=[]}get size(){return this.msgs.size}put(e,t,r=!1){let{msgIdStr:n}=e;return this.msgs.has(n)?!1:(this.msgs.set(n,{message:t,validated:r,originatingPeers:new Set,iwantCounts:new Map}),this.history[0].push({...e,topic:t.topic}),r||this.notValidatedCount++,!0)}observeDuplicate(e,t){let r=this.msgs.get(e);r!=null&&!r.validated&&r.originatingPeers.add(t)}get(e){return this.msgs.get(this.msgIdToStrFn(e))?.message}getWithIWantCount(e,t){let r=this.msgs.get(e);if(r==null)return null;let n=(r.iwantCounts.get(t)??0)+1;return r.iwantCounts.set(t,n),{msg:r.message,count:n}}getGossipIDs(e){let t=new Map;for(let r=0;r<this.gossip;r++)this.history[r].forEach(n=>{if((this.msgs.get(n.msgIdStr)?.validated??!1)&&e.has(n.topic)){let o=t.get(n.topic);o==null&&(o=[],t.set(n.topic,o)),o.push(n.msgId)}});return t}validate(e){let t=this.msgs.get(e);if(t==null)return null;t.validated||this.notValidatedCount--;let{message:r,originatingPeers:n}=t;return t.validated=!0,t.originatingPeers=new Set,{message:r,originatingPeers:n}}shift(){this.history[this.history.length-1].forEach(t=>{let r=this.msgs.get(t.msgIdStr);r!=null&&(this.msgs.delete(t.msgIdStr),r.validated||this.notValidatedCount--)}),this.history.pop(),this.history.unshift([])}remove(e){let t=this.msgs.get(e);return t==null?null:(this.msgs.delete(e),t)}};var Aa;(function(s){s.StrictSign="StrictSign",s.StrictNoSign="StrictNoSign"})(Aa||(Aa={}));var pt;(function(s){s[s.Signing=0]="Signing",s[s.Anonymous=1]="Anonymous"})(pt||(pt={}));var ve;(function(s){s.Error="error",s.Ignore="ignore",s.Reject="reject",s.Blacklisted="blacklisted"})(ve||(ve={}));var de;(function(s){s.InvalidSignature="invalid_signature",s.InvalidSeqno="invalid_seqno",s.InvalidPeerId="invalid_peerid",s.SignaturePresent="signature_present",s.SeqnoPresent="seqno_present",s.FromPresent="from_present",s.TransformFailed="transform_failed"})(de||(de={}));var pe;(function(s){s.duplicate="duplicate",s.invalid="invalid",s.valid="valid"})(pe||(pe={}));function bi(s){switch(s){case me.Ignore:return ve.Ignore;case me.Reject:return ve.Reject;default:throw new Error("Unreachable")}}var Ma;(function(s){s.forward="forward",s.publish="publish"})(Ma||(Ma={}));var Ee;(function(s){s.Fanout="fanout",s.Random="random",s.Subscribed="subscribed",s.Outbound="outbound",s.NotEnough="not_enough",s.Opportunistic="opportunistic"})(Ee||(Ee={}));var Ce;(function(s){s.Dc="disconnected",s.BadScore="bad_score",s.Prune="prune",s.Excess="excess"})(Ce||(Ce={}));var ts;(function(s){s.GraftBackoff="graft_backoff",s.BrokenPromise="broken_promise",s.MessageDeficit="message_deficit",s.IPColocation="IP_colocation"})(ts||(ts={}));var ss;(function(s){s.LowScore="low_score",s.MaxIhave="max_ihave",s.MaxIasked="max_iasked"})(ss||(ss={}));var es;(function(s){s.graylist="graylist",s.publish="publish",s.gossip="gossip",s.mesh="mesh"})(es||(es={}));function Pa(s,e,t){return{protocolsEnabled:s.gauge({name:"gossipsub_protocol",help:"Status of enabled protocols",labelNames:["protocol"]}),topicSubscriptionStatus:s.gauge({name:"gossipsub_topic_subscription_status",help:"Status of our subscription to this topic",labelNames:["topicStr"]}),topicPeersCount:s.gauge({name:"gossipsub_topic_peer_count",help:"Number of peers subscribed to each topic",labelNames:["topicStr"]}),meshPeerCounts:s.gauge({name:"gossipsub_mesh_peer_count",help:"Number of peers in our mesh",labelNames:["topicStr"]}),meshPeerInclusionEventsFanout:s.gauge({name:"gossipsub_mesh_peer_inclusion_events_fanout_total",help:"Number of times we include peers in a topic mesh for fanout reasons",labelNames:["topic"]}),meshPeerInclusionEventsRandom:s.gauge({name:"gossipsub_mesh_peer_inclusion_events_random_total",help:"Number of times we include peers in a topic mesh for random reasons",labelNames:["topic"]}),meshPeerInclusionEventsSubscribed:s.gauge({name:"gossipsub_mesh_peer_inclusion_events_subscribed_total",help:"Number of times we include peers in a topic mesh for subscribed reasons",labelNames:["topic"]}),meshPeerInclusionEventsOutbound:s.gauge({name:"gossipsub_mesh_peer_inclusion_events_outbound_total",help:"Number of times we include peers in a topic mesh for outbound reasons",labelNames:["topic"]}),meshPeerInclusionEventsNotEnough:s.gauge({name:"gossipsub_mesh_peer_inclusion_events_not_enough_total",help:"Number of times we include peers in a topic mesh for not_enough reasons",labelNames:["topic"]}),meshPeerInclusionEventsOpportunistic:s.gauge({name:"gossipsub_mesh_peer_inclusion_events_opportunistic_total",help:"Number of times we include peers in a topic mesh for opportunistic reasons",labelNames:["topic"]}),meshPeerInclusionEventsUnknown:s.gauge({name:"gossipsub_mesh_peer_inclusion_events_unknown_total",help:"Number of times we include peers in a topic mesh for unknown reasons",labelNames:["topic"]}),meshPeerChurnEventsDisconnected:s.gauge({name:"gossipsub_peer_churn_events_disconnected_total",help:"Number of times we remove peers in a topic mesh for disconnected reasons",labelNames:["topic"]}),meshPeerChurnEventsBadScore:s.gauge({name:"gossipsub_peer_churn_events_bad_score_total",help:"Number of times we remove peers in a topic mesh for bad_score reasons",labelNames:["topic"]}),meshPeerChurnEventsPrune:s.gauge({name:"gossipsub_peer_churn_events_prune_total",help:"Number of times we remove peers in a topic mesh for prune reasons",labelNames:["topic"]}),meshPeerChurnEventsExcess:s.gauge({name:"gossipsub_peer_churn_events_excess_total",help:"Number of times we remove peers in a topic mesh for excess reasons",labelNames:["topic"]}),meshPeerChurnEventsUnknown:s.gauge({name:"gossipsub_peer_churn_events_unknown_total",help:"Number of times we remove peers in a topic mesh for unknown reasons",labelNames:["topic"]}),peersPerProtocol:s.gauge({name:"gossipsub_peers_per_protocol_count",help:"Peers connected for each topic",labelNames:["protocol"]}),heartbeatDuration:s.histogram({name:"gossipsub_heartbeat_duration_seconds",help:"The time it takes to complete one iteration of the heartbeat",buckets:[.01,.1,1]}),heartbeatSkipped:s.gauge({name:"gossipsub_heartbeat_skipped",help:"Heartbeat run took longer than heartbeat interval so next is skipped"}),acceptedMessagesTotal:s.gauge({name:"gossipsub_accepted_messages_total",help:"Total accepted messages for each topic",labelNames:["topic"]}),ignoredMessagesTotal:s.gauge({name:"gossipsub_ignored_messages_total",help:"Total ignored messages for each topic",labelNames:["topic"]}),rejectedMessagesTotal:s.gauge({name:"gossipsub_rejected_messages_total",help:"Total rejected messages for each topic",labelNames:["topic"]}),unknownValidationResultsTotal:s.gauge({name:"gossipsub_unknown_validation_results_total",help:"Total unknown validation results for each topic",labelNames:["topic"]}),asyncValidationMcacheHit:s.gauge({name:"gossipsub_async_validation_mcache_hit_total",help:"Async validation result reported by the user layer",labelNames:["hit"]}),asyncValidationDelayFromFirstSeenSec:s.histogram({name:"gossipsub_async_validation_delay_from_first_seen",help:"Async validation report delay from first seen in second",buckets:[.01,.03,.1,.3,1,3,10]}),asyncValidationUnknownFirstSeen:s.gauge({name:"gossipsub_async_validation_unknown_first_seen_count_total",help:"Async validation report unknown first seen value for message"}),peerReadStreamError:s.gauge({name:"gossipsub_peer_read_stream_err_count_total",help:"Peer read stream error"}),rpcRecvBytes:s.gauge({name:"gossipsub_rpc_recv_bytes_total",help:"RPC recv"}),rpcRecvCount:s.gauge({name:"gossipsub_rpc_recv_count_total",help:"RPC recv"}),rpcRecvSubscription:s.gauge({name:"gossipsub_rpc_recv_subscription_total",help:"RPC recv"}),rpcRecvMessage:s.gauge({name:"gossipsub_rpc_recv_message_total",help:"RPC recv"}),rpcRecvControl:s.gauge({name:"gossipsub_rpc_recv_control_total",help:"RPC recv"}),rpcRecvIHave:s.gauge({name:"gossipsub_rpc_recv_ihave_total",help:"RPC recv"}),rpcRecvIWant:s.gauge({name:"gossipsub_rpc_recv_iwant_total",help:"RPC recv"}),rpcRecvGraft:s.gauge({name:"gossipsub_rpc_recv_graft_total",help:"RPC recv"}),rpcRecvPrune:s.gauge({name:"gossipsub_rpc_recv_prune_total",help:"RPC recv"}),rpcDataError:s.gauge({name:"gossipsub_rpc_data_err_count_total",help:"RPC data error"}),rpcRecvError:s.gauge({name:"gossipsub_rpc_recv_err_count_total",help:"RPC recv error"}),rpcRecvNotAccepted:s.gauge({name:"gossipsub_rpc_rcv_not_accepted_total",help:"Total count of RPC dropped because acceptFrom() == false"}),rpcSentBytes:s.gauge({name:"gossipsub_rpc_sent_bytes_total",help:"RPC sent"}),rpcSentCount:s.gauge({name:"gossipsub_rpc_sent_count_total",help:"RPC sent"}),rpcSentSubscription:s.gauge({name:"gossipsub_rpc_sent_subscription_total",help:"RPC sent"}),rpcSentMessage:s.gauge({name:"gossipsub_rpc_sent_message_total",help:"RPC sent"}),rpcSentControl:s.gauge({name:"gossipsub_rpc_sent_control_total",help:"RPC sent"}),rpcSentIHave:s.gauge({name:"gossipsub_rpc_sent_ihave_total",help:"RPC sent"}),rpcSentIWant:s.gauge({name:"gossipsub_rpc_sent_iwant_total",help:"RPC sent"}),rpcSentGraft:s.gauge({name:"gossipsub_rpc_sent_graft_total",help:"RPC sent"}),rpcSentPrune:s.gauge({name:"gossipsub_rpc_sent_prune_total",help:"RPC sent"}),rpcSentIDontWant:s.gauge({name:"gossipsub_rpc_sent_idontwant_total",help:"RPC sent"}),msgPublishCount:s.gauge({name:"gossipsub_msg_publish_count_total",help:"Total count of msg published by topic",labelNames:["topic"]}),msgPublishPeersByTopic:s.gauge({name:"gossipsub_msg_publish_peers_total",help:"Total count of peers that we publish a msg to",labelNames:["topic"]}),directPeersPublishedTotal:s.gauge({name:"gossipsub_direct_peers_published_total",help:"Total direct peers that we publish a msg to",labelNames:["topic"]}),floodsubPeersPublishedTotal:s.gauge({name:"gossipsub_floodsub_peers_published_total",help:"Total floodsub peers that we publish a msg to",labelNames:["topic"]}),meshPeersPublishedTotal:s.gauge({name:"gossipsub_mesh_peers_published_total",help:"Total mesh peers that we publish a msg to",labelNames:["topic"]}),fanoutPeersPublishedTotal:s.gauge({name:"gossipsub_fanout_peers_published_total",help:"Total fanout peers that we publish a msg to",labelNames:["topic"]}),msgPublishBytes:s.gauge({name:"gossipsub_msg_publish_bytes_total",help:"Total count of msg publish data.length bytes",labelNames:["topic"]}),msgPublishTime:s.histogram({name:"gossipsub_msg_publish_seconds",help:"Total time in seconds to publish a message",buckets:[.001,.002,.005,.01,.1,.5,1],labelNames:["topic"]}),msgForwardCount:s.gauge({name:"gossipsub_msg_forward_count_total",help:"Total count of msg forwarded by topic",labelNames:["topic"]}),msgForwardPeers:s.gauge({name:"gossipsub_msg_forward_peers_total",help:"Total count of peers that we forward a msg to",labelNames:["topic"]}),msgReceivedPreValidation:s.gauge({name:"gossipsub_msg_received_prevalidation_total",help:"Total count of recv msgs before any validation",labelNames:["topic"]}),msgReceivedError:s.gauge({name:"gossipsub_msg_received_error_total",help:"Total count of recv msgs error",labelNames:["topic"]}),prevalidationInvalidTotal:s.gauge({name:"gossipsub_pre_validation_invalid_total",help:"Total count of invalid messages received",labelNames:["topic"]}),prevalidationValidTotal:s.gauge({name:"gossipsub_pre_validation_valid_total",help:"Total count of valid messages received",labelNames:["topic"]}),prevalidationDuplicateTotal:s.gauge({name:"gossipsub_pre_validation_duplicate_total",help:"Total count of duplicate messages received",labelNames:["topic"]}),prevalidationUnknownTotal:s.gauge({name:"gossipsub_pre_validation_unknown_status_total",help:"Total count of unknown_status messages received",labelNames:["topic"]}),msgReceivedInvalid:s.gauge({name:"gossipsub_msg_received_invalid_total",help:"Tracks specific reason of invalid",labelNames:["error"]}),msgReceivedInvalidByTopic:s.gauge({name:"gossipsub_msg_received_invalid_by_topic_total",help:"Tracks specific invalid message by topic",labelNames:["topic"]}),duplicateMsgDeliveryDelay:s.histogram({name:"gossisub_duplicate_msg_delivery_delay_seconds",help:"Time since the 1st duplicated message validated",labelNames:["topic"],buckets:[.25*t.maxMeshMessageDeliveriesWindowSec,.5*t.maxMeshMessageDeliveriesWindowSec,Number(t.maxMeshMessageDeliveriesWindowSec),2*t.maxMeshMessageDeliveriesWindowSec,4*t.maxMeshMessageDeliveriesWindowSec]}),duplicateMsgLateDelivery:s.gauge({name:"gossisub_duplicate_msg_late_delivery_total",help:"Total count of late duplicate message delivery by topic, which triggers P3 penalty",labelNames:["topic"]}),duplicateMsgIgnored:s.gauge({name:"gossisub_ignored_published_duplicate_msgs_total",help:"Total count of published duplicate message ignored by topic",labelNames:["topic"]}),scoreFnCalls:s.gauge({name:"gossipsub_score_fn_calls_total",help:"Total times score() is called"}),scoreFnRuns:s.gauge({name:"gossipsub_score_fn_runs_total",help:"Total times score() call actually computed computeScore(), no cache"}),scoreCachedDelta:s.histogram({name:"gossipsub_score_cache_delta",help:"Delta of score between cached values that expired",buckets:[10,100,1e3]}),peersByScoreThreshold:s.gauge({name:"gossipsub_peers_by_score_threshold_count",help:"Current count of peers by score threshold",labelNames:["threshold"]}),score:s.avgMinMax({name:"gossipsub_score",help:"Avg min max of gossip scores"}),scoreWeights:s.avgMinMax({name:"gossipsub_score_weights",help:"Separate score weights",labelNames:["topic","p"]}),scorePerMesh:s.avgMinMax({name:"gossipsub_score_per_mesh",help:"Histogram of the scores for each mesh topic",labelNames:["topic"]}),scoringPenalties:s.gauge({name:"gossipsub_scoring_penalties_total",help:"A counter of the kind of penalties being applied to peers",labelNames:["penalty"]}),behaviourPenalty:s.histogram({name:"gossipsub_peer_stat_behaviour_penalty",help:"Current peer stat behaviour_penalty at each scrape",buckets:[.25*t.behaviourPenaltyThreshold,.5*t.behaviourPenaltyThreshold,Number(t.behaviourPenaltyThreshold),2*t.behaviourPenaltyThreshold,4*t.behaviourPenaltyThreshold]}),ihaveRcvIgnored:s.gauge({name:"gossipsub_ihave_rcv_ignored_total",help:"Total received IHAVE messages that we ignore for some reason",labelNames:["reason"]}),ihaveRcvMsgids:s.gauge({name:"gossipsub_ihave_rcv_msgids_total",help:"Total received IHAVE messages by topic",labelNames:["topic"]}),ihaveRcvNotSeenMsgids:s.gauge({name:"gossipsub_ihave_rcv_not_seen_msgids_total",help:"Total messages per topic we do not have, not actual requests",labelNames:["topic"]}),iwantRcvMsgids:s.gauge({name:"gossipsub_iwant_rcv_msgids_total",help:"Total received IWANT messages by topic",labelNames:["topic"]}),iwantRcvDonthaveMsgids:s.gauge({name:"gossipsub_iwant_rcv_dont_have_msgids_total",help:"Total requested messageIDs that we do not have"}),idontwantRcvMsgids:s.gauge({name:"gossipsub_idontwant_rcv_msgids_total",help:"Total received IDONTWANT messages"}),idontwantRcvDonthaveMsgids:s.gauge({name:"gossipsub_idontwant_rcv_dont_have_msgids_total",help:"Total received IDONTWANT messageIDs that we do not have in mcache"}),iwantPromiseStarted:s.gauge({name:"gossipsub_iwant_promise_sent_total",help:"Total count of started IWANT promises"}),iwantPromiseResolved:s.gauge({name:"gossipsub_iwant_promise_resolved_total",help:"Total count of resolved IWANT promises"}),iwantPromiseResolvedFromDuplicate:s.gauge({name:"gossipsub_iwant_promise_resolved_from_duplicate_total",help:"Total count of resolved IWANT promises from duplicate messages"}),iwantPromiseResolvedPeers:s.gauge({name:"gossipsub_iwant_promise_resolved_peers",help:"Total count of peers we have asked IWANT promises that are resolved"}),iwantPromiseBroken:s.gauge({name:"gossipsub_iwant_promise_broken",help:"Total count of broken IWANT promises"}),iwantMessagePruned:s.gauge({name:"gossipsub_iwant_message_pruned",help:"Total count of pruned IWANT messages"}),iwantPromiseDeliveryTime:s.histogram({name:"gossipsub_iwant_promise_delivery_seconds",help:"Histogram of delivery time of resolved IWANT promises",buckets:[.5*t.gossipPromiseExpireSec,Number(t.gossipPromiseExpireSec),2*t.gossipPromiseExpireSec,4*t.gossipPromiseExpireSec]}),iwantPromiseUntracked:s.gauge({name:"gossip_iwant_promise_untracked",help:"Total count of untracked IWANT promise"}),connectedPeersBackoffSec:s.histogram({name:"gossipsub_connected_peers_backoff_seconds",help:"Backoff time in seconds",buckets:[1,2,4,10,20,60,120]}),cacheSize:s.gauge({name:"gossipsub_cache_size",help:"Unbounded cache sizes",labelNames:["cache"]}),mcacheSize:s.gauge({name:"gossipsub_mcache_size",help:"Current mcache msg count"}),mcacheNotValidatedCount:s.gauge({name:"gossipsub_mcache_not_validated_count",help:"Current mcache msg count not validated"}),fastMsgIdCacheCollision:s.gauge({name:"gossipsub_fastmsgid_cache_collision_total",help:"Total count of key collisions on fastmsgid cache put"}),newConnectionCount:s.gauge({name:"gossipsub_new_connection_total",help:"Total new connection by status",labelNames:["status"]}),topicStrToLabel:e,toTopic(r){return this.topicStrToLabel.get(r)??r},onJoin(r){this.topicSubscriptionStatus.set({topicStr:r},1),this.meshPeerCounts.set({topicStr:r},0)},onLeave(r){this.topicSubscriptionStatus.set({topicStr:r},0),this.meshPeerCounts.set({topicStr:r},0)},onAddToMesh(r,n,i){let o=this.toTopic(r);switch(n){case Ee.Fanout:this.meshPeerInclusionEventsFanout.inc({topic:o},i);break;case Ee.Random:this.meshPeerInclusionEventsRandom.inc({topic:o},i);break;case Ee.Subscribed:this.meshPeerInclusionEventsSubscribed.inc({topic:o},i);break;case Ee.Outbound:this.meshPeerInclusionEventsOutbound.inc({topic:o},i);break;case Ee.NotEnough:this.meshPeerInclusionEventsNotEnough.inc({topic:o},i);break;case Ee.Opportunistic:this.meshPeerInclusionEventsOpportunistic.inc({topic:o},i);break;default:this.meshPeerInclusionEventsUnknown.inc({topic:o},i);break}},onRemoveFromMesh(r,n,i){let o=this.toTopic(r);switch(n){case Ce.Dc:this.meshPeerChurnEventsDisconnected.inc({topic:o},i);break;case Ce.BadScore:this.meshPeerChurnEventsBadScore.inc({topic:o},i);break;case Ce.Prune:this.meshPeerChurnEventsPrune.inc({topic:o},i);break;case Ce.Excess:this.meshPeerChurnEventsExcess.inc({topic:o},i);break;default:this.meshPeerChurnEventsUnknown.inc({topic:o},i);break}},onReportValidation(r,n,i){if(this.asyncValidationMcacheHit.inc({hit:r!=null?"hit":"miss"}),r!=null){let o=this.toTopic(r.message.topic);switch(n){case me.Accept:this.acceptedMessagesTotal.inc({topic:o});break;case me.Ignore:this.ignoredMessagesTotal.inc({topic:o});break;case me.Reject:this.rejectedMessagesTotal.inc({topic:o});break;default:this.unknownValidationResultsTotal.inc({topic:o});break}}i!=null?this.asyncValidationDelayFromFirstSeenSec.observe((Date.now()-i)/1e3):this.asyncValidationUnknownFirstSeen.inc()},onScorePenalty(r){this.scoringPenalties.inc({penalty:r},1)},onIhaveRcv(r,n,i){let o=this.toTopic(r);this.ihaveRcvMsgids.inc({topic:o},n),this.ihaveRcvNotSeenMsgids.inc({topic:o},i)},onIwantRcv(r,n){for(let[i,o]of r){let a=this.toTopic(i);this.iwantRcvMsgids.inc({topic:a},o)}this.iwantRcvDonthaveMsgids.inc(n)},onIdontwantRcv(r,n){this.idontwantRcvMsgids.inc(r),this.idontwantRcvDonthaveMsgids.inc(n)},onForwardMsg(r,n){let i=this.toTopic(r);this.msgForwardCount.inc({topic:i},1),this.msgForwardPeers.inc({topic:i},n)},onPublishMsg(r,n,i,o,a){let c=this.toTopic(r);this.msgPublishCount.inc({topic:c},1),this.msgPublishBytes.inc({topic:c},i*o),this.msgPublishPeersByTopic.inc({topic:c},i),this.directPeersPublishedTotal.inc({topic:c},n.direct),this.floodsubPeersPublishedTotal.inc({topic:c},n.floodsub),this.meshPeersPublishedTotal.inc({topic:c},n.mesh),this.fanoutPeersPublishedTotal.inc({topic:c},n.fanout),this.msgPublishTime.observe({topic:c},a/1e3)},onMsgRecvPreValidation(r){let n=this.toTopic(r);this.msgReceivedPreValidation.inc({topic:n},1)},onMsgRecvError(r){let n=this.toTopic(r);this.msgReceivedError.inc({topic:n},1)},onPrevalidationResult(r,n){let i=this.toTopic(r);switch(n){case pe.duplicate:this.prevalidationDuplicateTotal.inc({topic:i});break;case pe.invalid:this.prevalidationInvalidTotal.inc({topic:i});break;case pe.valid:this.prevalidationValidTotal.inc({topic:i});break;default:this.prevalidationUnknownTotal.inc({topic:i});break}},onMsgRecvInvalid(r,n){let i=this.toTopic(r),o=n.reason===ve.Error?n.error:n.reason;this.msgReceivedInvalid.inc({error:o},1),this.msgReceivedInvalidByTopic.inc({topic:i},1)},onDuplicateMsgDelivery(r,n,i){let o=this.toTopic(r);this.duplicateMsgDeliveryDelay.observe({topic:o},n/1e3),i&&this.duplicateMsgLateDelivery.inc({topic:o},1)},onPublishDuplicateMsg(r){let n=this.toTopic(r);this.duplicateMsgIgnored.inc({topic:n},1)},onPeerReadStreamError(){this.peerReadStreamError.inc(1)},onRpcRecvError(){this.rpcRecvError.inc(1)},onRpcDataError(){this.rpcDataError.inc(1)},onRpcRecv(r,n){this.rpcRecvBytes.inc(n),this.rpcRecvCount.inc(1),r.subscriptions!=null&&this.rpcRecvSubscription.inc(r.subscriptions.length),r.messages!=null&&this.rpcRecvMessage.inc(r.messages.length),r.control!=null&&(this.rpcRecvControl.inc(1),r.control.ihave!=null&&this.rpcRecvIHave.inc(r.control.ihave.length),r.control.iwant!=null&&this.rpcRecvIWant.inc(r.control.iwant.length),r.control.graft!=null&&this.rpcRecvGraft.inc(r.control.graft.length),r.control.prune!=null&&this.rpcRecvPrune.inc(r.control.prune.length))},onRpcSent(r,n){if(this.rpcSentBytes.inc(n),this.rpcSentCount.inc(1),r.subscriptions!=null&&this.rpcSentSubscription.inc(r.subscriptions.length),r.messages!=null&&this.rpcSentMessage.inc(r.messages.length),r.control!=null){let i=r.control.ihave?.length??0,o=r.control.iwant?.length??0,a=r.control.graft?.length??0,c=r.control.prune?.length??0,f=r.control.idontwant?.length??0;i>0&&this.rpcSentIHave.inc(i),o>0&&this.rpcSentIWant.inc(o),a>0&&this.rpcSentGraft.inc(a),c>0&&this.rpcSentPrune.inc(c),f>0&&this.rpcSentIDontWant.inc(f),(i>0||o>0||a>0||c>0||f>0)&&this.rpcSentControl.inc(1)}},registerScores(r,n){let i=0,o=0,a=0,c=0;for(let f of r)f>=n.graylistThreshold&&i++,f>=n.publishThreshold&&o++,f>=n.gossipThreshold&&a++,f>=0&&c++;this.peersByScoreThreshold.set({threshold:es.graylist},i),this.peersByScoreThreshold.set({threshold:es.publish},o),this.peersByScoreThreshold.set({threshold:es.gossip},a),this.peersByScoreThreshold.set({threshold:es.mesh},c),this.score.set(r)},registerScoreWeights(r){for(let[n,i]of r.byTopic)this.scoreWeights.set({topic:n,p:"p1"},i.p1w),this.scoreWeights.set({topic:n,p:"p2"},i.p2w),this.scoreWeights.set({topic:n,p:"p3"},i.p3w),this.scoreWeights.set({topic:n,p:"p3b"},i.p3bw),this.scoreWeights.set({topic:n,p:"p4"},i.p4w);this.scoreWeights.set({p:"p5"},r.p5w),this.scoreWeights.set({p:"p6"},r.p6w),this.scoreWeights.set({p:"p7"},r.p7w)},registerScorePerMesh(r,n){let i=new Map;r.forEach((o,a)=>{let c=this.topicStrToLabel.get(a)??"unknown",f=i.get(c);f==null&&(f=new Set,i.set(c,f)),o.forEach(p=>f?.add(p))});for(let[o,a]of i){let c=[];a.forEach(f=>{c.push(n.get(f)??0)}),this.scorePerMesh.set({topic:o},c)}}}}var H=class extends Error{static name="InvalidPeerScoreParamsError";constructor(e="Invalid peer score params"){super(e),this.name="InvalidPeerScoreParamsError"}};var Wu={topics:{},topicScoreCap:10,appSpecificScore:()=>0,appSpecificWeight:10,IPColocationFactorWeight:-5,IPColocationFactorThreshold:10,IPColocationFactorWhitelist:new Set,behaviourPenaltyWeight:-10,behaviourPenaltyThreshold:0,behaviourPenaltyDecay:.2,decayInterval:1e3,decayToZero:.1,retainScore:3600*1e3},$u={topicWeight:.5,timeInMeshWeight:1,timeInMeshQuantum:1,timeInMeshCap:3600,firstMessageDeliveriesWeight:1,firstMessageDeliveriesDecay:.5,firstMessageDeliveriesCap:2e3,meshMessageDeliveriesWeight:-1,meshMessageDeliveriesDecay:.5,meshMessageDeliveriesCap:100,meshMessageDeliveriesThreshold:20,meshMessageDeliveriesWindow:10,meshMessageDeliveriesActivation:5e3,meshFailurePenaltyWeight:-1,meshFailurePenaltyDecay:.5,invalidMessageDeliveriesWeight:-1,invalidMessageDeliveriesDecay:.3};function ka(s={}){return{...Wu,...s,topics:s.topics!=null?Object.entries(s.topics).reduce((e,[t,r])=>(e[t]=Zu(r),e),{}):{}}}function Zu(s={}){return{...$u,...s}}function La(s){for(let[e,t]of Object.entries(s.topics))try{ju(t)}catch(r){throw new H(`invalid score parameters for topic ${e}: ${r.message}`)}if(s.topicScoreCap<0)throw new H("invalid topic score cap; must be positive (or 0 for no cap)");if(s.appSpecificScore===null||s.appSpecificScore===void 0)throw new H("missing application specific score function");if(s.IPColocationFactorWeight>0)throw new H("invalid IPColocationFactorWeight; must be negative (or 0 to disable)");if(s.IPColocationFactorWeight!==0&&s.IPColocationFactorThreshold<1)throw new H("invalid IPColocationFactorThreshold; must be at least 1");if(s.behaviourPenaltyWeight>0)throw new H("invalid BehaviourPenaltyWeight; must be negative (or 0 to disable)");if(s.behaviourPenaltyWeight!==0&&(s.behaviourPenaltyDecay<=0||s.behaviourPenaltyDecay>=1))throw new H("invalid BehaviourPenaltyDecay; must be between 0 and 1");if(s.decayInterval<1e3)throw new H("invalid DecayInterval; must be at least 1s");if(s.decayToZero<=0||s.decayToZero>=1)throw new H("invalid DecayToZero; must be between 0 and 1")}function ju(s){if(s.topicWeight<0)throw new H("invalid topic weight; must be >= 0");if(s.timeInMeshQuantum===0)throw new H("invalid TimeInMeshQuantum; must be non zero");if(s.timeInMeshWeight<0)throw new H("invalid TimeInMeshWeight; must be positive (or 0 to disable)");if(s.timeInMeshWeight!==0&&s.timeInMeshQuantum<=0)throw new H("invalid TimeInMeshQuantum; must be positive");if(s.timeInMeshWeight!==0&&s.timeInMeshCap<=0)throw new H("invalid TimeInMeshCap; must be positive");if(s.firstMessageDeliveriesWeight<0)throw new H("invallid FirstMessageDeliveriesWeight; must be positive (or 0 to disable)");if(s.firstMessageDeliveriesWeight!==0&&(s.firstMessageDeliveriesDecay<=0||s.firstMessageDeliveriesDecay>=1))throw new H("invalid FirstMessageDeliveriesDecay; must be between 0 and 1");if(s.firstMessageDeliveriesWeight!==0&&s.firstMessageDeliveriesCap<=0)throw new H("invalid FirstMessageDeliveriesCap; must be positive");if(s.meshMessageDeliveriesWeight>0)throw new H("invalid MeshMessageDeliveriesWeight; must be negative (or 0 to disable)");if(s.meshMessageDeliveriesWeight!==0&&(s.meshMessageDeliveriesDecay<=0||s.meshMessageDeliveriesDecay>=1))throw new H("invalid MeshMessageDeliveriesDecay; must be between 0 and 1");if(s.meshMessageDeliveriesWeight!==0&&s.meshMessageDeliveriesCap<=0)throw new H("invalid MeshMessageDeliveriesCap; must be positive");if(s.meshMessageDeliveriesWeight!==0&&s.meshMessageDeliveriesThreshold<=0)throw new H("invalid MeshMessageDeliveriesThreshold; must be positive");if(s.meshMessageDeliveriesWindow<0)throw new H("invalid MeshMessageDeliveriesWindow; must be non-negative");if(s.meshMessageDeliveriesWeight!==0&&s.meshMessageDeliveriesActivation<1e3)throw new H("invalid MeshMessageDeliveriesActivation; must be at least 1s");if(s.meshFailurePenaltyWeight>0)throw new H("invalid MeshFailurePenaltyWeight; must be negative (or 0 to disable)");if(s.meshFailurePenaltyWeight!==0&&(s.meshFailurePenaltyDecay<=0||s.meshFailurePenaltyDecay>=1))throw new H("invalid MeshFailurePenaltyDecay; must be between 0 and 1");if(s.invalidMessageDeliveriesWeight>0)throw new H("invalid InvalidMessageDeliveriesWeight; must be negative (or 0 to disable)");if(s.invalidMessageDeliveriesDecay<=0||s.invalidMessageDeliveriesDecay>=1)throw new H("invalid InvalidMessageDeliveriesDecay; must be between 0 and 1")}var Yu={gossipThreshold:-10,publishThreshold:-50,graylistThreshold:-80,acceptPXThreshold:10,opportunisticGraftThreshold:20};function Ba(s={}){return{...Yu,...s}}function br(s,e,t=()=>!0){let r=new Set;if(e<=0)return r;for(let n of s){if(r.size>=e)break;t(n)&&(r.add(n),s.delete(n))}return r}function Ra(s,e){return br(s,e,()=>!0)}var gr=class extends Map{getDefault;constructor(e){super(),this.getDefault=e}getOrDefault(e){let t=super.get(e);return t===void 0&&(t=this.getDefault(),this.set(e,t)),t}};function Ca(s,e,t,r){let n=0;Object.entries(e.topics).forEach(([o,a])=>{let c=t.topics[o];if(c===void 0)return;let f=0;if(a.inMesh){let v=a.meshTime/c.timeInMeshQuantum;v>c.timeInMeshCap&&(v=c.timeInMeshCap),f+=v*c.timeInMeshWeight}let p=a.firstMessageDeliveries;if(p>c.firstMessageDeliveriesCap&&(p=c.firstMessageDeliveriesCap),f+=p*c.firstMessageDeliveriesWeight,a.meshMessageDeliveriesActive&&a.meshMessageDeliveries<c.meshMessageDeliveriesThreshold){let v=c.meshMessageDeliveriesThreshold-a.meshMessageDeliveries,u=v*v;f+=u*c.meshMessageDeliveriesWeight}let m=a.meshFailurePenalty;f+=m*c.meshFailurePenaltyWeight;let _=a.invalidMessageDeliveries*a.invalidMessageDeliveries;f+=_*c.invalidMessageDeliveriesWeight,n+=f*c.topicWeight}),t.topicScoreCap>0&&n>t.topicScoreCap&&(n=t.topicScoreCap);let i=t.appSpecificScore(s);if(n+=i*t.appSpecificWeight,e.knownIPs.forEach(o=>{if(t.IPColocationFactorWhitelist.has(o))return;let a=r.get(o),c=a!=null?a.size:0;if(c>t.IPColocationFactorThreshold){let f=c-t.IPColocationFactorThreshold,p=f*f;n+=p*t.IPColocationFactorWeight}}),e.behaviourPenalty>t.behaviourPenaltyThreshold){let o=e.behaviourPenalty-t.behaviourPenaltyThreshold,a=o*o;n+=a*t.behaviourPenaltyWeight}return n}var Ua=ic(Oa(),1);var Se;(function(s){s[s.unknown=0]="unknown",s[s.valid=1]="valid",s[s.invalid=2]="invalid",s[s.ignored=3]="ignored"})(Se||(Se={}));var yr=class{records;queue;constructor(){this.records=new Map,this.queue=new Ua.default}getRecord(e){return this.records.get(e)}ensureRecord(e){let t=this.records.get(e);if(t!=null)return t;t={status:Se.unknown,firstSeenTsMs:Date.now(),validated:0,peers:new Set},this.records.set(e,t);let r={msgId:e,expire:Date.now()+12e4};return this.queue.push(r),t}gc(){let e=Date.now(),t=this.queue.peekFront();for(;t!=null&&t.expire<e;)this.records.delete(t.msgId),this.queue.shift(),t=this.queue.peekFront()}clear(){this.records.clear(),this.queue.clear()}};var wr=class{params;metrics;peerStats=new Map;peerIPs=new gr(()=>new Set);scoreCache=new Map;deliveryRecords=new yr;_backgroundInterval;scoreCacheValidityMs;computeScore;log;constructor(e,t,r,n){this.params=e,this.metrics=t,La(e),this.scoreCacheValidityMs=n.scoreCacheValidityMs,this.computeScore=n.computeScore??Ca,this.log=r.forComponent("libp2p:gossipsub:score")}get size(){return this.peerStats.size}start(){if(this._backgroundInterval!=null){this.log("Peer score already running");return}this._backgroundInterval=setInterval(()=>{this.background()},this.params.decayInterval),this.log("started")}stop(){if(this._backgroundInterval==null){this.log("Peer score already stopped");return}clearInterval(this._backgroundInterval),delete this._backgroundInterval,this.peerIPs.clear(),this.peerStats.clear(),this.deliveryRecords.clear(),this.log("stopped")}background(){this.refreshScores(),this.deliveryRecords.gc()}dumpPeerScoreStats(){return Object.fromEntries(Array.from(this.peerStats.entries()).map(([e,t])=>[e,t]))}messageFirstSeenTimestampMs(e){let t=this.deliveryRecords.getRecord(e);return t!=null?t.firstSeenTsMs:null}refreshScores(){let e=Date.now(),t=this.params.decayToZero;this.peerStats.forEach((r,n)=>{if(!r.connected){e>r.expire&&(this.removeIPsForPeer(n,r.knownIPs),this.peerStats.delete(n),this.scoreCache.delete(n));return}Object.entries(r.topics).forEach(([i,o])=>{let a=this.params.topics[i];a!==void 0&&(o.firstMessageDeliveries*=a.firstMessageDeliveriesDecay,o.firstMessageDeliveries<t&&(o.firstMessageDeliveries=0),o.meshMessageDeliveries*=a.meshMessageDeliveriesDecay,o.meshMessageDeliveries<t&&(o.meshMessageDeliveries=0),o.meshFailurePenalty*=a.meshFailurePenaltyDecay,o.meshFailurePenalty<t&&(o.meshFailurePenalty=0),o.invalidMessageDeliveries*=a.invalidMessageDeliveriesDecay,o.invalidMessageDeliveries<t&&(o.invalidMessageDeliveries=0),o.inMesh&&(o.meshTime=e-o.graftTime,o.meshTime>a.meshMessageDeliveriesActivation&&(o.meshMessageDeliveriesActive=!0)))}),r.behaviourPenalty*=this.params.behaviourPenaltyDecay,r.behaviourPenalty<t&&(r.behaviourPenalty=0)})}score(e){this.metrics?.scoreFnCalls.inc();let t=this.peerStats.get(e);if(t==null)return 0;let r=Date.now(),n=this.scoreCache.get(e);if(n!=null&&n.cacheUntil>r)return n.score;this.metrics?.scoreFnRuns.inc();let i=this.computeScore(e,t,this.params,this.peerIPs),o=r+this.scoreCacheValidityMs;return n!=null?(this.metrics?.scoreCachedDelta.observe(Math.abs(i-n.score)),n.score=i,n.cacheUntil=o):this.scoreCache.set(e,{score:i,cacheUntil:o}),i}addPenalty(e,t,r){let n=this.peerStats.get(e);n!=null&&(n.behaviourPenalty+=t,this.metrics?.onScorePenalty(r))}addPeer(e){let t={connected:!0,expire:0,topics:{},knownIPs:new Set,behaviourPenalty:0};this.peerStats.set(e,t)}addIP(e,t){let r=this.peerStats.get(e);r?.knownIPs.add(t),this.peerIPs.getOrDefault(t).add(e)}removeIP(e,t){let r=this.peerStats.get(e);r?.knownIPs.delete(t);let n=this.peerIPs.get(t);n!=null&&(n.delete(e),n.size===0&&this.peerIPs.delete(t))}removePeer(e){let t=this.peerStats.get(e);if(t!=null){if(this.score(e)>0){this.removeIPsForPeer(e,t.knownIPs),this.peerStats.delete(e);return}Object.entries(t.topics).forEach(([r,n])=>{n.firstMessageDeliveries=0;let i=this.params.topics[r].meshMessageDeliveriesThreshold;if(n.inMesh&&n.meshMessageDeliveriesActive&&n.meshMessageDeliveries<i){let o=i-n.meshMessageDeliveries;n.meshFailurePenalty+=o*o}n.inMesh=!1,n.meshMessageDeliveriesActive=!1}),t.connected=!1,t.expire=Date.now()+this.params.retainScore}}graft(e,t){let r=this.peerStats.get(e);if(r!=null){let n=this.getPtopicStats(r,t);n!=null&&(n.inMesh=!0,n.graftTime=Date.now(),n.meshTime=0,n.meshMessageDeliveriesActive=!1)}}prune(e,t){let r=this.peerStats.get(e);if(r!=null){let n=this.getPtopicStats(r,t);if(n!=null){let i=this.params.topics[t].meshMessageDeliveriesThreshold;if(n.meshMessageDeliveriesActive&&n.meshMessageDeliveries<i){let o=i-n.meshMessageDeliveries;n.meshFailurePenalty+=o*o}n.meshMessageDeliveriesActive=!1,n.inMesh=!1}}}validateMessage(e){this.deliveryRecords.ensureRecord(e)}deliverMessage(e,t,r){this.markFirstMessageDelivery(e,r);let n=this.deliveryRecords.ensureRecord(t),i=Date.now();if(n.status!==Se.unknown){this.log("unexpected delivery: message from %s was first seen %s ago and has delivery status %s",e,i-n.firstSeenTsMs,Se[n.status]);return}n.status=Se.valid,n.validated=i,n.peers.forEach(o=>{o!==e.toString()&&this.markDuplicateMessageDelivery(o,r)})}rejectInvalidMessage(e,t){this.markInvalidMessageDelivery(e,t)}rejectMessage(e,t,r,n){switch(n){case ve.Error:this.markInvalidMessageDelivery(e,r);return;case ve.Blacklisted:return}let i=this.deliveryRecords.ensureRecord(t);if(i.status!==Se.unknown){this.log("unexpected rejection: message from %s was first seen %s ago and has delivery status %d",e,Date.now()-i.firstSeenTsMs,Se[i.status]);return}if(n===ve.Ignore){i.status=Se.ignored,i.peers.clear();return}i.status=Se.invalid,this.markInvalidMessageDelivery(e,r),i.peers.forEach(o=>{this.markInvalidMessageDelivery(o,r)}),i.peers.clear()}duplicateMessage(e,t,r){let n=this.deliveryRecords.ensureRecord(t);if(!n.peers.has(e))switch(n.status){case Se.unknown:n.peers.add(e);break;case Se.valid:n.peers.add(e),this.markDuplicateMessageDelivery(e,r,n.validated);break;case Se.invalid:this.markInvalidMessageDelivery(e,r);break;case Se.ignored:break}}markInvalidMessageDelivery(e,t){let r=this.peerStats.get(e);if(r!=null){let n=this.getPtopicStats(r,t);n!=null&&(n.invalidMessageDeliveries+=1)}}markFirstMessageDelivery(e,t){let r=this.peerStats.get(e);if(r!=null){let n=this.getPtopicStats(r,t);if(n!=null){let i=this.params.topics[t].firstMessageDeliveriesCap;n.firstMessageDeliveries=Math.min(i,n.firstMessageDeliveries+1),n.inMesh&&(i=this.params.topics[t].meshMessageDeliveriesCap,n.meshMessageDeliveries=Math.min(i,n.meshMessageDeliveries+1))}}}markDuplicateMessageDelivery(e,t,r){let n=this.peerStats.get(e);if(n!=null){let i=r!==void 0?Date.now():0,o=this.getPtopicStats(n,t);if(o!=null&&o.inMesh){let a=this.params.topics[t];if(r!==void 0){let f=i-r,p=f>a.meshMessageDeliveriesWindow;if(this.metrics?.onDuplicateMsgDelivery(t,f,p),p)return}let c=a.meshMessageDeliveriesCap;o.meshMessageDeliveries=Math.min(c,o.meshMessageDeliveries+1)}}}removeIPsForPeer(e,t){for(let r of t){let n=this.peerIPs.get(r);n!=null&&(n.delete(e),n.size===0&&this.peerIPs.delete(r))}}getPtopicStats(e,t){let r=e.topics[t];return r!==void 0?r:this.params.topics[t]!==void 0?(r={inMesh:!1,graftTime:0,meshTime:0,firstMessageDeliveries:0,meshMessageDeliveries:0,meshMessageDeliveriesActive:!1,meshFailurePenalty:0,invalidMessageDeliveries:0},e.topics[t]=r,r):null}};function Xu(s,e,t,r,n){let i=0,o=new Map;if(Object.entries(e.topics).forEach(([_,v])=>{let u=n.get(_)??"unknown",g=t.topics[_];if(g===void 0)return;let w=o.get(u);w==null&&(w={p1w:0,p2w:0,p3w:0,p3bw:0,p4w:0},o.set(u,w));let y=0,I=0,l=0,h=0,d=0;if(v.inMesh){let S=Math.max(v.meshTime/g.timeInMeshQuantum,g.timeInMeshCap);y+=S*g.timeInMeshWeight}let b=v.firstMessageDeliveries;if(b>g.firstMessageDeliveriesCap&&(b=g.firstMessageDeliveriesCap),I+=b*g.firstMessageDeliveriesWeight,v.meshMessageDeliveriesActive&&v.meshMessageDeliveries<g.meshMessageDeliveriesThreshold){let S=g.meshMessageDeliveriesThreshold-v.meshMessageDeliveries,P=S*S;l+=P*g.meshMessageDeliveriesWeight}let E=v.meshFailurePenalty;h+=E*g.meshFailurePenaltyWeight;let x=v.invalidMessageDeliveries*v.invalidMessageDeliveries;d+=x*g.invalidMessageDeliveriesWeight,i+=(y+I+l+h+d)*g.topicWeight,w.p1w+=y,w.p2w+=I,w.p3w+=l,w.p3bw+=h,w.p4w+=d}),t.topicScoreCap>0&&i>t.topicScoreCap){i=t.topicScoreCap;let _=t.topicScoreCap/i;for(let v of o.values())v.p1w*=_,v.p2w*=_,v.p3w*=_,v.p3bw*=_,v.p4w*=_}let a=0,c=0,f=0,p=t.appSpecificScore(s);a+=p*t.appSpecificWeight,e.knownIPs.forEach(_=>{if(t.IPColocationFactorWhitelist.has(_))return;let v=r.get(_),u=v!=null?v.size:0;if(u>t.IPColocationFactorThreshold){let g=u-t.IPColocationFactorThreshold,w=g*g;c+=w*t.IPColocationFactorWeight}});let m=e.behaviourPenalty*e.behaviourPenalty;return f+=m*t.behaviourPenaltyWeight,i+=a+c+f,{byTopic:o,p5w:a,p6w:c,p7w:f,score:i}}function Ka(s,e,t,r,n){let i={byTopic:new Map,p5w:[],p6w:[],p7w:[],score:[]};for(let o of s){let a=e.get(o);if(a!=null){let c=Xu(o,a,t,r,n);for(let[f,p]of c.byTopic){let m=i.byTopic.get(f);m==null&&(m={p1w:[],p2w:[],p3w:[],p3bw:[],p4w:[]},i.byTopic.set(f,m)),m.p1w.push(p.p1w),m.p2w.push(p.p2w),m.p3w.push(p.p3w),m.p3bw.push(p.p3bw),m.p4w.push(p.p4w)}i.p5w.push(c.p5w),i.p6w.push(c.p6w),i.p7w.push(c.p7w),i.score.push(c.score)}else i.p5w.push(0),i.p6w.push(0),i.p7w.push(0),i.score.push(0)}return i}function xr(s){let e=s.getComponents(),t={},r=0;if(e[r]?.name==="ip6zone"&&(t.zone=`${e[r].value}`,r++),e[r].name==="ip4"||e[r].name==="ip6"||e[r].name==="dns"||e[r].name==="dns4"||e[r].name==="dns6"?(t.type=e[r].name,t.host=e[r].value,r++):e[r].name==="dnsaddr"&&(t.type=e[r].name,t.host=`_dnsaddr.${e[r].value}`,r++),(e[r]?.name==="tcp"||e[r]?.name==="udp")&&(t.protocol=e[r].name==="tcp"?"tcp":"udp",t.port=parseInt(`${e[r].value}`),r++),e[r]?.name==="ipcidr"&&(t.type==="ip4"?t.cidr=parseInt(`${e[r].value}`):t.type==="ip6"&&(t.cidr=`${e[r].value}`),r++),t.type==null||t.host==null)throw new $(`Multiaddr ${s} was not an IPv4, IPv6, DNS, DNS4, DNS6 or DNSADDR address`);return e[r]?.name==="tls"&&e[r+1]?.name==="sni"&&(t.sni=e[r+1].value,r+=2),t}function Fa(s){try{return xr(s),!0}catch{return!1}}var yi=class s extends Error{name="TimeoutError";constructor(e,t){super(e,t),Error.captureStackTrace?.(this,s)}},Ga=s=>s.reason??new DOMException("This operation was aborted.","AbortError");function wi(s,e){let{milliseconds:t,fallback:r,message:n,customTimers:i={setTimeout,clearTimeout},signal:o}=e,a,c,p=new Promise((m,_)=>{if(typeof t!="number"||Math.sign(t)!==1)throw new TypeError(`Expected \`milliseconds\` to be a positive number, got \`${t}\``);if(o?.aborted){_(Ga(o));return}if(o&&(c=()=>{_(Ga(o))},o.addEventListener("abort",c,{once:!0})),s.then(m,_),t===Number.POSITIVE_INFINITY)return;let v=new yi;a=i.setTimeout.call(void 0,()=>{if(r){try{m(r())}catch(u){_(u)}return}typeof s.cancel=="function"&&s.cancel(),n===!1?m():n instanceof Error?_(n):(v.message=n??`Promise timed out after ${t} milliseconds`,_(v))},t)}).finally(()=>{p.clear(),c&&o&&o.removeEventListener("abort",c)});return p.clear=()=>{i.clearTimeout.call(void 0,a),a=void 0},p}var Ju=s=>{let e=s.addEventListener||s.on||s.addListener,t=s.removeEventListener||s.off||s.removeListener;if(!e||!t)throw new TypeError("Emitter is not compatible");return{addListener:e.bind(s),removeListener:t.bind(s)}};function Qu(s,e,t){let r,n=new Promise((i,o)=>{if(t={rejectionEvents:["error"],multiArgs:!1,rejectionMultiArgs:!1,resolveImmediately:!1,...t},!(t.count>=0&&(t.count===Number.POSITIVE_INFINITY||Number.isInteger(t.count))))throw new TypeError("The `count` option should be at least 0 or more");t.signal?.throwIfAborted();let a=[e].flat(),c=[],{addListener:f,removeListener:p}=Ju(s),m=async(...v)=>{let u=t.multiArgs?v:v[0];if(t.filter)try{if(!await t.filter(u))return}catch(g){r(),o(g);return}c.push(u),t.count===c.length&&(r(),i(c))},_=(...v)=>{r(),o(t.rejectionMultiArgs?v:v[0])};r=()=>{for(let v of a)p(v,m);for(let v of t.rejectionEvents)a.includes(v)||p(v,_)};for(let v of a)f(v,m);for(let v of t.rejectionEvents)a.includes(v)||f(v,_);t.signal&&t.signal.addEventListener("abort",()=>{_(t.signal.reason)},{once:!0}),t.resolveImmediately&&i(c)});if(n.cancel=r,typeof t.timeout=="number"){let i=wi(n,{milliseconds:t.timeout});return i.cancel=()=>{r(),i.clear()},i}return n}function Ha(s,e,t){typeof t=="function"&&(t={filter:t}),t={...t,count:1,resolveImmediately:!1};let r=Qu(s,e,t),n=r.then(i=>i[0]);return n.cancel=r.cancel,n}function eh(s){return s?.addEventListener!=null}function th(s){let e=Mt(),t,r=o=>{e.push(o.data)},n=()=>{e.end(),s.removeEventListener("message",r),s.removeEventListener("close",i),s.removeEventListener("remoteCloseWrite",n)},i=o=>{e.end(o.error),o.error!=null&&t?.reject(o.error),s.removeEventListener("message",r),s.removeEventListener("close",i),s.removeEventListener("remoteCloseWrite",n)};return s.addEventListener("message",r),s.addEventListener("close",i,{once:!0}),s.addEventListener("remoteCloseWrite",n,{once:!0}),{source:e,async sink(o){async function*a(){yield*o}let c=a();for(;;){t=Promise.withResolvers();let{done:f,value:p}=await Promise.race([c.next(),t.promise]);if(s.writeStatus==="closing"||s.writeStatus==="closed"||(p!=null&&(s.send(p)||await Promise.race([Ha(s,"drain",{rejectionEvents:["close"]})])),f===!0))break}await s.close()}}}function qa(...s){let e=s.map(t=>eh(t)?th(t):t);return Ms(...e)}var vr=class{rawStream;constructor(e,t,r){this.rawStream=e,r.maxBufferSize!=null&&(e.maxWriteBufferLength=r.maxBufferSize),e.addEventListener("close",n=>{n.error!=null&&t(n.error)})}get protocol(){return this.rawStream.protocol}async push(e){return this.pushPrefixed(Jt.single(e))}pushPrefixed(e){this.rawStream.send(e)}async close(e){await this.rawStream.close(e).catch(t=>{this.rawStream.abort(t)})}},Er=class{source;rawStream;closeController;constructor(e,t={}){this.rawStream=e,this.closeController=new AbortController,this.closeController.signal.addEventListener("abort",()=>{e.close().catch(r=>{e.abort(r)})}),this.source=qa(this.rawStream,r=>As(r,t))}async close(){this.closeController.abort()}};var Sr=class{gossipsubIWantFollowupMs;msgIdToStrFn;metrics;promises=new Map;requestMsByMsg=new Map;requestMsByMsgExpire;constructor(e,t,r){this.gossipsubIWantFollowupMs=e,this.msgIdToStrFn=t,this.metrics=r,this.requestMsByMsgExpire=10*e}get size(){return this.promises.size}get requestMsByMsgSize(){return this.requestMsByMsg.size}addPromise(e,t){let r=Math.floor(Math.random()*t.length),n=t[r],i=this.msgIdToStrFn(n),o=this.promises.get(i);o==null&&(o=new Map,this.promises.set(i,o));let a=Date.now();o.has(e)||(o.set(e,a+this.gossipsubIWantFollowupMs),this.metrics!=null&&(this.metrics.iwantPromiseStarted.inc(1),this.requestMsByMsg.has(i)||this.requestMsByMsg.set(i,a)))}getBrokenPromises(){let e=Date.now(),t=new Map,r=0;return this.promises.forEach((n,i)=>{n.forEach((o,a)=>{o<e&&(t.set(a,(t.get(a)??0)+1),n.delete(a),r++)}),n.size===0&&this.promises.delete(i)}),this.metrics?.iwantPromiseBroken.inc(r),t}deliverMessage(e,t=!1){this.trackMessage(e);let r=this.promises.get(e);r!=null&&(this.promises.delete(e),this.metrics!=null&&(this.metrics.iwantPromiseResolved.inc(1),t&&this.metrics.iwantPromiseResolvedFromDuplicate.inc(1),this.metrics.iwantPromiseResolvedPeers.inc(r.size)))}rejectMessage(e,t){switch(this.trackMessage(e),t){case ve.Error:return;default:break}this.promises.delete(e)}clear(){this.promises.clear()}prune(){let e=Date.now()-this.requestMsByMsgExpire,t=0;for(let[r,n]of this.requestMsByMsg.entries())if(n<e)this.requestMsByMsg.delete(r),t++;else break;this.metrics?.iwantMessagePruned.inc(t)}trackMessage(e){if(this.metrics!=null){let t=this.requestMsByMsg.get(e);t!==void 0&&(this.metrics.iwantPromiseDeliveryTime.observe((Date.now()-t)/1e3),this.requestMsByMsg.delete(e))}}};var za=z("libp2p-pubsub:");async function Va(s,e,t,r){switch(s.type){case pt.Signing:{let n={from:s.author.toMultihash().bytes,data:r,seqno:tr(8),topic:e,signature:void 0,key:void 0},i=gt([za,st.Message.encode(n)]);n.signature=await s.privateKey.sign(i),n.key=s.key;let o={type:"signed",from:s.author,data:t,sequenceNumber:BigInt(`0x${q(n.seqno??new Uint8Array(0),"base16")}`),topic:e,signature:n.signature,key:ir(n.key)};return{raw:n,msg:o}}case pt.Anonymous:return{raw:{from:void 0,data:r,seqno:void 0,topic:e,signature:void 0,key:void 0},msg:{type:"unsigned",data:t,topic:e}};default:throw new Error("Unreachable")}}async function Wa(s,e){switch(s){case Pt:return e.signature!=null?{valid:!1,error:de.SignaturePresent}:e.seqno!=null?{valid:!1,error:de.SeqnoPresent}:e.key!=null?{valid:!1,error:de.FromPresent}:{valid:!0,message:{type:"unsigned",topic:e.topic,data:e.data??new Uint8Array(0)}};case mt:{if(e.seqno==null)return{valid:!1,error:de.InvalidSeqno};if(e.seqno.length!==8)return{valid:!1,error:de.InvalidSeqno};if(e.signature==null)return{valid:!1,error:de.InvalidSignature};if(e.from==null)return{valid:!1,error:de.InvalidPeerId};let t;try{t=Yt(Ve(e.from))}catch{return{valid:!1,error:de.InvalidPeerId}}let r;if(e.key!=null){if(r=ir(e.key),t.publicKey!==void 0&&!r.equals(t.publicKey))return{valid:!1,error:de.InvalidPeerId}}else{if(t.publicKey==null)return{valid:!1,error:de.InvalidPeerId};r=t.publicKey}let n={from:e.from,data:e.data,seqno:e.seqno,topic:e.topic,signature:void 0,key:void 0},i=gt([za,st.Message.encode(n)]);return await r.verify(i,e.signature)?{valid:!0,message:{type:"signed",from:t,data:e.data??new Uint8Array(0),sequenceNumber:BigInt(`0x${q(e.seqno,"base16")}`),topic:e.topic,signature:e.signature,key:e.key!=null?ir(e.key):r}}:{valid:!1,error:de.InvalidSignature}}default:throw new Error("Unreachable")}}function Ne(s=[],e){return{subscriptions:[],messages:s,control:e!==void 0?{graft:e.graft??[],prune:e.prune??[],ihave:e.ihave??[],iwant:e.iwant??[],idontwant:e.idontwant??[]}:void 0}}function xi(s){return s.control===void 0&&(s.control={graft:[],prune:[],ihave:[],iwant:[],idontwant:[]}),s}function qe(s){if(s.length<=1)return s;let e=()=>Math.floor(Math.random()*Math.floor(s.length));for(let t=0;t<s.length;t++){let r=e(),n=s[t];s[t]=s[r],s[r]=n}return s}function $a(s){return q(s,"base64")}function Za(s,e,t){switch(s){case mt:return{type:pt.Signing,author:e,key:Ke(t.publicKey),privateKey:t};case Pt:return{type:pt.Anonymous};default:throw new Error(`Unknown signature policy "${s}"`)}}var sh=(s,e)=>{let t=z(e.toString(16).padStart(16,"0"),"base16"),r=Ke(s),n=new Uint8Array(r.byteLength+t.length);return n.set(r,0),n.set(t,r.byteLength),n};function ja(s){if(s.type!=="signed")throw new Error("expected signed message type");if(s.sequenceNumber==null)throw Error("missing seqno field");return sh(s.from.publicKey??s.key,s.sequenceNumber)}async function Ya(s){return bt.encode(s.data)}function Xa(s){if(Fa(s)){let e=xr(s);switch(e.type){case"ip4":case"ip6":return e.host;default:break}}return null}var rs=class{entries=new Map;validityMs;constructor(e){this.validityMs=e.validityMs}get size(){return this.entries.size}put(e,t){return this.entries.has(e)?!0:(this.entries.set(e,{value:t,validUntilMs:Date.now()+this.validityMs}),!1)}prune(){let e=Date.now();for(let[t,r]of this.entries.entries())if(r.validUntilMs<e)this.entries.delete(t);else break}has(e){return this.entries.has(e)}get(e){let t=this.entries.get(e);return t!=null&&t.validUntilMs>=Date.now()?t.value:void 0}clear(){this.entries.clear()}};var Me;(function(s){s[s.started=0]="started",s[s.stopped=1]="stopped"})(Me||(Me={}));var _r=class extends Rs{globalSignaturePolicy;protocols=[kt,_i,Tr];publishConfig;dataTransform;peers=new Map;streamsInbound=new Map;streamsOutbound=new Map;outboundInflightQueue=Mt({objectMode:!0});direct=new Set;floodsubPeers=new Set;seenCache;acceptFromWhitelist=new Map;topics=new Map;subscriptions=new Set;mesh=new Map;fanout=new Map;fanoutLastpub=new Map;gossip=new Map;control=new Map;peerhave=new Map;iasked=new Map;backoff=new Map;outbound=new Map;msgIdFn;fastMsgIdFn;msgIdToStrFn;fastMsgIdCache;publishedMessageIds;mcache;score;topicValidators=new Map;log;heartbeatTicks=0;gossipTracer;idontwantCounts=new Map;idontwants=new Map;components;directPeerInitial=null;static multicodec=kt;opts;decodeRpcLimits;metrics;status={code:Me.stopped};maxInboundStreams;maxOutboundStreams;runOnLimitedConnection;allowedTopics;heartbeatTimer=null;constructor(e,t={}){super();let r={fallbackToFloodsub:!0,floodPublish:!0,batchPublish:!1,tagMeshPeers:!0,doPX:!1,directPeers:[],D:6,Dlo:4,Dhi:12,Dscore:4,Dout:2,Dlazy:6,heartbeatInterval:1e3,fanoutTTL:6e4,mcacheLength:5,mcacheGossip:3,seenTTL:12e4,gossipsubIWantFollowupMs:3e3,prunePeers:16,pruneBackoff:6e4,unsubcribeBackoff:1e4,graftFloodThreshold:1e4,opportunisticGraftPeers:2,opportunisticGraftTicks:60,directConnectTicks:300,gossipFactor:.25,idontwantMinDataSize:512,idontwantMaxMessages:512,...t,scoreParams:ka(t.scoreParams),scoreThresholds:Ba(t.scoreThresholds)};if(this.components=e,this.decodeRpcLimits=r.decodeRpcLimits??Da,this.globalSignaturePolicy=r.globalSignaturePolicy??mt,r.fallbackToFloodsub&&this.protocols.push(Ir),this.log=e.logger.forComponent(r.debugName??"libp2p:gossipsub"),this.opts=r,this.direct=new Set(r.directPeers.map(n=>n.id.toString())),this.seenCache=new rs({validityMs:r.seenTTL}),this.publishedMessageIds=new rs({validityMs:r.seenTTL}),t.msgIdFn!=null)this.msgIdFn=t.msgIdFn;else switch(this.globalSignaturePolicy){case mt:this.msgIdFn=ja;break;case Pt:this.msgIdFn=Ya;break;default:throw new Error(`Invalid globalSignaturePolicy: ${this.globalSignaturePolicy}`)}if(t.fastMsgIdFn!=null&&(this.fastMsgIdFn=t.fastMsgIdFn,this.fastMsgIdCache=new rs({validityMs:r.seenTTL})),this.msgIdToStrFn=t.msgIdToStrFn??$a,this.mcache=t.messageCache??new mr(r.mcacheGossip,r.mcacheLength,this.msgIdToStrFn),t.dataTransform!=null&&(this.dataTransform=t.dataTransform),t.metricsRegister!=null){if(t.metricsTopicStrToLabel==null)throw Error("Must set metricsTopicStrToLabel with metrics");let n=Math.max(...Object.values(r.scoreParams.topics).map(o=>o.meshMessageDeliveriesWindow),1e3),i=Pa(t.metricsRegister,t.metricsTopicStrToLabel,{gossipPromiseExpireSec:this.opts.gossipsubIWantFollowupMs/1e3,behaviourPenaltyThreshold:r.scoreParams.behaviourPenaltyThreshold,maxMeshMessageDeliveriesWindowSec:n/1e3});i.mcacheSize.addCollect(()=>{this.onScrapeMetrics(i)});for(let o of this.protocols)i.protocolsEnabled.set({protocol:o},1);this.metrics=i}else this.metrics=null;this.gossipTracer=new Sr(this.opts.gossipsubIWantFollowupMs,this.msgIdToStrFn,this.metrics),this.score=new wr(this.opts.scoreParams,this.metrics,this.components.logger,{scoreCacheValidityMs:r.heartbeatInterval}),this.maxInboundStreams=t.maxInboundStreams,this.maxOutboundStreams=t.maxOutboundStreams,this.runOnLimitedConnection=t.runOnLimitedConnection,this.allowedTopics=r.allowedTopics!=null?new Set(r.allowedTopics):null}[Symbol.toStringTag]="@chainsafe/libp2p-gossipsub";[Ai]=["@libp2p/pubsub"];[Mi]=["@libp2p/identify"];getPeers(){return[...this.peers.values()]}isStarted(){return this.status.code===Me.started}async start(){if(this.isStarted())return;this.log("starting"),this.publishConfig=Za(this.globalSignaturePolicy,this.components.peerId,this.components.privateKey),this.outboundInflightQueue=Mt({objectMode:!0}),Ms(this.outboundInflightQueue,async i=>{for await(let{peerId:o,connection:a}of i)await this.createOutboundStream(o,a)}).catch(i=>{this.log.error("outbound inflight queue error",i)}),await Promise.all(this.opts.directPeers.map(async i=>{await this.components.peerStore.merge(i.id,{multiaddrs:i.addrs})}));let e=this.components.registrar;await Promise.all(this.protocols.map(async i=>e.handle(i,this.onIncomingStream.bind(this),{maxInboundStreams:this.maxInboundStreams,maxOutboundStreams:this.maxOutboundStreams,runOnLimitedConnection:this.runOnLimitedConnection})));let t={onConnect:this.onPeerConnected.bind(this),onDisconnect:this.onPeerDisconnected.bind(this),notifyOnLimitedConnection:this.runOnLimitedConnection},r=await Promise.all(this.protocols.map(async i=>e.register(i,t))),n=setTimeout(this.runHeartbeat,100);this.status={code:Me.started,registrarTopologyIds:r,heartbeatTimeout:n,hearbeatStartMs:Date.now()+100},this.score.start(),this.directPeerInitial=setTimeout(()=>{Promise.resolve().then(async()=>{await Promise.all(Array.from(this.direct).map(async i=>this.connect(i)))}).catch(i=>{this.log(i)})},1e3),this.opts.tagMeshPeers&&(this.addEventListener("gossipsub:graft",this.tagMeshPeer),this.addEventListener("gossipsub:prune",this.untagMeshPeer)),this.log("started")}async stop(){if(this.log("stopping"),this.status.code!==Me.started)return;let{registrarTopologyIds:e}=this.status;this.status={code:Me.stopped},this.opts.tagMeshPeers&&(this.removeEventListener("gossipsub:graft",this.tagMeshPeer),this.removeEventListener("gossipsub:prune",this.untagMeshPeer));let t=this.components.registrar;await Promise.all(this.protocols.map(async n=>t.unhandle(n))),e.forEach(n=>{t.unregister(n)}),this.outboundInflightQueue.end();let r=[];for(let n of this.streamsOutbound.values())r.push(n.close());this.streamsOutbound.clear();for(let n of this.streamsInbound.values())r.push(n.close());this.streamsInbound.clear(),await Promise.all(r),this.peers.clear(),this.subscriptions.clear(),this.heartbeatTimer!=null&&(this.heartbeatTimer.cancel(),this.heartbeatTimer=null),this.score.stop(),this.mesh.clear(),this.fanout.clear(),this.fanoutLastpub.clear(),this.gossip.clear(),this.control.clear(),this.peerhave.clear(),this.iasked.clear(),this.backoff.clear(),this.outbound.clear(),this.gossipTracer.clear(),this.seenCache.clear(),this.fastMsgIdCache!=null&&this.fastMsgIdCache.clear(),this.directPeerInitial!=null&&clearTimeout(this.directPeerInitial),this.idontwantCounts.clear(),this.idontwants.clear(),this.log("stopped")}dumpPeerScoreStats(){return this.score.dumpPeerScoreStats()}onIncomingStream(e,t){if(!this.isStarted())return;let r=t.remotePeer;this.addPeer(r,t.direction,t.remoteAddr),this.createInboundStream(r,e),this.outboundInflightQueue.push({peerId:r,connection:t})}onPeerConnected(e,t){this.metrics?.newConnectionCount.inc({status:t.status}),!(!this.isStarted()||t.status!=="open")&&(this.addPeer(e,t.direction,t.remoteAddr),this.outboundInflightQueue.push({peerId:e,connection:t}))}onPeerDisconnected(e){this.log("connection ended %p",e),this.removePeer(e)}async createOutboundStream(e,t){if(!this.isStarted())return;let r=e.toString();if(this.peers.has(r)&&!this.streamsOutbound.has(r))try{let n=new vr(await t.newStream(this.protocols,{runOnLimitedConnection:this.runOnLimitedConnection}),o=>{this.log.error("outbound pipe error",o)},{maxBufferSize:this.opts.maxOutboundBufferSize});this.log("create outbound stream %p",e),this.streamsOutbound.set(r,n);let i=n.protocol;i===Ir&&this.floodsubPeers.add(r),this.metrics?.peersPerProtocol.inc({protocol:i},1),this.subscriptions.size>0&&(this.log("send subscriptions to",r),this.sendSubscriptions(r,Array.from(this.subscriptions),!0))}catch(n){this.log.error("createOutboundStream error",n)}}createInboundStream(e,t){if(!this.isStarted())return;let r=e.toString();if(!this.peers.has(r))return;let n=this.streamsInbound.get(r);n!==void 0&&(this.log("replacing existing inbound steam %s",r),n.close().catch(o=>{this.log.error(o)})),this.log("create inbound stream %s",r);let i=new Er(t,{maxDataLength:this.opts.maxInboundDataLength});this.streamsInbound.set(r,i),this.pipePeerReadStream(e,i.source).catch(o=>{this.log(o)})}addPeer(e,t,r){let n=e.toString();if(!this.peers.has(n)){this.peers.set(n,e),this.score.addPeer(n);let i=Xa(r);i!==null?this.score.addIP(n,i):this.log("Added peer has no IP in current address %s %s",n,r.toString()),this.outbound.has(n)||this.outbound.set(n,t==="outbound")}}removePeer(e){let t=e.toString();if(!this.peers.has(t))return;this.log("delete peer %p",e),this.peers.delete(t);let r=this.streamsOutbound.get(t),n=this.streamsInbound.get(t);r!=null&&this.metrics?.peersPerProtocol.inc({protocol:r.protocol},-1),r?.close().catch(i=>{this.log.error(i)}),n?.close().catch(i=>{this.log.error(i)}),this.streamsOutbound.delete(t),this.streamsInbound.delete(t);for(let i of this.topics.values())i.delete(t);for(let[i,o]of this.mesh)o.delete(t)&&this.metrics?.onRemoveFromMesh(i,Ce.Dc,1);for(let i of this.fanout.values())i.delete(t);this.floodsubPeers.delete(t),this.gossip.delete(t),this.control.delete(t),this.outbound.delete(t),this.idontwantCounts.delete(t),this.idontwants.delete(t),this.score.removePeer(t),this.acceptFromWhitelist.delete(t)}get started(){return this.status.code===Me.started}getMeshPeers(e){let t=this.mesh.get(e);return t!=null?Array.from(t):[]}getSubscribers(e){let t=this.topics.get(e);return(t!=null?Array.from(t):[]).map(r=>this.peers.get(r)??Dt(r))}getTopics(){return Array.from(this.subscriptions)}async pipePeerReadStream(e,t){try{await Ms(t,async r=>{for await(let n of r)try{let i=n.subarray(),o=st.decode(i,{limits:{subscriptions:this.decodeRpcLimits.maxSubscriptions,messages:this.decodeRpcLimits.maxMessages,control$:{ihave:this.decodeRpcLimits.maxIhaveMessageIDs,iwant:this.decodeRpcLimits.maxIwantMessageIDs,graft:this.decodeRpcLimits.maxControlMessages,prune:this.decodeRpcLimits.maxControlMessages,prune$:{peers:this.decodeRpcLimits.maxPeerInfos},idontwant:this.decodeRpcLimits.maxControlMessages,idontwant$:{messageIDs:this.decodeRpcLimits.maxIdontwantMessageIDs}}}});if(this.metrics?.onRpcRecv(o,i.length),this.opts.awaitRpcHandler)try{await this.handleReceivedRpc(e,o)}catch(a){this.metrics?.onRpcRecvError(),this.log(a)}else this.handleReceivedRpc(e,o).catch(a=>{this.metrics?.onRpcRecvError(),this.log(a)})}catch(i){this.metrics?.onRpcDataError(),this.log(i)}})}catch(r){this.metrics?.onPeerReadStreamError(),this.handlePeerReadStreamError(r,e)}}handlePeerReadStreamError(e,t){this.log.error(e),this.onPeerDisconnected(t)}async handleReceivedRpc(e,t){if(!this.acceptFrom(e.toString())){this.log("received message from unacceptable peer %p",e),this.metrics?.rpcRecvNotAccepted.inc();return}let r=t.subscriptions!=null?t.subscriptions.length:0,n=t.messages!=null?t.messages.length:0,i=0,o=0,a=0,c=0;if(t.control!=null&&(t.control.ihave!=null&&(i=t.control.ihave.length),t.control.iwant!=null&&(o=t.control.iwant.length),t.control.graft!=null&&(a=t.control.graft.length),t.control.prune!=null&&(c=t.control.prune.length)),this.log(`rpc.from ${e.toString()} subscriptions ${r} messages ${n} ihave ${i} iwant ${o} graft ${a} prune ${c}`),t.subscriptions!=null&&t.subscriptions.length>0){let f=[];t.subscriptions.forEach(p=>{let m=p.topic,_=p.subscribe===!0;if(m!=null){if(this.allowedTopics!=null&&!this.allowedTopics.has(m))return;this.handleReceivedSubscription(e,m,_),f.push({topic:m,subscribe:_})}}),this.safeDispatchEvent("subscription-change",{detail:{peerId:e,subscriptions:f}})}for(let f of t.messages){if(this.allowedTopics!=null&&!this.allowedTopics.has(f.topic))continue;let p=this.handleReceivedMessage(e,f).catch(m=>{this.metrics?.onMsgRecvError(f.topic),this.log(m)});this.opts.awaitRpcMessageHandler&&await p}t.control!=null&&await this.handleControlMessage(e.toString(),t.control)}handleReceivedSubscription(e,t,r){this.log("subscription update from %p topic %s",e,t);let n=this.topics.get(t);n==null&&(n=new Set,this.topics.set(t,n)),r?n.add(e.toString()):n.delete(e.toString())}async handleReceivedMessage(e,t){this.metrics?.onMsgRecvPreValidation(t.topic);let r=await this.validateReceivedMessage(e,t);this.metrics?.onPrevalidationResult(t.topic,r.code);let n=r.code;switch(n){case pe.duplicate:this.score.duplicateMessage(e.toString(),r.msgIdStr,t.topic),this.gossipTracer.deliverMessage(r.msgIdStr,!0),this.mcache.observeDuplicate(r.msgIdStr,e.toString());return;case pe.invalid:if(r.msgIdStr!=null){let i=r.msgIdStr;this.score.rejectMessage(e.toString(),i,t.topic,r.reason),this.gossipTracer.rejectMessage(i,r.reason)}else this.score.rejectInvalidMessage(e.toString(),t.topic);this.metrics?.onMsgRecvInvalid(t.topic,r);return;case pe.valid:this.score.validateMessage(r.messageId.msgIdStr),this.gossipTracer.deliverMessage(r.messageId.msgIdStr),this.mcache.put(r.messageId,t,!this.opts.asyncValidation),this.subscriptions.has(t.topic)&&(!this.components.peerId.equals(e)||this.opts.emitSelf)&&(super.dispatchEvent(new CustomEvent("gossipsub:message",{detail:{propagationSource:e,msgId:r.messageId.msgIdStr,msg:r.msg}})),super.dispatchEvent(new CustomEvent("message",{detail:r.msg}))),this.opts.asyncValidation||this.forwardMessage(r.messageId.msgIdStr,t,e.toString());break;default:throw new Error(`Invalid validation result: ${n}`)}}async validateReceivedMessage(e,t){let r=this.fastMsgIdFn?.(t),n=r!==void 0?this.fastMsgIdCache?.get(r):void 0;if(n!=null)return{code:pe.duplicate,msgIdStr:n};let i=await Wa(this.globalSignaturePolicy,t);if(!i.valid)return{code:pe.invalid,reason:ve.Error,error:i.error};let o=i.message;try{this.dataTransform!=null&&(o.data=this.dataTransform.inboundTransform(t.topic,o.data))}catch(m){return this.log("Invalid message, transform failed",m),{code:pe.invalid,reason:ve.Error,error:de.TransformFailed}}let a=await this.msgIdFn(o),c=this.msgIdToStrFn(a),f={msgId:a,msgIdStr:c};if(r!==void 0&&this.fastMsgIdCache!=null&&this.fastMsgIdCache.put(r,c)&&this.metrics?.fastMsgIdCacheCollision.inc(),this.seenCache.has(c))return{code:pe.duplicate,msgIdStr:c};this.seenCache.put(c),(t.data?.length??0)>=this.opts.idontwantMinDataSize&&this.sendIDontWants(a,t.topic,e.toString());let p=this.topicValidators.get(t.topic);if(p!=null){let m;try{m=await p(e,o)}catch(_){let v=_.code;v===Ti&&(m=me.Ignore),v===Ii?m=me.Reject:m=me.Ignore}if(m!==me.Accept)return{code:pe.invalid,reason:bi(m),msgIdStr:c}}return{code:pe.valid,messageId:f,msg:o}}getScore(e){return this.score.score(e)}sendSubscriptions(e,t,r){this.sendRpc(e,{subscriptions:t.map(n=>({topic:n,subscribe:r})),messages:[]})}async handleControlMessage(e,t){if(t===void 0)return;let r=t.ihave?.length>0?this.handleIHave(e,t.ihave):[],n=t.iwant?.length>0?this.handleIWant(e,t.iwant):[],i=t.graft?.length>0?await this.handleGraft(e,t.graft):[];if(t.prune?.length>0&&await this.handlePrune(e,t.prune),t.idontwant?.length>0&&this.handleIdontwant(e,t.idontwant),r.length===0&&n.length===0&&i.length===0)return;let o=this.sendRpc(e,Ne(n,{iwant:r,prune:i})),a=r[0]?.messageIDs;a!=null&&(o?this.gossipTracer.addPromise(e,a):this.metrics?.iwantPromiseUntracked.inc(1))}acceptFrom(e){if(this.direct.has(e))return!0;let t=Date.now(),r=this.acceptFromWhitelist.get(e);if(r!=null&&r.messagesAccepted<128&&r.acceptUntil>=t)return r.messagesAccepted+=1,!0;let n=this.score.score(e);return n>=0?this.acceptFromWhitelist.set(e,{messagesAccepted:0,acceptUntil:t+1e3}):this.acceptFromWhitelist.delete(e),n>=this.opts.scoreThresholds.graylistThreshold}handleIHave(e,t){if(t.length===0)return[];let r=this.score.score(e);if(r<this.opts.scoreThresholds.gossipThreshold)return this.log("IHAVE: ignoring peer %s with score below threshold [ score = %d ]",e,r),this.metrics?.ihaveRcvIgnored.inc({reason:ss.LowScore}),[];let n=(this.peerhave.get(e)??0)+1;if(this.peerhave.set(e,n),n>10)return this.log("IHAVE: peer %s has advertised too many times (%d) within this heartbeat interval; ignoring",e,n),this.metrics?.ihaveRcvIgnored.inc({reason:ss.MaxIhave}),[];let i=this.iasked.get(e)??0;if(i>=5e3)return this.log("IHAVE: peer %s has already advertised too many messages (%d); ignoring",e,i),this.metrics?.ihaveRcvIgnored.inc({reason:ss.MaxIasked}),[];let o=new Map;if(t.forEach(({topicID:f,messageIDs:p})=>{if(f==null||p==null||!this.mesh.has(f))return;let m=0;p.forEach(_=>{let v=this.msgIdToStrFn(_);this.seenCache.has(v)||(o.set(v,_),m++)}),this.metrics?.onIhaveRcv(f,p.length,m)}),o.size===0)return[];let a=o.size;a+i>5e3&&(a=5e3-i),this.log("IHAVE: Asking for %d out of %d messages from %s",a,o.size,e);let c=Array.from(o.values());return qe(c),c=c.slice(0,a),this.iasked.set(e,i+a),[{messageIDs:c}]}handleIWant(e,t){if(t.length===0)return[];let r=this.score.score(e);if(r<this.opts.scoreThresholds.gossipThreshold)return this.log("IWANT: ignoring peer %s with score below threshold [score = %d]",e,r),[];let n=new Map,i=new Map,o=0;return t.forEach(({messageIDs:a})=>{a?.forEach(c=>{let f=this.msgIdToStrFn(c),p=this.mcache.getWithIWantCount(f,e);if(p==null){o++;return}if(i.set(p.msg.topic,1+(i.get(p.msg.topic)??0)),p.count>3){this.log("IWANT: Peer %s has asked for message %s too many times: ignoring request",e,c);return}n.set(f,p.msg)})}),this.metrics?.onIwantRcv(i,o),n.size===0?(this.log("IWANT: Could not provide any wanted messages to %s",e),[]):(this.log("IWANT: Sending %d messages to %s",n.size,e),Array.from(n.values()))}async handleGraft(e,t){let r=[],n=this.score.score(e),i=Date.now(),o=this.opts.doPX;if(t.forEach(({topicID:c})=>{if(c==null)return;let f=this.mesh.get(c);if(f==null){o=!1;return}if(f.has(e))return;let p=this.backoff.get(c)?.get(e);if(this.direct.has(e))this.log("GRAFT: ignoring request from direct peer %s",e),r.push(c),o=!1;else if(typeof p=="number"&&i<p){this.log("GRAFT: ignoring backed off peer %s",e),this.score.addPenalty(e,1,ts.GraftBackoff),o=!1;let m=p+this.opts.graftFloodThreshold-this.opts.pruneBackoff;i<m&&this.score.addPenalty(e,1,ts.GraftBackoff),this.addBackoff(e,c),r.push(c)}else n<0?(this.log("GRAFT: ignoring peer %s with negative score: score=%d, topic=%s",e,n,c),r.push(c),o=!1,this.addBackoff(e,c)):f.size>=this.opts.Dhi&&!(this.outbound.get(e)??!1)?(r.push(c),this.addBackoff(e,c)):(this.log("GRAFT: Add mesh link from %s in %s",e,c),this.score.graft(e,c),f.add(e),this.metrics?.onAddToMesh(c,Ee.Subscribed,1));this.safeDispatchEvent("gossipsub:graft",{detail:{peerId:e,topic:c,direction:"inbound"}})}),r.length===0)return[];let a=!1;return Promise.all(r.map(async c=>this.makePrune(e,c,o,a)))}async handlePrune(e,t){let r=this.score.score(e);for(let{topicID:n,backoff:i,peers:o}of t){if(n==null)continue;let a=this.mesh.get(n);if(a==null)return;this.log("PRUNE: Remove mesh link to %s in %s",e,n),this.score.prune(e,n),a.has(e)&&(a.delete(e),this.metrics?.onRemoveFromMesh(n,Ce.Prune,1)),typeof i=="number"&&i>0?this.doAddBackoff(e,n,i*1e3):this.addBackoff(e,n),o!=null&&o.length>0&&(r<this.opts.scoreThresholds.acceptPXThreshold?this.log("PRUNE: ignoring PX from peer %s with insufficient score [score = %d, topic = %s]",e,r,n):await this.pxConnect(o)),this.safeDispatchEvent("gossipsub:prune",{detail:{peerId:e,topic:n,direction:"inbound"}})}}handleIdontwant(e,t){let r=this.idontwantCounts.get(e)??0;if(r>=this.opts.idontwantMaxMessages)return;let n=r,i=this.idontwants.get(e);i==null&&(i=new Map,this.idontwants.set(e,i));let o=0;e:for(let{messageIDs:c}of t)for(let f of c){if(r>=this.opts.idontwantMaxMessages)break e;r++;let p=this.msgIdToStrFn(f);i.set(p,this.heartbeatTicks),this.mcache.msgs.has(p)||o++}this.idontwantCounts.set(e,r);let a=r-n;this.metrics?.onIdontwantRcv(a,o)}addBackoff(e,t){this.doAddBackoff(e,t,this.opts.pruneBackoff)}doAddBackoff(e,t,r){let n=this.backoff.get(t);n==null&&(n=new Map,this.backoff.set(t,n));let i=Date.now()+r;(n.get(e)??0)<i&&n.set(e,i)}applyIwantPenalties(){this.gossipTracer.getBrokenPromises().forEach((e,t)=>{this.log("peer %s didn't follow up in %d IWANT requests; adding penalty",t,e),this.score.addPenalty(t,e,ts.BrokenPromise)})}clearBackoff(){if(this.heartbeatTicks%15!==0)return;let e=Date.now();this.backoff.forEach((t,r)=>{t.forEach((n,i)=>{n+1*this.opts.heartbeatInterval<e&&t.delete(i)}),t.size===0&&this.backoff.delete(r)})}async directConnect(){let e=[];this.direct.forEach(t=>{this.streamsOutbound.has(t)||e.push(t)}),await Promise.all(e.map(async t=>this.connect(t)))}async pxConnect(e){e.length>this.opts.prunePeers&&(qe(e),e=e.slice(0,this.opts.prunePeers));let t=[];await Promise.all(e.map(async r=>{if(r.peerID==null)return;let n=Yt(Ve(r.peerID)),i=n.toString();if(!this.peers.has(i)){if(r.signedPeerRecord==null){t.push(i);return}try{if(!await this.components.peerStore.consumePeerRecord(r.signedPeerRecord,{expectedPeer:n})){this.log("bogus peer record obtained through px: could not add peer record to address book");return}t.push(i)}catch{this.log("bogus peer record obtained through px: invalid signature or not a peer record")}}})),t.length!==0&&await Promise.all(t.map(async r=>this.connect(r)))}async connect(e){this.log("Initiating connection with %s",e);let t=Dt(e),r=await this.components.connectionManager.openConnection(t);for(let n of this.protocols)for(let i of this.components.registrar.getTopologies(n))i.onConnect?.(t,r)}subscribe(e){if(this.status.code!==Me.started)throw new Error("Pubsub has not started");if(!this.subscriptions.has(e)){this.subscriptions.add(e);for(let t of this.peers.keys())this.sendSubscriptions(t,[e],!0)}this.join(e)}unsubscribe(e){if(this.status.code!==Me.started)throw new Error("Pubsub is not started");let t=this.subscriptions.delete(e);if(this.log("unsubscribe from %s - am subscribed %s",e,t),t)for(let r of this.peers.keys())this.sendSubscriptions(r,[e],!1);this.leave(e)}join(e){if(this.status.code!==Me.started)throw new Error("Gossipsub has not started");if(this.mesh.has(e))return;this.log("JOIN %s",e),this.metrics?.onJoin(e);let t=new Set,r=this.backoff.get(e),n=this.fanout.get(e);if(n!=null&&(this.fanout.delete(e),this.fanoutLastpub.delete(e),n.forEach(i=>{!this.direct.has(i)&&this.score.score(i)>=0&&r?.has(i)!==!0&&t.add(i)}),this.metrics?.onAddToMesh(e,Ee.Fanout,t.size)),t.size<this.opts.D){let i=t.size;this.getRandomGossipPeers(e,this.opts.D,a=>!t.has(a)&&!this.direct.has(a)&&this.score.score(a)>=0&&r?.has(a)!==!0).forEach(a=>{t.add(a)}),this.metrics?.onAddToMesh(e,Ee.Random,t.size-i)}this.mesh.set(e,t),t.forEach(i=>{this.log("JOIN: Add mesh link to %s in %s",i,e),this.sendGraft(i,e)})}leave(e){if(this.status.code!==Me.started)throw new Error("Gossipsub has not started");this.log("LEAVE %s",e),this.metrics?.onLeave(e);let t=this.mesh.get(e);t!=null&&(Promise.all(Array.from(t).map(async r=>{this.log("LEAVE: Remove mesh link to %s in %s",r,e),await this.sendPrune(r,e)})).catch(r=>{this.log("Error sending prunes to mesh peers",r)}),this.mesh.delete(e))}selectPeersToForward(e,t,r){let n=new Set,i=this.topics.get(e);i!=null&&(this.direct.forEach(a=>{i.has(a)&&t!==a&&!(r?.has(a)??!1)&&n.add(a)}),this.floodsubPeers.forEach(a=>{i.has(a)&&t!==a&&!(r?.has(a)??!1)&&this.score.score(a)>=this.opts.scoreThresholds.publishThreshold&&n.add(a)}));let o=this.mesh.get(e);return o!=null&&o.size>0&&o.forEach(a=>{t!==a&&!(r?.has(a)??!1)&&n.add(a)}),n}selectPeersToPublish(e){let t=new Set,r={direct:0,floodsub:0,mesh:0,fanout:0},n=this.topics.get(e);if(n!=null)if(this.opts.floodPublish)n.forEach(i=>{this.direct.has(i)?(t.add(i),r.direct++):this.score.score(i)>=this.opts.scoreThresholds.publishThreshold&&(t.add(i),r.floodsub++)});else{this.direct.forEach(o=>{n.has(o)&&(t.add(o),r.direct++)}),this.floodsubPeers.forEach(o=>{n.has(o)&&this.score.score(o)>=this.opts.scoreThresholds.publishThreshold&&(t.add(o),r.floodsub++)});let i=this.mesh.get(e);if(i!=null&&i.size>0)i.forEach(o=>{t.add(o),r.mesh++}),i.size<this.opts.D&&this.getRandomGossipPeers(e,this.opts.D-i.size,a=>!i.has(a)&&!this.direct.has(a)&&!this.floodsubPeers.has(a)&&this.score.score(a)>=this.opts.scoreThresholds.publishThreshold).forEach(a=>{t.add(a),r.mesh++});else{let o=this.fanout.get(e);if(o!=null&&o.size>0)o.forEach(a=>{t.add(a),r.fanout++});else{let a=this.getRandomGossipPeers(e,this.opts.D,c=>this.score.score(c)>=this.opts.scoreThresholds.publishThreshold);a.size>0&&(this.fanout.set(e,a),a.forEach(c=>{t.add(c),r.fanout++}))}this.fanoutLastpub.set(e,Date.now())}}return{tosend:t,tosendCount:r}}forwardMessage(e,t,r,n){r!=null&&this.score.deliverMessage(r,e,t.topic);let i=this.selectPeersToForward(t.topic,r,n);i.forEach(o=>{this.sendRpc(o,Ne([t]))}),this.metrics?.onForwardMsg(t.topic,i.size)}async publish(e,t,r){let n=Date.now(),i=this.dataTransform!=null?this.dataTransform.outboundTransform(e,t):t;if(this.publishConfig==null)throw Error("PublishError.Uninitialized");let{raw:o,msg:a}=await Va(this.publishConfig,e,t,i),c=await this.msgIdFn(a),f=this.msgIdToStrFn(c),p=r?.ignoreDuplicatePublishError??this.opts.ignoreDuplicatePublishError;if(this.seenCache.has(f)){if(p)return this.metrics?.onPublishDuplicateMsg(e),{recipients:[]};throw Error("PublishError.Duplicate")}let{tosend:m,tosendCount:_}=this.selectPeersToPublish(e),v=this.opts.emitSelf&&this.subscriptions.has(e),u=r?.allowPublishToZeroTopicPeers??this.opts.allowPublishToZeroTopicPeers;if(m.size===0&&!u&&!v)throw Error("PublishError.NoPeersSubscribedToTopic");this.seenCache.put(f),this.mcache.put({msgId:c,msgIdStr:f},o,!0),this.gossipTracer.deliverMessage(f),this.publishedMessageIds.put(f);let g=r?.batchPublish??this.opts.batchPublish,w=Ne([o]);if(g)this.sendRpcInBatch(m,w);else for(let I of m)this.sendRpc(I,w)||m.delete(I);let y=Date.now()-n;return this.metrics?.onPublishMsg(e,_,m.size,o.data!=null?o.data.length:0,y),v&&(m.add(this.components.peerId.toString()),super.dispatchEvent(new CustomEvent("gossipsub:message",{detail:{propagationSource:this.components.peerId,msgId:f,msg:a}})),super.dispatchEvent(new CustomEvent("message",{detail:a}))),{recipients:Array.from(m.values()).map(I=>this.peers.get(I)??Dt(I))}}sendRpcInBatch(e,t){let r=st.encode(t),n=Jt.single(r);for(let i of e){let o=this.streamsOutbound.get(i);if(o==null){this.log(`Cannot send RPC to ${i} as there is no open stream to it available`),e.delete(i);continue}try{o.pushPrefixed(n)}catch(a){e.delete(i),this.log.error(`Cannot send rpc to ${i}`,a)}this.metrics?.onRpcSent(t,r.length)}}reportMessageValidationResult(e,t,r){let n;if(r===me.Accept){if(n=this.mcache.validate(e),n!=null){let{message:o,originatingPeers:a}=n;this.score.deliverMessage(t,e,o.topic),this.forwardMessage(e,n.message,t,a)}}else if(n=this.mcache.remove(e),n!=null){let o=bi(r),{message:a,originatingPeers:c}=n;this.score.rejectMessage(t,e,a.topic,o);for(let f of c)this.score.rejectMessage(f,e,a.topic,o)}let i=this.score.messageFirstSeenTimestampMs(e);this.metrics?.onReportValidation(n,r,i)}sendGraft(e,t){let n=Ne([],{graft:[{topicID:t}]});this.sendRpc(e,n)}async sendPrune(e,t){let n=[await this.makePrune(e,t,this.opts.doPX,!0)],i=Ne([],{prune:n});this.sendRpc(e,i)}sendIDontWants(e,t,r){let n=this.mesh.get(t);if(n==null)return;let i=new Set(n);i.delete(r);for(let a of i)this.streamsOutbound.get(a)?.protocol!==kt&&i.delete(a);let o=Ne([],{idontwant:[{messageIDs:[e]}]});this.sendRpcInBatch(i,o)}sendRpc(e,t){let r=this.streamsOutbound.get(e);if(r==null)return this.log(`Cannot send RPC to ${e} as there is no open stream to it available`),!1;let n=this.control.get(e);n!=null&&(this.piggybackControl(e,t,n),this.control.delete(e));let i=this.gossip.get(e);i!=null&&(this.piggybackGossip(e,t,i),this.gossip.delete(e));let o=st.encode(t);try{r.push(o)}catch(a){return this.log.error(`Cannot send rpc to ${e}`,a),n!=null&&this.control.set(e,n),i!=null&&this.gossip.set(e,i),!1}if(this.metrics?.onRpcSent(t,o.length),t.control?.graft!=null)for(let a of t.control?.graft)a.topicID!=null&&this.safeDispatchEvent("gossipsub:graft",{detail:{peerId:e,topic:a.topicID,direction:"outbound"}});if(t.control?.prune!=null)for(let a of t.control?.prune)a.topicID!=null&&this.safeDispatchEvent("gossipsub:prune",{detail:{peerId:e,topic:a.topicID,direction:"outbound"}});return!0}piggybackControl(e,t,r){let n=xi(t);for(let i of r.graft)i.topicID!=null&&(this.mesh.get(i.topicID)?.has(e)??!1)&&n.control.graft.push(i);for(let i of r.prune)i.topicID!=null&&!(this.mesh.get(i.topicID)?.has(e)??!1)&&n.control.prune.push(i)}piggybackGossip(e,t,r){let n=xi(t);n.control.ihave=r}async sendGraftPrune(e,t,r){let n=this.opts.doPX,i=!1;for(let[o,a]of e){let c=a.map(m=>({topicID:m})),f=[],p=t.get(o);p!=null&&(f=await Promise.all(p.map(async m=>this.makePrune(o,m,n&&!(r.get(o)??!1),i))),t.delete(o)),this.sendRpc(o,Ne([],{graft:c,prune:f}))}for(let[o,a]of t){let c=await Promise.all(a.map(async f=>this.makePrune(o,f,n&&!(r.get(o)??!1),i)));this.sendRpc(o,Ne([],{prune:c}))}}emitGossip(e){let t=this.mcache.getGossipIDs(new Set(e.keys()));for(let[r,n]of e)this.doEmitGossip(r,n,t.get(r)??[])}doEmitGossip(e,t,r){if(r.length===0||(qe(r),r.length>5e3&&this.log("too many messages for gossip; will truncate IHAVE list (%d messages)",r.length),t.size===0))return;let n=this.opts.Dlazy,o=this.opts.gossipFactor*t.size,a=t;o>n&&(n=o),n>a.size?n=a.size:a=qe(Array.from(a)).slice(0,n),a.forEach(c=>{let f=r;r.length>5e3&&(f=qe(f.slice()).slice(0,5e3)),this.pushGossip(c,{topicID:e,messageIDs:f})})}flush(){for(let[e,t]of this.gossip.entries())this.gossip.delete(e),this.sendRpc(e,Ne([],{ihave:t}));for(let[e,t]of this.control.entries()){this.control.delete(e);let r=Ne([],{graft:t.graft,prune:t.prune});this.sendRpc(e,r)}}pushGossip(e,t){this.log("Add gossip to %s",e);let r=this.gossip.get(e)??[];this.gossip.set(e,r.concat(t))}async makePrune(e,t,r,n){if(this.score.prune(e,t),this.streamsOutbound.get(e)?.protocol===Tr)return{topicID:t,peers:[]};let i=n?this.opts.unsubcribeBackoff:this.opts.pruneBackoff,o=i/1e3;if(this.doAddBackoff(e,t,i),!r)return{topicID:t,peers:[],backoff:o};let a=this.getRandomGossipPeers(t,this.opts.prunePeers,f=>f!==e&&this.score.score(f)>=0),c=await Promise.all(Array.from(a).map(async f=>{let p=this.peers.get(f)??Dt(f),m;try{m=await this.components.peerStore.get(p)}catch(_){if(_.name!=="NotFoundError")throw _}return{peerID:p.toMultihash().bytes,signedPeerRecord:m?.peerRecordEnvelope}}));return{topicID:t,peers:c,backoff:o}}runHeartbeat=()=>{let e=this.metrics?.heartbeatDuration.startTimer();this.heartbeat().catch(t=>{this.log("Error running heartbeat",t)}).finally(()=>{if(e?.(),this.status.code===Me.started){clearTimeout(this.status.heartbeatTimeout);let t=this.opts.heartbeatInterval-(Date.now()-this.status.hearbeatStartMs)%this.opts.heartbeatInterval;t<this.opts.heartbeatInterval*.25&&(t+=this.opts.heartbeatInterval,this.metrics?.heartbeatSkipped.inc()),this.status.heartbeatTimeout=setTimeout(this.runHeartbeat,t)}})};async heartbeat(){let{D:e,Dlo:t,Dhi:r,Dscore:n,Dout:i,fanoutTTL:o}=this.opts;this.heartbeatTicks++;let a=new Map,c=u=>{let g=a.get(u);return g===void 0&&(g=this.score.score(u),a.set(u,g)),g},f=new Map,p=new Map,m=new Map;this.clearBackoff(),this.peerhave.clear(),this.metrics?.cacheSize.set({cache:"iasked"},this.iasked.size),this.iasked.clear(),this.applyIwantPenalties(),this.idontwantCounts.clear();for(let u of this.idontwants.values())for(let[g,w]of u)this.heartbeatTicks-w>=this.opts.mcacheLength&&u.delete(g);this.heartbeatTicks%this.opts.directConnectTicks===0&&await this.directConnect(),this.fastMsgIdCache?.prune(),this.seenCache.prune(),this.gossipTracer.prune(),this.publishedMessageIds.prune();let _=new Map;this.mesh.forEach((u,g)=>{let w=this.topics.get(g),y=new Set,I=new Set;if(_.set(g,I),w!=null){let d=qe(Array.from(w)),b=this.backoff.get(g);for(let E of d){let x=this.streamsOutbound.get(E);if(x!=null&&this.protocols.includes(x.protocol)&&!u.has(E)&&!this.direct.has(E)){let S=c(E);b?.has(E)!==!0&&S>=0&&y.add(E),S>=this.opts.scoreThresholds.gossipThreshold&&I.add(E)}}}let l=(d,b)=>{this.log("HEARTBEAT: Remove mesh link to %s in %s",d,g),this.addBackoff(d,g),u.delete(d),c(d)>=this.opts.scoreThresholds.gossipThreshold&&I.add(d),this.metrics?.onRemoveFromMesh(g,b,1);let E=p.get(d);E==null?p.set(d,[g]):E.push(g)},h=(d,b)=>{this.log("HEARTBEAT: Add mesh link to %s in %s",d,g),this.score.graft(d,g),u.add(d),I.delete(d),this.metrics?.onAddToMesh(g,b,1);let E=f.get(d);E==null?f.set(d,[g]):E.push(g)};if(u.forEach(d=>{let b=c(d);b<0&&(this.log("HEARTBEAT: Prune peer %s with negative score: score=%d, topic=%s",d,b,g),l(d,Ce.BadScore),m.set(d,!0))}),u.size<t){let d=e-u.size;Ra(y,d).forEach(E=>{h(E,Ee.NotEnough)})}if(u.size>r){let d=Array.from(u);d.sort((E,x)=>c(x)-c(E)),d=d.slice(0,n).concat(qe(d.slice(n)));let b=0;if(d.slice(0,e).forEach(E=>{(this.outbound.get(E)??!1)&&b++}),b<i){let E=S=>{let P=d[S];for(let O=S;O>0;O--)d[O]=d[O-1];d[0]=P};if(b>0){let S=b;for(let P=1;P<e&&S>0;P++)(this.outbound.get(d[P])??!1)&&(E(P),S--)}let x=e-b;for(let S=e;S<d.length&&x>0;S++)(this.outbound.get(d[S])??!1)&&(E(S),x--)}d.slice(e).forEach(E=>{l(E,Ce.Excess)})}if(u.size>=t){let d=0;if(u.forEach(b=>{(this.outbound.get(b)??!1)&&d++}),d<i){let b=i-d;br(y,b,x=>this.outbound.get(x)===!0).forEach(x=>{h(x,Ee.Outbound)})}}if(this.heartbeatTicks%this.opts.opportunisticGraftTicks===0&&u.size>1){let d=Array.from(u).sort((x,S)=>c(x)-c(S)),b=Math.floor(u.size/2),E=c(d[b]);if(E<this.opts.scoreThresholds.opportunisticGraftThreshold){let x=this.opts.opportunisticGraftPeers,S=br(y,x,P=>c(P)>E);for(let P of S)this.log("HEARTBEAT: Opportunistically graft peer %s on topic %s",P,g),h(P,Ee.Opportunistic)}}});let v=Date.now();this.fanoutLastpub.forEach((u,g)=>{u+o<v&&(this.fanout.delete(g),this.fanoutLastpub.delete(g))}),this.fanout.forEach((u,g)=>{let w=this.topics.get(g);u.forEach(h=>{(!(w?.has(h)??!1)||c(h)<this.opts.scoreThresholds.publishThreshold)&&u.delete(h)});let y=this.topics.get(g),I=[],l=new Set;if(_.set(g,l),y!=null){let h=qe(Array.from(y));for(let d of h){let b=this.streamsOutbound.get(d);if(b!=null&&this.protocols.includes(b.protocol)&&!u.has(d)&&!this.direct.has(d)){let E=c(d);E>=this.opts.scoreThresholds.publishThreshold&&I.push(d),E>=this.opts.scoreThresholds.gossipThreshold&&l.add(d)}}}if(u.size<e){let h=e-u.size;I.slice(0,h).forEach(d=>{u.add(d),l?.delete(d)})}}),this.emitGossip(_),await this.sendGraftPrune(f,p,m),this.flush(),this.mcache.shift(),this.dispatchEvent(new CustomEvent("gossipsub:heartbeat"))}getRandomGossipPeers(e,t,r=()=>!0){let n=this.topics.get(e);if(n==null)return new Set;let i=[];return n.forEach(o=>{let a=this.streamsOutbound.get(o);a!=null&&this.protocols.includes(a.protocol)&&r(o)&&i.push(o)}),i=qe(i),t>0&&i.length>t&&(i=i.slice(0,t)),new Set(i)}onScrapeMetrics(e){e.mcacheSize.set(this.mcache.size),e.mcacheNotValidatedCount.set(this.mcache.notValidatedCount),e.cacheSize.set({cache:"direct"},this.direct.size),e.cacheSize.set({cache:"seenCache"},this.seenCache.size),e.cacheSize.set({cache:"fastMsgIdCache"},this.fastMsgIdCache?.size??0),e.cacheSize.set({cache:"publishedMessageIds"},this.publishedMessageIds.size),e.cacheSize.set({cache:"mcache"},this.mcache.size),e.cacheSize.set({cache:"score"},this.score.size),e.cacheSize.set({cache:"gossipTracer.promises"},this.gossipTracer.size),e.cacheSize.set({cache:"gossipTracer.requests"},this.gossipTracer.requestMsByMsgSize),e.cacheSize.set({cache:"topics"},this.topics.size),e.cacheSize.set({cache:"subscriptions"},this.subscriptions.size),e.cacheSize.set({cache:"mesh"},this.mesh.size),e.cacheSize.set({cache:"fanout"},this.fanout.size),e.cacheSize.set({cache:"peers"},this.peers.size),e.cacheSize.set({cache:"streamsOutbound"},this.streamsOutbound.size),e.cacheSize.set({cache:"streamsInbound"},this.streamsInbound.size),e.cacheSize.set({cache:"acceptFromWhitelist"},this.acceptFromWhitelist.size),e.cacheSize.set({cache:"gossip"},this.gossip.size),e.cacheSize.set({cache:"control"},this.control.size),e.cacheSize.set({cache:"peerhave"},this.peerhave.size),e.cacheSize.set({cache:"outbound"},this.outbound.size);let t=0,r=Date.now();e.connectedPeersBackoffSec.reset();for(let c of this.backoff.values()){t+=c.size;for(let[f,p]of c.entries())this.peers.has(f)&&e.connectedPeersBackoffSec.observe(Math.max(0,p-r)/1e3)}e.cacheSize.set({cache:"backoff"},t);let n=0;for(let c of this.idontwants.values())n+=c.size;e.cacheSize.set({cache:"idontwants"},n);for(let[c,f]of this.topics)e.topicPeersCount.set({topicStr:c},f.size);for(let[c,f]of this.mesh)e.meshPeerCounts.set({topicStr:c},f.size);let i=[],o=new Map;e.behaviourPenalty.reset();for(let c of this.peers.keys()){let f=this.score.score(c);i.push(f),o.set(c,f),e.behaviourPenalty.observe(this.score.peerStats.get(c)?.behaviourPenalty??0)}e.registerScores(i,this.opts.scoreThresholds),e.registerScorePerMesh(this.mesh,o);let a=Ka(this.peers.keys(),this.score.peerStats,this.score.params,this.score.peerIPs,e.topicStrToLabel);e.registerScoreWeights(a)}tagMeshPeer=e=>{let{peerId:t,topic:r}=e.detail;this.components.peerStore.merge(this.peers.get(t)??Dt(t),{tags:{[r]:{value:100}}}).catch(n=>{this.log.error("Error tagging peer %s with topic %s",t,r,n)})};untagMeshPeer=e=>{let{peerId:t,topic:r}=e.detail;this.components.peerStore.merge(this.peers.get(t)??Dt(t),{tags:{[r]:void 0}}).catch(n=>{this.log.error("Error untagging peer %s with topic %s",t,r,n)})}};var mt="StrictSign",Pt="StrictNoSign",me;(function(s){s.Accept="accept",s.Ignore="ignore",s.Reject="reject"})(me||(me={}));var Ph=kt;function kh(s={}){return e=>new _r(e,s)}return oc(Lh);})();
2
+ "use strict";var Libp2PGossipsub=(()=>{var gc=Object.create;var Rs=Object.defineProperty;var bc=Object.getOwnPropertyDescriptor;var yc=Object.getOwnPropertyNames;var wc=Object.getPrototypeOf,xc=Object.prototype.hasOwnProperty;var vc=(s,e)=>()=>(e||s((e={exports:{}}).exports,e),e.exports),_e=(s,e)=>{for(var t in e)Rs(s,t,{get:e[t],enumerable:!0})},Bi=(s,e,t,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let n of yc(e))!xc.call(s,n)&&n!==t&&Rs(s,n,{get:()=>e[n],enumerable:!(r=bc(e,n))||r.enumerable});return s};var Ec=(s,e,t)=>(t=s!=null?gc(wc(s)):{},Bi(e||!s||!s.__esModule?Rs(t,"default",{value:s,enumerable:!0}):t,s)),Sc=s=>Bi(Rs({},"__esModule",{value:!0}),s);var ec=vc((yb,Qa)=>{"use strict";function Y(s,t){var t=t||{};this._capacity=t.capacity,this._head=0,this._tail=0,Array.isArray(s)?this._fromArray(s):(this._capacityMask=3,this._list=new Array(4))}Y.prototype.peekAt=function(e){var t=e;if(t===(t|0)){var r=this.size();if(!(t>=r||t<-r))return t<0&&(t+=r),t=this._head+t&this._capacityMask,this._list[t]}};Y.prototype.get=function(e){return this.peekAt(e)};Y.prototype.peek=function(){if(this._head!==this._tail)return this._list[this._head]};Y.prototype.peekFront=function(){return this.peek()};Y.prototype.peekBack=function(){return this.peekAt(-1)};Object.defineProperty(Y.prototype,"length",{get:function(){return this.size()}});Y.prototype.size=function(){return this._head===this._tail?0:this._head<this._tail?this._tail-this._head:this._capacityMask+1-(this._head-this._tail)};Y.prototype.unshift=function(e){if(arguments.length===0)return this.size();var t=this._list.length;return this._head=this._head-1+t&this._capacityMask,this._list[this._head]=e,this._tail===this._head&&this._growArray(),this._capacity&&this.size()>this._capacity&&this.pop(),this._head<this._tail?this._tail-this._head:this._capacityMask+1-(this._head-this._tail)};Y.prototype.shift=function(){var e=this._head;if(e!==this._tail){var t=this._list[e];return this._list[e]=void 0,this._head=e+1&this._capacityMask,e<2&&this._tail>1e4&&this._tail<=this._list.length>>>2&&this._shrinkArray(),t}};Y.prototype.push=function(e){if(arguments.length===0)return this.size();var t=this._tail;return this._list[t]=e,this._tail=t+1&this._capacityMask,this._tail===this._head&&this._growArray(),this._capacity&&this.size()>this._capacity&&this.shift(),this._head<this._tail?this._tail-this._head:this._capacityMask+1-(this._head-this._tail)};Y.prototype.pop=function(){var e=this._tail;if(e!==this._head){var t=this._list.length;this._tail=e-1+t&this._capacityMask;var r=this._list[this._tail];return this._list[this._tail]=void 0,this._head<2&&e>1e4&&e<=t>>>2&&this._shrinkArray(),r}};Y.prototype.removeOne=function(e){var t=e;if(t===(t|0)&&this._head!==this._tail){var r=this.size(),n=this._list.length;if(!(t>=r||t<-r)){t<0&&(t+=r),t=this._head+t&this._capacityMask;var i=this._list[t],o;if(e<r/2){for(o=e;o>0;o--)this._list[t]=this._list[t=t-1+n&this._capacityMask];this._list[t]=void 0,this._head=this._head+1+n&this._capacityMask}else{for(o=r-1-e;o>0;o--)this._list[t]=this._list[t=t+1+n&this._capacityMask];this._list[t]=void 0,this._tail=this._tail-1+n&this._capacityMask}return i}}};Y.prototype.remove=function(e,t){var r=e,n,i=t;if(r===(r|0)&&this._head!==this._tail){var o=this.size(),a=this._list.length;if(!(r>=o||r<-o||t<1)){if(r<0&&(r+=o),t===1||!t)return n=new Array(1),n[0]=this.removeOne(r),n;if(r===0&&r+t>=o)return n=this.toArray(),this.clear(),n;r+t>o&&(t=o-r);var c;for(n=new Array(t),c=0;c<t;c++)n[c]=this._list[this._head+r+c&this._capacityMask];if(r=this._head+r&this._capacityMask,e+t===o){for(this._tail=this._tail-t+a&this._capacityMask,c=t;c>0;c--)this._list[r=r+1+a&this._capacityMask]=void 0;return n}if(e===0){for(this._head=this._head+t+a&this._capacityMask,c=t-1;c>0;c--)this._list[r=r+1+a&this._capacityMask]=void 0;return n}if(r<o/2){for(this._head=this._head+e+t+a&this._capacityMask,c=e;c>0;c--)this.unshift(this._list[r=r-1+a&this._capacityMask]);for(r=this._head-1+a&this._capacityMask;i>0;)this._list[r=r-1+a&this._capacityMask]=void 0,i--;e<0&&(this._tail=r)}else{for(this._tail=r,r=r+t+a&this._capacityMask,c=o-(t+e);c>0;c--)this.push(this._list[r++]);for(r=this._tail;i>0;)this._list[r=r+1+a&this._capacityMask]=void 0,i--}return this._head<2&&this._tail>1e4&&this._tail<=a>>>2&&this._shrinkArray(),n}}};Y.prototype.splice=function(e,t){var r=e;if(r===(r|0)){var n=this.size();if(r<0&&(r+=n),!(r>n))if(arguments.length>2){var i,o,a,c=arguments.length,h=this._list.length,m=2;if(!n||r<n/2){for(o=new Array(r),i=0;i<r;i++)o[i]=this._list[this._head+i&this._capacityMask];for(t===0?(a=[],r>0&&(this._head=this._head+r+h&this._capacityMask)):(a=this.remove(r,t),this._head=this._head+r+h&this._capacityMask);c>m;)this.unshift(arguments[--c]);for(i=r;i>0;i--)this.unshift(o[i-1])}else{o=new Array(n-(r+t));var d=o.length;for(i=0;i<d;i++)o[i]=this._list[this._head+r+t+i&this._capacityMask];for(t===0?(a=[],r!=n&&(this._tail=this._head+r+h&this._capacityMask)):(a=this.remove(r,t),this._tail=this._tail-d+h&this._capacityMask);m<c;)this.push(arguments[m++]);for(i=0;i<d;i++)this.push(o[i])}return a}else return this.remove(r,t)}};Y.prototype.clear=function(){this._list=new Array(this._list.length),this._head=0,this._tail=0};Y.prototype.isEmpty=function(){return this._head===this._tail};Y.prototype.toArray=function(){return this._copyArray(!1)};Y.prototype._fromArray=function(e){var t=e.length,r=this._nextPowerOf2(t);this._list=new Array(r),this._capacityMask=r-1,this._tail=t;for(var n=0;n<t;n++)this._list[n]=e[n]};Y.prototype._copyArray=function(e,t){var r=this._list,n=r.length,i=this.length;if(t=t|i,t==i&&this._head<this._tail)return this._list.slice(this._head,this._tail);var o=new Array(t),a=0,c;if(e||this._head>this._tail){for(c=this._head;c<n;c++)o[a++]=r[c];for(c=0;c<this._tail;c++)o[a++]=r[c]}else for(c=this._head;c<this._tail;c++)o[a++]=r[c];return o};Y.prototype._growArray=function(){if(this._head!=0){var e=this._copyArray(!0,this._list.length<<1);this._tail=this._list.length,this._head=0,this._list=e}else this._tail=this._list.length,this._list.length<<=1;this._capacityMask=this._capacityMask<<1|1};Y.prototype._shrinkArray=function(){this._list.length>>>=1,this._capacityMask>>>=1};Y.prototype._nextPowerOf2=function(e){var t=Math.log(e)/Math.log(2),r=1<<t+1;return Math.max(r,4)};Qa.exports=Y});var ef={};_e(ef,{StrictNoSign:()=>Lt,StrictSign:()=>bt,TopicValidatorResult:()=>me,gossipsub:()=>Qh,multicodec:()=>Jh});var kr="/floodsub/1.0.0",Lr="/meshsub/1.0.0",Ri="/meshsub/1.1.0",Bt="/meshsub/1.2.0";var Ci="ERR_TOPIC_VALIDATOR_REJECT",Ni="ERR_TOPIC_VALIDATOR_IGNORE";var $=class extends Error{static name="InvalidParametersError";constructor(e="Invalid parameters"){super(e),this.name="InvalidParametersError"}},Rt=class extends Error{static name="InvalidPublicKeyError";constructor(e="Invalid public key"){super(e),this.name="InvalidPublicKeyError"}};var Cs=class extends Error{static name="InvalidCIDError";constructor(e="Invalid CID"){super(e),this.name="InvalidCIDError"}},Ns=class extends Error{static name="InvalidMultihashError";constructor(e="Invalid Multihash"){super(e),this.name="InvalidMultihashError"}};var Ct=class extends Error{static name="UnsupportedKeyTypeError";constructor(e="Unsupported key type"){super(e),this.name="UnsupportedKeyTypeError"}};var Br=Symbol.for("@libp2p/peer-id");function _c(s){return typeof s?.handleEvent=="function"}function Ic(s){return(s!==!0&&s!==!1&&s?.once)??!1}var Os=class extends EventTarget{#e=new Map;constructor(){super()}listenerCount(e){let t=this.#e.get(e);return t==null?0:t.length}addEventListener(e,t,r){let n=Ic(r);super.addEventListener(e,o=>{if(n){let a=this.#e.get(o.type);a!=null&&(a=a.filter(({callback:c})=>c!==t),this.#e.set(o.type,a))}_c(t)?t.handleEvent(o):t(o)},r);let i=this.#e.get(e);i==null&&(i=[],this.#e.set(e,i)),i.push({callback:t,once:n})}removeEventListener(e,t,r){super.removeEventListener(e.toString(),t??null,r);let n=this.#e.get(e);n!=null&&(n=n.filter(({callback:i})=>i!==t),this.#e.set(e,n))}safeDispatchEvent(e,t={}){return this.dispatchEvent(new CustomEvent(e,t))}};var Ui=Symbol.for("@libp2p/service-capabilities"),Ki=Symbol.for("@libp2p/service-dependencies");var Ur={};_e(Ur,{base58btc:()=>te,base58flickr:()=>Lc});var kf=new Uint8Array(0);function Fi(s,e){if(s===e)return!0;if(s.byteLength!==e.byteLength)return!1;for(let t=0;t<s.byteLength;t++)if(s[t]!==e[t])return!1;return!0}function ze(s){if(s instanceof Uint8Array&&s.constructor.name==="Uint8Array")return s;if(s instanceof ArrayBuffer)return new Uint8Array(s);if(ArrayBuffer.isView(s))return new Uint8Array(s.buffer,s.byteOffset,s.byteLength);throw new Error("Unknown type, must be binary type")}function Hi(s){return new TextEncoder().encode(s)}function Gi(s){return new TextDecoder().decode(s)}function Tc(s,e){if(s.length>=255)throw new TypeError("Alphabet too long");for(var t=new Uint8Array(256),r=0;r<t.length;r++)t[r]=255;for(var n=0;n<s.length;n++){var i=s.charAt(n),o=i.charCodeAt(0);if(t[o]!==255)throw new TypeError(i+" is ambiguous");t[o]=n}var a=s.length,c=s.charAt(0),h=Math.log(a)/Math.log(256),m=Math.log(256)/Math.log(a);function d(u){if(u instanceof Uint8Array||(ArrayBuffer.isView(u)?u=new Uint8Array(u.buffer,u.byteOffset,u.byteLength):Array.isArray(u)&&(u=Uint8Array.from(u))),!(u instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(u.length===0)return"";for(var g=0,w=0,y=0,I=u.length;y!==I&&u[y]===0;)y++,g++;for(var l=(I-y)*m+1>>>0,f=new Uint8Array(l);y!==I;){for(var p=u[y],b=0,S=l-1;(p!==0||b<w)&&S!==-1;S--,b++)p+=256*f[S]>>>0,f[S]=p%a>>>0,p=p/a>>>0;if(p!==0)throw new Error("Non-zero carry");w=b,y++}for(var x=l-w;x!==l&&f[x]===0;)x++;for(var _=c.repeat(g);x<l;++x)_+=s.charAt(f[x]);return _}function E(u){if(typeof u!="string")throw new TypeError("Expected String");if(u.length===0)return new Uint8Array;var g=0;if(u[g]!==" "){for(var w=0,y=0;u[g]===c;)w++,g++;for(var I=(u.length-g)*h+1>>>0,l=new Uint8Array(I);u[g];){var f=t[u.charCodeAt(g)];if(f===255)return;for(var p=0,b=I-1;(f!==0||p<y)&&b!==-1;b--,p++)f+=a*l[b]>>>0,l[b]=f%256>>>0,f=f/256>>>0;if(f!==0)throw new Error("Non-zero carry");y=p,g++}if(u[g]!==" "){for(var S=I-y;S!==I&&l[S]===0;)S++;for(var x=new Uint8Array(w+(I-S)),_=w;S!==I;)x[_++]=l[S++];return x}}}function v(u){var g=E(u);if(g)return g;throw new Error(`Non-${e} character`)}return{encode:d,decodeUnsafe:E,decode:v}}var Ac=Tc,Dc=Ac,qi=Dc;var Rr=class{name;prefix;baseEncode;constructor(e,t,r){this.name=e,this.prefix=t,this.baseEncode=r}encode(e){if(e instanceof Uint8Array)return`${this.prefix}${this.baseEncode(e)}`;throw Error("Unknown type, must be binary type")}},Cr=class{name;prefix;baseDecode;prefixCodePoint;constructor(e,t,r){this.name=e,this.prefix=t;let n=t.codePointAt(0);if(n===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=n,this.baseDecode=r}decode(e){if(typeof e=="string"){if(e.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(e)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(e.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(e){return zi(this,e)}},Nr=class{decoders;constructor(e){this.decoders=e}or(e){return zi(this,e)}decode(e){let t=e[0],r=this.decoders[t];if(r!=null)return r.decode(e);throw RangeError(`Unable to decode multibase string ${JSON.stringify(e)}, only inputs prefixed with ${Object.keys(this.decoders)} are supported`)}};function zi(s,e){return new Nr({...s.decoders??{[s.prefix]:s},...e.decoders??{[e.prefix]:e}})}var Or=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(e,t,r,n){this.name=e,this.prefix=t,this.baseEncode=r,this.baseDecode=n,this.encoder=new Rr(e,t,r),this.decoder=new Cr(e,t,n)}encode(e){return this.encoder.encode(e)}decode(e){return this.decoder.decode(e)}};function Nt({name:s,prefix:e,encode:t,decode:r}){return new Or(s,e,t,r)}function it({name:s,prefix:e,alphabet:t}){let{encode:r,decode:n}=qi(t,s);return Nt({prefix:e,name:s,encode:r,decode:i=>ze(n(i))})}function Mc(s,e,t,r){let n=s.length;for(;s[n-1]==="=";)--n;let i=new Uint8Array(n*t/8|0),o=0,a=0,c=0;for(let h=0;h<n;++h){let m=e[s[h]];if(m===void 0)throw new SyntaxError(`Non-${r} character`);a=a<<t|m,o+=t,o>=8&&(o-=8,i[c++]=255&a>>o)}if(o>=t||(255&a<<8-o)!==0)throw new SyntaxError("Unexpected end of data");return i}function Pc(s,e,t){let r=e[e.length-1]==="=",n=(1<<t)-1,i="",o=0,a=0;for(let c=0;c<s.length;++c)for(a=a<<8|s[c],o+=8;o>t;)o-=t,i+=e[n&a>>o];if(o!==0&&(i+=e[n&a<<t-o]),r)for(;(i.length*t&7)!==0;)i+="=";return i}function kc(s){let e={};for(let t=0;t<s.length;++t)e[s[t]]=t;return e}function ee({name:s,prefix:e,bitsPerChar:t,alphabet:r}){let n=kc(r);return Nt({prefix:e,name:s,encode(i){return Pc(i,r,t)},decode(i){return Mc(i,n,t,s)}})}var te=it({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),Lc=it({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Kr={};_e(Kr,{base32:()=>Ot,base32hex:()=>Nc,base32hexpad:()=>Uc,base32hexpadupper:()=>Kc,base32hexupper:()=>Oc,base32pad:()=>Rc,base32padupper:()=>Cc,base32upper:()=>Bc,base32z:()=>Fc});var Ot=ee({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),Bc=ee({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Rc=ee({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),Cc=ee({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),Nc=ee({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),Oc=ee({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),Uc=ee({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),Kc=ee({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),Fc=ee({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Fr={};_e(Fr,{base36:()=>as,base36upper:()=>Hc});var as=it({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),Hc=it({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Gc=ji,Wi=128,Vc=127,qc=~Vc,zc=Math.pow(2,31);function ji(s,e,t){e=e||[],t=t||0;for(var r=t;s>=zc;)e[t++]=s&255|Wi,s/=128;for(;s&qc;)e[t++]=s&255|Wi,s>>>=7;return e[t]=s|0,ji.bytes=t-r+1,e}var Wc=Hr,$c=128,$i=127;function Hr(s,r){var t=0,r=r||0,n=0,i=r,o,a=s.length;do{if(i>=a)throw Hr.bytes=0,new RangeError("Could not decode varint");o=s[i++],t+=n<28?(o&$i)<<n:(o&$i)*Math.pow(2,n),n+=7}while(o>=$c);return Hr.bytes=i-r,t}var jc=Math.pow(2,7),Zc=Math.pow(2,14),Yc=Math.pow(2,21),Xc=Math.pow(2,28),Jc=Math.pow(2,35),Qc=Math.pow(2,42),el=Math.pow(2,49),tl=Math.pow(2,56),sl=Math.pow(2,63),rl=function(s){return s<jc?1:s<Zc?2:s<Yc?3:s<Xc?4:s<Jc?5:s<Qc?6:s<el?7:s<tl?8:s<sl?9:10},nl={encode:Gc,decode:Wc,encodingLength:rl},il=nl,cs=il;function ls(s,e=0){return[cs.decode(s,e),cs.decode.bytes]}function Ut(s,e,t=0){return cs.encode(s,e,t),e}function Kt(s){return cs.encodingLength(s)}function Ke(s,e){let t=e.byteLength,r=Kt(s),n=r+Kt(t),i=new Uint8Array(n+t);return Ut(s,i,0),Ut(t,i,r),i.set(e,n),new Ft(s,t,e,i)}function We(s){let e=ze(s),[t,r]=ls(e),[n,i]=ls(e.subarray(r)),o=e.subarray(r+i);if(o.byteLength!==n)throw new Error("Incorrect length");return new Ft(t,n,o,e)}function Zi(s,e){if(s===e)return!0;{let t=e;return s.code===t.code&&s.size===t.size&&t.bytes instanceof Uint8Array&&Fi(s.bytes,t.bytes)}}var Ft=class{code;size;digest;bytes;constructor(e,t,r,n){this.code=e,this.size=t,this.digest=r,this.bytes=n}};function Yi(s,e){let{bytes:t,version:r}=s;return r===0?al(t,Gr(s),e??te.encoder):cl(t,Gr(s),e??Ot.encoder)}var Xi=new WeakMap;function Gr(s){let e=Xi.get(s);if(e==null){let t=new Map;return Xi.set(s,t),t}return e}var ae=class s{code;version;multihash;bytes;"/";constructor(e,t,r,n){this.code=t,this.version=e,this.multihash=r,this.bytes=n,this["/"]=n}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:e,multihash:t}=this;if(e!==us)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(t.code!==ll)throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");return s.createV0(t)}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:e,digest:t}=this.multihash,r=Ke(e,t);return s.createV1(this.code,r)}case 1:return this;default:throw Error(`Can not convert CID version ${this.version} to version 1. This is a bug please report`)}}equals(e){return s.equals(this,e)}static equals(e,t){let r=t;return r!=null&&e.code===r.code&&e.version===r.version&&Zi(e.multihash,r.multihash)}toString(e){return Yi(this,e)}toJSON(){return{"/":Yi(this)}}link(){return this}[Symbol.toStringTag]="CID";[Symbol.for("nodejs.util.inspect.custom")](){return`CID(${this.toString()})`}static asCID(e){if(e==null)return null;let t=e;if(t instanceof s)return t;if(t["/"]!=null&&t["/"]===t.bytes||t.asCID===t){let{version:r,code:n,multihash:i,bytes:o}=t;return new s(r,n,i,o??Ji(r,n,i.bytes))}else if(t[ul]===!0){let{version:r,multihash:n,code:i}=t,o=We(n);return s.create(r,i,o)}else return null}static create(e,t,r){if(typeof t!="number")throw new Error("String codecs are no longer supported");if(!(r.bytes instanceof Uint8Array))throw new Error("Invalid digest");switch(e){case 0:{if(t!==us)throw new Error(`Version 0 CID must use dag-pb (code: ${us}) block encoding`);return new s(e,t,r,r.bytes)}case 1:{let n=Ji(e,t,r.bytes);return new s(e,t,r,n)}default:throw new Error("Invalid version")}}static createV0(e){return s.create(0,us,e)}static createV1(e,t){return s.create(1,e,t)}static decode(e){let[t,r]=s.decodeFirst(e);if(r.length!==0)throw new Error("Incorrect length");return t}static decodeFirst(e){let t=s.inspectBytes(e),r=t.size-t.multihashSize,n=ze(e.subarray(r,r+t.multihashSize));if(n.byteLength!==t.multihashSize)throw new Error("Incorrect length");let i=n.subarray(t.multihashSize-t.digestSize),o=new Ft(t.multihashCode,t.digestSize,i,n);return[t.version===0?s.createV0(o):s.createV1(t.codec,o),e.subarray(t.size)]}static inspectBytes(e){let t=0,r=()=>{let[d,E]=ls(e.subarray(t));return t+=E,d},n=r(),i=us;if(n===18?(n=0,t=0):i=r(),n!==0&&n!==1)throw new RangeError(`Invalid CID version ${n}`);let o=t,a=r(),c=r(),h=t+c,m=h-o;return{version:n,codec:i,multihashCode:a,digestSize:c,multihashSize:m,size:h}}static parse(e,t){let[r,n]=ol(e,t),i=s.decode(n);if(i.version===0&&e[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return Gr(i).set(r,e),i}};function ol(s,e){switch(s[0]){case"Q":{let t=e??te;return[te.prefix,t.decode(`${te.prefix}${s}`)]}case te.prefix:{let t=e??te;return[te.prefix,t.decode(s)]}case Ot.prefix:{let t=e??Ot;return[Ot.prefix,t.decode(s)]}case as.prefix:{let t=e??as;return[as.prefix,t.decode(s)]}default:{if(e==null)throw Error("To parse non base32, base36 or base58btc encoded CID multibase decoder must be provided");return[s[0],e.decode(s)]}}}function al(s,e,t){let{prefix:r}=t;if(r!==te.prefix)throw Error(`Cannot string encode V0 in ${t.name} encoding`);let n=e.get(r);if(n==null){let i=t.encode(s).slice(1);return e.set(r,i),i}else return n}function cl(s,e,t){let{prefix:r}=t,n=e.get(r);if(n==null){let i=t.encode(s);return e.set(r,i),i}else return n}var us=112,ll=18;function Ji(s,e,t){let r=Kt(s),n=r+Kt(e),i=new Uint8Array(n+t.byteLength);return Ut(s,i,0),Ut(e,i,r),i.set(t,n),i}var ul=Symbol.for("@ipld/js-cid/CID");var Vr={};_e(Vr,{identity:()=>Le});var Qi=0,hl="identity",eo=ze;function fl(s,e){if(e?.truncate!=null&&e.truncate!==s.byteLength){if(e.truncate<0||e.truncate>s.byteLength)throw new Error(`Invalid truncate option, must be less than or equal to ${s.byteLength}`);s=s.subarray(0,e.truncate)}return Ke(Qi,eo(s))}var Le={code:Qi,name:hl,encode:eo,digest:fl};function Ie(s,e){if(s===e)return!0;if(s.byteLength!==e.byteLength)return!1;for(let t=0;t<s.byteLength;t++)if(s[t]!==e[t])return!1;return!0}function $e(s=0){return new Uint8Array(s)}function ue(s=0){return new Uint8Array(s)}function yt(s,e){e==null&&(e=s.reduce((n,i)=>n+i.length,0));let t=ue(e),r=0;for(let n of s)t.set(n,r),r+=n.length;return t}var so=Symbol.for("@achingbrain/uint8arraylist");function to(s,e){if(e==null||e<0)throw new RangeError("index is out of bounds");let t=0;for(let r of s){let n=t+r.byteLength;if(e<n)return{buf:r,index:e-t};t=n}throw new RangeError("index is out of bounds")}function Ks(s){return!!s?.[so]}var re=class s{bufs;length;[so]=!0;constructor(...e){this.bufs=[],this.length=0,e.length>0&&this.appendAll(e)}*[Symbol.iterator](){yield*this.bufs}get byteLength(){return this.length}append(...e){this.appendAll(e)}appendAll(e){let t=0;for(let r of e)if(r instanceof Uint8Array)t+=r.byteLength,this.bufs.push(r);else if(Ks(r))t+=r.byteLength,this.bufs.push(...r.bufs);else throw new Error("Could not append value, must be an Uint8Array or a Uint8ArrayList");this.length+=t}prepend(...e){this.prependAll(e)}prependAll(e){let t=0;for(let r of e.reverse())if(r instanceof Uint8Array)t+=r.byteLength,this.bufs.unshift(r);else if(Ks(r))t+=r.byteLength,this.bufs.unshift(...r.bufs);else throw new Error("Could not prepend value, must be an Uint8Array or a Uint8ArrayList");this.length+=t}get(e){let t=to(this.bufs,e);return t.buf[t.index]}set(e,t){let r=to(this.bufs,e);r.buf[r.index]=t}write(e,t=0){if(e instanceof Uint8Array)for(let r=0;r<e.length;r++)this.set(t+r,e[r]);else if(Ks(e))for(let r=0;r<e.length;r++)this.set(t+r,e.get(r));else throw new Error("Could not write value, must be an Uint8Array or a Uint8ArrayList")}consume(e){if(e=Math.trunc(e),!(Number.isNaN(e)||e<=0)){if(e===this.byteLength){this.bufs=[],this.length=0;return}for(;this.bufs.length>0;)if(e>=this.bufs[0].byteLength)e-=this.bufs[0].byteLength,this.length-=this.bufs[0].byteLength,this.bufs.shift();else{this.bufs[0]=this.bufs[0].subarray(e),this.length-=e;break}}}slice(e,t){let{bufs:r,length:n}=this._subList(e,t);return yt(r,n)}subarray(e,t){let{bufs:r,length:n}=this._subList(e,t);return r.length===1?r[0]:yt(r,n)}sublist(e,t){let{bufs:r,length:n}=this._subList(e,t),i=new s;return i.length=n,i.bufs=[...r],i}_subList(e,t){if(e=e??0,t=t??this.length,e<0&&(e=this.length+e),t<0&&(t=this.length+t),e<0||t>this.length)throw new RangeError("index is out of bounds");if(e===t)return{bufs:[],length:0};if(e===0&&t===this.length)return{bufs:this.bufs,length:this.length};let r=[],n=0;for(let i=0;i<this.bufs.length;i++){let o=this.bufs[i],a=n,c=a+o.byteLength;if(n=c,e>=c)continue;let h=e>=a&&e<c,m=t>a&&t<=c;if(h&&m){if(e===a&&t===c){r.push(o);break}let d=e-a;r.push(o.subarray(d,d+(t-e)));break}if(h){if(e===0){r.push(o);continue}r.push(o.subarray(e-a));continue}if(m){if(t===c){r.push(o);break}r.push(o.subarray(0,t-a));break}r.push(o)}return{bufs:r,length:t-e}}indexOf(e,t=0){if(!Ks(e)&&!(e instanceof Uint8Array))throw new TypeError('The "value" argument must be a Uint8ArrayList or Uint8Array');let r=e instanceof Uint8Array?e:e.subarray();if(t=Number(t??0),isNaN(t)&&(t=0),t<0&&(t=this.length+t),t<0&&(t=0),e.length===0)return t>this.length?this.length:t;let n=r.byteLength;if(n===0)throw new TypeError("search must be at least 1 byte long");let i=256,o=new Int32Array(i);for(let d=0;d<i;d++)o[d]=-1;for(let d=0;d<n;d++)o[r[d]]=d;let a=o,c=this.byteLength-r.byteLength,h=r.byteLength-1,m;for(let d=t;d<=c;d+=m){m=0;for(let E=h;E>=0;E--){let v=this.get(d+E);if(r[E]!==v){m=Math.max(1,E-a[v]);break}}if(m===0)return d}return-1}getInt8(e){let t=this.subarray(e,e+1);return new DataView(t.buffer,t.byteOffset,t.byteLength).getInt8(0)}setInt8(e,t){let r=ue(1);new DataView(r.buffer,r.byteOffset,r.byteLength).setInt8(0,t),this.write(r,e)}getInt16(e,t){let r=this.subarray(e,e+2);return new DataView(r.buffer,r.byteOffset,r.byteLength).getInt16(0,t)}setInt16(e,t,r){let n=$e(2);new DataView(n.buffer,n.byteOffset,n.byteLength).setInt16(0,t,r),this.write(n,e)}getInt32(e,t){let r=this.subarray(e,e+4);return new DataView(r.buffer,r.byteOffset,r.byteLength).getInt32(0,t)}setInt32(e,t,r){let n=$e(4);new DataView(n.buffer,n.byteOffset,n.byteLength).setInt32(0,t,r),this.write(n,e)}getBigInt64(e,t){let r=this.subarray(e,e+8);return new DataView(r.buffer,r.byteOffset,r.byteLength).getBigInt64(0,t)}setBigInt64(e,t,r){let n=$e(8);new DataView(n.buffer,n.byteOffset,n.byteLength).setBigInt64(0,t,r),this.write(n,e)}getUint8(e){let t=this.subarray(e,e+1);return new DataView(t.buffer,t.byteOffset,t.byteLength).getUint8(0)}setUint8(e,t){let r=ue(1);new DataView(r.buffer,r.byteOffset,r.byteLength).setUint8(0,t),this.write(r,e)}getUint16(e,t){let r=this.subarray(e,e+2);return new DataView(r.buffer,r.byteOffset,r.byteLength).getUint16(0,t)}setUint16(e,t,r){let n=$e(2);new DataView(n.buffer,n.byteOffset,n.byteLength).setUint16(0,t,r),this.write(n,e)}getUint32(e,t){let r=this.subarray(e,e+4);return new DataView(r.buffer,r.byteOffset,r.byteLength).getUint32(0,t)}setUint32(e,t,r){let n=$e(4);new DataView(n.buffer,n.byteOffset,n.byteLength).setUint32(0,t,r),this.write(n,e)}getBigUint64(e,t){let r=this.subarray(e,e+8);return new DataView(r.buffer,r.byteOffset,r.byteLength).getBigUint64(0,t)}setBigUint64(e,t,r){let n=$e(8);new DataView(n.buffer,n.byteOffset,n.byteLength).setBigUint64(0,t,r),this.write(n,e)}getFloat32(e,t){let r=this.subarray(e,e+4);return new DataView(r.buffer,r.byteOffset,r.byteLength).getFloat32(0,t)}setFloat32(e,t,r){let n=$e(4);new DataView(n.buffer,n.byteOffset,n.byteLength).setFloat32(0,t,r),this.write(n,e)}getFloat64(e,t){let r=this.subarray(e,e+8);return new DataView(r.buffer,r.byteOffset,r.byteLength).getFloat64(0,t)}setFloat64(e,t,r){let n=$e(8);new DataView(n.buffer,n.byteOffset,n.byteLength).setFloat64(0,t,r),this.write(n,e)}equals(e){if(e==null||!(e instanceof s)||e.bufs.length!==this.bufs.length)return!1;for(let t=0;t<this.bufs.length;t++)if(!Ie(this.bufs[t],e.bufs[t]))return!1;return!0}static fromUint8Arrays(e,t){let r=new s;return r.bufs=e,t==null&&(t=e.reduce((n,i)=>n+i.byteLength,0)),r.length=t,r}};var qr={};_e(qr,{base10:()=>dl});var dl=it({prefix:"9",name:"base10",alphabet:"0123456789"});var zr={};_e(zr,{base16:()=>pl,base16upper:()=>ml});var pl=ee({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),ml=ee({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Wr={};_e(Wr,{base2:()=>gl});var gl=ee({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var $r={};_e($r,{base256emoji:()=>vl});var ro=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}"),bl=ro.reduce((s,e,t)=>(s[t]=e,s),[]),yl=ro.reduce((s,e,t)=>{let r=e.codePointAt(0);if(r==null)throw new Error(`Invalid character: ${e}`);return s[r]=t,s},[]);function wl(s){return s.reduce((e,t)=>(e+=bl[t],e),"")}function xl(s){let e=[];for(let t of s){let r=t.codePointAt(0);if(r==null)throw new Error(`Invalid character: ${t}`);let n=yl[r];if(n==null)throw new Error(`Non-base256emoji character: ${t}`);e.push(n)}return new Uint8Array(e)}var vl=Nt({prefix:"\u{1F680}",name:"base256emoji",encode:wl,decode:xl});var jr={};_e(jr,{base64:()=>El,base64pad:()=>Sl,base64url:()=>_l,base64urlpad:()=>Il});var El=ee({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),Sl=ee({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),_l=ee({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Il=ee({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Zr={};_e(Zr,{base8:()=>Tl});var Tl=ee({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Yr={};_e(Yr,{identity:()=>Al});var Al=Nt({prefix:"\0",name:"identity",encode:s=>Gi(s),decode:s=>Hi(s)});var pd=new TextEncoder,md=new TextDecoder;var Qr={};_e(Qr,{sha256:()=>wt,sha512:()=>kl});var Pl=20;function Jr({name:s,code:e,encode:t,minDigestLength:r,maxDigestLength:n}){return new Xr(s,e,t,r,n)}var Xr=class{name;code;encode;minDigestLength;maxDigestLength;constructor(e,t,r,n,i){this.name=e,this.code=t,this.encode=r,this.minDigestLength=n??Pl,this.maxDigestLength=i}digest(e,t){if(t?.truncate!=null){if(t.truncate<this.minDigestLength)throw new Error(`Invalid truncate option, must be greater than or equal to ${this.minDigestLength}`);if(this.maxDigestLength!=null&&t.truncate>this.maxDigestLength)throw new Error(`Invalid truncate option, must be less than or equal to ${this.maxDigestLength}`)}if(e instanceof Uint8Array){let r=this.encode(e);return r instanceof Uint8Array?no(r,this.code,t?.truncate):r.then(n=>no(n,this.code,t?.truncate))}else throw Error("Unknown type, must be binary type")}};function no(s,e,t){if(t!=null&&t!==s.byteLength){if(t>s.byteLength)throw new Error(`Invalid truncate option, must be less than or equal to ${s.byteLength}`);s=s.subarray(0,t)}return Ke(e,s)}function oo(s){return async e=>new Uint8Array(await crypto.subtle.digest(s,e))}var wt=Jr({name:"sha2-256",code:18,encode:oo("SHA-256")}),kl=Jr({name:"sha2-512",code:19,encode:oo("SHA-512")});var en={...Yr,...Wr,...Zr,...qr,...zr,...Kr,...Fr,...Ur,...jr,...$r},Ad={...Qr,...Vr};function co(s,e,t,r){return{name:s,prefix:e,encoder:{name:s,prefix:e,encode:t},decoder:{decode:r}}}var ao=co("utf8","u",s=>"u"+new TextDecoder("utf8").decode(s),s=>new TextEncoder().encode(s.substring(1))),tn=co("ascii","a",s=>{let e="a";for(let t=0;t<s.length;t++)e+=String.fromCharCode(s[t]);return e},s=>{s=s.substring(1);let e=ue(s.length);for(let t=0;t<s.length;t++)e[t]=s.charCodeAt(t);return e}),Ll={utf8:ao,"utf-8":ao,hex:en.base16,latin1:tn,ascii:tn,binary:tn,...en},Fs=Ll;function q(s,e="utf8"){let t=Fs[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return t.decoder.decode(`${t.prefix}${s}`)}function V(s,e="utf8"){let t=Fs[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return t.encoder.encode(s).substring(1)}var Bl=parseInt("11111",2),sn=parseInt("10000000",2),Rl=parseInt("01111111",2),lo={0:hs,1:hs,2:Cl,3:Ul,4:Kl,5:Ol,6:Nl,16:hs,22:hs,48:hs};function je(s,e={offset:0}){let t=s[e.offset]&Bl;if(e.offset++,lo[t]!=null)return lo[t](s,e);throw new Error("No decoder for tag "+t)}function fs(s,e){let t=0;if((s[e.offset]&sn)===sn){let r=s[e.offset]&Rl,n="0x";e.offset++;for(let i=0;i<r;i++,e.offset++)n+=s[e.offset].toString(16).padStart(2,"0");t=parseInt(n,16)}else t=s[e.offset],e.offset++;return t}function hs(s,e){fs(s,e);let t=[];for(;!(e.offset>=s.byteLength);){let r=je(s,e);if(r===null)break;t.push(r)}return t}function Cl(s,e){let t=fs(s,e),r=e.offset,n=e.offset+t,i=[];for(let o=r;o<n;o++)o===r&&s[o]===0||i.push(s[o]);return e.offset+=t,Uint8Array.from(i)}function Nl(s,e){let t=fs(s,e),r=e.offset+t,n=s[e.offset];e.offset++;let i=0,o=0;n<40?(i=0,o=n):n<80?(i=1,o=n-40):(i=2,o=n-80);let a=`${i}.${o}`,c=[];for(;e.offset<r;){let h=s[e.offset];if(e.offset++,c.push(h&127),h<128){c.reverse();let m=0;for(let d=0;d<c.length;d++)m+=c[d]<<d*7;a+=`.${m}`,c=[]}}return a}function Ol(s,e){return e.offset++,null}function Ul(s,e){let t=fs(s,e),r=s[e.offset];e.offset++;let n=s.subarray(e.offset,e.offset+t-1);if(e.offset+=t,r!==0)throw new Error("Unused bits in bit string is unimplemented");return n}function Kl(s,e){let t=fs(s,e),r=s.subarray(e.offset,e.offset+t);return e.offset+=t,r}function Fl(s){let e=s.toString(16);e.length%2===1&&(e="0"+e);let t=new re;for(let r=0;r<e.length;r+=2)t.append(Uint8Array.from([parseInt(`${e[r]}${e[r+1]}`,16)]));return t}function rn(s){if(s.byteLength<128)return Uint8Array.from([s.byteLength]);let e=Fl(s.byteLength);return new re(Uint8Array.from([e.byteLength|sn]),e)}function Te(s){let e=new re,t=128;return(s.subarray()[0]&t)===t&&e.append(Uint8Array.from([0])),e.append(s),new re(Uint8Array.from([2]),rn(e),e)}function Hs(s){let e=Uint8Array.from([0]),t=new re(e,s);return new re(Uint8Array.from([3]),rn(t),t)}function at(s,e=48){let t=new re;for(let r of s)t.append(r);return new re(Uint8Array.from([e]),rn(t),t)}async function uo(s,e,t,r){let n=await crypto.subtle.importKey("jwk",s,{name:"ECDSA",namedCurve:s.crv??"P-256"},!1,["verify"]);r?.signal?.throwIfAborted();let i=await crypto.subtle.verify({name:"ECDSA",hash:{name:"SHA-256"}},n,e,t.subarray());return r?.signal?.throwIfAborted(),i}var Hl=Uint8Array.from([6,8,42,134,72,206,61,3,1,7]),Gl=Uint8Array.from([6,5,43,129,4,0,34]),Vl=Uint8Array.from([6,5,43,129,4,0,35]),ql={ext:!0,kty:"EC",crv:"P-256"},zl={ext:!0,kty:"EC",crv:"P-384"},Wl={ext:!0,kty:"EC",crv:"P-521"},nn=32,on=48,an=66;function cn(s){let e=je(s);return ho(e)}function ho(s){let e=s[1][1][0],t=1,r,n;if(e.byteLength===nn*2+1)return r=V(e.subarray(t,t+nn),"base64url"),n=V(e.subarray(t+nn),"base64url"),new Ht({...ql,key_ops:["verify"],x:r,y:n});if(e.byteLength===on*2+1)return r=V(e.subarray(t,t+on),"base64url"),n=V(e.subarray(t+on),"base64url"),new Ht({...zl,key_ops:["verify"],x:r,y:n});if(e.byteLength===an*2+1)return r=V(e.subarray(t,t+an),"base64url"),n=V(e.subarray(t+an),"base64url"),new Ht({...Wl,key_ops:["verify"],x:r,y:n});throw new $(`coordinates were wrong length, got ${e.byteLength}, expected 65, 97 or 133`)}function fo(s){return at([Te(Uint8Array.from([1])),at([$l(s.crv)],160),at([Hs(new re(Uint8Array.from([4]),q(s.x??"","base64url"),q(s.y??"","base64url")))],161)]).subarray()}function $l(s){if(s==="P-256")return Hl;if(s==="P-384")return Gl;if(s==="P-521")return Vl;throw new $(`Invalid curve ${s}`)}var Ht=class{type="ECDSA";jwk;_raw;constructor(e){this.jwk=e}get raw(){return this._raw==null&&(this._raw=fo(this.jwk)),this._raw}toMultihash(){return Le.digest(Fe(this))}toCID(){return ae.createV1(114,this.toMultihash())}toString(){return te.encode(this.toMultihash().bytes).substring(1)}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:Ie(this.raw,e.raw)}async verify(e,t,r){return uo(this.jwk,t,e,r)}};function xt(s){return s instanceof Uint8Array||ArrayBuffer.isView(s)&&s.constructor.name==="Uint8Array"}function He(s,e=""){if(!Number.isSafeInteger(s)||s<0){let t=e&&`"${e}" `;throw new Error(`${t}expected integer >= 0, got ${s}`)}}function K(s,e,t=""){let r=xt(s),n=s?.length,i=e!==void 0;if(!r||i&&n!==e){let o=t&&`"${t}" `,a=i?` of length ${e}`:"",c=r?`length=${n}`:`type=${typeof s}`;throw new Error(o+"expected Uint8Array"+a+", got "+c)}return s}function Gs(s){if(typeof s!="function"||typeof s.create!="function")throw new Error("Hash must wrapped by utils.createHasher");He(s.outputLen),He(s.blockLen)}function Gt(s,e=!0){if(s.destroyed)throw new Error("Hash instance has been destroyed");if(e&&s.finished)throw new Error("Hash#digest() has already been called")}function mo(s,e){K(s,void 0,"digestInto() output");let t=e.outputLen;if(s.length<t)throw new Error('"digestInto() output" expected to be of length >='+t)}function Ye(...s){for(let e=0;e<s.length;e++)s[e].fill(0)}function Vs(s){return new DataView(s.buffer,s.byteOffset,s.byteLength)}function Be(s,e){return s<<32-e|s>>>e}var go=typeof Uint8Array.from([]).toHex=="function"&&typeof Uint8Array.fromHex=="function",jl=Array.from({length:256},(s,e)=>e.toString(16).padStart(2,"0"));function Xe(s){if(K(s),go)return s.toHex();let e="";for(let t=0;t<s.length;t++)e+=jl[s[t]];return e}var Ze={_0:48,_9:57,A:65,F:70,a:97,f:102};function po(s){if(s>=Ze._0&&s<=Ze._9)return s-Ze._0;if(s>=Ze.A&&s<=Ze.F)return s-(Ze.A-10);if(s>=Ze.a&&s<=Ze.f)return s-(Ze.a-10)}function Je(s){if(typeof s!="string")throw new Error("hex string expected, got "+typeof s);if(go)return Uint8Array.fromHex(s);let e=s.length,t=e/2;if(e%2)throw new Error("hex string expected, got unpadded hex of length "+e);let r=new Uint8Array(t);for(let n=0,i=0;n<t;n++,i+=2){let o=po(s.charCodeAt(i)),a=po(s.charCodeAt(i+1));if(o===void 0||a===void 0){let c=s[i]+s[i+1];throw new Error('hex string expected, got non-hex character "'+c+'" at index '+i)}r[n]=o*16+a}return r}function Ae(...s){let e=0;for(let r=0;r<s.length;r++){let n=s[r];K(n),e+=n.length}let t=new Uint8Array(e);for(let r=0,n=0;r<s.length;r++){let i=s[r];t.set(i,n),n+=i.length}return t}function ln(s,e={}){let t=(n,i)=>s(i).update(n).digest(),r=s(void 0);return t.outputLen=r.outputLen,t.blockLen=r.blockLen,t.create=n=>s(n),Object.assign(t,e),Object.freeze(t)}function Vt(s=32){let e=typeof globalThis=="object"?globalThis.crypto:null;if(typeof e?.getRandomValues!="function")throw new Error("crypto.getRandomValues must be defined");return e.getRandomValues(new Uint8Array(s))}var un=s=>({oid:Uint8Array.from([6,9,96,134,72,1,101,3,4,2,s])});function bo(s,e,t){return s&e^~s&t}function yo(s,e,t){return s&e^s&t^e&t}var ds=class{blockLen;outputLen;padOffset;isLE;buffer;view;finished=!1;length=0;pos=0;destroyed=!1;constructor(e,t,r,n){this.blockLen=e,this.outputLen=t,this.padOffset=r,this.isLE=n,this.buffer=new Uint8Array(e),this.view=Vs(this.buffer)}update(e){Gt(this),K(e);let{view:t,buffer:r,blockLen:n}=this,i=e.length;for(let o=0;o<i;){let a=Math.min(n-this.pos,i-o);if(a===n){let c=Vs(e);for(;n<=i-o;o+=n)this.process(c,o);continue}r.set(e.subarray(o,o+a),this.pos),this.pos+=a,o+=a,this.pos===n&&(this.process(t,0),this.pos=0)}return this.length+=e.length,this.roundClean(),this}digestInto(e){Gt(this),mo(e,this),this.finished=!0;let{buffer:t,view:r,blockLen:n,isLE:i}=this,{pos:o}=this;t[o++]=128,Ye(this.buffer.subarray(o)),this.padOffset>n-o&&(this.process(r,0),o=0);for(let d=o;d<n;d++)t[d]=0;r.setBigUint64(n-8,BigInt(this.length*8),i),this.process(r,0);let a=Vs(e),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen must be aligned to 32bit");let h=c/4,m=this.get();if(h>m.length)throw new Error("_sha2: outputLen bigger than state");for(let d=0;d<h;d++)a.setUint32(4*d,m[d],i)}digest(){let{buffer:e,outputLen:t}=this;this.digestInto(e);let r=e.slice(0,t);return this.destroy(),r}_cloneInto(e){e||=new this.constructor,e.set(...this.get());let{blockLen:t,buffer:r,length:n,finished:i,destroyed:o,pos:a}=this;return e.destroyed=o,e.finished=i,e.length=n,e.pos=a,n%t&&e.buffer.set(r),e}clone(){return this._cloneInto()}},Qe=Uint32Array.from([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]);var ce=Uint32Array.from([1779033703,4089235720,3144134277,2227873595,1013904242,4271175723,2773480762,1595750129,1359893119,2917565137,2600822924,725511199,528734635,4215389547,1541459225,327033209]);var qs=BigInt(4294967295),wo=BigInt(32);function Zl(s,e=!1){return e?{h:Number(s&qs),l:Number(s>>wo&qs)}:{h:Number(s>>wo&qs)|0,l:Number(s&qs)|0}}function xo(s,e=!1){let t=s.length,r=new Uint32Array(t),n=new Uint32Array(t);for(let i=0;i<t;i++){let{h:o,l:a}=Zl(s[i],e);[r[i],n[i]]=[o,a]}return[r,n]}var hn=(s,e,t)=>s>>>t,fn=(s,e,t)=>s<<32-t|e>>>t,vt=(s,e,t)=>s>>>t|e<<32-t,Et=(s,e,t)=>s<<32-t|e>>>t,ps=(s,e,t)=>s<<64-t|e>>>t-32,ms=(s,e,t)=>s>>>t-32|e<<64-t;function Ge(s,e,t,r){let n=(e>>>0)+(r>>>0);return{h:s+t+(n/2**32|0)|0,l:n|0}}var vo=(s,e,t)=>(s>>>0)+(e>>>0)+(t>>>0),Eo=(s,e,t,r)=>e+t+r+(s/2**32|0)|0,So=(s,e,t,r)=>(s>>>0)+(e>>>0)+(t>>>0)+(r>>>0),_o=(s,e,t,r,n)=>e+t+r+n+(s/2**32|0)|0,Io=(s,e,t,r,n)=>(s>>>0)+(e>>>0)+(t>>>0)+(r>>>0)+(n>>>0),To=(s,e,t,r,n,i)=>e+t+r+n+i+(s/2**32|0)|0;var Xl=Uint32Array.from([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]),ct=new Uint32Array(64),dn=class extends ds{constructor(e){super(64,e,8,!1)}get(){let{A:e,B:t,C:r,D:n,E:i,F:o,G:a,H:c}=this;return[e,t,r,n,i,o,a,c]}set(e,t,r,n,i,o,a,c){this.A=e|0,this.B=t|0,this.C=r|0,this.D=n|0,this.E=i|0,this.F=o|0,this.G=a|0,this.H=c|0}process(e,t){for(let d=0;d<16;d++,t+=4)ct[d]=e.getUint32(t,!1);for(let d=16;d<64;d++){let E=ct[d-15],v=ct[d-2],u=Be(E,7)^Be(E,18)^E>>>3,g=Be(v,17)^Be(v,19)^v>>>10;ct[d]=g+ct[d-7]+u+ct[d-16]|0}let{A:r,B:n,C:i,D:o,E:a,F:c,G:h,H:m}=this;for(let d=0;d<64;d++){let E=Be(a,6)^Be(a,11)^Be(a,25),v=m+E+bo(a,c,h)+Xl[d]+ct[d]|0,g=(Be(r,2)^Be(r,13)^Be(r,22))+yo(r,n,i)|0;m=h,h=c,c=a,a=o+v|0,o=i,i=n,n=r,r=v+g|0}r=r+this.A|0,n=n+this.B|0,i=i+this.C|0,o=o+this.D|0,a=a+this.E|0,c=c+this.F|0,h=h+this.G|0,m=m+this.H|0,this.set(r,n,i,o,a,c,h,m)}roundClean(){Ye(ct)}destroy(){this.set(0,0,0,0,0,0,0,0),Ye(this.buffer)}},pn=class extends dn{A=Qe[0]|0;B=Qe[1]|0;C=Qe[2]|0;D=Qe[3]|0;E=Qe[4]|0;F=Qe[5]|0;G=Qe[6]|0;H=Qe[7]|0;constructor(){super(32)}};var Ao=xo(["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(s=>BigInt(s))),Jl=Ao[0],Ql=Ao[1],lt=new Uint32Array(80),ut=new Uint32Array(80),mn=class extends ds{constructor(e){super(128,e,16,!1)}get(){let{Ah:e,Al:t,Bh:r,Bl:n,Ch:i,Cl:o,Dh:a,Dl:c,Eh:h,El:m,Fh:d,Fl:E,Gh:v,Gl:u,Hh:g,Hl:w}=this;return[e,t,r,n,i,o,a,c,h,m,d,E,v,u,g,w]}set(e,t,r,n,i,o,a,c,h,m,d,E,v,u,g,w){this.Ah=e|0,this.Al=t|0,this.Bh=r|0,this.Bl=n|0,this.Ch=i|0,this.Cl=o|0,this.Dh=a|0,this.Dl=c|0,this.Eh=h|0,this.El=m|0,this.Fh=d|0,this.Fl=E|0,this.Gh=v|0,this.Gl=u|0,this.Hh=g|0,this.Hl=w|0}process(e,t){for(let l=0;l<16;l++,t+=4)lt[l]=e.getUint32(t),ut[l]=e.getUint32(t+=4);for(let l=16;l<80;l++){let f=lt[l-15]|0,p=ut[l-15]|0,b=vt(f,p,1)^vt(f,p,8)^hn(f,p,7),S=Et(f,p,1)^Et(f,p,8)^fn(f,p,7),x=lt[l-2]|0,_=ut[l-2]|0,P=vt(x,_,19)^ps(x,_,61)^hn(x,_,6),O=Et(x,_,19)^ms(x,_,61)^fn(x,_,6),R=So(S,O,ut[l-7],ut[l-16]),A=_o(R,b,P,lt[l-7],lt[l-16]);lt[l]=A|0,ut[l]=R|0}let{Ah:r,Al:n,Bh:i,Bl:o,Ch:a,Cl:c,Dh:h,Dl:m,Eh:d,El:E,Fh:v,Fl:u,Gh:g,Gl:w,Hh:y,Hl:I}=this;for(let l=0;l<80;l++){let f=vt(d,E,14)^vt(d,E,18)^ps(d,E,41),p=Et(d,E,14)^Et(d,E,18)^ms(d,E,41),b=d&v^~d&g,S=E&u^~E&w,x=Io(I,p,S,Ql[l],ut[l]),_=To(x,y,f,b,Jl[l],lt[l]),P=x|0,O=vt(r,n,28)^ps(r,n,34)^ps(r,n,39),R=Et(r,n,28)^ms(r,n,34)^ms(r,n,39),A=r&i^r&a^i&a,D=n&o^n&c^o&c;y=g|0,I=w|0,g=v|0,w=u|0,v=d|0,u=E|0,{h:d,l:E}=Ge(h|0,m|0,_|0,P|0),h=a|0,m=c|0,a=i|0,c=o|0,i=r|0,o=n|0;let T=vo(P,R,D);r=Eo(T,_,O,A),n=T|0}({h:r,l:n}=Ge(this.Ah|0,this.Al|0,r|0,n|0)),{h:i,l:o}=Ge(this.Bh|0,this.Bl|0,i|0,o|0),{h:a,l:c}=Ge(this.Ch|0,this.Cl|0,a|0,c|0),{h,l:m}=Ge(this.Dh|0,this.Dl|0,h|0,m|0),{h:d,l:E}=Ge(this.Eh|0,this.El|0,d|0,E|0),{h:v,l:u}=Ge(this.Fh|0,this.Fl|0,v|0,u|0),{h:g,l:w}=Ge(this.Gh|0,this.Gl|0,g|0,w|0),{h:y,l:I}=Ge(this.Hh|0,this.Hl|0,y|0,I|0),this.set(r,n,i,o,a,c,h,m,d,E,v,u,g,w,y,I)}roundClean(){Ye(lt,ut)}destroy(){Ye(this.buffer),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}},gn=class extends mn{Ah=ce[0]|0;Al=ce[1]|0;Bh=ce[2]|0;Bl=ce[3]|0;Ch=ce[4]|0;Cl=ce[5]|0;Dh=ce[6]|0;Dl=ce[7]|0;Eh=ce[8]|0;El=ce[9]|0;Fh=ce[10]|0;Fl=ce[11]|0;Gh=ce[12]|0;Gl=ce[13]|0;Hh=ce[14]|0;Hl=ce[15]|0;constructor(){super(64)}};var Do=ln(()=>new pn,un(1));var Mo=ln(()=>new gn,un(3));var yn=BigInt(0),bn=BigInt(1);function et(s,e=""){if(typeof s!="boolean"){let t=e&&`"${e}" `;throw new Error(t+"expected boolean, got type="+typeof s)}return s}function Po(s){if(typeof s=="bigint"){if(!zs(s))throw new Error("positive bigint expected, got "+s)}else He(s);return s}function gs(s){let e=Po(s).toString(16);return e.length&1?"0"+e:e}function ko(s){if(typeof s!="string")throw new Error("hex string expected, got "+typeof s);return s===""?yn:BigInt("0x"+s)}function qt(s){return ko(Xe(s))}function St(s){return ko(Xe($s(K(s)).reverse()))}function Ws(s,e){He(e),s=Po(s);let t=Je(s.toString(16).padStart(e*2,"0"));if(t.length!==e)throw new Error("number too large");return t}function wn(s,e){return Ws(s,e).reverse()}function $s(s){return Uint8Array.from(s)}var zs=s=>typeof s=="bigint"&&yn<=s;function eu(s,e,t){return zs(s)&&zs(e)&&zs(t)&&e<=s&&s<t}function bs(s,e,t,r){if(!eu(e,t,r))throw new Error("expected valid "+s+": "+t+" <= n < "+r+", got "+e)}function xn(s){let e;for(e=0;s>yn;s>>=bn,e+=1);return e}var ys=s=>(bn<<BigInt(s))-bn;function Lo(s,e,t){if(He(s,"hashLen"),He(e,"qByteLen"),typeof t!="function")throw new Error("hmacFn must be a function");let r=w=>new Uint8Array(w),n=Uint8Array.of(),i=Uint8Array.of(0),o=Uint8Array.of(1),a=1e3,c=r(s),h=r(s),m=0,d=()=>{c.fill(1),h.fill(0),m=0},E=(...w)=>t(h,Ae(c,...w)),v=(w=n)=>{h=E(i,w),c=E(),w.length!==0&&(h=E(o,w),c=E())},u=()=>{if(m++>=a)throw new Error("drbg: tried max amount of iterations");let w=0,y=[];for(;w<e;){c=E();let I=c.slice();y.push(I),w+=c.length}return Ae(...y)};return(w,y)=>{d(),v(w);let I;for(;!(I=y(u()));)v();return d(),I}}function ht(s,e={},t={}){if(!s||typeof s!="object")throw new Error("expected valid options object");function r(i,o,a){let c=s[i];if(a&&c===void 0)return;let h=typeof c;if(h!==o||c===null)throw new Error(`param "${i}" is invalid: expected ${o}, got ${h}`)}let n=(i,o)=>Object.entries(i).forEach(([a,c])=>r(a,c,o));n(e,!1),n(t,!0)}function zt(s){let e=new WeakMap;return(t,...r)=>{let n=e.get(t);if(n!==void 0)return n;let i=s(t,...r);return e.set(t,i),i}}var ge=BigInt(0),ne=BigInt(1),_t=BigInt(2),Co=BigInt(3),No=BigInt(4),Oo=BigInt(5),tu=BigInt(7),Uo=BigInt(8),su=BigInt(9),Ko=BigInt(16);function se(s,e){let t=s%e;return t>=ge?t:e+t}function j(s,e,t){let r=s;for(;e-- >ge;)r*=r,r%=t;return r}function Bo(s,e){if(s===ge)throw new Error("invert: expected non-zero number");if(e<=ge)throw new Error("invert: expected positive modulus, got "+e);let t=se(s,e),r=e,n=ge,i=ne,o=ne,a=ge;for(;t!==ge;){let h=r/t,m=r%t,d=n-o*h,E=i-a*h;r=t,t=m,n=o,i=a,o=d,a=E}if(r!==ne)throw new Error("invert: does not exist");return se(n,e)}function En(s,e,t){if(!s.eql(s.sqr(e),t))throw new Error("Cannot find square root")}function Fo(s,e){let t=(s.ORDER+ne)/No,r=s.pow(e,t);return En(s,r,e),r}function ru(s,e){let t=(s.ORDER-Oo)/Uo,r=s.mul(e,_t),n=s.pow(r,t),i=s.mul(e,n),o=s.mul(s.mul(i,_t),n),a=s.mul(i,s.sub(o,s.ONE));return En(s,a,e),a}function nu(s){let e=Wt(s),t=Ho(s),r=t(e,e.neg(e.ONE)),n=t(e,r),i=t(e,e.neg(r)),o=(s+tu)/Ko;return(a,c)=>{let h=a.pow(c,o),m=a.mul(h,r),d=a.mul(h,n),E=a.mul(h,i),v=a.eql(a.sqr(m),c),u=a.eql(a.sqr(d),c);h=a.cmov(h,m,v),m=a.cmov(E,d,u);let g=a.eql(a.sqr(m),c),w=a.cmov(h,m,g);return En(a,w,c),w}}function Ho(s){if(s<Co)throw new Error("sqrt is not defined for small field");let e=s-ne,t=0;for(;e%_t===ge;)e/=_t,t++;let r=_t,n=Wt(s);for(;Ro(n,r)===1;)if(r++>1e3)throw new Error("Cannot find square root: probably non-prime P");if(t===1)return Fo;let i=n.pow(r,e),o=(e+ne)/_t;return function(c,h){if(c.is0(h))return h;if(Ro(c,h)!==1)throw new Error("Cannot find square root");let m=t,d=c.mul(c.ONE,i),E=c.pow(h,e),v=c.pow(h,o);for(;!c.eql(E,c.ONE);){if(c.is0(E))return c.ZERO;let u=1,g=c.sqr(E);for(;!c.eql(g,c.ONE);)if(u++,g=c.sqr(g),u===m)throw new Error("Cannot find square root");let w=ne<<BigInt(m-u-1),y=c.pow(d,w);m=u,d=c.sqr(y),E=c.mul(E,d),v=c.mul(v,y)}return v}}function iu(s){return s%No===Co?Fo:s%Uo===Oo?ru:s%Ko===su?nu(s):Ho(s)}var Go=(s,e)=>(se(s,e)&ne)===ne,ou=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function Sn(s){let e={ORDER:"bigint",BYTES:"number",BITS:"number"},t=ou.reduce((r,n)=>(r[n]="function",r),e);return ht(s,t),s}function au(s,e,t){if(t<ge)throw new Error("invalid exponent, negatives unsupported");if(t===ge)return s.ONE;if(t===ne)return e;let r=s.ONE,n=e;for(;t>ge;)t&ne&&(r=s.mul(r,n)),n=s.sqr(n),t>>=ne;return r}function ws(s,e,t=!1){let r=new Array(e.length).fill(t?s.ZERO:void 0),n=e.reduce((o,a,c)=>s.is0(a)?o:(r[c]=o,s.mul(o,a)),s.ONE),i=s.inv(n);return e.reduceRight((o,a,c)=>s.is0(a)?o:(r[c]=s.mul(o,r[c]),s.mul(o,a)),i),r}function Ro(s,e){let t=(s.ORDER-ne)/_t,r=s.pow(e,t),n=s.eql(r,s.ONE),i=s.eql(r,s.ZERO),o=s.eql(r,s.neg(s.ONE));if(!n&&!i&&!o)throw new Error("invalid Legendre symbol result");return n?1:i?0:-1}function cu(s,e){e!==void 0&&He(e);let t=e!==void 0?e:s.toString(2).length,r=Math.ceil(t/8);return{nBitLength:t,nByteLength:r}}var vn=class{ORDER;BITS;BYTES;isLE;ZERO=ge;ONE=ne;_lengths;_sqrt;_mod;constructor(e,t={}){if(e<=ge)throw new Error("invalid field: expected ORDER > 0, got "+e);let r;this.isLE=!1,t!=null&&typeof t=="object"&&(typeof t.BITS=="number"&&(r=t.BITS),typeof t.sqrt=="function"&&(this.sqrt=t.sqrt),typeof t.isLE=="boolean"&&(this.isLE=t.isLE),t.allowedLengths&&(this._lengths=t.allowedLengths?.slice()),typeof t.modFromBytes=="boolean"&&(this._mod=t.modFromBytes));let{nBitLength:n,nByteLength:i}=cu(e,r);if(i>2048)throw new Error("invalid field: expected ORDER of <= 2048 bytes");this.ORDER=e,this.BITS=n,this.BYTES=i,this._sqrt=void 0,Object.preventExtensions(this)}create(e){return se(e,this.ORDER)}isValid(e){if(typeof e!="bigint")throw new Error("invalid field element: expected bigint, got "+typeof e);return ge<=e&&e<this.ORDER}is0(e){return e===ge}isValidNot0(e){return!this.is0(e)&&this.isValid(e)}isOdd(e){return(e&ne)===ne}neg(e){return se(-e,this.ORDER)}eql(e,t){return e===t}sqr(e){return se(e*e,this.ORDER)}add(e,t){return se(e+t,this.ORDER)}sub(e,t){return se(e-t,this.ORDER)}mul(e,t){return se(e*t,this.ORDER)}pow(e,t){return au(this,e,t)}div(e,t){return se(e*Bo(t,this.ORDER),this.ORDER)}sqrN(e){return e*e}addN(e,t){return e+t}subN(e,t){return e-t}mulN(e,t){return e*t}inv(e){return Bo(e,this.ORDER)}sqrt(e){return this._sqrt||(this._sqrt=iu(this.ORDER)),this._sqrt(this,e)}toBytes(e){return this.isLE?wn(e,this.BYTES):Ws(e,this.BYTES)}fromBytes(e,t=!1){K(e);let{_lengths:r,BYTES:n,isLE:i,ORDER:o,_mod:a}=this;if(r){if(!r.includes(e.length)||e.length>n)throw new Error("Field.fromBytes: expected "+r+" bytes, got "+e.length);let h=new Uint8Array(n);h.set(e,i?0:h.length-e.length),e=h}if(e.length!==n)throw new Error("Field.fromBytes: expected "+n+" bytes, got "+e.length);let c=i?St(e):qt(e);if(a&&(c=se(c,o)),!t&&!this.isValid(c))throw new Error("invalid field element: outside of range 0..ORDER");return c}invertBatch(e){return ws(this,e)}cmov(e,t,r){return r?t:e}};function Wt(s,e={}){return new vn(s,e)}function Vo(s){if(typeof s!="bigint")throw new Error("field order must be bigint");let e=s.toString(2).length;return Math.ceil(e/8)}function _n(s){let e=Vo(s);return e+Math.ceil(e/2)}function In(s,e,t=!1){K(s);let r=s.length,n=Vo(e),i=_n(e);if(r<16||r<i||r>1024)throw new Error("expected "+i+"-1024 bytes of input, got "+r);let o=t?St(s):qt(s),a=se(o,e-ne)+ne;return t?wn(a,n):Ws(a,n)}var $t=BigInt(0),It=BigInt(1);function xs(s,e){let t=e.negate();return s?t:e}function Tt(s,e){let t=ws(s.Fp,e.map(r=>r.Z));return e.map((r,n)=>s.fromAffine(r.toAffine(t[n])))}function $o(s,e){if(!Number.isSafeInteger(s)||s<=0||s>e)throw new Error("invalid window size, expected [1.."+e+"], got W="+s)}function Tn(s,e){$o(s,e);let t=Math.ceil(e/s)+1,r=2**(s-1),n=2**s,i=ys(s),o=BigInt(s);return{windows:t,windowSize:r,mask:i,maxNumber:n,shiftBy:o}}function qo(s,e,t){let{windowSize:r,mask:n,maxNumber:i,shiftBy:o}=t,a=Number(s&n),c=s>>o;a>r&&(a-=i,c+=It);let h=e*r,m=h+Math.abs(a)-1,d=a===0,E=a<0,v=e%2!==0;return{nextN:c,offset:m,isZero:d,isNeg:E,isNegF:v,offsetF:h}}var An=new WeakMap,jo=new WeakMap;function Dn(s){return jo.get(s)||1}function zo(s){if(s!==$t)throw new Error("invalid wNAF")}var jt=class{BASE;ZERO;Fn;bits;constructor(e,t){this.BASE=e.BASE,this.ZERO=e.ZERO,this.Fn=e.Fn,this.bits=t}_unsafeLadder(e,t,r=this.ZERO){let n=e;for(;t>$t;)t&It&&(r=r.add(n)),n=n.double(),t>>=It;return r}precomputeWindow(e,t){let{windows:r,windowSize:n}=Tn(t,this.bits),i=[],o=e,a=o;for(let c=0;c<r;c++){a=o,i.push(a);for(let h=1;h<n;h++)a=a.add(o),i.push(a);o=a.double()}return i}wNAF(e,t,r){if(!this.Fn.isValid(r))throw new Error("invalid scalar");let n=this.ZERO,i=this.BASE,o=Tn(e,this.bits);for(let a=0;a<o.windows;a++){let{nextN:c,offset:h,isZero:m,isNeg:d,isNegF:E,offsetF:v}=qo(r,a,o);r=c,m?i=i.add(xs(E,t[v])):n=n.add(xs(d,t[h]))}return zo(r),{p:n,f:i}}wNAFUnsafe(e,t,r,n=this.ZERO){let i=Tn(e,this.bits);for(let o=0;o<i.windows&&r!==$t;o++){let{nextN:a,offset:c,isZero:h,isNeg:m}=qo(r,o,i);if(r=a,!h){let d=t[c];n=n.add(m?d.negate():d)}}return zo(r),n}getPrecomputes(e,t,r){let n=An.get(t);return n||(n=this.precomputeWindow(t,e),e!==1&&(typeof r=="function"&&(n=r(n)),An.set(t,n))),n}cached(e,t,r){let n=Dn(e);return this.wNAF(n,this.getPrecomputes(n,e,r),t)}unsafe(e,t,r,n){let i=Dn(e);return i===1?this._unsafeLadder(e,t,n):this.wNAFUnsafe(i,this.getPrecomputes(i,e,r),t,n)}createCache(e,t){$o(t,this.bits),jo.set(e,t),An.delete(e)}hasCache(e){return Dn(e)!==1}};function Zo(s,e,t,r){let n=e,i=s.ZERO,o=s.ZERO;for(;t>$t||r>$t;)t&It&&(i=i.add(n)),r&It&&(o=o.add(n)),n=n.double(),t>>=It,r>>=It;return{p1:i,p2:o}}function Wo(s,e,t){if(e){if(e.ORDER!==s)throw new Error("Field.ORDER must match order: Fp == p, Fn == n");return Sn(e),e}else return Wt(s,{isLE:t})}function js(s,e,t={},r){if(r===void 0&&(r=s==="edwards"),!e||typeof e!="object")throw new Error(`expected valid ${s} CURVE object`);for(let c of["p","n","h"]){let h=e[c];if(!(typeof h=="bigint"&&h>$t))throw new Error(`CURVE.${c} must be positive bigint`)}let n=Wo(e.p,t.Fp,r),i=Wo(e.n,t.Fn,r),a=["Gx","Gy","a",s==="weierstrass"?"b":"d"];for(let c of a)if(!n.isValid(e[c]))throw new Error(`CURVE.${c} must be valid field element of CURVE.Fp`);return e=Object.freeze(Object.assign({},e)),{CURVE:e,Fp:n,Fn:i}}function Zs(s,e){return function(r){let n=s(r);return{secretKey:n,publicKey:e(n)}}}var ft=BigInt(0),ie=BigInt(1),Mn=BigInt(2),lu=BigInt(8);function uu(s,e,t,r){let n=s.sqr(t),i=s.sqr(r),o=s.add(s.mul(e.a,n),i),a=s.add(s.ONE,s.mul(e.d,s.mul(n,i)));return s.eql(o,a)}function Yo(s,e={}){let t=js("edwards",s,e,e.FpFnLE),{Fp:r,Fn:n}=t,i=t.CURVE,{h:o}=i;ht(e,{},{uvRatio:"function"});let a=Mn<<BigInt(n.BYTES*8)-ie,c=w=>r.create(w),h=e.uvRatio||((w,y)=>{try{return{isValid:!0,value:r.sqrt(r.div(w,y))}}catch{return{isValid:!1,value:ft}}});if(!uu(r,i,i.Gx,i.Gy))throw new Error("bad curve params: generator point");function m(w,y,I=!1){let l=I?ie:ft;return bs("coordinate "+w,y,l,a),y}function d(w){if(!(w instanceof u))throw new Error("EdwardsPoint expected")}let E=zt((w,y)=>{let{X:I,Y:l,Z:f}=w,p=w.is0();y==null&&(y=p?lu:r.inv(f));let b=c(I*y),S=c(l*y),x=r.mul(f,y);if(p)return{x:ft,y:ie};if(x!==ie)throw new Error("invZ was invalid");return{x:b,y:S}}),v=zt(w=>{let{a:y,d:I}=i;if(w.is0())throw new Error("bad point: ZERO");let{X:l,Y:f,Z:p,T:b}=w,S=c(l*l),x=c(f*f),_=c(p*p),P=c(_*_),O=c(S*y),R=c(_*c(O+x)),A=c(P+c(I*c(S*x)));if(R!==A)throw new Error("bad point: equation left != right (1)");let D=c(l*f),T=c(p*b);if(D!==T)throw new Error("bad point: equation left != right (2)");return!0});class u{static BASE=new u(i.Gx,i.Gy,ie,c(i.Gx*i.Gy));static ZERO=new u(ft,ie,ie,ft);static Fp=r;static Fn=n;X;Y;Z;T;constructor(y,I,l,f){this.X=m("x",y),this.Y=m("y",I),this.Z=m("z",l,!0),this.T=m("t",f),Object.freeze(this)}static CURVE(){return i}static fromAffine(y){if(y instanceof u)throw new Error("extended point not allowed");let{x:I,y:l}=y||{};return m("x",I),m("y",l),new u(I,l,ie,c(I*l))}static fromBytes(y,I=!1){let l=r.BYTES,{a:f,d:p}=i;y=$s(K(y,l,"point")),et(I,"zip215");let b=$s(y),S=y[l-1];b[l-1]=S&-129;let x=St(b),_=I?a:r.ORDER;bs("point.y",x,ft,_);let P=c(x*x),O=c(P-ie),R=c(p*P-f),{isValid:A,value:D}=h(O,R);if(!A)throw new Error("bad point: invalid y coordinate");let T=(D&ie)===ie,M=(S&128)!==0;if(!I&&D===ft&&M)throw new Error("bad point: x=0 and x_0=1");return M!==T&&(D=c(-D)),u.fromAffine({x:D,y:x})}static fromHex(y,I=!1){return u.fromBytes(Je(y),I)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}precompute(y=8,I=!0){return g.createCache(this,y),I||this.multiply(Mn),this}assertValidity(){v(this)}equals(y){d(y);let{X:I,Y:l,Z:f}=this,{X:p,Y:b,Z:S}=y,x=c(I*S),_=c(p*f),P=c(l*S),O=c(b*f);return x===_&&P===O}is0(){return this.equals(u.ZERO)}negate(){return new u(c(-this.X),this.Y,this.Z,c(-this.T))}double(){let{a:y}=i,{X:I,Y:l,Z:f}=this,p=c(I*I),b=c(l*l),S=c(Mn*c(f*f)),x=c(y*p),_=I+l,P=c(c(_*_)-p-b),O=x+b,R=O-S,A=x-b,D=c(P*R),T=c(O*A),M=c(P*A),k=c(R*O);return new u(D,T,k,M)}add(y){d(y);let{a:I,d:l}=i,{X:f,Y:p,Z:b,T:S}=this,{X:x,Y:_,Z:P,T:O}=y,R=c(f*x),A=c(p*_),D=c(S*l*O),T=c(b*P),M=c((f+p)*(x+_)-R-A),k=T-D,B=T+D,C=c(A-I*R),L=c(M*k),N=c(B*C),U=c(M*C),X=c(k*B);return new u(L,N,X,U)}subtract(y){return this.add(y.negate())}multiply(y){if(!n.isValidNot0(y))throw new Error("invalid scalar: expected 1 <= sc < curve.n");let{p:I,f:l}=g.cached(this,y,f=>Tt(u,f));return Tt(u,[I,l])[0]}multiplyUnsafe(y,I=u.ZERO){if(!n.isValid(y))throw new Error("invalid scalar: expected 0 <= sc < curve.n");return y===ft?u.ZERO:this.is0()||y===ie?this:g.unsafe(this,y,l=>Tt(u,l),I)}isSmallOrder(){return this.multiplyUnsafe(o).is0()}isTorsionFree(){return g.unsafe(this,i.n).is0()}toAffine(y){return E(this,y)}clearCofactor(){return o===ie?this:this.multiplyUnsafe(o)}toBytes(){let{x:y,y:I}=this.toAffine(),l=r.toBytes(I);return l[l.length-1]|=y&ie?128:0,l}toHex(){return Xe(this.toBytes())}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}}let g=new jt(u,n.BITS);return u.BASE.precompute(8),u}function Xo(s,e,t={}){if(typeof e!="function")throw new Error('"hash" function param is required');ht(t,{},{adjustScalarBytes:"function",randomBytes:"function",domain:"function",prehash:"function",mapToCurve:"function"});let{prehash:r}=t,{BASE:n,Fp:i,Fn:o}=s,a=t.randomBytes||Vt,c=t.adjustScalarBytes||(x=>x),h=t.domain||((x,_,P)=>{if(et(P,"phflag"),_.length||P)throw new Error("Contexts/pre-hash are not supported");return x});function m(x){return o.create(St(x))}function d(x){let _=l.secretKey;K(x,l.secretKey,"secretKey");let P=K(e(x),2*_,"hashedSecretKey"),O=c(P.slice(0,_)),R=P.slice(_,2*_),A=m(O);return{head:O,prefix:R,scalar:A}}function E(x){let{head:_,prefix:P,scalar:O}=d(x),R=n.multiply(O),A=R.toBytes();return{head:_,prefix:P,scalar:O,point:R,pointBytes:A}}function v(x){return E(x).pointBytes}function u(x=Uint8Array.of(),..._){let P=Ae(..._);return m(e(h(P,K(x,void 0,"context"),!!r)))}function g(x,_,P={}){x=K(x,void 0,"message"),r&&(x=r(x));let{prefix:O,scalar:R,pointBytes:A}=E(_),D=u(P.context,O,x),T=n.multiply(D).toBytes(),M=u(P.context,T,A,x),k=o.create(D+M*R);if(!o.isValid(k))throw new Error("sign failed: invalid s");let B=Ae(T,o.toBytes(k));return K(B,l.signature,"result")}let w={zip215:!0};function y(x,_,P,O=w){let{context:R,zip215:A}=O,D=l.signature;x=K(x,D,"signature"),_=K(_,void 0,"message"),P=K(P,l.publicKey,"publicKey"),A!==void 0&&et(A,"zip215"),r&&(_=r(_));let T=D/2,M=x.subarray(0,T),k=St(x.subarray(T,D)),B,C,L;try{B=s.fromBytes(P,A),C=s.fromBytes(M,A),L=n.multiplyUnsafe(k)}catch{return!1}if(!A&&B.isSmallOrder())return!1;let N=u(R,C.toBytes(),B.toBytes(),_);return C.add(B.multiplyUnsafe(N)).subtract(L).clearCofactor().is0()}let I=i.BYTES,l={secretKey:I,publicKey:I,signature:2*I,seed:I};function f(x=a(l.seed)){return K(x,l.seed,"seed")}function p(x){return xt(x)&&x.length===o.BYTES}function b(x,_){try{return!!s.fromBytes(x,_)}catch{return!1}}let S={getExtendedPublicKey:E,randomSecretKey:f,isValidSecretKey:p,isValidPublicKey:b,toMontgomery(x){let{y:_}=s.fromBytes(x),P=l.publicKey,O=P===32;if(!O&&P!==57)throw new Error("only defined for 25519 and 448");let R=O?i.div(ie+_,ie-_):i.div(_-ie,_+ie);return i.toBytes(R)},toMontgomerySecret(x){let _=l.secretKey;K(x,_);let P=e(x.subarray(0,_));return c(P).subarray(0,_)}};return Object.freeze({keygen:Zs(f,v),getPublicKey:v,sign:g,verify:y,utils:S,Point:s,lengths:l})}var hu=BigInt(1),Jo=BigInt(2);var fu=BigInt(5),du=BigInt(8),Pn=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffed"),pu={p:Pn,n:BigInt("0x1000000000000000000000000000000014def9dea2f79cd65812631a5cf5d3ed"),h:du,a:BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffec"),d:BigInt("0x52036cee2b6ffe738cc740797779e89800700a4d4141d8ab75eb4dca135978a3"),Gx:BigInt("0x216936d3cd6e53fec0a4e231fdd6dc5c692cc7609525a7b2c9562d608f25d51a"),Gy:BigInt("0x6666666666666666666666666666666666666666666666666666666666666658")};function mu(s){let e=BigInt(10),t=BigInt(20),r=BigInt(40),n=BigInt(80),i=Pn,a=s*s%i*s%i,c=j(a,Jo,i)*a%i,h=j(c,hu,i)*s%i,m=j(h,fu,i)*h%i,d=j(m,e,i)*m%i,E=j(d,t,i)*d%i,v=j(E,r,i)*E%i,u=j(v,n,i)*v%i,g=j(u,n,i)*v%i,w=j(g,e,i)*m%i;return{pow_p_5_8:j(w,Jo,i)*s%i,b2:a}}function gu(s){return s[0]&=248,s[31]&=127,s[31]|=64,s}var Qo=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752");function bu(s,e){let t=Pn,r=se(e*e*e,t),n=se(r*r*e,t),i=mu(s*n).pow_p_5_8,o=se(s*r*i,t),a=se(e*o*o,t),c=o,h=se(o*Qo,t),m=a===s,d=a===se(-s,t),E=a===se(-s*Qo,t);return m&&(o=c),(d||E)&&(o=h),Go(o,t)&&(o=se(-o,t)),{isValid:m||d,value:o}}var yu=Yo(pu,{uvRatio:bu});function wu(s){return Xo(yu,Mo,Object.assign({adjustScalarBytes:gu},s))}var ea=wu({});var vs=class extends Error{constructor(e="An error occurred while verifying a message"){super(e),this.name="VerificationError"}},Ys=class extends Error{constructor(e="Missing Web Crypto API"){super(e),this.name="WebCryptoMissingError"}};var ta={get(s=globalThis){let e=s.crypto;if(e?.subtle==null)throw new Ys("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 e}};var Pe=ta;var Xs=32;var kn,xu=(async()=>{try{return await Pe.get().subtle.generateKey({name:"Ed25519"},!0,["sign","verify"]),!0}catch{return!1}})();async function vu(s,e,t){if(s.buffer instanceof ArrayBuffer){let r=await Pe.get().subtle.importKey("raw",s.buffer,{name:"Ed25519"},!1,["verify"]);return await Pe.get().subtle.verify({name:"Ed25519"},r,e,t instanceof Uint8Array?t:t.subarray())}throw new TypeError("WebCrypto does not support SharedArrayBuffer for Ed25519 keys")}function Eu(s,e,t){return ea.verify(e,t instanceof Uint8Array?t:t.subarray(),s)}async function sa(s,e,t){return kn==null&&(kn=await xu),kn?vu(s,e,t):Eu(s,e,t)}function Js(s){return s==null?!1:typeof s.then=="function"&&typeof s.catch=="function"&&typeof s.finally=="function"}var Qs=class{type="Ed25519";raw;constructor(e){this.raw=Ln(e,Xs)}toMultihash(){return Le.digest(Fe(this))}toCID(){return ae.createV1(114,this.toMultihash())}toString(){return te.encode(this.toMultihash().bytes).substring(1)}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:Ie(this.raw,e.raw)}verify(e,t,r){r?.signal?.throwIfAborted();let n=sa(this.raw,t,e);return Js(n)?n.then(i=>(r?.signal?.throwIfAborted(),i)):n}};function Bn(s){return s=Ln(s,Xs),new Qs(s)}function Ln(s,e){if(s=Uint8Array.from(s??[]),s.length!==e)throw new $(`Key must be a Uint8Array of length ${e}, got ${s.length}`);return s}var _u=Math.pow(2,7),Iu=Math.pow(2,14),Tu=Math.pow(2,21),Rn=Math.pow(2,28),Cn=Math.pow(2,35),Nn=Math.pow(2,42),On=Math.pow(2,49),H=128,he=127;function ke(s){if(s<_u)return 1;if(s<Iu)return 2;if(s<Tu)return 3;if(s<Rn)return 4;if(s<Cn)return 5;if(s<Nn)return 6;if(s<On)return 7;if(Number.MAX_SAFE_INTEGER!=null&&s>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function Un(s,e,t=0){switch(ke(s)){case 8:e[t++]=s&255|H,s/=128;case 7:e[t++]=s&255|H,s/=128;case 6:e[t++]=s&255|H,s/=128;case 5:e[t++]=s&255|H,s/=128;case 4:e[t++]=s&255|H,s>>>=7;case 3:e[t++]=s&255|H,s>>>=7;case 2:e[t++]=s&255|H,s>>>=7;case 1:{e[t++]=s&255,s>>>=7;break}default:throw new Error("unreachable")}return e}function Au(s,e,t=0){switch(ke(s)){case 8:e.set(t++,s&255|H),s/=128;case 7:e.set(t++,s&255|H),s/=128;case 6:e.set(t++,s&255|H),s/=128;case 5:e.set(t++,s&255|H),s/=128;case 4:e.set(t++,s&255|H),s>>>=7;case 3:e.set(t++,s&255|H),s>>>=7;case 2:e.set(t++,s&255|H),s>>>=7;case 1:{e.set(t++,s&255),s>>>=7;break}default:throw new Error("unreachable")}return e}function Kn(s,e){let t=s[e],r=0;if(r+=t&he,t<H||(t=s[e+1],r+=(t&he)<<7,t<H)||(t=s[e+2],r+=(t&he)<<14,t<H)||(t=s[e+3],r+=(t&he)<<21,t<H)||(t=s[e+4],r+=(t&he)*Rn,t<H)||(t=s[e+5],r+=(t&he)*Cn,t<H)||(t=s[e+6],r+=(t&he)*Nn,t<H)||(t=s[e+7],r+=(t&he)*On,t<H))return r;throw new RangeError("Could not decode varint")}function Du(s,e){let t=s.get(e),r=0;if(r+=t&he,t<H||(t=s.get(e+1),r+=(t&he)<<7,t<H)||(t=s.get(e+2),r+=(t&he)<<14,t<H)||(t=s.get(e+3),r+=(t&he)<<21,t<H)||(t=s.get(e+4),r+=(t&he)*Rn,t<H)||(t=s.get(e+5),r+=(t&he)*Cn,t<H)||(t=s.get(e+6),r+=(t&he)*Nn,t<H)||(t=s.get(e+7),r+=(t&he)*On,t<H))return r;throw new RangeError("Could not decode varint")}function Fn(s,e,t=0){return e==null&&(e=ue(ke(s))),e instanceof Uint8Array?Un(s,e,t):Au(s,e,t)}function Hn(s,e=0){return s instanceof Uint8Array?Kn(s,e):Du(s,e)}var Vn=new Float32Array([-0]),dt=new Uint8Array(Vn.buffer);function na(s,e,t){Vn[0]=s,e[t]=dt[0],e[t+1]=dt[1],e[t+2]=dt[2],e[t+3]=dt[3]}function ia(s,e){return dt[0]=s[e],dt[1]=s[e+1],dt[2]=s[e+2],dt[3]=s[e+3],Vn[0]}var qn=new Float64Array([-0]),fe=new Uint8Array(qn.buffer);function oa(s,e,t){qn[0]=s,e[t]=fe[0],e[t+1]=fe[1],e[t+2]=fe[2],e[t+3]=fe[3],e[t+4]=fe[4],e[t+5]=fe[5],e[t+6]=fe[6],e[t+7]=fe[7]}function aa(s,e){return fe[0]=s[e],fe[1]=s[e+1],fe[2]=s[e+2],fe[3]=s[e+3],fe[4]=s[e+4],fe[5]=s[e+5],fe[6]=s[e+6],fe[7]=s[e+7],qn[0]}var Mu=BigInt(Number.MAX_SAFE_INTEGER),Pu=BigInt(Number.MIN_SAFE_INTEGER),De=class s{lo;hi;constructor(e,t){this.lo=e|0,this.hi=t|0}toNumber(e=!1){if(!e&&this.hi>>>31>0){let t=~this.lo+1>>>0,r=~this.hi>>>0;return t===0&&(r=r+1>>>0),-(t+r*4294967296)}return this.lo+this.hi*4294967296}toBigInt(e=!1){if(e)return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n);if(this.hi>>>31){let t=~this.lo+1>>>0,r=~this.hi>>>0;return t===0&&(r=r+1>>>0),-(BigInt(t)+(BigInt(r)<<32n))}return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n)}toString(e=!1){return this.toBigInt(e).toString()}zzEncode(){let e=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^e)>>>0,this.lo=(this.lo<<1^e)>>>0,this}zzDecode(){let e=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^e)>>>0,this.hi=(this.hi>>>1^e)>>>0,this}length(){let e=this.lo,t=(this.lo>>>28|this.hi<<4)>>>0,r=this.hi>>>24;return r===0?t===0?e<16384?e<128?1:2:e<2097152?3:4:t<16384?t<128?5:6:t<2097152?7:8:r<128?9:10}static fromBigInt(e){if(e===0n)return At;if(e<Mu&&e>Pu)return this.fromNumber(Number(e));let t=e<0n;t&&(e=-e);let r=e>>32n,n=e-(r<<32n);return t&&(r=~r|0n,n=~n|0n,++n>ca&&(n=0n,++r>ca&&(r=0n))),new s(Number(n),Number(r))}static fromNumber(e){if(e===0)return At;let t=e<0;t&&(e=-e);let r=e>>>0,n=(e-r)/4294967296>>>0;return t&&(n=~n>>>0,r=~r>>>0,++r>4294967295&&(r=0,++n>4294967295&&(n=0))),new s(r,n)}static from(e){return typeof e=="number"?s.fromNumber(e):typeof e=="bigint"?s.fromBigInt(e):typeof e=="string"?s.fromBigInt(BigInt(e)):e.low!=null||e.high!=null?new s(e.low>>>0,e.high>>>0):At}},At=new De(0,0);At.toBigInt=function(){return 0n};At.zzEncode=At.zzDecode=function(){return this};At.length=function(){return 1};var ca=4294967296n;function la(s){let e=0,t=0;for(let r=0;r<s.length;++r)t=s.charCodeAt(r),t<128?e+=1:t<2048?e+=2:(t&64512)===55296&&(s.charCodeAt(r+1)&64512)===56320?(++r,e+=4):e+=3;return e}function ua(s,e,t){if(t-e<1)return"";let n,i=[],o=0,a;for(;e<t;)a=s[e++],a<128?i[o++]=a:a>191&&a<224?i[o++]=(a&31)<<6|s[e++]&63:a>239&&a<365?(a=((a&7)<<18|(s[e++]&63)<<12|(s[e++]&63)<<6|s[e++]&63)-65536,i[o++]=55296+(a>>10),i[o++]=56320+(a&1023)):i[o++]=(a&15)<<12|(s[e++]&63)<<6|s[e++]&63,o>8191&&((n??(n=[])).push(String.fromCharCode.apply(String,i)),o=0);return n!=null?(o>0&&n.push(String.fromCharCode.apply(String,i.slice(0,o))),n.join("")):String.fromCharCode.apply(String,i.slice(0,o))}function zn(s,e,t){let r=t,n,i;for(let o=0;o<s.length;++o)n=s.charCodeAt(o),n<128?e[t++]=n:n<2048?(e[t++]=n>>6|192,e[t++]=n&63|128):(n&64512)===55296&&((i=s.charCodeAt(o+1))&64512)===56320?(n=65536+((n&1023)<<10)+(i&1023),++o,e[t++]=n>>18|240,e[t++]=n>>12&63|128,e[t++]=n>>6&63|128,e[t++]=n&63|128):(e[t++]=n>>12|224,e[t++]=n>>6&63|128,e[t++]=n&63|128);return t-r}function Re(s,e){return RangeError(`index out of range: ${s.pos} + ${e??1} > ${s.len}`)}function er(s,e){return(s[e-4]|s[e-3]<<8|s[e-2]<<16|s[e-1]<<24)>>>0}var Wn=class{buf;pos;len;_slice=Uint8Array.prototype.subarray;constructor(e){this.buf=e,this.pos=0,this.len=e.length}uint32(){let e=4294967295;if(e=(this.buf[this.pos]&127)>>>0,this.buf[this.pos++]<128||(e=(e|(this.buf[this.pos]&127)<<7)>>>0,this.buf[this.pos++]<128)||(e=(e|(this.buf[this.pos]&127)<<14)>>>0,this.buf[this.pos++]<128)||(e=(e|(this.buf[this.pos]&127)<<21)>>>0,this.buf[this.pos++]<128)||(e=(e|(this.buf[this.pos]&15)<<28)>>>0,this.buf[this.pos++]<128))return e;if((this.pos+=5)>this.len)throw this.pos=this.len,Re(this,10);return e}int32(){return this.uint32()|0}sint32(){let e=this.uint32();return e>>>1^-(e&1)|0}bool(){return this.uint32()!==0}fixed32(){if(this.pos+4>this.len)throw Re(this,4);return er(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Re(this,4);return er(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Re(this,4);let e=ia(this.buf,this.pos);return this.pos+=4,e}double(){if(this.pos+8>this.len)throw Re(this,4);let e=aa(this.buf,this.pos);return this.pos+=8,e}bytes(){let e=this.uint32(),t=this.pos,r=this.pos+e;if(r>this.len)throw Re(this,e);return this.pos+=e,t===r?new Uint8Array(0):this.buf.subarray(t,r)}string(){let e=this.bytes();return ua(e,0,e.length)}skip(e){if(typeof e=="number"){if(this.pos+e>this.len)throw Re(this,e);this.pos+=e}else do if(this.pos>=this.len)throw Re(this);while((this.buf[this.pos++]&128)!==0);return this}skipType(e){switch(e){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;(e=this.uint32()&7)!==4;)this.skipType(e);break;case 5:this.skip(4);break;default:throw Error(`invalid wire type ${e} at offset ${this.pos}`)}return this}readLongVarint(){let e=new De(0,0),t=0;if(this.len-this.pos>4){for(;t<4;++t)if(e.lo=(e.lo|(this.buf[this.pos]&127)<<t*7)>>>0,this.buf[this.pos++]<128)return e;if(e.lo=(e.lo|(this.buf[this.pos]&127)<<28)>>>0,e.hi=(e.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return e;t=0}else{for(;t<3;++t){if(this.pos>=this.len)throw Re(this);if(e.lo=(e.lo|(this.buf[this.pos]&127)<<t*7)>>>0,this.buf[this.pos++]<128)return e}return e.lo=(e.lo|(this.buf[this.pos++]&127)<<t*7)>>>0,e}if(this.len-this.pos>4){for(;t<5;++t)if(e.hi=(e.hi|(this.buf[this.pos]&127)<<t*7+3)>>>0,this.buf[this.pos++]<128)return e}else for(;t<5;++t){if(this.pos>=this.len)throw Re(this);if(e.hi=(e.hi|(this.buf[this.pos]&127)<<t*7+3)>>>0,this.buf[this.pos++]<128)return e}throw Error("invalid varint encoding")}readFixed64(){if(this.pos+8>this.len)throw Re(this,8);let e=er(this.buf,this.pos+=4),t=er(this.buf,this.pos+=4);return new De(e,t)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){let e=Kn(this.buf,this.pos);return this.pos+=ke(e),e}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 Es(s){return new Wn(s instanceof Uint8Array?s:s.subarray())}function be(s,e,t){let r=Es(s);return e.decode(r,void 0,t)}function $n(s){let e=s??8192,t=e>>>1,r,n=e;return function(o){if(o<1||o>t)return ue(o);n+o>e&&(r=ue(e),n=0);let a=r.subarray(n,n+=o);return(n&7)!==0&&(n=(n|7)+1),a}}var Dt=class{fn;len;next;val;constructor(e,t,r){this.fn=e,this.len=t,this.next=void 0,this.val=r}};function jn(){}var Yn=class{head;tail;len;next;constructor(e){this.head=e.head,this.tail=e.tail,this.len=e.len,this.next=e.states}},ku=$n();function Lu(s){return globalThis.Buffer!=null?ue(s):ku(s)}var _s=class{len;head;tail;states;constructor(){this.len=0,this.head=new Dt(jn,0,0),this.tail=this.head,this.states=null}_push(e,t,r){return this.tail=this.tail.next=new Dt(e,t,r),this.len+=t,this}uint32(e){return this.len+=(this.tail=this.tail.next=new Xn((e=e>>>0)<128?1:e<16384?2:e<2097152?3:e<268435456?4:5,e)).len,this}int32(e){return e<0?this._push(tr,10,De.fromNumber(e)):this.uint32(e)}sint32(e){return this.uint32((e<<1^e>>31)>>>0)}uint64(e){let t=De.fromBigInt(e);return this._push(tr,t.length(),t)}uint64Number(e){return this._push(Un,ke(e),e)}uint64String(e){return this.uint64(BigInt(e))}int64(e){return this.uint64(e)}int64Number(e){return this.uint64Number(e)}int64String(e){return this.uint64String(e)}sint64(e){let t=De.fromBigInt(e).zzEncode();return this._push(tr,t.length(),t)}sint64Number(e){let t=De.fromNumber(e).zzEncode();return this._push(tr,t.length(),t)}sint64String(e){return this.sint64(BigInt(e))}bool(e){return this._push(Zn,1,e?1:0)}fixed32(e){return this._push(Ss,4,e>>>0)}sfixed32(e){return this.fixed32(e)}fixed64(e){let t=De.fromBigInt(e);return this._push(Ss,4,t.lo)._push(Ss,4,t.hi)}fixed64Number(e){let t=De.fromNumber(e);return this._push(Ss,4,t.lo)._push(Ss,4,t.hi)}fixed64String(e){return this.fixed64(BigInt(e))}sfixed64(e){return this.fixed64(e)}sfixed64Number(e){return this.fixed64Number(e)}sfixed64String(e){return this.fixed64String(e)}float(e){return this._push(na,4,e)}double(e){return this._push(oa,8,e)}bytes(e){let t=e.length>>>0;return t===0?this._push(Zn,1,0):this.uint32(t)._push(Ru,t,e)}string(e){let t=la(e);return t!==0?this.uint32(t)._push(zn,t,e):this._push(Zn,1,0)}fork(){return this.states=new Yn(this),this.head=this.tail=new Dt(jn,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 Dt(jn,0,0),this.len=0),this}ldelim(){let e=this.head,t=this.tail,r=this.len;return this.reset().uint32(r),r!==0&&(this.tail.next=e.next,this.tail=t,this.len+=r),this}finish(){let e=this.head.next,t=Lu(this.len),r=0;for(;e!=null;)e.fn(e.val,t,r),r+=e.len,e=e.next;return t}};function Zn(s,e,t){e[t]=s&255}function Bu(s,e,t){for(;s>127;)e[t++]=s&127|128,s>>>=7;e[t]=s}var Xn=class extends Dt{next;constructor(e,t){super(Bu,e,t),this.next=void 0}};function tr(s,e,t){for(;s.hi!==0;)e[t++]=s.lo&127|128,s.lo=(s.lo>>>7|s.hi<<25)>>>0,s.hi>>>=7;for(;s.lo>127;)e[t++]=s.lo&127|128,s.lo=s.lo>>>7;e[t++]=s.lo}function Ss(s,e,t){e[t]=s&255,e[t+1]=s>>>8&255,e[t+2]=s>>>16&255,e[t+3]=s>>>24}function Ru(s,e,t){e.set(s,t)}globalThis.Buffer!=null&&(_s.prototype.bytes=function(s){let e=s.length>>>0;return this.uint32(e),e>0&&this._push(Cu,e,s),this},_s.prototype.string=function(s){let e=globalThis.Buffer.byteLength(s);return this.uint32(e),e>0&&this._push(Nu,e,s),this});function Cu(s,e,t){e.set(s,t)}function Nu(s,e,t){s.length<40?zn(s,e,t):e.utf8Write!=null?e.utf8Write(s,t):e.set(q(s),t)}function Jn(){return new _s}function ye(s,e){let t=Jn();return e.encode(s,t,{lengthDelimited:!1}),t.finish()}function*we(s,e,t){let r=Es(s);yield*e.stream(r,void 0,"$",t)}var sr={VARINT:0,BIT64:1,LENGTH_DELIMITED:2,START_GROUP:3,END_GROUP:4,BIT32:5};function rr(s,e,t,r,n){return{name:s,type:e,encode:t,decode:r,stream:n}}function Qn(s){function e(i){if(s[i.toString()]==null)throw new Error("Invalid enum value");return s[i]}let t=function(o,a){let c=e(o);a.int32(c)},r=function(o){let a=o.int32();return e(a)},n=function*(o){let a=o.int32();yield e(a)};return rr("enum",sr.VARINT,t,r,n)}function xe(s,e,t){return rr("message",sr.LENGTH_DELIMITED,s,e,t)}var z=class extends Error{code="ERR_MAX_LENGTH";name="MaxLengthError"};var Z;(function(s){s.RSA="RSA",s.Ed25519="Ed25519",s.secp256k1="secp256k1",s.ECDSA="ECDSA"})(Z||(Z={}));var ei;(function(s){s[s.RSA=0]="RSA",s[s.Ed25519=1]="Ed25519",s[s.secp256k1=2]="secp256k1",s[s.ECDSA=3]="ECDSA"})(ei||(ei={}));(function(s){s.codec=()=>Qn(ei)})(Z||(Z={}));var Ve;(function(s){let e;s.codec=()=>(e==null&&(e=xe((i,o,a={})=>{a.lengthDelimited!==!1&&o.fork(),i.Type!=null&&(o.uint32(8),Z.codec().encode(i.Type,o)),i.Data!=null&&(o.uint32(18),o.bytes(i.Data)),a.lengthDelimited!==!1&&o.ldelim()},(i,o,a={})=>{let c={},h=o==null?i.len:i.pos+o;for(;i.pos<h;){let m=i.uint32();switch(m>>>3){case 1:{c.Type=Z.codec().decode(i);break}case 2:{c.Data=i.bytes();break}default:{i.skipType(m&7);break}}}return c},function*(i,o,a,c={}){let h=o==null?i.len:i.pos+o;for(;i.pos<h;){let m=i.uint32();switch(m>>>3){case 1:{yield{field:`${a}.Type`,value:Z.codec().decode(i)};break}case 2:{yield{field:`${a}.Data`,value:i.bytes()};break}default:{i.skipType(m&7);break}}}})),e);function t(i){return ye(i,s.codec())}s.encode=t;function r(i,o){return be(i,s.codec(),o)}s.decode=r;function n(i,o){return we(i,s.codec(),o)}s.stream=n})(Ve||(Ve={}));var ti;(function(s){let e;s.codec=()=>(e==null&&(e=xe((i,o,a={})=>{a.lengthDelimited!==!1&&o.fork(),i.Type!=null&&(o.uint32(8),Z.codec().encode(i.Type,o)),i.Data!=null&&(o.uint32(18),o.bytes(i.Data)),a.lengthDelimited!==!1&&o.ldelim()},(i,o,a={})=>{let c={},h=o==null?i.len:i.pos+o;for(;i.pos<h;){let m=i.uint32();switch(m>>>3){case 1:{c.Type=Z.codec().decode(i);break}case 2:{c.Data=i.bytes();break}default:{i.skipType(m&7);break}}}return c},function*(i,o,a,c={}){let h=o==null?i.len:i.pos+o;for(;i.pos<h;){let m=i.uint32();switch(m>>>3){case 1:{yield{field:`${a}.Type`,value:Z.codec().decode(i)};break}case 2:{yield{field:`${a}.Data`,value:i.bytes()};break}default:{i.skipType(m&7);break}}}})),e);function t(i){return ye(i,s.codec())}s.encode=t;function r(i,o){return be(i,s.codec(),o)}s.decode=r;function n(i,o){return we(i,s.codec(),o)}s.stream=n})(ti||(ti={}));function Ou(s){return s instanceof Uint8Array||ArrayBuffer.isView(s)&&s.constructor.name==="Uint8Array"&&"BYTES_PER_ELEMENT"in s&&s.BYTES_PER_ELEMENT===1}function Uu(s,e=""){if(typeof s!="number"){let t=e&&`"${e}" `;throw new TypeError(`${t}expected number, got ${typeof s}`)}if(!Number.isSafeInteger(s)||s<0){let t=e&&`"${e}" `;throw new RangeError(`${t}expected integer >= 0, got ${s}`)}}function si(s,e,t=""){let r=Ou(s),n=s?.length,i=e!==void 0;if(!r||i&&n!==e){let o=t&&`"${t}" `,a=i?` of length ${e}`:"",c=r?`length=${n}`:`type=${typeof s}`,h=o+"expected Uint8Array"+a+", got "+c;throw r?new RangeError(h):new TypeError(h)}return s}function ri(s,e=!0){if(s.destroyed)throw new Error("Hash instance has been destroyed");if(e&&s.finished)throw new Error("Hash#digest() has already been called")}function da(s,e){si(s,void 0,"digestInto() output");let t=e.outputLen;if(s.length<t)throw new RangeError('"digestInto() output" expected to be of length >='+t)}function Is(...s){for(let e=0;e<s.length;e++)s[e].fill(0)}function nr(s){return new DataView(s.buffer,s.byteOffset,s.byteLength)}function Ce(s,e){return s<<32-e|s>>>e}function pa(s,e={}){let t=(n,i)=>s(i).update(n).digest(),r=s(void 0);return t.outputLen=r.outputLen,t.blockLen=r.blockLen,t.canXOF=r.canXOF,t.create=n=>s(n),Object.assign(t,e),Object.freeze(t)}function ma(s=32){Uu(s,"bytesLength");let e=typeof globalThis=="object"?globalThis.crypto:null;if(typeof e?.getRandomValues!="function")throw new Error("crypto.getRandomValues must be defined");if(s>65536)throw new RangeError(`"bytesLength" expected <= 65536, got ${s}`);return e.getRandomValues(new Uint8Array(s))}var ga=s=>({oid:Uint8Array.from([6,9,96,134,72,1,101,3,4,2,s])});function ir(s){if(isNaN(s)||s<=0)throw new $("random bytes length must be a Number bigger than 0");return ma(s)}var As={};_e(As,{MAX_RSA_KEY_SIZE:()=>oi,generateRSAKeyPair:()=>Ea,jwkToJWKKeyPair:()=>Sa,jwkToPkcs1:()=>Vu,jwkToPkix:()=>ui,jwkToRSAPrivateKey:()=>pi,pkcs1MessageToJwk:()=>ci,pkcs1MessageToRSAPrivateKey:()=>hi,pkcs1ToJwk:()=>Gu,pkcs1ToRSAPrivateKey:()=>va,pkixMessageToJwk:()=>li,pkixMessageToRSAPublicKey:()=>di,pkixToJwk:()=>qu,pkixToRSAPublicKey:()=>fi});function ba(s,e,t){return s&e^~s&t}function ya(s,e,t){return s&e^s&t^e&t}var or=class{blockLen;outputLen;canXOF=!1;padOffset;isLE;buffer;view;finished=!1;length=0;pos=0;destroyed=!1;constructor(e,t,r,n){this.blockLen=e,this.outputLen=t,this.padOffset=r,this.isLE=n,this.buffer=new Uint8Array(e),this.view=nr(this.buffer)}update(e){ri(this),si(e);let{view:t,buffer:r,blockLen:n}=this,i=e.length;for(let o=0;o<i;){let a=Math.min(n-this.pos,i-o);if(a===n){let c=nr(e);for(;n<=i-o;o+=n)this.process(c,o);continue}r.set(e.subarray(o,o+a),this.pos),this.pos+=a,o+=a,this.pos===n&&(this.process(t,0),this.pos=0)}return this.length+=e.length,this.roundClean(),this}digestInto(e){ri(this),da(e,this),this.finished=!0;let{buffer:t,view:r,blockLen:n,isLE:i}=this,{pos:o}=this;t[o++]=128,Is(this.buffer.subarray(o)),this.padOffset>n-o&&(this.process(r,0),o=0);for(let d=o;d<n;d++)t[d]=0;r.setBigUint64(n-8,BigInt(this.length*8),i),this.process(r,0);let a=nr(e),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen must be aligned to 32bit");let h=c/4,m=this.get();if(h>m.length)throw new Error("_sha2: outputLen bigger than state");for(let d=0;d<h;d++)a.setUint32(4*d,m[d],i)}digest(){let{buffer:e,outputLen:t}=this;this.digestInto(e);let r=e.slice(0,t);return this.destroy(),r}_cloneInto(e){e||=new this.constructor,e.set(...this.get());let{blockLen:t,buffer:r,length:n,finished:i,destroyed:o,pos:a}=this;return e.destroyed=o,e.finished=i,e.length=n,e.pos=a,n%t&&e.buffer.set(r),e}clone(){return this._cloneInto()}},tt=Uint32Array.from([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]);var Ku=Uint32Array.from([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]),pt=new Uint32Array(64),ni=class extends or{constructor(e){super(64,e,8,!1)}get(){let{A:e,B:t,C:r,D:n,E:i,F:o,G:a,H:c}=this;return[e,t,r,n,i,o,a,c]}set(e,t,r,n,i,o,a,c){this.A=e|0,this.B=t|0,this.C=r|0,this.D=n|0,this.E=i|0,this.F=o|0,this.G=a|0,this.H=c|0}process(e,t){for(let d=0;d<16;d++,t+=4)pt[d]=e.getUint32(t,!1);for(let d=16;d<64;d++){let E=pt[d-15],v=pt[d-2],u=Ce(E,7)^Ce(E,18)^E>>>3,g=Ce(v,17)^Ce(v,19)^v>>>10;pt[d]=g+pt[d-7]+u+pt[d-16]|0}let{A:r,B:n,C:i,D:o,E:a,F:c,G:h,H:m}=this;for(let d=0;d<64;d++){let E=Ce(a,6)^Ce(a,11)^Ce(a,25),v=m+E+ba(a,c,h)+Ku[d]+pt[d]|0,g=(Ce(r,2)^Ce(r,13)^Ce(r,22))+ya(r,n,i)|0;m=h,h=c,c=a,a=o+v|0,o=i,i=n,n=r,r=v+g|0}r=r+this.A|0,n=n+this.B|0,i=i+this.C|0,o=o+this.D|0,a=a+this.E|0,c=c+this.F|0,h=h+this.G|0,m=m+this.H|0,this.set(r,n,i,o,a,c,h,m)}roundClean(){Is(pt)}destroy(){this.destroyed=!0,this.set(0,0,0,0,0,0,0,0),Is(this.buffer)}},ii=class extends ni{A=tt[0]|0;B=tt[1]|0;C=tt[2]|0;D=tt[3]|0;E=tt[4]|0;F=tt[5]|0;G=tt[6]|0;H=tt[7]|0;constructor(){super(32)}};var ar=pa(()=>new ii,ga(1));var Zt=class{type="RSA";jwk;_raw;_multihash;constructor(e,t){this.jwk=e,this._multihash=t}get raw(){return this._raw==null&&(this._raw=As.jwkToPkix(this.jwk)),this._raw}toMultihash(){return this._multihash}toCID(){return ae.createV1(114,this._multihash)}toString(){return te.encode(this.toMultihash().bytes).substring(1)}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:Ie(this.raw,e.raw)}verify(e,t,r){return xa(this.jwk,t,e,r)}},Ts=class{type="RSA";jwk;_raw;publicKey;constructor(e,t){this.jwk=e,this.publicKey=t}get raw(){return this._raw==null&&(this._raw=As.jwkToPkcs1(this.jwk)),this._raw}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:Ie(this.raw,e.raw)}sign(e,t){return wa(this.jwk,e,t)}};var oi=8192,ai=18,Fu=1062,Hu=Uint8Array.from([48,13,6,9,42,134,72,134,247,13,1,1,1,5,0]);function Gu(s){let e=je(s);return ci(e)}function ci(s){return{n:V(s[1],"base64url"),e:V(s[2],"base64url"),d:V(s[3],"base64url"),p:V(s[4],"base64url"),q:V(s[5],"base64url"),dp:V(s[6],"base64url"),dq:V(s[7],"base64url"),qi:V(s[8],"base64url"),kty:"RSA"}}function Vu(s){if(s.n==null||s.e==null||s.d==null||s.p==null||s.q==null||s.dp==null||s.dq==null||s.qi==null)throw new $("JWK was missing components");return at([Te(Uint8Array.from([0])),Te(q(s.n,"base64url")),Te(q(s.e,"base64url")),Te(q(s.d,"base64url")),Te(q(s.p,"base64url")),Te(q(s.q,"base64url")),Te(q(s.dp,"base64url")),Te(q(s.dq,"base64url")),Te(q(s.qi,"base64url"))]).subarray()}function qu(s){let e=je(s,{offset:0});return li(e)}function li(s){let e=je(s[1],{offset:0});return{kty:"RSA",n:V(e[0],"base64url"),e:V(e[1],"base64url")}}function ui(s){if(s.n==null||s.e==null)throw new $("JWK was missing components");return at([Hu,Hs(at([Te(q(s.n,"base64url")),Te(q(s.e,"base64url"))]))]).subarray()}function va(s){let e=je(s);return hi(e)}function hi(s){let e=ci(s);return pi(e)}function fi(s,e){if(s.byteLength>=Fu)throw new Rt("Key size is too large");let t=je(s,{offset:0});return di(t,s,e)}function di(s,e,t){let r=li(s);if(t==null){let n=ar(Ve.encode({Type:Z.RSA,Data:e}));t=Ke(ai,n)}return new Zt(r,t)}function pi(s){if(Ia(s)>oi)throw new $("Key size is too large");let e=Sa(s),t=ar(Ve.encode({Type:Z.RSA,Data:ui(e.publicKey)})),r=Ke(ai,t);return new Ts(e.privateKey,new Zt(e.publicKey,r))}async function Ea(s){if(s>oi)throw new $("Key size is too large");let e=await _a(s),t=ar(Ve.encode({Type:Z.RSA,Data:ui(e.publicKey)})),r=Ke(ai,t);return new Ts(e.privateKey,new Zt(e.publicKey,r))}function Sa(s){if(s==null)throw new $("Missing key parameter");return{privateKey:s,publicKey:{kty:s.kty,n:s.n,e:s.e}}}async function _a(s,e){let t=await Pe.get().subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:s,publicExponent:new Uint8Array([1,0,1]),hash:{name:"SHA-256"}},!0,["sign","verify"]);e?.signal?.throwIfAborted();let r=await zu(t,e);return{privateKey:r[0],publicKey:r[1]}}async function wa(s,e,t){let r=await Pe.get().subtle.importKey("jwk",s,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]);t?.signal?.throwIfAborted();let n=await Pe.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},r,e instanceof Uint8Array?e:e.subarray());return t?.signal?.throwIfAborted(),new Uint8Array(n,0,n.byteLength)}async function xa(s,e,t,r){let n=await Pe.get().subtle.importKey("jwk",s,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);r?.signal?.throwIfAborted();let i=await Pe.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,e,t instanceof Uint8Array?t:t.subarray());return r?.signal?.throwIfAborted(),i}async function zu(s,e){if(s.privateKey==null||s.publicKey==null)throw new $("Private and public key are required");let t=await Promise.all([Pe.get().subtle.exportKey("jwk",s.privateKey),Pe.get().subtle.exportKey("jwk",s.publicKey)]);return e?.signal?.throwIfAborted(),t}function Ia(s){if(s.kty!=="RSA")throw new $("invalid key type");if(s.n==null)throw new $("invalid key modulus");return q(s.n,"base64url").length*8}var cr=class{oHash;iHash;blockLen;outputLen;finished=!1;destroyed=!1;constructor(e,t){if(Gs(e),K(t,void 0,"key"),this.iHash=e.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 r=this.blockLen,n=new Uint8Array(r);n.set(t.length>r?e.create().update(t).digest():t);for(let i=0;i<n.length;i++)n[i]^=54;this.iHash.update(n),this.oHash=e.create();for(let i=0;i<n.length;i++)n[i]^=106;this.oHash.update(n),Ye(n)}update(e){return Gt(this),this.iHash.update(e),this}digestInto(e){Gt(this),K(e,this.outputLen,"output"),this.finished=!0,this.iHash.digestInto(e),this.oHash.update(e),this.oHash.digestInto(e),this.destroy()}digest(){let e=new Uint8Array(this.oHash.outputLen);return this.digestInto(e),e}_cloneInto(e){e||=Object.create(Object.getPrototypeOf(this),{});let{oHash:t,iHash:r,finished:n,destroyed:i,blockLen:o,outputLen:a}=this;return e=e,e.finished=n,e.destroyed=i,e.blockLen=o,e.outputLen=a,e.oHash=t._cloneInto(e.oHash),e.iHash=r._cloneInto(e.iHash),e}clone(){return this._cloneInto()}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},mi=(s,e,t)=>new cr(s,e).update(t).digest();mi.create=(s,e)=>new cr(s,e);var Ta=(s,e)=>(s+(s>=0?e:-e)/Aa)/e;function Wu(s,e,t){let[[r,n],[i,o]]=e,a=Ta(o*s,t),c=Ta(-n*s,t),h=s-a*r-c*i,m=-a*n-c*o,d=h<st,E=m<st;d&&(h=-h),E&&(m=-m);let v=ys(Math.ceil(xn(t)/2))+Yt;if(h<st||h>=v||m<st||m>=v)throw new Error("splitScalar (endomorphism): failed, k="+s);return{k1neg:d,k1:h,k2neg:E,k2:m}}function bi(s){if(!["compact","recovered","der"].includes(s))throw new Error('Signature format must be "compact", "recovered", or "der"');return s}function gi(s,e){let t={};for(let r of Object.keys(e))t[r]=s[r]===void 0?e[r]:s[r];return et(t.lowS,"lowS"),et(t.prehash,"prehash"),t.format!==void 0&&bi(t.format),t}var yi=class extends Error{constructor(e=""){super(e)}},mt={Err:yi,_tlv:{encode:(s,e)=>{let{Err:t}=mt;if(s<0||s>256)throw new t("tlv.encode: wrong tag");if(e.length&1)throw new t("tlv.encode: unpadded data");let r=e.length/2,n=gs(r);if(n.length/2&128)throw new t("tlv.encode: long form length too big");let i=r>127?gs(n.length/2|128):"";return gs(s)+i+n+e},decode(s,e){let{Err:t}=mt,r=0;if(s<0||s>256)throw new t("tlv.encode: wrong tag");if(e.length<2||e[r++]!==s)throw new t("tlv.decode: wrong tlv");let n=e[r++],i=!!(n&128),o=0;if(!i)o=n;else{let c=n&127;if(!c)throw new t("tlv.decode(long): indefinite length not supported");if(c>4)throw new t("tlv.decode(long): byte length is too big");let h=e.subarray(r,r+c);if(h.length!==c)throw new t("tlv.decode: length bytes not complete");if(h[0]===0)throw new t("tlv.decode(long): zero leftmost byte");for(let m of h)o=o<<8|m;if(r+=c,o<128)throw new t("tlv.decode(long): not minimal encoding")}let a=e.subarray(r,r+o);if(a.length!==o)throw new t("tlv.decode: wrong value length");return{v:a,l:e.subarray(r+o)}}},_int:{encode(s){let{Err:e}=mt;if(s<st)throw new e("integer: negative integers are not allowed");let t=gs(s);if(Number.parseInt(t[0],16)&8&&(t="00"+t),t.length&1)throw new e("unexpected DER parsing assertion: unpadded hex");return t},decode(s){let{Err:e}=mt;if(s[0]&128)throw new e("invalid signature integer: negative");if(s[0]===0&&!(s[1]&128))throw new e("invalid signature integer: unnecessary leading zero");return qt(s)}},toSig(s){let{Err:e,_int:t,_tlv:r}=mt,n=K(s,void 0,"signature"),{v:i,l:o}=r.decode(48,n);if(o.length)throw new e("invalid signature: left bytes after parsing");let{v:a,l:c}=r.decode(2,i),{v:h,l:m}=r.decode(2,c);if(m.length)throw new e("invalid signature: left bytes after parsing");return{r:t.decode(a),s:t.decode(h)}},hexFromSig(s){let{_tlv:e,_int:t}=mt,r=e.encode(2,t.encode(s.r)),n=e.encode(2,t.encode(s.s)),i=r+n;return e.encode(48,i)}},st=BigInt(0),Yt=BigInt(1),Aa=BigInt(2),lr=BigInt(3),$u=BigInt(4);function Da(s,e={}){let t=js("weierstrass",s,e),{Fp:r,Fn:n}=t,i=t.CURVE,{h:o,n:a}=i;ht(e,{},{allowInfinityPoint:"boolean",clearCofactor:"function",isTorsionFree:"function",fromBytes:"function",toBytes:"function",endo:"object"});let{endo:c}=e;if(c&&(!r.is0(i.a)||typeof c.beta!="bigint"||!Array.isArray(c.basises)))throw new Error('invalid endo: expected "beta": bigint and "basises": array');let h=Pa(r,n);function m(){if(!r.isOdd)throw new Error("compression is not supported: Field does not have .isOdd()")}function d(R,A,D){let{x:T,y:M}=A.toAffine(),k=r.toBytes(T);if(et(D,"isCompressed"),D){m();let B=!r.isOdd(M);return Ae(Ma(B),k)}else return Ae(Uint8Array.of(4),k,r.toBytes(M))}function E(R){K(R,void 0,"Point");let{publicKey:A,publicKeyUncompressed:D}=h,T=R.length,M=R[0],k=R.subarray(1);if(T===A&&(M===2||M===3)){let B=r.fromBytes(k);if(!r.isValid(B))throw new Error("bad point: is not on curve, wrong x");let C=g(B),L;try{L=r.sqrt(C)}catch(X){let W=X instanceof Error?": "+X.message:"";throw new Error("bad point: is not on curve, sqrt error"+W)}m();let N=r.isOdd(L);return(M&1)===1!==N&&(L=r.neg(L)),{x:B,y:L}}else if(T===D&&M===4){let B=r.BYTES,C=r.fromBytes(k.subarray(0,B)),L=r.fromBytes(k.subarray(B,B*2));if(!w(C,L))throw new Error("bad point: is not on curve");return{x:C,y:L}}else throw new Error(`bad point: got length ${T}, expected compressed=${A} or uncompressed=${D}`)}let v=e.toBytes||d,u=e.fromBytes||E;function g(R){let A=r.sqr(R),D=r.mul(A,R);return r.add(r.add(D,r.mul(R,i.a)),i.b)}function w(R,A){let D=r.sqr(A),T=g(R);return r.eql(D,T)}if(!w(i.Gx,i.Gy))throw new Error("bad curve params: generator point");let y=r.mul(r.pow(i.a,lr),$u),I=r.mul(r.sqr(i.b),BigInt(27));if(r.is0(r.add(y,I)))throw new Error("bad curve params: a or b");function l(R,A,D=!1){if(!r.isValid(A)||D&&r.is0(A))throw new Error(`bad point coordinate ${R}`);return A}function f(R){if(!(R instanceof _))throw new Error("Weierstrass Point expected")}function p(R){if(!c||!c.basises)throw new Error("no endo");return Wu(R,c.basises,n.ORDER)}let b=zt((R,A)=>{let{X:D,Y:T,Z:M}=R;if(r.eql(M,r.ONE))return{x:D,y:T};let k=R.is0();A==null&&(A=k?r.ONE:r.inv(M));let B=r.mul(D,A),C=r.mul(T,A),L=r.mul(M,A);if(k)return{x:r.ZERO,y:r.ZERO};if(!r.eql(L,r.ONE))throw new Error("invZ was invalid");return{x:B,y:C}}),S=zt(R=>{if(R.is0()){if(e.allowInfinityPoint&&!r.is0(R.Y))return;throw new Error("bad point: ZERO")}let{x:A,y:D}=R.toAffine();if(!r.isValid(A)||!r.isValid(D))throw new Error("bad point: x or y not field elements");if(!w(A,D))throw new Error("bad point: equation left != right");if(!R.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});function x(R,A,D,T,M){return D=new _(r.mul(D.X,R),D.Y,D.Z),A=xs(T,A),D=xs(M,D),A.add(D)}class _{static BASE=new _(i.Gx,i.Gy,r.ONE);static ZERO=new _(r.ZERO,r.ONE,r.ZERO);static Fp=r;static Fn=n;X;Y;Z;constructor(A,D,T){this.X=l("x",A),this.Y=l("y",D,!0),this.Z=l("z",T),Object.freeze(this)}static CURVE(){return i}static fromAffine(A){let{x:D,y:T}=A||{};if(!A||!r.isValid(D)||!r.isValid(T))throw new Error("invalid affine point");if(A instanceof _)throw new Error("projective point not allowed");return r.is0(D)&&r.is0(T)?_.ZERO:new _(D,T,r.ONE)}static fromBytes(A){let D=_.fromAffine(u(K(A,void 0,"point")));return D.assertValidity(),D}static fromHex(A){return _.fromBytes(Je(A))}get x(){return this.toAffine().x}get y(){return this.toAffine().y}precompute(A=8,D=!0){return O.createCache(this,A),D||this.multiply(lr),this}assertValidity(){S(this)}hasEvenY(){let{y:A}=this.toAffine();if(!r.isOdd)throw new Error("Field doesn't support isOdd");return!r.isOdd(A)}equals(A){f(A);let{X:D,Y:T,Z:M}=this,{X:k,Y:B,Z:C}=A,L=r.eql(r.mul(D,C),r.mul(k,M)),N=r.eql(r.mul(T,C),r.mul(B,M));return L&&N}negate(){return new _(this.X,r.neg(this.Y),this.Z)}double(){let{a:A,b:D}=i,T=r.mul(D,lr),{X:M,Y:k,Z:B}=this,C=r.ZERO,L=r.ZERO,N=r.ZERO,U=r.mul(M,M),X=r.mul(k,k),W=r.mul(B,B),F=r.mul(M,k);return F=r.add(F,F),N=r.mul(M,B),N=r.add(N,N),C=r.mul(A,N),L=r.mul(T,W),L=r.add(C,L),C=r.sub(X,L),L=r.add(X,L),L=r.mul(C,L),C=r.mul(F,C),N=r.mul(T,N),W=r.mul(A,W),F=r.sub(U,W),F=r.mul(A,F),F=r.add(F,N),N=r.add(U,U),U=r.add(N,U),U=r.add(U,W),U=r.mul(U,F),L=r.add(L,U),W=r.mul(k,B),W=r.add(W,W),U=r.mul(W,F),C=r.sub(C,U),N=r.mul(W,X),N=r.add(N,N),N=r.add(N,N),new _(C,L,N)}add(A){f(A);let{X:D,Y:T,Z:M}=this,{X:k,Y:B,Z:C}=A,L=r.ZERO,N=r.ZERO,U=r.ZERO,X=i.a,W=r.mul(i.b,lr),F=r.mul(D,k),J=r.mul(T,B),oe=r.mul(M,C),Ue=r.add(D,T),Q=r.add(k,B);Ue=r.mul(Ue,Q),Q=r.add(F,J),Ue=r.sub(Ue,Q),Q=r.add(D,M);let le=r.add(k,C);return Q=r.mul(Q,le),le=r.add(F,oe),Q=r.sub(Q,le),le=r.add(T,M),L=r.add(B,C),le=r.mul(le,L),L=r.add(J,oe),le=r.sub(le,L),U=r.mul(X,Q),L=r.mul(W,oe),U=r.add(L,U),L=r.sub(J,U),U=r.add(J,U),N=r.mul(L,U),J=r.add(F,F),J=r.add(J,F),oe=r.mul(X,oe),Q=r.mul(W,Q),J=r.add(J,oe),oe=r.sub(F,oe),oe=r.mul(X,oe),Q=r.add(Q,oe),F=r.mul(J,Q),N=r.add(N,F),F=r.mul(le,Q),L=r.mul(Ue,L),L=r.sub(L,F),F=r.mul(Ue,J),U=r.mul(le,U),U=r.add(U,F),new _(L,N,U)}subtract(A){return this.add(A.negate())}is0(){return this.equals(_.ZERO)}multiply(A){let{endo:D}=e;if(!n.isValidNot0(A))throw new Error("invalid scalar: out of range");let T,M,k=B=>O.cached(this,B,C=>Tt(_,C));if(D){let{k1neg:B,k1:C,k2neg:L,k2:N}=p(A),{p:U,f:X}=k(C),{p:W,f:F}=k(N);M=X.add(F),T=x(D.beta,U,W,B,L)}else{let{p:B,f:C}=k(A);T=B,M=C}return Tt(_,[T,M])[0]}multiplyUnsafe(A){let{endo:D}=e,T=this;if(!n.isValid(A))throw new Error("invalid scalar: out of range");if(A===st||T.is0())return _.ZERO;if(A===Yt)return T;if(O.hasCache(this))return this.multiply(A);if(D){let{k1neg:M,k1:k,k2neg:B,k2:C}=p(A),{p1:L,p2:N}=Zo(_,T,k,C);return x(D.beta,L,N,M,B)}else return O.unsafe(T,A)}toAffine(A){return b(this,A)}isTorsionFree(){let{isTorsionFree:A}=e;return o===Yt?!0:A?A(_,this):O.unsafe(this,a).is0()}clearCofactor(){let{clearCofactor:A}=e;return o===Yt?this:A?A(_,this):this.multiplyUnsafe(o)}isSmallOrder(){return this.multiplyUnsafe(o).is0()}toBytes(A=!0){return et(A,"isCompressed"),this.assertValidity(),v(_,this,A)}toHex(A=!0){return Xe(this.toBytes(A))}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}}let P=n.BITS,O=new jt(_,e.endo?Math.ceil(P/2):P);return _.BASE.precompute(8),_}function Ma(s){return Uint8Array.of(s?2:3)}function Pa(s,e){return{secretKey:e.BYTES,publicKey:1+s.BYTES,publicKeyUncompressed:1+2*s.BYTES,publicKeyHasPrefix:!0,signature:2*e.BYTES}}function ju(s,e={}){let{Fn:t}=s,r=e.randomBytes||Vt,n=Object.assign(Pa(s.Fp,t),{seed:_n(t.ORDER)});function i(v){try{let u=t.fromBytes(v);return t.isValidNot0(u)}catch{return!1}}function o(v,u){let{publicKey:g,publicKeyUncompressed:w}=n;try{let y=v.length;return u===!0&&y!==g||u===!1&&y!==w?!1:!!s.fromBytes(v)}catch{return!1}}function a(v=r(n.seed)){return In(K(v,n.seed,"seed"),t.ORDER)}function c(v,u=!0){return s.BASE.multiply(t.fromBytes(v)).toBytes(u)}function h(v){let{secretKey:u,publicKey:g,publicKeyUncompressed:w}=n;if(!xt(v)||"_lengths"in t&&t._lengths||u===g)return;let y=K(v,void 0,"key").length;return y===g||y===w}function m(v,u,g=!0){if(h(v)===!0)throw new Error("first arg must be private key");if(h(u)===!1)throw new Error("second arg must be public key");let w=t.fromBytes(v);return s.fromBytes(u).multiply(w).toBytes(g)}let d={isValidSecretKey:i,isValidPublicKey:o,randomSecretKey:a},E=Zs(a,c);return Object.freeze({getPublicKey:c,getSharedSecret:m,keygen:E,Point:s,utils:d,lengths:n})}function ka(s,e,t={}){Gs(e),ht(t,{},{hmac:"function",lowS:"boolean",randomBytes:"function",bits2int:"function",bits2int_modN:"function"}),t=Object.assign({},t);let r=t.randomBytes||Vt,n=t.hmac||((D,T)=>mi(e,D,T)),{Fp:i,Fn:o}=s,{ORDER:a,BITS:c}=o,{keygen:h,getPublicKey:m,getSharedSecret:d,utils:E,lengths:v}=ju(s,t),u={prehash:!0,lowS:typeof t.lowS=="boolean"?t.lowS:!0,format:"compact",extraEntropy:!1},g=a*Aa<i.ORDER;function w(D){let T=a>>Yt;return D>T}function y(D,T){if(!o.isValidNot0(T))throw new Error(`invalid signature ${D}: out of range 1..Point.Fn.ORDER`);return T}function I(){if(g)throw new Error('"recovered" sig type is not supported for cofactor >2 curves')}function l(D,T){bi(T);let M=v.signature,k=T==="compact"?M:T==="recovered"?M+1:void 0;return K(D,k)}class f{r;s;recovery;constructor(T,M,k){if(this.r=y("r",T),this.s=y("s",M),k!=null){if(I(),![0,1,2,3].includes(k))throw new Error("invalid recovery id");this.recovery=k}Object.freeze(this)}static fromBytes(T,M=u.format){l(T,M);let k;if(M==="der"){let{r:N,s:U}=mt.toSig(K(T));return new f(N,U)}M==="recovered"&&(k=T[0],M="compact",T=T.subarray(1));let B=v.signature/2,C=T.subarray(0,B),L=T.subarray(B,B*2);return new f(o.fromBytes(C),o.fromBytes(L),k)}static fromHex(T,M){return this.fromBytes(Je(T),M)}assertRecovery(){let{recovery:T}=this;if(T==null)throw new Error("invalid recovery id: must be present");return T}addRecoveryBit(T){return new f(this.r,this.s,T)}recoverPublicKey(T){let{r:M,s:k}=this,B=this.assertRecovery(),C=B===2||B===3?M+a:M;if(!i.isValid(C))throw new Error("invalid recovery id: sig.r+curve.n != R.x");let L=i.toBytes(C),N=s.fromBytes(Ae(Ma((B&1)===0),L)),U=o.inv(C),X=b(K(T,void 0,"msgHash")),W=o.create(-X*U),F=o.create(k*U),J=s.BASE.multiplyUnsafe(W).add(N.multiplyUnsafe(F));if(J.is0())throw new Error("invalid recovery: point at infinify");return J.assertValidity(),J}hasHighS(){return w(this.s)}toBytes(T=u.format){if(bi(T),T==="der")return Je(mt.hexFromSig(this));let{r:M,s:k}=this,B=o.toBytes(M),C=o.toBytes(k);return T==="recovered"?(I(),Ae(Uint8Array.of(this.assertRecovery()),B,C)):Ae(B,C)}toHex(T){return Xe(this.toBytes(T))}}let p=t.bits2int||function(T){if(T.length>8192)throw new Error("input is too large");let M=qt(T),k=T.length*8-c;return k>0?M>>BigInt(k):M},b=t.bits2int_modN||function(T){return o.create(p(T))},S=ys(c);function x(D){return bs("num < 2^"+c,D,st,S),o.toBytes(D)}function _(D,T){return K(D,void 0,"message"),T?K(e(D),void 0,"prehashed message"):D}function P(D,T,M){let{lowS:k,prehash:B,extraEntropy:C}=gi(M,u);D=_(D,B);let L=b(D),N=o.fromBytes(T);if(!o.isValidNot0(N))throw new Error("invalid private key");let U=[x(N),x(L)];if(C!=null&&C!==!1){let J=C===!0?r(v.secretKey):C;U.push(K(J,void 0,"extraEntropy"))}let X=Ae(...U),W=L;function F(J){let oe=p(J);if(!o.isValidNot0(oe))return;let Ue=o.inv(oe),Q=s.BASE.multiply(oe).toAffine(),le=o.create(Q.x);if(le===st)return;let Bs=o.create(Ue*o.create(W+le*N));if(Bs===st)return;let ki=(Q.x===le?0:2)|Number(Q.y&Yt),Li=Bs;return k&&w(Bs)&&(Li=o.neg(Bs),ki^=1),new f(le,Li,g?void 0:ki)}return{seed:X,k2sig:F}}function O(D,T,M={}){let{seed:k,k2sig:B}=P(D,T,M);return Lo(e.outputLen,o.BYTES,n)(k,B).toBytes(M.format)}function R(D,T,M,k={}){let{lowS:B,prehash:C,format:L}=gi(k,u);if(M=K(M,void 0,"publicKey"),T=_(T,C),!xt(D)){let N=D instanceof f?", use sig.toBytes()":"";throw new Error("verify expects Uint8Array signature"+N)}l(D,L);try{let N=f.fromBytes(D,L),U=s.fromBytes(M);if(B&&N.hasHighS())return!1;let{r:X,s:W}=N,F=b(T),J=o.inv(W),oe=o.create(F*J),Ue=o.create(X*J),Q=s.BASE.multiplyUnsafe(oe).add(U.multiplyUnsafe(Ue));return Q.is0()?!1:o.create(Q.x)===X}catch{return!1}}function A(D,T,M={}){let{prehash:k}=gi(M,u);return T=_(T,k),f.fromBytes(D,"recovered").recoverPublicKey(T).toBytes()}return Object.freeze({keygen:h,getPublicKey:m,getSharedSecret:d,utils:E,lengths:v,Point:s,sign:O,verify:R,recoverPublicKey:A,Signature:f,hash:e})}var xi={p:BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),n:BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),h:BigInt(1),a:BigInt(0),b:BigInt(7),Gx:BigInt("0x79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798"),Gy:BigInt("0x483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8")},Zu={beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),basises:[[BigInt("0x3086d221a7d46bcde86c90e49284eb15"),-BigInt("0xe4437ed6010e88286f547fa90abfe4c3")],[BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),BigInt("0x3086d221a7d46bcde86c90e49284eb15")]]};var La=BigInt(2);function Yu(s){let e=xi.p,t=BigInt(3),r=BigInt(6),n=BigInt(11),i=BigInt(22),o=BigInt(23),a=BigInt(44),c=BigInt(88),h=s*s*s%e,m=h*h*s%e,d=j(m,t,e)*m%e,E=j(d,t,e)*m%e,v=j(E,La,e)*h%e,u=j(v,n,e)*v%e,g=j(u,i,e)*u%e,w=j(g,a,e)*g%e,y=j(w,c,e)*w%e,I=j(y,a,e)*g%e,l=j(I,t,e)*m%e,f=j(l,o,e)*u%e,p=j(f,r,e)*h%e,b=j(p,La,e);if(!wi.eql(wi.sqr(b),s))throw new Error("Cannot find square root");return b}var wi=Wt(xi.p,{sqrt:Yu}),Xu=Da(xi,{Fp:wi,endo:Zu}),Xt=ka(Xu,Do);function Ba(s,e,t,r){let n=wt.digest(t instanceof Uint8Array?t:t.subarray());if(Js(n))return n.then(({digest:i})=>(r?.signal?.throwIfAborted(),Xt.verify(e,i,s,{prehash:!1,format:"der"}))).catch(i=>{throw i.name==="AbortError"?i:new vs(String(i))});try{return r?.signal?.throwIfAborted(),Xt.verify(e,n.digest,s,{prehash:!1,format:"der"})}catch(i){throw new vs(String(i))}}var ur=class{type="secp256k1";raw;_key;constructor(e){this._key=Ca(e),this.raw=Ra(this._key)}toMultihash(){return Le.digest(Fe(this))}toCID(){return ae.createV1(114,this.toMultihash())}toString(){return te.encode(this.toMultihash().bytes).substring(1)}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:Ie(this.raw,e.raw)}verify(e,t,r){return Ba(this._key,t,e,r)}};function vi(s){return new ur(s)}function Ra(s){return Xt.Point.fromBytes(s).toBytes()}function Ca(s){try{return Xt.Point.fromBytes(s),s}catch(e){throw new Rt(String(e))}}function hr(s,e){let{Type:t,Data:r}=Ve.decode(s),n=r??new Uint8Array;switch(t){case Z.RSA:return fi(n,e);case Z.Ed25519:return Bn(n);case Z.secp256k1:return vi(n);case Z.ECDSA:return cn(n);default:throw new Ct}}function Na(s){let{Type:e,Data:t}=Ve.decode(s.digest),r=t??new Uint8Array;switch(e){case Z.Ed25519:return Bn(r);case Z.secp256k1:return vi(r);case Z.ECDSA:return cn(r);default:throw new Ct}}function Fe(s){return Ve.encode({Type:Z[s.type],Data:s.raw})}var Oa=Symbol.for("nodejs.util.inspect.custom"),Ju=114,Ds=class{type;multihash;publicKey;string;constructor(e){this.type=e.type,this.multihash=e.multihash,Object.defineProperty(this,"string",{enumerable:!1,writable:!0})}get[Symbol.toStringTag](){return`PeerId(${this.toString()})`}[Br]=!0;toString(){return this.string==null&&(this.string=te.encode(this.multihash.bytes).slice(1)),this.string}toMultihash(){return this.multihash}toCID(){return ae.createV1(Ju,this.multihash)}toJSON(){return this.toString()}equals(e){if(e==null)return!1;if(e instanceof Uint8Array)return Ie(this.multihash.bytes,e);if(typeof e=="string")return this.toString()===e;if(e?.toMultihash()?.bytes!=null)return Ie(this.multihash.bytes,e.toMultihash().bytes);throw new Error("not valid Id")}[Oa](){return`PeerId(${this.toString()})`}},fr=class extends Ds{type="RSA";publicKey;constructor(e){super({...e,type:"RSA"}),this.publicKey=e.publicKey}},dr=class extends Ds{type="Ed25519";publicKey;constructor(e){super({...e,type:"Ed25519"}),this.publicKey=e.publicKey}},pr=class extends Ds{type="secp256k1";publicKey;constructor(e){super({...e,type:"secp256k1"}),this.publicKey=e.publicKey}},Qu=2336,Ms=class{type="url";multihash;publicKey;url;constructor(e){this.url=e.toString(),this.multihash=Le.digest(q(this.url))}[Oa](){return`PeerId(${this.url})`}[Br]=!0;toString(){return this.toCID().toString()}toMultihash(){return this.multihash}toCID(){return ae.createV1(Qu,this.toMultihash())}toJSON(){return this.toString()}equals(e){return e==null?!1:(e instanceof Uint8Array&&(e=V(e)),e.toString()===this.toString())}};var eh=114,Ua=2336;function Mt(s,e){let t;if(s.charAt(0)==="1"||s.charAt(0)==="Q")t=We(te.decode(`z${s}`));else{if(s.startsWith("k51qzi5uqu5")||s.startsWith("kzwfwjn5ji4")||s.startsWith("k2k4r8")||s.startsWith("bafz"))return th(ae.parse(s));if(e==null)throw new $('Please pass a multibase decoder for strings that do not start with "1" or "Q"');t=We(e.decode(s))}return Jt(t)}function Jt(s){if(rh(s))return new fr({multihash:s});if(sh(s))try{let e=Na(s);if(e.type==="Ed25519")return new dr({multihash:s,publicKey:e});if(e.type==="secp256k1")return new pr({multihash:s,publicKey:e})}catch{let t=V(s.digest);return new Ms(new URL(t))}throw new Ns("Supplied PeerID Multihash is invalid")}function th(s){if(s?.multihash==null||s.version==null||s.version===1&&s.code!==eh&&s.code!==Ua)throw new Cs("Supplied PeerID CID is invalid");if(s.code===Ua){let e=V(s.multihash.digest);return new Ms(new URL(e))}return Jt(s.multihash)}function sh(s){return s.code===Le.code}function rh(s){return s.code===wt.code}var mr=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},Qt=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},gr=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"},Ps=class extends Error{name="UnexpectedEOFError";code="ERR_UNEXPECTED_EOF"};function br(s){return s[Symbol.asyncIterator]!=null}function Ka(s,e){if(s.byteLength>e)throw new Qt("Message length too long")}var wr=s=>{let e=ke(s),t=ue(e);return Fn(s,t),wr.bytes=e,t};wr.bytes=0;function es(s,e){e=e??{};let t=e.lengthEncoder??wr,r=e?.maxDataLength??4194304;function*n(i){Ka(i,r);let o=t(i.byteLength);o instanceof Uint8Array?yield o:yield*o,i instanceof Uint8Array?yield i:yield*i}return br(s)?(async function*(){for await(let i of s)yield*n(i)})():(function*(){for(let i of s)yield*n(i)})()}es.single=(s,e)=>{e=e??{};let t=e.lengthEncoder??wr,r=e?.maxDataLength??4194304;return Ka(s,r),new re(t(s.byteLength),s)};var Pt;(function(s){s[s.LENGTH=0]="LENGTH",s[s.DATA=1]="DATA"})(Pt||(Pt={}));var Ei=s=>{let e=Hn(s);return Ei.bytes=ke(e),e};Ei.bytes=0;function ks(s,e){let t=new re,r=Pt.LENGTH,n=-1,i=e?.lengthDecoder??Ei,o=e?.maxLengthLength??8,a=e?.maxDataLength??4194304;function*c(){for(;t.byteLength>0;){if(r===Pt.LENGTH)try{if(n=i(t),n<0)throw new mr("Invalid message length");if(n>a)throw new Qt("Message length too long");let h=i.bytes;t.consume(h),e?.onLength!=null&&e.onLength(n),r=Pt.DATA}catch(h){if(h instanceof RangeError){if(t.byteLength>o)throw new gr("Message length length too long");break}throw h}if(r===Pt.DATA){if(t.byteLength<n)break;let h=t.sublist(0,n);t.consume(n),e?.onData!=null&&e.onData(h),yield h,r=Pt.LENGTH}}}return br(s)?(async function*(){for await(let h of s)t.append(h),yield*c();if(t.byteLength>0)throw new Ps("Unexpected end of input")})():(function*(){for(let h of s)t.append(h),yield*c();if(t.byteLength>0)throw new Ps("Unexpected end of input")})()}ks.fromReader=(s,e)=>{let t=1,r=(async function*(){for(;;)try{let{done:i,value:o}=await s.next(t);if(i===!0)return;o!=null&&(yield o)}catch(i){if(i.code==="ERR_UNDER_READ")return{done:!0,value:null};throw i}finally{t=1}})();return ks(r,{...e??{},onLength:i=>{t=i}})};function rt(){let s={};return s.promise=new Promise((e,t)=>{s.resolve=e,s.reject=t}),s}var xr=class{buffer;mask;top;btm;next;constructor(e){if(!(e>0)||(e-1&e)!==0)throw new Error("Max size for a FixedFIFO should be a power of two");this.buffer=new Array(e),this.mask=e-1,this.top=0,this.btm=0,this.next=null}push(e){return this.buffer[this.top]!==void 0?!1:(this.buffer[this.top]=e,this.top=this.top+1&this.mask,!0)}shift(){let e=this.buffer[this.btm];if(e!==void 0)return this.buffer[this.btm]=void 0,this.btm=this.btm+1&this.mask,e}isEmpty(){return this.buffer[this.btm]===void 0}},ts=class{size;hwm;head;tail;constructor(e={}){this.hwm=e.splitLimit??16,this.head=new xr(this.hwm),this.tail=this.head,this.size=0}calculateSize(e){return e?.byteLength!=null?e.byteLength:1}push(e){if(e?.value!=null&&(this.size+=this.calculateSize(e.value)),!this.head.push(e)){let t=this.head;this.head=t.next=new xr(2*this.head.buffer.length),this.head.push(e)}}shift(){let e=this.tail.shift();if(e===void 0&&this.tail.next!=null){let t=this.tail.next;this.tail.next=null,this.tail=t,e=this.tail.shift()}return e?.value!=null&&(this.size-=this.calculateSize(e.value)),e}isEmpty(){return this.head.isEmpty()}};var Si=class extends Error{type;code;constructor(e,t){super(e??"The operation was aborted"),this.type="aborted",this.code=t??"ABORT_ERR"}};function kt(s={}){return ih(t=>{let r=t.shift();if(r==null)return{done:!0};if(r.error!=null)throw r.error;return{done:r.done===!0,value:r.value}},s)}function ih(s,e){e=e??{};let t=e.onEnd,r=new ts,n,i,o,a=rt(),c=async()=>{try{return r.isEmpty()?o?{done:!0}:await new Promise((w,y)=>{i=I=>{i=null,r.push(I);try{w(s(r))}catch(l){y(l)}return n}}):s(r)}finally{r.isEmpty()&&queueMicrotask(()=>{a.resolve(),a=rt()})}},h=w=>i!=null?i(w):(r.push(w),n),m=w=>(r=new ts,i!=null?i({error:w}):(r.push({error:w}),n)),d=w=>{if(o)return n;if(e?.objectMode!==!0&&w?.byteLength==null)throw new Error("objectMode was not true but tried to push non-Uint8Array value");return h({done:!1,value:w})},E=w=>o?n:(o=!0,w!=null?m(w):h({done:!0})),v=()=>(r=new ts,E(),{done:!0}),u=w=>(E(w),{done:!0});if(n={[Symbol.asyncIterator](){return this},next:c,return:v,throw:u,push:d,end:E,get readableLength(){return r.size},onEmpty:async w=>{let y=w?.signal;if(y?.throwIfAborted(),r.isEmpty())return;let I,l;y!=null&&(I=new Promise((f,p)=>{l=()=>{p(new Si)},y.addEventListener("abort",l)}));try{await Promise.race([a.promise,I])}finally{l!=null&&y!=null&&y?.removeEventListener("abort",l)}}},t==null)return n;let g=n;return n={[Symbol.asyncIterator](){return this},next(){return g.next()},throw(w){return g.throw(w),t!=null&&(t(w),t=void 0),{done:!0}},return(){return g.return(),t!=null&&(t(),t=void 0),{done:!0}},push:d,end(w){return g.end(w),t!=null&&(t(w),t=void 0),n},get readableLength(){return g.readableLength},onEmpty:w=>g.onEmpty(w)},n}function oh(s){return s.reason}async function _i(s,e,t){if(e==null)return s;let r=t?.translateError??oh;if(e.aborted)return s.catch(()=>{}),Promise.reject(r(e));let n;try{return await Promise.race([s,new Promise((i,o)=>{n=()=>{o(r(e))},e.addEventListener("abort",n)})])}finally{n!=null&&e.removeEventListener("abort",n)}}var Ii=class{readNext;haveNext;ended;nextResult;error;constructor(){this.ended=!1,this.readNext=rt(),this.haveNext=rt()}[Symbol.asyncIterator](){return this}async next(){if(this.nextResult==null&&await this.haveNext.promise,this.nextResult==null)throw new Error("HaveNext promise resolved but nextResult was undefined");let e=this.nextResult;return this.nextResult=void 0,this.readNext.resolve(),this.readNext=rt(),e}async throw(e){return this.ended=!0,this.error=e,e!=null&&(this.haveNext.promise.catch(()=>{}),this.haveNext.reject(e)),{done:!0,value:void 0}}async return(){let e={done:!0,value:void 0};return this.ended=!0,this.nextResult=e,this.haveNext.resolve(),e}async push(e,t){await this._push(e,t)}async end(e,t){e!=null?await this.throw(e):await this._push(void 0,t)}async _push(e,t){if(e!=null&&this.ended)throw this.error??new Error("Cannot push value onto an ended pushable");for(;this.nextResult!=null;)await this.readNext.promise;e!=null?this.nextResult={done:!1,value:e}:(this.ended=!0,this.nextResult={done:!0,value:void 0}),this.haveNext.resolve(),this.haveNext=rt(),await _i(this.readNext.promise,t?.signal,t)}};function Fa(){return new Ii}function ah(s){return s[Symbol.asyncIterator]!=null}async function ch(s,e,t){try{await Promise.all(s.map(async r=>{for await(let n of r)await e.push(n,{signal:t}),t.throwIfAborted()})),await e.end(void 0,{signal:t})}catch(r){await e.end(r,{signal:t}).catch(()=>{})}}async function*lh(s){let e=new AbortController,t=Fa();ch(s,t,e.signal).catch(()=>{});try{yield*t}finally{e.abort()}}function*uh(s){for(let e of s)yield*e}function hh(...s){let e=[];for(let t of s)ah(t)||e.push(t);return e.length===s.length?uh(e):lh(s)}var Ha=hh;function Ls(s,...e){if(s==null)throw new Error("Empty pipeline");if(Ti(s)){let r=s;s=()=>r.source}else if(Va(s)||Ga(s)){let r=s;s=()=>r}let t=[s,...e];if(t.length>1&&Ti(t[t.length-1])&&(t[t.length-1]=t[t.length-1].sink),t.length>2)for(let r=1;r<t.length-1;r++)Ti(t[r])&&(t[r]=dh(t[r]));return fh(...t)}var fh=(...s)=>{let e;for(;s.length>0;)e=s.shift()(e);return e},Ga=s=>s?.[Symbol.asyncIterator]!=null,Va=s=>s?.[Symbol.iterator]!=null,Ti=s=>s==null?!1:s.sink!=null&&s.source!=null,dh=s=>e=>{let t=s.sink(e);if(t?.then!=null){let r=kt({objectMode:!0});t.then(()=>{r.end()},o=>{r.end(o)});let n,i=s.source;if(Ga(i))n=async function*(){yield*i,r.end()};else if(Va(i))n=function*(){yield*i,r.end()};else throw new Error("Unknown duplex source type - must be Iterable or AsyncIterable");return Ha(r,n())}return s.source};var qa={maxSubscriptions:1/0,maxMessages:1/0,maxIhaveMessageIDs:1/0,maxIwantMessageIDs:1/0,maxIdontwantMessageIDs:1/0,maxControlMessages:1/0,maxPeerInfos:1/0};var nt;(function(s){let e;(function(u){let g;u.codec=()=>(g==null&&(g=xe((l,f,p={})=>{p.lengthDelimited!==!1&&f.fork(),l.subscribe!=null&&(f.uint32(8),f.bool(l.subscribe)),l.topic!=null&&(f.uint32(18),f.string(l.topic)),p.lengthDelimited!==!1&&f.ldelim()},(l,f,p={})=>{let b={},S=f==null?l.len:l.pos+f;for(;l.pos<S;){let x=l.uint32();switch(x>>>3){case 1:{b.subscribe=l.bool();break}case 2:{b.topic=l.string();break}default:{l.skipType(x&7);break}}}return b},function*(l,f,p,b={}){let S=f==null?l.len:l.pos+f;for(;l.pos<S;){let x=l.uint32();switch(x>>>3){case 1:{yield{field:`${p}.subscribe`,value:l.bool()};break}case 2:{yield{field:`${p}.topic`,value:l.string()};break}default:{l.skipType(x&7);break}}}})),g);function w(l){return ye(l,u.codec())}u.encode=w;function y(l,f){return be(l,u.codec(),f)}u.decode=y;function I(l,f){return we(l,u.codec(),f)}u.stream=I})(e=s.SubOpts||(s.SubOpts={}));let t;(function(u){let g;u.codec=()=>(g==null&&(g=xe((l,f,p={})=>{p.lengthDelimited!==!1&&f.fork(),l.from!=null&&(f.uint32(10),f.bytes(l.from)),l.data!=null&&(f.uint32(18),f.bytes(l.data)),l.seqno!=null&&(f.uint32(26),f.bytes(l.seqno)),l.topic!=null&&l.topic!==""&&(f.uint32(34),f.string(l.topic)),l.signature!=null&&(f.uint32(42),f.bytes(l.signature)),l.key!=null&&(f.uint32(50),f.bytes(l.key)),p.lengthDelimited!==!1&&f.ldelim()},(l,f,p={})=>{let b={topic:""},S=f==null?l.len:l.pos+f;for(;l.pos<S;){let x=l.uint32();switch(x>>>3){case 1:{b.from=l.bytes();break}case 2:{b.data=l.bytes();break}case 3:{b.seqno=l.bytes();break}case 4:{b.topic=l.string();break}case 5:{b.signature=l.bytes();break}case 6:{b.key=l.bytes();break}default:{l.skipType(x&7);break}}}return b},function*(l,f,p,b={}){let S=f==null?l.len:l.pos+f;for(;l.pos<S;){let x=l.uint32();switch(x>>>3){case 1:{yield{field:`${p}.from`,value:l.bytes()};break}case 2:{yield{field:`${p}.data`,value:l.bytes()};break}case 3:{yield{field:`${p}.seqno`,value:l.bytes()};break}case 4:{yield{field:`${p}.topic`,value:l.string()};break}case 5:{yield{field:`${p}.signature`,value:l.bytes()};break}case 6:{yield{field:`${p}.key`,value:l.bytes()};break}default:{l.skipType(x&7);break}}}})),g);function w(l){return ye(l,u.codec())}u.encode=w;function y(l,f){return be(l,u.codec(),f)}u.decode=y;function I(l,f){return we(l,u.codec(),f)}u.stream=I})(t=s.Message||(s.Message={}));let r;(function(u){let g;u.codec=()=>(g==null&&(g=xe((l,f,p={})=>{if(p.lengthDelimited!==!1&&f.fork(),l.ihave!=null&&l.ihave.length>0)for(let b of l.ihave)f.uint32(10),s.ControlIHave.codec().encode(b,f);if(l.iwant!=null&&l.iwant.length>0)for(let b of l.iwant)f.uint32(18),s.ControlIWant.codec().encode(b,f);if(l.graft!=null&&l.graft.length>0)for(let b of l.graft)f.uint32(26),s.ControlGraft.codec().encode(b,f);if(l.prune!=null&&l.prune.length>0)for(let b of l.prune)f.uint32(34),s.ControlPrune.codec().encode(b,f);if(l.idontwant!=null&&l.idontwant.length>0)for(let b of l.idontwant)f.uint32(42),s.ControlIDontWant.codec().encode(b,f);p.lengthDelimited!==!1&&f.ldelim()},(l,f,p={})=>{let b={ihave:[],iwant:[],graft:[],prune:[],idontwant:[]},S=f==null?l.len:l.pos+f;for(;l.pos<S;){let x=l.uint32();switch(x>>>3){case 1:{if(p.limits?.ihave!=null&&b.ihave.length===p.limits.ihave)throw new z('Decode error - repeated field "ihave" had too many elements');b.ihave.push(s.ControlIHave.codec().decode(l,l.uint32(),{limits:p.limits?.ihave$}));break}case 2:{if(p.limits?.iwant!=null&&b.iwant.length===p.limits.iwant)throw new z('Decode error - repeated field "iwant" had too many elements');b.iwant.push(s.ControlIWant.codec().decode(l,l.uint32(),{limits:p.limits?.iwant$}));break}case 3:{if(p.limits?.graft!=null&&b.graft.length===p.limits.graft)throw new z('Decode error - repeated field "graft" had too many elements');b.graft.push(s.ControlGraft.codec().decode(l,l.uint32(),{limits:p.limits?.graft$}));break}case 4:{if(p.limits?.prune!=null&&b.prune.length===p.limits.prune)throw new z('Decode error - repeated field "prune" had too many elements');b.prune.push(s.ControlPrune.codec().decode(l,l.uint32(),{limits:p.limits?.prune$}));break}case 5:{if(p.limits?.idontwant!=null&&b.idontwant.length===p.limits.idontwant)throw new z('Decode error - repeated field "idontwant" had too many elements');b.idontwant.push(s.ControlIDontWant.codec().decode(l,l.uint32(),{limits:p.limits?.idontwant$}));break}default:{l.skipType(x&7);break}}}return b},function*(l,f,p,b={}){let S={ihave:0,iwant:0,graft:0,prune:0,idontwant:0},x=f==null?l.len:l.pos+f;for(;l.pos<x;){let _=l.uint32();switch(_>>>3){case 1:{if(b.limits?.ihave!=null&&S.ihave===b.limits.ihave)throw new z('Streaming decode error - repeated field "ihave" had too many elements');for(let P of s.ControlIHave.codec().stream(l,l.uint32(),`${p}.ihave[]`,{limits:b.limits?.ihave$}))yield{...P,index:S.ihave};S.ihave++;break}case 2:{if(b.limits?.iwant!=null&&S.iwant===b.limits.iwant)throw new z('Streaming decode error - repeated field "iwant" had too many elements');for(let P of s.ControlIWant.codec().stream(l,l.uint32(),`${p}.iwant[]`,{limits:b.limits?.iwant$}))yield{...P,index:S.iwant};S.iwant++;break}case 3:{if(b.limits?.graft!=null&&S.graft===b.limits.graft)throw new z('Streaming decode error - repeated field "graft" had too many elements');for(let P of s.ControlGraft.codec().stream(l,l.uint32(),`${p}.graft[]`,{limits:b.limits?.graft$}))yield{...P,index:S.graft};S.graft++;break}case 4:{if(b.limits?.prune!=null&&S.prune===b.limits.prune)throw new z('Streaming decode error - repeated field "prune" had too many elements');for(let P of s.ControlPrune.codec().stream(l,l.uint32(),`${p}.prune[]`,{limits:b.limits?.prune$}))yield{...P,index:S.prune};S.prune++;break}case 5:{if(b.limits?.idontwant!=null&&S.idontwant===b.limits.idontwant)throw new z('Streaming decode error - repeated field "idontwant" had too many elements');for(let P of s.ControlIDontWant.codec().stream(l,l.uint32(),`${p}.idontwant[]`,{limits:b.limits?.idontwant$}))yield{...P,index:S.idontwant};S.idontwant++;break}default:{l.skipType(_&7);break}}}})),g);function w(l){return ye(l,u.codec())}u.encode=w;function y(l,f){return be(l,u.codec(),f)}u.decode=y;function I(l,f){return we(l,u.codec(),f)}u.stream=I})(r=s.ControlMessage||(s.ControlMessage={}));let n;(function(u){let g;u.codec=()=>(g==null&&(g=xe((l,f,p={})=>{if(p.lengthDelimited!==!1&&f.fork(),l.topicID!=null&&(f.uint32(10),f.string(l.topicID)),l.messageIDs!=null&&l.messageIDs.length>0)for(let b of l.messageIDs)f.uint32(18),f.bytes(b);p.lengthDelimited!==!1&&f.ldelim()},(l,f,p={})=>{let b={messageIDs:[]},S=f==null?l.len:l.pos+f;for(;l.pos<S;){let x=l.uint32();switch(x>>>3){case 1:{b.topicID=l.string();break}case 2:{if(p.limits?.messageIDs!=null&&b.messageIDs.length===p.limits.messageIDs)throw new z('Decode error - repeated field "messageIDs" had too many elements');b.messageIDs.push(l.bytes());break}default:{l.skipType(x&7);break}}}return b},function*(l,f,p,b={}){let S={messageIDs:0},x=f==null?l.len:l.pos+f;for(;l.pos<x;){let _=l.uint32();switch(_>>>3){case 1:{yield{field:`${p}.topicID`,value:l.string()};break}case 2:{if(b.limits?.messageIDs!=null&&S.messageIDs===b.limits.messageIDs)throw new z('Streaming decode error - repeated field "messageIDs" had too many elements');yield{field:`${p}.messageIDs[]`,index:S.messageIDs,value:l.bytes()},S.messageIDs++;break}default:{l.skipType(_&7);break}}}})),g);function w(l){return ye(l,u.codec())}u.encode=w;function y(l,f){return be(l,u.codec(),f)}u.decode=y;function I(l,f){return we(l,u.codec(),f)}u.stream=I})(n=s.ControlIHave||(s.ControlIHave={}));let i;(function(u){let g;u.codec=()=>(g==null&&(g=xe((l,f,p={})=>{if(p.lengthDelimited!==!1&&f.fork(),l.messageIDs!=null&&l.messageIDs.length>0)for(let b of l.messageIDs)f.uint32(10),f.bytes(b);p.lengthDelimited!==!1&&f.ldelim()},(l,f,p={})=>{let b={messageIDs:[]},S=f==null?l.len:l.pos+f;for(;l.pos<S;){let x=l.uint32();switch(x>>>3){case 1:{if(p.limits?.messageIDs!=null&&b.messageIDs.length===p.limits.messageIDs)throw new z('Decode error - repeated field "messageIDs" had too many elements');b.messageIDs.push(l.bytes());break}default:{l.skipType(x&7);break}}}return b},function*(l,f,p,b={}){let S={messageIDs:0},x=f==null?l.len:l.pos+f;for(;l.pos<x;){let _=l.uint32();switch(_>>>3){case 1:{if(b.limits?.messageIDs!=null&&S.messageIDs===b.limits.messageIDs)throw new z('Streaming decode error - repeated field "messageIDs" had too many elements');yield{field:`${p}.messageIDs[]`,index:S.messageIDs,value:l.bytes()},S.messageIDs++;break}default:{l.skipType(_&7);break}}}})),g);function w(l){return ye(l,u.codec())}u.encode=w;function y(l,f){return be(l,u.codec(),f)}u.decode=y;function I(l,f){return we(l,u.codec(),f)}u.stream=I})(i=s.ControlIWant||(s.ControlIWant={}));let o;(function(u){let g;u.codec=()=>(g==null&&(g=xe((l,f,p={})=>{p.lengthDelimited!==!1&&f.fork(),l.topicID!=null&&(f.uint32(10),f.string(l.topicID)),p.lengthDelimited!==!1&&f.ldelim()},(l,f,p={})=>{let b={},S=f==null?l.len:l.pos+f;for(;l.pos<S;){let x=l.uint32();x>>>3===1?b.topicID=l.string():l.skipType(x&7)}return b},function*(l,f,p,b={}){let S=f==null?l.len:l.pos+f;for(;l.pos<S;){let x=l.uint32();x>>>3===1?yield{field:`${p}.topicID`,value:l.string()}:l.skipType(x&7)}})),g);function w(l){return ye(l,u.codec())}u.encode=w;function y(l,f){return be(l,u.codec(),f)}u.decode=y;function I(l,f){return we(l,u.codec(),f)}u.stream=I})(o=s.ControlGraft||(s.ControlGraft={}));let a;(function(u){let g;u.codec=()=>(g==null&&(g=xe((l,f,p={})=>{if(p.lengthDelimited!==!1&&f.fork(),l.topicID!=null&&(f.uint32(10),f.string(l.topicID)),l.peers!=null&&l.peers.length>0)for(let b of l.peers)f.uint32(18),s.PeerInfo.codec().encode(b,f);l.backoff!=null&&(f.uint32(24),f.uint64Number(l.backoff)),p.lengthDelimited!==!1&&f.ldelim()},(l,f,p={})=>{let b={peers:[]},S=f==null?l.len:l.pos+f;for(;l.pos<S;){let x=l.uint32();switch(x>>>3){case 1:{b.topicID=l.string();break}case 2:{if(p.limits?.peers!=null&&b.peers.length===p.limits.peers)throw new z('Decode error - repeated field "peers" had too many elements');b.peers.push(s.PeerInfo.codec().decode(l,l.uint32(),{limits:p.limits?.peers$}));break}case 3:{b.backoff=l.uint64Number();break}default:{l.skipType(x&7);break}}}return b},function*(l,f,p,b={}){let S={peers:0},x=f==null?l.len:l.pos+f;for(;l.pos<x;){let _=l.uint32();switch(_>>>3){case 1:{yield{field:`${p}.topicID`,value:l.string()};break}case 2:{if(b.limits?.peers!=null&&S.peers===b.limits.peers)throw new z('Streaming decode error - repeated field "peers" had too many elements');for(let P of s.PeerInfo.codec().stream(l,l.uint32(),`${p}.peers[]`,{limits:b.limits?.peers$}))yield{...P,index:S.peers};S.peers++;break}case 3:{yield{field:`${p}.backoff`,value:l.uint64Number()};break}default:{l.skipType(_&7);break}}}})),g);function w(l){return ye(l,u.codec())}u.encode=w;function y(l,f){return be(l,u.codec(),f)}u.decode=y;function I(l,f){return we(l,u.codec(),f)}u.stream=I})(a=s.ControlPrune||(s.ControlPrune={}));let c;(function(u){let g;u.codec=()=>(g==null&&(g=xe((l,f,p={})=>{p.lengthDelimited!==!1&&f.fork(),l.peerID!=null&&(f.uint32(10),f.bytes(l.peerID)),l.signedPeerRecord!=null&&(f.uint32(18),f.bytes(l.signedPeerRecord)),p.lengthDelimited!==!1&&f.ldelim()},(l,f,p={})=>{let b={},S=f==null?l.len:l.pos+f;for(;l.pos<S;){let x=l.uint32();switch(x>>>3){case 1:{b.peerID=l.bytes();break}case 2:{b.signedPeerRecord=l.bytes();break}default:{l.skipType(x&7);break}}}return b},function*(l,f,p,b={}){let S=f==null?l.len:l.pos+f;for(;l.pos<S;){let x=l.uint32();switch(x>>>3){case 1:{yield{field:`${p}.peerID`,value:l.bytes()};break}case 2:{yield{field:`${p}.signedPeerRecord`,value:l.bytes()};break}default:{l.skipType(x&7);break}}}})),g);function w(l){return ye(l,u.codec())}u.encode=w;function y(l,f){return be(l,u.codec(),f)}u.decode=y;function I(l,f){return we(l,u.codec(),f)}u.stream=I})(c=s.PeerInfo||(s.PeerInfo={}));let h;(function(u){let g;u.codec=()=>(g==null&&(g=xe((l,f,p={})=>{if(p.lengthDelimited!==!1&&f.fork(),l.messageIDs!=null&&l.messageIDs.length>0)for(let b of l.messageIDs)f.uint32(10),f.bytes(b);p.lengthDelimited!==!1&&f.ldelim()},(l,f,p={})=>{let b={messageIDs:[]},S=f==null?l.len:l.pos+f;for(;l.pos<S;){let x=l.uint32();switch(x>>>3){case 1:{if(p.limits?.messageIDs!=null&&b.messageIDs.length===p.limits.messageIDs)throw new z('Decode error - repeated field "messageIDs" had too many elements');b.messageIDs.push(l.bytes());break}default:{l.skipType(x&7);break}}}return b},function*(l,f,p,b={}){let S={messageIDs:0},x=f==null?l.len:l.pos+f;for(;l.pos<x;){let _=l.uint32();switch(_>>>3){case 1:{if(b.limits?.messageIDs!=null&&S.messageIDs===b.limits.messageIDs)throw new z('Streaming decode error - repeated field "messageIDs" had too many elements');yield{field:`${p}.messageIDs[]`,index:S.messageIDs,value:l.bytes()},S.messageIDs++;break}default:{l.skipType(_&7);break}}}})),g);function w(l){return ye(l,u.codec())}u.encode=w;function y(l,f){return be(l,u.codec(),f)}u.decode=y;function I(l,f){return we(l,u.codec(),f)}u.stream=I})(h=s.ControlIDontWant||(s.ControlIDontWant={}));let m;s.codec=()=>(m==null&&(m=xe((u,g,w={})=>{if(w.lengthDelimited!==!1&&g.fork(),u.subscriptions!=null&&u.subscriptions.length>0)for(let y of u.subscriptions)g.uint32(10),s.SubOpts.codec().encode(y,g);if(u.messages!=null&&u.messages.length>0)for(let y of u.messages)g.uint32(18),s.Message.codec().encode(y,g);u.control!=null&&(g.uint32(26),s.ControlMessage.codec().encode(u.control,g)),w.lengthDelimited!==!1&&g.ldelim()},(u,g,w={})=>{let y={subscriptions:[],messages:[]},I=g==null?u.len:u.pos+g;for(;u.pos<I;){let l=u.uint32();switch(l>>>3){case 1:{if(w.limits?.subscriptions!=null&&y.subscriptions.length===w.limits.subscriptions)throw new z('Decode error - repeated field "subscriptions" had too many elements');y.subscriptions.push(s.SubOpts.codec().decode(u,u.uint32(),{limits:w.limits?.subscriptions$}));break}case 2:{if(w.limits?.messages!=null&&y.messages.length===w.limits.messages)throw new z('Decode error - repeated field "messages" had too many elements');y.messages.push(s.Message.codec().decode(u,u.uint32(),{limits:w.limits?.messages$}));break}case 3:{y.control=s.ControlMessage.codec().decode(u,u.uint32(),{limits:w.limits?.control});break}default:{u.skipType(l&7);break}}}return y},function*(u,g,w,y={}){let I={subscriptions:0,messages:0},l=g==null?u.len:u.pos+g;for(;u.pos<l;){let f=u.uint32();switch(f>>>3){case 1:{if(y.limits?.subscriptions!=null&&I.subscriptions===y.limits.subscriptions)throw new z('Streaming decode error - repeated field "subscriptions" had too many elements');for(let p of s.SubOpts.codec().stream(u,u.uint32(),`${w}.subscriptions[]`,{limits:y.limits?.subscriptions$}))yield{...p,index:I.subscriptions};I.subscriptions++;break}case 2:{if(y.limits?.messages!=null&&I.messages===y.limits.messages)throw new z('Streaming decode error - repeated field "messages" had too many elements');for(let p of s.Message.codec().stream(u,u.uint32(),`${w}.messages[]`,{limits:y.limits?.messages$}))yield{...p,index:I.messages};I.messages++;break}case 3:{yield*s.ControlMessage.codec().stream(u,u.uint32(),`${w}.control`,{limits:y.limits?.control});break}default:{u.skipType(f&7);break}}}})),m);function d(u){return ye(u,s.codec())}s.encode=d;function E(u,g){return be(u,s.codec(),g)}s.decode=E;function v(u,g){return we(u,s.codec(),g)}s.stream=v})(nt||(nt={}));var vr=class{gossip;msgs=new Map;msgIdToStrFn;history=[];notValidatedCount=0;constructor(e,t,r){this.gossip=e,this.msgIdToStrFn=r;for(let n=0;n<t;n++)this.history[n]=[]}get size(){return this.msgs.size}put(e,t,r=!1){let{msgIdStr:n}=e;return this.msgs.has(n)?!1:(this.msgs.set(n,{message:t,validated:r,originatingPeers:new Set,iwantCounts:new Map}),this.history[0].push({...e,topic:t.topic}),r||this.notValidatedCount++,!0)}observeDuplicate(e,t){let r=this.msgs.get(e);r!=null&&!r.validated&&r.originatingPeers.add(t)}get(e){return this.msgs.get(this.msgIdToStrFn(e))?.message}getWithIWantCount(e,t){let r=this.msgs.get(e);if(r==null)return null;let n=(r.iwantCounts.get(t)??0)+1;return r.iwantCounts.set(t,n),{msg:r.message,count:n}}getGossipIDs(e){let t=new Map;for(let r=0;r<this.gossip;r++)this.history[r].forEach(n=>{if((this.msgs.get(n.msgIdStr)?.validated??!1)&&e.has(n.topic)){let o=t.get(n.topic);o==null&&(o=[],t.set(n.topic,o)),o.push(n.msgId)}});return t}validate(e){let t=this.msgs.get(e);if(t==null)return null;t.validated||this.notValidatedCount--;let{message:r,originatingPeers:n}=t;return t.validated=!0,t.originatingPeers=new Set,{message:r,originatingPeers:n}}shift(){this.history[this.history.length-1].forEach(t=>{let r=this.msgs.get(t.msgIdStr);r!=null&&(this.msgs.delete(t.msgIdStr),r.validated||this.notValidatedCount--)}),this.history.pop(),this.history.unshift([])}remove(e){let t=this.msgs.get(e);return t==null?null:(this.msgs.delete(e),t)}};var za;(function(s){s.StrictSign="StrictSign",s.StrictNoSign="StrictNoSign"})(za||(za={}));var gt;(function(s){s[s.Signing=0]="Signing",s[s.Anonymous=1]="Anonymous"})(gt||(gt={}));var ve;(function(s){s.Error="error",s.Ignore="ignore",s.Reject="reject",s.Blacklisted="blacklisted"})(ve||(ve={}));var de;(function(s){s.InvalidSignature="invalid_signature",s.InvalidSeqno="invalid_seqno",s.InvalidPeerId="invalid_peerid",s.SignaturePresent="signature_present",s.SeqnoPresent="seqno_present",s.FromPresent="from_present",s.TransformFailed="transform_failed"})(de||(de={}));var pe;(function(s){s.duplicate="duplicate",s.invalid="invalid",s.valid="valid"})(pe||(pe={}));function Ai(s){switch(s){case me.Ignore:return ve.Ignore;case me.Reject:return ve.Reject;default:throw new Error("Unreachable")}}var Wa;(function(s){s.forward="forward",s.publish="publish"})(Wa||(Wa={}));var Ee;(function(s){s.Fanout="fanout",s.Random="random",s.Subscribed="subscribed",s.Outbound="outbound",s.NotEnough="not_enough",s.Opportunistic="opportunistic"})(Ee||(Ee={}));var Ne;(function(s){s.Dc="disconnected",s.BadScore="bad_score",s.Prune="prune",s.Excess="excess"})(Ne||(Ne={}));var rs;(function(s){s.GraftBackoff="graft_backoff",s.BrokenPromise="broken_promise",s.MessageDeficit="message_deficit",s.IPColocation="IP_colocation"})(rs||(rs={}));var ns;(function(s){s.LowScore="low_score",s.MaxIhave="max_ihave",s.MaxIasked="max_iasked"})(ns||(ns={}));var ss;(function(s){s.graylist="graylist",s.publish="publish",s.gossip="gossip",s.mesh="mesh"})(ss||(ss={}));function $a(s,e,t){return{protocolsEnabled:s.gauge({name:"gossipsub_protocol",help:"Status of enabled protocols",labelNames:["protocol"]}),topicSubscriptionStatus:s.gauge({name:"gossipsub_topic_subscription_status",help:"Status of our subscription to this topic",labelNames:["topicStr"]}),topicPeersCount:s.gauge({name:"gossipsub_topic_peer_count",help:"Number of peers subscribed to each topic",labelNames:["topicStr"]}),meshPeerCounts:s.gauge({name:"gossipsub_mesh_peer_count",help:"Number of peers in our mesh",labelNames:["topicStr"]}),meshPeerInclusionEventsFanout:s.gauge({name:"gossipsub_mesh_peer_inclusion_events_fanout_total",help:"Number of times we include peers in a topic mesh for fanout reasons",labelNames:["topic"]}),meshPeerInclusionEventsRandom:s.gauge({name:"gossipsub_mesh_peer_inclusion_events_random_total",help:"Number of times we include peers in a topic mesh for random reasons",labelNames:["topic"]}),meshPeerInclusionEventsSubscribed:s.gauge({name:"gossipsub_mesh_peer_inclusion_events_subscribed_total",help:"Number of times we include peers in a topic mesh for subscribed reasons",labelNames:["topic"]}),meshPeerInclusionEventsOutbound:s.gauge({name:"gossipsub_mesh_peer_inclusion_events_outbound_total",help:"Number of times we include peers in a topic mesh for outbound reasons",labelNames:["topic"]}),meshPeerInclusionEventsNotEnough:s.gauge({name:"gossipsub_mesh_peer_inclusion_events_not_enough_total",help:"Number of times we include peers in a topic mesh for not_enough reasons",labelNames:["topic"]}),meshPeerInclusionEventsOpportunistic:s.gauge({name:"gossipsub_mesh_peer_inclusion_events_opportunistic_total",help:"Number of times we include peers in a topic mesh for opportunistic reasons",labelNames:["topic"]}),meshPeerInclusionEventsUnknown:s.gauge({name:"gossipsub_mesh_peer_inclusion_events_unknown_total",help:"Number of times we include peers in a topic mesh for unknown reasons",labelNames:["topic"]}),meshPeerChurnEventsDisconnected:s.gauge({name:"gossipsub_peer_churn_events_disconnected_total",help:"Number of times we remove peers in a topic mesh for disconnected reasons",labelNames:["topic"]}),meshPeerChurnEventsBadScore:s.gauge({name:"gossipsub_peer_churn_events_bad_score_total",help:"Number of times we remove peers in a topic mesh for bad_score reasons",labelNames:["topic"]}),meshPeerChurnEventsPrune:s.gauge({name:"gossipsub_peer_churn_events_prune_total",help:"Number of times we remove peers in a topic mesh for prune reasons",labelNames:["topic"]}),meshPeerChurnEventsExcess:s.gauge({name:"gossipsub_peer_churn_events_excess_total",help:"Number of times we remove peers in a topic mesh for excess reasons",labelNames:["topic"]}),meshPeerChurnEventsUnknown:s.gauge({name:"gossipsub_peer_churn_events_unknown_total",help:"Number of times we remove peers in a topic mesh for unknown reasons",labelNames:["topic"]}),peersPerProtocol:s.gauge({name:"gossipsub_peers_per_protocol_count",help:"Peers connected for each topic",labelNames:["protocol"]}),heartbeatDuration:s.histogram({name:"gossipsub_heartbeat_duration_seconds",help:"The time it takes to complete one iteration of the heartbeat",buckets:[.01,.1,1]}),heartbeatSkipped:s.gauge({name:"gossipsub_heartbeat_skipped",help:"Heartbeat run took longer than heartbeat interval so next is skipped"}),acceptedMessagesTotal:s.gauge({name:"gossipsub_accepted_messages_total",help:"Total accepted messages for each topic",labelNames:["topic"]}),ignoredMessagesTotal:s.gauge({name:"gossipsub_ignored_messages_total",help:"Total ignored messages for each topic",labelNames:["topic"]}),rejectedMessagesTotal:s.gauge({name:"gossipsub_rejected_messages_total",help:"Total rejected messages for each topic",labelNames:["topic"]}),unknownValidationResultsTotal:s.gauge({name:"gossipsub_unknown_validation_results_total",help:"Total unknown validation results for each topic",labelNames:["topic"]}),asyncValidationMcacheHit:s.gauge({name:"gossipsub_async_validation_mcache_hit_total",help:"Async validation result reported by the user layer",labelNames:["hit"]}),asyncValidationDelayFromFirstSeenSec:s.histogram({name:"gossipsub_async_validation_delay_from_first_seen",help:"Async validation report delay from first seen in second",buckets:[.01,.03,.1,.3,1,3,10]}),asyncValidationUnknownFirstSeen:s.gauge({name:"gossipsub_async_validation_unknown_first_seen_count_total",help:"Async validation report unknown first seen value for message"}),peerReadStreamError:s.gauge({name:"gossipsub_peer_read_stream_err_count_total",help:"Peer read stream error"}),rpcRecvBytes:s.gauge({name:"gossipsub_rpc_recv_bytes_total",help:"RPC recv"}),rpcRecvCount:s.gauge({name:"gossipsub_rpc_recv_count_total",help:"RPC recv"}),rpcRecvSubscription:s.gauge({name:"gossipsub_rpc_recv_subscription_total",help:"RPC recv"}),rpcRecvMessage:s.gauge({name:"gossipsub_rpc_recv_message_total",help:"RPC recv"}),rpcRecvControl:s.gauge({name:"gossipsub_rpc_recv_control_total",help:"RPC recv"}),rpcRecvIHave:s.gauge({name:"gossipsub_rpc_recv_ihave_total",help:"RPC recv"}),rpcRecvIWant:s.gauge({name:"gossipsub_rpc_recv_iwant_total",help:"RPC recv"}),rpcRecvGraft:s.gauge({name:"gossipsub_rpc_recv_graft_total",help:"RPC recv"}),rpcRecvPrune:s.gauge({name:"gossipsub_rpc_recv_prune_total",help:"RPC recv"}),rpcDataError:s.gauge({name:"gossipsub_rpc_data_err_count_total",help:"RPC data error"}),rpcRecvError:s.gauge({name:"gossipsub_rpc_recv_err_count_total",help:"RPC recv error"}),rpcRecvNotAccepted:s.gauge({name:"gossipsub_rpc_rcv_not_accepted_total",help:"Total count of RPC dropped because acceptFrom() == false"}),rpcSentBytes:s.gauge({name:"gossipsub_rpc_sent_bytes_total",help:"RPC sent"}),rpcSentCount:s.gauge({name:"gossipsub_rpc_sent_count_total",help:"RPC sent"}),rpcSentSubscription:s.gauge({name:"gossipsub_rpc_sent_subscription_total",help:"RPC sent"}),rpcSentMessage:s.gauge({name:"gossipsub_rpc_sent_message_total",help:"RPC sent"}),rpcSentControl:s.gauge({name:"gossipsub_rpc_sent_control_total",help:"RPC sent"}),rpcSentIHave:s.gauge({name:"gossipsub_rpc_sent_ihave_total",help:"RPC sent"}),rpcSentIWant:s.gauge({name:"gossipsub_rpc_sent_iwant_total",help:"RPC sent"}),rpcSentGraft:s.gauge({name:"gossipsub_rpc_sent_graft_total",help:"RPC sent"}),rpcSentPrune:s.gauge({name:"gossipsub_rpc_sent_prune_total",help:"RPC sent"}),rpcSentIDontWant:s.gauge({name:"gossipsub_rpc_sent_idontwant_total",help:"RPC sent"}),msgPublishCount:s.gauge({name:"gossipsub_msg_publish_count_total",help:"Total count of msg published by topic",labelNames:["topic"]}),msgPublishPeersByTopic:s.gauge({name:"gossipsub_msg_publish_peers_total",help:"Total count of peers that we publish a msg to",labelNames:["topic"]}),directPeersPublishedTotal:s.gauge({name:"gossipsub_direct_peers_published_total",help:"Total direct peers that we publish a msg to",labelNames:["topic"]}),floodsubPeersPublishedTotal:s.gauge({name:"gossipsub_floodsub_peers_published_total",help:"Total floodsub peers that we publish a msg to",labelNames:["topic"]}),meshPeersPublishedTotal:s.gauge({name:"gossipsub_mesh_peers_published_total",help:"Total mesh peers that we publish a msg to",labelNames:["topic"]}),fanoutPeersPublishedTotal:s.gauge({name:"gossipsub_fanout_peers_published_total",help:"Total fanout peers that we publish a msg to",labelNames:["topic"]}),msgPublishBytes:s.gauge({name:"gossipsub_msg_publish_bytes_total",help:"Total count of msg publish data.length bytes",labelNames:["topic"]}),msgPublishTime:s.histogram({name:"gossipsub_msg_publish_seconds",help:"Total time in seconds to publish a message",buckets:[.001,.002,.005,.01,.1,.5,1],labelNames:["topic"]}),msgForwardCount:s.gauge({name:"gossipsub_msg_forward_count_total",help:"Total count of msg forwarded by topic",labelNames:["topic"]}),msgForwardPeers:s.gauge({name:"gossipsub_msg_forward_peers_total",help:"Total count of peers that we forward a msg to",labelNames:["topic"]}),msgReceivedPreValidation:s.gauge({name:"gossipsub_msg_received_prevalidation_total",help:"Total count of recv msgs before any validation",labelNames:["topic"]}),msgReceivedError:s.gauge({name:"gossipsub_msg_received_error_total",help:"Total count of recv msgs error",labelNames:["topic"]}),prevalidationInvalidTotal:s.gauge({name:"gossipsub_pre_validation_invalid_total",help:"Total count of invalid messages received",labelNames:["topic"]}),prevalidationValidTotal:s.gauge({name:"gossipsub_pre_validation_valid_total",help:"Total count of valid messages received",labelNames:["topic"]}),prevalidationDuplicateTotal:s.gauge({name:"gossipsub_pre_validation_duplicate_total",help:"Total count of duplicate messages received",labelNames:["topic"]}),prevalidationUnknownTotal:s.gauge({name:"gossipsub_pre_validation_unknown_status_total",help:"Total count of unknown_status messages received",labelNames:["topic"]}),msgReceivedInvalid:s.gauge({name:"gossipsub_msg_received_invalid_total",help:"Tracks specific reason of invalid",labelNames:["error"]}),msgReceivedInvalidByTopic:s.gauge({name:"gossipsub_msg_received_invalid_by_topic_total",help:"Tracks specific invalid message by topic",labelNames:["topic"]}),duplicateMsgDeliveryDelay:s.histogram({name:"gossisub_duplicate_msg_delivery_delay_seconds",help:"Time since the 1st duplicated message validated",labelNames:["topic"],buckets:[.25*t.maxMeshMessageDeliveriesWindowSec,.5*t.maxMeshMessageDeliveriesWindowSec,Number(t.maxMeshMessageDeliveriesWindowSec),2*t.maxMeshMessageDeliveriesWindowSec,4*t.maxMeshMessageDeliveriesWindowSec]}),duplicateMsgLateDelivery:s.gauge({name:"gossisub_duplicate_msg_late_delivery_total",help:"Total count of late duplicate message delivery by topic, which triggers P3 penalty",labelNames:["topic"]}),duplicateMsgIgnored:s.gauge({name:"gossisub_ignored_published_duplicate_msgs_total",help:"Total count of published duplicate message ignored by topic",labelNames:["topic"]}),scoreFnCalls:s.gauge({name:"gossipsub_score_fn_calls_total",help:"Total times score() is called"}),scoreFnRuns:s.gauge({name:"gossipsub_score_fn_runs_total",help:"Total times score() call actually computed computeScore(), no cache"}),scoreCachedDelta:s.histogram({name:"gossipsub_score_cache_delta",help:"Delta of score between cached values that expired",buckets:[10,100,1e3]}),peersByScoreThreshold:s.gauge({name:"gossipsub_peers_by_score_threshold_count",help:"Current count of peers by score threshold",labelNames:["threshold"]}),score:s.avgMinMax({name:"gossipsub_score",help:"Avg min max of gossip scores"}),scoreWeights:s.avgMinMax({name:"gossipsub_score_weights",help:"Separate score weights",labelNames:["topic","p"]}),scorePerMesh:s.avgMinMax({name:"gossipsub_score_per_mesh",help:"Histogram of the scores for each mesh topic",labelNames:["topic"]}),scoringPenalties:s.gauge({name:"gossipsub_scoring_penalties_total",help:"A counter of the kind of penalties being applied to peers",labelNames:["penalty"]}),behaviourPenalty:s.histogram({name:"gossipsub_peer_stat_behaviour_penalty",help:"Current peer stat behaviour_penalty at each scrape",buckets:[.25*t.behaviourPenaltyThreshold,.5*t.behaviourPenaltyThreshold,Number(t.behaviourPenaltyThreshold),2*t.behaviourPenaltyThreshold,4*t.behaviourPenaltyThreshold]}),ihaveRcvIgnored:s.gauge({name:"gossipsub_ihave_rcv_ignored_total",help:"Total received IHAVE messages that we ignore for some reason",labelNames:["reason"]}),ihaveRcvMsgids:s.gauge({name:"gossipsub_ihave_rcv_msgids_total",help:"Total received IHAVE messages by topic",labelNames:["topic"]}),ihaveRcvNotSeenMsgids:s.gauge({name:"gossipsub_ihave_rcv_not_seen_msgids_total",help:"Total messages per topic we do not have, not actual requests",labelNames:["topic"]}),iwantRcvMsgids:s.gauge({name:"gossipsub_iwant_rcv_msgids_total",help:"Total received IWANT messages by topic",labelNames:["topic"]}),iwantRcvDonthaveMsgids:s.gauge({name:"gossipsub_iwant_rcv_dont_have_msgids_total",help:"Total requested messageIDs that we do not have"}),idontwantRcvMsgids:s.gauge({name:"gossipsub_idontwant_rcv_msgids_total",help:"Total received IDONTWANT messages"}),idontwantRcvDonthaveMsgids:s.gauge({name:"gossipsub_idontwant_rcv_dont_have_msgids_total",help:"Total received IDONTWANT messageIDs that we do not have in mcache"}),iwantPromiseStarted:s.gauge({name:"gossipsub_iwant_promise_sent_total",help:"Total count of started IWANT promises"}),iwantPromiseResolved:s.gauge({name:"gossipsub_iwant_promise_resolved_total",help:"Total count of resolved IWANT promises"}),iwantPromiseResolvedFromDuplicate:s.gauge({name:"gossipsub_iwant_promise_resolved_from_duplicate_total",help:"Total count of resolved IWANT promises from duplicate messages"}),iwantPromiseResolvedPeers:s.gauge({name:"gossipsub_iwant_promise_resolved_peers",help:"Total count of peers we have asked IWANT promises that are resolved"}),iwantPromiseBroken:s.gauge({name:"gossipsub_iwant_promise_broken",help:"Total count of broken IWANT promises"}),iwantMessagePruned:s.gauge({name:"gossipsub_iwant_message_pruned",help:"Total count of pruned IWANT messages"}),iwantPromiseDeliveryTime:s.histogram({name:"gossipsub_iwant_promise_delivery_seconds",help:"Histogram of delivery time of resolved IWANT promises",buckets:[.5*t.gossipPromiseExpireSec,Number(t.gossipPromiseExpireSec),2*t.gossipPromiseExpireSec,4*t.gossipPromiseExpireSec]}),iwantPromiseUntracked:s.gauge({name:"gossip_iwant_promise_untracked",help:"Total count of untracked IWANT promise"}),connectedPeersBackoffSec:s.histogram({name:"gossipsub_connected_peers_backoff_seconds",help:"Backoff time in seconds",buckets:[1,2,4,10,20,60,120]}),cacheSize:s.gauge({name:"gossipsub_cache_size",help:"Unbounded cache sizes",labelNames:["cache"]}),mcacheSize:s.gauge({name:"gossipsub_mcache_size",help:"Current mcache msg count"}),mcacheNotValidatedCount:s.gauge({name:"gossipsub_mcache_not_validated_count",help:"Current mcache msg count not validated"}),fastMsgIdCacheCollision:s.gauge({name:"gossipsub_fastmsgid_cache_collision_total",help:"Total count of key collisions on fastmsgid cache put"}),newConnectionCount:s.gauge({name:"gossipsub_new_connection_total",help:"Total new connection by status",labelNames:["status"]}),topicStrToLabel:e,toTopic(r){return this.topicStrToLabel.get(r)??r},onJoin(r){this.topicSubscriptionStatus.set({topicStr:r},1),this.meshPeerCounts.set({topicStr:r},0)},onLeave(r){this.topicSubscriptionStatus.set({topicStr:r},0),this.meshPeerCounts.set({topicStr:r},0)},onAddToMesh(r,n,i){let o=this.toTopic(r);switch(n){case Ee.Fanout:this.meshPeerInclusionEventsFanout.inc({topic:o},i);break;case Ee.Random:this.meshPeerInclusionEventsRandom.inc({topic:o},i);break;case Ee.Subscribed:this.meshPeerInclusionEventsSubscribed.inc({topic:o},i);break;case Ee.Outbound:this.meshPeerInclusionEventsOutbound.inc({topic:o},i);break;case Ee.NotEnough:this.meshPeerInclusionEventsNotEnough.inc({topic:o},i);break;case Ee.Opportunistic:this.meshPeerInclusionEventsOpportunistic.inc({topic:o},i);break;default:this.meshPeerInclusionEventsUnknown.inc({topic:o},i);break}},onRemoveFromMesh(r,n,i){let o=this.toTopic(r);switch(n){case Ne.Dc:this.meshPeerChurnEventsDisconnected.inc({topic:o},i);break;case Ne.BadScore:this.meshPeerChurnEventsBadScore.inc({topic:o},i);break;case Ne.Prune:this.meshPeerChurnEventsPrune.inc({topic:o},i);break;case Ne.Excess:this.meshPeerChurnEventsExcess.inc({topic:o},i);break;default:this.meshPeerChurnEventsUnknown.inc({topic:o},i);break}},onReportValidation(r,n,i){if(this.asyncValidationMcacheHit.inc({hit:r!=null?"hit":"miss"}),r!=null){let o=this.toTopic(r.message.topic);switch(n){case me.Accept:this.acceptedMessagesTotal.inc({topic:o});break;case me.Ignore:this.ignoredMessagesTotal.inc({topic:o});break;case me.Reject:this.rejectedMessagesTotal.inc({topic:o});break;default:this.unknownValidationResultsTotal.inc({topic:o});break}}i!=null?this.asyncValidationDelayFromFirstSeenSec.observe((Date.now()-i)/1e3):this.asyncValidationUnknownFirstSeen.inc()},onScorePenalty(r){this.scoringPenalties.inc({penalty:r},1)},onIhaveRcv(r,n,i){let o=this.toTopic(r);this.ihaveRcvMsgids.inc({topic:o},n),this.ihaveRcvNotSeenMsgids.inc({topic:o},i)},onIwantRcv(r,n){for(let[i,o]of r){let a=this.toTopic(i);this.iwantRcvMsgids.inc({topic:a},o)}this.iwantRcvDonthaveMsgids.inc(n)},onIdontwantRcv(r,n){this.idontwantRcvMsgids.inc(r),this.idontwantRcvDonthaveMsgids.inc(n)},onForwardMsg(r,n){let i=this.toTopic(r);this.msgForwardCount.inc({topic:i},1),this.msgForwardPeers.inc({topic:i},n)},onPublishMsg(r,n,i,o,a){let c=this.toTopic(r);this.msgPublishCount.inc({topic:c},1),this.msgPublishBytes.inc({topic:c},i*o),this.msgPublishPeersByTopic.inc({topic:c},i),this.directPeersPublishedTotal.inc({topic:c},n.direct),this.floodsubPeersPublishedTotal.inc({topic:c},n.floodsub),this.meshPeersPublishedTotal.inc({topic:c},n.mesh),this.fanoutPeersPublishedTotal.inc({topic:c},n.fanout),this.msgPublishTime.observe({topic:c},a/1e3)},onMsgRecvPreValidation(r){let n=this.toTopic(r);this.msgReceivedPreValidation.inc({topic:n},1)},onMsgRecvError(r){let n=this.toTopic(r);this.msgReceivedError.inc({topic:n},1)},onPrevalidationResult(r,n){let i=this.toTopic(r);switch(n){case pe.duplicate:this.prevalidationDuplicateTotal.inc({topic:i});break;case pe.invalid:this.prevalidationInvalidTotal.inc({topic:i});break;case pe.valid:this.prevalidationValidTotal.inc({topic:i});break;default:this.prevalidationUnknownTotal.inc({topic:i});break}},onMsgRecvInvalid(r,n){let i=this.toTopic(r),o=n.reason===ve.Error?n.error:n.reason;this.msgReceivedInvalid.inc({error:o},1),this.msgReceivedInvalidByTopic.inc({topic:i},1)},onDuplicateMsgDelivery(r,n,i){let o=this.toTopic(r);this.duplicateMsgDeliveryDelay.observe({topic:o},n/1e3),i&&this.duplicateMsgLateDelivery.inc({topic:o},1)},onPublishDuplicateMsg(r){let n=this.toTopic(r);this.duplicateMsgIgnored.inc({topic:n},1)},onPeerReadStreamError(){this.peerReadStreamError.inc(1)},onRpcRecvError(){this.rpcRecvError.inc(1)},onRpcDataError(){this.rpcDataError.inc(1)},onRpcRecv(r,n){this.rpcRecvBytes.inc(n),this.rpcRecvCount.inc(1),r.subscriptions!=null&&this.rpcRecvSubscription.inc(r.subscriptions.length),r.messages!=null&&this.rpcRecvMessage.inc(r.messages.length),r.control!=null&&(this.rpcRecvControl.inc(1),r.control.ihave!=null&&this.rpcRecvIHave.inc(r.control.ihave.length),r.control.iwant!=null&&this.rpcRecvIWant.inc(r.control.iwant.length),r.control.graft!=null&&this.rpcRecvGraft.inc(r.control.graft.length),r.control.prune!=null&&this.rpcRecvPrune.inc(r.control.prune.length))},onRpcSent(r,n){if(this.rpcSentBytes.inc(n),this.rpcSentCount.inc(1),r.subscriptions!=null&&this.rpcSentSubscription.inc(r.subscriptions.length),r.messages!=null&&this.rpcSentMessage.inc(r.messages.length),r.control!=null){let i=r.control.ihave?.length??0,o=r.control.iwant?.length??0,a=r.control.graft?.length??0,c=r.control.prune?.length??0,h=r.control.idontwant?.length??0;i>0&&this.rpcSentIHave.inc(i),o>0&&this.rpcSentIWant.inc(o),a>0&&this.rpcSentGraft.inc(a),c>0&&this.rpcSentPrune.inc(c),h>0&&this.rpcSentIDontWant.inc(h),(i>0||o>0||a>0||c>0||h>0)&&this.rpcSentControl.inc(1)}},registerScores(r,n){let i=0,o=0,a=0,c=0;for(let h of r)h>=n.graylistThreshold&&i++,h>=n.publishThreshold&&o++,h>=n.gossipThreshold&&a++,h>=0&&c++;this.peersByScoreThreshold.set({threshold:ss.graylist},i),this.peersByScoreThreshold.set({threshold:ss.publish},o),this.peersByScoreThreshold.set({threshold:ss.gossip},a),this.peersByScoreThreshold.set({threshold:ss.mesh},c),this.score.set(r)},registerScoreWeights(r){for(let[n,i]of r.byTopic)this.scoreWeights.set({topic:n,p:"p1"},i.p1w),this.scoreWeights.set({topic:n,p:"p2"},i.p2w),this.scoreWeights.set({topic:n,p:"p3"},i.p3w),this.scoreWeights.set({topic:n,p:"p3b"},i.p3bw),this.scoreWeights.set({topic:n,p:"p4"},i.p4w);this.scoreWeights.set({p:"p5"},r.p5w),this.scoreWeights.set({p:"p6"},r.p6w),this.scoreWeights.set({p:"p7"},r.p7w)},registerScorePerMesh(r,n){let i=new Map;r.forEach((o,a)=>{let c=this.topicStrToLabel.get(a)??"unknown",h=i.get(c);h==null&&(h=new Set,i.set(c,h)),o.forEach(m=>h?.add(m))});for(let[o,a]of i){let c=[];a.forEach(h=>{c.push(n.get(h)??0)}),this.scorePerMesh.set({topic:o},c)}}}}var G=class extends Error{static name="InvalidPeerScoreParamsError";constructor(e="Invalid peer score params"){super(e),this.name="InvalidPeerScoreParamsError"}};var ph={topics:{},topicScoreCap:10,appSpecificScore:()=>0,appSpecificWeight:10,IPColocationFactorWeight:-5,IPColocationFactorThreshold:10,IPColocationFactorWhitelist:new Set,behaviourPenaltyWeight:-10,behaviourPenaltyThreshold:0,behaviourPenaltyDecay:.2,decayInterval:1e3,decayToZero:.1,retainScore:3600*1e3},mh={topicWeight:.5,timeInMeshWeight:1,timeInMeshQuantum:1,timeInMeshCap:3600,firstMessageDeliveriesWeight:1,firstMessageDeliveriesDecay:.5,firstMessageDeliveriesCap:2e3,meshMessageDeliveriesWeight:-1,meshMessageDeliveriesDecay:.5,meshMessageDeliveriesCap:100,meshMessageDeliveriesThreshold:20,meshMessageDeliveriesWindow:10,meshMessageDeliveriesActivation:5e3,meshFailurePenaltyWeight:-1,meshFailurePenaltyDecay:.5,invalidMessageDeliveriesWeight:-1,invalidMessageDeliveriesDecay:.3};function ja(s={}){return{...ph,...s,topics:s.topics!=null?Object.entries(s.topics).reduce((e,[t,r])=>(e[t]=gh(r),e),{}):{}}}function gh(s={}){return{...mh,...s}}function Za(s){for(let[e,t]of Object.entries(s.topics))try{bh(t)}catch(r){throw new G(`invalid score parameters for topic ${e}: ${r.message}`)}if(s.topicScoreCap<0)throw new G("invalid topic score cap; must be positive (or 0 for no cap)");if(s.appSpecificScore===null||s.appSpecificScore===void 0)throw new G("missing application specific score function");if(s.IPColocationFactorWeight>0)throw new G("invalid IPColocationFactorWeight; must be negative (or 0 to disable)");if(s.IPColocationFactorWeight!==0&&s.IPColocationFactorThreshold<1)throw new G("invalid IPColocationFactorThreshold; must be at least 1");if(s.behaviourPenaltyWeight>0)throw new G("invalid BehaviourPenaltyWeight; must be negative (or 0 to disable)");if(s.behaviourPenaltyWeight!==0&&(s.behaviourPenaltyDecay<=0||s.behaviourPenaltyDecay>=1))throw new G("invalid BehaviourPenaltyDecay; must be between 0 and 1");if(s.decayInterval<1e3)throw new G("invalid DecayInterval; must be at least 1s");if(s.decayToZero<=0||s.decayToZero>=1)throw new G("invalid DecayToZero; must be between 0 and 1")}function bh(s){if(s.topicWeight<0)throw new G("invalid topic weight; must be >= 0");if(s.timeInMeshQuantum===0)throw new G("invalid TimeInMeshQuantum; must be non zero");if(s.timeInMeshWeight<0)throw new G("invalid TimeInMeshWeight; must be positive (or 0 to disable)");if(s.timeInMeshWeight!==0&&s.timeInMeshQuantum<=0)throw new G("invalid TimeInMeshQuantum; must be positive");if(s.timeInMeshWeight!==0&&s.timeInMeshCap<=0)throw new G("invalid TimeInMeshCap; must be positive");if(s.firstMessageDeliveriesWeight<0)throw new G("invallid FirstMessageDeliveriesWeight; must be positive (or 0 to disable)");if(s.firstMessageDeliveriesWeight!==0&&(s.firstMessageDeliveriesDecay<=0||s.firstMessageDeliveriesDecay>=1))throw new G("invalid FirstMessageDeliveriesDecay; must be between 0 and 1");if(s.firstMessageDeliveriesWeight!==0&&s.firstMessageDeliveriesCap<=0)throw new G("invalid FirstMessageDeliveriesCap; must be positive");if(s.meshMessageDeliveriesWeight>0)throw new G("invalid MeshMessageDeliveriesWeight; must be negative (or 0 to disable)");if(s.meshMessageDeliveriesWeight!==0&&(s.meshMessageDeliveriesDecay<=0||s.meshMessageDeliveriesDecay>=1))throw new G("invalid MeshMessageDeliveriesDecay; must be between 0 and 1");if(s.meshMessageDeliveriesWeight!==0&&s.meshMessageDeliveriesCap<=0)throw new G("invalid MeshMessageDeliveriesCap; must be positive");if(s.meshMessageDeliveriesWeight!==0&&s.meshMessageDeliveriesThreshold<=0)throw new G("invalid MeshMessageDeliveriesThreshold; must be positive");if(s.meshMessageDeliveriesWindow<0)throw new G("invalid MeshMessageDeliveriesWindow; must be non-negative");if(s.meshMessageDeliveriesWeight!==0&&s.meshMessageDeliveriesActivation<1e3)throw new G("invalid MeshMessageDeliveriesActivation; must be at least 1s");if(s.meshFailurePenaltyWeight>0)throw new G("invalid MeshFailurePenaltyWeight; must be negative (or 0 to disable)");if(s.meshFailurePenaltyWeight!==0&&(s.meshFailurePenaltyDecay<=0||s.meshFailurePenaltyDecay>=1))throw new G("invalid MeshFailurePenaltyDecay; must be between 0 and 1");if(s.invalidMessageDeliveriesWeight>0)throw new G("invalid InvalidMessageDeliveriesWeight; must be negative (or 0 to disable)");if(s.invalidMessageDeliveriesDecay<=0||s.invalidMessageDeliveriesDecay>=1)throw new G("invalid InvalidMessageDeliveriesDecay; must be between 0 and 1")}var yh={gossipThreshold:-10,publishThreshold:-50,graylistThreshold:-80,acceptPXThreshold:10,opportunisticGraftThreshold:20};function Ya(s={}){return{...yh,...s}}function Sr(s,e,t=()=>!0){let r=new Set;if(e<=0)return r;for(let n of s){if(r.size>=e)break;t(n)&&(r.add(n),s.delete(n))}return r}function Xa(s,e){return Sr(s,e,()=>!0)}var Er=class extends Map{getDefault;constructor(e){super(),this.getDefault=e}getOrDefault(e){let t=super.get(e);return t===void 0&&(t=this.getDefault(),this.set(e,t)),t}};function Ja(s,e,t,r){let n=0;Object.entries(e.topics).forEach(([o,a])=>{let c=t.topics[o];if(c===void 0)return;let h=0;if(a.inMesh){let v=a.meshTime/c.timeInMeshQuantum;v>c.timeInMeshCap&&(v=c.timeInMeshCap),h+=v*c.timeInMeshWeight}let m=a.firstMessageDeliveries;if(m>c.firstMessageDeliveriesCap&&(m=c.firstMessageDeliveriesCap),h+=m*c.firstMessageDeliveriesWeight,a.meshMessageDeliveriesActive&&a.meshMessageDeliveries<c.meshMessageDeliveriesThreshold){let v=c.meshMessageDeliveriesThreshold-a.meshMessageDeliveries,u=v*v;h+=u*c.meshMessageDeliveriesWeight}let d=a.meshFailurePenalty;h+=d*c.meshFailurePenaltyWeight;let E=a.invalidMessageDeliveries*a.invalidMessageDeliveries;h+=E*c.invalidMessageDeliveriesWeight,n+=h*c.topicWeight}),t.topicScoreCap>0&&n>t.topicScoreCap&&(n=t.topicScoreCap);let i=t.appSpecificScore(s);if(n+=i*t.appSpecificWeight,e.knownIPs.forEach(o=>{if(t.IPColocationFactorWhitelist.has(o))return;let a=r.get(o),c=a!=null?a.size:0;if(c>t.IPColocationFactorThreshold){let h=c-t.IPColocationFactorThreshold,m=h*h;n+=m*t.IPColocationFactorWeight}}),e.behaviourPenalty>t.behaviourPenaltyThreshold){let o=e.behaviourPenalty-t.behaviourPenaltyThreshold,a=o*o;n+=a*t.behaviourPenaltyWeight}return n}var tc=Ec(ec(),1);var Se;(function(s){s[s.unknown=0]="unknown",s[s.valid=1]="valid",s[s.invalid=2]="invalid",s[s.ignored=3]="ignored"})(Se||(Se={}));var _r=class{records;queue;constructor(){this.records=new Map,this.queue=new tc.default}getRecord(e){return this.records.get(e)}ensureRecord(e){let t=this.records.get(e);if(t!=null)return t;t={status:Se.unknown,firstSeenTsMs:Date.now(),validated:0,peers:new Set},this.records.set(e,t);let r={msgId:e,expire:Date.now()+12e4};return this.queue.push(r),t}gc(){let e=Date.now(),t=this.queue.peekFront();for(;t!=null&&t.expire<e;)this.records.delete(t.msgId),this.queue.shift(),t=this.queue.peekFront()}clear(){this.records.clear(),this.queue.clear()}};var Ir=class{params;metrics;peerStats=new Map;peerIPs=new Er(()=>new Set);scoreCache=new Map;deliveryRecords=new _r;_backgroundInterval;scoreCacheValidityMs;computeScore;log;constructor(e,t,r,n){this.params=e,this.metrics=t,Za(e),this.scoreCacheValidityMs=n.scoreCacheValidityMs,this.computeScore=n.computeScore??Ja,this.log=r.forComponent("libp2p:gossipsub:score")}get size(){return this.peerStats.size}start(){if(this._backgroundInterval!=null){this.log("Peer score already running");return}this._backgroundInterval=setInterval(()=>{this.background()},this.params.decayInterval),this.log("started")}stop(){if(this._backgroundInterval==null){this.log("Peer score already stopped");return}clearInterval(this._backgroundInterval),delete this._backgroundInterval,this.peerIPs.clear(),this.peerStats.clear(),this.deliveryRecords.clear(),this.log("stopped")}background(){this.refreshScores(),this.deliveryRecords.gc()}dumpPeerScoreStats(){return Object.fromEntries(Array.from(this.peerStats.entries()).map(([e,t])=>[e,t]))}messageFirstSeenTimestampMs(e){let t=this.deliveryRecords.getRecord(e);return t!=null?t.firstSeenTsMs:null}refreshScores(){let e=Date.now(),t=this.params.decayToZero;this.peerStats.forEach((r,n)=>{if(!r.connected){e>r.expire&&(this.removeIPsForPeer(n,r.knownIPs),this.peerStats.delete(n),this.scoreCache.delete(n));return}Object.entries(r.topics).forEach(([i,o])=>{let a=this.params.topics[i];a!==void 0&&(o.firstMessageDeliveries*=a.firstMessageDeliveriesDecay,o.firstMessageDeliveries<t&&(o.firstMessageDeliveries=0),o.meshMessageDeliveries*=a.meshMessageDeliveriesDecay,o.meshMessageDeliveries<t&&(o.meshMessageDeliveries=0),o.meshFailurePenalty*=a.meshFailurePenaltyDecay,o.meshFailurePenalty<t&&(o.meshFailurePenalty=0),o.invalidMessageDeliveries*=a.invalidMessageDeliveriesDecay,o.invalidMessageDeliveries<t&&(o.invalidMessageDeliveries=0),o.inMesh&&(o.meshTime=e-o.graftTime,o.meshTime>a.meshMessageDeliveriesActivation&&(o.meshMessageDeliveriesActive=!0)))}),r.behaviourPenalty*=this.params.behaviourPenaltyDecay,r.behaviourPenalty<t&&(r.behaviourPenalty=0)})}score(e){this.metrics?.scoreFnCalls.inc();let t=this.peerStats.get(e);if(t==null)return 0;let r=Date.now(),n=this.scoreCache.get(e);if(n!=null&&n.cacheUntil>r)return n.score;this.metrics?.scoreFnRuns.inc();let i=this.computeScore(e,t,this.params,this.peerIPs),o=r+this.scoreCacheValidityMs;return n!=null?(this.metrics?.scoreCachedDelta.observe(Math.abs(i-n.score)),n.score=i,n.cacheUntil=o):this.scoreCache.set(e,{score:i,cacheUntil:o}),i}addPenalty(e,t,r){let n=this.peerStats.get(e);n!=null&&(n.behaviourPenalty+=t,this.metrics?.onScorePenalty(r))}addPeer(e){let t={connected:!0,expire:0,topics:{},knownIPs:new Set,behaviourPenalty:0};this.peerStats.set(e,t)}addIP(e,t){let r=this.peerStats.get(e);r?.knownIPs.add(t),this.peerIPs.getOrDefault(t).add(e)}removeIP(e,t){let r=this.peerStats.get(e);r?.knownIPs.delete(t);let n=this.peerIPs.get(t);n!=null&&(n.delete(e),n.size===0&&this.peerIPs.delete(t))}removePeer(e){let t=this.peerStats.get(e);if(t!=null){if(this.score(e)>0){this.removeIPsForPeer(e,t.knownIPs),this.peerStats.delete(e);return}Object.entries(t.topics).forEach(([r,n])=>{n.firstMessageDeliveries=0;let i=this.params.topics[r].meshMessageDeliveriesThreshold;if(n.inMesh&&n.meshMessageDeliveriesActive&&n.meshMessageDeliveries<i){let o=i-n.meshMessageDeliveries;n.meshFailurePenalty+=o*o}n.inMesh=!1,n.meshMessageDeliveriesActive=!1}),t.connected=!1,t.expire=Date.now()+this.params.retainScore}}graft(e,t){let r=this.peerStats.get(e);if(r!=null){let n=this.getPtopicStats(r,t);n!=null&&(n.inMesh=!0,n.graftTime=Date.now(),n.meshTime=0,n.meshMessageDeliveriesActive=!1)}}prune(e,t){let r=this.peerStats.get(e);if(r!=null){let n=this.getPtopicStats(r,t);if(n!=null){let i=this.params.topics[t].meshMessageDeliveriesThreshold;if(n.meshMessageDeliveriesActive&&n.meshMessageDeliveries<i){let o=i-n.meshMessageDeliveries;n.meshFailurePenalty+=o*o}n.meshMessageDeliveriesActive=!1,n.inMesh=!1}}}validateMessage(e){this.deliveryRecords.ensureRecord(e)}deliverMessage(e,t,r){this.markFirstMessageDelivery(e,r);let n=this.deliveryRecords.ensureRecord(t),i=Date.now();if(n.status!==Se.unknown){this.log("unexpected delivery: message from %s was first seen %s ago and has delivery status %s",e,i-n.firstSeenTsMs,Se[n.status]);return}n.status=Se.valid,n.validated=i,n.peers.forEach(o=>{o!==e.toString()&&this.markDuplicateMessageDelivery(o,r)})}rejectInvalidMessage(e,t){this.markInvalidMessageDelivery(e,t)}rejectMessage(e,t,r,n){switch(n){case ve.Error:this.markInvalidMessageDelivery(e,r);return;case ve.Blacklisted:return}let i=this.deliveryRecords.ensureRecord(t);if(i.status!==Se.unknown){this.log("unexpected rejection: message from %s was first seen %s ago and has delivery status %d",e,Date.now()-i.firstSeenTsMs,Se[i.status]);return}if(n===ve.Ignore){i.status=Se.ignored,i.peers.clear();return}i.status=Se.invalid,this.markInvalidMessageDelivery(e,r),i.peers.forEach(o=>{this.markInvalidMessageDelivery(o,r)}),i.peers.clear()}duplicateMessage(e,t,r){let n=this.deliveryRecords.ensureRecord(t);if(!n.peers.has(e))switch(n.status){case Se.unknown:n.peers.add(e);break;case Se.valid:n.peers.add(e),this.markDuplicateMessageDelivery(e,r,n.validated);break;case Se.invalid:this.markInvalidMessageDelivery(e,r);break;case Se.ignored:break}}markInvalidMessageDelivery(e,t){let r=this.peerStats.get(e);if(r!=null){let n=this.getPtopicStats(r,t);n!=null&&(n.invalidMessageDeliveries+=1)}}markFirstMessageDelivery(e,t){let r=this.peerStats.get(e);if(r!=null){let n=this.getPtopicStats(r,t);if(n!=null){let i=this.params.topics[t].firstMessageDeliveriesCap;n.firstMessageDeliveries=Math.min(i,n.firstMessageDeliveries+1),n.inMesh&&(i=this.params.topics[t].meshMessageDeliveriesCap,n.meshMessageDeliveries=Math.min(i,n.meshMessageDeliveries+1))}}}markDuplicateMessageDelivery(e,t,r){let n=this.peerStats.get(e);if(n!=null){let i=r!==void 0?Date.now():0,o=this.getPtopicStats(n,t);if(o!=null&&o.inMesh){let a=this.params.topics[t];if(r!==void 0){let h=i-r,m=h>a.meshMessageDeliveriesWindow;if(this.metrics?.onDuplicateMsgDelivery(t,h,m),m)return}let c=a.meshMessageDeliveriesCap;o.meshMessageDeliveries=Math.min(c,o.meshMessageDeliveries+1)}}}removeIPsForPeer(e,t){for(let r of t){let n=this.peerIPs.get(r);n!=null&&(n.delete(e),n.size===0&&this.peerIPs.delete(r))}}getPtopicStats(e,t){let r=e.topics[t];return r!==void 0?r:this.params.topics[t]!==void 0?(r={inMesh:!1,graftTime:0,meshTime:0,firstMessageDeliveries:0,meshMessageDeliveries:0,meshMessageDeliveriesActive:!1,meshFailurePenalty:0,invalidMessageDeliveries:0},e.topics[t]=r,r):null}};function wh(s,e,t,r,n){let i=0,o=new Map;if(Object.entries(e.topics).forEach(([E,v])=>{let u=n.get(E)??"unknown",g=t.topics[E];if(g===void 0)return;let w=o.get(u);w==null&&(w={p1w:0,p2w:0,p3w:0,p3bw:0,p4w:0},o.set(u,w));let y=0,I=0,l=0,f=0,p=0;if(v.inMesh){let _=Math.max(v.meshTime/g.timeInMeshQuantum,g.timeInMeshCap);y+=_*g.timeInMeshWeight}let b=v.firstMessageDeliveries;if(b>g.firstMessageDeliveriesCap&&(b=g.firstMessageDeliveriesCap),I+=b*g.firstMessageDeliveriesWeight,v.meshMessageDeliveriesActive&&v.meshMessageDeliveries<g.meshMessageDeliveriesThreshold){let _=g.meshMessageDeliveriesThreshold-v.meshMessageDeliveries,P=_*_;l+=P*g.meshMessageDeliveriesWeight}let S=v.meshFailurePenalty;f+=S*g.meshFailurePenaltyWeight;let x=v.invalidMessageDeliveries*v.invalidMessageDeliveries;p+=x*g.invalidMessageDeliveriesWeight,i+=(y+I+l+f+p)*g.topicWeight,w.p1w+=y,w.p2w+=I,w.p3w+=l,w.p3bw+=f,w.p4w+=p}),t.topicScoreCap>0&&i>t.topicScoreCap){i=t.topicScoreCap;let E=t.topicScoreCap/i;for(let v of o.values())v.p1w*=E,v.p2w*=E,v.p3w*=E,v.p3bw*=E,v.p4w*=E}let a=0,c=0,h=0,m=t.appSpecificScore(s);a+=m*t.appSpecificWeight,e.knownIPs.forEach(E=>{if(t.IPColocationFactorWhitelist.has(E))return;let v=r.get(E),u=v!=null?v.size:0;if(u>t.IPColocationFactorThreshold){let g=u-t.IPColocationFactorThreshold,w=g*g;c+=w*t.IPColocationFactorWeight}});let d=e.behaviourPenalty*e.behaviourPenalty;return h+=d*t.behaviourPenaltyWeight,i+=a+c+h,{byTopic:o,p5w:a,p6w:c,p7w:h,score:i}}function sc(s,e,t,r,n){let i={byTopic:new Map,p5w:[],p6w:[],p7w:[],score:[]};for(let o of s){let a=e.get(o);if(a!=null){let c=wh(o,a,t,r,n);for(let[h,m]of c.byTopic){let d=i.byTopic.get(h);d==null&&(d={p1w:[],p2w:[],p3w:[],p3bw:[],p4w:[]},i.byTopic.set(h,d)),d.p1w.push(m.p1w),d.p2w.push(m.p2w),d.p3w.push(m.p3w),d.p3bw.push(m.p3bw),d.p4w.push(m.p4w)}i.p5w.push(c.p5w),i.p6w.push(c.p6w),i.p7w.push(c.p7w),i.score.push(c.score)}else i.p5w.push(0),i.p6w.push(0),i.p7w.push(0),i.score.push(0)}return i}function Tr(s){let e=s.getComponents(),t={},r=0;if(e[r]?.name==="ip6zone"&&(t.zone=`${e[r].value}`,r++),e[r].name==="ip4"||e[r].name==="ip6"||e[r].name==="dns"||e[r].name==="dns4"||e[r].name==="dns6"?(t.type=e[r].name,t.host=e[r].value,r++):e[r].name==="dnsaddr"&&(t.type=e[r].name,t.host=`_dnsaddr.${e[r].value}`,r++),(e[r]?.name==="tcp"||e[r]?.name==="udp")&&(t.protocol=e[r].name==="tcp"?"tcp":"udp",t.port=parseInt(`${e[r].value}`),r++),e[r]?.name==="ipcidr"&&(t.type==="ip4"?t.cidr=parseInt(`${e[r].value}`):t.type==="ip6"&&(t.cidr=`${e[r].value}`),r++),t.type==null||t.host==null)throw new $(`Multiaddr ${s} was not an IPv4, IPv6, DNS, DNS4, DNS6 or DNSADDR address`);return e[r]?.name==="tls"&&e[r+1]?.name==="sni"&&(t.sni=e[r+1].value,r+=2),t}function rc(s){try{return Tr(s),!0}catch{return!1}}var Di=class s extends Error{name="TimeoutError";constructor(e,t){super(e,t),Error.captureStackTrace?.(this,s)}},nc=s=>s.reason??new DOMException("This operation was aborted.","AbortError");function Mi(s,e){let{milliseconds:t,fallback:r,message:n,customTimers:i={setTimeout,clearTimeout},signal:o}=e,a,c,m=new Promise((d,E)=>{if(typeof t!="number"||Math.sign(t)!==1)throw new TypeError(`Expected \`milliseconds\` to be a positive number, got \`${t}\``);if(o?.aborted){E(nc(o));return}if(o&&(c=()=>{E(nc(o))},o.addEventListener("abort",c,{once:!0})),s.then(d,E),t===Number.POSITIVE_INFINITY)return;let v=new Di;a=i.setTimeout.call(void 0,()=>{if(r){try{d(r())}catch(u){E(u)}return}typeof s.cancel=="function"&&s.cancel(),n===!1?d():n instanceof Error?E(n):(v.message=n??`Promise timed out after ${t} milliseconds`,E(v))},t)}).finally(()=>{m.clear(),c&&o&&o.removeEventListener("abort",c)});return m.clear=()=>{i.clearTimeout.call(void 0,a),a=void 0},m}var xh=s=>{let e=s.addEventListener||s.on||s.addListener,t=s.removeEventListener||s.off||s.removeListener;if(!e||!t)throw new TypeError("Emitter is not compatible");return{addListener:e.bind(s),removeListener:t.bind(s)}};function vh(s,e,t){let r,n=new Promise((i,o)=>{if(t={rejectionEvents:["error"],multiArgs:!1,rejectionMultiArgs:!1,resolveImmediately:!1,...t},!(t.count>=0&&(t.count===Number.POSITIVE_INFINITY||Number.isInteger(t.count))))throw new TypeError("The `count` option should be at least 0 or more");t.signal?.throwIfAborted();let a=[e].flat(),c=[],{addListener:h,removeListener:m}=xh(s),d=async(...v)=>{let u=t.multiArgs?v:v[0];if(t.filter)try{if(!await t.filter(u))return}catch(g){r(),o(g);return}c.push(u),t.count===c.length&&(r(),i(c))},E=(...v)=>{r(),o(t.rejectionMultiArgs?v:v[0])};r=()=>{for(let v of a)m(v,d);for(let v of t.rejectionEvents)a.includes(v)||m(v,E)};for(let v of a)h(v,d);for(let v of t.rejectionEvents)a.includes(v)||h(v,E);t.signal&&t.signal.addEventListener("abort",()=>{E(t.signal.reason)},{once:!0}),t.resolveImmediately&&i(c)});if(n.cancel=r,typeof t.timeout=="number"){let i=Mi(n,{milliseconds:t.timeout});return i.cancel=()=>{r(),i.clear()},i}return n}function ic(s,e,t){typeof t=="function"&&(t={filter:t}),t={...t,count:1,resolveImmediately:!1};let r=vh(s,e,t),n=r.then(i=>i[0]);return n.cancel=r.cancel,n}function Eh(s){return s?.addEventListener!=null}function Sh(s){let e=kt(),t,r=o=>{e.push(o.data)},n=()=>{e.end(),s.removeEventListener("message",r),s.removeEventListener("close",i),s.removeEventListener("remoteCloseWrite",n)},i=o=>{e.end(o.error),o.error!=null&&t?.reject(o.error),s.removeEventListener("message",r),s.removeEventListener("close",i),s.removeEventListener("remoteCloseWrite",n)};return s.addEventListener("message",r),s.addEventListener("close",i,{once:!0}),s.addEventListener("remoteCloseWrite",n,{once:!0}),{source:e,async sink(o){async function*a(){yield*o}let c=a();for(;;){t=Promise.withResolvers();let{done:h,value:m}=await Promise.race([c.next(),t.promise]);if(s.writeStatus==="closing"||s.writeStatus==="closed"||(m!=null&&(s.send(m)||await Promise.race([ic(s,"drain",{rejectionEvents:["close"]})])),h===!0))break}await s.close()}}}function oc(...s){let e=s.map(t=>Eh(t)?Sh(t):t);return Ls(...e)}var Ar=class{rawStream;constructor(e,t,r){this.rawStream=e,r.maxBufferSize!=null&&(e.maxWriteBufferLength=r.maxBufferSize),e.addEventListener("close",n=>{n.error!=null&&t(n.error)})}get protocol(){return this.rawStream.protocol}async push(e){return this.pushPrefixed(es.single(e))}pushPrefixed(e){this.rawStream.send(e)}async close(e){await this.rawStream.close(e).catch(t=>{this.rawStream.abort(t)})}},Dr=class{source;rawStream;closeController;constructor(e,t={}){this.rawStream=e,this.closeController=new AbortController,this.closeController.signal.addEventListener("abort",()=>{e.close().catch(r=>{e.abort(r)})}),this.source=oc(this.rawStream,r=>ks(r,t))}async close(){this.closeController.abort()}};var Mr=class{gossipsubIWantFollowupMs;msgIdToStrFn;metrics;promises=new Map;requestMsByMsg=new Map;requestMsByMsgExpire;constructor(e,t,r){this.gossipsubIWantFollowupMs=e,this.msgIdToStrFn=t,this.metrics=r,this.requestMsByMsgExpire=10*e}get size(){return this.promises.size}get requestMsByMsgSize(){return this.requestMsByMsg.size}addPromise(e,t){let r=Math.floor(Math.random()*t.length),n=t[r],i=this.msgIdToStrFn(n),o=this.promises.get(i);o==null&&(o=new Map,this.promises.set(i,o));let a=Date.now();o.has(e)||(o.set(e,a+this.gossipsubIWantFollowupMs),this.metrics!=null&&(this.metrics.iwantPromiseStarted.inc(1),this.requestMsByMsg.has(i)||this.requestMsByMsg.set(i,a)))}getBrokenPromises(){let e=Date.now(),t=new Map,r=0;return this.promises.forEach((n,i)=>{n.forEach((o,a)=>{o<e&&(t.set(a,(t.get(a)??0)+1),n.delete(a),r++)}),n.size===0&&this.promises.delete(i)}),this.metrics?.iwantPromiseBroken.inc(r),t}deliverMessage(e,t=!1){this.trackMessage(e);let r=this.promises.get(e);r!=null&&(this.promises.delete(e),this.metrics!=null&&(this.metrics.iwantPromiseResolved.inc(1),t&&this.metrics.iwantPromiseResolvedFromDuplicate.inc(1),this.metrics.iwantPromiseResolvedPeers.inc(r.size)))}rejectMessage(e,t){this.trackMessage(e),t!==ve.Error&&this.promises.delete(e)}clear(){this.promises.clear()}prune(){let e=Date.now()-this.requestMsByMsgExpire,t=0;for(let[r,n]of this.requestMsByMsg.entries())if(n<e)this.requestMsByMsg.delete(r),t++;else break;this.metrics?.iwantMessagePruned.inc(t)}trackMessage(e){if(this.metrics!=null){let t=this.requestMsByMsg.get(e);t!==void 0&&(this.metrics.iwantPromiseDeliveryTime.observe((Date.now()-t)/1e3),this.requestMsByMsg.delete(e))}}};var ac=q("libp2p-pubsub:");async function cc(s,e,t,r){switch(s.type){case gt.Signing:{let n={from:s.author.toMultihash().bytes,data:r,seqno:ir(8),topic:e,signature:void 0,key:void 0},i=yt([ac,nt.Message.encode(n)]);n.signature=await s.privateKey.sign(i),n.key=s.key;let o={type:"signed",from:s.author,data:t,sequenceNumber:BigInt(`0x${V(n.seqno??new Uint8Array(0),"base16")}`),topic:e,signature:n.signature,key:hr(n.key)};return{raw:n,msg:o}}case gt.Anonymous:return{raw:{from:void 0,data:r,seqno:void 0,topic:e,signature:void 0,key:void 0},msg:{type:"unsigned",data:t,topic:e}};default:throw new Error("Unreachable")}}async function lc(s,e){switch(s){case Lt:return e.signature!=null?{valid:!1,error:de.SignaturePresent}:e.seqno!=null?{valid:!1,error:de.SeqnoPresent}:e.key!=null?{valid:!1,error:de.FromPresent}:{valid:!0,message:{type:"unsigned",topic:e.topic,data:e.data??new Uint8Array(0)}};case bt:{if(e.seqno==null)return{valid:!1,error:de.InvalidSeqno};if(e.seqno.length!==8)return{valid:!1,error:de.InvalidSeqno};if(e.signature==null)return{valid:!1,error:de.InvalidSignature};if(e.from==null)return{valid:!1,error:de.InvalidPeerId};let t;try{t=Jt(We(e.from))}catch{return{valid:!1,error:de.InvalidPeerId}}let r;if(e.key!=null){if(r=hr(e.key),t.publicKey!==void 0&&!r.equals(t.publicKey))return{valid:!1,error:de.InvalidPeerId}}else{if(t.publicKey==null)return{valid:!1,error:de.InvalidPeerId};r=t.publicKey}let n={from:e.from,data:e.data,seqno:e.seqno,topic:e.topic,signature:void 0,key:void 0},i=yt([ac,nt.Message.encode(n)]);return await r.verify(i,e.signature)?{valid:!0,message:{type:"signed",from:t,data:e.data??new Uint8Array(0),sequenceNumber:BigInt(`0x${V(e.seqno,"base16")}`),topic:e.topic,signature:e.signature,key:e.key!=null?hr(e.key):r}}:{valid:!1,error:de.InvalidSignature}}default:throw new Error("Unreachable")}}function Oe(s=[],e){return{subscriptions:[],messages:s,control:e!==void 0?{graft:e.graft??[],prune:e.prune??[],ihave:e.ihave??[],iwant:e.iwant??[],idontwant:e.idontwant??[]}:void 0}}function Pi(s){return s.control===void 0&&(s.control={graft:[],prune:[],ihave:[],iwant:[],idontwant:[]}),s}function qe(s){if(s.length<=1)return s;let e=()=>Math.floor(Math.random()*Math.floor(s.length));for(let t=0;t<s.length;t++){let r=e(),n=s[t];s[t]=s[r],s[r]=n}return s}function uc(s){return V(s,"base64")}function hc(s,e,t){switch(s){case bt:return{type:gt.Signing,author:e,key:Fe(t.publicKey),privateKey:t};case Lt:return{type:gt.Anonymous};default:throw new Error(`Unknown signature policy "${s}"`)}}var _h=(s,e)=>{let t=q(e.toString(16).padStart(16,"0"),"base16"),r=Fe(s),n=new Uint8Array(r.byteLength+t.length);return n.set(r,0),n.set(t,r.byteLength),n};function fc(s){if(s.type!=="signed")throw new Error("expected signed message type");if(s.sequenceNumber==null)throw Error("missing seqno field");return _h(s.from.publicKey??s.key,s.sequenceNumber)}async function dc(s){return wt.encode(s.data)}function pc(s){if(rc(s)){let e=Tr(s);switch(e.type){case"ip4":case"ip6":return e.host;default:break}}return null}var is=class{entries=new Map;validityMs;constructor(e){this.validityMs=e.validityMs}get size(){return this.entries.size}put(e,t){return this.entries.has(e)?!0:(this.entries.set(e,{value:t,validUntilMs:Date.now()+this.validityMs}),!1)}prune(){let e=Date.now();for(let[t,r]of this.entries.entries())if(r.validUntilMs<e)this.entries.delete(t);else break}has(e){return this.entries.has(e)}get(e){let t=this.entries.get(e);return t!=null&&t.validUntilMs>=Date.now()?t.value:void 0}clear(){this.entries.clear()}};var Me;(function(s){s[s.started=0]="started",s[s.stopped=1]="stopped"})(Me||(Me={}));var Pr=class extends Os{globalSignaturePolicy;protocols=[Bt,Ri,Lr];publishConfig;dataTransform;peers=new Map;streamsInbound=new Map;streamsOutbound=new Map;outboundInflightQueue=kt({objectMode:!0});direct=new Set;floodsubPeers=new Set;seenCache;acceptFromWhitelist=new Map;topics=new Map;subscriptions=new Set;mesh=new Map;fanout=new Map;fanoutLastpub=new Map;gossip=new Map;control=new Map;peerhave=new Map;iasked=new Map;backoff=new Map;outbound=new Map;msgIdFn;fastMsgIdFn;msgIdToStrFn;fastMsgIdCache;publishedMessageIds;mcache;score;topicValidators=new Map;log;heartbeatTicks=0;gossipTracer;idontwantCounts=new Map;idontwants=new Map;components;directPeerInitial=null;static multicodec=Bt;opts;decodeRpcLimits;metrics;status={code:Me.stopped};maxInboundStreams;maxOutboundStreams;runOnLimitedConnection;allowedTopics;heartbeatTimer=null;constructor(e,t={}){super();let r={fallbackToFloodsub:!0,floodPublish:!0,batchPublish:!1,tagMeshPeers:!0,doPX:!1,directPeers:[],D:6,Dlo:4,Dhi:12,Dscore:4,Dout:2,Dlazy:6,heartbeatInterval:1e3,fanoutTTL:6e4,mcacheLength:5,mcacheGossip:3,seenTTL:12e4,gossipsubIWantFollowupMs:3e3,prunePeers:16,pruneBackoff:6e4,unsubcribeBackoff:1e4,graftFloodThreshold:1e4,opportunisticGraftPeers:2,opportunisticGraftTicks:60,directConnectTicks:300,gossipFactor:.25,idontwantMinDataSize:512,idontwantMaxMessages:512,...t,scoreParams:ja(t.scoreParams),scoreThresholds:Ya(t.scoreThresholds)};if(this.components=e,this.decodeRpcLimits=r.decodeRpcLimits??qa,this.globalSignaturePolicy=r.globalSignaturePolicy??bt,r.fallbackToFloodsub&&this.protocols.push(kr),this.log=e.logger.forComponent(r.debugName??"libp2p:gossipsub"),this.opts=r,this.direct=new Set(r.directPeers.map(n=>n.id.toString())),this.seenCache=new is({validityMs:r.seenTTL}),this.publishedMessageIds=new is({validityMs:r.seenTTL}),t.msgIdFn!=null)this.msgIdFn=t.msgIdFn;else switch(this.globalSignaturePolicy){case bt:this.msgIdFn=fc;break;case Lt:this.msgIdFn=dc;break;default:throw new Error(`Invalid globalSignaturePolicy: ${this.globalSignaturePolicy}`)}if(t.fastMsgIdFn!=null&&(this.fastMsgIdFn=t.fastMsgIdFn,this.fastMsgIdCache=new is({validityMs:r.seenTTL})),this.msgIdToStrFn=t.msgIdToStrFn??uc,this.mcache=t.messageCache??new vr(r.mcacheGossip,r.mcacheLength,this.msgIdToStrFn),t.dataTransform!=null&&(this.dataTransform=t.dataTransform),t.metricsRegister!=null){if(t.metricsTopicStrToLabel==null)throw Error("Must set metricsTopicStrToLabel with metrics");let n=Math.max(...Object.values(r.scoreParams.topics).map(o=>o.meshMessageDeliveriesWindow),1e3),i=$a(t.metricsRegister,t.metricsTopicStrToLabel,{gossipPromiseExpireSec:this.opts.gossipsubIWantFollowupMs/1e3,behaviourPenaltyThreshold:r.scoreParams.behaviourPenaltyThreshold,maxMeshMessageDeliveriesWindowSec:n/1e3});i.mcacheSize.addCollect(()=>{this.onScrapeMetrics(i)});for(let o of this.protocols)i.protocolsEnabled.set({protocol:o},1);this.metrics=i}else this.metrics=null;this.gossipTracer=new Mr(this.opts.gossipsubIWantFollowupMs,this.msgIdToStrFn,this.metrics),this.score=new Ir(this.opts.scoreParams,this.metrics,this.components.logger,{scoreCacheValidityMs:r.heartbeatInterval}),this.maxInboundStreams=t.maxInboundStreams,this.maxOutboundStreams=t.maxOutboundStreams,this.runOnLimitedConnection=t.runOnLimitedConnection,this.allowedTopics=r.allowedTopics!=null?new Set(r.allowedTopics):null}[Symbol.toStringTag]="@chainsafe/libp2p-gossipsub";[Ui]=["@libp2p/pubsub"];[Ki]=["@libp2p/identify"];getPeers(){return[...this.peers.values()]}isStarted(){return this.status.code===Me.started}async start(){if(this.isStarted())return;this.log("starting"),this.publishConfig=hc(this.globalSignaturePolicy,this.components.peerId,this.components.privateKey),this.outboundInflightQueue=kt({objectMode:!0}),Ls(this.outboundInflightQueue,async i=>{for await(let{peerId:o,connection:a}of i)await this.createOutboundStream(o,a)}).catch(i=>{this.log.error("outbound inflight queue error",i)}),await Promise.all(this.opts.directPeers.map(async i=>{await this.components.peerStore.merge(i.id,{multiaddrs:i.addrs})}));let e=this.components.registrar;await Promise.all(this.protocols.map(async i=>e.handle(i,this.onIncomingStream.bind(this),{maxInboundStreams:this.maxInboundStreams,maxOutboundStreams:this.maxOutboundStreams,runOnLimitedConnection:this.runOnLimitedConnection})));let t={onConnect:this.onPeerConnected.bind(this),onDisconnect:this.onPeerDisconnected.bind(this),notifyOnLimitedConnection:this.runOnLimitedConnection},r=await Promise.all(this.protocols.map(async i=>e.register(i,t))),n=setTimeout(this.runHeartbeat,100);this.status={code:Me.started,registrarTopologyIds:r,heartbeatTimeout:n,hearbeatStartMs:Date.now()+100},this.score.start(),this.directPeerInitial=setTimeout(()=>{Promise.resolve().then(async()=>{await Promise.all(Array.from(this.direct).map(async i=>this.connect(i)))}).catch(i=>{this.log(i)})},1e3),this.opts.tagMeshPeers&&(this.addEventListener("gossipsub:graft",this.tagMeshPeer),this.addEventListener("gossipsub:prune",this.untagMeshPeer)),this.log("started")}async stop(){if(this.log("stopping"),this.status.code!==Me.started)return;let{registrarTopologyIds:e}=this.status;this.status={code:Me.stopped},this.opts.tagMeshPeers&&(this.removeEventListener("gossipsub:graft",this.tagMeshPeer),this.removeEventListener("gossipsub:prune",this.untagMeshPeer));let t=this.components.registrar;await Promise.all(this.protocols.map(async n=>t.unhandle(n))),e.forEach(n=>{t.unregister(n)}),this.outboundInflightQueue.end();let r=[];for(let n of this.streamsOutbound.values())r.push(n.close());this.streamsOutbound.clear();for(let n of this.streamsInbound.values())r.push(n.close());this.streamsInbound.clear(),await Promise.all(r),this.peers.clear(),this.subscriptions.clear(),this.heartbeatTimer!=null&&(this.heartbeatTimer.cancel(),this.heartbeatTimer=null),this.score.stop(),this.mesh.clear(),this.fanout.clear(),this.fanoutLastpub.clear(),this.gossip.clear(),this.control.clear(),this.peerhave.clear(),this.iasked.clear(),this.backoff.clear(),this.outbound.clear(),this.gossipTracer.clear(),this.seenCache.clear(),this.fastMsgIdCache!=null&&this.fastMsgIdCache.clear(),this.directPeerInitial!=null&&clearTimeout(this.directPeerInitial),this.idontwantCounts.clear(),this.idontwants.clear(),this.log("stopped")}dumpPeerScoreStats(){return this.score.dumpPeerScoreStats()}onIncomingStream(e,t){if(!this.isStarted())return;let r=t.remotePeer;this.addPeer(r,t.direction,t.remoteAddr),this.createInboundStream(r,e),this.outboundInflightQueue.push({peerId:r,connection:t})}onPeerConnected(e,t){this.metrics?.newConnectionCount.inc({status:t.status}),!(!this.isStarted()||t.status!=="open")&&(this.addPeer(e,t.direction,t.remoteAddr),this.outboundInflightQueue.push({peerId:e,connection:t}))}onPeerDisconnected(e){this.log("connection ended %p",e),this.removePeer(e)}async createOutboundStream(e,t){if(!this.isStarted())return;let r=e.toString();if(this.peers.has(r)&&!this.streamsOutbound.has(r))try{let n=new Ar(await t.newStream(this.protocols,{runOnLimitedConnection:this.runOnLimitedConnection}),o=>{this.log.error("outbound pipe error",o)},{maxBufferSize:this.opts.maxOutboundBufferSize});this.log("create outbound stream %p",e),this.streamsOutbound.set(r,n);let i=n.protocol;i===kr&&this.floodsubPeers.add(r),this.metrics?.peersPerProtocol.inc({protocol:i},1),this.subscriptions.size>0&&(this.log("send subscriptions to",r),this.sendSubscriptions(r,Array.from(this.subscriptions),!0))}catch(n){this.log.error("createOutboundStream error",n)}}createInboundStream(e,t){if(!this.isStarted())return;let r=e.toString();if(!this.peers.has(r))return;let n=this.streamsInbound.get(r);n!==void 0&&(this.log("replacing existing inbound steam %s",r),n.close().catch(o=>{this.log.error(o)})),this.log("create inbound stream %s",r);let i=new Dr(t,{maxDataLength:this.opts.maxInboundDataLength});this.streamsInbound.set(r,i),this.pipePeerReadStream(e,i.source).catch(o=>{this.log(o)})}addPeer(e,t,r){let n=e.toString();if(!this.peers.has(n)){this.peers.set(n,e),this.score.addPeer(n);let i=pc(r);i!==null?this.score.addIP(n,i):this.log("Added peer has no IP in current address %s %s",n,r.toString()),this.outbound.has(n)||this.outbound.set(n,t==="outbound")}}removePeer(e){let t=e.toString();if(!this.peers.has(t))return;this.log("delete peer %p",e),this.peers.delete(t);let r=this.streamsOutbound.get(t),n=this.streamsInbound.get(t);r!=null&&this.metrics?.peersPerProtocol.inc({protocol:r.protocol},-1),r?.close().catch(i=>{this.log.error(i)}),n?.close().catch(i=>{this.log.error(i)}),this.streamsOutbound.delete(t),this.streamsInbound.delete(t);for(let i of this.topics.values())i.delete(t);for(let[i,o]of this.mesh)o.delete(t)&&this.metrics?.onRemoveFromMesh(i,Ne.Dc,1);for(let i of this.fanout.values())i.delete(t);this.floodsubPeers.delete(t),this.gossip.delete(t),this.control.delete(t),this.outbound.delete(t),this.idontwantCounts.delete(t),this.idontwants.delete(t),this.score.removePeer(t),this.acceptFromWhitelist.delete(t)}get started(){return this.status.code===Me.started}getMeshPeers(e){let t=this.mesh.get(e);return t!=null?Array.from(t):[]}getSubscribers(e){let t=this.topics.get(e);return(t!=null?Array.from(t):[]).map(r=>this.peers.get(r)??Mt(r))}getTopics(){return Array.from(this.subscriptions)}async pipePeerReadStream(e,t){try{await Ls(t,async r=>{for await(let n of r)try{let i=n.subarray(),o=nt.decode(i,{limits:{subscriptions:this.decodeRpcLimits.maxSubscriptions,messages:this.decodeRpcLimits.maxMessages,control$:{ihave:this.decodeRpcLimits.maxIhaveMessageIDs,iwant:this.decodeRpcLimits.maxIwantMessageIDs,graft:this.decodeRpcLimits.maxControlMessages,prune:this.decodeRpcLimits.maxControlMessages,prune$:{peers:this.decodeRpcLimits.maxPeerInfos},idontwant:this.decodeRpcLimits.maxControlMessages,idontwant$:{messageIDs:this.decodeRpcLimits.maxIdontwantMessageIDs}}}});if(this.metrics?.onRpcRecv(o,i.length),this.opts.awaitRpcHandler)try{await this.handleReceivedRpc(e,o)}catch(a){this.metrics?.onRpcRecvError(),this.log(a)}else this.handleReceivedRpc(e,o).catch(a=>{this.metrics?.onRpcRecvError(),this.log(a)})}catch(i){this.metrics?.onRpcDataError(),this.log(i)}})}catch(r){this.metrics?.onPeerReadStreamError(),this.handlePeerReadStreamError(r,e)}}handlePeerReadStreamError(e,t){this.log.error(e),this.onPeerDisconnected(t)}async handleReceivedRpc(e,t){if(!this.acceptFrom(e.toString())){this.log("received message from unacceptable peer %p",e),this.metrics?.rpcRecvNotAccepted.inc();return}let r=t.subscriptions!=null?t.subscriptions.length:0,n=t.messages!=null?t.messages.length:0,i=0,o=0,a=0,c=0;if(t.control!=null&&(t.control.ihave!=null&&(i=t.control.ihave.length),t.control.iwant!=null&&(o=t.control.iwant.length),t.control.graft!=null&&(a=t.control.graft.length),t.control.prune!=null&&(c=t.control.prune.length)),this.log(`rpc.from ${e.toString()} subscriptions ${r} messages ${n} ihave ${i} iwant ${o} graft ${a} prune ${c}`),t.subscriptions!=null&&t.subscriptions.length>0){let h=[];t.subscriptions.forEach(m=>{let d=m.topic,E=m.subscribe===!0;if(d!=null){if(this.allowedTopics!=null&&!this.allowedTopics.has(d))return;this.handleReceivedSubscription(e,d,E),h.push({topic:d,subscribe:E})}}),this.safeDispatchEvent("subscription-change",{detail:{peerId:e,subscriptions:h}})}for(let h of t.messages){if(this.allowedTopics!=null&&!this.allowedTopics.has(h.topic))continue;let m=this.handleReceivedMessage(e,h).catch(d=>{this.metrics?.onMsgRecvError(h.topic),this.log(d)});this.opts.awaitRpcMessageHandler&&await m}t.control!=null&&await this.handleControlMessage(e.toString(),t.control)}handleReceivedSubscription(e,t,r){this.log("subscription update from %p topic %s",e,t);let n=this.topics.get(t);n==null&&(n=new Set,this.topics.set(t,n)),r?n.add(e.toString()):n.delete(e.toString())}async handleReceivedMessage(e,t){this.metrics?.onMsgRecvPreValidation(t.topic);let r=await this.validateReceivedMessage(e,t);this.metrics?.onPrevalidationResult(t.topic,r.code);let n=r.code;switch(n){case pe.duplicate:this.score.duplicateMessage(e.toString(),r.msgIdStr,t.topic),this.gossipTracer.deliverMessage(r.msgIdStr,!0),this.mcache.observeDuplicate(r.msgIdStr,e.toString());return;case pe.invalid:if(r.msgIdStr!=null){let i=r.msgIdStr;this.score.rejectMessage(e.toString(),i,t.topic,r.reason),this.gossipTracer.rejectMessage(i,r.reason)}else this.score.rejectInvalidMessage(e.toString(),t.topic);this.metrics?.onMsgRecvInvalid(t.topic,r);return;case pe.valid:this.score.validateMessage(r.messageId.msgIdStr),this.gossipTracer.deliverMessage(r.messageId.msgIdStr),this.mcache.put(r.messageId,t,!this.opts.asyncValidation),this.subscriptions.has(t.topic)&&(!this.components.peerId.equals(e)||this.opts.emitSelf)&&(super.dispatchEvent(new CustomEvent("gossipsub:message",{detail:{propagationSource:e,msgId:r.messageId.msgIdStr,msg:r.msg}})),super.dispatchEvent(new CustomEvent("message",{detail:r.msg}))),this.opts.asyncValidation||this.forwardMessage(r.messageId.msgIdStr,t,e.toString());break;default:throw new Error(`Invalid validation result: ${n}`)}}async validateReceivedMessage(e,t){let r=this.fastMsgIdFn?.(t),n=r!==void 0?this.fastMsgIdCache?.get(r):void 0;if(n!=null)return{code:pe.duplicate,msgIdStr:n};let i=await lc(this.globalSignaturePolicy,t);if(!i.valid)return{code:pe.invalid,reason:ve.Error,error:i.error};let o=i.message;try{this.dataTransform!=null&&(o.data=this.dataTransform.inboundTransform(t.topic,o.data))}catch(d){return this.log("Invalid message, transform failed",d),{code:pe.invalid,reason:ve.Error,error:de.TransformFailed}}let a=await this.msgIdFn(o),c=this.msgIdToStrFn(a),h={msgId:a,msgIdStr:c};if(r!==void 0&&this.fastMsgIdCache!=null&&this.fastMsgIdCache.put(r,c)&&this.metrics?.fastMsgIdCacheCollision.inc(),this.seenCache.has(c))return{code:pe.duplicate,msgIdStr:c};this.seenCache.put(c),(t.data?.length??0)>=this.opts.idontwantMinDataSize&&this.sendIDontWants(a,t.topic,e.toString());let m=this.topicValidators.get(t.topic);if(m!=null){let d;try{d=await m(e,o)}catch(E){let v=E.code;v===Ni&&(d=me.Ignore),v===Ci?d=me.Reject:d=me.Ignore}if(d!==me.Accept)return{code:pe.invalid,reason:Ai(d),msgIdStr:c}}return{code:pe.valid,messageId:h,msg:o}}getScore(e){return this.score.score(e)}sendSubscriptions(e,t,r){this.sendRpc(e,{subscriptions:t.map(n=>({topic:n,subscribe:r})),messages:[]})}async handleControlMessage(e,t){if(t===void 0)return;let r=t.ihave?.length>0?this.handleIHave(e,t.ihave):[],n=t.iwant?.length>0?this.handleIWant(e,t.iwant):[],i=t.graft?.length>0?await this.handleGraft(e,t.graft):[];if(t.prune?.length>0&&await this.handlePrune(e,t.prune),t.idontwant?.length>0&&this.handleIdontwant(e,t.idontwant),r.length===0&&n.length===0&&i.length===0)return;let o=this.sendRpc(e,Oe(n,{iwant:r,prune:i})),a=r[0]?.messageIDs;a!=null&&(o?this.gossipTracer.addPromise(e,a):this.metrics?.iwantPromiseUntracked.inc(1))}acceptFrom(e){if(this.direct.has(e))return!0;let t=Date.now(),r=this.acceptFromWhitelist.get(e);if(r!=null&&r.messagesAccepted<128&&r.acceptUntil>=t)return r.messagesAccepted+=1,!0;let n=this.score.score(e);return n>=0?this.acceptFromWhitelist.set(e,{messagesAccepted:0,acceptUntil:t+1e3}):this.acceptFromWhitelist.delete(e),n>=this.opts.scoreThresholds.graylistThreshold}handleIHave(e,t){if(t.length===0)return[];let r=this.score.score(e);if(r<this.opts.scoreThresholds.gossipThreshold)return this.log("IHAVE: ignoring peer %s with score below threshold [ score = %d ]",e,r),this.metrics?.ihaveRcvIgnored.inc({reason:ns.LowScore}),[];let n=(this.peerhave.get(e)??0)+1;if(this.peerhave.set(e,n),n>10)return this.log("IHAVE: peer %s has advertised too many times (%d) within this heartbeat interval; ignoring",e,n),this.metrics?.ihaveRcvIgnored.inc({reason:ns.MaxIhave}),[];let i=this.iasked.get(e)??0;if(i>=5e3)return this.log("IHAVE: peer %s has already advertised too many messages (%d); ignoring",e,i),this.metrics?.ihaveRcvIgnored.inc({reason:ns.MaxIasked}),[];let o=new Map;if(t.forEach(({topicID:h,messageIDs:m})=>{if(h==null||m==null||!this.mesh.has(h))return;let d=0;m.forEach(E=>{let v=this.msgIdToStrFn(E);this.seenCache.has(v)||(o.set(v,E),d++)}),this.metrics?.onIhaveRcv(h,m.length,d)}),o.size===0)return[];let a=o.size;a+i>5e3&&(a=5e3-i),this.log("IHAVE: Asking for %d out of %d messages from %s",a,o.size,e);let c=Array.from(o.values());return qe(c),c=c.slice(0,a),this.iasked.set(e,i+a),[{messageIDs:c}]}handleIWant(e,t){if(t.length===0)return[];let r=this.score.score(e);if(r<this.opts.scoreThresholds.gossipThreshold)return this.log("IWANT: ignoring peer %s with score below threshold [score = %d]",e,r),[];let n=new Map,i=new Map,o=0;return t.forEach(({messageIDs:a})=>{a?.forEach(c=>{let h=this.msgIdToStrFn(c),m=this.mcache.getWithIWantCount(h,e);if(m==null){o++;return}if(i.set(m.msg.topic,1+(i.get(m.msg.topic)??0)),m.count>3){this.log("IWANT: Peer %s has asked for message %s too many times: ignoring request",e,c);return}n.set(h,m.msg)})}),this.metrics?.onIwantRcv(i,o),n.size===0?(this.log("IWANT: Could not provide any wanted messages to %s",e),[]):(this.log("IWANT: Sending %d messages to %s",n.size,e),Array.from(n.values()))}async handleGraft(e,t){let r=[],n=this.score.score(e),i=Date.now(),o=this.opts.doPX;if(t.forEach(({topicID:c})=>{if(c==null)return;let h=this.mesh.get(c);if(h==null){o=!1;return}if(h.has(e))return;let m=this.backoff.get(c)?.get(e);if(this.direct.has(e))this.log("GRAFT: ignoring request from direct peer %s",e),r.push(c),o=!1;else if(typeof m=="number"&&i<m){this.log("GRAFT: ignoring backed off peer %s",e),this.score.addPenalty(e,1,rs.GraftBackoff),o=!1;let d=m+this.opts.graftFloodThreshold-this.opts.pruneBackoff;i<d&&this.score.addPenalty(e,1,rs.GraftBackoff),this.addBackoff(e,c),r.push(c)}else n<0?(this.log("GRAFT: ignoring peer %s with negative score: score=%d, topic=%s",e,n,c),r.push(c),o=!1,this.addBackoff(e,c)):h.size>=this.opts.Dhi&&!(this.outbound.get(e)??!1)?(r.push(c),this.addBackoff(e,c)):(this.log("GRAFT: Add mesh link from %s in %s",e,c),this.score.graft(e,c),h.add(e),this.metrics?.onAddToMesh(c,Ee.Subscribed,1));this.safeDispatchEvent("gossipsub:graft",{detail:{peerId:e,topic:c,direction:"inbound"}})}),r.length===0)return[];let a=!1;return Promise.all(r.map(async c=>this.makePrune(e,c,o,a)))}async handlePrune(e,t){let r=this.score.score(e);for(let{topicID:n,backoff:i,peers:o}of t){if(n==null)continue;let a=this.mesh.get(n);if(a==null)return;this.log("PRUNE: Remove mesh link to %s in %s",e,n),this.score.prune(e,n),a.has(e)&&(a.delete(e),this.metrics?.onRemoveFromMesh(n,Ne.Prune,1)),typeof i=="number"&&i>0?this.doAddBackoff(e,n,i*1e3):this.addBackoff(e,n),o!=null&&o.length>0&&(r<this.opts.scoreThresholds.acceptPXThreshold?this.log("PRUNE: ignoring PX from peer %s with insufficient score [score = %d, topic = %s]",e,r,n):await this.pxConnect(o)),this.safeDispatchEvent("gossipsub:prune",{detail:{peerId:e,topic:n,direction:"inbound"}})}}handleIdontwant(e,t){let r=this.idontwantCounts.get(e)??0;if(r>=this.opts.idontwantMaxMessages)return;let n=r,i=this.idontwants.get(e);i==null&&(i=new Map,this.idontwants.set(e,i));let o=0;e:for(let{messageIDs:c}of t)for(let h of c){if(r>=this.opts.idontwantMaxMessages)break e;r++;let m=this.msgIdToStrFn(h);i.set(m,this.heartbeatTicks),this.mcache.msgs.has(m)||o++}this.idontwantCounts.set(e,r);let a=r-n;this.metrics?.onIdontwantRcv(a,o)}addBackoff(e,t){this.doAddBackoff(e,t,this.opts.pruneBackoff)}doAddBackoff(e,t,r){let n=this.backoff.get(t);n==null&&(n=new Map,this.backoff.set(t,n));let i=Date.now()+r;(n.get(e)??0)<i&&n.set(e,i)}applyIwantPenalties(){this.gossipTracer.getBrokenPromises().forEach((e,t)=>{this.log("peer %s didn't follow up in %d IWANT requests; adding penalty",t,e),this.score.addPenalty(t,e,rs.BrokenPromise)})}clearBackoff(){if(this.heartbeatTicks%15!==0)return;let e=Date.now();this.backoff.forEach((t,r)=>{t.forEach((n,i)=>{n+1*this.opts.heartbeatInterval<e&&t.delete(i)}),t.size===0&&this.backoff.delete(r)})}async directConnect(){let e=[];this.direct.forEach(t=>{this.streamsOutbound.has(t)||e.push(t)}),await Promise.all(e.map(async t=>this.connect(t)))}async pxConnect(e){e.length>this.opts.prunePeers&&(qe(e),e=e.slice(0,this.opts.prunePeers));let t=[];await Promise.all(e.map(async r=>{if(r.peerID==null)return;let n=Jt(We(r.peerID)),i=n.toString();if(!this.peers.has(i)){if(r.signedPeerRecord==null){t.push(i);return}try{if(!await this.components.peerStore.consumePeerRecord(r.signedPeerRecord,{expectedPeer:n})){this.log("bogus peer record obtained through px: could not add peer record to address book");return}t.push(i)}catch{this.log("bogus peer record obtained through px: invalid signature or not a peer record")}}})),t.length!==0&&await Promise.all(t.map(async r=>this.connect(r)))}async connect(e){this.log("Initiating connection with %s",e);let t=Mt(e),r=await this.components.connectionManager.openConnection(t);for(let n of this.protocols)for(let i of this.components.registrar.getTopologies(n))i.onConnect?.(t,r)}subscribe(e){if(this.status.code!==Me.started)throw new Error("Pubsub has not started");if(!this.subscriptions.has(e)){this.subscriptions.add(e);for(let t of this.peers.keys())this.sendSubscriptions(t,[e],!0)}this.join(e)}unsubscribe(e){if(this.status.code!==Me.started)throw new Error("Pubsub is not started");let t=this.subscriptions.delete(e);if(this.log("unsubscribe from %s - am subscribed %s",e,t),t)for(let r of this.peers.keys())this.sendSubscriptions(r,[e],!1);this.leave(e)}join(e){if(this.status.code!==Me.started)throw new Error("Gossipsub has not started");if(this.mesh.has(e))return;this.log("JOIN %s",e),this.metrics?.onJoin(e);let t=new Set,r=this.backoff.get(e),n=this.fanout.get(e);if(n!=null&&(this.fanout.delete(e),this.fanoutLastpub.delete(e),n.forEach(i=>{!this.direct.has(i)&&this.score.score(i)>=0&&r?.has(i)!==!0&&t.add(i)}),this.metrics?.onAddToMesh(e,Ee.Fanout,t.size)),t.size<this.opts.D){let i=t.size;this.getRandomGossipPeers(e,this.opts.D,a=>!t.has(a)&&!this.direct.has(a)&&this.score.score(a)>=0&&r?.has(a)!==!0).forEach(a=>{t.add(a)}),this.metrics?.onAddToMesh(e,Ee.Random,t.size-i)}this.mesh.set(e,t),t.forEach(i=>{this.log("JOIN: Add mesh link to %s in %s",i,e),this.sendGraft(i,e)})}leave(e){if(this.status.code!==Me.started)throw new Error("Gossipsub has not started");this.log("LEAVE %s",e),this.metrics?.onLeave(e);let t=this.mesh.get(e);t!=null&&(Promise.all(Array.from(t).map(async r=>{this.log("LEAVE: Remove mesh link to %s in %s",r,e),await this.sendPrune(r,e)})).catch(r=>{this.log("Error sending prunes to mesh peers",r)}),this.mesh.delete(e))}selectPeersToForward(e,t,r){let n=new Set,i=this.topics.get(e);i!=null&&(this.direct.forEach(a=>{i.has(a)&&t!==a&&!(r?.has(a)??!1)&&n.add(a)}),this.floodsubPeers.forEach(a=>{i.has(a)&&t!==a&&!(r?.has(a)??!1)&&this.score.score(a)>=this.opts.scoreThresholds.publishThreshold&&n.add(a)}));let o=this.mesh.get(e);return o!=null&&o.size>0&&o.forEach(a=>{t!==a&&!(r?.has(a)??!1)&&n.add(a)}),n}selectPeersToPublish(e){let t=new Set,r={direct:0,floodsub:0,mesh:0,fanout:0},n=this.topics.get(e);if(n!=null)if(this.opts.floodPublish)n.forEach(i=>{this.direct.has(i)?(t.add(i),r.direct++):this.score.score(i)>=this.opts.scoreThresholds.publishThreshold&&(t.add(i),r.floodsub++)});else{this.direct.forEach(o=>{n.has(o)&&(t.add(o),r.direct++)}),this.floodsubPeers.forEach(o=>{n.has(o)&&this.score.score(o)>=this.opts.scoreThresholds.publishThreshold&&(t.add(o),r.floodsub++)});let i=this.mesh.get(e);if(i!=null&&i.size>0)i.forEach(o=>{t.add(o),r.mesh++}),i.size<this.opts.D&&this.getRandomGossipPeers(e,this.opts.D-i.size,a=>!i.has(a)&&!this.direct.has(a)&&!this.floodsubPeers.has(a)&&this.score.score(a)>=this.opts.scoreThresholds.publishThreshold).forEach(a=>{t.add(a),r.mesh++});else{let o=this.fanout.get(e);if(o!=null&&o.size>0)o.forEach(a=>{t.add(a),r.fanout++});else{let a=this.getRandomGossipPeers(e,this.opts.D,c=>this.score.score(c)>=this.opts.scoreThresholds.publishThreshold);a.size>0&&(this.fanout.set(e,a),a.forEach(c=>{t.add(c),r.fanout++}))}this.fanoutLastpub.set(e,Date.now())}}return{tosend:t,tosendCount:r}}forwardMessage(e,t,r,n){r!=null&&this.score.deliverMessage(r,e,t.topic);let i=this.selectPeersToForward(t.topic,r,n);i.forEach(o=>{this.sendRpc(o,Oe([t]))}),this.metrics?.onForwardMsg(t.topic,i.size)}async publish(e,t,r){let n=Date.now(),i=this.dataTransform!=null?this.dataTransform.outboundTransform(e,t):t;if(this.publishConfig==null)throw Error("PublishError.Uninitialized");let{raw:o,msg:a}=await cc(this.publishConfig,e,t,i),c=await this.msgIdFn(a),h=this.msgIdToStrFn(c),m=r?.ignoreDuplicatePublishError??this.opts.ignoreDuplicatePublishError;if(this.seenCache.has(h)){if(m)return this.metrics?.onPublishDuplicateMsg(e),{recipients:[]};throw Error("PublishError.Duplicate")}let{tosend:d,tosendCount:E}=this.selectPeersToPublish(e),v=this.opts.emitSelf&&this.subscriptions.has(e),u=r?.allowPublishToZeroTopicPeers??this.opts.allowPublishToZeroTopicPeers;if(d.size===0&&!u&&!v)throw Error("PublishError.NoPeersSubscribedToTopic");this.seenCache.put(h),this.mcache.put({msgId:c,msgIdStr:h},o,!0),this.gossipTracer.deliverMessage(h),this.publishedMessageIds.put(h);let g=r?.batchPublish??this.opts.batchPublish,w=Oe([o]);if(g)this.sendRpcInBatch(d,w);else for(let I of d)this.sendRpc(I,w)||d.delete(I);let y=Date.now()-n;return this.metrics?.onPublishMsg(e,E,d.size,o.data!=null?o.data.length:0,y),v&&(d.add(this.components.peerId.toString()),super.dispatchEvent(new CustomEvent("gossipsub:message",{detail:{propagationSource:this.components.peerId,msgId:h,msg:a}})),super.dispatchEvent(new CustomEvent("message",{detail:a}))),{recipients:Array.from(d.values()).map(I=>this.peers.get(I)??Mt(I))}}sendRpcInBatch(e,t){let r=nt.encode(t),n=es.single(r);for(let i of e){let o=this.streamsOutbound.get(i);if(o==null){this.log(`Cannot send RPC to ${i} as there is no open stream to it available`),e.delete(i);continue}try{o.pushPrefixed(n)}catch(a){e.delete(i),this.log.error(`Cannot send rpc to ${i}`,a)}this.metrics?.onRpcSent(t,r.length)}}reportMessageValidationResult(e,t,r){let n;if(r===me.Accept){if(n=this.mcache.validate(e),n!=null){let{message:o,originatingPeers:a}=n;this.score.deliverMessage(t,e,o.topic),this.forwardMessage(e,n.message,t,a)}}else if(n=this.mcache.remove(e),n!=null){let o=Ai(r),{message:a,originatingPeers:c}=n;this.score.rejectMessage(t,e,a.topic,o);for(let h of c)this.score.rejectMessage(h,e,a.topic,o)}let i=this.score.messageFirstSeenTimestampMs(e);this.metrics?.onReportValidation(n,r,i)}sendGraft(e,t){let n=Oe([],{graft:[{topicID:t}]});this.sendRpc(e,n)}async sendPrune(e,t){let n=[await this.makePrune(e,t,this.opts.doPX,!0)],i=Oe([],{prune:n});this.sendRpc(e,i)}sendIDontWants(e,t,r){let n=this.mesh.get(t);if(n==null)return;let i=new Set(n);i.delete(r);for(let a of i)this.streamsOutbound.get(a)?.protocol!==Bt&&i.delete(a);let o=Oe([],{idontwant:[{messageIDs:[e]}]});this.sendRpcInBatch(i,o)}sendRpc(e,t){let r=this.streamsOutbound.get(e);if(r==null)return this.log(`Cannot send RPC to ${e} as there is no open stream to it available`),!1;let n=this.control.get(e);n!=null&&(this.piggybackControl(e,t,n),this.control.delete(e));let i=this.gossip.get(e);i!=null&&(this.piggybackGossip(e,t,i),this.gossip.delete(e));let o=nt.encode(t);try{r.push(o)}catch(a){return this.log.error(`Cannot send rpc to ${e}`,a),n!=null&&this.control.set(e,n),i!=null&&this.gossip.set(e,i),!1}if(this.metrics?.onRpcSent(t,o.length),t.control?.graft!=null)for(let a of t.control?.graft)a.topicID!=null&&this.safeDispatchEvent("gossipsub:graft",{detail:{peerId:e,topic:a.topicID,direction:"outbound"}});if(t.control?.prune!=null)for(let a of t.control?.prune)a.topicID!=null&&this.safeDispatchEvent("gossipsub:prune",{detail:{peerId:e,topic:a.topicID,direction:"outbound"}});return!0}piggybackControl(e,t,r){let n=Pi(t);for(let i of r.graft)i.topicID!=null&&(this.mesh.get(i.topicID)?.has(e)??!1)&&n.control.graft.push(i);for(let i of r.prune)i.topicID!=null&&!(this.mesh.get(i.topicID)?.has(e)??!1)&&n.control.prune.push(i)}piggybackGossip(e,t,r){let n=Pi(t);n.control.ihave=r}async sendGraftPrune(e,t,r){let n=this.opts.doPX,i=!1;for(let[o,a]of e){let c=a.map(d=>({topicID:d})),h=[],m=t.get(o);m!=null&&(h=await Promise.all(m.map(async d=>this.makePrune(o,d,n&&!(r.get(o)??!1),i))),t.delete(o)),this.sendRpc(o,Oe([],{graft:c,prune:h}))}for(let[o,a]of t){let c=await Promise.all(a.map(async h=>this.makePrune(o,h,n&&!(r.get(o)??!1),i)));this.sendRpc(o,Oe([],{prune:c}))}}emitGossip(e){let t=this.mcache.getGossipIDs(new Set(e.keys()));for(let[r,n]of e)this.doEmitGossip(r,n,t.get(r)??[])}doEmitGossip(e,t,r){if(r.length===0||(qe(r),r.length>5e3&&this.log("too many messages for gossip; will truncate IHAVE list (%d messages)",r.length),t.size===0))return;let n=this.opts.Dlazy,o=this.opts.gossipFactor*t.size,a=t;o>n&&(n=o),n>a.size?n=a.size:a=qe(Array.from(a)).slice(0,n),a.forEach(c=>{let h=r;r.length>5e3&&(h=qe(h.slice()).slice(0,5e3)),this.pushGossip(c,{topicID:e,messageIDs:h})})}flush(){for(let[e,t]of this.gossip.entries())this.gossip.delete(e),this.sendRpc(e,Oe([],{ihave:t}));for(let[e,t]of this.control.entries()){this.control.delete(e);let r=Oe([],{graft:t.graft,prune:t.prune});this.sendRpc(e,r)}}pushGossip(e,t){this.log("Add gossip to %s",e);let r=this.gossip.get(e)??[];this.gossip.set(e,r.concat(t))}async makePrune(e,t,r,n){if(this.score.prune(e,t),this.streamsOutbound.get(e)?.protocol===Lr)return{topicID:t,peers:[]};let i=n?this.opts.unsubcribeBackoff:this.opts.pruneBackoff,o=i/1e3;if(this.doAddBackoff(e,t,i),!r)return{topicID:t,peers:[],backoff:o};let a=this.getRandomGossipPeers(t,this.opts.prunePeers,h=>h!==e&&this.score.score(h)>=0),c=await Promise.all(Array.from(a).map(async h=>{let m=this.peers.get(h)??Mt(h),d;try{d=await this.components.peerStore.get(m)}catch(E){if(E.name!=="NotFoundError")throw E}return{peerID:m.toMultihash().bytes,signedPeerRecord:d?.peerRecordEnvelope}}));return{topicID:t,peers:c,backoff:o}}runHeartbeat=()=>{let e=this.metrics?.heartbeatDuration.startTimer();this.heartbeat().catch(t=>{this.log("Error running heartbeat",t)}).finally(()=>{if(e?.(),this.status.code===Me.started){clearTimeout(this.status.heartbeatTimeout);let t=this.opts.heartbeatInterval-(Date.now()-this.status.hearbeatStartMs)%this.opts.heartbeatInterval;t<this.opts.heartbeatInterval*.25&&(t+=this.opts.heartbeatInterval,this.metrics?.heartbeatSkipped.inc()),this.status.heartbeatTimeout=setTimeout(this.runHeartbeat,t)}})};async heartbeat(){let{D:e,Dlo:t,Dhi:r,Dscore:n,Dout:i,fanoutTTL:o}=this.opts;this.heartbeatTicks++;let a=new Map,c=u=>{let g=a.get(u);return g===void 0&&(g=this.score.score(u),a.set(u,g)),g},h=new Map,m=new Map,d=new Map;this.clearBackoff(),this.peerhave.clear(),this.metrics?.cacheSize.set({cache:"iasked"},this.iasked.size),this.iasked.clear(),this.applyIwantPenalties(),this.idontwantCounts.clear();for(let u of this.idontwants.values())for(let[g,w]of u)this.heartbeatTicks-w>=this.opts.mcacheLength&&u.delete(g);this.heartbeatTicks%this.opts.directConnectTicks===0&&await this.directConnect(),this.fastMsgIdCache?.prune(),this.seenCache.prune(),this.gossipTracer.prune(),this.publishedMessageIds.prune();let E=new Map;this.mesh.forEach((u,g)=>{let w=this.topics.get(g),y=new Set,I=new Set;if(E.set(g,I),w!=null){let p=qe(Array.from(w)),b=this.backoff.get(g);for(let S of p){let x=this.streamsOutbound.get(S);if(x!=null&&this.protocols.includes(x.protocol)&&!u.has(S)&&!this.direct.has(S)){let _=c(S);b?.has(S)!==!0&&_>=0&&y.add(S),_>=this.opts.scoreThresholds.gossipThreshold&&I.add(S)}}}let l=(p,b)=>{this.log("HEARTBEAT: Remove mesh link to %s in %s",p,g),this.addBackoff(p,g),u.delete(p),c(p)>=this.opts.scoreThresholds.gossipThreshold&&I.add(p),this.metrics?.onRemoveFromMesh(g,b,1);let S=m.get(p);S==null?m.set(p,[g]):S.push(g)},f=(p,b)=>{this.log("HEARTBEAT: Add mesh link to %s in %s",p,g),this.score.graft(p,g),u.add(p),I.delete(p),this.metrics?.onAddToMesh(g,b,1);let S=h.get(p);S==null?h.set(p,[g]):S.push(g)};if(u.forEach(p=>{let b=c(p);b<0&&(this.log("HEARTBEAT: Prune peer %s with negative score: score=%d, topic=%s",p,b,g),l(p,Ne.BadScore),d.set(p,!0))}),u.size<t){let p=e-u.size;Xa(y,p).forEach(S=>{f(S,Ee.NotEnough)})}if(u.size>r){let p=Array.from(u);p.sort((S,x)=>c(x)-c(S)),p=p.slice(0,n).concat(qe(p.slice(n)));let b=0;if(p.slice(0,e).forEach(S=>{(this.outbound.get(S)??!1)&&b++}),b<i){let S=_=>{let P=p[_];for(let O=_;O>0;O--)p[O]=p[O-1];p[0]=P};if(b>0){let _=b;for(let P=1;P<e&&_>0;P++)(this.outbound.get(p[P])??!1)&&(S(P),_--)}let x=e-b;for(let _=e;_<p.length&&x>0;_++)(this.outbound.get(p[_])??!1)&&(S(_),x--)}p.slice(e).forEach(S=>{l(S,Ne.Excess)})}if(u.size>=t){let p=0;if(u.forEach(b=>{(this.outbound.get(b)??!1)&&p++}),p<i){let b=i-p;Sr(y,b,x=>this.outbound.get(x)===!0).forEach(x=>{f(x,Ee.Outbound)})}}if(this.heartbeatTicks%this.opts.opportunisticGraftTicks===0&&u.size>1){let p=Array.from(u).sort((x,_)=>c(x)-c(_)),b=Math.floor(u.size/2),S=c(p[b]);if(S<this.opts.scoreThresholds.opportunisticGraftThreshold){let x=this.opts.opportunisticGraftPeers,_=Sr(y,x,P=>c(P)>S);for(let P of _)this.log("HEARTBEAT: Opportunistically graft peer %s on topic %s",P,g),f(P,Ee.Opportunistic)}}});let v=Date.now();this.fanoutLastpub.forEach((u,g)=>{u+o<v&&(this.fanout.delete(g),this.fanoutLastpub.delete(g))}),this.fanout.forEach((u,g)=>{let w=this.topics.get(g);u.forEach(f=>{(!(w?.has(f)??!1)||c(f)<this.opts.scoreThresholds.publishThreshold)&&u.delete(f)});let y=this.topics.get(g),I=[],l=new Set;if(E.set(g,l),y!=null){let f=qe(Array.from(y));for(let p of f){let b=this.streamsOutbound.get(p);if(b!=null&&this.protocols.includes(b.protocol)&&!u.has(p)&&!this.direct.has(p)){let S=c(p);S>=this.opts.scoreThresholds.publishThreshold&&I.push(p),S>=this.opts.scoreThresholds.gossipThreshold&&l.add(p)}}}if(u.size<e){let f=e-u.size;I.slice(0,f).forEach(p=>{u.add(p),l?.delete(p)})}}),this.emitGossip(E),await this.sendGraftPrune(h,m,d),this.flush(),this.mcache.shift(),this.dispatchEvent(new CustomEvent("gossipsub:heartbeat"))}getRandomGossipPeers(e,t,r=()=>!0){let n=this.topics.get(e);if(n==null)return new Set;let i=[];return n.forEach(o=>{let a=this.streamsOutbound.get(o);a!=null&&this.protocols.includes(a.protocol)&&r(o)&&i.push(o)}),i=qe(i),t>0&&i.length>t&&(i=i.slice(0,t)),new Set(i)}onScrapeMetrics(e){e.mcacheSize.set(this.mcache.size),e.mcacheNotValidatedCount.set(this.mcache.notValidatedCount),e.cacheSize.set({cache:"direct"},this.direct.size),e.cacheSize.set({cache:"seenCache"},this.seenCache.size),e.cacheSize.set({cache:"fastMsgIdCache"},this.fastMsgIdCache?.size??0),e.cacheSize.set({cache:"publishedMessageIds"},this.publishedMessageIds.size),e.cacheSize.set({cache:"mcache"},this.mcache.size),e.cacheSize.set({cache:"score"},this.score.size),e.cacheSize.set({cache:"gossipTracer.promises"},this.gossipTracer.size),e.cacheSize.set({cache:"gossipTracer.requests"},this.gossipTracer.requestMsByMsgSize),e.cacheSize.set({cache:"topics"},this.topics.size),e.cacheSize.set({cache:"subscriptions"},this.subscriptions.size),e.cacheSize.set({cache:"mesh"},this.mesh.size),e.cacheSize.set({cache:"fanout"},this.fanout.size),e.cacheSize.set({cache:"peers"},this.peers.size),e.cacheSize.set({cache:"streamsOutbound"},this.streamsOutbound.size),e.cacheSize.set({cache:"streamsInbound"},this.streamsInbound.size),e.cacheSize.set({cache:"acceptFromWhitelist"},this.acceptFromWhitelist.size),e.cacheSize.set({cache:"gossip"},this.gossip.size),e.cacheSize.set({cache:"control"},this.control.size),e.cacheSize.set({cache:"peerhave"},this.peerhave.size),e.cacheSize.set({cache:"outbound"},this.outbound.size);let t=0,r=Date.now();e.connectedPeersBackoffSec.reset();for(let c of this.backoff.values()){t+=c.size;for(let[h,m]of c.entries())this.peers.has(h)&&e.connectedPeersBackoffSec.observe(Math.max(0,m-r)/1e3)}e.cacheSize.set({cache:"backoff"},t);let n=0;for(let c of this.idontwants.values())n+=c.size;e.cacheSize.set({cache:"idontwants"},n);for(let[c,h]of this.topics)e.topicPeersCount.set({topicStr:c},h.size);for(let[c,h]of this.mesh)e.meshPeerCounts.set({topicStr:c},h.size);let i=[],o=new Map;e.behaviourPenalty.reset();for(let c of this.peers.keys()){let h=this.score.score(c);i.push(h),o.set(c,h),e.behaviourPenalty.observe(this.score.peerStats.get(c)?.behaviourPenalty??0)}e.registerScores(i,this.opts.scoreThresholds),e.registerScorePerMesh(this.mesh,o);let a=sc(this.peers.keys(),this.score.peerStats,this.score.params,this.score.peerIPs,e.topicStrToLabel);e.registerScoreWeights(a)}tagMeshPeer=e=>{let{peerId:t,topic:r}=e.detail;this.components.peerStore.merge(this.peers.get(t)??Mt(t),{tags:{[r]:{value:100}}}).catch(n=>{this.log.error("Error tagging peer %s with topic %s",t,r,n)})};untagMeshPeer=e=>{let{peerId:t,topic:r}=e.detail;this.components.peerStore.merge(this.peers.get(t)??Mt(t),{tags:{[r]:void 0}}).catch(n=>{this.log.error("Error untagging peer %s with topic %s",t,r,n)})}};var bt="StrictSign",Lt="StrictNoSign",me;(function(s){s.Accept="accept",s.Ignore="ignore",s.Reject="reject"})(me||(me={}));var Jh=Bt;function Qh(s={}){return e=>new Pr(e,s)}return Sc(ef);})();
3
3
  /*! Bundled license information:
4
4
 
5
5
  @noble/hashes/utils.js: