@libp2p/webtransport 5.0.41 → 5.0.42
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/dist/src/stream.d.ts.map +1 -1
- package/dist/src/stream.js +1 -1
- package/dist/src/stream.js.map +1 -1
- package/dist/src/utils/parse-multiaddr.d.ts +1 -1
- package/dist/src/utils/parse-multiaddr.d.ts.map +1 -1
- package/dist/src/utils/parse-multiaddr.js.map +1 -1
- package/dist/src/webtransport.browser.d.ts +1 -1
- package/package.json +19 -26
- package/src/stream.ts +3 -2
- package/src/utils/parse-multiaddr.ts +2 -1
package/dist/index.min.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
(function (root, factory) {(typeof module === 'object' && module.exports) ? module.exports = factory() : root.Libp2PWebtransport = factory()}(typeof self !== 'undefined' ? self : this, function () {
|
|
2
|
-
"use strict";var Libp2PWebtransport=(()=>{var mo=Object.defineProperty;var Zu=Object.getOwnPropertyDescriptor;var Yu=Object.getOwnPropertyNames;var Xu=Object.prototype.hasOwnProperty;var Ct=(r,t)=>{for(var e in t)mo(r,e,{get:t[e],enumerable:!0})},Ju=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of Yu(t))!Xu.call(r,o)&&o!==e&&mo(r,o,{get:()=>t[o],enumerable:!(n=Zu(t,o))||n.enumerable});return r};var Qu=r=>Ju(mo({},"__esModule",{value:!0}),r);var Kd={};Ct(Kd,{webTransport:()=>Dd});var yo=Symbol.for("@libp2p/peer-id");var Gi=Symbol.for("@libp2p/transport");var Fi;(function(r){r[r.FATAL_ALL=0]="FATAL_ALL",r[r.NO_FATAL=1]="NO_FATAL"})(Fi||(Fi={}));var rn=class extends Error{static name="UnexpectedPeerError";constructor(t="Unexpected Peer"){super(t),this.name="UnexpectedPeerError"}},ze=class extends Error{static name="InvalidCryptoExchangeError";constructor(t="Invalid crypto exchange"){super(t),this.name="InvalidCryptoExchangeError"}},at=class extends Error{static name="InvalidParametersError";constructor(t="Invalid parameters"){super(t),this.name="InvalidParametersError"}},Fe=class extends Error{static name="InvalidPublicKeyError";constructor(t="Invalid public key"){super(t),this.name="InvalidPublicKeyError"}};var nn=class extends Error{static name="StreamResetError";constructor(t="The stream has been reset"){super(t),this.name="StreamResetError"}},on=class extends Error{static name="StreamStateError";constructor(t="The stream is in an invalid state"){super(t),this.name="StreamStateError"}};var sn=class extends Error{static name="InvalidMultiaddrError";constructor(t="Invalid multiaddr"){super(t),this.name="InvalidMultiaddrError"}},an=class extends Error{static name="InvalidCIDError";constructor(t="Invalid CID"){super(t),this.name="InvalidCIDError"}},cn=class extends Error{static name="InvalidMultihashError";constructor(t="Invalid Multihash"){super(t),this.name="InvalidMultihashError"}};var ve=class extends Error{static name="UnsupportedKeyTypeError";constructor(t="Unsupported key type"){super(t),this.name="UnsupportedKeyTypeError"}};var un=Symbol.for("@libp2p/service-capabilities"),Vd=Symbol.for("@libp2p/service-dependencies");var Eo={};Ct(Eo,{base58btc:()=>nt,base58flickr:()=>sf});var fp=new Uint8Array(0);function Wi(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 Jt(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 ji(r){return new TextEncoder().encode(r)}function $i(r){return new TextDecoder().decode(r)}function tf(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 a=r.length,c=r.charAt(0),f=Math.log(a)/Math.log(256),u=Math.log(256)/Math.log(a);function l(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 m=0,x=0,_=0,M=y.length;_!==M&&y[_]===0;)_++,m++;for(var S=(M-_)*u+1>>>0,d=new Uint8Array(S);_!==M;){for(var I=y[_],U=0,B=S-1;(I!==0||U<x)&&B!==-1;B--,U++)I+=256*d[B]>>>0,d[B]=I%a>>>0,I=I/a>>>0;if(I!==0)throw new Error("Non-zero carry");x=U,_++}for(var L=S-x;L!==S&&d[L]===0;)L++;for(var k=c.repeat(m);L<S;++L)k+=r.charAt(d[L]);return k}function p(y){if(typeof y!="string")throw new TypeError("Expected String");if(y.length===0)return new Uint8Array;var m=0;if(y[m]!==" "){for(var x=0,_=0;y[m]===c;)x++,m++;for(var M=(y.length-m)*f+1>>>0,S=new Uint8Array(M);y[m];){var d=e[y.charCodeAt(m)];if(d===255)return;for(var I=0,U=M-1;(d!==0||I<_)&&U!==-1;U--,I++)d+=a*S[U]>>>0,S[U]=d%256>>>0,d=d/256>>>0;if(d!==0)throw new Error("Non-zero carry");_=I,m++}if(y[m]!==" "){for(var B=M-_;B!==M&&S[B]===0;)B++;for(var L=new Uint8Array(x+(M-B)),k=x;B!==M;)L[k++]=S[B++];return L}}}function w(y){var m=p(y);if(m)return m;throw new Error(`Non-${t} character`)}return{encode:l,decodeUnsafe:p,decode:w}}var ef=tf,rf=ef,Yi=rf;var go=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")}},xo=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 Xi(this,t)}},wo=class{decoders;constructor(t){this.decoders=t}or(t){return Xi(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 Xi(r,t){return new wo({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var bo=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 go(t,e,n),this.decoder=new xo(t,e,o)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function Ge({name:r,prefix:t,encode:e,decode:n}){return new bo(r,t,e,n)}function fe({name:r,prefix:t,alphabet:e}){let{encode:n,decode:o}=Yi(e,r);return Ge({prefix:t,name:r,encode:n,decode:s=>Jt(o(s))})}function nf(r,t,e,n){let o={};for(let u=0;u<t.length;++u)o[t[u]]=u;let s=r.length;for(;r[s-1]==="=";)--s;let i=new Uint8Array(s*e/8|0),a=0,c=0,f=0;for(let u=0;u<s;++u){let l=o[r[u]];if(l===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<e|l,a+=e,a>=8&&(a-=8,i[f++]=255&c>>a)}if(a>=e||(255&c<<8-a)!==0)throw new SyntaxError("Unexpected end of data");return i}function of(r,t,e){let n=t[t.length-1]==="=",o=(1<<e)-1,s="",i=0,a=0;for(let c=0;c<r.length;++c)for(a=a<<8|r[c],i+=8;i>e;)i-=e,s+=t[o&a>>i];if(i!==0&&(s+=t[o&a<<e-i]),n)for(;(s.length*e&7)!==0;)s+="=";return s}function ct({name:r,prefix:t,bitsPerChar:e,alphabet:n}){return Ge({prefix:t,name:r,encode(o){return of(o,n,e)},decode(o){return nf(o,n,e,r)}})}var nt=fe({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),sf=fe({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var So={};Ct(So,{base32:()=>Qt,base32hex:()=>ff,base32hexpad:()=>hf,base32hexpadupper:()=>df,base32hexupper:()=>lf,base32pad:()=>cf,base32padupper:()=>uf,base32upper:()=>af,base32z:()=>pf});var Qt=ct({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),af=ct({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),cf=ct({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),uf=ct({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),ff=ct({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),lf=ct({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),hf=ct({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),df=ct({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),pf=ct({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Ao={};Ct(Ao,{base36:()=>gr,base36upper:()=>mf});var gr=fe({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),mf=fe({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Gt={};Ct(Gt,{Digest:()=>Ie,create:()=>Nt,decode:()=>le,equals:()=>Io,hasCode:()=>Rf});var yf=ta,Ji=128,gf=127,xf=~gf,wf=Math.pow(2,31);function ta(r,t,e){t=t||[],e=e||0;for(var n=e;r>=wf;)t[e++]=r&255|Ji,r/=128;for(;r&xf;)t[e++]=r&255|Ji,r>>>=7;return t[e]=r|0,ta.bytes=e-n+1,t}var bf=vo,Ef=128,Qi=127;function vo(r,n){var e=0,n=n||0,o=0,s=n,i,a=r.length;do{if(s>=a)throw vo.bytes=0,new RangeError("Could not decode varint");i=r[s++],e+=o<28?(i&Qi)<<o:(i&Qi)*Math.pow(2,o),o+=7}while(i>=Ef);return vo.bytes=s-n,e}var Sf=Math.pow(2,7),Af=Math.pow(2,14),vf=Math.pow(2,21),If=Math.pow(2,28),Bf=Math.pow(2,35),_f=Math.pow(2,42),Lf=Math.pow(2,49),Tf=Math.pow(2,56),Cf=Math.pow(2,63),Pf=function(r){return r<Sf?1:r<Af?2:r<vf?3:r<If?4:r<Bf?5:r<_f?6:r<Lf?7:r<Tf?8:r<Cf?9:10},Uf={encode:yf,decode:bf,encodingLength:Pf},kf=Uf,xr=kf;function wr(r,t=0){return[xr.decode(r,t),xr.decode.bytes]}function We(r,t,e=0){return xr.encode(r,t,e),t}function je(r){return xr.encodingLength(r)}function Nt(r,t){let e=t.byteLength,n=je(r),o=n+je(e),s=new Uint8Array(o+e);return We(r,s,0),We(e,s,n),s.set(t,o),new Ie(r,e,t,s)}function le(r){let t=Jt(r),[e,n]=wr(t),[o,s]=wr(t.subarray(n)),i=t.subarray(n+s);if(i.byteLength!==o)throw new Error("Incorrect length");return new Ie(e,o,i,t)}function Io(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&Wi(r.bytes,e.bytes)}}var Ie=class{code;size;digest;bytes;constructor(t,e,n,o){this.code=t,this.size=e,this.digest=n,this.bytes=o}};function Rf(r,t){return r.code===t}function ea(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return Kf(e,Bo(r),t??nt.encoder);default:return Nf(e,Bo(r),t??Qt.encoder)}}var ra=new WeakMap;function Bo(r){let t=ra.get(r);if(t==null){let e=new Map;return ra.set(r,e),e}return t}var ut=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!==br)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==Mf)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=Nt(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&&Io(t.multihash,n.multihash)}toString(t){return ea(this,t)}toJSON(){return{"/":ea(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??na(n,o,s.bytes))}else if(e[Of]===!0){let{version:n,multihash:o,code:s}=e,i=le(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!==br)throw new Error(`Version 0 CID must use dag-pb (code: ${br}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let o=na(t,e,n.bytes);return new r(t,e,n,o)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,br,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=Jt(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 Ie(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[l,p]=wr(t.subarray(e));return e+=p,l},o=n(),s=br;if(o===18?(o=0,e=0):s=n(),o!==0&&o!==1)throw new RangeError(`Invalid CID version ${o}`);let i=e,a=n(),c=n(),f=e+c,u=f-i;return{version:o,codec:s,multihashCode:a,digestSize:c,multihashSize:u,size:f}}static parse(t,e){let[n,o]=Df(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 Bo(s).set(n,t),s}};function Df(r,t){switch(r[0]){case"Q":{let e=t??nt;return[nt.prefix,e.decode(`${nt.prefix}${r}`)]}case nt.prefix:{let e=t??nt;return[nt.prefix,e.decode(r)]}case Qt.prefix:{let e=t??Qt;return[Qt.prefix,e.decode(r)]}case gr.prefix:{let e=t??gr;return[gr.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 Kf(r,t,e){let{prefix:n}=e;if(n!==nt.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 Nf(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 br=112,Mf=18;function na(r,t,e){let n=je(r),o=n+je(t),s=new Uint8Array(o+e.byteLength);return We(r,s,0),We(t,s,n),s.set(e,o),s}var Of=Symbol.for("@ipld/js-cid/CID");var _o={};Ct(_o,{identity:()=>Ot});var oa=0,Hf="identity",sa=Jt;function Vf(r){return Nt(oa,sa(r))}var Ot={code:oa,name:Hf,encode:sa,digest:Vf};function ht(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 dt(r=0){return new Uint8Array(r)}function pt(r=0){return new Uint8Array(r)}function At(r,t){t==null&&(t=r.reduce((o,s)=>o+s.length,0));let e=pt(t),n=0;for(let o of r)e.set(o,n),n+=o.length;return e}var aa=Symbol.for("@achingbrain/uint8arraylist");function ia(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 ln(r){return!!r?.[aa]}var $=class r{bufs;length;[aa]=!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(ln(n))e+=n.byteLength,this.bufs.push(...n.bufs);else throw new Error("Could not append value, must be an Uint8Array or a Uint8ArrayList");this.length+=e}prepend(...t){this.prependAll(t)}prependAll(t){let e=0;for(let n of t.reverse())if(n instanceof Uint8Array)e+=n.byteLength,this.bufs.unshift(n);else if(ln(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=ia(this.bufs,t);return e.buf[e.index]}set(t,e){let n=ia(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(ln(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 At(n,o)}subarray(t,e){let{bufs:n,length:o}=this._subList(t,e);return n.length===1?n[0]:At(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],a=o,c=a+i.byteLength;if(o=c,t>=c)continue;let f=t>=a&&t<c,u=e>a&&e<=c;if(f&&u){if(t===a&&e===c){n.push(i);break}let l=t-a;n.push(i.subarray(l,l+(e-t)));break}if(f){if(t===0){n.push(i);continue}n.push(i.subarray(t-a));continue}if(u){if(e===c){n.push(i);break}n.push(i.subarray(0,e-a));break}n.push(i)}return{bufs:n,length:e-t}}indexOf(t,e=0){if(!ln(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 l=0;l<s;l++)i[l]=-1;for(let l=0;l<o;l++)i[n[l]]=l;let a=i,c=this.byteLength-n.byteLength,f=n.byteLength-1,u;for(let l=e;l<=c;l+=u){u=0;for(let p=f;p>=0;p--){let w=this.get(l+p);if(n[p]!==w){u=Math.max(1,p-a[w]);break}}if(u===0)return l}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=pt(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=pt(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(!ht(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 Lo={};Ct(Lo,{base10:()=>zf});var zf=fe({prefix:"9",name:"base10",alphabet:"0123456789"});var To={};Ct(To,{base16:()=>Ff,base16upper:()=>Gf});var Ff=ct({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Gf=ct({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Co={};Ct(Co,{base2:()=>Wf});var Wf=ct({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Po={};Ct(Po,{base256emoji:()=>Xf});var ca=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}"),jf=ca.reduce((r,t,e)=>(r[e]=t,r),[]),$f=ca.reduce((r,t,e)=>{let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);return r[n]=e,r},[]);function Zf(r){return r.reduce((t,e)=>(t+=jf[e],t),"")}function Yf(r){let t=[];for(let e of r){let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);let o=$f[n];if(o==null)throw new Error(`Non-base256emoji character: ${e}`);t.push(o)}return new Uint8Array(t)}var Xf=Ge({prefix:"\u{1F680}",name:"base256emoji",encode:Zf,decode:Yf});var ko={};Ct(ko,{base64:()=>Jf,base64pad:()=>Qf,base64url:()=>Uo,base64urlpad:()=>tl});var Jf=ct({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),Qf=ct({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Uo=ct({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),tl=ct({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Ro={};Ct(Ro,{base8:()=>el});var el=ct({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Do={};Ct(Do,{identity:()=>rl});var rl=Ge({prefix:"\0",name:"identity",encode:r=>$i(r),decode:r=>ji(r)});var Wp=new TextEncoder,jp=new TextDecoder;var Mo={};Ct(Mo,{sha256:()=>Er,sha512:()=>sl});function No({name:r,code:t,encode:e}){return new Ko(r,t,e)}var Ko=class{name;code;encode;constructor(t,e,n){this.name=t,this.code=e,this.encode=n}digest(t){if(t instanceof Uint8Array){let e=this.encode(t);return e instanceof Uint8Array?Nt(this.code,e):e.then(n=>Nt(this.code,n))}else throw Error("Unknown type, must be binary type")}};function fa(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var Er=No({name:"sha2-256",code:18,encode:fa("SHA-256")}),sl=No({name:"sha2-512",code:19,encode:fa("SHA-512")});var Be={...Do,...Co,...Ro,...Lo,...To,...So,...Ao,...Eo,...ko,...Po},s0={...Mo,..._o};function ha(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var la=ha("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),Oo=ha("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=pt(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),il={utf8:la,"utf-8":la,hex:Be.base16,latin1:Oo,ascii:Oo,binary:Oo,...Be},hn=il;function Q(r,t="utf8"){let e=hn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function V(r,t="utf8"){let e=hn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}var al=parseInt("11111",2),Ho=parseInt("10000000",2),cl=parseInt("01111111",2),da={0:Sr,1:Sr,2:ul,3:hl,4:dl,5:ll,6:fl,16:Sr,22:Sr,48:Sr};function te(r,t={offset:0}){let e=r[t.offset]&al;if(t.offset++,da[e]!=null)return da[e](r,t);throw new Error("No decoder for tag "+e)}function Ar(r,t){let e=0;if((r[t.offset]&Ho)===Ho){let n=r[t.offset]&cl,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 Sr(r,t){Ar(r,t);let e=[];for(;!(t.offset>=r.byteLength);){let n=te(r,t);if(n===null)break;e.push(n)}return e}function ul(r,t){let e=Ar(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 fl(r,t){let e=Ar(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 a=`${s}.${i}`,c=[];for(;t.offset<n;){let f=r[t.offset];if(t.offset++,c.push(f&127),f<128){c.reverse();let u=0;for(let l=0;l<c.length;l++)u+=c[l]<<l*7;a+=`.${u}`,c=[]}}return a}function ll(r,t){return t.offset++,null}function hl(r,t){let e=Ar(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 dl(r,t){let e=Ar(r,t),n=r.subarray(t.offset,t.offset+e);return t.offset+=e,n}function pl(r){let t=r.toString(16);t.length%2===1&&(t="0"+t);let e=new $;for(let n=0;n<t.length;n+=2)e.append(Uint8Array.from([parseInt(`${t[n]}${t[n+1]}`,16)]));return e}function Vo(r){if(r.byteLength<128)return Uint8Array.from([r.byteLength]);let t=pl(r.byteLength);return new $(Uint8Array.from([t.byteLength|Ho]),t)}function Rt(r){let t=new $,e=128;return(r.subarray()[0]&e)===e&&t.append(Uint8Array.from([0])),t.append(r),new $(Uint8Array.from([2]),Vo(t),t)}function dn(r){let t=Uint8Array.from([0]),e=new $(t,r);return new $(Uint8Array.from([3]),Vo(e),e)}function he(r,t=48){let e=new $;for(let n of r)e.append(n);return new $(Uint8Array.from([t]),Vo(e),e)}async function pa(r,t,e){let n=await crypto.subtle.importKey("jwk",r,{name:"ECDSA",namedCurve:r.crv??"P-256"},!1,["verify"]);return crypto.subtle.verify({name:"ECDSA",hash:{name:"SHA-256"}},n,t,e.subarray())}var ml=Uint8Array.from([6,8,42,134,72,206,61,3,1,7]),yl=Uint8Array.from([6,5,43,129,4,0,34]),gl=Uint8Array.from([6,5,43,129,4,0,35]),xl={ext:!0,kty:"EC",crv:"P-256"},wl={ext:!0,kty:"EC",crv:"P-384"},bl={ext:!0,kty:"EC",crv:"P-521"},qo=32,zo=48,Fo=66;function Go(r){let t=te(r);return ma(t)}function ma(r){let t=r[1][1][0],e=1,n,o;if(t.byteLength===qo*2+1)return n=V(t.subarray(e,e+qo),"base64url"),o=V(t.subarray(e+qo),"base64url"),new $e({...xl,key_ops:["verify"],x:n,y:o});if(t.byteLength===zo*2+1)return n=V(t.subarray(e,e+zo),"base64url"),o=V(t.subarray(e+zo),"base64url"),new $e({...wl,key_ops:["verify"],x:n,y:o});if(t.byteLength===Fo*2+1)return n=V(t.subarray(e,e+Fo),"base64url"),o=V(t.subarray(e+Fo),"base64url"),new $e({...bl,key_ops:["verify"],x:n,y:o});throw new at(`coordinates were wrong length, got ${t.byteLength}, expected 65, 97 or 133`)}function ya(r){return he([Rt(Uint8Array.from([1])),he([El(r.crv)],160),he([dn(new $(Uint8Array.from([4]),Q(r.x??"","base64url"),Q(r.y??"","base64url")))],161)]).subarray()}function El(r){if(r==="P-256")return ml;if(r==="P-384")return yl;if(r==="P-521")return gl;throw new at(`Invalid curve ${r}`)}var $e=class{type="ECDSA";jwk;_raw;constructor(t){this.jwk=t}get raw(){return this._raw==null&&(this._raw=ya(this.jwk)),this._raw}toMultihash(){return Ot.digest(de(this))}toCID(){return ut.createV1(114,this.toMultihash())}toString(){return nt.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:ht(this.raw,t.raw)}async verify(t,e){return pa(this.jwk,e,t)}};var _e=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;function Sl(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function Ze(r){if(!Number.isSafeInteger(r)||r<0)throw new Error("positive integer expected, got "+r)}function Le(r,...t){if(!Sl(r))throw new Error("Uint8Array expected");if(t.length>0&&!t.includes(r.length))throw new Error("Uint8Array expected of length "+t+", got length="+r.length)}function vr(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.createHasher");Ze(r.outputLen),Ze(r.blockLen)}function Xe(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 ga(r,t){Le(r);let e=t.outputLen;if(r.length<e)throw new Error("digestInto() expects output buffer of length at least "+e)}function Ht(...r){for(let t=0;t<r.length;t++)r[t].fill(0)}function pn(r){return new DataView(r.buffer,r.byteOffset,r.byteLength)}function Vt(r,t){return r<<32-t|r>>>t}function xa(r){if(typeof r!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(r))}function pe(r){return typeof r=="string"&&(r=xa(r)),Le(r),r}function Wo(...r){let t=0;for(let n=0;n<r.length;n++){let o=r[n];Le(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}var Ye=class{};function jo(r){let t=n=>r().update(pe(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function Ir(r=32){if(_e&&typeof _e.getRandomValues=="function")return _e.getRandomValues(new Uint8Array(r));if(_e&&typeof _e.randomBytes=="function")return Uint8Array.from(_e.randomBytes(r));throw new Error("crypto.getRandomValues must be defined")}function Al(r,t,e,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(t,e,n);let o=BigInt(32),s=BigInt(4294967295),i=Number(e>>o&s),a=Number(e&s),c=n?4:0,f=n?0:4;r.setUint32(t+c,i,n),r.setUint32(t+f,a,n)}function wa(r,t,e){return r&t^~r&e}function ba(r,t,e){return r&t^r&e^t&e}var Br=class extends Ye{constructor(t,e,n,o){super(),this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.blockLen=t,this.outputLen=e,this.padOffset=n,this.isLE=o,this.buffer=new Uint8Array(t),this.view=pn(this.buffer)}update(t){Xe(this),t=pe(t),Le(t);let{view:e,buffer:n,blockLen:o}=this,s=t.length;for(let i=0;i<s;){let a=Math.min(o-this.pos,s-i);if(a===o){let c=pn(t);for(;o<=s-i;i+=o)this.process(c,i);continue}n.set(t.subarray(i,i+a),this.pos),this.pos+=a,i+=a,this.pos===o&&(this.process(e,0),this.pos=0)}return this.length+=t.length,this.roundClean(),this}digestInto(t){Xe(this),ga(t,this),this.finished=!0;let{buffer:e,view:n,blockLen:o,isLE:s}=this,{pos:i}=this;e[i++]=128,Ht(this.buffer.subarray(i)),this.padOffset>o-i&&(this.process(n,0),i=0);for(let l=i;l<o;l++)e[l]=0;Al(n,o-8,BigInt(this.length*8),s),this.process(n,0);let a=pn(t),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let f=c/4,u=this.get();if(f>u.length)throw new Error("_sha2: outputLen bigger than state");for(let l=0;l<f;l++)a.setUint32(4*l,u[l],s)}digest(){let{buffer:t,outputLen:e}=this;this.digestInto(t);let n=t.slice(0,e);return this.destroy(),n}_cloneInto(t){t||(t=new this.constructor),t.set(...this.get());let{blockLen:e,buffer:n,length:o,finished:s,destroyed:i,pos:a}=this;return t.destroyed=i,t.finished=s,t.length=o,t.pos=a,o%e&&t.buffer.set(n),t}clone(){return this._cloneInto()}},ee=Uint32Array.from([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]);var bt=Uint32Array.from([1779033703,4089235720,3144134277,2227873595,1013904242,4271175723,2773480762,1595750129,1359893119,2917565137,2600822924,725511199,528734635,4215389547,1541459225,327033209]);var mn=BigInt(4294967295),Ea=BigInt(32);function vl(r,t=!1){return t?{h:Number(r&mn),l:Number(r>>Ea&mn)}:{h:Number(r>>Ea&mn)|0,l:Number(r&mn)|0}}function Sa(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:a}=vl(r[s],t);[n[s],o[s]]=[i,a]}return[n,o]}var $o=(r,t,e)=>r>>>e,Zo=(r,t,e)=>r<<32-e|t>>>e,Te=(r,t,e)=>r>>>e|t<<32-e,Ce=(r,t,e)=>r<<32-e|t>>>e,_r=(r,t,e)=>r<<64-e|t>>>e-32,Lr=(r,t,e)=>r>>>e-32|t<<64-e;function Wt(r,t,e,n){let o=(t>>>0)+(n>>>0);return{h:r+e+(o/2**32|0)|0,l:o|0}}var Aa=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),va=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,Ia=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),Ba=(r,t,e,n,o)=>t+e+n+o+(r/2**32|0)|0,_a=(r,t,e,n,o)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(o>>>0),La=(r,t,e,n,o,s)=>t+e+n+o+s+(r/2**32|0)|0;var Bl=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]),me=new Uint32Array(64),yn=class extends Br{constructor(t=32){super(64,t,8,!1),this.A=ee[0]|0,this.B=ee[1]|0,this.C=ee[2]|0,this.D=ee[3]|0,this.E=ee[4]|0,this.F=ee[5]|0,this.G=ee[6]|0,this.H=ee[7]|0}get(){let{A:t,B:e,C:n,D:o,E:s,F:i,G:a,H:c}=this;return[t,e,n,o,s,i,a,c]}set(t,e,n,o,s,i,a,c){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=a|0,this.H=c|0}process(t,e){for(let l=0;l<16;l++,e+=4)me[l]=t.getUint32(e,!1);for(let l=16;l<64;l++){let p=me[l-15],w=me[l-2],y=Vt(p,7)^Vt(p,18)^p>>>3,m=Vt(w,17)^Vt(w,19)^w>>>10;me[l]=m+me[l-7]+y+me[l-16]|0}let{A:n,B:o,C:s,D:i,E:a,F:c,G:f,H:u}=this;for(let l=0;l<64;l++){let p=Vt(a,6)^Vt(a,11)^Vt(a,25),w=u+p+wa(a,c,f)+Bl[l]+me[l]|0,m=(Vt(n,2)^Vt(n,13)^Vt(n,22))+ba(n,o,s)|0;u=f,f=c,c=a,a=i+w|0,i=s,s=o,o=n,n=w+m|0}n=n+this.A|0,o=o+this.B|0,s=s+this.C|0,i=i+this.D|0,a=a+this.E|0,c=c+this.F|0,f=f+this.G|0,u=u+this.H|0,this.set(n,o,s,i,a,c,f,u)}roundClean(){Ht(me)}destroy(){this.set(0,0,0,0,0,0,0,0),Ht(this.buffer)}};var Ta=Sa(["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))),_l=Ta[0],Ll=Ta[1],ye=new Uint32Array(80),ge=new Uint32Array(80),Yo=class extends Br{constructor(t=64){super(128,t,16,!1),this.Ah=bt[0]|0,this.Al=bt[1]|0,this.Bh=bt[2]|0,this.Bl=bt[3]|0,this.Ch=bt[4]|0,this.Cl=bt[5]|0,this.Dh=bt[6]|0,this.Dl=bt[7]|0,this.Eh=bt[8]|0,this.El=bt[9]|0,this.Fh=bt[10]|0,this.Fl=bt[11]|0,this.Gh=bt[12]|0,this.Gl=bt[13]|0,this.Hh=bt[14]|0,this.Hl=bt[15]|0}get(){let{Ah:t,Al:e,Bh:n,Bl:o,Ch:s,Cl:i,Dh:a,Dl:c,Eh:f,El:u,Fh:l,Fl:p,Gh:w,Gl:y,Hh:m,Hl:x}=this;return[t,e,n,o,s,i,a,c,f,u,l,p,w,y,m,x]}set(t,e,n,o,s,i,a,c,f,u,l,p,w,y,m,x){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=a|0,this.Dl=c|0,this.Eh=f|0,this.El=u|0,this.Fh=l|0,this.Fl=p|0,this.Gh=w|0,this.Gl=y|0,this.Hh=m|0,this.Hl=x|0}process(t,e){for(let S=0;S<16;S++,e+=4)ye[S]=t.getUint32(e),ge[S]=t.getUint32(e+=4);for(let S=16;S<80;S++){let d=ye[S-15]|0,I=ge[S-15]|0,U=Te(d,I,1)^Te(d,I,8)^$o(d,I,7),B=Ce(d,I,1)^Ce(d,I,8)^Zo(d,I,7),L=ye[S-2]|0,k=ge[S-2]|0,K=Te(L,k,19)^_r(L,k,61)^$o(L,k,6),T=Ce(L,k,19)^Lr(L,k,61)^Zo(L,k,6),D=Ia(B,T,ge[S-7],ge[S-16]),C=Ba(D,U,K,ye[S-7],ye[S-16]);ye[S]=C|0,ge[S]=D|0}let{Ah:n,Al:o,Bh:s,Bl:i,Ch:a,Cl:c,Dh:f,Dl:u,Eh:l,El:p,Fh:w,Fl:y,Gh:m,Gl:x,Hh:_,Hl:M}=this;for(let S=0;S<80;S++){let d=Te(l,p,14)^Te(l,p,18)^_r(l,p,41),I=Ce(l,p,14)^Ce(l,p,18)^Lr(l,p,41),U=l&w^~l&m,B=p&y^~p&x,L=_a(M,I,B,Ll[S],ge[S]),k=La(L,_,d,U,_l[S],ye[S]),K=L|0,T=Te(n,o,28)^_r(n,o,34)^_r(n,o,39),D=Ce(n,o,28)^Lr(n,o,34)^Lr(n,o,39),C=n&s^n&a^s&a,H=o&i^o&c^i&c;_=m|0,M=x|0,m=w|0,x=y|0,w=l|0,y=p|0,{h:l,l:p}=Wt(f|0,u|0,k|0,K|0),f=a|0,u=c|0,a=s|0,c=i|0,s=n|0,i=o|0;let E=Aa(K,D,H);n=va(E,k,T,C),o=E|0}({h:n,l:o}=Wt(this.Ah|0,this.Al|0,n|0,o|0)),{h:s,l:i}=Wt(this.Bh|0,this.Bl|0,s|0,i|0),{h:a,l:c}=Wt(this.Ch|0,this.Cl|0,a|0,c|0),{h:f,l:u}=Wt(this.Dh|0,this.Dl|0,f|0,u|0),{h:l,l:p}=Wt(this.Eh|0,this.El|0,l|0,p|0),{h:w,l:y}=Wt(this.Fh|0,this.Fl|0,w|0,y|0),{h:m,l:x}=Wt(this.Gh|0,this.Gl|0,m|0,x|0),{h:_,l:M}=Wt(this.Hh|0,this.Hl|0,_|0,M|0),this.set(n,o,s,i,a,c,f,u,l,p,w,y,m,x,_,M)}roundClean(){Ht(ye,ge)}destroy(){Ht(this.buffer),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}};var gn=jo(()=>new yn);var Ca=jo(()=>new Yo);var ts=BigInt(0),Qo=BigInt(1);function Je(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function es(r){if(!Je(r))throw new Error("Uint8Array expected")}function jt(r,t){if(typeof t!="boolean")throw new Error(r+" boolean expected, got "+t)}function Tr(r){let t=r.toString(16);return t.length&1?"0"+t:t}function ka(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return r===""?ts:BigInt("0x"+r)}var Ra=typeof Uint8Array.from([]).toHex=="function"&&typeof Uint8Array.fromHex=="function",Tl=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function xe(r){if(es(r),Ra)return r.toHex();let t="";for(let e=0;e<r.length;e++)t+=Tl[r[e]];return t}var re={_0:48,_9:57,A:65,F:70,a:97,f:102};function Pa(r){if(r>=re._0&&r<=re._9)return r-re._0;if(r>=re.A&&r<=re.F)return r-(re.A-10);if(r>=re.a&&r<=re.f)return r-(re.a-10)}function Cr(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);if(Ra)return Uint8Array.fromHex(r);let t=r.length,e=t/2;if(t%2)throw new Error("hex string expected, got unpadded hex of length "+t);let n=new Uint8Array(e);for(let o=0,s=0;o<e;o++,s+=2){let i=Pa(r.charCodeAt(s)),a=Pa(r.charCodeAt(s+1));if(i===void 0||a===void 0){let c=r[s]+r[s+1];throw new Error('hex string expected, got non-hex character "'+c+'" at index '+s)}n[o]=i*16+a}return n}function ne(r){return ka(xe(r))}function $t(r){return es(r),ka(xe(Uint8Array.from(r).reverse()))}function Pe(r,t){return Cr(r.toString(16).padStart(t*2,"0"))}function we(r,t){return Pe(r,t).reverse()}function ot(r,t,e){let n;if(typeof t=="string")try{n=Cr(t)}catch(s){throw new Error(r+" must be hex string or Uint8Array, cause: "+s)}else if(Je(t))n=Uint8Array.from(t);else throw new Error(r+" must be hex string or Uint8Array");let o=n.length;if(typeof e=="number"&&o!==e)throw new Error(r+" of length "+e+" expected, got "+o);return n}function be(...r){let t=0;for(let n=0;n<r.length;n++){let o=r[n];es(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}var Xo=r=>typeof r=="bigint"&&ts<=r;function xn(r,t,e){return Xo(r)&&Xo(t)&&Xo(e)&&t<=r&&r<e}function vt(r,t,e,n){if(!xn(t,e,n))throw new Error("expected valid "+r+": "+e+" <= n < "+n+", got "+t)}function Da(r){let t;for(t=0;r>ts;r>>=Qo,t+=1);return t}var Ue=r=>(Qo<<BigInt(r))-Qo,Jo=r=>new Uint8Array(r),Ua=r=>Uint8Array.from(r);function Ka(r,t,e){if(typeof r!="number"||r<2)throw new Error("hashLen must be a number");if(typeof t!="number"||t<2)throw new Error("qByteLen must be a number");if(typeof e!="function")throw new Error("hmacFn must be a function");let n=Jo(r),o=Jo(r),s=0,i=()=>{n.fill(1),o.fill(0),s=0},a=(...l)=>e(o,n,...l),c=(l=Jo(0))=>{o=a(Ua([0]),l),n=a(),l.length!==0&&(o=a(Ua([1]),l),n=a())},f=()=>{if(s++>=1e3)throw new Error("drbg: tried 1000 values");let l=0,p=[];for(;l<t;){n=a();let w=n.slice();p.push(w),l+=n.length}return be(...p)};return(l,p)=>{i(),c(l);let w;for(;!(w=p(f()));)c();return i(),w}}var Cl={bigint:r=>typeof r=="bigint",function:r=>typeof r=="function",boolean:r=>typeof r=="boolean",string:r=>typeof r=="string",stringOrUint8Array:r=>typeof r=="string"||Je(r),isSafeInteger:r=>Number.isSafeInteger(r),array:r=>Array.isArray(r),field:(r,t)=>t.Fp.isValid(r),hash:r=>typeof r=="function"&&Number.isSafeInteger(r.outputLen)};function qt(r,t,e={}){let n=(o,s,i)=>{let a=Cl[s];if(typeof a!="function")throw new Error("invalid validator function");let c=r[o];if(!(i&&c===void 0)&&!a(c,r))throw new Error("param "+String(o)+" is invalid. Expected "+s+", got "+c)};for(let[o,s]of Object.entries(t))n(o,s,!1);for(let[o,s]of Object.entries(e))n(o,s,!0);return r}function Qe(r){let t=new WeakMap;return(e,...n)=>{let o=t.get(e);if(o!==void 0)return o;let s=r(e,...n);return t.set(e,s),s}}var Pt=BigInt(0),yt=BigInt(1),ke=BigInt(2),Pl=BigInt(3),Ma=BigInt(4),Oa=BigInt(5),Ha=BigInt(8);function Y(r,t){let e=r%t;return e>=Pt?e:t+e}function st(r,t,e){let n=r;for(;t-- >Pt;)n*=n,n%=e;return n}function wn(r,t){if(r===Pt)throw new Error("invert: expected non-zero number");if(t<=Pt)throw new Error("invert: expected positive modulus, got "+t);let e=Y(r,t),n=t,o=Pt,s=yt,i=yt,a=Pt;for(;e!==Pt;){let f=n/e,u=n%e,l=o-i*f,p=s-a*f;n=e,e=u,o=i,s=a,i=l,a=p}if(n!==yt)throw new Error("invert: does not exist");return Y(o,t)}function Va(r,t){let e=(r.ORDER+yt)/Ma,n=r.pow(t,e);if(!r.eql(r.sqr(n),t))throw new Error("Cannot find square root");return n}function Ul(r,t){let e=(r.ORDER-Oa)/Ha,n=r.mul(t,ke),o=r.pow(n,e),s=r.mul(t,o),i=r.mul(r.mul(s,ke),o),a=r.mul(s,r.sub(i,r.ONE));if(!r.eql(r.sqr(a),t))throw new Error("Cannot find square root");return a}function kl(r){if(r<BigInt(3))throw new Error("sqrt is not defined for small field");let t=r-yt,e=0;for(;t%ke===Pt;)t/=ke,e++;let n=ke,o=oe(r);for(;Na(o,n)===1;)if(n++>1e3)throw new Error("Cannot find square root: probably non-prime P");if(e===1)return Va;let s=o.pow(n,t),i=(t+yt)/ke;return function(c,f){if(c.is0(f))return f;if(Na(c,f)!==1)throw new Error("Cannot find square root");let u=e,l=c.mul(c.ONE,s),p=c.pow(f,t),w=c.pow(f,i);for(;!c.eql(p,c.ONE);){if(c.is0(p))return c.ZERO;let y=1,m=c.sqr(p);for(;!c.eql(m,c.ONE);)if(y++,m=c.sqr(m),y===u)throw new Error("Cannot find square root");let x=yt<<BigInt(u-y-1),_=c.pow(l,x);u=y,l=c.sqr(_),p=c.mul(p,l),w=c.mul(w,_)}return w}}function Rl(r){return r%Ma===Pl?Va:r%Ha===Oa?Ul:kl(r)}var qa=(r,t)=>(Y(r,t)&yt)===yt,Dl=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function rs(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=Dl.reduce((n,o)=>(n[o]="function",n),t);return qt(r,e)}function Kl(r,t,e){if(e<Pt)throw new Error("invalid exponent, negatives unsupported");if(e===Pt)return r.ONE;if(e===yt)return t;let n=r.ONE,o=t;for(;e>Pt;)e&yt&&(n=r.mul(n,o)),o=r.sqr(o),e>>=yt;return n}function tr(r,t,e=!1){let n=new Array(t.length).fill(e?r.ZERO:void 0),o=t.reduce((i,a,c)=>r.is0(a)?i:(n[c]=i,r.mul(i,a)),r.ONE),s=r.inv(o);return t.reduceRight((i,a,c)=>r.is0(a)?i:(n[c]=r.mul(i,n[c]),r.mul(i,a)),s),n}function Na(r,t){let e=(r.ORDER-yt)/ke,n=r.pow(t,e),o=r.eql(n,r.ONE),s=r.eql(n,r.ZERO),i=r.eql(n,r.neg(r.ONE));if(!o&&!s&&!i)throw new Error("invalid Legendre symbol result");return o?1:s?0:-1}function ns(r,t){t!==void 0&&Ze(t);let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function oe(r,t,e=!1,n={}){if(r<=Pt)throw new Error("invalid field: expected ORDER > 0, got "+r);let{nBitLength:o,nByteLength:s}=ns(r,t);if(s>2048)throw new Error("invalid field: expected ORDER of <= 2048 bytes");let i,a=Object.freeze({ORDER:r,isLE:e,BITS:o,BYTES:s,MASK:Ue(o),ZERO:Pt,ONE:yt,create:c=>Y(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error("invalid field element: expected bigint, got "+typeof c);return Pt<=c&&c<r},is0:c=>c===Pt,isOdd:c=>(c&yt)===yt,neg:c=>Y(-c,r),eql:(c,f)=>c===f,sqr:c=>Y(c*c,r),add:(c,f)=>Y(c+f,r),sub:(c,f)=>Y(c-f,r),mul:(c,f)=>Y(c*f,r),pow:(c,f)=>Kl(a,c,f),div:(c,f)=>Y(c*wn(f,r),r),sqrN:c=>c*c,addN:(c,f)=>c+f,subN:(c,f)=>c-f,mulN:(c,f)=>c*f,inv:c=>wn(c,r),sqrt:n.sqrt||(c=>(i||(i=Rl(r)),i(a,c))),toBytes:c=>e?we(c,s):Pe(c,s),fromBytes:c=>{if(c.length!==s)throw new Error("Field.fromBytes: expected "+s+" bytes, got "+c.length);return e?$t(c):ne(c)},invertBatch:c=>tr(a,c),cmov:(c,f,u)=>u?f:c});return Object.freeze(a)}function za(r){if(typeof r!="bigint")throw new Error("field order must be bigint");let t=r.toString(2).length;return Math.ceil(t/8)}function os(r){let t=za(r);return t+Math.ceil(t/2)}function Fa(r,t,e=!1){let n=r.length,o=za(t),s=os(t);if(n<16||n<s||n>1024)throw new Error("expected "+s+"-1024 bytes of input, got "+n);let i=e?$t(r):ne(r),a=Y(i,t-yt)+yt;return e?we(a,o):Pe(a,o)}var Ga=BigInt(0),us=BigInt(1);function ss(r,t){let e=t.negate();return r?e:t}function ja(r,t){if(!Number.isSafeInteger(r)||r<=0||r>t)throw new Error("invalid window size, expected [1.."+t+"], got W="+r)}function is(r,t){ja(r,t);let e=Math.ceil(t/r)+1,n=2**(r-1),o=2**r,s=Ue(r),i=BigInt(r);return{windows:e,windowSize:n,mask:s,maxNumber:o,shiftBy:i}}function Wa(r,t,e){let{windowSize:n,mask:o,maxNumber:s,shiftBy:i}=e,a=Number(r&o),c=r>>i;a>n&&(a-=s,c+=us);let f=t*n,u=f+Math.abs(a)-1,l=a===0,p=a<0,w=t%2!==0;return{nextN:c,offset:u,isZero:l,isNeg:p,isNegF:w,offsetF:f}}function Nl(r,t){if(!Array.isArray(r))throw new Error("array expected");r.forEach((e,n)=>{if(!(e instanceof t))throw new Error("invalid point at index "+n)})}function Ml(r,t){if(!Array.isArray(r))throw new Error("array of scalars expected");r.forEach((e,n)=>{if(!t.isValid(e))throw new Error("invalid scalar at index "+n)})}var as=new WeakMap,$a=new WeakMap;function cs(r){return $a.get(r)||1}function bn(r,t){return{constTimeNegate:ss,hasPrecomputes(e){return cs(e)!==1},unsafeLadder(e,n,o=r.ZERO){let s=e;for(;n>Ga;)n&us&&(o=o.add(s)),s=s.double(),n>>=us;return o},precomputeWindow(e,n){let{windows:o,windowSize:s}=is(n,t),i=[],a=e,c=a;for(let f=0;f<o;f++){c=a,i.push(c);for(let u=1;u<s;u++)c=c.add(a),i.push(c);a=c.double()}return i},wNAF(e,n,o){let s=r.ZERO,i=r.BASE,a=is(e,t);for(let c=0;c<a.windows;c++){let{nextN:f,offset:u,isZero:l,isNeg:p,isNegF:w,offsetF:y}=Wa(o,c,a);o=f,l?i=i.add(ss(w,n[y])):s=s.add(ss(p,n[u]))}return{p:s,f:i}},wNAFUnsafe(e,n,o,s=r.ZERO){let i=is(e,t);for(let a=0;a<i.windows&&o!==Ga;a++){let{nextN:c,offset:f,isZero:u,isNeg:l}=Wa(o,a,i);if(o=c,!u){let p=n[f];s=s.add(l?p.negate():p)}}return s},getPrecomputes(e,n,o){let s=as.get(n);return s||(s=this.precomputeWindow(n,e),e!==1&&as.set(n,o(s))),s},wNAFCached(e,n,o){let s=cs(e);return this.wNAF(s,this.getPrecomputes(s,e,o),n)},wNAFCachedUnsafe(e,n,o,s){let i=cs(e);return i===1?this.unsafeLadder(e,n,s):this.wNAFUnsafe(i,this.getPrecomputes(i,e,o),n,s)},setWindowSize(e,n){ja(n,t),$a.set(e,n),as.delete(e)}}}function En(r,t,e,n){Nl(e,r),Ml(n,t);let o=e.length,s=n.length;if(o!==s)throw new Error("arrays of points and scalars must have equal length");let i=r.ZERO,a=Da(BigInt(o)),c=1;a>12?c=a-3:a>4?c=a-2:a>0&&(c=2);let f=Ue(c),u=new Array(Number(f)+1).fill(i),l=Math.floor((t.BITS-1)/c)*c,p=i;for(let w=l;w>=0;w-=c){u.fill(i);for(let m=0;m<s;m++){let x=n[m],_=Number(x>>BigInt(w)&f);u[_]=u[_].add(e[m])}let y=i;for(let m=u.length-1,x=i;m>0;m--)x=x.add(u[m]),y=y.add(x);if(p=p.add(y),w!==0)for(let m=0;m<c;m++)p=p.double()}return p}function Pr(r){return rs(r.Fp),qt(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...ns(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Zt=BigInt(0),Ut=BigInt(1),Za=BigInt(2),Ol=BigInt(8),Hl={zip215:!0};function Vl(r){let t=Pr(r);return qt(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function Ya(r){let t=Vl(r),{Fp:e,n,prehash:o,hash:s,randomBytes:i,nByteLength:a,h:c}=t,f=Za<<BigInt(a*8)-Ut,u=e.create,l=oe(t.n,t.nBitLength);function p(b,h){let g=e.sqr(b),v=e.sqr(h),R=e.add(e.mul(t.a,g),v),O=e.add(e.ONE,e.mul(t.d,e.mul(g,v)));return e.eql(R,O)}if(!p(t.Gx,t.Gy))throw new Error("bad curve params: generator point");let w=t.uvRatio||((b,h)=>{try{return{isValid:!0,value:e.sqrt(b*e.inv(h))}}catch{return{isValid:!1,value:Zt}}}),y=t.adjustScalarBytes||(b=>b),m=t.domain||((b,h,g)=>{if(jt("phflag",g),h.length||g)throw new Error("Contexts/pre-hash are not supported");return b});function x(b,h,g=!1){let v=g?Ut:Zt;vt("coordinate "+b,h,v,f)}function _(b){if(!(b instanceof d))throw new Error("ExtendedPoint expected")}let M=Qe((b,h)=>{let{ex:g,ey:v,ez:R}=b,O=b.is0();h==null&&(h=O?Ol:e.inv(R));let q=u(g*h),z=u(v*h),F=u(R*h);if(O)return{x:Zt,y:Ut};if(F!==Ut)throw new Error("invZ was invalid");return{x:q,y:z}}),S=Qe(b=>{let{a:h,d:g}=t;if(b.is0())throw new Error("bad point: ZERO");let{ex:v,ey:R,ez:O,et:q}=b,z=u(v*v),F=u(R*R),G=u(O*O),J=u(G*G),Z=u(z*h),wt=u(G*u(Z+F)),kt=u(J+u(g*u(z*F)));if(wt!==kt)throw new Error("bad point: equation left != right (1)");let mt=u(v*R),St=u(O*q);if(mt!==St)throw new Error("bad point: equation left != right (2)");return!0});class d{constructor(h,g,v,R){x("x",h),x("y",g),x("z",v,!0),x("t",R),this.ex=h,this.ey=g,this.ez=v,this.et=R,Object.freeze(this)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(h){if(h instanceof d)throw new Error("extended point not allowed");let{x:g,y:v}=h||{};return x("x",g),x("y",v),new d(g,v,Ut,u(g*v))}static normalizeZ(h){let g=tr(e,h.map(v=>v.ez));return h.map((v,R)=>v.toAffine(g[R])).map(d.fromAffine)}static msm(h,g){return En(d,l,h,g)}_setWindowSize(h){B.setWindowSize(this,h)}assertValidity(){S(this)}equals(h){_(h);let{ex:g,ey:v,ez:R}=this,{ex:O,ey:q,ez:z}=h,F=u(g*z),G=u(O*R),J=u(v*z),Z=u(q*R);return F===G&&J===Z}is0(){return this.equals(d.ZERO)}negate(){return new d(u(-this.ex),this.ey,this.ez,u(-this.et))}double(){let{a:h}=t,{ex:g,ey:v,ez:R}=this,O=u(g*g),q=u(v*v),z=u(Za*u(R*R)),F=u(h*O),G=g+v,J=u(u(G*G)-O-q),Z=F+q,wt=Z-z,kt=F-q,mt=u(J*wt),St=u(Z*kt),Dt=u(J*kt),Mt=u(wt*Z);return new d(mt,St,Mt,Dt)}add(h){_(h);let{a:g,d:v}=t,{ex:R,ey:O,ez:q,et:z}=this,{ex:F,ey:G,ez:J,et:Z}=h,wt=u(R*F),kt=u(O*G),mt=u(z*v*Z),St=u(q*J),Dt=u((R+O)*(F+G)-wt-kt),Mt=St-mt,yr=St+mt,zi=u(kt-g*wt),Gu=u(Dt*Mt),Wu=u(yr*zi),ju=u(Dt*zi),$u=u(Mt*yr);return new d(Gu,Wu,$u,ju)}subtract(h){return this.add(h.negate())}wNAF(h){return B.wNAFCached(this,h,d.normalizeZ)}multiply(h){let g=h;vt("scalar",g,Ut,n);let{p:v,f:R}=this.wNAF(g);return d.normalizeZ([v,R])[0]}multiplyUnsafe(h,g=d.ZERO){let v=h;return vt("scalar",v,Zt,n),v===Zt?U:this.is0()||v===Ut?this:B.wNAFCachedUnsafe(this,v,d.normalizeZ,g)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return B.unsafeLadder(this,n).is0()}toAffine(h){return M(this,h)}clearCofactor(){let{h}=t;return h===Ut?this:this.multiplyUnsafe(h)}static fromHex(h,g=!1){let{d:v,a:R}=t,O=e.BYTES;h=ot("pointHex",h,O),jt("zip215",g);let q=h.slice(),z=h[O-1];q[O-1]=z&-129;let F=$t(q),G=g?f:e.ORDER;vt("pointHex.y",F,Zt,G);let J=u(F*F),Z=u(J-Ut),wt=u(v*J-R),{isValid:kt,value:mt}=w(Z,wt);if(!kt)throw new Error("Point.fromHex: invalid y coordinate");let St=(mt&Ut)===Ut,Dt=(z&128)!==0;if(!g&&mt===Zt&&Dt)throw new Error("Point.fromHex: x=0 and x_0=1");return Dt!==St&&(mt=u(-mt)),d.fromAffine({x:mt,y:F})}static fromPrivateKey(h){let{scalar:g}=K(h);return I.multiply(g)}toRawBytes(){let{x:h,y:g}=this.toAffine(),v=we(g,e.BYTES);return v[v.length-1]|=h&Ut?128:0,v}toHex(){return xe(this.toRawBytes())}}d.BASE=new d(t.Gx,t.Gy,Ut,u(t.Gx*t.Gy)),d.ZERO=new d(Zt,Ut,Ut,Zt);let{BASE:I,ZERO:U}=d,B=bn(d,a*8);function L(b){return Y(b,n)}function k(b){return L($t(b))}function K(b){let h=e.BYTES;b=ot("private key",b,h);let g=ot("hashed private key",s(b),2*h),v=y(g.slice(0,h)),R=g.slice(h,2*h),O=k(v);return{head:v,prefix:R,scalar:O}}function T(b){let{head:h,prefix:g,scalar:v}=K(b),R=I.multiply(v),O=R.toRawBytes();return{head:h,prefix:g,scalar:v,point:R,pointBytes:O}}function D(b){return T(b).pointBytes}function C(b=Uint8Array.of(),...h){let g=be(...h);return k(s(m(g,ot("context",b),!!o)))}function H(b,h,g={}){b=ot("message",b),o&&(b=o(b));let{prefix:v,scalar:R,pointBytes:O}=T(h),q=C(g.context,v,b),z=I.multiply(q).toRawBytes(),F=C(g.context,z,O,b),G=L(q+F*R);vt("signature.s",G,Zt,n);let J=be(z,we(G,e.BYTES));return ot("result",J,e.BYTES*2)}let E=Hl;function A(b,h,g,v=E){let{context:R,zip215:O}=v,q=e.BYTES;b=ot("signature",b,2*q),h=ot("message",h),g=ot("publicKey",g,q),O!==void 0&&jt("zip215",O),o&&(h=o(h));let z=$t(b.slice(q,2*q)),F,G,J;try{F=d.fromHex(g,O),G=d.fromHex(b.slice(0,q),O),J=I.multiplyUnsafe(z)}catch{return!1}if(!O&&F.isSmallOrder())return!1;let Z=C(R,G.toRawBytes(),F.toRawBytes(),h);return G.add(F.multiplyUnsafe(Z)).subtract(J).clearCofactor().equals(d.ZERO)}return I._setWindowSize(8),{CURVE:t,getPublicKey:D,sign:H,verify:A,ExtendedPoint:d,utils:{getExtendedPublicKey:T,randomPrivateKey:()=>i(e.BYTES),precompute(b=8,h=d.BASE){return h._setWindowSize(b),h.multiply(BigInt(3)),h}}}}var Ur=BigInt(0),er=BigInt(1),Sn=BigInt(2);function ql(r){return qt(r,{adjustScalarBytes:"function",powPminus2:"function"}),Object.freeze({...r})}function Xa(r){let t=ql(r),{P:e,type:n,adjustScalarBytes:o,powPminus2:s}=t,i=n==="x25519";if(!i&&n!=="x448")throw new Error("invalid type");let a=i?255:448,c=i?32:56,f=BigInt(i?9:5),u=BigInt(i?121665:39081),l=i?Sn**BigInt(254):Sn**BigInt(447),p=i?BigInt(8)*Sn**BigInt(251)-er:BigInt(4)*Sn**BigInt(445)-er,w=l+p+er,y=B=>Y(B,e),m=x(f);function x(B){return we(y(B),c)}function _(B){let L=ot("u coordinate",B,c);return i&&(L[31]&=127),y($t(L))}function M(B){return $t(o(ot("scalar",B,c)))}function S(B,L){let k=U(_(L),M(B));if(k===Ur)throw new Error("invalid private or public key received");return x(k)}function d(B){return S(B,m)}function I(B,L,k){let K=y(B*(L-k));return L=y(L-K),k=y(k+K),{x_2:L,x_3:k}}function U(B,L){vt("u",B,Ur,e),vt("scalar",L,l,w);let k=L,K=B,T=er,D=Ur,C=B,H=er,E=Ur;for(let P=BigInt(a-1);P>=Ur;P--){let b=k>>P&er;E^=b,{x_2:T,x_3:C}=I(E,T,C),{x_2:D,x_3:H}=I(E,D,H),E=b;let h=T+D,g=y(h*h),v=T-D,R=y(v*v),O=g-R,q=C+H,z=C-H,F=y(z*h),G=y(q*v),J=F+G,Z=F-G;C=y(J*J),H=y(K*y(Z*Z)),T=y(g*R),D=y(O*(g+y(u*O)))}({x_2:T,x_3:C}=I(E,T,C)),{x_2:D,x_3:H}=I(E,D,H);let A=s(D);return y(T*A)}return{scalarMult:S,scalarMultBase:d,getSharedSecret:(B,L)=>S(B,L),getPublicKey:B=>d(B),utils:{randomPrivateKey:()=>t.randomBytes(c)},GuBytes:m.slice()}}var kr=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),Ja=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),hm=BigInt(0),zl=BigInt(1),Qa=BigInt(2),Fl=BigInt(3),Gl=BigInt(5),Wl=BigInt(8);function ec(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),o=BigInt(80),s=kr,a=r*r%s*r%s,c=st(a,Qa,s)*a%s,f=st(c,zl,s)*r%s,u=st(f,Gl,s)*f%s,l=st(u,t,s)*u%s,p=st(l,e,s)*l%s,w=st(p,n,s)*p%s,y=st(w,o,s)*w%s,m=st(y,o,s)*w%s,x=st(m,t,s)*u%s;return{pow_p_5_8:st(x,Qa,s)*r%s,b2:a}}function rc(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function jl(r,t){let e=kr,n=Y(t*t*t,e),o=Y(n*n*t,e),s=ec(r*o).pow_p_5_8,i=Y(r*n*s,e),a=Y(t*i*i,e),c=i,f=Y(i*Ja,e),u=a===r,l=a===Y(-r,e),p=a===Y(-r*Ja,e);return u&&(i=c),(l||p)&&(i=f),qa(i,e)&&(i=Y(-i,e)),{isValid:u||l,value:i}}var tc=oe(kr,void 0,!0),$l={a:tc.create(BigInt(-1)),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:tc,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:Wl,Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:Ca,randomBytes:Ir,adjustScalarBytes:rc,uvRatio:jl},nc=Ya($l);var Rr=Xa({P:kr,type:"x25519",powPminus2:r=>{let t=kr,{pow_p_5_8:e,b2:n}=ec(r);return Y(st(e,Fl,t)*n,t)},adjustScalarBytes:rc,randomBytes:Ir});var An=32;function oc(r,t,e){return nc.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}var vn=class{type="Ed25519";raw;constructor(t){this.raw=fs(t,An)}toMultihash(){return Ot.digest(de(this))}toCID(){return ut.createV1(114,this.toMultihash())}toString(){return nt.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:ht(this.raw,t.raw)}verify(t,e){return oc(this.raw,e,t)}};function ls(r){return r=fs(r,An),new vn(r)}function fs(r,t){if(r=Uint8Array.from(r??[]),r.length!==t)throw new at(`Key must be a Uint8Array of length ${t}, got ${r.length}`);return r}var Yl=Math.pow(2,7),Xl=Math.pow(2,14),Jl=Math.pow(2,21),hs=Math.pow(2,28),ds=Math.pow(2,35),ps=Math.pow(2,42),ms=Math.pow(2,49),tt=128,It=127;function lt(r){if(r<Yl)return 1;if(r<Xl)return 2;if(r<Jl)return 3;if(r<hs)return 4;if(r<ds)return 5;if(r<ps)return 6;if(r<ms)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function ys(r,t,e=0){switch(lt(r)){case 8:t[e++]=r&255|tt,r/=128;case 7:t[e++]=r&255|tt,r/=128;case 6:t[e++]=r&255|tt,r/=128;case 5:t[e++]=r&255|tt,r/=128;case 4:t[e++]=r&255|tt,r>>>=7;case 3:t[e++]=r&255|tt,r>>>=7;case 2:t[e++]=r&255|tt,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function Ql(r,t,e=0){switch(lt(r)){case 8:t.set(e++,r&255|tt),r/=128;case 7:t.set(e++,r&255|tt),r/=128;case 6:t.set(e++,r&255|tt),r/=128;case 5:t.set(e++,r&255|tt),r/=128;case 4:t.set(e++,r&255|tt),r>>>=7;case 3:t.set(e++,r&255|tt),r>>>=7;case 2:t.set(e++,r&255|tt),r>>>=7;case 1:{t.set(e++,r&255),r>>>=7;break}default:throw new Error("unreachable")}return t}function gs(r,t){let e=r[t],n=0;if(n+=e&It,e<tt||(e=r[t+1],n+=(e&It)<<7,e<tt)||(e=r[t+2],n+=(e&It)<<14,e<tt)||(e=r[t+3],n+=(e&It)<<21,e<tt)||(e=r[t+4],n+=(e&It)*hs,e<tt)||(e=r[t+5],n+=(e&It)*ds,e<tt)||(e=r[t+6],n+=(e&It)*ps,e<tt)||(e=r[t+7],n+=(e&It)*ms,e<tt))return n;throw new RangeError("Could not decode varint")}function th(r,t){let e=r.get(t),n=0;if(n+=e&It,e<tt||(e=r.get(t+1),n+=(e&It)<<7,e<tt)||(e=r.get(t+2),n+=(e&It)<<14,e<tt)||(e=r.get(t+3),n+=(e&It)<<21,e<tt)||(e=r.get(t+4),n+=(e&It)*hs,e<tt)||(e=r.get(t+5),n+=(e&It)*ds,e<tt)||(e=r.get(t+6),n+=(e&It)*ps,e<tt)||(e=r.get(t+7),n+=(e&It)*ms,e<tt))return n;throw new RangeError("Could not decode varint")}function Yt(r,t,e=0){return t==null&&(t=pt(lt(r))),t instanceof Uint8Array?ys(r,t,e):Ql(r,t,e)}function zt(r,t=0){return r instanceof Uint8Array?gs(r,t):th(r,t)}var xs=new Float32Array([-0]),Ee=new Uint8Array(xs.buffer);function ic(r,t,e){xs[0]=r,t[e]=Ee[0],t[e+1]=Ee[1],t[e+2]=Ee[2],t[e+3]=Ee[3]}function ac(r,t){return Ee[0]=r[t],Ee[1]=r[t+1],Ee[2]=r[t+2],Ee[3]=r[t+3],xs[0]}var ws=new Float64Array([-0]),Bt=new Uint8Array(ws.buffer);function cc(r,t,e){ws[0]=r,t[e]=Bt[0],t[e+1]=Bt[1],t[e+2]=Bt[2],t[e+3]=Bt[3],t[e+4]=Bt[4],t[e+5]=Bt[5],t[e+6]=Bt[6],t[e+7]=Bt[7]}function uc(r,t){return Bt[0]=r[t],Bt[1]=r[t+1],Bt[2]=r[t+2],Bt[3]=r[t+3],Bt[4]=r[t+4],Bt[5]=r[t+5],Bt[6]=r[t+6],Bt[7]=r[t+7],ws[0]}var eh=BigInt(Number.MAX_SAFE_INTEGER),rh=BigInt(Number.MIN_SAFE_INTEGER),Kt=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 Re;if(t<eh&&t>rh)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>fc&&(o=0n,++n>fc&&(n=0n))),new r(Number(o),Number(n))}static fromNumber(t){if(t===0)return Re;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):Re}},Re=new Kt(0,0);Re.toBigInt=function(){return 0n};Re.zzEncode=Re.zzDecode=function(){return this};Re.length=function(){return 1};var fc=4294967296n;function lc(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 hc(r,t,e){if(e-t<1)return"";let o,s=[],i=0,a;for(;t<e;)a=r[t++],a<128?s[i++]=a:a>191&&a<224?s[i++]=(a&31)<<6|r[t++]&63:a>239&&a<365?(a=((a&7)<<18|(r[t++]&63)<<12|(r[t++]&63)<<6|r[t++]&63)-65536,s[i++]=55296+(a>>10),s[i++]=56320+(a&1023)):s[i++]=(a&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 bs(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 Ft(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function In(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var Es=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,Ft(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 Ft(this,4);return In(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Ft(this,4);return In(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Ft(this,4);let t=ac(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Ft(this,4);let t=uc(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 Ft(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return hc(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw Ft(this,t);this.pos+=t}else do if(this.pos>=this.len)throw Ft(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 Kt(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 Ft(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 Ft(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 Ft(this,8);let t=In(this.buf,this.pos+=4),e=In(this.buf,this.pos+=4);return new Kt(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=gs(this.buf,this.pos);return this.pos+=lt(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 Ss(r){return new Es(r instanceof Uint8Array?r:r.subarray())}function De(r,t,e){let n=Ss(r);return t.decode(n,void 0,e)}function As(r){let t=r??8192,e=t>>>1,n,o=t;return function(i){if(i<1||i>e)return pt(i);o+i>t&&(n=pt(t),o=0);let a=n.subarray(o,o+=i);return(o&7)!==0&&(o=(o|7)+1),a}}var Ke=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function vs(){}var Bs=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},nh=As();function oh(r){return globalThis.Buffer!=null?pt(r):nh(r)}var Nr=class{len;head;tail;states;constructor(){this.len=0,this.head=new Ke(vs,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new Ke(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new _s((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(Bn,10,Kt.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=Kt.fromBigInt(t);return this._push(Bn,e.length(),e)}uint64Number(t){return this._push(ys,lt(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=Kt.fromBigInt(t).zzEncode();return this._push(Bn,e.length(),e)}sint64Number(t){let e=Kt.fromNumber(t).zzEncode();return this._push(Bn,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(Is,1,t?1:0)}fixed32(t){return this._push(Kr,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=Kt.fromBigInt(t);return this._push(Kr,4,e.lo)._push(Kr,4,e.hi)}fixed64Number(t){let e=Kt.fromNumber(t);return this._push(Kr,4,e.lo)._push(Kr,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(ic,4,t)}double(t){return this._push(cc,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(Is,1,0):this.uint32(e)._push(ih,e,t)}string(t){let e=lc(t);return e!==0?this.uint32(e)._push(bs,e,t):this._push(Is,1,0)}fork(){return this.states=new Bs(this),this.head=this.tail=new Ke(vs,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 Ke(vs,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=oh(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function Is(r,t,e){t[e]=r&255}function sh(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var _s=class extends Ke{next;constructor(t,e){super(sh,t,e),this.next=void 0}};function Bn(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 Kr(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 ih(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(Nr.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(ah,t,r),this},Nr.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(ch,t,r),this});function ah(r,t,e){t.set(r,e)}function ch(r,t,e){r.length<40?bs(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(Q(r),e)}function Ls(){return new Nr}function Ne(r,t){let e=Ls();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var rr;(function(r){r[r.VARINT=0]="VARINT",r[r.BIT64=1]="BIT64",r[r.LENGTH_DELIMITED=2]="LENGTH_DELIMITED",r[r.START_GROUP=3]="START_GROUP",r[r.END_GROUP=4]="END_GROUP",r[r.BIT32=5]="BIT32"})(rr||(rr={}));function _n(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function Ts(r){function t(o){if(r[o.toString()]==null)throw new Error("Invalid enum value");return r[o]}let e=function(s,i){let a=t(s);i.int32(a)},n=function(s){let i=s.int32();return t(i)};return _n("enum",rr.VARINT,e,n)}function Me(r,t){return _n("message",rr.LENGTH_DELIMITED,r,t)}var Mr=class extends Error{code="ERR_MAX_LENGTH";name="MaxLengthError"};var ft;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.secp256k1="secp256k1",r.ECDSA="ECDSA"})(ft||(ft={}));var Cs;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1",r[r.ECDSA=3]="ECDSA"})(Cs||(Cs={}));(function(r){r.codec=()=>Ts(Cs)})(ft||(ft={}));var Xt;(function(r){let t;r.codec=()=>(t==null&&(t=Me((e,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),ft.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),o.lengthDelimited!==!1&&n.ldelim()},(e,n,o={})=>{let s={},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let a=e.uint32();switch(a>>>3){case 1:{s.Type=ft.codec().decode(e);break}case 2:{s.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return s})),t),r.encode=e=>Ne(e,r.codec()),r.decode=(e,n)=>De(e,r.codec(),n)})(Xt||(Xt={}));var Ps;(function(r){let t;r.codec=()=>(t==null&&(t=Me((e,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),ft.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),o.lengthDelimited!==!1&&n.ldelim()},(e,n,o={})=>{let s={},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let a=e.uint32();switch(a>>>3){case 1:{s.Type=ft.codec().decode(e);break}case 2:{s.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return s})),t),r.encode=e=>Ne(e,r.codec()),r.decode=(e,n)=>De(e,r.codec(),n)})(Ps||(Ps={}));var Or=class extends Error{constructor(t="An error occurred while verifying a message"){super(t),this.name="VerificationError"}},Ln=class extends Error{constructor(t="Missing Web Crypto API"){super(t),this.name="WebCryptoMissingError"}};var mc={get(r=globalThis){let t=r.crypto;if(t?.subtle==null)throw new Ln("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 Se=mc;var Vr={};Ct(Vr,{MAX_RSA_KEY_SIZE:()=>Us,generateRSAKeyPair:()=>wc,jwkToJWKKeyPair:()=>bc,jwkToPkcs1:()=>hh,jwkToPkix:()=>Ks,jwkToRSAPrivateKey:()=>Hs,pkcs1MessageToJwk:()=>Rs,pkcs1MessageToRSAPrivateKey:()=>Ns,pkcs1ToJwk:()=>lh,pkcs1ToRSAPrivateKey:()=>xc,pkixMessageToJwk:()=>Ds,pkixMessageToRSAPublicKey:()=>Os,pkixToJwk:()=>dh,pkixToRSAPublicKey:()=>Ms});var Ae=gn;var nr=class{type="RSA";jwk;_raw;_multihash;constructor(t,e){this.jwk=t,this._multihash=e}get raw(){return this._raw==null&&(this._raw=Vr.jwkToPkix(this.jwk)),this._raw}toMultihash(){return this._multihash}toCID(){return ut.createV1(114,this._multihash)}toString(){return nt.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:ht(this.raw,t.raw)}verify(t,e){return gc(this.jwk,e,t)}},Hr=class{type="RSA";jwk;_raw;publicKey;constructor(t,e){this.jwk=t,this.publicKey=e}get raw(){return this._raw==null&&(this._raw=Vr.jwkToPkcs1(this.jwk)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:ht(this.raw,t.raw)}sign(t){return yc(this.jwk,t)}};var Us=8192,ks=18,uh=1062,fh=Uint8Array.from([48,13,6,9,42,134,72,134,247,13,1,1,1,5,0]);function lh(r){let t=te(r);return Rs(t)}function Rs(r){return{n:V(r[1],"base64url"),e:V(r[2],"base64url"),d:V(r[3],"base64url"),p:V(r[4],"base64url"),q:V(r[5],"base64url"),dp:V(r[6],"base64url"),dq:V(r[7],"base64url"),qi:V(r[8],"base64url"),kty:"RSA"}}function hh(r){if(r.n==null||r.e==null||r.d==null||r.p==null||r.q==null||r.dp==null||r.dq==null||r.qi==null)throw new at("JWK was missing components");return he([Rt(Uint8Array.from([0])),Rt(Q(r.n,"base64url")),Rt(Q(r.e,"base64url")),Rt(Q(r.d,"base64url")),Rt(Q(r.p,"base64url")),Rt(Q(r.q,"base64url")),Rt(Q(r.dp,"base64url")),Rt(Q(r.dq,"base64url")),Rt(Q(r.qi,"base64url"))]).subarray()}function dh(r){let t=te(r,{offset:0});return Ds(t)}function Ds(r){let t=te(r[1],{offset:0});return{kty:"RSA",n:V(t[0],"base64url"),e:V(t[1],"base64url")}}function Ks(r){if(r.n==null||r.e==null)throw new at("JWK was missing components");return he([fh,dn(he([Rt(Q(r.n,"base64url")),Rt(Q(r.e,"base64url"))]))]).subarray()}function xc(r){let t=te(r);return Ns(t)}function Ns(r){let t=Rs(r);return Hs(t)}function Ms(r,t){if(r.byteLength>=uh)throw new Fe("Key size is too large");let e=te(r,{offset:0});return Os(e,r,t)}function Os(r,t,e){let n=Ds(r);if(e==null){let o=Ae(Xt.encode({Type:ft.RSA,Data:t}));e=Nt(ks,o)}return new nr(n,e)}function Hs(r){if(Sc(r)>Us)throw new at("Key size is too large");let t=bc(r),e=Ae(Xt.encode({Type:ft.RSA,Data:Ks(t.publicKey)})),n=Nt(ks,e);return new Hr(t.privateKey,new nr(t.publicKey,n))}async function wc(r){if(r>Us)throw new at("Key size is too large");let t=await Ec(r),e=Ae(Xt.encode({Type:ft.RSA,Data:Ks(t.publicKey)})),n=Nt(ks,e);return new Hr(t.privateKey,new nr(t.publicKey,n))}function bc(r){if(r==null)throw new at("Missing key parameter");return{privateKey:r,publicKey:{kty:r.kty,n:r.n,e:r.e}}}async function Ec(r){let t=await Se.get().subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:r,publicExponent:new Uint8Array([1,0,1]),hash:{name:"SHA-256"}},!0,["sign","verify"]),e=await ph(t);return{privateKey:e[0],publicKey:e[1]}}async function yc(r,t){let e=await Se.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await Se.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},e,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(n,0,n.byteLength)}async function gc(r,t,e){let n=await Se.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return Se.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,t,e instanceof Uint8Array?e:e.subarray())}async function ph(r){if(r.privateKey==null||r.publicKey==null)throw new at("Private and public key are required");return Promise.all([Se.get().subtle.exportKey("jwk",r.privateKey),Se.get().subtle.exportKey("jwk",r.publicKey)])}function Sc(r){if(r.kty!=="RSA")throw new at("invalid key type");if(r.n==null)throw new at("invalid key modulus");return Q(r.n,"base64url").length*8}var Tn=class extends Ye{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,vr(t);let n=pe(e);if(this.iHash=t.create(),typeof this.iHash.update!="function")throw new Error("Expected instance of class which extends utils.Hash");this.blockLen=this.iHash.blockLen,this.outputLen=this.iHash.outputLen;let o=this.blockLen,s=new Uint8Array(o);s.set(n.length>o?t.create().update(n).digest():n);for(let i=0;i<s.length;i++)s[i]^=54;this.iHash.update(s),this.oHash=t.create();for(let i=0;i<s.length;i++)s[i]^=106;this.oHash.update(s),Ht(s)}update(t){return Xe(this),this.iHash.update(t),this}digestInto(t){Xe(this),Le(t,this.outputLen),this.finished=!0,this.iHash.digestInto(t),this.oHash.update(t),this.oHash.digestInto(t),this.destroy()}digest(){let t=new Uint8Array(this.oHash.outputLen);return this.digestInto(t),t}_cloneInto(t){t||(t=Object.create(Object.getPrototypeOf(this),{}));let{oHash:e,iHash:n,finished:o,destroyed:s,blockLen:i,outputLen:a}=this;return t=t,t.finished=o,t.destroyed=s,t.blockLen=i,t.outputLen=a,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()}},or=(r,t,e)=>new Tn(r,t).update(e).digest();or.create=(r,t)=>new Tn(r,t);function Ac(r){r.lowS!==void 0&&jt("lowS",r.lowS),r.prehash!==void 0&&jt("prehash",r.prehash)}function mh(r){let t=Pr(r);qt(t,{a:"field",b:"field"},{allowInfinityPoint:"boolean",allowedPrivateKeyLengths:"array",clearCofactor:"function",fromBytes:"function",isTorsionFree:"function",toBytes:"function",wrapPrivateKey:"boolean"});let{endo:e,Fp:n,a:o}=t;if(e){if(!n.eql(o,n.ZERO))throw new Error("invalid endo: CURVE.a must be 0");if(typeof e!="object"||typeof e.beta!="bigint"||typeof e.splitScalar!="function")throw new Error('invalid endo: expected "beta": bigint and "splitScalar": function')}return Object.freeze({...t})}var zs=class extends Error{constructor(t=""){super(t)}},se={Err:zs,_tlv:{encode:(r,t)=>{let{Err:e}=se;if(r<0||r>256)throw new e("tlv.encode: wrong tag");if(t.length&1)throw new e("tlv.encode: unpadded data");let n=t.length/2,o=Tr(n);if(o.length/2&128)throw new e("tlv.encode: long form length too big");let s=n>127?Tr(o.length/2|128):"";return Tr(r)+s+o+t},decode(r,t){let{Err:e}=se,n=0;if(r<0||r>256)throw new e("tlv.encode: wrong tag");if(t.length<2||t[n++]!==r)throw new e("tlv.decode: wrong tlv");let o=t[n++],s=!!(o&128),i=0;if(!s)i=o;else{let c=o&127;if(!c)throw new e("tlv.decode(long): indefinite length not supported");if(c>4)throw new e("tlv.decode(long): byte length is too big");let f=t.subarray(n,n+c);if(f.length!==c)throw new e("tlv.decode: length bytes not complete");if(f[0]===0)throw new e("tlv.decode(long): zero leftmost byte");for(let u of f)i=i<<8|u;if(n+=c,i<128)throw new e("tlv.decode(long): not minimal encoding")}let a=t.subarray(n,n+i);if(a.length!==i)throw new e("tlv.decode: wrong value length");return{v:a,l:t.subarray(n+i)}}},_int:{encode(r){let{Err:t}=se;if(r<ie)throw new t("integer: negative integers are not allowed");let e=Tr(r);if(Number.parseInt(e[0],16)&8&&(e="00"+e),e.length&1)throw new t("unexpected DER parsing assertion: unpadded hex");return e},decode(r){let{Err:t}=se;if(r[0]&128)throw new t("invalid signature integer: negative");if(r[0]===0&&!(r[1]&128))throw new t("invalid signature integer: unnecessary leading zero");return ne(r)}},toSig(r){let{Err:t,_int:e,_tlv:n}=se,o=ot("signature",r),{v:s,l:i}=n.decode(48,o);if(i.length)throw new t("invalid signature: left bytes after parsing");let{v:a,l:c}=n.decode(2,s),{v:f,l:u}=n.decode(2,c);if(u.length)throw new t("invalid signature: left bytes after parsing");return{r:e.decode(a),s:e.decode(f)}},hexFromSig(r){let{_tlv:t,_int:e}=se,n=t.encode(2,e.encode(r.r)),o=t.encode(2,e.encode(r.s)),s=n+o;return t.encode(48,s)}};function Vs(r,t){return xe(Pe(r,t))}var ie=BigInt(0),gt=BigInt(1),Vy=BigInt(2),qs=BigInt(3),yh=BigInt(4);function gh(r){let t=mh(r),{Fp:e}=t,n=oe(t.n,t.nBitLength),o=t.toBytes||((S,d,I)=>{let U=d.toAffine();return be(Uint8Array.from([4]),e.toBytes(U.x),e.toBytes(U.y))}),s=t.fromBytes||(S=>{let d=S.subarray(1),I=e.fromBytes(d.subarray(0,e.BYTES)),U=e.fromBytes(d.subarray(e.BYTES,2*e.BYTES));return{x:I,y:U}});function i(S){let{a:d,b:I}=t,U=e.sqr(S),B=e.mul(U,S);return e.add(e.add(B,e.mul(S,d)),I)}function a(S,d){let I=e.sqr(d),U=i(S);return e.eql(I,U)}if(!a(t.Gx,t.Gy))throw new Error("bad curve params: generator point");let c=e.mul(e.pow(t.a,qs),yh),f=e.mul(e.sqr(t.b),BigInt(27));if(e.is0(e.add(c,f)))throw new Error("bad curve params: a or b");function u(S){return xn(S,gt,t.n)}function l(S){let{allowedPrivateKeyLengths:d,nByteLength:I,wrapPrivateKey:U,n:B}=t;if(d&&typeof S!="bigint"){if(Je(S)&&(S=xe(S)),typeof S!="string"||!d.includes(S.length))throw new Error("invalid private key");S=S.padStart(I*2,"0")}let L;try{L=typeof S=="bigint"?S:ne(ot("private key",S,I))}catch{throw new Error("invalid private key, expected hex or "+I+" bytes, got "+typeof S)}return U&&(L=Y(L,B)),vt("private key",L,gt,B),L}function p(S){if(!(S instanceof m))throw new Error("ProjectivePoint expected")}let w=Qe((S,d)=>{let{px:I,py:U,pz:B}=S;if(e.eql(B,e.ONE))return{x:I,y:U};let L=S.is0();d==null&&(d=L?e.ONE:e.inv(B));let k=e.mul(I,d),K=e.mul(U,d),T=e.mul(B,d);if(L)return{x:e.ZERO,y:e.ZERO};if(!e.eql(T,e.ONE))throw new Error("invZ was invalid");return{x:k,y:K}}),y=Qe(S=>{if(S.is0()){if(t.allowInfinityPoint&&!e.is0(S.py))return;throw new Error("bad point: ZERO")}let{x:d,y:I}=S.toAffine();if(!e.isValid(d)||!e.isValid(I))throw new Error("bad point: x or y not FE");if(!a(d,I))throw new Error("bad point: equation left != right");if(!S.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});class m{constructor(d,I,U){if(d==null||!e.isValid(d))throw new Error("x required");if(I==null||!e.isValid(I)||e.is0(I))throw new Error("y required");if(U==null||!e.isValid(U))throw new Error("z required");this.px=d,this.py=I,this.pz=U,Object.freeze(this)}static fromAffine(d){let{x:I,y:U}=d||{};if(!d||!e.isValid(I)||!e.isValid(U))throw new Error("invalid affine point");if(d instanceof m)throw new Error("projective point not allowed");let B=L=>e.eql(L,e.ZERO);return B(I)&&B(U)?m.ZERO:new m(I,U,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(d){let I=tr(e,d.map(U=>U.pz));return d.map((U,B)=>U.toAffine(I[B])).map(m.fromAffine)}static fromHex(d){let I=m.fromAffine(s(ot("pointHex",d)));return I.assertValidity(),I}static fromPrivateKey(d){return m.BASE.multiply(l(d))}static msm(d,I){return En(m,n,d,I)}_setWindowSize(d){M.setWindowSize(this,d)}assertValidity(){y(this)}hasEvenY(){let{y:d}=this.toAffine();if(e.isOdd)return!e.isOdd(d);throw new Error("Field doesn't support isOdd")}equals(d){p(d);let{px:I,py:U,pz:B}=this,{px:L,py:k,pz:K}=d,T=e.eql(e.mul(I,K),e.mul(L,B)),D=e.eql(e.mul(U,K),e.mul(k,B));return T&&D}negate(){return new m(this.px,e.neg(this.py),this.pz)}double(){let{a:d,b:I}=t,U=e.mul(I,qs),{px:B,py:L,pz:k}=this,K=e.ZERO,T=e.ZERO,D=e.ZERO,C=e.mul(B,B),H=e.mul(L,L),E=e.mul(k,k),A=e.mul(B,L);return A=e.add(A,A),D=e.mul(B,k),D=e.add(D,D),K=e.mul(d,D),T=e.mul(U,E),T=e.add(K,T),K=e.sub(H,T),T=e.add(H,T),T=e.mul(K,T),K=e.mul(A,K),D=e.mul(U,D),E=e.mul(d,E),A=e.sub(C,E),A=e.mul(d,A),A=e.add(A,D),D=e.add(C,C),C=e.add(D,C),C=e.add(C,E),C=e.mul(C,A),T=e.add(T,C),E=e.mul(L,k),E=e.add(E,E),C=e.mul(E,A),K=e.sub(K,C),D=e.mul(E,H),D=e.add(D,D),D=e.add(D,D),new m(K,T,D)}add(d){p(d);let{px:I,py:U,pz:B}=this,{px:L,py:k,pz:K}=d,T=e.ZERO,D=e.ZERO,C=e.ZERO,H=t.a,E=e.mul(t.b,qs),A=e.mul(I,L),P=e.mul(U,k),b=e.mul(B,K),h=e.add(I,U),g=e.add(L,k);h=e.mul(h,g),g=e.add(A,P),h=e.sub(h,g),g=e.add(I,B);let v=e.add(L,K);return g=e.mul(g,v),v=e.add(A,b),g=e.sub(g,v),v=e.add(U,B),T=e.add(k,K),v=e.mul(v,T),T=e.add(P,b),v=e.sub(v,T),C=e.mul(H,g),T=e.mul(E,b),C=e.add(T,C),T=e.sub(P,C),C=e.add(P,C),D=e.mul(T,C),P=e.add(A,A),P=e.add(P,A),b=e.mul(H,b),g=e.mul(E,g),P=e.add(P,b),b=e.sub(A,b),b=e.mul(H,b),g=e.add(g,b),A=e.mul(P,g),D=e.add(D,A),A=e.mul(v,g),T=e.mul(h,T),T=e.sub(T,A),A=e.mul(h,P),C=e.mul(v,C),C=e.add(C,A),new m(T,D,C)}subtract(d){return this.add(d.negate())}is0(){return this.equals(m.ZERO)}wNAF(d){return M.wNAFCached(this,d,m.normalizeZ)}multiplyUnsafe(d){let{endo:I,n:U}=t;vt("scalar",d,ie,U);let B=m.ZERO;if(d===ie)return B;if(this.is0()||d===gt)return this;if(!I||M.hasPrecomputes(this))return M.wNAFCachedUnsafe(this,d,m.normalizeZ);let{k1neg:L,k1:k,k2neg:K,k2:T}=I.splitScalar(d),D=B,C=B,H=this;for(;k>ie||T>ie;)k>&&(D=D.add(H)),T>&&(C=C.add(H)),H=H.double(),k>>=gt,T>>=gt;return L&&(D=D.negate()),K&&(C=C.negate()),C=new m(e.mul(C.px,I.beta),C.py,C.pz),D.add(C)}multiply(d){let{endo:I,n:U}=t;vt("scalar",d,gt,U);let B,L;if(I){let{k1neg:k,k1:K,k2neg:T,k2:D}=I.splitScalar(d),{p:C,f:H}=this.wNAF(K),{p:E,f:A}=this.wNAF(D);C=M.constTimeNegate(k,C),E=M.constTimeNegate(T,E),E=new m(e.mul(E.px,I.beta),E.py,E.pz),B=C.add(E),L=H.add(A)}else{let{p:k,f:K}=this.wNAF(d);B=k,L=K}return m.normalizeZ([B,L])[0]}multiplyAndAddUnsafe(d,I,U){let B=m.BASE,L=(K,T)=>T===ie||T===gt||!K.equals(B)?K.multiplyUnsafe(T):K.multiply(T),k=L(this,I).add(L(d,U));return k.is0()?void 0:k}toAffine(d){return w(this,d)}isTorsionFree(){let{h:d,isTorsionFree:I}=t;if(d===gt)return!0;if(I)return I(m,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h:d,clearCofactor:I}=t;return d===gt?this:I?I(m,this):this.multiplyUnsafe(t.h)}toRawBytes(d=!0){return jt("isCompressed",d),this.assertValidity(),o(m,this,d)}toHex(d=!0){return jt("isCompressed",d),xe(this.toRawBytes(d))}}m.BASE=new m(t.Gx,t.Gy,e.ONE),m.ZERO=new m(e.ZERO,e.ONE,e.ZERO);let{endo:x,nBitLength:_}=t,M=bn(m,x?Math.ceil(_/2):_);return{CURVE:t,ProjectivePoint:m,normPrivateKeyToScalar:l,weierstrassEquation:i,isWithinCurveOrder:u}}function xh(r){let t=Pr(r);return qt(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function vc(r){let t=xh(r),{Fp:e,n,nByteLength:o,nBitLength:s}=t,i=e.BYTES+1,a=2*e.BYTES+1;function c(E){return Y(E,n)}function f(E){return wn(E,n)}let{ProjectivePoint:u,normPrivateKeyToScalar:l,weierstrassEquation:p,isWithinCurveOrder:w}=gh({...t,toBytes(E,A,P){let b=A.toAffine(),h=e.toBytes(b.x),g=be;return jt("isCompressed",P),P?g(Uint8Array.from([A.hasEvenY()?2:3]),h):g(Uint8Array.from([4]),h,e.toBytes(b.y))},fromBytes(E){let A=E.length,P=E[0],b=E.subarray(1);if(A===i&&(P===2||P===3)){let h=ne(b);if(!xn(h,gt,e.ORDER))throw new Error("Point is not on curve");let g=p(h),v;try{v=e.sqrt(g)}catch(q){let z=q instanceof Error?": "+q.message:"";throw new Error("Point is not on curve"+z)}let R=(v>)===gt;return(P&1)===1!==R&&(v=e.neg(v)),{x:h,y:v}}else if(A===a&&P===4){let h=e.fromBytes(b.subarray(0,e.BYTES)),g=e.fromBytes(b.subarray(e.BYTES,2*e.BYTES));return{x:h,y:g}}else{let h=i,g=a;throw new Error("invalid Point, expected length of "+h+", or uncompressed "+g+", got "+A)}}});function y(E){let A=n>>gt;return E>A}function m(E){return y(E)?c(-E):E}let x=(E,A,P)=>ne(E.slice(A,P));class _{constructor(A,P,b){vt("r",A,gt,n),vt("s",P,gt,n),this.r=A,this.s=P,b!=null&&(this.recovery=b),Object.freeze(this)}static fromCompact(A){let P=o;return A=ot("compactSignature",A,P*2),new _(x(A,0,P),x(A,P,2*P))}static fromDER(A){let{r:P,s:b}=se.toSig(ot("DER",A));return new _(P,b)}assertValidity(){}addRecoveryBit(A){return new _(this.r,this.s,A)}recoverPublicKey(A){let{r:P,s:b,recovery:h}=this,g=B(ot("msgHash",A));if(h==null||![0,1,2,3].includes(h))throw new Error("recovery id invalid");let v=h===2||h===3?P+t.n:P;if(v>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let R=(h&1)===0?"02":"03",O=u.fromHex(R+Vs(v,e.BYTES)),q=f(v),z=c(-g*q),F=c(b*q),G=u.BASE.multiplyAndAddUnsafe(O,z,F);if(!G)throw new Error("point at infinify");return G.assertValidity(),G}hasHighS(){return y(this.s)}normalizeS(){return this.hasHighS()?new _(this.r,c(-this.s),this.recovery):this}toDERRawBytes(){return Cr(this.toDERHex())}toDERHex(){return se.hexFromSig(this)}toCompactRawBytes(){return Cr(this.toCompactHex())}toCompactHex(){let A=o;return Vs(this.r,A)+Vs(this.s,A)}}let M={isValidPrivateKey(E){try{return l(E),!0}catch{return!1}},normPrivateKeyToScalar:l,randomPrivateKey:()=>{let E=os(t.n);return Fa(t.randomBytes(E),t.n)},precompute(E=8,A=u.BASE){return A._setWindowSize(E),A.multiply(BigInt(3)),A}};function S(E,A=!0){return u.fromPrivateKey(E).toRawBytes(A)}function d(E){if(typeof E=="bigint")return!1;if(E instanceof u)return!0;let P=ot("key",E).length,b=e.BYTES,h=b+1,g=2*b+1;if(!(t.allowedPrivateKeyLengths||o===h))return P===h||P===g}function I(E,A,P=!0){if(d(E)===!0)throw new Error("first arg must be private key");if(d(A)===!1)throw new Error("second arg must be public key");return u.fromHex(A).multiply(l(E)).toRawBytes(P)}let U=t.bits2int||function(E){if(E.length>8192)throw new Error("input is too large");let A=ne(E),P=E.length*8-s;return P>0?A>>BigInt(P):A},B=t.bits2int_modN||function(E){return c(U(E))},L=Ue(s);function k(E){return vt("num < 2^"+s,E,ie,L),Pe(E,o)}function K(E,A,P=T){if(["recovered","canonical"].some(Z=>Z in P))throw new Error("sign() legacy options not supported");let{hash:b,randomBytes:h}=t,{lowS:g,prehash:v,extraEntropy:R}=P;g==null&&(g=!0),E=ot("msgHash",E),Ac(P),v&&(E=ot("prehashed msgHash",b(E)));let O=B(E),q=l(A),z=[k(q),k(O)];if(R!=null&&R!==!1){let Z=R===!0?h(e.BYTES):R;z.push(ot("extraEntropy",Z))}let F=be(...z),G=O;function J(Z){let wt=U(Z);if(!w(wt))return;let kt=f(wt),mt=u.BASE.multiply(wt).toAffine(),St=c(mt.x);if(St===ie)return;let Dt=c(kt*c(G+St*q));if(Dt===ie)return;let Mt=(mt.x===St?0:2)|Number(mt.y>),yr=Dt;return g&&y(Dt)&&(yr=m(Dt),Mt^=1),new _(St,yr,Mt)}return{seed:F,k2sig:J}}let T={lowS:t.lowS,prehash:!1},D={lowS:t.lowS,prehash:!1};function C(E,A,P=T){let{seed:b,k2sig:h}=K(E,A,P),g=t;return Ka(g.hash.outputLen,g.nByteLength,g.hmac)(b,h)}u.BASE._setWindowSize(8);function H(E,A,P,b=D){let h=E;A=ot("msgHash",A),P=ot("publicKey",P);let{lowS:g,prehash:v,format:R}=b;if(Ac(b),"strict"in b)throw new Error("options.strict was renamed to lowS");if(R!==void 0&&R!=="compact"&&R!=="der")throw new Error("format must be compact or der");let O=typeof h=="string"||Je(h),q=!O&&!R&&typeof h=="object"&&h!==null&&typeof h.r=="bigint"&&typeof h.s=="bigint";if(!O&&!q)throw new Error("invalid signature, expected Uint8Array, hex string or Signature instance");let z,F;try{if(q&&(z=new _(h.r,h.s)),O){try{R!=="compact"&&(z=_.fromDER(h))}catch(Mt){if(!(Mt instanceof se.Err))throw Mt}!z&&R!=="der"&&(z=_.fromCompact(h))}F=u.fromHex(P)}catch{return!1}if(!z||g&&z.hasHighS())return!1;v&&(A=t.hash(A));let{r:G,s:J}=z,Z=B(A),wt=f(J),kt=c(Z*wt),mt=c(G*wt),St=u.BASE.multiplyAndAddUnsafe(F,kt,mt)?.toAffine();return St?c(St.x)===G:!1}return{CURVE:t,getPublicKey:S,getSharedSecret:I,sign:C,verify:H,ProjectivePoint:u,Signature:_,utils:M}}function wh(r){return{hash:r,hmac:(t,...e)=>or(r,t,Wo(...e)),randomBytes:Ir}}function Ic(r,t){let e=n=>vc({...r,...wh(n)});return{...e(t),create:e}}var Lc=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),Bc=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),bh=BigInt(0),Eh=BigInt(1),Fs=BigInt(2),_c=(r,t)=>(r+t/Fs)/t;function Sh(r){let t=Lc,e=BigInt(3),n=BigInt(6),o=BigInt(11),s=BigInt(22),i=BigInt(23),a=BigInt(44),c=BigInt(88),f=r*r*r%t,u=f*f*r%t,l=st(u,e,t)*u%t,p=st(l,e,t)*u%t,w=st(p,Fs,t)*f%t,y=st(w,o,t)*w%t,m=st(y,s,t)*y%t,x=st(m,a,t)*m%t,_=st(x,c,t)*x%t,M=st(_,a,t)*m%t,S=st(M,e,t)*u%t,d=st(S,i,t)*y%t,I=st(d,n,t)*f%t,U=st(I,Fs,t);if(!Gs.eql(Gs.sqr(U),r))throw new Error("Cannot find square root");return U}var Gs=oe(Lc,void 0,void 0,{sqrt:Sh}),sr=Ic({a:bh,b:BigInt(7),Fp:Gs,n:Bc,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=Bc,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-Eh*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),o=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),s=e,i=BigInt("0x100000000000000000000000000000000"),a=_c(s*r,t),c=_c(-n*r,t),f=Y(r-a*e-c*o,t),u=Y(-a*n-c*s,t),l=f>i,p=u>i;if(l&&(f=t-f),p&&(u=t-u),f>i||u>i)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:l,k1:f,k2neg:p,k2:u}}}},gn);function Tc(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function Cc(r,t,e){let n=Er.digest(e instanceof Uint8Array?e:e.subarray());if(Tc(n))return n.then(({digest:o})=>sr.verify(t,o,r)).catch(o=>{throw new Or(String(o))});try{return sr.verify(t,n.digest,r)}catch(o){throw new Or(String(o))}}var Cn=class{type="secp256k1";raw;_key;constructor(t){this._key=Uc(t),this.raw=Pc(this._key)}toMultihash(){return Ot.digest(de(this))}toCID(){return ut.createV1(114,this.toMultihash())}toString(){return nt.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:ht(this.raw,t.raw)}verify(t,e){return Cc(this._key,e,t)}};function Ws(r){return new Cn(r)}function Pc(r){return sr.ProjectivePoint.fromHex(r).toRawBytes(!0)}function Uc(r){try{return sr.ProjectivePoint.fromHex(r),r}catch(t){throw new Fe(String(t))}}function qr(r,t){let{Type:e,Data:n}=Xt.decode(r),o=n??new Uint8Array;switch(e){case ft.RSA:return Ms(o,t);case ft.Ed25519:return ls(o);case ft.secp256k1:return Ws(o);case ft.ECDSA:return Go(o);default:throw new ve}}function kc(r){let{Type:t,Data:e}=Xt.decode(r.digest),n=e??new Uint8Array;switch(t){case ft.Ed25519:return ls(n);case ft.secp256k1:return Ws(n);case ft.ECDSA:return Go(n);default:throw new ve}}function de(r){return Xt.encode({Type:ft[r.type],Data:r.raw})}var Rc=Symbol.for("nodejs.util.inspect.custom"),Ah=114,zr=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()})`}[yo]=!0;toString(){return this.string==null&&(this.string=nt.encode(this.multihash.bytes).slice(1)),this.string}toMultihash(){return this.multihash}toCID(){return ut.createV1(Ah,this.multihash)}toJSON(){return this.toString()}equals(t){if(t==null)return!1;if(t instanceof Uint8Array)return ht(this.multihash.bytes,t);if(typeof t=="string")return this.toString()===t;if(t?.toMultihash()?.bytes!=null)return ht(this.multihash.bytes,t.toMultihash().bytes);throw new Error("not valid Id")}[Rc](){return`PeerId(${this.toString()})`}},Fr=class extends zr{type="RSA";publicKey;constructor(t){super({...t,type:"RSA"}),this.publicKey=t.publicKey}},Gr=class extends zr{type="Ed25519";publicKey;constructor(t){super({...t,type:"Ed25519"}),this.publicKey=t.publicKey}},Wr=class extends zr{type="secp256k1";publicKey;constructor(t){super({...t,type:"secp256k1"}),this.publicKey=t.publicKey}},vh=2336,jr=class{type="url";multihash;publicKey;url;constructor(t){this.url=t.toString(),this.multihash=Ot.digest(Q(this.url))}[Rc](){return`PeerId(${this.url})`}[yo]=!0;toString(){return this.toCID().toString()}toMultihash(){return this.multihash}toCID(){return ut.createV1(vh,this.toMultihash())}toJSON(){return this.toString()}equals(t){return t==null?!1:(t instanceof Uint8Array&&(t=V(t)),t.toString()===this.toString())}};var Ih=114,Dc=2336;function Kc(r,t){let e;if(r.charAt(0)==="1"||r.charAt(0)==="Q")e=le(nt.decode(`z${r}`));else{if(r.startsWith("k51qzi5uqu5")||r.startsWith("kzwfwjn5ji4")||r.startsWith("k2k4r8")||r.startsWith("bafz"))return Bh(ut.parse(r));if(t==null)throw new at('Please pass a multibase decoder for strings that do not start with "1" or "Q"');e=le(t.decode(r))}return Nc(e)}function js(r){if(r.type==="Ed25519")return new Gr({multihash:r.toCID().multihash,publicKey:r});if(r.type==="secp256k1")return new Wr({multihash:r.toCID().multihash,publicKey:r});if(r.type==="RSA")return new Fr({multihash:r.toCID().multihash,publicKey:r});throw new ve}function Nc(r){if(Lh(r))return new Fr({multihash:r});if(_h(r))try{let t=kc(r);if(t.type==="Ed25519")return new Gr({multihash:r,publicKey:t});if(t.type==="secp256k1")return new Wr({multihash:r,publicKey:t})}catch{let e=V(r.digest);return new jr(new URL(e))}throw new cn("Supplied PeerID Multihash is invalid")}function Bh(r){if(r?.multihash==null||r.version==null||r.version===1&&r.code!==Ih&&r.code!==Dc)throw new an("Supplied PeerID CID is invalid");if(r.code===Dc){let t=V(r.multihash.digest);return new jr(new URL(t))}return Nc(r.multihash)}function _h(r){return r.code===Ot.code}function Lh(r){return r.code===Er.code}var Pn=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},ir=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},Un=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"},$r=class extends Error{name="UnexpectedEOFError";code="ERR_UNEXPECTED_EOF"};function kn(r){return r[Symbol.asyncIterator]!=null}function Mc(r,t){if(r.byteLength>t)throw new ir("Message length too long")}var Dn=r=>{let t=lt(r),e=pt(t);return Yt(r,e),Dn.bytes=t,e};Dn.bytes=0;function Oc(r,t){t=t??{};let e=t.lengthEncoder??Dn,n=t?.maxDataLength??4194304;function*o(s){Mc(s,n);let i=e(s.byteLength);i instanceof Uint8Array?yield i:yield*i,s instanceof Uint8Array?yield s:yield*s}return kn(r)?async function*(){for await(let s of r)yield*o(s)}():function*(){for(let s of r)yield*o(s)}()}Oc.single=(r,t)=>{t=t??{};let e=t.lengthEncoder??Dn,n=t?.maxDataLength??4194304;return Mc(r,n),new $(e(r.byteLength),r)};var Oe;(function(r){r[r.LENGTH=0]="LENGTH",r[r.DATA=1]="DATA"})(Oe||(Oe={}));var $s=r=>{let t=zt(r);return $s.bytes=lt(t),t};$s.bytes=0;function Zr(r,t){let e=new $,n=Oe.LENGTH,o=-1,s=t?.lengthDecoder??$s,i=t?.maxLengthLength??8,a=t?.maxDataLength??4194304;function*c(){for(;e.byteLength>0;){if(n===Oe.LENGTH)try{if(o=s(e),o<0)throw new Pn("Invalid message length");if(o>a)throw new ir("Message length too long");let f=s.bytes;e.consume(f),t?.onLength!=null&&t.onLength(o),n=Oe.DATA}catch(f){if(f instanceof RangeError){if(e.byteLength>i)throw new Un("Message length length too long");break}throw f}if(n===Oe.DATA){if(e.byteLength<o)break;let f=e.sublist(0,o);e.consume(o),t?.onData!=null&&t.onData(f),yield f,n=Oe.LENGTH}}}return kn(r)?async function*(){for await(let f of r)e.append(f),yield*c();if(e.byteLength>0)throw new $r("Unexpected end of input")}():function*(){for(let f of r)e.append(f),yield*c();if(e.byteLength>0)throw new $r("Unexpected end of input")}()}Zr.fromReader=(r,t)=>{let e=1,n=async function*(){for(;;)try{let{done:s,value:i}=await r.next(e);if(s===!0)return;i!=null&&(yield i)}catch(s){if(s.code==="ERR_UNDER_READ")return{done:!0,value:null};throw s}finally{e=1}}();return Zr(n,{...t??{},onLength:s=>{e=s}})};function _t(){let r={};return r.promise=new Promise((t,e)=>{r.resolve=t,r.reject=e}),r}var Kn=class extends Error{type;code;constructor(t,e,n){super(t??"The operation was aborted"),this.type="aborted",this.name=n??"AbortError",this.code=e??"ABORT_ERR"}};async function xt(r,t,e){if(t==null)return r;if(t.aborted)return r.catch(()=>{}),Promise.reject(new Kn(e?.errorMessage,e?.errorCode,e?.errorName));let n,o=new Kn(e?.errorMessage,e?.errorCode,e?.errorName);try{return await Promise.race([r,new Promise((s,i)=>{n=()=>{i(o)},t.addEventListener("abort",n)})])}finally{n!=null&&t.removeEventListener("abort",n)}}var Zs=class{readNext;haveNext;ended;nextResult;error;constructor(){this.ended=!1,this.readNext=_t(),this.haveNext=_t()}[Symbol.asyncIterator](){return this}async next(){if(this.nextResult==null&&await this.haveNext.promise,this.nextResult==null)throw new Error("HaveNext promise resolved but nextResult was undefined");let t=this.nextResult;return this.nextResult=void 0,this.readNext.resolve(),this.readNext=_t(),t}async throw(t){return this.ended=!0,this.error=t,t!=null&&(this.haveNext.promise.catch(()=>{}),this.haveNext.reject(t)),{done:!0,value:void 0}}async return(){let t={done:!0,value:void 0};return this.ended=!0,this.nextResult=t,this.haveNext.resolve(),t}async push(t,e){await this._push(t,e)}async end(t,e){t!=null?await this.throw(t):await this._push(void 0,e)}async _push(t,e){if(t!=null&&this.ended)throw this.error??new Error("Cannot push value onto an ended pushable");for(;this.nextResult!=null;)await this.readNext.promise;t!=null?this.nextResult={done:!1,value:t}:(this.ended=!0,this.nextResult={done:!0,value:void 0}),this.haveNext.resolve(),this.haveNext=_t(),await xt(this.readNext.promise,e?.signal,e)}};function Nn(){return new Zs}var Mn=class extends Error{name="UnexpectedEOFError";code="ERR_UNEXPECTED_EOF"};function Hc(r,t){let e=Nn();r.sink(e).catch(async i=>{await e.end(i)}),r.sink=async i=>{for await(let a of i)await e.push(a);await e.end()};let n=r.source;r.source[Symbol.iterator]!=null?n=r.source[Symbol.iterator]():r.source[Symbol.asyncIterator]!=null&&(n=r.source[Symbol.asyncIterator]());let o=new $;return{read:async i=>{if(i?.signal?.throwIfAborted(),i?.bytes==null){let{done:c,value:f}=await xt(n.next(),i?.signal);return c===!0?null:f}for(;o.byteLength<i.bytes;){let{value:c,done:f}=await xt(n.next(),i?.signal);if(f===!0)throw new Mn("unexpected end of input");o.append(c)}let a=o.sublist(0,i.bytes);return o.consume(i.bytes),a},write:async(i,a)=>{a?.signal?.throwIfAborted(),i instanceof Uint8Array?await e.push(i,a):await e.push(i.subarray(),a)},unwrap:()=>{if(o.byteLength>0){let i=r.source;r.source=async function*(){t?.yieldBytes===!1?yield o:yield*o,yield*i}()}return r}}}var On=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},Hn=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},Vn=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"};function Ys(r,t={}){let e=Hc(r,t);t.maxDataLength!=null&&t.maxLengthLength==null&&(t.maxLengthLength=lt(t.maxDataLength));let n=t?.lengthDecoder??zt,o=t?.lengthEncoder??Yt;return{read:async i=>{let a=-1,c=new $;for(;;){c.append(await e.read({...i,bytes:1}));try{a=n(c)}catch(f){if(f instanceof RangeError)continue;throw f}if(a<0)throw new On("Invalid message length");if(t?.maxLengthLength!=null&&c.byteLength>t.maxLengthLength)throw new Vn("message length length too long");if(a>-1)break}if(t?.maxDataLength!=null&&a>t.maxDataLength)throw new Hn("message length too long");return e.read({...i,bytes:a})},write:async(i,a)=>{await e.write(new $(o(i.byteLength),i),a)},writeV:async(i,a)=>{let c=new $(...i.flatMap(f=>[o(f.byteLength),f]));await e.write(c,a)},unwrap:()=>e.unwrap()}}function Xs(){let r=_t(),t=!1;return{sink:async e=>{if(t)throw new Error("already piped");t=!0,r.resolve(e)},source:async function*(){yield*await r.promise}()}}function Vc(){let r=Xs(),t=Xs();return[{source:r.source,sink:t.sink},{source:t.source,sink:r.sink}]}var qn=class{buffer;mask;top;btm;next;constructor(t){if(!(t>0)||(t-1&t)!==0)throw new Error("Max size for a FixedFIFO should be a power of two");this.buffer=new Array(t),this.mask=t-1,this.top=0,this.btm=0,this.next=null}push(t){return this.buffer[this.top]!==void 0?!1:(this.buffer[this.top]=t,this.top=this.top+1&this.mask,!0)}shift(){let t=this.buffer[this.btm];if(t!==void 0)return this.buffer[this.btm]=void 0,this.btm=this.btm+1&this.mask,t}isEmpty(){return this.buffer[this.btm]===void 0}},ar=class{size;hwm;head;tail;constructor(t={}){this.hwm=t.splitLimit??16,this.head=new qn(this.hwm),this.tail=this.head,this.size=0}calculateSize(t){return t?.byteLength!=null?t.byteLength:1}push(t){if(t?.value!=null&&(this.size+=this.calculateSize(t.value)),!this.head.push(t)){let e=this.head;this.head=e.next=new qn(2*this.head.buffer.length),this.head.push(t)}}shift(){let t=this.tail.shift();if(t===void 0&&this.tail.next!=null){let e=this.tail.next;this.tail.next=null,this.tail=e,t=this.tail.shift()}return t?.value!=null&&(this.size-=this.calculateSize(t.value)),t}isEmpty(){return this.head.isEmpty()}};var Js=class extends Error{type;code;constructor(t,e){super(t??"The operation was aborted"),this.type="aborted",this.code=e??"ABORT_ERR"}};function zn(r={}){return Ch(e=>{let n=e.shift();if(n==null)return{done:!0};if(n.error!=null)throw n.error;return{done:n.done===!0,value:n.value}},r)}function Ch(r,t){t=t??{};let e=t.onEnd,n=new ar,o,s,i,a=_t(),c=async()=>{try{return n.isEmpty()?i?{done:!0}:await new Promise((x,_)=>{s=M=>{s=null,n.push(M);try{x(r(n))}catch(S){_(S)}return o}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{a.resolve(),a=_t()})}},f=x=>s!=null?s(x):(n.push(x),o),u=x=>(n=new ar,s!=null?s({error:x}):(n.push({error:x}),o)),l=x=>{if(i)return o;if(t?.objectMode!==!0&&x?.byteLength==null)throw new Error("objectMode was not true but tried to push non-Uint8Array value");return f({done:!1,value:x})},p=x=>i?o:(i=!0,x!=null?u(x):f({done:!0})),w=()=>(n=new ar,p(),{done:!0}),y=x=>(p(x),{done:!0});if(o={[Symbol.asyncIterator](){return this},next:c,return:w,throw:y,push:l,end:p,get readableLength(){return n.size},onEmpty:async x=>{let _=x?.signal;if(_?.throwIfAborted(),n.isEmpty())return;let M,S;_!=null&&(M=new Promise((d,I)=>{S=()=>{I(new Js)},_.addEventListener("abort",S)}));try{await Promise.race([a.promise,M])}finally{S!=null&&_!=null&&_?.removeEventListener("abort",S)}}},e==null)return o;let m=o;return o={[Symbol.asyncIterator](){return this},next(){return m.next()},throw(x){return m.throw(x),e!=null&&(e(x),e=void 0),{done:!0}},return(){return m.return(),e!=null&&(e(),e=void 0),{done:!0}},push:l,end(x){return m.end(x),e!=null&&(e(x),e=void 0),o},get readableLength(){return m.readableLength},onEmpty:x=>m.onEmpty(x)},o}function Ph(r){return r[Symbol.asyncIterator]!=null}async function Uh(r,t,e){try{await Promise.all(r.map(async n=>{for await(let o of n)await t.push(o,{signal:e}),e.throwIfAborted()})),await t.end(void 0,{signal:e})}catch(n){await t.end(n,{signal:e}).catch(()=>{})}}async function*kh(r){let t=new AbortController,e=Nn();Uh(r,e,t.signal).catch(()=>{});try{yield*e}finally{t.abort()}}function*Rh(r){for(let t of r)yield*t}function Dh(...r){let t=[];for(let e of r)Ph(e)||t.push(e);return t.length===r.length?Rh(t):kh(r)}var qc=Dh;function zc(r,...t){if(r==null)throw new Error("Empty pipeline");if(Qs(r)){let n=r;r=()=>n.source}else if(Gc(r)||Fc(r)){let n=r;r=()=>n}let e=[r,...t];if(e.length>1&&Qs(e[e.length-1])&&(e[e.length-1]=e[e.length-1].sink),e.length>2)for(let n=1;n<e.length-1;n++)Qs(e[n])&&(e[n]=Nh(e[n]));return Kh(...e)}var Kh=(...r)=>{let t;for(;r.length>0;)t=r.shift()(t);return t},Fc=r=>r?.[Symbol.asyncIterator]!=null,Gc=r=>r?.[Symbol.iterator]!=null,Qs=r=>r==null?!1:r.sink!=null&&r.source!=null,Nh=r=>t=>{let e=r.sink(t);if(e?.then!=null){let n=zn({objectMode:!0});e.then(()=>{n.end()},i=>{n.end(i)});let o,s=r.source;if(Fc(s))o=async function*(){yield*s,n.end()};else if(Gc(s))o=function*(){yield*s,n.end()};else throw new Error("Unknown duplex source type - must be Iterable or AsyncIterable");return qc(n,o())}return r.source};var cr=!!globalThis.process?.env?.DUMP_SESSION_KEYS;function jc(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function Fn(r){if(typeof r!="boolean")throw new Error(`boolean expected, not ${r}`)}function Gn(r){if(!Number.isSafeInteger(r)||r<0)throw new Error("positive integer expected, got "+r)}function Lt(r,...t){if(!jc(r))throw new Error("Uint8Array expected");if(t.length>0&&!t.includes(r.length))throw new Error("Uint8Array expected of length "+t+", got length="+r.length)}function ti(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 $c(r,t){Lt(r);let e=t.outputLen;if(r.length<e)throw new Error("digestInto() expects output buffer of length at least "+e)}function ae(r){return new Uint32Array(r.buffer,r.byteOffset,Math.floor(r.byteLength/4))}function ce(...r){for(let t=0;t<r.length;t++)r[t].fill(0)}function Mh(r){return new DataView(r.buffer,r.byteOffset,r.byteLength)}var Oh=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;function Hh(r){if(typeof r!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(r))}function Wn(r){if(typeof r=="string")r=Hh(r);else if(jc(r))r=jn(r);else throw new Error("Uint8Array expected, got "+typeof r);return r}function Zc(r,t){if(t==null||typeof t!="object")throw new Error("options must be defined");return Object.assign(r,t)}function Yc(r,t){if(r.length!==t.length)return!1;let e=0;for(let n=0;n<r.length;n++)e|=r[n]^t[n];return e===0}var ei=(r,t)=>{function e(n,...o){if(Lt(n),!Oh)throw new Error("Non little-endian hardware is not yet supported");if(r.nonceLength!==void 0){let u=o[0];if(!u)throw new Error("nonce / iv required");r.varSizeNonce?Lt(u):Lt(u,r.nonceLength)}let s=r.tagLength;s&&o[1]!==void 0&&Lt(o[1]);let i=t(n,...o),a=(u,l)=>{if(l!==void 0){if(u!==2)throw new Error("cipher output not supported");Lt(l)}},c=!1;return{encrypt(u,l){if(c)throw new Error("cannot encrypt() twice with same key + nonce");return c=!0,Lt(u),a(i.encrypt.length,l),i.encrypt(u,l)},decrypt(u,l){if(Lt(u),s&&u.length<s)throw new Error("invalid ciphertext length: smaller than tagLength="+s);return a(i.decrypt.length,l),i.decrypt(u,l)}}}return Object.assign(e,r),e};function ri(r,t,e=!0){if(t===void 0)return new Uint8Array(r);if(t.length!==r)throw new Error("invalid output length, expected "+r+", got: "+t.length);if(e&&!Vh(t))throw new Error("invalid output, must be aligned");return t}function Wc(r,t,e,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(t,e,n);let o=BigInt(32),s=BigInt(4294967295),i=Number(e>>o&s),a=Number(e&s),c=n?4:0,f=n?0:4;r.setUint32(t+c,i,n),r.setUint32(t+f,a,n)}function Xc(r,t,e){Fn(e);let n=new Uint8Array(16),o=Mh(n);return Wc(o,0,BigInt(t),e),Wc(o,8,BigInt(r),e),n}function Vh(r){return r.byteOffset%4===0}function jn(r){return Uint8Array.from(r)}var Qc=r=>Uint8Array.from(r.split("").map(t=>t.charCodeAt(0))),qh=Qc("expand 16-byte k"),zh=Qc("expand 32-byte k"),Fh=ae(qh),Gh=ae(zh);function N(r,t){return r<<t|r>>>32-t}function ni(r){return r.byteOffset%4===0}var $n=64,Wh=16,tu=2**32-1,Jc=new Uint32Array;function jh(r,t,e,n,o,s,i,a){let c=o.length,f=new Uint8Array($n),u=ae(f),l=ni(o)&&ni(s),p=l?ae(o):Jc,w=l?ae(s):Jc;for(let y=0;y<c;i++){if(r(t,e,n,u,i,a),i>=tu)throw new Error("arx: counter overflow");let m=Math.min($n,c-y);if(l&&m===$n){let x=y/4;if(y%4!==0)throw new Error("arx: invalid block position");for(let _=0,M;_<Wh;_++)M=x+_,w[M]=p[M]^u[_];y+=$n;continue}for(let x=0,_;x<m;x++)_=y+x,s[_]=o[_]^f[x];y+=m}}function oi(r,t){let{allowShortKeys:e,extendNonceFn:n,counterLength:o,counterRight:s,rounds:i}=Zc({allowShortKeys:!1,counterLength:8,counterRight:!1,rounds:20},t);if(typeof r!="function")throw new Error("core must be a function");return Gn(o),Gn(i),Fn(s),Fn(e),(a,c,f,u,l=0)=>{Lt(a),Lt(c),Lt(f);let p=f.length;if(u===void 0&&(u=new Uint8Array(p)),Lt(u),Gn(l),l<0||l>=tu)throw new Error("arx: counter overflow");if(u.length<p)throw new Error(`arx: output (${u.length}) is shorter than data (${p})`);let w=[],y=a.length,m,x;if(y===32)w.push(m=jn(a)),x=Gh;else if(y===16&&e)m=new Uint8Array(32),m.set(a),m.set(a,16),x=Fh,w.push(m);else throw new Error(`arx: invalid 32-byte key, got length=${y}`);ni(c)||w.push(c=jn(c));let _=ae(m);if(n){if(c.length!==24)throw new Error("arx: extended nonce must be 24 bytes");n(x,_,ae(c.subarray(0,16)),_),c=c.subarray(16)}let M=16-o;if(M!==c.length)throw new Error(`arx: nonce must be ${M} or 16 bytes`);if(M!==12){let d=new Uint8Array(12);d.set(c,s?0:12-c.length),c=d,w.push(c)}let S=ae(c);return jh(r,x,_,S,f,u,l,i),ce(...w),u}}var Et=(r,t)=>r[t++]&255|(r[t++]&255)<<8,si=class{constructor(t){this.blockLen=16,this.outputLen=16,this.buffer=new Uint8Array(16),this.r=new Uint16Array(10),this.h=new Uint16Array(10),this.pad=new Uint16Array(8),this.pos=0,this.finished=!1,t=Wn(t),Lt(t,32);let e=Et(t,0),n=Et(t,2),o=Et(t,4),s=Et(t,6),i=Et(t,8),a=Et(t,10),c=Et(t,12),f=Et(t,14);this.r[0]=e&8191,this.r[1]=(e>>>13|n<<3)&8191,this.r[2]=(n>>>10|o<<6)&7939,this.r[3]=(o>>>7|s<<9)&8191,this.r[4]=(s>>>4|i<<12)&255,this.r[5]=i>>>1&8190,this.r[6]=(i>>>14|a<<2)&8191,this.r[7]=(a>>>11|c<<5)&8065,this.r[8]=(c>>>8|f<<8)&8191,this.r[9]=f>>>5&127;for(let u=0;u<8;u++)this.pad[u]=Et(t,16+2*u)}process(t,e,n=!1){let o=n?0:2048,{h:s,r:i}=this,a=i[0],c=i[1],f=i[2],u=i[3],l=i[4],p=i[5],w=i[6],y=i[7],m=i[8],x=i[9],_=Et(t,e+0),M=Et(t,e+2),S=Et(t,e+4),d=Et(t,e+6),I=Et(t,e+8),U=Et(t,e+10),B=Et(t,e+12),L=Et(t,e+14),k=s[0]+(_&8191),K=s[1]+((_>>>13|M<<3)&8191),T=s[2]+((M>>>10|S<<6)&8191),D=s[3]+((S>>>7|d<<9)&8191),C=s[4]+((d>>>4|I<<12)&8191),H=s[5]+(I>>>1&8191),E=s[6]+((I>>>14|U<<2)&8191),A=s[7]+((U>>>11|B<<5)&8191),P=s[8]+((B>>>8|L<<8)&8191),b=s[9]+(L>>>5|o),h=0,g=h+k*a+K*(5*x)+T*(5*m)+D*(5*y)+C*(5*w);h=g>>>13,g&=8191,g+=H*(5*p)+E*(5*l)+A*(5*u)+P*(5*f)+b*(5*c),h+=g>>>13,g&=8191;let v=h+k*c+K*a+T*(5*x)+D*(5*m)+C*(5*y);h=v>>>13,v&=8191,v+=H*(5*w)+E*(5*p)+A*(5*l)+P*(5*u)+b*(5*f),h+=v>>>13,v&=8191;let R=h+k*f+K*c+T*a+D*(5*x)+C*(5*m);h=R>>>13,R&=8191,R+=H*(5*y)+E*(5*w)+A*(5*p)+P*(5*l)+b*(5*u),h+=R>>>13,R&=8191;let O=h+k*u+K*f+T*c+D*a+C*(5*x);h=O>>>13,O&=8191,O+=H*(5*m)+E*(5*y)+A*(5*w)+P*(5*p)+b*(5*l),h+=O>>>13,O&=8191;let q=h+k*l+K*u+T*f+D*c+C*a;h=q>>>13,q&=8191,q+=H*(5*x)+E*(5*m)+A*(5*y)+P*(5*w)+b*(5*p),h+=q>>>13,q&=8191;let z=h+k*p+K*l+T*u+D*f+C*c;h=z>>>13,z&=8191,z+=H*a+E*(5*x)+A*(5*m)+P*(5*y)+b*(5*w),h+=z>>>13,z&=8191;let F=h+k*w+K*p+T*l+D*u+C*f;h=F>>>13,F&=8191,F+=H*c+E*a+A*(5*x)+P*(5*m)+b*(5*y),h+=F>>>13,F&=8191;let G=h+k*y+K*w+T*p+D*l+C*u;h=G>>>13,G&=8191,G+=H*f+E*c+A*a+P*(5*x)+b*(5*m),h+=G>>>13,G&=8191;let J=h+k*m+K*y+T*w+D*p+C*l;h=J>>>13,J&=8191,J+=H*u+E*f+A*c+P*a+b*(5*x),h+=J>>>13,J&=8191;let Z=h+k*x+K*m+T*y+D*w+C*p;h=Z>>>13,Z&=8191,Z+=H*l+E*u+A*f+P*c+b*a,h+=Z>>>13,Z&=8191,h=(h<<2)+h|0,h=h+g|0,g=h&8191,h=h>>>13,v+=h,s[0]=g,s[1]=v,s[2]=R,s[3]=O,s[4]=q,s[5]=z,s[6]=F,s[7]=G,s[8]=J,s[9]=Z}finalize(){let{h:t,pad:e}=this,n=new Uint16Array(10),o=t[1]>>>13;t[1]&=8191;for(let a=2;a<10;a++)t[a]+=o,o=t[a]>>>13,t[a]&=8191;t[0]+=o*5,o=t[0]>>>13,t[0]&=8191,t[1]+=o,o=t[1]>>>13,t[1]&=8191,t[2]+=o,n[0]=t[0]+5,o=n[0]>>>13,n[0]&=8191;for(let a=1;a<10;a++)n[a]=t[a]+o,o=n[a]>>>13,n[a]&=8191;n[9]-=8192;let s=(o^1)-1;for(let a=0;a<10;a++)n[a]&=s;s=~s;for(let a=0;a<10;a++)t[a]=t[a]&s|n[a];t[0]=(t[0]|t[1]<<13)&65535,t[1]=(t[1]>>>3|t[2]<<10)&65535,t[2]=(t[2]>>>6|t[3]<<7)&65535,t[3]=(t[3]>>>9|t[4]<<4)&65535,t[4]=(t[4]>>>12|t[5]<<1|t[6]<<14)&65535,t[5]=(t[6]>>>2|t[7]<<11)&65535,t[6]=(t[7]>>>5|t[8]<<8)&65535,t[7]=(t[8]>>>8|t[9]<<5)&65535;let i=t[0]+e[0];t[0]=i&65535;for(let a=1;a<8;a++)i=(t[a]+e[a]|0)+(i>>>16)|0,t[a]=i&65535;ce(n)}update(t){ti(this),t=Wn(t),Lt(t);let{buffer:e,blockLen:n}=this,o=t.length;for(let s=0;s<o;){let i=Math.min(n-this.pos,o-s);if(i===n){for(;n<=o-s;s+=n)this.process(t,s);continue}e.set(t.subarray(s,s+i),this.pos),this.pos+=i,s+=i,this.pos===n&&(this.process(e,0,!1),this.pos=0)}return this}destroy(){ce(this.h,this.r,this.buffer,this.pad)}digestInto(t){ti(this),$c(t,this),this.finished=!0;let{buffer:e,h:n}=this,{pos:o}=this;if(o){for(e[o++]=1;o<16;o++)e[o]=0;this.process(e,0,!0)}this.finalize();let s=0;for(let i=0;i<8;i++)t[s++]=n[i]>>>0,t[s++]=n[i]>>>8;return t}digest(){let{buffer:t,outputLen:e}=this;this.digestInto(t);let n=t.slice(0,e);return this.destroy(),n}};function $h(r){let t=(n,o)=>r(o).update(Wn(n)).digest(),e=r(new Uint8Array(32));return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=n=>r(n),t}var eu=$h(r=>new si(r));function ou(r,t,e,n,o,s=20){let i=r[0],a=r[1],c=r[2],f=r[3],u=t[0],l=t[1],p=t[2],w=t[3],y=t[4],m=t[5],x=t[6],_=t[7],M=o,S=e[0],d=e[1],I=e[2],U=i,B=a,L=c,k=f,K=u,T=l,D=p,C=w,H=y,E=m,A=x,P=_,b=M,h=S,g=d,v=I;for(let O=0;O<s;O+=2)U=U+K|0,b=N(b^U,16),H=H+b|0,K=N(K^H,12),U=U+K|0,b=N(b^U,8),H=H+b|0,K=N(K^H,7),B=B+T|0,h=N(h^B,16),E=E+h|0,T=N(T^E,12),B=B+T|0,h=N(h^B,8),E=E+h|0,T=N(T^E,7),L=L+D|0,g=N(g^L,16),A=A+g|0,D=N(D^A,12),L=L+D|0,g=N(g^L,8),A=A+g|0,D=N(D^A,7),k=k+C|0,v=N(v^k,16),P=P+v|0,C=N(C^P,12),k=k+C|0,v=N(v^k,8),P=P+v|0,C=N(C^P,7),U=U+T|0,v=N(v^U,16),A=A+v|0,T=N(T^A,12),U=U+T|0,v=N(v^U,8),A=A+v|0,T=N(T^A,7),B=B+D|0,b=N(b^B,16),P=P+b|0,D=N(D^P,12),B=B+D|0,b=N(b^B,8),P=P+b|0,D=N(D^P,7),L=L+C|0,h=N(h^L,16),H=H+h|0,C=N(C^H,12),L=L+C|0,h=N(h^L,8),H=H+h|0,C=N(C^H,7),k=k+K|0,g=N(g^k,16),E=E+g|0,K=N(K^E,12),k=k+K|0,g=N(g^k,8),E=E+g|0,K=N(K^E,7);let R=0;n[R++]=i+U|0,n[R++]=a+B|0,n[R++]=c+L|0,n[R++]=f+k|0,n[R++]=u+K|0,n[R++]=l+T|0,n[R++]=p+D|0,n[R++]=w+C|0,n[R++]=y+H|0,n[R++]=m+E|0,n[R++]=x+A|0,n[R++]=_+P|0,n[R++]=M+b|0,n[R++]=S+h|0,n[R++]=d+g|0,n[R++]=I+v|0}function Zh(r,t,e,n){let o=r[0],s=r[1],i=r[2],a=r[3],c=t[0],f=t[1],u=t[2],l=t[3],p=t[4],w=t[5],y=t[6],m=t[7],x=e[0],_=e[1],M=e[2],S=e[3];for(let I=0;I<20;I+=2)o=o+c|0,x=N(x^o,16),p=p+x|0,c=N(c^p,12),o=o+c|0,x=N(x^o,8),p=p+x|0,c=N(c^p,7),s=s+f|0,_=N(_^s,16),w=w+_|0,f=N(f^w,12),s=s+f|0,_=N(_^s,8),w=w+_|0,f=N(f^w,7),i=i+u|0,M=N(M^i,16),y=y+M|0,u=N(u^y,12),i=i+u|0,M=N(M^i,8),y=y+M|0,u=N(u^y,7),a=a+l|0,S=N(S^a,16),m=m+S|0,l=N(l^m,12),a=a+l|0,S=N(S^a,8),m=m+S|0,l=N(l^m,7),o=o+f|0,S=N(S^o,16),y=y+S|0,f=N(f^y,12),o=o+f|0,S=N(S^o,8),y=y+S|0,f=N(f^y,7),s=s+u|0,x=N(x^s,16),m=m+x|0,u=N(u^m,12),s=s+u|0,x=N(x^s,8),m=m+x|0,u=N(u^m,7),i=i+l|0,_=N(_^i,16),p=p+_|0,l=N(l^p,12),i=i+l|0,_=N(_^i,8),p=p+_|0,l=N(l^p,7),a=a+c|0,M=N(M^a,16),w=w+M|0,c=N(c^w,12),a=a+c|0,M=N(M^a,8),w=w+M|0,c=N(c^w,7);let d=0;n[d++]=o,n[d++]=s,n[d++]=i,n[d++]=a,n[d++]=x,n[d++]=_,n[d++]=M,n[d++]=S}var Yh=oi(ou,{counterRight:!1,counterLength:4,allowShortKeys:!1}),Xh=oi(ou,{counterRight:!1,counterLength:8,extendNonceFn:Zh,allowShortKeys:!1});var Jh=new Uint8Array(16),ru=(r,t)=>{r.update(t);let e=t.length%16;e&&r.update(Jh.subarray(e))},Qh=new Uint8Array(32);function nu(r,t,e,n,o){let s=r(t,e,Qh),i=eu.create(s);o&&ru(i,o),ru(i,n);let a=Xc(n.length,o?o.length:0,!0);i.update(a);let c=i.digest();return ce(s,a),c}var su=r=>(t,e,n)=>({encrypt(s,i){let a=s.length;i=ri(a+16,i,!1),i.set(s);let c=i.subarray(0,-16);r(t,e,c,c,1);let f=nu(r,t,e,c,n);return i.set(f,a),ce(f),i},decrypt(s,i){i=ri(s.length-16,i,!1);let a=s.subarray(0,-16),c=s.subarray(-16),f=nu(r,t,e,a,n);if(!Yc(c,f))throw new Error("invalid tag");return i.set(s.subarray(0,-16)),r(t,e,i,i,1),ce(f),i}}),ii=ei({blockSize:64,nonceLength:12,tagLength:16},su(Yh)),rw=ei({blockSize:64,nonceLength:24,tagLength:16},su(Xh));function au(r,t,e){return vr(r),e===void 0&&(e=new Uint8Array(r.outputLen)),or(r,pe(e),pe(t))}var ai=Uint8Array.from([0]),iu=Uint8Array.of();function cu(r,t,e,n=32){vr(r),Ze(n);let o=r.outputLen;if(n>255*o)throw new Error("Length should be <= 255*HashLen");let s=Math.ceil(n/o);e===void 0&&(e=iu);let i=new Uint8Array(s*o),a=or.create(r,t),c=a._cloneInto(),f=new Uint8Array(a.outputLen);for(let u=0;u<s;u++)ai[0]=u+1,c.update(u===0?iu:f).update(e).update(ai).digestInto(f),i.set(f,o*u),a._cloneInto(c);return a.destroy(),c.destroy(),Ht(f,ai),i.slice(0,n)}var ci={hashSHA256(r){return Ae(r.subarray())},getHKDF(r,t){let e=au(Ae,t,r),o=cu(Ae,e,void 0,96),s=o.subarray(0,32),i=o.subarray(32,64),a=o.subarray(64,96);return[s,i,a]},generateX25519KeyPair(){let r=Rr.utils.randomPrivateKey();return{publicKey:Rr.getPublicKey(r),privateKey:r}},generateX25519KeyPairFromSeed(r){return{publicKey:Rr.getPublicKey(r),privateKey:r}},generateX25519SharedKey(r,t){return Rr.getSharedSecret(r.subarray(),t.subarray())},chaCha20Poly1305Encrypt(r,t,e,n){return ii(n,t,e).encrypt(r.subarray())},chaCha20Poly1305Decrypt(r,t,e,n,o){return ii(n,t,e).decrypt(r.subarray(),o)}};var uu=ci;function fu(r){return{generateKeypair:r.generateX25519KeyPair,dh:(t,e)=>r.generateX25519SharedKey(t.privateKey,e).subarray(0,32),encrypt:r.chaCha20Poly1305Encrypt,decrypt:r.chaCha20Poly1305Decrypt,hash:r.hashSHA256,hkdf:r.getHKDF}}var ur=r=>{let t=pt(2);return t[0]=r>>8,t[1]=r,t};ur.bytes=2;var Yr=r=>{if(r.length<2)throw RangeError("Could not decode int16BE");if(r instanceof Uint8Array){let t=0;return t+=r[0]<<8,t+=r[1],t}return r.getUint16(0)};Yr.bytes=2;function lu(r){return{xxHandshakeSuccesses:r.registerCounter("libp2p_noise_xxhandshake_successes_total",{help:"Total count of noise xxHandshakes successes_"}),xxHandshakeErrors:r.registerCounter("libp2p_noise_xxhandshake_error_total",{help:"Total count of noise xxHandshakes errors"}),encryptedPackets:r.registerCounter("libp2p_noise_encrypted_packets_total",{help:"Total count of noise encrypted packets successfully"}),decryptedPackets:r.registerCounter("libp2p_noise_decrypted_packets_total",{help:"Total count of noise decrypted packets"}),decryptErrors:r.registerCounter("libp2p_noise_decrypt_errors_total",{help:"Total count of noise decrypt errors"})}}function ui(r,t){!t.enabled||!cr||(r?(t(`LOCAL_STATIC_PUBLIC_KEY ${V(r.publicKey,"hex")}`),t(`LOCAL_STATIC_PRIVATE_KEY ${V(r.privateKey,"hex")}`)):t("Missing local static keys."))}function fi(r,t){!t.enabled||!cr||(r?(t(`LOCAL_PUBLIC_EPHEMERAL_KEY ${V(r.publicKey,"hex")}`),t(`LOCAL_PRIVATE_EPHEMERAL_KEY ${V(r.privateKey,"hex")}`)):t("Missing local ephemeral keys."))}function hu(r,t){!t.enabled||!cr||t(r?`REMOTE_STATIC_PUBLIC_KEY ${V(r.subarray(),"hex")}`:"Missing remote static public key.")}function li(r,t){!t.enabled||!cr||t(r?`REMOTE_EPHEMERAL_PUBLIC_KEY ${V(r.subarray(),"hex")}`:"Missing remote ephemeral keys.")}function hi(r,t,e){!e.enabled||!cr||(e(`CIPHER_STATE_1 ${r.n.getUint64()} ${r.k&&V(r.k,"hex")}`),e(`CIPHER_STATE_2 ${t.n.getUint64()} ${t.k&&V(t.k,"hex")}`))}var fr=class r extends Error{code;constructor(t="Invalid crypto exchange"){super(t),this.code=r.code}static code="ERR_INVALID_CRYPTO_EXCHANGE"};var td=0,ed=4294967295,rd="Cipherstate has reached maximum n, a new handshake must be performed",Zn=class{n;bytes;view;constructor(t=td){this.n=t,this.bytes=dt(12),this.view=new DataView(this.bytes.buffer,this.bytes.byteOffset,this.bytes.byteLength),this.view.setUint32(4,t,!0)}increment(){this.n++,this.view.setUint32(4,this.n,!0)}getBytes(){return this.bytes}getUint64(){return this.n}assertValue(){if(this.n>ed)throw new Error(rd)}};var He=dt(0),lr=class{k;n;crypto;constructor(t,e=void 0,n=0){this.crypto=t,this.k=e,this.n=new Zn(n)}hasKey(){return!!this.k}encryptWithAd(t,e){if(!this.hasKey())return e;this.n.assertValue();let n=this.crypto.encrypt(e,this.n.getBytes(),t,this.k);return this.n.increment(),n}decryptWithAd(t,e,n){if(!this.hasKey())return e;this.n.assertValue();let o=this.crypto.decrypt(e,this.n.getBytes(),t,this.k,n);return this.n.increment(),o}},di=class{cs;ck;h;crypto;constructor(t,e){this.crypto=t;let n=Q(e,"utf-8");this.h=nd(t,n),this.ck=this.h,this.cs=new lr(t)}mixKey(t){let[e,n]=this.crypto.hkdf(this.ck,t);this.ck=e,this.cs=new lr(this.crypto,n)}mixHash(t){this.h=this.crypto.hash(new $(this.h,t))}encryptAndHash(t){let e=this.cs.encryptWithAd(this.h,t);return this.mixHash(e),e}decryptAndHash(t){let e=this.cs.decryptWithAd(this.h,t);return this.mixHash(t),e}split(){let[t,e]=this.crypto.hkdf(this.ck,He);return[new lr(this.crypto,t),new lr(this.crypto,e)]}},pi=class{ss;s;e;rs;re;initiator;crypto;constructor(t){let{crypto:e,protocolName:n,prologue:o,initiator:s,s:i,e:a,rs:c,re:f}=t;this.crypto=e,this.ss=new di(e,n),this.ss.mixHash(o),this.initiator=s,this.s=i,this.e=a,this.rs=c,this.re=f}writeE(){if(this.e)throw new Error("ephemeral keypair is already set");let t=this.crypto.generateKeypair();return this.ss.mixHash(t.publicKey),this.e=t,t.publicKey}writeS(){if(!this.s)throw new Error("static keypair is not set");return this.ss.encryptAndHash(this.s.publicKey)}writeEE(){if(!this.e)throw new Error("ephemeral keypair is not set");if(!this.re)throw new Error("remote ephemeral public key is not set");this.ss.mixKey(this.crypto.dh(this.e,this.re))}writeES(){if(this.initiator){if(!this.e)throw new Error("ephemeral keypair is not set");if(!this.rs)throw new Error("remote static public key is not set");this.ss.mixKey(this.crypto.dh(this.e,this.rs))}else{if(!this.s)throw new Error("static keypair is not set");if(!this.re)throw new Error("remote ephemeral public key is not set");this.ss.mixKey(this.crypto.dh(this.s,this.re))}}writeSE(){if(this.initiator){if(!this.s)throw new Error("static keypair is not set");if(!this.re)throw new Error("remote ephemeral public key is not set");this.ss.mixKey(this.crypto.dh(this.s,this.re))}else{if(!this.e)throw new Error("ephemeral keypair is not set");if(!this.rs)throw new Error("remote static public key is not set");this.ss.mixKey(this.crypto.dh(this.e,this.rs))}}readE(t,e=0){if(this.re)throw new Error("remote ephemeral public key is already set");if(t.byteLength<e+32)throw new Error("message is not long enough");this.re=t.sublist(e,e+32),this.ss.mixHash(this.re)}readS(t,e=0){if(this.rs)throw new Error("remote static public key is already set");let n=32+(this.ss.cs.hasKey()?16:0);if(t.byteLength<e+n)throw new Error("message is not long enough");let o=t.sublist(e,e+n);return this.rs=this.ss.decryptAndHash(o),n}readEE(){this.writeEE()}readES(){this.writeES()}readSE(){this.writeSE()}},Xr=class extends pi{writeMessageA(t){return new $(this.writeE(),this.ss.encryptAndHash(t))}writeMessageB(t){let e=this.writeE();this.writeEE();let n=this.writeS();return this.writeES(),new $(e,n,this.ss.encryptAndHash(t))}writeMessageC(t){let e=this.writeS();return this.writeSE(),new $(e,this.ss.encryptAndHash(t))}readMessageA(t){try{return this.readE(t),this.ss.decryptAndHash(t.sublist(32))}catch(e){throw new fr(`handshake stage 0 validation fail: ${e.message}`)}}readMessageB(t){try{this.readE(t),this.readEE();let e=this.readS(t,32);return this.readES(),this.ss.decryptAndHash(t.sublist(32+e))}catch(e){throw new fr(`handshake stage 1 validation fail: ${e.message}`)}}readMessageC(t){try{let e=this.readS(t);return this.readSE(),this.ss.decryptAndHash(t.sublist(e))}catch(e){throw new fr(`handshake stage 2 validation fail: ${e.message}`)}}};function nd(r,t){if(t.length<=32){let e=dt(32);return e.set(t),e}else return r.hash(t)}var Yn;(function(r){let t;r.codec=()=>(t==null&&(t=Me((e,n,o={})=>{if(o.lengthDelimited!==!1&&n.fork(),e.webtransportCerthashes!=null)for(let s of e.webtransportCerthashes)n.uint32(10),n.bytes(s);if(e.streamMuxers!=null)for(let s of e.streamMuxers)n.uint32(18),n.string(s);o.lengthDelimited!==!1&&n.ldelim()},(e,n,o={})=>{let s={webtransportCerthashes:[],streamMuxers:[]},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let a=e.uint32();switch(a>>>3){case 1:{if(o.limits?.webtransportCerthashes!=null&&s.webtransportCerthashes.length===o.limits.webtransportCerthashes)throw new Mr('Decode error - map field "webtransportCerthashes" had too many elements');s.webtransportCerthashes.push(e.bytes());break}case 2:{if(o.limits?.streamMuxers!=null&&s.streamMuxers.length===o.limits.streamMuxers)throw new Mr('Decode error - map field "streamMuxers" had too many elements');s.streamMuxers.push(e.string());break}default:{e.skipType(a&7);break}}}return s})),t),r.encode=e=>Ne(e,r.codec()),r.decode=(e,n)=>De(e,r.codec(),n)})(Yn||(Yn={}));var Jr;(function(r){let t;r.codec=()=>(t==null&&(t=Me((e,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),e.identityKey!=null&&e.identityKey.byteLength>0&&(n.uint32(10),n.bytes(e.identityKey)),e.identitySig!=null&&e.identitySig.byteLength>0&&(n.uint32(18),n.bytes(e.identitySig)),e.extensions!=null&&(n.uint32(34),Yn.codec().encode(e.extensions,n)),o.lengthDelimited!==!1&&n.ldelim()},(e,n,o={})=>{let s={identityKey:dt(0),identitySig:dt(0)},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let a=e.uint32();switch(a>>>3){case 1:{s.identityKey=e.bytes();break}case 2:{s.identitySig=e.bytes();break}case 4:{s.extensions=Yn.codec().decode(e,e.uint32(),{limits:o.limits?.extensions});break}default:{e.skipType(a&7);break}}}return s})),t),r.encode=e=>Ne(e,r.codec()),r.decode=(e,n)=>De(e,r.codec(),n)})(Jr||(Jr={}));async function mi(r,t,e){let n=await r.sign(du(t));return Jr.encode({identityKey:de(r.publicKey),identitySig:n,extensions:e})}async function yi(r,t,e){try{let n=Jr.decode(r),o=qr(n.identityKey);if(e?.equals(o)===!1)throw new Error(`Payload identity key ${o} does not match expected remote identity key ${e}`);if(!t)throw new Error("Remote static does not exist");let s=du(t);if(!await o.verify(s,n.identitySig))throw new Error("Invalid payload signature");return n}catch(n){throw new rn(n.message)}}function du(r){let t=Q("noise-libp2p-static-key:");return r instanceof Uint8Array?At([t,r],t.length+r.length):(r.prepend(t),r)}async function pu(r,t){let{log:e,connection:n,crypto:o,privateKey:s,prologue:i,s:a,remoteIdentityKey:c,extensions:f}=r,u=await mi(s,a.publicKey,f),l=new Xr({crypto:o,protocolName:"Noise_XX_25519_ChaChaPoly_SHA256",initiator:!0,prologue:i,s:a});ui(l.s,e),e.trace("Stage 0 - Initiator starting to send first message."),await n.write(l.writeMessageA(He),t),e.trace("Stage 0 - Initiator finished sending first message."),fi(l.e,e),e.trace("Stage 1 - Initiator waiting to receive first message from responder...");let p=l.readMessageB(await n.read(t));e.trace("Stage 1 - Initiator received the message."),li(l.re,e),hu(l.rs,e),e.trace("Initiator going to check remote's signature...");let w=await yi(p,l.rs,c);e.trace("All good with the signature!"),e.trace("Stage 2 - Initiator sending third handshake message."),await n.write(l.writeMessageC(u),t),e.trace("Stage 2 - Initiator sent message with signed payload.");let[y,m]=l.ss.split();return hi(y,m,e),{payload:w,encrypt:x=>y.encryptWithAd(He,x),decrypt:(x,_)=>m.decryptWithAd(He,x,_)}}async function mu(r,t){let{log:e,connection:n,crypto:o,privateKey:s,prologue:i,s:a,remoteIdentityKey:c,extensions:f}=r,u=await mi(s,a.publicKey,f),l=new Xr({crypto:o,protocolName:"Noise_XX_25519_ChaChaPoly_SHA256",initiator:!1,prologue:i,s:a});ui(l.s,e),e.trace("Stage 0 - Responder waiting to receive first message."),l.readMessageA(await n.read(t)),e.trace("Stage 0 - Responder received first message."),li(l.re,e),e.trace("Stage 1 - Responder sending out first message with signed payload and static key."),await n.write(l.writeMessageB(u),t),e.trace("Stage 1 - Responder sent the second handshake message with signed payload."),fi(l.e,e),e.trace("Stage 2 - Responder waiting for third handshake message...");let p=l.readMessageC(await n.read(t));e.trace("Stage 2 - Responder received the message, finished handshake.");let w=await yi(p,l.rs,c),[y,m]=l.ss.split();return hi(y,m,e),{payload:w,encrypt:x=>m.encryptWithAd(He,x),decrypt:(x,_)=>y.decryptWithAd(He,x,_)}}var gu=16;function xu(r,t){return async function*(e){for await(let n of e)for(let o=0;o<n.length;o+=65519){let s=o+65519;s>n.length&&(s=n.length);let i;n instanceof Uint8Array?i=r.encrypt(n.subarray(o,s)):i=r.encrypt(n.sublist(o,s)),t?.encryptedPackets.increment(),yield new $(ur(i.byteLength),i)}}}function wu(r,t){return async function*(e){for await(let n of e)for(let o=0;o<n.length;o+=65535){let s=o+65535;if(s>n.length&&(s=n.length),s-gu<o)throw new Error("Invalid chunk");let i=n.sublist(o,s),a=n.subarray(o,s-gu);try{let c=r.decrypt(i,a);t?.decryptedPackets.increment(),yield c}catch(c){throw t?.decryptErrors.increment(),c}}}}var Xn=class{protocol="/noise";crypto;prologue;staticKey;extensions;metrics;components;constructor(t,e={}){let{staticNoiseKey:n,extensions:o,crypto:s,prologueBytes:i}=e,{metrics:a}=t;this.components=t;let c=s??uu;this.crypto=fu(c),this.extensions={webtransportCerthashes:[],...o},this.metrics=a?lu(a):void 0,n?this.staticKey=c.generateX25519KeyPairFromSeed(n):this.staticKey=c.generateX25519KeyPair(),this.prologue=i??dt(0)}[Symbol.toStringTag]="@chainsafe/libp2p-noise";[un]=["@libp2p/connection-encryption","@chainsafe/libp2p-noise"];async secureOutbound(t,e){let n=Ys(t,{lengthEncoder:ur,lengthDecoder:Yr,maxDataLength:65535}),o=await this.performHandshakeInitiator(n,this.components.privateKey,e?.remotePeer?.publicKey,e),s=await this.createSecureConnection(n,o);t.source=s.source,t.sink=s.sink;let i=qr(o.payload.identityKey);return{conn:t,remoteExtensions:o.payload.extensions,remotePeer:js(i),streamMuxer:e?.skipStreamMuxerNegotiation===!0?void 0:this.getStreamMuxer(o.payload.extensions?.streamMuxers)}}getStreamMuxer(t){if(t==null||t.length===0)return;let e=this.components.upgrader.getStreamMuxers();if(e!=null)for(let n of t){let o=e.get(n);if(o!=null)return o}if(t.length)throw new ze("Early muxer negotiation was requested but the initiator and responder had no common muxers")}async secureInbound(t,e){let n=Ys(t,{lengthEncoder:ur,lengthDecoder:Yr,maxDataLength:65535}),o=await this.performHandshakeResponder(n,this.components.privateKey,e?.remotePeer?.publicKey,e),s=await this.createSecureConnection(n,o);t.source=s.source,t.sink=s.sink;let i=qr(o.payload.identityKey);return{conn:t,remoteExtensions:o.payload.extensions,remotePeer:js(i),streamMuxer:e?.skipStreamMuxerNegotiation===!0?void 0:this.getStreamMuxer(o.payload.extensions?.streamMuxers)}}async performHandshakeInitiator(t,e,n,o){let s,i=o?.skipStreamMuxerNegotiation===!0?[]:[...this.components.upgrader.getStreamMuxers().keys()];try{s=await pu({connection:t,privateKey:e,remoteIdentityKey:n,log:this.components.logger.forComponent("libp2p:noise:xxhandshake"),crypto:this.crypto,prologue:this.prologue,s:this.staticKey,extensions:{streamMuxers:i,webtransportCerthashes:[],...this.extensions}},o),this.metrics?.xxHandshakeSuccesses.increment()}catch(a){throw this.metrics?.xxHandshakeErrors.increment(),a}return s}async performHandshakeResponder(t,e,n,o){let s,i=o?.skipStreamMuxerNegotiation===!0?[]:[...this.components.upgrader.getStreamMuxers().keys()];try{s=await mu({connection:t,privateKey:e,remoteIdentityKey:n,log:this.components.logger.forComponent("libp2p:noise:xxhandshake"),crypto:this.crypto,prologue:this.prologue,s:this.staticKey,extensions:{streamMuxers:i,webtransportCerthashes:[],...this.extensions}},o),this.metrics?.xxHandshakeSuccesses.increment()}catch(a){throw this.metrics?.xxHandshakeErrors.increment(),a}return s}async createSecureConnection(t,e){let[n,o]=Vc(),s=t.unwrap();return await zc(n,xu(e,this.metrics),s,i=>Zr(i,{lengthDecoder:Yr}),wu(e,this.metrics),n),o}};function bu(r={}){return t=>new Xn(t,r)}var Jn=class{index=0;input="";new(t){return this.index=0,this.input=t,this}readAtomically(t){let e=this.index,n=t();return n===void 0&&(this.index=e),n}parseWith(t){let e=t();if(this.index===this.input.length)return e}peekChar(){if(!(this.index>=this.input.length))return this.input[this.index]}readChar(){if(!(this.index>=this.input.length))return this.input[this.index++]}readGivenChar(t){return this.readAtomically(()=>{let e=this.readChar();if(e===t)return e})}readSeparator(t,e,n){return this.readAtomically(()=>{if(!(e>0&&this.readGivenChar(t)===void 0))return n()})}readNumber(t,e,n,o){return this.readAtomically(()=>{let s=0,i=0,a=this.peekChar();if(a===void 0)return;let c=a==="0",f=2**(8*o)-1;for(;;){let u=this.readAtomically(()=>{let l=this.readChar();if(l===void 0)return;let p=Number.parseInt(l,t);if(!Number.isNaN(p))return p});if(u===void 0)break;if(s*=t,s+=u,s>f||(i+=1,e!==void 0&&i>e))return}if(i!==0)return!n&&c&&i>1?void 0:s})}readIPv4Addr(){return this.readAtomically(()=>{let t=new Uint8Array(4);for(let e=0;e<t.length;e++){let n=this.readSeparator(".",e,()=>this.readNumber(10,3,!1,1));if(n===void 0)return;t[e]=n}return t})}readIPv6Addr(){let t=e=>{for(let n=0;n<e.length/2;n++){let o=n*2;if(n<e.length-3){let i=this.readSeparator(":",n,()=>this.readIPv4Addr());if(i!==void 0)return e[o]=i[0],e[o+1]=i[1],e[o+2]=i[2],e[o+3]=i[3],[o+4,!0]}let s=this.readSeparator(":",n,()=>this.readNumber(16,4,!0,2));if(s===void 0)return[o,!1];e[o]=s>>8,e[o+1]=s&255}return[e.length,!1]};return this.readAtomically(()=>{let e=new Uint8Array(16),[n,o]=t(e);if(n===16)return e;if(o||this.readGivenChar(":")===void 0||this.readGivenChar(":")===void 0)return;let s=new Uint8Array(14),i=16-(n+2),[a]=t(s.subarray(0,i));return e.set(s.subarray(0,a),16-a),e})}readIPAddr(){return this.readIPv4Addr()??this.readIPv6Addr()}};var Eu=45,od=15,hr=new Jn;function gi(r){if(!(r.length>od))return hr.new(r).parseWith(()=>hr.readIPv4Addr())}function xi(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>Eu))return hr.new(r).parseWith(()=>hr.readIPv6Addr())}function Qn(r,t=!1){if(r.includes("%")&&(r=r.split("%")[0]),r.length>Eu)return;let e=hr.new(r).parseWith(()=>hr.readIPAddr());if(e)return t&&e.length===4?Uint8Array.from([0,0,0,0,0,0,0,0,0,0,255,255,e[0],e[1],e[2],e[3]]):e}function to(r){return!!gi(r)}function eo(r){return!!xi(r)}function ro(r){return!!Qn(r)}var sd=r=>r.toString().split("/").slice(1),dr=r=>({match:t=>t.length<1?!1:r(t[0])?t.slice(1):!1,pattern:"fn"}),W=r=>({match:t=>dr(e=>e===r).match(t),pattern:r}),Ve=()=>({match:r=>dr(t=>typeof t=="string").match(r),pattern:"{string}"}),pr=()=>({match:r=>dr(t=>!isNaN(parseInt(t))).match(r),pattern:"{number}"}),rt=()=>({match:r=>{if(r.length<2||r[0]!=="p2p"&&r[0]!=="ipfs")return!1;if(r[1].startsWith("Q")||r[1].startsWith("1"))try{nt.decode(`z${r[1]}`)}catch{return!1}else return!1;return r.slice(2)},pattern:"/p2p/{peerid}"}),tn=()=>({match:r=>{if(r.length<2||r[0]!=="certhash")return!1;try{Uo.decode(r[1])}catch{return!1}return r.slice(2)},pattern:"/certhash/{certhash}"}),X=r=>({match:t=>{let e=r.match(t);return e===!1?t:e},pattern:`optional(${r.pattern})`}),Tt=(...r)=>({match:t=>{let e;for(let n of r){let o=n.match(t);o!==!1&&(e==null||o.length<e.length)&&(e=o)}return e??!1},pattern:`or(${r.map(t=>t.pattern).join(", ")})`}),j=(...r)=>({match:t=>{for(let e of r){let n=e.match(t);if(n===!1)return!1;t=n}return t},pattern:`and(${r.map(t=>t.pattern).join(", ")})`});function it(...r){function t(o){let s=sd(o);for(let i of r){let a=i.match(s);if(a===!1)return!1;s=a}return s}function e(o){return t(o)!==!1}function n(o){let s=t(o);return s===!1?!1:s.length===0}return{matchers:r,matches:e,exactMatch:n}}var id=rt(),Nb=it(id),oo=j(W("dns4"),Ve()),so=j(W("dns6"),Ve()),io=j(W("dnsaddr"),Ve()),bi=j(W("dns"),Ve()),Mb=it(oo,X(rt())),Ob=it(so,X(rt())),Hb=it(io,X(rt())),Vb=it(Tt(bi,io,oo,so),X(rt())),Su=j(W("ip4"),dr(to)),Au=j(W("ip6"),dr(eo)),Ei=Tt(Su,Au),ue=Tt(Ei,bi,oo,so,io),qb=it(Tt(Ei,j(Tt(bi,io,oo,so),X(rt())))),zb=it(Su),Fb=it(Au),Gb=it(Ei),Si=j(ue,W("tcp"),pr()),en=j(ue,W("udp"),pr()),Wb=it(j(Si,X(rt()))),jb=it(en),Ai=j(en,W("quic"),X(rt())),ao=j(en,W("quic-v1"),X(rt())),ad=Tt(Ai,ao),$b=it(Ai),Zb=it(ao),wi=Tt(ue,Si,en,Ai,ao),vu=Tt(j(wi,W("ws"),X(rt()))),Yb=it(vu),Iu=Tt(j(wi,W("wss"),X(rt())),j(wi,W("tls"),X(j(W("sni"),Ve())),W("ws"),X(rt()))),Xb=it(Iu),Bu=j(en,W("webrtc-direct"),X(tn()),X(tn()),X(rt())),Jb=it(Bu),_u=j(ao,W("webtransport"),X(tn()),X(tn()),X(rt())),co=it(_u),no=Tt(vu,Iu,j(Si,X(rt())),j(ad,X(rt())),j(ue,X(rt())),Bu,_u,rt()),Qb=it(no),cd=j(no,W("p2p-circuit"),rt()),t1=it(cd),ud=Tt(j(no,W("p2p-circuit"),W("webrtc"),X(rt())),j(no,W("webrtc"),X(rt())),j(W("webrtc"),X(rt()))),e1=it(ud),fd=Tt(j(ue,W("tcp"),pr(),W("http"),X(rt())),j(ue,W("http"),X(rt()))),r1=it(fd),ld=Tt(j(ue,W("tcp"),Tt(j(W("443"),W("http")),j(pr(),W("https")),j(pr(),W("tls"),W("http"))),X(rt())),j(ue,W("tls"),W("http"),X(rt())),j(ue,W("https"),X(rt()))),n1=it(ld),hd=Tt(j(W("memory"),Ve(),X(rt()))),o1=it(hd);var qe=class extends Event{type;detail;constructor(t,e){super(t),this.type=t,this.detail=e}};function vi(r){throw new Error("Not implemented")}function Lu(r){if(r!=null){if(typeof r[Symbol.iterator]=="function")return r[Symbol.iterator]();if(typeof r[Symbol.asyncIterator]=="function")return r[Symbol.asyncIterator]();if(typeof r.next=="function")return r}throw new Error("argument is not an iterator or iterable")}function Tu(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function Cu(r,t){let e=Lu(r).return?.();Tu(e)&&e.catch(n=>{t.error("could not cause iterator to return",n)})}var dd=5e3;function Ii(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}var uo=class{id;direction;timeline;protocol;metadata;source;status;readStatus;writeStatus;log;sinkController;sinkEnd;closed;endErr;streamSource;onEnd;onCloseRead;onCloseWrite;onReset;onAbort;sendCloseWriteTimeout;sendingData;constructor(t){this.sinkController=new AbortController,this.sinkEnd=_t(),this.closed=_t(),this.log=t.log,this.status="open",this.readStatus="ready",this.writeStatus="ready",this.id=t.id,this.metadata=t.metadata??{},this.direction=t.direction,this.timeline={open:Date.now()},this.sendCloseWriteTimeout=t.sendCloseWriteTimeout??dd,this.onEnd=t.onEnd,this.onCloseRead=t?.onCloseRead,this.onCloseWrite=t?.onCloseWrite,this.onReset=t?.onReset,this.onAbort=t?.onAbort,this.source=this.streamSource=zn({onEnd:e=>{e!=null?this.log.trace("source ended with error",e):this.log.trace("source ended"),this.onSourceEnd(e)}}),this.sink=this.sink.bind(this)}async sink(t){if(this.writeStatus!=="ready")throw new on(`writable end state is "${this.writeStatus}" not "ready"`);try{this.writeStatus="writing";let e={signal:this.sinkController.signal};if(this.direction==="outbound"){let o=this.sendNewStream(e);Ii(o)&&await o}let n=()=>{Cu(t,this.log)};try{this.sinkController.signal.addEventListener("abort",n),this.log.trace("sink reading from source");for await(let o of t){o=o instanceof Uint8Array?new $(o):o;let s=this.sendData(o,e);Ii(s)&&(this.sendingData=_t(),await s,this.sendingData.resolve(),this.sendingData=void 0)}}finally{this.sinkController.signal.removeEventListener("abort",n)}this.log.trace('sink finished reading from source, write status is "%s"',this.writeStatus),this.writeStatus==="writing"&&(this.writeStatus="closing",this.log.trace("send close write to remote"),await this.sendCloseWrite({signal:AbortSignal.timeout(this.sendCloseWriteTimeout)}),this.writeStatus="closed"),this.onSinkEnd()}catch(e){throw this.log.trace("sink ended with error, calling abort with error",e),this.abort(e),e}finally{this.log.trace("resolve sink end"),this.sinkEnd.resolve()}}onSourceEnd(t){this.timeline.closeRead==null&&(this.timeline.closeRead=Date.now(),this.readStatus="closed",t!=null&&this.endErr==null&&(this.endErr=t),this.onCloseRead?.(),this.timeline.closeWrite!=null?(this.log.trace("source and sink ended"),this.timeline.close=Date.now(),this.status!=="aborted"&&this.status!=="reset"&&(this.status="closed"),this.onEnd!=null&&this.onEnd(this.endErr),this.closed.resolve()):this.log.trace("source ended, waiting for sink to end"))}onSinkEnd(t){this.timeline.closeWrite==null&&(this.timeline.closeWrite=Date.now(),this.writeStatus="closed",t!=null&&this.endErr==null&&(this.endErr=t),this.onCloseWrite?.(),this.timeline.closeRead!=null?(this.log.trace("sink and source ended"),this.timeline.close=Date.now(),this.status!=="aborted"&&this.status!=="reset"&&(this.status="closed"),this.onEnd!=null&&this.onEnd(this.endErr),this.closed.resolve()):this.log.trace("sink ended, waiting for source to end"))}async close(t){this.status==="open"&&(this.log.trace("closing gracefully"),this.status="closing",await xt(Promise.all([this.closeWrite(t),this.closeRead(t),this.closed.promise]),t?.signal),this.status="closed",this.log.trace("closed gracefully"))}async closeRead(t={}){if(this.readStatus==="closing"||this.readStatus==="closed")return;this.log.trace('closing readable end of stream with starting read status "%s"',this.readStatus);let e=this.readStatus;this.readStatus="closing",this.status!=="reset"&&this.status!=="aborted"&&this.timeline.closeRead==null&&(this.log.trace("send close read to remote"),await this.sendCloseRead(t)),e==="ready"&&(this.log.trace("ending internal source queue with %d queued bytes",this.streamSource.readableLength),this.streamSource.end()),this.log.trace("closed readable end of stream")}async closeWrite(t={}){this.writeStatus==="closing"||this.writeStatus==="closed"||(this.log.trace('closing writable end of stream with starting write status "%s"',this.writeStatus),this.writeStatus==="ready"&&(this.log.trace("sink was never sunk, sink an empty array"),await xt(this.sink([]),t.signal)),this.writeStatus==="writing"&&(this.sendingData!=null&&await xt(this.sendingData.promise,t.signal),this.log.trace("aborting source passed to .sink"),this.sinkController.abort(),await xt(this.sinkEnd.promise,t.signal)),this.writeStatus="closed",this.log.trace("closed writable end of stream"))}abort(t){if(this.status==="closed"||this.status==="aborted"||this.status==="reset")return;this.log("abort with error",t),this.log("try to send reset to remote");let e=this.sendReset();Ii(e)&&e.catch(n=>{this.log.error("error sending reset message",n)}),this.status="aborted",this.timeline.abort=Date.now(),this._closeSinkAndSource(t),this.onAbort?.(t)}reset(){if(this.status==="closed"||this.status==="aborted"||this.status==="reset")return;let t=new nn("stream reset");this.status="reset",this.timeline.reset=Date.now(),this._closeSinkAndSource(t),this.onReset?.()}_closeSinkAndSource(t){this._closeSink(t),this._closeSource(t)}_closeSink(t){this.writeStatus==="writing"&&(this.log.trace("end sink source"),this.sinkController.abort()),this.onSinkEnd(t)}_closeSource(t){this.readStatus!=="closing"&&this.readStatus!=="closed"&&(this.log.trace("ending source with %d bytes to be read by consumer",this.streamSource.readableLength),this.readStatus="closing",this.streamSource.end(t))}remoteCloseWrite(){if(this.readStatus==="closing"||this.readStatus==="closed"){this.log("received remote close write but local source is already closed");return}this.log.trace("remote close write"),this._closeSource()}remoteCloseRead(){if(this.writeStatus==="closing"||this.writeStatus==="closed"){this.log("received remote close read but local sink is already closed");return}this.log.trace("remote close read"),this._closeSink()}destroy(){if(this.status==="closed"||this.status==="aborted"||this.status==="reset"){this.log("received destroy but we are already closed");return}this.log.trace("stream destroyed"),this._closeSinkAndSource()}sourcePush(t){this.streamSource.push(t)}sourceReadableLength(){return this.streamSource.readableLength}};var Bi=class extends uo{writer;reader;constructor(t){super(t),this.writer=t.bidiStream.writable.getWriter(),this.reader=t.bidiStream.readable.getReader(),Promise.resolve().then(async()=>{for(;;){let e=await this.reader.read();if(e.done){t.log("remote closed write");return}e.value!=null&&this.sourcePush(new $(e.value))}}).catch(e=>{t.log.error("error reading from stream",e),this.abort(e)}).finally(()=>{this.remoteCloseWrite()}),this.writer.closed.then(()=>{t.log("writer closed")}).catch(e=>{t.log("writer close promise rejected",e)}).finally(()=>{this.remoteCloseRead()})}sendNewStream(t){}async sendData(t,e){for await(let n of t)this.log("sendData waiting for writer to be ready"),await xt(this.writer.ready,e?.signal),this.writer.write(n).catch(o=>{this.log.error("error sending stream data",o)})}async sendReset(t){this.log("sendReset aborting writer"),await xt(this.writer.abort(),t?.signal),this.log("sendReset aborted writer")}async sendCloseWrite(t){this.log("sendCloseWrite closing writer"),await xt(this.writer.close(),t?.signal),this.log("sendCloseWrite closed writer")}async sendCloseRead(t){this.log("sendCloseRead cancelling reader"),await xt(this.reader.cancel(),t?.signal),this.log("sendCloseRead cancelled reader")}};async function _i(r,t,e,n,o,s){let i=s.forComponent(`libp2p:webtransport:stream:${e}:${t}`),a=new Bi({bidiStream:r,id:t,direction:e,log:i,onEnd:()=>{let c=n.findIndex(f=>f===a);c!==-1&&n.splice(c,1),o?.(a)}});return a}function fo(){return{source:{[Symbol.asyncIterator](){return{async next(){return new Promise(()=>{})}}}},sink:async r=>new Promise(()=>{})}}function Pu(r,t,e,n){let o=0,s=e.forComponent("libp2p:webtransport:muxer");return{protocol:"webtransport",createStreamMuxer:i=>{typeof i=="function"&&(i={onIncomingStream:i});let a=[];Promise.resolve().then(async()=>{for(;;){let{done:f,value:u}=await t.read();if(f)break;if(a.length>=n.maxInboundStreams)s(`too many inbound streams open - ${a.length}/${n.maxInboundStreams}, closing new incoming stream`),u.writable.close().catch(l=>{s.error(`failed to close inbound stream that crossed our maxInboundStream limit: ${l.message}`)}),u.readable.cancel().catch(l=>{s.error(`failed to close inbound stream that crossed our maxInboundStream limit: ${l.message}`)});else{let l=await _i(u,String(o++),"inbound",a,i?.onStreamEnd,e);a.push(l),i?.onIncomingStream?.(l)}}}).catch(f=>{s.error("could not create a new stream",f)});let c={protocol:"webtransport",streams:a,newStream:async f=>{s("new outgoing stream",f);let u=await r.createBidirectionalStream(),l=await _i(u,String(o++),i?.direction??"outbound",a,i?.onStreamEnd,e);return a.push(l),l},close:async()=>{s("closing webtransport muxer gracefully");try{r.close()}catch(f){c.abort(f)}},abort:f=>{s("closing webtransport muxer with err:",f);try{r.close()}catch(u){s.error("webtransport session threw error during close",u)}},...fo()};return c}}}function Uu(r,t){return t.filter(n=>!!r.find(o=>ht(n,o))).length===t.length}var N1=parseInt("0xFFFF",16),M1=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);var Du=to,xd=eo,Li=function(r){let t=0;if(r=r.toString().trim(),Du(r)){let e=new Uint8Array(t+4);return r.split(/\./g).forEach(n=>{e[t++]=parseInt(n,10)&255}),e}if(xd(r)){let e=r.split(":",8),n;for(n=0;n<e.length;n++){let s=Du(e[n]),i;s&&(i=Li(e[n]),e[n]=V(i.slice(0,2),"base16")),i!=null&&++n<8&&e.splice(n,0,V(i.slice(2,4),"base16"))}if(e[0]==="")for(;e.length<8;)e.unshift("0");else if(e[e.length-1]==="")for(;e.length<8;)e.push("0");else if(e.length<8){for(n=0;n<e.length&&e[n]!=="";n++);let s=[n,1];for(n=9-e.length;n>0;n--)s.push("0");e.splice.apply(e,s)}let o=new Uint8Array(t+16);for(n=0;n<e.length;n++){let s=parseInt(e[n],16);o[t++]=s>>8&255,o[t++]=s&255}return o}throw new Error("invalid ip address")},Ku=function(r,t=0,e){t=~~t,e=e??r.length-t;let n=new DataView(r.buffer);if(e===4){let o=[];for(let s=0;s<e;s++)o.push(r[t+s]);return o.join(".")}if(e===16){let o=[];for(let s=0;s<e;s+=2)o.push(n.getUint16(t+s).toString(16));return o.join(":").replace(/(^|:)0(:0)*:0(:|$)/,"$1::$3").replace(/:{3,4}/,"::")}return""};var mr={},Ti={},bd=[[4,32,"ip4"],[6,16,"tcp"],[33,16,"dccp"],[41,128,"ip6"],[42,-1,"ip6zone"],[43,8,"ipcidr"],[53,-1,"dns",!0],[54,-1,"dns4",!0],[55,-1,"dns6",!0],[56,-1,"dnsaddr",!0],[132,16,"sctp"],[273,16,"udp"],[275,0,"p2p-webrtc-star"],[276,0,"p2p-webrtc-direct"],[277,0,"p2p-stardust"],[280,0,"webrtc-direct"],[281,0,"webrtc"],[290,0,"p2p-circuit"],[301,0,"udt"],[302,0,"utp"],[400,-1,"unix",!1,!0],[421,-1,"ipfs"],[421,-1,"p2p"],[443,0,"https"],[444,96,"onion"],[445,296,"onion3"],[446,-1,"garlic64"],[448,0,"tls"],[449,-1,"sni"],[460,0,"quic"],[461,0,"quic-v1"],[465,0,"webtransport"],[466,-1,"certhash"],[477,0,"ws"],[478,0,"wss"],[479,0,"p2p-websocket-star"],[480,0,"http"],[481,-1,"http-path"],[777,-1,"memory"]];bd.forEach(r=>{let t=Ed(...r);Ti[t.code]=t,mr[t.name]=t});function Ed(r,t,e,n,o){return{code:r,size:t,name:e,resolvable:!!n,path:!!o}}function et(r){if(typeof r=="number"){if(Ti[r]!=null)return Ti[r];throw new Error(`no protocol with code: ${r}`)}else if(typeof r=="string"){if(mr[r]!=null)return mr[r];throw new Error(`no protocol with name: ${r}`)}throw new Error(`invalid protocol id type: ${typeof r}`)}var w2=et("ip4"),b2=et("ip6"),E2=et("ipcidr");function ki(r,t){switch(et(r).code){case 4:case 41:return Ad(t);case 42:return Ui(t);case 43:return V(t,"base10");case 6:case 273:case 33:case 132:return Ou(t).toString();case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Ui(t);case 421:return _d(t);case 444:return Mu(t);case 445:return Mu(t);case 466:return Bd(t);case 481:return globalThis.encodeURIComponent(Ui(t));default:return V(t,"base16")}}function Ri(r,t){switch(et(r).code){case 4:return Nu(t);case 41:return Nu(t);case 42:return Pi(t);case 43:return Q(t,"base10");case 6:case 273:case 33:case 132:return Di(parseInt(t,10));case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Pi(t);case 421:return vd(t);case 444:return Ld(t);case 445:return Td(t);case 466:return Id(t);case 481:return Pi(globalThis.decodeURIComponent(t));default:return Q(t,"base16")}}var Ci=Object.values(Be).map(r=>r.decoder),Sd=function(){let r=Ci[0].or(Ci[1]);return Ci.slice(2).forEach(t=>r=r.or(t)),r}();function Nu(r){if(!ro(r))throw new Error("invalid ip address");return Li(r)}function Ad(r){let t=Ku(r,0,r.length);if(t==null)throw new Error("ipBuff is required");if(!ro(t))throw new Error("invalid ip address");return t}function Di(r){let t=new ArrayBuffer(2);return new DataView(t).setUint16(0,r),new Uint8Array(t)}function Ou(r){return new DataView(r.buffer).getUint16(r.byteOffset)}function Pi(r){let t=Q(r),e=Uint8Array.from(Yt(t.length));return At([e,t],e.length+t.length)}function Ui(r){let t=zt(r);if(r=r.slice(lt(t)),r.length!==t)throw new Error("inconsistent lengths");return V(r)}function vd(r){let t;r[0]==="Q"||r[0]==="1"?t=le(nt.decode(`z${r}`)).bytes:t=ut.parse(r).multihash.bytes;let e=Uint8Array.from(Yt(t.length));return At([e,t],e.length+t.length)}function Id(r){let t=Sd.decode(r),e=Uint8Array.from(Yt(t.length));return At([e,t],e.length+t.length)}function Bd(r){let t=zt(r),e=r.slice(lt(t));if(e.length!==t)throw new Error("inconsistent lengths");return"u"+V(e,"base64url")}function _d(r){let t=zt(r),e=r.slice(lt(t));if(e.length!==t)throw new Error("inconsistent lengths");return V(e,"base58btc")}function Ld(r){let t=r.split(":");if(t.length!==2)throw new Error(`failed to parse onion addr: ["'${t.join('", "')}'"]' does not contain a port number`);if(t[0].length!==16)throw new Error(`failed to parse onion addr: ${t[0]} not a Tor onion address.`);let e=Qt.decode("b"+t[0]),n=parseInt(t[1],10);if(n<1||n>65536)throw new Error("Port number is not in range(1, 65536)");let o=Di(n);return At([e,o],e.length+o.length)}function Td(r){let t=r.split(":");if(t.length!==2)throw new Error(`failed to parse onion addr: ["'${t.join('", "')}'"]' does not contain a port number`);if(t[0].length!==56)throw new Error(`failed to parse onion addr: ${t[0]} not a Tor onion3 address.`);let e=Qt.decode(`b${t[0]}`),n=parseInt(t[1],10);if(n<1||n>65536)throw new Error("Port number is not in range(1, 65536)");let o=Di(n);return At([e,o],e.length+o.length)}function Mu(r){let t=r.slice(0,r.length-2),e=r.slice(r.length-2),n=V(t,"base32"),o=Ou(e);return`${n}:${o}`}function Hu(r){r=Ki(r);let t=[],e=[],n=null,o=r.split("/").slice(1);if(o.length===1&&o[0]==="")return{bytes:new Uint8Array,string:"/",tuples:[],stringTuples:[],path:null};for(let s=0;s<o.length;s++){let i=o[s],a=et(i);if(a.size===0){t.push([a.code]),e.push([a.code]);continue}if(s++,s>=o.length)throw new lo("invalid address: "+r);if(a.path===!0){n=Ki(o.slice(s).join("/")),t.push([a.code,Ri(a.code,n)]),e.push([a.code,n]);break}let c=Ri(a.code,o[s]);t.push([a.code,c]),e.push([a.code,ki(a.code,c)])}return{string:Vu(e),bytes:ho(t),tuples:t,stringTuples:e,path:n}}function Ni(r){let t=[],e=[],n=null,o=0;for(;o<r.length;){let s=zt(r,o),i=lt(s),a=et(s),c=Cd(a,r.slice(o+i));if(c===0){t.push([s]),e.push([s]),o+=i;continue}let f=r.slice(o+i,o+i+c);if(o+=c+i,o>r.length)throw new lo("Invalid address Uint8Array: "+V(r,"base16"));t.push([s,f]);let u=ki(s,f);if(e.push([s,u]),a.path===!0){n=u;break}}return{bytes:Uint8Array.from(r),string:Vu(e),tuples:t,stringTuples:e,path:n}}function Vu(r){let t=[];return r.map(e=>{let n=et(e[0]);return t.push(n.name),e.length>1&&e[1]!=null&&t.push(e[1]),null}),Ki(t.join("/"))}function ho(r){return At(r.map(t=>{let e=et(t[0]),n=Uint8Array.from(Yt(e.code));return t.length>1&&t[1]!=null&&(n=At([n,t[1]])),n}))}function Cd(r,t){if(r.size>0)return r.size/8;if(r.size===0)return 0;{let e=zt(t instanceof Uint8Array?t:Uint8Array.from(t));return e+lt(e)}}function Ki(r){return"/"+r.trim().split("/").filter(t=>t).join("/")}var lo=class extends Error{static name="ParseError";name="ParseError";constructor(t){super(`Error parsing address: ${t}`)}};var Pd=Symbol.for("nodejs.util.inspect.custom"),Oi=Symbol.for("@multiformats/js-multiaddr/multiaddr"),Ud=[et("dns").code,et("dns4").code,et("dns6").code,et("dnsaddr").code],Mi=class extends Error{constructor(t="No available resolver"){super(t),this.name="NoAvailableResolverError"}},po=class r{bytes;#e;#t;#r;#n;[Oi]=!0;constructor(t){t==null&&(t="");let e;if(t instanceof Uint8Array)e=Ni(t);else if(typeof t=="string"){if(t.length>0&&t.charAt(0)!=="/")throw new Error(`multiaddr "${t}" must start with a "/"`);e=Hu(t)}else if(zu(t))e=Ni(t.bytes);else throw new Error("addr must be a string, Buffer, or another Multiaddr");this.bytes=e.bytes,this.#e=e.string,this.#t=e.tuples,this.#r=e.stringTuples,this.#n=e.path}toString(){return this.#e}toJSON(){return this.toString()}toOptions(){let t,e,n,o,s="",i=et("tcp"),a=et("udp"),c=et("ip4"),f=et("ip6"),u=et("dns6"),l=et("ip6zone");for(let[w,y]of this.stringTuples())w===l.code&&(s=`%${y??""}`),Ud.includes(w)&&(e=i.name==="tcp"?"tcp":"udp",o=443,n=`${y??""}${s}`,t=w===u.code?6:4),(w===i.code||w===a.code)&&(e=et(w).name==="tcp"?"tcp":"udp",o=parseInt(y??"")),(w===c.code||w===f.code)&&(e=et(w).name==="tcp"?"tcp":"udp",n=`${y??""}${s}`,t=w===f.code?6:4);if(t==null||e==null||n==null||o==null)throw new Error('multiaddr must have a valid format: "/{ip4, ip6, dns4, dns6, dnsaddr}/{address}/{tcp, udp}/{port}".');return{family:t,host:n,transport:e,port:o}}protos(){return this.#t.map(([t])=>Object.assign({},et(t)))}protoCodes(){return this.#t.map(([t])=>t)}protoNames(){return this.#t.map(([t])=>et(t).name)}tuples(){return this.#t.map(([t,e])=>e==null?[t]:[t,e])}stringTuples(){return this.#r.map(([t,e])=>e==null?[t]:[t,e])}encapsulate(t){return t=new r(t),new r(this.toString()+t.toString())}decapsulate(t){let e=t.toString(),n=this.toString(),o=n.lastIndexOf(e);if(o<0)throw new Error(`Address ${this.toString()} does not contain subaddress: ${t.toString()}`);return new r(n.slice(0,o))}decapsulateCode(t){let e=this.tuples();for(let n=e.length-1;n>=0;n--)if(e[n][0]===t)return new r(ho(e.slice(0,n)));return this}getPeerId(){try{let t=[];this.stringTuples().forEach(([n,o])=>{n===mr.p2p.code&&t.push([n,o]),n===mr["p2p-circuit"].code&&(t=[])});let e=t.pop();if(e?.[1]!=null){let n=e[1];return n[0]==="Q"||n[0]==="1"?V(nt.decode(`z${n}`),"base58btc"):V(ut.parse(n).multihash.bytes,"base58btc")}return null}catch{return null}}getPath(){return this.#n}equals(t){return ht(this.bytes,t.bytes)}async resolve(t){let e=this.protos().find(s=>s.resolvable);if(e==null)return[this];let n=qu.get(e.name);if(n==null)throw new Mi(`no available resolver for ${e.name}`);return(await n(this,t)).map(s=>Hi(s))}nodeAddress(){let t=this.toOptions();if(t.transport!=="tcp"&&t.transport!=="udp")throw new Error(`multiaddr must have a valid format - no protocol with name: "${t.transport}". Must have a valid transport protocol: "{tcp, udp}"`);return{family:t.family,address:t.host,port:t.port}}isThinWaistAddress(t){let e=(t??this).protos();return!(e.length!==2||e[0].code!==4&&e[0].code!==41||e[1].code!==6&&e[1].code!==273)}[Pd](){return`Multiaddr(${this.#e})`}};var qu=new Map;function zu(r){return!!r?.[Oi]}function Hi(r){return new po(r)}var kd=Object.values(Be).map(r=>r.decoder).reduce((r,t)=>r.or(t));function Rd(r){return Gt.decode(kd.decode(r))}function Vi(r){if(!co.matches(r))throw new sn("Invalid multiaddr, was not a WebTransport address");let t=r.stringTuples(),e=t.filter(([i,a])=>i===et("certhash").code).map(([i,a])=>Rd(a??"")),n=t.filter(([i,a])=>i===et("p2p").code).map(([i,a])=>Kc(a??""))[0],o=r.toOptions(),s=o.host;return o.family===6&&s?.includes(":")&&(s=`[${s}]`),{url:`https://${s}:${o.port}`,certhashes:e,remotePeer:n}}var Fu=globalThis.WebTransport;var qi=class{log;components;config;metrics;constructor(t,e={}){this.log=t.logger.forComponent("libp2p:webtransport"),this.components=t,this.config={...e,maxInboundStreams:e.maxInboundStreams??1e3,certificates:e.certificates??[]},t.metrics!=null&&(this.metrics={dialerEvents:t.metrics.registerCounterGroup("libp2p_webtransport_dialer_events_total",{label:"event",help:"Total count of WebTransport dialer events by type"})})}[Symbol.toStringTag]="@libp2p/webtransport";[Gi]=!0;[un]=["@libp2p/transport"];async dial(t,e){e.signal.throwIfAborted(),this.log("dialing %s",t),e=e??{};let{url:n,certhashes:o,remotePeer:s}=Vi(t),i,a,c=()=>{},f=!1,u=!1,l=!1;try{this.metrics?.dialerEvents.increment({pending:!0});let p=new Fu(`${n}/.well-known/libp2p-webtransport?type=noise`,{serverCertificateHashes:o.map(w=>({algorithm:"sha-256",value:w.digest}))});if(c=w=>{if(!f)try{this.metrics?.dialerEvents.increment({[w]:!0}),p.close()}catch(y){this.log.error("error closing wt session",y)}finally{a!=null&&(a.timeline.close=Date.now()),f=!0}},i=()=>{c(u?"noise_timeout":"ready_timeout")},e.signal.addEventListener("abort",i,{once:!0}),this.log("wait for session to be ready"),e.onProgress?.(new qe("webtransport:wait-for-session")),await Promise.race([p.closed,p.ready]),this.log("session became ready"),u=!0,this.metrics?.dialerEvents.increment({ready:!0}),p.closed.catch(w=>{this.log.error("error on remote wt session close",w)}).finally(()=>{c("remote_close")}),l=await xt(this.authenticateWebTransport({wt:p,remotePeer:s,certhashes:o,...e}),e.signal),!l)throw new ze("Failed to authenticate webtransport");return this.metrics?.dialerEvents.increment({open:!0}),a={close:async()=>{this.log("closing webtransport"),c("close")},abort:w=>{this.log("aborting webtransport due to passed err",w),c("abort")},remoteAddr:t,timeline:{open:Date.now()},log:this.components.logger.forComponent("libp2p:webtransport:maconn"),...fo()},await e.upgrader.upgradeOutbound(a,{...e,skipEncryption:!0,muxerFactory:Pu(p,p.incomingBidirectionalStreams.getReader(),this.components.logger,this.config),skipProtection:!0})}catch(p){throw this.log.error("caught wt session err",p),c(l?"upgrade_error":u?"noise_error":"ready_error"),p}finally{i!=null&&e.signal?.removeEventListener("abort",i)}}async authenticateWebTransport({wt:t,remotePeer:e,certhashes:n,onProgress:o,signal:s}){s?.throwIfAborted(),o?.(new qe("webtransport:open-authentication-stream"));let i=await t.createBidirectionalStream(),a=i.writable.getWriter(),c=i.readable.getReader(),f={source:async function*(){for(;;){let p=await c.read();if(p.value!=null&&(yield p.value),p.done)break}}(),sink:async p=>{for await(let w of p){await xt(a.ready,s);let y=w instanceof Uint8Array?w:w.subarray();a.write(y).catch(m=>{this.log.error("could not write chunk during authentication of WebTransport stream",m)})}}},u=bu()(this.components);o?.(new qe("webtransport:secure-outbound-connection"));let{remoteExtensions:l}=await u.secureOutbound(f,{signal:s,remotePeer:e,skipStreamMuxerNegotiation:!0});if(o?.(new qe("webtransport:close-authentication-stream")),a.close().catch(p=>{this.log.error(`Failed to close authentication stream writer: ${p.message}`)}),c.cancel().catch(p=>{this.log.error(`Failed to close authentication stream reader: ${p.message}`)}),!Uu(l?.webtransportCerthashes??[],n.map(p=>p.bytes)))throw new at("Our certhashes are not a subset of the remote's reported certhashes");return!0}createListener(t){return vi(this.components,{...t,certificates:this.config.certificates,maxInboundStreams:this.config.maxInboundStreams})}listenFilter(){return[]}dialFilter(t){return globalThis.WebTransport==null?[]:t.filter(e=>{if(!co.exactMatch(e))return!1;let{url:n,certhashes:o}=Vi(e);return n!=null&&o.length>0})}};function Dd(r={}){return t=>new qi(t,r)}return Qu(Kd);})();
|
|
2
|
+
"use strict";var Libp2PWebtransport=(()=>{var mo=Object.defineProperty;var Zu=Object.getOwnPropertyDescriptor;var Yu=Object.getOwnPropertyNames;var Xu=Object.prototype.hasOwnProperty;var Tt=(r,t)=>{for(var e in t)mo(r,e,{get:t[e],enumerable:!0})},Ju=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of Yu(t))!Xu.call(r,o)&&o!==e&&mo(r,o,{get:()=>t[o],enumerable:!(n=Zu(t,o))||n.enumerable});return r};var Qu=r=>Ju(mo({},"__esModule",{value:!0}),r);var Nd={};Tt(Nd,{webTransport:()=>Kd});var yo=Symbol.for("@libp2p/peer-id");var Gi=Symbol.for("@libp2p/transport");var Fi;(function(r){r[r.FATAL_ALL=0]="FATAL_ALL",r[r.NO_FATAL=1]="NO_FATAL"})(Fi||(Fi={}));var rn=class extends Error{static name="UnexpectedPeerError";constructor(t="Unexpected Peer"){super(t),this.name="UnexpectedPeerError"}},ze=class extends Error{static name="InvalidCryptoExchangeError";constructor(t="Invalid crypto exchange"){super(t),this.name="InvalidCryptoExchangeError"}},at=class extends Error{static name="InvalidParametersError";constructor(t="Invalid parameters"){super(t),this.name="InvalidParametersError"}},Fe=class extends Error{static name="InvalidPublicKeyError";constructor(t="Invalid public key"){super(t),this.name="InvalidPublicKeyError"}};var nn=class extends Error{static name="StreamResetError";constructor(t="The stream has been reset"){super(t),this.name="StreamResetError"}},on=class extends Error{static name="StreamStateError";constructor(t="The stream is in an invalid state"){super(t),this.name="StreamStateError"}};var sn=class extends Error{static name="InvalidMultiaddrError";constructor(t="Invalid multiaddr"){super(t),this.name="InvalidMultiaddrError"}},an=class extends Error{static name="InvalidCIDError";constructor(t="Invalid CID"){super(t),this.name="InvalidCIDError"}},cn=class extends Error{static name="InvalidMultihashError";constructor(t="Invalid Multihash"){super(t),this.name="InvalidMultihashError"}};var ve=class extends Error{static name="UnsupportedKeyTypeError";constructor(t="Unsupported key type"){super(t),this.name="UnsupportedKeyTypeError"}};var un=Symbol.for("@libp2p/service-capabilities"),qd=Symbol.for("@libp2p/service-dependencies");var Eo={};Tt(Eo,{base58btc:()=>nt,base58flickr:()=>af});var lp=new Uint8Array(0);function Wi(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 Jt(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 ji(r){return new TextEncoder().encode(r)}function $i(r){return new TextDecoder().decode(r)}function tf(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 a=r.length,c=r.charAt(0),f=Math.log(a)/Math.log(256),u=Math.log(256)/Math.log(a);function l(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 m=0,x=0,_=0,M=y.length;_!==M&&y[_]===0;)_++,m++;for(var S=(M-_)*u+1>>>0,d=new Uint8Array(S);_!==M;){for(var I=y[_],U=0,B=S-1;(I!==0||U<x)&&B!==-1;B--,U++)I+=256*d[B]>>>0,d[B]=I%a>>>0,I=I/a>>>0;if(I!==0)throw new Error("Non-zero carry");x=U,_++}for(var L=S-x;L!==S&&d[L]===0;)L++;for(var k=c.repeat(m);L<S;++L)k+=r.charAt(d[L]);return k}function p(y){if(typeof y!="string")throw new TypeError("Expected String");if(y.length===0)return new Uint8Array;var m=0;if(y[m]!==" "){for(var x=0,_=0;y[m]===c;)x++,m++;for(var M=(y.length-m)*f+1>>>0,S=new Uint8Array(M);y[m];){var d=e[y.charCodeAt(m)];if(d===255)return;for(var I=0,U=M-1;(d!==0||I<_)&&U!==-1;U--,I++)d+=a*S[U]>>>0,S[U]=d%256>>>0,d=d/256>>>0;if(d!==0)throw new Error("Non-zero carry");_=I,m++}if(y[m]!==" "){for(var B=M-_;B!==M&&S[B]===0;)B++;for(var L=new Uint8Array(x+(M-B)),k=x;B!==M;)L[k++]=S[B++];return L}}}function w(y){var m=p(y);if(m)return m;throw new Error(`Non-${t} character`)}return{encode:l,decodeUnsafe:p,decode:w}}var ef=tf,rf=ef,Yi=rf;var go=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")}},xo=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 Xi(this,t)}},wo=class{decoders;constructor(t){this.decoders=t}or(t){return Xi(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 Xi(r,t){return new wo({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var bo=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 go(t,e,n),this.decoder=new xo(t,e,o)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function Ge({name:r,prefix:t,encode:e,decode:n}){return new bo(r,t,e,n)}function fe({name:r,prefix:t,alphabet:e}){let{encode:n,decode:o}=Yi(e,r);return Ge({prefix:t,name:r,encode:n,decode:s=>Jt(o(s))})}function nf(r,t,e,n){let o=r.length;for(;r[o-1]==="=";)--o;let s=new Uint8Array(o*e/8|0),i=0,a=0,c=0;for(let f=0;f<o;++f){let u=t[r[f]];if(u===void 0)throw new SyntaxError(`Non-${n} character`);a=a<<e|u,i+=e,i>=8&&(i-=8,s[c++]=255&a>>i)}if(i>=e||(255&a<<8-i)!==0)throw new SyntaxError("Unexpected end of data");return s}function of(r,t,e){let n=t[t.length-1]==="=",o=(1<<e)-1,s="",i=0,a=0;for(let c=0;c<r.length;++c)for(a=a<<8|r[c],i+=8;i>e;)i-=e,s+=t[o&a>>i];if(i!==0&&(s+=t[o&a<<e-i]),n)for(;(s.length*e&7)!==0;)s+="=";return s}function sf(r){let t={};for(let e=0;e<r.length;++e)t[r[e]]=e;return t}function ct({name:r,prefix:t,bitsPerChar:e,alphabet:n}){let o=sf(n);return Ge({prefix:t,name:r,encode(s){return of(s,n,e)},decode(s){return nf(s,o,e,r)}})}var nt=fe({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),af=fe({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var So={};Tt(So,{base32:()=>Qt,base32hex:()=>lf,base32hexpad:()=>df,base32hexpadupper:()=>pf,base32hexupper:()=>hf,base32pad:()=>uf,base32padupper:()=>ff,base32upper:()=>cf,base32z:()=>mf});var Qt=ct({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),cf=ct({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),uf=ct({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),ff=ct({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),lf=ct({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),hf=ct({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),df=ct({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),pf=ct({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),mf=ct({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Ao={};Tt(Ao,{base36:()=>gr,base36upper:()=>yf});var gr=fe({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),yf=fe({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Gt={};Tt(Gt,{Digest:()=>Ie,create:()=>Nt,decode:()=>le,equals:()=>Io,hasCode:()=>Df});var gf=ta,Ji=128,xf=127,wf=~xf,bf=Math.pow(2,31);function ta(r,t,e){t=t||[],e=e||0;for(var n=e;r>=bf;)t[e++]=r&255|Ji,r/=128;for(;r&wf;)t[e++]=r&255|Ji,r>>>=7;return t[e]=r|0,ta.bytes=e-n+1,t}var Ef=vo,Sf=128,Qi=127;function vo(r,n){var e=0,n=n||0,o=0,s=n,i,a=r.length;do{if(s>=a)throw vo.bytes=0,new RangeError("Could not decode varint");i=r[s++],e+=o<28?(i&Qi)<<o:(i&Qi)*Math.pow(2,o),o+=7}while(i>=Sf);return vo.bytes=s-n,e}var Af=Math.pow(2,7),vf=Math.pow(2,14),If=Math.pow(2,21),Bf=Math.pow(2,28),_f=Math.pow(2,35),Lf=Math.pow(2,42),Tf=Math.pow(2,49),Cf=Math.pow(2,56),Pf=Math.pow(2,63),Uf=function(r){return r<Af?1:r<vf?2:r<If?3:r<Bf?4:r<_f?5:r<Lf?6:r<Tf?7:r<Cf?8:r<Pf?9:10},kf={encode:gf,decode:Ef,encodingLength:Uf},Rf=kf,xr=Rf;function wr(r,t=0){return[xr.decode(r,t),xr.decode.bytes]}function We(r,t,e=0){return xr.encode(r,t,e),t}function je(r){return xr.encodingLength(r)}function Nt(r,t){let e=t.byteLength,n=je(r),o=n+je(e),s=new Uint8Array(o+e);return We(r,s,0),We(e,s,n),s.set(t,o),new Ie(r,e,t,s)}function le(r){let t=Jt(r),[e,n]=wr(t),[o,s]=wr(t.subarray(n)),i=t.subarray(n+s);if(i.byteLength!==o)throw new Error("Incorrect length");return new Ie(e,o,i,t)}function Io(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&Wi(r.bytes,e.bytes)}}var Ie=class{code;size;digest;bytes;constructor(t,e,n,o){this.code=t,this.size=e,this.digest=n,this.bytes=o}};function Df(r,t){return r.code===t}function ea(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return Nf(e,Bo(r),t??nt.encoder);default:return Mf(e,Bo(r),t??Qt.encoder)}}var ra=new WeakMap;function Bo(r){let t=ra.get(r);if(t==null){let e=new Map;return ra.set(r,e),e}return t}var ut=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!==br)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==Of)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=Nt(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&&Io(t.multihash,n.multihash)}toString(t){return ea(this,t)}toJSON(){return{"/":ea(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??na(n,o,s.bytes))}else if(e[Hf]===!0){let{version:n,multihash:o,code:s}=e,i=le(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!==br)throw new Error(`Version 0 CID must use dag-pb (code: ${br}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let o=na(t,e,n.bytes);return new r(t,e,n,o)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,br,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=Jt(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 Ie(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[l,p]=wr(t.subarray(e));return e+=p,l},o=n(),s=br;if(o===18?(o=0,e=0):s=n(),o!==0&&o!==1)throw new RangeError(`Invalid CID version ${o}`);let i=e,a=n(),c=n(),f=e+c,u=f-i;return{version:o,codec:s,multihashCode:a,digestSize:c,multihashSize:u,size:f}}static parse(t,e){let[n,o]=Kf(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 Bo(s).set(n,t),s}};function Kf(r,t){switch(r[0]){case"Q":{let e=t??nt;return[nt.prefix,e.decode(`${nt.prefix}${r}`)]}case nt.prefix:{let e=t??nt;return[nt.prefix,e.decode(r)]}case Qt.prefix:{let e=t??Qt;return[Qt.prefix,e.decode(r)]}case gr.prefix:{let e=t??gr;return[gr.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 Nf(r,t,e){let{prefix:n}=e;if(n!==nt.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 Mf(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 br=112,Of=18;function na(r,t,e){let n=je(r),o=n+je(t),s=new Uint8Array(o+e.byteLength);return We(r,s,0),We(t,s,n),s.set(e,o),s}var Hf=Symbol.for("@ipld/js-cid/CID");var _o={};Tt(_o,{identity:()=>Ot});var oa=0,Vf="identity",sa=Jt;function qf(r){return Nt(oa,sa(r))}var Ot={code:oa,name:Vf,encode:sa,digest:qf};function ht(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 dt(r=0){return new Uint8Array(r)}function pt(r=0){return new Uint8Array(r)}function At(r,t){t==null&&(t=r.reduce((o,s)=>o+s.length,0));let e=pt(t),n=0;for(let o of r)e.set(o,n),n+=o.length;return e}var aa=Symbol.for("@achingbrain/uint8arraylist");function ia(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 ln(r){return!!r?.[aa]}var $=class r{bufs;length;[aa]=!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(ln(n))e+=n.byteLength,this.bufs.push(...n.bufs);else throw new Error("Could not append value, must be an Uint8Array or a Uint8ArrayList");this.length+=e}prepend(...t){this.prependAll(t)}prependAll(t){let e=0;for(let n of t.reverse())if(n instanceof Uint8Array)e+=n.byteLength,this.bufs.unshift(n);else if(ln(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=ia(this.bufs,t);return e.buf[e.index]}set(t,e){let n=ia(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(ln(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 At(n,o)}subarray(t,e){let{bufs:n,length:o}=this._subList(t,e);return n.length===1?n[0]:At(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],a=o,c=a+i.byteLength;if(o=c,t>=c)continue;let f=t>=a&&t<c,u=e>a&&e<=c;if(f&&u){if(t===a&&e===c){n.push(i);break}let l=t-a;n.push(i.subarray(l,l+(e-t)));break}if(f){if(t===0){n.push(i);continue}n.push(i.subarray(t-a));continue}if(u){if(e===c){n.push(i);break}n.push(i.subarray(0,e-a));break}n.push(i)}return{bufs:n,length:e-t}}indexOf(t,e=0){if(!ln(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 l=0;l<s;l++)i[l]=-1;for(let l=0;l<o;l++)i[n[l]]=l;let a=i,c=this.byteLength-n.byteLength,f=n.byteLength-1,u;for(let l=e;l<=c;l+=u){u=0;for(let p=f;p>=0;p--){let w=this.get(l+p);if(n[p]!==w){u=Math.max(1,p-a[w]);break}}if(u===0)return l}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=pt(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=pt(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(!ht(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 Lo={};Tt(Lo,{base10:()=>Ff});var Ff=fe({prefix:"9",name:"base10",alphabet:"0123456789"});var To={};Tt(To,{base16:()=>Gf,base16upper:()=>Wf});var Gf=ct({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Wf=ct({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Co={};Tt(Co,{base2:()=>jf});var jf=ct({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Po={};Tt(Po,{base256emoji:()=>Jf});var ca=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}"),$f=ca.reduce((r,t,e)=>(r[e]=t,r),[]),Zf=ca.reduce((r,t,e)=>{let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);return r[n]=e,r},[]);function Yf(r){return r.reduce((t,e)=>(t+=$f[e],t),"")}function Xf(r){let t=[];for(let e of r){let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);let o=Zf[n];if(o==null)throw new Error(`Non-base256emoji character: ${e}`);t.push(o)}return new Uint8Array(t)}var Jf=Ge({prefix:"\u{1F680}",name:"base256emoji",encode:Yf,decode:Xf});var ko={};Tt(ko,{base64:()=>Qf,base64pad:()=>tl,base64url:()=>Uo,base64urlpad:()=>el});var Qf=ct({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),tl=ct({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Uo=ct({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),el=ct({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Ro={};Tt(Ro,{base8:()=>rl});var rl=ct({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Do={};Tt(Do,{identity:()=>nl});var nl=Ge({prefix:"\0",name:"identity",encode:r=>$i(r),decode:r=>ji(r)});var jp=new TextEncoder,$p=new TextDecoder;var Mo={};Tt(Mo,{sha256:()=>Er,sha512:()=>il});function No({name:r,code:t,encode:e}){return new Ko(r,t,e)}var Ko=class{name;code;encode;constructor(t,e,n){this.name=t,this.code=e,this.encode=n}digest(t){if(t instanceof Uint8Array){let e=this.encode(t);return e instanceof Uint8Array?Nt(this.code,e):e.then(n=>Nt(this.code,n))}else throw Error("Unknown type, must be binary type")}};function fa(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var Er=No({name:"sha2-256",code:18,encode:fa("SHA-256")}),il=No({name:"sha2-512",code:19,encode:fa("SHA-512")});var Be={...Do,...Co,...Ro,...Lo,...To,...So,...Ao,...Eo,...ko,...Po},i0={...Mo,..._o};function ha(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var la=ha("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),Oo=ha("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=pt(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),al={utf8:la,"utf-8":la,hex:Be.base16,latin1:Oo,ascii:Oo,binary:Oo,...Be},hn=al;function Q(r,t="utf8"){let e=hn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function V(r,t="utf8"){let e=hn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}var cl=parseInt("11111",2),Ho=parseInt("10000000",2),ul=parseInt("01111111",2),da={0:Sr,1:Sr,2:fl,3:dl,4:pl,5:hl,6:ll,16:Sr,22:Sr,48:Sr};function te(r,t={offset:0}){let e=r[t.offset]&cl;if(t.offset++,da[e]!=null)return da[e](r,t);throw new Error("No decoder for tag "+e)}function Ar(r,t){let e=0;if((r[t.offset]&Ho)===Ho){let n=r[t.offset]&ul,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 Sr(r,t){Ar(r,t);let e=[];for(;!(t.offset>=r.byteLength);){let n=te(r,t);if(n===null)break;e.push(n)}return e}function fl(r,t){let e=Ar(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 ll(r,t){let e=Ar(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 a=`${s}.${i}`,c=[];for(;t.offset<n;){let f=r[t.offset];if(t.offset++,c.push(f&127),f<128){c.reverse();let u=0;for(let l=0;l<c.length;l++)u+=c[l]<<l*7;a+=`.${u}`,c=[]}}return a}function hl(r,t){return t.offset++,null}function dl(r,t){let e=Ar(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 pl(r,t){let e=Ar(r,t),n=r.subarray(t.offset,t.offset+e);return t.offset+=e,n}function ml(r){let t=r.toString(16);t.length%2===1&&(t="0"+t);let e=new $;for(let n=0;n<t.length;n+=2)e.append(Uint8Array.from([parseInt(`${t[n]}${t[n+1]}`,16)]));return e}function Vo(r){if(r.byteLength<128)return Uint8Array.from([r.byteLength]);let t=ml(r.byteLength);return new $(Uint8Array.from([t.byteLength|Ho]),t)}function Rt(r){let t=new $,e=128;return(r.subarray()[0]&e)===e&&t.append(Uint8Array.from([0])),t.append(r),new $(Uint8Array.from([2]),Vo(t),t)}function dn(r){let t=Uint8Array.from([0]),e=new $(t,r);return new $(Uint8Array.from([3]),Vo(e),e)}function he(r,t=48){let e=new $;for(let n of r)e.append(n);return new $(Uint8Array.from([t]),Vo(e),e)}async function pa(r,t,e){let n=await crypto.subtle.importKey("jwk",r,{name:"ECDSA",namedCurve:r.crv??"P-256"},!1,["verify"]);return crypto.subtle.verify({name:"ECDSA",hash:{name:"SHA-256"}},n,t,e.subarray())}var yl=Uint8Array.from([6,8,42,134,72,206,61,3,1,7]),gl=Uint8Array.from([6,5,43,129,4,0,34]),xl=Uint8Array.from([6,5,43,129,4,0,35]),wl={ext:!0,kty:"EC",crv:"P-256"},bl={ext:!0,kty:"EC",crv:"P-384"},El={ext:!0,kty:"EC",crv:"P-521"},qo=32,zo=48,Fo=66;function Go(r){let t=te(r);return ma(t)}function ma(r){let t=r[1][1][0],e=1,n,o;if(t.byteLength===qo*2+1)return n=V(t.subarray(e,e+qo),"base64url"),o=V(t.subarray(e+qo),"base64url"),new $e({...wl,key_ops:["verify"],x:n,y:o});if(t.byteLength===zo*2+1)return n=V(t.subarray(e,e+zo),"base64url"),o=V(t.subarray(e+zo),"base64url"),new $e({...bl,key_ops:["verify"],x:n,y:o});if(t.byteLength===Fo*2+1)return n=V(t.subarray(e,e+Fo),"base64url"),o=V(t.subarray(e+Fo),"base64url"),new $e({...El,key_ops:["verify"],x:n,y:o});throw new at(`coordinates were wrong length, got ${t.byteLength}, expected 65, 97 or 133`)}function ya(r){return he([Rt(Uint8Array.from([1])),he([Sl(r.crv)],160),he([dn(new $(Uint8Array.from([4]),Q(r.x??"","base64url"),Q(r.y??"","base64url")))],161)]).subarray()}function Sl(r){if(r==="P-256")return yl;if(r==="P-384")return gl;if(r==="P-521")return xl;throw new at(`Invalid curve ${r}`)}var $e=class{type="ECDSA";jwk;_raw;constructor(t){this.jwk=t}get raw(){return this._raw==null&&(this._raw=ya(this.jwk)),this._raw}toMultihash(){return Ot.digest(de(this))}toCID(){return ut.createV1(114,this.toMultihash())}toString(){return nt.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:ht(this.raw,t.raw)}async verify(t,e){return pa(this.jwk,e,t)}};var _e=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;function Al(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function Ze(r){if(!Number.isSafeInteger(r)||r<0)throw new Error("positive integer expected, got "+r)}function Le(r,...t){if(!Al(r))throw new Error("Uint8Array expected");if(t.length>0&&!t.includes(r.length))throw new Error("Uint8Array expected of length "+t+", got length="+r.length)}function vr(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.createHasher");Ze(r.outputLen),Ze(r.blockLen)}function Xe(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 ga(r,t){Le(r);let e=t.outputLen;if(r.length<e)throw new Error("digestInto() expects output buffer of length at least "+e)}function Ht(...r){for(let t=0;t<r.length;t++)r[t].fill(0)}function pn(r){return new DataView(r.buffer,r.byteOffset,r.byteLength)}function Vt(r,t){return r<<32-t|r>>>t}function xa(r){if(typeof r!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(r))}function pe(r){return typeof r=="string"&&(r=xa(r)),Le(r),r}function Wo(...r){let t=0;for(let n=0;n<r.length;n++){let o=r[n];Le(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}var Ye=class{};function jo(r){let t=n=>r().update(pe(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function Ir(r=32){if(_e&&typeof _e.getRandomValues=="function")return _e.getRandomValues(new Uint8Array(r));if(_e&&typeof _e.randomBytes=="function")return Uint8Array.from(_e.randomBytes(r));throw new Error("crypto.getRandomValues must be defined")}function vl(r,t,e,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(t,e,n);let o=BigInt(32),s=BigInt(4294967295),i=Number(e>>o&s),a=Number(e&s),c=n?4:0,f=n?0:4;r.setUint32(t+c,i,n),r.setUint32(t+f,a,n)}function wa(r,t,e){return r&t^~r&e}function ba(r,t,e){return r&t^r&e^t&e}var Br=class extends Ye{constructor(t,e,n,o){super(),this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.blockLen=t,this.outputLen=e,this.padOffset=n,this.isLE=o,this.buffer=new Uint8Array(t),this.view=pn(this.buffer)}update(t){Xe(this),t=pe(t),Le(t);let{view:e,buffer:n,blockLen:o}=this,s=t.length;for(let i=0;i<s;){let a=Math.min(o-this.pos,s-i);if(a===o){let c=pn(t);for(;o<=s-i;i+=o)this.process(c,i);continue}n.set(t.subarray(i,i+a),this.pos),this.pos+=a,i+=a,this.pos===o&&(this.process(e,0),this.pos=0)}return this.length+=t.length,this.roundClean(),this}digestInto(t){Xe(this),ga(t,this),this.finished=!0;let{buffer:e,view:n,blockLen:o,isLE:s}=this,{pos:i}=this;e[i++]=128,Ht(this.buffer.subarray(i)),this.padOffset>o-i&&(this.process(n,0),i=0);for(let l=i;l<o;l++)e[l]=0;vl(n,o-8,BigInt(this.length*8),s),this.process(n,0);let a=pn(t),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let f=c/4,u=this.get();if(f>u.length)throw new Error("_sha2: outputLen bigger than state");for(let l=0;l<f;l++)a.setUint32(4*l,u[l],s)}digest(){let{buffer:t,outputLen:e}=this;this.digestInto(t);let n=t.slice(0,e);return this.destroy(),n}_cloneInto(t){t||(t=new this.constructor),t.set(...this.get());let{blockLen:e,buffer:n,length:o,finished:s,destroyed:i,pos:a}=this;return t.destroyed=i,t.finished=s,t.length=o,t.pos=a,o%e&&t.buffer.set(n),t}clone(){return this._cloneInto()}},ee=Uint32Array.from([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]);var bt=Uint32Array.from([1779033703,4089235720,3144134277,2227873595,1013904242,4271175723,2773480762,1595750129,1359893119,2917565137,2600822924,725511199,528734635,4215389547,1541459225,327033209]);var mn=BigInt(4294967295),Ea=BigInt(32);function Il(r,t=!1){return t?{h:Number(r&mn),l:Number(r>>Ea&mn)}:{h:Number(r>>Ea&mn)|0,l:Number(r&mn)|0}}function Sa(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:a}=Il(r[s],t);[n[s],o[s]]=[i,a]}return[n,o]}var $o=(r,t,e)=>r>>>e,Zo=(r,t,e)=>r<<32-e|t>>>e,Te=(r,t,e)=>r>>>e|t<<32-e,Ce=(r,t,e)=>r<<32-e|t>>>e,_r=(r,t,e)=>r<<64-e|t>>>e-32,Lr=(r,t,e)=>r>>>e-32|t<<64-e;function Wt(r,t,e,n){let o=(t>>>0)+(n>>>0);return{h:r+e+(o/2**32|0)|0,l:o|0}}var Aa=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),va=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,Ia=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),Ba=(r,t,e,n,o)=>t+e+n+o+(r/2**32|0)|0,_a=(r,t,e,n,o)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(o>>>0),La=(r,t,e,n,o,s)=>t+e+n+o+s+(r/2**32|0)|0;var _l=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]),me=new Uint32Array(64),yn=class extends Br{constructor(t=32){super(64,t,8,!1),this.A=ee[0]|0,this.B=ee[1]|0,this.C=ee[2]|0,this.D=ee[3]|0,this.E=ee[4]|0,this.F=ee[5]|0,this.G=ee[6]|0,this.H=ee[7]|0}get(){let{A:t,B:e,C:n,D:o,E:s,F:i,G:a,H:c}=this;return[t,e,n,o,s,i,a,c]}set(t,e,n,o,s,i,a,c){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=a|0,this.H=c|0}process(t,e){for(let l=0;l<16;l++,e+=4)me[l]=t.getUint32(e,!1);for(let l=16;l<64;l++){let p=me[l-15],w=me[l-2],y=Vt(p,7)^Vt(p,18)^p>>>3,m=Vt(w,17)^Vt(w,19)^w>>>10;me[l]=m+me[l-7]+y+me[l-16]|0}let{A:n,B:o,C:s,D:i,E:a,F:c,G:f,H:u}=this;for(let l=0;l<64;l++){let p=Vt(a,6)^Vt(a,11)^Vt(a,25),w=u+p+wa(a,c,f)+_l[l]+me[l]|0,m=(Vt(n,2)^Vt(n,13)^Vt(n,22))+ba(n,o,s)|0;u=f,f=c,c=a,a=i+w|0,i=s,s=o,o=n,n=w+m|0}n=n+this.A|0,o=o+this.B|0,s=s+this.C|0,i=i+this.D|0,a=a+this.E|0,c=c+this.F|0,f=f+this.G|0,u=u+this.H|0,this.set(n,o,s,i,a,c,f,u)}roundClean(){Ht(me)}destroy(){this.set(0,0,0,0,0,0,0,0),Ht(this.buffer)}};var Ta=Sa(["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))),Ll=Ta[0],Tl=Ta[1],ye=new Uint32Array(80),ge=new Uint32Array(80),Yo=class extends Br{constructor(t=64){super(128,t,16,!1),this.Ah=bt[0]|0,this.Al=bt[1]|0,this.Bh=bt[2]|0,this.Bl=bt[3]|0,this.Ch=bt[4]|0,this.Cl=bt[5]|0,this.Dh=bt[6]|0,this.Dl=bt[7]|0,this.Eh=bt[8]|0,this.El=bt[9]|0,this.Fh=bt[10]|0,this.Fl=bt[11]|0,this.Gh=bt[12]|0,this.Gl=bt[13]|0,this.Hh=bt[14]|0,this.Hl=bt[15]|0}get(){let{Ah:t,Al:e,Bh:n,Bl:o,Ch:s,Cl:i,Dh:a,Dl:c,Eh:f,El:u,Fh:l,Fl:p,Gh:w,Gl:y,Hh:m,Hl:x}=this;return[t,e,n,o,s,i,a,c,f,u,l,p,w,y,m,x]}set(t,e,n,o,s,i,a,c,f,u,l,p,w,y,m,x){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=a|0,this.Dl=c|0,this.Eh=f|0,this.El=u|0,this.Fh=l|0,this.Fl=p|0,this.Gh=w|0,this.Gl=y|0,this.Hh=m|0,this.Hl=x|0}process(t,e){for(let S=0;S<16;S++,e+=4)ye[S]=t.getUint32(e),ge[S]=t.getUint32(e+=4);for(let S=16;S<80;S++){let d=ye[S-15]|0,I=ge[S-15]|0,U=Te(d,I,1)^Te(d,I,8)^$o(d,I,7),B=Ce(d,I,1)^Ce(d,I,8)^Zo(d,I,7),L=ye[S-2]|0,k=ge[S-2]|0,K=Te(L,k,19)^_r(L,k,61)^$o(L,k,6),T=Ce(L,k,19)^Lr(L,k,61)^Zo(L,k,6),D=Ia(B,T,ge[S-7],ge[S-16]),C=Ba(D,U,K,ye[S-7],ye[S-16]);ye[S]=C|0,ge[S]=D|0}let{Ah:n,Al:o,Bh:s,Bl:i,Ch:a,Cl:c,Dh:f,Dl:u,Eh:l,El:p,Fh:w,Fl:y,Gh:m,Gl:x,Hh:_,Hl:M}=this;for(let S=0;S<80;S++){let d=Te(l,p,14)^Te(l,p,18)^_r(l,p,41),I=Ce(l,p,14)^Ce(l,p,18)^Lr(l,p,41),U=l&w^~l&m,B=p&y^~p&x,L=_a(M,I,B,Tl[S],ge[S]),k=La(L,_,d,U,Ll[S],ye[S]),K=L|0,T=Te(n,o,28)^_r(n,o,34)^_r(n,o,39),D=Ce(n,o,28)^Lr(n,o,34)^Lr(n,o,39),C=n&s^n&a^s&a,H=o&i^o&c^i&c;_=m|0,M=x|0,m=w|0,x=y|0,w=l|0,y=p|0,{h:l,l:p}=Wt(f|0,u|0,k|0,K|0),f=a|0,u=c|0,a=s|0,c=i|0,s=n|0,i=o|0;let E=Aa(K,D,H);n=va(E,k,T,C),o=E|0}({h:n,l:o}=Wt(this.Ah|0,this.Al|0,n|0,o|0)),{h:s,l:i}=Wt(this.Bh|0,this.Bl|0,s|0,i|0),{h:a,l:c}=Wt(this.Ch|0,this.Cl|0,a|0,c|0),{h:f,l:u}=Wt(this.Dh|0,this.Dl|0,f|0,u|0),{h:l,l:p}=Wt(this.Eh|0,this.El|0,l|0,p|0),{h:w,l:y}=Wt(this.Fh|0,this.Fl|0,w|0,y|0),{h:m,l:x}=Wt(this.Gh|0,this.Gl|0,m|0,x|0),{h:_,l:M}=Wt(this.Hh|0,this.Hl|0,_|0,M|0),this.set(n,o,s,i,a,c,f,u,l,p,w,y,m,x,_,M)}roundClean(){Ht(ye,ge)}destroy(){Ht(this.buffer),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}};var gn=jo(()=>new yn);var Ca=jo(()=>new Yo);var ts=BigInt(0),Qo=BigInt(1);function Je(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function es(r){if(!Je(r))throw new Error("Uint8Array expected")}function jt(r,t){if(typeof t!="boolean")throw new Error(r+" boolean expected, got "+t)}function Tr(r){let t=r.toString(16);return t.length&1?"0"+t:t}function ka(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return r===""?ts:BigInt("0x"+r)}var Ra=typeof Uint8Array.from([]).toHex=="function"&&typeof Uint8Array.fromHex=="function",Cl=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function xe(r){if(es(r),Ra)return r.toHex();let t="";for(let e=0;e<r.length;e++)t+=Cl[r[e]];return t}var re={_0:48,_9:57,A:65,F:70,a:97,f:102};function Pa(r){if(r>=re._0&&r<=re._9)return r-re._0;if(r>=re.A&&r<=re.F)return r-(re.A-10);if(r>=re.a&&r<=re.f)return r-(re.a-10)}function Cr(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);if(Ra)return Uint8Array.fromHex(r);let t=r.length,e=t/2;if(t%2)throw new Error("hex string expected, got unpadded hex of length "+t);let n=new Uint8Array(e);for(let o=0,s=0;o<e;o++,s+=2){let i=Pa(r.charCodeAt(s)),a=Pa(r.charCodeAt(s+1));if(i===void 0||a===void 0){let c=r[s]+r[s+1];throw new Error('hex string expected, got non-hex character "'+c+'" at index '+s)}n[o]=i*16+a}return n}function ne(r){return ka(xe(r))}function $t(r){return es(r),ka(xe(Uint8Array.from(r).reverse()))}function Pe(r,t){return Cr(r.toString(16).padStart(t*2,"0"))}function we(r,t){return Pe(r,t).reverse()}function ot(r,t,e){let n;if(typeof t=="string")try{n=Cr(t)}catch(s){throw new Error(r+" must be hex string or Uint8Array, cause: "+s)}else if(Je(t))n=Uint8Array.from(t);else throw new Error(r+" must be hex string or Uint8Array");let o=n.length;if(typeof e=="number"&&o!==e)throw new Error(r+" of length "+e+" expected, got "+o);return n}function be(...r){let t=0;for(let n=0;n<r.length;n++){let o=r[n];es(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}var Xo=r=>typeof r=="bigint"&&ts<=r;function xn(r,t,e){return Xo(r)&&Xo(t)&&Xo(e)&&t<=r&&r<e}function vt(r,t,e,n){if(!xn(t,e,n))throw new Error("expected valid "+r+": "+e+" <= n < "+n+", got "+t)}function Da(r){let t;for(t=0;r>ts;r>>=Qo,t+=1);return t}var Ue=r=>(Qo<<BigInt(r))-Qo,Jo=r=>new Uint8Array(r),Ua=r=>Uint8Array.from(r);function Ka(r,t,e){if(typeof r!="number"||r<2)throw new Error("hashLen must be a number");if(typeof t!="number"||t<2)throw new Error("qByteLen must be a number");if(typeof e!="function")throw new Error("hmacFn must be a function");let n=Jo(r),o=Jo(r),s=0,i=()=>{n.fill(1),o.fill(0),s=0},a=(...l)=>e(o,n,...l),c=(l=Jo(0))=>{o=a(Ua([0]),l),n=a(),l.length!==0&&(o=a(Ua([1]),l),n=a())},f=()=>{if(s++>=1e3)throw new Error("drbg: tried 1000 values");let l=0,p=[];for(;l<t;){n=a();let w=n.slice();p.push(w),l+=n.length}return be(...p)};return(l,p)=>{i(),c(l);let w;for(;!(w=p(f()));)c();return i(),w}}var Pl={bigint:r=>typeof r=="bigint",function:r=>typeof r=="function",boolean:r=>typeof r=="boolean",string:r=>typeof r=="string",stringOrUint8Array:r=>typeof r=="string"||Je(r),isSafeInteger:r=>Number.isSafeInteger(r),array:r=>Array.isArray(r),field:(r,t)=>t.Fp.isValid(r),hash:r=>typeof r=="function"&&Number.isSafeInteger(r.outputLen)};function qt(r,t,e={}){let n=(o,s,i)=>{let a=Pl[s];if(typeof a!="function")throw new Error("invalid validator function");let c=r[o];if(!(i&&c===void 0)&&!a(c,r))throw new Error("param "+String(o)+" is invalid. Expected "+s+", got "+c)};for(let[o,s]of Object.entries(t))n(o,s,!1);for(let[o,s]of Object.entries(e))n(o,s,!0);return r}function Qe(r){let t=new WeakMap;return(e,...n)=>{let o=t.get(e);if(o!==void 0)return o;let s=r(e,...n);return t.set(e,s),s}}var Ct=BigInt(0),yt=BigInt(1),ke=BigInt(2),Ul=BigInt(3),Ma=BigInt(4),Oa=BigInt(5),Ha=BigInt(8);function Y(r,t){let e=r%t;return e>=Ct?e:t+e}function st(r,t,e){let n=r;for(;t-- >Ct;)n*=n,n%=e;return n}function wn(r,t){if(r===Ct)throw new Error("invert: expected non-zero number");if(t<=Ct)throw new Error("invert: expected positive modulus, got "+t);let e=Y(r,t),n=t,o=Ct,s=yt,i=yt,a=Ct;for(;e!==Ct;){let f=n/e,u=n%e,l=o-i*f,p=s-a*f;n=e,e=u,o=i,s=a,i=l,a=p}if(n!==yt)throw new Error("invert: does not exist");return Y(o,t)}function Va(r,t){let e=(r.ORDER+yt)/Ma,n=r.pow(t,e);if(!r.eql(r.sqr(n),t))throw new Error("Cannot find square root");return n}function kl(r,t){let e=(r.ORDER-Oa)/Ha,n=r.mul(t,ke),o=r.pow(n,e),s=r.mul(t,o),i=r.mul(r.mul(s,ke),o),a=r.mul(s,r.sub(i,r.ONE));if(!r.eql(r.sqr(a),t))throw new Error("Cannot find square root");return a}function Rl(r){if(r<BigInt(3))throw new Error("sqrt is not defined for small field");let t=r-yt,e=0;for(;t%ke===Ct;)t/=ke,e++;let n=ke,o=oe(r);for(;Na(o,n)===1;)if(n++>1e3)throw new Error("Cannot find square root: probably non-prime P");if(e===1)return Va;let s=o.pow(n,t),i=(t+yt)/ke;return function(c,f){if(c.is0(f))return f;if(Na(c,f)!==1)throw new Error("Cannot find square root");let u=e,l=c.mul(c.ONE,s),p=c.pow(f,t),w=c.pow(f,i);for(;!c.eql(p,c.ONE);){if(c.is0(p))return c.ZERO;let y=1,m=c.sqr(p);for(;!c.eql(m,c.ONE);)if(y++,m=c.sqr(m),y===u)throw new Error("Cannot find square root");let x=yt<<BigInt(u-y-1),_=c.pow(l,x);u=y,l=c.sqr(_),p=c.mul(p,l),w=c.mul(w,_)}return w}}function Dl(r){return r%Ma===Ul?Va:r%Ha===Oa?kl:Rl(r)}var qa=(r,t)=>(Y(r,t)&yt)===yt,Kl=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function rs(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=Kl.reduce((n,o)=>(n[o]="function",n),t);return qt(r,e)}function Nl(r,t,e){if(e<Ct)throw new Error("invalid exponent, negatives unsupported");if(e===Ct)return r.ONE;if(e===yt)return t;let n=r.ONE,o=t;for(;e>Ct;)e&yt&&(n=r.mul(n,o)),o=r.sqr(o),e>>=yt;return n}function tr(r,t,e=!1){let n=new Array(t.length).fill(e?r.ZERO:void 0),o=t.reduce((i,a,c)=>r.is0(a)?i:(n[c]=i,r.mul(i,a)),r.ONE),s=r.inv(o);return t.reduceRight((i,a,c)=>r.is0(a)?i:(n[c]=r.mul(i,n[c]),r.mul(i,a)),s),n}function Na(r,t){let e=(r.ORDER-yt)/ke,n=r.pow(t,e),o=r.eql(n,r.ONE),s=r.eql(n,r.ZERO),i=r.eql(n,r.neg(r.ONE));if(!o&&!s&&!i)throw new Error("invalid Legendre symbol result");return o?1:s?0:-1}function ns(r,t){t!==void 0&&Ze(t);let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function oe(r,t,e=!1,n={}){if(r<=Ct)throw new Error("invalid field: expected ORDER > 0, got "+r);let{nBitLength:o,nByteLength:s}=ns(r,t);if(s>2048)throw new Error("invalid field: expected ORDER of <= 2048 bytes");let i,a=Object.freeze({ORDER:r,isLE:e,BITS:o,BYTES:s,MASK:Ue(o),ZERO:Ct,ONE:yt,create:c=>Y(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error("invalid field element: expected bigint, got "+typeof c);return Ct<=c&&c<r},is0:c=>c===Ct,isOdd:c=>(c&yt)===yt,neg:c=>Y(-c,r),eql:(c,f)=>c===f,sqr:c=>Y(c*c,r),add:(c,f)=>Y(c+f,r),sub:(c,f)=>Y(c-f,r),mul:(c,f)=>Y(c*f,r),pow:(c,f)=>Nl(a,c,f),div:(c,f)=>Y(c*wn(f,r),r),sqrN:c=>c*c,addN:(c,f)=>c+f,subN:(c,f)=>c-f,mulN:(c,f)=>c*f,inv:c=>wn(c,r),sqrt:n.sqrt||(c=>(i||(i=Dl(r)),i(a,c))),toBytes:c=>e?we(c,s):Pe(c,s),fromBytes:c=>{if(c.length!==s)throw new Error("Field.fromBytes: expected "+s+" bytes, got "+c.length);return e?$t(c):ne(c)},invertBatch:c=>tr(a,c),cmov:(c,f,u)=>u?f:c});return Object.freeze(a)}function za(r){if(typeof r!="bigint")throw new Error("field order must be bigint");let t=r.toString(2).length;return Math.ceil(t/8)}function os(r){let t=za(r);return t+Math.ceil(t/2)}function Fa(r,t,e=!1){let n=r.length,o=za(t),s=os(t);if(n<16||n<s||n>1024)throw new Error("expected "+s+"-1024 bytes of input, got "+n);let i=e?$t(r):ne(r),a=Y(i,t-yt)+yt;return e?we(a,o):Pe(a,o)}var Ga=BigInt(0),us=BigInt(1);function ss(r,t){let e=t.negate();return r?e:t}function ja(r,t){if(!Number.isSafeInteger(r)||r<=0||r>t)throw new Error("invalid window size, expected [1.."+t+"], got W="+r)}function is(r,t){ja(r,t);let e=Math.ceil(t/r)+1,n=2**(r-1),o=2**r,s=Ue(r),i=BigInt(r);return{windows:e,windowSize:n,mask:s,maxNumber:o,shiftBy:i}}function Wa(r,t,e){let{windowSize:n,mask:o,maxNumber:s,shiftBy:i}=e,a=Number(r&o),c=r>>i;a>n&&(a-=s,c+=us);let f=t*n,u=f+Math.abs(a)-1,l=a===0,p=a<0,w=t%2!==0;return{nextN:c,offset:u,isZero:l,isNeg:p,isNegF:w,offsetF:f}}function Ml(r,t){if(!Array.isArray(r))throw new Error("array expected");r.forEach((e,n)=>{if(!(e instanceof t))throw new Error("invalid point at index "+n)})}function Ol(r,t){if(!Array.isArray(r))throw new Error("array of scalars expected");r.forEach((e,n)=>{if(!t.isValid(e))throw new Error("invalid scalar at index "+n)})}var as=new WeakMap,$a=new WeakMap;function cs(r){return $a.get(r)||1}function bn(r,t){return{constTimeNegate:ss,hasPrecomputes(e){return cs(e)!==1},unsafeLadder(e,n,o=r.ZERO){let s=e;for(;n>Ga;)n&us&&(o=o.add(s)),s=s.double(),n>>=us;return o},precomputeWindow(e,n){let{windows:o,windowSize:s}=is(n,t),i=[],a=e,c=a;for(let f=0;f<o;f++){c=a,i.push(c);for(let u=1;u<s;u++)c=c.add(a),i.push(c);a=c.double()}return i},wNAF(e,n,o){let s=r.ZERO,i=r.BASE,a=is(e,t);for(let c=0;c<a.windows;c++){let{nextN:f,offset:u,isZero:l,isNeg:p,isNegF:w,offsetF:y}=Wa(o,c,a);o=f,l?i=i.add(ss(w,n[y])):s=s.add(ss(p,n[u]))}return{p:s,f:i}},wNAFUnsafe(e,n,o,s=r.ZERO){let i=is(e,t);for(let a=0;a<i.windows&&o!==Ga;a++){let{nextN:c,offset:f,isZero:u,isNeg:l}=Wa(o,a,i);if(o=c,!u){let p=n[f];s=s.add(l?p.negate():p)}}return s},getPrecomputes(e,n,o){let s=as.get(n);return s||(s=this.precomputeWindow(n,e),e!==1&&as.set(n,o(s))),s},wNAFCached(e,n,o){let s=cs(e);return this.wNAF(s,this.getPrecomputes(s,e,o),n)},wNAFCachedUnsafe(e,n,o,s){let i=cs(e);return i===1?this.unsafeLadder(e,n,s):this.wNAFUnsafe(i,this.getPrecomputes(i,e,o),n,s)},setWindowSize(e,n){ja(n,t),$a.set(e,n),as.delete(e)}}}function En(r,t,e,n){Ml(e,r),Ol(n,t);let o=e.length,s=n.length;if(o!==s)throw new Error("arrays of points and scalars must have equal length");let i=r.ZERO,a=Da(BigInt(o)),c=1;a>12?c=a-3:a>4?c=a-2:a>0&&(c=2);let f=Ue(c),u=new Array(Number(f)+1).fill(i),l=Math.floor((t.BITS-1)/c)*c,p=i;for(let w=l;w>=0;w-=c){u.fill(i);for(let m=0;m<s;m++){let x=n[m],_=Number(x>>BigInt(w)&f);u[_]=u[_].add(e[m])}let y=i;for(let m=u.length-1,x=i;m>0;m--)x=x.add(u[m]),y=y.add(x);if(p=p.add(y),w!==0)for(let m=0;m<c;m++)p=p.double()}return p}function Pr(r){return rs(r.Fp),qt(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...ns(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Zt=BigInt(0),Pt=BigInt(1),Za=BigInt(2),Hl=BigInt(8),Vl={zip215:!0};function ql(r){let t=Pr(r);return qt(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function Ya(r){let t=ql(r),{Fp:e,n,prehash:o,hash:s,randomBytes:i,nByteLength:a,h:c}=t,f=Za<<BigInt(a*8)-Pt,u=e.create,l=oe(t.n,t.nBitLength);function p(b,h){let g=e.sqr(b),v=e.sqr(h),R=e.add(e.mul(t.a,g),v),O=e.add(e.ONE,e.mul(t.d,e.mul(g,v)));return e.eql(R,O)}if(!p(t.Gx,t.Gy))throw new Error("bad curve params: generator point");let w=t.uvRatio||((b,h)=>{try{return{isValid:!0,value:e.sqrt(b*e.inv(h))}}catch{return{isValid:!1,value:Zt}}}),y=t.adjustScalarBytes||(b=>b),m=t.domain||((b,h,g)=>{if(jt("phflag",g),h.length||g)throw new Error("Contexts/pre-hash are not supported");return b});function x(b,h,g=!1){let v=g?Pt:Zt;vt("coordinate "+b,h,v,f)}function _(b){if(!(b instanceof d))throw new Error("ExtendedPoint expected")}let M=Qe((b,h)=>{let{ex:g,ey:v,ez:R}=b,O=b.is0();h==null&&(h=O?Hl:e.inv(R));let q=u(g*h),z=u(v*h),F=u(R*h);if(O)return{x:Zt,y:Pt};if(F!==Pt)throw new Error("invZ was invalid");return{x:q,y:z}}),S=Qe(b=>{let{a:h,d:g}=t;if(b.is0())throw new Error("bad point: ZERO");let{ex:v,ey:R,ez:O,et:q}=b,z=u(v*v),F=u(R*R),G=u(O*O),J=u(G*G),Z=u(z*h),wt=u(G*u(Z+F)),kt=u(J+u(g*u(z*F)));if(wt!==kt)throw new Error("bad point: equation left != right (1)");let mt=u(v*R),St=u(O*q);if(mt!==St)throw new Error("bad point: equation left != right (2)");return!0});class d{constructor(h,g,v,R){x("x",h),x("y",g),x("z",v,!0),x("t",R),this.ex=h,this.ey=g,this.ez=v,this.et=R,Object.freeze(this)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(h){if(h instanceof d)throw new Error("extended point not allowed");let{x:g,y:v}=h||{};return x("x",g),x("y",v),new d(g,v,Pt,u(g*v))}static normalizeZ(h){let g=tr(e,h.map(v=>v.ez));return h.map((v,R)=>v.toAffine(g[R])).map(d.fromAffine)}static msm(h,g){return En(d,l,h,g)}_setWindowSize(h){B.setWindowSize(this,h)}assertValidity(){S(this)}equals(h){_(h);let{ex:g,ey:v,ez:R}=this,{ex:O,ey:q,ez:z}=h,F=u(g*z),G=u(O*R),J=u(v*z),Z=u(q*R);return F===G&&J===Z}is0(){return this.equals(d.ZERO)}negate(){return new d(u(-this.ex),this.ey,this.ez,u(-this.et))}double(){let{a:h}=t,{ex:g,ey:v,ez:R}=this,O=u(g*g),q=u(v*v),z=u(Za*u(R*R)),F=u(h*O),G=g+v,J=u(u(G*G)-O-q),Z=F+q,wt=Z-z,kt=F-q,mt=u(J*wt),St=u(Z*kt),Dt=u(J*kt),Mt=u(wt*Z);return new d(mt,St,Mt,Dt)}add(h){_(h);let{a:g,d:v}=t,{ex:R,ey:O,ez:q,et:z}=this,{ex:F,ey:G,ez:J,et:Z}=h,wt=u(R*F),kt=u(O*G),mt=u(z*v*Z),St=u(q*J),Dt=u((R+O)*(F+G)-wt-kt),Mt=St-mt,yr=St+mt,zi=u(kt-g*wt),Gu=u(Dt*Mt),Wu=u(yr*zi),ju=u(Dt*zi),$u=u(Mt*yr);return new d(Gu,Wu,$u,ju)}subtract(h){return this.add(h.negate())}wNAF(h){return B.wNAFCached(this,h,d.normalizeZ)}multiply(h){let g=h;vt("scalar",g,Pt,n);let{p:v,f:R}=this.wNAF(g);return d.normalizeZ([v,R])[0]}multiplyUnsafe(h,g=d.ZERO){let v=h;return vt("scalar",v,Zt,n),v===Zt?U:this.is0()||v===Pt?this:B.wNAFCachedUnsafe(this,v,d.normalizeZ,g)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return B.unsafeLadder(this,n).is0()}toAffine(h){return M(this,h)}clearCofactor(){let{h}=t;return h===Pt?this:this.multiplyUnsafe(h)}static fromHex(h,g=!1){let{d:v,a:R}=t,O=e.BYTES;h=ot("pointHex",h,O),jt("zip215",g);let q=h.slice(),z=h[O-1];q[O-1]=z&-129;let F=$t(q),G=g?f:e.ORDER;vt("pointHex.y",F,Zt,G);let J=u(F*F),Z=u(J-Pt),wt=u(v*J-R),{isValid:kt,value:mt}=w(Z,wt);if(!kt)throw new Error("Point.fromHex: invalid y coordinate");let St=(mt&Pt)===Pt,Dt=(z&128)!==0;if(!g&&mt===Zt&&Dt)throw new Error("Point.fromHex: x=0 and x_0=1");return Dt!==St&&(mt=u(-mt)),d.fromAffine({x:mt,y:F})}static fromPrivateKey(h){let{scalar:g}=K(h);return I.multiply(g)}toRawBytes(){let{x:h,y:g}=this.toAffine(),v=we(g,e.BYTES);return v[v.length-1]|=h&Pt?128:0,v}toHex(){return xe(this.toRawBytes())}}d.BASE=new d(t.Gx,t.Gy,Pt,u(t.Gx*t.Gy)),d.ZERO=new d(Zt,Pt,Pt,Zt);let{BASE:I,ZERO:U}=d,B=bn(d,a*8);function L(b){return Y(b,n)}function k(b){return L($t(b))}function K(b){let h=e.BYTES;b=ot("private key",b,h);let g=ot("hashed private key",s(b),2*h),v=y(g.slice(0,h)),R=g.slice(h,2*h),O=k(v);return{head:v,prefix:R,scalar:O}}function T(b){let{head:h,prefix:g,scalar:v}=K(b),R=I.multiply(v),O=R.toRawBytes();return{head:h,prefix:g,scalar:v,point:R,pointBytes:O}}function D(b){return T(b).pointBytes}function C(b=Uint8Array.of(),...h){let g=be(...h);return k(s(m(g,ot("context",b),!!o)))}function H(b,h,g={}){b=ot("message",b),o&&(b=o(b));let{prefix:v,scalar:R,pointBytes:O}=T(h),q=C(g.context,v,b),z=I.multiply(q).toRawBytes(),F=C(g.context,z,O,b),G=L(q+F*R);vt("signature.s",G,Zt,n);let J=be(z,we(G,e.BYTES));return ot("result",J,e.BYTES*2)}let E=Vl;function A(b,h,g,v=E){let{context:R,zip215:O}=v,q=e.BYTES;b=ot("signature",b,2*q),h=ot("message",h),g=ot("publicKey",g,q),O!==void 0&&jt("zip215",O),o&&(h=o(h));let z=$t(b.slice(q,2*q)),F,G,J;try{F=d.fromHex(g,O),G=d.fromHex(b.slice(0,q),O),J=I.multiplyUnsafe(z)}catch{return!1}if(!O&&F.isSmallOrder())return!1;let Z=C(R,G.toRawBytes(),F.toRawBytes(),h);return G.add(F.multiplyUnsafe(Z)).subtract(J).clearCofactor().equals(d.ZERO)}return I._setWindowSize(8),{CURVE:t,getPublicKey:D,sign:H,verify:A,ExtendedPoint:d,utils:{getExtendedPublicKey:T,randomPrivateKey:()=>i(e.BYTES),precompute(b=8,h=d.BASE){return h._setWindowSize(b),h.multiply(BigInt(3)),h}}}}var Ur=BigInt(0),er=BigInt(1),Sn=BigInt(2);function zl(r){return qt(r,{adjustScalarBytes:"function",powPminus2:"function"}),Object.freeze({...r})}function Xa(r){let t=zl(r),{P:e,type:n,adjustScalarBytes:o,powPminus2:s}=t,i=n==="x25519";if(!i&&n!=="x448")throw new Error("invalid type");let a=i?255:448,c=i?32:56,f=BigInt(i?9:5),u=BigInt(i?121665:39081),l=i?Sn**BigInt(254):Sn**BigInt(447),p=i?BigInt(8)*Sn**BigInt(251)-er:BigInt(4)*Sn**BigInt(445)-er,w=l+p+er,y=B=>Y(B,e),m=x(f);function x(B){return we(y(B),c)}function _(B){let L=ot("u coordinate",B,c);return i&&(L[31]&=127),y($t(L))}function M(B){return $t(o(ot("scalar",B,c)))}function S(B,L){let k=U(_(L),M(B));if(k===Ur)throw new Error("invalid private or public key received");return x(k)}function d(B){return S(B,m)}function I(B,L,k){let K=y(B*(L-k));return L=y(L-K),k=y(k+K),{x_2:L,x_3:k}}function U(B,L){vt("u",B,Ur,e),vt("scalar",L,l,w);let k=L,K=B,T=er,D=Ur,C=B,H=er,E=Ur;for(let P=BigInt(a-1);P>=Ur;P--){let b=k>>P&er;E^=b,{x_2:T,x_3:C}=I(E,T,C),{x_2:D,x_3:H}=I(E,D,H),E=b;let h=T+D,g=y(h*h),v=T-D,R=y(v*v),O=g-R,q=C+H,z=C-H,F=y(z*h),G=y(q*v),J=F+G,Z=F-G;C=y(J*J),H=y(K*y(Z*Z)),T=y(g*R),D=y(O*(g+y(u*O)))}({x_2:T,x_3:C}=I(E,T,C)),{x_2:D,x_3:H}=I(E,D,H);let A=s(D);return y(T*A)}return{scalarMult:S,scalarMultBase:d,getSharedSecret:(B,L)=>S(B,L),getPublicKey:B=>d(B),utils:{randomPrivateKey:()=>t.randomBytes(c)},GuBytes:m.slice()}}var kr=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),Ja=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),dm=BigInt(0),Fl=BigInt(1),Qa=BigInt(2),Gl=BigInt(3),Wl=BigInt(5),jl=BigInt(8);function ec(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),o=BigInt(80),s=kr,a=r*r%s*r%s,c=st(a,Qa,s)*a%s,f=st(c,Fl,s)*r%s,u=st(f,Wl,s)*f%s,l=st(u,t,s)*u%s,p=st(l,e,s)*l%s,w=st(p,n,s)*p%s,y=st(w,o,s)*w%s,m=st(y,o,s)*w%s,x=st(m,t,s)*u%s;return{pow_p_5_8:st(x,Qa,s)*r%s,b2:a}}function rc(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function $l(r,t){let e=kr,n=Y(t*t*t,e),o=Y(n*n*t,e),s=ec(r*o).pow_p_5_8,i=Y(r*n*s,e),a=Y(t*i*i,e),c=i,f=Y(i*Ja,e),u=a===r,l=a===Y(-r,e),p=a===Y(-r*Ja,e);return u&&(i=c),(l||p)&&(i=f),qa(i,e)&&(i=Y(-i,e)),{isValid:u||l,value:i}}var tc=oe(kr,void 0,!0),Zl={a:tc.create(BigInt(-1)),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:tc,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:jl,Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:Ca,randomBytes:Ir,adjustScalarBytes:rc,uvRatio:$l},nc=Ya(Zl);var Rr=Xa({P:kr,type:"x25519",powPminus2:r=>{let t=kr,{pow_p_5_8:e,b2:n}=ec(r);return Y(st(e,Gl,t)*n,t)},adjustScalarBytes:rc,randomBytes:Ir});var An=32;function oc(r,t,e){return nc.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}var vn=class{type="Ed25519";raw;constructor(t){this.raw=fs(t,An)}toMultihash(){return Ot.digest(de(this))}toCID(){return ut.createV1(114,this.toMultihash())}toString(){return nt.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:ht(this.raw,t.raw)}verify(t,e){return oc(this.raw,e,t)}};function ls(r){return r=fs(r,An),new vn(r)}function fs(r,t){if(r=Uint8Array.from(r??[]),r.length!==t)throw new at(`Key must be a Uint8Array of length ${t}, got ${r.length}`);return r}var Xl=Math.pow(2,7),Jl=Math.pow(2,14),Ql=Math.pow(2,21),hs=Math.pow(2,28),ds=Math.pow(2,35),ps=Math.pow(2,42),ms=Math.pow(2,49),tt=128,It=127;function lt(r){if(r<Xl)return 1;if(r<Jl)return 2;if(r<Ql)return 3;if(r<hs)return 4;if(r<ds)return 5;if(r<ps)return 6;if(r<ms)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function ys(r,t,e=0){switch(lt(r)){case 8:t[e++]=r&255|tt,r/=128;case 7:t[e++]=r&255|tt,r/=128;case 6:t[e++]=r&255|tt,r/=128;case 5:t[e++]=r&255|tt,r/=128;case 4:t[e++]=r&255|tt,r>>>=7;case 3:t[e++]=r&255|tt,r>>>=7;case 2:t[e++]=r&255|tt,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function th(r,t,e=0){switch(lt(r)){case 8:t.set(e++,r&255|tt),r/=128;case 7:t.set(e++,r&255|tt),r/=128;case 6:t.set(e++,r&255|tt),r/=128;case 5:t.set(e++,r&255|tt),r/=128;case 4:t.set(e++,r&255|tt),r>>>=7;case 3:t.set(e++,r&255|tt),r>>>=7;case 2:t.set(e++,r&255|tt),r>>>=7;case 1:{t.set(e++,r&255),r>>>=7;break}default:throw new Error("unreachable")}return t}function gs(r,t){let e=r[t],n=0;if(n+=e&It,e<tt||(e=r[t+1],n+=(e&It)<<7,e<tt)||(e=r[t+2],n+=(e&It)<<14,e<tt)||(e=r[t+3],n+=(e&It)<<21,e<tt)||(e=r[t+4],n+=(e&It)*hs,e<tt)||(e=r[t+5],n+=(e&It)*ds,e<tt)||(e=r[t+6],n+=(e&It)*ps,e<tt)||(e=r[t+7],n+=(e&It)*ms,e<tt))return n;throw new RangeError("Could not decode varint")}function eh(r,t){let e=r.get(t),n=0;if(n+=e&It,e<tt||(e=r.get(t+1),n+=(e&It)<<7,e<tt)||(e=r.get(t+2),n+=(e&It)<<14,e<tt)||(e=r.get(t+3),n+=(e&It)<<21,e<tt)||(e=r.get(t+4),n+=(e&It)*hs,e<tt)||(e=r.get(t+5),n+=(e&It)*ds,e<tt)||(e=r.get(t+6),n+=(e&It)*ps,e<tt)||(e=r.get(t+7),n+=(e&It)*ms,e<tt))return n;throw new RangeError("Could not decode varint")}function Yt(r,t,e=0){return t==null&&(t=pt(lt(r))),t instanceof Uint8Array?ys(r,t,e):th(r,t,e)}function zt(r,t=0){return r instanceof Uint8Array?gs(r,t):eh(r,t)}var xs=new Float32Array([-0]),Ee=new Uint8Array(xs.buffer);function ic(r,t,e){xs[0]=r,t[e]=Ee[0],t[e+1]=Ee[1],t[e+2]=Ee[2],t[e+3]=Ee[3]}function ac(r,t){return Ee[0]=r[t],Ee[1]=r[t+1],Ee[2]=r[t+2],Ee[3]=r[t+3],xs[0]}var ws=new Float64Array([-0]),Bt=new Uint8Array(ws.buffer);function cc(r,t,e){ws[0]=r,t[e]=Bt[0],t[e+1]=Bt[1],t[e+2]=Bt[2],t[e+3]=Bt[3],t[e+4]=Bt[4],t[e+5]=Bt[5],t[e+6]=Bt[6],t[e+7]=Bt[7]}function uc(r,t){return Bt[0]=r[t],Bt[1]=r[t+1],Bt[2]=r[t+2],Bt[3]=r[t+3],Bt[4]=r[t+4],Bt[5]=r[t+5],Bt[6]=r[t+6],Bt[7]=r[t+7],ws[0]}var rh=BigInt(Number.MAX_SAFE_INTEGER),nh=BigInt(Number.MIN_SAFE_INTEGER),Kt=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 Re;if(t<rh&&t>nh)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>fc&&(o=0n,++n>fc&&(n=0n))),new r(Number(o),Number(n))}static fromNumber(t){if(t===0)return Re;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):Re}},Re=new Kt(0,0);Re.toBigInt=function(){return 0n};Re.zzEncode=Re.zzDecode=function(){return this};Re.length=function(){return 1};var fc=4294967296n;function lc(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 hc(r,t,e){if(e-t<1)return"";let o,s=[],i=0,a;for(;t<e;)a=r[t++],a<128?s[i++]=a:a>191&&a<224?s[i++]=(a&31)<<6|r[t++]&63:a>239&&a<365?(a=((a&7)<<18|(r[t++]&63)<<12|(r[t++]&63)<<6|r[t++]&63)-65536,s[i++]=55296+(a>>10),s[i++]=56320+(a&1023)):s[i++]=(a&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 bs(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 Ft(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function In(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var Es=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,Ft(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 Ft(this,4);return In(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Ft(this,4);return In(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Ft(this,4);let t=ac(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Ft(this,4);let t=uc(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 Ft(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return hc(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw Ft(this,t);this.pos+=t}else do if(this.pos>=this.len)throw Ft(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 Kt(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 Ft(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 Ft(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 Ft(this,8);let t=In(this.buf,this.pos+=4),e=In(this.buf,this.pos+=4);return new Kt(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=gs(this.buf,this.pos);return this.pos+=lt(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 Ss(r){return new Es(r instanceof Uint8Array?r:r.subarray())}function De(r,t,e){let n=Ss(r);return t.decode(n,void 0,e)}function As(r){let t=r??8192,e=t>>>1,n,o=t;return function(i){if(i<1||i>e)return pt(i);o+i>t&&(n=pt(t),o=0);let a=n.subarray(o,o+=i);return(o&7)!==0&&(o=(o|7)+1),a}}var Ke=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function vs(){}var Bs=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},oh=As();function sh(r){return globalThis.Buffer!=null?pt(r):oh(r)}var Nr=class{len;head;tail;states;constructor(){this.len=0,this.head=new Ke(vs,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new Ke(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new _s((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(Bn,10,Kt.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=Kt.fromBigInt(t);return this._push(Bn,e.length(),e)}uint64Number(t){return this._push(ys,lt(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=Kt.fromBigInt(t).zzEncode();return this._push(Bn,e.length(),e)}sint64Number(t){let e=Kt.fromNumber(t).zzEncode();return this._push(Bn,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(Is,1,t?1:0)}fixed32(t){return this._push(Kr,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=Kt.fromBigInt(t);return this._push(Kr,4,e.lo)._push(Kr,4,e.hi)}fixed64Number(t){let e=Kt.fromNumber(t);return this._push(Kr,4,e.lo)._push(Kr,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(ic,4,t)}double(t){return this._push(cc,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(Is,1,0):this.uint32(e)._push(ah,e,t)}string(t){let e=lc(t);return e!==0?this.uint32(e)._push(bs,e,t):this._push(Is,1,0)}fork(){return this.states=new Bs(this),this.head=this.tail=new Ke(vs,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 Ke(vs,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=sh(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function Is(r,t,e){t[e]=r&255}function ih(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var _s=class extends Ke{next;constructor(t,e){super(ih,t,e),this.next=void 0}};function Bn(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 Kr(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&&(Nr.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(ch,t,r),this},Nr.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(uh,t,r),this});function ch(r,t,e){t.set(r,e)}function uh(r,t,e){r.length<40?bs(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(Q(r),e)}function Ls(){return new Nr}function Ne(r,t){let e=Ls();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var rr;(function(r){r[r.VARINT=0]="VARINT",r[r.BIT64=1]="BIT64",r[r.LENGTH_DELIMITED=2]="LENGTH_DELIMITED",r[r.START_GROUP=3]="START_GROUP",r[r.END_GROUP=4]="END_GROUP",r[r.BIT32=5]="BIT32"})(rr||(rr={}));function _n(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function Ts(r){function t(o){if(r[o.toString()]==null)throw new Error("Invalid enum value");return r[o]}let e=function(s,i){let a=t(s);i.int32(a)},n=function(s){let i=s.int32();return t(i)};return _n("enum",rr.VARINT,e,n)}function Me(r,t){return _n("message",rr.LENGTH_DELIMITED,r,t)}var Mr=class extends Error{code="ERR_MAX_LENGTH";name="MaxLengthError"};var ft;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.secp256k1="secp256k1",r.ECDSA="ECDSA"})(ft||(ft={}));var Cs;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1",r[r.ECDSA=3]="ECDSA"})(Cs||(Cs={}));(function(r){r.codec=()=>Ts(Cs)})(ft||(ft={}));var Xt;(function(r){let t;r.codec=()=>(t==null&&(t=Me((e,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),ft.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),o.lengthDelimited!==!1&&n.ldelim()},(e,n,o={})=>{let s={},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let a=e.uint32();switch(a>>>3){case 1:{s.Type=ft.codec().decode(e);break}case 2:{s.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return s})),t),r.encode=e=>Ne(e,r.codec()),r.decode=(e,n)=>De(e,r.codec(),n)})(Xt||(Xt={}));var Ps;(function(r){let t;r.codec=()=>(t==null&&(t=Me((e,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),ft.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),o.lengthDelimited!==!1&&n.ldelim()},(e,n,o={})=>{let s={},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let a=e.uint32();switch(a>>>3){case 1:{s.Type=ft.codec().decode(e);break}case 2:{s.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return s})),t),r.encode=e=>Ne(e,r.codec()),r.decode=(e,n)=>De(e,r.codec(),n)})(Ps||(Ps={}));var Or=class extends Error{constructor(t="An error occurred while verifying a message"){super(t),this.name="VerificationError"}},Ln=class extends Error{constructor(t="Missing Web Crypto API"){super(t),this.name="WebCryptoMissingError"}};var mc={get(r=globalThis){let t=r.crypto;if(t?.subtle==null)throw new Ln("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 Se=mc;var Vr={};Tt(Vr,{MAX_RSA_KEY_SIZE:()=>Us,generateRSAKeyPair:()=>wc,jwkToJWKKeyPair:()=>bc,jwkToPkcs1:()=>dh,jwkToPkix:()=>Ks,jwkToRSAPrivateKey:()=>Hs,pkcs1MessageToJwk:()=>Rs,pkcs1MessageToRSAPrivateKey:()=>Ns,pkcs1ToJwk:()=>hh,pkcs1ToRSAPrivateKey:()=>xc,pkixMessageToJwk:()=>Ds,pkixMessageToRSAPublicKey:()=>Os,pkixToJwk:()=>ph,pkixToRSAPublicKey:()=>Ms});var Ae=gn;var nr=class{type="RSA";jwk;_raw;_multihash;constructor(t,e){this.jwk=t,this._multihash=e}get raw(){return this._raw==null&&(this._raw=Vr.jwkToPkix(this.jwk)),this._raw}toMultihash(){return this._multihash}toCID(){return ut.createV1(114,this._multihash)}toString(){return nt.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:ht(this.raw,t.raw)}verify(t,e){return gc(this.jwk,e,t)}},Hr=class{type="RSA";jwk;_raw;publicKey;constructor(t,e){this.jwk=t,this.publicKey=e}get raw(){return this._raw==null&&(this._raw=Vr.jwkToPkcs1(this.jwk)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:ht(this.raw,t.raw)}sign(t){return yc(this.jwk,t)}};var Us=8192,ks=18,fh=1062,lh=Uint8Array.from([48,13,6,9,42,134,72,134,247,13,1,1,1,5,0]);function hh(r){let t=te(r);return Rs(t)}function Rs(r){return{n:V(r[1],"base64url"),e:V(r[2],"base64url"),d:V(r[3],"base64url"),p:V(r[4],"base64url"),q:V(r[5],"base64url"),dp:V(r[6],"base64url"),dq:V(r[7],"base64url"),qi:V(r[8],"base64url"),kty:"RSA"}}function dh(r){if(r.n==null||r.e==null||r.d==null||r.p==null||r.q==null||r.dp==null||r.dq==null||r.qi==null)throw new at("JWK was missing components");return he([Rt(Uint8Array.from([0])),Rt(Q(r.n,"base64url")),Rt(Q(r.e,"base64url")),Rt(Q(r.d,"base64url")),Rt(Q(r.p,"base64url")),Rt(Q(r.q,"base64url")),Rt(Q(r.dp,"base64url")),Rt(Q(r.dq,"base64url")),Rt(Q(r.qi,"base64url"))]).subarray()}function ph(r){let t=te(r,{offset:0});return Ds(t)}function Ds(r){let t=te(r[1],{offset:0});return{kty:"RSA",n:V(t[0],"base64url"),e:V(t[1],"base64url")}}function Ks(r){if(r.n==null||r.e==null)throw new at("JWK was missing components");return he([lh,dn(he([Rt(Q(r.n,"base64url")),Rt(Q(r.e,"base64url"))]))]).subarray()}function xc(r){let t=te(r);return Ns(t)}function Ns(r){let t=Rs(r);return Hs(t)}function Ms(r,t){if(r.byteLength>=fh)throw new Fe("Key size is too large");let e=te(r,{offset:0});return Os(e,r,t)}function Os(r,t,e){let n=Ds(r);if(e==null){let o=Ae(Xt.encode({Type:ft.RSA,Data:t}));e=Nt(ks,o)}return new nr(n,e)}function Hs(r){if(Sc(r)>Us)throw new at("Key size is too large");let t=bc(r),e=Ae(Xt.encode({Type:ft.RSA,Data:Ks(t.publicKey)})),n=Nt(ks,e);return new Hr(t.privateKey,new nr(t.publicKey,n))}async function wc(r){if(r>Us)throw new at("Key size is too large");let t=await Ec(r),e=Ae(Xt.encode({Type:ft.RSA,Data:Ks(t.publicKey)})),n=Nt(ks,e);return new Hr(t.privateKey,new nr(t.publicKey,n))}function bc(r){if(r==null)throw new at("Missing key parameter");return{privateKey:r,publicKey:{kty:r.kty,n:r.n,e:r.e}}}async function Ec(r){let t=await Se.get().subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:r,publicExponent:new Uint8Array([1,0,1]),hash:{name:"SHA-256"}},!0,["sign","verify"]),e=await mh(t);return{privateKey:e[0],publicKey:e[1]}}async function yc(r,t){let e=await Se.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await Se.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},e,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(n,0,n.byteLength)}async function gc(r,t,e){let n=await Se.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return Se.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,t,e instanceof Uint8Array?e:e.subarray())}async function mh(r){if(r.privateKey==null||r.publicKey==null)throw new at("Private and public key are required");return Promise.all([Se.get().subtle.exportKey("jwk",r.privateKey),Se.get().subtle.exportKey("jwk",r.publicKey)])}function Sc(r){if(r.kty!=="RSA")throw new at("invalid key type");if(r.n==null)throw new at("invalid key modulus");return Q(r.n,"base64url").length*8}var Tn=class extends Ye{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,vr(t);let n=pe(e);if(this.iHash=t.create(),typeof this.iHash.update!="function")throw new Error("Expected instance of class which extends utils.Hash");this.blockLen=this.iHash.blockLen,this.outputLen=this.iHash.outputLen;let o=this.blockLen,s=new Uint8Array(o);s.set(n.length>o?t.create().update(n).digest():n);for(let i=0;i<s.length;i++)s[i]^=54;this.iHash.update(s),this.oHash=t.create();for(let i=0;i<s.length;i++)s[i]^=106;this.oHash.update(s),Ht(s)}update(t){return Xe(this),this.iHash.update(t),this}digestInto(t){Xe(this),Le(t,this.outputLen),this.finished=!0,this.iHash.digestInto(t),this.oHash.update(t),this.oHash.digestInto(t),this.destroy()}digest(){let t=new Uint8Array(this.oHash.outputLen);return this.digestInto(t),t}_cloneInto(t){t||(t=Object.create(Object.getPrototypeOf(this),{}));let{oHash:e,iHash:n,finished:o,destroyed:s,blockLen:i,outputLen:a}=this;return t=t,t.finished=o,t.destroyed=s,t.blockLen=i,t.outputLen=a,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()}},or=(r,t,e)=>new Tn(r,t).update(e).digest();or.create=(r,t)=>new Tn(r,t);function Ac(r){r.lowS!==void 0&&jt("lowS",r.lowS),r.prehash!==void 0&&jt("prehash",r.prehash)}function yh(r){let t=Pr(r);qt(t,{a:"field",b:"field"},{allowInfinityPoint:"boolean",allowedPrivateKeyLengths:"array",clearCofactor:"function",fromBytes:"function",isTorsionFree:"function",toBytes:"function",wrapPrivateKey:"boolean"});let{endo:e,Fp:n,a:o}=t;if(e){if(!n.eql(o,n.ZERO))throw new Error("invalid endo: CURVE.a must be 0");if(typeof e!="object"||typeof e.beta!="bigint"||typeof e.splitScalar!="function")throw new Error('invalid endo: expected "beta": bigint and "splitScalar": function')}return Object.freeze({...t})}var zs=class extends Error{constructor(t=""){super(t)}},se={Err:zs,_tlv:{encode:(r,t)=>{let{Err:e}=se;if(r<0||r>256)throw new e("tlv.encode: wrong tag");if(t.length&1)throw new e("tlv.encode: unpadded data");let n=t.length/2,o=Tr(n);if(o.length/2&128)throw new e("tlv.encode: long form length too big");let s=n>127?Tr(o.length/2|128):"";return Tr(r)+s+o+t},decode(r,t){let{Err:e}=se,n=0;if(r<0||r>256)throw new e("tlv.encode: wrong tag");if(t.length<2||t[n++]!==r)throw new e("tlv.decode: wrong tlv");let o=t[n++],s=!!(o&128),i=0;if(!s)i=o;else{let c=o&127;if(!c)throw new e("tlv.decode(long): indefinite length not supported");if(c>4)throw new e("tlv.decode(long): byte length is too big");let f=t.subarray(n,n+c);if(f.length!==c)throw new e("tlv.decode: length bytes not complete");if(f[0]===0)throw new e("tlv.decode(long): zero leftmost byte");for(let u of f)i=i<<8|u;if(n+=c,i<128)throw new e("tlv.decode(long): not minimal encoding")}let a=t.subarray(n,n+i);if(a.length!==i)throw new e("tlv.decode: wrong value length");return{v:a,l:t.subarray(n+i)}}},_int:{encode(r){let{Err:t}=se;if(r<ie)throw new t("integer: negative integers are not allowed");let e=Tr(r);if(Number.parseInt(e[0],16)&8&&(e="00"+e),e.length&1)throw new t("unexpected DER parsing assertion: unpadded hex");return e},decode(r){let{Err:t}=se;if(r[0]&128)throw new t("invalid signature integer: negative");if(r[0]===0&&!(r[1]&128))throw new t("invalid signature integer: unnecessary leading zero");return ne(r)}},toSig(r){let{Err:t,_int:e,_tlv:n}=se,o=ot("signature",r),{v:s,l:i}=n.decode(48,o);if(i.length)throw new t("invalid signature: left bytes after parsing");let{v:a,l:c}=n.decode(2,s),{v:f,l:u}=n.decode(2,c);if(u.length)throw new t("invalid signature: left bytes after parsing");return{r:e.decode(a),s:e.decode(f)}},hexFromSig(r){let{_tlv:t,_int:e}=se,n=t.encode(2,e.encode(r.r)),o=t.encode(2,e.encode(r.s)),s=n+o;return t.encode(48,s)}};function Vs(r,t){return xe(Pe(r,t))}var ie=BigInt(0),gt=BigInt(1),Hy=BigInt(2),qs=BigInt(3),gh=BigInt(4);function xh(r){let t=yh(r),{Fp:e}=t,n=oe(t.n,t.nBitLength),o=t.toBytes||((S,d,I)=>{let U=d.toAffine();return be(Uint8Array.from([4]),e.toBytes(U.x),e.toBytes(U.y))}),s=t.fromBytes||(S=>{let d=S.subarray(1),I=e.fromBytes(d.subarray(0,e.BYTES)),U=e.fromBytes(d.subarray(e.BYTES,2*e.BYTES));return{x:I,y:U}});function i(S){let{a:d,b:I}=t,U=e.sqr(S),B=e.mul(U,S);return e.add(e.add(B,e.mul(S,d)),I)}function a(S,d){let I=e.sqr(d),U=i(S);return e.eql(I,U)}if(!a(t.Gx,t.Gy))throw new Error("bad curve params: generator point");let c=e.mul(e.pow(t.a,qs),gh),f=e.mul(e.sqr(t.b),BigInt(27));if(e.is0(e.add(c,f)))throw new Error("bad curve params: a or b");function u(S){return xn(S,gt,t.n)}function l(S){let{allowedPrivateKeyLengths:d,nByteLength:I,wrapPrivateKey:U,n:B}=t;if(d&&typeof S!="bigint"){if(Je(S)&&(S=xe(S)),typeof S!="string"||!d.includes(S.length))throw new Error("invalid private key");S=S.padStart(I*2,"0")}let L;try{L=typeof S=="bigint"?S:ne(ot("private key",S,I))}catch{throw new Error("invalid private key, expected hex or "+I+" bytes, got "+typeof S)}return U&&(L=Y(L,B)),vt("private key",L,gt,B),L}function p(S){if(!(S instanceof m))throw new Error("ProjectivePoint expected")}let w=Qe((S,d)=>{let{px:I,py:U,pz:B}=S;if(e.eql(B,e.ONE))return{x:I,y:U};let L=S.is0();d==null&&(d=L?e.ONE:e.inv(B));let k=e.mul(I,d),K=e.mul(U,d),T=e.mul(B,d);if(L)return{x:e.ZERO,y:e.ZERO};if(!e.eql(T,e.ONE))throw new Error("invZ was invalid");return{x:k,y:K}}),y=Qe(S=>{if(S.is0()){if(t.allowInfinityPoint&&!e.is0(S.py))return;throw new Error("bad point: ZERO")}let{x:d,y:I}=S.toAffine();if(!e.isValid(d)||!e.isValid(I))throw new Error("bad point: x or y not FE");if(!a(d,I))throw new Error("bad point: equation left != right");if(!S.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});class m{constructor(d,I,U){if(d==null||!e.isValid(d))throw new Error("x required");if(I==null||!e.isValid(I)||e.is0(I))throw new Error("y required");if(U==null||!e.isValid(U))throw new Error("z required");this.px=d,this.py=I,this.pz=U,Object.freeze(this)}static fromAffine(d){let{x:I,y:U}=d||{};if(!d||!e.isValid(I)||!e.isValid(U))throw new Error("invalid affine point");if(d instanceof m)throw new Error("projective point not allowed");let B=L=>e.eql(L,e.ZERO);return B(I)&&B(U)?m.ZERO:new m(I,U,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(d){let I=tr(e,d.map(U=>U.pz));return d.map((U,B)=>U.toAffine(I[B])).map(m.fromAffine)}static fromHex(d){let I=m.fromAffine(s(ot("pointHex",d)));return I.assertValidity(),I}static fromPrivateKey(d){return m.BASE.multiply(l(d))}static msm(d,I){return En(m,n,d,I)}_setWindowSize(d){M.setWindowSize(this,d)}assertValidity(){y(this)}hasEvenY(){let{y:d}=this.toAffine();if(e.isOdd)return!e.isOdd(d);throw new Error("Field doesn't support isOdd")}equals(d){p(d);let{px:I,py:U,pz:B}=this,{px:L,py:k,pz:K}=d,T=e.eql(e.mul(I,K),e.mul(L,B)),D=e.eql(e.mul(U,K),e.mul(k,B));return T&&D}negate(){return new m(this.px,e.neg(this.py),this.pz)}double(){let{a:d,b:I}=t,U=e.mul(I,qs),{px:B,py:L,pz:k}=this,K=e.ZERO,T=e.ZERO,D=e.ZERO,C=e.mul(B,B),H=e.mul(L,L),E=e.mul(k,k),A=e.mul(B,L);return A=e.add(A,A),D=e.mul(B,k),D=e.add(D,D),K=e.mul(d,D),T=e.mul(U,E),T=e.add(K,T),K=e.sub(H,T),T=e.add(H,T),T=e.mul(K,T),K=e.mul(A,K),D=e.mul(U,D),E=e.mul(d,E),A=e.sub(C,E),A=e.mul(d,A),A=e.add(A,D),D=e.add(C,C),C=e.add(D,C),C=e.add(C,E),C=e.mul(C,A),T=e.add(T,C),E=e.mul(L,k),E=e.add(E,E),C=e.mul(E,A),K=e.sub(K,C),D=e.mul(E,H),D=e.add(D,D),D=e.add(D,D),new m(K,T,D)}add(d){p(d);let{px:I,py:U,pz:B}=this,{px:L,py:k,pz:K}=d,T=e.ZERO,D=e.ZERO,C=e.ZERO,H=t.a,E=e.mul(t.b,qs),A=e.mul(I,L),P=e.mul(U,k),b=e.mul(B,K),h=e.add(I,U),g=e.add(L,k);h=e.mul(h,g),g=e.add(A,P),h=e.sub(h,g),g=e.add(I,B);let v=e.add(L,K);return g=e.mul(g,v),v=e.add(A,b),g=e.sub(g,v),v=e.add(U,B),T=e.add(k,K),v=e.mul(v,T),T=e.add(P,b),v=e.sub(v,T),C=e.mul(H,g),T=e.mul(E,b),C=e.add(T,C),T=e.sub(P,C),C=e.add(P,C),D=e.mul(T,C),P=e.add(A,A),P=e.add(P,A),b=e.mul(H,b),g=e.mul(E,g),P=e.add(P,b),b=e.sub(A,b),b=e.mul(H,b),g=e.add(g,b),A=e.mul(P,g),D=e.add(D,A),A=e.mul(v,g),T=e.mul(h,T),T=e.sub(T,A),A=e.mul(h,P),C=e.mul(v,C),C=e.add(C,A),new m(T,D,C)}subtract(d){return this.add(d.negate())}is0(){return this.equals(m.ZERO)}wNAF(d){return M.wNAFCached(this,d,m.normalizeZ)}multiplyUnsafe(d){let{endo:I,n:U}=t;vt("scalar",d,ie,U);let B=m.ZERO;if(d===ie)return B;if(this.is0()||d===gt)return this;if(!I||M.hasPrecomputes(this))return M.wNAFCachedUnsafe(this,d,m.normalizeZ);let{k1neg:L,k1:k,k2neg:K,k2:T}=I.splitScalar(d),D=B,C=B,H=this;for(;k>ie||T>ie;)k>&&(D=D.add(H)),T>&&(C=C.add(H)),H=H.double(),k>>=gt,T>>=gt;return L&&(D=D.negate()),K&&(C=C.negate()),C=new m(e.mul(C.px,I.beta),C.py,C.pz),D.add(C)}multiply(d){let{endo:I,n:U}=t;vt("scalar",d,gt,U);let B,L;if(I){let{k1neg:k,k1:K,k2neg:T,k2:D}=I.splitScalar(d),{p:C,f:H}=this.wNAF(K),{p:E,f:A}=this.wNAF(D);C=M.constTimeNegate(k,C),E=M.constTimeNegate(T,E),E=new m(e.mul(E.px,I.beta),E.py,E.pz),B=C.add(E),L=H.add(A)}else{let{p:k,f:K}=this.wNAF(d);B=k,L=K}return m.normalizeZ([B,L])[0]}multiplyAndAddUnsafe(d,I,U){let B=m.BASE,L=(K,T)=>T===ie||T===gt||!K.equals(B)?K.multiplyUnsafe(T):K.multiply(T),k=L(this,I).add(L(d,U));return k.is0()?void 0:k}toAffine(d){return w(this,d)}isTorsionFree(){let{h:d,isTorsionFree:I}=t;if(d===gt)return!0;if(I)return I(m,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h:d,clearCofactor:I}=t;return d===gt?this:I?I(m,this):this.multiplyUnsafe(t.h)}toRawBytes(d=!0){return jt("isCompressed",d),this.assertValidity(),o(m,this,d)}toHex(d=!0){return jt("isCompressed",d),xe(this.toRawBytes(d))}}m.BASE=new m(t.Gx,t.Gy,e.ONE),m.ZERO=new m(e.ZERO,e.ONE,e.ZERO);let{endo:x,nBitLength:_}=t,M=bn(m,x?Math.ceil(_/2):_);return{CURVE:t,ProjectivePoint:m,normPrivateKeyToScalar:l,weierstrassEquation:i,isWithinCurveOrder:u}}function wh(r){let t=Pr(r);return qt(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function vc(r){let t=wh(r),{Fp:e,n,nByteLength:o,nBitLength:s}=t,i=e.BYTES+1,a=2*e.BYTES+1;function c(E){return Y(E,n)}function f(E){return wn(E,n)}let{ProjectivePoint:u,normPrivateKeyToScalar:l,weierstrassEquation:p,isWithinCurveOrder:w}=xh({...t,toBytes(E,A,P){let b=A.toAffine(),h=e.toBytes(b.x),g=be;return jt("isCompressed",P),P?g(Uint8Array.from([A.hasEvenY()?2:3]),h):g(Uint8Array.from([4]),h,e.toBytes(b.y))},fromBytes(E){let A=E.length,P=E[0],b=E.subarray(1);if(A===i&&(P===2||P===3)){let h=ne(b);if(!xn(h,gt,e.ORDER))throw new Error("Point is not on curve");let g=p(h),v;try{v=e.sqrt(g)}catch(q){let z=q instanceof Error?": "+q.message:"";throw new Error("Point is not on curve"+z)}let R=(v>)===gt;return(P&1)===1!==R&&(v=e.neg(v)),{x:h,y:v}}else if(A===a&&P===4){let h=e.fromBytes(b.subarray(0,e.BYTES)),g=e.fromBytes(b.subarray(e.BYTES,2*e.BYTES));return{x:h,y:g}}else{let h=i,g=a;throw new Error("invalid Point, expected length of "+h+", or uncompressed "+g+", got "+A)}}});function y(E){let A=n>>gt;return E>A}function m(E){return y(E)?c(-E):E}let x=(E,A,P)=>ne(E.slice(A,P));class _{constructor(A,P,b){vt("r",A,gt,n),vt("s",P,gt,n),this.r=A,this.s=P,b!=null&&(this.recovery=b),Object.freeze(this)}static fromCompact(A){let P=o;return A=ot("compactSignature",A,P*2),new _(x(A,0,P),x(A,P,2*P))}static fromDER(A){let{r:P,s:b}=se.toSig(ot("DER",A));return new _(P,b)}assertValidity(){}addRecoveryBit(A){return new _(this.r,this.s,A)}recoverPublicKey(A){let{r:P,s:b,recovery:h}=this,g=B(ot("msgHash",A));if(h==null||![0,1,2,3].includes(h))throw new Error("recovery id invalid");let v=h===2||h===3?P+t.n:P;if(v>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let R=(h&1)===0?"02":"03",O=u.fromHex(R+Vs(v,e.BYTES)),q=f(v),z=c(-g*q),F=c(b*q),G=u.BASE.multiplyAndAddUnsafe(O,z,F);if(!G)throw new Error("point at infinify");return G.assertValidity(),G}hasHighS(){return y(this.s)}normalizeS(){return this.hasHighS()?new _(this.r,c(-this.s),this.recovery):this}toDERRawBytes(){return Cr(this.toDERHex())}toDERHex(){return se.hexFromSig(this)}toCompactRawBytes(){return Cr(this.toCompactHex())}toCompactHex(){let A=o;return Vs(this.r,A)+Vs(this.s,A)}}let M={isValidPrivateKey(E){try{return l(E),!0}catch{return!1}},normPrivateKeyToScalar:l,randomPrivateKey:()=>{let E=os(t.n);return Fa(t.randomBytes(E),t.n)},precompute(E=8,A=u.BASE){return A._setWindowSize(E),A.multiply(BigInt(3)),A}};function S(E,A=!0){return u.fromPrivateKey(E).toRawBytes(A)}function d(E){if(typeof E=="bigint")return!1;if(E instanceof u)return!0;let P=ot("key",E).length,b=e.BYTES,h=b+1,g=2*b+1;if(!(t.allowedPrivateKeyLengths||o===h))return P===h||P===g}function I(E,A,P=!0){if(d(E)===!0)throw new Error("first arg must be private key");if(d(A)===!1)throw new Error("second arg must be public key");return u.fromHex(A).multiply(l(E)).toRawBytes(P)}let U=t.bits2int||function(E){if(E.length>8192)throw new Error("input is too large");let A=ne(E),P=E.length*8-s;return P>0?A>>BigInt(P):A},B=t.bits2int_modN||function(E){return c(U(E))},L=Ue(s);function k(E){return vt("num < 2^"+s,E,ie,L),Pe(E,o)}function K(E,A,P=T){if(["recovered","canonical"].some(Z=>Z in P))throw new Error("sign() legacy options not supported");let{hash:b,randomBytes:h}=t,{lowS:g,prehash:v,extraEntropy:R}=P;g==null&&(g=!0),E=ot("msgHash",E),Ac(P),v&&(E=ot("prehashed msgHash",b(E)));let O=B(E),q=l(A),z=[k(q),k(O)];if(R!=null&&R!==!1){let Z=R===!0?h(e.BYTES):R;z.push(ot("extraEntropy",Z))}let F=be(...z),G=O;function J(Z){let wt=U(Z);if(!w(wt))return;let kt=f(wt),mt=u.BASE.multiply(wt).toAffine(),St=c(mt.x);if(St===ie)return;let Dt=c(kt*c(G+St*q));if(Dt===ie)return;let Mt=(mt.x===St?0:2)|Number(mt.y>),yr=Dt;return g&&y(Dt)&&(yr=m(Dt),Mt^=1),new _(St,yr,Mt)}return{seed:F,k2sig:J}}let T={lowS:t.lowS,prehash:!1},D={lowS:t.lowS,prehash:!1};function C(E,A,P=T){let{seed:b,k2sig:h}=K(E,A,P),g=t;return Ka(g.hash.outputLen,g.nByteLength,g.hmac)(b,h)}u.BASE._setWindowSize(8);function H(E,A,P,b=D){let h=E;A=ot("msgHash",A),P=ot("publicKey",P);let{lowS:g,prehash:v,format:R}=b;if(Ac(b),"strict"in b)throw new Error("options.strict was renamed to lowS");if(R!==void 0&&R!=="compact"&&R!=="der")throw new Error("format must be compact or der");let O=typeof h=="string"||Je(h),q=!O&&!R&&typeof h=="object"&&h!==null&&typeof h.r=="bigint"&&typeof h.s=="bigint";if(!O&&!q)throw new Error("invalid signature, expected Uint8Array, hex string or Signature instance");let z,F;try{if(q&&(z=new _(h.r,h.s)),O){try{R!=="compact"&&(z=_.fromDER(h))}catch(Mt){if(!(Mt instanceof se.Err))throw Mt}!z&&R!=="der"&&(z=_.fromCompact(h))}F=u.fromHex(P)}catch{return!1}if(!z||g&&z.hasHighS())return!1;v&&(A=t.hash(A));let{r:G,s:J}=z,Z=B(A),wt=f(J),kt=c(Z*wt),mt=c(G*wt),St=u.BASE.multiplyAndAddUnsafe(F,kt,mt)?.toAffine();return St?c(St.x)===G:!1}return{CURVE:t,getPublicKey:S,getSharedSecret:I,sign:C,verify:H,ProjectivePoint:u,Signature:_,utils:M}}function bh(r){return{hash:r,hmac:(t,...e)=>or(r,t,Wo(...e)),randomBytes:Ir}}function Ic(r,t){let e=n=>vc({...r,...bh(n)});return{...e(t),create:e}}var Lc=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),Bc=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),Eh=BigInt(0),Sh=BigInt(1),Fs=BigInt(2),_c=(r,t)=>(r+t/Fs)/t;function Ah(r){let t=Lc,e=BigInt(3),n=BigInt(6),o=BigInt(11),s=BigInt(22),i=BigInt(23),a=BigInt(44),c=BigInt(88),f=r*r*r%t,u=f*f*r%t,l=st(u,e,t)*u%t,p=st(l,e,t)*u%t,w=st(p,Fs,t)*f%t,y=st(w,o,t)*w%t,m=st(y,s,t)*y%t,x=st(m,a,t)*m%t,_=st(x,c,t)*x%t,M=st(_,a,t)*m%t,S=st(M,e,t)*u%t,d=st(S,i,t)*y%t,I=st(d,n,t)*f%t,U=st(I,Fs,t);if(!Gs.eql(Gs.sqr(U),r))throw new Error("Cannot find square root");return U}var Gs=oe(Lc,void 0,void 0,{sqrt:Ah}),sr=Ic({a:Eh,b:BigInt(7),Fp:Gs,n:Bc,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=Bc,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-Sh*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),o=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),s=e,i=BigInt("0x100000000000000000000000000000000"),a=_c(s*r,t),c=_c(-n*r,t),f=Y(r-a*e-c*o,t),u=Y(-a*n-c*s,t),l=f>i,p=u>i;if(l&&(f=t-f),p&&(u=t-u),f>i||u>i)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:l,k1:f,k2neg:p,k2:u}}}},gn);function Tc(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function Cc(r,t,e){let n=Er.digest(e instanceof Uint8Array?e:e.subarray());if(Tc(n))return n.then(({digest:o})=>sr.verify(t,o,r)).catch(o=>{throw new Or(String(o))});try{return sr.verify(t,n.digest,r)}catch(o){throw new Or(String(o))}}var Cn=class{type="secp256k1";raw;_key;constructor(t){this._key=Uc(t),this.raw=Pc(this._key)}toMultihash(){return Ot.digest(de(this))}toCID(){return ut.createV1(114,this.toMultihash())}toString(){return nt.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:ht(this.raw,t.raw)}verify(t,e){return Cc(this._key,e,t)}};function Ws(r){return new Cn(r)}function Pc(r){return sr.ProjectivePoint.fromHex(r).toRawBytes(!0)}function Uc(r){try{return sr.ProjectivePoint.fromHex(r),r}catch(t){throw new Fe(String(t))}}function qr(r,t){let{Type:e,Data:n}=Xt.decode(r),o=n??new Uint8Array;switch(e){case ft.RSA:return Ms(o,t);case ft.Ed25519:return ls(o);case ft.secp256k1:return Ws(o);case ft.ECDSA:return Go(o);default:throw new ve}}function kc(r){let{Type:t,Data:e}=Xt.decode(r.digest),n=e??new Uint8Array;switch(t){case ft.Ed25519:return ls(n);case ft.secp256k1:return Ws(n);case ft.ECDSA:return Go(n);default:throw new ve}}function de(r){return Xt.encode({Type:ft[r.type],Data:r.raw})}var Rc=Symbol.for("nodejs.util.inspect.custom"),vh=114,zr=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()})`}[yo]=!0;toString(){return this.string==null&&(this.string=nt.encode(this.multihash.bytes).slice(1)),this.string}toMultihash(){return this.multihash}toCID(){return ut.createV1(vh,this.multihash)}toJSON(){return this.toString()}equals(t){if(t==null)return!1;if(t instanceof Uint8Array)return ht(this.multihash.bytes,t);if(typeof t=="string")return this.toString()===t;if(t?.toMultihash()?.bytes!=null)return ht(this.multihash.bytes,t.toMultihash().bytes);throw new Error("not valid Id")}[Rc](){return`PeerId(${this.toString()})`}},Fr=class extends zr{type="RSA";publicKey;constructor(t){super({...t,type:"RSA"}),this.publicKey=t.publicKey}},Gr=class extends zr{type="Ed25519";publicKey;constructor(t){super({...t,type:"Ed25519"}),this.publicKey=t.publicKey}},Wr=class extends zr{type="secp256k1";publicKey;constructor(t){super({...t,type:"secp256k1"}),this.publicKey=t.publicKey}},Ih=2336,jr=class{type="url";multihash;publicKey;url;constructor(t){this.url=t.toString(),this.multihash=Ot.digest(Q(this.url))}[Rc](){return`PeerId(${this.url})`}[yo]=!0;toString(){return this.toCID().toString()}toMultihash(){return this.multihash}toCID(){return ut.createV1(Ih,this.toMultihash())}toJSON(){return this.toString()}equals(t){return t==null?!1:(t instanceof Uint8Array&&(t=V(t)),t.toString()===this.toString())}};var Bh=114,Dc=2336;function Kc(r,t){let e;if(r.charAt(0)==="1"||r.charAt(0)==="Q")e=le(nt.decode(`z${r}`));else{if(r.startsWith("k51qzi5uqu5")||r.startsWith("kzwfwjn5ji4")||r.startsWith("k2k4r8")||r.startsWith("bafz"))return _h(ut.parse(r));if(t==null)throw new at('Please pass a multibase decoder for strings that do not start with "1" or "Q"');e=le(t.decode(r))}return Nc(e)}function js(r){if(r.type==="Ed25519")return new Gr({multihash:r.toCID().multihash,publicKey:r});if(r.type==="secp256k1")return new Wr({multihash:r.toCID().multihash,publicKey:r});if(r.type==="RSA")return new Fr({multihash:r.toCID().multihash,publicKey:r});throw new ve}function Nc(r){if(Th(r))return new Fr({multihash:r});if(Lh(r))try{let t=kc(r);if(t.type==="Ed25519")return new Gr({multihash:r,publicKey:t});if(t.type==="secp256k1")return new Wr({multihash:r,publicKey:t})}catch{let e=V(r.digest);return new jr(new URL(e))}throw new cn("Supplied PeerID Multihash is invalid")}function _h(r){if(r?.multihash==null||r.version==null||r.version===1&&r.code!==Bh&&r.code!==Dc)throw new an("Supplied PeerID CID is invalid");if(r.code===Dc){let t=V(r.multihash.digest);return new jr(new URL(t))}return Nc(r.multihash)}function Lh(r){return r.code===Ot.code}function Th(r){return r.code===Er.code}var Pn=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},ir=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},Un=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"},$r=class extends Error{name="UnexpectedEOFError";code="ERR_UNEXPECTED_EOF"};function kn(r){return r[Symbol.asyncIterator]!=null}function Mc(r,t){if(r.byteLength>t)throw new ir("Message length too long")}var Dn=r=>{let t=lt(r),e=pt(t);return Yt(r,e),Dn.bytes=t,e};Dn.bytes=0;function Oc(r,t){t=t??{};let e=t.lengthEncoder??Dn,n=t?.maxDataLength??4194304;function*o(s){Mc(s,n);let i=e(s.byteLength);i instanceof Uint8Array?yield i:yield*i,s instanceof Uint8Array?yield s:yield*s}return kn(r)?async function*(){for await(let s of r)yield*o(s)}():function*(){for(let s of r)yield*o(s)}()}Oc.single=(r,t)=>{t=t??{};let e=t.lengthEncoder??Dn,n=t?.maxDataLength??4194304;return Mc(r,n),new $(e(r.byteLength),r)};var Oe;(function(r){r[r.LENGTH=0]="LENGTH",r[r.DATA=1]="DATA"})(Oe||(Oe={}));var $s=r=>{let t=zt(r);return $s.bytes=lt(t),t};$s.bytes=0;function Zr(r,t){let e=new $,n=Oe.LENGTH,o=-1,s=t?.lengthDecoder??$s,i=t?.maxLengthLength??8,a=t?.maxDataLength??4194304;function*c(){for(;e.byteLength>0;){if(n===Oe.LENGTH)try{if(o=s(e),o<0)throw new Pn("Invalid message length");if(o>a)throw new ir("Message length too long");let f=s.bytes;e.consume(f),t?.onLength!=null&&t.onLength(o),n=Oe.DATA}catch(f){if(f instanceof RangeError){if(e.byteLength>i)throw new Un("Message length length too long");break}throw f}if(n===Oe.DATA){if(e.byteLength<o)break;let f=e.sublist(0,o);e.consume(o),t?.onData!=null&&t.onData(f),yield f,n=Oe.LENGTH}}}return kn(r)?async function*(){for await(let f of r)e.append(f),yield*c();if(e.byteLength>0)throw new $r("Unexpected end of input")}():function*(){for(let f of r)e.append(f),yield*c();if(e.byteLength>0)throw new $r("Unexpected end of input")}()}Zr.fromReader=(r,t)=>{let e=1,n=async function*(){for(;;)try{let{done:s,value:i}=await r.next(e);if(s===!0)return;i!=null&&(yield i)}catch(s){if(s.code==="ERR_UNDER_READ")return{done:!0,value:null};throw s}finally{e=1}}();return Zr(n,{...t??{},onLength:s=>{e=s}})};function Ut(){let r={};return r.promise=new Promise((t,e)=>{r.resolve=t,r.reject=e}),r}var Kn=class extends Error{type;code;constructor(t,e,n){super(t??"The operation was aborted"),this.type="aborted",this.name=n??"AbortError",this.code=e??"ABORT_ERR"}};async function xt(r,t,e){if(t==null)return r;if(t.aborted)return r.catch(()=>{}),Promise.reject(new Kn(e?.errorMessage,e?.errorCode,e?.errorName));let n,o=new Kn(e?.errorMessage,e?.errorCode,e?.errorName);try{return await Promise.race([r,new Promise((s,i)=>{n=()=>{i(o)},t.addEventListener("abort",n)})])}finally{n!=null&&t.removeEventListener("abort",n)}}var Zs=class{readNext;haveNext;ended;nextResult;error;constructor(){this.ended=!1,this.readNext=Ut(),this.haveNext=Ut()}[Symbol.asyncIterator](){return this}async next(){if(this.nextResult==null&&await this.haveNext.promise,this.nextResult==null)throw new Error("HaveNext promise resolved but nextResult was undefined");let t=this.nextResult;return this.nextResult=void 0,this.readNext.resolve(),this.readNext=Ut(),t}async throw(t){return this.ended=!0,this.error=t,t!=null&&(this.haveNext.promise.catch(()=>{}),this.haveNext.reject(t)),{done:!0,value:void 0}}async return(){let t={done:!0,value:void 0};return this.ended=!0,this.nextResult=t,this.haveNext.resolve(),t}async push(t,e){await this._push(t,e)}async end(t,e){t!=null?await this.throw(t):await this._push(void 0,e)}async _push(t,e){if(t!=null&&this.ended)throw this.error??new Error("Cannot push value onto an ended pushable");for(;this.nextResult!=null;)await this.readNext.promise;t!=null?this.nextResult={done:!1,value:t}:(this.ended=!0,this.nextResult={done:!0,value:void 0}),this.haveNext.resolve(),this.haveNext=Ut(),await xt(this.readNext.promise,e?.signal,e)}};function Nn(){return new Zs}var Mn=class extends Error{name="UnexpectedEOFError";code="ERR_UNEXPECTED_EOF"};function Hc(r,t){let e=Nn();r.sink(e).catch(async i=>{await e.end(i)}),r.sink=async i=>{for await(let a of i)await e.push(a);await e.end()};let n=r.source;r.source[Symbol.iterator]!=null?n=r.source[Symbol.iterator]():r.source[Symbol.asyncIterator]!=null&&(n=r.source[Symbol.asyncIterator]());let o=new $;return{read:async i=>{if(i?.signal?.throwIfAborted(),i?.bytes==null){let{done:c,value:f}=await xt(n.next(),i?.signal);return c===!0?null:f}for(;o.byteLength<i.bytes;){let{value:c,done:f}=await xt(n.next(),i?.signal);if(f===!0)throw new Mn("unexpected end of input");o.append(c)}let a=o.sublist(0,i.bytes);return o.consume(i.bytes),a},write:async(i,a)=>{a?.signal?.throwIfAborted(),i instanceof Uint8Array?await e.push(i,a):await e.push(i.subarray(),a)},unwrap:()=>{if(o.byteLength>0){let i=r.source;r.source=async function*(){t?.yieldBytes===!1?yield o:yield*o,yield*i}()}return r}}}var On=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},Hn=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},Vn=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"};function Ys(r,t={}){let e=Hc(r,t);t.maxDataLength!=null&&t.maxLengthLength==null&&(t.maxLengthLength=lt(t.maxDataLength));let n=t?.lengthDecoder??zt,o=t?.lengthEncoder??Yt;return{read:async i=>{let a=-1,c=new $;for(;;){c.append(await e.read({...i,bytes:1}));try{a=n(c)}catch(f){if(f instanceof RangeError)continue;throw f}if(a<0)throw new On("Invalid message length");if(t?.maxLengthLength!=null&&c.byteLength>t.maxLengthLength)throw new Vn("message length length too long");if(a>-1)break}if(t?.maxDataLength!=null&&a>t.maxDataLength)throw new Hn("message length too long");return e.read({...i,bytes:a})},write:async(i,a)=>{await e.write(new $(o(i.byteLength),i),a)},writeV:async(i,a)=>{let c=new $(...i.flatMap(f=>[o(f.byteLength),f]));await e.write(c,a)},unwrap:()=>e.unwrap()}}function Xs(){let r=Ut(),t=!1;return{sink:async e=>{if(t)throw new Error("already piped");t=!0,r.resolve(e)},source:async function*(){yield*await r.promise}()}}function Vc(){let r=Xs(),t=Xs();return[{source:r.source,sink:t.sink},{source:t.source,sink:r.sink}]}var qn=class{buffer;mask;top;btm;next;constructor(t){if(!(t>0)||(t-1&t)!==0)throw new Error("Max size for a FixedFIFO should be a power of two");this.buffer=new Array(t),this.mask=t-1,this.top=0,this.btm=0,this.next=null}push(t){return this.buffer[this.top]!==void 0?!1:(this.buffer[this.top]=t,this.top=this.top+1&this.mask,!0)}shift(){let t=this.buffer[this.btm];if(t!==void 0)return this.buffer[this.btm]=void 0,this.btm=this.btm+1&this.mask,t}isEmpty(){return this.buffer[this.btm]===void 0}},ar=class{size;hwm;head;tail;constructor(t={}){this.hwm=t.splitLimit??16,this.head=new qn(this.hwm),this.tail=this.head,this.size=0}calculateSize(t){return t?.byteLength!=null?t.byteLength:1}push(t){if(t?.value!=null&&(this.size+=this.calculateSize(t.value)),!this.head.push(t)){let e=this.head;this.head=e.next=new qn(2*this.head.buffer.length),this.head.push(t)}}shift(){let t=this.tail.shift();if(t===void 0&&this.tail.next!=null){let e=this.tail.next;this.tail.next=null,this.tail=e,t=this.tail.shift()}return t?.value!=null&&(this.size-=this.calculateSize(t.value)),t}isEmpty(){return this.head.isEmpty()}};var Js=class extends Error{type;code;constructor(t,e){super(t??"The operation was aborted"),this.type="aborted",this.code=e??"ABORT_ERR"}};function zn(r={}){return Ph(e=>{let n=e.shift();if(n==null)return{done:!0};if(n.error!=null)throw n.error;return{done:n.done===!0,value:n.value}},r)}function Ph(r,t){t=t??{};let e=t.onEnd,n=new ar,o,s,i,a=Ut(),c=async()=>{try{return n.isEmpty()?i?{done:!0}:await new Promise((x,_)=>{s=M=>{s=null,n.push(M);try{x(r(n))}catch(S){_(S)}return o}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{a.resolve(),a=Ut()})}},f=x=>s!=null?s(x):(n.push(x),o),u=x=>(n=new ar,s!=null?s({error:x}):(n.push({error:x}),o)),l=x=>{if(i)return o;if(t?.objectMode!==!0&&x?.byteLength==null)throw new Error("objectMode was not true but tried to push non-Uint8Array value");return f({done:!1,value:x})},p=x=>i?o:(i=!0,x!=null?u(x):f({done:!0})),w=()=>(n=new ar,p(),{done:!0}),y=x=>(p(x),{done:!0});if(o={[Symbol.asyncIterator](){return this},next:c,return:w,throw:y,push:l,end:p,get readableLength(){return n.size},onEmpty:async x=>{let _=x?.signal;if(_?.throwIfAborted(),n.isEmpty())return;let M,S;_!=null&&(M=new Promise((d,I)=>{S=()=>{I(new Js)},_.addEventListener("abort",S)}));try{await Promise.race([a.promise,M])}finally{S!=null&&_!=null&&_?.removeEventListener("abort",S)}}},e==null)return o;let m=o;return o={[Symbol.asyncIterator](){return this},next(){return m.next()},throw(x){return m.throw(x),e!=null&&(e(x),e=void 0),{done:!0}},return(){return m.return(),e!=null&&(e(),e=void 0),{done:!0}},push:l,end(x){return m.end(x),e!=null&&(e(x),e=void 0),o},get readableLength(){return m.readableLength},onEmpty:x=>m.onEmpty(x)},o}function Uh(r){return r[Symbol.asyncIterator]!=null}async function kh(r,t,e){try{await Promise.all(r.map(async n=>{for await(let o of n)await t.push(o,{signal:e}),e.throwIfAborted()})),await t.end(void 0,{signal:e})}catch(n){await t.end(n,{signal:e}).catch(()=>{})}}async function*Rh(r){let t=new AbortController,e=Nn();kh(r,e,t.signal).catch(()=>{});try{yield*e}finally{t.abort()}}function*Dh(r){for(let t of r)yield*t}function Kh(...r){let t=[];for(let e of r)Uh(e)||t.push(e);return t.length===r.length?Dh(t):Rh(r)}var qc=Kh;function zc(r,...t){if(r==null)throw new Error("Empty pipeline");if(Qs(r)){let n=r;r=()=>n.source}else if(Gc(r)||Fc(r)){let n=r;r=()=>n}let e=[r,...t];if(e.length>1&&Qs(e[e.length-1])&&(e[e.length-1]=e[e.length-1].sink),e.length>2)for(let n=1;n<e.length-1;n++)Qs(e[n])&&(e[n]=Mh(e[n]));return Nh(...e)}var Nh=(...r)=>{let t;for(;r.length>0;)t=r.shift()(t);return t},Fc=r=>r?.[Symbol.asyncIterator]!=null,Gc=r=>r?.[Symbol.iterator]!=null,Qs=r=>r==null?!1:r.sink!=null&&r.source!=null,Mh=r=>t=>{let e=r.sink(t);if(e?.then!=null){let n=zn({objectMode:!0});e.then(()=>{n.end()},i=>{n.end(i)});let o,s=r.source;if(Fc(s))o=async function*(){yield*s,n.end()};else if(Gc(s))o=function*(){yield*s,n.end()};else throw new Error("Unknown duplex source type - must be Iterable or AsyncIterable");return qc(n,o())}return r.source};var cr=!!globalThis.process?.env?.DUMP_SESSION_KEYS;function jc(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function Fn(r){if(typeof r!="boolean")throw new Error(`boolean expected, not ${r}`)}function Gn(r){if(!Number.isSafeInteger(r)||r<0)throw new Error("positive integer expected, got "+r)}function _t(r,...t){if(!jc(r))throw new Error("Uint8Array expected");if(t.length>0&&!t.includes(r.length))throw new Error("Uint8Array expected of length "+t+", got length="+r.length)}function ti(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 $c(r,t){_t(r);let e=t.outputLen;if(r.length<e)throw new Error("digestInto() expects output buffer of length at least "+e)}function ae(r){return new Uint32Array(r.buffer,r.byteOffset,Math.floor(r.byteLength/4))}function ce(...r){for(let t=0;t<r.length;t++)r[t].fill(0)}function Oh(r){return new DataView(r.buffer,r.byteOffset,r.byteLength)}var Hh=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;function Vh(r){if(typeof r!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(r))}function Wn(r){if(typeof r=="string")r=Vh(r);else if(jc(r))r=jn(r);else throw new Error("Uint8Array expected, got "+typeof r);return r}function Zc(r,t){if(t==null||typeof t!="object")throw new Error("options must be defined");return Object.assign(r,t)}function Yc(r,t){if(r.length!==t.length)return!1;let e=0;for(let n=0;n<r.length;n++)e|=r[n]^t[n];return e===0}var ei=(r,t)=>{function e(n,...o){if(_t(n),!Hh)throw new Error("Non little-endian hardware is not yet supported");if(r.nonceLength!==void 0){let u=o[0];if(!u)throw new Error("nonce / iv required");r.varSizeNonce?_t(u):_t(u,r.nonceLength)}let s=r.tagLength;s&&o[1]!==void 0&&_t(o[1]);let i=t(n,...o),a=(u,l)=>{if(l!==void 0){if(u!==2)throw new Error("cipher output not supported");_t(l)}},c=!1;return{encrypt(u,l){if(c)throw new Error("cannot encrypt() twice with same key + nonce");return c=!0,_t(u),a(i.encrypt.length,l),i.encrypt(u,l)},decrypt(u,l){if(_t(u),s&&u.length<s)throw new Error("invalid ciphertext length: smaller than tagLength="+s);return a(i.decrypt.length,l),i.decrypt(u,l)}}}return Object.assign(e,r),e};function ri(r,t,e=!0){if(t===void 0)return new Uint8Array(r);if(t.length!==r)throw new Error("invalid output length, expected "+r+", got: "+t.length);if(e&&!qh(t))throw new Error("invalid output, must be aligned");return t}function Wc(r,t,e,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(t,e,n);let o=BigInt(32),s=BigInt(4294967295),i=Number(e>>o&s),a=Number(e&s),c=n?4:0,f=n?0:4;r.setUint32(t+c,i,n),r.setUint32(t+f,a,n)}function Xc(r,t,e){Fn(e);let n=new Uint8Array(16),o=Oh(n);return Wc(o,0,BigInt(t),e),Wc(o,8,BigInt(r),e),n}function qh(r){return r.byteOffset%4===0}function jn(r){return Uint8Array.from(r)}var Qc=r=>Uint8Array.from(r.split("").map(t=>t.charCodeAt(0))),zh=Qc("expand 16-byte k"),Fh=Qc("expand 32-byte k"),Gh=ae(zh),Wh=ae(Fh);function N(r,t){return r<<t|r>>>32-t}function ni(r){return r.byteOffset%4===0}var $n=64,jh=16,tu=2**32-1,Jc=new Uint32Array;function $h(r,t,e,n,o,s,i,a){let c=o.length,f=new Uint8Array($n),u=ae(f),l=ni(o)&&ni(s),p=l?ae(o):Jc,w=l?ae(s):Jc;for(let y=0;y<c;i++){if(r(t,e,n,u,i,a),i>=tu)throw new Error("arx: counter overflow");let m=Math.min($n,c-y);if(l&&m===$n){let x=y/4;if(y%4!==0)throw new Error("arx: invalid block position");for(let _=0,M;_<jh;_++)M=x+_,w[M]=p[M]^u[_];y+=$n;continue}for(let x=0,_;x<m;x++)_=y+x,s[_]=o[_]^f[x];y+=m}}function oi(r,t){let{allowShortKeys:e,extendNonceFn:n,counterLength:o,counterRight:s,rounds:i}=Zc({allowShortKeys:!1,counterLength:8,counterRight:!1,rounds:20},t);if(typeof r!="function")throw new Error("core must be a function");return Gn(o),Gn(i),Fn(s),Fn(e),(a,c,f,u,l=0)=>{_t(a),_t(c),_t(f);let p=f.length;if(u===void 0&&(u=new Uint8Array(p)),_t(u),Gn(l),l<0||l>=tu)throw new Error("arx: counter overflow");if(u.length<p)throw new Error(`arx: output (${u.length}) is shorter than data (${p})`);let w=[],y=a.length,m,x;if(y===32)w.push(m=jn(a)),x=Wh;else if(y===16&&e)m=new Uint8Array(32),m.set(a),m.set(a,16),x=Gh,w.push(m);else throw new Error(`arx: invalid 32-byte key, got length=${y}`);ni(c)||w.push(c=jn(c));let _=ae(m);if(n){if(c.length!==24)throw new Error("arx: extended nonce must be 24 bytes");n(x,_,ae(c.subarray(0,16)),_),c=c.subarray(16)}let M=16-o;if(M!==c.length)throw new Error(`arx: nonce must be ${M} or 16 bytes`);if(M!==12){let d=new Uint8Array(12);d.set(c,s?0:12-c.length),c=d,w.push(c)}let S=ae(c);return $h(r,x,_,S,f,u,l,i),ce(...w),u}}var Et=(r,t)=>r[t++]&255|(r[t++]&255)<<8,si=class{constructor(t){this.blockLen=16,this.outputLen=16,this.buffer=new Uint8Array(16),this.r=new Uint16Array(10),this.h=new Uint16Array(10),this.pad=new Uint16Array(8),this.pos=0,this.finished=!1,t=Wn(t),_t(t,32);let e=Et(t,0),n=Et(t,2),o=Et(t,4),s=Et(t,6),i=Et(t,8),a=Et(t,10),c=Et(t,12),f=Et(t,14);this.r[0]=e&8191,this.r[1]=(e>>>13|n<<3)&8191,this.r[2]=(n>>>10|o<<6)&7939,this.r[3]=(o>>>7|s<<9)&8191,this.r[4]=(s>>>4|i<<12)&255,this.r[5]=i>>>1&8190,this.r[6]=(i>>>14|a<<2)&8191,this.r[7]=(a>>>11|c<<5)&8065,this.r[8]=(c>>>8|f<<8)&8191,this.r[9]=f>>>5&127;for(let u=0;u<8;u++)this.pad[u]=Et(t,16+2*u)}process(t,e,n=!1){let o=n?0:2048,{h:s,r:i}=this,a=i[0],c=i[1],f=i[2],u=i[3],l=i[4],p=i[5],w=i[6],y=i[7],m=i[8],x=i[9],_=Et(t,e+0),M=Et(t,e+2),S=Et(t,e+4),d=Et(t,e+6),I=Et(t,e+8),U=Et(t,e+10),B=Et(t,e+12),L=Et(t,e+14),k=s[0]+(_&8191),K=s[1]+((_>>>13|M<<3)&8191),T=s[2]+((M>>>10|S<<6)&8191),D=s[3]+((S>>>7|d<<9)&8191),C=s[4]+((d>>>4|I<<12)&8191),H=s[5]+(I>>>1&8191),E=s[6]+((I>>>14|U<<2)&8191),A=s[7]+((U>>>11|B<<5)&8191),P=s[8]+((B>>>8|L<<8)&8191),b=s[9]+(L>>>5|o),h=0,g=h+k*a+K*(5*x)+T*(5*m)+D*(5*y)+C*(5*w);h=g>>>13,g&=8191,g+=H*(5*p)+E*(5*l)+A*(5*u)+P*(5*f)+b*(5*c),h+=g>>>13,g&=8191;let v=h+k*c+K*a+T*(5*x)+D*(5*m)+C*(5*y);h=v>>>13,v&=8191,v+=H*(5*w)+E*(5*p)+A*(5*l)+P*(5*u)+b*(5*f),h+=v>>>13,v&=8191;let R=h+k*f+K*c+T*a+D*(5*x)+C*(5*m);h=R>>>13,R&=8191,R+=H*(5*y)+E*(5*w)+A*(5*p)+P*(5*l)+b*(5*u),h+=R>>>13,R&=8191;let O=h+k*u+K*f+T*c+D*a+C*(5*x);h=O>>>13,O&=8191,O+=H*(5*m)+E*(5*y)+A*(5*w)+P*(5*p)+b*(5*l),h+=O>>>13,O&=8191;let q=h+k*l+K*u+T*f+D*c+C*a;h=q>>>13,q&=8191,q+=H*(5*x)+E*(5*m)+A*(5*y)+P*(5*w)+b*(5*p),h+=q>>>13,q&=8191;let z=h+k*p+K*l+T*u+D*f+C*c;h=z>>>13,z&=8191,z+=H*a+E*(5*x)+A*(5*m)+P*(5*y)+b*(5*w),h+=z>>>13,z&=8191;let F=h+k*w+K*p+T*l+D*u+C*f;h=F>>>13,F&=8191,F+=H*c+E*a+A*(5*x)+P*(5*m)+b*(5*y),h+=F>>>13,F&=8191;let G=h+k*y+K*w+T*p+D*l+C*u;h=G>>>13,G&=8191,G+=H*f+E*c+A*a+P*(5*x)+b*(5*m),h+=G>>>13,G&=8191;let J=h+k*m+K*y+T*w+D*p+C*l;h=J>>>13,J&=8191,J+=H*u+E*f+A*c+P*a+b*(5*x),h+=J>>>13,J&=8191;let Z=h+k*x+K*m+T*y+D*w+C*p;h=Z>>>13,Z&=8191,Z+=H*l+E*u+A*f+P*c+b*a,h+=Z>>>13,Z&=8191,h=(h<<2)+h|0,h=h+g|0,g=h&8191,h=h>>>13,v+=h,s[0]=g,s[1]=v,s[2]=R,s[3]=O,s[4]=q,s[5]=z,s[6]=F,s[7]=G,s[8]=J,s[9]=Z}finalize(){let{h:t,pad:e}=this,n=new Uint16Array(10),o=t[1]>>>13;t[1]&=8191;for(let a=2;a<10;a++)t[a]+=o,o=t[a]>>>13,t[a]&=8191;t[0]+=o*5,o=t[0]>>>13,t[0]&=8191,t[1]+=o,o=t[1]>>>13,t[1]&=8191,t[2]+=o,n[0]=t[0]+5,o=n[0]>>>13,n[0]&=8191;for(let a=1;a<10;a++)n[a]=t[a]+o,o=n[a]>>>13,n[a]&=8191;n[9]-=8192;let s=(o^1)-1;for(let a=0;a<10;a++)n[a]&=s;s=~s;for(let a=0;a<10;a++)t[a]=t[a]&s|n[a];t[0]=(t[0]|t[1]<<13)&65535,t[1]=(t[1]>>>3|t[2]<<10)&65535,t[2]=(t[2]>>>6|t[3]<<7)&65535,t[3]=(t[3]>>>9|t[4]<<4)&65535,t[4]=(t[4]>>>12|t[5]<<1|t[6]<<14)&65535,t[5]=(t[6]>>>2|t[7]<<11)&65535,t[6]=(t[7]>>>5|t[8]<<8)&65535,t[7]=(t[8]>>>8|t[9]<<5)&65535;let i=t[0]+e[0];t[0]=i&65535;for(let a=1;a<8;a++)i=(t[a]+e[a]|0)+(i>>>16)|0,t[a]=i&65535;ce(n)}update(t){ti(this),t=Wn(t),_t(t);let{buffer:e,blockLen:n}=this,o=t.length;for(let s=0;s<o;){let i=Math.min(n-this.pos,o-s);if(i===n){for(;n<=o-s;s+=n)this.process(t,s);continue}e.set(t.subarray(s,s+i),this.pos),this.pos+=i,s+=i,this.pos===n&&(this.process(e,0,!1),this.pos=0)}return this}destroy(){ce(this.h,this.r,this.buffer,this.pad)}digestInto(t){ti(this),$c(t,this),this.finished=!0;let{buffer:e,h:n}=this,{pos:o}=this;if(o){for(e[o++]=1;o<16;o++)e[o]=0;this.process(e,0,!0)}this.finalize();let s=0;for(let i=0;i<8;i++)t[s++]=n[i]>>>0,t[s++]=n[i]>>>8;return t}digest(){let{buffer:t,outputLen:e}=this;this.digestInto(t);let n=t.slice(0,e);return this.destroy(),n}};function Zh(r){let t=(n,o)=>r(o).update(Wn(n)).digest(),e=r(new Uint8Array(32));return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=n=>r(n),t}var eu=Zh(r=>new si(r));function ou(r,t,e,n,o,s=20){let i=r[0],a=r[1],c=r[2],f=r[3],u=t[0],l=t[1],p=t[2],w=t[3],y=t[4],m=t[5],x=t[6],_=t[7],M=o,S=e[0],d=e[1],I=e[2],U=i,B=a,L=c,k=f,K=u,T=l,D=p,C=w,H=y,E=m,A=x,P=_,b=M,h=S,g=d,v=I;for(let O=0;O<s;O+=2)U=U+K|0,b=N(b^U,16),H=H+b|0,K=N(K^H,12),U=U+K|0,b=N(b^U,8),H=H+b|0,K=N(K^H,7),B=B+T|0,h=N(h^B,16),E=E+h|0,T=N(T^E,12),B=B+T|0,h=N(h^B,8),E=E+h|0,T=N(T^E,7),L=L+D|0,g=N(g^L,16),A=A+g|0,D=N(D^A,12),L=L+D|0,g=N(g^L,8),A=A+g|0,D=N(D^A,7),k=k+C|0,v=N(v^k,16),P=P+v|0,C=N(C^P,12),k=k+C|0,v=N(v^k,8),P=P+v|0,C=N(C^P,7),U=U+T|0,v=N(v^U,16),A=A+v|0,T=N(T^A,12),U=U+T|0,v=N(v^U,8),A=A+v|0,T=N(T^A,7),B=B+D|0,b=N(b^B,16),P=P+b|0,D=N(D^P,12),B=B+D|0,b=N(b^B,8),P=P+b|0,D=N(D^P,7),L=L+C|0,h=N(h^L,16),H=H+h|0,C=N(C^H,12),L=L+C|0,h=N(h^L,8),H=H+h|0,C=N(C^H,7),k=k+K|0,g=N(g^k,16),E=E+g|0,K=N(K^E,12),k=k+K|0,g=N(g^k,8),E=E+g|0,K=N(K^E,7);let R=0;n[R++]=i+U|0,n[R++]=a+B|0,n[R++]=c+L|0,n[R++]=f+k|0,n[R++]=u+K|0,n[R++]=l+T|0,n[R++]=p+D|0,n[R++]=w+C|0,n[R++]=y+H|0,n[R++]=m+E|0,n[R++]=x+A|0,n[R++]=_+P|0,n[R++]=M+b|0,n[R++]=S+h|0,n[R++]=d+g|0,n[R++]=I+v|0}function Yh(r,t,e,n){let o=r[0],s=r[1],i=r[2],a=r[3],c=t[0],f=t[1],u=t[2],l=t[3],p=t[4],w=t[5],y=t[6],m=t[7],x=e[0],_=e[1],M=e[2],S=e[3];for(let I=0;I<20;I+=2)o=o+c|0,x=N(x^o,16),p=p+x|0,c=N(c^p,12),o=o+c|0,x=N(x^o,8),p=p+x|0,c=N(c^p,7),s=s+f|0,_=N(_^s,16),w=w+_|0,f=N(f^w,12),s=s+f|0,_=N(_^s,8),w=w+_|0,f=N(f^w,7),i=i+u|0,M=N(M^i,16),y=y+M|0,u=N(u^y,12),i=i+u|0,M=N(M^i,8),y=y+M|0,u=N(u^y,7),a=a+l|0,S=N(S^a,16),m=m+S|0,l=N(l^m,12),a=a+l|0,S=N(S^a,8),m=m+S|0,l=N(l^m,7),o=o+f|0,S=N(S^o,16),y=y+S|0,f=N(f^y,12),o=o+f|0,S=N(S^o,8),y=y+S|0,f=N(f^y,7),s=s+u|0,x=N(x^s,16),m=m+x|0,u=N(u^m,12),s=s+u|0,x=N(x^s,8),m=m+x|0,u=N(u^m,7),i=i+l|0,_=N(_^i,16),p=p+_|0,l=N(l^p,12),i=i+l|0,_=N(_^i,8),p=p+_|0,l=N(l^p,7),a=a+c|0,M=N(M^a,16),w=w+M|0,c=N(c^w,12),a=a+c|0,M=N(M^a,8),w=w+M|0,c=N(c^w,7);let d=0;n[d++]=o,n[d++]=s,n[d++]=i,n[d++]=a,n[d++]=x,n[d++]=_,n[d++]=M,n[d++]=S}var Xh=oi(ou,{counterRight:!1,counterLength:4,allowShortKeys:!1}),Jh=oi(ou,{counterRight:!1,counterLength:8,extendNonceFn:Yh,allowShortKeys:!1});var Qh=new Uint8Array(16),ru=(r,t)=>{r.update(t);let e=t.length%16;e&&r.update(Qh.subarray(e))},td=new Uint8Array(32);function nu(r,t,e,n,o){let s=r(t,e,td),i=eu.create(s);o&&ru(i,o),ru(i,n);let a=Xc(n.length,o?o.length:0,!0);i.update(a);let c=i.digest();return ce(s,a),c}var su=r=>(t,e,n)=>({encrypt(s,i){let a=s.length;i=ri(a+16,i,!1),i.set(s);let c=i.subarray(0,-16);r(t,e,c,c,1);let f=nu(r,t,e,c,n);return i.set(f,a),ce(f),i},decrypt(s,i){i=ri(s.length-16,i,!1);let a=s.subarray(0,-16),c=s.subarray(-16),f=nu(r,t,e,a,n);if(!Yc(c,f))throw new Error("invalid tag");return i.set(s.subarray(0,-16)),r(t,e,i,i,1),ce(f),i}}),ii=ei({blockSize:64,nonceLength:12,tagLength:16},su(Xh)),ew=ei({blockSize:64,nonceLength:24,tagLength:16},su(Jh));function au(r,t,e){return vr(r),e===void 0&&(e=new Uint8Array(r.outputLen)),or(r,pe(e),pe(t))}var ai=Uint8Array.from([0]),iu=Uint8Array.of();function cu(r,t,e,n=32){vr(r),Ze(n);let o=r.outputLen;if(n>255*o)throw new Error("Length should be <= 255*HashLen");let s=Math.ceil(n/o);e===void 0&&(e=iu);let i=new Uint8Array(s*o),a=or.create(r,t),c=a._cloneInto(),f=new Uint8Array(a.outputLen);for(let u=0;u<s;u++)ai[0]=u+1,c.update(u===0?iu:f).update(e).update(ai).digestInto(f),i.set(f,o*u),a._cloneInto(c);return a.destroy(),c.destroy(),Ht(f,ai),i.slice(0,n)}var ci={hashSHA256(r){return Ae(r.subarray())},getHKDF(r,t){let e=au(Ae,t,r),o=cu(Ae,e,void 0,96),s=o.subarray(0,32),i=o.subarray(32,64),a=o.subarray(64,96);return[s,i,a]},generateX25519KeyPair(){let r=Rr.utils.randomPrivateKey();return{publicKey:Rr.getPublicKey(r),privateKey:r}},generateX25519KeyPairFromSeed(r){return{publicKey:Rr.getPublicKey(r),privateKey:r}},generateX25519SharedKey(r,t){return Rr.getSharedSecret(r.subarray(),t.subarray())},chaCha20Poly1305Encrypt(r,t,e,n){return ii(n,t,e).encrypt(r.subarray())},chaCha20Poly1305Decrypt(r,t,e,n,o){return ii(n,t,e).decrypt(r.subarray(),o)}};var uu=ci;function fu(r){return{generateKeypair:r.generateX25519KeyPair,dh:(t,e)=>r.generateX25519SharedKey(t.privateKey,e).subarray(0,32),encrypt:r.chaCha20Poly1305Encrypt,decrypt:r.chaCha20Poly1305Decrypt,hash:r.hashSHA256,hkdf:r.getHKDF}}var ur=r=>{let t=pt(2);return t[0]=r>>8,t[1]=r,t};ur.bytes=2;var Yr=r=>{if(r.length<2)throw RangeError("Could not decode int16BE");if(r instanceof Uint8Array){let t=0;return t+=r[0]<<8,t+=r[1],t}return r.getUint16(0)};Yr.bytes=2;function lu(r){return{xxHandshakeSuccesses:r.registerCounter("libp2p_noise_xxhandshake_successes_total",{help:"Total count of noise xxHandshakes successes_"}),xxHandshakeErrors:r.registerCounter("libp2p_noise_xxhandshake_error_total",{help:"Total count of noise xxHandshakes errors"}),encryptedPackets:r.registerCounter("libp2p_noise_encrypted_packets_total",{help:"Total count of noise encrypted packets successfully"}),decryptedPackets:r.registerCounter("libp2p_noise_decrypted_packets_total",{help:"Total count of noise decrypted packets"}),decryptErrors:r.registerCounter("libp2p_noise_decrypt_errors_total",{help:"Total count of noise decrypt errors"})}}function ui(r,t){!t.enabled||!cr||(r?(t(`LOCAL_STATIC_PUBLIC_KEY ${V(r.publicKey,"hex")}`),t(`LOCAL_STATIC_PRIVATE_KEY ${V(r.privateKey,"hex")}`)):t("Missing local static keys."))}function fi(r,t){!t.enabled||!cr||(r?(t(`LOCAL_PUBLIC_EPHEMERAL_KEY ${V(r.publicKey,"hex")}`),t(`LOCAL_PRIVATE_EPHEMERAL_KEY ${V(r.privateKey,"hex")}`)):t("Missing local ephemeral keys."))}function hu(r,t){!t.enabled||!cr||t(r?`REMOTE_STATIC_PUBLIC_KEY ${V(r.subarray(),"hex")}`:"Missing remote static public key.")}function li(r,t){!t.enabled||!cr||t(r?`REMOTE_EPHEMERAL_PUBLIC_KEY ${V(r.subarray(),"hex")}`:"Missing remote ephemeral keys.")}function hi(r,t,e){!e.enabled||!cr||(e(`CIPHER_STATE_1 ${r.n.getUint64()} ${r.k&&V(r.k,"hex")}`),e(`CIPHER_STATE_2 ${t.n.getUint64()} ${t.k&&V(t.k,"hex")}`))}var fr=class r extends Error{code;constructor(t="Invalid crypto exchange"){super(t),this.code=r.code}static code="ERR_INVALID_CRYPTO_EXCHANGE"};var ed=0,rd=4294967295,nd="Cipherstate has reached maximum n, a new handshake must be performed",Zn=class{n;bytes;view;constructor(t=ed){this.n=t,this.bytes=dt(12),this.view=new DataView(this.bytes.buffer,this.bytes.byteOffset,this.bytes.byteLength),this.view.setUint32(4,t,!0)}increment(){this.n++,this.view.setUint32(4,this.n,!0)}getBytes(){return this.bytes}getUint64(){return this.n}assertValue(){if(this.n>rd)throw new Error(nd)}};var He=dt(0),lr=class{k;n;crypto;constructor(t,e=void 0,n=0){this.crypto=t,this.k=e,this.n=new Zn(n)}hasKey(){return!!this.k}encryptWithAd(t,e){if(!this.hasKey())return e;this.n.assertValue();let n=this.crypto.encrypt(e,this.n.getBytes(),t,this.k);return this.n.increment(),n}decryptWithAd(t,e,n){if(!this.hasKey())return e;this.n.assertValue();let o=this.crypto.decrypt(e,this.n.getBytes(),t,this.k,n);return this.n.increment(),o}},di=class{cs;ck;h;crypto;constructor(t,e){this.crypto=t;let n=Q(e,"utf-8");this.h=od(t,n),this.ck=this.h,this.cs=new lr(t)}mixKey(t){let[e,n]=this.crypto.hkdf(this.ck,t);this.ck=e,this.cs=new lr(this.crypto,n)}mixHash(t){this.h=this.crypto.hash(new $(this.h,t))}encryptAndHash(t){let e=this.cs.encryptWithAd(this.h,t);return this.mixHash(e),e}decryptAndHash(t){let e=this.cs.decryptWithAd(this.h,t);return this.mixHash(t),e}split(){let[t,e]=this.crypto.hkdf(this.ck,He);return[new lr(this.crypto,t),new lr(this.crypto,e)]}},pi=class{ss;s;e;rs;re;initiator;crypto;constructor(t){let{crypto:e,protocolName:n,prologue:o,initiator:s,s:i,e:a,rs:c,re:f}=t;this.crypto=e,this.ss=new di(e,n),this.ss.mixHash(o),this.initiator=s,this.s=i,this.e=a,this.rs=c,this.re=f}writeE(){if(this.e)throw new Error("ephemeral keypair is already set");let t=this.crypto.generateKeypair();return this.ss.mixHash(t.publicKey),this.e=t,t.publicKey}writeS(){if(!this.s)throw new Error("static keypair is not set");return this.ss.encryptAndHash(this.s.publicKey)}writeEE(){if(!this.e)throw new Error("ephemeral keypair is not set");if(!this.re)throw new Error("remote ephemeral public key is not set");this.ss.mixKey(this.crypto.dh(this.e,this.re))}writeES(){if(this.initiator){if(!this.e)throw new Error("ephemeral keypair is not set");if(!this.rs)throw new Error("remote static public key is not set");this.ss.mixKey(this.crypto.dh(this.e,this.rs))}else{if(!this.s)throw new Error("static keypair is not set");if(!this.re)throw new Error("remote ephemeral public key is not set");this.ss.mixKey(this.crypto.dh(this.s,this.re))}}writeSE(){if(this.initiator){if(!this.s)throw new Error("static keypair is not set");if(!this.re)throw new Error("remote ephemeral public key is not set");this.ss.mixKey(this.crypto.dh(this.s,this.re))}else{if(!this.e)throw new Error("ephemeral keypair is not set");if(!this.rs)throw new Error("remote static public key is not set");this.ss.mixKey(this.crypto.dh(this.e,this.rs))}}readE(t,e=0){if(this.re)throw new Error("remote ephemeral public key is already set");if(t.byteLength<e+32)throw new Error("message is not long enough");this.re=t.sublist(e,e+32),this.ss.mixHash(this.re)}readS(t,e=0){if(this.rs)throw new Error("remote static public key is already set");let n=32+(this.ss.cs.hasKey()?16:0);if(t.byteLength<e+n)throw new Error("message is not long enough");let o=t.sublist(e,e+n);return this.rs=this.ss.decryptAndHash(o),n}readEE(){this.writeEE()}readES(){this.writeES()}readSE(){this.writeSE()}},Xr=class extends pi{writeMessageA(t){return new $(this.writeE(),this.ss.encryptAndHash(t))}writeMessageB(t){let e=this.writeE();this.writeEE();let n=this.writeS();return this.writeES(),new $(e,n,this.ss.encryptAndHash(t))}writeMessageC(t){let e=this.writeS();return this.writeSE(),new $(e,this.ss.encryptAndHash(t))}readMessageA(t){try{return this.readE(t),this.ss.decryptAndHash(t.sublist(32))}catch(e){throw new fr(`handshake stage 0 validation fail: ${e.message}`)}}readMessageB(t){try{this.readE(t),this.readEE();let e=this.readS(t,32);return this.readES(),this.ss.decryptAndHash(t.sublist(32+e))}catch(e){throw new fr(`handshake stage 1 validation fail: ${e.message}`)}}readMessageC(t){try{let e=this.readS(t);return this.readSE(),this.ss.decryptAndHash(t.sublist(e))}catch(e){throw new fr(`handshake stage 2 validation fail: ${e.message}`)}}};function od(r,t){if(t.length<=32){let e=dt(32);return e.set(t),e}else return r.hash(t)}var Yn;(function(r){let t;r.codec=()=>(t==null&&(t=Me((e,n,o={})=>{if(o.lengthDelimited!==!1&&n.fork(),e.webtransportCerthashes!=null)for(let s of e.webtransportCerthashes)n.uint32(10),n.bytes(s);if(e.streamMuxers!=null)for(let s of e.streamMuxers)n.uint32(18),n.string(s);o.lengthDelimited!==!1&&n.ldelim()},(e,n,o={})=>{let s={webtransportCerthashes:[],streamMuxers:[]},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let a=e.uint32();switch(a>>>3){case 1:{if(o.limits?.webtransportCerthashes!=null&&s.webtransportCerthashes.length===o.limits.webtransportCerthashes)throw new Mr('Decode error - map field "webtransportCerthashes" had too many elements');s.webtransportCerthashes.push(e.bytes());break}case 2:{if(o.limits?.streamMuxers!=null&&s.streamMuxers.length===o.limits.streamMuxers)throw new Mr('Decode error - map field "streamMuxers" had too many elements');s.streamMuxers.push(e.string());break}default:{e.skipType(a&7);break}}}return s})),t),r.encode=e=>Ne(e,r.codec()),r.decode=(e,n)=>De(e,r.codec(),n)})(Yn||(Yn={}));var Jr;(function(r){let t;r.codec=()=>(t==null&&(t=Me((e,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),e.identityKey!=null&&e.identityKey.byteLength>0&&(n.uint32(10),n.bytes(e.identityKey)),e.identitySig!=null&&e.identitySig.byteLength>0&&(n.uint32(18),n.bytes(e.identitySig)),e.extensions!=null&&(n.uint32(34),Yn.codec().encode(e.extensions,n)),o.lengthDelimited!==!1&&n.ldelim()},(e,n,o={})=>{let s={identityKey:dt(0),identitySig:dt(0)},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let a=e.uint32();switch(a>>>3){case 1:{s.identityKey=e.bytes();break}case 2:{s.identitySig=e.bytes();break}case 4:{s.extensions=Yn.codec().decode(e,e.uint32(),{limits:o.limits?.extensions});break}default:{e.skipType(a&7);break}}}return s})),t),r.encode=e=>Ne(e,r.codec()),r.decode=(e,n)=>De(e,r.codec(),n)})(Jr||(Jr={}));async function mi(r,t,e){let n=await r.sign(du(t));return Jr.encode({identityKey:de(r.publicKey),identitySig:n,extensions:e})}async function yi(r,t,e){try{let n=Jr.decode(r),o=qr(n.identityKey);if(e?.equals(o)===!1)throw new Error(`Payload identity key ${o} does not match expected remote identity key ${e}`);if(!t)throw new Error("Remote static does not exist");let s=du(t);if(!await o.verify(s,n.identitySig))throw new Error("Invalid payload signature");return n}catch(n){throw new rn(n.message)}}function du(r){let t=Q("noise-libp2p-static-key:");return r instanceof Uint8Array?At([t,r],t.length+r.length):(r.prepend(t),r)}async function pu(r,t){let{log:e,connection:n,crypto:o,privateKey:s,prologue:i,s:a,remoteIdentityKey:c,extensions:f}=r,u=await mi(s,a.publicKey,f),l=new Xr({crypto:o,protocolName:"Noise_XX_25519_ChaChaPoly_SHA256",initiator:!0,prologue:i,s:a});ui(l.s,e),e.trace("Stage 0 - Initiator starting to send first message."),await n.write(l.writeMessageA(He),t),e.trace("Stage 0 - Initiator finished sending first message."),fi(l.e,e),e.trace("Stage 1 - Initiator waiting to receive first message from responder...");let p=l.readMessageB(await n.read(t));e.trace("Stage 1 - Initiator received the message."),li(l.re,e),hu(l.rs,e),e.trace("Initiator going to check remote's signature...");let w=await yi(p,l.rs,c);e.trace("All good with the signature!"),e.trace("Stage 2 - Initiator sending third handshake message."),await n.write(l.writeMessageC(u),t),e.trace("Stage 2 - Initiator sent message with signed payload.");let[y,m]=l.ss.split();return hi(y,m,e),{payload:w,encrypt:x=>y.encryptWithAd(He,x),decrypt:(x,_)=>m.decryptWithAd(He,x,_)}}async function mu(r,t){let{log:e,connection:n,crypto:o,privateKey:s,prologue:i,s:a,remoteIdentityKey:c,extensions:f}=r,u=await mi(s,a.publicKey,f),l=new Xr({crypto:o,protocolName:"Noise_XX_25519_ChaChaPoly_SHA256",initiator:!1,prologue:i,s:a});ui(l.s,e),e.trace("Stage 0 - Responder waiting to receive first message."),l.readMessageA(await n.read(t)),e.trace("Stage 0 - Responder received first message."),li(l.re,e),e.trace("Stage 1 - Responder sending out first message with signed payload and static key."),await n.write(l.writeMessageB(u),t),e.trace("Stage 1 - Responder sent the second handshake message with signed payload."),fi(l.e,e),e.trace("Stage 2 - Responder waiting for third handshake message...");let p=l.readMessageC(await n.read(t));e.trace("Stage 2 - Responder received the message, finished handshake.");let w=await yi(p,l.rs,c),[y,m]=l.ss.split();return hi(y,m,e),{payload:w,encrypt:x=>m.encryptWithAd(He,x),decrypt:(x,_)=>y.decryptWithAd(He,x,_)}}var gu=16;function xu(r,t){return async function*(e){for await(let n of e)for(let o=0;o<n.length;o+=65519){let s=o+65519;s>n.length&&(s=n.length);let i;n instanceof Uint8Array?i=r.encrypt(n.subarray(o,s)):i=r.encrypt(n.sublist(o,s)),t?.encryptedPackets.increment(),yield new $(ur(i.byteLength),i)}}}function wu(r,t){return async function*(e){for await(let n of e)for(let o=0;o<n.length;o+=65535){let s=o+65535;if(s>n.length&&(s=n.length),s-gu<o)throw new Error("Invalid chunk");let i=n.sublist(o,s),a=n.subarray(o,s-gu);try{let c=r.decrypt(i,a);t?.decryptedPackets.increment(),yield c}catch(c){throw t?.decryptErrors.increment(),c}}}}var Xn=class{protocol="/noise";crypto;prologue;staticKey;extensions;metrics;components;constructor(t,e={}){let{staticNoiseKey:n,extensions:o,crypto:s,prologueBytes:i}=e,{metrics:a}=t;this.components=t;let c=s??uu;this.crypto=fu(c),this.extensions={webtransportCerthashes:[],...o},this.metrics=a?lu(a):void 0,n?this.staticKey=c.generateX25519KeyPairFromSeed(n):this.staticKey=c.generateX25519KeyPair(),this.prologue=i??dt(0)}[Symbol.toStringTag]="@chainsafe/libp2p-noise";[un]=["@libp2p/connection-encryption","@chainsafe/libp2p-noise"];async secureOutbound(t,e){let n=Ys(t,{lengthEncoder:ur,lengthDecoder:Yr,maxDataLength:65535}),o=await this.performHandshakeInitiator(n,this.components.privateKey,e?.remotePeer?.publicKey,e),s=await this.createSecureConnection(n,o);t.source=s.source,t.sink=s.sink;let i=qr(o.payload.identityKey);return{conn:t,remoteExtensions:o.payload.extensions,remotePeer:js(i),streamMuxer:e?.skipStreamMuxerNegotiation===!0?void 0:this.getStreamMuxer(o.payload.extensions?.streamMuxers)}}getStreamMuxer(t){if(t==null||t.length===0)return;let e=this.components.upgrader.getStreamMuxers();if(e!=null)for(let n of t){let o=e.get(n);if(o!=null)return o}if(t.length)throw new ze("Early muxer negotiation was requested but the initiator and responder had no common muxers")}async secureInbound(t,e){let n=Ys(t,{lengthEncoder:ur,lengthDecoder:Yr,maxDataLength:65535}),o=await this.performHandshakeResponder(n,this.components.privateKey,e?.remotePeer?.publicKey,e),s=await this.createSecureConnection(n,o);t.source=s.source,t.sink=s.sink;let i=qr(o.payload.identityKey);return{conn:t,remoteExtensions:o.payload.extensions,remotePeer:js(i),streamMuxer:e?.skipStreamMuxerNegotiation===!0?void 0:this.getStreamMuxer(o.payload.extensions?.streamMuxers)}}async performHandshakeInitiator(t,e,n,o){let s,i=o?.skipStreamMuxerNegotiation===!0?[]:[...this.components.upgrader.getStreamMuxers().keys()];try{s=await pu({connection:t,privateKey:e,remoteIdentityKey:n,log:this.components.logger.forComponent("libp2p:noise:xxhandshake"),crypto:this.crypto,prologue:this.prologue,s:this.staticKey,extensions:{streamMuxers:i,webtransportCerthashes:[],...this.extensions}},o),this.metrics?.xxHandshakeSuccesses.increment()}catch(a){throw this.metrics?.xxHandshakeErrors.increment(),a}return s}async performHandshakeResponder(t,e,n,o){let s,i=o?.skipStreamMuxerNegotiation===!0?[]:[...this.components.upgrader.getStreamMuxers().keys()];try{s=await mu({connection:t,privateKey:e,remoteIdentityKey:n,log:this.components.logger.forComponent("libp2p:noise:xxhandshake"),crypto:this.crypto,prologue:this.prologue,s:this.staticKey,extensions:{streamMuxers:i,webtransportCerthashes:[],...this.extensions}},o),this.metrics?.xxHandshakeSuccesses.increment()}catch(a){throw this.metrics?.xxHandshakeErrors.increment(),a}return s}async createSecureConnection(t,e){let[n,o]=Vc(),s=t.unwrap();return await zc(n,xu(e,this.metrics),s,i=>Zr(i,{lengthDecoder:Yr}),wu(e,this.metrics),n),o}};function bu(r={}){return t=>new Xn(t,r)}var Jn=class{index=0;input="";new(t){return this.index=0,this.input=t,this}readAtomically(t){let e=this.index,n=t();return n===void 0&&(this.index=e),n}parseWith(t){let e=t();if(this.index===this.input.length)return e}peekChar(){if(!(this.index>=this.input.length))return this.input[this.index]}readChar(){if(!(this.index>=this.input.length))return this.input[this.index++]}readGivenChar(t){return this.readAtomically(()=>{let e=this.readChar();if(e===t)return e})}readSeparator(t,e,n){return this.readAtomically(()=>{if(!(e>0&&this.readGivenChar(t)===void 0))return n()})}readNumber(t,e,n,o){return this.readAtomically(()=>{let s=0,i=0,a=this.peekChar();if(a===void 0)return;let c=a==="0",f=2**(8*o)-1;for(;;){let u=this.readAtomically(()=>{let l=this.readChar();if(l===void 0)return;let p=Number.parseInt(l,t);if(!Number.isNaN(p))return p});if(u===void 0)break;if(s*=t,s+=u,s>f||(i+=1,e!==void 0&&i>e))return}if(i!==0)return!n&&c&&i>1?void 0:s})}readIPv4Addr(){return this.readAtomically(()=>{let t=new Uint8Array(4);for(let e=0;e<t.length;e++){let n=this.readSeparator(".",e,()=>this.readNumber(10,3,!1,1));if(n===void 0)return;t[e]=n}return t})}readIPv6Addr(){let t=e=>{for(let n=0;n<e.length/2;n++){let o=n*2;if(n<e.length-3){let i=this.readSeparator(":",n,()=>this.readIPv4Addr());if(i!==void 0)return e[o]=i[0],e[o+1]=i[1],e[o+2]=i[2],e[o+3]=i[3],[o+4,!0]}let s=this.readSeparator(":",n,()=>this.readNumber(16,4,!0,2));if(s===void 0)return[o,!1];e[o]=s>>8,e[o+1]=s&255}return[e.length,!1]};return this.readAtomically(()=>{let e=new Uint8Array(16),[n,o]=t(e);if(n===16)return e;if(o||this.readGivenChar(":")===void 0||this.readGivenChar(":")===void 0)return;let s=new Uint8Array(14),i=16-(n+2),[a]=t(s.subarray(0,i));return e.set(s.subarray(0,a),16-a),e})}readIPAddr(){return this.readIPv4Addr()??this.readIPv6Addr()}};var Eu=45,sd=15,hr=new Jn;function gi(r){if(!(r.length>sd))return hr.new(r).parseWith(()=>hr.readIPv4Addr())}function xi(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>Eu))return hr.new(r).parseWith(()=>hr.readIPv6Addr())}function Qn(r,t=!1){if(r.includes("%")&&(r=r.split("%")[0]),r.length>Eu)return;let e=hr.new(r).parseWith(()=>hr.readIPAddr());if(e)return t&&e.length===4?Uint8Array.from([0,0,0,0,0,0,0,0,0,0,255,255,e[0],e[1],e[2],e[3]]):e}function to(r){return!!gi(r)}function eo(r){return!!xi(r)}function ro(r){return!!Qn(r)}var id=r=>r.toString().split("/").slice(1),dr=r=>({match:t=>t.length<1?!1:r(t[0])?t.slice(1):!1,pattern:"fn"}),W=r=>({match:t=>dr(e=>e===r).match(t),pattern:r}),Ve=()=>({match:r=>dr(t=>typeof t=="string").match(r),pattern:"{string}"}),pr=()=>({match:r=>dr(t=>!isNaN(parseInt(t))).match(r),pattern:"{number}"}),rt=()=>({match:r=>{if(r.length<2||r[0]!=="p2p"&&r[0]!=="ipfs")return!1;if(r[1].startsWith("Q")||r[1].startsWith("1"))try{nt.decode(`z${r[1]}`)}catch{return!1}else return!1;return r.slice(2)},pattern:"/p2p/{peerid}"}),tn=()=>({match:r=>{if(r.length<2||r[0]!=="certhash")return!1;try{Uo.decode(r[1])}catch{return!1}return r.slice(2)},pattern:"/certhash/{certhash}"}),X=r=>({match:t=>{let e=r.match(t);return e===!1?t:e},pattern:`optional(${r.pattern})`}),Lt=(...r)=>({match:t=>{let e;for(let n of r){let o=n.match(t);o!==!1&&(e==null||o.length<e.length)&&(e=o)}return e??!1},pattern:`or(${r.map(t=>t.pattern).join(", ")})`}),j=(...r)=>({match:t=>{for(let e of r){let n=e.match(t);if(n===!1)return!1;t=n}return t},pattern:`and(${r.map(t=>t.pattern).join(", ")})`});function it(...r){function t(o){let s=id(o);for(let i of r){let a=i.match(s);if(a===!1)return!1;s=a}return s}function e(o){return t(o)!==!1}function n(o){let s=t(o);return s===!1?!1:s.length===0}return{matchers:r,matches:e,exactMatch:n}}var ad=rt(),Kb=it(ad),oo=j(W("dns4"),Ve()),so=j(W("dns6"),Ve()),io=j(W("dnsaddr"),Ve()),bi=j(W("dns"),Ve()),Nb=it(oo,X(rt())),Mb=it(so,X(rt())),Ob=it(io,X(rt())),Hb=it(Lt(bi,io,oo,so),X(rt())),Su=j(W("ip4"),dr(to)),Au=j(W("ip6"),dr(eo)),Ei=Lt(Su,Au),ue=Lt(Ei,bi,oo,so,io),Vb=it(Lt(Ei,j(Lt(bi,io,oo,so),X(rt())))),qb=it(Su),zb=it(Au),Fb=it(Ei),Si=j(ue,W("tcp"),pr()),en=j(ue,W("udp"),pr()),Gb=it(j(Si,X(rt()))),Wb=it(en),Ai=j(en,W("quic"),X(rt())),ao=j(en,W("quic-v1"),X(rt())),cd=Lt(Ai,ao),jb=it(Ai),$b=it(ao),wi=Lt(ue,Si,en,Ai,ao),vu=Lt(j(wi,W("ws"),X(rt()))),Zb=it(vu),Iu=Lt(j(wi,W("wss"),X(rt())),j(wi,W("tls"),X(j(W("sni"),Ve())),W("ws"),X(rt()))),Yb=it(Iu),Bu=j(en,W("webrtc-direct"),X(tn()),X(tn()),X(rt())),Xb=it(Bu),_u=j(ao,W("webtransport"),X(tn()),X(tn()),X(rt())),co=it(_u),no=Lt(vu,Iu,j(Si,X(rt())),j(cd,X(rt())),j(ue,X(rt())),Bu,_u,rt()),Jb=it(no),ud=j(no,W("p2p-circuit"),rt()),Qb=it(ud),fd=Lt(j(no,W("p2p-circuit"),W("webrtc"),X(rt())),j(no,W("webrtc"),X(rt())),j(W("webrtc"),X(rt()))),t1=it(fd),ld=Lt(j(ue,W("tcp"),pr(),W("http"),X(rt())),j(ue,W("http"),X(rt()))),e1=it(ld),hd=Lt(j(ue,W("tcp"),Lt(j(W("443"),W("http")),j(pr(),W("https")),j(pr(),W("tls"),W("http"))),X(rt())),j(ue,W("tls"),W("http"),X(rt())),j(ue,W("https"),X(rt()))),r1=it(hd),dd=Lt(j(W("memory"),Ve(),X(rt()))),n1=it(dd);var qe=class extends Event{type;detail;constructor(t,e){super(t),this.type=t,this.detail=e}};function vi(r){throw new Error("Not implemented")}function Lu(r){if(r!=null){if(typeof r[Symbol.iterator]=="function")return r[Symbol.iterator]();if(typeof r[Symbol.asyncIterator]=="function")return r[Symbol.asyncIterator]();if(typeof r.next=="function")return r}throw new Error("argument is not an iterator or iterable")}function Tu(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function Cu(r,t){let e=Lu(r).return?.();Tu(e)&&e.catch(n=>{t.error("could not cause iterator to return",n)})}var pd=5e3;function Ii(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}var uo=class{id;direction;timeline;protocol;metadata;source;status;readStatus;writeStatus;log;sinkController;sinkEnd;closed;endErr;streamSource;onEnd;onCloseRead;onCloseWrite;onReset;onAbort;sendCloseWriteTimeout;sendingData;constructor(t){this.sinkController=new AbortController,this.sinkEnd=Ut(),this.closed=Ut(),this.log=t.log,this.status="open",this.readStatus="ready",this.writeStatus="ready",this.id=t.id,this.metadata=t.metadata??{},this.direction=t.direction,this.timeline={open:Date.now()},this.sendCloseWriteTimeout=t.sendCloseWriteTimeout??pd,this.onEnd=t.onEnd,this.onCloseRead=t.onCloseRead,this.onCloseWrite=t.onCloseWrite,this.onReset=t.onReset,this.onAbort=t.onAbort,this.source=this.streamSource=zn({onEnd:e=>{e!=null?this.log.trace("source ended with error",e):this.log.trace("source ended"),this.onSourceEnd(e)}}),this.sink=this.sink.bind(this)}async sink(t){if(this.writeStatus!=="ready")throw new on(`writable end state is "${this.writeStatus}" not "ready"`);try{this.writeStatus="writing";let e={signal:this.sinkController.signal};if(this.direction==="outbound"){let o=this.sendNewStream(e);Ii(o)&&await o}let n=()=>{Cu(t,this.log)};try{this.sinkController.signal.addEventListener("abort",n),this.log.trace("sink reading from source");for await(let o of t){o=o instanceof Uint8Array?new $(o):o;let s=this.sendData(o,e);Ii(s)&&(this.sendingData=Ut(),await s,this.sendingData.resolve(),this.sendingData=void 0)}}finally{this.sinkController.signal.removeEventListener("abort",n)}this.log.trace('sink finished reading from source, write status is "%s"',this.writeStatus),this.writeStatus==="writing"&&(this.writeStatus="closing",this.log.trace("send close write to remote"),await this.sendCloseWrite({signal:AbortSignal.timeout(this.sendCloseWriteTimeout)}),this.writeStatus="closed"),this.onSinkEnd()}catch(e){throw this.log.trace("sink ended with error, calling abort with error",e),this.abort(e),e}finally{this.log.trace("resolve sink end"),this.sinkEnd.resolve()}}onSourceEnd(t){this.timeline.closeRead==null&&(this.timeline.closeRead=Date.now(),this.readStatus="closed",t!=null&&this.endErr==null&&(this.endErr=t),this.onCloseRead?.(),this.timeline.closeWrite!=null?(this.log.trace("source and sink ended"),this.timeline.close=Date.now(),this.status!=="aborted"&&this.status!=="reset"&&(this.status="closed"),this.onEnd!=null&&this.onEnd(this.endErr),this.closed.resolve()):this.log.trace("source ended, waiting for sink to end"))}onSinkEnd(t){this.timeline.closeWrite==null&&(this.timeline.closeWrite=Date.now(),this.writeStatus="closed",t!=null&&this.endErr==null&&(this.endErr=t),this.onCloseWrite?.(),this.timeline.closeRead!=null?(this.log.trace("sink and source ended"),this.timeline.close=Date.now(),this.status!=="aborted"&&this.status!=="reset"&&(this.status="closed"),this.onEnd!=null&&this.onEnd(this.endErr),this.closed.resolve()):this.log.trace("sink ended, waiting for source to end"))}async close(t){this.status==="open"&&(this.log.trace("closing gracefully"),this.status="closing",await xt(Promise.all([this.closeWrite(t),this.closeRead(t),this.closed.promise]),t?.signal),this.status="closed",this.log.trace("closed gracefully"))}async closeRead(t={}){if(this.readStatus==="closing"||this.readStatus==="closed")return;this.log.trace('closing readable end of stream with starting read status "%s"',this.readStatus);let e=this.readStatus;this.readStatus="closing",this.status!=="reset"&&this.status!=="aborted"&&this.timeline.closeRead==null&&(this.log.trace("send close read to remote"),await this.sendCloseRead(t)),e==="ready"&&(this.log.trace("ending internal source queue with %d queued bytes",this.streamSource.readableLength),this.streamSource.end()),this.log.trace("closed readable end of stream")}async closeWrite(t={}){this.writeStatus==="closing"||this.writeStatus==="closed"||(this.log.trace('closing writable end of stream with starting write status "%s"',this.writeStatus),this.writeStatus==="ready"&&(this.log.trace("sink was never sunk, sink an empty array"),await xt(this.sink([]),t.signal)),this.writeStatus==="writing"&&(this.sendingData!=null&&await xt(this.sendingData.promise,t.signal),this.log.trace("aborting source passed to .sink"),this.sinkController.abort(),await xt(this.sinkEnd.promise,t.signal)),this.writeStatus="closed",this.log.trace("closed writable end of stream"))}abort(t){if(this.status==="closed"||this.status==="aborted"||this.status==="reset")return;this.log("abort with error",t),this.log("try to send reset to remote");let e=this.sendReset();Ii(e)&&e.catch(n=>{this.log.error("error sending reset message",n)}),this.status="aborted",this.timeline.abort=Date.now(),this._closeSinkAndSource(t),this.onAbort?.(t)}reset(){if(this.status==="closed"||this.status==="aborted"||this.status==="reset")return;let t=new nn("stream reset");this.status="reset",this.timeline.reset=Date.now(),this._closeSinkAndSource(t),this.onReset?.()}_closeSinkAndSource(t){this._closeSink(t),this._closeSource(t)}_closeSink(t){this.writeStatus==="writing"&&(this.log.trace("end sink source"),this.sinkController.abort()),this.onSinkEnd(t)}_closeSource(t){this.readStatus!=="closing"&&this.readStatus!=="closed"&&(this.log.trace("ending source with %d bytes to be read by consumer",this.streamSource.readableLength),this.readStatus="closing",this.streamSource.end(t))}remoteCloseWrite(){if(this.readStatus==="closing"||this.readStatus==="closed"){this.log("received remote close write but local source is already closed");return}this.log.trace("remote close write"),this._closeSource()}remoteCloseRead(){if(this.writeStatus==="closing"||this.writeStatus==="closed"){this.log("received remote close read but local sink is already closed");return}this.log.trace("remote close read"),this._closeSink()}destroy(){if(this.status==="closed"||this.status==="aborted"||this.status==="reset"){this.log("received destroy but we are already closed");return}this.log.trace("stream destroyed"),this._closeSinkAndSource()}sourcePush(t){this.streamSource.push(t)}sourceReadableLength(){return this.streamSource.readableLength}};var Bi=class extends uo{writer;reader;constructor(t){super(t),this.writer=t.bidiStream.writable.getWriter(),this.reader=t.bidiStream.readable.getReader(),Promise.resolve().then(async()=>{for(;;){let e=await this.reader.read();if(e.done){t.log("remote closed write");return}e.value!=null&&this.sourcePush(new $(e.value))}}).catch(e=>{t.log.error("error reading from stream",e),this.abort(e)}).finally(()=>{this.remoteCloseWrite()}),this.writer.closed.then(()=>{t.log("writer closed")}).catch(e=>{t.log("writer close promise rejected",e)}).finally(()=>{this.remoteCloseRead()})}sendNewStream(t){}async sendData(t,e){for(let n of t)this.log("sendData waiting for writer to be ready"),await xt(this.writer.ready,e?.signal),this.writer.write(n).catch(o=>{this.log.error("error sending stream data",o)})}async sendReset(t){this.log("sendReset aborting writer"),await xt(this.writer.abort(),t?.signal),this.log("sendReset aborted writer")}async sendCloseWrite(t){this.log("sendCloseWrite closing writer"),await xt(this.writer.close(),t?.signal),this.log("sendCloseWrite closed writer")}async sendCloseRead(t){this.log("sendCloseRead cancelling reader"),await xt(this.reader.cancel(),t?.signal),this.log("sendCloseRead cancelled reader")}};async function _i(r,t,e,n,o,s){let i=s.forComponent(`libp2p:webtransport:stream:${e}:${t}`),a=new Bi({bidiStream:r,id:t,direction:e,log:i,onEnd:()=>{let c=n.findIndex(f=>f===a);c!==-1&&n.splice(c,1),o?.(a)}});return a}function fo(){return{source:{[Symbol.asyncIterator](){return{async next(){return new Promise(()=>{})}}}},sink:async r=>new Promise(()=>{})}}function Pu(r,t,e,n){let o=0,s=e.forComponent("libp2p:webtransport:muxer");return{protocol:"webtransport",createStreamMuxer:i=>{typeof i=="function"&&(i={onIncomingStream:i});let a=[];Promise.resolve().then(async()=>{for(;;){let{done:f,value:u}=await t.read();if(f)break;if(a.length>=n.maxInboundStreams)s(`too many inbound streams open - ${a.length}/${n.maxInboundStreams}, closing new incoming stream`),u.writable.close().catch(l=>{s.error(`failed to close inbound stream that crossed our maxInboundStream limit: ${l.message}`)}),u.readable.cancel().catch(l=>{s.error(`failed to close inbound stream that crossed our maxInboundStream limit: ${l.message}`)});else{let l=await _i(u,String(o++),"inbound",a,i?.onStreamEnd,e);a.push(l),i?.onIncomingStream?.(l)}}}).catch(f=>{s.error("could not create a new stream",f)});let c={protocol:"webtransport",streams:a,newStream:async f=>{s("new outgoing stream",f);let u=await r.createBidirectionalStream(),l=await _i(u,String(o++),i?.direction??"outbound",a,i?.onStreamEnd,e);return a.push(l),l},close:async()=>{s("closing webtransport muxer gracefully");try{r.close()}catch(f){c.abort(f)}},abort:f=>{s("closing webtransport muxer with err:",f);try{r.close()}catch(u){s.error("webtransport session threw error during close",u)}},...fo()};return c}}}function Uu(r,t){return t.filter(n=>!!r.find(o=>ht(n,o))).length===t.length}var D1=parseInt("0xFFFF",16),K1=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);var Du=to,wd=eo,Li=function(r){let t=0;if(r=r.toString().trim(),Du(r)){let e=new Uint8Array(t+4);return r.split(/\./g).forEach(n=>{e[t++]=parseInt(n,10)&255}),e}if(wd(r)){let e=r.split(":",8),n;for(n=0;n<e.length;n++){let s=Du(e[n]),i;s&&(i=Li(e[n]),e[n]=V(i.slice(0,2),"base16")),i!=null&&++n<8&&e.splice(n,0,V(i.slice(2,4),"base16"))}if(e[0]==="")for(;e.length<8;)e.unshift("0");else if(e[e.length-1]==="")for(;e.length<8;)e.push("0");else if(e.length<8){for(n=0;n<e.length&&e[n]!=="";n++);let s=[n,1];for(n=9-e.length;n>0;n--)s.push("0");e.splice.apply(e,s)}let o=new Uint8Array(t+16);for(n=0;n<e.length;n++){let s=parseInt(e[n],16);o[t++]=s>>8&255,o[t++]=s&255}return o}throw new Error("invalid ip address")},Ku=function(r,t=0,e){t=~~t,e=e??r.length-t;let n=new DataView(r.buffer);if(e===4){let o=[];for(let s=0;s<e;s++)o.push(r[t+s]);return o.join(".")}if(e===16){let o=[];for(let s=0;s<e;s+=2)o.push(n.getUint16(t+s).toString(16));return o.join(":").replace(/(^|:)0(:0)*:0(:|$)/,"$1::$3").replace(/:{3,4}/,"::")}return""};var mr={},Ti={},Ed=[[4,32,"ip4"],[6,16,"tcp"],[33,16,"dccp"],[41,128,"ip6"],[42,-1,"ip6zone"],[43,8,"ipcidr"],[53,-1,"dns",!0],[54,-1,"dns4",!0],[55,-1,"dns6",!0],[56,-1,"dnsaddr",!0],[132,16,"sctp"],[273,16,"udp"],[275,0,"p2p-webrtc-star"],[276,0,"p2p-webrtc-direct"],[277,0,"p2p-stardust"],[280,0,"webrtc-direct"],[281,0,"webrtc"],[290,0,"p2p-circuit"],[301,0,"udt"],[302,0,"utp"],[400,-1,"unix",!1,!0],[421,-1,"ipfs"],[421,-1,"p2p"],[443,0,"https"],[444,96,"onion"],[445,296,"onion3"],[446,-1,"garlic64"],[448,0,"tls"],[449,-1,"sni"],[460,0,"quic"],[461,0,"quic-v1"],[465,0,"webtransport"],[466,-1,"certhash"],[477,0,"ws"],[478,0,"wss"],[479,0,"p2p-websocket-star"],[480,0,"http"],[481,-1,"http-path"],[777,-1,"memory"]];Ed.forEach(r=>{let t=Sd(...r);Ti[t.code]=t,mr[t.name]=t});function Sd(r,t,e,n,o){return{code:r,size:t,name:e,resolvable:!!n,path:!!o}}function et(r){if(typeof r=="number"){if(Ti[r]!=null)return Ti[r];throw new Error(`no protocol with code: ${r}`)}else if(typeof r=="string"){if(mr[r]!=null)return mr[r];throw new Error(`no protocol with name: ${r}`)}throw new Error(`invalid protocol id type: ${typeof r}`)}var g2=et("ip4"),x2=et("ip6"),w2=et("ipcidr");function ki(r,t){switch(et(r).code){case 4:case 41:return vd(t);case 42:return Ui(t);case 43:return V(t,"base10");case 6:case 273:case 33:case 132:return Ou(t).toString();case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Ui(t);case 421:return Ld(t);case 444:return Mu(t);case 445:return Mu(t);case 466:return _d(t);case 481:return globalThis.encodeURIComponent(Ui(t));default:return V(t,"base16")}}function Ri(r,t){switch(et(r).code){case 4:return Nu(t);case 41:return Nu(t);case 42:return Pi(t);case 43:return Q(t,"base10");case 6:case 273:case 33:case 132:return Di(parseInt(t,10));case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Pi(t);case 421:return Id(t);case 444:return Td(t);case 445:return Cd(t);case 466:return Bd(t);case 481:return Pi(globalThis.decodeURIComponent(t));default:return Q(t,"base16")}}var Ci=Object.values(Be).map(r=>r.decoder),Ad=function(){let r=Ci[0].or(Ci[1]);return Ci.slice(2).forEach(t=>r=r.or(t)),r}();function Nu(r){if(!ro(r))throw new Error("invalid ip address");return Li(r)}function vd(r){let t=Ku(r,0,r.length);if(t==null)throw new Error("ipBuff is required");if(!ro(t))throw new Error("invalid ip address");return t}function Di(r){let t=new ArrayBuffer(2);return new DataView(t).setUint16(0,r),new Uint8Array(t)}function Ou(r){return new DataView(r.buffer).getUint16(r.byteOffset)}function Pi(r){let t=Q(r),e=Uint8Array.from(Yt(t.length));return At([e,t],e.length+t.length)}function Ui(r){let t=zt(r);if(r=r.slice(lt(t)),r.length!==t)throw new Error("inconsistent lengths");return V(r)}function Id(r){let t;r[0]==="Q"||r[0]==="1"?t=le(nt.decode(`z${r}`)).bytes:t=ut.parse(r).multihash.bytes;let e=Uint8Array.from(Yt(t.length));return At([e,t],e.length+t.length)}function Bd(r){let t=Ad.decode(r),e=Uint8Array.from(Yt(t.length));return At([e,t],e.length+t.length)}function _d(r){let t=zt(r),e=r.slice(lt(t));if(e.length!==t)throw new Error("inconsistent lengths");return"u"+V(e,"base64url")}function Ld(r){let t=zt(r),e=r.slice(lt(t));if(e.length!==t)throw new Error("inconsistent lengths");return V(e,"base58btc")}function Td(r){let t=r.split(":");if(t.length!==2)throw new Error(`failed to parse onion addr: ["'${t.join('", "')}'"]' does not contain a port number`);if(t[0].length!==16)throw new Error(`failed to parse onion addr: ${t[0]} not a Tor onion address.`);let e=Qt.decode("b"+t[0]),n=parseInt(t[1],10);if(n<1||n>65536)throw new Error("Port number is not in range(1, 65536)");let o=Di(n);return At([e,o],e.length+o.length)}function Cd(r){let t=r.split(":");if(t.length!==2)throw new Error(`failed to parse onion addr: ["'${t.join('", "')}'"]' does not contain a port number`);if(t[0].length!==56)throw new Error(`failed to parse onion addr: ${t[0]} not a Tor onion3 address.`);let e=Qt.decode(`b${t[0]}`),n=parseInt(t[1],10);if(n<1||n>65536)throw new Error("Port number is not in range(1, 65536)");let o=Di(n);return At([e,o],e.length+o.length)}function Mu(r){let t=r.slice(0,r.length-2),e=r.slice(r.length-2),n=V(t,"base32"),o=Ou(e);return`${n}:${o}`}function Hu(r){r=Ki(r);let t=[],e=[],n=null,o=r.split("/").slice(1);if(o.length===1&&o[0]==="")return{bytes:new Uint8Array,string:"/",tuples:[],stringTuples:[],path:null};for(let s=0;s<o.length;s++){let i=o[s],a=et(i);if(a.size===0){t.push([a.code]),e.push([a.code]);continue}if(s++,s>=o.length)throw new lo("invalid address: "+r);if(a.path===!0){n=Ki(o.slice(s).join("/")),t.push([a.code,Ri(a.code,n)]),e.push([a.code,n]);break}let c=Ri(a.code,o[s]);t.push([a.code,c]),e.push([a.code,ki(a.code,c)])}return{string:Vu(e),bytes:ho(t),tuples:t,stringTuples:e,path:n}}function Ni(r){let t=[],e=[],n=null,o=0;for(;o<r.length;){let s=zt(r,o),i=lt(s),a=et(s),c=Pd(a,r.slice(o+i));if(c===0){t.push([s]),e.push([s]),o+=i;continue}let f=r.slice(o+i,o+i+c);if(o+=c+i,o>r.length)throw new lo("Invalid address Uint8Array: "+V(r,"base16"));t.push([s,f]);let u=ki(s,f);if(e.push([s,u]),a.path===!0){n=u;break}}return{bytes:Uint8Array.from(r),string:Vu(e),tuples:t,stringTuples:e,path:n}}function Vu(r){let t=[];return r.map(e=>{let n=et(e[0]);return t.push(n.name),e.length>1&&e[1]!=null&&t.push(e[1]),null}),Ki(t.join("/"))}function ho(r){return At(r.map(t=>{let e=et(t[0]),n=Uint8Array.from(Yt(e.code));return t.length>1&&t[1]!=null&&(n=At([n,t[1]])),n}))}function Pd(r,t){if(r.size>0)return r.size/8;if(r.size===0)return 0;{let e=zt(t instanceof Uint8Array?t:Uint8Array.from(t));return e+lt(e)}}function Ki(r){return"/"+r.trim().split("/").filter(t=>t).join("/")}var lo=class extends Error{static name="ParseError";name="ParseError";constructor(t){super(`Error parsing address: ${t}`)}};var Ud=Symbol.for("nodejs.util.inspect.custom"),Oi=Symbol.for("@multiformats/js-multiaddr/multiaddr"),kd=[et("dns").code,et("dns4").code,et("dns6").code,et("dnsaddr").code],Mi=class extends Error{constructor(t="No available resolver"){super(t),this.name="NoAvailableResolverError"}},po=class r{bytes;#e;#t;#r;#n;[Oi]=!0;constructor(t){t==null&&(t="");let e;if(t instanceof Uint8Array)e=Ni(t);else if(typeof t=="string"){if(t.length>0&&t.charAt(0)!=="/")throw new Error(`multiaddr "${t}" must start with a "/"`);e=Hu(t)}else if(zu(t))e=Ni(t.bytes);else throw new Error("addr must be a string, Buffer, or another Multiaddr");this.bytes=e.bytes,this.#e=e.string,this.#t=e.tuples,this.#r=e.stringTuples,this.#n=e.path}toString(){return this.#e}toJSON(){return this.toString()}toOptions(){let t,e,n,o,s="",i=et("tcp"),a=et("udp"),c=et("ip4"),f=et("ip6"),u=et("dns6"),l=et("ip6zone");for(let[w,y]of this.stringTuples())w===l.code&&(s=`%${y??""}`),kd.includes(w)&&(e=i.name==="tcp"?"tcp":"udp",o=443,n=`${y??""}${s}`,t=w===u.code?6:4),(w===i.code||w===a.code)&&(e=et(w).name==="tcp"?"tcp":"udp",o=parseInt(y??"")),(w===c.code||w===f.code)&&(e=et(w).name==="tcp"?"tcp":"udp",n=`${y??""}${s}`,t=w===f.code?6:4);if(t==null||e==null||n==null||o==null)throw new Error('multiaddr must have a valid format: "/{ip4, ip6, dns4, dns6, dnsaddr}/{address}/{tcp, udp}/{port}".');return{family:t,host:n,transport:e,port:o}}protos(){return this.#t.map(([t])=>Object.assign({},et(t)))}protoCodes(){return this.#t.map(([t])=>t)}protoNames(){return this.#t.map(([t])=>et(t).name)}tuples(){return this.#t.map(([t,e])=>e==null?[t]:[t,e])}stringTuples(){return this.#r.map(([t,e])=>e==null?[t]:[t,e])}encapsulate(t){return t=new r(t),new r(this.toString()+t.toString())}decapsulate(t){let e=t.toString(),n=this.toString(),o=n.lastIndexOf(e);if(o<0)throw new Error(`Address ${this.toString()} does not contain subaddress: ${t.toString()}`);return new r(n.slice(0,o))}decapsulateCode(t){let e=this.tuples();for(let n=e.length-1;n>=0;n--)if(e[n][0]===t)return new r(ho(e.slice(0,n)));return this}getPeerId(){try{let t=[];this.stringTuples().forEach(([n,o])=>{n===mr.p2p.code&&t.push([n,o]),n===mr["p2p-circuit"].code&&(t=[])});let e=t.pop();if(e?.[1]!=null){let n=e[1];return n[0]==="Q"||n[0]==="1"?V(nt.decode(`z${n}`),"base58btc"):V(ut.parse(n).multihash.bytes,"base58btc")}return null}catch{return null}}getPath(){return this.#n}equals(t){return ht(this.bytes,t.bytes)}async resolve(t){let e=this.protos().find(s=>s.resolvable);if(e==null)return[this];let n=qu.get(e.name);if(n==null)throw new Mi(`no available resolver for ${e.name}`);return(await n(this,t)).map(s=>Hi(s))}nodeAddress(){let t=this.toOptions();if(t.transport!=="tcp"&&t.transport!=="udp")throw new Error(`multiaddr must have a valid format - no protocol with name: "${t.transport}". Must have a valid transport protocol: "{tcp, udp}"`);return{family:t.family,address:t.host,port:t.port}}isThinWaistAddress(t){let e=(t??this).protos();return!(e.length!==2||e[0].code!==4&&e[0].code!==41||e[1].code!==6&&e[1].code!==273)}[Ud](){return`Multiaddr(${this.#e})`}};var qu=new Map;function zu(r){return!!r?.[Oi]}function Hi(r){return new po(r)}var Rd=Object.values(Be).map(r=>r.decoder).reduce((r,t)=>r.or(t));function Dd(r){return Gt.decode(Rd.decode(r))}function Vi(r){if(!co.matches(r))throw new sn("Invalid multiaddr, was not a WebTransport address");let t=r.stringTuples(),e=t.filter(([i,a])=>i===et("certhash").code).map(([i,a])=>Dd(a??"")),n=t.filter(([i,a])=>i===et("p2p").code).map(([i,a])=>Kc(a??""))[0],o=r.toOptions(),s=o.host;return o.family===6&&s?.includes(":")&&(s=`[${s}]`),{url:`https://${s}:${o.port}`,certhashes:e,remotePeer:n}}var Fu=globalThis.WebTransport;var qi=class{log;components;config;metrics;constructor(t,e={}){this.log=t.logger.forComponent("libp2p:webtransport"),this.components=t,this.config={...e,maxInboundStreams:e.maxInboundStreams??1e3,certificates:e.certificates??[]},t.metrics!=null&&(this.metrics={dialerEvents:t.metrics.registerCounterGroup("libp2p_webtransport_dialer_events_total",{label:"event",help:"Total count of WebTransport dialer events by type"})})}[Symbol.toStringTag]="@libp2p/webtransport";[Gi]=!0;[un]=["@libp2p/transport"];async dial(t,e){e.signal.throwIfAborted(),this.log("dialing %s",t),e=e??{};let{url:n,certhashes:o,remotePeer:s}=Vi(t),i,a,c=()=>{},f=!1,u=!1,l=!1;try{this.metrics?.dialerEvents.increment({pending:!0});let p=new Fu(`${n}/.well-known/libp2p-webtransport?type=noise`,{serverCertificateHashes:o.map(w=>({algorithm:"sha-256",value:w.digest}))});if(c=w=>{if(!f)try{this.metrics?.dialerEvents.increment({[w]:!0}),p.close()}catch(y){this.log.error("error closing wt session",y)}finally{a!=null&&(a.timeline.close=Date.now()),f=!0}},i=()=>{c(u?"noise_timeout":"ready_timeout")},e.signal.addEventListener("abort",i,{once:!0}),this.log("wait for session to be ready"),e.onProgress?.(new qe("webtransport:wait-for-session")),await Promise.race([p.closed,p.ready]),this.log("session became ready"),u=!0,this.metrics?.dialerEvents.increment({ready:!0}),p.closed.catch(w=>{this.log.error("error on remote wt session close",w)}).finally(()=>{c("remote_close")}),l=await xt(this.authenticateWebTransport({wt:p,remotePeer:s,certhashes:o,...e}),e.signal),!l)throw new ze("Failed to authenticate webtransport");return this.metrics?.dialerEvents.increment({open:!0}),a={close:async()=>{this.log("closing webtransport"),c("close")},abort:w=>{this.log("aborting webtransport due to passed err",w),c("abort")},remoteAddr:t,timeline:{open:Date.now()},log:this.components.logger.forComponent("libp2p:webtransport:maconn"),...fo()},await e.upgrader.upgradeOutbound(a,{...e,skipEncryption:!0,muxerFactory:Pu(p,p.incomingBidirectionalStreams.getReader(),this.components.logger,this.config),skipProtection:!0})}catch(p){throw this.log.error("caught wt session err",p),c(l?"upgrade_error":u?"noise_error":"ready_error"),p}finally{i!=null&&e.signal?.removeEventListener("abort",i)}}async authenticateWebTransport({wt:t,remotePeer:e,certhashes:n,onProgress:o,signal:s}){s?.throwIfAborted(),o?.(new qe("webtransport:open-authentication-stream"));let i=await t.createBidirectionalStream(),a=i.writable.getWriter(),c=i.readable.getReader(),f={source:async function*(){for(;;){let p=await c.read();if(p.value!=null&&(yield p.value),p.done)break}}(),sink:async p=>{for await(let w of p){await xt(a.ready,s);let y=w instanceof Uint8Array?w:w.subarray();a.write(y).catch(m=>{this.log.error("could not write chunk during authentication of WebTransport stream",m)})}}},u=bu()(this.components);o?.(new qe("webtransport:secure-outbound-connection"));let{remoteExtensions:l}=await u.secureOutbound(f,{signal:s,remotePeer:e,skipStreamMuxerNegotiation:!0});if(o?.(new qe("webtransport:close-authentication-stream")),a.close().catch(p=>{this.log.error(`Failed to close authentication stream writer: ${p.message}`)}),c.cancel().catch(p=>{this.log.error(`Failed to close authentication stream reader: ${p.message}`)}),!Uu(l?.webtransportCerthashes??[],n.map(p=>p.bytes)))throw new at("Our certhashes are not a subset of the remote's reported certhashes");return!0}createListener(t){return vi(this.components,{...t,certificates:this.config.certificates,maxInboundStreams:this.config.maxInboundStreams})}listenFilter(){return[]}dialFilter(t){return globalThis.WebTransport==null?[]:t.filter(e=>{if(!co.exactMatch(e))return!1;let{url:n,certhashes:o}=Vi(e);return n!=null&&o.length>0})}};function Kd(r={}){return t=>new qi(t,r)}return Qu(Nd);})();
|
|
3
3
|
//! TODO unclear how to add backpressure here?
|
|
4
4
|
/*! Bundled license information:
|
|
5
5
|
|