@libp2p/peer-collections 7.0.20-3574648c3 → 7.0.20-b7c6dc0f2
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 +1 -1
- package/dist/index.min.js.map +4 -4
- package/package.json +6 -6
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⁣)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:()=>aa});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 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 gs(r){return new TextEncoder().encode(r)}function ws(r){return new TextDecoder().decode(r)}function ra(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 na=ra,oa=na,Ss=oa;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 sa(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 ia(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 ca(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=ca(n);return de({prefix:t,name:r,encode(s){return ia(s,n,e)},decode(s){return sa(s,o,e,r)}})}var Y=kt({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),aa=kt({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var En={};q(En,{base32:()=>pe,base32hex:()=>la,base32hexpad:()=>pa,base32hexpadupper:()=>ma,base32hexupper:()=>da,base32pad:()=>ua,base32padupper:()=>ha,base32upper:()=>fa,base32z:()=>ba});var pe=H({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),fa=H({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),ua=H({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),ha=H({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),la=H({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),da=H({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),pa=H({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),ma=H({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),ba=H({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Sn={};q(Sn,{base36:()=>Pe,base36upper:()=>ya});var Pe=kt({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),ya=kt({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var xa=Bs,vs=128,ga=127,wa=~ga,Ea=Math.pow(2,31);function Bs(r,t,e){t=t||[],e=e||0;for(var n=e;r>=Ea;)t[e++]=r&255|vs,r/=128;for(;r&wa;)t[e++]=r&255|vs,r>>>=7;return t[e]=r|0,Bs.bytes=e-n+1,t}var Sa=_n,_a=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>=_a);return _n.bytes=s-n,e}var va=Math.pow(2,7),Aa=Math.pow(2,14),Ba=Math.pow(2,21),Ia=Math.pow(2,28),Ta=Math.pow(2,35),Da=Math.pow(2,42),Ca=Math.pow(2,49),La=Math.pow(2,56),Ua=Math.pow(2,63),Fa=function(r){return r<va?1:r<Aa?2:r<Ba?3:r<Ia?4:r<Ta?5:r<Da?6:r<Ca?7:r<La?8:r<Ua?9:10},Ra={encode:xa,decode:Sa,encodingLength:Fa},Oa=Ra,ze=Oa;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=n,this.bytes=o}};function Ts(r,t){let{bytes:e,version:n}=r;return n===0?Na(e,vn(r),t??Y.encoder):Ka(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=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!==He)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==Ma)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[Pa]===!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]=ka(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 ka(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 Na(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 Ka(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,Ma=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 Pa=Symbol.for("@ipld/js-cid/CID");var An={};q(An,{identity:()=>dt});var Ls=0,za="identity",Us=Tt;function qa(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:za,encode:Us,digest:qa};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 Va(r){return r.buffer instanceof ArrayBuffer}function ge(r){return Va(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 Ln={};q(Ln,{base10:()=>Wa});var Tl=new Uint8Array(0);function Ns(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 Ct(r){if(r instanceof Uint8Array&&r.constructor.name==="Uint8Array")return Qt(r);if(r instanceof ArrayBuffer)return new Uint8Array(r);if(ArrayBuffer.isView(r))return Qt(new Uint8Array(r.buffer,r.byteOffset,r.byteLength));throw new Error("Unknown type, must be binary type")}function Ks(r){return new TextEncoder().encode(r)}function Ms(r){return new TextDecoder().decode(r)}function Ha(r){return r?.buffer instanceof ArrayBuffer}function Qt(r){return Ha(r)?r:r.slice()}function ja(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 Za=ja,$a=Za,zs=$a;var In=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")}},Tn=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 qs(this,t)}},Dn=class{decoders;constructor(t){this.decoders=t}or(t){return qs(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 qs(r,t){return new Dn({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var Cn=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 In(t,e,n),this.decoder=new Tn(t,e,o)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function we({name:r,prefix:t,encode:e,decode:n}){return new Cn(r,t,e,n)}function Nt({name:r,prefix:t,alphabet:e}){let{encode:n,decode:o}=zs(e,r);return we({prefix:t,name:r,encode:n,decode:s=>Ct(o(s))})}function Ya(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 Ga(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 Xa(r){let t={};for(let e=0;e<r.length;++e)t[r[e]]=e;return t}function j({name:r,prefix:t,bitsPerChar:e,alphabet:n}){let o=Xa(n);return we({prefix:t,name:r,encode(s){return Ga(s,n,e)},decode(s){return Ya(s,o,e,r)}})}var Wa=Nt({prefix:"9",name:"base10",alphabet:"0123456789"});var Un={};q(Un,{base16:()=>Ja,base16upper:()=>Qa});var Ja=j({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Qa=j({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Fn={};q(Fn,{base2:()=>tf});var tf=j({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Rn={};q(Rn,{base256emoji:()=>sf});var Vs=Array.from("\u{1F680}\u{1FA90}\u2604\u{1F6F0}\u{1F30C}\u{1F311}\u{1F312}\u{1F313}\u{1F314}\u{1F315}\u{1F316}\u{1F317}\u{1F318}\u{1F30D}\u{1F30F}\u{1F30E}\u{1F409}\u2600\u{1F4BB}\u{1F5A5}\u{1F4BE}\u{1F4BF}\u{1F602}\u2764\u{1F60D}\u{1F923}\u{1F60A}\u{1F64F}\u{1F495}\u{1F62D}\u{1F618}\u{1F44D}\u{1F605}\u{1F44F}\u{1F601}\u{1F525}\u{1F970}\u{1F494}\u{1F496}\u{1F499}\u{1F622}\u{1F914}\u{1F606}\u{1F644}\u{1F4AA}\u{1F609}\u263A\u{1F44C}\u{1F917}\u{1F49C}\u{1F614}\u{1F60E}\u{1F607}\u{1F339}\u{1F926}\u{1F389}\u{1F49E}\u270C\u2728\u{1F937}\u{1F631}\u{1F60C}\u{1F338}\u{1F64C}\u{1F60B}\u{1F497}\u{1F49A}\u{1F60F}\u{1F49B}\u{1F642}\u{1F493}\u{1F929}\u{1F604}\u{1F600}\u{1F5A4}\u{1F603}\u{1F4AF}\u{1F648}\u{1F447}\u{1F3B6}\u{1F612}\u{1F92D}\u2763\u{1F61C}\u{1F48B}\u{1F440}\u{1F62A}\u{1F611}\u{1F4A5}\u{1F64B}\u{1F61E}\u{1F629}\u{1F621}\u{1F92A}\u{1F44A}\u{1F973}\u{1F625}\u{1F924}\u{1F449}\u{1F483}\u{1F633}\u270B\u{1F61A}\u{1F61D}\u{1F634}\u{1F31F}\u{1F62C}\u{1F643}\u{1F340}\u{1F337}\u{1F63B}\u{1F613}\u2B50\u2705\u{1F97A}\u{1F308}\u{1F608}\u{1F918}\u{1F4A6}\u2714\u{1F623}\u{1F3C3}\u{1F490}\u2639\u{1F38A}\u{1F498}\u{1F620}\u261D\u{1F615}\u{1F33A}\u{1F382}\u{1F33B}\u{1F610}\u{1F595}\u{1F49D}\u{1F64A}\u{1F639}\u{1F5E3}\u{1F4AB}\u{1F480}\u{1F451}\u{1F3B5}\u{1F91E}\u{1F61B}\u{1F534}\u{1F624}\u{1F33C}\u{1F62B}\u26BD\u{1F919}\u2615\u{1F3C6}\u{1F92B}\u{1F448}\u{1F62E}\u{1F646}\u{1F37B}\u{1F343}\u{1F436}\u{1F481}\u{1F632}\u{1F33F}\u{1F9E1}\u{1F381}\u26A1\u{1F31E}\u{1F388}\u274C\u270A\u{1F44B}\u{1F630}\u{1F928}\u{1F636}\u{1F91D}\u{1F6B6}\u{1F4B0}\u{1F353}\u{1F4A2}\u{1F91F}\u{1F641}\u{1F6A8}\u{1F4A8}\u{1F92C}\u2708\u{1F380}\u{1F37A}\u{1F913}\u{1F619}\u{1F49F}\u{1F331}\u{1F616}\u{1F476}\u{1F974}\u25B6\u27A1\u2753\u{1F48E}\u{1F4B8}\u2B07\u{1F628}\u{1F31A}\u{1F98B}\u{1F637}\u{1F57A}\u26A0\u{1F645}\u{1F61F}\u{1F635}\u{1F44E}\u{1F932}\u{1F920}\u{1F927}\u{1F4CC}\u{1F535}\u{1F485}\u{1F9D0}\u{1F43E}\u{1F352}\u{1F617}\u{1F911}\u{1F30A}\u{1F92F}\u{1F437}\u260E\u{1F4A7}\u{1F62F}\u{1F486}\u{1F446}\u{1F3A4}\u{1F647}\u{1F351}\u2744\u{1F334}\u{1F4A3}\u{1F438}\u{1F48C}\u{1F4CD}\u{1F940}\u{1F922}\u{1F445}\u{1F4A1}\u{1F4A9}\u{1F450}\u{1F4F8}\u{1F47B}\u{1F910}\u{1F92E}\u{1F3BC}\u{1F975}\u{1F6A9}\u{1F34E}\u{1F34A}\u{1F47C}\u{1F48D}\u{1F4E3}\u{1F942}"),ef=Vs.reduce((r,t,e)=>(r[e]=t,r),[]),rf=Vs.reduce((r,t,e)=>{let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);return r[n]=e,r},[]);function nf(r){return r.reduce((t,e)=>(t+=ef[e],t),"")}function of(r){let t=[];for(let e of r){let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);let o=rf[n];if(o==null)throw new Error(`Non-base256emoji character: ${e}`);t.push(o)}return new Uint8Array(t)}var sf=we({prefix:"\u{1F680}",name:"base256emoji",encode:nf,decode:of});var On={};q(On,{base32:()=>Ee,base32hex:()=>uf,base32hexpad:()=>lf,base32hexpadupper:()=>df,base32hexupper:()=>hf,base32pad:()=>af,base32padupper:()=>ff,base32upper:()=>cf,base32z:()=>pf});var Ee=j({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),cf=j({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),af=j({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),ff=j({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),uf=j({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),hf=j({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),lf=j({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),df=j({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),pf=j({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var kn={};q(kn,{base36:()=>Ze,base36upper:()=>mf});var Ze=Nt({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),mf=Nt({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Nn={};q(Nn,{base58btc:()=>St,base58flickr:()=>bf});var St=Nt({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),bf=Nt({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Kn={};q(Kn,{base64:()=>yf,base64pad:()=>xf,base64url:()=>gf,base64urlpad:()=>wf});var yf=j({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),xf=j({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),gf=j({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),wf=j({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Mn={};q(Mn,{base8:()=>Ef});var Ef=j({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Pn={};q(Pn,{identity:()=>Sf});var Sf=we({prefix:"\0",name:"identity",encode:r=>Ms(r),decode:r=>Ks(r)});var Hl=new TextEncoder,jl=new TextDecoder;var qn={};q(qn,{identity:()=>jf});var Af=Zs,Hs=128,Bf=127,If=~Bf,Tf=Math.pow(2,31);function Zs(r,t,e){t=t||[],e=e||0;for(var n=e;r>=Tf;)t[e++]=r&255|Hs,r/=128;for(;r&If;)t[e++]=r&255|Hs,r>>>=7;return t[e]=r|0,Zs.bytes=e-n+1,t}var Df=zn,Cf=128,js=127;function zn(r,n){var e=0,n=n||0,o=0,s=n,i,c=r.length;do{if(s>=c)throw zn.bytes=0,new RangeError("Could not decode varint");i=r[s++],e+=o<28?(i&js)<<o:(i&js)*Math.pow(2,o),o+=7}while(i>=Cf);return zn.bytes=s-n,e}var Lf=Math.pow(2,7),Uf=Math.pow(2,14),Ff=Math.pow(2,21),Rf=Math.pow(2,28),Of=Math.pow(2,35),kf=Math.pow(2,42),Nf=Math.pow(2,49),Kf=Math.pow(2,56),Mf=Math.pow(2,63),Pf=function(r){return r<Lf?1:r<Uf?2:r<Ff?3:r<Rf?4:r<Of?5:r<kf?6:r<Nf?7:r<Kf?8:r<Mf?9:10},zf={encode:Af,decode:Df,encodingLength:Pf},qf=zf,$e=qf;function Ye(r,t=0){return[$e.decode(r,t),$e.decode.bytes]}function Se(r,t,e=0){return $e.encode(r,t,e),t}function _e(r){return $e.encodingLength(r)}function Ae(r,t){let e=t.byteLength,n=_e(r),o=n+_e(e),s=new Uint8Array(o+e);return Se(r,s,0),Se(e,s,n),s.set(t,o),new ve(r,e,t,s)}function $s(r){let t=Ct(r),[e,n]=Ye(t),[o,s]=Ye(t.subarray(n)),i=t.subarray(n+s);if(i.byteLength!==o)throw new Error("Incorrect length");return new ve(e,o,i,t)}function Ys(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&Ns(r.bytes,e.bytes)}}var ve=class{code;size;digest;bytes;constructor(t,e,n,o){this.code=t,this.size=e,this.digest=Qt(n),this.bytes=Qt(o)}};var Gs=0,Vf="identity",Xs=Ct;function Hf(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 Ae(Gs,Xs(r))}var jf={code:Gs,name:Vf,encode:Xs,digest:Hf};var jn={};q(jn,{sha256:()=>$f,sha512:()=>Yf});var Zf=20;function Hn({name:r,code:t,encode:e,minDigestLength:n,maxDigestLength:o}){return new Vn(r,t,e,n,o)}var Vn=class{name;code;encode;minDigestLength;maxDigestLength;constructor(t,e,n,o,s){this.name=t,this.code=e,this.encode=n,this.minDigestLength=o??Zf,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?Ws(n,this.code,e?.truncate):n.then(o=>Ws(o,this.code,e?.truncate))}else throw Error("Unknown type, must be binary type")}};function Ws(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 Ae(t,r)}function Qs(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var $f=Hn({name:"sha2-256",code:18,encode:Qs("SHA-256")}),Yf=Hn({name:"sha2-512",code:19,encode:Qs("SHA-512")});function ti(r,t){let{bytes:e,version:n}=r;return n===0?Xf(e,Zn(r),t??St.encoder):Wf(e,Zn(r),t??Ee.encoder)}var ei=new WeakMap;function Zn(r){let t=ei.get(r);if(t==null){let e=new Map;return ei.set(r,e),e}return t}var Ir=class r{code;version;multihash;bytes;"/";constructor(t,e,n,o){this.code=e,this.version=t,this.multihash=n,this.bytes=Qt(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!==Xe)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==Jf)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=Ae(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&&Ys(t.multihash,n.multihash)}toString(t){return ti(this,t)}toJSON(){return{"/":ti(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??ri(n,o,s.bytes))}else if(e[Qf]===!0){let{version:n,multihash:o,code:s}=e,i=$s(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!==Xe)throw new Error(`Version 0 CID must use dag-pb (code: ${Xe}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let o=ri(t,e,n.bytes);return new r(t,e,n,o)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,Xe,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=Ct(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 ve(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]=Ye(t.subarray(e));return e+=E,h},o=n(),s=Xe;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]=Gf(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 Zn(s).set(n,t),s}};function Gf(r,t){switch(r[0]){case"Q":{let e=t??St;return[St.prefix,e.decode(`${St.prefix}${r}`)]}case St.prefix:{let e=t??St;return[St.prefix,e.decode(r)]}case Ee.prefix:{let e=t??Ee;return[Ee.prefix,e.decode(r)]}case Ze.prefix:{let e=t??Ze;return[Ze.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 Xf(r,t,e){let{prefix:n}=e;if(n!==St.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 Wf(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 Xe=112,Jf=18;function ri(r,t,e){let n=_e(r),o=n+_e(t),s=new Uint8Array(o+e.byteLength);return Se(r,s,0),Se(t,s,n),s.set(e,o),s}var Qf=Symbol.for("@ipld/js-cid/CID");var $n={...Pn,...Fn,...Mn,...Ln,...Un,...On,...kn,...Nn,...Kn,...Rn},dd={...jn,...qn};function ni(r=0){return new Uint8Array(r)}function Yn(r=0){return new Uint8Array(r)}function si(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var oi=si("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),Gn=si("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=Yn(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),tu={utf8:oi,"utf-8":oi,hex:$n.base16,latin1:Gn,ascii:Gn,binary:Gn,...$n},Tr=tu;function nt(r,t="utf8"){let e=Tr[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function lt(r,t="utf8"){let e=Tr[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}var eu=parseInt("11111",2),Xn=parseInt("10000000",2),ru=parseInt("01111111",2),ii={0:We,1:We,2:nu,3:iu,4:cu,5:su,6:ou,16:We,22:We,48:We};function Wn(r,t={offset:0}){let e=r[t.offset]&eu;if(t.offset++,ii[e]!=null)return ii[e](r,t);throw new Error("No decoder for tag "+e)}function Je(r,t){let e=0;if((r[t.offset]&Xn)===Xn){let n=r[t.offset]&ru,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 We(r,t){Je(r,t);let e=[];for(;!(t.offset>=r.byteLength);){let n=Wn(r,t);if(n===null)break;e.push(n)}return e}function nu(r,t){let e=Je(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 ou(r,t){let e=Je(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 su(r,t){return t.offset++,null}function iu(r,t){let e=Je(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 cu(r,t){let e=Je(r,t),n=r.subarray(t.offset,t.offset+e);return t.offset+=e,n}function au(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 Jn(r){if(r.byteLength<128)return Uint8Array.from([r.byteLength]);let t=au(r.byteLength);return new ft(Uint8Array.from([t.byteLength|Xn]),t)}function ci(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]),Jn(t),t)}function ai(r){let t=Uint8Array.from([0]),e=new ft(t,r);return new ft(Uint8Array.from([3]),Jn(e),e)}function Dr(r,t=48){let e=new ft;for(let n of r)e.append(n);return new ft(Uint8Array.from([t]),Jn(e),e)}var fu=Uint8Array.from([6,8,42,134,72,206,61,3,1,7]),uu=Uint8Array.from([6,5,43,129,4,0,34]),hu=Uint8Array.from([6,5,43,129,4,0,35]),lu={ext:!0,kty:"EC",crv:"P-256"},du={ext:!0,kty:"EC",crv:"P-384"},pu={ext:!0,kty:"EC",crv:"P-521"},Qn=32,to=48,eo=66;function fi(r){let t=Wn(r);return ui(t)}function ui(r){let t=r[1][1][0],e=1,n,o;if(t.byteLength===Qn*2+1)return n=lt(t.subarray(e,e+Qn),"base64url"),o=lt(t.subarray(e+Qn),"base64url"),new Be({...lu,key_ops:["verify"],x:n,y:o});if(t.byteLength===to*2+1)return n=lt(t.subarray(e,e+to),"base64url"),o=lt(t.subarray(e+to),"base64url"),new Be({...du,key_ops:["verify"],x:n,y:o});if(t.byteLength===eo*2+1)return n=lt(t.subarray(e,e+eo),"base64url"),o=lt(t.subarray(e+eo),"base64url"),new Be({...pu,key_ops:["verify"],x:n,y:o});throw new It(`coordinates were wrong length, got ${t.byteLength}, expected 65, 97 or 133`)}function hi(r){return Dr([ci(Uint8Array.from([1])),Dr([mu(r.crv)],160),Dr([ai(new ft(Uint8Array.from([4]),nt(r.x??"","base64url"),nt(r.y??"","base64url")))],161)]).subarray()}function mu(r){if(r==="P-256")return fu;if(r==="P-384")return uu;if(r==="P-521")return hu;throw new It(`Invalid curve ${r}`)}var Be=class{type="ECDSA";jwk;_raw;constructor(t){this.jwk=t}get raw(){return this._raw==null&&(this._raw=hi(this.jwk)),this._raw}toMultihash(){return dt.digest(Ie(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 ro(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"&&"BYTES_PER_ELEMENT"in r&&r.BYTES_PER_ELEMENT===1}function Kt(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=ro(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 Cr(r){if(typeof r!="function"||typeof r.create!="function")throw new TypeError("Hash must wrapped by utils.createHasher");if(Kt(r.outputLen),Kt(r.blockLen),r.outputLen<1)throw new Error('"outputLen" must be >= 1');if(r.blockLen<1)throw new Error('"blockLen" must be >= 1')}function Te(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){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 Ut(...r){for(let t=0;t<r.length;t++)r[t].fill(0)}function Ur(r){return new DataView(r.buffer,r.byteOffset,r.byteLength)}function mt(r,t){return r<<32-t|r>>>t}var di=typeof Uint8Array.from([]).toHex=="function"&&typeof Uint8Array.fromHex=="function",bu=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function Fr(r){if(ut(r),di)return r.toHex();let t="";for(let e=0;e<r.length;e++)t+=bu[r[e]];return t}var Lt={_0:48,_9:57,A:65,F:70,a:97,f:102};function li(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 Qe(r){if(typeof r!="string")throw new TypeError("hex string expected, got "+typeof r);if(di)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=li(r.charCodeAt(s)),c=li(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 no(...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 oo(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 pi(r=32){Kt(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 so=r=>({oid:Uint8Array.from([6,9,96,134,72,1,101,3,4,2,r])});function mi(r,t,e){return r&t^~r&e}function bi(r,t,e){return r&t^r&e^t&e}var tr=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=Ur(this.buffer)}update(t){Te(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=Ur(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){Te(this),Lr(t,this),this.finished=!0;let{buffer:e,view:n,blockLen:o,isLE:s}=this,{pos:i}=this;e[i++]=128,Ut(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=Ur(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()}},Ft=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 Rr=BigInt(4294967295),yi=BigInt(32);function yu(r,t=!1){return t?{h:Number(r&Rr),l:Number(r>>yi&Rr)}:{h:Number(r>>yi&Rr)|0,l:Number(r&Rr)|0}}function xi(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}=yu(r[s],t);[n[s],o[s]]=[i,c]}return[n,o]}var io=(r,t,e)=>r>>>e,co=(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,er=(r,t,e)=>r<<64-e|t>>>e-32,rr=(r,t,e)=>r>>>e-32|t<<64-e;function _t(r,t,e,n){let o=(t>>>0)+(n>>>0);return{h:r+e+(o/2**32|0)|0,l:o|0}}var gi=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),wi=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,Ei=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),Si=(r,t,e,n,o)=>t+e+n+o+(r/2**32|0)|0,_i=(r,t,e,n,o)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(o>>>0),vi=(r,t,e,n,o,s)=>t+e+n+o+s+(r/2**32|0)|0;var gu=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]),Mt=new Uint32Array(64),ao=class extends tr{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)Mt[h]=t.getUint32(e,!1);for(let h=16;h<64;h++){let E=Mt[h-15],m=Mt[h-2],d=mt(E,7)^mt(E,18)^E>>>3,w=mt(m,17)^mt(m,19)^m>>>10;Mt[h]=w+Mt[h-7]+d+Mt[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+mi(c,f,a)+gu[h]+Mt[h]|0,w=(mt(n,2)^mt(n,13)^mt(n,22))+bi(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(){Ut(Mt)}destroy(){this.destroyed=!0,this.set(0,0,0,0,0,0,0,0),Ut(this.buffer)}},fo=class extends ao{A=Ft[0]|0;B=Ft[1]|0;C=Ft[2]|0;D=Ft[3]|0;E=Ft[4]|0;F=Ft[5]|0;G=Ft[6]|0;H=Ft[7]|0;constructor(){super(32)}};var Ai=xi(["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))),wu=Ai[0],Eu=Ai[1],Pt=new Uint32Array(80),zt=new Uint32Array(80),uo=class extends tr{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)Pt[_]=t.getUint32(e),zt[_]=t.getUint32(e+=4);for(let _=16;_<80;_++){let T=Pt[_-15]|0,I=zt[_-15]|0,F=te(T,I,1)^te(T,I,8)^io(T,I,7),L=ee(T,I,1)^ee(T,I,8)^co(T,I,7),B=Pt[_-2]|0,O=zt[_-2]|0,z=te(B,O,19)^er(B,O,61)^io(B,O,6),k=ee(B,O,19)^rr(B,O,61)^co(B,O,6),l=Ei(L,k,zt[_-7],zt[_-16]),y=Si(l,F,z,Pt[_-7],Pt[_-16]);Pt[_]=y|0,zt[_]=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)^er(h,E,41),I=ee(h,E,14)^ee(h,E,18)^rr(h,E,41),F=h&m^~h&w,L=E&d^~E&p,B=_i(S,I,L,Eu[_],zt[_]),O=vi(B,b,T,F,wu[_],Pt[_]),z=B|0,k=te(n,o,28)^er(n,o,34)^er(n,o,39),l=ee(n,o,28)^rr(n,o,34)^rr(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}=_t(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=gi(z,l,v);n=wi(g,O,k,y),o=g|0}({h:n,l:o}=_t(this.Ah|0,this.Al|0,n|0,o|0)),{h:s,l:i}=_t(this.Bh|0,this.Bl|0,s|0,i|0),{h:c,l:f}=_t(this.Ch|0,this.Cl|0,c|0,f|0),{h:a,l:u}=_t(this.Dh|0,this.Dl|0,a|0,u|0),{h,l:E}=_t(this.Eh|0,this.El|0,h|0,E|0),{h:m,l:d}=_t(this.Fh|0,this.Fl|0,m|0,d|0),{h:w,l:p}=_t(this.Gh|0,this.Gl|0,w|0,p|0),{h:b,l:S}=_t(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(){Ut(Pt,zt)}destroy(){this.destroyed=!0,Ut(this.buffer),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}},ho=class extends uo{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 Bi=oo(()=>new fo,so(1));var Or=oo(()=>new ho,so(3));var M=(r,t,e)=>ut(r,t,e),po=Kt,De=Fr,W=(...r)=>no(...r),Ce=r=>Qe(r),re=ro,nr=r=>pi(r),Nr=BigInt(0),lo=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(!kr(r))throw new RangeError("positive bigint expected, got "+r)}else po(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 or(r){let t=Kr(r).toString(16);return t.length&1?"0"+t:t}function Ii(r){if(typeof r!="string")throw new TypeError("hex string expected, got "+typeof r);return r===""?Nr:BigInt("0x"+r)}function ne(r){return Ii(Fr(r))}function vt(r){return Ii(Fr(sr(ut(r)).reverse()))}function Mr(r,t){if(Kt(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 Qe(e.padStart(t*2,"0"))}function mo(r,t){return Mr(r,t).reverse()}function Ti(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 sr(r){return Uint8Array.from(M(r))}function Pr(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 kr=r=>typeof r=="bigint"&&Nr<=r;function Su(r,t,e){return kr(r)&&kr(t)&&kr(e)&&t<=r&&r<e}function Le(r,t,e,n){if(!Su(t,e,n))throw new RangeError("expected valid "+r+": "+e+" <= n < "+n+", got "+t)}function Ue(r){if(r<Nr)throw new Error("expected non-negative bigint, got "+r);let t;for(t=0;r>Nr;r>>=lo,t+=1);return t}var ir=r=>(lo<<BigInt(r))-lo;function Di(r,t,e){if(Kt(r,"hashLen"),Kt(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 bo=()=>{throw new Error("not implemented")};var rt=BigInt(0),Z=BigInt(1),oe=BigInt(2),Fi=BigInt(3),Ri=BigInt(4),Oi=BigInt(5),_u=BigInt(7),ki=BigInt(8),vu=BigInt(9),Ni=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 Ci(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=Z,i=Z,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!==Z)throw new Error("invert: does not exist");return G(o,t)}function yo(r,t,e){let n=r;if(!n.eql(n.sqr(t),e))throw new Error("Cannot find square root")}function Ki(r,t){let e=r,n=(e.ORDER+Z)/Ri,o=e.pow(t,n);return yo(e,o,t),o}function Au(r,t){let e=r,n=(e.ORDER-Oi)/ki,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 yo(e,f,t),f}function Bu(r){let t=Fe(r),e=Mi(r),n=e(t,t.neg(t.ONE)),o=e(t,n),s=e(t,t.neg(n)),i=(r+_u)/Ni;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 yo(a,b,f),b})}function Mi(r){if(r<Fi)throw new Error("sqrt is not defined for small field");let t=r-Z,e=0;for(;t%oe===rt;)t/=oe,e++;let n=oe,o=Fe(r);for(;Li(o,n)===1;)if(n++>1e3)throw new Error("Cannot find square root: probably non-prime P");if(e===1)return Ki;let s=o.pow(n,t),i=(t+Z)/oe;return function(f,a){let u=f;if(u.is0(a))return a;if(Li(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=Z<<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 Iu(r){return r%Ri===Fi?Ki:r%ki===Oi?Au:r%Ni===vu?Bu(r):Mi(r)}var Rt=(r,t)=>(G(r,t)&Z)===Z,Tu=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function xo(r){let t={ORDER:"bigint",BYTES:"number",BITS:"number"},e=Tu.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<=Z)throw new Error("invalid field: expected ORDER > 1, got "+r.ORDER);return r}function Du(r,t,e){let n=r;if(e<rt)throw new Error("invalid exponent, negatives unsupported");if(e===rt)return n.ONE;if(e===Z)return t;let o=n.ONE,s=t;for(;e>rt;)e&Z&&(o=n.mul(o,s)),s=n.sqr(s),e>>=Z;return o}function cr(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 Li(r,t){let e=r,n=(e.ORDER-Z)/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 Cu(r,t){if(t!==void 0&&po(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=Ue(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 Ui=new WeakMap,zr=class{ORDER;BITS;BYTES;isLE;ZERO=rt;ONE=Z;_lengths;_mod;constructor(t,e={}){if(t<=Z)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}=Cu(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&Z)===Z}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 Du(this,t,e)}div(t,e){return G(t*Ci(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 Ci(t,this.ORDER)}sqrt(t){let e=Ui.get(this);return e||Ui.set(this,e=Iu(this.ORDER)),e(this,t)}toBytes(t){return this.isLE?mo(t,this.BYTES):Mr(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):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 cr(this,t)}cmov(t,e,n){return bt(n,"condition"),n?e:t}};Object.freeze(zr.prototype);function Fe(r,t={}){return new zr(r,t)}function Pi(r){if(typeof r!="bigint")throw new Error("field order must be bigint");if(r<=Z)throw new Error("field order must be greater than 1");let t=Ue(r-Z);return Math.ceil(t/8)}function go(r){let t=Pi(r);return t+Math.ceil(t/2)}function wo(r,t,e=!1){M(r);let n=r.length,o=Pi(t),s=Math.max(go(t),16);if(n<s||n>1024)throw new Error("expected "+s+"-1024 bytes of input, got "+n);let i=e?vt(r):ne(r),c=G(i,t-Z)+Z;return e?mo(c,o):Mr(c,o)}var Re=BigInt(0),se=BigInt(1);function ar(r,t){let e=t.negate();return r?e:t}function ie(r,t){let e=cr(r.Fp,t.map(n=>n.Z));return t.map((n,o)=>r.fromAffine(n.toAffine(e[o])))}function Hi(r,t){if(!Number.isSafeInteger(r)||r<=0||r>t)throw new Error("invalid window size, expected [1.."+t+"], got W="+r)}function Eo(r,t){Hi(r,t);let e=Math.ceil(t/r)+1,n=2**(r-1),o=2**r,s=ir(r),i=BigInt(r);return{windows:e,windowSize:n,mask:s,maxNumber:o,shiftBy:i}}function zi(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 So=new WeakMap,ji=new WeakMap;function _o(r){return ji.get(r)||1}function qi(r){if(r!==Re)throw new Error("invalid wNAF")}var Oe=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>Re;)e&se&&(n=n.add(o)),o=o.double(),e>>=se;return n}precomputeWindow(t,e){let{windows:n,windowSize:o}=Eo(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=Eo(t,this.bits);for(let c=0;c<i.windows;c++){let{nextN:f,offset:a,isZero:u,isNeg:h,isNegF:E,offsetF:m}=zi(n,c,i);n=f,u?s=s.add(ar(E,e[m])):o=o.add(ar(h,e[a]))}return qi(n),{p:o,f:s}}wNAFUnsafe(t,e,n,o=this.ZERO){let s=Eo(t,this.bits);for(let i=0;i<s.windows&&n!==Re;i++){let{nextN:c,offset:f,isZero:a,isNeg:u}=zi(n,i,s);if(n=c,!a){let h=e[f];o=o.add(u?h.negate():h)}}return qi(n),o}getPrecomputes(t,e,n){let o=So.get(e);return o||(o=this.precomputeWindow(e,t),t!==1&&(typeof n=="function"&&(o=n(o)),So.set(e,o))),o}cached(t,e,n){let o=_o(t);return this.wNAF(o,this.getPrecomputes(o,t,n),e)}unsafe(t,e,n,o){let s=_o(t);return s===1?this._unsafeLadder(t,e,o):this.wNAFUnsafe(s,this.getPrecomputes(s,t,n),e,o)}createCache(t,e){Hi(e,this.bits),ji.set(t,e),So.delete(t)}hasCache(t){return _o(t)!==1}};function Zi(r,t,e,n){let o=t,s=r.ZERO,i=r.ZERO;for(;e>Re||n>Re;)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 Vi(r,t,e){if(t){if(t.ORDER!==r)throw new Error("Field.ORDER must match order: Fp == p, Fn == n");return xo(t),t}else return Fe(r,{isLE:e})}function qr(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>Re))throw new Error(`CURVE.${f} must be positive bigint`)}let o=Vi(t.p,e.Fp,n),s=Vi(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 qt=BigInt(0),tt=BigInt(1),vo=BigInt(2),Lu=BigInt(8);function Uu(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 $i(r,t={}){let e=t,n=qr("edwards",r,e,e.FpFnLE),{Fp:o,Fn:s}=n,i=n.CURVE,{h:c}=i;xt(e,{},{uvRatio:"function"});let f=vo<<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:qt}}}:e.uvRatio;if(!Uu(o,i,i.Gx,i.Gy))throw new Error("bad curve params: generator point");function h(w,p,b=!1){let S=b?tt:qt;return Le("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(qt,tt,tt,qt);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=sr(M(p,S,"point")),bt(b,"zip215");let I=sr(p),F=p[S-1];I[S-1]=F&-129;let L=vt(I),B=b?f:o.ORDER;Le("point.y",L,qt,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===qt&&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(Ce(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(vo),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(vo*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===qt?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?Lu:o.inv(I));let L=a(_*S),B=a(T*S),O=o.mul(I,S);if(F)return{x:qt,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 De(this.toBytes())}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}}let d=new Oe(m,s.BITS);return s.BITS>=8&&m.BASE.precompute(8),Object.freeze(m.prototype),Object.freeze(m),m}var Hr=class{static BASE;static ZERO;static Fp;static Fn;ep;constructor(t){this.ep=t}static fromBytes(t){bo()}static fromHex(t){bo()}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 De(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 Yi(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?nr: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(vt(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=vt(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:Vr(B,b),getPublicKey:b,sign:_,verify:I,utils:k,Point:r,lengths:L})}function fr(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 Fu(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 Ru(r){if(!re(r)&&typeof r!="string")throw new Error("DST must be Uint8Array or ascii string");let t=typeof r=="string"?Pr(r):r;if(t.length===0)throw new Error("DST must be non-empty");return t}function Ao(r,t,e,n){M(r),yt(e),t=Ru(t),t.length>255&&(t=n(W(Pr("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,fr(t.length,1)),f=new Uint8Array(s),a=fr(e,2),u=new Array(i),h=n(W(f,r,a,fr(0,1),c));u[0]=n(W(h,fr(1,1),c));for(let m=1;m<i;m++){let d=[Fu(h,u[m-1]),fr(m+1,1),c];u[m]=n(W(...d))}return W(...u).slice(0,e)}var Gi="HashToScalar-";var Ou=BigInt(0),Ot=BigInt(1),Xi=BigInt(2);var ku=BigInt(5),Nu=BigInt(8),ke=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffed"),Do={p:ke,n:BigInt("0x1000000000000000000000000000000014def9dea2f79cd65812631a5cf5d3ed"),h:Nu,a:BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffec"),d:BigInt("0x52036cee2b6ffe738cc740797779e89800700a4d4141d8ab75eb4dca135978a3"),Gx:BigInt("0x216936d3cd6e53fec0a4e231fdd6dc5c692cc7609525a7b2c9562d608f25d51a"),Gy:BigInt("0x6666666666666666666666666666666666666666666666666666666666666658")};function Ku(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),o=BigInt(80),s=ke,c=r*r%s*r%s,f=V(c,Xi,s)*c%s,a=V(f,Ot,s)*r%s,u=V(a,ku,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,Xi,s)*r%s,b2:c}}function Mu(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}var Bo=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752");function Co(r,t){let e=ke,n=G(t*t*t,e),o=G(n*n*t,e),s=Ku(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),Rt(i,e)&&(i=G(-i,e)),{isValid:u||h,value:i}}var Ht=$i(Do,{uvRatio:Co}),Vt=Ht.Fp,Qi=Ht.Fn;function Pu(r){return Yi(Ht,Or,Object.assign({adjustScalarBytes:Mu,zip215:!0},r))}var tc=Pu({});var Io=Bo,zu=BigInt("25063068953384623474111414158702152701244531502492656460079210482610430750235"),qu=BigInt("54469307008909316920995813868745141605393597292927456921205312896311721017578"),Vu=BigInt("1159843021668779879193775521855586647937357759715417654439879720876111806838"),Hu=BigInt("40440834346308536858101042469323190826248399146238708352240133220865137265952"),Wi=r=>Co(Ot,r),ju=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"),To=r=>Vt.create(vt(r)&ju);function Ji(r){let{d:t}=Do,e=ke,n=b=>Vt.create(b),o=n(Io*r*r),s=n((o+Ot)*Vu),i=BigInt(-1),c=n((i-t*o)*n(o+t)),{isValid:f,value:a}=Co(s,c),u=n(a*r);Rt(u,e)||(u=n(-u)),f||(a=u),f||(i=o);let h=n(i*(o-Ot)*Hu-c),E=a*a,m=n((a+a)*c),d=n(h*zu),w=n(Ot-E),p=n(Ot+E);return new Ht(n(m*p),n(w*d),n(d*p),n(m*w))}var jt=class r extends Hr{static BASE=new r(Ht.BASE);static ZERO=new r(Ht.ZERO);static Fp=Vt;static Fn=Qi;constructor(t){super(t)}static fromAffine(t){return new r(Ht.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}=Do,o=ke,s=T=>Vt.create(T),i=To(t);if(!Ti(Vt.toBytes(i),t)||Rt(i,o))throw new Error("invalid ristretto255 encoding 1");let c=s(i*i),f=s(Ot+e*c),a=s(Ot-e*c),u=s(f*f),h=s(a*a),E=s(e*n*u-h),{isValid:m,value:d}=Wi(s(E*h)),w=s(d*a),p=s(d*w*E),b=s((i+i)*w);Rt(b,o)&&(b=s(-b));let S=s(f*p),_=s(b*S);if(!m||Rt(_,o)||S===Ou)throw new Error("invalid ristretto255 encoding 2");return new r(new Ht(b,S,Ot,_))}static fromHex(t){return r.fromBytes(Qe(t))}toBytes(){let{X:t,Y:e,Z:n,T:o}=this.ep,s=ke,i=p=>Vt.create(p),c=i(i(n+e)*i(n-e)),f=i(t*e),a=i(f*f),{value:u}=Wi(i(c*a)),h=i(u*c),E=i(u*f),m=i(h*E*o),d;if(Rt(o*m,s)){let p=i(e*Io),b=i(t*Io);t=p,e=b,d=i(h*qu)}else d=E;Rt(t*m,s)&&(e=i(-e));let w=i((n-e)*d);return Rt(w,s)&&(w=i(-w)),Vt.toBytes(w)}equals(t){this.assertSame(t);let{X:e,Y:n}=this.ep,{X:o,Y:s}=t.ep,i=a=>Vt.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(jt.BASE);Object.freeze(jt.ZERO);Object.freeze(jt.prototype);Object.freeze(jt);var Zu=Object.freeze({Point:jt,hashToCurve(r,t){let e=t?.DST===void 0?"ristretto255_XMD:SHA-512_R255MAP_RO_":t.DST,n=Ao(r,e,64,Or);return Zu.deriveToCurve(n)},hashToScalar(r,t={DST:Gi}){let e=Ao(r,t.DST,64,Or);return Qi.create(vt(e))},deriveToCurve(r){ut(r,64);let t=To(r.subarray(0,32)),e=Ji(t),n=To(r.subarray(32,64)),o=Ji(n);return new jt(e.add(o))}});var ur=class extends Error{constructor(t="An error occurred while verifying a message"){super(t),this.name="VerificationError"}},jr=class extends Error{constructor(t="Missing Web Crypto API"){super(t),this.name="WebCryptoMissingError"}};var Zr={get(r=globalThis){let t=r.crypto;if(t?.subtle==null)throw new jr("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 $r=32;var Lo,$u=(async()=>{try{return await Zr.get().subtle.generateKey({name:"Ed25519"},!0,["sign","verify"]),!0}catch{return!1}})();async function Yu(r,t,e){if(r.buffer instanceof ArrayBuffer){let n=await Zr.get().subtle.importKey("raw",r.buffer,{name:"Ed25519"},!1,["verify"]);return await Zr.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 Gu(r,t,e){return tc.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}async function ec(r,t,e){return Lo==null&&(Lo=await $u),Lo?Yu(r,t,e):Gu(r,t,e)}function Yr(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}var Gr=class{type="Ed25519";raw;constructor(t){this.raw=Uo(t,$r)}toMultihash(){return dt.digest(Ie(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=ec(this.raw,e,t);return Yr(o)?o.then(s=>(n?.signal?.throwIfAborted(),s)):o}};function nc(r){return r=Uo(r,$r),new Gr(r)}function Uo(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 Wu=Math.pow(2,7),Ju=Math.pow(2,14),Qu=Math.pow(2,21),oc=Math.pow(2,28),sc=Math.pow(2,35),ic=Math.pow(2,42),cc=Math.pow(2,49),st=128,Zt=127;function hr(r){if(r<Wu)return 1;if(r<Ju)return 2;if(r<Qu)return 3;if(r<oc)return 4;if(r<sc)return 5;if(r<ic)return 6;if(r<cc)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function ac(r,t,e=0){switch(hr(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 fc(r,t){let e=r[t],n=0;if(n+=e&Zt,e<st||(e=r[t+1],n+=(e&Zt)<<7,e<st)||(e=r[t+2],n+=(e&Zt)<<14,e<st)||(e=r[t+3],n+=(e&Zt)<<21,e<st)||(e=r[t+4],n+=(e&Zt)*oc,e<st)||(e=r[t+5],n+=(e&Zt)*sc,e<st)||(e=r[t+6],n+=(e&Zt)*ic,e<st)||(e=r[t+7],n+=(e&Zt)*cc,e<st))return n;throw new RangeError("Could not decode varint")}var Fo=new Float32Array([-0]),$t=new Uint8Array(Fo.buffer);function uc(r,t,e){Fo[0]=r,t[e]=$t[0],t[e+1]=$t[1],t[e+2]=$t[2],t[e+3]=$t[3]}function hc(r,t){return $t[0]=r[t],$t[1]=r[t+1],$t[2]=r[t+2],$t[3]=r[t+3],Fo[0]}var Ro=new Float64Array([-0]),ot=new Uint8Array(Ro.buffer);function lc(r,t,e){Ro[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 dc(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],Ro[0]}var th=BigInt(Number.MAX_SAFE_INTEGER),eh=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<th&&t>eh)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>pc&&(o=0n,++n>pc&&(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 pc=4294967296n;function mc(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 bc(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 Oo(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 Xr(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var ko=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 Xr(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw gt(this,4);return Xr(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw gt(this,4);let t=hc(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw gt(this,4);let t=dc(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 bc(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=Xr(this.buf,this.pos+=4),e=Xr(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=fc(this.buf,this.pos);return this.pos+=hr(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 lr(r){return new ko(r instanceof Uint8Array?r:r.subarray())}function Wr(r,t,e){let n=lr(r);return t.decode(n,void 0,e)}function ae(r=0){return new Uint8Array(r)}var No={};q(No,{base10:()=>rh});var rh=kt({prefix:"9",name:"base10",alphabet:"0123456789"});var Ko={};q(Ko,{base16:()=>nh,base16upper:()=>oh});var nh=H({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),oh=H({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Mo={};q(Mo,{base2:()=>sh});var sh=H({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Po={};q(Po,{base256emoji:()=>uh});var xc=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}"),ih=xc.reduce((r,t,e)=>(r[e]=t,r),[]),ch=xc.reduce((r,t,e)=>{let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);return r[n]=e,r},[]);function ah(r){return r.reduce((t,e)=>(t+=ih[e],t),"")}function fh(r){let t=[];for(let e of r){let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);let o=ch[n];if(o==null)throw new Error(`Non-base256emoji character: ${e}`);t.push(o)}return new Uint8Array(t)}var uh=de({prefix:"\u{1F680}",name:"base256emoji",encode:ah,decode:fh});var zo={};q(zo,{base64:()=>hh,base64pad:()=>lh,base64url:()=>dh,base64urlpad:()=>ph});var hh=H({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),lh=H({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),dh=H({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),ph=H({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var qo={};q(qo,{base8:()=>mh});var mh=H({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Vo={};q(Vo,{identity:()=>bh});var bh=de({prefix:"\0",name:"identity",encode:r=>ws(r),decode:r=>gs(r)});var y0=new TextEncoder,x0=new TextDecoder;var Zo={};q(Zo,{sha256:()=>dr,sha512:()=>wh});var gh=20;function jo({name:r,code:t,encode:e,minDigestLength:n,maxDigestLength:o}){return new Ho(r,t,e,n,o)}var Ho=class{name;code;encode;minDigestLength;maxDigestLength;constructor(t,e,n,o,s){this.name=t,this.code=e,this.encode=n,this.minDigestLength=o??gh,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?gc(n,this.code,e?.truncate):n.then(o=>gc(o,this.code,e?.truncate))}else throw Error("Unknown type, must be binary type")}};function gc(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 Ec(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var dr=jo({name:"sha2-256",code:18,encode:Ec("SHA-256")}),wh=jo({name:"sha2-512",code:19,encode:Ec("SHA-512")});var $o={...Vo,...Mo,...qo,...No,...Ko,...En,...Sn,...wn,...zo,...Po},C0={...Zo,...An};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(ac,hr(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(uc,4,t)}double(t){return this._push(lc,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=mc(t);return e!==0?this.uint32(e)._push(Oo,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?Oo(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=lr(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 Wr(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 Wr(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(Cr(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),Ut(o)}update(t){return Te(this),this.iHash.update(t),this}digestInto(t){Te(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()}},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){Le("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=ir(Math.ceil(Ue(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=or(n);if(o.length/2&128)throw new e("tlv.encode: long form length too big");let s=n>127?or(o.length/2|128):"";return or(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=or(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=qr("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=ar(v,l),y=ar(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(Ce(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}=Zi(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 De(this.toBytes(l))}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}}let O=o.BITS,z=new Oe(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?nr:t.randomBytes,o=Object.assign(Lc(r.Fp,e),{seed:Math.max(go(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,wo(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=Vr(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;Cr(n),xt(e,{},{hmac:"function",lowS:"boolean",randomBytes:"function",bits2int:"function",bits2int_modN:"function"}),e=Object.assign({},e);let o=e.randomBytes===void 0?nr: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(Ce(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 Ce(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 De(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=ir(a);function O(g){return Le("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=Fe(as.p,{sqrt:Fh}),Rh=Dc(as,{Fp:cs,endo:Uh}),Ne=Uc(Rh,Bi);function Rc(r,t,e,n){let o=dr.digest(e instanceof Uint8Array?e:e.subarray());if(Yr(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 ur(String(s))});try{return n?.signal?.throwIfAborted(),Ne.verify(t,o.digest,r,{prehash:!1,format:"der"})}catch(s){throw new ur(String(s))}}var cn=class{type="secp256k1";raw;_key;constructor(t){this._key=kc(t),this.raw=Oc(this._key)}toMultihash(){return dt.digest(Ie(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 nc(n);case it.secp256k1:return Nc(n);case it.ECDSA:return fi(n);default:throw new Me}}function Ie(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===dr.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=ni(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:
|