@libp2p/peer-collections 7.0.20-ed1ad1f26 → 7.0.21-a34745c01

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.Libp2PPeerCollections = factory()}(typeof self !== 'undefined' ? self : this, function () {
2
- "use strict";var Libp2PPeerCollections=(()=>{var $r=Object.defineProperty;var Ki=Object.getOwnPropertyDescriptor;var Ni=Object.getOwnPropertyNames;var Mi=Object.prototype.hasOwnProperty;var ct=(r,t)=>{for(var e in t)$r(r,e,{get:t[e],enumerable:!0})},Pi=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of Ni(t))!Mi.call(r,o)&&o!==e&&$r(r,o,{get:()=>t[o],enumerable:!(n=Ki(t,o))||n.enumerable});return r};var zi=r=>Pi($r({},"__esModule",{value:!0}),r);var wf={};ct(wf,{PeerFilter:()=>rr,PeerList:()=>$t,PeerMap:()=>Zt,PeerSet:()=>Yt,peerFilter:()=>Fi,peerList:()=>Li,peerMap:()=>Ii,peerSet:()=>Ti,trackedPeerList:()=>ki,trackedPeerMap:()=>Oi,trackedPeerSet:()=>Ui});var It=class extends Error{static name="InvalidParametersError";constructor(t="Invalid parameters"){super(t),this.name="InvalidParametersError"}},or=class extends Error{static name="InvalidPublicKeyError";constructor(t="Invalid public key"){super(t),this.name="InvalidPublicKeyError"}};var sr=class extends Error{static name="InvalidMultihashError";constructor(t="Invalid Multihash"){super(t),this.name="InvalidMultihashError"}};var Ie=class extends Error{static name="UnsupportedKeyTypeError";constructor(t="Unsupported key type"){super(t),this.name="UnsupportedKeyTypeError"}};var Gr=Symbol.for("@libp2p/peer-id");var tn={};ct(tn,{base58btc:()=>Z,base58flickr:()=>$i});var vf=new Uint8Array(0);function Lo(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function Tt(r){if(r instanceof Uint8Array&&r.constructor.name==="Uint8Array")return r;if(r instanceof ArrayBuffer)return new Uint8Array(r);if(ArrayBuffer.isView(r))return new Uint8Array(r.buffer,r.byteOffset,r.byteLength);throw new Error("Unknown type, must be binary type")}function Do(r){return new TextEncoder().encode(r)}function Co(r){return new TextDecoder().decode(r)}function Hi(r,t){if(r.length>=255)throw new TypeError("Alphabet too long");for(var e=new Uint8Array(256),n=0;n<e.length;n++)e[n]=255;for(var o=0;o<r.length;o++){var s=r.charAt(o),i=s.charCodeAt(0);if(e[i]!==255)throw new TypeError(s+" is ambiguous");e[i]=o}var c=r.length,f=r.charAt(0),a=Math.log(c)/Math.log(256),u=Math.log(256)/Math.log(c);function h(y){if(y instanceof Uint8Array||(ArrayBuffer.isView(y)?y=new Uint8Array(y.buffer,y.byteOffset,y.byteLength):Array.isArray(y)&&(y=Uint8Array.from(y))),!(y instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(y.length===0)return"";for(var _=0,d=0,x=0,S=y.length;x!==S&&y[x]===0;)x++,_++;for(var A=(S-x)*u+1>>>0,C=new Uint8Array(A);x!==S;){for(var L=y[x],O=0,R=A-1;(L!==0||O<d)&&R!==-1;R--,O++)L+=256*C[R]>>>0,C[R]=L%c>>>0,L=L/c>>>0;if(L!==0)throw new Error("Non-zero carry");d=O,x++}for(var I=A-d;I!==A&&C[I]===0;)I++;for(var U=f.repeat(_);I<A;++I)U+=r.charAt(C[I]);return U}function w(y){if(typeof y!="string")throw new TypeError("Expected String");if(y.length===0)return new Uint8Array;var _=0;if(y[_]!==" "){for(var d=0,x=0;y[_]===f;)d++,_++;for(var S=(y.length-_)*a+1>>>0,A=new Uint8Array(S);y[_];){var C=e[y.charCodeAt(_)];if(C===255)return;for(var L=0,O=S-1;(C!==0||L<x)&&O!==-1;O--,L++)C+=c*A[O]>>>0,A[O]=C%256>>>0,C=C/256>>>0;if(C!==0)throw new Error("Non-zero carry");x=L,_++}if(y[_]!==" "){for(var R=S-x;R!==S&&A[R]===0;)R++;for(var I=new Uint8Array(d+(S-R)),U=d;R!==S;)I[U++]=A[R++];return I}}}function p(y){var _=w(y);if(_)return _;throw new Error(`Non-${t} character`)}return{encode:h,decodeUnsafe:w,decode:p}}var qi=Hi,Vi=qi,Fo=Vi;var Xr=class{name;prefix;baseEncode;constructor(t,e,n){this.name=t,this.prefix=e,this.baseEncode=n}encode(t){if(t instanceof Uint8Array)return`${this.prefix}${this.baseEncode(t)}`;throw Error("Unknown type, must be binary type")}},Wr=class{name;prefix;baseDecode;prefixCodePoint;constructor(t,e,n){this.name=t,this.prefix=e;let o=e.codePointAt(0);if(o===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=o,this.baseDecode=n}decode(t){if(typeof t=="string"){if(t.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(t)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(t.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(t){return Oo(this,t)}},Jr=class{decoders;constructor(t){this.decoders=t}or(t){return Oo(this,t)}decode(t){let e=t[0],n=this.decoders[e];if(n!=null)return n.decode(t);throw RangeError(`Unable to decode multibase string ${JSON.stringify(t)}, only inputs prefixed with ${Object.keys(this.decoders)} are supported`)}};function Oo(r,t){return new Jr({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var Qr=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(t,e,n,o){this.name=t,this.prefix=e,this.baseEncode=n,this.baseDecode=o,this.encoder=new Xr(t,e,n),this.decoder=new Wr(t,e,o)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function ae({name:r,prefix:t,encode:e,decode:n}){return new Qr(r,t,e,n)}function Ot({name:r,prefix:t,alphabet:e}){let{encode:n,decode:o}=Fo(e,r);return ae({prefix:t,name:r,encode:n,decode:s=>Tt(o(s))})}function ji(r,t,e,n){let o=r.length;for(;r[o-1]==="=";)--o;let s=new Uint8Array(o*e/8|0),i=0,c=0,f=0;for(let a=0;a<o;++a){let u=t[r[a]];if(u===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<e|u,i+=e,i>=8&&(i-=8,s[f++]=255&c>>i)}if(i>=e||(255&c<<8-i)!==0)throw new SyntaxError("Unexpected end of data");return s}function Zi(r,t,e){let n=t[t.length-1]==="=",o=(1<<e)-1,s="",i=0,c=0;for(let f=0;f<r.length;++f)for(c=c<<8|r[f],i+=8;i>e;)i-=e,s+=t[o&c>>i];if(i!==0&&(s+=t[o&c<<e-i]),n)for(;(s.length*e&7)!==0;)s+="=";return s}function Yi(r){let t={};for(let e=0;e<r.length;++e)t[r[e]]=e;return t}function q({name:r,prefix:t,bitsPerChar:e,alphabet:n}){let o=Yi(n);return ae({prefix:t,name:r,encode(s){return Zi(s,n,e)},decode(s){return ji(s,o,e,r)}})}var Z=Ot({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),$i=Ot({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var en={};ct(en,{base32:()=>fe,base32hex:()=>Ji,base32hexpad:()=>tc,base32hexpadupper:()=>ec,base32hexupper:()=>Qi,base32pad:()=>Xi,base32padupper:()=>Wi,base32upper:()=>Gi,base32z:()=>rc});var fe=q({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),Gi=q({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Xi=q({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),Wi=q({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),Ji=q({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),Qi=q({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),tc=q({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),ec=q({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),rc=q({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var rn={};ct(rn,{base36:()=>Te,base36upper:()=>nc});var Te=Ot({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),nc=Ot({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var oc=Ko,Uo=128,sc=127,ic=~sc,cc=Math.pow(2,31);function Ko(r,t,e){t=t||[],e=e||0;for(var n=e;r>=cc;)t[e++]=r&255|Uo,r/=128;for(;r&ic;)t[e++]=r&255|Uo,r>>>=7;return t[e]=r|0,Ko.bytes=e-n+1,t}var ac=nn,fc=128,ko=127;function nn(r,n){var e=0,n=n||0,o=0,s=n,i,c=r.length;do{if(s>=c)throw nn.bytes=0,new RangeError("Could not decode varint");i=r[s++],e+=o<28?(i&ko)<<o:(i&ko)*Math.pow(2,o),o+=7}while(i>=fc);return nn.bytes=s-n,e}var uc=Math.pow(2,7),hc=Math.pow(2,14),lc=Math.pow(2,21),dc=Math.pow(2,28),pc=Math.pow(2,35),mc=Math.pow(2,42),bc=Math.pow(2,49),yc=Math.pow(2,56),gc=Math.pow(2,63),xc=function(r){return r<uc?1:r<hc?2:r<lc?3:r<dc?4:r<pc?5:r<mc?6:r<bc?7:r<yc?8:r<gc?9:10},wc={encode:oc,decode:ac,encodingLength:xc},Ec=wc,Le=Ec;function De(r,t=0){return[Le.decode(r,t),Le.decode.bytes]}function ue(r,t,e=0){return Le.encode(r,t,e),t}function he(r){return Le.encodingLength(r)}function de(r,t){let e=t.byteLength,n=he(r),o=n+he(e),s=new Uint8Array(o+e);return ue(r,s,0),ue(e,s,n),s.set(t,o),new le(r,e,t,s)}function Ce(r){let t=Tt(r),[e,n]=De(t),[o,s]=De(t.subarray(n)),i=t.subarray(n+s);if(i.byteLength!==o)throw new Error("Incorrect length");return new le(e,o,i,t)}function No(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&Lo(r.bytes,e.bytes)}}var le=class{code;size;digest;bytes;constructor(t,e,n,o){this.code=t,this.size=e,this.digest=n,this.bytes=o}};function Mo(r,t){let{bytes:e,version:n}=r;return n===0?Sc(e,on(r),t??Z.encoder):vc(e,on(r),t??fe.encoder)}var Po=new WeakMap;function on(r){let t=Po.get(r);if(t==null){let e=new Map;return Po.set(r,e),e}return t}var it=class r{code;version;multihash;bytes;"/";constructor(t,e,n,o){this.code=e,this.version=t,this.multihash=n,this.bytes=o,this["/"]=o}get asCID(){return this}get byteOffset(){return this.bytes.byteOffset}get byteLength(){return this.bytes.byteLength}toV0(){switch(this.version){case 0:return this;case 1:{let{code:t,multihash:e}=this;if(t!==Re)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==Ac)throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");return r.createV0(e)}default:throw Error(`Can not convert CID version ${this.version} to version 0. This is a bug please report`)}}toV1(){switch(this.version){case 0:{let{code:t,digest:e}=this.multihash,n=de(t,e);return r.createV1(this.code,n)}case 1:return this;default:throw Error(`Can not convert CID version ${this.version} to version 1. This is a bug please report`)}}equals(t){return r.equals(this,t)}static equals(t,e){let n=e;return n!=null&&t.code===n.code&&t.version===n.version&&No(t.multihash,n.multihash)}toString(t){return Mo(this,t)}toJSON(){return{"/":Mo(this)}}link(){return this}[Symbol.toStringTag]="CID";[Symbol.for("nodejs.util.inspect.custom")](){return`CID(${this.toString()})`}static asCID(t){if(t==null)return null;let e=t;if(e instanceof r)return e;if(e["/"]!=null&&e["/"]===e.bytes||e.asCID===e){let{version:n,code:o,multihash:s,bytes:i}=e;return new r(n,o,s,i??zo(n,o,s.bytes))}else if(e[Bc]===!0){let{version:n,multihash:o,code:s}=e,i=Ce(o);return r.create(n,s,i)}else return null}static create(t,e,n){if(typeof e!="number")throw new Error("String codecs are no longer supported");if(!(n.bytes instanceof Uint8Array))throw new Error("Invalid digest");switch(t){case 0:{if(e!==Re)throw new Error(`Version 0 CID must use dag-pb (code: ${Re}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let o=zo(t,e,n.bytes);return new r(t,e,n,o)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,Re,t)}static createV1(t,e){return r.create(1,t,e)}static decode(t){let[e,n]=r.decodeFirst(t);if(n.length!==0)throw new Error("Incorrect length");return e}static decodeFirst(t){let e=r.inspectBytes(t),n=e.size-e.multihashSize,o=Tt(t.subarray(n,n+e.multihashSize));if(o.byteLength!==e.multihashSize)throw new Error("Incorrect length");let s=o.subarray(e.multihashSize-e.digestSize),i=new le(e.multihashCode,e.digestSize,s,o);return[e.version===0?r.createV0(i):r.createV1(e.codec,i),t.subarray(e.size)]}static inspectBytes(t){let e=0,n=()=>{let[h,w]=De(t.subarray(e));return e+=w,h},o=n(),s=Re;if(o===18?(o=0,e=0):s=n(),o!==0&&o!==1)throw new RangeError(`Invalid CID version ${o}`);let i=e,c=n(),f=n(),a=e+f,u=a-i;return{version:o,codec:s,multihashCode:c,digestSize:f,multihashSize:u,size:a}}static parse(t,e){let[n,o]=_c(t,e),s=r.decode(o);if(s.version===0&&t[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return on(s).set(n,t),s}};function _c(r,t){switch(r[0]){case"Q":{let e=t??Z;return[Z.prefix,e.decode(`${Z.prefix}${r}`)]}case Z.prefix:{let e=t??Z;return[Z.prefix,e.decode(r)]}case fe.prefix:{let e=t??fe;return[fe.prefix,e.decode(r)]}case Te.prefix:{let e=t??Te;return[Te.prefix,e.decode(r)]}default:{if(t==null)throw Error("To parse non base32, base36 or base58btc encoded CID multibase decoder must be provided");return[r[0],t.decode(r)]}}}function Sc(r,t,e){let{prefix:n}=e;if(n!==Z.prefix)throw Error(`Cannot string encode V0 in ${e.name} encoding`);let o=t.get(n);if(o==null){let s=e.encode(r).slice(1);return t.set(n,s),s}else return o}function vc(r,t,e){let{prefix:n}=e,o=t.get(n);if(o==null){let s=e.encode(r);return t.set(n,s),s}else return o}var Re=112,Ac=18;function zo(r,t,e){let n=he(r),o=n+he(t),s=new Uint8Array(o+e.byteLength);return ue(r,s,0),ue(t,s,n),s.set(e,o),s}var Bc=Symbol.for("@ipld/js-cid/CID");var sn={};ct(sn,{identity:()=>pt});var Ho=0,Ic="identity",qo=Tt;function Tc(r,t){if(t?.truncate!=null&&t.truncate!==r.byteLength){if(t.truncate<0||t.truncate>r.byteLength)throw new Error(`Invalid truncate option, must be less than or equal to ${r.byteLength}`);r=r.subarray(0,t.truncate)}return de(Ho,qo(r))}var pt={code:Ho,name:Ic,encode:qo,digest:Tc};function at(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}async function Vo(r,t,e,n){let o=await crypto.subtle.importKey("jwk",r,{name:"ECDSA",namedCurve:r.crv??"P-256"},!1,["verify"]);n?.signal?.throwIfAborted();let s=await crypto.subtle.verify({name:"ECDSA",hash:{name:"SHA-256"}},o,t,e.subarray());return n?.signal?.throwIfAborted(),s}function mt(r=0){return new Uint8Array(r)}function ft(r=0){return new Uint8Array(r)}function cr(r,t){t==null&&(t=r.reduce((o,s)=>o+s.length,0));let e=ft(t),n=0;for(let o of r)e.set(o,n),n+=o.length;return e}var Zo=Symbol.for("@achingbrain/uint8arraylist");function jo(r,t){if(t==null||t<0)throw new RangeError("index is out of bounds");let e=0;for(let n of r){let o=e+n.byteLength;if(t<o)return{buf:n,index:t-e};e=o}throw new RangeError("index is out of bounds")}function ar(r){return!!r?.[Zo]}var ut=class r{bufs;length;[Zo]=!0;constructor(...t){this.bufs=[],this.length=0,t.length>0&&this.appendAll(t)}*[Symbol.iterator](){yield*this.bufs}get byteLength(){return this.length}append(...t){this.appendAll(t)}appendAll(t){let e=0;for(let n of t)if(n instanceof Uint8Array)e+=n.byteLength,this.bufs.push(n);else if(ar(n)){e+=n.byteLength;for(let o of n.bufs)this.bufs.push(o)}else throw new Error("Could not append value, must be an Uint8Array or a Uint8ArrayList");this.length+=e}prepend(...t){this.prependAll(t)}prependAll(t){let e=0;for(let n of t.reverse())if(n instanceof Uint8Array)e+=n.byteLength,this.bufs.unshift(n);else if(ar(n))e+=n.byteLength,this.bufs.unshift(...n.bufs);else throw new Error("Could not prepend value, must be an Uint8Array or a Uint8ArrayList");this.length+=e}get(t){let e=jo(this.bufs,t);return e.buf[e.index]}set(t,e){let n=jo(this.bufs,t);n.buf[n.index]=e}write(t,e=0){if(t instanceof Uint8Array)for(let n=0;n<t.length;n++)this.set(e+n,t[n]);else if(ar(t))for(let n=0;n<t.length;n++)this.set(e+n,t.get(n));else throw new Error("Could not write value, must be an Uint8Array or a Uint8ArrayList")}consume(t){if(t=Math.trunc(t),!(Number.isNaN(t)||t<=0)){if(t===this.byteLength){this.bufs=[],this.length=0;return}for(;this.bufs.length>0;)if(t>=this.bufs[0].byteLength)t-=this.bufs[0].byteLength,this.length-=this.bufs[0].byteLength,this.bufs.shift();else{this.bufs[0]=this.bufs[0].subarray(t),this.length-=t;break}}}slice(t,e){let{bufs:n,length:o}=this._subList(t,e);return cr(n,o)}subarray(t,e){let{bufs:n,length:o}=this._subList(t,e);return n.length===1?n[0]:cr(n,o)}sublist(t,e){let{bufs:n,length:o}=this._subList(t,e),s=new r;return s.length=o,s.bufs=n,s}_subList(t,e){if(t=t??0,e=e??this.length,t<0&&(t=this.length+t),e<0&&(e=this.length+e),t<0||e>this.length)throw new RangeError("index is out of bounds");if(t===e)return{bufs:[],length:0};if(t===0&&e===this.length)return{bufs:[...this.bufs],length:this.length};let n=[],o=0;for(let s=0;s<this.bufs.length;s++){let i=this.bufs[s],c=o,f=c+i.byteLength;if(o=f,t>=f)continue;let a=t>=c&&t<f,u=e>c&&e<=f;if(a&&u){if(t===c&&e===f){n.push(i);break}let h=t-c;n.push(i.subarray(h,h+(e-t)));break}if(a){if(t===0){n.push(i);continue}n.push(i.subarray(t-c));continue}if(u){if(e===f){n.push(i);break}n.push(i.subarray(0,e-c));break}n.push(i)}return{bufs:n,length:e-t}}indexOf(t,e=0){if(!ar(t)&&!(t instanceof Uint8Array))throw new TypeError('The "value" argument must be a Uint8ArrayList or Uint8Array');let n=t instanceof Uint8Array?t:t.subarray();if(e=Number(e??0),isNaN(e)&&(e=0),e<0&&(e=this.length+e),e<0&&(e=0),t.length===0)return e>this.length?this.length:e;let o=n.byteLength;if(o===0)throw new TypeError("search must be at least 1 byte long");let s=256,i=new Int32Array(s);for(let h=0;h<s;h++)i[h]=-1;for(let h=0;h<o;h++)i[n[h]]=h;let c=i,f=this.byteLength-n.byteLength,a=n.byteLength-1,u;for(let h=e;h<=f;h+=u){u=0;for(let w=a;w>=0;w--){let p=this.get(h+w);if(n[w]!==p){u=Math.max(1,w-c[p]);break}}if(u===0)return h}return-1}getInt8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getInt8(0)}setInt8(t,e){let n=ft(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setInt8(0,e),this.write(n,t)}getInt16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt16(0,e)}setInt16(t,e,n){let o=mt(2);new DataView(o.buffer,o.byteOffset,o.byteLength).setInt16(0,e,n),this.write(o,t)}getInt32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt32(0,e)}setInt32(t,e,n){let o=mt(4);new DataView(o.buffer,o.byteOffset,o.byteLength).setInt32(0,e,n),this.write(o,t)}getBigInt64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigInt64(0,e)}setBigInt64(t,e,n){let o=mt(8);new DataView(o.buffer,o.byteOffset,o.byteLength).setBigInt64(0,e,n),this.write(o,t)}getUint8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getUint8(0)}setUint8(t,e){let n=ft(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setUint8(0,e),this.write(n,t)}getUint16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint16(0,e)}setUint16(t,e,n){let o=mt(2);new DataView(o.buffer,o.byteOffset,o.byteLength).setUint16(0,e,n),this.write(o,t)}getUint32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint32(0,e)}setUint32(t,e,n){let o=mt(4);new DataView(o.buffer,o.byteOffset,o.byteLength).setUint32(0,e,n),this.write(o,t)}getBigUint64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigUint64(0,e)}setBigUint64(t,e,n){let o=mt(8);new DataView(o.buffer,o.byteOffset,o.byteLength).setBigUint64(0,e,n),this.write(o,t)}getFloat32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat32(0,e)}setFloat32(t,e,n){let o=mt(4);new DataView(o.buffer,o.byteOffset,o.byteLength).setFloat32(0,e,n),this.write(o,t)}getFloat64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat64(0,e)}setFloat64(t,e,n){let o=mt(8);new DataView(o.buffer,o.byteOffset,o.byteLength).setFloat64(0,e,n),this.write(o,t)}equals(t){if(t==null||!(t instanceof r)||t.bufs.length!==this.bufs.length)return!1;for(let e=0;e<this.bufs.length;e++)if(!at(this.bufs[e],t.bufs[e]))return!1;return!0}static fromUint8Arrays(t,e){let n=new r;return n.bufs=t,e==null&&(e=t.reduce((o,s)=>o+s.byteLength,0)),n.length=e,n}};var cn={};ct(cn,{base10:()=>Lc});var Lc=Ot({prefix:"9",name:"base10",alphabet:"0123456789"});var an={};ct(an,{base16:()=>Dc,base16upper:()=>Cc});var Dc=q({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Cc=q({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var fn={};ct(fn,{base2:()=>Rc});var Rc=q({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var un={};ct(un,{base256emoji:()=>Kc});var Yo=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}"),Fc=Yo.reduce((r,t,e)=>(r[e]=t,r),[]),Oc=Yo.reduce((r,t,e)=>{let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);return r[n]=e,r},[]);function Uc(r){return r.reduce((t,e)=>(t+=Fc[e],t),"")}function kc(r){let t=[];for(let e of r){let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);let o=Oc[n];if(o==null)throw new Error(`Non-base256emoji character: ${e}`);t.push(o)}return new Uint8Array(t)}var Kc=ae({prefix:"\u{1F680}",name:"base256emoji",encode:Uc,decode:kc});var hn={};ct(hn,{base64:()=>Nc,base64pad:()=>Mc,base64url:()=>Pc,base64urlpad:()=>zc});var Nc=q({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),Mc=q({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Pc=q({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),zc=q({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var ln={};ct(ln,{base8:()=>Hc});var Hc=q({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var dn={};ct(dn,{identity:()=>qc});var qc=ae({prefix:"\0",name:"identity",encode:r=>Co(r),decode:r=>Do(r)});var au=new TextEncoder,fu=new TextDecoder;var bn={};ct(bn,{sha256:()=>Fe,sha512:()=>Yc});var Zc=20;function mn({name:r,code:t,encode:e,minDigestLength:n,maxDigestLength:o}){return new pn(r,t,e,n,o)}var pn=class{name;code;encode;minDigestLength;maxDigestLength;constructor(t,e,n,o,s){this.name=t,this.code=e,this.encode=n,this.minDigestLength=o??Zc,this.maxDigestLength=s}digest(t,e){if(e?.truncate!=null){if(e.truncate<this.minDigestLength)throw new Error(`Invalid truncate option, must be greater than or equal to ${this.minDigestLength}`);if(this.maxDigestLength!=null&&e.truncate>this.maxDigestLength)throw new Error(`Invalid truncate option, must be less than or equal to ${this.maxDigestLength}`)}if(t instanceof Uint8Array){let n=this.encode(t);return n instanceof Uint8Array?$o(n,this.code,e?.truncate):n.then(o=>$o(o,this.code,e?.truncate))}else throw Error("Unknown type, must be binary type")}};function $o(r,t,e){if(e!=null&&e!==r.byteLength){if(e>r.byteLength)throw new Error(`Invalid truncate option, must be less than or equal to ${r.byteLength}`);r=r.subarray(0,e)}return de(t,r)}function Xo(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var Fe=mn({name:"sha2-256",code:18,encode:Xo("SHA-256")}),Yc=mn({name:"sha2-512",code:19,encode:Xo("SHA-512")});var yn={...dn,...fn,...ln,...cn,...an,...en,...rn,...tn,...hn,...un},Eu={...bn,...sn};function Jo(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var Wo=Jo("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),gn=Jo("ascii","a",r=>{let t="a";for(let e=0;e<r.length;e++)t+=String.fromCharCode(r[e]);return t},r=>{r=r.substring(1);let t=ft(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),$c={utf8:Wo,"utf-8":Wo,hex:yn.base16,latin1:gn,ascii:gn,binary:gn,...yn},fr=$c;function J(r,t="utf8"){let e=fr[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function dt(r,t="utf8"){let e=fr[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}var Gc=parseInt("11111",2),xn=parseInt("10000000",2),Xc=parseInt("01111111",2),Qo={0:Oe,1:Oe,2:Wc,3:ta,4:ea,5:Qc,6:Jc,16:Oe,22:Oe,48:Oe};function wn(r,t={offset:0}){let e=r[t.offset]&Gc;if(t.offset++,Qo[e]!=null)return Qo[e](r,t);throw new Error("No decoder for tag "+e)}function Ue(r,t){let e=0;if((r[t.offset]&xn)===xn){let n=r[t.offset]&Xc,o="0x";t.offset++;for(let s=0;s<n;s++,t.offset++)o+=r[t.offset].toString(16).padStart(2,"0");e=parseInt(o,16)}else e=r[t.offset],t.offset++;return e}function Oe(r,t){Ue(r,t);let e=[];for(;!(t.offset>=r.byteLength);){let n=wn(r,t);if(n===null)break;e.push(n)}return e}function Wc(r,t){let e=Ue(r,t),n=t.offset,o=t.offset+e,s=[];for(let i=n;i<o;i++)i===n&&r[i]===0||s.push(r[i]);return t.offset+=e,Uint8Array.from(s)}function Jc(r,t){let e=Ue(r,t),n=t.offset+e,o=r[t.offset];t.offset++;let s=0,i=0;o<40?(s=0,i=o):o<80?(s=1,i=o-40):(s=2,i=o-80);let c=`${s}.${i}`,f=[];for(;t.offset<n;){let a=r[t.offset];if(t.offset++,f.push(a&127),a<128){f.reverse();let u=0;for(let h=0;h<f.length;h++)u+=f[h]<<h*7;c+=`.${u}`,f=[]}}return c}function Qc(r,t){return t.offset++,null}function ta(r,t){let e=Ue(r,t),n=r[t.offset];t.offset++;let o=r.subarray(t.offset,t.offset+e-1);if(t.offset+=e,n!==0)throw new Error("Unused bits in bit string is unimplemented");return o}function ea(r,t){let e=Ue(r,t),n=r.subarray(t.offset,t.offset+e);return t.offset+=e,n}function ra(r){let t=r.toString(16);t.length%2===1&&(t="0"+t);let e=new ut;for(let n=0;n<t.length;n+=2)e.append(Uint8Array.from([parseInt(`${t[n]}${t[n+1]}`,16)]));return e}function En(r){if(r.byteLength<128)return Uint8Array.from([r.byteLength]);let t=ra(r.byteLength);return new ut(Uint8Array.from([t.byteLength|xn]),t)}function ts(r){let t=new ut,e=128;return(r.subarray()[0]&e)===e&&t.append(Uint8Array.from([0])),t.append(r),new ut(Uint8Array.from([2]),En(t),t)}function es(r){let t=Uint8Array.from([0]),e=new ut(t,r);return new ut(Uint8Array.from([3]),En(e),e)}function ur(r,t=48){let e=new ut;for(let n of r)e.append(n);return new ut(Uint8Array.from([t]),En(e),e)}var na=Uint8Array.from([6,8,42,134,72,206,61,3,1,7]),oa=Uint8Array.from([6,5,43,129,4,0,34]),sa=Uint8Array.from([6,5,43,129,4,0,35]),ia={ext:!0,kty:"EC",crv:"P-256"},ca={ext:!0,kty:"EC",crv:"P-384"},aa={ext:!0,kty:"EC",crv:"P-521"},_n=32,Sn=48,vn=66;function rs(r){let t=wn(r);return ns(t)}function ns(r){let t=r[1][1][0],e=1,n,o;if(t.byteLength===_n*2+1)return n=dt(t.subarray(e,e+_n),"base64url"),o=dt(t.subarray(e+_n),"base64url"),new pe({...ia,key_ops:["verify"],x:n,y:o});if(t.byteLength===Sn*2+1)return n=dt(t.subarray(e,e+Sn),"base64url"),o=dt(t.subarray(e+Sn),"base64url"),new pe({...ca,key_ops:["verify"],x:n,y:o});if(t.byteLength===vn*2+1)return n=dt(t.subarray(e,e+vn),"base64url"),o=dt(t.subarray(e+vn),"base64url"),new pe({...aa,key_ops:["verify"],x:n,y:o});throw new It(`coordinates were wrong length, got ${t.byteLength}, expected 65, 97 or 133`)}function os(r){return ur([ts(Uint8Array.from([1])),ur([fa(r.crv)],160),ur([es(new ut(Uint8Array.from([4]),J(r.x??"","base64url"),J(r.y??"","base64url")))],161)]).subarray()}function fa(r){if(r==="P-256")return na;if(r==="P-384")return oa;if(r==="P-521")return sa;throw new It(`Invalid curve ${r}`)}var pe=class{type="ECDSA";jwk;_raw;constructor(t){this.jwk=t}get raw(){return this._raw==null&&(this._raw=os(this.jwk)),this._raw}toMultihash(){return pt.digest(me(this))}toCID(){return it.createV1(114,this.toMultihash())}toString(){return Z.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:at(this.raw,t.raw)}async verify(t,e,n){return Vo(this.jwk,e,t,n)}};function An(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"&&"BYTES_PER_ELEMENT"in r&&r.BYTES_PER_ELEMENT===1}function Ut(r,t=""){if(typeof r!="number"){let e=t&&`"${t}" `;throw new TypeError(`${e}expected number, got ${typeof r}`)}if(!Number.isSafeInteger(r)||r<0){let e=t&&`"${t}" `;throw new RangeError(`${e}expected integer >= 0, got ${r}`)}}function ht(r,t,e=""){let n=An(r),o=r?.length,s=t!==void 0;if(!n||s&&o!==t){let i=e&&`"${e}" `,c=s?` of length ${t}`:"",f=n?`length=${o}`:`type=${typeof r}`,a=i+"expected Uint8Array"+c+", got "+f;throw n?new RangeError(a):new TypeError(a)}return r}function hr(r){if(typeof r!="function"||typeof r.create!="function")throw new TypeError("Hash must wrapped by utils.createHasher");if(Ut(r.outputLen),Ut(r.blockLen),r.outputLen<1)throw new Error('"outputLen" must be >= 1');if(r.blockLen<1)throw new Error('"blockLen" must be >= 1')}function be(r,t=!0){if(r.destroyed)throw new Error("Hash instance has been destroyed");if(t&&r.finished)throw new Error("Hash#digest() has already been called")}function lr(r,t){ht(r,void 0,"digestInto() output");let e=t.outputLen;if(r.length<e)throw new RangeError('"digestInto() output" expected to be of length >='+e)}function Dt(...r){for(let t=0;t<r.length;t++)r[t].fill(0)}function dr(r){return new DataView(r.buffer,r.byteOffset,r.byteLength)}function bt(r,t){return r<<32-t|r>>>t}var is=typeof Uint8Array.from([]).toHex=="function"&&typeof Uint8Array.fromHex=="function",ua=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function pr(r){if(ht(r),is)return r.toHex();let t="";for(let e=0;e<r.length;e++)t+=ua[r[e]];return t}var Lt={_0:48,_9:57,A:65,F:70,a:97,f:102};function ss(r){if(r>=Lt._0&&r<=Lt._9)return r-Lt._0;if(r>=Lt.A&&r<=Lt.F)return r-(Lt.A-10);if(r>=Lt.a&&r<=Lt.f)return r-(Lt.a-10)}function ke(r){if(typeof r!="string")throw new TypeError("hex string expected, got "+typeof r);if(is)try{return Uint8Array.fromHex(r)}catch(o){throw o instanceof SyntaxError?new RangeError(o.message):o}let t=r.length,e=t/2;if(t%2)throw new RangeError("hex string expected, got unpadded hex of length "+t);let n=new Uint8Array(e);for(let o=0,s=0;o<e;o++,s+=2){let i=ss(r.charCodeAt(s)),c=ss(r.charCodeAt(s+1));if(i===void 0||c===void 0){let f=r[s]+r[s+1];throw new RangeError('hex string expected, got non-hex character "'+f+'" at index '+s)}n[o]=i*16+c}return n}function Bn(...r){let t=0;for(let n=0;n<r.length;n++){let o=r[n];ht(o),t+=o.length}let e=new Uint8Array(t);for(let n=0,o=0;n<r.length;n++){let s=r[n];e.set(s,o),o+=s.length}return e}function In(r,t={}){let e=(o,s)=>r(s).update(o).digest(),n=r(void 0);return e.outputLen=n.outputLen,e.blockLen=n.blockLen,e.canXOF=n.canXOF,e.create=o=>r(o),Object.assign(e,t),Object.freeze(e)}function cs(r=32){Ut(r,"bytesLength");let t=typeof globalThis=="object"?globalThis.crypto:null;if(typeof t?.getRandomValues!="function")throw new Error("crypto.getRandomValues must be defined");if(r>65536)throw new RangeError(`"bytesLength" expected <= 65536, got ${r}`);return t.getRandomValues(new Uint8Array(r))}var Tn=r=>({oid:Uint8Array.from([6,9,96,134,72,1,101,3,4,2,r])});function as(r,t,e){return r&t^~r&e}function fs(r,t,e){return r&t^r&e^t&e}var Ke=class{blockLen;outputLen;canXOF=!1;padOffset;isLE;buffer;view;finished=!1;length=0;pos=0;destroyed=!1;constructor(t,e,n,o){this.blockLen=t,this.outputLen=e,this.padOffset=n,this.isLE=o,this.buffer=new Uint8Array(t),this.view=dr(this.buffer)}update(t){be(this),ht(t);let{view:e,buffer:n,blockLen:o}=this,s=t.length;for(let i=0;i<s;){let c=Math.min(o-this.pos,s-i);if(c===o){let f=dr(t);for(;o<=s-i;i+=o)this.process(f,i);continue}n.set(t.subarray(i,i+c),this.pos),this.pos+=c,i+=c,this.pos===o&&(this.process(e,0),this.pos=0)}return this.length+=t.length,this.roundClean(),this}digestInto(t){be(this),lr(t,this),this.finished=!0;let{buffer:e,view:n,blockLen:o,isLE:s}=this,{pos:i}=this;e[i++]=128,Dt(this.buffer.subarray(i)),this.padOffset>o-i&&(this.process(n,0),i=0);for(let h=i;h<o;h++)e[h]=0;n.setBigUint64(o-8,BigInt(this.length*8),s),this.process(n,0);let c=dr(t),f=this.outputLen;if(f%4)throw new Error("_sha2: outputLen must be aligned to 32bit");let a=f/4,u=this.get();if(a>u.length)throw new Error("_sha2: outputLen bigger than state");for(let h=0;h<a;h++)c.setUint32(4*h,u[h],s)}digest(){let{buffer:t,outputLen:e}=this;this.digestInto(t);let n=t.slice(0,e);return this.destroy(),n}_cloneInto(t){t||=new this.constructor,t.set(...this.get());let{blockLen:e,buffer:n,length:o,finished:s,destroyed:i,pos:c}=this;return t.destroyed=i,t.finished=s,t.length=o,t.pos=c,o%e&&t.buffer.set(n),t}clone(){return this._cloneInto()}},Ct=Uint32Array.from([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]);var tt=Uint32Array.from([1779033703,4089235720,3144134277,2227873595,1013904242,4271175723,2773480762,1595750129,1359893119,2917565137,2600822924,725511199,528734635,4215389547,1541459225,327033209]);var mr=BigInt(4294967295),us=BigInt(32);function ha(r,t=!1){return t?{h:Number(r&mr),l:Number(r>>us&mr)}:{h:Number(r>>us&mr)|0,l:Number(r&mr)|0}}function hs(r,t=!1){let e=r.length,n=new Uint32Array(e),o=new Uint32Array(e);for(let s=0;s<e;s++){let{h:i,l:c}=ha(r[s],t);[n[s],o[s]]=[i,c]}return[n,o]}var Ln=(r,t,e)=>r>>>e,Dn=(r,t,e)=>r<<32-e|t>>>e,Xt=(r,t,e)=>r>>>e|t<<32-e,Wt=(r,t,e)=>r<<32-e|t>>>e,Ne=(r,t,e)=>r<<64-e|t>>>e-32,Me=(r,t,e)=>r>>>e-32|t<<64-e;function St(r,t,e,n){let o=(t>>>0)+(n>>>0);return{h:r+e+(o/2**32|0)|0,l:o|0}}var ls=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),ds=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,ps=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),ms=(r,t,e,n,o)=>t+e+n+o+(r/2**32|0)|0,bs=(r,t,e,n,o)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(o>>>0),ys=(r,t,e,n,o,s)=>t+e+n+o+s+(r/2**32|0)|0;var da=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]),kt=new Uint32Array(64),Cn=class extends Ke{constructor(t){super(64,t,8,!1)}get(){let{A:t,B:e,C:n,D:o,E:s,F:i,G:c,H:f}=this;return[t,e,n,o,s,i,c,f]}set(t,e,n,o,s,i,c,f){this.A=t|0,this.B=e|0,this.C=n|0,this.D=o|0,this.E=s|0,this.F=i|0,this.G=c|0,this.H=f|0}process(t,e){for(let h=0;h<16;h++,e+=4)kt[h]=t.getUint32(e,!1);for(let h=16;h<64;h++){let w=kt[h-15],p=kt[h-2],y=bt(w,7)^bt(w,18)^w>>>3,_=bt(p,17)^bt(p,19)^p>>>10;kt[h]=_+kt[h-7]+y+kt[h-16]|0}let{A:n,B:o,C:s,D:i,E:c,F:f,G:a,H:u}=this;for(let h=0;h<64;h++){let w=bt(c,6)^bt(c,11)^bt(c,25),p=u+w+as(c,f,a)+da[h]+kt[h]|0,_=(bt(n,2)^bt(n,13)^bt(n,22))+fs(n,o,s)|0;u=a,a=f,f=c,c=i+p|0,i=s,s=o,o=n,n=p+_|0}n=n+this.A|0,o=o+this.B|0,s=s+this.C|0,i=i+this.D|0,c=c+this.E|0,f=f+this.F|0,a=a+this.G|0,u=u+this.H|0,this.set(n,o,s,i,c,f,a,u)}roundClean(){Dt(kt)}destroy(){this.destroyed=!0,this.set(0,0,0,0,0,0,0,0),Dt(this.buffer)}},Rn=class extends Cn{A=Ct[0]|0;B=Ct[1]|0;C=Ct[2]|0;D=Ct[3]|0;E=Ct[4]|0;F=Ct[5]|0;G=Ct[6]|0;H=Ct[7]|0;constructor(){super(32)}};var gs=hs(["0x428a2f98d728ae22","0x7137449123ef65cd","0xb5c0fbcfec4d3b2f","0xe9b5dba58189dbbc","0x3956c25bf348b538","0x59f111f1b605d019","0x923f82a4af194f9b","0xab1c5ed5da6d8118","0xd807aa98a3030242","0x12835b0145706fbe","0x243185be4ee4b28c","0x550c7dc3d5ffb4e2","0x72be5d74f27b896f","0x80deb1fe3b1696b1","0x9bdc06a725c71235","0xc19bf174cf692694","0xe49b69c19ef14ad2","0xefbe4786384f25e3","0x0fc19dc68b8cd5b5","0x240ca1cc77ac9c65","0x2de92c6f592b0275","0x4a7484aa6ea6e483","0x5cb0a9dcbd41fbd4","0x76f988da831153b5","0x983e5152ee66dfab","0xa831c66d2db43210","0xb00327c898fb213f","0xbf597fc7beef0ee4","0xc6e00bf33da88fc2","0xd5a79147930aa725","0x06ca6351e003826f","0x142929670a0e6e70","0x27b70a8546d22ffc","0x2e1b21385c26c926","0x4d2c6dfc5ac42aed","0x53380d139d95b3df","0x650a73548baf63de","0x766a0abb3c77b2a8","0x81c2c92e47edaee6","0x92722c851482353b","0xa2bfe8a14cf10364","0xa81a664bbc423001","0xc24b8b70d0f89791","0xc76c51a30654be30","0xd192e819d6ef5218","0xd69906245565a910","0xf40e35855771202a","0x106aa07032bbd1b8","0x19a4c116b8d2d0c8","0x1e376c085141ab53","0x2748774cdf8eeb99","0x34b0bcb5e19b48a8","0x391c0cb3c5c95a63","0x4ed8aa4ae3418acb","0x5b9cca4f7763e373","0x682e6ff3d6b2b8a3","0x748f82ee5defb2fc","0x78a5636f43172f60","0x84c87814a1f0ab72","0x8cc702081a6439ec","0x90befffa23631e28","0xa4506cebde82bde9","0xbef9a3f7b2c67915","0xc67178f2e372532b","0xca273eceea26619c","0xd186b8c721c0c207","0xeada7dd6cde0eb1e","0xf57d4f7fee6ed178","0x06f067aa72176fba","0x0a637dc5a2c898a6","0x113f9804bef90dae","0x1b710b35131c471b","0x28db77f523047d84","0x32caab7b40c72493","0x3c9ebe0a15c9bebc","0x431d67c49c100d4c","0x4cc5d4becb3e42b6","0x597f299cfc657e2a","0x5fcb6fab3ad6faec","0x6c44198c4a475817"].map(r=>BigInt(r))),pa=gs[0],ma=gs[1],Kt=new Uint32Array(80),Nt=new Uint32Array(80),Fn=class extends Ke{constructor(t){super(128,t,16,!1)}get(){let{Ah:t,Al:e,Bh:n,Bl:o,Ch:s,Cl:i,Dh:c,Dl:f,Eh:a,El:u,Fh:h,Fl:w,Gh:p,Gl:y,Hh:_,Hl:d}=this;return[t,e,n,o,s,i,c,f,a,u,h,w,p,y,_,d]}set(t,e,n,o,s,i,c,f,a,u,h,w,p,y,_,d){this.Ah=t|0,this.Al=e|0,this.Bh=n|0,this.Bl=o|0,this.Ch=s|0,this.Cl=i|0,this.Dh=c|0,this.Dl=f|0,this.Eh=a|0,this.El=u|0,this.Fh=h|0,this.Fl=w|0,this.Gh=p|0,this.Gl=y|0,this.Hh=_|0,this.Hl=d|0}process(t,e){for(let A=0;A<16;A++,e+=4)Kt[A]=t.getUint32(e),Nt[A]=t.getUint32(e+=4);for(let A=16;A<80;A++){let C=Kt[A-15]|0,L=Nt[A-15]|0,O=Xt(C,L,1)^Xt(C,L,8)^Ln(C,L,7),R=Wt(C,L,1)^Wt(C,L,8)^Dn(C,L,7),I=Kt[A-2]|0,U=Nt[A-2]|0,z=Xt(I,U,19)^Ne(I,U,61)^Ln(I,U,6),k=Wt(I,U,19)^Me(I,U,61)^Dn(I,U,6),l=ps(R,k,Nt[A-7],Nt[A-16]),m=ms(l,O,z,Kt[A-7],Kt[A-16]);Kt[A]=m|0,Nt[A]=l|0}let{Ah:n,Al:o,Bh:s,Bl:i,Ch:c,Cl:f,Dh:a,Dl:u,Eh:h,El:w,Fh:p,Fl:y,Gh:_,Gl:d,Hh:x,Hl:S}=this;for(let A=0;A<80;A++){let C=Xt(h,w,14)^Xt(h,w,18)^Ne(h,w,41),L=Wt(h,w,14)^Wt(h,w,18)^Me(h,w,41),O=h&p^~h&_,R=w&y^~w&d,I=bs(S,L,R,ma[A],Nt[A]),U=ys(I,x,C,O,pa[A],Kt[A]),z=I|0,k=Xt(n,o,28)^Ne(n,o,34)^Ne(n,o,39),l=Wt(n,o,28)^Me(n,o,34)^Me(n,o,39),m=n&s^n&c^s&c,E=o&i^o&f^i&f;x=_|0,S=d|0,_=p|0,d=y|0,p=h|0,y=w|0,{h,l:w}=St(a|0,u|0,U|0,z|0),a=c|0,u=f|0,c=s|0,f=i|0,s=n|0,i=o|0;let g=ls(z,l,E);n=ds(g,U,k,m),o=g|0}({h:n,l:o}=St(this.Ah|0,this.Al|0,n|0,o|0)),{h:s,l:i}=St(this.Bh|0,this.Bl|0,s|0,i|0),{h:c,l:f}=St(this.Ch|0,this.Cl|0,c|0,f|0),{h:a,l:u}=St(this.Dh|0,this.Dl|0,a|0,u|0),{h,l:w}=St(this.Eh|0,this.El|0,h|0,w|0),{h:p,l:y}=St(this.Fh|0,this.Fl|0,p|0,y|0),{h:_,l:d}=St(this.Gh|0,this.Gl|0,_|0,d|0),{h:x,l:S}=St(this.Hh|0,this.Hl|0,x|0,S|0),this.set(n,o,s,i,c,f,a,u,h,w,p,y,_,d,x,S)}roundClean(){Dt(Kt,Nt)}destroy(){this.destroyed=!0,Dt(this.buffer),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}},On=class extends Fn{Ah=tt[0]|0;Al=tt[1]|0;Bh=tt[2]|0;Bl=tt[3]|0;Ch=tt[4]|0;Cl=tt[5]|0;Dh=tt[6]|0;Dl=tt[7]|0;Eh=tt[8]|0;El=tt[9]|0;Fh=tt[10]|0;Fl=tt[11]|0;Gh=tt[12]|0;Gl=tt[13]|0;Hh=tt[14]|0;Hl=tt[15]|0;constructor(){super(64)}};var xs=In(()=>new Rn,Tn(1));var br=In(()=>new On,Tn(3));var M=(r,t,e)=>ht(r,t,e),kn=Ut,ye=pr,G=(...r)=>Bn(...r),ge=r=>ke(r),Jt=An,Pe=r=>cs(r),gr=BigInt(0),Un=BigInt(1);function yt(r,t=""){if(typeof r!="boolean"){let e=t&&`"${t}" `;throw new TypeError(e+"expected boolean, got type="+typeof r)}return r}function xr(r){if(typeof r=="bigint"){if(!yr(r))throw new RangeError("positive bigint expected, got "+r)}else kn(r);return r}function gt(r,t=""){if(typeof r!="number"){let e=t&&`"${t}" `;throw new TypeError(e+"expected number, got type="+typeof r)}if(!Number.isSafeInteger(r)){let e=t&&`"${t}" `;throw new RangeError(e+"expected safe integer, got "+r)}}function ze(r){let t=xr(r).toString(16);return t.length&1?"0"+t:t}function ws(r){if(typeof r!="string")throw new TypeError("hex string expected, got "+typeof r);return r===""?gr:BigInt("0x"+r)}function Qt(r){return ws(pr(r))}function vt(r){return ws(pr(He(ht(r)).reverse()))}function wr(r,t){if(Ut(t),t===0)throw new RangeError("zero length");r=xr(r);let e=r.toString(16);if(e.length>t*2)throw new RangeError("number too large");return ke(e.padStart(t*2,"0"))}function Kn(r,t){return wr(r,t).reverse()}function Es(r,t){if(r=M(r),t=M(t),r.length!==t.length)return!1;let e=0;for(let n=0;n<r.length;n++)e|=r[n]^t[n];return e===0}function He(r){return Uint8Array.from(M(r))}function Er(r){if(typeof r!="string")throw new TypeError("ascii string expected, got "+typeof r);return Uint8Array.from(r,(t,e)=>{let n=t.charCodeAt(0);if(t.length!==1||n>127)throw new RangeError(`string contains non-ASCII character "${r[e]}" with code ${n} at position ${e}`);return n})}var yr=r=>typeof r=="bigint"&&gr<=r;function ba(r,t,e){return yr(r)&&yr(t)&&yr(e)&&t<=r&&r<e}function xe(r,t,e,n){if(!ba(t,e,n))throw new RangeError("expected valid "+r+": "+e+" <= n < "+n+", got "+t)}function we(r){if(r<gr)throw new Error("expected non-negative bigint, got "+r);let t;for(t=0;r>gr;r>>=Un,t+=1);return t}var qe=r=>(Un<<BigInt(r))-Un;function _s(r,t,e){if(Ut(r,"hashLen"),Ut(t,"qByteLen"),typeof e!="function")throw new TypeError("hmacFn must be a function");let n=d=>new Uint8Array(d),o=Uint8Array.of(),s=Uint8Array.of(0),i=Uint8Array.of(1),c=1e3,f=n(r),a=n(r),u=0,h=()=>{f.fill(1),a.fill(0),u=0},w=(...d)=>e(a,G(f,...d)),p=(d=o)=>{a=w(s,d),f=w(),d.length!==0&&(a=w(i,d),f=w())},y=()=>{if(u++>=c)throw new Error("drbg: tried max amount of iterations");let d=0,x=[];for(;d<t;){f=w();let S=f.slice();x.push(S),d+=f.length}return G(...x)};return(d,x)=>{h(),p(d);let S;for(;(S=x(y()))===void 0;)p();return h(),S}}function xt(r,t={},e={}){if(Object.prototype.toString.call(r)!=="[object Object]")throw new TypeError("expected valid options object");function n(s,i,c){if(!c&&i!=="function"&&!Object.hasOwn(r,s))throw new TypeError(`param "${s}" is invalid: expected own property`);let f=r[s];if(c&&f===void 0)return;let a=typeof f;if(a!==i||f===null)throw new TypeError(`param "${s}" is invalid: expected ${i}, got ${a}`)}let o=(s,i)=>Object.entries(s).forEach(([c,f])=>n(c,f,i));o(t,!1),o(e,!0)}var Nn=()=>{throw new Error("not implemented")};var et=BigInt(0),V=BigInt(1),te=BigInt(2),Bs=BigInt(3),Is=BigInt(4),Ts=BigInt(5),ya=BigInt(7),Ls=BigInt(8),ga=BigInt(9),Ds=BigInt(16);function Y(r,t){if(t<=et)throw new Error("mod: expected positive modulus, got "+t);let e=r%t;return e>=et?e:t+e}function H(r,t,e){if(t<et)throw new Error("pow2: expected non-negative exponent, got "+t);let n=r;for(;t-- >et;)n*=n,n%=e;return n}function Ss(r,t){if(r===et)throw new Error("invert: expected non-zero number");if(t<=et)throw new Error("invert: expected positive modulus, got "+t);let e=Y(r,t),n=t,o=et,s=V,i=V,c=et;for(;e!==et;){let a=n/e,u=n-e*a,h=o-i*a,w=s-c*a;n=e,e=u,o=i,s=c,i=h,c=w}if(n!==V)throw new Error("invert: does not exist");return Y(o,t)}function Mn(r,t,e){let n=r;if(!n.eql(n.sqr(t),e))throw new Error("Cannot find square root")}function Cs(r,t){let e=r,n=(e.ORDER+V)/Is,o=e.pow(t,n);return Mn(e,o,t),o}function xa(r,t){let e=r,n=(e.ORDER-Ts)/Ls,o=e.mul(t,te),s=e.pow(o,n),i=e.mul(t,s),c=e.mul(e.mul(i,te),s),f=e.mul(i,e.sub(c,e.ONE));return Mn(e,f,t),f}function wa(r){let t=Ee(r),e=Rs(r),n=e(t,t.neg(t.ONE)),o=e(t,n),s=e(t,t.neg(n)),i=(r+ya)/Ds;return((c,f)=>{let a=c,u=a.pow(f,i),h=a.mul(u,n),w=a.mul(u,o),p=a.mul(u,s),y=a.eql(a.sqr(h),f),_=a.eql(a.sqr(w),f);u=a.cmov(u,h,y),h=a.cmov(p,w,_);let d=a.eql(a.sqr(h),f),x=a.cmov(u,h,d);return Mn(a,x,f),x})}function Rs(r){if(r<Bs)throw new Error("sqrt is not defined for small field");let t=r-V,e=0;for(;t%te===et;)t/=te,e++;let n=te,o=Ee(r);for(;vs(o,n)===1;)if(n++>1e3)throw new Error("Cannot find square root: probably non-prime P");if(e===1)return Cs;let s=o.pow(n,t),i=(t+V)/te;return function(f,a){let u=f;if(u.is0(a))return a;if(vs(u,a)!==1)throw new Error("Cannot find square root");let h=e,w=u.mul(u.ONE,s),p=u.pow(a,t),y=u.pow(a,i);for(;!u.eql(p,u.ONE);){if(u.is0(p))return u.ZERO;let _=1,d=u.sqr(p);for(;!u.eql(d,u.ONE);)if(_++,d=u.sqr(d),_===h)throw new Error("Cannot find square root");let x=V<<BigInt(h-_-1),S=u.pow(w,x);h=_,w=u.sqr(S),p=u.mul(p,w),y=u.mul(y,S)}return y}}function Ea(r){return r%Is===Bs?Cs:r%Ls===Ts?xa:r%Ds===ga?wa(r):Rs(r)}var Rt=(r,t)=>(Y(r,t)&V)===V,_a=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function Pn(r){let t={ORDER:"bigint",BYTES:"number",BITS:"number"},e=_a.reduce((n,o)=>(n[o]="function",n),t);if(xt(r,e),gt(r.BYTES,"BYTES"),gt(r.BITS,"BITS"),r.BYTES<1||r.BITS<1)throw new Error("invalid field: expected BYTES/BITS > 0");if(r.ORDER<=V)throw new Error("invalid field: expected ORDER > 1, got "+r.ORDER);return r}function Sa(r,t,e){let n=r;if(e<et)throw new Error("invalid exponent, negatives unsupported");if(e===et)return n.ONE;if(e===V)return t;let o=n.ONE,s=t;for(;e>et;)e&V&&(o=n.mul(o,s)),s=n.sqr(s),e>>=V;return o}function Ve(r,t,e=!1){let n=r,o=new Array(t.length).fill(e?n.ZERO:void 0),s=t.reduce((c,f,a)=>n.is0(f)?c:(o[a]=c,n.mul(c,f)),n.ONE),i=n.inv(s);return t.reduceRight((c,f,a)=>n.is0(f)?c:(o[a]=n.mul(c,o[a]),n.mul(c,f)),i),o}function vs(r,t){let e=r,n=(e.ORDER-V)/te,o=e.pow(t,n),s=e.eql(o,e.ONE),i=e.eql(o,e.ZERO),c=e.eql(o,e.neg(e.ONE));if(!s&&!i&&!c)throw new Error("invalid Legendre symbol result");return s?1:i?0:-1}function va(r,t){if(t!==void 0&&kn(t),r<=et)throw new Error("invalid n length: expected positive n, got "+r);if(t!==void 0&&t<1)throw new Error("invalid n length: expected positive bit length, got "+t);let e=we(r);if(t!==void 0&&t<e)throw new Error(`invalid n length: expected bit length (${e}) >= n.length (${t})`);let n=t!==void 0?t:e,o=Math.ceil(n/8);return{nBitLength:n,nByteLength:o}}var As=new WeakMap,_r=class{ORDER;BITS;BYTES;isLE;ZERO=et;ONE=V;_lengths;_mod;constructor(t,e={}){if(t<=V)throw new Error("invalid field: expected ORDER > 1, got "+t);let n;this.isLE=!1,e!=null&&typeof e=="object"&&(typeof e.BITS=="number"&&(n=e.BITS),typeof e.sqrt=="function"&&Object.defineProperty(this,"sqrt",{value:e.sqrt,enumerable:!0}),typeof e.isLE=="boolean"&&(this.isLE=e.isLE),e.allowedLengths&&(this._lengths=Object.freeze(e.allowedLengths.slice())),typeof e.modFromBytes=="boolean"&&(this._mod=e.modFromBytes));let{nBitLength:o,nByteLength:s}=va(t,n);if(s>2048)throw new Error("invalid field: expected ORDER of <= 2048 bytes");this.ORDER=t,this.BITS=o,this.BYTES=s,Object.freeze(this)}create(t){return Y(t,this.ORDER)}isValid(t){if(typeof t!="bigint")throw new TypeError("invalid field element: expected bigint, got "+typeof t);return et<=t&&t<this.ORDER}is0(t){return t===et}isValidNot0(t){return!this.is0(t)&&this.isValid(t)}isOdd(t){return(t&V)===V}neg(t){return Y(-t,this.ORDER)}eql(t,e){return t===e}sqr(t){return Y(t*t,this.ORDER)}add(t,e){return Y(t+e,this.ORDER)}sub(t,e){return Y(t-e,this.ORDER)}mul(t,e){return Y(t*e,this.ORDER)}pow(t,e){return Sa(this,t,e)}div(t,e){return Y(t*Ss(e,this.ORDER),this.ORDER)}sqrN(t){return t*t}addN(t,e){return t+e}subN(t,e){return t-e}mulN(t,e){return t*e}inv(t){return Ss(t,this.ORDER)}sqrt(t){let e=As.get(this);return e||As.set(this,e=Ea(this.ORDER)),e(this,t)}toBytes(t){return this.isLE?Kn(t,this.BYTES):wr(t,this.BYTES)}fromBytes(t,e=!1){M(t);let{_lengths:n,BYTES:o,isLE:s,ORDER:i,_mod:c}=this;if(n){if(t.length<1||!n.includes(t.length)||t.length>o)throw new Error("Field.fromBytes: expected "+n+" bytes, got "+t.length);let a=new Uint8Array(o);a.set(t,s?0:a.length-t.length),t=a}if(t.length!==o)throw new Error("Field.fromBytes: expected "+o+" bytes, got "+t.length);let f=s?vt(t):Qt(t);if(c&&(f=Y(f,i)),!e&&!this.isValid(f))throw new Error("invalid field element: outside of range 0..ORDER");return f}invertBatch(t){return Ve(this,t)}cmov(t,e,n){return yt(n,"condition"),n?e:t}};Object.freeze(_r.prototype);function Ee(r,t={}){return new _r(r,t)}function Fs(r){if(typeof r!="bigint")throw new Error("field order must be bigint");if(r<=V)throw new Error("field order must be greater than 1");let t=we(r-V);return Math.ceil(t/8)}function zn(r){let t=Fs(r);return t+Math.ceil(t/2)}function Hn(r,t,e=!1){M(r);let n=r.length,o=Fs(t),s=Math.max(zn(t),16);if(n<s||n>1024)throw new Error("expected "+s+"-1024 bytes of input, got "+n);let i=e?vt(r):Qt(r),c=Y(i,t-V)+V;return e?Kn(c,o):wr(c,o)}var _e=BigInt(0),ee=BigInt(1);function je(r,t){let e=t.negate();return r?e:t}function re(r,t){let e=Ve(r.Fp,t.map(n=>n.Z));return t.map((n,o)=>r.fromAffine(n.toAffine(e[o])))}function Ks(r,t){if(!Number.isSafeInteger(r)||r<=0||r>t)throw new Error("invalid window size, expected [1.."+t+"], got W="+r)}function qn(r,t){Ks(r,t);let e=Math.ceil(t/r)+1,n=2**(r-1),o=2**r,s=qe(r),i=BigInt(r);return{windows:e,windowSize:n,mask:s,maxNumber:o,shiftBy:i}}function Os(r,t,e){let{windowSize:n,mask:o,maxNumber:s,shiftBy:i}=e,c=Number(r&o),f=r>>i;c>n&&(c-=s,f+=ee);let a=t*n,u=a+Math.abs(c)-1,h=c===0,w=c<0,p=t%2!==0;return{nextN:f,offset:u,isZero:h,isNeg:w,isNegF:p,offsetF:a}}var Vn=new WeakMap,Ns=new WeakMap;function jn(r){return Ns.get(r)||1}function Us(r){if(r!==_e)throw new Error("invalid wNAF")}var Se=class{BASE;ZERO;Fn;bits;constructor(t,e){this.BASE=t.BASE,this.ZERO=t.ZERO,this.Fn=t.Fn,this.bits=e}_unsafeLadder(t,e,n=this.ZERO){let o=t;for(;e>_e;)e&ee&&(n=n.add(o)),o=o.double(),e>>=ee;return n}precomputeWindow(t,e){let{windows:n,windowSize:o}=qn(e,this.bits),s=[],i=t,c=i;for(let f=0;f<n;f++){c=i,s.push(c);for(let a=1;a<o;a++)c=c.add(i),s.push(c);i=c.double()}return s}wNAF(t,e,n){if(!this.Fn.isValid(n))throw new Error("invalid scalar");let o=this.ZERO,s=this.BASE,i=qn(t,this.bits);for(let c=0;c<i.windows;c++){let{nextN:f,offset:a,isZero:u,isNeg:h,isNegF:w,offsetF:p}=Os(n,c,i);n=f,u?s=s.add(je(w,e[p])):o=o.add(je(h,e[a]))}return Us(n),{p:o,f:s}}wNAFUnsafe(t,e,n,o=this.ZERO){let s=qn(t,this.bits);for(let i=0;i<s.windows&&n!==_e;i++){let{nextN:c,offset:f,isZero:a,isNeg:u}=Os(n,i,s);if(n=c,!a){let h=e[f];o=o.add(u?h.negate():h)}}return Us(n),o}getPrecomputes(t,e,n){let o=Vn.get(e);return o||(o=this.precomputeWindow(e,t),t!==1&&(typeof n=="function"&&(o=n(o)),Vn.set(e,o))),o}cached(t,e,n){let o=jn(t);return this.wNAF(o,this.getPrecomputes(o,t,n),e)}unsafe(t,e,n,o){let s=jn(t);return s===1?this._unsafeLadder(t,e,o):this.wNAFUnsafe(s,this.getPrecomputes(s,t,n),e,o)}createCache(t,e){Ks(e,this.bits),Ns.set(t,e),Vn.delete(t)}hasCache(t){return jn(t)!==1}};function Ms(r,t,e,n){let o=t,s=r.ZERO,i=r.ZERO;for(;e>_e||n>_e;)e&ee&&(s=s.add(o)),n&ee&&(i=i.add(o)),o=o.double(),e>>=ee,n>>=ee;return{p1:s,p2:i}}function ks(r,t,e){if(t){if(t.ORDER!==r)throw new Error("Field.ORDER must match order: Fp == p, Fn == n");return Pn(t),t}else return Ee(r,{isLE:e})}function Sr(r,t,e={},n){if(n===void 0&&(n=r==="edwards"),!t||typeof t!="object")throw new Error(`expected valid ${r} CURVE object`);for(let f of["p","n","h"]){let a=t[f];if(!(typeof a=="bigint"&&a>_e))throw new Error(`CURVE.${f} must be positive bigint`)}let o=ks(t.p,e.Fp,n),s=ks(t.n,e.Fn,n),c=["Gx","Gy","a",r==="weierstrass"?"b":"d"];for(let f of c)if(!o.isValid(t[f]))throw new Error(`CURVE.${f} must be valid field element of CURVE.Fp`);return t=Object.freeze(Object.assign({},t)),{CURVE:t,Fp:o,Fn:s}}function vr(r,t){return function(n){let o=r(n);return{secretKey:o,publicKey:t(o)}}}var Mt=BigInt(0),Q=BigInt(1),Zn=BigInt(2),Aa=BigInt(8);function Ba(r,t,e,n){let o=r.sqr(e),s=r.sqr(n),i=r.add(r.mul(t.a,o),s),c=r.add(r.ONE,r.mul(t.d,r.mul(o,s)));return r.eql(i,c)}function Ps(r,t={}){let e=t,n=Sr("edwards",r,e,e.FpFnLE),{Fp:o,Fn:s}=n,i=n.CURVE,{h:c}=i;xt(e,{},{uvRatio:"function"});let f=Zn<<BigInt(s.BYTES*8)-Q,a=_=>o.create(_),u=e.uvRatio===void 0?(_,d)=>{try{return{isValid:!0,value:o.sqrt(o.div(_,d))}}catch{return{isValid:!1,value:Mt}}}:e.uvRatio;if(!Ba(o,i,i.Gx,i.Gy))throw new Error("bad curve params: generator point");function h(_,d,x=!1){let S=x?Q:Mt;return xe("coordinate "+_,d,S,f),d}function w(_){if(!(_ instanceof p))throw new Error("EdwardsPoint expected")}class p{static BASE=new p(i.Gx,i.Gy,Q,a(i.Gx*i.Gy));static ZERO=new p(Mt,Q,Q,Mt);static Fp=o;static Fn=s;X;Y;Z;T;constructor(d,x,S,A){this.X=h("x",d),this.Y=h("y",x),this.Z=h("z",S,!0),this.T=h("t",A),Object.freeze(this)}static CURVE(){return i}static fromAffine(d){if(d instanceof p)throw new Error("extended point not allowed");let{x,y:S}=d||{};return h("x",x),h("y",S),new p(x,S,Q,a(x*S))}static fromBytes(d,x=!1){let S=o.BYTES,{a:A,d:C}=i;d=He(M(d,S,"point")),yt(x,"zip215");let L=He(d),O=d[S-1];L[S-1]=O&-129;let R=vt(L),I=x?f:o.ORDER;xe("point.y",R,Mt,I);let U=a(R*R),z=a(U-Q),k=a(C*U-A),{isValid:l,value:m}=u(z,k);if(!l)throw new Error("bad point: invalid y coordinate");let E=(m&Q)===Q,g=(O&128)!==0;if(!x&&m===Mt&&g)throw new Error("bad point: x=0 and x_0=1");return g!==E&&(m=a(-m)),p.fromAffine({x:m,y:R})}static fromHex(d,x=!1){return p.fromBytes(ge(d),x)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}precompute(d=8,x=!0){return y.createCache(this,d),x||this.multiply(Zn),this}assertValidity(){let d=this,{a:x,d:S}=i;if(d.is0())throw new Error("bad point: ZERO");let{X:A,Y:C,Z:L,T:O}=d,R=a(A*A),I=a(C*C),U=a(L*L),z=a(U*U),k=a(R*x),l=a(U*a(k+I)),m=a(z+a(S*a(R*I)));if(l!==m)throw new Error("bad point: equation left != right (1)");let E=a(A*C),g=a(L*O);if(E!==g)throw new Error("bad point: equation left != right (2)")}equals(d){w(d);let{X:x,Y:S,Z:A}=this,{X:C,Y:L,Z:O}=d,R=a(x*O),I=a(C*A),U=a(S*O),z=a(L*A);return R===I&&U===z}is0(){return this.equals(p.ZERO)}negate(){return new p(a(-this.X),this.Y,this.Z,a(-this.T))}double(){let{a:d}=i,{X:x,Y:S,Z:A}=this,C=a(x*x),L=a(S*S),O=a(Zn*a(A*A)),R=a(d*C),I=x+S,U=a(a(I*I)-C-L),z=R+L,k=z-O,l=R-L,m=a(U*k),E=a(z*l),g=a(U*l),b=a(k*z);return new p(m,E,b,g)}add(d){w(d);let{a:x,d:S}=i,{X:A,Y:C,Z:L,T:O}=this,{X:R,Y:I,Z:U,T:z}=d,k=a(A*R),l=a(C*I),m=a(O*S*z),E=a(L*U),g=a((A+C)*(R+I)-k-l),b=E-m,v=E+m,T=a(l-x*k),B=a(g*b),D=a(v*T),F=a(g*T),N=a(b*v);return new p(B,D,N,F)}subtract(d){return w(d),this.add(d.negate())}multiply(d){if(!s.isValidNot0(d))throw new RangeError("invalid scalar: expected 1 <= sc < curve.n");let{p:x,f:S}=y.cached(this,d,A=>re(p,A));return re(p,[x,S])[0]}multiplyUnsafe(d){if(!s.isValid(d))throw new RangeError("invalid scalar: expected 0 <= sc < curve.n");return d===Mt?p.ZERO:this.is0()||d===Q?this:y.unsafe(this,d,x=>re(p,x))}isSmallOrder(){return this.clearCofactor().is0()}isTorsionFree(){return y.unsafe(this,i.n).is0()}toAffine(d){let x=this,S=d,{X:A,Y:C,Z:L}=x,O=x.is0();S==null&&(S=O?Aa:o.inv(L));let R=a(A*S),I=a(C*S),U=o.mul(L,S);if(O)return{x:Mt,y:Q};if(U!==Q)throw new Error("invZ was invalid");return{x:R,y:I}}clearCofactor(){return c===Q?this:this.multiplyUnsafe(c)}toBytes(){let{x:d,y:x}=this.toAffine(),S=o.toBytes(x);return S[S.length-1]|=d&Q?128:0,S}toHex(){return ye(this.toBytes())}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}}let y=new Se(p,s.BITS);return s.BITS>=8&&p.BASE.precompute(8),Object.freeze(p.prototype),Object.freeze(p),p}var Ar=class{static BASE;static ZERO;static Fp;static Fn;ep;constructor(t){this.ep=t}static fromBytes(t){Nn()}static fromHex(t){Nn()}get x(){return this.toAffine().x}get y(){return this.toAffine().y}clearCofactor(){return this}assertValidity(){this.ep.assertValidity()}toAffine(t){return this.ep.toAffine(t)}toHex(){return ye(this.toBytes())}toString(){return this.toHex()}isTorsionFree(){return!0}isSmallOrder(){return!1}add(t){return this.assertSame(t),this.init(this.ep.add(t.ep))}subtract(t){return this.assertSame(t),this.init(this.ep.subtract(t.ep))}multiply(t){return this.init(this.ep.multiply(t))}multiplyUnsafe(t){return this.init(this.ep.multiplyUnsafe(t))}double(){return this.init(this.ep.double())}negate(){return this.init(this.ep.negate())}precompute(t,e){return this.ep.precompute(t,e),this}};function zs(r,t,e={}){if(typeof t!="function")throw new Error('"hash" function param is required');let n=t,o=e;xt(o,{},{adjustScalarBytes:"function",randomBytes:"function",domain:"function",prehash:"function",zip215:"boolean",mapToCurve:"function"});let{prehash:s}=o,{BASE:i,Fp:c,Fn:f}=r,a=n.outputLen,u=2*c.BYTES;if(a!==void 0&&(gt(a,"hash.outputLen"),a!==u))throw new Error(`hash.outputLen must be ${u}, got ${a}`);let h=o.randomBytes===void 0?Pe:o.randomBytes,w=o.adjustScalarBytes===void 0?l=>l:o.adjustScalarBytes,p=o.domain===void 0?(l,m,E)=>{if(yt(E,"phflag"),m.length||E)throw new Error("Contexts/pre-hash are not supported");return l}:o.domain;function y(l){return f.create(vt(l))}function _(l){let m=R.secretKey;M(l,R.secretKey,"secretKey");let E=M(n(l),2*m,"hashedSecretKey"),g=w(E.slice(0,m)),b=E.slice(m,2*m),v=y(g);return{head:g,prefix:b,scalar:v}}function d(l){let{head:m,prefix:E,scalar:g}=_(l),b=i.multiply(g),v=b.toBytes();return{head:m,prefix:E,scalar:g,point:b,pointBytes:v}}function x(l){return d(l).pointBytes}function S(l=Uint8Array.of(),...m){let E=G(...m);return y(n(p(E,M(l,void 0,"context"),!!s)))}function A(l,m,E={}){l=M(l,void 0,"message"),s&&(l=s(l));let{prefix:g,scalar:b,pointBytes:v}=d(m),T=S(E.context,g,l),B=i.multiply(T).toBytes(),D=S(E.context,B,v,l),F=f.create(T+D*b);if(!f.isValid(F))throw new Error("sign failed: invalid s");let N=G(B,f.toBytes(F));return M(N,R.signature,"result")}let C={zip215:o.zip215};function L(l,m,E,g=C){let{context:b}=g,v=g.zip215===void 0?!!C.zip215:g.zip215,T=R.signature;l=M(l,T,"signature"),m=M(m,void 0,"message"),E=M(E,R.publicKey,"publicKey"),v!==void 0&&yt(v,"zip215"),s&&(m=s(m));let B=T/2,D=l.subarray(0,B),F=vt(l.subarray(B,T)),N,P,K;try{N=r.fromBytes(E,v),P=r.fromBytes(D,v),K=i.multiplyUnsafe(F)}catch{return!1}if(!v&&N.isSmallOrder())return!1;let $=S(b,D,E,m);return P.add(N.multiplyUnsafe($)).subtract(K).clearCofactor().is0()}let O=c.BYTES,R={secretKey:O,publicKey:O,signature:2*O,seed:O};function I(l){return l=l===void 0?h(R.seed):l,M(l,R.seed,"seed")}function U(l){return Jt(l)&&l.length===R.secretKey}function z(l,m){try{return!!r.fromBytes(l,m===void 0?C.zip215:m)}catch{return!1}}let k={getExtendedPublicKey:d,randomSecretKey:I,isValidSecretKey:U,isValidPublicKey:z,toMontgomery(l){let{y:m}=r.fromBytes(l),E=R.publicKey,g=E===32;if(!g&&E!==57)throw new Error("only defined for 25519 and 448");let b=g?c.div(Q+m,Q-m):c.div(m-Q,m+Q);return c.toBytes(b)},toMontgomerySecret(l){let m=R.secretKey;M(l,m);let E=n(l.subarray(0,m));return w(E).subarray(0,m)}};return Object.freeze(R),Object.freeze(k),Object.freeze({keygen:vr(I,x),getPublicKey:x,sign:A,verify:L,utils:k,Point:r,lengths:R})}function Ze(r,t){if(gt(r),gt(t),t<0||t>4)throw new Error("invalid I2OSP length: "+t);if(r<0||r>2**(8*t)-1)throw new Error("invalid I2OSP input: "+r);let e=Array.from({length:t}).fill(0);for(let n=t-1;n>=0;n--)e[n]=r&255,r>>>=8;return new Uint8Array(e)}function Ia(r,t){let e=new Uint8Array(r.length);for(let n=0;n<r.length;n++)e[n]=r[n]^t[n];return e}function Ta(r){if(!Jt(r)&&typeof r!="string")throw new Error("DST must be Uint8Array or ascii string");let t=typeof r=="string"?Er(r):r;if(t.length===0)throw new Error("DST must be non-empty");return t}function Yn(r,t,e,n){M(r),gt(e),t=Ta(t),t.length>255&&(t=n(G(Er("H2C-OVERSIZE-DST-"),t)));let{outputLen:o,blockLen:s}=n,i=Math.ceil(e/o);if(e>65535||i>255)throw new Error("expand_message_xmd: invalid lenInBytes");let c=G(t,Ze(t.length,1)),f=new Uint8Array(s),a=Ze(e,2),u=new Array(i),h=n(G(f,r,a,Ze(0,1),c));u[0]=n(G(h,Ze(1,1),c));for(let p=1;p<i;p++){let y=[Ia(h,u[p-1]),Ze(p+1,1),c];u[p]=n(G(...y))}return G(...u).slice(0,e)}var Hs="HashToScalar-";var La=BigInt(0),Ft=BigInt(1),qs=BigInt(2);var Da=BigInt(5),Ca=BigInt(8),ve=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffed"),Wn={p:ve,n:BigInt("0x1000000000000000000000000000000014def9dea2f79cd65812631a5cf5d3ed"),h:Ca,a:BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffec"),d:BigInt("0x52036cee2b6ffe738cc740797779e89800700a4d4141d8ab75eb4dca135978a3"),Gx:BigInt("0x216936d3cd6e53fec0a4e231fdd6dc5c692cc7609525a7b2c9562d608f25d51a"),Gy:BigInt("0x6666666666666666666666666666666666666666666666666666666666666658")};function Ra(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),o=BigInt(80),s=ve,c=r*r%s*r%s,f=H(c,qs,s)*c%s,a=H(f,Ft,s)*r%s,u=H(a,Da,s)*a%s,h=H(u,t,s)*u%s,w=H(h,e,s)*h%s,p=H(w,n,s)*w%s,y=H(p,o,s)*p%s,_=H(y,o,s)*p%s,d=H(_,t,s)*u%s;return{pow_p_5_8:H(d,qs,s)*r%s,b2:c}}function Fa(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}var $n=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752");function Jn(r,t){let e=ve,n=Y(t*t*t,e),o=Y(n*n*t,e),s=Ra(r*o).pow_p_5_8,i=Y(r*n*s,e),c=Y(t*i*i,e),f=i,a=Y(i*$n,e),u=c===r,h=c===Y(-r,e),w=c===Y(-r*$n,e);return u&&(i=f),(h||w)&&(i=a),Rt(i,e)&&(i=Y(-i,e)),{isValid:u||h,value:i}}var zt=Ps(Wn,{uvRatio:Jn}),Pt=zt.Fp,Zs=zt.Fn;function Oa(r){return zs(zt,br,Object.assign({adjustScalarBytes:Fa,zip215:!0},r))}var Ys=Oa({});var Gn=$n,Ua=BigInt("25063068953384623474111414158702152701244531502492656460079210482610430750235"),ka=BigInt("54469307008909316920995813868745141605393597292927456921205312896311721017578"),Ka=BigInt("1159843021668779879193775521855586647937357759715417654439879720876111806838"),Na=BigInt("40440834346308536858101042469323190826248399146238708352240133220865137265952"),Vs=r=>Jn(Ft,r),Ma=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"),Xn=r=>Pt.create(vt(r)&Ma);function js(r){let{d:t}=Wn,e=ve,n=x=>Pt.create(x),o=n(Gn*r*r),s=n((o+Ft)*Ka),i=BigInt(-1),c=n((i-t*o)*n(o+t)),{isValid:f,value:a}=Jn(s,c),u=n(a*r);Rt(u,e)||(u=n(-u)),f||(a=u),f||(i=o);let h=n(i*(o-Ft)*Na-c),w=a*a,p=n((a+a)*c),y=n(h*Ua),_=n(Ft-w),d=n(Ft+w);return new zt(n(p*d),n(_*y),n(y*d),n(p*_))}var Ht=class r extends Ar{static BASE=new r(zt.BASE);static ZERO=new r(zt.ZERO);static Fp=Pt;static Fn=Zs;constructor(t){super(t)}static fromAffine(t){return new r(zt.fromAffine(t))}assertSame(t){if(!(t instanceof r))throw new Error("RistrettoPoint expected")}init(t){return new r(t)}static fromBytes(t){ht(t,32);let{a:e,d:n}=Wn,o=ve,s=C=>Pt.create(C),i=Xn(t);if(!Es(Pt.toBytes(i),t)||Rt(i,o))throw new Error("invalid ristretto255 encoding 1");let c=s(i*i),f=s(Ft+e*c),a=s(Ft-e*c),u=s(f*f),h=s(a*a),w=s(e*n*u-h),{isValid:p,value:y}=Vs(s(w*h)),_=s(y*a),d=s(y*_*w),x=s((i+i)*_);Rt(x,o)&&(x=s(-x));let S=s(f*d),A=s(x*S);if(!p||Rt(A,o)||S===La)throw new Error("invalid ristretto255 encoding 2");return new r(new zt(x,S,Ft,A))}static fromHex(t){return r.fromBytes(ke(t))}toBytes(){let{X:t,Y:e,Z:n,T:o}=this.ep,s=ve,i=d=>Pt.create(d),c=i(i(n+e)*i(n-e)),f=i(t*e),a=i(f*f),{value:u}=Vs(i(c*a)),h=i(u*c),w=i(u*f),p=i(h*w*o),y;if(Rt(o*p,s)){let d=i(e*Gn),x=i(t*Gn);t=d,e=x,y=i(h*ka)}else y=w;Rt(t*p,s)&&(e=i(-e));let _=i((n-e)*y);return Rt(_,s)&&(_=i(-_)),Pt.toBytes(_)}equals(t){this.assertSame(t);let{X:e,Y:n}=this.ep,{X:o,Y:s}=t.ep,i=a=>Pt.create(a),c=i(e*s)===i(n*o),f=i(n*s)===i(e*o);return c||f}is0(){return this.equals(r.ZERO)}};Object.freeze(Ht.BASE);Object.freeze(Ht.ZERO);Object.freeze(Ht.prototype);Object.freeze(Ht);var Pa=Object.freeze({Point:Ht,hashToCurve(r,t){let e=t?.DST===void 0?"ristretto255_XMD:SHA-512_R255MAP_RO_":t.DST,n=Yn(r,e,64,br);return Pa.deriveToCurve(n)},hashToScalar(r,t={DST:Hs}){let e=Yn(r,t.DST,64,br);return Zs.create(vt(e))},deriveToCurve(r){ht(r,64);let t=Xn(r.subarray(0,32)),e=js(t),n=Xn(r.subarray(32,64)),o=js(n);return new Ht(e.add(o))}});var Ye=class extends Error{constructor(t="An error occurred while verifying a message"){super(t),this.name="VerificationError"}},Br=class extends Error{constructor(t="Missing Web Crypto API"){super(t),this.name="WebCryptoMissingError"}};var $s={get(r=globalThis){let t=r.crypto;if(t?.subtle==null)throw new Br("Missing Web Crypto API. The most likely cause of this error is that this page is being accessed from an insecure context (i.e. not HTTPS). For more information and possible resolutions see https://github.com/libp2p/js-libp2p/blob/main/packages/crypto/README.md#web-crypto-api");return t}};var Ir=$s;var Tr=32;var Qn,za=(async()=>{try{return await Ir.get().subtle.generateKey({name:"Ed25519"},!0,["sign","verify"]),!0}catch{return!1}})();async function Ha(r,t,e){if(r.buffer instanceof ArrayBuffer){let n=await Ir.get().subtle.importKey("raw",r.buffer,{name:"Ed25519"},!1,["verify"]);return await Ir.get().subtle.verify({name:"Ed25519"},n,t,e instanceof Uint8Array?e:e.subarray())}throw new TypeError("WebCrypto does not support SharedArrayBuffer for Ed25519 keys")}function qa(r,t,e){return Ys.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}async function Gs(r,t,e){return Qn==null&&(Qn=await za),Qn?Ha(r,t,e):qa(r,t,e)}function Lr(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}var Dr=class{type="Ed25519";raw;constructor(t){this.raw=to(t,Tr)}toMultihash(){return pt.digest(me(this))}toCID(){return it.createV1(114,this.toMultihash())}toString(){return Z.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:at(this.raw,t.raw)}verify(t,e,n){n?.signal?.throwIfAborted();let o=Gs(this.raw,e,t);return Lr(o)?o.then(s=>(n?.signal?.throwIfAborted(),s)):o}};function Ws(r){return r=to(r,Tr),new Dr(r)}function to(r,t){if(r=Uint8Array.from(r??[]),r.length!==t)throw new It(`Key must be a Uint8Array of length ${t}, got ${r.length}`);return r}var ja=Math.pow(2,7),Za=Math.pow(2,14),Ya=Math.pow(2,21),Js=Math.pow(2,28),Qs=Math.pow(2,35),ti=Math.pow(2,42),ei=Math.pow(2,49),nt=128,qt=127;function $e(r){if(r<ja)return 1;if(r<Za)return 2;if(r<Ya)return 3;if(r<Js)return 4;if(r<Qs)return 5;if(r<ti)return 6;if(r<ei)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function ri(r,t,e=0){switch($e(r)){case 8:t[e++]=r&255|nt,r/=128;case 7:t[e++]=r&255|nt,r/=128;case 6:t[e++]=r&255|nt,r/=128;case 5:t[e++]=r&255|nt,r/=128;case 4:t[e++]=r&255|nt,r>>>=7;case 3:t[e++]=r&255|nt,r>>>=7;case 2:t[e++]=r&255|nt,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function ni(r,t){let e=r[t],n=0;if(n+=e&qt,e<nt||(e=r[t+1],n+=(e&qt)<<7,e<nt)||(e=r[t+2],n+=(e&qt)<<14,e<nt)||(e=r[t+3],n+=(e&qt)<<21,e<nt)||(e=r[t+4],n+=(e&qt)*Js,e<nt)||(e=r[t+5],n+=(e&qt)*Qs,e<nt)||(e=r[t+6],n+=(e&qt)*ti,e<nt)||(e=r[t+7],n+=(e&qt)*ei,e<nt))return n;throw new RangeError("Could not decode varint")}var eo=new Float32Array([-0]),Vt=new Uint8Array(eo.buffer);function oi(r,t,e){eo[0]=r,t[e]=Vt[0],t[e+1]=Vt[1],t[e+2]=Vt[2],t[e+3]=Vt[3]}function si(r,t){return Vt[0]=r[t],Vt[1]=r[t+1],Vt[2]=r[t+2],Vt[3]=r[t+3],eo[0]}var ro=new Float64Array([-0]),rt=new Uint8Array(ro.buffer);function ii(r,t,e){ro[0]=r,t[e]=rt[0],t[e+1]=rt[1],t[e+2]=rt[2],t[e+3]=rt[3],t[e+4]=rt[4],t[e+5]=rt[5],t[e+6]=rt[6],t[e+7]=rt[7]}function ci(r,t){return rt[0]=r[t],rt[1]=r[t+1],rt[2]=r[t+2],rt[3]=r[t+3],rt[4]=r[t+4],rt[5]=r[t+5],rt[6]=r[t+6],rt[7]=r[t+7],ro[0]}var $a=BigInt(Number.MAX_SAFE_INTEGER),Ga=BigInt(Number.MIN_SAFE_INTEGER),lt=class r{lo;hi;constructor(t,e){this.lo=t|0,this.hi=e|0}toNumber(t=!1){if(!t&&this.hi>>>31>0){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(e+n*4294967296)}return this.lo+this.hi*4294967296}toBigInt(t=!1){if(t)return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n);if(this.hi>>>31){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(BigInt(e)+(BigInt(n)<<32n))}return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n)}toString(t=!1){return this.toBigInt(t).toString()}zzEncode(){let t=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^t)>>>0,this.lo=(this.lo<<1^t)>>>0,this}zzDecode(){let t=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^t)>>>0,this.hi=(this.hi>>>1^t)>>>0,this}length(){let t=this.lo,e=(this.lo>>>28|this.hi<<4)>>>0,n=this.hi>>>24;return n===0?e===0?t<16384?t<128?1:2:t<2097152?3:4:e<16384?e<128?5:6:e<2097152?7:8:n<128?9:10}static fromBigInt(t){if(t===0n)return ne;if(t<$a&&t>Ga)return this.fromNumber(Number(t));let e=t<0n;e&&(t=-t);let n=t>>32n,o=t-(n<<32n);return e&&(n=~n|0n,o=~o|0n,++o>ai&&(o=0n,++n>ai&&(n=0n))),new r(Number(o),Number(n))}static fromNumber(t){if(t===0)return ne;let e=t<0;e&&(t=-t);let n=t>>>0,o=(t-n)/4294967296>>>0;return e&&(o=~o>>>0,n=~n>>>0,++n>4294967295&&(n=0,++o>4294967295&&(o=0))),new r(n,o)}static from(t){return typeof t=="number"?r.fromNumber(t):typeof t=="bigint"?r.fromBigInt(t):typeof t=="string"?r.fromBigInt(BigInt(t)):t.low!=null||t.high!=null?new r(t.low>>>0,t.high>>>0):ne}},ne=new lt(0,0);ne.toBigInt=function(){return 0n};ne.zzEncode=ne.zzDecode=function(){return this};ne.length=function(){return 1};var ai=4294967296n;function fi(r){let t=0,e=0;for(let n=0;n<r.length;++n)e=r.charCodeAt(n),e<128?t+=1:e<2048?t+=2:(e&64512)===55296&&(r.charCodeAt(n+1)&64512)===56320?(++n,t+=4):t+=3;return t}function ui(r,t,e){if(e-t<1)return"";let o,s=[],i=0,c;for(;t<e;)c=r[t++],c<128?s[i++]=c:c>191&&c<224?s[i++]=(c&31)<<6|r[t++]&63:c>239&&c<365?(c=((c&7)<<18|(r[t++]&63)<<12|(r[t++]&63)<<6|r[t++]&63)-65536,s[i++]=55296+(c>>10),s[i++]=56320+(c&1023)):s[i++]=(c&15)<<12|(r[t++]&63)<<6|r[t++]&63,i>8191&&((o??(o=[])).push(String.fromCharCode.apply(String,s)),i=0);return o!=null?(i>0&&o.push(String.fromCharCode.apply(String,s.slice(0,i))),o.join("")):String.fromCharCode.apply(String,s.slice(0,i))}function no(r,t,e){let n=e,o,s;for(let i=0;i<r.length;++i)o=r.charCodeAt(i),o<128?t[e++]=o:o<2048?(t[e++]=o>>6|192,t[e++]=o&63|128):(o&64512)===55296&&((s=r.charCodeAt(i+1))&64512)===56320?(o=65536+((o&1023)<<10)+(s&1023),++i,t[e++]=o>>18|240,t[e++]=o>>12&63|128,t[e++]=o>>6&63|128,t[e++]=o&63|128):(t[e++]=o>>12|224,t[e++]=o>>6&63|128,t[e++]=o&63|128);return e-n}function wt(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function Cr(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var oo=class{buf;pos;len;_slice=Uint8Array.prototype.subarray;constructor(t){this.buf=t,this.pos=0,this.len=t.length}uint32(){let t=4294967295;if(t=(this.buf[this.pos]&127)>>>0,this.buf[this.pos++]<128||(t=(t|(this.buf[this.pos]&127)<<7)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<14)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<21)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&15)<<28)>>>0,this.buf[this.pos++]<128))return t;if((this.pos+=5)>this.len)throw this.pos=this.len,wt(this,10);return t}int32(){return this.uint32()|0}sint32(){let t=this.uint32();return t>>>1^-(t&1)|0}bool(){return this.uint32()!==0}fixed32(){if(this.pos+4>this.len)throw wt(this,4);return Cr(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw wt(this,4);return Cr(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw wt(this,4);let t=si(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw wt(this,4);let t=ci(this.buf,this.pos);return this.pos+=8,t}bytes(){let t=this.uint32(),e=this.pos,n=this.pos+t;if(n>this.len)throw wt(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return ui(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw wt(this,t);this.pos+=t}else do if(this.pos>=this.len)throw wt(this);while((this.buf[this.pos++]&128)!==0);return this}skipType(t){switch(t){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;(t=this.uint32()&7)!==4;)this.skipType(t);break;case 5:this.skip(4);break;default:throw Error(`invalid wire type ${t} at offset ${this.pos}`)}return this}readLongVarint(){let t=new lt(0,0),e=0;if(this.len-this.pos>4){for(;e<4;++e)if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t;if(t.lo=(t.lo|(this.buf[this.pos]&127)<<28)>>>0,t.hi=(t.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return t;e=0}else{for(;e<3;++e){if(this.pos>=this.len)throw wt(this);if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t}return t.lo=(t.lo|(this.buf[this.pos++]&127)<<e*7)>>>0,t}if(this.len-this.pos>4){for(;e<5;++e)if(t.hi=(t.hi|(this.buf[this.pos]&127)<<e*7+3)>>>0,this.buf[this.pos++]<128)return t}else for(;e<5;++e){if(this.pos>=this.len)throw wt(this);if(t.hi=(t.hi|(this.buf[this.pos]&127)<<e*7+3)>>>0,this.buf[this.pos++]<128)return t}throw Error("invalid varint encoding")}readFixed64(){if(this.pos+8>this.len)throw wt(this,8);let t=Cr(this.buf,this.pos+=4),e=Cr(this.buf,this.pos+=4);return new lt(t,e)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){let t=ni(this.buf,this.pos);return this.pos+=$e(t),t}uint64String(){return this.readLongVarint().toString(!0)}sint64(){return this.readLongVarint().zzDecode().toBigInt()}sint64Number(){return this.readLongVarint().zzDecode().toNumber()}sint64String(){return this.readLongVarint().zzDecode().toString()}fixed64(){return this.readFixed64().toBigInt()}fixed64Number(){return this.readFixed64().toNumber()}fixed64String(){return this.readFixed64().toString()}sfixed64(){return this.readFixed64().toBigInt()}sfixed64Number(){return this.readFixed64().toNumber()}sfixed64String(){return this.readFixed64().toString()}};function Ge(r){return new oo(r instanceof Uint8Array?r:r.subarray())}function Rr(r,t,e){let n=Ge(r);return t.decode(n,void 0,e)}function so(r){let t=r??8192,e=t>>>1,n,o=t;return function(i){if(i<1||i>e)return ft(i);o+i>t&&(n=ft(t),o=0);let c=n.subarray(o,o+=i);return(o&7)!==0&&(o=(o|7)+1),c}}var oe=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function io(){}var ao=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},Xa=so();function Wa(r){return globalThis.Buffer!=null?ft(r):Xa(r)}var We=class{len;head;tail;states;constructor(){this.len=0,this.head=new oe(io,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new oe(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new fo((t=t>>>0)<128?1:t<16384?2:t<2097152?3:t<268435456?4:5,t)).len,this}int32(t){return t<0?this._push(Fr,10,lt.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=lt.fromBigInt(t);return this._push(Fr,e.length(),e)}uint64Number(t){return this._push(ri,$e(t),t)}uint64String(t){return this.uint64(BigInt(t))}int64(t){return this.uint64(t)}int64Number(t){return this.uint64Number(t)}int64String(t){return this.uint64String(t)}sint64(t){let e=lt.fromBigInt(t).zzEncode();return this._push(Fr,e.length(),e)}sint64Number(t){let e=lt.fromNumber(t).zzEncode();return this._push(Fr,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(co,1,t?1:0)}fixed32(t){return this._push(Xe,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=lt.fromBigInt(t);return this._push(Xe,4,e.lo)._push(Xe,4,e.hi)}fixed64Number(t){let e=lt.fromNumber(t);return this._push(Xe,4,e.lo)._push(Xe,4,e.hi)}fixed64String(t){return this.fixed64(BigInt(t))}sfixed64(t){return this.fixed64(t)}sfixed64Number(t){return this.fixed64Number(t)}sfixed64String(t){return this.fixed64String(t)}float(t){return this._push(oi,4,t)}double(t){return this._push(ii,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(co,1,0):this.uint32(e)._push(Qa,e,t)}string(t){let e=fi(t);return e!==0?this.uint32(e)._push(no,e,t):this._push(co,1,0)}fork(){return this.states=new ao(this),this.head=this.tail=new oe(io,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 oe(io,0,0),this.len=0),this}ldelim(){let t=this.head,e=this.tail,n=this.len;return this.reset().uint32(n),n!==0&&(this.tail.next=t.next,this.tail=e,this.len+=n),this}finish(){let t=this.head.next,e=Wa(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function co(r,t,e){t[e]=r&255}function Ja(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var fo=class extends oe{next;constructor(t,e){super(Ja,t,e),this.next=void 0}};function Fr(r,t,e){for(;r.hi!==0;)t[e++]=r.lo&127|128,r.lo=(r.lo>>>7|r.hi<<25)>>>0,r.hi>>>=7;for(;r.lo>127;)t[e++]=r.lo&127|128,r.lo=r.lo>>>7;t[e++]=r.lo}function Xe(r,t,e){t[e]=r&255,t[e+1]=r>>>8&255,t[e+2]=r>>>16&255,t[e+3]=r>>>24}function Qa(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(We.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(tf,t,r),this},We.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(ef,t,r),this});function tf(r,t,e){t.set(r,e)}function ef(r,t,e){r.length<40?no(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(J(r),e)}function uo(){return new We}function Or(r,t){let e=uo();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}function*Ur(r,t,e){let n=Ge(r);yield*t.stream(n,void 0,"$",e)}var kr={VARINT:0,BIT64:1,LENGTH_DELIMITED:2,START_GROUP:3,END_GROUP:4,BIT32:5};function Kr(r,t,e,n,o){return{name:r,type:t,encode:e,decode:n,stream:o}}function ho(r){function t(s){if(r[s.toString()]==null)throw new Error("Invalid enum value");return r[s]}let e=function(i,c){let f=t(i);c.int32(f)},n=function(i){let c=i.int32();return t(c)},o=function*(i){let c=i.int32();yield t(c)};return Kr("enum",kr.VARINT,e,n,o)}function Nr(r,t,e){return Kr("message",kr.LENGTH_DELIMITED,r,t,e)}var ot;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.secp256k1="secp256k1",r.ECDSA="ECDSA"})(ot||(ot={}));var lo;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1",r[r.ECDSA=3]="ECDSA"})(lo||(lo={}));(function(r){r.codec=()=>ho(lo)})(ot||(ot={}));var Je;(function(r){let t;r.codec=()=>(t==null&&(t=Nr((s,i,c={})=>{c.lengthDelimited!==!1&&i.fork(),s.Type!=null&&(i.uint32(8),ot.codec().encode(s.Type,i)),s.Data!=null&&(i.uint32(18),i.bytes(s.Data)),c.lengthDelimited!==!1&&i.ldelim()},(s,i,c={})=>{let f={},a=i==null?s.len:s.pos+i;for(;s.pos<a;){let u=s.uint32();switch(u>>>3){case 1:{f.Type=ot.codec().decode(s);break}case 2:{f.Data=s.bytes();break}default:{s.skipType(u&7);break}}}return f},function*(s,i,c,f={}){let a=i==null?s.len:s.pos+i;for(;s.pos<a;){let u=s.uint32();switch(u>>>3){case 1:{yield{field:`${c}.Type`,value:ot.codec().decode(s)};break}case 2:{yield{field:`${c}.Data`,value:s.bytes()};break}default:{s.skipType(u&7);break}}}})),t);function e(s){return Or(s,r.codec())}r.encode=e;function n(s,i){return Rr(s,r.codec(),i)}r.decode=n;function o(s,i){return Ur(s,r.codec(),i)}r.stream=o})(Je||(Je={}));var po;(function(r){let t;r.codec=()=>(t==null&&(t=Nr((s,i,c={})=>{c.lengthDelimited!==!1&&i.fork(),s.Type!=null&&(i.uint32(8),ot.codec().encode(s.Type,i)),s.Data!=null&&(i.uint32(18),i.bytes(s.Data)),c.lengthDelimited!==!1&&i.ldelim()},(s,i,c={})=>{let f={},a=i==null?s.len:s.pos+i;for(;s.pos<a;){let u=s.uint32();switch(u>>>3){case 1:{f.Type=ot.codec().decode(s);break}case 2:{f.Data=s.bytes();break}default:{s.skipType(u&7);break}}}return f},function*(s,i,c,f={}){let a=i==null?s.len:s.pos+i;for(;s.pos<a;){let u=s.uint32();switch(u>>>3){case 1:{yield{field:`${c}.Type`,value:ot.codec().decode(s)};break}case 2:{yield{field:`${c}.Data`,value:s.bytes()};break}default:{s.skipType(u&7);break}}}})),t);function e(s){return Or(s,r.codec())}r.encode=e;function n(s,i){return Rr(s,r.codec(),i)}r.decode=n;function o(s,i){return Ur(s,r.codec(),i)}r.stream=o})(po||(po={}));var Mr=class{oHash;iHash;blockLen;outputLen;canXOF=!1;finished=!1;destroyed=!1;constructor(t,e){if(hr(t),ht(e,void 0,"key"),this.iHash=t.create(),typeof this.iHash.update!="function")throw new Error("Expected instance of class which extends utils.Hash");this.blockLen=this.iHash.blockLen,this.outputLen=this.iHash.outputLen;let n=this.blockLen,o=new Uint8Array(n);o.set(e.length>n?t.create().update(e).digest():e);for(let s=0;s<o.length;s++)o[s]^=54;this.iHash.update(o),this.oHash=t.create();for(let s=0;s<o.length;s++)o[s]^=106;this.oHash.update(o),Dt(o)}update(t){return be(this),this.iHash.update(t),this}digestInto(t){be(this),lr(t,this),this.finished=!0;let e=t.subarray(0,this.outputLen);this.iHash.digestInto(e),this.oHash.update(e),this.oHash.digestInto(e),this.destroy()}digest(){let t=new Uint8Array(this.oHash.outputLen);return this.digestInto(t),t}_cloneInto(t){t||=Object.create(Object.getPrototypeOf(this),{});let{oHash:e,iHash:n,finished:o,destroyed:s,blockLen:i,outputLen:c}=this;return t=t,t.finished=o,t.destroyed=s,t.blockLen=i,t.outputLen=c,t.oHash=e._cloneInto(t.oHash),t.iHash=n._cloneInto(t.iHash),t}clone(){return this._cloneInto()}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},li=(()=>{let r=((t,e,n)=>new Mr(t,e).update(n).digest());return r.create=(t,e)=>new Mr(t,e),r})();var di=(r,t)=>(r+(r>=0?t:-t)/pi)/t;function nf(r,t,e){xe("scalar",r,At,e);let[[n,o],[s,i]]=t,c=di(i*r,e),f=di(-o*r,e),a=r-c*n-f*s,u=-c*o-f*i,h=a<At,w=u<At;h&&(a=-a),w&&(u=-u);let p=qe(Math.ceil(we(e)/2))+jt;if(a<At||a>=p||u<At||u>=p)throw new Error("splitScalar (endomorphism): failed for k");return{k1neg:h,k1:a,k2neg:w,k2:u}}function bo(r){if(!["compact","recovered","der"].includes(r))throw new Error('Signature format must be "compact", "recovered", or "der"');return r}function mo(r,t){xt(r);let e={};for(let n of Object.keys(t))e[n]=r[n]===void 0?t[n]:r[n];return yt(e.lowS,"lowS"),yt(e.prehash,"prehash"),e.format!==void 0&&bo(e.format),e}var yo=class extends Error{constructor(t=""){super(t)}},Et={Err:yo,_tlv:{encode:(r,t)=>{let{Err:e}=Et;if(gt(r,"tag"),r<0||r>255)throw new e("tlv.encode: wrong tag");if(typeof t!="string")throw new TypeError('"data" expected string, got type='+typeof t);if(t.length&1)throw new e("tlv.encode: unpadded data");let n=t.length/2,o=ze(n);if(o.length/2&128)throw new e("tlv.encode: long form length too big");let s=n>127?ze(o.length/2|128):"";return ze(r)+s+o+t},decode(r,t){let{Err:e}=Et;t=M(t,void 0,"DER data");let n=0;if(r<0||r>255)throw new e("tlv.encode: wrong tag");if(t.length<2||t[n++]!==r)throw new e("tlv.decode: wrong tlv");let o=t[n++],s=!!(o&128),i=0;if(!s)i=o;else{let f=o&127;if(!f)throw new e("tlv.decode(long): indefinite length not supported");if(f>4)throw new e("tlv.decode(long): byte length is too big");let a=t.subarray(n,n+f);if(a.length!==f)throw new e("tlv.decode: length bytes not complete");if(a[0]===0)throw new e("tlv.decode(long): zero leftmost byte");for(let u of a)i=i<<8|u;if(n+=f,i<128)throw new e("tlv.decode(long): not minimal encoding")}let c=t.subarray(n,n+i);if(c.length!==i)throw new e("tlv.decode: wrong value length");return{v:c,l:t.subarray(n+i)}}},_int:{encode(r){let{Err:t}=Et;if(xr(r),r<At)throw new t("integer: negative integers are not allowed");let e=ze(r);if(Number.parseInt(e[0],16)&8&&(e="00"+e),e.length&1)throw new t("unexpected DER parsing assertion: unpadded hex");return e},decode(r){let{Err:t}=Et;if(r.length<1)throw new t("invalid signature integer: empty");if(r[0]&128)throw new t("invalid signature integer: negative");if(r.length>1&&r[0]===0&&!(r[1]&128))throw new t("invalid signature integer: unnecessary leading zero");return Qt(r)}},toSig(r){let{Err:t,_int:e,_tlv:n}=Et,o=M(r,void 0,"signature"),{v:s,l:i}=n.decode(48,o);if(i.length)throw new t("invalid signature: left bytes after parsing");let{v:c,l:f}=n.decode(2,s),{v:a,l:u}=n.decode(2,f);if(u.length)throw new t("invalid signature: left bytes after parsing");return{r:e.decode(c),s:e.decode(a)}},hexFromSig(r){let{_tlv:t,_int:e}=Et,n=t.encode(2,e.encode(r.r)),o=t.encode(2,e.encode(r.s)),s=n+o;return t.encode(48,s)}};Object.freeze(Et._tlv);Object.freeze(Et._int);Object.freeze(Et);var At=BigInt(0),jt=BigInt(1),pi=BigInt(2),Pr=BigInt(3),of=BigInt(4);function mi(r,t={}){let e=Sr("weierstrass",r,t),n=e.Fp,o=e.Fn,s=e.CURVE,{h:i,n:c}=s;xt(t,{},{allowInfinityPoint:"boolean",clearCofactor:"function",isTorsionFree:"function",fromBytes:"function",toBytes:"function",endo:"object"});let{endo:f,allowInfinityPoint:a}=t;if(f&&(!n.is0(s.a)||typeof f.beta!="bigint"||!Array.isArray(f.basises)))throw new Error('invalid endo: expected "beta": bigint and "basises": array');let u=yi(n,o);function h(){if(!n.isOdd)throw new Error("compression is not supported: Field does not have .isOdd()")}function w(k,l,m){if(a&&l.is0())return Uint8Array.of(0);let{x:E,y:g}=l.toAffine(),b=n.toBytes(E);if(yt(m,"isCompressed"),m){h();let v=!n.isOdd(g);return G(bi(v),b)}else return G(Uint8Array.of(4),b,n.toBytes(g))}function p(k){M(k,void 0,"Point");let{publicKey:l,publicKeyUncompressed:m}=u,E=k.length,g=k[0],b=k.subarray(1);if(a&&E===1&&g===0)return{x:n.ZERO,y:n.ZERO};if(E===l&&(g===2||g===3)){let v=n.fromBytes(b);if(!n.isValid(v))throw new Error("bad point: is not on curve, wrong x");let T=d(v),B;try{B=n.sqrt(T)}catch(N){let P=N instanceof Error?": "+N.message:"";throw new Error("bad point: is not on curve, sqrt error"+P)}h();let D=n.isOdd(B);return(g&1)===1!==D&&(B=n.neg(B)),{x:v,y:B}}else if(E===m&&g===4){let v=n.BYTES,T=n.fromBytes(b.subarray(0,v)),B=n.fromBytes(b.subarray(v,v*2));if(!x(T,B))throw new Error("bad point: is not on curve");return{x:T,y:B}}else throw new Error(`bad point: got length ${E}, expected compressed=${l} or uncompressed=${m}`)}let y=t.toBytes===void 0?w:t.toBytes,_=t.fromBytes===void 0?p:t.fromBytes;function d(k){let l=n.sqr(k),m=n.mul(l,k);return n.add(n.add(m,n.mul(k,s.a)),s.b)}function x(k,l){let m=n.sqr(l),E=d(k);return n.eql(m,E)}if(!x(s.Gx,s.Gy))throw new Error("bad curve params: generator point");let S=n.mul(n.pow(s.a,Pr),of),A=n.mul(n.sqr(s.b),BigInt(27));if(n.is0(n.add(S,A)))throw new Error("bad curve params: a or b");function C(k,l,m=!1){if(!n.isValid(l)||m&&n.is0(l))throw new Error(`bad point coordinate ${k}`);return l}function L(k){if(!(k instanceof I))throw new Error("Weierstrass Point expected")}function O(k){if(!f||!f.basises)throw new Error("no endo");return nf(k,f.basises,o.ORDER)}function R(k,l,m,E,g){return m=new I(n.mul(m.X,k),m.Y,m.Z),l=je(E,l),m=je(g,m),l.add(m)}class I{static BASE=new I(s.Gx,s.Gy,n.ONE);static ZERO=new I(n.ZERO,n.ONE,n.ZERO);static Fp=n;static Fn=o;X;Y;Z;constructor(l,m,E){this.X=C("x",l),this.Y=C("y",m,!0),this.Z=C("z",E),Object.freeze(this)}static CURVE(){return s}static fromAffine(l){let{x:m,y:E}=l||{};if(!l||!n.isValid(m)||!n.isValid(E))throw new Error("invalid affine point");if(l instanceof I)throw new Error("projective point not allowed");return n.is0(m)&&n.is0(E)?I.ZERO:new I(m,E,n.ONE)}static fromBytes(l){let m=I.fromAffine(_(M(l,void 0,"point")));return m.assertValidity(),m}static fromHex(l){return I.fromBytes(ge(l))}get x(){return this.toAffine().x}get y(){return this.toAffine().y}precompute(l=8,m=!0){return z.createCache(this,l),m||this.multiply(Pr),this}assertValidity(){let l=this;if(l.is0()){if(t.allowInfinityPoint&&n.is0(l.X)&&n.eql(l.Y,n.ONE)&&n.is0(l.Z))return;throw new Error("bad point: ZERO")}let{x:m,y:E}=l.toAffine();if(!n.isValid(m)||!n.isValid(E))throw new Error("bad point: x or y not field elements");if(!x(m,E))throw new Error("bad point: equation left != right");if(!l.isTorsionFree())throw new Error("bad point: not in prime-order subgroup")}hasEvenY(){let{y:l}=this.toAffine();if(!n.isOdd)throw new Error("Field doesn't support isOdd");return!n.isOdd(l)}equals(l){L(l);let{X:m,Y:E,Z:g}=this,{X:b,Y:v,Z:T}=l,B=n.eql(n.mul(m,T),n.mul(b,g)),D=n.eql(n.mul(E,T),n.mul(v,g));return B&&D}negate(){return new I(this.X,n.neg(this.Y),this.Z)}double(){let{a:l,b:m}=s,E=n.mul(m,Pr),{X:g,Y:b,Z:v}=this,T=n.ZERO,B=n.ZERO,D=n.ZERO,F=n.mul(g,g),N=n.mul(b,b),P=n.mul(v,v),K=n.mul(g,b);return K=n.add(K,K),D=n.mul(g,v),D=n.add(D,D),T=n.mul(l,D),B=n.mul(E,P),B=n.add(T,B),T=n.sub(N,B),B=n.add(N,B),B=n.mul(T,B),T=n.mul(K,T),D=n.mul(E,D),P=n.mul(l,P),K=n.sub(F,P),K=n.mul(l,K),K=n.add(K,D),D=n.add(F,F),F=n.add(D,F),F=n.add(F,P),F=n.mul(F,K),B=n.add(B,F),P=n.mul(b,v),P=n.add(P,P),F=n.mul(P,K),T=n.sub(T,F),D=n.mul(P,N),D=n.add(D,D),D=n.add(D,D),new I(T,B,D)}add(l){L(l);let{X:m,Y:E,Z:g}=this,{X:b,Y:v,Z:T}=l,B=n.ZERO,D=n.ZERO,F=n.ZERO,N=s.a,P=n.mul(s.b,Pr),K=n.mul(m,b),$=n.mul(E,v),X=n.mul(g,T),W=n.add(m,E),j=n.add(b,v);W=n.mul(W,j),j=n.add(K,$),W=n.sub(W,j),j=n.add(m,g);let st=n.add(b,T);return j=n.mul(j,st),st=n.add(K,X),j=n.sub(j,st),st=n.add(E,g),B=n.add(v,T),st=n.mul(st,B),B=n.add($,X),st=n.sub(st,B),F=n.mul(N,j),B=n.mul(P,X),F=n.add(B,F),B=n.sub($,F),F=n.add($,F),D=n.mul(B,F),$=n.add(K,K),$=n.add($,K),X=n.mul(N,X),j=n.mul(P,j),$=n.add($,X),X=n.sub(K,X),X=n.mul(N,X),j=n.add(j,X),K=n.mul($,j),D=n.add(D,K),K=n.mul(st,j),B=n.mul(W,B),B=n.sub(B,K),K=n.mul(W,$),F=n.mul(st,F),F=n.add(F,K),new I(B,D,F)}subtract(l){return L(l),this.add(l.negate())}is0(){return this.equals(I.ZERO)}multiply(l){let{endo:m}=t;if(!o.isValidNot0(l))throw new RangeError("invalid scalar: out of range");let E,g,b=v=>z.cached(this,v,T=>re(I,T));if(m){let{k1neg:v,k1:T,k2neg:B,k2:D}=O(l),{p:F,f:N}=b(T),{p:P,f:K}=b(D);g=N.add(K),E=R(m.beta,F,P,v,B)}else{let{p:v,f:T}=b(l);E=v,g=T}return re(I,[E,g])[0]}multiplyUnsafe(l){let{endo:m}=t,E=this,g=l;if(!o.isValid(g))throw new RangeError("invalid scalar: out of range");if(g===At||E.is0())return I.ZERO;if(g===jt)return E;if(z.hasCache(this))return this.multiply(g);if(m){let{k1neg:b,k1:v,k2neg:T,k2:B}=O(g),{p1:D,p2:F}=Ms(I,E,v,B);return R(m.beta,D,F,b,T)}else return z.unsafe(E,g)}toAffine(l){let m=this,E=l,{X:g,Y:b,Z:v}=m;if(n.eql(v,n.ONE))return{x:g,y:b};let T=m.is0();E==null&&(E=T?n.ONE:n.inv(v));let B=n.mul(g,E),D=n.mul(b,E),F=n.mul(v,E);if(T)return{x:n.ZERO,y:n.ZERO};if(!n.eql(F,n.ONE))throw new Error("invZ was invalid");return{x:B,y:D}}isTorsionFree(){let{isTorsionFree:l}=t;return i===jt?!0:l?l(I,this):z.unsafe(this,c).is0()}clearCofactor(){let{clearCofactor:l}=t;return i===jt?this:l?l(I,this):this.multiplyUnsafe(i)}isSmallOrder(){return i===jt?this.is0():this.clearCofactor().is0()}toBytes(l=!0){return yt(l,"isCompressed"),this.assertValidity(),y(I,this,l)}toHex(l=!0){return ye(this.toBytes(l))}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}}let U=o.BITS,z=new Se(I,t.endo?Math.ceil(U/2):U);return U>=8&&I.BASE.precompute(8),Object.freeze(I.prototype),Object.freeze(I),I}function bi(r){return Uint8Array.of(r?2:3)}function yi(r,t){return{secretKey:t.BYTES,publicKey:1+r.BYTES,publicKeyUncompressed:1+2*r.BYTES,publicKeyHasPrefix:!0,signature:2*t.BYTES}}function sf(r,t={}){let{Fn:e}=r,n=t.randomBytes===void 0?Pe:t.randomBytes,o=Object.assign(yi(r.Fp,e),{seed:Math.max(zn(e.ORDER),16)});function s(p){try{let y=e.fromBytes(p);return e.isValidNot0(y)}catch{return!1}}function i(p,y){let{publicKey:_,publicKeyUncompressed:d}=o;try{let x=p.length;return y===!0&&x!==_||y===!1&&x!==d?!1:!!r.fromBytes(p)}catch{return!1}}function c(p){return p=p===void 0?n(o.seed):p,Hn(M(p,o.seed,"seed"),e.ORDER)}function f(p,y=!0){return r.BASE.multiply(e.fromBytes(p)).toBytes(y)}function a(p){let{secretKey:y,publicKey:_,publicKeyUncompressed:d}=o,x=e._lengths;if(!Jt(p))return;let S=M(p,void 0,"key").length,A=S===_||S===d,C=S===y||!!x?.includes(S);if(!(A&&C))return A}function u(p,y,_=!0){if(a(p)===!0)throw new Error("first arg must be private key");if(a(y)===!1)throw new Error("second arg must be public key");let d=e.fromBytes(p);return r.fromBytes(y).multiply(d).toBytes(_)}let h={isValidSecretKey:s,isValidPublicKey:i,randomSecretKey:c},w=vr(c,f);return Object.freeze(h),Object.freeze(o),Object.freeze({getPublicKey:f,getSharedSecret:u,keygen:w,Point:r,utils:h,lengths:o})}function gi(r,t,e={}){let n=t;hr(n),xt(e,{},{hmac:"function",lowS:"boolean",randomBytes:"function",bits2int:"function",bits2int_modN:"function"}),e=Object.assign({},e);let o=e.randomBytes===void 0?Pe:e.randomBytes,s=e.hmac===void 0?(g,b)=>li(n,g,b):e.hmac,{Fp:i,Fn:c}=r,{ORDER:f,BITS:a}=c,{keygen:u,getPublicKey:h,getSharedSecret:w,utils:p,lengths:y}=sf(r,e),_={prehash:!0,lowS:typeof e.lowS=="boolean"?e.lowS:!0,format:"compact",extraEntropy:!1},d=f*pi+jt<i.ORDER;function x(g){let b=f>>jt;return g>b}function S(g,b){if(!c.isValidNot0(b))throw new Error(`invalid signature ${g}: out of range 1..Point.Fn.ORDER`);return b}function A(){if(d)throw new Error('"recovered" sig type is not supported for cofactor >2 curves')}function C(g,b){bo(b);let v=y.signature,T=b==="compact"?v:b==="recovered"?v+1:void 0;return M(g,T)}class L{r;s;recovery;constructor(b,v,T){if(this.r=S("r",b),this.s=S("s",v),T!=null){if(A(),![0,1,2,3].includes(T))throw new Error("invalid recovery id");this.recovery=T}Object.freeze(this)}static fromBytes(b,v=_.format){C(b,v);let T;if(v==="der"){let{r:N,s:P}=Et.toSig(M(b));return new L(N,P)}v==="recovered"&&(T=b[0],v="compact",b=b.subarray(1));let B=y.signature/2,D=b.subarray(0,B),F=b.subarray(B,B*2);return new L(c.fromBytes(D),c.fromBytes(F),T)}static fromHex(b,v){return this.fromBytes(ge(b),v)}assertRecovery(){let{recovery:b}=this;if(b==null)throw new Error("invalid recovery id: must be present");return b}addRecoveryBit(b){return new L(this.r,this.s,b)}recoverPublicKey(b){let{r:v,s:T}=this,B=this.assertRecovery(),D=B===2||B===3?v+f:v;if(!i.isValid(D))throw new Error("invalid recovery id: sig.r+curve.n != R.x");let F=i.toBytes(D),N=r.fromBytes(G(bi((B&1)===0),F)),P=c.inv(D),K=R(M(b,void 0,"msgHash")),$=c.create(-K*P),X=c.create(T*P),W=r.BASE.multiplyUnsafe($).add(N.multiplyUnsafe(X));if(W.is0())throw new Error("invalid recovery: point at infinify");return W.assertValidity(),W}hasHighS(){return x(this.s)}toBytes(b=_.format){if(bo(b),b==="der")return ge(Et.hexFromSig(this));let{r:v,s:T}=this,B=c.toBytes(v),D=c.toBytes(T);return b==="recovered"?(A(),G(Uint8Array.of(this.assertRecovery()),B,D)):G(B,D)}toHex(b){return ye(this.toBytes(b))}}Object.freeze(L.prototype),Object.freeze(L);let O=e.bits2int===void 0?function(b){if(b.length>8192)throw new Error("input is too large");let v=Qt(b),T=b.length*8-a;return T>0?v>>BigInt(T):v}:e.bits2int,R=e.bits2int_modN===void 0?function(b){return c.create(O(b))}:e.bits2int_modN,I=qe(a);function U(g){return xe("num < 2^"+a,g,At,I),c.toBytes(g)}function z(g,b){return M(g,void 0,"message"),b?M(n(g),void 0,"prehashed message"):g}function k(g,b,v){let{lowS:T,prehash:B,extraEntropy:D}=mo(v,_);g=z(g,B);let F=R(g),N=c.fromBytes(b);if(!c.isValidNot0(N))throw new Error("invalid private key");let P=[U(N),U(F)];if(D!=null&&D!==!1){let W=D===!0?o(y.secretKey):D;P.push(M(W,void 0,"extraEntropy"))}let K=G(...P),$=F;function X(W){let j=O(W);if(!c.isValidNot0(j))return;let st=c.inv(j),ce=r.BASE.multiply(j).toAffine(),Be=c.create(ce.x);if(Be===At)return;let nr=c.create(st*c.create($+Be*N));if(nr===At)return;let Io=(ce.x===Be?0:2)|Number(ce.y&jt),To=nr;return T&&x(nr)&&(To=c.neg(nr),Io^=1),new L(Be,To,d?void 0:Io)}return{seed:K,k2sig:X}}function l(g,b,v={}){let{seed:T,k2sig:B}=k(g,b,v);return _s(n.outputLen,c.BYTES,s)(T,B).toBytes(v.format)}function m(g,b,v,T={}){let{lowS:B,prehash:D,format:F}=mo(T,_);if(v=M(v,void 0,"publicKey"),b=z(b,D),!Jt(g)){let N=g instanceof L?", use sig.toBytes()":"";throw new Error("verify expects Uint8Array signature"+N)}C(g,F);try{let N=L.fromBytes(g,F),P=r.fromBytes(v);if(B&&N.hasHighS())return!1;let{r:K,s:$}=N,X=R(b),W=c.inv($),j=c.create(X*W),st=c.create(K*W),ce=r.BASE.multiplyUnsafe(j).add(P.multiplyUnsafe(st));return ce.is0()?!1:c.create(ce.x)===K}catch{return!1}}function E(g,b,v={}){let{prehash:T}=mo(v,_);return b=z(b,T),L.fromBytes(g,"recovered").recoverPublicKey(b).toBytes()}return Object.freeze({keygen:u,getPublicKey:h,getSharedSecret:w,utils:p,lengths:y,Point:r,sign:l,verify:m,recoverPublicKey:E,Signature:L,hash:n})}var xo={p:BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),n:BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),h:BigInt(1),a:BigInt(0),b:BigInt(7),Gx:BigInt("0x79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798"),Gy:BigInt("0x483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8")},cf={beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),basises:[[BigInt("0x3086d221a7d46bcde86c90e49284eb15"),-BigInt("0xe4437ed6010e88286f547fa90abfe4c3")],[BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),BigInt("0x3086d221a7d46bcde86c90e49284eb15")]]};var xi=BigInt(2);function af(r){let t=xo.p,e=BigInt(3),n=BigInt(6),o=BigInt(11),s=BigInt(22),i=BigInt(23),c=BigInt(44),f=BigInt(88),a=r*r*r%t,u=a*a*r%t,h=H(u,e,t)*u%t,w=H(h,e,t)*u%t,p=H(w,xi,t)*a%t,y=H(p,o,t)*p%t,_=H(y,s,t)*y%t,d=H(_,c,t)*_%t,x=H(d,f,t)*d%t,S=H(x,c,t)*_%t,A=H(S,e,t)*u%t,C=H(A,i,t)*y%t,L=H(C,n,t)*a%t,O=H(L,xi,t);if(!go.eql(go.sqr(O),r))throw new Error("Cannot find square root");return O}var go=Ee(xo.p,{sqrt:af}),ff=mi(xo,{Fp:go,endo:cf}),Ae=gi(ff,xs);function wi(r,t,e,n){let o=Fe.digest(e instanceof Uint8Array?e:e.subarray());if(Lr(o))return o.then(({digest:s})=>(n?.signal?.throwIfAborted(),Ae.verify(t,s,r,{prehash:!1,format:"der"}))).catch(s=>{throw s.name==="AbortError"?s:new Ye(String(s))});try{return n?.signal?.throwIfAborted(),Ae.verify(t,o.digest,r,{prehash:!1,format:"der"})}catch(s){throw new Ye(String(s))}}var zr=class{type="secp256k1";raw;_key;constructor(t){this._key=_i(t),this.raw=Ei(this._key)}toMultihash(){return pt.digest(me(this))}toCID(){return it.createV1(114,this.toMultihash())}toString(){return Z.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:at(this.raw,t.raw)}verify(t,e,n){return wi(this._key,e,t,n)}};function Si(r){return new zr(r)}function Ei(r){return Ae.Point.fromBytes(r).toBytes()}function _i(r){try{return Ae.Point.fromBytes(r),r}catch(t){throw new or(String(t))}}function vi(r){let{Type:t,Data:e}=Je.decode(r.digest),n=e??new Uint8Array;switch(t){case ot.Ed25519:return Ws(n);case ot.secp256k1:return Si(n);case ot.ECDSA:return rs(n);default:throw new Ie}}function me(r){return Je.encode({Type:ot[r.type],Data:r.raw})}var Ai=Symbol.for("nodejs.util.inspect.custom"),uf=114,Qe=class{type;multihash;publicKey;string;constructor(t){this.type=t.type,this.multihash=t.multihash,Object.defineProperty(this,"string",{enumerable:!1,writable:!0})}get[Symbol.toStringTag](){return`PeerId(${this.toString()})`}[Gr]=!0;toString(){return this.string==null&&(this.string=Z.encode(this.multihash.bytes).slice(1)),this.string}toMultihash(){return this.multihash}toCID(){return it.createV1(uf,this.multihash)}toJSON(){return this.toString()}equals(t){if(t==null)return!1;if(t instanceof Uint8Array)return at(this.multihash.bytes,t);if(typeof t=="string")return this.toString()===t;if(t?.toMultihash()?.bytes!=null)return at(this.multihash.bytes,t.toMultihash().bytes);throw new Error("not valid Id")}[Ai](){return`PeerId(${this.toString()})`}},Hr=class extends Qe{type="RSA";publicKey;constructor(t){super({...t,type:"RSA"}),this.publicKey=t.publicKey}},qr=class extends Qe{type="Ed25519";publicKey;constructor(t){super({...t,type:"Ed25519"}),this.publicKey=t.publicKey}},Vr=class extends Qe{type="secp256k1";publicKey;constructor(t){super({...t,type:"secp256k1"}),this.publicKey=t.publicKey}},hf=2336,jr=class{type="url";multihash;publicKey;url;constructor(t){this.url=t.toString(),this.multihash=pt.digest(J(this.url))}[Ai](){return`PeerId(${this.url})`}[Gr]=!0;toString(){return this.toCID().toString()}toMultihash(){return this.multihash}toCID(){return it.createV1(hf,this.toMultihash())}toJSON(){return this.toString()}equals(t){return t==null?!1:(t instanceof Uint8Array&&(t=dt(t)),t.toString()===this.toString())}};function Bi(r){if(df(r))return new Hr({multihash:r});if(lf(r))try{let t=vi(r);if(t.type==="Ed25519")return new qr({multihash:r,publicKey:t});if(t.type==="secp256k1")return new Vr({multihash:r,publicKey:t})}catch{let e=dt(r.digest);return new jr(new URL(e))}throw new sr("Supplied PeerID Multihash is invalid")}function lf(r){return r.code===pt.code}function df(r){return r.code===Fe.code}function Bt(r,t){let e={[Symbol.iterator]:()=>e,next:()=>{let n=r.next(),o=n.value;return n.done===!0||o==null?{done:!0,value:void 0}:{done:!1,value:t(o)}}};return e}function Zr(r){let t=Ce(Z.decode(`z${r}`));return Bi(t)}var Zt=class{map;constructor(t){if(this.map=new Map,t!=null)for(let[e,n]of t.entries())this.map.set(e.toString(),{key:e,value:n})}[Symbol.iterator](){return this.entries()}clear(){this.map.clear()}delete(t){return this.map.delete(t.toString())}entries(){return Bt(this.map.entries(),t=>[t[1].key,t[1].value])}forEach(t){this.map.forEach((e,n)=>{t(e.value,e.key,this)})}get(t){return this.map.get(t.toString())?.value}has(t){return this.map.has(t.toString())}set(t,e){this.map.set(t.toString(),{key:t,value:e})}keys(){return Bt(this.map.values(),t=>t.key)}values(){return Bt(this.map.values(),t=>t.value)}get size(){return this.map.size}};function Ii(){return new Zt}var Yt=class r{set;constructor(t){if(this.set=new Set,t!=null)for(let e of t)this.set.add(e.toString())}get size(){return this.set.size}[Symbol.iterator](){return this.values()}add(t){this.set.add(t.toString())}clear(){this.set.clear()}delete(t){this.set.delete(t.toString())}entries(){return Bt(this.set.entries(),t=>{let e=Zr(t[0]);return[e,e]})}forEach(t){this.set.forEach(e=>{let n=Zr(e);t(n,n,this)})}has(t){return this.set.has(t.toString())}values(){return Bt(this.set.values(),t=>Zr(t))}intersection(t){let e=new r;for(let n of t)this.has(n)&&e.add(n);return e}difference(t){let e=new r;for(let n of this)t.has(n)||e.add(n);return e}union(t){let e=new r;for(let n of t)e.add(n);for(let n of this)e.add(n);return e}};function Ti(){return new Yt}var $t=class r{list;constructor(t){if(this.list=[],t!=null)for(let e of t)this.list.push(e)}[Symbol.iterator](){return Bt(this.list.entries(),t=>t[1])}concat(t){let e=new r(this);for(let n of t)e.push(n);return e}entries(){return Bt(this.list.entries(),t=>[t[0],t[1]])}every(t){return this.list.every((e,n)=>t(e,n,this))}filter(t){let e=new r;return this.list.forEach((n,o)=>{t(n,o,this)&&e.push(n)}),e}find(t){let e=this.list.find((n,o)=>t(n,o,this));if(e!=null)return e}findIndex(t){return this.list.findIndex((e,n)=>t(e,n,this))}forEach(t){this.list.forEach((e,n)=>{t(e,n,this)})}includes(t){return this.includes(t)}indexOf(t){return this.list.findIndex(e=>e.equals(t))}pop(){let t=this.list.pop();if(t!=null)return t}push(...t){for(let e of t)this.list.push(e)}shift(){let t=this.list.shift();if(t!=null)return t}unshift(...t){let e=this.list.length;for(let n=t.length-1;n>-1;n--)e=this.list.unshift(t[n]);return e}clear(){this.list=[]}get length(){return this.list.length}};function Li(){return new $t}var wo={32:16777619n,64:1099511628211n,128:309485009821345068724781371n,256:374144419156711147060143317175368453031918731002211n,512:35835915874844867368919076489095108449946327955754392558399825615420669938882575126094039892345713852759n,1024:5016456510113118655434598811035278955030765345404790744303017523831112055108147451509157692220295382716162651878526895249385292291816524375083746691371804094271873160484737966720260389217684476157468082573n},Di={32:2166136261n,64:14695981039346656037n,128:144066263297769815596495629667062367629n,256:100029257958052580907070968620625704837092796014241193945225284501741471925557n,512:9659303129496669498009435400716310466090418745672637896108374329434462657994582932197716438449813051892206539805784495328239340083876191928701583869517785n,1024:14197795064947621068722070641403218320880622795441933960878474914617582723252296732303717722150864096521202355549365628174669108571814760471015076148029755969804077320157692458563003215304957150157403644460363550505412711285966361610267868082893823963790439336411086884584107735010676915n},Ci=new globalThis.TextEncoder;function pf(r,t){let e=wo[t],n=Di[t];for(let o=0;o<r.length;o++)n^=BigInt(r[o]),n=BigInt.asUintN(t,n*e);return n}function mf(r,t,e){if(e.length===0)throw new Error("The `utf8Buffer` option must have a length greater than zero");let n=wo[t],o=Di[t],s=r;for(;s.length>0;){let i=Ci.encodeInto(s,e);s=s.slice(i.read);for(let c=0;c<i.written;c++)o^=BigInt(e[c]),o=BigInt.asUintN(t,o*n)}return o}function Eo(r,{size:t=32,utf8Buffer:e}={}){if(!wo[t])throw new Error("The `size` option must be one of 32, 64, 128, 256, 512, or 1024");if(typeof r=="string"){if(e)return mf(r,t,e);r=Ci.encode(r)}return pf(r,t)}var tr={hash:r=>Number(Eo(r,{size:32})),hashV:(r,t)=>bf(tr.hash(r,t))};function bf(r){let t=r.toString(16);return t.length%2===1&&(t=`0${t}`),J(t,"base16")}var _o=64,_t=class{fp;h;seed;constructor(t,e,n,o=2){if(o>_o)throw new TypeError("Invalid Fingerprint Size");let s=e.hashV(t,n),i=mt(o);for(let c=0;c<i.length;c++)i[c]=s[c];i.length===0&&(i[0]=7),this.fp=i,this.h=e,this.seed=n}hash(){return this.h.hash(this.fp,this.seed)}equals(t){return t?.fp instanceof Uint8Array?at(this.fp,t.fp):!1}};function se(r,t){return Math.floor(Math.random()*(t-r))+r}var ie=class{contents;constructor(t){this.contents=new Array(t).fill(null)}has(t){if(!(t instanceof _t))throw new TypeError("Invalid Fingerprint");return this.contents.some(e=>t.equals(e))}add(t){if(!(t instanceof _t))throw new TypeError("Invalid Fingerprint");for(let e=0;e<this.contents.length;e++)if(this.contents[e]==null)return this.contents[e]=t,!0;return!0}swap(t){if(!(t instanceof _t))throw new TypeError("Invalid Fingerprint");let e=se(0,this.contents.length-1),n=this.contents[e];return this.contents[e]=t,n}remove(t){if(!(t instanceof _t))throw new TypeError("Invalid Fingerprint");let e=this.contents.findIndex(n=>t.equals(n));return e>-1?(this.contents[e]=null,!0):!1}};var yf=500,er=class{bucketSize;filterSize;fingerprintSize;buckets;count;hash;seed;constructor(t){this.filterSize=t.filterSize,this.bucketSize=t.bucketSize??4,this.fingerprintSize=t.fingerprintSize??2,this.count=0,this.buckets=[],this.hash=t.hash??tr,this.seed=t.seed??se(0,Math.pow(2,10))}add(t){typeof t=="string"&&(t=J(t));let e=new _t(t,this.hash,this.seed,this.fingerprintSize),n=this.hash.hash(t,this.seed)%this.filterSize,o=(n^e.hash())%this.filterSize;if(this.buckets[n]==null&&(this.buckets[n]=new ie(this.bucketSize)),this.buckets[o]==null&&(this.buckets[o]=new ie(this.bucketSize)),this.buckets[n].add(e)||this.buckets[o].add(e))return this.count++,!0;let s=[n,o],i=s[se(0,s.length-1)];this.buckets[i]==null&&(this.buckets[i]=new ie(this.bucketSize));for(let c=0;c<yf;c++){let f=this.buckets[i].swap(e);if(f!=null&&(i=(i^f.hash())%this.filterSize,this.buckets[i]==null&&(this.buckets[i]=new ie(this.bucketSize)),this.buckets[i].add(f)))return this.count++,!0}return!1}has(t){typeof t=="string"&&(t=J(t));let e=new _t(t,this.hash,this.seed,this.fingerprintSize),n=this.hash.hash(t,this.seed)%this.filterSize,o=this.buckets[n]?.has(e)??!1;if(o)return o;let s=(n^e.hash())%this.filterSize;return this.buckets[s]?.has(e)??!1}remove(t){typeof t=="string"&&(t=J(t));let e=new _t(t,this.hash,this.seed,this.fingerprintSize),n=this.hash.hash(t,this.seed)%this.filterSize,o=this.buckets[n]?.remove(e)??!1;if(o)return this.count--,o;let s=(n^e.hash())%this.filterSize,i=this.buckets[s]?.remove(e)??!1;return i&&this.count--,i}get reliable(){return Math.floor(100*(this.count/this.filterSize))<=90}},gf={1:.5,2:.84,4:.95,8:.98};function xf(r=.001){return r>.002?2:r>1e-5?4:8}function Ri(r,t=.001){let e=xf(t),n=gf[e],o=Math.round(r/n),s=Math.min(Math.ceil(Math.log2(1/t)+Math.log2(2*e)),_o);return{filterSize:o,bucketSize:e,fingerprintSize:s}}var Yr=class{filterSize;bucketSize;fingerprintSize;scale;filterSeries;hash;seed;constructor(t){this.bucketSize=t.bucketSize??4,this.filterSize=t.filterSize??(1<<18)/this.bucketSize,this.fingerprintSize=t.fingerprintSize??2,this.scale=t.scale??2,this.hash=t.hash??tr,this.seed=t.seed??se(0,Math.pow(2,10)),this.filterSeries=[new er({filterSize:this.filterSize,bucketSize:this.bucketSize,fingerprintSize:this.fingerprintSize,hash:this.hash,seed:this.seed})]}add(t){if(typeof t=="string"&&(t=J(t)),this.has(t))return!0;let e=this.filterSeries.find(n=>n.reliable);if(e==null){let n=this.filterSize*Math.pow(this.scale,this.filterSeries.length);e=new er({filterSize:n,bucketSize:this.bucketSize,fingerprintSize:this.fingerprintSize,hash:this.hash,seed:this.seed}),this.filterSeries.push(e)}return e.add(t)}has(t){typeof t=="string"&&(t=J(t));for(let e=0;e<this.filterSeries.length;e++)if(this.filterSeries[e].has(t))return!0;return!1}remove(t){typeof t=="string"&&(t=J(t));for(let e=0;e<this.filterSeries.length;e++)if(this.filterSeries[e].remove(t))return!0;return!1}get count(){return this.filterSeries.reduce((t,e)=>t+e.count,0)}};function So(r,t=.001,e){return new Yr({...Ri(r,t),...e??{}})}var rr=class{filter;constructor(t,e){this.filter=So(t,e)}has(t){return this.filter.has(t.toMultihash().bytes)}add(t){this.filter.add(t.toMultihash().bytes)}remove(t){this.filter.remove?.(t.toMultihash().bytes)}};function Fi(r,t=.001){return new rr(r,t)}var vo=class extends Zt{metric;constructor(t){super();let{name:e,metrics:n}=t;this.metric=n.registerMetric(e),this.updateComponentMetric()}set(t,e){return super.set(t,e),this.updateComponentMetric(),this}delete(t){let e=super.delete(t);return this.updateComponentMetric(),e}clear(){super.clear(),this.updateComponentMetric()}updateComponentMetric(){this.metric.update(this.size)}};function Oi(r){let{name:t,metrics:e}=r,n;return e!=null?n=new vo({name:t,metrics:e}):n=new Zt,n}var Ao=class extends Yt{metric;constructor(t){super();let{name:e,metrics:n}=t;this.metric=n.registerMetric(e),this.updateComponentMetric()}add(t){super.add(t),this.updateComponentMetric()}delete(t){super.delete(t),this.updateComponentMetric()}clear(){super.clear(),this.updateComponentMetric()}updateComponentMetric(){this.metric.update(this.size)}};function Ui(r){let{name:t,metrics:e}=r,n;return e!=null?n=new Ao({name:t,metrics:e}):n=new Yt,n}var Bo=class extends $t{metric;constructor(t){super();let{name:e,metrics:n}=t;this.metric=n.registerMetric(e),this.updateComponentMetric()}pop(){let t=super.pop();return this.updateComponentMetric(),t}push(...t){super.push(...t),this.updateComponentMetric()}shift(){let t=super.shift();return this.updateComponentMetric(),t}unshift(...t){let e=super.unshift(...t);return this.updateComponentMetric(),e}clear(){super.clear(),this.updateComponentMetric()}updateComponentMetric(){this.metric.update(this.length)}};function ki(r){let{name:t,metrics:e}=r,n;return e!=null?n=new Bo({name:t,metrics:e}):n=new $t,n}return zi(wf);})();
2
+ "use strict";var Libp2PPeerCollections=(()=>{var pn=Object.defineProperty;var Wc=Object.getOwnPropertyDescriptor;var Jc=Object.getOwnPropertyNames;var Qc=Object.prototype.hasOwnProperty;var q=(r,t)=>{for(var e in t)pn(r,e,{get:t[e],enumerable:!0})},ta=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of Jc(t))!Qc.call(r,o)&&o!==e&&pn(r,o,{get:()=>t[o],enumerable:!(n=Wc(t,o))||n.enumerable});return r};var ea=r=>ta(pn({},"__esModule",{value:!0}),r);var jh={};q(jh,{PeerFilter:()=>wr,PeerList:()=>Wt,PeerMap:()=>Gt,PeerSet:()=>Xt,peerFilter:()=>$c,peerList:()=>Vc,peerMap:()=>zc,peerSet:()=>qc,trackedPeerList:()=>Xc,trackedPeerMap:()=>Yc,trackedPeerSet:()=>Gc});var It=class extends Error{static name="InvalidParametersError";constructor(t="Invalid parameters"){super(t),this.name="InvalidParametersError"}},Sr=class extends Error{static name="InvalidPublicKeyError";constructor(t="Invalid public key"){super(t),this.name="InvalidPublicKeyError"}};var _r=class extends Error{static name="InvalidMultihashError";constructor(t="Invalid Multihash"){super(t),this.name="InvalidMultihashError"}};var Me=class extends Error{static name="UnsupportedKeyTypeError";constructor(t="Unsupported key type"){super(t),this.name="UnsupportedKeyTypeError"}};var mn=Symbol.for("@libp2p/peer-id");var wn={};q(wn,{base58btc:()=>Y,base58flickr:()=>fa});var Gh=new Uint8Array(0);function xs(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function Tt(r){if(r instanceof Uint8Array&&r.constructor.name==="Uint8Array")return Jt(r);if(r instanceof ArrayBuffer)return new Uint8Array(r);if(ArrayBuffer.isView(r))return Jt(new Uint8Array(r.buffer,r.byteOffset,r.byteLength));throw new Error("Unknown type, must be binary type")}function gs(r){return new TextEncoder().encode(r)}function ws(r){return new TextDecoder().decode(r)}function ra(r){return r?.buffer instanceof ArrayBuffer}function Jt(r){return ra(r)?r:r.slice()}function na(r,t){if(r.length>=255)throw new TypeError("Alphabet too long");for(var e=new Uint8Array(256),n=0;n<e.length;n++)e[n]=255;for(var o=0;o<r.length;o++){var s=r.charAt(o),i=s.charCodeAt(0);if(e[i]!==255)throw new TypeError(s+" is ambiguous");e[i]=o}var c=r.length,f=r.charAt(0),a=Math.log(c)/Math.log(256),u=Math.log(256)/Math.log(c);function h(d){if(d instanceof Uint8Array||(ArrayBuffer.isView(d)?d=new Uint8Array(d.buffer,d.byteOffset,d.byteLength):Array.isArray(d)&&(d=Uint8Array.from(d))),!(d instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(d.length===0)return"";for(var w=0,p=0,b=0,S=d.length;b!==S&&d[b]===0;)b++,w++;for(var _=(S-b)*u+1>>>0,T=new Uint8Array(_);b!==S;){for(var I=d[b],F=0,L=_-1;(I!==0||F<p)&&L!==-1;L--,F++)I+=256*T[L]>>>0,T[L]=I%c>>>0,I=I/c>>>0;if(I!==0)throw new Error("Non-zero carry");p=F,b++}for(var B=_-p;B!==_&&T[B]===0;)B++;for(var O=f.repeat(w);B<_;++B)O+=r.charAt(T[B]);return O}function E(d){if(typeof d!="string")throw new TypeError("Expected String");if(d.length===0)return new Uint8Array;var w=0;if(d[w]!==" "){for(var p=0,b=0;d[w]===f;)p++,w++;for(var S=(d.length-w)*a+1>>>0,_=new Uint8Array(S);d[w];){var T=e[d.charCodeAt(w)];if(T===255)return;for(var I=0,F=S-1;(T!==0||I<b)&&F!==-1;F--,I++)T+=c*_[F]>>>0,_[F]=T%256>>>0,T=T/256>>>0;if(T!==0)throw new Error("Non-zero carry");b=I,w++}if(d[w]!==" "){for(var L=S-b;L!==S&&_[L]===0;)L++;for(var B=new Uint8Array(p+(S-L)),O=p;L!==S;)B[O++]=_[L++];return B}}}function m(d){var w=E(d);if(w)return w;throw new Error(`Non-${t} character`)}return{encode:h,decodeUnsafe:E,decode:m}}var oa=na,sa=oa,Ss=sa;var bn=class{name;prefix;baseEncode;constructor(t,e,n){this.name=t,this.prefix=e,this.baseEncode=n}encode(t){if(t instanceof Uint8Array)return`${this.prefix}${this.baseEncode(t)}`;throw Error("Unknown type, must be binary type")}},yn=class{name;prefix;baseDecode;prefixCodePoint;constructor(t,e,n){this.name=t,this.prefix=e;let o=e.codePointAt(0);if(o===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=o,this.baseDecode=n}decode(t){if(typeof t=="string"){if(t.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(t)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(t.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(t){return _s(this,t)}},xn=class{decoders;constructor(t){this.decoders=t}or(t){return _s(this,t)}decode(t){let e=t[0],n=this.decoders[e];if(n!=null)return n.decode(t);throw RangeError(`Unable to decode multibase string ${JSON.stringify(t)}, only inputs prefixed with ${Object.keys(this.decoders)} are supported`)}};function _s(r,t){return new xn({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var gn=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(t,e,n,o){this.name=t,this.prefix=e,this.baseEncode=n,this.baseDecode=o,this.encoder=new bn(t,e,n),this.decoder=new yn(t,e,o)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function de({name:r,prefix:t,encode:e,decode:n}){return new gn(r,t,e,n)}function kt({name:r,prefix:t,alphabet:e}){let{encode:n,decode:o}=Ss(e,r);return de({prefix:t,name:r,encode:n,decode:s=>Tt(o(s))})}function ia(r,t,e,n){let o=r.length;for(;r[o-1]==="=";)--o;let s=new Uint8Array(o*e/8|0),i=0,c=0,f=0;for(let a=0;a<o;++a){let u=t[r[a]];if(u===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<e|u,i+=e,i>=8&&(i-=8,s[f++]=255&c>>i)}if(i>=e||(255&c<<8-i)!==0)throw new SyntaxError("Unexpected end of data");return s}function ca(r,t,e){let n=t[t.length-1]==="=",o=(1<<e)-1,s="",i=0,c=0;for(let f=0;f<r.length;++f)for(c=c<<8|r[f],i+=8;i>e;)i-=e,s+=t[o&c>>i];if(i!==0&&(s+=t[o&c<<e-i]),n)for(;(s.length*e&7)!==0;)s+="=";return s}function aa(r){let t={};for(let e=0;e<r.length;++e)t[r[e]]=e;return t}function H({name:r,prefix:t,bitsPerChar:e,alphabet:n}){let o=aa(n);return de({prefix:t,name:r,encode(s){return ca(s,n,e)},decode(s){return ia(s,o,e,r)}})}var Y=kt({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),fa=kt({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var En={};q(En,{base32:()=>pe,base32hex:()=>da,base32hexpad:()=>ma,base32hexpadupper:()=>ba,base32hexupper:()=>pa,base32pad:()=>ha,base32padupper:()=>la,base32upper:()=>ua,base32z:()=>ya});var pe=H({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),ua=H({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),ha=H({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),la=H({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),da=H({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),pa=H({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),ma=H({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),ba=H({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),ya=H({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Sn={};q(Sn,{base36:()=>Pe,base36upper:()=>xa});var Pe=kt({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),xa=kt({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var ga=Bs,vs=128,wa=127,Ea=~wa,Sa=Math.pow(2,31);function Bs(r,t,e){t=t||[],e=e||0;for(var n=e;r>=Sa;)t[e++]=r&255|vs,r/=128;for(;r&Ea;)t[e++]=r&255|vs,r>>>=7;return t[e]=r|0,Bs.bytes=e-n+1,t}var _a=_n,va=128,As=127;function _n(r,n){var e=0,n=n||0,o=0,s=n,i,c=r.length;do{if(s>=c)throw _n.bytes=0,new RangeError("Could not decode varint");i=r[s++],e+=o<28?(i&As)<<o:(i&As)*Math.pow(2,o),o+=7}while(i>=va);return _n.bytes=s-n,e}var Aa=Math.pow(2,7),Ba=Math.pow(2,14),Ia=Math.pow(2,21),Ta=Math.pow(2,28),Da=Math.pow(2,35),Ca=Math.pow(2,42),La=Math.pow(2,49),Ua=Math.pow(2,56),Fa=Math.pow(2,63),Ra=function(r){return r<Aa?1:r<Ba?2:r<Ia?3:r<Ta?4:r<Da?5:r<Ca?6:r<La?7:r<Ua?8:r<Fa?9:10},Oa={encode:ga,decode:_a,encodingLength:Ra},ka=Oa,ze=ka;function qe(r,t=0){return[ze.decode(r,t),ze.decode.bytes]}function me(r,t,e=0){return ze.encode(r,t,e),t}function be(r){return ze.encodingLength(r)}function xe(r,t){let e=t.byteLength,n=be(r),o=n+be(e),s=new Uint8Array(o+e);return me(r,s,0),me(e,s,n),s.set(t,o),new ye(r,e,t,s)}function Ve(r){let t=Tt(r),[e,n]=qe(t),[o,s]=qe(t.subarray(n)),i=t.subarray(n+s);if(i.byteLength!==o)throw new Error("Incorrect length");return new ye(e,o,i,t)}function Is(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&xs(r.bytes,e.bytes)}}var ye=class{code;size;digest;bytes;constructor(t,e,n,o){this.code=t,this.size=e,this.digest=Jt(n),this.bytes=Jt(o)}};function Ts(r,t){let{bytes:e,version:n}=r;return n===0?Ka(e,vn(r),t??Y.encoder):Ma(e,vn(r),t??pe.encoder)}var Ds=new WeakMap;function vn(r){let t=Ds.get(r);if(t==null){let e=new Map;return Ds.set(r,e),e}return t}var at=class r{code;version;multihash;bytes;"/";constructor(t,e,n,o){this.code=e,this.version=t,this.multihash=n,this.bytes=Jt(o),this["/"]=this.bytes}get asCID(){return this}get byteOffset(){return this.bytes.byteOffset}get byteLength(){return this.bytes.byteLength}toV0(){switch(this.version){case 0:return this;case 1:{let{code:t,multihash:e}=this;if(t!==He)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==Pa)throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");return r.createV0(e)}default:throw Error(`Can not convert CID version ${this.version} to version 0. This is a bug please report`)}}toV1(){switch(this.version){case 0:{let{code:t,digest:e}=this.multihash,n=xe(t,e);return r.createV1(this.code,n)}case 1:return this;default:throw Error(`Can not convert CID version ${this.version} to version 1. This is a bug please report`)}}equals(t){return r.equals(this,t)}static equals(t,e){let n=e;return n!=null&&t.code===n.code&&t.version===n.version&&Is(t.multihash,n.multihash)}toString(t){return Ts(this,t)}toJSON(){return{"/":Ts(this)}}link(){return this}[Symbol.toStringTag]="CID";[Symbol.for("nodejs.util.inspect.custom")](){return`CID(${this.toString()})`}static asCID(t){if(t==null)return null;let e=t;if(e instanceof r)return e;if(e["/"]!=null&&e["/"]===e.bytes||e.asCID===e){let{version:n,code:o,multihash:s,bytes:i}=e;return new r(n,o,s,i??Cs(n,o,s.bytes))}else if(e[za]===!0){let{version:n,multihash:o,code:s}=e,i=Ve(o);return r.create(n,s,i)}else return null}static create(t,e,n){if(typeof e!="number")throw new Error("String codecs are no longer supported");if(!(n.bytes instanceof Uint8Array))throw new Error("Invalid digest");switch(t){case 0:{if(e!==He)throw new Error(`Version 0 CID must use dag-pb (code: ${He}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let o=Cs(t,e,n.bytes);return new r(t,e,n,o)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,He,t)}static createV1(t,e){return r.create(1,t,e)}static decode(t){let[e,n]=r.decodeFirst(t);if(n.length!==0)throw new Error("Incorrect length");return e}static decodeFirst(t){let e=r.inspectBytes(t),n=e.size-e.multihashSize,o=Tt(t.subarray(n,n+e.multihashSize));if(o.byteLength!==e.multihashSize)throw new Error("Incorrect length");let s=o.subarray(e.multihashSize-e.digestSize),i=new ye(e.multihashCode,e.digestSize,s,o);return[e.version===0?r.createV0(i):r.createV1(e.codec,i),t.subarray(e.size)]}static inspectBytes(t){let e=0,n=()=>{let[h,E]=qe(t.subarray(e));return e+=E,h},o=n(),s=He;if(o===18?(o=0,e=0):s=n(),o!==0&&o!==1)throw new RangeError(`Invalid CID version ${o}`);let i=e,c=n(),f=n(),a=e+f,u=a-i;return{version:o,codec:s,multihashCode:c,digestSize:f,multihashSize:u,size:a}}static parse(t,e){let[n,o]=Na(t,e),s=r.decode(o);if(s.version===0&&t[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return vn(s).set(n,t),s}};function Na(r,t){switch(r[0]){case"Q":{let e=t??Y;return[Y.prefix,e.decode(`${Y.prefix}${r}`)]}case Y.prefix:{let e=t??Y;return[Y.prefix,e.decode(r)]}case pe.prefix:{let e=t??pe;return[pe.prefix,e.decode(r)]}case Pe.prefix:{let e=t??Pe;return[Pe.prefix,e.decode(r)]}default:{if(t==null)throw Error("To parse non base32, base36 or base58btc encoded CID multibase decoder must be provided");return[r[0],t.decode(r)]}}}function Ka(r,t,e){let{prefix:n}=e;if(n!==Y.prefix)throw Error(`Cannot string encode V0 in ${e.name} encoding`);let o=t.get(n);if(o==null){let s=e.encode(r).slice(1);return t.set(n,s),s}else return o}function Ma(r,t,e){let{prefix:n}=e,o=t.get(n);if(o==null){let s=e.encode(r);return t.set(n,s),s}else return o}var He=112,Pa=18;function Cs(r,t,e){let n=be(r),o=n+be(t),s=new Uint8Array(o+e.byteLength);return me(r,s,0),me(t,s,n),s.set(e,o),s}var za=Symbol.for("@ipld/js-cid/CID");var An={};q(An,{identity:()=>dt});var Ls=0,qa="identity",Us=Tt;function Va(r,t){if(t?.truncate!=null&&t.truncate!==r.byteLength){if(t.truncate<0||t.truncate>r.byteLength)throw new Error(`Invalid truncate option, must be less than or equal to ${r.byteLength}`);r=r.subarray(0,t.truncate)}return xe(Ls,Us(r))}var dt={code:Ls,name:qa,encode:Us,digest:Va};function pt(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function Ha(r){return r.buffer instanceof ArrayBuffer}function ge(r){return Ha(r)?r:r.slice()}async function Fs(r,t,e,n){let o=await crypto.subtle.importKey("jwk",r,{name:"ECDSA",namedCurve:r.crv??"P-256"},!1,["verify"]);n?.signal?.throwIfAborted();let s=await crypto.subtle.verify({name:"ECDSA",hash:{name:"SHA-256"}},o,ge(t),ge(e.subarray()));return n?.signal?.throwIfAborted(),s}function Dt(r=0){return new Uint8Array(r)}function je(r=0){return new Uint8Array(r)}function Bn(r,t){t==null&&(t=r.reduce((o,s)=>o+s.length,0));let e=je(t),n=0;for(let o of r)e.set(o,n),n+=o.length;return e}function Rs(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}var ks=Symbol.for("@achingbrain/uint8arraylist");function Os(r,t){if(t==null||t<0)throw new RangeError("index is out of bounds");let e=0;for(let n of r){let o=e+n.byteLength;if(t<o)return{buf:n,index:t-e};e=o}throw new RangeError("index is out of bounds")}function Ar(r){return!!r?.[ks]}var ft=class r{bufs;length;[ks]=!0;constructor(...t){this.bufs=[],this.length=0,t.length>0&&this.appendAll(t)}*[Symbol.iterator](){yield*this.bufs}get byteLength(){return this.length}append(...t){this.appendAll(t)}appendAll(t){let e=0;for(let n of t)if(n instanceof Uint8Array)e+=n.byteLength,this.bufs.push(n);else if(Ar(n)){e+=n.byteLength;for(let o of n.bufs)this.bufs.push(o)}else throw new Error("Could not append value, must be an Uint8Array or a Uint8ArrayList");this.length+=e}prepend(...t){this.prependAll(t)}prependAll(t){let e=0;for(let n of t.reverse())if(n instanceof Uint8Array)e+=n.byteLength,this.bufs.unshift(n);else if(Ar(n))e+=n.byteLength,this.bufs.unshift(...n.bufs);else throw new Error("Could not prepend value, must be an Uint8Array or a Uint8ArrayList");this.length+=e}get(t){let e=Os(this.bufs,t);return e.buf[e.index]}set(t,e){let n=Os(this.bufs,t);n.buf[n.index]=e}write(t,e=0){if(t instanceof Uint8Array)for(let n=0;n<t.length;n++)this.set(e+n,t[n]);else if(Ar(t))for(let n=0;n<t.length;n++)this.set(e+n,t.get(n));else throw new Error("Could not write value, must be an Uint8Array or a Uint8ArrayList")}consume(t){if(t=Math.trunc(t),!(Number.isNaN(t)||t<=0)){if(t===this.byteLength){this.bufs=[],this.length=0;return}for(;this.bufs.length>0;)if(t>=this.bufs[0].byteLength)t-=this.bufs[0].byteLength,this.length-=this.bufs[0].byteLength,this.bufs.shift();else{this.bufs[0]=this.bufs[0].subarray(t),this.length-=t;break}}}slice(t,e){let{bufs:n,length:o}=this._subList(t,e);return Bn(n,o)}subarray(t,e){let{bufs:n,length:o}=this._subList(t,e);return n.length===1?n[0]:Bn(n,o)}sublist(t,e){let{bufs:n,length:o}=this._subList(t,e),s=new r;return s.length=o,s.bufs=n,s}_subList(t,e){if(t=t??0,e=e??this.length,t<0&&(t=this.length+t),e<0&&(e=this.length+e),t<0||e>this.length)throw new RangeError("index is out of bounds");if(t===e)return{bufs:[],length:0};if(t===0&&e===this.length)return{bufs:[...this.bufs],length:this.length};let n=[],o=0;for(let s=0;s<this.bufs.length;s++){let i=this.bufs[s],c=o,f=c+i.byteLength;if(o=f,t>=f)continue;let a=t>=c&&t<f,u=e>c&&e<=f;if(a&&u){if(t===c&&e===f){n.push(i);break}let h=t-c;n.push(i.subarray(h,h+(e-t)));break}if(a){if(t===0){n.push(i);continue}n.push(i.subarray(t-c));continue}if(u){if(e===f){n.push(i);break}n.push(i.subarray(0,e-c));break}n.push(i)}return{bufs:n,length:e-t}}indexOf(t,e=0){if(!Ar(t)&&!(t instanceof Uint8Array))throw new TypeError('The "value" argument must be a Uint8ArrayList or Uint8Array');let n=t instanceof Uint8Array?t:t.subarray();if(e=Number(e??0),isNaN(e)&&(e=0),e<0&&(e=this.length+e),e<0&&(e=0),t.length===0)return e>this.length?this.length:e;let o=n.byteLength;if(o===0)throw new TypeError("search must be at least 1 byte long");let s=256,i=new Int32Array(s);for(let h=0;h<s;h++)i[h]=-1;for(let h=0;h<o;h++)i[n[h]]=h;let c=i,f=this.byteLength-n.byteLength,a=n.byteLength-1,u;for(let h=e;h<=f;h+=u){u=0;for(let E=a;E>=0;E--){let m=this.get(h+E);if(n[E]!==m){u=Math.max(1,E-c[m]);break}}if(u===0)return h}return-1}getInt8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getInt8(0)}setInt8(t,e){let n=je(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setInt8(0,e),this.write(n,t)}getInt16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt16(0,e)}setInt16(t,e,n){let o=Dt(2);new DataView(o.buffer,o.byteOffset,o.byteLength).setInt16(0,e,n),this.write(o,t)}getInt32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt32(0,e)}setInt32(t,e,n){let o=Dt(4);new DataView(o.buffer,o.byteOffset,o.byteLength).setInt32(0,e,n),this.write(o,t)}getBigInt64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigInt64(0,e)}setBigInt64(t,e,n){let o=Dt(8);new DataView(o.buffer,o.byteOffset,o.byteLength).setBigInt64(0,e,n),this.write(o,t)}getUint8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getUint8(0)}setUint8(t,e){let n=je(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setUint8(0,e),this.write(n,t)}getUint16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint16(0,e)}setUint16(t,e,n){let o=Dt(2);new DataView(o.buffer,o.byteOffset,o.byteLength).setUint16(0,e,n),this.write(o,t)}getUint32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint32(0,e)}setUint32(t,e,n){let o=Dt(4);new DataView(o.buffer,o.byteOffset,o.byteLength).setUint32(0,e,n),this.write(o,t)}getBigUint64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigUint64(0,e)}setBigUint64(t,e,n){let o=Dt(8);new DataView(o.buffer,o.byteOffset,o.byteLength).setBigUint64(0,e,n),this.write(o,t)}getFloat32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat32(0,e)}setFloat32(t,e,n){let o=Dt(4);new DataView(o.buffer,o.byteOffset,o.byteLength).setFloat32(0,e,n),this.write(o,t)}getFloat64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat64(0,e)}setFloat64(t,e,n){let o=Dt(8);new DataView(o.buffer,o.byteOffset,o.byteLength).setFloat64(0,e,n),this.write(o,t)}equals(t){if(t==null||!(t instanceof r)||t.bufs.length!==this.bufs.length)return!1;for(let e=0;e<this.bufs.length;e++)if(!Rs(this.bufs[e],t.bufs[e]))return!1;return!0}static fromUint8Arrays(t,e){let n=new r;return n.bufs=t,e==null&&(e=t.reduce((o,s)=>o+s.byteLength,0)),n.length=e,n}};var In={};q(In,{base10:()=>ja});var ja=kt({prefix:"9",name:"base10",alphabet:"0123456789"});var Tn={};q(Tn,{base16:()=>Za,base16upper:()=>$a});var Za=H({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),$a=H({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Dn={};q(Dn,{base2:()=>Ya});var Ya=H({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Cn={};q(Cn,{base256emoji:()=>Qa});var Ns=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}"),Ga=Ns.reduce((r,t,e)=>(r[e]=t,r),[]),Xa=Ns.reduce((r,t,e)=>{let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);return r[n]=e,r},[]);function Wa(r){return r.reduce((t,e)=>(t+=Ga[e],t),"")}function Ja(r){let t=[];for(let e of r){let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);let o=Xa[n];if(o==null)throw new Error(`Non-base256emoji character: ${e}`);t.push(o)}return new Uint8Array(t)}var Qa=de({prefix:"\u{1F680}",name:"base256emoji",encode:Wa,decode:Ja});var Ln={};q(Ln,{base64:()=>tf,base64pad:()=>ef,base64url:()=>rf,base64urlpad:()=>nf});var tf=H({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),ef=H({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),rf=H({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),nf=H({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Un={};q(Un,{base8:()=>of});var of=H({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Fn={};q(Fn,{identity:()=>sf});var sf=de({prefix:"\0",name:"identity",encode:r=>ws(r),decode:r=>gs(r)});var kl=new TextEncoder,Nl=new TextDecoder;var kn={};q(kn,{sha256:()=>Ze,sha512:()=>uf});var ff=20;function On({name:r,code:t,encode:e,minDigestLength:n,maxDigestLength:o}){return new Rn(r,t,e,n,o)}var Rn=class{name;code;encode;minDigestLength;maxDigestLength;constructor(t,e,n,o,s){this.name=t,this.code=e,this.encode=n,this.minDigestLength=o??ff,this.maxDigestLength=s}digest(t,e){if(e?.truncate!=null){if(e.truncate<this.minDigestLength)throw new Error(`Invalid truncate option, must be greater than or equal to ${this.minDigestLength}`);if(this.maxDigestLength!=null&&e.truncate>this.maxDigestLength)throw new Error(`Invalid truncate option, must be less than or equal to ${this.maxDigestLength}`)}if(t instanceof Uint8Array){let n=this.encode(t);return n instanceof Uint8Array?Ks(n,this.code,e?.truncate):n.then(o=>Ks(o,this.code,e?.truncate))}else throw Error("Unknown type, must be binary type")}};function Ks(r,t,e){if(e!=null&&e!==r.byteLength){if(e>r.byteLength)throw new Error(`Invalid truncate option, must be less than or equal to ${r.byteLength}`);r=r.subarray(0,e)}return xe(t,r)}function Ps(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var Ze=On({name:"sha2-256",code:18,encode:Ps("SHA-256")}),uf=On({name:"sha2-512",code:19,encode:Ps("SHA-512")});var Nn={...Fn,...Dn,...Un,...In,...Tn,...En,...Sn,...wn,...Ln,...Cn},Gl={...kn,...An};function zs(r=0){return new Uint8Array(r)}function Kn(r=0){return new Uint8Array(r)}function Vs(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var qs=Vs("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),Mn=Vs("ascii","a",r=>{let t="a";for(let e=0;e<r.length;e++)t+=String.fromCharCode(r[e]);return t},r=>{r=r.substring(1);let t=Kn(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),hf={utf8:qs,"utf-8":qs,hex:Nn.base16,latin1:Mn,ascii:Mn,binary:Mn,...Nn},Br=hf;function nt(r,t="utf8"){let e=Br[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function lt(r,t="utf8"){let e=Br[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}var lf=parseInt("11111",2),Pn=parseInt("10000000",2),df=parseInt("01111111",2),Hs={0:$e,1:$e,2:pf,3:yf,4:xf,5:bf,6:mf,16:$e,22:$e,48:$e};function zn(r,t={offset:0}){let e=r[t.offset]&lf;if(t.offset++,Hs[e]!=null)return Hs[e](r,t);throw new Error("No decoder for tag "+e)}function Ye(r,t){let e=0;if((r[t.offset]&Pn)===Pn){let n=r[t.offset]&df,o="0x";t.offset++;for(let s=0;s<n;s++,t.offset++)o+=r[t.offset].toString(16).padStart(2,"0");e=parseInt(o,16)}else e=r[t.offset],t.offset++;return e}function $e(r,t){Ye(r,t);let e=[];for(;!(t.offset>=r.byteLength);){let n=zn(r,t);if(n===null)break;e.push(n)}return e}function pf(r,t){let e=Ye(r,t),n=t.offset,o=t.offset+e,s=[];for(let i=n;i<o;i++)i===n&&r[i]===0||s.push(r[i]);return t.offset+=e,Uint8Array.from(s)}function mf(r,t){let e=Ye(r,t),n=t.offset+e,o=r[t.offset];t.offset++;let s=0,i=0;o<40?(s=0,i=o):o<80?(s=1,i=o-40):(s=2,i=o-80);let c=`${s}.${i}`,f=[];for(;t.offset<n;){let a=r[t.offset];if(t.offset++,f.push(a&127),a<128){f.reverse();let u=0;for(let h=0;h<f.length;h++)u+=f[h]<<h*7;c+=`.${u}`,f=[]}}return c}function bf(r,t){return t.offset++,null}function yf(r,t){let e=Ye(r,t),n=r[t.offset];t.offset++;let o=r.subarray(t.offset,t.offset+e-1);if(t.offset+=e,n!==0)throw new Error("Unused bits in bit string is unimplemented");return o}function xf(r,t){let e=Ye(r,t),n=r.subarray(t.offset,t.offset+e);return t.offset+=e,n}function gf(r){let t=r.toString(16);t.length%2===1&&(t="0"+t);let e=new ft;for(let n=0;n<t.length;n+=2)e.append(Uint8Array.from([parseInt(`${t[n]}${t[n+1]}`,16)]));return e}function qn(r){if(r.byteLength<128)return Uint8Array.from([r.byteLength]);let t=gf(r.byteLength);return new ft(Uint8Array.from([t.byteLength|Pn]),t)}function js(r){let t=new ft,e=128;return(r.subarray()[0]&e)===e&&t.append(Uint8Array.from([0])),t.append(r),new ft(Uint8Array.from([2]),qn(t),t)}function Zs(r){let t=Uint8Array.from([0]),e=new ft(t,r);return new ft(Uint8Array.from([3]),qn(e),e)}function Ir(r,t=48){let e=new ft;for(let n of r)e.append(n);return new ft(Uint8Array.from([t]),qn(e),e)}var wf=Uint8Array.from([6,8,42,134,72,206,61,3,1,7]),Ef=Uint8Array.from([6,5,43,129,4,0,34]),Sf=Uint8Array.from([6,5,43,129,4,0,35]),_f={ext:!0,kty:"EC",crv:"P-256"},vf={ext:!0,kty:"EC",crv:"P-384"},Af={ext:!0,kty:"EC",crv:"P-521"},Vn=32,Hn=48,jn=66;function $s(r){let t=zn(r);return Ys(t)}function Ys(r){let t=r[1][1][0],e=1,n,o;if(t.byteLength===Vn*2+1)return n=lt(t.subarray(e,e+Vn),"base64url"),o=lt(t.subarray(e+Vn),"base64url"),new we({..._f,key_ops:["verify"],x:n,y:o});if(t.byteLength===Hn*2+1)return n=lt(t.subarray(e,e+Hn),"base64url"),o=lt(t.subarray(e+Hn),"base64url"),new we({...vf,key_ops:["verify"],x:n,y:o});if(t.byteLength===jn*2+1)return n=lt(t.subarray(e,e+jn),"base64url"),o=lt(t.subarray(e+jn),"base64url"),new we({...Af,key_ops:["verify"],x:n,y:o});throw new It(`coordinates were wrong length, got ${t.byteLength}, expected 65, 97 or 133`)}function Gs(r){return Ir([js(Uint8Array.from([1])),Ir([Bf(r.crv)],160),Ir([Zs(new ft(Uint8Array.from([4]),nt(r.x??"","base64url"),nt(r.y??"","base64url")))],161)]).subarray()}function Bf(r){if(r==="P-256")return wf;if(r==="P-384")return Ef;if(r==="P-521")return Sf;throw new It(`Invalid curve ${r}`)}var we=class{type="ECDSA";jwk;_raw;constructor(t){this.jwk=t}get raw(){return this._raw==null&&(this._raw=Gs(this.jwk)),this._raw}toMultihash(){return dt.digest(Ee(this))}toCID(){return at.createV1(114,this.toMultihash())}toString(){return Y.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:pt(this.raw,t.raw)}async verify(t,e,n){return Fs(this.jwk,e,t,n)}};function Zn(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"&&"BYTES_PER_ELEMENT"in r&&r.BYTES_PER_ELEMENT===1}function Nt(r,t=""){if(typeof r!="number"){let e=t&&`"${t}" `;throw new TypeError(`${e}expected number, got ${typeof r}`)}if(!Number.isSafeInteger(r)||r<0){let e=t&&`"${t}" `;throw new RangeError(`${e}expected integer >= 0, got ${r}`)}}function ut(r,t,e=""){let n=Zn(r),o=r?.length,s=t!==void 0;if(!n||s&&o!==t){let i=e&&`"${e}" `,c=s?` of length ${t}`:"",f=n?`length=${o}`:`type=${typeof r}`,a=i+"expected Uint8Array"+c+", got "+f;throw n?new RangeError(a):new TypeError(a)}return r}function Tr(r){if(typeof r!="function"||typeof r.create!="function")throw new TypeError("Hash must wrapped by utils.createHasher");if(Nt(r.outputLen),Nt(r.blockLen),r.outputLen<1)throw new Error('"outputLen" must be >= 1');if(r.blockLen<1)throw new Error('"blockLen" must be >= 1')}function Se(r,t=!0){if(r.destroyed)throw new Error("Hash instance has been destroyed");if(t&&r.finished)throw new Error("Hash#digest() has already been called")}function Dr(r,t){ut(r,void 0,"digestInto() output");let e=t.outputLen;if(r.length<e)throw new RangeError('"digestInto() output" expected to be of length >='+e)}function Lt(...r){for(let t=0;t<r.length;t++)r[t].fill(0)}function Cr(r){return new DataView(r.buffer,r.byteOffset,r.byteLength)}function mt(r,t){return r<<32-t|r>>>t}var Ws=typeof Uint8Array.from([]).toHex=="function"&&typeof Uint8Array.fromHex=="function",If=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function Lr(r){if(ut(r),Ws)return r.toHex();let t="";for(let e=0;e<r.length;e++)t+=If[r[e]];return t}var Ct={_0:48,_9:57,A:65,F:70,a:97,f:102};function Xs(r){if(r>=Ct._0&&r<=Ct._9)return r-Ct._0;if(r>=Ct.A&&r<=Ct.F)return r-(Ct.A-10);if(r>=Ct.a&&r<=Ct.f)return r-(Ct.a-10)}function Ge(r){if(typeof r!="string")throw new TypeError("hex string expected, got "+typeof r);if(Ws)try{return Uint8Array.fromHex(r)}catch(o){throw o instanceof SyntaxError?new RangeError(o.message):o}let t=r.length,e=t/2;if(t%2)throw new RangeError("hex string expected, got unpadded hex of length "+t);let n=new Uint8Array(e);for(let o=0,s=0;o<e;o++,s+=2){let i=Xs(r.charCodeAt(s)),c=Xs(r.charCodeAt(s+1));if(i===void 0||c===void 0){let f=r[s]+r[s+1];throw new RangeError('hex string expected, got non-hex character "'+f+'" at index '+s)}n[o]=i*16+c}return n}function $n(...r){let t=0;for(let n=0;n<r.length;n++){let o=r[n];ut(o),t+=o.length}let e=new Uint8Array(t);for(let n=0,o=0;n<r.length;n++){let s=r[n];e.set(s,o),o+=s.length}return e}function Yn(r,t={}){let e=(o,s)=>r(s).update(o).digest(),n=r(void 0);return e.outputLen=n.outputLen,e.blockLen=n.blockLen,e.canXOF=n.canXOF,e.create=o=>r(o),Object.assign(e,t),Object.freeze(e)}function Js(r=32){Nt(r,"bytesLength");let t=typeof globalThis=="object"?globalThis.crypto:null;if(typeof t?.getRandomValues!="function")throw new Error("crypto.getRandomValues must be defined");if(r>65536)throw new RangeError(`"bytesLength" expected <= 65536, got ${r}`);return t.getRandomValues(new Uint8Array(r))}var Gn=r=>({oid:Uint8Array.from([6,9,96,134,72,1,101,3,4,2,r])});function Qs(r,t,e){return r&t^~r&e}function ti(r,t,e){return r&t^r&e^t&e}var Xe=class{blockLen;outputLen;canXOF=!1;padOffset;isLE;buffer;view;finished=!1;length=0;pos=0;destroyed=!1;constructor(t,e,n,o){this.blockLen=t,this.outputLen=e,this.padOffset=n,this.isLE=o,this.buffer=new Uint8Array(t),this.view=Cr(this.buffer)}update(t){Se(this),ut(t);let{view:e,buffer:n,blockLen:o}=this,s=t.length;for(let i=0;i<s;){let c=Math.min(o-this.pos,s-i);if(c===o){let f=Cr(t);for(;o<=s-i;i+=o)this.process(f,i);continue}n.set(t.subarray(i,i+c),this.pos),this.pos+=c,i+=c,this.pos===o&&(this.process(e,0),this.pos=0)}return this.length+=t.length,this.roundClean(),this}digestInto(t){Se(this),Dr(t,this),this.finished=!0;let{buffer:e,view:n,blockLen:o,isLE:s}=this,{pos:i}=this;e[i++]=128,Lt(this.buffer.subarray(i)),this.padOffset>o-i&&(this.process(n,0),i=0);for(let h=i;h<o;h++)e[h]=0;n.setBigUint64(o-8,BigInt(this.length*8),s),this.process(n,0);let c=Cr(t),f=this.outputLen;if(f%4)throw new Error("_sha2: outputLen must be aligned to 32bit");let a=f/4,u=this.get();if(a>u.length)throw new Error("_sha2: outputLen bigger than state");for(let h=0;h<a;h++)c.setUint32(4*h,u[h],s)}digest(){let{buffer:t,outputLen:e}=this;this.digestInto(t);let n=t.slice(0,e);return this.destroy(),n}_cloneInto(t){t||=new this.constructor,t.set(...this.get());let{blockLen:e,buffer:n,length:o,finished:s,destroyed:i,pos:c}=this;return t.destroyed=i,t.finished=s,t.length=o,t.pos=c,o%e&&t.buffer.set(n),t}clone(){return this._cloneInto()}},Ut=Uint32Array.from([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]);var et=Uint32Array.from([1779033703,4089235720,3144134277,2227873595,1013904242,4271175723,2773480762,1595750129,1359893119,2917565137,2600822924,725511199,528734635,4215389547,1541459225,327033209]);var Ur=BigInt(4294967295),ei=BigInt(32);function Tf(r,t=!1){return t?{h:Number(r&Ur),l:Number(r>>ei&Ur)}:{h:Number(r>>ei&Ur)|0,l:Number(r&Ur)|0}}function ri(r,t=!1){let e=r.length,n=new Uint32Array(e),o=new Uint32Array(e);for(let s=0;s<e;s++){let{h:i,l:c}=Tf(r[s],t);[n[s],o[s]]=[i,c]}return[n,o]}var Xn=(r,t,e)=>r>>>e,Wn=(r,t,e)=>r<<32-e|t>>>e,te=(r,t,e)=>r>>>e|t<<32-e,ee=(r,t,e)=>r<<32-e|t>>>e,We=(r,t,e)=>r<<64-e|t>>>e-32,Je=(r,t,e)=>r>>>e-32|t<<64-e;function St(r,t,e,n){let o=(t>>>0)+(n>>>0);return{h:r+e+(o/2**32|0)|0,l:o|0}}var ni=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),oi=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,si=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),ii=(r,t,e,n,o)=>t+e+n+o+(r/2**32|0)|0,ci=(r,t,e,n,o)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(o>>>0),ai=(r,t,e,n,o,s)=>t+e+n+o+s+(r/2**32|0)|0;var Cf=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]),Kt=new Uint32Array(64),Jn=class extends Xe{constructor(t){super(64,t,8,!1)}get(){let{A:t,B:e,C:n,D:o,E:s,F:i,G:c,H:f}=this;return[t,e,n,o,s,i,c,f]}set(t,e,n,o,s,i,c,f){this.A=t|0,this.B=e|0,this.C=n|0,this.D=o|0,this.E=s|0,this.F=i|0,this.G=c|0,this.H=f|0}process(t,e){for(let h=0;h<16;h++,e+=4)Kt[h]=t.getUint32(e,!1);for(let h=16;h<64;h++){let E=Kt[h-15],m=Kt[h-2],d=mt(E,7)^mt(E,18)^E>>>3,w=mt(m,17)^mt(m,19)^m>>>10;Kt[h]=w+Kt[h-7]+d+Kt[h-16]|0}let{A:n,B:o,C:s,D:i,E:c,F:f,G:a,H:u}=this;for(let h=0;h<64;h++){let E=mt(c,6)^mt(c,11)^mt(c,25),m=u+E+Qs(c,f,a)+Cf[h]+Kt[h]|0,w=(mt(n,2)^mt(n,13)^mt(n,22))+ti(n,o,s)|0;u=a,a=f,f=c,c=i+m|0,i=s,s=o,o=n,n=m+w|0}n=n+this.A|0,o=o+this.B|0,s=s+this.C|0,i=i+this.D|0,c=c+this.E|0,f=f+this.F|0,a=a+this.G|0,u=u+this.H|0,this.set(n,o,s,i,c,f,a,u)}roundClean(){Lt(Kt)}destroy(){this.destroyed=!0,this.set(0,0,0,0,0,0,0,0),Lt(this.buffer)}},Qn=class extends Jn{A=Ut[0]|0;B=Ut[1]|0;C=Ut[2]|0;D=Ut[3]|0;E=Ut[4]|0;F=Ut[5]|0;G=Ut[6]|0;H=Ut[7]|0;constructor(){super(32)}};var fi=ri(["0x428a2f98d728ae22","0x7137449123ef65cd","0xb5c0fbcfec4d3b2f","0xe9b5dba58189dbbc","0x3956c25bf348b538","0x59f111f1b605d019","0x923f82a4af194f9b","0xab1c5ed5da6d8118","0xd807aa98a3030242","0x12835b0145706fbe","0x243185be4ee4b28c","0x550c7dc3d5ffb4e2","0x72be5d74f27b896f","0x80deb1fe3b1696b1","0x9bdc06a725c71235","0xc19bf174cf692694","0xe49b69c19ef14ad2","0xefbe4786384f25e3","0x0fc19dc68b8cd5b5","0x240ca1cc77ac9c65","0x2de92c6f592b0275","0x4a7484aa6ea6e483","0x5cb0a9dcbd41fbd4","0x76f988da831153b5","0x983e5152ee66dfab","0xa831c66d2db43210","0xb00327c898fb213f","0xbf597fc7beef0ee4","0xc6e00bf33da88fc2","0xd5a79147930aa725","0x06ca6351e003826f","0x142929670a0e6e70","0x27b70a8546d22ffc","0x2e1b21385c26c926","0x4d2c6dfc5ac42aed","0x53380d139d95b3df","0x650a73548baf63de","0x766a0abb3c77b2a8","0x81c2c92e47edaee6","0x92722c851482353b","0xa2bfe8a14cf10364","0xa81a664bbc423001","0xc24b8b70d0f89791","0xc76c51a30654be30","0xd192e819d6ef5218","0xd69906245565a910","0xf40e35855771202a","0x106aa07032bbd1b8","0x19a4c116b8d2d0c8","0x1e376c085141ab53","0x2748774cdf8eeb99","0x34b0bcb5e19b48a8","0x391c0cb3c5c95a63","0x4ed8aa4ae3418acb","0x5b9cca4f7763e373","0x682e6ff3d6b2b8a3","0x748f82ee5defb2fc","0x78a5636f43172f60","0x84c87814a1f0ab72","0x8cc702081a6439ec","0x90befffa23631e28","0xa4506cebde82bde9","0xbef9a3f7b2c67915","0xc67178f2e372532b","0xca273eceea26619c","0xd186b8c721c0c207","0xeada7dd6cde0eb1e","0xf57d4f7fee6ed178","0x06f067aa72176fba","0x0a637dc5a2c898a6","0x113f9804bef90dae","0x1b710b35131c471b","0x28db77f523047d84","0x32caab7b40c72493","0x3c9ebe0a15c9bebc","0x431d67c49c100d4c","0x4cc5d4becb3e42b6","0x597f299cfc657e2a","0x5fcb6fab3ad6faec","0x6c44198c4a475817"].map(r=>BigInt(r))),Lf=fi[0],Uf=fi[1],Mt=new Uint32Array(80),Pt=new Uint32Array(80),to=class extends Xe{constructor(t){super(128,t,16,!1)}get(){let{Ah:t,Al:e,Bh:n,Bl:o,Ch:s,Cl:i,Dh:c,Dl:f,Eh:a,El:u,Fh:h,Fl:E,Gh:m,Gl:d,Hh:w,Hl:p}=this;return[t,e,n,o,s,i,c,f,a,u,h,E,m,d,w,p]}set(t,e,n,o,s,i,c,f,a,u,h,E,m,d,w,p){this.Ah=t|0,this.Al=e|0,this.Bh=n|0,this.Bl=o|0,this.Ch=s|0,this.Cl=i|0,this.Dh=c|0,this.Dl=f|0,this.Eh=a|0,this.El=u|0,this.Fh=h|0,this.Fl=E|0,this.Gh=m|0,this.Gl=d|0,this.Hh=w|0,this.Hl=p|0}process(t,e){for(let _=0;_<16;_++,e+=4)Mt[_]=t.getUint32(e),Pt[_]=t.getUint32(e+=4);for(let _=16;_<80;_++){let T=Mt[_-15]|0,I=Pt[_-15]|0,F=te(T,I,1)^te(T,I,8)^Xn(T,I,7),L=ee(T,I,1)^ee(T,I,8)^Wn(T,I,7),B=Mt[_-2]|0,O=Pt[_-2]|0,z=te(B,O,19)^We(B,O,61)^Xn(B,O,6),k=ee(B,O,19)^Je(B,O,61)^Wn(B,O,6),l=si(L,k,Pt[_-7],Pt[_-16]),y=ii(l,F,z,Mt[_-7],Mt[_-16]);Mt[_]=y|0,Pt[_]=l|0}let{Ah:n,Al:o,Bh:s,Bl:i,Ch:c,Cl:f,Dh:a,Dl:u,Eh:h,El:E,Fh:m,Fl:d,Gh:w,Gl:p,Hh:b,Hl:S}=this;for(let _=0;_<80;_++){let T=te(h,E,14)^te(h,E,18)^We(h,E,41),I=ee(h,E,14)^ee(h,E,18)^Je(h,E,41),F=h&m^~h&w,L=E&d^~E&p,B=ci(S,I,L,Uf[_],Pt[_]),O=ai(B,b,T,F,Lf[_],Mt[_]),z=B|0,k=te(n,o,28)^We(n,o,34)^We(n,o,39),l=ee(n,o,28)^Je(n,o,34)^Je(n,o,39),y=n&s^n&c^s&c,v=o&i^o&f^i&f;b=w|0,S=p|0,w=m|0,p=d|0,m=h|0,d=E|0,{h,l:E}=St(a|0,u|0,O|0,z|0),a=c|0,u=f|0,c=s|0,f=i|0,s=n|0,i=o|0;let g=ni(z,l,v);n=oi(g,O,k,y),o=g|0}({h:n,l:o}=St(this.Ah|0,this.Al|0,n|0,o|0)),{h:s,l:i}=St(this.Bh|0,this.Bl|0,s|0,i|0),{h:c,l:f}=St(this.Ch|0,this.Cl|0,c|0,f|0),{h:a,l:u}=St(this.Dh|0,this.Dl|0,a|0,u|0),{h,l:E}=St(this.Eh|0,this.El|0,h|0,E|0),{h:m,l:d}=St(this.Fh|0,this.Fl|0,m|0,d|0),{h:w,l:p}=St(this.Gh|0,this.Gl|0,w|0,p|0),{h:b,l:S}=St(this.Hh|0,this.Hl|0,b|0,S|0),this.set(n,o,s,i,c,f,a,u,h,E,m,d,w,p,b,S)}roundClean(){Lt(Mt,Pt)}destroy(){this.destroyed=!0,Lt(this.buffer),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}},eo=class extends to{Ah=et[0]|0;Al=et[1]|0;Bh=et[2]|0;Bl=et[3]|0;Ch=et[4]|0;Cl=et[5]|0;Dh=et[6]|0;Dl=et[7]|0;Eh=et[8]|0;El=et[9]|0;Fh=et[10]|0;Fl=et[11]|0;Gh=et[12]|0;Gl=et[13]|0;Hh=et[14]|0;Hl=et[15]|0;constructor(){super(64)}};var ui=Yn(()=>new Qn,Gn(1));var Fr=Yn(()=>new eo,Gn(3));var M=(r,t,e)=>ut(r,t,e),no=Nt,_e=Lr,W=(...r)=>$n(...r),ve=r=>Ge(r),re=Zn,Qe=r=>Js(r),Or=BigInt(0),ro=BigInt(1);function bt(r,t=""){if(typeof r!="boolean"){let e=t&&`"${t}" `;throw new TypeError(e+"expected boolean, got type="+typeof r)}return r}function kr(r){if(typeof r=="bigint"){if(!Rr(r))throw new RangeError("positive bigint expected, got "+r)}else no(r);return r}function yt(r,t=""){if(typeof r!="number"){let e=t&&`"${t}" `;throw new TypeError(e+"expected number, got type="+typeof r)}if(!Number.isSafeInteger(r)){let e=t&&`"${t}" `;throw new RangeError(e+"expected safe integer, got "+r)}}function tr(r){let t=kr(r).toString(16);return t.length&1?"0"+t:t}function hi(r){if(typeof r!="string")throw new TypeError("hex string expected, got "+typeof r);return r===""?Or:BigInt("0x"+r)}function ne(r){return hi(Lr(r))}function _t(r){return hi(Lr(er(ut(r)).reverse()))}function Nr(r,t){if(Nt(t),t===0)throw new RangeError("zero length");r=kr(r);let e=r.toString(16);if(e.length>t*2)throw new RangeError("number too large");return Ge(e.padStart(t*2,"0"))}function oo(r,t){return Nr(r,t).reverse()}function li(r,t){if(r=M(r),t=M(t),r.length!==t.length)return!1;let e=0;for(let n=0;n<r.length;n++)e|=r[n]^t[n];return e===0}function er(r){return Uint8Array.from(M(r))}function Kr(r){if(typeof r!="string")throw new TypeError("ascii string expected, got "+typeof r);return Uint8Array.from(r,(t,e)=>{let n=t.charCodeAt(0);if(t.length!==1||n>127)throw new RangeError(`string contains non-ASCII character "${r[e]}" with code ${n} at position ${e}`);return n})}var Rr=r=>typeof r=="bigint"&&Or<=r;function Ff(r,t,e){return Rr(r)&&Rr(t)&&Rr(e)&&t<=r&&r<e}function Ae(r,t,e,n){if(!Ff(t,e,n))throw new RangeError("expected valid "+r+": "+e+" <= n < "+n+", got "+t)}function Be(r){if(r<Or)throw new Error("expected non-negative bigint, got "+r);let t;for(t=0;r>Or;r>>=ro,t+=1);return t}var rr=r=>(ro<<BigInt(r))-ro;function di(r,t,e){if(Nt(r,"hashLen"),Nt(t,"qByteLen"),typeof e!="function")throw new TypeError("hmacFn must be a function");let n=p=>new Uint8Array(p),o=Uint8Array.of(),s=Uint8Array.of(0),i=Uint8Array.of(1),c=1e3,f=n(r),a=n(r),u=0,h=()=>{f.fill(1),a.fill(0),u=0},E=(...p)=>e(a,W(f,...p)),m=(p=o)=>{a=E(s,p),f=E(),p.length!==0&&(a=E(i,p),f=E())},d=()=>{if(u++>=c)throw new Error("drbg: tried max amount of iterations");let p=0,b=[];for(;p<t;){f=E();let S=f.slice();b.push(S),p+=f.length}return W(...b)};return(p,b)=>{h(),m(p);let S;for(;(S=b(d()))===void 0;)m();return h(),S}}function xt(r,t={},e={}){if(Object.prototype.toString.call(r)!=="[object Object]")throw new TypeError("expected valid options object");function n(s,i,c){if(!c&&i!=="function"&&!Object.hasOwn(r,s))throw new TypeError(`param "${s}" is invalid: expected own property`);let f=r[s];if(c&&f===void 0)return;let a=typeof f;if(a!==i||f===null)throw new TypeError(`param "${s}" is invalid: expected ${i}, got ${a}`)}let o=(s,i)=>Object.entries(s).forEach(([c,f])=>n(c,f,i));o(t,!1),o(e,!0)}var so=()=>{throw new Error("not implemented")};var rt=BigInt(0),j=BigInt(1),oe=BigInt(2),yi=BigInt(3),xi=BigInt(4),gi=BigInt(5),Rf=BigInt(7),wi=BigInt(8),Of=BigInt(9),Ei=BigInt(16);function G(r,t){if(t<=rt)throw new Error("mod: expected positive modulus, got "+t);let e=r%t;return e>=rt?e:t+e}function V(r,t,e){if(t<rt)throw new Error("pow2: expected non-negative exponent, got "+t);let n=r;for(;t-- >rt;)n*=n,n%=e;return n}function pi(r,t){if(r===rt)throw new Error("invert: expected non-zero number");if(t<=rt)throw new Error("invert: expected positive modulus, got "+t);let e=G(r,t),n=t,o=rt,s=j,i=j,c=rt;for(;e!==rt;){let a=n/e,u=n-e*a,h=o-i*a,E=s-c*a;n=e,e=u,o=i,s=c,i=h,c=E}if(n!==j)throw new Error("invert: does not exist");return G(o,t)}function io(r,t,e){let n=r;if(!n.eql(n.sqr(t),e))throw new Error("Cannot find square root")}function Si(r,t){let e=r,n=(e.ORDER+j)/xi,o=e.pow(t,n);return io(e,o,t),o}function kf(r,t){let e=r,n=(e.ORDER-gi)/wi,o=e.mul(t,oe),s=e.pow(o,n),i=e.mul(t,s),c=e.mul(e.mul(i,oe),s),f=e.mul(i,e.sub(c,e.ONE));return io(e,f,t),f}function Nf(r){let t=Ie(r),e=_i(r),n=e(t,t.neg(t.ONE)),o=e(t,n),s=e(t,t.neg(n)),i=(r+Rf)/Ei;return((c,f)=>{let a=c,u=a.pow(f,i),h=a.mul(u,n),E=a.mul(u,o),m=a.mul(u,s),d=a.eql(a.sqr(h),f),w=a.eql(a.sqr(E),f);u=a.cmov(u,h,d),h=a.cmov(m,E,w);let p=a.eql(a.sqr(h),f),b=a.cmov(u,h,p);return io(a,b,f),b})}function _i(r){if(r<yi)throw new Error("sqrt is not defined for small field");let t=r-j,e=0;for(;t%oe===rt;)t/=oe,e++;let n=oe,o=Ie(r);for(;mi(o,n)===1;)if(n++>1e3)throw new Error("Cannot find square root: probably non-prime P");if(e===1)return Si;let s=o.pow(n,t),i=(t+j)/oe;return function(f,a){let u=f;if(u.is0(a))return a;if(mi(u,a)!==1)throw new Error("Cannot find square root");let h=e,E=u.mul(u.ONE,s),m=u.pow(a,t),d=u.pow(a,i);for(;!u.eql(m,u.ONE);){if(u.is0(m))return u.ZERO;let w=1,p=u.sqr(m);for(;!u.eql(p,u.ONE);)if(w++,p=u.sqr(p),w===h)throw new Error("Cannot find square root");let b=j<<BigInt(h-w-1),S=u.pow(E,b);h=w,E=u.sqr(S),m=u.mul(m,E),d=u.mul(d,S)}return d}}function Kf(r){return r%xi===yi?Si:r%wi===gi?kf:r%Ei===Of?Nf(r):_i(r)}var Ft=(r,t)=>(G(r,t)&j)===j,Mf=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function co(r){let t={ORDER:"bigint",BYTES:"number",BITS:"number"},e=Mf.reduce((n,o)=>(n[o]="function",n),t);if(xt(r,e),yt(r.BYTES,"BYTES"),yt(r.BITS,"BITS"),r.BYTES<1||r.BITS<1)throw new Error("invalid field: expected BYTES/BITS > 0");if(r.ORDER<=j)throw new Error("invalid field: expected ORDER > 1, got "+r.ORDER);return r}function Pf(r,t,e){let n=r;if(e<rt)throw new Error("invalid exponent, negatives unsupported");if(e===rt)return n.ONE;if(e===j)return t;let o=n.ONE,s=t;for(;e>rt;)e&j&&(o=n.mul(o,s)),s=n.sqr(s),e>>=j;return o}function nr(r,t,e=!1){let n=r,o=new Array(t.length).fill(e?n.ZERO:void 0),s=t.reduce((c,f,a)=>n.is0(f)?c:(o[a]=c,n.mul(c,f)),n.ONE),i=n.inv(s);return t.reduceRight((c,f,a)=>n.is0(f)?c:(o[a]=n.mul(c,o[a]),n.mul(c,f)),i),o}function mi(r,t){let e=r,n=(e.ORDER-j)/oe,o=e.pow(t,n),s=e.eql(o,e.ONE),i=e.eql(o,e.ZERO),c=e.eql(o,e.neg(e.ONE));if(!s&&!i&&!c)throw new Error("invalid Legendre symbol result");return s?1:i?0:-1}function zf(r,t){if(t!==void 0&&no(t),r<=rt)throw new Error("invalid n length: expected positive n, got "+r);if(t!==void 0&&t<1)throw new Error("invalid n length: expected positive bit length, got "+t);let e=Be(r);if(t!==void 0&&t<e)throw new Error(`invalid n length: expected bit length (${e}) >= n.length (${t})`);let n=t!==void 0?t:e,o=Math.ceil(n/8);return{nBitLength:n,nByteLength:o}}var bi=new WeakMap,Mr=class{ORDER;BITS;BYTES;isLE;ZERO=rt;ONE=j;_lengths;_mod;constructor(t,e={}){if(t<=j)throw new Error("invalid field: expected ORDER > 1, got "+t);let n;this.isLE=!1,e!=null&&typeof e=="object"&&(typeof e.BITS=="number"&&(n=e.BITS),typeof e.sqrt=="function"&&Object.defineProperty(this,"sqrt",{value:e.sqrt,enumerable:!0}),typeof e.isLE=="boolean"&&(this.isLE=e.isLE),e.allowedLengths&&(this._lengths=Object.freeze(e.allowedLengths.slice())),typeof e.modFromBytes=="boolean"&&(this._mod=e.modFromBytes));let{nBitLength:o,nByteLength:s}=zf(t,n);if(s>2048)throw new Error("invalid field: expected ORDER of <= 2048 bytes");this.ORDER=t,this.BITS=o,this.BYTES=s,Object.freeze(this)}create(t){return G(t,this.ORDER)}isValid(t){if(typeof t!="bigint")throw new TypeError("invalid field element: expected bigint, got "+typeof t);return rt<=t&&t<this.ORDER}is0(t){return t===rt}isValidNot0(t){return!this.is0(t)&&this.isValid(t)}isOdd(t){return(t&j)===j}neg(t){return G(-t,this.ORDER)}eql(t,e){return t===e}sqr(t){return G(t*t,this.ORDER)}add(t,e){return G(t+e,this.ORDER)}sub(t,e){return G(t-e,this.ORDER)}mul(t,e){return G(t*e,this.ORDER)}pow(t,e){return Pf(this,t,e)}div(t,e){return G(t*pi(e,this.ORDER),this.ORDER)}sqrN(t){return t*t}addN(t,e){return t+e}subN(t,e){return t-e}mulN(t,e){return t*e}inv(t){return pi(t,this.ORDER)}sqrt(t){let e=bi.get(this);return e||bi.set(this,e=Kf(this.ORDER)),e(this,t)}toBytes(t){return this.isLE?oo(t,this.BYTES):Nr(t,this.BYTES)}fromBytes(t,e=!1){M(t);let{_lengths:n,BYTES:o,isLE:s,ORDER:i,_mod:c}=this;if(n){if(t.length<1||!n.includes(t.length)||t.length>o)throw new Error("Field.fromBytes: expected "+n+" bytes, got "+t.length);let a=new Uint8Array(o);a.set(t,s?0:a.length-t.length),t=a}if(t.length!==o)throw new Error("Field.fromBytes: expected "+o+" bytes, got "+t.length);let f=s?_t(t):ne(t);if(c&&(f=G(f,i)),!e&&!this.isValid(f))throw new Error("invalid field element: outside of range 0..ORDER");return f}invertBatch(t){return nr(this,t)}cmov(t,e,n){return bt(n,"condition"),n?e:t}};Object.freeze(Mr.prototype);function Ie(r,t={}){return new Mr(r,t)}function vi(r){if(typeof r!="bigint")throw new Error("field order must be bigint");if(r<=j)throw new Error("field order must be greater than 1");let t=Be(r-j);return Math.ceil(t/8)}function ao(r){let t=vi(r);return t+Math.ceil(t/2)}function fo(r,t,e=!1){M(r);let n=r.length,o=vi(t),s=Math.max(ao(t),16);if(n<s||n>1024)throw new Error("expected "+s+"-1024 bytes of input, got "+n);let i=e?_t(r):ne(r),c=G(i,t-j)+j;return e?oo(c,o):Nr(c,o)}var Te=BigInt(0),se=BigInt(1);function or(r,t){let e=t.negate();return r?e:t}function ie(r,t){let e=nr(r.Fp,t.map(n=>n.Z));return t.map((n,o)=>r.fromAffine(n.toAffine(e[o])))}function Ti(r,t){if(!Number.isSafeInteger(r)||r<=0||r>t)throw new Error("invalid window size, expected [1.."+t+"], got W="+r)}function uo(r,t){Ti(r,t);let e=Math.ceil(t/r)+1,n=2**(r-1),o=2**r,s=rr(r),i=BigInt(r);return{windows:e,windowSize:n,mask:s,maxNumber:o,shiftBy:i}}function Ai(r,t,e){let{windowSize:n,mask:o,maxNumber:s,shiftBy:i}=e,c=Number(r&o),f=r>>i;c>n&&(c-=s,f+=se);let a=t*n,u=a+Math.abs(c)-1,h=c===0,E=c<0,m=t%2!==0;return{nextN:f,offset:u,isZero:h,isNeg:E,isNegF:m,offsetF:a}}var ho=new WeakMap,Di=new WeakMap;function lo(r){return Di.get(r)||1}function Bi(r){if(r!==Te)throw new Error("invalid wNAF")}var De=class{BASE;ZERO;Fn;bits;constructor(t,e){this.BASE=t.BASE,this.ZERO=t.ZERO,this.Fn=t.Fn,this.bits=e}_unsafeLadder(t,e,n=this.ZERO){let o=t;for(;e>Te;)e&se&&(n=n.add(o)),o=o.double(),e>>=se;return n}precomputeWindow(t,e){let{windows:n,windowSize:o}=uo(e,this.bits),s=[],i=t,c=i;for(let f=0;f<n;f++){c=i,s.push(c);for(let a=1;a<o;a++)c=c.add(i),s.push(c);i=c.double()}return s}wNAF(t,e,n){if(!this.Fn.isValid(n))throw new Error("invalid scalar");let o=this.ZERO,s=this.BASE,i=uo(t,this.bits);for(let c=0;c<i.windows;c++){let{nextN:f,offset:a,isZero:u,isNeg:h,isNegF:E,offsetF:m}=Ai(n,c,i);n=f,u?s=s.add(or(E,e[m])):o=o.add(or(h,e[a]))}return Bi(n),{p:o,f:s}}wNAFUnsafe(t,e,n,o=this.ZERO){let s=uo(t,this.bits);for(let i=0;i<s.windows&&n!==Te;i++){let{nextN:c,offset:f,isZero:a,isNeg:u}=Ai(n,i,s);if(n=c,!a){let h=e[f];o=o.add(u?h.negate():h)}}return Bi(n),o}getPrecomputes(t,e,n){let o=ho.get(e);return o||(o=this.precomputeWindow(e,t),t!==1&&(typeof n=="function"&&(o=n(o)),ho.set(e,o))),o}cached(t,e,n){let o=lo(t);return this.wNAF(o,this.getPrecomputes(o,t,n),e)}unsafe(t,e,n,o){let s=lo(t);return s===1?this._unsafeLadder(t,e,o):this.wNAFUnsafe(s,this.getPrecomputes(s,t,n),e,o)}createCache(t,e){Ti(e,this.bits),Di.set(t,e),ho.delete(t)}hasCache(t){return lo(t)!==1}};function Ci(r,t,e,n){let o=t,s=r.ZERO,i=r.ZERO;for(;e>Te||n>Te;)e&se&&(s=s.add(o)),n&se&&(i=i.add(o)),o=o.double(),e>>=se,n>>=se;return{p1:s,p2:i}}function Ii(r,t,e){if(t){if(t.ORDER!==r)throw new Error("Field.ORDER must match order: Fp == p, Fn == n");return co(t),t}else return Ie(r,{isLE:e})}function Pr(r,t,e={},n){if(n===void 0&&(n=r==="edwards"),!t||typeof t!="object")throw new Error(`expected valid ${r} CURVE object`);for(let f of["p","n","h"]){let a=t[f];if(!(typeof a=="bigint"&&a>Te))throw new Error(`CURVE.${f} must be positive bigint`)}let o=Ii(t.p,e.Fp,n),s=Ii(t.n,e.Fn,n),c=["Gx","Gy","a",r==="weierstrass"?"b":"d"];for(let f of c)if(!o.isValid(t[f]))throw new Error(`CURVE.${f} must be valid field element of CURVE.Fp`);return t=Object.freeze(Object.assign({},t)),{CURVE:t,Fp:o,Fn:s}}function zr(r,t){return function(n){let o=r(n);return{secretKey:o,publicKey:t(o)}}}var zt=BigInt(0),tt=BigInt(1),po=BigInt(2),qf=BigInt(8);function Vf(r,t,e,n){let o=r.sqr(e),s=r.sqr(n),i=r.add(r.mul(t.a,o),s),c=r.add(r.ONE,r.mul(t.d,r.mul(o,s)));return r.eql(i,c)}function Li(r,t={}){let e=t,n=Pr("edwards",r,e,e.FpFnLE),{Fp:o,Fn:s}=n,i=n.CURVE,{h:c}=i;xt(e,{},{uvRatio:"function"});let f=po<<BigInt(s.BYTES*8)-tt,a=w=>o.create(w),u=e.uvRatio===void 0?(w,p)=>{try{return{isValid:!0,value:o.sqrt(o.div(w,p))}}catch{return{isValid:!1,value:zt}}}:e.uvRatio;if(!Vf(o,i,i.Gx,i.Gy))throw new Error("bad curve params: generator point");function h(w,p,b=!1){let S=b?tt:zt;return Ae("coordinate "+w,p,S,f),p}function E(w){if(!(w instanceof m))throw new Error("EdwardsPoint expected")}class m{static BASE=new m(i.Gx,i.Gy,tt,a(i.Gx*i.Gy));static ZERO=new m(zt,tt,tt,zt);static Fp=o;static Fn=s;X;Y;Z;T;constructor(p,b,S,_){this.X=h("x",p),this.Y=h("y",b),this.Z=h("z",S,!0),this.T=h("t",_),Object.freeze(this)}static CURVE(){return i}static fromAffine(p){if(p instanceof m)throw new Error("extended point not allowed");let{x:b,y:S}=p||{};return h("x",b),h("y",S),new m(b,S,tt,a(b*S))}static fromBytes(p,b=!1){let S=o.BYTES,{a:_,d:T}=i;p=er(M(p,S,"point")),bt(b,"zip215");let I=er(p),F=p[S-1];I[S-1]=F&-129;let L=_t(I),B=b?f:o.ORDER;Ae("point.y",L,zt,B);let O=a(L*L),z=a(O-tt),k=a(T*O-_),{isValid:l,value:y}=u(z,k);if(!l)throw new Error("bad point: invalid y coordinate");let v=(y&tt)===tt,g=(F&128)!==0;if(!b&&y===zt&&g)throw new Error("bad point: x=0 and x_0=1");return g!==v&&(y=a(-y)),m.fromAffine({x:y,y:L})}static fromHex(p,b=!1){return m.fromBytes(ve(p),b)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}precompute(p=8,b=!0){return d.createCache(this,p),b||this.multiply(po),this}assertValidity(){let p=this,{a:b,d:S}=i;if(p.is0())throw new Error("bad point: ZERO");let{X:_,Y:T,Z:I,T:F}=p,L=a(_*_),B=a(T*T),O=a(I*I),z=a(O*O),k=a(L*b),l=a(O*a(k+B)),y=a(z+a(S*a(L*B)));if(l!==y)throw new Error("bad point: equation left != right (1)");let v=a(_*T),g=a(I*F);if(v!==g)throw new Error("bad point: equation left != right (2)")}equals(p){E(p);let{X:b,Y:S,Z:_}=this,{X:T,Y:I,Z:F}=p,L=a(b*F),B=a(T*_),O=a(S*F),z=a(I*_);return L===B&&O===z}is0(){return this.equals(m.ZERO)}negate(){return new m(a(-this.X),this.Y,this.Z,a(-this.T))}double(){let{a:p}=i,{X:b,Y:S,Z:_}=this,T=a(b*b),I=a(S*S),F=a(po*a(_*_)),L=a(p*T),B=b+S,O=a(a(B*B)-T-I),z=L+I,k=z-F,l=L-I,y=a(O*k),v=a(z*l),g=a(O*l),x=a(k*z);return new m(y,v,x,g)}add(p){E(p);let{a:b,d:S}=i,{X:_,Y:T,Z:I,T:F}=this,{X:L,Y:B,Z:O,T:z}=p,k=a(_*L),l=a(T*B),y=a(F*S*z),v=a(I*O),g=a((_+T)*(L+B)-k-l),x=v-y,A=v+y,C=a(l-b*k),D=a(g*x),U=a(A*C),R=a(g*C),K=a(x*A);return new m(D,U,K,R)}subtract(p){return E(p),this.add(p.negate())}multiply(p){if(!s.isValidNot0(p))throw new RangeError("invalid scalar: expected 1 <= sc < curve.n");let{p:b,f:S}=d.cached(this,p,_=>ie(m,_));return ie(m,[b,S])[0]}multiplyUnsafe(p){if(!s.isValid(p))throw new RangeError("invalid scalar: expected 0 <= sc < curve.n");return p===zt?m.ZERO:this.is0()||p===tt?this:d.unsafe(this,p,b=>ie(m,b))}isSmallOrder(){return this.clearCofactor().is0()}isTorsionFree(){return d.unsafe(this,i.n).is0()}toAffine(p){let b=this,S=p,{X:_,Y:T,Z:I}=b,F=b.is0();S==null&&(S=F?qf:o.inv(I));let L=a(_*S),B=a(T*S),O=o.mul(I,S);if(F)return{x:zt,y:tt};if(O!==tt)throw new Error("invZ was invalid");return{x:L,y:B}}clearCofactor(){return c===tt?this:this.multiplyUnsafe(c)}toBytes(){let{x:p,y:b}=this.toAffine(),S=o.toBytes(b);return S[S.length-1]|=p&tt?128:0,S}toHex(){return _e(this.toBytes())}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}}let d=new De(m,s.BITS);return s.BITS>=8&&m.BASE.precompute(8),Object.freeze(m.prototype),Object.freeze(m),m}var qr=class{static BASE;static ZERO;static Fp;static Fn;ep;constructor(t){this.ep=t}static fromBytes(t){so()}static fromHex(t){so()}get x(){return this.toAffine().x}get y(){return this.toAffine().y}clearCofactor(){return this}assertValidity(){this.ep.assertValidity()}toAffine(t){return this.ep.toAffine(t)}toHex(){return _e(this.toBytes())}toString(){return this.toHex()}isTorsionFree(){return!0}isSmallOrder(){return!1}add(t){return this.assertSame(t),this.init(this.ep.add(t.ep))}subtract(t){return this.assertSame(t),this.init(this.ep.subtract(t.ep))}multiply(t){return this.init(this.ep.multiply(t))}multiplyUnsafe(t){return this.init(this.ep.multiplyUnsafe(t))}double(){return this.init(this.ep.double())}negate(){return this.init(this.ep.negate())}precompute(t,e){return this.ep.precompute(t,e),this}};function Ui(r,t,e={}){if(typeof t!="function")throw new Error('"hash" function param is required');let n=t,o=e;xt(o,{},{adjustScalarBytes:"function",randomBytes:"function",domain:"function",prehash:"function",zip215:"boolean",mapToCurve:"function"});let{prehash:s}=o,{BASE:i,Fp:c,Fn:f}=r,a=n.outputLen,u=2*c.BYTES;if(a!==void 0&&(yt(a,"hash.outputLen"),a!==u))throw new Error(`hash.outputLen must be ${u}, got ${a}`);let h=o.randomBytes===void 0?Qe:o.randomBytes,E=o.adjustScalarBytes===void 0?l=>l:o.adjustScalarBytes,m=o.domain===void 0?(l,y,v)=>{if(bt(v,"phflag"),y.length||v)throw new Error("Contexts/pre-hash are not supported");return l}:o.domain;function d(l){return f.create(_t(l))}function w(l){let y=L.secretKey;M(l,L.secretKey,"secretKey");let v=M(n(l),2*y,"hashedSecretKey"),g=E(v.slice(0,y)),x=v.slice(y,2*y),A=d(g);return{head:g,prefix:x,scalar:A}}function p(l){let{head:y,prefix:v,scalar:g}=w(l),x=i.multiply(g),A=x.toBytes();return{head:y,prefix:v,scalar:g,point:x,pointBytes:A}}function b(l){return p(l).pointBytes}function S(l=Uint8Array.of(),...y){let v=W(...y);return d(n(m(v,M(l,void 0,"context"),!!s)))}function _(l,y,v={}){l=M(l,void 0,"message"),s&&(l=s(l));let{prefix:g,scalar:x,pointBytes:A}=p(y),C=S(v.context,g,l),D=i.multiply(C).toBytes(),U=S(v.context,D,A,l),R=f.create(C+U*x);if(!f.isValid(R))throw new Error("sign failed: invalid s");let K=W(D,f.toBytes(R));return M(K,L.signature,"result")}let T={zip215:o.zip215};function I(l,y,v,g=T){let{context:x}=g,A=g.zip215===void 0?!!T.zip215:g.zip215,C=L.signature;l=M(l,C,"signature"),y=M(y,void 0,"message"),v=M(v,L.publicKey,"publicKey"),A!==void 0&&bt(A,"zip215"),s&&(y=s(y));let D=C/2,U=l.subarray(0,D),R=_t(l.subarray(D,C)),K,P,N;try{K=r.fromBytes(v,A),P=r.fromBytes(U,A),N=i.multiplyUnsafe(R)}catch{return!1}if(!A&&K.isSmallOrder())return!1;let X=S(x,U,v,y);return P.add(K.multiplyUnsafe(X)).subtract(N).clearCofactor().is0()}let F=c.BYTES,L={secretKey:F,publicKey:F,signature:2*F,seed:F};function B(l){return l=l===void 0?h(L.seed):l,M(l,L.seed,"seed")}function O(l){return re(l)&&l.length===L.secretKey}function z(l,y){try{return!!r.fromBytes(l,y===void 0?T.zip215:y)}catch{return!1}}let k={getExtendedPublicKey:p,randomSecretKey:B,isValidSecretKey:O,isValidPublicKey:z,toMontgomery(l){let{y}=r.fromBytes(l),v=L.publicKey,g=v===32;if(!g&&v!==57)throw new Error("only defined for 25519 and 448");let x=g?c.div(tt+y,tt-y):c.div(y-tt,y+tt);return c.toBytes(x)},toMontgomerySecret(l){let y=L.secretKey;M(l,y);let v=n(l.subarray(0,y));return E(v).subarray(0,y)}};return Object.freeze(L),Object.freeze(k),Object.freeze({keygen:zr(B,b),getPublicKey:b,sign:_,verify:I,utils:k,Point:r,lengths:L})}function sr(r,t){if(yt(r),yt(t),t<0||t>4)throw new Error("invalid I2OSP length: "+t);if(r<0||r>2**(8*t)-1)throw new Error("invalid I2OSP input: "+r);let e=Array.from({length:t}).fill(0);for(let n=t-1;n>=0;n--)e[n]=r&255,r>>>=8;return new Uint8Array(e)}function Hf(r,t){let e=new Uint8Array(r.length);for(let n=0;n<r.length;n++)e[n]=r[n]^t[n];return e}function jf(r){if(!re(r)&&typeof r!="string")throw new Error("DST must be Uint8Array or ascii string");let t=typeof r=="string"?Kr(r):r;if(t.length===0)throw new Error("DST must be non-empty");return t}function mo(r,t,e,n){M(r),yt(e),t=jf(t),t.length>255&&(t=n(W(Kr("H2C-OVERSIZE-DST-"),t)));let{outputLen:o,blockLen:s}=n,i=Math.ceil(e/o);if(e>65535||i>255)throw new Error("expand_message_xmd: invalid lenInBytes");let c=W(t,sr(t.length,1)),f=new Uint8Array(s),a=sr(e,2),u=new Array(i),h=n(W(f,r,a,sr(0,1),c));u[0]=n(W(h,sr(1,1),c));for(let m=1;m<i;m++){let d=[Hf(h,u[m-1]),sr(m+1,1),c];u[m]=n(W(...d))}return W(...u).slice(0,e)}var Fi="HashToScalar-";var Zf=BigInt(0),Rt=BigInt(1),Ri=BigInt(2);var $f=BigInt(5),Yf=BigInt(8),Ce=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffed"),go={p:Ce,n:BigInt("0x1000000000000000000000000000000014def9dea2f79cd65812631a5cf5d3ed"),h:Yf,a:BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffec"),d:BigInt("0x52036cee2b6ffe738cc740797779e89800700a4d4141d8ab75eb4dca135978a3"),Gx:BigInt("0x216936d3cd6e53fec0a4e231fdd6dc5c692cc7609525a7b2c9562d608f25d51a"),Gy:BigInt("0x6666666666666666666666666666666666666666666666666666666666666658")};function Gf(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),o=BigInt(80),s=Ce,c=r*r%s*r%s,f=V(c,Ri,s)*c%s,a=V(f,Rt,s)*r%s,u=V(a,$f,s)*a%s,h=V(u,t,s)*u%s,E=V(h,e,s)*h%s,m=V(E,n,s)*E%s,d=V(m,o,s)*m%s,w=V(d,o,s)*m%s,p=V(w,t,s)*u%s;return{pow_p_5_8:V(p,Ri,s)*r%s,b2:c}}function Xf(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}var bo=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752");function wo(r,t){let e=Ce,n=G(t*t*t,e),o=G(n*n*t,e),s=Gf(r*o).pow_p_5_8,i=G(r*n*s,e),c=G(t*i*i,e),f=i,a=G(i*bo,e),u=c===r,h=c===G(-r,e),E=c===G(-r*bo,e);return u&&(i=f),(h||E)&&(i=a),Ft(i,e)&&(i=G(-i,e)),{isValid:u||h,value:i}}var Vt=Li(go,{uvRatio:wo}),qt=Vt.Fp,Ni=Vt.Fn;function Wf(r){return Ui(Vt,Fr,Object.assign({adjustScalarBytes:Xf,zip215:!0},r))}var Ki=Wf({});var yo=bo,Jf=BigInt("25063068953384623474111414158702152701244531502492656460079210482610430750235"),Qf=BigInt("54469307008909316920995813868745141605393597292927456921205312896311721017578"),tu=BigInt("1159843021668779879193775521855586647937357759715417654439879720876111806838"),eu=BigInt("40440834346308536858101042469323190826248399146238708352240133220865137265952"),Oi=r=>wo(Rt,r),ru=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"),xo=r=>qt.create(_t(r)&ru);function ki(r){let{d:t}=go,e=Ce,n=b=>qt.create(b),o=n(yo*r*r),s=n((o+Rt)*tu),i=BigInt(-1),c=n((i-t*o)*n(o+t)),{isValid:f,value:a}=wo(s,c),u=n(a*r);Ft(u,e)||(u=n(-u)),f||(a=u),f||(i=o);let h=n(i*(o-Rt)*eu-c),E=a*a,m=n((a+a)*c),d=n(h*Jf),w=n(Rt-E),p=n(Rt+E);return new Vt(n(m*p),n(w*d),n(d*p),n(m*w))}var Ht=class r extends qr{static BASE=new r(Vt.BASE);static ZERO=new r(Vt.ZERO);static Fp=qt;static Fn=Ni;constructor(t){super(t)}static fromAffine(t){return new r(Vt.fromAffine(t))}assertSame(t){if(!(t instanceof r))throw new Error("RistrettoPoint expected")}init(t){return new r(t)}static fromBytes(t){ut(t,32);let{a:e,d:n}=go,o=Ce,s=T=>qt.create(T),i=xo(t);if(!li(qt.toBytes(i),t)||Ft(i,o))throw new Error("invalid ristretto255 encoding 1");let c=s(i*i),f=s(Rt+e*c),a=s(Rt-e*c),u=s(f*f),h=s(a*a),E=s(e*n*u-h),{isValid:m,value:d}=Oi(s(E*h)),w=s(d*a),p=s(d*w*E),b=s((i+i)*w);Ft(b,o)&&(b=s(-b));let S=s(f*p),_=s(b*S);if(!m||Ft(_,o)||S===Zf)throw new Error("invalid ristretto255 encoding 2");return new r(new Vt(b,S,Rt,_))}static fromHex(t){return r.fromBytes(Ge(t))}toBytes(){let{X:t,Y:e,Z:n,T:o}=this.ep,s=Ce,i=p=>qt.create(p),c=i(i(n+e)*i(n-e)),f=i(t*e),a=i(f*f),{value:u}=Oi(i(c*a)),h=i(u*c),E=i(u*f),m=i(h*E*o),d;if(Ft(o*m,s)){let p=i(e*yo),b=i(t*yo);t=p,e=b,d=i(h*Qf)}else d=E;Ft(t*m,s)&&(e=i(-e));let w=i((n-e)*d);return Ft(w,s)&&(w=i(-w)),qt.toBytes(w)}equals(t){this.assertSame(t);let{X:e,Y:n}=this.ep,{X:o,Y:s}=t.ep,i=a=>qt.create(a),c=i(e*s)===i(n*o),f=i(n*s)===i(e*o);return c||f}is0(){return this.equals(r.ZERO)}};Object.freeze(Ht.BASE);Object.freeze(Ht.ZERO);Object.freeze(Ht.prototype);Object.freeze(Ht);var nu=Object.freeze({Point:Ht,hashToCurve(r,t){let e=t?.DST===void 0?"ristretto255_XMD:SHA-512_R255MAP_RO_":t.DST,n=mo(r,e,64,Fr);return nu.deriveToCurve(n)},hashToScalar(r,t={DST:Fi}){let e=mo(r,t.DST,64,Fr);return Ni.create(_t(e))},deriveToCurve(r){ut(r,64);let t=xo(r.subarray(0,32)),e=ki(t),n=xo(r.subarray(32,64)),o=ki(n);return new Ht(e.add(o))}});var ir=class extends Error{constructor(t="An error occurred while verifying a message"){super(t),this.name="VerificationError"}},Vr=class extends Error{constructor(t="Missing Web Crypto API"){super(t),this.name="WebCryptoMissingError"}};var Hr={get(r=globalThis){let t=r.crypto;if(t?.subtle==null)throw new Vr("Missing Web Crypto API. The most likely cause of this error is that this page is being accessed from an insecure context (i.e. not HTTPS). For more information and possible resolutions see https://github.com/libp2p/js-libp2p/blob/main/packages/crypto/README.md#web-crypto-api");return t}};var jr=32;var Eo,ou=(async()=>{try{return await Hr.get().subtle.generateKey({name:"Ed25519"},!0,["sign","verify"]),!0}catch{return!1}})();async function su(r,t,e){if(r.buffer instanceof ArrayBuffer){let n=await Hr.get().subtle.importKey("raw",r.buffer,{name:"Ed25519"},!1,["verify"]);return await Hr.get().subtle.verify({name:"Ed25519"},n,ge(t),ge(e instanceof Uint8Array?e:e.subarray()))}throw new TypeError("WebCrypto does not support SharedArrayBuffer for Ed25519 keys")}function iu(r,t,e){return Ki.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}async function Mi(r,t,e){return Eo==null&&(Eo=await ou),Eo?su(r,t,e):iu(r,t,e)}function Zr(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}var $r=class{type="Ed25519";raw;constructor(t){this.raw=So(t,jr)}toMultihash(){return dt.digest(Ee(this))}toCID(){return at.createV1(114,this.toMultihash())}toString(){return Y.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:pt(this.raw,t.raw)}verify(t,e,n){n?.signal?.throwIfAborted();let o=Mi(this.raw,e,t);return Zr(o)?o.then(s=>(n?.signal?.throwIfAborted(),s)):o}};function zi(r){return r=So(r,jr),new $r(r)}function So(r,t){if(r=Uint8Array.from(r??[]),r.length!==t)throw new It(`Key must be a Uint8Array of length ${t}, got ${r.length}`);return r}var au=Math.pow(2,7),fu=Math.pow(2,14),uu=Math.pow(2,21),qi=Math.pow(2,28),Vi=Math.pow(2,35),Hi=Math.pow(2,42),ji=Math.pow(2,49),st=128,jt=127;function cr(r){if(r<au)return 1;if(r<fu)return 2;if(r<uu)return 3;if(r<qi)return 4;if(r<Vi)return 5;if(r<Hi)return 6;if(r<ji)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function Zi(r,t,e=0){switch(cr(r)){case 8:t[e++]=r&255|st,r/=128;case 7:t[e++]=r&255|st,r/=128;case 6:t[e++]=r&255|st,r/=128;case 5:t[e++]=r&255|st,r/=128;case 4:t[e++]=r&255|st,r>>>=7;case 3:t[e++]=r&255|st,r>>>=7;case 2:t[e++]=r&255|st,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function $i(r,t){let e=r[t],n=0;if(n+=e&jt,e<st||(e=r[t+1],n+=(e&jt)<<7,e<st)||(e=r[t+2],n+=(e&jt)<<14,e<st)||(e=r[t+3],n+=(e&jt)<<21,e<st)||(e=r[t+4],n+=(e&jt)*qi,e<st)||(e=r[t+5],n+=(e&jt)*Vi,e<st)||(e=r[t+6],n+=(e&jt)*Hi,e<st)||(e=r[t+7],n+=(e&jt)*ji,e<st))return n;throw new RangeError("Could not decode varint")}var _o=new Float32Array([-0]),Zt=new Uint8Array(_o.buffer);function Yi(r,t,e){_o[0]=r,t[e]=Zt[0],t[e+1]=Zt[1],t[e+2]=Zt[2],t[e+3]=Zt[3]}function Gi(r,t){return Zt[0]=r[t],Zt[1]=r[t+1],Zt[2]=r[t+2],Zt[3]=r[t+3],_o[0]}var vo=new Float64Array([-0]),ot=new Uint8Array(vo.buffer);function Xi(r,t,e){vo[0]=r,t[e]=ot[0],t[e+1]=ot[1],t[e+2]=ot[2],t[e+3]=ot[3],t[e+4]=ot[4],t[e+5]=ot[5],t[e+6]=ot[6],t[e+7]=ot[7]}function Wi(r,t){return ot[0]=r[t],ot[1]=r[t+1],ot[2]=r[t+2],ot[3]=r[t+3],ot[4]=r[t+4],ot[5]=r[t+5],ot[6]=r[t+6],ot[7]=r[t+7],vo[0]}var hu=BigInt(Number.MAX_SAFE_INTEGER),lu=BigInt(Number.MIN_SAFE_INTEGER),ht=class r{lo;hi;constructor(t,e){this.lo=t|0,this.hi=e|0}toNumber(t=!1){if(!t&&this.hi>>>31>0){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(e+n*4294967296)}return this.lo+this.hi*4294967296}toBigInt(t=!1){if(t)return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n);if(this.hi>>>31){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(BigInt(e)+(BigInt(n)<<32n))}return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n)}toString(t=!1){return this.toBigInt(t).toString()}zzEncode(){let t=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^t)>>>0,this.lo=(this.lo<<1^t)>>>0,this}zzDecode(){let t=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^t)>>>0,this.hi=(this.hi>>>1^t)>>>0,this}length(){let t=this.lo,e=(this.lo>>>28|this.hi<<4)>>>0,n=this.hi>>>24;return n===0?e===0?t<16384?t<128?1:2:t<2097152?3:4:e<16384?e<128?5:6:e<2097152?7:8:n<128?9:10}static fromBigInt(t){if(t===0n)return ce;if(t<hu&&t>lu)return this.fromNumber(Number(t));let e=t<0n;e&&(t=-t);let n=t>>32n,o=t-(n<<32n);return e&&(n=~n|0n,o=~o|0n,++o>Ji&&(o=0n,++n>Ji&&(n=0n))),new r(Number(o),Number(n))}static fromNumber(t){if(t===0)return ce;let e=t<0;e&&(t=-t);let n=t>>>0,o=(t-n)/4294967296>>>0;return e&&(o=~o>>>0,n=~n>>>0,++n>4294967295&&(n=0,++o>4294967295&&(o=0))),new r(n,o)}static from(t){return typeof t=="number"?r.fromNumber(t):typeof t=="bigint"?r.fromBigInt(t):typeof t=="string"?r.fromBigInt(BigInt(t)):t.low!=null||t.high!=null?new r(t.low>>>0,t.high>>>0):ce}},ce=new ht(0,0);ce.toBigInt=function(){return 0n};ce.zzEncode=ce.zzDecode=function(){return this};ce.length=function(){return 1};var Ji=4294967296n;function Qi(r){let t=0,e=0;for(let n=0;n<r.length;++n)e=r.charCodeAt(n),e<128?t+=1:e<2048?t+=2:(e&64512)===55296&&(r.charCodeAt(n+1)&64512)===56320?(++n,t+=4):t+=3;return t}function tc(r,t,e){if(e-t<1)return"";let o,s=[],i=0,c;for(;t<e;)c=r[t++],c<128?s[i++]=c:c>191&&c<224?s[i++]=(c&31)<<6|r[t++]&63:c>239&&c<365?(c=((c&7)<<18|(r[t++]&63)<<12|(r[t++]&63)<<6|r[t++]&63)-65536,s[i++]=55296+(c>>10),s[i++]=56320+(c&1023)):s[i++]=(c&15)<<12|(r[t++]&63)<<6|r[t++]&63,i>8191&&((o??(o=[])).push(String.fromCharCode.apply(String,s)),i=0);return o!=null?(i>0&&o.push(String.fromCharCode.apply(String,s.slice(0,i))),o.join("")):String.fromCharCode.apply(String,s.slice(0,i))}function Ao(r,t,e){let n=e,o,s;for(let i=0;i<r.length;++i)o=r.charCodeAt(i),o<128?t[e++]=o:o<2048?(t[e++]=o>>6|192,t[e++]=o&63|128):(o&64512)===55296&&((s=r.charCodeAt(i+1))&64512)===56320?(o=65536+((o&1023)<<10)+(s&1023),++i,t[e++]=o>>18|240,t[e++]=o>>12&63|128,t[e++]=o>>6&63|128,t[e++]=o&63|128):(t[e++]=o>>12|224,t[e++]=o>>6&63|128,t[e++]=o&63|128);return e-n}function gt(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function Yr(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var Bo=class{buf;pos;len;_slice=Uint8Array.prototype.subarray;constructor(t){this.buf=t,this.pos=0,this.len=t.length}uint32(){let t=4294967295;if(t=(this.buf[this.pos]&127)>>>0,this.buf[this.pos++]<128||(t=(t|(this.buf[this.pos]&127)<<7)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<14)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<21)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&15)<<28)>>>0,this.buf[this.pos++]<128))return t;if((this.pos+=5)>this.len)throw this.pos=this.len,gt(this,10);return t}int32(){return this.uint32()|0}sint32(){let t=this.uint32();return t>>>1^-(t&1)|0}bool(){return this.uint32()!==0}fixed32(){if(this.pos+4>this.len)throw gt(this,4);return Yr(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw gt(this,4);return Yr(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw gt(this,4);let t=Gi(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw gt(this,4);let t=Wi(this.buf,this.pos);return this.pos+=8,t}bytes(){let t=this.uint32(),e=this.pos,n=this.pos+t;if(n>this.len)throw gt(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return tc(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw gt(this,t);this.pos+=t}else do if(this.pos>=this.len)throw gt(this);while((this.buf[this.pos++]&128)!==0);return this}skipType(t){switch(t){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;(t=this.uint32()&7)!==4;)this.skipType(t);break;case 5:this.skip(4);break;default:throw Error(`invalid wire type ${t} at offset ${this.pos}`)}return this}readLongVarint(){let t=new ht(0,0),e=0;if(this.len-this.pos>4){for(;e<4;++e)if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t;if(t.lo=(t.lo|(this.buf[this.pos]&127)<<28)>>>0,t.hi=(t.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return t;e=0}else{for(;e<3;++e){if(this.pos>=this.len)throw gt(this);if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t}return t.lo=(t.lo|(this.buf[this.pos++]&127)<<e*7)>>>0,t}if(this.len-this.pos>4){for(;e<5;++e)if(t.hi=(t.hi|(this.buf[this.pos]&127)<<e*7+3)>>>0,this.buf[this.pos++]<128)return t}else for(;e<5;++e){if(this.pos>=this.len)throw gt(this);if(t.hi=(t.hi|(this.buf[this.pos]&127)<<e*7+3)>>>0,this.buf[this.pos++]<128)return t}throw Error("invalid varint encoding")}readFixed64(){if(this.pos+8>this.len)throw gt(this,8);let t=Yr(this.buf,this.pos+=4),e=Yr(this.buf,this.pos+=4);return new ht(t,e)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){let t=$i(this.buf,this.pos);return this.pos+=cr(t),t}uint64String(){return this.readLongVarint().toString(!0)}sint64(){return this.readLongVarint().zzDecode().toBigInt()}sint64Number(){return this.readLongVarint().zzDecode().toNumber()}sint64String(){return this.readLongVarint().zzDecode().toString()}fixed64(){return this.readFixed64().toBigInt()}fixed64Number(){return this.readFixed64().toNumber()}fixed64String(){return this.readFixed64().toString()}sfixed64(){return this.readFixed64().toBigInt()}sfixed64Number(){return this.readFixed64().toNumber()}sfixed64String(){return this.readFixed64().toString()}};function ar(r){return new Bo(r instanceof Uint8Array?r:r.subarray())}function Gr(r,t,e){let n=ar(r);return t.decode(n,void 0,e)}function ae(r=0){return new Uint8Array(r)}var Lo={};q(Lo,{base10:()=>gu});var jp=new Uint8Array(0);function rc(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function Ot(r){if(r instanceof Uint8Array&&r.constructor.name==="Uint8Array")return r;if(r instanceof ArrayBuffer)return new Uint8Array(r);if(ArrayBuffer.isView(r))return new Uint8Array(r.buffer,r.byteOffset,r.byteLength);throw new Error("Unknown type, must be binary type")}function nc(r){return new TextEncoder().encode(r)}function oc(r){return new TextDecoder().decode(r)}function du(r,t){if(r.length>=255)throw new TypeError("Alphabet too long");for(var e=new Uint8Array(256),n=0;n<e.length;n++)e[n]=255;for(var o=0;o<r.length;o++){var s=r.charAt(o),i=s.charCodeAt(0);if(e[i]!==255)throw new TypeError(s+" is ambiguous");e[i]=o}var c=r.length,f=r.charAt(0),a=Math.log(c)/Math.log(256),u=Math.log(256)/Math.log(c);function h(d){if(d instanceof Uint8Array||(ArrayBuffer.isView(d)?d=new Uint8Array(d.buffer,d.byteOffset,d.byteLength):Array.isArray(d)&&(d=Uint8Array.from(d))),!(d instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(d.length===0)return"";for(var w=0,p=0,b=0,S=d.length;b!==S&&d[b]===0;)b++,w++;for(var _=(S-b)*u+1>>>0,T=new Uint8Array(_);b!==S;){for(var I=d[b],F=0,L=_-1;(I!==0||F<p)&&L!==-1;L--,F++)I+=256*T[L]>>>0,T[L]=I%c>>>0,I=I/c>>>0;if(I!==0)throw new Error("Non-zero carry");p=F,b++}for(var B=_-p;B!==_&&T[B]===0;)B++;for(var O=f.repeat(w);B<_;++B)O+=r.charAt(T[B]);return O}function E(d){if(typeof d!="string")throw new TypeError("Expected String");if(d.length===0)return new Uint8Array;var w=0;if(d[w]!==" "){for(var p=0,b=0;d[w]===f;)p++,w++;for(var S=(d.length-w)*a+1>>>0,_=new Uint8Array(S);d[w];){var T=e[d.charCodeAt(w)];if(T===255)return;for(var I=0,F=S-1;(T!==0||I<b)&&F!==-1;F--,I++)T+=c*_[F]>>>0,_[F]=T%256>>>0,T=T/256>>>0;if(T!==0)throw new Error("Non-zero carry");b=I,w++}if(d[w]!==" "){for(var L=S-b;L!==S&&_[L]===0;)L++;for(var B=new Uint8Array(p+(S-L)),O=p;L!==S;)B[O++]=_[L++];return B}}}function m(d){var w=E(d);if(w)return w;throw new Error(`Non-${t} character`)}return{encode:h,decodeUnsafe:E,decode:m}}var pu=du,mu=pu,ic=mu;var Io=class{name;prefix;baseEncode;constructor(t,e,n){this.name=t,this.prefix=e,this.baseEncode=n}encode(t){if(t instanceof Uint8Array)return`${this.prefix}${this.baseEncode(t)}`;throw Error("Unknown type, must be binary type")}},To=class{name;prefix;baseDecode;prefixCodePoint;constructor(t,e,n){this.name=t,this.prefix=e;let o=e.codePointAt(0);if(o===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=o,this.baseDecode=n}decode(t){if(typeof t=="string"){if(t.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(t)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(t.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(t){return cc(this,t)}},Do=class{decoders;constructor(t){this.decoders=t}or(t){return cc(this,t)}decode(t){let e=t[0],n=this.decoders[e];if(n!=null)return n.decode(t);throw RangeError(`Unable to decode multibase string ${JSON.stringify(t)}, only inputs prefixed with ${Object.keys(this.decoders)} are supported`)}};function cc(r,t){return new Do({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var Co=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(t,e,n,o){this.name=t,this.prefix=e,this.baseEncode=n,this.baseDecode=o,this.encoder=new Io(t,e,n),this.decoder=new To(t,e,o)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function Le({name:r,prefix:t,encode:e,decode:n}){return new Co(r,t,e,n)}function $t({name:r,prefix:t,alphabet:e}){let{encode:n,decode:o}=ic(e,r);return Le({prefix:t,name:r,encode:n,decode:s=>Ot(o(s))})}function bu(r,t,e,n){let o=r.length;for(;r[o-1]==="=";)--o;let s=new Uint8Array(o*e/8|0),i=0,c=0,f=0;for(let a=0;a<o;++a){let u=t[r[a]];if(u===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<e|u,i+=e,i>=8&&(i-=8,s[f++]=255&c>>i)}if(i>=e||(255&c<<8-i)!==0)throw new SyntaxError("Unexpected end of data");return s}function yu(r,t,e){let n=t[t.length-1]==="=",o=(1<<e)-1,s="",i=0,c=0;for(let f=0;f<r.length;++f)for(c=c<<8|r[f],i+=8;i>e;)i-=e,s+=t[o&c>>i];if(i!==0&&(s+=t[o&c<<e-i]),n)for(;(s.length*e&7)!==0;)s+="=";return s}function xu(r){let t={};for(let e=0;e<r.length;++e)t[r[e]]=e;return t}function Z({name:r,prefix:t,bitsPerChar:e,alphabet:n}){let o=xu(n);return Le({prefix:t,name:r,encode(s){return yu(s,n,e)},decode(s){return bu(s,o,e,r)}})}var gu=$t({prefix:"9",name:"base10",alphabet:"0123456789"});var Uo={};q(Uo,{base16:()=>wu,base16upper:()=>Eu});var wu=Z({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Eu=Z({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Fo={};q(Fo,{base2:()=>Su});var Su=Z({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Ro={};q(Ro,{base256emoji:()=>Iu});var ac=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}"),_u=ac.reduce((r,t,e)=>(r[e]=t,r),[]),vu=ac.reduce((r,t,e)=>{let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);return r[n]=e,r},[]);function Au(r){return r.reduce((t,e)=>(t+=_u[e],t),"")}function Bu(r){let t=[];for(let e of r){let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);let o=vu[n];if(o==null)throw new Error(`Non-base256emoji character: ${e}`);t.push(o)}return new Uint8Array(t)}var Iu=Le({prefix:"\u{1F680}",name:"base256emoji",encode:Au,decode:Bu});var Oo={};q(Oo,{base32:()=>Ue,base32hex:()=>Lu,base32hexpad:()=>Fu,base32hexpadupper:()=>Ru,base32hexupper:()=>Uu,base32pad:()=>Du,base32padupper:()=>Cu,base32upper:()=>Tu,base32z:()=>Ou});var Ue=Z({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),Tu=Z({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Du=Z({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),Cu=Z({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),Lu=Z({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),Uu=Z({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),Fu=Z({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),Ru=Z({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),Ou=Z({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var ko={};q(ko,{base36:()=>fr,base36upper:()=>ku});var fr=$t({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),ku=$t({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var No={};q(No,{base58btc:()=>vt,base58flickr:()=>Nu});var vt=$t({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),Nu=$t({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Ko={};q(Ko,{base64:()=>Ku,base64pad:()=>Mu,base64url:()=>Pu,base64urlpad:()=>zu});var Ku=Z({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),Mu=Z({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Pu=Z({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),zu=Z({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Mo={};q(Mo,{base8:()=>qu});var qu=Z({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Po={};q(Po,{identity:()=>Vu});var Vu=Le({prefix:"\0",name:"identity",encode:r=>oc(r),decode:r=>nc(r)});var c0=new TextEncoder,a0=new TextDecoder;var qo={};q(qo,{identity:()=>lh});var Zu=hc,fc=128,$u=127,Yu=~$u,Gu=Math.pow(2,31);function hc(r,t,e){t=t||[],e=e||0;for(var n=e;r>=Gu;)t[e++]=r&255|fc,r/=128;for(;r&Yu;)t[e++]=r&255|fc,r>>>=7;return t[e]=r|0,hc.bytes=e-n+1,t}var Xu=zo,Wu=128,uc=127;function zo(r,n){var e=0,n=n||0,o=0,s=n,i,c=r.length;do{if(s>=c)throw zo.bytes=0,new RangeError("Could not decode varint");i=r[s++],e+=o<28?(i&uc)<<o:(i&uc)*Math.pow(2,o),o+=7}while(i>=Wu);return zo.bytes=s-n,e}var Ju=Math.pow(2,7),Qu=Math.pow(2,14),th=Math.pow(2,21),eh=Math.pow(2,28),rh=Math.pow(2,35),nh=Math.pow(2,42),oh=Math.pow(2,49),sh=Math.pow(2,56),ih=Math.pow(2,63),ch=function(r){return r<Ju?1:r<Qu?2:r<th?3:r<eh?4:r<rh?5:r<nh?6:r<oh?7:r<sh?8:r<ih?9:10},ah={encode:Zu,decode:Xu,encodingLength:ch},fh=ah,ur=fh;function hr(r,t=0){return[ur.decode(r,t),ur.decode.bytes]}function Fe(r,t,e=0){return ur.encode(r,t,e),t}function Re(r){return ur.encodingLength(r)}function ke(r,t){let e=t.byteLength,n=Re(r),o=n+Re(e),s=new Uint8Array(o+e);return Fe(r,s,0),Fe(e,s,n),s.set(t,o),new Oe(r,e,t,s)}function lc(r){let t=Ot(r),[e,n]=hr(t),[o,s]=hr(t.subarray(n)),i=t.subarray(n+s);if(i.byteLength!==o)throw new Error("Incorrect length");return new Oe(e,o,i,t)}function dc(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&rc(r.bytes,e.bytes)}}var Oe=class{code;size;digest;bytes;constructor(t,e,n,o){this.code=t,this.size=e,this.digest=n,this.bytes=o}};var pc=0,uh="identity",mc=Ot;function hh(r,t){if(t?.truncate!=null&&t.truncate!==r.byteLength){if(t.truncate<0||t.truncate>r.byteLength)throw new Error(`Invalid truncate option, must be less than or equal to ${r.byteLength}`);r=r.subarray(0,t.truncate)}return ke(pc,mc(r))}var lh={code:pc,name:uh,encode:mc,digest:hh};var jo={};q(jo,{sha256:()=>ph,sha512:()=>mh});var dh=20;function Ho({name:r,code:t,encode:e,minDigestLength:n,maxDigestLength:o}){return new Vo(r,t,e,n,o)}var Vo=class{name;code;encode;minDigestLength;maxDigestLength;constructor(t,e,n,o,s){this.name=t,this.code=e,this.encode=n,this.minDigestLength=o??dh,this.maxDigestLength=s}digest(t,e){if(e?.truncate!=null){if(e.truncate<this.minDigestLength)throw new Error(`Invalid truncate option, must be greater than or equal to ${this.minDigestLength}`);if(this.maxDigestLength!=null&&e.truncate>this.maxDigestLength)throw new Error(`Invalid truncate option, must be less than or equal to ${this.maxDigestLength}`)}if(t instanceof Uint8Array){let n=this.encode(t);return n instanceof Uint8Array?bc(n,this.code,e?.truncate):n.then(o=>bc(o,this.code,e?.truncate))}else throw Error("Unknown type, must be binary type")}};function bc(r,t,e){if(e!=null&&e!==r.byteLength){if(e>r.byteLength)throw new Error(`Invalid truncate option, must be less than or equal to ${r.byteLength}`);r=r.subarray(0,e)}return ke(t,r)}function xc(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var ph=Ho({name:"sha2-256",code:18,encode:xc("SHA-256")}),mh=Ho({name:"sha2-512",code:19,encode:xc("SHA-512")});function gc(r,t){let{bytes:e,version:n}=r;return n===0?yh(e,Zo(r),t??vt.encoder):xh(e,Zo(r),t??Ue.encoder)}var wc=new WeakMap;function Zo(r){let t=wc.get(r);if(t==null){let e=new Map;return wc.set(r,e),e}return t}var Wr=class r{code;version;multihash;bytes;"/";constructor(t,e,n,o){this.code=e,this.version=t,this.multihash=n,this.bytes=o,this["/"]=o}get asCID(){return this}get byteOffset(){return this.bytes.byteOffset}get byteLength(){return this.bytes.byteLength}toV0(){switch(this.version){case 0:return this;case 1:{let{code:t,multihash:e}=this;if(t!==dr)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==gh)throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");return r.createV0(e)}default:throw Error(`Can not convert CID version ${this.version} to version 0. This is a bug please report`)}}toV1(){switch(this.version){case 0:{let{code:t,digest:e}=this.multihash,n=ke(t,e);return r.createV1(this.code,n)}case 1:return this;default:throw Error(`Can not convert CID version ${this.version} to version 1. This is a bug please report`)}}equals(t){return r.equals(this,t)}static equals(t,e){let n=e;return n!=null&&t.code===n.code&&t.version===n.version&&dc(t.multihash,n.multihash)}toString(t){return gc(this,t)}toJSON(){return{"/":gc(this)}}link(){return this}[Symbol.toStringTag]="CID";[Symbol.for("nodejs.util.inspect.custom")](){return`CID(${this.toString()})`}static asCID(t){if(t==null)return null;let e=t;if(e instanceof r)return e;if(e["/"]!=null&&e["/"]===e.bytes||e.asCID===e){let{version:n,code:o,multihash:s,bytes:i}=e;return new r(n,o,s,i??Ec(n,o,s.bytes))}else if(e[wh]===!0){let{version:n,multihash:o,code:s}=e,i=lc(o);return r.create(n,s,i)}else return null}static create(t,e,n){if(typeof e!="number")throw new Error("String codecs are no longer supported");if(!(n.bytes instanceof Uint8Array))throw new Error("Invalid digest");switch(t){case 0:{if(e!==dr)throw new Error(`Version 0 CID must use dag-pb (code: ${dr}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let o=Ec(t,e,n.bytes);return new r(t,e,n,o)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,dr,t)}static createV1(t,e){return r.create(1,t,e)}static decode(t){let[e,n]=r.decodeFirst(t);if(n.length!==0)throw new Error("Incorrect length");return e}static decodeFirst(t){let e=r.inspectBytes(t),n=e.size-e.multihashSize,o=Ot(t.subarray(n,n+e.multihashSize));if(o.byteLength!==e.multihashSize)throw new Error("Incorrect length");let s=o.subarray(e.multihashSize-e.digestSize),i=new Oe(e.multihashCode,e.digestSize,s,o);return[e.version===0?r.createV0(i):r.createV1(e.codec,i),t.subarray(e.size)]}static inspectBytes(t){let e=0,n=()=>{let[h,E]=hr(t.subarray(e));return e+=E,h},o=n(),s=dr;if(o===18?(o=0,e=0):s=n(),o!==0&&o!==1)throw new RangeError(`Invalid CID version ${o}`);let i=e,c=n(),f=n(),a=e+f,u=a-i;return{version:o,codec:s,multihashCode:c,digestSize:f,multihashSize:u,size:a}}static parse(t,e){let[n,o]=bh(t,e),s=r.decode(o);if(s.version===0&&t[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return Zo(s).set(n,t),s}};function bh(r,t){switch(r[0]){case"Q":{let e=t??vt;return[vt.prefix,e.decode(`${vt.prefix}${r}`)]}case vt.prefix:{let e=t??vt;return[vt.prefix,e.decode(r)]}case Ue.prefix:{let e=t??Ue;return[Ue.prefix,e.decode(r)]}case fr.prefix:{let e=t??fr;return[fr.prefix,e.decode(r)]}default:{if(t==null)throw Error("To parse non base32, base36 or base58btc encoded CID multibase decoder must be provided");return[r[0],t.decode(r)]}}}function yh(r,t,e){let{prefix:n}=e;if(n!==vt.prefix)throw Error(`Cannot string encode V0 in ${e.name} encoding`);let o=t.get(n);if(o==null){let s=e.encode(r).slice(1);return t.set(n,s),s}else return o}function xh(r,t,e){let{prefix:n}=e,o=t.get(n);if(o==null){let s=e.encode(r);return t.set(n,s),s}else return o}var dr=112,gh=18;function Ec(r,t,e){let n=Re(r),o=n+Re(t),s=new Uint8Array(o+e.byteLength);return Fe(r,s,0),Fe(t,s,n),s.set(e,o),s}var wh=Symbol.for("@ipld/js-cid/CID");var $o={...Po,...Fo,...Mo,...Lo,...Uo,...Oo,...ko,...No,...Ko,...Ro},C0={...jo,...qo};function _c(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var Sc=_c("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),Yo=_c("ascii","a",r=>{let t="a";for(let e=0;e<r.length;e++)t+=String.fromCharCode(r[e]);return t},r=>{r=r.substring(1);let t=ae(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),Eh={utf8:Sc,"utf-8":Sc,hex:$o.base16,latin1:Yo,ascii:Yo,binary:Yo,...$o},vc=Eh;function Ac(r,t="utf8"){let e=vc[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function Go(r){let t=r??8192,e=t>>>1,n,o=t;return function(i){if(i<1||i>e)return ae(i);o+i>t&&(n=ae(t),o=0);let c=n.subarray(o,o+=i);return(o&7)!==0&&(o=(o|7)+1),c}}var fe=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function Xo(){}var Jo=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},Sh=Go();function _h(r){return globalThis.Buffer!=null?ae(r):Sh(r)}var mr=class{len;head;tail;states;constructor(){this.len=0,this.head=new fe(Xo,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new fe(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new Qo((t=t>>>0)<128?1:t<16384?2:t<2097152?3:t<268435456?4:5,t)).len,this}int32(t){return t<0?this._push(Jr,10,ht.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=ht.fromBigInt(t);return this._push(Jr,e.length(),e)}uint64Number(t){return this._push(Zi,cr(t),t)}uint64String(t){return this.uint64(BigInt(t))}int64(t){return this.uint64(t)}int64Number(t){return this.uint64Number(t)}int64String(t){return this.uint64String(t)}sint64(t){let e=ht.fromBigInt(t).zzEncode();return this._push(Jr,e.length(),e)}sint64Number(t){let e=ht.fromNumber(t).zzEncode();return this._push(Jr,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(Wo,1,t?1:0)}fixed32(t){return this._push(pr,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=ht.fromBigInt(t);return this._push(pr,4,e.lo)._push(pr,4,e.hi)}fixed64Number(t){let e=ht.fromNumber(t);return this._push(pr,4,e.lo)._push(pr,4,e.hi)}fixed64String(t){return this.fixed64(BigInt(t))}sfixed64(t){return this.fixed64(t)}sfixed64Number(t){return this.fixed64Number(t)}sfixed64String(t){return this.fixed64String(t)}float(t){return this._push(Yi,4,t)}double(t){return this._push(Xi,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(Wo,1,0):this.uint32(e)._push(Ah,e,t)}string(t){let e=Qi(t);return e!==0?this.uint32(e)._push(Ao,e,t):this._push(Wo,1,0)}fork(){return this.states=new Jo(this),this.head=this.tail=new fe(Xo,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 fe(Xo,0,0),this.len=0),this}ldelim(){let t=this.head,e=this.tail,n=this.len;return this.reset().uint32(n),n!==0&&(this.tail.next=t.next,this.tail=e,this.len+=n),this}finish(){let t=this.head.next,e=_h(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function Wo(r,t,e){t[e]=r&255}function vh(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var Qo=class extends fe{next;constructor(t,e){super(vh,t,e),this.next=void 0}};function Jr(r,t,e){for(;r.hi!==0;)t[e++]=r.lo&127|128,r.lo=(r.lo>>>7|r.hi<<25)>>>0,r.hi>>>=7;for(;r.lo>127;)t[e++]=r.lo&127|128,r.lo=r.lo>>>7;t[e++]=r.lo}function pr(r,t,e){t[e]=r&255,t[e+1]=r>>>8&255,t[e+2]=r>>>16&255,t[e+3]=r>>>24}function Ah(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(mr.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(Bh,t,r),this},mr.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(Ih,t,r),this});function Bh(r,t,e){t.set(r,e)}function Ih(r,t,e){r.length<40?Ao(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(Ac(r),e)}function ts(){return new mr}function Qr(r,t){let e=ts();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}function*tn(r,t,e){let n=ar(r);yield*t.stream(n,void 0,"$",e)}var en={VARINT:0,BIT64:1,LENGTH_DELIMITED:2,START_GROUP:3,END_GROUP:4,BIT32:5};function rn(r,t,e,n,o){return{name:r,type:t,encode:e,decode:n,stream:o}}function es(r){function t(s){if(r[s.toString()]==null)throw new Error("Invalid enum value");return r[s]}let e=function(i,c){let f=t(i);c.int32(f)},n=function(i){let c=i.int32();return t(c)},o=function*(i){let c=i.int32();yield t(c)};return rn("enum",en.VARINT,e,n,o)}function nn(r,t,e){return rn("message",en.LENGTH_DELIMITED,r,t,e)}var it;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.secp256k1="secp256k1",r.ECDSA="ECDSA"})(it||(it={}));var rs;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1",r[r.ECDSA=3]="ECDSA"})(rs||(rs={}));(function(r){r.codec=()=>es(rs)})(it||(it={}));var br;(function(r){let t;r.codec=()=>(t==null&&(t=nn((s,i,c={})=>{c.lengthDelimited!==!1&&i.fork(),s.Type!=null&&(i.uint32(8),it.codec().encode(s.Type,i)),s.Data!=null&&(i.uint32(18),i.bytes(s.Data)),c.lengthDelimited!==!1&&i.ldelim()},(s,i,c={})=>{let f={},a=i==null?s.len:s.pos+i;for(;s.pos<a;){let u=s.uint32();switch(u>>>3){case 1:{f.Type=it.codec().decode(s);break}case 2:{f.Data=s.bytes();break}default:{s.skipType(u&7);break}}}return f},function*(s,i,c,f={}){let a=i==null?s.len:s.pos+i;for(;s.pos<a;){let u=s.uint32();switch(u>>>3){case 1:{yield{field:`${c}.Type`,value:it.codec().decode(s)};break}case 2:{yield{field:`${c}.Data`,value:s.bytes()};break}default:{s.skipType(u&7);break}}}})),t);function e(s){return Qr(s,r.codec())}r.encode=e;function n(s,i){return Gr(s,r.codec(),i)}r.decode=n;function o(s,i){return tn(s,r.codec(),i)}r.stream=o})(br||(br={}));var ns;(function(r){let t;r.codec=()=>(t==null&&(t=nn((s,i,c={})=>{c.lengthDelimited!==!1&&i.fork(),s.Type!=null&&(i.uint32(8),it.codec().encode(s.Type,i)),s.Data!=null&&(i.uint32(18),i.bytes(s.Data)),c.lengthDelimited!==!1&&i.ldelim()},(s,i,c={})=>{let f={},a=i==null?s.len:s.pos+i;for(;s.pos<a;){let u=s.uint32();switch(u>>>3){case 1:{f.Type=it.codec().decode(s);break}case 2:{f.Data=s.bytes();break}default:{s.skipType(u&7);break}}}return f},function*(s,i,c,f={}){let a=i==null?s.len:s.pos+i;for(;s.pos<a;){let u=s.uint32();switch(u>>>3){case 1:{yield{field:`${c}.Type`,value:it.codec().decode(s)};break}case 2:{yield{field:`${c}.Data`,value:s.bytes()};break}default:{s.skipType(u&7);break}}}})),t);function e(s){return Qr(s,r.codec())}r.encode=e;function n(s,i){return Gr(s,r.codec(),i)}r.decode=n;function o(s,i){return tn(s,r.codec(),i)}r.stream=o})(ns||(ns={}));var on=class{oHash;iHash;blockLen;outputLen;canXOF=!1;finished=!1;destroyed=!1;constructor(t,e){if(Tr(t),ut(e,void 0,"key"),this.iHash=t.create(),typeof this.iHash.update!="function")throw new Error("Expected instance of class which extends utils.Hash");this.blockLen=this.iHash.blockLen,this.outputLen=this.iHash.outputLen;let n=this.blockLen,o=new Uint8Array(n);o.set(e.length>n?t.create().update(e).digest():e);for(let s=0;s<o.length;s++)o[s]^=54;this.iHash.update(o),this.oHash=t.create();for(let s=0;s<o.length;s++)o[s]^=106;this.oHash.update(o),Lt(o)}update(t){return Se(this),this.iHash.update(t),this}digestInto(t){Se(this),Dr(t,this),this.finished=!0;let e=t.subarray(0,this.outputLen);this.iHash.digestInto(e),this.oHash.update(e),this.oHash.digestInto(e),this.destroy()}digest(){let t=new Uint8Array(this.oHash.outputLen);return this.digestInto(t),t}_cloneInto(t){t||=Object.create(Object.getPrototypeOf(this),{});let{oHash:e,iHash:n,finished:o,destroyed:s,blockLen:i,outputLen:c}=this;return t=t,t.finished=o,t.destroyed=s,t.blockLen=i,t.outputLen=c,t.oHash=e._cloneInto(t.oHash),t.iHash=n._cloneInto(t.iHash),t}clone(){return this._cloneInto()}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},Bc=(()=>{let r=((t,e,n)=>new on(t,e).update(n).digest());return r.create=(t,e)=>new on(t,e),r})();var Ic=(r,t)=>(r+(r>=0?t:-t)/Tc)/t;function Dh(r,t,e){Ae("scalar",r,At,e);let[[n,o],[s,i]]=t,c=Ic(i*r,e),f=Ic(-o*r,e),a=r-c*n-f*s,u=-c*o-f*i,h=a<At,E=u<At;h&&(a=-a),E&&(u=-u);let m=rr(Math.ceil(Be(e)/2))+Yt;if(a<At||a>=m||u<At||u>=m)throw new Error("splitScalar (endomorphism): failed for k");return{k1neg:h,k1:a,k2neg:E,k2:u}}function ss(r){if(!["compact","recovered","der"].includes(r))throw new Error('Signature format must be "compact", "recovered", or "der"');return r}function os(r,t){xt(r);let e={};for(let n of Object.keys(t))e[n]=r[n]===void 0?t[n]:r[n];return bt(e.lowS,"lowS"),bt(e.prehash,"prehash"),e.format!==void 0&&ss(e.format),e}var is=class extends Error{constructor(t=""){super(t)}},wt={Err:is,_tlv:{encode:(r,t)=>{let{Err:e}=wt;if(yt(r,"tag"),r<0||r>255)throw new e("tlv.encode: wrong tag");if(typeof t!="string")throw new TypeError('"data" expected string, got type='+typeof t);if(t.length&1)throw new e("tlv.encode: unpadded data");let n=t.length/2,o=tr(n);if(o.length/2&128)throw new e("tlv.encode: long form length too big");let s=n>127?tr(o.length/2|128):"";return tr(r)+s+o+t},decode(r,t){let{Err:e}=wt;t=M(t,void 0,"DER data");let n=0;if(r<0||r>255)throw new e("tlv.encode: wrong tag");if(t.length<2||t[n++]!==r)throw new e("tlv.decode: wrong tlv");let o=t[n++],s=!!(o&128),i=0;if(!s)i=o;else{let f=o&127;if(!f)throw new e("tlv.decode(long): indefinite length not supported");if(f>4)throw new e("tlv.decode(long): byte length is too big");let a=t.subarray(n,n+f);if(a.length!==f)throw new e("tlv.decode: length bytes not complete");if(a[0]===0)throw new e("tlv.decode(long): zero leftmost byte");for(let u of a)i=i<<8|u;if(n+=f,i<128)throw new e("tlv.decode(long): not minimal encoding")}let c=t.subarray(n,n+i);if(c.length!==i)throw new e("tlv.decode: wrong value length");return{v:c,l:t.subarray(n+i)}}},_int:{encode(r){let{Err:t}=wt;if(kr(r),r<At)throw new t("integer: negative integers are not allowed");let e=tr(r);if(Number.parseInt(e[0],16)&8&&(e="00"+e),e.length&1)throw new t("unexpected DER parsing assertion: unpadded hex");return e},decode(r){let{Err:t}=wt;if(r.length<1)throw new t("invalid signature integer: empty");if(r[0]&128)throw new t("invalid signature integer: negative");if(r.length>1&&r[0]===0&&!(r[1]&128))throw new t("invalid signature integer: unnecessary leading zero");return ne(r)}},toSig(r){let{Err:t,_int:e,_tlv:n}=wt,o=M(r,void 0,"signature"),{v:s,l:i}=n.decode(48,o);if(i.length)throw new t("invalid signature: left bytes after parsing");let{v:c,l:f}=n.decode(2,s),{v:a,l:u}=n.decode(2,f);if(u.length)throw new t("invalid signature: left bytes after parsing");return{r:e.decode(c),s:e.decode(a)}},hexFromSig(r){let{_tlv:t,_int:e}=wt,n=t.encode(2,e.encode(r.r)),o=t.encode(2,e.encode(r.s)),s=n+o;return t.encode(48,s)}};Object.freeze(wt._tlv);Object.freeze(wt._int);Object.freeze(wt);var At=BigInt(0),Yt=BigInt(1),Tc=BigInt(2),sn=BigInt(3),Ch=BigInt(4);function Dc(r,t={}){let e=Pr("weierstrass",r,t),n=e.Fp,o=e.Fn,s=e.CURVE,{h:i,n:c}=s;xt(t,{},{allowInfinityPoint:"boolean",clearCofactor:"function",isTorsionFree:"function",fromBytes:"function",toBytes:"function",endo:"object"});let{endo:f,allowInfinityPoint:a}=t;if(f&&(!n.is0(s.a)||typeof f.beta!="bigint"||!Array.isArray(f.basises)))throw new Error('invalid endo: expected "beta": bigint and "basises": array');let u=Lc(n,o);function h(){if(!n.isOdd)throw new Error("compression is not supported: Field does not have .isOdd()")}function E(k,l,y){if(a&&l.is0())return Uint8Array.of(0);let{x:v,y:g}=l.toAffine(),x=n.toBytes(v);if(bt(y,"isCompressed"),y){h();let A=!n.isOdd(g);return W(Cc(A),x)}else return W(Uint8Array.of(4),x,n.toBytes(g))}function m(k){M(k,void 0,"Point");let{publicKey:l,publicKeyUncompressed:y}=u,v=k.length,g=k[0],x=k.subarray(1);if(a&&v===1&&g===0)return{x:n.ZERO,y:n.ZERO};if(v===l&&(g===2||g===3)){let A=n.fromBytes(x);if(!n.isValid(A))throw new Error("bad point: is not on curve, wrong x");let C=p(A),D;try{D=n.sqrt(C)}catch(K){let P=K instanceof Error?": "+K.message:"";throw new Error("bad point: is not on curve, sqrt error"+P)}h();let U=n.isOdd(D);return(g&1)===1!==U&&(D=n.neg(D)),{x:A,y:D}}else if(v===y&&g===4){let A=n.BYTES,C=n.fromBytes(x.subarray(0,A)),D=n.fromBytes(x.subarray(A,A*2));if(!b(C,D))throw new Error("bad point: is not on curve");return{x:C,y:D}}else throw new Error(`bad point: got length ${v}, expected compressed=${l} or uncompressed=${y}`)}let d=t.toBytes===void 0?E:t.toBytes,w=t.fromBytes===void 0?m:t.fromBytes;function p(k){let l=n.sqr(k),y=n.mul(l,k);return n.add(n.add(y,n.mul(k,s.a)),s.b)}function b(k,l){let y=n.sqr(l),v=p(k);return n.eql(y,v)}if(!b(s.Gx,s.Gy))throw new Error("bad curve params: generator point");let S=n.mul(n.pow(s.a,sn),Ch),_=n.mul(n.sqr(s.b),BigInt(27));if(n.is0(n.add(S,_)))throw new Error("bad curve params: a or b");function T(k,l,y=!1){if(!n.isValid(l)||y&&n.is0(l))throw new Error(`bad point coordinate ${k}`);return l}function I(k){if(!(k instanceof B))throw new Error("Weierstrass Point expected")}function F(k){if(!f||!f.basises)throw new Error("no endo");return Dh(k,f.basises,o.ORDER)}function L(k,l,y,v,g){return y=new B(n.mul(y.X,k),y.Y,y.Z),l=or(v,l),y=or(g,y),l.add(y)}class B{static BASE=new B(s.Gx,s.Gy,n.ONE);static ZERO=new B(n.ZERO,n.ONE,n.ZERO);static Fp=n;static Fn=o;X;Y;Z;constructor(l,y,v){this.X=T("x",l),this.Y=T("y",y,!0),this.Z=T("z",v),Object.freeze(this)}static CURVE(){return s}static fromAffine(l){let{x:y,y:v}=l||{};if(!l||!n.isValid(y)||!n.isValid(v))throw new Error("invalid affine point");if(l instanceof B)throw new Error("projective point not allowed");return n.is0(y)&&n.is0(v)?B.ZERO:new B(y,v,n.ONE)}static fromBytes(l){let y=B.fromAffine(w(M(l,void 0,"point")));return y.assertValidity(),y}static fromHex(l){return B.fromBytes(ve(l))}get x(){return this.toAffine().x}get y(){return this.toAffine().y}precompute(l=8,y=!0){return z.createCache(this,l),y||this.multiply(sn),this}assertValidity(){let l=this;if(l.is0()){if(t.allowInfinityPoint&&n.is0(l.X)&&n.eql(l.Y,n.ONE)&&n.is0(l.Z))return;throw new Error("bad point: ZERO")}let{x:y,y:v}=l.toAffine();if(!n.isValid(y)||!n.isValid(v))throw new Error("bad point: x or y not field elements");if(!b(y,v))throw new Error("bad point: equation left != right");if(!l.isTorsionFree())throw new Error("bad point: not in prime-order subgroup")}hasEvenY(){let{y:l}=this.toAffine();if(!n.isOdd)throw new Error("Field doesn't support isOdd");return!n.isOdd(l)}equals(l){I(l);let{X:y,Y:v,Z:g}=this,{X:x,Y:A,Z:C}=l,D=n.eql(n.mul(y,C),n.mul(x,g)),U=n.eql(n.mul(v,C),n.mul(A,g));return D&&U}negate(){return new B(this.X,n.neg(this.Y),this.Z)}double(){let{a:l,b:y}=s,v=n.mul(y,sn),{X:g,Y:x,Z:A}=this,C=n.ZERO,D=n.ZERO,U=n.ZERO,R=n.mul(g,g),K=n.mul(x,x),P=n.mul(A,A),N=n.mul(g,x);return N=n.add(N,N),U=n.mul(g,A),U=n.add(U,U),C=n.mul(l,U),D=n.mul(v,P),D=n.add(C,D),C=n.sub(K,D),D=n.add(K,D),D=n.mul(C,D),C=n.mul(N,C),U=n.mul(v,U),P=n.mul(l,P),N=n.sub(R,P),N=n.mul(l,N),N=n.add(N,U),U=n.add(R,R),R=n.add(U,R),R=n.add(R,P),R=n.mul(R,N),D=n.add(D,R),P=n.mul(x,A),P=n.add(P,P),R=n.mul(P,N),C=n.sub(C,R),U=n.mul(P,K),U=n.add(U,U),U=n.add(U,U),new B(C,D,U)}add(l){I(l);let{X:y,Y:v,Z:g}=this,{X:x,Y:A,Z:C}=l,D=n.ZERO,U=n.ZERO,R=n.ZERO,K=s.a,P=n.mul(s.b,sn),N=n.mul(y,x),X=n.mul(v,A),J=n.mul(g,C),Q=n.add(y,v),$=n.add(x,A);Q=n.mul(Q,$),$=n.add(N,X),Q=n.sub(Q,$),$=n.add(y,g);let ct=n.add(x,C);return $=n.mul($,ct),ct=n.add(N,J),$=n.sub($,ct),ct=n.add(v,g),D=n.add(A,C),ct=n.mul(ct,D),D=n.add(X,J),ct=n.sub(ct,D),R=n.mul(K,$),D=n.mul(P,J),R=n.add(D,R),D=n.sub(X,R),R=n.add(X,R),U=n.mul(D,R),X=n.add(N,N),X=n.add(X,N),J=n.mul(K,J),$=n.mul(P,$),X=n.add(X,J),J=n.sub(N,J),J=n.mul(K,J),$=n.add($,J),N=n.mul(X,$),U=n.add(U,N),N=n.mul(ct,$),D=n.mul(Q,D),D=n.sub(D,N),N=n.mul(Q,X),R=n.mul(ct,R),R=n.add(R,N),new B(D,U,R)}subtract(l){return I(l),this.add(l.negate())}is0(){return this.equals(B.ZERO)}multiply(l){let{endo:y}=t;if(!o.isValidNot0(l))throw new RangeError("invalid scalar: out of range");let v,g,x=A=>z.cached(this,A,C=>ie(B,C));if(y){let{k1neg:A,k1:C,k2neg:D,k2:U}=F(l),{p:R,f:K}=x(C),{p:P,f:N}=x(U);g=K.add(N),v=L(y.beta,R,P,A,D)}else{let{p:A,f:C}=x(l);v=A,g=C}return ie(B,[v,g])[0]}multiplyUnsafe(l){let{endo:y}=t,v=this,g=l;if(!o.isValid(g))throw new RangeError("invalid scalar: out of range");if(g===At||v.is0())return B.ZERO;if(g===Yt)return v;if(z.hasCache(this))return this.multiply(g);if(y){let{k1neg:x,k1:A,k2neg:C,k2:D}=F(g),{p1:U,p2:R}=Ci(B,v,A,D);return L(y.beta,U,R,x,C)}else return z.unsafe(v,g)}toAffine(l){let y=this,v=l,{X:g,Y:x,Z:A}=y;if(n.eql(A,n.ONE))return{x:g,y:x};let C=y.is0();v==null&&(v=C?n.ONE:n.inv(A));let D=n.mul(g,v),U=n.mul(x,v),R=n.mul(A,v);if(C)return{x:n.ZERO,y:n.ZERO};if(!n.eql(R,n.ONE))throw new Error("invZ was invalid");return{x:D,y:U}}isTorsionFree(){let{isTorsionFree:l}=t;return i===Yt?!0:l?l(B,this):z.unsafe(this,c).is0()}clearCofactor(){let{clearCofactor:l}=t;return i===Yt?this:l?l(B,this):this.multiplyUnsafe(i)}isSmallOrder(){return i===Yt?this.is0():this.clearCofactor().is0()}toBytes(l=!0){return bt(l,"isCompressed"),this.assertValidity(),d(B,this,l)}toHex(l=!0){return _e(this.toBytes(l))}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}}let O=o.BITS,z=new De(B,t.endo?Math.ceil(O/2):O);return O>=8&&B.BASE.precompute(8),Object.freeze(B.prototype),Object.freeze(B),B}function Cc(r){return Uint8Array.of(r?2:3)}function Lc(r,t){return{secretKey:t.BYTES,publicKey:1+r.BYTES,publicKeyUncompressed:1+2*r.BYTES,publicKeyHasPrefix:!0,signature:2*t.BYTES}}function Lh(r,t={}){let{Fn:e}=r,n=t.randomBytes===void 0?Qe:t.randomBytes,o=Object.assign(Lc(r.Fp,e),{seed:Math.max(ao(e.ORDER),16)});function s(m){try{let d=e.fromBytes(m);return e.isValidNot0(d)}catch{return!1}}function i(m,d){let{publicKey:w,publicKeyUncompressed:p}=o;try{let b=m.length;return d===!0&&b!==w||d===!1&&b!==p?!1:!!r.fromBytes(m)}catch{return!1}}function c(m){return m=m===void 0?n(o.seed):m,fo(M(m,o.seed,"seed"),e.ORDER)}function f(m,d=!0){return r.BASE.multiply(e.fromBytes(m)).toBytes(d)}function a(m){let{secretKey:d,publicKey:w,publicKeyUncompressed:p}=o,b=e._lengths;if(!re(m))return;let S=M(m,void 0,"key").length,_=S===w||S===p,T=S===d||!!b?.includes(S);if(!(_&&T))return _}function u(m,d,w=!0){if(a(m)===!0)throw new Error("first arg must be private key");if(a(d)===!1)throw new Error("second arg must be public key");let p=e.fromBytes(m);return r.fromBytes(d).multiply(p).toBytes(w)}let h={isValidSecretKey:s,isValidPublicKey:i,randomSecretKey:c},E=zr(c,f);return Object.freeze(h),Object.freeze(o),Object.freeze({getPublicKey:f,getSharedSecret:u,keygen:E,Point:r,utils:h,lengths:o})}function Uc(r,t,e={}){let n=t;Tr(n),xt(e,{},{hmac:"function",lowS:"boolean",randomBytes:"function",bits2int:"function",bits2int_modN:"function"}),e=Object.assign({},e);let o=e.randomBytes===void 0?Qe:e.randomBytes,s=e.hmac===void 0?(g,x)=>Bc(n,g,x):e.hmac,{Fp:i,Fn:c}=r,{ORDER:f,BITS:a}=c,{keygen:u,getPublicKey:h,getSharedSecret:E,utils:m,lengths:d}=Lh(r,e),w={prehash:!0,lowS:typeof e.lowS=="boolean"?e.lowS:!0,format:"compact",extraEntropy:!1},p=f*Tc+Yt<i.ORDER;function b(g){let x=f>>Yt;return g>x}function S(g,x){if(!c.isValidNot0(x))throw new Error(`invalid signature ${g}: out of range 1..Point.Fn.ORDER`);return x}function _(){if(p)throw new Error('"recovered" sig type is not supported for cofactor >2 curves')}function T(g,x){ss(x);let A=d.signature,C=x==="compact"?A:x==="recovered"?A+1:void 0;return M(g,C)}class I{r;s;recovery;constructor(x,A,C){if(this.r=S("r",x),this.s=S("s",A),C!=null){if(_(),![0,1,2,3].includes(C))throw new Error("invalid recovery id");this.recovery=C}Object.freeze(this)}static fromBytes(x,A=w.format){T(x,A);let C;if(A==="der"){let{r:K,s:P}=wt.toSig(M(x));return new I(K,P)}A==="recovered"&&(C=x[0],A="compact",x=x.subarray(1));let D=d.signature/2,U=x.subarray(0,D),R=x.subarray(D,D*2);return new I(c.fromBytes(U),c.fromBytes(R),C)}static fromHex(x,A){return this.fromBytes(ve(x),A)}assertRecovery(){let{recovery:x}=this;if(x==null)throw new Error("invalid recovery id: must be present");return x}addRecoveryBit(x){return new I(this.r,this.s,x)}recoverPublicKey(x){let{r:A,s:C}=this,D=this.assertRecovery(),U=D===2||D===3?A+f:A;if(!i.isValid(U))throw new Error("invalid recovery id: sig.r+curve.n != R.x");let R=i.toBytes(U),K=r.fromBytes(W(Cc((D&1)===0),R)),P=c.inv(U),N=L(M(x,void 0,"msgHash")),X=c.create(-N*P),J=c.create(C*P),Q=r.BASE.multiplyUnsafe(X).add(K.multiplyUnsafe(J));if(Q.is0())throw new Error("invalid recovery: point at infinify");return Q.assertValidity(),Q}hasHighS(){return b(this.s)}toBytes(x=w.format){if(ss(x),x==="der")return ve(wt.hexFromSig(this));let{r:A,s:C}=this,D=c.toBytes(A),U=c.toBytes(C);return x==="recovered"?(_(),W(Uint8Array.of(this.assertRecovery()),D,U)):W(D,U)}toHex(x){return _e(this.toBytes(x))}}Object.freeze(I.prototype),Object.freeze(I);let F=e.bits2int===void 0?function(x){if(x.length>8192)throw new Error("input is too large");let A=ne(x),C=x.length*8-a;return C>0?A>>BigInt(C):A}:e.bits2int,L=e.bits2int_modN===void 0?function(x){return c.create(F(x))}:e.bits2int_modN,B=rr(a);function O(g){return Ae("num < 2^"+a,g,At,B),c.toBytes(g)}function z(g,x){return M(g,void 0,"message"),x?M(n(g),void 0,"prehashed message"):g}function k(g,x,A){let{lowS:C,prehash:D,extraEntropy:U}=os(A,w);g=z(g,D);let R=L(g),K=c.fromBytes(x);if(!c.isValidNot0(K))throw new Error("invalid private key");let P=[O(K),O(R)];if(U!=null&&U!==!1){let Q=U===!0?o(d.secretKey):U;P.push(M(Q,void 0,"extraEntropy"))}let N=W(...P),X=R;function J(Q){let $=F(Q);if(!c.isValidNot0($))return;let ct=c.inv($),le=r.BASE.multiply($).toAffine(),Ke=c.create(le.x);if(Ke===At)return;let Er=c.create(ct*c.create(X+Ke*K));if(Er===At)return;let bs=(le.x===Ke?0:2)|Number(le.y&Yt),ys=Er;return C&&b(Er)&&(ys=c.neg(Er),bs^=1),new I(Ke,ys,p?void 0:bs)}return{seed:N,k2sig:J}}function l(g,x,A={}){let{seed:C,k2sig:D}=k(g,x,A);return di(n.outputLen,c.BYTES,s)(C,D).toBytes(A.format)}function y(g,x,A,C={}){let{lowS:D,prehash:U,format:R}=os(C,w);if(A=M(A,void 0,"publicKey"),x=z(x,U),!re(g)){let K=g instanceof I?", use sig.toBytes()":"";throw new Error("verify expects Uint8Array signature"+K)}T(g,R);try{let K=I.fromBytes(g,R),P=r.fromBytes(A);if(D&&K.hasHighS())return!1;let{r:N,s:X}=K,J=L(x),Q=c.inv(X),$=c.create(J*Q),ct=c.create(N*Q),le=r.BASE.multiplyUnsafe($).add(P.multiplyUnsafe(ct));return le.is0()?!1:c.create(le.x)===N}catch{return!1}}function v(g,x,A={}){let{prehash:C}=os(A,w);return x=z(x,C),I.fromBytes(g,"recovered").recoverPublicKey(x).toBytes()}return Object.freeze({keygen:u,getPublicKey:h,getSharedSecret:E,utils:m,lengths:d,Point:r,sign:l,verify:y,recoverPublicKey:v,Signature:I,hash:n})}var as={p:BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),n:BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),h:BigInt(1),a:BigInt(0),b:BigInt(7),Gx:BigInt("0x79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798"),Gy:BigInt("0x483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8")},Uh={beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),basises:[[BigInt("0x3086d221a7d46bcde86c90e49284eb15"),-BigInt("0xe4437ed6010e88286f547fa90abfe4c3")],[BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),BigInt("0x3086d221a7d46bcde86c90e49284eb15")]]};var Fc=BigInt(2);function Fh(r){let t=as.p,e=BigInt(3),n=BigInt(6),o=BigInt(11),s=BigInt(22),i=BigInt(23),c=BigInt(44),f=BigInt(88),a=r*r*r%t,u=a*a*r%t,h=V(u,e,t)*u%t,E=V(h,e,t)*u%t,m=V(E,Fc,t)*a%t,d=V(m,o,t)*m%t,w=V(d,s,t)*d%t,p=V(w,c,t)*w%t,b=V(p,f,t)*p%t,S=V(b,c,t)*w%t,_=V(S,e,t)*u%t,T=V(_,i,t)*d%t,I=V(T,n,t)*a%t,F=V(I,Fc,t);if(!cs.eql(cs.sqr(F),r))throw new Error("Cannot find square root");return F}var cs=Ie(as.p,{sqrt:Fh}),Rh=Dc(as,{Fp:cs,endo:Uh}),Ne=Uc(Rh,ui);function Rc(r,t,e,n){let o=Ze.digest(e instanceof Uint8Array?e:e.subarray());if(Zr(o))return o.then(({digest:s})=>(n?.signal?.throwIfAborted(),Ne.verify(t,s,r,{prehash:!1,format:"der"}))).catch(s=>{throw s.name==="AbortError"?s:new ir(String(s))});try{return n?.signal?.throwIfAborted(),Ne.verify(t,o.digest,r,{prehash:!1,format:"der"})}catch(s){throw new ir(String(s))}}var cn=class{type="secp256k1";raw;_key;constructor(t){this._key=kc(t),this.raw=Oc(this._key)}toMultihash(){return dt.digest(Ee(this))}toCID(){return at.createV1(114,this.toMultihash())}toString(){return Y.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:pt(this.raw,t.raw)}verify(t,e,n){return Rc(this._key,e,t,n)}};function Nc(r){return new cn(r)}function Oc(r){return Ne.Point.fromBytes(r).toBytes()}function kc(r){try{return Ne.Point.fromBytes(r),r}catch(t){throw new Sr(String(t))}}function Kc(r){let{Type:t,Data:e}=br.decode(r.digest),n=e??new Uint8Array;switch(t){case it.Ed25519:return zi(n);case it.secp256k1:return Nc(n);case it.ECDSA:return $s(n);default:throw new Me}}function Ee(r){return br.encode({Type:it[r.type],Data:r.raw})}var Mc=Symbol.for("nodejs.util.inspect.custom"),Oh=114,yr=class{type;multihash;publicKey;string;constructor(t){this.type=t.type,this.multihash=t.multihash,Object.defineProperty(this,"string",{enumerable:!1,writable:!0})}get[Symbol.toStringTag](){return`PeerId(${this.toString()})`}[mn]=!0;toString(){return this.string==null&&(this.string=Y.encode(this.multihash.bytes).slice(1)),this.string}toMultihash(){return this.multihash}toCID(){return at.createV1(Oh,this.multihash)}toJSON(){return this.toString()}equals(t){if(t==null)return!1;if(t instanceof Uint8Array)return pt(this.multihash.bytes,t);if(typeof t=="string")return this.toString()===t;if(t?.toMultihash()?.bytes!=null)return pt(this.multihash.bytes,t.toMultihash().bytes);throw new Error("not valid Id")}[Mc](){return`PeerId(${this.toString()})`}},an=class extends yr{type="RSA";publicKey;constructor(t){super({...t,type:"RSA"}),this.publicKey=t.publicKey}},fn=class extends yr{type="Ed25519";publicKey;constructor(t){super({...t,type:"Ed25519"}),this.publicKey=t.publicKey}},un=class extends yr{type="secp256k1";publicKey;constructor(t){super({...t,type:"secp256k1"}),this.publicKey=t.publicKey}},kh=2336,hn=class{type="url";multihash;publicKey;url;constructor(t){this.url=t.toString(),this.multihash=dt.digest(nt(this.url))}[Mc](){return`PeerId(${this.url})`}[mn]=!0;toString(){return this.toCID().toString()}toMultihash(){return this.multihash}toCID(){return at.createV1(kh,this.toMultihash())}toJSON(){return this.toString()}equals(t){return t==null?!1:(t instanceof Uint8Array&&(t=lt(t)),t.toString()===this.toString())}};function Pc(r){if(Kh(r))return new an({multihash:r});if(Nh(r))try{let t=Kc(r);if(t.type==="Ed25519")return new fn({multihash:r,publicKey:t});if(t.type==="secp256k1")return new un({multihash:r,publicKey:t})}catch{let e=lt(r.digest);return new hn(new URL(e))}throw new _r("Supplied PeerID Multihash is invalid")}function Nh(r){return r.code===dt.code}function Kh(r){return r.code===Ze.code}function Bt(r,t){let e={[Symbol.iterator]:()=>e,next:()=>{let n=r.next(),o=n.value;return n.done===!0||o==null?{done:!0,value:void 0}:{done:!1,value:t(o)}}};return e}function ln(r){let t=Ve(Y.decode(`z${r}`));return Pc(t)}var Gt=class{map;constructor(t){if(this.map=new Map,t!=null)for(let[e,n]of t.entries())this.map.set(e.toString(),{key:e,value:n})}[Symbol.iterator](){return this.entries()}clear(){this.map.clear()}delete(t){return this.map.delete(t.toString())}entries(){return Bt(this.map.entries(),t=>[t[1].key,t[1].value])}forEach(t){this.map.forEach((e,n)=>{t(e.value,e.key,this)})}get(t){return this.map.get(t.toString())?.value}has(t){return this.map.has(t.toString())}set(t,e){this.map.set(t.toString(),{key:t,value:e})}keys(){return Bt(this.map.values(),t=>t.key)}values(){return Bt(this.map.values(),t=>t.value)}get size(){return this.map.size}};function zc(){return new Gt}var Xt=class r{set;constructor(t){if(this.set=new Set,t!=null)for(let e of t)this.set.add(e.toString())}get size(){return this.set.size}[Symbol.iterator](){return this.values()}add(t){this.set.add(t.toString())}clear(){this.set.clear()}delete(t){this.set.delete(t.toString())}entries(){return Bt(this.set.entries(),t=>{let e=ln(t[0]);return[e,e]})}forEach(t){this.set.forEach(e=>{let n=ln(e);t(n,n,this)})}has(t){return this.set.has(t.toString())}values(){return Bt(this.set.values(),t=>ln(t))}intersection(t){let e=new r;for(let n of t)this.has(n)&&e.add(n);return e}difference(t){let e=new r;for(let n of this)t.has(n)||e.add(n);return e}union(t){let e=new r;for(let n of t)e.add(n);for(let n of this)e.add(n);return e}};function qc(){return new Xt}var Wt=class r{list;constructor(t){if(this.list=[],t!=null)for(let e of t)this.list.push(e)}[Symbol.iterator](){return Bt(this.list.entries(),t=>t[1])}concat(t){let e=new r(this);for(let n of t)e.push(n);return e}entries(){return Bt(this.list.entries(),t=>[t[0],t[1]])}every(t){return this.list.every((e,n)=>t(e,n,this))}filter(t){let e=new r;return this.list.forEach((n,o)=>{t(n,o,this)&&e.push(n)}),e}find(t){let e=this.list.find((n,o)=>t(n,o,this));if(e!=null)return e}findIndex(t){return this.list.findIndex((e,n)=>t(e,n,this))}forEach(t){this.list.forEach((e,n)=>{t(e,n,this)})}includes(t){return this.includes(t)}indexOf(t){return this.list.findIndex(e=>e.equals(t))}pop(){let t=this.list.pop();if(t!=null)return t}push(...t){for(let e of t)this.list.push(e)}shift(){let t=this.list.shift();if(t!=null)return t}unshift(...t){let e=this.list.length;for(let n=t.length-1;n>-1;n--)e=this.list.unshift(t[n]);return e}clear(){this.list=[]}get length(){return this.list.length}};function Vc(){return new Wt}var fs={32:16777619n,64:1099511628211n,128:309485009821345068724781371n,256:374144419156711147060143317175368453031918731002211n,512:35835915874844867368919076489095108449946327955754392558399825615420669938882575126094039892345713852759n,1024:5016456510113118655434598811035278955030765345404790744303017523831112055108147451509157692220295382716162651878526895249385292291816524375083746691371804094271873160484737966720260389217684476157468082573n},Hc={32:2166136261n,64:14695981039346656037n,128:144066263297769815596495629667062367629n,256:100029257958052580907070968620625704837092796014241193945225284501741471925557n,512:9659303129496669498009435400716310466090418745672637896108374329434462657994582932197716438449813051892206539805784495328239340083876191928701583869517785n,1024:14197795064947621068722070641403218320880622795441933960878474914617582723252296732303717722150864096521202355549365628174669108571814760471015076148029755969804077320157692458563003215304957150157403644460363550505412711285966361610267868082893823963790439336411086884584107735010676915n},jc=new globalThis.TextEncoder;function Mh(r,t){let e=fs[t],n=Hc[t];for(let o=0;o<r.length;o++)n^=BigInt(r[o]),n=BigInt.asUintN(t,n*e);return n}function Ph(r,t,e){if(e.length===0)throw new Error("The `utf8Buffer` option must have a length greater than zero");let n=fs[t],o=Hc[t],s=r;for(;s.length>0;){let i=jc.encodeInto(s,e);s=s.slice(i.read);for(let c=0;c<i.written;c++)o^=BigInt(e[c]),o=BigInt.asUintN(t,o*n)}return o}function us(r,{size:t=32,utf8Buffer:e}={}){if(!fs[t])throw new Error("The `size` option must be one of 32, 64, 128, 256, 512, or 1024");if(typeof r=="string"){if(e)return Ph(r,t,e);r=jc.encode(r)}return Mh(r,t)}var xr={hash:r=>Number(us(r,{size:32})),hashV:(r,t)=>zh(xr.hash(r,t))};function zh(r){let t=r.toString(16);return t.length%2===1&&(t=`0${t}`),nt(t,"base16")}var hs=64,Et=class{fp;h;seed;constructor(t,e,n,o=2){if(o>hs)throw new TypeError("Invalid Fingerprint Size");let s=e.hashV(t,n),i=zs(o);for(let c=0;c<i.length;c++)i[c]=s[c];i.length===0&&(i[0]=7),this.fp=i,this.h=e,this.seed=n}hash(){return this.h.hash(this.fp,this.seed)}equals(t){return t?.fp instanceof Uint8Array?pt(this.fp,t.fp):!1}};function ue(r,t){return Math.floor(Math.random()*(t-r))+r}var he=class{contents;constructor(t){this.contents=new Array(t).fill(null)}has(t){if(!(t instanceof Et))throw new TypeError("Invalid Fingerprint");return this.contents.some(e=>t.equals(e))}add(t){if(!(t instanceof Et))throw new TypeError("Invalid Fingerprint");for(let e=0;e<this.contents.length;e++)if(this.contents[e]==null)return this.contents[e]=t,!0;return!0}swap(t){if(!(t instanceof Et))throw new TypeError("Invalid Fingerprint");let e=ue(0,this.contents.length-1),n=this.contents[e];return this.contents[e]=t,n}remove(t){if(!(t instanceof Et))throw new TypeError("Invalid Fingerprint");let e=this.contents.findIndex(n=>t.equals(n));return e>-1?(this.contents[e]=null,!0):!1}};var qh=500,gr=class{bucketSize;filterSize;fingerprintSize;buckets;count;hash;seed;constructor(t){this.filterSize=t.filterSize,this.bucketSize=t.bucketSize??4,this.fingerprintSize=t.fingerprintSize??2,this.count=0,this.buckets=[],this.hash=t.hash??xr,this.seed=t.seed??ue(0,Math.pow(2,10))}add(t){typeof t=="string"&&(t=nt(t));let e=new Et(t,this.hash,this.seed,this.fingerprintSize),n=this.hash.hash(t,this.seed)%this.filterSize,o=(n^e.hash())%this.filterSize;if(this.buckets[n]==null&&(this.buckets[n]=new he(this.bucketSize)),this.buckets[o]==null&&(this.buckets[o]=new he(this.bucketSize)),this.buckets[n].add(e)||this.buckets[o].add(e))return this.count++,!0;let s=[n,o],i=s[ue(0,s.length-1)];this.buckets[i]==null&&(this.buckets[i]=new he(this.bucketSize));for(let c=0;c<qh;c++){let f=this.buckets[i].swap(e);if(f!=null&&(i=(i^f.hash())%this.filterSize,this.buckets[i]==null&&(this.buckets[i]=new he(this.bucketSize)),this.buckets[i].add(f)))return this.count++,!0}return!1}has(t){typeof t=="string"&&(t=nt(t));let e=new Et(t,this.hash,this.seed,this.fingerprintSize),n=this.hash.hash(t,this.seed)%this.filterSize,o=this.buckets[n]?.has(e)??!1;if(o)return o;let s=(n^e.hash())%this.filterSize;return this.buckets[s]?.has(e)??!1}remove(t){typeof t=="string"&&(t=nt(t));let e=new Et(t,this.hash,this.seed,this.fingerprintSize),n=this.hash.hash(t,this.seed)%this.filterSize,o=this.buckets[n]?.remove(e)??!1;if(o)return this.count--,o;let s=(n^e.hash())%this.filterSize,i=this.buckets[s]?.remove(e)??!1;return i&&this.count--,i}get reliable(){return Math.floor(100*(this.count/this.filterSize))<=90}},Vh={1:.5,2:.84,4:.95,8:.98};function Hh(r=.001){return r>.002?2:r>1e-5?4:8}function Zc(r,t=.001){let e=Hh(t),n=Vh[e],o=Math.round(r/n),s=Math.min(Math.ceil(Math.log2(1/t)+Math.log2(2*e)),hs);return{filterSize:o,bucketSize:e,fingerprintSize:s}}var dn=class{filterSize;bucketSize;fingerprintSize;scale;filterSeries;hash;seed;constructor(t){this.bucketSize=t.bucketSize??4,this.filterSize=t.filterSize??(1<<18)/this.bucketSize,this.fingerprintSize=t.fingerprintSize??2,this.scale=t.scale??2,this.hash=t.hash??xr,this.seed=t.seed??ue(0,Math.pow(2,10)),this.filterSeries=[new gr({filterSize:this.filterSize,bucketSize:this.bucketSize,fingerprintSize:this.fingerprintSize,hash:this.hash,seed:this.seed})]}add(t){if(typeof t=="string"&&(t=nt(t)),this.has(t))return!0;let e=this.filterSeries.find(n=>n.reliable);if(e==null){let n=this.filterSize*Math.pow(this.scale,this.filterSeries.length);e=new gr({filterSize:n,bucketSize:this.bucketSize,fingerprintSize:this.fingerprintSize,hash:this.hash,seed:this.seed}),this.filterSeries.push(e)}return e.add(t)}has(t){typeof t=="string"&&(t=nt(t));for(let e=0;e<this.filterSeries.length;e++)if(this.filterSeries[e].has(t))return!0;return!1}remove(t){typeof t=="string"&&(t=nt(t));for(let e=0;e<this.filterSeries.length;e++)if(this.filterSeries[e].remove(t))return!0;return!1}get count(){return this.filterSeries.reduce((t,e)=>t+e.count,0)}};function ls(r,t=.001,e){return new dn({...Zc(r,t),...e??{}})}var wr=class{filter;constructor(t,e){this.filter=ls(t,e)}has(t){return this.filter.has(t.toMultihash().bytes)}add(t){this.filter.add(t.toMultihash().bytes)}remove(t){this.filter.remove?.(t.toMultihash().bytes)}};function $c(r,t=.001){return new wr(r,t)}var ds=class extends Gt{metric;constructor(t){super();let{name:e,metrics:n}=t;this.metric=n.registerMetric(e),this.updateComponentMetric()}set(t,e){return super.set(t,e),this.updateComponentMetric(),this}delete(t){let e=super.delete(t);return this.updateComponentMetric(),e}clear(){super.clear(),this.updateComponentMetric()}updateComponentMetric(){this.metric.update(this.size)}};function Yc(r){let{name:t,metrics:e}=r,n;return e!=null?n=new ds({name:t,metrics:e}):n=new Gt,n}var ps=class extends Xt{metric;constructor(t){super();let{name:e,metrics:n}=t;this.metric=n.registerMetric(e),this.updateComponentMetric()}add(t){super.add(t),this.updateComponentMetric()}delete(t){super.delete(t),this.updateComponentMetric()}clear(){super.clear(),this.updateComponentMetric()}updateComponentMetric(){this.metric.update(this.size)}};function Gc(r){let{name:t,metrics:e}=r,n;return e!=null?n=new ps({name:t,metrics:e}):n=new Xt,n}var ms=class extends Wt{metric;constructor(t){super();let{name:e,metrics:n}=t;this.metric=n.registerMetric(e),this.updateComponentMetric()}pop(){let t=super.pop();return this.updateComponentMetric(),t}push(...t){super.push(...t),this.updateComponentMetric()}shift(){let t=super.shift();return this.updateComponentMetric(),t}unshift(...t){let e=super.unshift(...t);return this.updateComponentMetric(),e}clear(){super.clear(),this.updateComponentMetric()}updateComponentMetric(){this.metric.update(this.length)}};function Xc(r){let{name:t,metrics:e}=r,n;return e!=null?n=new ms({name:t,metrics:e}):n=new Wt,n}return ea(jh);})();
3
3
  /*! Bundled license information:
4
4
 
5
5
  @noble/curves/utils.js: