@libp2p/webtransport 5.0.40-f1de46607 → 5.0.41

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.min.js CHANGED
@@ -1,5 +1,5 @@
1
1
  (function (root, factory) {(typeof module === 'object' && module.exports) ? module.exports = factory() : root.Libp2PWebtransport = factory()}(typeof self !== 'undefined' ? self : this, function () {
2
- "use strict";var Libp2PWebtransport=(()=>{var lo=Object.defineProperty;var Gu=Object.getOwnPropertyDescriptor;var Wu=Object.getOwnPropertyNames;var ju=Object.prototype.hasOwnProperty;var Tt=(r,t)=>{for(var e in t)lo(r,e,{get:t[e],enumerable:!0})},$u=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of Wu(t))!ju.call(r,o)&&o!==e&&lo(r,o,{get:()=>t[o],enumerable:!(n=Gu(t,o))||n.enumerable});return r};var Zu=r=>$u(lo({},"__esModule",{value:!0}),r);var Ud={};Tt(Ud,{webTransport:()=>Pd});var ho=Symbol.for("@libp2p/peer-id");var Vi=Symbol.for("@libp2p/transport");var qi;(function(r){r[r.FATAL_ALL=0]="FATAL_ALL",r[r.NO_FATAL=1]="NO_FATAL"})(qi||(qi={}));var tn=class extends Error{static name="UnexpectedPeerError";constructor(t="Unexpected Peer"){super(t),this.name="UnexpectedPeerError"}},Fe=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"}},Ge=class extends Error{static name="InvalidPublicKeyError";constructor(t="Invalid public key"){super(t),this.name="InvalidPublicKeyError"}};var en=class extends Error{static name="StreamResetError";constructor(t="The stream has been reset"){super(t),this.name="StreamResetError"}},rn=class extends Error{static name="StreamStateError";constructor(t="The stream is in an invalid state"){super(t),this.name="StreamStateError"}};var nn=class extends Error{static name="InvalidMultiaddrError";constructor(t="Invalid multiaddr"){super(t),this.name="InvalidMultiaddrError"}},on=class extends Error{static name="InvalidCIDError";constructor(t="Invalid CID"){super(t),this.name="InvalidCIDError"}},sn=class extends Error{static name="InvalidMultihashError";constructor(t="Invalid Multihash"){super(t),this.name="InvalidMultihashError"}};var Ae=class extends Error{static name="UnsupportedKeyTypeError";constructor(t="Unsupported key type"){super(t),this.name="UnsupportedKeyTypeError"}};var an=Symbol.for("@libp2p/service-capabilities"),Nd=Symbol.for("@libp2p/service-dependencies");var xo={};Tt(xo,{base58btc:()=>et,base58flickr:()=>ef});var ip=new Uint8Array(0);function zi(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 Fi(r){return new TextEncoder().encode(r)}function Gi(r){return new TextDecoder().decode(r)}function Yu(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(b){if(b instanceof Uint8Array||(ArrayBuffer.isView(b)?b=new Uint8Array(b.buffer,b.byteOffset,b.byteLength):Array.isArray(b)&&(b=Uint8Array.from(b))),!(b instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(b.length===0)return"";for(var m=0,h=0,w=0,S=b.length;w!==S&&b[w]===0;)w++,m++;for(var p=(S-w)*u+1>>>0,A=new Uint8Array(p);w!==S;){for(var U=b[w],P=0,B=p-1;(U!==0||P<h)&&B!==-1;B--,P++)U+=256*A[B]>>>0,A[B]=U%a>>>0,U=U/a>>>0;if(U!==0)throw new Error("Non-zero carry");h=P,w++}for(var C=p-h;C!==p&&A[C]===0;)C++;for(var I=c.repeat(m);C<p;++C)I+=r.charAt(A[C]);return I}function d(b){if(typeof b!="string")throw new TypeError("Expected String");if(b.length===0)return new Uint8Array;var m=0;if(b[m]!==" "){for(var h=0,w=0;b[m]===c;)h++,m++;for(var S=(b.length-m)*f+1>>>0,p=new Uint8Array(S);b[m];){var A=e[b.charCodeAt(m)];if(A===255)return;for(var U=0,P=S-1;(A!==0||U<w)&&P!==-1;P--,U++)A+=a*p[P]>>>0,p[P]=A%256>>>0,A=A/256>>>0;if(A!==0)throw new Error("Non-zero carry");w=U,m++}if(b[m]!==" "){for(var B=S-w;B!==S&&p[B]===0;)B++;for(var C=new Uint8Array(h+(S-B)),I=h;B!==S;)C[I++]=p[B++];return C}}}function x(b){var m=d(b);if(m)return m;throw new Error(`Non-${t} character`)}return{encode:l,decodeUnsafe:d,decode:x}}var Xu=Yu,Ju=Xu,ji=Ju;var po=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")}},mo=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 $i(this,t)}},yo=class{decoders;constructor(t){this.decoders=t}or(t){return $i(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 $i(r,t){return new yo({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var go=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 po(t,e,n),this.decoder=new mo(t,e,o)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function We({name:r,prefix:t,encode:e,decode:n}){return new go(r,t,e,n)}function ue({name:r,prefix:t,alphabet:e}){let{encode:n,decode:o}=ji(e,r);return We({prefix:t,name:r,encode:n,decode:s=>Jt(o(s))})}function Qu(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 tf(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 We({prefix:t,name:r,encode(o){return tf(o,n,e)},decode(o){return Qu(o,n,e,r)}})}var et=ue({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),ef=ue({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var wo={};Tt(wo,{base32:()=>Qt,base32hex:()=>sf,base32hexpad:()=>cf,base32hexpadupper:()=>uf,base32hexupper:()=>af,base32pad:()=>nf,base32padupper:()=>of,base32upper:()=>rf,base32z:()=>ff});var Qt=ct({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),rf=ct({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),nf=ct({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),of=ct({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),sf=ct({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),af=ct({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),cf=ct({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),uf=ct({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),ff=ct({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var bo={};Tt(bo,{base36:()=>mr,base36upper:()=>lf});var mr=ue({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),lf=ue({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Gt={};Tt(Gt,{Digest:()=>ve,create:()=>Kt,decode:()=>fe,equals:()=>So,hasCode:()=>Cf});var hf=Xi,Zi=128,df=127,pf=~df,mf=Math.pow(2,31);function Xi(r,t,e){t=t||[],e=e||0;for(var n=e;r>=mf;)t[e++]=r&255|Zi,r/=128;for(;r&pf;)t[e++]=r&255|Zi,r>>>=7;return t[e]=r|0,Xi.bytes=e-n+1,t}var yf=Eo,gf=128,Yi=127;function Eo(r,n){var e=0,n=n||0,o=0,s=n,i,a=r.length;do{if(s>=a)throw Eo.bytes=0,new RangeError("Could not decode varint");i=r[s++],e+=o<28?(i&Yi)<<o:(i&Yi)*Math.pow(2,o),o+=7}while(i>=gf);return Eo.bytes=s-n,e}var xf=Math.pow(2,7),wf=Math.pow(2,14),bf=Math.pow(2,21),Ef=Math.pow(2,28),Sf=Math.pow(2,35),Af=Math.pow(2,42),vf=Math.pow(2,49),If=Math.pow(2,56),Bf=Math.pow(2,63),_f=function(r){return r<xf?1:r<wf?2:r<bf?3:r<Ef?4:r<Sf?5:r<Af?6:r<vf?7:r<If?8:r<Bf?9:10},Lf={encode:hf,decode:yf,encodingLength:_f},Tf=Lf,yr=Tf;function gr(r,t=0){return[yr.decode(r,t),yr.decode.bytes]}function je(r,t,e=0){return yr.encode(r,t,e),t}function $e(r){return yr.encodingLength(r)}function Kt(r,t){let e=t.byteLength,n=$e(r),o=n+$e(e),s=new Uint8Array(o+e);return je(r,s,0),je(e,s,n),s.set(t,o),new ve(r,e,t,s)}function fe(r){let t=Jt(r),[e,n]=gr(t),[o,s]=gr(t.subarray(n)),i=t.subarray(n+s);if(i.byteLength!==o)throw new Error("Incorrect length");return new ve(e,o,i,t)}function So(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&zi(r.bytes,e.bytes)}}var ve=class{code;size;digest;bytes;constructor(t,e,n,o){this.code=t,this.size=e,this.digest=n,this.bytes=o}};function Cf(r,t){return r.code===t}function Ji(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return Uf(e,Ao(r),t??et.encoder);default:return kf(e,Ao(r),t??Qt.encoder)}}var Qi=new WeakMap;function Ao(r){let t=Qi.get(r);if(t==null){let e=new Map;return Qi.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!==xr)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==Rf)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=Kt(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&&So(t.multihash,n.multihash)}toString(t){return Ji(this,t)}toJSON(){return{"/":Ji(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??ta(n,o,s.bytes))}else if(e[Df]===!0){let{version:n,multihash:o,code:s}=e,i=fe(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!==xr)throw new Error(`Version 0 CID must use dag-pb (code: ${xr}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let o=ta(t,e,n.bytes);return new r(t,e,n,o)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,xr,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 ve(e.multihashCode,e.digestSize,s,o);return[e.version===0?r.createV0(i):r.createV1(e.codec,i),t.subarray(e.size)]}static inspectBytes(t){let e=0,n=()=>{let[l,d]=gr(t.subarray(e));return e+=d,l},o=n(),s=xr;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]=Pf(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 Ao(s).set(n,t),s}};function Pf(r,t){switch(r[0]){case"Q":{let e=t??et;return[et.prefix,e.decode(`${et.prefix}${r}`)]}case et.prefix:{let e=t??et;return[et.prefix,e.decode(r)]}case Qt.prefix:{let e=t??Qt;return[Qt.prefix,e.decode(r)]}case mr.prefix:{let e=t??mr;return[mr.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 Uf(r,t,e){let{prefix:n}=e;if(n!==et.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 kf(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 xr=112,Rf=18;function ta(r,t,e){let n=$e(r),o=n+$e(t),s=new Uint8Array(o+e.byteLength);return je(r,s,0),je(t,s,n),s.set(e,o),s}var Df=Symbol.for("@ipld/js-cid/CID");var vo={};Tt(vo,{identity:()=>Mt});var ea=0,Kf="identity",ra=Jt;function Nf(r){return Kt(ea,ra(r))}var Mt={code:ea,name:Kf,encode:ra,digest:Nf};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 St(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 oa=Symbol.for("@achingbrain/uint8arraylist");function na(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 un(r){return!!r?.[oa]}var G=class r{bufs;length;[oa]=!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(un(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(un(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=na(this.bufs,t);return e.buf[e.index]}set(t,e){let n=na(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(un(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 St(n,o)}subarray(t,e){let{bufs:n,length:o}=this._subList(t,e);return n.length===1?n[0]:St(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(!un(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 d=f;d>=0;d--){let x=this.get(l+d);if(n[d]!==x){u=Math.max(1,d-a[x]);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 Io={};Tt(Io,{base10:()=>Of});var Of=ue({prefix:"9",name:"base10",alphabet:"0123456789"});var Bo={};Tt(Bo,{base16:()=>Hf,base16upper:()=>qf});var Hf=ct({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),qf=ct({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var _o={};Tt(_o,{base2:()=>Vf});var Vf=ct({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Lo={};Tt(Lo,{base256emoji:()=>jf});var sa=Array.from("\u{1F680}\u{1FA90}\u2604\u{1F6F0}\u{1F30C}\u{1F311}\u{1F312}\u{1F313}\u{1F314}\u{1F315}\u{1F316}\u{1F317}\u{1F318}\u{1F30D}\u{1F30F}\u{1F30E}\u{1F409}\u2600\u{1F4BB}\u{1F5A5}\u{1F4BE}\u{1F4BF}\u{1F602}\u2764\u{1F60D}\u{1F923}\u{1F60A}\u{1F64F}\u{1F495}\u{1F62D}\u{1F618}\u{1F44D}\u{1F605}\u{1F44F}\u{1F601}\u{1F525}\u{1F970}\u{1F494}\u{1F496}\u{1F499}\u{1F622}\u{1F914}\u{1F606}\u{1F644}\u{1F4AA}\u{1F609}\u263A\u{1F44C}\u{1F917}\u{1F49C}\u{1F614}\u{1F60E}\u{1F607}\u{1F339}\u{1F926}\u{1F389}\u{1F49E}\u270C\u2728\u{1F937}\u{1F631}\u{1F60C}\u{1F338}\u{1F64C}\u{1F60B}\u{1F497}\u{1F49A}\u{1F60F}\u{1F49B}\u{1F642}\u{1F493}\u{1F929}\u{1F604}\u{1F600}\u{1F5A4}\u{1F603}\u{1F4AF}\u{1F648}\u{1F447}\u{1F3B6}\u{1F612}\u{1F92D}\u2763\u{1F61C}\u{1F48B}\u{1F440}\u{1F62A}\u{1F611}\u{1F4A5}\u{1F64B}\u{1F61E}\u{1F629}\u{1F621}\u{1F92A}\u{1F44A}\u{1F973}\u{1F625}\u{1F924}\u{1F449}\u{1F483}\u{1F633}\u270B\u{1F61A}\u{1F61D}\u{1F634}\u{1F31F}\u{1F62C}\u{1F643}\u{1F340}\u{1F337}\u{1F63B}\u{1F613}\u2B50\u2705\u{1F97A}\u{1F308}\u{1F608}\u{1F918}\u{1F4A6}\u2714\u{1F623}\u{1F3C3}\u{1F490}\u2639\u{1F38A}\u{1F498}\u{1F620}\u261D\u{1F615}\u{1F33A}\u{1F382}\u{1F33B}\u{1F610}\u{1F595}\u{1F49D}\u{1F64A}\u{1F639}\u{1F5E3}\u{1F4AB}\u{1F480}\u{1F451}\u{1F3B5}\u{1F91E}\u{1F61B}\u{1F534}\u{1F624}\u{1F33C}\u{1F62B}\u26BD\u{1F919}\u2615\u{1F3C6}\u{1F92B}\u{1F448}\u{1F62E}\u{1F646}\u{1F37B}\u{1F343}\u{1F436}\u{1F481}\u{1F632}\u{1F33F}\u{1F9E1}\u{1F381}\u26A1\u{1F31E}\u{1F388}\u274C\u270A\u{1F44B}\u{1F630}\u{1F928}\u{1F636}\u{1F91D}\u{1F6B6}\u{1F4B0}\u{1F353}\u{1F4A2}\u{1F91F}\u{1F641}\u{1F6A8}\u{1F4A8}\u{1F92C}\u2708\u{1F380}\u{1F37A}\u{1F913}\u{1F619}\u{1F49F}\u{1F331}\u{1F616}\u{1F476}\u{1F974}\u25B6\u27A1\u2753\u{1F48E}\u{1F4B8}\u2B07\u{1F628}\u{1F31A}\u{1F98B}\u{1F637}\u{1F57A}\u26A0\u{1F645}\u{1F61F}\u{1F635}\u{1F44E}\u{1F932}\u{1F920}\u{1F927}\u{1F4CC}\u{1F535}\u{1F485}\u{1F9D0}\u{1F43E}\u{1F352}\u{1F617}\u{1F911}\u{1F30A}\u{1F92F}\u{1F437}\u260E\u{1F4A7}\u{1F62F}\u{1F486}\u{1F446}\u{1F3A4}\u{1F647}\u{1F351}\u2744\u{1F334}\u{1F4A3}\u{1F438}\u{1F48C}\u{1F4CD}\u{1F940}\u{1F922}\u{1F445}\u{1F4A1}\u{1F4A9}\u{1F450}\u{1F4F8}\u{1F47B}\u{1F910}\u{1F92E}\u{1F3BC}\u{1F975}\u{1F6A9}\u{1F34E}\u{1F34A}\u{1F47C}\u{1F48D}\u{1F4E3}\u{1F942}"),zf=sa.reduce((r,t,e)=>(r[e]=t,r),[]),Ff=sa.reduce((r,t,e)=>{let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);return r[n]=e,r},[]);function Gf(r){return r.reduce((t,e)=>(t+=zf[e],t),"")}function Wf(r){let t=[];for(let e of r){let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);let o=Ff[n];if(o==null)throw new Error(`Non-base256emoji character: ${e}`);t.push(o)}return new Uint8Array(t)}var jf=We({prefix:"\u{1F680}",name:"base256emoji",encode:Gf,decode:Wf});var Co={};Tt(Co,{base64:()=>$f,base64pad:()=>Zf,base64url:()=>To,base64urlpad:()=>Yf});var $f=ct({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),Zf=ct({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),To=ct({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Yf=ct({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Po={};Tt(Po,{base8:()=>Xf});var Xf=ct({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Uo={};Tt(Uo,{identity:()=>Jf});var Jf=We({prefix:"\0",name:"identity",encode:r=>Gi(r),decode:r=>Fi(r)});var Vp=new TextEncoder,zp=new TextDecoder;var Do={};Tt(Do,{sha256:()=>wr,sha512:()=>el});function Ro({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?Kt(this.code,e):e.then(n=>Kt(this.code,n))}else throw Error("Unknown type, must be binary type")}};function aa(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var wr=Ro({name:"sha2-256",code:18,encode:aa("SHA-256")}),el=Ro({name:"sha2-512",code:19,encode:aa("SHA-512")});var Ie={...Uo,..._o,...Po,...Io,...Bo,...wo,...bo,...xo,...Co,...Lo},e0={...Do,...vo};function ua(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var ca=ua("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),Ko=ua("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}),rl={utf8:ca,"utf-8":ca,hex:Ie.base16,latin1:Ko,ascii:Ko,binary:Ko,...Ie},fn=rl;function Y(r,t="utf8"){let e=fn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function H(r,t="utf8"){let e=fn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}var nl=parseInt("11111",2),No=parseInt("10000000",2),ol=parseInt("01111111",2),fa={0:br,1:br,2:sl,3:cl,4:ul,5:al,6:il,16:br,22:br,48:br};function te(r,t={offset:0}){let e=r[t.offset]&nl;if(t.offset++,fa[e]!=null)return fa[e](r,t);throw new Error("No decoder for tag "+e)}function Er(r,t){let e=0;if((r[t.offset]&No)===No){let n=r[t.offset]&ol,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 br(r,t){Er(r,t);let e=[];for(;!(t.offset>=r.byteLength);){let n=te(r,t);if(n===null)break;e.push(n)}return e}function sl(r,t){let e=Er(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 il(r,t){let e=Er(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 al(r,t){return t.offset++,null}function cl(r,t){let e=Er(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 ul(r,t){let e=Er(r,t),n=r.subarray(t.offset,t.offset+e);return t.offset+=e,n}function fl(r){let t=r.toString(16);t.length%2===1&&(t="0"+t);let e=new G;for(let n=0;n<t.length;n+=2)e.append(Uint8Array.from([parseInt(`${t[n]}${t[n+1]}`,16)]));return e}function Mo(r){if(r.byteLength<128)return Uint8Array.from([r.byteLength]);let t=fl(r.byteLength);return new G(Uint8Array.from([t.byteLength|No]),t)}function kt(r){let t=new G,e=128;return(r.subarray()[0]&e)===e&&t.append(Uint8Array.from([0])),t.append(r),new G(Uint8Array.from([2]),Mo(t),t)}function ln(r){let t=Uint8Array.from([0]),e=new G(t,r);return new G(Uint8Array.from([3]),Mo(e),e)}function le(r,t=48){let e=new G;for(let n of r)e.append(n);return new G(Uint8Array.from([t]),Mo(e),e)}async function la(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 ll=Uint8Array.from([6,8,42,134,72,206,61,3,1,7]),hl=Uint8Array.from([6,5,43,129,4,0,34]),dl=Uint8Array.from([6,5,43,129,4,0,35]),pl={ext:!0,kty:"EC",crv:"P-256"},ml={ext:!0,kty:"EC",crv:"P-384"},yl={ext:!0,kty:"EC",crv:"P-521"},Oo=32,Ho=48,qo=66;function Vo(r){let t=te(r);return ha(t)}function ha(r){let t=r[1][1][0],e=1,n,o;if(t.byteLength===Oo*2+1)return n=H(t.subarray(e,e+Oo),"base64url"),o=H(t.subarray(e+Oo),"base64url"),new Ze({...pl,key_ops:["verify"],x:n,y:o});if(t.byteLength===Ho*2+1)return n=H(t.subarray(e,e+Ho),"base64url"),o=H(t.subarray(e+Ho),"base64url"),new Ze({...ml,key_ops:["verify"],x:n,y:o});if(t.byteLength===qo*2+1)return n=H(t.subarray(e,e+qo),"base64url"),o=H(t.subarray(e+qo),"base64url"),new Ze({...yl,key_ops:["verify"],x:n,y:o});throw new at(`coordinates were wrong length, got ${t.byteLength}, expected 65, 97 or 133`)}function da(r){return le([kt(Uint8Array.from([1])),le([gl(r.crv)],160),le([ln(new G(Uint8Array.from([4]),Y(r.x??"","base64url"),Y(r.y??"","base64url")))],161)]).subarray()}function gl(r){if(r==="P-256")return ll;if(r==="P-384")return hl;if(r==="P-521")return dl;throw new at(`Invalid curve ${r}`)}var Ze=class{type="ECDSA";jwk;_raw;constructor(t){this.jwk=t}get raw(){return this._raw==null&&(this._raw=da(this.jwk)),this._raw}toMultihash(){return Mt.digest(he(this))}toCID(){return ut.createV1(114,this.toMultihash())}toString(){return et.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 la(this.jwk,e,t)}};var Be=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;function xl(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function Ye(r){if(!Number.isSafeInteger(r)||r<0)throw new Error("positive integer expected, got "+r)}function _e(r,...t){if(!xl(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 Sr(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.createHasher");Ye(r.outputLen),Ye(r.blockLen)}function Je(r,t=!0){if(r.destroyed)throw new Error("Hash instance has been destroyed");if(t&&r.finished)throw new Error("Hash#digest() has already been called")}function pa(r,t){_e(r);let e=t.outputLen;if(r.length<e)throw new Error("digestInto() expects output buffer of length at least "+e)}function Ot(...r){for(let t=0;t<r.length;t++)r[t].fill(0)}function hn(r){return new DataView(r.buffer,r.byteOffset,r.byteLength)}function Ht(r,t){return r<<32-t|r>>>t}function ma(r){if(typeof r!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(r))}function de(r){return typeof r=="string"&&(r=ma(r)),_e(r),r}function zo(...r){let t=0;for(let n=0;n<r.length;n++){let o=r[n];_e(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 Xe=class{};function Fo(r){let t=n=>r().update(de(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function Ar(r=32){if(Be&&typeof Be.getRandomValues=="function")return Be.getRandomValues(new Uint8Array(r));if(Be&&typeof Be.randomBytes=="function")return Uint8Array.from(Be.randomBytes(r));throw new Error("crypto.getRandomValues must be defined")}function wl(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 ya(r,t,e){return r&t^~r&e}function ga(r,t,e){return r&t^r&e^t&e}var vr=class extends Xe{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=hn(this.buffer)}update(t){Je(this),t=de(t),_e(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=hn(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){Je(this),pa(t,this),this.finished=!0;let{buffer:e,view:n,blockLen:o,isLE:s}=this,{pos:i}=this;e[i++]=128,Ot(this.buffer.subarray(i)),this.padOffset>o-i&&(this.process(n,0),i=0);for(let l=i;l<o;l++)e[l]=0;wl(n,o-8,BigInt(this.length*8),s),this.process(n,0);let a=hn(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 wt=Uint32Array.from([1779033703,4089235720,3144134277,2227873595,1013904242,4271175723,2773480762,1595750129,1359893119,2917565137,2600822924,725511199,528734635,4215389547,1541459225,327033209]);var dn=BigInt(4294967295),xa=BigInt(32);function bl(r,t=!1){return t?{h:Number(r&dn),l:Number(r>>xa&dn)}:{h:Number(r>>xa&dn)|0,l:Number(r&dn)|0}}function wa(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}=bl(r[s],t);[n[s],o[s]]=[i,a]}return[n,o]}var Go=(r,t,e)=>r>>>e,Wo=(r,t,e)=>r<<32-e|t>>>e,Le=(r,t,e)=>r>>>e|t<<32-e,Te=(r,t,e)=>r<<32-e|t>>>e,Ir=(r,t,e)=>r<<64-e|t>>>e-32,Br=(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 ba=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),Ea=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,Sa=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),Aa=(r,t,e,n,o)=>t+e+n+o+(r/2**32|0)|0,va=(r,t,e,n,o)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(o>>>0),Ia=(r,t,e,n,o,s)=>t+e+n+o+s+(r/2**32|0)|0;var Sl=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]),pe=new Uint32Array(64),pn=class extends vr{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)pe[l]=t.getUint32(e,!1);for(let l=16;l<64;l++){let d=pe[l-15],x=pe[l-2],b=Ht(d,7)^Ht(d,18)^d>>>3,m=Ht(x,17)^Ht(x,19)^x>>>10;pe[l]=m+pe[l-7]+b+pe[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 d=Ht(a,6)^Ht(a,11)^Ht(a,25),x=u+d+ya(a,c,f)+Sl[l]+pe[l]|0,m=(Ht(n,2)^Ht(n,13)^Ht(n,22))+ga(n,o,s)|0;u=f,f=c,c=a,a=i+x|0,i=s,s=o,o=n,n=x+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(){Ot(pe)}destroy(){this.set(0,0,0,0,0,0,0,0),Ot(this.buffer)}};var Ba=wa(["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))),Al=Ba[0],vl=Ba[1],me=new Uint32Array(80),ye=new Uint32Array(80),jo=class extends vr{constructor(t=64){super(128,t,16,!1),this.Ah=wt[0]|0,this.Al=wt[1]|0,this.Bh=wt[2]|0,this.Bl=wt[3]|0,this.Ch=wt[4]|0,this.Cl=wt[5]|0,this.Dh=wt[6]|0,this.Dl=wt[7]|0,this.Eh=wt[8]|0,this.El=wt[9]|0,this.Fh=wt[10]|0,this.Fl=wt[11]|0,this.Gh=wt[12]|0,this.Gl=wt[13]|0,this.Hh=wt[14]|0,this.Hl=wt[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:d,Gh:x,Gl:b,Hh:m,Hl:h}=this;return[t,e,n,o,s,i,a,c,f,u,l,d,x,b,m,h]}set(t,e,n,o,s,i,a,c,f,u,l,d,x,b,m,h){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=d|0,this.Gh=x|0,this.Gl=b|0,this.Hh=m|0,this.Hl=h|0}process(t,e){for(let p=0;p<16;p++,e+=4)me[p]=t.getUint32(e),ye[p]=t.getUint32(e+=4);for(let p=16;p<80;p++){let A=me[p-15]|0,U=ye[p-15]|0,P=Le(A,U,1)^Le(A,U,8)^Go(A,U,7),B=Te(A,U,1)^Te(A,U,8)^Wo(A,U,7),C=me[p-2]|0,I=ye[p-2]|0,M=Le(C,I,19)^Ir(C,I,61)^Go(C,I,6),N=Te(C,I,19)^Br(C,I,61)^Wo(C,I,6),k=Sa(B,N,ye[p-7],ye[p-16]),q=Aa(k,P,M,me[p-7],me[p-16]);me[p]=q|0,ye[p]=k|0}let{Ah:n,Al:o,Bh:s,Bl:i,Ch:a,Cl:c,Dh:f,Dl:u,Eh:l,El:d,Fh:x,Fl:b,Gh:m,Gl:h,Hh:w,Hl:S}=this;for(let p=0;p<80;p++){let A=Le(l,d,14)^Le(l,d,18)^Ir(l,d,41),U=Te(l,d,14)^Te(l,d,18)^Br(l,d,41),P=l&x^~l&m,B=d&b^~d&h,C=va(S,U,B,vl[p],ye[p]),I=Ia(C,w,A,P,Al[p],me[p]),M=C|0,N=Le(n,o,28)^Ir(n,o,34)^Ir(n,o,39),k=Te(n,o,28)^Br(n,o,34)^Br(n,o,39),q=n&s^n&a^s&a,v=o&i^o&c^i&c;w=m|0,S=h|0,m=x|0,h=b|0,x=l|0,b=d|0,{h:l,l:d}=Wt(f|0,u|0,I|0,M|0),f=a|0,u=c|0,a=s|0,c=i|0,s=n|0,i=o|0;let _=ba(M,k,v);n=Ea(_,I,N,q),o=_|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:d}=Wt(this.Eh|0,this.El|0,l|0,d|0),{h:x,l:b}=Wt(this.Fh|0,this.Fl|0,x|0,b|0),{h:m,l:h}=Wt(this.Gh|0,this.Gl|0,m|0,h|0),{h:w,l:S}=Wt(this.Hh|0,this.Hl|0,w|0,S|0),this.set(n,o,s,i,a,c,f,u,l,d,x,b,m,h,w,S)}roundClean(){Ot(me,ye)}destroy(){Ot(this.buffer),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}};var mn=Fo(()=>new pn);var _a=Fo(()=>new jo);var Xo=BigInt(0),Yo=BigInt(1);function Ce(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function Jo(r){if(!Ce(r))throw new Error("Uint8Array expected")}function jt(r,t){if(typeof t!="boolean")throw new Error(r+" boolean expected, got "+t)}function _r(r){let t=r.toString(16);return t.length&1?"0"+t:t}function Ca(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return r===""?Xo:BigInt("0x"+r)}var Pa=typeof Uint8Array.from([]).toHex=="function"&&typeof Uint8Array.fromHex=="function",Il=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function ge(r){if(Jo(r),Pa)return r.toHex();let t="";for(let e=0;e<r.length;e++)t+=Il[r[e]];return t}var re={_0:48,_9:57,A:65,F:70,a:97,f:102};function La(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 Lr(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);if(Pa)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=La(r.charCodeAt(s)),a=La(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 Ca(ge(r))}function $t(r){return Jo(r),Ca(ge(Uint8Array.from(r).reverse()))}function Pe(r,t){return Lr(r.toString(16).padStart(t*2,"0"))}function xe(r,t){return Pe(r,t).reverse()}function nt(r,t,e){let n;if(typeof t=="string")try{n=Lr(t)}catch(s){throw new Error(r+" must be hex string or Uint8Array, cause: "+s)}else if(Ce(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 we(...r){let t=0;for(let n=0;n<r.length;n++){let o=r[n];Jo(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 $o=r=>typeof r=="bigint"&&Xo<=r;function yn(r,t,e){return $o(r)&&$o(t)&&$o(e)&&t<=r&&r<e}function At(r,t,e,n){if(!yn(t,e,n))throw new Error("expected valid "+r+": "+e+" <= n < "+n+", got "+t)}function Ua(r){let t;for(t=0;r>Xo;r>>=Yo,t+=1);return t}var Ue=r=>(Yo<<BigInt(r))-Yo,Zo=r=>new Uint8Array(r),Ta=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=Zo(r),o=Zo(r),s=0,i=()=>{n.fill(1),o.fill(0),s=0},a=(...l)=>e(o,n,...l),c=(l=Zo(0))=>{o=a(Ta([0]),l),n=a(),l.length!==0&&(o=a(Ta([1]),l),n=a())},f=()=>{if(s++>=1e3)throw new Error("drbg: tried 1000 values");let l=0,d=[];for(;l<t;){n=a();let x=n.slice();d.push(x),l+=n.length}return we(...d)};return(l,d)=>{i(),c(l);let x;for(;!(x=d(f()));)c();return i(),x}}var Bl={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"||Ce(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=Bl[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),mt=BigInt(1),ke=BigInt(2),_l=BigInt(3),Qo=BigInt(4),Ra=BigInt(5),Da=BigInt(8),Ll=BigInt(9),Tl=BigInt(16);function $(r,t){let e=r%t;return e>=Ct?e:t+e}function ot(r,t,e){let n=r;for(;t-- >Ct;)n*=n,n%=e;return n}function gn(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=$(r,t),n=t,o=Ct,s=mt,i=mt,a=Ct;for(;e!==Ct;){let f=n/e,u=n%e,l=o-i*f,d=s-a*f;n=e,e=u,o=i,s=a,i=l,a=d}if(n!==mt)throw new Error("invert: does not exist");return $(o,t)}function Cl(r){let t=r-mt,e=0;for(;t%ke===Ct;)t/=ke,e++;let n=ke,o=Vt(r);for(;n<r&&Ka(o,n);)if(n++>1e3)throw new Error("Cannot find square root: probably non-prime P");if(e===1){let i=(r+mt)/Qo;return function(c,f){let u=c.pow(f,i);if(!c.eql(c.sqr(u),f))throw new Error("Cannot find square root");return u}}let s=(t+mt)/ke;return function(a,c){if(!Ka(a,c))throw new Error("Cannot find square root");let f=e,u=a.pow(a.mul(a.ONE,n),t),l=a.pow(c,s),d=a.pow(c,t);for(;!a.eql(d,a.ONE);){if(a.eql(d,a.ZERO))return a.ZERO;let x=1;for(let m=a.sqr(d);x<f&&!a.eql(m,a.ONE);x++)m=a.sqr(m);let b=a.pow(u,mt<<BigInt(f-x-1));u=a.sqr(b),l=a.mul(l,b),d=a.mul(d,u),f=x}return l}}function Pl(r){return r%Qo===_l?function(e,n){let o=(r+mt)/Qo,s=e.pow(n,o);if(!e.eql(e.sqr(s),n))throw new Error("Cannot find square root");return s}:r%Da===Ra?function(e,n){let o=e.mul(n,ke),s=(r-Ra)/Da,i=e.pow(o,s),a=e.mul(n,i),c=e.mul(e.mul(a,ke),i),f=e.mul(a,e.sub(c,e.ONE));if(!e.eql(e.sqr(f),n))throw new Error("Cannot find square root");return f}:(r%Tl,Cl(r))}var Na=(r,t)=>($(r,t)&mt)===mt,Ul=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function ts(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=Ul.reduce((n,o)=>(n[o]="function",n),t);return qt(r,e)}function kl(r,t,e){if(e<Ct)throw new Error("invalid exponent, negatives unsupported");if(e===Ct)return r.ONE;if(e===mt)return t;let n=r.ONE,o=t;for(;e>Ct;)e&mt&&(n=r.mul(n,o)),o=r.sqr(o),e>>=mt;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 Rl(r,t){let e=(r.ORDER-mt)/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("Cannot find square root: probably non-prime P");return o?1:s?0:-1}function Ka(r,t){let e=Rl(r,t);return e===0||e===1}function es(r,t){t!==void 0&&Ye(t);let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function Vt(r,t,e=!1,n={}){if(r<=Ct)throw new Error("invalid field: expected ORDER > 0, got "+r);let{nBitLength:o,nByteLength:s}=es(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:mt,create:c=>$(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&mt)===mt,neg:c=>$(-c,r),eql:(c,f)=>c===f,sqr:c=>$(c*c,r),add:(c,f)=>$(c+f,r),sub:(c,f)=>$(c-f,r),mul:(c,f)=>$(c*f,r),pow:(c,f)=>kl(a,c,f),div:(c,f)=>$(c*gn(f,r),r),sqrN:c=>c*c,addN:(c,f)=>c+f,subN:(c,f)=>c-f,mulN:(c,f)=>c*f,inv:c=>gn(c,r),sqrt:n.sqrt||(c=>(i||(i=Pl(r)),i(a,c))),toBytes:c=>e?xe(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 Ma(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 rs(r){let t=Ma(r);return t+Math.ceil(t/2)}function Oa(r,t,e=!1){let n=r.length,o=Ma(t),s=rs(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=$(i,t-mt)+mt;return e?xe(a,o):Pe(a,o)}var Ha=BigInt(0),as=BigInt(1);function ns(r,t){let e=t.negate();return r?e:t}function Va(r,t){if(!Number.isSafeInteger(r)||r<=0||r>t)throw new Error("invalid window size, expected [1.."+t+"], got W="+r)}function os(r,t){Va(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 qa(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+=as);let f=t*n,u=f+Math.abs(a)-1,l=a===0,d=a<0,x=t%2!==0;return{nextN:c,offset:u,isZero:l,isNeg:d,isNegF:x,offsetF:f}}function Dl(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 Kl(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 ss=new WeakMap,za=new WeakMap;function is(r){return za.get(r)||1}function xn(r,t){return{constTimeNegate:ns,hasPrecomputes(e){return is(e)!==1},unsafeLadder(e,n,o=r.ZERO){let s=e;for(;n>Ha;)n&as&&(o=o.add(s)),s=s.double(),n>>=as;return o},precomputeWindow(e,n){let{windows:o,windowSize:s}=os(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=os(e,t);for(let c=0;c<a.windows;c++){let{nextN:f,offset:u,isZero:l,isNeg:d,isNegF:x,offsetF:b}=qa(o,c,a);o=f,l?i=i.add(ns(x,n[b])):s=s.add(ns(d,n[u]))}return{p:s,f:i}},wNAFUnsafe(e,n,o,s=r.ZERO){let i=os(e,t);for(let a=0;a<i.windows&&o!==Ha;a++){let{nextN:c,offset:f,isZero:u,isNeg:l}=qa(o,a,i);if(o=c,!u){let d=n[f];s=s.add(l?d.negate():d)}}return s},getPrecomputes(e,n,o){let s=ss.get(n);return s||(s=this.precomputeWindow(n,e),e!==1&&ss.set(n,o(s))),s},wNAFCached(e,n,o){let s=is(e);return this.wNAF(s,this.getPrecomputes(s,e,o),n)},wNAFCachedUnsafe(e,n,o,s){let i=is(e);return i===1?this.unsafeLadder(e,n,s):this.wNAFUnsafe(i,this.getPrecomputes(i,e,o),n,s)},setWindowSize(e,n){Va(n,t),za.set(e,n),ss.delete(e)}}}function wn(r,t,e,n){if(Dl(e,r),Kl(n,t),e.length!==n.length)throw new Error("arrays of points and scalars must have equal length");let o=r.ZERO,s=Ua(BigInt(e.length)),i=s>12?s-3:s>4?s-2:s?2:1,a=Ue(i),c=new Array(Number(a)+1).fill(o),f=Math.floor((t.BITS-1)/i)*i,u=o;for(let l=f;l>=0;l-=i){c.fill(o);for(let x=0;x<n.length;x++){let b=n[x],m=Number(b>>BigInt(l)&a);c[m]=c[m].add(e[x])}let d=o;for(let x=c.length-1,b=o;x>0;x--)b=b.add(c[x]),d=d.add(b);if(u=u.add(d),l!==0)for(let x=0;x<i;x++)u=u.double()}return u}function Tr(r){return ts(r.Fp),qt(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...es(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Zt=BigInt(0),Pt=BigInt(1),Fa=BigInt(2),Nl=BigInt(8),Ml={zip215:!0};function Ol(r){let t=Tr(r);return qt(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function Ga(r){let t=Ol(r),{Fp:e,n,prehash:o,hash:s,randomBytes:i,nByteLength:a,h:c}=t,f=Fa<<BigInt(a*8)-Pt,u=e.create,l=Vt(t.n,t.nBitLength),d=t.uvRatio||((E,y)=>{try{return{isValid:!0,value:e.sqrt(E*e.inv(y))}}catch{return{isValid:!1,value:Zt}}}),x=t.adjustScalarBytes||(E=>E),b=t.domain||((E,y,g)=>{if(jt("phflag",g),y.length||g)throw new Error("Contexts/pre-hash are not supported");return E});function m(E,y,g=!1){let L=g?Pt:Zt;At("coordinate "+E,y,L,f)}function h(E){if(!(E instanceof p))throw new Error("ExtendedPoint expected")}let w=Qe((E,y)=>{let{ex:g,ey:L,ez:R}=E,D=E.is0();y==null&&(y=D?Nl:e.inv(R));let O=u(g*y),V=u(L*y),z=u(R*y);if(D)return{x:Zt,y:Pt};if(z!==Pt)throw new Error("invZ was invalid");return{x:O,y:V}}),S=Qe(E=>{let{a:y,d:g}=t;if(E.is0())throw new Error("bad point: ZERO");let{ex:L,ey:R,ez:D,et:O}=E,V=u(L*L),z=u(R*R),F=u(D*D),rt=u(F*F),tt=u(V*y),st=u(F*u(tt+z)),Ut=u(rt+u(g*u(V*z)));if(st!==Ut)throw new Error("bad point: equation left != right (1)");let yt=u(L*R),Et=u(D*O);if(yt!==Et)throw new Error("bad point: equation left != right (2)");return!0});class p{constructor(y,g,L,R){m("x",y),m("y",g),m("z",L,!0),m("t",R),this.ex=y,this.ey=g,this.ez=L,this.et=R,Object.freeze(this)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(y){if(y instanceof p)throw new Error("extended point not allowed");let{x:g,y:L}=y||{};return m("x",g),m("y",L),new p(g,L,Pt,u(g*L))}static normalizeZ(y){let g=tr(e,y.map(L=>L.ez));return y.map((L,R)=>L.toAffine(g[R])).map(p.fromAffine)}static msm(y,g){return wn(p,l,y,g)}_setWindowSize(y){P.setWindowSize(this,y)}assertValidity(){S(this)}equals(y){h(y);let{ex:g,ey:L,ez:R}=this,{ex:D,ey:O,ez:V}=y,z=u(g*V),F=u(D*R),rt=u(L*V),tt=u(O*R);return z===F&&rt===tt}is0(){return this.equals(p.ZERO)}negate(){return new p(u(-this.ex),this.ey,this.ez,u(-this.et))}double(){let{a:y}=t,{ex:g,ey:L,ez:R}=this,D=u(g*g),O=u(L*L),V=u(Fa*u(R*R)),z=u(y*D),F=g+L,rt=u(u(F*F)-D-O),tt=z+O,st=tt-V,Ut=z-O,yt=u(rt*st),Et=u(tt*Ut),Rt=u(rt*Ut),Nt=u(st*tt);return new p(yt,Et,Nt,Rt)}add(y){h(y);let{a:g,d:L}=t,{ex:R,ey:D,ez:O,et:V}=this,{ex:z,ey:F,ez:rt,et:tt}=y,st=u(R*z),Ut=u(D*F),yt=u(V*L*tt),Et=u(O*rt),Rt=u((R+D)*(z+F)-st-Ut),Nt=Et-yt,pr=Et+yt,Hi=u(Ut-g*st),qu=u(Rt*Nt),Vu=u(pr*Hi),zu=u(Rt*Hi),Fu=u(Nt*pr);return new p(qu,Vu,Fu,zu)}subtract(y){return this.add(y.negate())}wNAF(y){return P.wNAFCached(this,y,p.normalizeZ)}multiply(y){let g=y;At("scalar",g,Pt,n);let{p:L,f:R}=this.wNAF(g);return p.normalizeZ([L,R])[0]}multiplyUnsafe(y,g=p.ZERO){let L=y;return At("scalar",L,Zt,n),L===Zt?U:this.is0()||L===Pt?this:P.wNAFCachedUnsafe(this,L,p.normalizeZ,g)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return P.unsafeLadder(this,n).is0()}toAffine(y){return w(this,y)}clearCofactor(){let{h:y}=t;return y===Pt?this:this.multiplyUnsafe(y)}static fromHex(y,g=!1){let{d:L,a:R}=t,D=e.BYTES;y=nt("pointHex",y,D),jt("zip215",g);let O=y.slice(),V=y[D-1];O[D-1]=V&-129;let z=$t(O),F=g?f:e.ORDER;At("pointHex.y",z,Zt,F);let rt=u(z*z),tt=u(rt-Pt),st=u(L*rt-R),{isValid:Ut,value:yt}=d(tt,st);if(!Ut)throw new Error("Point.fromHex: invalid y coordinate");let Et=(yt&Pt)===Pt,Rt=(V&128)!==0;if(!g&&yt===Zt&&Rt)throw new Error("Point.fromHex: x=0 and x_0=1");return Rt!==Et&&(yt=u(-yt)),p.fromAffine({x:yt,y:z})}static fromPrivateKey(y){let{scalar:g}=I(y);return A.multiply(g)}toRawBytes(){let{x:y,y:g}=this.toAffine(),L=xe(g,e.BYTES);return L[L.length-1]|=y&Pt?128:0,L}toHex(){return ge(this.toRawBytes())}}p.BASE=new p(t.Gx,t.Gy,Pt,u(t.Gx*t.Gy)),p.ZERO=new p(Zt,Pt,Pt,Zt);let{BASE:A,ZERO:U}=p,P=xn(p,a*8);function B(E){return $(E,n)}function C(E){return B($t(E))}function I(E){let y=e.BYTES;E=nt("private key",E,y);let g=nt("hashed private key",s(E),2*y),L=x(g.slice(0,y)),R=g.slice(y,2*y),D=C(L);return{head:L,prefix:R,scalar:D}}function M(E){let{head:y,prefix:g,scalar:L}=I(E),R=A.multiply(L),D=R.toRawBytes();return{head:y,prefix:g,scalar:L,point:R,pointBytes:D}}function N(E){return M(E).pointBytes}function k(E=Uint8Array.of(),...y){let g=we(...y);return C(s(b(g,nt("context",E),!!o)))}function q(E,y,g={}){E=nt("message",E),o&&(E=o(E));let{prefix:L,scalar:R,pointBytes:D}=M(y),O=k(g.context,L,E),V=A.multiply(O).toRawBytes(),z=k(g.context,V,D,E),F=B(O+z*R);At("signature.s",F,Zt,n);let rt=we(V,xe(F,e.BYTES));return nt("result",rt,e.BYTES*2)}let v=Ml;function _(E,y,g,L=v){let{context:R,zip215:D}=L,O=e.BYTES;E=nt("signature",E,2*O),y=nt("message",y),g=nt("publicKey",g,O),D!==void 0&&jt("zip215",D),o&&(y=o(y));let V=$t(E.slice(O,2*O)),z,F,rt;try{z=p.fromHex(g,D),F=p.fromHex(E.slice(0,O),D),rt=A.multiplyUnsafe(V)}catch{return!1}if(!D&&z.isSmallOrder())return!1;let tt=k(R,F.toRawBytes(),z.toRawBytes(),y);return F.add(z.multiplyUnsafe(tt)).subtract(rt).clearCofactor().equals(p.ZERO)}return A._setWindowSize(8),{CURVE:t,getPublicKey:N,sign:q,verify:_,ExtendedPoint:p,utils:{getExtendedPublicKey:M,randomPrivateKey:()=>i(e.BYTES),precompute(E=8,y=p.BASE){return y._setWindowSize(E),y.multiply(BigInt(3)),y}}}}var er=BigInt(0),cs=BigInt(1);function Hl(r){return qt(r,{a:"bigint"},{montgomeryBits:"isSafeInteger",nByteLength:"isSafeInteger",adjustScalarBytes:"function",domain:"function",powPminus2:"function",Gu:"bigint"}),Object.freeze({...r})}function Wa(r){let t=Hl(r),{P:e}=t,n=Vt(e),o=p=>$(p,e),s=t.montgomeryBits,i=Math.ceil(s/8),a=t.nByteLength,c=t.adjustScalarBytes||(p=>p),f=t.powPminus2||(p=>n.pow(p,e-BigInt(2)));function u(p,A,U){let P=o(p*(A-U));return A=o(A-P),U=o(U+P),[A,U]}let l=(t.a-BigInt(2))/BigInt(4);function d(p,A){At("u",p,er,e),At("scalar",A,er,e);let U=A,P=p,B=cs,C=er,I=p,M=cs,N=er,k;for(let v=BigInt(s-1);v>=er;v--){let _=U>>v&cs;N^=_,k=u(N,B,I),B=k[0],I=k[1],k=u(N,C,M),C=k[0],M=k[1],N=_;let T=B+C,E=o(T*T),y=B-C,g=o(y*y),L=E-g,R=I+M,D=I-M,O=o(D*T),V=o(R*y),z=O+V,F=O-V;I=o(z*z),M=o(P*o(F*F)),B=o(E*g),C=o(L*(E+o(l*L)))}k=u(N,B,I),B=k[0],I=k[1],k=u(N,C,M),C=k[0],M=k[1];let q=f(C);return o(B*q)}function x(p){return xe(o(p),i)}function b(p){let A=nt("u coordinate",p,i);return a===32&&(A[31]&=127),$t(A)}function m(p){let A=nt("scalar",p),U=A.length;if(U!==i&&U!==a){let P=""+i+" or "+a;throw new Error("invalid scalar, expected "+P+" bytes, got "+U)}return $t(c(A))}function h(p,A){let U=b(A),P=m(p),B=d(U,P);if(B===er)throw new Error("invalid private or public key received");return x(B)}let w=x(t.Gu);function S(p){return h(p,w)}return{scalarMult:h,scalarMultBase:S,getSharedSecret:(p,A)=>h(p,A),getPublicKey:p=>S(p),utils:{randomPrivateKey:()=>t.randomBytes(t.nByteLength)},GuBytes:w}}var Cr=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),ja=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),cm=BigInt(0),ql=BigInt(1),$a=BigInt(2),Vl=BigInt(3),zl=BigInt(5),Fl=BigInt(8);function Ya(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),o=BigInt(80),s=Cr,a=r*r%s*r%s,c=ot(a,$a,s)*a%s,f=ot(c,ql,s)*r%s,u=ot(f,zl,s)*f%s,l=ot(u,t,s)*u%s,d=ot(l,e,s)*l%s,x=ot(d,n,s)*d%s,b=ot(x,o,s)*x%s,m=ot(b,o,s)*x%s,h=ot(m,t,s)*u%s;return{pow_p_5_8:ot(h,$a,s)*r%s,b2:a}}function Xa(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function Gl(r,t){let e=Cr,n=$(t*t*t,e),o=$(n*n*t,e),s=Ya(r*o).pow_p_5_8,i=$(r*n*s,e),a=$(t*i*i,e),c=i,f=$(i*ja,e),u=a===r,l=a===$(-r,e),d=a===$(-r*ja,e);return u&&(i=c),(l||d)&&(i=f),Na(i,e)&&(i=$(-i,e)),{isValid:u||l,value:i}}var Za=Vt(Cr,void 0,!0),Wl={a:Za.create(BigInt(-1)),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:Za,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:Fl,Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:_a,randomBytes:Ar,adjustScalarBytes:Xa,uvRatio:Gl},Ja=Ga(Wl);var Pr=Wa({P:Cr,a:BigInt(486662),montgomeryBits:255,nByteLength:32,Gu:BigInt(9),powPminus2:r=>{let t=Cr,{pow_p_5_8:e,b2:n}=Ya(r);return $(ot(e,Vl,t)*n,t)},adjustScalarBytes:Xa,randomBytes:Ar});var bn=32;function Qa(r,t,e){return Ja.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}var En=class{type="Ed25519";raw;constructor(t){this.raw=us(t,bn)}toMultihash(){return Mt.digest(he(this))}toCID(){return ut.createV1(114,this.toMultihash())}toString(){return et.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 Qa(this.raw,e,t)}};function fs(r){return r=us(r,bn),new En(r)}function us(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 $l=Math.pow(2,7),Zl=Math.pow(2,14),Yl=Math.pow(2,21),ls=Math.pow(2,28),hs=Math.pow(2,35),ds=Math.pow(2,42),ps=Math.pow(2,49),X=128,vt=127;function lt(r){if(r<$l)return 1;if(r<Zl)return 2;if(r<Yl)return 3;if(r<ls)return 4;if(r<hs)return 5;if(r<ds)return 6;if(r<ps)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function ms(r,t,e=0){switch(lt(r)){case 8:t[e++]=r&255|X,r/=128;case 7:t[e++]=r&255|X,r/=128;case 6:t[e++]=r&255|X,r/=128;case 5:t[e++]=r&255|X,r/=128;case 4:t[e++]=r&255|X,r>>>=7;case 3:t[e++]=r&255|X,r>>>=7;case 2:t[e++]=r&255|X,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function Xl(r,t,e=0){switch(lt(r)){case 8:t.set(e++,r&255|X),r/=128;case 7:t.set(e++,r&255|X),r/=128;case 6:t.set(e++,r&255|X),r/=128;case 5:t.set(e++,r&255|X),r/=128;case 4:t.set(e++,r&255|X),r>>>=7;case 3:t.set(e++,r&255|X),r>>>=7;case 2:t.set(e++,r&255|X),r>>>=7;case 1:{t.set(e++,r&255),r>>>=7;break}default:throw new Error("unreachable")}return t}function ys(r,t){let e=r[t],n=0;if(n+=e&vt,e<X||(e=r[t+1],n+=(e&vt)<<7,e<X)||(e=r[t+2],n+=(e&vt)<<14,e<X)||(e=r[t+3],n+=(e&vt)<<21,e<X)||(e=r[t+4],n+=(e&vt)*ls,e<X)||(e=r[t+5],n+=(e&vt)*hs,e<X)||(e=r[t+6],n+=(e&vt)*ds,e<X)||(e=r[t+7],n+=(e&vt)*ps,e<X))return n;throw new RangeError("Could not decode varint")}function Jl(r,t){let e=r.get(t),n=0;if(n+=e&vt,e<X||(e=r.get(t+1),n+=(e&vt)<<7,e<X)||(e=r.get(t+2),n+=(e&vt)<<14,e<X)||(e=r.get(t+3),n+=(e&vt)<<21,e<X)||(e=r.get(t+4),n+=(e&vt)*ls,e<X)||(e=r.get(t+5),n+=(e&vt)*hs,e<X)||(e=r.get(t+6),n+=(e&vt)*ds,e<X)||(e=r.get(t+7),n+=(e&vt)*ps,e<X))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?ms(r,t,e):Xl(r,t,e)}function zt(r,t=0){return r instanceof Uint8Array?ys(r,t):Jl(r,t)}var gs=new Float32Array([-0]),be=new Uint8Array(gs.buffer);function ec(r,t,e){gs[0]=r,t[e]=be[0],t[e+1]=be[1],t[e+2]=be[2],t[e+3]=be[3]}function rc(r,t){return be[0]=r[t],be[1]=r[t+1],be[2]=r[t+2],be[3]=r[t+3],gs[0]}var xs=new Float64Array([-0]),It=new Uint8Array(xs.buffer);function nc(r,t,e){xs[0]=r,t[e]=It[0],t[e+1]=It[1],t[e+2]=It[2],t[e+3]=It[3],t[e+4]=It[4],t[e+5]=It[5],t[e+6]=It[6],t[e+7]=It[7]}function oc(r,t){return It[0]=r[t],It[1]=r[t+1],It[2]=r[t+2],It[3]=r[t+3],It[4]=r[t+4],It[5]=r[t+5],It[6]=r[t+6],It[7]=r[t+7],xs[0]}var Ql=BigInt(Number.MAX_SAFE_INTEGER),th=BigInt(Number.MIN_SAFE_INTEGER),Dt=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<Ql&&t>th)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>sc&&(o=0n,++n>sc&&(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 Dt(0,0);Re.toBigInt=function(){return 0n};Re.zzEncode=Re.zzDecode=function(){return this};Re.length=function(){return 1};var sc=4294967296n;function ic(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 ac(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 ws(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 Sn(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var bs=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 Sn(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Ft(this,4);return Sn(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Ft(this,4);let t=rc(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Ft(this,4);let t=oc(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 ac(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 Dt(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=Sn(this.buf,this.pos+=4),e=Sn(this.buf,this.pos+=4);return new Dt(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=ys(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 Es(r){return new bs(r instanceof Uint8Array?r:r.subarray())}function De(r,t,e){let n=Es(r);return t.decode(n,void 0,e)}function Ss(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 As(){}var Is=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},eh=Ss();function rh(r){return globalThis.Buffer!=null?pt(r):eh(r)}var Rr=class{len;head;tail;states;constructor(){this.len=0,this.head=new Ke(As,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 Bs((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(An,10,Dt.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=Dt.fromBigInt(t);return this._push(An,e.length(),e)}uint64Number(t){return this._push(ms,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=Dt.fromBigInt(t).zzEncode();return this._push(An,e.length(),e)}sint64Number(t){let e=Dt.fromNumber(t).zzEncode();return this._push(An,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(vs,1,t?1:0)}fixed32(t){return this._push(kr,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=Dt.fromBigInt(t);return this._push(kr,4,e.lo)._push(kr,4,e.hi)}fixed64Number(t){let e=Dt.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(ec,4,t)}double(t){return this._push(nc,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(vs,1,0):this.uint32(e)._push(oh,e,t)}string(t){let e=ic(t);return e!==0?this.uint32(e)._push(ws,e,t):this._push(vs,1,0)}fork(){return this.states=new Is(this),this.head=this.tail=new Ke(As,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(As,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=rh(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function vs(r,t,e){t[e]=r&255}function nh(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var Bs=class extends Ke{next;constructor(t,e){super(nh,t,e),this.next=void 0}};function An(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 oh(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(Rr.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(sh,t,r),this},Rr.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(ih,t,r),this});function sh(r,t,e){t.set(r,e)}function ih(r,t,e){r.length<40?ws(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(Y(r),e)}function _s(){return new Rr}function Ne(r,t){let e=_s();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 vn(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function Ls(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 vn("enum",rr.VARINT,e,n)}function Me(r,t){return vn("message",rr.LENGTH_DELIMITED,r,t)}var Dr=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 Ts;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1",r[r.ECDSA=3]="ECDSA"})(Ts||(Ts={}));(function(r){r.codec=()=>Ls(Ts)})(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 Cs;(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)})(Cs||(Cs={}));var Kr=class extends Error{constructor(t="An error occurred while verifying a message"){super(t),this.name="VerificationError"}},In=class extends Error{constructor(t="Missing Web Crypto API"){super(t),this.name="WebCryptoMissingError"}};var fc={get(r=globalThis){let t=r.crypto;if(t?.subtle==null)throw new In("Missing Web Crypto API. The most likely cause of this error is that this page is being accessed from an insecure context (i.e. not HTTPS). For more information and possible resolutions see https://github.com/libp2p/js-libp2p/blob/main/packages/crypto/README.md#web-crypto-api");return t}};var Ee=fc;var Mr={};Tt(Mr,{MAX_RSA_KEY_SIZE:()=>Ps,generateRSAKeyPair:()=>pc,jwkToJWKKeyPair:()=>mc,jwkToPkcs1:()=>fh,jwkToPkix:()=>Ds,jwkToRSAPrivateKey:()=>Os,pkcs1MessageToJwk:()=>ks,pkcs1MessageToRSAPrivateKey:()=>Ks,pkcs1ToJwk:()=>uh,pkcs1ToRSAPrivateKey:()=>dc,pkixMessageToJwk:()=>Rs,pkixMessageToRSAPublicKey:()=>Ms,pkixToJwk:()=>lh,pkixToRSAPublicKey:()=>Ns});var Se=mn;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=Mr.jwkToPkix(this.jwk)),this._raw}toMultihash(){return this._multihash}toCID(){return ut.createV1(114,this._multihash)}toString(){return et.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 hc(this.jwk,e,t)}},Nr=class{type="RSA";jwk;_raw;publicKey;constructor(t,e){this.jwk=t,this.publicKey=e}get raw(){return this._raw==null&&(this._raw=Mr.jwkToPkcs1(this.jwk)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:ht(this.raw,t.raw)}sign(t){return lc(this.jwk,t)}};var Ps=8192,Us=18,ah=1062,ch=Uint8Array.from([48,13,6,9,42,134,72,134,247,13,1,1,1,5,0]);function uh(r){let t=te(r);return ks(t)}function ks(r){return{n:H(r[1],"base64url"),e:H(r[2],"base64url"),d:H(r[3],"base64url"),p:H(r[4],"base64url"),q:H(r[5],"base64url"),dp:H(r[6],"base64url"),dq:H(r[7],"base64url"),qi:H(r[8],"base64url"),kty:"RSA"}}function fh(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 le([kt(Uint8Array.from([0])),kt(Y(r.n,"base64url")),kt(Y(r.e,"base64url")),kt(Y(r.d,"base64url")),kt(Y(r.p,"base64url")),kt(Y(r.q,"base64url")),kt(Y(r.dp,"base64url")),kt(Y(r.dq,"base64url")),kt(Y(r.qi,"base64url"))]).subarray()}function lh(r){let t=te(r,{offset:0});return Rs(t)}function Rs(r){let t=te(r[1],{offset:0});return{kty:"RSA",n:H(t[0],"base64url"),e:H(t[1],"base64url")}}function Ds(r){if(r.n==null||r.e==null)throw new at("JWK was missing components");return le([ch,ln(le([kt(Y(r.n,"base64url")),kt(Y(r.e,"base64url"))]))]).subarray()}function dc(r){let t=te(r);return Ks(t)}function Ks(r){let t=ks(r);return Os(t)}function Ns(r,t){if(r.byteLength>=ah)throw new Ge("Key size is too large");let e=te(r,{offset:0});return Ms(e,r,t)}function Ms(r,t,e){let n=Rs(r);if(e==null){let o=Se(Xt.encode({Type:ft.RSA,Data:t}));e=Kt(Us,o)}return new nr(n,e)}function Os(r){if(gc(r)>Ps)throw new at("Key size is too large");let t=mc(r),e=Se(Xt.encode({Type:ft.RSA,Data:Ds(t.publicKey)})),n=Kt(Us,e);return new Nr(t.privateKey,new nr(t.publicKey,n))}async function pc(r){if(r>Ps)throw new at("Key size is too large");let t=await yc(r),e=Se(Xt.encode({Type:ft.RSA,Data:Ds(t.publicKey)})),n=Kt(Us,e);return new Nr(t.privateKey,new nr(t.publicKey,n))}function mc(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 yc(r){let t=await Ee.get().subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:r,publicExponent:new Uint8Array([1,0,1]),hash:{name:"SHA-256"}},!0,["sign","verify"]),e=await hh(t);return{privateKey:e[0],publicKey:e[1]}}async function lc(r,t){let e=await Ee.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await Ee.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},e,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(n,0,n.byteLength)}async function hc(r,t,e){let n=await Ee.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return Ee.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,t,e instanceof Uint8Array?e:e.subarray())}async function hh(r){if(r.privateKey==null||r.publicKey==null)throw new at("Private and public key are required");return Promise.all([Ee.get().subtle.exportKey("jwk",r.privateKey),Ee.get().subtle.exportKey("jwk",r.publicKey)])}function gc(r){if(r.kty!=="RSA")throw new at("invalid key type");if(r.n==null)throw new at("invalid key modulus");return Y(r.n,"base64url").length*8}var Bn=class extends Xe{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,Sr(t);let n=de(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),Ot(s)}update(t){return Je(this),this.iHash.update(t),this}digestInto(t){Je(this),_e(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 Bn(r,t).update(e).digest();or.create=(r,t)=>new Bn(r,t);function xc(r){r.lowS!==void 0&&jt("lowS",r.lowS),r.prehash!==void 0&&jt("prehash",r.prehash)}function dh(r){let t=Tr(r);qt(t,{a:"field",b:"field"},{allowedPrivateKeyLengths:"array",wrapPrivateKey:"boolean",isTorsionFree:"function",clearCofactor:"function",allowInfinityPoint:"boolean",fromBytes:"function",toBytes:"function"});let{endo:e,Fp:n,a:o}=t;if(e){if(!n.eql(o,n.ZERO))throw new Error("invalid endomorphism, can only be defined for Koblitz curves that have a=0");if(typeof e!="object"||typeof e.beta!="bigint"||typeof e.splitScalar!="function")throw new Error("invalid endomorphism, expected beta: bigint and splitScalar: function")}return Object.freeze({...t})}var Hs=class extends Error{constructor(t=""){super(t)}},oe={Err:Hs,_tlv:{encode:(r,t)=>{let{Err:e}=oe;if(r<0||r>256)throw new e("tlv.encode: wrong tag");if(t.length&1)throw new e("tlv.encode: unpadded data");let n=t.length/2,o=_r(n);if(o.length/2&128)throw new e("tlv.encode: long form length too big");let s=n>127?_r(o.length/2|128):"";return _r(r)+s+o+t},decode(r,t){let{Err:e}=oe,n=0;if(r<0||r>256)throw new e("tlv.encode: wrong tag");if(t.length<2||t[n++]!==r)throw new e("tlv.decode: wrong tlv");let 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}=oe;if(r<se)throw new t("integer: negative integers are not allowed");let e=_r(r);if(Number.parseInt(e[0],16)&8&&(e="00"+e),e.length&1)throw new t("unexpected DER parsing assertion: unpadded hex");return e},decode(r){let{Err:t}=oe;if(r[0]&128)throw new t("invalid signature integer: negative");if(r[0]===0&&!(r[1]&128))throw new t("invalid signature integer: unnecessary leading zero");return ne(r)}},toSig(r){let{Err:t,_int:e,_tlv:n}=oe,o=nt("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}=oe,n=t.encode(2,e.encode(r.r)),o=t.encode(2,e.encode(r.s)),s=n+o;return t.encode(48,s)}},se=BigInt(0),gt=BigInt(1),Ny=BigInt(2),wc=BigInt(3),My=BigInt(4);function ph(r){let t=dh(r),{Fp:e}=t,n=Vt(t.n,t.nBitLength),o=t.toBytes||((m,h,w)=>{let S=h.toAffine();return we(Uint8Array.from([4]),e.toBytes(S.x),e.toBytes(S.y))}),s=t.fromBytes||(m=>{let h=m.subarray(1),w=e.fromBytes(h.subarray(0,e.BYTES)),S=e.fromBytes(h.subarray(e.BYTES,2*e.BYTES));return{x:w,y:S}});function i(m){let{a:h,b:w}=t,S=e.sqr(m),p=e.mul(S,m);return e.add(e.add(p,e.mul(m,h)),w)}if(!e.eql(e.sqr(t.Gy),i(t.Gx)))throw new Error("bad generator point: equation left != right");function a(m){return yn(m,gt,t.n)}function c(m){let{allowedPrivateKeyLengths:h,nByteLength:w,wrapPrivateKey:S,n:p}=t;if(h&&typeof m!="bigint"){if(Ce(m)&&(m=ge(m)),typeof m!="string"||!h.includes(m.length))throw new Error("invalid private key");m=m.padStart(w*2,"0")}let A;try{A=typeof m=="bigint"?m:ne(nt("private key",m,w))}catch{throw new Error("invalid private key, expected hex or "+w+" bytes, got "+typeof m)}return S&&(A=$(A,p)),At("private key",A,gt,p),A}function f(m){if(!(m instanceof d))throw new Error("ProjectivePoint expected")}let u=Qe((m,h)=>{let{px:w,py:S,pz:p}=m;if(e.eql(p,e.ONE))return{x:w,y:S};let A=m.is0();h==null&&(h=A?e.ONE:e.inv(p));let U=e.mul(w,h),P=e.mul(S,h),B=e.mul(p,h);if(A)return{x:e.ZERO,y:e.ZERO};if(!e.eql(B,e.ONE))throw new Error("invZ was invalid");return{x:U,y:P}}),l=Qe(m=>{if(m.is0()){if(t.allowInfinityPoint&&!e.is0(m.py))return;throw new Error("bad point: ZERO")}let{x:h,y:w}=m.toAffine();if(!e.isValid(h)||!e.isValid(w))throw new Error("bad point: x or y not FE");let S=e.sqr(w),p=i(h);if(!e.eql(S,p))throw new Error("bad point: equation left != right");if(!m.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});class d{constructor(h,w,S){if(h==null||!e.isValid(h))throw new Error("x required");if(w==null||!e.isValid(w)||e.is0(w))throw new Error("y required");if(S==null||!e.isValid(S))throw new Error("z required");this.px=h,this.py=w,this.pz=S,Object.freeze(this)}static fromAffine(h){let{x:w,y:S}=h||{};if(!h||!e.isValid(w)||!e.isValid(S))throw new Error("invalid affine point");if(h instanceof d)throw new Error("projective point not allowed");let p=A=>e.eql(A,e.ZERO);return p(w)&&p(S)?d.ZERO:new d(w,S,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(h){let w=tr(e,h.map(S=>S.pz));return h.map((S,p)=>S.toAffine(w[p])).map(d.fromAffine)}static fromHex(h){let w=d.fromAffine(s(nt("pointHex",h)));return w.assertValidity(),w}static fromPrivateKey(h){return d.BASE.multiply(c(h))}static msm(h,w){return wn(d,n,h,w)}_setWindowSize(h){b.setWindowSize(this,h)}assertValidity(){l(this)}hasEvenY(){let{y:h}=this.toAffine();if(e.isOdd)return!e.isOdd(h);throw new Error("Field doesn't support isOdd")}equals(h){f(h);let{px:w,py:S,pz:p}=this,{px:A,py:U,pz:P}=h,B=e.eql(e.mul(w,P),e.mul(A,p)),C=e.eql(e.mul(S,P),e.mul(U,p));return B&&C}negate(){return new d(this.px,e.neg(this.py),this.pz)}double(){let{a:h,b:w}=t,S=e.mul(w,wc),{px:p,py:A,pz:U}=this,P=e.ZERO,B=e.ZERO,C=e.ZERO,I=e.mul(p,p),M=e.mul(A,A),N=e.mul(U,U),k=e.mul(p,A);return k=e.add(k,k),C=e.mul(p,U),C=e.add(C,C),P=e.mul(h,C),B=e.mul(S,N),B=e.add(P,B),P=e.sub(M,B),B=e.add(M,B),B=e.mul(P,B),P=e.mul(k,P),C=e.mul(S,C),N=e.mul(h,N),k=e.sub(I,N),k=e.mul(h,k),k=e.add(k,C),C=e.add(I,I),I=e.add(C,I),I=e.add(I,N),I=e.mul(I,k),B=e.add(B,I),N=e.mul(A,U),N=e.add(N,N),I=e.mul(N,k),P=e.sub(P,I),C=e.mul(N,M),C=e.add(C,C),C=e.add(C,C),new d(P,B,C)}add(h){f(h);let{px:w,py:S,pz:p}=this,{px:A,py:U,pz:P}=h,B=e.ZERO,C=e.ZERO,I=e.ZERO,M=t.a,N=e.mul(t.b,wc),k=e.mul(w,A),q=e.mul(S,U),v=e.mul(p,P),_=e.add(w,S),T=e.add(A,U);_=e.mul(_,T),T=e.add(k,q),_=e.sub(_,T),T=e.add(w,p);let E=e.add(A,P);return T=e.mul(T,E),E=e.add(k,v),T=e.sub(T,E),E=e.add(S,p),B=e.add(U,P),E=e.mul(E,B),B=e.add(q,v),E=e.sub(E,B),I=e.mul(M,T),B=e.mul(N,v),I=e.add(B,I),B=e.sub(q,I),I=e.add(q,I),C=e.mul(B,I),q=e.add(k,k),q=e.add(q,k),v=e.mul(M,v),T=e.mul(N,T),q=e.add(q,v),v=e.sub(k,v),v=e.mul(M,v),T=e.add(T,v),k=e.mul(q,T),C=e.add(C,k),k=e.mul(E,T),B=e.mul(_,B),B=e.sub(B,k),k=e.mul(_,q),I=e.mul(E,I),I=e.add(I,k),new d(B,C,I)}subtract(h){return this.add(h.negate())}is0(){return this.equals(d.ZERO)}wNAF(h){return b.wNAFCached(this,h,d.normalizeZ)}multiplyUnsafe(h){let{endo:w,n:S}=t;At("scalar",h,se,S);let p=d.ZERO;if(h===se)return p;if(this.is0()||h===gt)return this;if(!w||b.hasPrecomputes(this))return b.wNAFCachedUnsafe(this,h,d.normalizeZ);let{k1neg:A,k1:U,k2neg:P,k2:B}=w.splitScalar(h),C=p,I=p,M=this;for(;U>se||B>se;)U&gt&&(C=C.add(M)),B&gt&&(I=I.add(M)),M=M.double(),U>>=gt,B>>=gt;return A&&(C=C.negate()),P&&(I=I.negate()),I=new d(e.mul(I.px,w.beta),I.py,I.pz),C.add(I)}multiply(h){let{endo:w,n:S}=t;At("scalar",h,gt,S);let p,A;if(w){let{k1neg:U,k1:P,k2neg:B,k2:C}=w.splitScalar(h),{p:I,f:M}=this.wNAF(P),{p:N,f:k}=this.wNAF(C);I=b.constTimeNegate(U,I),N=b.constTimeNegate(B,N),N=new d(e.mul(N.px,w.beta),N.py,N.pz),p=I.add(N),A=M.add(k)}else{let{p:U,f:P}=this.wNAF(h);p=U,A=P}return d.normalizeZ([p,A])[0]}multiplyAndAddUnsafe(h,w,S){let p=d.BASE,A=(P,B)=>B===se||B===gt||!P.equals(p)?P.multiplyUnsafe(B):P.multiply(B),U=A(this,w).add(A(h,S));return U.is0()?void 0:U}toAffine(h){return u(this,h)}isTorsionFree(){let{h,isTorsionFree:w}=t;if(h===gt)return!0;if(w)return w(d,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h,clearCofactor:w}=t;return h===gt?this:w?w(d,this):this.multiplyUnsafe(t.h)}toRawBytes(h=!0){return jt("isCompressed",h),this.assertValidity(),o(d,this,h)}toHex(h=!0){return jt("isCompressed",h),ge(this.toRawBytes(h))}}d.BASE=new d(t.Gx,t.Gy,e.ONE),d.ZERO=new d(e.ZERO,e.ONE,e.ZERO);let x=t.nBitLength,b=xn(d,t.endo?Math.ceil(x/2):x);return{CURVE:t,ProjectivePoint:d,normPrivateKeyToScalar:c,weierstrassEquation:i,isWithinCurveOrder:a}}function mh(r){let t=Tr(r);return qt(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function bc(r){let t=mh(r),{Fp:e,n}=t,o=e.BYTES+1,s=2*e.BYTES+1;function i(v){return $(v,n)}function a(v){return gn(v,n)}let{ProjectivePoint:c,normPrivateKeyToScalar:f,weierstrassEquation:u,isWithinCurveOrder:l}=ph({...t,toBytes(v,_,T){let E=_.toAffine(),y=e.toBytes(E.x),g=we;return jt("isCompressed",T),T?g(Uint8Array.from([_.hasEvenY()?2:3]),y):g(Uint8Array.from([4]),y,e.toBytes(E.y))},fromBytes(v){let _=v.length,T=v[0],E=v.subarray(1);if(_===o&&(T===2||T===3)){let y=ne(E);if(!yn(y,gt,e.ORDER))throw new Error("Point is not on curve");let g=u(y),L;try{L=e.sqrt(g)}catch(O){let V=O instanceof Error?": "+O.message:"";throw new Error("Point is not on curve"+V)}let R=(L&gt)===gt;return(T&1)===1!==R&&(L=e.neg(L)),{x:y,y:L}}else if(_===s&&T===4){let y=e.fromBytes(E.subarray(0,e.BYTES)),g=e.fromBytes(E.subarray(e.BYTES,2*e.BYTES));return{x:y,y:g}}else{let y=o,g=s;throw new Error("invalid Point, expected length of "+y+", or uncompressed "+g+", got "+_)}}}),d=v=>ge(Pe(v,t.nByteLength));function x(v){let _=n>>gt;return v>_}function b(v){return x(v)?i(-v):v}let m=(v,_,T)=>ne(v.slice(_,T));class h{constructor(_,T,E){At("r",_,gt,n),At("s",T,gt,n),this.r=_,this.s=T,E!=null&&(this.recovery=E),Object.freeze(this)}static fromCompact(_){let T=t.nByteLength;return _=nt("compactSignature",_,T*2),new h(m(_,0,T),m(_,T,2*T))}static fromDER(_){let{r:T,s:E}=oe.toSig(nt("DER",_));return new h(T,E)}assertValidity(){}addRecoveryBit(_){return new h(this.r,this.s,_)}recoverPublicKey(_){let{r:T,s:E,recovery:y}=this,g=P(nt("msgHash",_));if(y==null||![0,1,2,3].includes(y))throw new Error("recovery id invalid");let L=y===2||y===3?T+t.n:T;if(L>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let R=(y&1)===0?"02":"03",D=c.fromHex(R+d(L)),O=a(L),V=i(-g*O),z=i(E*O),F=c.BASE.multiplyAndAddUnsafe(D,V,z);if(!F)throw new Error("point at infinify");return F.assertValidity(),F}hasHighS(){return x(this.s)}normalizeS(){return this.hasHighS()?new h(this.r,i(-this.s),this.recovery):this}toDERRawBytes(){return Lr(this.toDERHex())}toDERHex(){return oe.hexFromSig(this)}toCompactRawBytes(){return Lr(this.toCompactHex())}toCompactHex(){return d(this.r)+d(this.s)}}let w={isValidPrivateKey(v){try{return f(v),!0}catch{return!1}},normPrivateKeyToScalar:f,randomPrivateKey:()=>{let v=rs(t.n);return Oa(t.randomBytes(v),t.n)},precompute(v=8,_=c.BASE){return _._setWindowSize(v),_.multiply(BigInt(3)),_}};function S(v,_=!0){return c.fromPrivateKey(v).toRawBytes(_)}function p(v){let _=Ce(v),T=typeof v=="string",E=(_||T)&&v.length;return _?E===o||E===s:T?E===2*o||E===2*s:v instanceof c}function A(v,_,T=!0){if(p(v))throw new Error("first arg must be private key");if(!p(_))throw new Error("second arg must be public key");return c.fromHex(_).multiply(f(v)).toRawBytes(T)}let U=t.bits2int||function(v){if(v.length>8192)throw new Error("input is too large");let _=ne(v),T=v.length*8-t.nBitLength;return T>0?_>>BigInt(T):_},P=t.bits2int_modN||function(v){return i(U(v))},B=Ue(t.nBitLength);function C(v){return At("num < 2^"+t.nBitLength,v,se,B),Pe(v,t.nByteLength)}function I(v,_,T=M){if(["recovered","canonical"].some(tt=>tt in T))throw new Error("sign() legacy options not supported");let{hash:E,randomBytes:y}=t,{lowS:g,prehash:L,extraEntropy:R}=T;g==null&&(g=!0),v=nt("msgHash",v),xc(T),L&&(v=nt("prehashed msgHash",E(v)));let D=P(v),O=f(_),V=[C(O),C(D)];if(R!=null&&R!==!1){let tt=R===!0?y(e.BYTES):R;V.push(nt("extraEntropy",tt))}let z=we(...V),F=D;function rt(tt){let st=U(tt);if(!l(st))return;let Ut=a(st),yt=c.BASE.multiply(st).toAffine(),Et=i(yt.x);if(Et===se)return;let Rt=i(Ut*i(F+Et*O));if(Rt===se)return;let Nt=(yt.x===Et?0:2)|Number(yt.y&gt),pr=Rt;return g&&x(Rt)&&(pr=b(Rt),Nt^=1),new h(Et,pr,Nt)}return{seed:z,k2sig:rt}}let M={lowS:t.lowS,prehash:!1},N={lowS:t.lowS,prehash:!1};function k(v,_,T=M){let{seed:E,k2sig:y}=I(v,_,T),g=t;return ka(g.hash.outputLen,g.nByteLength,g.hmac)(E,y)}c.BASE._setWindowSize(8);function q(v,_,T,E=N){let y=v;_=nt("msgHash",_),T=nt("publicKey",T);let{lowS:g,prehash:L,format:R}=E;if(xc(E),"strict"in E)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 D=typeof y=="string"||Ce(y),O=!D&&!R&&typeof y=="object"&&y!==null&&typeof y.r=="bigint"&&typeof y.s=="bigint";if(!D&&!O)throw new Error("invalid signature, expected Uint8Array, hex string or Signature instance");let V,z;try{if(O&&(V=new h(y.r,y.s)),D){try{R!=="compact"&&(V=h.fromDER(y))}catch(Nt){if(!(Nt instanceof oe.Err))throw Nt}!V&&R!=="der"&&(V=h.fromCompact(y))}z=c.fromHex(T)}catch{return!1}if(!V||g&&V.hasHighS())return!1;L&&(_=t.hash(_));let{r:F,s:rt}=V,tt=P(_),st=a(rt),Ut=i(tt*st),yt=i(F*st),Et=c.BASE.multiplyAndAddUnsafe(z,Ut,yt)?.toAffine();return Et?i(Et.x)===F:!1}return{CURVE:t,getPublicKey:S,getSharedSecret:A,sign:k,verify:q,ProjectivePoint:c,Signature:h,utils:w}}function yh(r){return{hash:r,hmac:(t,...e)=>or(r,t,zo(...e)),randomBytes:Ar}}function Ec(r,t){let e=n=>bc({...r,...yh(n)});return{...e(t),create:e}}var vc=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),Sc=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),gh=BigInt(1),qs=BigInt(2),Ac=(r,t)=>(r+t/qs)/t;function xh(r){let t=vc,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=ot(u,e,t)*u%t,d=ot(l,e,t)*u%t,x=ot(d,qs,t)*f%t,b=ot(x,o,t)*x%t,m=ot(b,s,t)*b%t,h=ot(m,a,t)*m%t,w=ot(h,c,t)*h%t,S=ot(w,a,t)*m%t,p=ot(S,e,t)*u%t,A=ot(p,i,t)*b%t,U=ot(A,n,t)*f%t,P=ot(U,qs,t);if(!Vs.eql(Vs.sqr(P),r))throw new Error("Cannot find square root");return P}var Vs=Vt(vc,void 0,void 0,{sqrt:xh}),Oe=Ec({a:BigInt(0),b:BigInt(7),Fp:Vs,n:Sc,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=Sc,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-gh*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),o=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),s=e,i=BigInt("0x100000000000000000000000000000000"),a=Ac(s*r,t),c=Ac(-n*r,t),f=$(r-a*e-c*o,t),u=$(-a*n-c*s,t),l=f>i,d=u>i;if(l&&(f=t-f),d&&(u=t-u),f>i||u>i)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:l,k1:f,k2neg:d,k2:u}}}},mn),jy=BigInt(0);var $y=Oe.ProjectivePoint;function Ic(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function Bc(r,t,e){let n=wr.digest(e instanceof Uint8Array?e:e.subarray());if(Ic(n))return n.then(({digest:o})=>Oe.verify(t,o,r)).catch(o=>{throw new Kr(String(o))});try{return Oe.verify(t,n.digest,r)}catch(o){throw new Kr(String(o))}}var _n=class{type="secp256k1";raw;_key;constructor(t){this._key=Lc(t),this.raw=_c(this._key)}toMultihash(){return Mt.digest(he(this))}toCID(){return ut.createV1(114,this.toMultihash())}toString(){return et.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 Bc(this._key,e,t)}};function zs(r){return new _n(r)}function _c(r){return Oe.ProjectivePoint.fromHex(r).toRawBytes(!0)}function Lc(r){try{return Oe.ProjectivePoint.fromHex(r),r}catch(t){throw new Ge(String(t))}}function Or(r,t){let{Type:e,Data:n}=Xt.decode(r),o=n??new Uint8Array;switch(e){case ft.RSA:return Ns(o,t);case ft.Ed25519:return fs(o);case ft.secp256k1:return zs(o);case ft.ECDSA:return Vo(o);default:throw new Ae}}function Tc(r){let{Type:t,Data:e}=Xt.decode(r.digest),n=e??new Uint8Array;switch(t){case ft.Ed25519:return fs(n);case ft.secp256k1:return zs(n);case ft.ECDSA:return Vo(n);default:throw new Ae}}function he(r){return Xt.encode({Type:ft[r.type],Data:r.raw})}var Cc=Symbol.for("nodejs.util.inspect.custom"),wh=114,Hr=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()})`}[ho]=!0;toString(){return this.string==null&&(this.string=et.encode(this.multihash.bytes).slice(1)),this.string}toMultihash(){return this.multihash}toCID(){return ut.createV1(wh,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")}[Cc](){return`PeerId(${this.toString()})`}},qr=class extends Hr{type="RSA";publicKey;constructor(t){super({...t,type:"RSA"}),this.publicKey=t.publicKey}},Vr=class extends Hr{type="Ed25519";publicKey;constructor(t){super({...t,type:"Ed25519"}),this.publicKey=t.publicKey}},zr=class extends Hr{type="secp256k1";publicKey;constructor(t){super({...t,type:"secp256k1"}),this.publicKey=t.publicKey}},bh=2336,Fr=class{type="url";multihash;publicKey;url;constructor(t){this.url=t.toString(),this.multihash=Mt.digest(Y(this.url))}[Cc](){return`PeerId(${this.url})`}[ho]=!0;toString(){return this.toCID().toString()}toMultihash(){return this.multihash}toCID(){return ut.createV1(bh,this.toMultihash())}toJSON(){return this.toString()}equals(t){return t==null?!1:(t instanceof Uint8Array&&(t=H(t)),t.toString()===this.toString())}};var Eh=114,Pc=2336;function Uc(r,t){let e;if(r.charAt(0)==="1"||r.charAt(0)==="Q")e=fe(et.decode(`z${r}`));else{if(r.startsWith("k51qzi5uqu5")||r.startsWith("kzwfwjn5ji4")||r.startsWith("k2k4r8")||r.startsWith("bafz"))return Sh(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=fe(t.decode(r))}return kc(e)}function Fs(r){if(r.type==="Ed25519")return new Vr({multihash:r.toCID().multihash,publicKey:r});if(r.type==="secp256k1")return new zr({multihash:r.toCID().multihash,publicKey:r});if(r.type==="RSA")return new qr({multihash:r.toCID().multihash,publicKey:r});throw new Ae}function kc(r){if(vh(r))return new qr({multihash:r});if(Ah(r))try{let t=Tc(r);if(t.type==="Ed25519")return new Vr({multihash:r,publicKey:t});if(t.type==="secp256k1")return new zr({multihash:r,publicKey:t})}catch{let e=H(r.digest);return new Fr(new URL(e))}throw new sn("Supplied PeerID Multihash is invalid")}function Sh(r){if(r?.multihash==null||r.version==null||r.version===1&&r.code!==Eh&&r.code!==Pc)throw new on("Supplied PeerID CID is invalid");if(r.code===Pc){let t=H(r.multihash.digest);return new Fr(new URL(t))}return kc(r.multihash)}function Ah(r){return r.code===Mt.code}function vh(r){return r.code===wr.code}var Ln=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},sr=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},Tn=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"},Gr=class extends Error{name="UnexpectedEOFError";code="ERR_UNEXPECTED_EOF"};function Cn(r){return r[Symbol.asyncIterator]!=null}function Rc(r,t){if(r.byteLength>t)throw new sr("Message length too long")}var Un=r=>{let t=lt(r),e=pt(t);return Yt(r,e),Un.bytes=t,e};Un.bytes=0;function Dc(r,t){t=t??{};let e=t.lengthEncoder??Un,n=t?.maxDataLength??4194304;function*o(s){Rc(s,n);let i=e(s.byteLength);i instanceof Uint8Array?yield i:yield*i,s instanceof Uint8Array?yield s:yield*s}return Cn(r)?async function*(){for await(let s of r)yield*o(s)}():function*(){for(let s of r)yield*o(s)}()}Dc.single=(r,t)=>{t=t??{};let e=t.lengthEncoder??Un,n=t?.maxDataLength??4194304;return Rc(r,n),new G(e(r.byteLength),r)};var He;(function(r){r[r.LENGTH=0]="LENGTH",r[r.DATA=1]="DATA"})(He||(He={}));var Gs=r=>{let t=zt(r);return Gs.bytes=lt(t),t};Gs.bytes=0;function Wr(r,t){let e=new G,n=He.LENGTH,o=-1,s=t?.lengthDecoder??Gs,i=t?.maxLengthLength??8,a=t?.maxDataLength??4194304;function*c(){for(;e.byteLength>0;){if(n===He.LENGTH)try{if(o=s(e),o<0)throw new Ln("Invalid message length");if(o>a)throw new sr("Message length too long");let f=s.bytes;e.consume(f),t?.onLength!=null&&t.onLength(o),n=He.DATA}catch(f){if(f instanceof RangeError){if(e.byteLength>i)throw new Tn("Message length length too long");break}throw f}if(n===He.DATA){if(e.byteLength<o)break;let f=e.sublist(0,o);e.consume(o),t?.onData!=null&&t.onData(f),yield f,n=He.LENGTH}}}return Cn(r)?async function*(){for await(let f of r)e.append(f),yield*c();if(e.byteLength>0)throw new Gr("Unexpected end of input")}():function*(){for(let f of r)e.append(f),yield*c();if(e.byteLength>0)throw new Gr("Unexpected end of input")}()}Wr.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 Wr(n,{...t??{},onLength:s=>{e=s}})};function Bt(){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 Ws=class{readNext;haveNext;ended;nextResult;error;constructor(){this.ended=!1,this.readNext=Bt(),this.haveNext=Bt()}[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=Bt(),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=Bt(),await xt(this.readNext.promise,e?.signal,e)}};function Rn(){return new Ws}var Dn=class extends Error{name="UnexpectedEOFError";code="ERR_UNEXPECTED_EOF"};function Kc(r,t){let e=Rn();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 G;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 Dn("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 Kn=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},Nn=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},Mn=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"};function js(r,t={}){let e=Kc(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 G;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 Kn("Invalid message length");if(t?.maxLengthLength!=null&&c.byteLength>t.maxLengthLength)throw new Mn("message length length too long");if(a>-1)break}if(t?.maxDataLength!=null&&a>t.maxDataLength)throw new Nn("message length too long");return e.read({...i,bytes:a})},write:async(i,a)=>{await e.write(new G(o(i.byteLength),i),a)},writeV:async(i,a)=>{let c=new G(...i.flatMap(f=>[o(f.byteLength),f]));await e.write(c,a)},unwrap:()=>e.unwrap()}}function $s(){let r=Bt(),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 Nc(){let r=$s(),t=$s();return[{source:r.source,sink:t.sink},{source:t.source,sink:r.sink}]}var On=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}},ir=class{size;hwm;head;tail;constructor(t={}){this.hwm=t.splitLimit??16,this.head=new On(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 On(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 Zs=class extends Error{type;code;constructor(t,e){super(t??"The operation was aborted"),this.type="aborted",this.code=e??"ABORT_ERR"}};function Hn(r={}){return Bh(e=>{let n=e.shift();if(n==null)return{done:!0};if(n.error!=null)throw n.error;return{done:n.done===!0,value:n.value}},r)}function Bh(r,t){t=t??{};let e=t.onEnd,n=new ir,o,s,i,a=Bt(),c=async()=>{try{return n.isEmpty()?i?{done:!0}:await new Promise((h,w)=>{s=S=>{s=null,n.push(S);try{h(r(n))}catch(p){w(p)}return o}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{a.resolve(),a=Bt()})}},f=h=>s!=null?s(h):(n.push(h),o),u=h=>(n=new ir,s!=null?s({error:h}):(n.push({error:h}),o)),l=h=>{if(i)return o;if(t?.objectMode!==!0&&h?.byteLength==null)throw new Error("objectMode was not true but tried to push non-Uint8Array value");return f({done:!1,value:h})},d=h=>i?o:(i=!0,h!=null?u(h):f({done:!0})),x=()=>(n=new ir,d(),{done:!0}),b=h=>(d(h),{done:!0});if(o={[Symbol.asyncIterator](){return this},next:c,return:x,throw:b,push:l,end:d,get readableLength(){return n.size},onEmpty:async h=>{let w=h?.signal;if(w?.throwIfAborted(),n.isEmpty())return;let S,p;w!=null&&(S=new Promise((A,U)=>{p=()=>{U(new Zs)},w.addEventListener("abort",p)}));try{await Promise.race([a.promise,S])}finally{p!=null&&w!=null&&w?.removeEventListener("abort",p)}}},e==null)return o;let m=o;return o={[Symbol.asyncIterator](){return this},next(){return m.next()},throw(h){return m.throw(h),e!=null&&(e(h),e=void 0),{done:!0}},return(){return m.return(),e!=null&&(e(),e=void 0),{done:!0}},push:l,end(h){return m.end(h),e!=null&&(e(h),e=void 0),o},get readableLength(){return m.readableLength},onEmpty:h=>m.onEmpty(h)},o}function _h(r){return r[Symbol.asyncIterator]!=null}async function Lh(r,t){try{await Promise.all(r.map(async e=>{for await(let n of e)await t.push(n)})),await t.end()}catch(e){await t.end(e).catch(()=>{})}}async function*Th(r){let t=Rn();Lh(r,t).catch(()=>{}),yield*t}function*Ch(r){for(let t of r)yield*t}function Ph(...r){let t=[];for(let e of r)_h(e)||t.push(e);return t.length===r.length?Ch(t):Th(r)}var Mc=Ph;function Oc(r,...t){if(r==null)throw new Error("Empty pipeline");if(Ys(r)){let n=r;r=()=>n.source}else if(qc(r)||Hc(r)){let n=r;r=()=>n}let e=[r,...t];if(e.length>1&&Ys(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++)Ys(e[n])&&(e[n]=kh(e[n]));return Uh(...e)}var Uh=(...r)=>{let t;for(;r.length>0;)t=r.shift()(t);return t},Hc=r=>r?.[Symbol.asyncIterator]!=null,qc=r=>r?.[Symbol.iterator]!=null,Ys=r=>r==null?!1:r.sink!=null&&r.source!=null,kh=r=>t=>{let e=r.sink(t);if(e?.then!=null){let n=Hn({objectMode:!0});e.then(()=>{n.end()},i=>{n.end(i)});let o,s=r.source;if(Hc(s))o=async function*(){yield*s,n.end()};else if(qc(s))o=function*(){yield*s,n.end()};else throw new Error("Unknown duplex source type - must be Iterable or AsyncIterable");return Mc(n,o())}return r.source};var ar=!!globalThis.process?.env?.DUMP_SESSION_KEYS;function zc(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function qn(r){if(typeof r!="boolean")throw new Error(`boolean expected, not ${r}`)}function Vn(r){if(!Number.isSafeInteger(r)||r<0)throw new Error("positive integer expected, got "+r)}function _t(r,...t){if(!zc(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 Xs(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 Fc(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 ie(r){return new Uint32Array(r.buffer,r.byteOffset,Math.floor(r.byteLength/4))}function ae(...r){for(let t=0;t<r.length;t++)r[t].fill(0)}function Rh(r){return new DataView(r.buffer,r.byteOffset,r.byteLength)}var Dh=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;function Kh(r){if(typeof r!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(r))}function zn(r){if(typeof r=="string")r=Kh(r);else if(zc(r))r=Fn(r);else throw new Error("Uint8Array expected, got "+typeof r);return r}function Gc(r,t){if(t==null||typeof t!="object")throw new Error("options must be defined");return Object.assign(r,t)}function Wc(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 Js=(r,t)=>{function e(n,...o){if(_t(n),!Dh)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 Qs(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&&!Nh(t))throw new Error("invalid output, must be aligned");return t}function Vc(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 jc(r,t,e){qn(e);let n=new Uint8Array(16),o=Rh(n);return Vc(o,0,BigInt(t),e),Vc(o,8,BigInt(r),e),n}function Nh(r){return r.byteOffset%4===0}function Fn(r){return Uint8Array.from(r)}var Zc=r=>Uint8Array.from(r.split("").map(t=>t.charCodeAt(0))),Mh=Zc("expand 16-byte k"),Oh=Zc("expand 32-byte k"),Hh=ie(Mh),qh=ie(Oh);function K(r,t){return r<<t|r>>>32-t}function ti(r){return r.byteOffset%4===0}var Gn=64,Vh=16,Yc=2**32-1,$c=new Uint32Array;function zh(r,t,e,n,o,s,i,a){let c=o.length,f=new Uint8Array(Gn),u=ie(f),l=ti(o)&&ti(s),d=l?ie(o):$c,x=l?ie(s):$c;for(let b=0;b<c;i++){if(r(t,e,n,u,i,a),i>=Yc)throw new Error("arx: counter overflow");let m=Math.min(Gn,c-b);if(l&&m===Gn){let h=b/4;if(b%4!==0)throw new Error("arx: invalid block position");for(let w=0,S;w<Vh;w++)S=h+w,x[S]=d[S]^u[w];b+=Gn;continue}for(let h=0,w;h<m;h++)w=b+h,s[w]=o[w]^f[h];b+=m}}function ei(r,t){let{allowShortKeys:e,extendNonceFn:n,counterLength:o,counterRight:s,rounds:i}=Gc({allowShortKeys:!1,counterLength:8,counterRight:!1,rounds:20},t);if(typeof r!="function")throw new Error("core must be a function");return Vn(o),Vn(i),qn(s),qn(e),(a,c,f,u,l=0)=>{_t(a),_t(c),_t(f);let d=f.length;if(u===void 0&&(u=new Uint8Array(d)),_t(u),Vn(l),l<0||l>=Yc)throw new Error("arx: counter overflow");if(u.length<d)throw new Error(`arx: output (${u.length}) is shorter than data (${d})`);let x=[],b=a.length,m,h;if(b===32)x.push(m=Fn(a)),h=qh;else if(b===16&&e)m=new Uint8Array(32),m.set(a),m.set(a,16),h=Hh,x.push(m);else throw new Error(`arx: invalid 32-byte key, got length=${b}`);ti(c)||x.push(c=Fn(c));let w=ie(m);if(n){if(c.length!==24)throw new Error("arx: extended nonce must be 24 bytes");n(h,w,ie(c.subarray(0,16)),w),c=c.subarray(16)}let S=16-o;if(S!==c.length)throw new Error(`arx: nonce must be ${S} or 16 bytes`);if(S!==12){let A=new Uint8Array(12);A.set(c,s?0:12-c.length),c=A,x.push(c)}let p=ie(c);return zh(r,h,w,p,f,u,l,i),ae(...x),u}}var bt=(r,t)=>r[t++]&255|(r[t++]&255)<<8,ri=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=zn(t),_t(t,32);let e=bt(t,0),n=bt(t,2),o=bt(t,4),s=bt(t,6),i=bt(t,8),a=bt(t,10),c=bt(t,12),f=bt(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]=bt(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],d=i[5],x=i[6],b=i[7],m=i[8],h=i[9],w=bt(t,e+0),S=bt(t,e+2),p=bt(t,e+4),A=bt(t,e+6),U=bt(t,e+8),P=bt(t,e+10),B=bt(t,e+12),C=bt(t,e+14),I=s[0]+(w&8191),M=s[1]+((w>>>13|S<<3)&8191),N=s[2]+((S>>>10|p<<6)&8191),k=s[3]+((p>>>7|A<<9)&8191),q=s[4]+((A>>>4|U<<12)&8191),v=s[5]+(U>>>1&8191),_=s[6]+((U>>>14|P<<2)&8191),T=s[7]+((P>>>11|B<<5)&8191),E=s[8]+((B>>>8|C<<8)&8191),y=s[9]+(C>>>5|o),g=0,L=g+I*a+M*(5*h)+N*(5*m)+k*(5*b)+q*(5*x);g=L>>>13,L&=8191,L+=v*(5*d)+_*(5*l)+T*(5*u)+E*(5*f)+y*(5*c),g+=L>>>13,L&=8191;let R=g+I*c+M*a+N*(5*h)+k*(5*m)+q*(5*b);g=R>>>13,R&=8191,R+=v*(5*x)+_*(5*d)+T*(5*l)+E*(5*u)+y*(5*f),g+=R>>>13,R&=8191;let D=g+I*f+M*c+N*a+k*(5*h)+q*(5*m);g=D>>>13,D&=8191,D+=v*(5*b)+_*(5*x)+T*(5*d)+E*(5*l)+y*(5*u),g+=D>>>13,D&=8191;let O=g+I*u+M*f+N*c+k*a+q*(5*h);g=O>>>13,O&=8191,O+=v*(5*m)+_*(5*b)+T*(5*x)+E*(5*d)+y*(5*l),g+=O>>>13,O&=8191;let V=g+I*l+M*u+N*f+k*c+q*a;g=V>>>13,V&=8191,V+=v*(5*h)+_*(5*m)+T*(5*b)+E*(5*x)+y*(5*d),g+=V>>>13,V&=8191;let z=g+I*d+M*l+N*u+k*f+q*c;g=z>>>13,z&=8191,z+=v*a+_*(5*h)+T*(5*m)+E*(5*b)+y*(5*x),g+=z>>>13,z&=8191;let F=g+I*x+M*d+N*l+k*u+q*f;g=F>>>13,F&=8191,F+=v*c+_*a+T*(5*h)+E*(5*m)+y*(5*b),g+=F>>>13,F&=8191;let rt=g+I*b+M*x+N*d+k*l+q*u;g=rt>>>13,rt&=8191,rt+=v*f+_*c+T*a+E*(5*h)+y*(5*m),g+=rt>>>13,rt&=8191;let tt=g+I*m+M*b+N*x+k*d+q*l;g=tt>>>13,tt&=8191,tt+=v*u+_*f+T*c+E*a+y*(5*h),g+=tt>>>13,tt&=8191;let st=g+I*h+M*m+N*b+k*x+q*d;g=st>>>13,st&=8191,st+=v*l+_*u+T*f+E*c+y*a,g+=st>>>13,st&=8191,g=(g<<2)+g|0,g=g+L|0,L=g&8191,g=g>>>13,R+=g,s[0]=L,s[1]=R,s[2]=D,s[3]=O,s[4]=V,s[5]=z,s[6]=F,s[7]=rt,s[8]=tt,s[9]=st}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;ae(n)}update(t){Xs(this),t=zn(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(){ae(this.h,this.r,this.buffer,this.pad)}digestInto(t){Xs(this),Fc(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 Fh(r){let t=(n,o)=>r(o).update(zn(n)).digest(),e=r(new Uint8Array(32));return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=n=>r(n),t}var Xc=Fh(r=>new ri(r));function tu(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],d=t[2],x=t[3],b=t[4],m=t[5],h=t[6],w=t[7],S=o,p=e[0],A=e[1],U=e[2],P=i,B=a,C=c,I=f,M=u,N=l,k=d,q=x,v=b,_=m,T=h,E=w,y=S,g=p,L=A,R=U;for(let O=0;O<s;O+=2)P=P+M|0,y=K(y^P,16),v=v+y|0,M=K(M^v,12),P=P+M|0,y=K(y^P,8),v=v+y|0,M=K(M^v,7),B=B+N|0,g=K(g^B,16),_=_+g|0,N=K(N^_,12),B=B+N|0,g=K(g^B,8),_=_+g|0,N=K(N^_,7),C=C+k|0,L=K(L^C,16),T=T+L|0,k=K(k^T,12),C=C+k|0,L=K(L^C,8),T=T+L|0,k=K(k^T,7),I=I+q|0,R=K(R^I,16),E=E+R|0,q=K(q^E,12),I=I+q|0,R=K(R^I,8),E=E+R|0,q=K(q^E,7),P=P+N|0,R=K(R^P,16),T=T+R|0,N=K(N^T,12),P=P+N|0,R=K(R^P,8),T=T+R|0,N=K(N^T,7),B=B+k|0,y=K(y^B,16),E=E+y|0,k=K(k^E,12),B=B+k|0,y=K(y^B,8),E=E+y|0,k=K(k^E,7),C=C+q|0,g=K(g^C,16),v=v+g|0,q=K(q^v,12),C=C+q|0,g=K(g^C,8),v=v+g|0,q=K(q^v,7),I=I+M|0,L=K(L^I,16),_=_+L|0,M=K(M^_,12),I=I+M|0,L=K(L^I,8),_=_+L|0,M=K(M^_,7);let D=0;n[D++]=i+P|0,n[D++]=a+B|0,n[D++]=c+C|0,n[D++]=f+I|0,n[D++]=u+M|0,n[D++]=l+N|0,n[D++]=d+k|0,n[D++]=x+q|0,n[D++]=b+v|0,n[D++]=m+_|0,n[D++]=h+T|0,n[D++]=w+E|0,n[D++]=S+y|0,n[D++]=p+g|0,n[D++]=A+L|0,n[D++]=U+R|0}function Gh(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],d=t[4],x=t[5],b=t[6],m=t[7],h=e[0],w=e[1],S=e[2],p=e[3];for(let U=0;U<20;U+=2)o=o+c|0,h=K(h^o,16),d=d+h|0,c=K(c^d,12),o=o+c|0,h=K(h^o,8),d=d+h|0,c=K(c^d,7),s=s+f|0,w=K(w^s,16),x=x+w|0,f=K(f^x,12),s=s+f|0,w=K(w^s,8),x=x+w|0,f=K(f^x,7),i=i+u|0,S=K(S^i,16),b=b+S|0,u=K(u^b,12),i=i+u|0,S=K(S^i,8),b=b+S|0,u=K(u^b,7),a=a+l|0,p=K(p^a,16),m=m+p|0,l=K(l^m,12),a=a+l|0,p=K(p^a,8),m=m+p|0,l=K(l^m,7),o=o+f|0,p=K(p^o,16),b=b+p|0,f=K(f^b,12),o=o+f|0,p=K(p^o,8),b=b+p|0,f=K(f^b,7),s=s+u|0,h=K(h^s,16),m=m+h|0,u=K(u^m,12),s=s+u|0,h=K(h^s,8),m=m+h|0,u=K(u^m,7),i=i+l|0,w=K(w^i,16),d=d+w|0,l=K(l^d,12),i=i+l|0,w=K(w^i,8),d=d+w|0,l=K(l^d,7),a=a+c|0,S=K(S^a,16),x=x+S|0,c=K(c^x,12),a=a+c|0,S=K(S^a,8),x=x+S|0,c=K(c^x,7);let A=0;n[A++]=o,n[A++]=s,n[A++]=i,n[A++]=a,n[A++]=h,n[A++]=w,n[A++]=S,n[A++]=p}var Wh=ei(tu,{counterRight:!1,counterLength:4,allowShortKeys:!1}),jh=ei(tu,{counterRight:!1,counterLength:8,extendNonceFn:Gh,allowShortKeys:!1});var $h=new Uint8Array(16),Jc=(r,t)=>{r.update(t);let e=t.length%16;e&&r.update($h.subarray(e))},Zh=new Uint8Array(32);function Qc(r,t,e,n,o){let s=r(t,e,Zh),i=Xc.create(s);o&&Jc(i,o),Jc(i,n);let a=jc(n.length,o?o.length:0,!0);i.update(a);let c=i.digest();return ae(s,a),c}var eu=r=>(t,e,n)=>({encrypt(s,i){let a=s.length;i=Qs(a+16,i,!1),i.set(s);let c=i.subarray(0,-16);r(t,e,c,c,1);let f=Qc(r,t,e,c,n);return i.set(f,a),ae(f),i},decrypt(s,i){i=Qs(s.length-16,i,!1);let a=s.subarray(0,-16),c=s.subarray(-16),f=Qc(r,t,e,a,n);if(!Wc(c,f))throw new Error("invalid tag");return i.set(s.subarray(0,-16)),r(t,e,i,i,1),ae(f),i}}),ni=Js({blockSize:64,nonceLength:12,tagLength:16},eu(Wh)),ew=Js({blockSize:64,nonceLength:24,tagLength:16},eu(jh));function nu(r,t,e){return Sr(r),e===void 0&&(e=new Uint8Array(r.outputLen)),or(r,de(e),de(t))}var oi=Uint8Array.from([0]),ru=Uint8Array.of();function ou(r,t,e,n=32){Sr(r),Ye(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=ru);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++)oi[0]=u+1,c.update(u===0?ru:f).update(e).update(oi).digestInto(f),i.set(f,o*u),a._cloneInto(c);return a.destroy(),c.destroy(),Ot(f,oi),i.slice(0,n)}var si={hashSHA256(r){return Se(r.subarray())},getHKDF(r,t){let e=nu(Se,t,r),o=ou(Se,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=Pr.utils.randomPrivateKey();return{publicKey:Pr.getPublicKey(r),privateKey:r}},generateX25519KeyPairFromSeed(r){return{publicKey:Pr.getPublicKey(r),privateKey:r}},generateX25519SharedKey(r,t){return Pr.getSharedSecret(r.subarray(),t.subarray())},chaCha20Poly1305Encrypt(r,t,e,n){return ni(n,t,e).encrypt(r.subarray())},chaCha20Poly1305Decrypt(r,t,e,n,o){return ni(n,t,e).decrypt(r.subarray(),o)}};var su=si;function iu(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 cr=r=>{let t=pt(2);return t[0]=r>>8,t[1]=r,t};cr.bytes=2;var jr=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)};jr.bytes=2;function au(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 ii(r,t){!t.enabled||!ar||(r?(t(`LOCAL_STATIC_PUBLIC_KEY ${H(r.publicKey,"hex")}`),t(`LOCAL_STATIC_PRIVATE_KEY ${H(r.privateKey,"hex")}`)):t("Missing local static keys."))}function ai(r,t){!t.enabled||!ar||(r?(t(`LOCAL_PUBLIC_EPHEMERAL_KEY ${H(r.publicKey,"hex")}`),t(`LOCAL_PRIVATE_EPHEMERAL_KEY ${H(r.privateKey,"hex")}`)):t("Missing local ephemeral keys."))}function cu(r,t){!t.enabled||!ar||t(r?`REMOTE_STATIC_PUBLIC_KEY ${H(r.subarray(),"hex")}`:"Missing remote static public key.")}function ci(r,t){!t.enabled||!ar||t(r?`REMOTE_EPHEMERAL_PUBLIC_KEY ${H(r.subarray(),"hex")}`:"Missing remote ephemeral keys.")}function ui(r,t,e){!e.enabled||!ar||(e(`CIPHER_STATE_1 ${r.n.getUint64()} ${r.k&&H(r.k,"hex")}`),e(`CIPHER_STATE_2 ${t.n.getUint64()} ${t.k&&H(t.k,"hex")}`))}var ur=class r extends Error{code;constructor(t="Invalid crypto exchange"){super(t),this.code=r.code}static code="ERR_INVALID_CRYPTO_EXCHANGE"};var Yh=0,Xh=4294967295,Jh="Cipherstate has reached maximum n, a new handshake must be performed",Wn=class{n;bytes;view;constructor(t=Yh){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>Xh)throw new Error(Jh)}};var qe=dt(0),fr=class{k;n;crypto;constructor(t,e=void 0,n=0){this.crypto=t,this.k=e,this.n=new Wn(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}},fi=class{cs;ck;h;crypto;constructor(t,e){this.crypto=t;let n=Y(e,"utf-8");this.h=Qh(t,n),this.ck=this.h,this.cs=new fr(t)}mixKey(t){let[e,n]=this.crypto.hkdf(this.ck,t);this.ck=e,this.cs=new fr(this.crypto,n)}mixHash(t){this.h=this.crypto.hash(new G(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,qe);return[new fr(this.crypto,t),new fr(this.crypto,e)]}},li=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 fi(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()}},$r=class extends li{writeMessageA(t){return new G(this.writeE(),this.ss.encryptAndHash(t))}writeMessageB(t){let e=this.writeE();this.writeEE();let n=this.writeS();return this.writeES(),new G(e,n,this.ss.encryptAndHash(t))}writeMessageC(t){let e=this.writeS();return this.writeSE(),new G(e,this.ss.encryptAndHash(t))}readMessageA(t){try{return this.readE(t),this.ss.decryptAndHash(t.sublist(32))}catch(e){throw new ur(`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 ur(`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 ur(`handshake stage 2 validation fail: ${e.message}`)}}};function Qh(r,t){if(t.length<=32){let e=dt(32);return e.set(t),e}else return r.hash(t)}var jn;(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 Dr('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 Dr('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)})(jn||(jn={}));var Zr;(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),jn.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=jn.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)})(Zr||(Zr={}));async function hi(r,t,e){let n=await r.sign(uu(t));return Zr.encode({identityKey:he(r.publicKey),identitySig:n,extensions:e})}async function di(r,t,e){try{let n=Zr.decode(r),o=Or(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=uu(t);if(!await o.verify(s,n.identitySig))throw new Error("Invalid payload signature");return n}catch(n){throw new tn(n.message)}}function uu(r){let t=Y("noise-libp2p-static-key:");return r instanceof Uint8Array?St([t,r],t.length+r.length):(r.prepend(t),r)}async function fu(r,t){let{log:e,connection:n,crypto:o,privateKey:s,prologue:i,s:a,remoteIdentityKey:c,extensions:f}=r,u=await hi(s,a.publicKey,f),l=new $r({crypto:o,protocolName:"Noise_XX_25519_ChaChaPoly_SHA256",initiator:!0,prologue:i,s:a});ii(l.s,e),e.trace("Stage 0 - Initiator starting to send first message."),await n.write(l.writeMessageA(qe),t),e.trace("Stage 0 - Initiator finished sending first message."),ai(l.e,e),e.trace("Stage 1 - Initiator waiting to receive first message from responder...");let d=l.readMessageB(await n.read(t));e.trace("Stage 1 - Initiator received the message."),ci(l.re,e),cu(l.rs,e),e.trace("Initiator going to check remote's signature...");let x=await di(d,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[b,m]=l.ss.split();return ui(b,m,e),{payload:x,encrypt:h=>b.encryptWithAd(qe,h),decrypt:(h,w)=>m.decryptWithAd(qe,h,w)}}async function lu(r,t){let{log:e,connection:n,crypto:o,privateKey:s,prologue:i,s:a,remoteIdentityKey:c,extensions:f}=r,u=await hi(s,a.publicKey,f),l=new $r({crypto:o,protocolName:"Noise_XX_25519_ChaChaPoly_SHA256",initiator:!1,prologue:i,s:a});ii(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."),ci(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."),ai(l.e,e),e.trace("Stage 2 - Responder waiting for third handshake message...");let d=l.readMessageC(await n.read(t));e.trace("Stage 2 - Responder received the message, finished handshake.");let x=await di(d,l.rs,c),[b,m]=l.ss.split();return ui(b,m,e),{payload:x,encrypt:h=>m.encryptWithAd(qe,h),decrypt:(h,w)=>b.decryptWithAd(qe,h,w)}}var du=16;function pu(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 G(cr(i.byteLength),i)}}}function mu(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-du<o)throw new Error("Invalid chunk");let i=n.sublist(o,s),a=n.subarray(o,s-du);try{let c=r.decrypt(i,a);t?.decryptedPackets.increment(),yield c}catch(c){throw t?.decryptErrors.increment(),c}}}}var $n=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??su;this.crypto=iu(c),this.extensions={webtransportCerthashes:[],...o},this.metrics=a?au(a):void 0,n?this.staticKey=c.generateX25519KeyPairFromSeed(n):this.staticKey=c.generateX25519KeyPair(),this.prologue=i??dt(0)}[Symbol.toStringTag]="@chainsafe/libp2p-noise";[an]=["@libp2p/connection-encryption","@chainsafe/libp2p-noise"];async secureOutbound(t,e){let n=js(t,{lengthEncoder:cr,lengthDecoder:jr,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=Or(o.payload.identityKey);return{conn:t,remoteExtensions:o.payload.extensions,remotePeer:Fs(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 Fe("Early muxer negotiation was requested but the initiator and responder had no common muxers")}async secureInbound(t,e){let n=js(t,{lengthEncoder:cr,lengthDecoder:jr,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=Or(o.payload.identityKey);return{conn:t,remoteExtensions:o.payload.extensions,remotePeer:Fs(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 fu({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 lu({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]=Nc(),s=t.unwrap();return await Oc(n,pu(e,this.metrics),s,i=>Wr(i,{lengthDecoder:jr}),mu(e,this.metrics),n),o}};function yu(r={}){return t=>new $n(t,r)}var Zn=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 d=Number.parseInt(l,t);if(!Number.isNaN(d))return d});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 gu=45,td=15,lr=new Zn;function pi(r){if(!(r.length>td))return lr.new(r).parseWith(()=>lr.readIPv4Addr())}function mi(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>gu))return lr.new(r).parseWith(()=>lr.readIPv6Addr())}function Yn(r,t=!1){if(r.includes("%")&&(r=r.split("%")[0]),r.length>gu)return;let e=lr.new(r).parseWith(()=>lr.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 Xn(r){return!!pi(r)}function Jn(r){return!!mi(r)}function Qn(r){return!!Yn(r)}var ed=r=>r.toString().split("/").slice(1),hr=r=>({match:t=>t.length<1?!1:r(t[0])?t.slice(1):!1,pattern:"fn"}),W=r=>({match:t=>hr(e=>e===r).match(t),pattern:r}),Ve=()=>({match:r=>hr(t=>typeof t=="string").match(r),pattern:"{string}"}),Xr=()=>({match:r=>hr(t=>!isNaN(parseInt(t))).match(r),pattern:"{number}"}),Q=()=>({match:r=>{if(r.length<2||r[0]!=="p2p"&&r[0]!=="ipfs")return!1;if(r[1].startsWith("Q")||r[1].startsWith("1"))try{et.decode(`z${r[1]}`)}catch{return!1}else return!1;return r.slice(2)},pattern:"/p2p/{peerid}"}),Jr=()=>({match:r=>{if(r.length<2||r[0]!=="certhash")return!1;try{To.decode(r[1])}catch{return!1}return r.slice(2)},pattern:"/certhash/{certhash}"}),Z=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=ed(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 rd=Q(),Kb=it(rd),eo=j(W("dns4"),Ve()),ro=j(W("dns6"),Ve()),no=j(W("dnsaddr"),Ve()),gi=j(W("dns"),Ve()),Nb=it(eo,Z(Q())),Mb=it(ro,Z(Q())),Ob=it(no,Z(Q())),Hb=it(Lt(gi,no,eo,ro),Z(Q())),xu=j(W("ip4"),hr(Xn)),wu=j(W("ip6"),hr(Jn)),xi=Lt(xu,wu),ce=Lt(xi,gi,eo,ro,no),qb=it(Lt(xi,j(Lt(gi,no,eo,ro),Z(Q())))),Vb=it(xu),zb=it(wu),Fb=it(xi),wi=j(ce,W("tcp"),Xr()),Qr=j(ce,W("udp"),Xr()),Gb=it(j(wi,Z(Q()))),Wb=it(Qr),bi=j(Qr,W("quic"),Z(Q())),oo=j(Qr,W("quic-v1"),Z(Q())),nd=Lt(bi,oo),jb=it(bi),$b=it(oo),yi=Lt(ce,wi,Qr,bi,oo),bu=Lt(j(yi,W("ws"),Z(Q()))),Zb=it(bu),Eu=Lt(j(yi,W("wss"),Z(Q())),j(yi,W("tls"),Z(j(W("sni"),Ve())),W("ws"),Z(Q()))),Yb=it(Eu),Su=j(Qr,W("webrtc-direct"),Z(Jr()),Z(Jr()),Z(Q())),Xb=it(Su),Au=j(oo,W("webtransport"),Z(Jr()),Z(Jr()),Z(Q())),so=it(Au),to=Lt(bu,Eu,j(wi,Z(Q())),j(nd,Z(Q())),j(ce,Z(Q())),Su,Au,Q()),Jb=it(to),od=j(to,W("p2p-circuit"),Q()),Qb=it(od),sd=Lt(j(to,W("p2p-circuit"),W("webrtc"),Z(Q())),j(to,W("webrtc"),Z(Q())),j(W("webrtc"),Z(Q()))),t1=it(sd),id=Lt(j(ce,W("tcp"),Xr(),W("http"),Z(Q())),j(ce,W("http"),Z(Q()))),e1=it(id),ad=Lt(j(ce,W("tcp"),Lt(j(W("443"),W("http")),j(Xr(),W("https"))),Z(Q())),j(ce,W("tls"),W("http"),Z(Q())),j(ce,W("https"),Z(Q()))),r1=it(ad),cd=Lt(j(W("memory"),Ve(),Z(Q()))),n1=it(cd);var ze=class extends Event{type;detail;constructor(t,e){super(t),this.type=t,this.detail=e}};function Ei(r){throw new Error("Not implemented")}function vu(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 Iu(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function Bu(r,t){let e=vu(r).return?.();Iu(e)&&e.catch(n=>{t.error("could not cause iterator to return",n)})}var ud=5e3;function Si(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}var io=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=Bt(),this.closed=Bt(),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??ud,this.onEnd=t.onEnd,this.onCloseRead=t?.onCloseRead,this.onCloseWrite=t?.onCloseWrite,this.onReset=t?.onReset,this.onAbort=t?.onAbort,this.source=this.streamSource=Hn({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 rn(`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);Si(o)&&await o}let n=()=>{Bu(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 G(o):o;let s=this.sendData(o,e);Si(s)&&(this.sendingData=Bt(),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();Si(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 en("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 Ai=class extends io{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 G(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 vi(r,t,e,n,o,s){let i=s.forComponent(`libp2p:webtransport:stream:${e}:${t}`),a=new Ai({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 ao(){return{source:{[Symbol.asyncIterator](){return{async next(){return new Promise(()=>{})}}}},sink:async r=>new Promise(()=>{})}}function _u(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 vi(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 vi(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)}},...ao()};return c}}}function Lu(r,t){return t.filter(n=>!!r.find(o=>ht(n,o))).length===t.length}var K1=parseInt("0xFFFF",16),N1=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);var Pu=Xn,pd=Jn,Ii=function(r){let t=0;if(r=r.toString().trim(),Pu(r)){let e=new Uint8Array(t+4);return r.split(/\./g).forEach(n=>{e[t++]=parseInt(n,10)&255}),e}if(pd(r)){let e=r.split(":",8),n;for(n=0;n<e.length;n++){let s=Pu(e[n]),i;s&&(i=Ii(e[n]),e[n]=H(i.slice(0,2),"base16")),i!=null&&++n<8&&e.splice(n,0,H(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")},Uu=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 dr={},Bi={},yd=[[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"]];yd.forEach(r=>{let t=gd(...r);Bi[t.code]=t,dr[t.name]=t});function gd(r,t,e,n,o){return{code:r,size:t,name:e,resolvable:!!n,path:!!o}}function J(r){if(typeof r=="number"){if(Bi[r]!=null)return Bi[r];throw new Error(`no protocol with code: ${r}`)}else if(typeof r=="string"){if(dr[r]!=null)return dr[r];throw new Error(`no protocol with name: ${r}`)}throw new Error(`invalid protocol id type: ${typeof r}`)}var x2=J("ip4"),w2=J("ip6"),b2=J("ipcidr");function Ci(r,t){switch(J(r).code){case 4:case 41:return wd(t);case 42:return Ti(t);case 43:return H(t,"base10");case 6:case 273:case 33:case 132:return Du(t).toString();case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Ti(t);case 421:return Ad(t);case 444:return Ru(t);case 445:return Ru(t);case 466:return Sd(t);case 481:return globalThis.encodeURIComponent(Ti(t));default:return H(t,"base16")}}function Pi(r,t){switch(J(r).code){case 4:return ku(t);case 41:return ku(t);case 42:return Li(t);case 43:return Y(t,"base10");case 6:case 273:case 33:case 132:return Ui(parseInt(t,10));case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Li(t);case 421:return bd(t);case 444:return vd(t);case 445:return Id(t);case 466:return Ed(t);case 481:return Li(globalThis.decodeURIComponent(t));default:return Y(t,"base16")}}var _i=Object.values(Ie).map(r=>r.decoder),xd=function(){let r=_i[0].or(_i[1]);return _i.slice(2).forEach(t=>r=r.or(t)),r}();function ku(r){if(!Qn(r))throw new Error("invalid ip address");return Ii(r)}function wd(r){let t=Uu(r,0,r.length);if(t==null)throw new Error("ipBuff is required");if(!Qn(t))throw new Error("invalid ip address");return t}function Ui(r){let t=new ArrayBuffer(2);return new DataView(t).setUint16(0,r),new Uint8Array(t)}function Du(r){return new DataView(r.buffer).getUint16(r.byteOffset)}function Li(r){let t=Y(r),e=Uint8Array.from(Yt(t.length));return St([e,t],e.length+t.length)}function Ti(r){let t=zt(r);if(r=r.slice(lt(t)),r.length!==t)throw new Error("inconsistent lengths");return H(r)}function bd(r){let t;r[0]==="Q"||r[0]==="1"?t=fe(et.decode(`z${r}`)).bytes:t=ut.parse(r).multihash.bytes;let e=Uint8Array.from(Yt(t.length));return St([e,t],e.length+t.length)}function Ed(r){let t=xd.decode(r),e=Uint8Array.from(Yt(t.length));return St([e,t],e.length+t.length)}function Sd(r){let t=zt(r),e=r.slice(lt(t));if(e.length!==t)throw new Error("inconsistent lengths");return"u"+H(e,"base64url")}function Ad(r){let t=zt(r),e=r.slice(lt(t));if(e.length!==t)throw new Error("inconsistent lengths");return H(e,"base58btc")}function vd(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=Ui(n);return St([e,o],e.length+o.length)}function Id(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=Ui(n);return St([e,o],e.length+o.length)}function Ru(r){let t=r.slice(0,r.length-2),e=r.slice(r.length-2),n=H(t,"base32"),o=Du(e);return`${n}:${o}`}function Ku(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=J(i);if(a.size===0){t.push([a.code]),e.push([a.code]);continue}if(s++,s>=o.length)throw new co("invalid address: "+r);if(a.path===!0){n=ki(o.slice(s).join("/")),t.push([a.code,Pi(a.code,n)]),e.push([a.code,n]);break}let c=Pi(a.code,o[s]);t.push([a.code,c]),e.push([a.code,Ci(a.code,c)])}return{string:Nu(e),bytes:uo(t),tuples:t,stringTuples:e,path:n}}function Ri(r){let t=[],e=[],n=null,o=0;for(;o<r.length;){let s=zt(r,o),i=lt(s),a=J(s),c=Bd(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 co("Invalid address Uint8Array: "+H(r,"base16"));t.push([s,f]);let u=Ci(s,f);if(e.push([s,u]),a.path===!0){n=u;break}}return{bytes:Uint8Array.from(r),string:Nu(e),tuples:t,stringTuples:e,path:n}}function Nu(r){let t=[];return r.map(e=>{let n=J(e[0]);return t.push(n.name),e.length>1&&e[1]!=null&&t.push(e[1]),null}),ki(t.join("/"))}function uo(r){return St(r.map(t=>{let e=J(t[0]),n=Uint8Array.from(Yt(e.code));return t.length>1&&t[1]!=null&&(n=St([n,t[1]])),n}))}function Bd(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 co=class extends Error{static name="ParseError";name="ParseError";constructor(t){super(`Error parsing address: ${t}`)}};var _d=Symbol.for("nodejs.util.inspect.custom"),Ki=Symbol.for("@multiformats/js-multiaddr/multiaddr"),Ld=[J("dns").code,J("dns4").code,J("dns6").code,J("dnsaddr").code],Di=class extends Error{constructor(t="No available resolver"){super(t),this.name="NoAvailableResolverError"}},fo=class r{bytes;#e;#t;#r;#n;[Ki]=!0;constructor(t){t==null&&(t="");let e;if(t instanceof Uint8Array)e=Ri(t);else if(typeof t=="string"){if(t.length>0&&t.charAt(0)!=="/")throw new Error(`multiaddr "${t}" must start with a "/"`);e=Ku(t)}else if(Ou(t))e=Ri(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=J("tcp"),a=J("udp"),c=J("ip4"),f=J("ip6"),u=J("dns6"),l=J("ip6zone");for(let[x,b]of this.stringTuples())x===l.code&&(s=`%${b??""}`),Ld.includes(x)&&(e=i.name==="tcp"?"tcp":"udp",o=443,n=`${b??""}${s}`,t=x===u.code?6:4),(x===i.code||x===a.code)&&(e=J(x).name==="tcp"?"tcp":"udp",o=parseInt(b??"")),(x===c.code||x===f.code)&&(e=J(x).name==="tcp"?"tcp":"udp",n=`${b??""}${s}`,t=x===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({},J(t)))}protoCodes(){return this.#t.map(([t])=>t)}protoNames(){return this.#t.map(([t])=>J(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(uo(e.slice(0,n)));return this}getPeerId(){try{let t=[];this.stringTuples().forEach(([n,o])=>{n===dr.p2p.code&&t.push([n,o]),n===dr["p2p-circuit"].code&&(t=[])});let e=t.pop();if(e?.[1]!=null){let n=e[1];return n[0]==="Q"||n[0]==="1"?H(et.decode(`z${n}`),"base58btc"):H(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=Mu.get(e.name);if(n==null)throw new Di(`no available resolver for ${e.name}`);return(await n(this,t)).map(s=>Ni(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)}[_d](){return`Multiaddr(${this.#e})`}};var Mu=new Map;function Ou(r){return!!r?.[Ki]}function Ni(r){return new fo(r)}var Td=Object.values(Ie).map(r=>r.decoder).reduce((r,t)=>r.or(t));function Cd(r){return Gt.decode(Td.decode(r))}function Mi(r){if(!so.matches(r))throw new nn("Invalid multiaddr, was not a WebTransport address");let t=r.stringTuples(),e=t.filter(([i,a])=>i===J("certhash").code).map(([i,a])=>Cd(a??"")),n=t.filter(([i,a])=>i===J("p2p").code).map(([i,a])=>Uc(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 Hu=globalThis.WebTransport;var Oi=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";[Vi]=!0;[an]=["@libp2p/transport"];async dial(t,e){e.signal.throwIfAborted(),this.log("dialing %s",t),e=e??{};let{url:n,certhashes:o,remotePeer:s}=Mi(t),i,a,c=()=>{},f=!1,u=!1,l=!1;try{this.metrics?.dialerEvents.increment({pending:!0});let d=new Hu(`${n}/.well-known/libp2p-webtransport?type=noise`,{serverCertificateHashes:o.map(x=>({algorithm:"sha-256",value:x.digest}))});if(c=x=>{if(!f)try{this.metrics?.dialerEvents.increment({[x]:!0}),d.close()}catch(b){this.log.error("error closing wt session",b)}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 ze("webtransport:wait-for-session")),await Promise.race([d.closed,d.ready]),this.log("session became ready"),u=!0,this.metrics?.dialerEvents.increment({ready:!0}),d.closed.catch(x=>{this.log.error("error on remote wt session close",x)}).finally(()=>{c("remote_close")}),l=await xt(this.authenticateWebTransport({wt:d,remotePeer:s,certhashes:o,...e}),e.signal),!l)throw new Fe("Failed to authenticate webtransport");return this.metrics?.dialerEvents.increment({open:!0}),a={close:async()=>{this.log("closing webtransport"),c("close")},abort:x=>{this.log("aborting webtransport due to passed err",x),c("abort")},remoteAddr:t,timeline:{open:Date.now()},log:this.components.logger.forComponent("libp2p:webtransport:maconn"),...ao()},await e.upgrader.upgradeOutbound(a,{...e,skipEncryption:!0,muxerFactory:_u(d,d.incomingBidirectionalStreams.getReader(),this.components.logger,this.config),skipProtection:!0})}catch(d){throw this.log.error("caught wt session err",d),c(l?"upgrade_error":u?"noise_error":"ready_error"),d}finally{i!=null&&e.signal?.removeEventListener("abort",i)}}async authenticateWebTransport({wt:t,remotePeer:e,certhashes:n,onProgress:o,signal:s}){s?.throwIfAborted(),o?.(new ze("webtransport:open-authentication-stream"));let i=await t.createBidirectionalStream(),a=i.writable.getWriter(),c=i.readable.getReader(),f={source:async function*(){for(;;){let d=await c.read();if(d.value!=null&&(yield d.value),d.done)break}}(),sink:async d=>{for await(let x of d){await xt(a.ready,s);let b=x instanceof Uint8Array?x:x.subarray();a.write(b).catch(m=>{this.log.error("could not write chunk during authentication of WebTransport stream",m)})}}},u=yu()(this.components);o?.(new ze("webtransport:secure-outbound-connection"));let{remoteExtensions:l}=await u.secureOutbound(f,{signal:s,remotePeer:e,skipStreamMuxerNegotiation:!0});if(o?.(new ze("webtransport:close-authentication-stream")),a.close().catch(d=>{this.log.error(`Failed to close authentication stream writer: ${d.message}`)}),c.cancel().catch(d=>{this.log.error(`Failed to close authentication stream reader: ${d.message}`)}),!Lu(l?.webtransportCerthashes??[],n.map(d=>d.bytes)))throw new at("Our certhashes are not a subset of the remote's reported certhashes");return!0}createListener(t){return Ei(this.components,{...t,certificates:this.config.certificates,maxInboundStreams:this.config.maxInboundStreams})}listenFilter(){return[]}dialFilter(t){return globalThis.WebTransport==null?[]:t.filter(e=>{if(!so.exactMatch(e))return!1;let{url:n,certhashes:o}=Mi(e);return n!=null&&o.length>0})}};function Pd(r={}){return t=>new Oi(t,r)}return Zu(Ud);})();
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&gt&&(D=D.add(H)),T&gt&&(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)===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&gt),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);})();
3
3
  //! TODO unclear how to add backpressure here?
4
4
  /*! Bundled license information:
5
5