@libp2p/webtransport 5.0.39 → 5.0.40-9b33d202e
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 +2 -17
- package/dist/index.min.js.map +7 -0
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/index.js +2 -1
- package/dist/src/index.js.map +1 -1
- package/package.json +8 -8
- package/src/index.ts +2 -1
- package/dist/typedoc-urls.json +0 -14
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 ro=Object.defineProperty;var Lu=Object.getOwnPropertyDescriptor;var Tu=Object.getOwnPropertyNames;var Cu=Object.prototype.hasOwnProperty;var Ct=(r,t)=>{for(var e in t)ro(r,e,{get:t[e],enumerable:!0})},Pu=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of Tu(t))!Cu.call(r,o)&&o!==e&&ro(r,o,{get:()=>t[o],enumerable:!(n=Lu(t,o))||n.enumerable});return r};var Uu=r=>Pu(ro({},"__esModule",{value:!0}),r);var Rd={};Ct(Rd,{webTransport:()=>kd});var no=Symbol.for("@libp2p/peer-id");var Ni=Symbol.for("@libp2p/transport");var Ki;(function(r){r[r.FATAL_ALL=0]="FATAL_ALL",r[r.NO_FATAL=1]="NO_FATAL"})(Ki||(Ki={}));var Wr=class extends Error{static name="UnexpectedPeerError";constructor(t="Unexpected Peer"){super(t),this.name="UnexpectedPeerError"}},Oe=class extends Error{static name="InvalidCryptoExchangeError";constructor(t="Invalid crypto exchange"){super(t),this.name="InvalidCryptoExchangeError"}},ut=class extends Error{static name="InvalidParametersError";constructor(t="Invalid parameters"){super(t),this.name="InvalidParametersError"}},He=class extends Error{static name="InvalidPublicKeyError";constructor(t="Invalid public key"){super(t),this.name="InvalidPublicKeyError"}};var jr=class extends Error{static name="StreamResetError";constructor(t="The stream has been reset"){super(t),this.name="StreamResetError"}},$r=class extends Error{static name="StreamStateError";constructor(t="The stream is in an invalid state"){super(t),this.name="StreamStateError"}};var Zr=class extends Error{static name="InvalidMultiaddrError";constructor(t="Invalid multiaddr"){super(t),this.name="InvalidMultiaddrError"}},Yr=class extends Error{static name="InvalidCIDError";constructor(t="Invalid CID"){super(t),this.name="InvalidCIDError"}},Xr=class extends Error{static name="InvalidMultihashError";constructor(t="Invalid Multihash"){super(t),this.name="InvalidMultihashError"}};var Ee=class extends Error{static name="UnsupportedKeyTypeError";constructor(t="Unsupported key type"){super(t),this.name="UnsupportedKeyTypeError"}};var Jr=Symbol.for("@libp2p/service-capabilities"),Od=Symbol.for("@libp2p/service-dependencies");var co={};Ct(co,{base58btc:()=>rt,base58flickr:()=>Mu});var cp=new Uint8Array(0);function Mi(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 Yt(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 Oi(r){return new TextEncoder().encode(r)}function Hi(r){return new TextDecoder().decode(r)}function ku(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),u=Math.log(a)/Math.log(256),f=Math.log(256)/Math.log(a);function l(x){if(x instanceof Uint8Array||(ArrayBuffer.isView(x)?x=new Uint8Array(x.buffer,x.byteOffset,x.byteLength):Array.isArray(x)&&(x=Uint8Array.from(x))),!(x instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(x.length===0)return"";for(var m=0,h=0,b=0,E=x.length;b!==E&&x[b]===0;)b++,m++;for(var p=(E-b)*f+1>>>0,v=new Uint8Array(p);b!==E;){for(var k=x[b],P=0,L=p-1;(k!==0||P<h)&&L!==-1;L--,P++)k+=256*v[L]>>>0,v[L]=k%a>>>0,k=k/a>>>0;if(k!==0)throw new Error("Non-zero carry");h=P,b++}for(var C=p-h;C!==p&&v[C]===0;)C++;for(var I=c.repeat(m);C<p;++C)I+=r.charAt(v[C]);return I}function d(x){if(typeof x!="string")throw new TypeError("Expected String");if(x.length===0)return new Uint8Array;var m=0;if(x[m]!==" "){for(var h=0,b=0;x[m]===c;)h++,m++;for(var E=(x.length-m)*u+1>>>0,p=new Uint8Array(E);x[m];){var v=e[x.charCodeAt(m)];if(v===255)return;for(var k=0,P=E-1;(v!==0||k<b)&&P!==-1;P--,k++)v+=a*p[P]>>>0,p[P]=v%256>>>0,v=v/256>>>0;if(v!==0)throw new Error("Non-zero carry");b=k,m++}if(x[m]!==" "){for(var L=E-b;L!==E&&p[L]===0;)L++;for(var C=new Uint8Array(h+(E-L)),I=h;L!==E;)C[I++]=p[L++];return C}}}function w(x){var m=d(x);if(m)return m;throw new Error(`Non-${t} character`)}return{encode:l,decodeUnsafe:d,decode:w}}var Ru=ku,Du=Ru,Vi=Du;var oo=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")}},so=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 Fi(this,t)}},io=class{decoders;constructor(t){this.decoders=t}or(t){return Fi(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 Fi(r,t){return new io({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var ao=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 oo(t,e,n),this.decoder=new so(t,e,o)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function qe({name:r,prefix:t,encode:e,decode:n}){return new ao(r,t,e,n)}function ie({name:r,prefix:t,alphabet:e}){let{encode:n,decode:o}=Vi(e,r);return qe({prefix:t,name:r,encode:n,decode:s=>Yt(o(s))})}function Ku(r,t,e,n){let o={};for(let f=0;f<t.length;++f)o[t[f]]=f;let s=r.length;for(;r[s-1]==="=";)--s;let i=new Uint8Array(s*e/8|0),a=0,c=0,u=0;for(let f=0;f<s;++f){let l=o[r[f]];if(l===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<e|l,a+=e,a>=8&&(a-=8,i[u++]=255&c>>a)}if(a>=e||(255&c<<8-a)!==0)throw new SyntaxError("Unexpected end of data");return i}function Nu(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 ft({name:r,prefix:t,bitsPerChar:e,alphabet:n}){return qe({prefix:t,name:r,encode(o){return Nu(o,n,e)},decode(o){return Ku(o,n,e,r)}})}var rt=ie({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),Mu=ie({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var uo={};Ct(uo,{base32:()=>Xt,base32hex:()=>Vu,base32hexpad:()=>zu,base32hexpadupper:()=>Gu,base32hexupper:()=>Fu,base32pad:()=>Hu,base32padupper:()=>qu,base32upper:()=>Ou,base32z:()=>Wu});var Xt=ft({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),Ou=ft({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Hu=ft({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),qu=ft({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),Vu=ft({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),Fu=ft({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),zu=ft({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),Gu=ft({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),Wu=ft({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var fo={};Ct(fo,{base36:()=>fr,base36upper:()=>ju});var fr=ie({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),ju=ie({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var zt={};Ct(zt,{Digest:()=>Se,create:()=>Kt,decode:()=>ae,equals:()=>ho,hasCode:()=>df});var $u=Wi,zi=128,Zu=127,Yu=~Zu,Xu=Math.pow(2,31);function Wi(r,t,e){t=t||[],e=e||0;for(var n=e;r>=Xu;)t[e++]=r&255|zi,r/=128;for(;r&Yu;)t[e++]=r&255|zi,r>>>=7;return t[e]=r|0,Wi.bytes=e-n+1,t}var Ju=lo,Qu=128,Gi=127;function lo(r,n){var e=0,n=n||0,o=0,s=n,i,a=r.length;do{if(s>=a)throw lo.bytes=0,new RangeError("Could not decode varint");i=r[s++],e+=o<28?(i&Gi)<<o:(i&Gi)*Math.pow(2,o),o+=7}while(i>=Qu);return lo.bytes=s-n,e}var tf=Math.pow(2,7),ef=Math.pow(2,14),rf=Math.pow(2,21),nf=Math.pow(2,28),of=Math.pow(2,35),sf=Math.pow(2,42),af=Math.pow(2,49),cf=Math.pow(2,56),uf=Math.pow(2,63),ff=function(r){return r<tf?1:r<ef?2:r<rf?3:r<nf?4:r<of?5:r<sf?6:r<af?7:r<cf?8:r<uf?9:10},lf={encode:$u,decode:Ju,encodingLength:ff},hf=lf,lr=hf;function hr(r,t=0){return[lr.decode(r,t),lr.decode.bytes]}function Ve(r,t,e=0){return lr.encode(r,t,e),t}function Fe(r){return lr.encodingLength(r)}function Kt(r,t){let e=t.byteLength,n=Fe(r),o=n+Fe(e),s=new Uint8Array(o+e);return Ve(r,s,0),Ve(e,s,n),s.set(t,o),new Se(r,e,t,s)}function ae(r){let t=Yt(r),[e,n]=hr(t),[o,s]=hr(t.subarray(n)),i=t.subarray(n+s);if(i.byteLength!==o)throw new Error("Incorrect length");return new Se(e,o,i,t)}function ho(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&Mi(r.bytes,e.bytes)}}var Se=class{code;size;digest;bytes;constructor(t,e,n,o){this.code=t,this.size=e,this.digest=n,this.bytes=o}};function df(r,t){return r.code===t}function ji(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return mf(e,po(r),t??rt.encoder);default:return yf(e,po(r),t??Xt.encoder)}}var $i=new WeakMap;function po(r){let t=$i.get(r);if(t==null){let e=new Map;return $i.set(r,e),e}return t}var lt=class r{code;version;multihash;bytes;"/";constructor(t,e,n,o){this.code=e,this.version=t,this.multihash=n,this.bytes=o,this["/"]=o}get asCID(){return this}get byteOffset(){return this.bytes.byteOffset}get byteLength(){return this.bytes.byteLength}toV0(){switch(this.version){case 0:return this;case 1:{let{code:t,multihash:e}=this;if(t!==dr)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==gf)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&&ho(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??Zi(n,o,s.bytes))}else if(e[wf]===!0){let{version:n,multihash:o,code:s}=e,i=ae(o);return r.create(n,s,i)}else return null}static create(t,e,n){if(typeof e!="number")throw new Error("String codecs are no longer supported");if(!(n.bytes instanceof Uint8Array))throw new Error("Invalid digest");switch(t){case 0:{if(e!==dr)throw new Error(`Version 0 CID must use dag-pb (code: ${dr}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let o=Zi(t,e,n.bytes);return new r(t,e,n,o)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,dr,t)}static createV1(t,e){return r.create(1,t,e)}static decode(t){let[e,n]=r.decodeFirst(t);if(n.length!==0)throw new Error("Incorrect length");return e}static decodeFirst(t){let e=r.inspectBytes(t),n=e.size-e.multihashSize,o=Yt(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 Se(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]=hr(t.subarray(e));return e+=d,l},o=n(),s=dr;if(o===18?(o=0,e=0):s=n(),o!==0&&o!==1)throw new RangeError(`Invalid CID version ${o}`);let i=e,a=n(),c=n(),u=e+c,f=u-i;return{version:o,codec:s,multihashCode:a,digestSize:c,multihashSize:f,size:u}}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 po(s).set(n,t),s}};function pf(r,t){switch(r[0]){case"Q":{let e=t??rt;return[rt.prefix,e.decode(`${rt.prefix}${r}`)]}case rt.prefix:{let e=t??rt;return[rt.prefix,e.decode(r)]}case Xt.prefix:{let e=t??Xt;return[Xt.prefix,e.decode(r)]}case fr.prefix:{let e=t??fr;return[fr.prefix,e.decode(r)]}default:{if(t==null)throw Error("To parse non base32, base36 or base58btc encoded CID multibase decoder must be provided");return[r[0],t.decode(r)]}}}function mf(r,t,e){let{prefix:n}=e;if(n!==rt.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 yf(r,t,e){let{prefix:n}=e,o=t.get(n);if(o==null){let s=e.encode(r);return t.set(n,s),s}else return o}var dr=112,gf=18;function Zi(r,t,e){let n=Fe(r),o=n+Fe(t),s=new Uint8Array(o+e.byteLength);return Ve(r,s,0),Ve(t,s,n),s.set(e,o),s}var wf=Symbol.for("@ipld/js-cid/CID");var mo={};Ct(mo,{identity:()=>Mt});var Yi=0,xf="identity",Xi=Yt;function bf(r){return Kt(Yi,Xi(r))}var Mt={code:Yi,name:xf,encode:Xi,digest:bf};function pt(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function mt(r=0){return new Uint8Array(r)}function yt(r=0){return new Uint8Array(r)}function At(r,t){t==null&&(t=r.reduce((o,s)=>o+s.length,0));let e=yt(t),n=0;for(let o of r)e.set(o,n),n+=o.length;return e}var Qi=Symbol.for("@achingbrain/uint8arraylist");function Ji(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 tn(r){return!!r?.[Qi]}var W=class r{bufs;length;[Qi]=!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(tn(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(tn(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=Ji(this.bufs,t);return e.buf[e.index]}set(t,e){let n=Ji(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(tn(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 u=t>=a&&t<c,f=e>a&&e<=c;if(u&&f){if(t===a&&e===c){n.push(i);break}let l=t-a;n.push(i.subarray(l,l+(e-t)));break}if(u){if(t===0){n.push(i);continue}n.push(i.subarray(t-a));continue}if(f){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(!tn(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,u=n.byteLength-1,f;for(let l=e;l<=c;l+=f){f=0;for(let d=u;d>=0;d--){let w=this.get(l+d);if(n[d]!==w){f=Math.max(1,d-a[w]);break}}if(f===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=yt(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setInt8(0,e),this.write(n,t)}getInt16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt16(0,e)}setInt16(t,e,n){let o=mt(2);new DataView(o.buffer,o.byteOffset,o.byteLength).setInt16(0,e,n),this.write(o,t)}getInt32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt32(0,e)}setInt32(t,e,n){let o=mt(4);new DataView(o.buffer,o.byteOffset,o.byteLength).setInt32(0,e,n),this.write(o,t)}getBigInt64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigInt64(0,e)}setBigInt64(t,e,n){let o=mt(8);new DataView(o.buffer,o.byteOffset,o.byteLength).setBigInt64(0,e,n),this.write(o,t)}getUint8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getUint8(0)}setUint8(t,e){let n=yt(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setUint8(0,e),this.write(n,t)}getUint16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint16(0,e)}setUint16(t,e,n){let o=mt(2);new DataView(o.buffer,o.byteOffset,o.byteLength).setUint16(0,e,n),this.write(o,t)}getUint32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint32(0,e)}setUint32(t,e,n){let o=mt(4);new DataView(o.buffer,o.byteOffset,o.byteLength).setUint32(0,e,n),this.write(o,t)}getBigUint64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigUint64(0,e)}setBigUint64(t,e,n){let o=mt(8);new DataView(o.buffer,o.byteOffset,o.byteLength).setBigUint64(0,e,n),this.write(o,t)}getFloat32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat32(0,e)}setFloat32(t,e,n){let o=mt(4);new DataView(o.buffer,o.byteOffset,o.byteLength).setFloat32(0,e,n),this.write(o,t)}getFloat64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat64(0,e)}setFloat64(t,e,n){let o=mt(8);new DataView(o.buffer,o.byteOffset,o.byteLength).setFloat64(0,e,n),this.write(o,t)}equals(t){if(t==null||!(t instanceof r)||t.bufs.length!==this.bufs.length)return!1;for(let e=0;e<this.bufs.length;e++)if(!pt(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 yo={};Ct(yo,{base10:()=>Sf});var Sf=ie({prefix:"9",name:"base10",alphabet:"0123456789"});var go={};Ct(go,{base16:()=>Af,base16upper:()=>vf});var Af=ft({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),vf=ft({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var wo={};Ct(wo,{base2:()=>If});var If=ft({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var xo={};Ct(xo,{base256emoji:()=>Cf});var ta=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}"),Bf=ta.reduce((r,t,e)=>(r[e]=t,r),[]),_f=ta.reduce((r,t,e)=>{let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);return r[n]=e,r},[]);function Lf(r){return r.reduce((t,e)=>(t+=Bf[e],t),"")}function Tf(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 Cf=qe({prefix:"\u{1F680}",name:"base256emoji",encode:Lf,decode:Tf});var Eo={};Ct(Eo,{base64:()=>Pf,base64pad:()=>Uf,base64url:()=>bo,base64urlpad:()=>kf});var Pf=ft({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),Uf=ft({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),bo=ft({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),kf=ft({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var So={};Ct(So,{base8:()=>Rf});var Rf=ft({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Ao={};Ct(Ao,{identity:()=>Df});var Df=qe({prefix:"\0",name:"identity",encode:r=>Hi(r),decode:r=>Oi(r)});var zp=new TextEncoder,Gp=new TextDecoder;var Bo={};Ct(Bo,{sha256:()=>pr,sha512:()=>Mf});function Io({name:r,code:t,encode:e}){return new vo(r,t,e)}var vo=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 ra(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var pr=Io({name:"sha2-256",code:18,encode:ra("SHA-256")}),Mf=Io({name:"sha2-512",code:19,encode:ra("SHA-512")});var Ae={...Ao,...wo,...So,...yo,...go,...uo,...fo,...co,...Eo,...xo},n0={...Bo,...mo};function oa(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var na=oa("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),_o=oa("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=yt(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),Of={utf8:na,"utf-8":na,hex:Ae.base16,latin1:_o,ascii:_o,binary:_o,...Ae},en=Of;function X(r,t="utf8"){let e=en[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function q(r,t="utf8"){let e=en[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}var Hf=parseInt("11111",2),Lo=parseInt("10000000",2),qf=parseInt("01111111",2),sa={0:mr,1:mr,2:Vf,3:Gf,4:Wf,5:zf,6:Ff,16:mr,22:mr,48:mr};function Jt(r,t={offset:0}){let e=r[t.offset]&Hf;if(t.offset++,sa[e]!=null)return sa[e](r,t);throw new Error("No decoder for tag "+e)}function yr(r,t){let e=0;if((r[t.offset]&Lo)===Lo){let n=r[t.offset]&qf,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 mr(r,t){yr(r,t);let e=[];for(;!(t.offset>=r.byteLength);){let n=Jt(r,t);if(n===null)break;e.push(n)}return e}function Vf(r,t){let e=yr(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 Ff(r,t){let e=yr(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 u=r[t.offset];if(t.offset++,c.push(u&127),u<128){c.reverse();let f=0;for(let l=0;l<c.length;l++)f+=c[l]<<l*7;a+=`.${f}`,c=[]}}return a}function zf(r,t){return t.offset++,null}function Gf(r,t){let e=yr(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 Wf(r,t){let e=yr(r,t),n=r.subarray(t.offset,t.offset+e);return t.offset+=e,n}function jf(r){let t=r.toString(16);t.length%2===1&&(t="0"+t);let e=new W;for(let n=0;n<t.length;n+=2)e.append(Uint8Array.from([parseInt(`${t[n]}${t[n+1]}`,16)]));return e}function To(r){if(r.byteLength<128)return Uint8Array.from([r.byteLength]);let t=jf(r.byteLength);return new W(Uint8Array.from([t.byteLength|Lo]),t)}function kt(r){let t=new W,e=128;return(r.subarray()[0]&e)===e&&t.append(Uint8Array.from([0])),t.append(r),new W(Uint8Array.from([2]),To(t),t)}function rn(r){let t=Uint8Array.from([0]),e=new W(t,r);return new W(Uint8Array.from([3]),To(e),e)}function ce(r,t=48){let e=new W;for(let n of r)e.append(n);return new W(Uint8Array.from([t]),To(e),e)}async function ia(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 $f=Uint8Array.from([6,8,42,134,72,206,61,3,1,7]),Zf=Uint8Array.from([6,5,43,129,4,0,34]),Yf=Uint8Array.from([6,5,43,129,4,0,35]),Xf={ext:!0,kty:"EC",crv:"P-256"},Jf={ext:!0,kty:"EC",crv:"P-384"},Qf={ext:!0,kty:"EC",crv:"P-521"},Co=32,Po=48,Uo=66;function ko(r){let t=Jt(r);return aa(t)}function aa(r){let t=r[1][1][0],e=1,n,o;if(t.byteLength===Co*2+1)return n=q(t.subarray(e,e+Co),"base64url"),o=q(t.subarray(e+Co),"base64url"),new ze({...Xf,key_ops:["verify"],x:n,y:o});if(t.byteLength===Po*2+1)return n=q(t.subarray(e,e+Po),"base64url"),o=q(t.subarray(e+Po),"base64url"),new ze({...Jf,key_ops:["verify"],x:n,y:o});if(t.byteLength===Uo*2+1)return n=q(t.subarray(e,e+Uo),"base64url"),o=q(t.subarray(e+Uo),"base64url"),new ze({...Qf,key_ops:["verify"],x:n,y:o});throw new ut(`coordinates were wrong length, got ${t.byteLength}, expected 65, 97 or 133`)}function ca(r){return ce([kt(Uint8Array.from([1])),ce([tl(r.crv)],160),ce([rn(new W(Uint8Array.from([4]),X(r.x??"","base64url"),X(r.y??"","base64url")))],161)]).subarray()}function tl(r){if(r==="P-256")return $f;if(r==="P-384")return Zf;if(r==="P-521")return Yf;throw new ut(`Invalid curve ${r}`)}var ze=class{type="ECDSA";jwk;_raw;constructor(t){this.jwk=t}get raw(){return this._raw==null&&(this._raw=ca(this.jwk)),this._raw}toMultihash(){return Mt.digest(ue(this))}toCID(){return lt.createV1(114,this.toMultihash())}toString(){return rt.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:pt(this.raw,t.raw)}async verify(t,e){return ia(this.jwk,e,t)}};function nn(r){if(!Number.isSafeInteger(r)||r<0)throw new Error("positive integer expected, got "+r)}function el(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function Ge(r,...t){if(!el(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 gr(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");nn(r.outputLen),nn(r.blockLen)}function We(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 ua(r,t){Ge(r);let e=t.outputLen;if(r.length<e)throw new Error("digestInto() expects output buffer of length at least "+e)}var ve=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;function on(r){return new DataView(r.buffer,r.byteOffset,r.byteLength)}function Ot(r,t){return r<<32-t|r>>>t}var M0=typeof Uint8Array.from([]).toHex=="function"&&typeof Uint8Array.fromHex=="function";function fa(r){if(typeof r!="string")throw new Error("utf8ToBytes expected string, got "+typeof r);return new Uint8Array(new TextEncoder().encode(r))}function fe(r){return typeof r=="string"&&(r=fa(r)),Ge(r),r}function Ro(...r){let t=0;for(let n=0;n<r.length;n++){let o=r[n];Ge(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 je=class{clone(){return this._cloneInto()}};function sn(r){let t=n=>r().update(fe(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function wr(r=32){if(ve&&typeof ve.getRandomValues=="function")return ve.getRandomValues(new Uint8Array(r));if(ve&&typeof ve.randomBytes=="function")return Uint8Array.from(ve.randomBytes(r));throw new Error("crypto.getRandomValues must be defined")}function rl(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,u=n?0:4;r.setUint32(t+c,i,n),r.setUint32(t+u,a,n)}function la(r,t,e){return r&t^~r&e}function ha(r,t,e){return r&t^r&e^t&e}var $e=class extends je{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=on(this.buffer)}update(t){We(this);let{view:e,buffer:n,blockLen:o}=this;t=fe(t);let s=t.length;for(let i=0;i<s;){let a=Math.min(o-this.pos,s-i);if(a===o){let c=on(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){We(this),ua(t,this),this.finished=!0;let{buffer:e,view:n,blockLen:o,isLE:s}=this,{pos:i}=this;e[i++]=128,this.buffer.subarray(i).fill(0),this.padOffset>o-i&&(this.process(n,0),i=0);for(let l=i;l<o;l++)e[l]=0;rl(n,o-8,BigInt(this.length*8),s),this.process(n,0);let a=on(t),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let u=c/4,f=this.get();if(u>f.length)throw new Error("_sha2: outputLen bigger than state");for(let l=0;l<u;l++)a.setUint32(4*l,f[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.length=o,t.pos=a,t.finished=s,t.destroyed=i,o%e&&t.buffer.set(n),t}};var nl=new Uint32Array([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]),le=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),he=new Uint32Array(64),Do=class extends $e{constructor(t=32){super(64,t,8,!1),this.A=le[0]|0,this.B=le[1]|0,this.C=le[2]|0,this.D=le[3]|0,this.E=le[4]|0,this.F=le[5]|0,this.G=le[6]|0,this.H=le[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)he[l]=t.getUint32(e,!1);for(let l=16;l<64;l++){let d=he[l-15],w=he[l-2],x=Ot(d,7)^Ot(d,18)^d>>>3,m=Ot(w,17)^Ot(w,19)^w>>>10;he[l]=m+he[l-7]+x+he[l-16]|0}let{A:n,B:o,C:s,D:i,E:a,F:c,G:u,H:f}=this;for(let l=0;l<64;l++){let d=Ot(a,6)^Ot(a,11)^Ot(a,25),w=f+d+la(a,c,u)+nl[l]+he[l]|0,m=(Ot(n,2)^Ot(n,13)^Ot(n,22))+ha(n,o,s)|0;f=u,u=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,u=u+this.G|0,f=f+this.H|0,this.set(n,o,s,i,a,c,u,f)}roundClean(){he.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var Ht=sn(()=>new Do);var an=BigInt(4294967295),Ko=BigInt(32);function da(r,t=!1){return t?{h:Number(r&an),l:Number(r>>Ko&an)}:{h:Number(r>>Ko&an)|0,l:Number(r&an)|0}}function ol(r,t=!1){let e=new Uint32Array(r.length),n=new Uint32Array(r.length);for(let o=0;o<r.length;o++){let{h:s,l:i}=da(r[o],t);[e[o],n[o]]=[s,i]}return[e,n]}var sl=(r,t)=>BigInt(r>>>0)<<Ko|BigInt(t>>>0),il=(r,t,e)=>r>>>e,al=(r,t,e)=>r<<32-e|t>>>e,cl=(r,t,e)=>r>>>e|t<<32-e,ul=(r,t,e)=>r<<32-e|t>>>e,fl=(r,t,e)=>r<<64-e|t>>>e-32,ll=(r,t,e)=>r>>>e-32|t<<64-e,hl=(r,t)=>t,dl=(r,t)=>r,pl=(r,t,e)=>r<<e|t>>>32-e,ml=(r,t,e)=>t<<e|r>>>32-e,yl=(r,t,e)=>t<<e-32|r>>>64-e,gl=(r,t,e)=>r<<e-32|t>>>64-e;function wl(r,t,e,n){let o=(t>>>0)+(n>>>0);return{h:r+e+(o/2**32|0)|0,l:o|0}}var xl=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),bl=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,El=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),Sl=(r,t,e,n,o)=>t+e+n+o+(r/2**32|0)|0,Al=(r,t,e,n,o)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(o>>>0),vl=(r,t,e,n,o,s)=>t+e+n+o+s+(r/2**32|0)|0;var Il={fromBig:da,split:ol,toBig:sl,shrSH:il,shrSL:al,rotrSH:cl,rotrSL:ul,rotrBH:fl,rotrBL:ll,rotr32H:hl,rotr32L:dl,rotlSH:pl,rotlSL:ml,rotlBH:yl,rotlBL:gl,add:wl,add3L:xl,add3H:bl,add4L:El,add4H:Sl,add5H:vl,add5L:Al},z=Il;var[Bl,_l]=z.split(["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))),de=new Uint32Array(80),pe=new Uint32Array(80),No=class extends $e{constructor(t=64){super(128,t,16,!1),this.Ah=1779033703,this.Al=-205731576,this.Bh=-1150833019,this.Bl=-2067093701,this.Ch=1013904242,this.Cl=-23791573,this.Dh=-1521486534,this.Dl=1595750129,this.Eh=1359893119,this.El=-1377402159,this.Fh=-1694144372,this.Fl=725511199,this.Gh=528734635,this.Gl=-79577749,this.Hh=1541459225,this.Hl=327033209}get(){let{Ah:t,Al:e,Bh:n,Bl:o,Ch:s,Cl:i,Dh:a,Dl:c,Eh:u,El:f,Fh:l,Fl:d,Gh:w,Gl:x,Hh:m,Hl:h}=this;return[t,e,n,o,s,i,a,c,u,f,l,d,w,x,m,h]}set(t,e,n,o,s,i,a,c,u,f,l,d,w,x,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=u|0,this.El=f|0,this.Fh=l|0,this.Fl=d|0,this.Gh=w|0,this.Gl=x|0,this.Hh=m|0,this.Hl=h|0}process(t,e){for(let p=0;p<16;p++,e+=4)de[p]=t.getUint32(e),pe[p]=t.getUint32(e+=4);for(let p=16;p<80;p++){let v=de[p-15]|0,k=pe[p-15]|0,P=z.rotrSH(v,k,1)^z.rotrSH(v,k,8)^z.shrSH(v,k,7),L=z.rotrSL(v,k,1)^z.rotrSL(v,k,8)^z.shrSL(v,k,7),C=de[p-2]|0,I=pe[p-2]|0,M=z.rotrSH(C,I,19)^z.rotrBH(C,I,61)^z.shrSH(C,I,6),R=z.rotrSL(C,I,19)^z.rotrBL(C,I,61)^z.shrSL(C,I,6),N=z.add4L(L,R,pe[p-7],pe[p-16]),O=z.add4H(N,P,M,de[p-7],de[p-16]);de[p]=O|0,pe[p]=N|0}let{Ah:n,Al:o,Bh:s,Bl:i,Ch:a,Cl:c,Dh:u,Dl:f,Eh:l,El:d,Fh:w,Fl:x,Gh:m,Gl:h,Hh:b,Hl:E}=this;for(let p=0;p<80;p++){let v=z.rotrSH(l,d,14)^z.rotrSH(l,d,18)^z.rotrBH(l,d,41),k=z.rotrSL(l,d,14)^z.rotrSL(l,d,18)^z.rotrBL(l,d,41),P=l&w^~l&m,L=d&x^~d&h,C=z.add5L(E,k,L,_l[p],pe[p]),I=z.add5H(C,b,v,P,Bl[p],de[p]),M=C|0,R=z.rotrSH(n,o,28)^z.rotrBH(n,o,34)^z.rotrBH(n,o,39),N=z.rotrSL(n,o,28)^z.rotrBL(n,o,34)^z.rotrBL(n,o,39),O=n&s^n&a^s&a,A=o&i^o&c^i&c;b=m|0,E=h|0,m=w|0,h=x|0,w=l|0,x=d|0,{h:l,l:d}=z.add(u|0,f|0,I|0,M|0),u=a|0,f=c|0,a=s|0,c=i|0,s=n|0,i=o|0;let B=z.add3L(M,N,A);n=z.add3H(B,I,R,O),o=B|0}({h:n,l:o}=z.add(this.Ah|0,this.Al|0,n|0,o|0)),{h:s,l:i}=z.add(this.Bh|0,this.Bl|0,s|0,i|0),{h:a,l:c}=z.add(this.Ch|0,this.Cl|0,a|0,c|0),{h:u,l:f}=z.add(this.Dh|0,this.Dl|0,u|0,f|0),{h:l,l:d}=z.add(this.Eh|0,this.El|0,l|0,d|0),{h:w,l:x}=z.add(this.Fh|0,this.Fl|0,w|0,x|0),{h:m,l:h}=z.add(this.Gh|0,this.Gl|0,m|0,h|0),{h:b,l:E}=z.add(this.Hh|0,this.Hl|0,b|0,E|0),this.set(n,o,s,i,a,c,u,f,l,d,w,x,m,h,b,E)}roundClean(){de.fill(0),pe.fill(0)}destroy(){this.buffer.fill(0),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}};var Mo=sn(()=>new No);var Vo=BigInt(0),qo=BigInt(1);function Ie(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function Fo(r){if(!Ie(r))throw new Error("Uint8Array expected")}function Gt(r,t){if(typeof t!="boolean")throw new Error(r+" boolean expected, got "+t)}function xr(r){let t=r.toString(16);return t.length&1?"0"+t:t}function ya(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return r===""?Vo:BigInt("0x"+r)}var ga=typeof Uint8Array.from([]).toHex=="function"&&typeof Uint8Array.fromHex=="function",Ll=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function me(r){if(Fo(r),ga)return r.toHex();let t="";for(let e=0;e<r.length;e++)t+=Ll[r[e]];return t}var Qt={_0:48,_9:57,A:65,F:70,a:97,f:102};function pa(r){if(r>=Qt._0&&r<=Qt._9)return r-Qt._0;if(r>=Qt.A&&r<=Qt.F)return r-(Qt.A-10);if(r>=Qt.a&&r<=Qt.f)return r-(Qt.a-10)}function br(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);if(ga)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 te(r){return ya(me(r))}function Wt(r){return Fo(r),ya(me(Uint8Array.from(r).reverse()))}function Be(r,t){return br(r.toString(16).padStart(t*2,"0"))}function ye(r,t){return Be(r,t).reverse()}function ot(r,t,e){let n;if(typeof t=="string")try{n=br(t)}catch(s){throw new Error(r+" must be hex string or Uint8Array, cause: "+s)}else if(Ie(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 ge(...r){let t=0;for(let n=0;n<r.length;n++){let o=r[n];Fo(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 Oo=r=>typeof r=="bigint"&&Vo<=r;function cn(r,t,e){return Oo(r)&&Oo(t)&&Oo(e)&&t<=r&&r<e}function vt(r,t,e,n){if(!cn(t,e,n))throw new Error("expected valid "+r+": "+e+" <= n < "+n+", got "+t)}function wa(r){let t;for(t=0;r>Vo;r>>=qo,t+=1);return t}var _e=r=>(qo<<BigInt(r))-qo,Ho=r=>new Uint8Array(r),ma=r=>Uint8Array.from(r);function xa(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=Ho(r),o=Ho(r),s=0,i=()=>{n.fill(1),o.fill(0),s=0},a=(...l)=>e(o,n,...l),c=(l=Ho(0))=>{o=a(ma([0]),l),n=a(),l.length!==0&&(o=a(ma([1]),l),n=a())},u=()=>{if(s++>=1e3)throw new Error("drbg: tried 1000 values");let l=0,d=[];for(;l<t;){n=a();let w=n.slice();d.push(w),l+=n.length}return ge(...d)};return(l,d)=>{i(),c(l);let w;for(;!(w=d(u()));)c();return i(),w}}var Tl={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"||Ie(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=Tl[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 Ze(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 gt=BigInt(0),at=BigInt(1),Le=BigInt(2),Cl=BigInt(3),zo=BigInt(4),ba=BigInt(5),Ea=BigInt(8),Pl=BigInt(9),Ul=BigInt(16);function Z(r,t){let e=r%t;return e>=gt?e:t+e}function Go(r,t,e){if(t<gt)throw new Error("invalid exponent, negatives unsupported");if(e<=gt)throw new Error("invalid modulus");if(e===at)return gt;let n=at;for(;t>gt;)t&at&&(n=n*r%e),r=r*r%e,t>>=at;return n}function st(r,t,e){let n=r;for(;t-- >gt;)n*=n,n%=e;return n}function un(r,t){if(r===gt)throw new Error("invert: expected non-zero number");if(t<=gt)throw new Error("invert: expected positive modulus, got "+t);let e=Z(r,t),n=t,o=gt,s=at,i=at,a=gt;for(;e!==gt;){let u=n/e,f=n%e,l=o-i*u,d=s-a*u;n=e,e=f,o=i,s=a,i=l,a=d}if(n!==at)throw new Error("invert: does not exist");return Z(o,t)}function kl(r){let t=(r-at)/Le,e,n,o;for(e=r-at,n=0;e%Le===gt;e/=Le,n++);for(o=Le;o<r&&Go(o,t,r)!==r-at;o++)if(o>1e3)throw new Error("Cannot find square root: likely non-prime P");if(n===1){let i=(r+at)/zo;return function(c,u){let f=c.pow(u,i);if(!c.eql(c.sqr(f),u))throw new Error("Cannot find square root");return f}}let s=(e+at)/Le;return function(a,c){if(a.pow(c,t)===a.neg(a.ONE))throw new Error("Cannot find square root");let u=n,f=a.pow(a.mul(a.ONE,o),e),l=a.pow(c,s),d=a.pow(c,e);for(;!a.eql(d,a.ONE);){if(a.eql(d,a.ZERO))return a.ZERO;let w=1;for(let m=a.sqr(d);w<u&&!a.eql(m,a.ONE);w++)m=a.sqr(m);let x=a.pow(f,at<<BigInt(u-w-1));f=a.sqr(x),l=a.mul(l,x),d=a.mul(d,f),u=w}return l}}function Rl(r){if(r%zo===Cl){let t=(r+at)/zo;return function(n,o){let s=n.pow(o,t);if(!n.eql(n.sqr(s),o))throw new Error("Cannot find square root");return s}}if(r%Ea===ba){let t=(r-ba)/Ea;return function(n,o){let s=n.mul(o,Le),i=n.pow(s,t),a=n.mul(o,i),c=n.mul(n.mul(a,Le),i),u=n.mul(a,n.sub(c,n.ONE));if(!n.eql(n.sqr(u),o))throw new Error("Cannot find square root");return u}}return r%Ul,kl(r)}var Sa=(r,t)=>(Z(r,t)&at)===at,Dl=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function Wo(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<gt)throw new Error("invalid exponent, negatives unsupported");if(e===gt)return r.ONE;if(e===at)return t;let n=r.ONE,o=t;for(;e>gt;)e&at&&(n=r.mul(n,o)),o=r.sqr(o),e>>=at;return n}function Nl(r,t){let e=new Array(t.length),n=t.reduce((s,i,a)=>r.is0(i)?s:(e[a]=s,r.mul(s,i)),r.ONE),o=r.inv(n);return t.reduceRight((s,i,a)=>r.is0(i)?s:(e[a]=r.mul(s,e[a]),r.mul(s,i)),o),e}function jo(r,t){let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function we(r,t,e=!1,n={}){if(r<=gt)throw new Error("invalid field: expected ORDER > 0, got "+r);let{nBitLength:o,nByteLength:s}=jo(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:_e(o),ZERO:gt,ONE:at,create:c=>Z(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error("invalid field element: expected bigint, got "+typeof c);return gt<=c&&c<r},is0:c=>c===gt,isOdd:c=>(c&at)===at,neg:c=>Z(-c,r),eql:(c,u)=>c===u,sqr:c=>Z(c*c,r),add:(c,u)=>Z(c+u,r),sub:(c,u)=>Z(c-u,r),mul:(c,u)=>Z(c*u,r),pow:(c,u)=>Kl(a,c,u),div:(c,u)=>Z(c*un(u,r),r),sqrN:c=>c*c,addN:(c,u)=>c+u,subN:(c,u)=>c-u,mulN:(c,u)=>c*u,inv:c=>un(c,r),sqrt:n.sqrt||(c=>(i||(i=Rl(r)),i(a,c))),invertBatch:c=>Nl(a,c),cmov:(c,u,f)=>f?u:c,toBytes:c=>e?ye(c,s):Be(c,s),fromBytes:c=>{if(c.length!==s)throw new Error("Field.fromBytes: expected "+s+" bytes, got "+c.length);return e?Wt(c):te(c)}});return Object.freeze(a)}function Aa(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 $o(r){let t=Aa(r);return t+Math.ceil(t/2)}function va(r,t,e=!1){let n=r.length,o=Aa(t),s=$o(t);if(n<16||n<s||n>1024)throw new Error("expected "+s+"-1024 bytes of input, got "+n);let i=e?Wt(r):te(r),a=Z(i,t-at)+at;return e?ye(a,o):Be(a,o)}var Ia=BigInt(0),Qo=BigInt(1);function Zo(r,t){let e=t.negate();return r?e:t}function _a(r,t){if(!Number.isSafeInteger(r)||r<=0||r>t)throw new Error("invalid window size, expected [1.."+t+"], got W="+r)}function Yo(r,t){_a(r,t);let e=Math.ceil(t/r)+1,n=2**(r-1),o=2**r,s=_e(r),i=BigInt(r);return{windows:e,windowSize:n,mask:s,maxNumber:o,shiftBy:i}}function Ba(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+=Qo);let u=t*n,f=u+Math.abs(a)-1,l=a===0,d=a<0,w=t%2!==0;return{nextN:c,offset:f,isZero:l,isNeg:d,isNegF:w,offsetF:u}}function Ml(r,t){if(!Array.isArray(r))throw new Error("array expected");r.forEach((e,n)=>{if(!(e instanceof t))throw new Error("invalid point at index "+n)})}function Ol(r,t){if(!Array.isArray(r))throw new Error("array of scalars expected");r.forEach((e,n)=>{if(!t.isValid(e))throw new Error("invalid scalar at index "+n)})}var Xo=new WeakMap,La=new WeakMap;function Jo(r){return La.get(r)||1}function fn(r,t){return{constTimeNegate:Zo,hasPrecomputes(e){return Jo(e)!==1},unsafeLadder(e,n,o=r.ZERO){let s=e;for(;n>Ia;)n&Qo&&(o=o.add(s)),s=s.double(),n>>=Qo;return o},precomputeWindow(e,n){let{windows:o,windowSize:s}=Yo(n,t),i=[],a=e,c=a;for(let u=0;u<o;u++){c=a,i.push(c);for(let f=1;f<s;f++)c=c.add(a),i.push(c);a=c.double()}return i},wNAF(e,n,o){let s=r.ZERO,i=r.BASE,a=Yo(e,t);for(let c=0;c<a.windows;c++){let{nextN:u,offset:f,isZero:l,isNeg:d,isNegF:w,offsetF:x}=Ba(o,c,a);o=u,l?i=i.add(Zo(w,n[x])):s=s.add(Zo(d,n[f]))}return{p:s,f:i}},wNAFUnsafe(e,n,o,s=r.ZERO){let i=Yo(e,t);for(let a=0;a<i.windows&&o!==Ia;a++){let{nextN:c,offset:u,isZero:f,isNeg:l}=Ba(o,a,i);if(o=c,!f){let d=n[u];s=s.add(l?d.negate():d)}}return s},getPrecomputes(e,n,o){let s=Xo.get(n);return s||(s=this.precomputeWindow(n,e),e!==1&&Xo.set(n,o(s))),s},wNAFCached(e,n,o){let s=Jo(e);return this.wNAF(s,this.getPrecomputes(s,e,o),n)},wNAFCachedUnsafe(e,n,o,s){let i=Jo(e);return i===1?this.unsafeLadder(e,n,s):this.wNAFUnsafe(i,this.getPrecomputes(i,e,o),n,s)},setWindowSize(e,n){_a(n,t),La.set(e,n),Xo.delete(e)}}}function ln(r,t,e,n){if(Ml(e,r),Ol(n,t),e.length!==n.length)throw new Error("arrays of points and scalars must have equal length");let o=r.ZERO,s=wa(BigInt(e.length)),i=s>12?s-3:s>4?s-2:s?2:1,a=_e(i),c=new Array(Number(a)+1).fill(o),u=Math.floor((t.BITS-1)/i)*i,f=o;for(let l=u;l>=0;l-=i){c.fill(o);for(let w=0;w<n.length;w++){let x=n[w],m=Number(x>>BigInt(l)&a);c[m]=c[m].add(e[w])}let d=o;for(let w=c.length-1,x=o;w>0;w--)x=x.add(c[w]),d=d.add(x);if(f=f.add(d),l!==0)for(let w=0;w<i;w++)f=f.double()}return f}function Er(r){return Wo(r.Fp),qt(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...jo(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var jt=BigInt(0),Pt=BigInt(1),Ta=BigInt(2),Hl=BigInt(8),ql={zip215:!0};function Vl(r){let t=Er(r);return qt(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function Ca(r){let t=Vl(r),{Fp:e,n,prehash:o,hash:s,randomBytes:i,nByteLength:a,h:c}=t,u=Ta<<BigInt(a*8)-Pt,f=e.create,l=we(t.n,t.nBitLength),d=t.uvRatio||((S,y)=>{try{return{isValid:!0,value:e.sqrt(S*e.inv(y))}}catch{return{isValid:!1,value:jt}}}),w=t.adjustScalarBytes||(S=>S),x=t.domain||((S,y,g)=>{if(Gt("phflag",g),y.length||g)throw new Error("Contexts/pre-hash are not supported");return S});function m(S,y,g=!1){let _=g?Pt:jt;vt("coordinate "+S,y,_,u)}function h(S){if(!(S instanceof p))throw new Error("ExtendedPoint expected")}let b=Ze((S,y)=>{let{ex:g,ey:_,ez:U}=S,D=S.is0();y==null&&(y=D?Hl:e.inv(U));let H=f(g*y),V=f(_*y),F=f(U*y);if(D)return{x:jt,y:Pt};if(F!==Pt)throw new Error("invZ was invalid");return{x:H,y:V}}),E=Ze(S=>{let{a:y,d:g}=t;if(S.is0())throw new Error("bad point: ZERO");let{ex:_,ey:U,ez:D,et:H}=S,V=f(_*_),F=f(U*U),G=f(D*D),nt=f(G*G),et=f(V*y),it=f(G*f(et+F)),Ut=f(nt+f(g*f(V*F)));if(it!==Ut)throw new Error("bad point: equation left != right (1)");let wt=f(_*U),St=f(D*H);if(wt!==St)throw new Error("bad point: equation left != right (2)");return!0});class p{constructor(y,g,_,U){m("x",y),m("y",g),m("z",_,!0),m("t",U),this.ex=y,this.ey=g,this.ez=_,this.et=U,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:_}=y||{};return m("x",g),m("y",_),new p(g,_,Pt,f(g*_))}static normalizeZ(y){let g=e.invertBatch(y.map(_=>_.ez));return y.map((_,U)=>_.toAffine(g[U])).map(p.fromAffine)}static msm(y,g){return ln(p,l,y,g)}_setWindowSize(y){P.setWindowSize(this,y)}assertValidity(){E(this)}equals(y){h(y);let{ex:g,ey:_,ez:U}=this,{ex:D,ey:H,ez:V}=y,F=f(g*V),G=f(D*U),nt=f(_*V),et=f(H*U);return F===G&&nt===et}is0(){return this.equals(p.ZERO)}negate(){return new p(f(-this.ex),this.ey,this.ez,f(-this.et))}double(){let{a:y}=t,{ex:g,ey:_,ez:U}=this,D=f(g*g),H=f(_*_),V=f(Ta*f(U*U)),F=f(y*D),G=g+_,nt=f(f(G*G)-D-H),et=F+H,it=et-V,Ut=F-H,wt=f(nt*it),St=f(et*Ut),Rt=f(nt*Ut),Nt=f(it*et);return new p(wt,St,Nt,Rt)}add(y){h(y);let{a:g,d:_}=t,{ex:U,ey:D,ez:H,et:V}=this,{ex:F,ey:G,ez:nt,et}=y,it=f(U*F),Ut=f(D*G),wt=f(V*_*et),St=f(H*nt),Rt=f((U+D)*(F+G)-it-Ut),Nt=St-wt,ur=St+wt,Di=f(Ut-g*it),vu=f(Rt*Nt),Iu=f(ur*Di),Bu=f(Rt*Di),_u=f(Nt*ur);return new p(vu,Iu,_u,Bu)}subtract(y){return this.add(y.negate())}wNAF(y){return P.wNAFCached(this,y,p.normalizeZ)}multiply(y){let g=y;vt("scalar",g,Pt,n);let{p:_,f:U}=this.wNAF(g);return p.normalizeZ([_,U])[0]}multiplyUnsafe(y,g=p.ZERO){let _=y;return vt("scalar",_,jt,n),_===jt?k:this.is0()||_===Pt?this:P.wNAFCachedUnsafe(this,_,p.normalizeZ,g)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return P.unsafeLadder(this,n).is0()}toAffine(y){return b(this,y)}clearCofactor(){let{h:y}=t;return y===Pt?this:this.multiplyUnsafe(y)}static fromHex(y,g=!1){let{d:_,a:U}=t,D=e.BYTES;y=ot("pointHex",y,D),Gt("zip215",g);let H=y.slice(),V=y[D-1];H[D-1]=V&-129;let F=Wt(H),G=g?u:e.ORDER;vt("pointHex.y",F,jt,G);let nt=f(F*F),et=f(nt-Pt),it=f(_*nt-U),{isValid:Ut,value:wt}=d(et,it);if(!Ut)throw new Error("Point.fromHex: invalid y coordinate");let St=(wt&Pt)===Pt,Rt=(V&128)!==0;if(!g&&wt===jt&&Rt)throw new Error("Point.fromHex: x=0 and x_0=1");return Rt!==St&&(wt=f(-wt)),p.fromAffine({x:wt,y:F})}static fromPrivateKey(y){let{scalar:g}=I(y);return v.multiply(g)}toRawBytes(){let{x:y,y:g}=this.toAffine(),_=ye(g,e.BYTES);return _[_.length-1]|=y&Pt?128:0,_}toHex(){return me(this.toRawBytes())}}p.BASE=new p(t.Gx,t.Gy,Pt,f(t.Gx*t.Gy)),p.ZERO=new p(jt,Pt,Pt,jt);let{BASE:v,ZERO:k}=p,P=fn(p,a*8);function L(S){return Z(S,n)}function C(S){return L(Wt(S))}function I(S){let y=e.BYTES;S=ot("private key",S,y);let g=ot("hashed private key",s(S),2*y),_=w(g.slice(0,y)),U=g.slice(y,2*y),D=C(_);return{head:_,prefix:U,scalar:D}}function M(S){let{head:y,prefix:g,scalar:_}=I(S),U=v.multiply(_),D=U.toRawBytes();return{head:y,prefix:g,scalar:_,point:U,pointBytes:D}}function R(S){return M(S).pointBytes}function N(S=new Uint8Array,...y){let g=ge(...y);return C(s(x(g,ot("context",S),!!o)))}function O(S,y,g={}){S=ot("message",S),o&&(S=o(S));let{prefix:_,scalar:U,pointBytes:D}=M(y),H=N(g.context,_,S),V=v.multiply(H).toRawBytes(),F=N(g.context,V,D,S),G=L(H+F*U);vt("signature.s",G,jt,n);let nt=ge(V,ye(G,e.BYTES));return ot("result",nt,e.BYTES*2)}let A=ql;function B(S,y,g,_=A){let{context:U,zip215:D}=_,H=e.BYTES;S=ot("signature",S,2*H),y=ot("message",y),g=ot("publicKey",g,H),D!==void 0&&Gt("zip215",D),o&&(y=o(y));let V=Wt(S.slice(H,2*H)),F,G,nt;try{F=p.fromHex(g,D),G=p.fromHex(S.slice(0,H),D),nt=v.multiplyUnsafe(V)}catch{return!1}if(!D&&F.isSmallOrder())return!1;let et=N(U,G.toRawBytes(),F.toRawBytes(),y);return G.add(F.multiplyUnsafe(et)).subtract(nt).clearCofactor().equals(p.ZERO)}return v._setWindowSize(8),{CURVE:t,getPublicKey:R,sign:O,verify:B,ExtendedPoint:p,utils:{getExtendedPublicKey:M,randomPrivateKey:()=>i(e.BYTES),precompute(S=8,y=p.BASE){return y._setWindowSize(S),y.multiply(BigInt(3)),y}}}}var Ye=BigInt(0),ts=BigInt(1);function Fl(r){return qt(r,{a:"bigint"},{montgomeryBits:"isSafeInteger",nByteLength:"isSafeInteger",adjustScalarBytes:"function",domain:"function",powPminus2:"function",Gu:"bigint"}),Object.freeze({...r})}function Pa(r){let t=Fl(r),{P:e}=t,n=E=>Z(E,e),o=t.montgomeryBits,s=Math.ceil(o/8),i=t.nByteLength,a=t.adjustScalarBytes||(E=>E),c=t.powPminus2||(E=>Go(E,e-BigInt(2),e));function u(E,p,v){let k=n(E*(p-v));return p=n(p-k),v=n(v+k),[p,v]}let f=(t.a-BigInt(2))/BigInt(4);function l(E,p){vt("u",E,Ye,e),vt("scalar",p,Ye,e);let v=p,k=E,P=ts,L=Ye,C=E,I=ts,M=Ye,R;for(let O=BigInt(o-1);O>=Ye;O--){let A=v>>O&ts;M^=A,R=u(M,P,C),P=R[0],C=R[1],R=u(M,L,I),L=R[0],I=R[1],M=A;let B=P+L,T=n(B*B),S=P-L,y=n(S*S),g=T-y,_=C+I,U=C-I,D=n(U*B),H=n(_*S),V=D+H,F=D-H;C=n(V*V),I=n(k*n(F*F)),P=n(T*y),L=n(g*(T+n(f*g)))}R=u(M,P,C),P=R[0],C=R[1],R=u(M,L,I),L=R[0],I=R[1];let N=c(L);return n(P*N)}function d(E){return ye(n(E),s)}function w(E){let p=ot("u coordinate",E,s);return i===32&&(p[31]&=127),Wt(p)}function x(E){let p=ot("scalar",E),v=p.length;if(v!==s&&v!==i){let k=""+s+" or "+i;throw new Error("invalid scalar, expected "+k+" bytes, got "+v)}return Wt(a(p))}function m(E,p){let v=w(p),k=x(E),P=l(v,k);if(P===Ye)throw new Error("invalid private or public key received");return d(P)}let h=d(t.Gu);function b(E){return m(E,h)}return{scalarMult:m,scalarMultBase:b,getSharedSecret:(E,p)=>m(E,p),getPublicKey:E=>b(E),utils:{randomPrivateKey:()=>t.randomBytes(t.nByteLength)},GuBytes:h}}var Sr=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),Ua=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),Am=BigInt(0),zl=BigInt(1),ka=BigInt(2),Gl=BigInt(3),Wl=BigInt(5),jl=BigInt(8);function Da(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),o=BigInt(80),s=Sr,a=r*r%s*r%s,c=st(a,ka,s)*a%s,u=st(c,zl,s)*r%s,f=st(u,Wl,s)*u%s,l=st(f,t,s)*f%s,d=st(l,e,s)*l%s,w=st(d,n,s)*d%s,x=st(w,o,s)*w%s,m=st(x,o,s)*w%s,h=st(m,t,s)*f%s;return{pow_p_5_8:st(h,ka,s)*r%s,b2:a}}function Ka(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function $l(r,t){let e=Sr,n=Z(t*t*t,e),o=Z(n*n*t,e),s=Da(r*o).pow_p_5_8,i=Z(r*n*s,e),a=Z(t*i*i,e),c=i,u=Z(i*Ua,e),f=a===r,l=a===Z(-r,e),d=a===Z(-r*Ua,e);return f&&(i=c),(l||d)&&(i=u),Sa(i,e)&&(i=Z(-i,e)),{isValid:f||l,value:i}}var Ra=we(Sr,void 0,!0),Zl={a:Ra.create(BigInt(-1)),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:Ra,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:jl,Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:Mo,randomBytes:wr,adjustScalarBytes:Ka,uvRatio:$l},Na=Ca(Zl);var Ar=Pa({P:Sr,a:BigInt(486662),montgomeryBits:255,nByteLength:32,Gu:BigInt(9),powPminus2:r=>{let t=Sr,{pow_p_5_8:e,b2:n}=Da(r);return Z(st(e,Gl,t)*n,t)},adjustScalarBytes:Ka,randomBytes:wr});var hn=32;function Ma(r,t,e){return Na.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}var dn=class{type="Ed25519";raw;constructor(t){this.raw=es(t,hn)}toMultihash(){return Mt.digest(ue(this))}toCID(){return lt.createV1(114,this.toMultihash())}toString(){return rt.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:pt(this.raw,t.raw)}verify(t,e){return Ma(this.raw,e,t)}};function rs(r){return r=es(r,hn),new dn(r)}function es(r,t){if(r=Uint8Array.from(r??[]),r.length!==t)throw new ut(`Key must be a Uint8Array of length ${t}, got ${r.length}`);return r}var Xl=Math.pow(2,7),Jl=Math.pow(2,14),Ql=Math.pow(2,21),ns=Math.pow(2,28),os=Math.pow(2,35),ss=Math.pow(2,42),is=Math.pow(2,49),J=128,It=127;function dt(r){if(r<Xl)return 1;if(r<Jl)return 2;if(r<Ql)return 3;if(r<ns)return 4;if(r<os)return 5;if(r<ss)return 6;if(r<is)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function as(r,t,e=0){switch(dt(r)){case 8:t[e++]=r&255|J,r/=128;case 7:t[e++]=r&255|J,r/=128;case 6:t[e++]=r&255|J,r/=128;case 5:t[e++]=r&255|J,r/=128;case 4:t[e++]=r&255|J,r>>>=7;case 3:t[e++]=r&255|J,r>>>=7;case 2:t[e++]=r&255|J,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function th(r,t,e=0){switch(dt(r)){case 8:t.set(e++,r&255|J),r/=128;case 7:t.set(e++,r&255|J),r/=128;case 6:t.set(e++,r&255|J),r/=128;case 5:t.set(e++,r&255|J),r/=128;case 4:t.set(e++,r&255|J),r>>>=7;case 3:t.set(e++,r&255|J),r>>>=7;case 2:t.set(e++,r&255|J),r>>>=7;case 1:{t.set(e++,r&255),r>>>=7;break}default:throw new Error("unreachable")}return t}function cs(r,t){let e=r[t],n=0;if(n+=e&It,e<J||(e=r[t+1],n+=(e&It)<<7,e<J)||(e=r[t+2],n+=(e&It)<<14,e<J)||(e=r[t+3],n+=(e&It)<<21,e<J)||(e=r[t+4],n+=(e&It)*ns,e<J)||(e=r[t+5],n+=(e&It)*os,e<J)||(e=r[t+6],n+=(e&It)*ss,e<J)||(e=r[t+7],n+=(e&It)*is,e<J))return n;throw new RangeError("Could not decode varint")}function eh(r,t){let e=r.get(t),n=0;if(n+=e&It,e<J||(e=r.get(t+1),n+=(e&It)<<7,e<J)||(e=r.get(t+2),n+=(e&It)<<14,e<J)||(e=r.get(t+3),n+=(e&It)<<21,e<J)||(e=r.get(t+4),n+=(e&It)*ns,e<J)||(e=r.get(t+5),n+=(e&It)*os,e<J)||(e=r.get(t+6),n+=(e&It)*ss,e<J)||(e=r.get(t+7),n+=(e&It)*is,e<J))return n;throw new RangeError("Could not decode varint")}function $t(r,t,e=0){return t==null&&(t=yt(dt(r))),t instanceof Uint8Array?as(r,t,e):th(r,t,e)}function Vt(r,t=0){return r instanceof Uint8Array?cs(r,t):eh(r,t)}var us=new Float32Array([-0]),xe=new Uint8Array(us.buffer);function Ha(r,t,e){us[0]=r,t[e]=xe[0],t[e+1]=xe[1],t[e+2]=xe[2],t[e+3]=xe[3]}function qa(r,t){return xe[0]=r[t],xe[1]=r[t+1],xe[2]=r[t+2],xe[3]=r[t+3],us[0]}var fs=new Float64Array([-0]),Bt=new Uint8Array(fs.buffer);function Va(r,t,e){fs[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 Fa(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],fs[0]}var rh=BigInt(Number.MAX_SAFE_INTEGER),nh=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 Te;if(t<rh&&t>nh)return this.fromNumber(Number(t));let e=t<0n;e&&(t=-t);let n=t>>32n,o=t-(n<<32n);return e&&(n=~n|0n,o=~o|0n,++o>za&&(o=0n,++n>za&&(n=0n))),new r(Number(o),Number(n))}static fromNumber(t){if(t===0)return Te;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):Te}},Te=new Dt(0,0);Te.toBigInt=function(){return 0n};Te.zzEncode=Te.zzDecode=function(){return this};Te.length=function(){return 1};var za=4294967296n;function Ga(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 Wa(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 ls(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 pn(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var hs=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 pn(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Ft(this,4);return pn(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Ft(this,4);let t=qa(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Ft(this,4);let t=Fa(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 Wa(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=pn(this.buf,this.pos+=4),e=pn(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=cs(this.buf,this.pos);return this.pos+=dt(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 ds(r){return new hs(r instanceof Uint8Array?r:r.subarray())}function Ce(r,t,e){let n=ds(r);return t.decode(n,void 0,e)}function ps(r){let t=r??8192,e=t>>>1,n,o=t;return function(i){if(i<1||i>e)return yt(i);o+i>t&&(n=yt(t),o=0);let a=n.subarray(o,o+=i);return(o&7)!==0&&(o=(o|7)+1),a}}var Pe=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function ms(){}var gs=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},oh=ps();function sh(r){return globalThis.Buffer!=null?yt(r):oh(r)}var Br=class{len;head;tail;states;constructor(){this.len=0,this.head=new Pe(ms,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new Pe(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new ws((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(mn,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(mn,e.length(),e)}uint64Number(t){return this._push(as,dt(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(mn,e.length(),e)}sint64Number(t){let e=Dt.fromNumber(t).zzEncode();return this._push(mn,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(ys,1,t?1:0)}fixed32(t){return this._push(Ir,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=Dt.fromBigInt(t);return this._push(Ir,4,e.lo)._push(Ir,4,e.hi)}fixed64Number(t){let e=Dt.fromNumber(t);return this._push(Ir,4,e.lo)._push(Ir,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(Ha,4,t)}double(t){return this._push(Va,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(ys,1,0):this.uint32(e)._push(ah,e,t)}string(t){let e=Ga(t);return e!==0?this.uint32(e)._push(ls,e,t):this._push(ys,1,0)}fork(){return this.states=new gs(this),this.head=this.tail=new Pe(ms,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 Pe(ms,0,0),this.len=0),this}ldelim(){let t=this.head,e=this.tail,n=this.len;return this.reset().uint32(n),n!==0&&(this.tail.next=t.next,this.tail=e,this.len+=n),this}finish(){let t=this.head.next,e=sh(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function ys(r,t,e){t[e]=r&255}function ih(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var ws=class extends Pe{next;constructor(t,e){super(ih,t,e),this.next=void 0}};function mn(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 Ir(r,t,e){t[e]=r&255,t[e+1]=r>>>8&255,t[e+2]=r>>>16&255,t[e+3]=r>>>24}function ah(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(Br.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(ch,t,r),this},Br.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(uh,t,r),this});function ch(r,t,e){t.set(r,e)}function uh(r,t,e){r.length<40?ls(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(X(r),e)}function xs(){return new Br}function Ue(r,t){let e=xs();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var Xe;(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"})(Xe||(Xe={}));function yn(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function bs(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 yn("enum",Xe.VARINT,e,n)}function ke(r,t){return yn("message",Xe.LENGTH_DELIMITED,r,t)}var _r=class extends Error{code="ERR_MAX_LENGTH";name="MaxLengthError"};var ht;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.secp256k1="secp256k1",r.ECDSA="ECDSA"})(ht||(ht={}));var Es;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1",r[r.ECDSA=3]="ECDSA"})(Es||(Es={}));(function(r){r.codec=()=>bs(Es)})(ht||(ht={}));var Zt;(function(r){let t;r.codec=()=>(t==null&&(t=ke((e,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),ht.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=ht.codec().decode(e);break}case 2:{s.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return s})),t),r.encode=e=>Ue(e,r.codec()),r.decode=(e,n)=>Ce(e,r.codec(),n)})(Zt||(Zt={}));var Ss;(function(r){let t;r.codec=()=>(t==null&&(t=ke((e,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),ht.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=ht.codec().decode(e);break}case 2:{s.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return s})),t),r.encode=e=>Ue(e,r.codec()),r.decode=(e,n)=>Ce(e,r.codec(),n)})(Ss||(Ss={}));var Lr=class extends Error{constructor(t="An error occurred while verifying a message"){super(t),this.name="VerificationError"}},gn=class extends Error{constructor(t="Missing Web Crypto API"){super(t),this.name="WebCryptoMissingError"}};var Za={get(r=globalThis){let t=r.crypto;if(t?.subtle==null)throw new gn("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 be=Za;var Cr={};Ct(Cr,{MAX_RSA_KEY_SIZE:()=>As,generateRSAKeyPair:()=>Qa,jwkToJWKKeyPair:()=>tc,jwkToPkcs1:()=>dh,jwkToPkix:()=>_s,jwkToRSAPrivateKey:()=>Ps,pkcs1MessageToJwk:()=>Is,pkcs1MessageToRSAPrivateKey:()=>Ls,pkcs1ToJwk:()=>hh,pkcs1ToRSAPrivateKey:()=>Ja,pkixMessageToJwk:()=>Bs,pkixMessageToRSAPublicKey:()=>Cs,pkixToJwk:()=>ph,pkixToRSAPublicKey:()=>Ts});var Je=class{type="RSA";jwk;_raw;_multihash;constructor(t,e){this.jwk=t,this._multihash=e}get raw(){return this._raw==null&&(this._raw=Cr.jwkToPkix(this.jwk)),this._raw}toMultihash(){return this._multihash}toCID(){return lt.createV1(114,this._multihash)}toString(){return rt.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:pt(this.raw,t.raw)}verify(t,e){return Xa(this.jwk,e,t)}},Tr=class{type="RSA";jwk;_raw;publicKey;constructor(t,e){this.jwk=t,this.publicKey=e}get raw(){return this._raw==null&&(this._raw=Cr.jwkToPkcs1(this.jwk)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:pt(this.raw,t.raw)}sign(t){return Ya(this.jwk,t)}};var As=8192,vs=18,fh=1062,lh=Uint8Array.from([48,13,6,9,42,134,72,134,247,13,1,1,1,5,0]);function hh(r){let t=Jt(r);return Is(t)}function Is(r){return{n:q(r[1],"base64url"),e:q(r[2],"base64url"),d:q(r[3],"base64url"),p:q(r[4],"base64url"),q:q(r[5],"base64url"),dp:q(r[6],"base64url"),dq:q(r[7],"base64url"),qi:q(r[8],"base64url"),kty:"RSA"}}function dh(r){if(r.n==null||r.e==null||r.d==null||r.p==null||r.q==null||r.dp==null||r.dq==null||r.qi==null)throw new ut("JWK was missing components");return ce([kt(Uint8Array.from([0])),kt(X(r.n,"base64url")),kt(X(r.e,"base64url")),kt(X(r.d,"base64url")),kt(X(r.p,"base64url")),kt(X(r.q,"base64url")),kt(X(r.dp,"base64url")),kt(X(r.dq,"base64url")),kt(X(r.qi,"base64url"))]).subarray()}function ph(r){let t=Jt(r,{offset:0});return Bs(t)}function Bs(r){let t=Jt(r[1],{offset:0});return{kty:"RSA",n:q(t[0],"base64url"),e:q(t[1],"base64url")}}function _s(r){if(r.n==null||r.e==null)throw new ut("JWK was missing components");return ce([lh,rn(ce([kt(X(r.n,"base64url")),kt(X(r.e,"base64url"))]))]).subarray()}function Ja(r){let t=Jt(r);return Ls(t)}function Ls(r){let t=Is(r);return Ps(t)}function Ts(r,t){if(r.byteLength>=fh)throw new He("Key size is too large");let e=Jt(r,{offset:0});return Cs(e,r,t)}function Cs(r,t,e){let n=Bs(r);if(e==null){let o=Ht(Zt.encode({Type:ht.RSA,Data:t}));e=Kt(vs,o)}return new Je(n,e)}function Ps(r){if(rc(r)>As)throw new ut("Key size is too large");let t=tc(r),e=Ht(Zt.encode({Type:ht.RSA,Data:_s(t.publicKey)})),n=Kt(vs,e);return new Tr(t.privateKey,new Je(t.publicKey,n))}async function Qa(r){if(r>As)throw new ut("Key size is too large");let t=await ec(r),e=Ht(Zt.encode({Type:ht.RSA,Data:_s(t.publicKey)})),n=Kt(vs,e);return new Tr(t.privateKey,new Je(t.publicKey,n))}function tc(r){if(r==null)throw new ut("Missing key parameter");return{privateKey:r,publicKey:{kty:r.kty,n:r.n,e:r.e}}}async function ec(r){let t=await be.get().subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:r,publicExponent:new Uint8Array([1,0,1]),hash:{name:"SHA-256"}},!0,["sign","verify"]),e=await mh(t);return{privateKey:e[0],publicKey:e[1]}}async function Ya(r,t){let e=await be.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await be.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},e,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(n,0,n.byteLength)}async function Xa(r,t,e){let n=await be.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return be.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,t,e instanceof Uint8Array?e:e.subarray())}async function mh(r){if(r.privateKey==null||r.publicKey==null)throw new ut("Private and public key are required");return Promise.all([be.get().subtle.exportKey("jwk",r.privateKey),be.get().subtle.exportKey("jwk",r.publicKey)])}function rc(r){if(r.kty!=="RSA")throw new ut("invalid key type");if(r.n==null)throw new ut("invalid key modulus");return X(r.n,"base64url").length*8}var wn=class extends je{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,gr(t);let n=fe(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),s.fill(0)}update(t){return We(this),this.iHash.update(t),this}digestInto(t){We(this),Ge(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}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},Qe=(r,t,e)=>new wn(r,t).update(e).digest();Qe.create=(r,t)=>new wn(r,t);function nc(r){r.lowS!==void 0&&Gt("lowS",r.lowS),r.prehash!==void 0&&Gt("prehash",r.prehash)}function yh(r){let t=Er(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 Us=class extends Error{constructor(t=""){super(t)}},ee={Err:Us,_tlv:{encode:(r,t)=>{let{Err:e}=ee;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=xr(n);if(o.length/2&128)throw new e("tlv.encode: long form length too big");let s=n>127?xr(o.length/2|128):"";return xr(r)+s+o+t},decode(r,t){let{Err:e}=ee,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 u=t.subarray(n,n+c);if(u.length!==c)throw new e("tlv.decode: length bytes not complete");if(u[0]===0)throw new e("tlv.decode(long): zero leftmost byte");for(let f of u)i=i<<8|f;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}=ee;if(r<re)throw new t("integer: negative integers are not allowed");let e=xr(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}=ee;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 te(r)}},toSig(r){let{Err:t,_int:e,_tlv:n}=ee,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:u,l:f}=n.decode(2,c);if(f.length)throw new t("invalid signature: left bytes after parsing");return{r:e.decode(a),s:e.decode(u)}},hexFromSig(r){let{_tlv:t,_int:e}=ee,n=t.encode(2,e.encode(r.r)),o=t.encode(2,e.encode(r.s)),s=n+o;return t.encode(48,s)}},re=BigInt(0),xt=BigInt(1),Zy=BigInt(2),oc=BigInt(3),Yy=BigInt(4);function gh(r){let t=yh(r),{Fp:e}=t,n=we(t.n,t.nBitLength),o=t.toBytes||((m,h,b)=>{let E=h.toAffine();return ge(Uint8Array.from([4]),e.toBytes(E.x),e.toBytes(E.y))}),s=t.fromBytes||(m=>{let h=m.subarray(1),b=e.fromBytes(h.subarray(0,e.BYTES)),E=e.fromBytes(h.subarray(e.BYTES,2*e.BYTES));return{x:b,y:E}});function i(m){let{a:h,b}=t,E=e.sqr(m),p=e.mul(E,m);return e.add(e.add(p,e.mul(m,h)),b)}if(!e.eql(e.sqr(t.Gy),i(t.Gx)))throw new Error("bad generator point: equation left != right");function a(m){return cn(m,xt,t.n)}function c(m){let{allowedPrivateKeyLengths:h,nByteLength:b,wrapPrivateKey:E,n:p}=t;if(h&&typeof m!="bigint"){if(Ie(m)&&(m=me(m)),typeof m!="string"||!h.includes(m.length))throw new Error("invalid private key");m=m.padStart(b*2,"0")}let v;try{v=typeof m=="bigint"?m:te(ot("private key",m,b))}catch{throw new Error("invalid private key, expected hex or "+b+" bytes, got "+typeof m)}return E&&(v=Z(v,p)),vt("private key",v,xt,p),v}function u(m){if(!(m instanceof d))throw new Error("ProjectivePoint expected")}let f=Ze((m,h)=>{let{px:b,py:E,pz:p}=m;if(e.eql(p,e.ONE))return{x:b,y:E};let v=m.is0();h==null&&(h=v?e.ONE:e.inv(p));let k=e.mul(b,h),P=e.mul(E,h),L=e.mul(p,h);if(v)return{x:e.ZERO,y:e.ZERO};if(!e.eql(L,e.ONE))throw new Error("invZ was invalid");return{x:k,y:P}}),l=Ze(m=>{if(m.is0()){if(t.allowInfinityPoint&&!e.is0(m.py))return;throw new Error("bad point: ZERO")}let{x:h,y:b}=m.toAffine();if(!e.isValid(h)||!e.isValid(b))throw new Error("bad point: x or y not FE");let E=e.sqr(b),p=i(h);if(!e.eql(E,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,b,E){if(h==null||!e.isValid(h))throw new Error("x required");if(b==null||!e.isValid(b))throw new Error("y required");if(E==null||!e.isValid(E))throw new Error("z required");this.px=h,this.py=b,this.pz=E,Object.freeze(this)}static fromAffine(h){let{x:b,y:E}=h||{};if(!h||!e.isValid(b)||!e.isValid(E))throw new Error("invalid affine point");if(h instanceof d)throw new Error("projective point not allowed");let p=v=>e.eql(v,e.ZERO);return p(b)&&p(E)?d.ZERO:new d(b,E,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(h){let b=e.invertBatch(h.map(E=>E.pz));return h.map((E,p)=>E.toAffine(b[p])).map(d.fromAffine)}static fromHex(h){let b=d.fromAffine(s(ot("pointHex",h)));return b.assertValidity(),b}static fromPrivateKey(h){return d.BASE.multiply(c(h))}static msm(h,b){return ln(d,n,h,b)}_setWindowSize(h){x.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){u(h);let{px:b,py:E,pz:p}=this,{px:v,py:k,pz:P}=h,L=e.eql(e.mul(b,P),e.mul(v,p)),C=e.eql(e.mul(E,P),e.mul(k,p));return L&&C}negate(){return new d(this.px,e.neg(this.py),this.pz)}double(){let{a:h,b}=t,E=e.mul(b,oc),{px:p,py:v,pz:k}=this,P=e.ZERO,L=e.ZERO,C=e.ZERO,I=e.mul(p,p),M=e.mul(v,v),R=e.mul(k,k),N=e.mul(p,v);return N=e.add(N,N),C=e.mul(p,k),C=e.add(C,C),P=e.mul(h,C),L=e.mul(E,R),L=e.add(P,L),P=e.sub(M,L),L=e.add(M,L),L=e.mul(P,L),P=e.mul(N,P),C=e.mul(E,C),R=e.mul(h,R),N=e.sub(I,R),N=e.mul(h,N),N=e.add(N,C),C=e.add(I,I),I=e.add(C,I),I=e.add(I,R),I=e.mul(I,N),L=e.add(L,I),R=e.mul(v,k),R=e.add(R,R),I=e.mul(R,N),P=e.sub(P,I),C=e.mul(R,M),C=e.add(C,C),C=e.add(C,C),new d(P,L,C)}add(h){u(h);let{px:b,py:E,pz:p}=this,{px:v,py:k,pz:P}=h,L=e.ZERO,C=e.ZERO,I=e.ZERO,M=t.a,R=e.mul(t.b,oc),N=e.mul(b,v),O=e.mul(E,k),A=e.mul(p,P),B=e.add(b,E),T=e.add(v,k);B=e.mul(B,T),T=e.add(N,O),B=e.sub(B,T),T=e.add(b,p);let S=e.add(v,P);return T=e.mul(T,S),S=e.add(N,A),T=e.sub(T,S),S=e.add(E,p),L=e.add(k,P),S=e.mul(S,L),L=e.add(O,A),S=e.sub(S,L),I=e.mul(M,T),L=e.mul(R,A),I=e.add(L,I),L=e.sub(O,I),I=e.add(O,I),C=e.mul(L,I),O=e.add(N,N),O=e.add(O,N),A=e.mul(M,A),T=e.mul(R,T),O=e.add(O,A),A=e.sub(N,A),A=e.mul(M,A),T=e.add(T,A),N=e.mul(O,T),C=e.add(C,N),N=e.mul(S,T),L=e.mul(B,L),L=e.sub(L,N),N=e.mul(B,O),I=e.mul(S,I),I=e.add(I,N),new d(L,C,I)}subtract(h){return this.add(h.negate())}is0(){return this.equals(d.ZERO)}wNAF(h){return x.wNAFCached(this,h,d.normalizeZ)}multiplyUnsafe(h){let{endo:b,n:E}=t;vt("scalar",h,re,E);let p=d.ZERO;if(h===re)return p;if(this.is0()||h===xt)return this;if(!b||x.hasPrecomputes(this))return x.wNAFCachedUnsafe(this,h,d.normalizeZ);let{k1neg:v,k1:k,k2neg:P,k2:L}=b.splitScalar(h),C=p,I=p,M=this;for(;k>re||L>re;)k&xt&&(C=C.add(M)),L&xt&&(I=I.add(M)),M=M.double(),k>>=xt,L>>=xt;return v&&(C=C.negate()),P&&(I=I.negate()),I=new d(e.mul(I.px,b.beta),I.py,I.pz),C.add(I)}multiply(h){let{endo:b,n:E}=t;vt("scalar",h,xt,E);let p,v;if(b){let{k1neg:k,k1:P,k2neg:L,k2:C}=b.splitScalar(h),{p:I,f:M}=this.wNAF(P),{p:R,f:N}=this.wNAF(C);I=x.constTimeNegate(k,I),R=x.constTimeNegate(L,R),R=new d(e.mul(R.px,b.beta),R.py,R.pz),p=I.add(R),v=M.add(N)}else{let{p:k,f:P}=this.wNAF(h);p=k,v=P}return d.normalizeZ([p,v])[0]}multiplyAndAddUnsafe(h,b,E){let p=d.BASE,v=(P,L)=>L===re||L===xt||!P.equals(p)?P.multiplyUnsafe(L):P.multiply(L),k=v(this,b).add(v(h,E));return k.is0()?void 0:k}toAffine(h){return f(this,h)}isTorsionFree(){let{h,isTorsionFree:b}=t;if(h===xt)return!0;if(b)return b(d,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h,clearCofactor:b}=t;return h===xt?this:b?b(d,this):this.multiplyUnsafe(t.h)}toRawBytes(h=!0){return Gt("isCompressed",h),this.assertValidity(),o(d,this,h)}toHex(h=!0){return Gt("isCompressed",h),me(this.toRawBytes(h))}}d.BASE=new d(t.Gx,t.Gy,e.ONE),d.ZERO=new d(e.ZERO,e.ONE,e.ZERO);let w=t.nBitLength,x=fn(d,t.endo?Math.ceil(w/2):w);return{CURVE:t,ProjectivePoint:d,normPrivateKeyToScalar:c,weierstrassEquation:i,isWithinCurveOrder:a}}function wh(r){let t=Er(r);return qt(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function sc(r){let t=wh(r),{Fp:e,n}=t,o=e.BYTES+1,s=2*e.BYTES+1;function i(A){return Z(A,n)}function a(A){return un(A,n)}let{ProjectivePoint:c,normPrivateKeyToScalar:u,weierstrassEquation:f,isWithinCurveOrder:l}=gh({...t,toBytes(A,B,T){let S=B.toAffine(),y=e.toBytes(S.x),g=ge;return Gt("isCompressed",T),T?g(Uint8Array.from([B.hasEvenY()?2:3]),y):g(Uint8Array.from([4]),y,e.toBytes(S.y))},fromBytes(A){let B=A.length,T=A[0],S=A.subarray(1);if(B===o&&(T===2||T===3)){let y=te(S);if(!cn(y,xt,e.ORDER))throw new Error("Point is not on curve");let g=f(y),_;try{_=e.sqrt(g)}catch(H){let V=H instanceof Error?": "+H.message:"";throw new Error("Point is not on curve"+V)}let U=(_&xt)===xt;return(T&1)===1!==U&&(_=e.neg(_)),{x:y,y:_}}else if(B===s&&T===4){let y=e.fromBytes(S.subarray(0,e.BYTES)),g=e.fromBytes(S.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 "+B)}}}),d=A=>me(Be(A,t.nByteLength));function w(A){let B=n>>xt;return A>B}function x(A){return w(A)?i(-A):A}let m=(A,B,T)=>te(A.slice(B,T));class h{constructor(B,T,S){vt("r",B,xt,n),vt("s",T,xt,n),this.r=B,this.s=T,S!=null&&(this.recovery=S),Object.freeze(this)}static fromCompact(B){let T=t.nByteLength;return B=ot("compactSignature",B,T*2),new h(m(B,0,T),m(B,T,2*T))}static fromDER(B){let{r:T,s:S}=ee.toSig(ot("DER",B));return new h(T,S)}assertValidity(){}addRecoveryBit(B){return new h(this.r,this.s,B)}recoverPublicKey(B){let{r:T,s:S,recovery:y}=this,g=P(ot("msgHash",B));if(y==null||![0,1,2,3].includes(y))throw new Error("recovery id invalid");let _=y===2||y===3?T+t.n:T;if(_>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let U=(y&1)===0?"02":"03",D=c.fromHex(U+d(_)),H=a(_),V=i(-g*H),F=i(S*H),G=c.BASE.multiplyAndAddUnsafe(D,V,F);if(!G)throw new Error("point at infinify");return G.assertValidity(),G}hasHighS(){return w(this.s)}normalizeS(){return this.hasHighS()?new h(this.r,i(-this.s),this.recovery):this}toDERRawBytes(){return br(this.toDERHex())}toDERHex(){return ee.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return br(this.toCompactHex())}toCompactHex(){return d(this.r)+d(this.s)}}let b={isValidPrivateKey(A){try{return u(A),!0}catch{return!1}},normPrivateKeyToScalar:u,randomPrivateKey:()=>{let A=$o(t.n);return va(t.randomBytes(A),t.n)},precompute(A=8,B=c.BASE){return B._setWindowSize(A),B.multiply(BigInt(3)),B}};function E(A,B=!0){return c.fromPrivateKey(A).toRawBytes(B)}function p(A){let B=Ie(A),T=typeof A=="string",S=(B||T)&&A.length;return B?S===o||S===s:T?S===2*o||S===2*s:A instanceof c}function v(A,B,T=!0){if(p(A))throw new Error("first arg must be private key");if(!p(B))throw new Error("second arg must be public key");return c.fromHex(B).multiply(u(A)).toRawBytes(T)}let k=t.bits2int||function(A){if(A.length>8192)throw new Error("input is too large");let B=te(A),T=A.length*8-t.nBitLength;return T>0?B>>BigInt(T):B},P=t.bits2int_modN||function(A){return i(k(A))},L=_e(t.nBitLength);function C(A){return vt("num < 2^"+t.nBitLength,A,re,L),Be(A,t.nByteLength)}function I(A,B,T=M){if(["recovered","canonical"].some(et=>et in T))throw new Error("sign() legacy options not supported");let{hash:S,randomBytes:y}=t,{lowS:g,prehash:_,extraEntropy:U}=T;g==null&&(g=!0),A=ot("msgHash",A),nc(T),_&&(A=ot("prehashed msgHash",S(A)));let D=P(A),H=u(B),V=[C(H),C(D)];if(U!=null&&U!==!1){let et=U===!0?y(e.BYTES):U;V.push(ot("extraEntropy",et))}let F=ge(...V),G=D;function nt(et){let it=k(et);if(!l(it))return;let Ut=a(it),wt=c.BASE.multiply(it).toAffine(),St=i(wt.x);if(St===re)return;let Rt=i(Ut*i(G+St*H));if(Rt===re)return;let Nt=(wt.x===St?0:2)|Number(wt.y&xt),ur=Rt;return g&&w(Rt)&&(ur=x(Rt),Nt^=1),new h(St,ur,Nt)}return{seed:F,k2sig:nt}}let M={lowS:t.lowS,prehash:!1},R={lowS:t.lowS,prehash:!1};function N(A,B,T=M){let{seed:S,k2sig:y}=I(A,B,T),g=t;return xa(g.hash.outputLen,g.nByteLength,g.hmac)(S,y)}c.BASE._setWindowSize(8);function O(A,B,T,S=R){let y=A;B=ot("msgHash",B),T=ot("publicKey",T);let{lowS:g,prehash:_,format:U}=S;if(nc(S),"strict"in S)throw new Error("options.strict was renamed to lowS");if(U!==void 0&&U!=="compact"&&U!=="der")throw new Error("format must be compact or der");let D=typeof y=="string"||Ie(y),H=!D&&!U&&typeof y=="object"&&y!==null&&typeof y.r=="bigint"&&typeof y.s=="bigint";if(!D&&!H)throw new Error("invalid signature, expected Uint8Array, hex string or Signature instance");let V,F;try{if(H&&(V=new h(y.r,y.s)),D){try{U!=="compact"&&(V=h.fromDER(y))}catch(Nt){if(!(Nt instanceof ee.Err))throw Nt}!V&&U!=="der"&&(V=h.fromCompact(y))}F=c.fromHex(T)}catch{return!1}if(!V||g&&V.hasHighS())return!1;_&&(B=t.hash(B));let{r:G,s:nt}=V,et=P(B),it=a(nt),Ut=i(et*it),wt=i(G*it),St=c.BASE.multiplyAndAddUnsafe(F,Ut,wt)?.toAffine();return St?i(St.x)===G:!1}return{CURVE:t,getPublicKey:E,getSharedSecret:v,sign:N,verify:O,ProjectivePoint:c,Signature:h,utils:b}}function xh(r){return{hash:r,hmac:(t,...e)=>Qe(r,t,Ro(...e)),randomBytes:wr}}function ic(r,t){let e=n=>sc({...r,...xh(n)});return{...e(t),create:e}}var uc=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),ac=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),bh=BigInt(1),ks=BigInt(2),cc=(r,t)=>(r+t/ks)/t;function Eh(r){let t=uc,e=BigInt(3),n=BigInt(6),o=BigInt(11),s=BigInt(22),i=BigInt(23),a=BigInt(44),c=BigInt(88),u=r*r*r%t,f=u*u*r%t,l=st(f,e,t)*f%t,d=st(l,e,t)*f%t,w=st(d,ks,t)*u%t,x=st(w,o,t)*w%t,m=st(x,s,t)*x%t,h=st(m,a,t)*m%t,b=st(h,c,t)*h%t,E=st(b,a,t)*m%t,p=st(E,e,t)*f%t,v=st(p,i,t)*x%t,k=st(v,n,t)*u%t,P=st(k,ks,t);if(!Rs.eql(Rs.sqr(P),r))throw new Error("Cannot find square root");return P}var Rs=we(uc,void 0,void 0,{sqrt:Eh}),Re=ic({a:BigInt(0),b:BigInt(7),Fp:Rs,n:ac,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=ac,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-bh*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),o=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),s=e,i=BigInt("0x100000000000000000000000000000000"),a=cc(s*r,t),c=cc(-n*r,t),u=Z(r-a*e-c*o,t),f=Z(-a*n-c*s,t),l=u>i,d=f>i;if(l&&(u=t-u),d&&(f=t-f),u>i||f>i)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:l,k1:u,k2neg:d,k2:f}}}},Ht),sg=BigInt(0);var ig=Re.ProjectivePoint;function fc(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function lc(r,t,e){let n=pr.digest(e instanceof Uint8Array?e:e.subarray());if(fc(n))return n.then(({digest:o})=>Re.verify(t,o,r)).catch(o=>{throw new Lr(String(o))});try{return Re.verify(t,n.digest,r)}catch(o){throw new Lr(String(o))}}var xn=class{type="secp256k1";raw;_key;constructor(t){this._key=dc(t),this.raw=hc(this._key)}toMultihash(){return Mt.digest(ue(this))}toCID(){return lt.createV1(114,this.toMultihash())}toString(){return rt.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:pt(this.raw,t.raw)}verify(t,e){return lc(this._key,e,t)}};function Ds(r){return new xn(r)}function hc(r){return Re.ProjectivePoint.fromHex(r).toRawBytes(!0)}function dc(r){try{return Re.ProjectivePoint.fromHex(r),r}catch(t){throw new He(String(t))}}function Pr(r,t){let{Type:e,Data:n}=Zt.decode(r),o=n??new Uint8Array;switch(e){case ht.RSA:return Ts(o,t);case ht.Ed25519:return rs(o);case ht.secp256k1:return Ds(o);case ht.ECDSA:return ko(o);default:throw new Ee}}function pc(r){let{Type:t,Data:e}=Zt.decode(r.digest),n=e??new Uint8Array;switch(t){case ht.Ed25519:return rs(n);case ht.secp256k1:return Ds(n);case ht.ECDSA:return ko(n);default:throw new Ee}}function ue(r){return Zt.encode({Type:ht[r.type],Data:r.raw})}var mc=Symbol.for("nodejs.util.inspect.custom"),Sh=114,Ur=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()})`}[no]=!0;toString(){return this.string==null&&(this.string=rt.encode(this.multihash.bytes).slice(1)),this.string}toMultihash(){return this.multihash}toCID(){return lt.createV1(Sh,this.multihash)}toJSON(){return this.toString()}equals(t){if(t==null)return!1;if(t instanceof Uint8Array)return pt(this.multihash.bytes,t);if(typeof t=="string")return this.toString()===t;if(t?.toMultihash()?.bytes!=null)return pt(this.multihash.bytes,t.toMultihash().bytes);throw new Error("not valid Id")}[mc](){return`PeerId(${this.toString()})`}},kr=class extends Ur{type="RSA";publicKey;constructor(t){super({...t,type:"RSA"}),this.publicKey=t.publicKey}},Rr=class extends Ur{type="Ed25519";publicKey;constructor(t){super({...t,type:"Ed25519"}),this.publicKey=t.publicKey}},Dr=class extends Ur{type="secp256k1";publicKey;constructor(t){super({...t,type:"secp256k1"}),this.publicKey=t.publicKey}},Ah=2336,Kr=class{type="url";multihash;publicKey;url;constructor(t){this.url=t.toString(),this.multihash=Mt.digest(X(this.url))}[mc](){return`PeerId(${this.url})`}[no]=!0;toString(){return this.toCID().toString()}toMultihash(){return this.multihash}toCID(){return lt.createV1(Ah,this.toMultihash())}toJSON(){return this.toString()}equals(t){return t==null?!1:(t instanceof Uint8Array&&(t=q(t)),t.toString()===this.toString())}};var vh=114,yc=2336;function gc(r,t){let e;if(r.charAt(0)==="1"||r.charAt(0)==="Q")e=ae(rt.decode(`z${r}`));else{if(r.startsWith("k51qzi5uqu5")||r.startsWith("kzwfwjn5ji4")||r.startsWith("k2k4r8")||r.startsWith("bafz"))return Ih(lt.parse(r));if(t==null)throw new ut('Please pass a multibase decoder for strings that do not start with "1" or "Q"');e=ae(t.decode(r))}return wc(e)}function Ks(r){if(r.type==="Ed25519")return new Rr({multihash:r.toCID().multihash,publicKey:r});if(r.type==="secp256k1")return new Dr({multihash:r.toCID().multihash,publicKey:r});if(r.type==="RSA")return new kr({multihash:r.toCID().multihash,publicKey:r});throw new Ee}function wc(r){if(_h(r))return new kr({multihash:r});if(Bh(r))try{let t=pc(r);if(t.type==="Ed25519")return new Rr({multihash:r,publicKey:t});if(t.type==="secp256k1")return new Dr({multihash:r,publicKey:t})}catch{let e=q(r.digest);return new Kr(new URL(e))}throw new Xr("Supplied PeerID Multihash is invalid")}function Ih(r){if(r?.multihash==null||r.version==null||r.version===1&&r.code!==vh&&r.code!==yc)throw new Yr("Supplied PeerID CID is invalid");if(r.code===yc){let t=q(r.multihash.digest);return new Kr(new URL(t))}return wc(r.multihash)}function Bh(r){return r.code===Mt.code}function _h(r){return r.code===pr.code}var bn=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},tr=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},En=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"},Nr=class extends Error{name="UnexpectedEOFError";code="ERR_UNEXPECTED_EOF"};function Sn(r){return r[Symbol.asyncIterator]!=null}function xc(r,t){if(r.byteLength>t)throw new tr("Message length too long")}var vn=r=>{let t=dt(r),e=yt(t);return $t(r,e),vn.bytes=t,e};vn.bytes=0;function bc(r,t){t=t??{};let e=t.lengthEncoder??vn,n=t?.maxDataLength??4194304;function*o(s){xc(s,n);let i=e(s.byteLength);i instanceof Uint8Array?yield i:yield*i,s instanceof Uint8Array?yield s:yield*s}return Sn(r)?async function*(){for await(let s of r)yield*o(s)}():function*(){for(let s of r)yield*o(s)}()}bc.single=(r,t)=>{t=t??{};let e=t.lengthEncoder??vn,n=t?.maxDataLength??4194304;return xc(r,n),new W(e(r.byteLength),r)};var De;(function(r){r[r.LENGTH=0]="LENGTH",r[r.DATA=1]="DATA"})(De||(De={}));var Ns=r=>{let t=Vt(r);return Ns.bytes=dt(t),t};Ns.bytes=0;function Mr(r,t){let e=new W,n=De.LENGTH,o=-1,s=t?.lengthDecoder??Ns,i=t?.maxLengthLength??8,a=t?.maxDataLength??4194304;function*c(){for(;e.byteLength>0;){if(n===De.LENGTH)try{if(o=s(e),o<0)throw new bn("Invalid message length");if(o>a)throw new tr("Message length too long");let u=s.bytes;e.consume(u),t?.onLength!=null&&t.onLength(o),n=De.DATA}catch(u){if(u instanceof RangeError){if(e.byteLength>i)throw new En("Message length length too long");break}throw u}if(n===De.DATA){if(e.byteLength<o)break;let u=e.sublist(0,o);e.consume(o),t?.onData!=null&&t.onData(u),yield u,n=De.LENGTH}}}return Sn(r)?async function*(){for await(let u of r)e.append(u),yield*c();if(e.byteLength>0)throw new Nr("Unexpected end of input")}():function*(){for(let u of r)e.append(u),yield*c();if(e.byteLength>0)throw new Nr("Unexpected end of input")}()}Mr.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 Mr(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 In=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 bt(r,t,e){if(t==null)return r;if(t.aborted)return r.catch(()=>{}),Promise.reject(new In(e?.errorMessage,e?.errorCode,e?.errorName));let n,o=new In(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 Ms=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 bt(this.readNext.promise,e?.signal,e)}};function Bn(){return new Ms}var _n=class extends Error{name="UnexpectedEOFError";code="ERR_UNEXPECTED_EOF"};function Ec(r,t){let e=Bn();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 W;return{read:async i=>{if(i?.signal?.throwIfAborted(),i?.bytes==null){let{done:c,value:u}=await bt(n.next(),i?.signal);return c===!0?null:u}for(;o.byteLength<i.bytes;){let{value:c,done:u}=await bt(n.next(),i?.signal);if(u===!0)throw new _n("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 Ln=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},Tn=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},Cn=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"};function Os(r,t={}){let e=Ec(r,t);t.maxDataLength!=null&&t.maxLengthLength==null&&(t.maxLengthLength=dt(t.maxDataLength));let n=t?.lengthDecoder??Vt,o=t?.lengthEncoder??$t;return{read:async i=>{let a=-1,c=new W;for(;;){c.append(await e.read({...i,bytes:1}));try{a=n(c)}catch(u){if(u instanceof RangeError)continue;throw u}if(a<0)throw new Ln("Invalid message length");if(t?.maxLengthLength!=null&&c.byteLength>t.maxLengthLength)throw new Cn("message length length too long");if(a>-1)break}if(t?.maxDataLength!=null&&a>t.maxDataLength)throw new Tn("message length too long");return e.read({...i,bytes:a})},write:async(i,a)=>{await e.write(new W(o(i.byteLength),i),a)},writeV:async(i,a)=>{let c=new W(...i.flatMap(u=>[o(u.byteLength),u]));await e.write(c,a)},unwrap:()=>e.unwrap()}}function Hs(){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 Sc(){let r=Hs(),t=Hs();return[{source:r.source,sink:t.sink},{source:t.source,sink:r.sink}]}var Pn=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}},er=class{size;hwm;head;tail;constructor(t={}){this.hwm=t.splitLimit??16,this.head=new Pn(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 Pn(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 qs=class extends Error{type;code;constructor(t,e){super(t??"The operation was aborted"),this.type="aborted",this.code=e??"ABORT_ERR"}};function Un(r={}){return Th(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 Th(r,t){t=t??{};let e=t.onEnd,n=new er,o,s,i,a=_t(),c=async()=>{try{return n.isEmpty()?i?{done:!0}:await new Promise((h,b)=>{s=E=>{s=null,n.push(E);try{h(r(n))}catch(p){b(p)}return o}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{a.resolve(),a=_t()})}},u=h=>s!=null?s(h):(n.push(h),o),f=h=>(n=new er,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 u({done:!1,value:h})},d=h=>i?o:(i=!0,h!=null?f(h):u({done:!0})),w=()=>(n=new er,d(),{done:!0}),x=h=>(d(h),{done:!0});if(o={[Symbol.asyncIterator](){return this},next:c,return:w,throw:x,push:l,end:d,get readableLength(){return n.size},onEmpty:async h=>{let b=h?.signal;if(b?.throwIfAborted(),n.isEmpty())return;let E,p;b!=null&&(E=new Promise((v,k)=>{p=()=>{k(new qs)},b.addEventListener("abort",p)}));try{await Promise.race([a.promise,E])}finally{p!=null&&b!=null&&b?.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 Ch(r){return r[Symbol.asyncIterator]!=null}async function Ph(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*Uh(r){let t=Bn();Ph(r,t).catch(()=>{}),yield*t}function*kh(r){for(let t of r)yield*t}function Rh(...r){let t=[];for(let e of r)Ch(e)||t.push(e);return t.length===r.length?kh(t):Uh(r)}var Ac=Rh;function vc(r,...t){if(r==null)throw new Error("Empty pipeline");if(Vs(r)){let n=r;r=()=>n.source}else if(Bc(r)||Ic(r)){let n=r;r=()=>n}let e=[r,...t];if(e.length>1&&Vs(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++)Vs(e[n])&&(e[n]=Kh(e[n]));return Dh(...e)}var Dh=(...r)=>{let t;for(;r.length>0;)t=r.shift()(t);return t},Ic=r=>r?.[Symbol.asyncIterator]!=null,Bc=r=>r?.[Symbol.iterator]!=null,Vs=r=>r==null?!1:r.sink!=null&&r.source!=null,Kh=r=>t=>{let e=r.sink(t);if(e?.then!=null){let n=Un({objectMode:!0});e.then(()=>{n.end()},i=>{n.end(i)});let o,s=r.source;if(Ic(s))o=async function*(){yield*s,n.end()};else if(Bc(s))o=function*(){yield*s,n.end()};else throw new Error("Unknown duplex source type - must be Iterable or AsyncIterable");return Ac(n,o())}return r.source};var rr=!!globalThis.process?.env?.DUMP_SESSION_KEYS;function kn(r){if(!Number.isSafeInteger(r)||r<0)throw new Error("positive integer expected, got "+r)}function Fs(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function Lt(r,...t){if(!Fs(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 zs(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 Gs(r){if(typeof r!="boolean")throw new Error(`boolean expected, not ${r}`)}var ne=r=>new Uint32Array(r.buffer,r.byteOffset,Math.floor(r.byteLength/4)),Lc=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),Nh=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;if(!Nh)throw new Error("Non little-endian hardware is not supported");function Mh(r){if(typeof r!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(r))}function Rn(r){if(typeof r=="string")r=Mh(r);else if(Fs(r))r=Dn(r);else throw new Error("Uint8Array expected, got "+typeof r);return r}function Tc(r,t){if(t==null||typeof t!="object")throw new Error("options must be defined");return Object.assign(r,t)}function Cc(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 Ws=(r,t)=>{function e(n,...o){if(Lt(n),r.nonceLength!==void 0){let f=o[0];if(!f)throw new Error("nonce / iv required");r.varSizeNonce?Lt(f):Lt(f,r.nonceLength)}let s=r.tagLength;s&&o[1]!==void 0&&Lt(o[1]);let i=t(n,...o),a=(f,l)=>{if(l!==void 0){if(f!==2)throw new Error("cipher output not supported");Lt(l)}},c=!1;return{encrypt(f,l){if(c)throw new Error("cannot encrypt() twice with same key + nonce");return c=!0,Lt(f),a(i.encrypt.length,l),i.encrypt(f,l)},decrypt(f,l){if(Lt(f),s&&f.length<s)throw new Error("invalid ciphertext length: smaller than tagLength="+s);return a(i.decrypt.length,l),i.decrypt(f,l)}}}return Object.assign(e,r),e};function js(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&&!Oh(t))throw new Error("invalid output, must be aligned");return t}function $s(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,u=n?0:4;r.setUint32(t+c,i,n),r.setUint32(t+u,a,n)}function Oh(r){return r.byteOffset%4===0}function Dn(r){return Uint8Array.from(r)}function oe(...r){for(let t=0;t<r.length;t++)r[t].fill(0)}var Uc=r=>Uint8Array.from(r.split("").map(t=>t.charCodeAt(0))),Hh=Uc("expand 16-byte k"),qh=Uc("expand 32-byte k"),Vh=ne(Hh),Fh=ne(qh);function K(r,t){return r<<t|r>>>32-t}function Zs(r){return r.byteOffset%4===0}var Kn=64,zh=16,kc=2**32-1,Pc=new Uint32Array;function Gh(r,t,e,n,o,s,i,a){let c=o.length,u=new Uint8Array(Kn),f=ne(u),l=Zs(o)&&Zs(s),d=l?ne(o):Pc,w=l?ne(s):Pc;for(let x=0;x<c;i++){if(r(t,e,n,f,i,a),i>=kc)throw new Error("arx: counter overflow");let m=Math.min(Kn,c-x);if(l&&m===Kn){let h=x/4;if(x%4!==0)throw new Error("arx: invalid block position");for(let b=0,E;b<zh;b++)E=h+b,w[E]=d[E]^f[b];x+=Kn;continue}for(let h=0,b;h<m;h++)b=x+h,s[b]=o[b]^u[h];x+=m}}function Ys(r,t){let{allowShortKeys:e,extendNonceFn:n,counterLength:o,counterRight:s,rounds:i}=Tc({allowShortKeys:!1,counterLength:8,counterRight:!1,rounds:20},t);if(typeof r!="function")throw new Error("core must be a function");return kn(o),kn(i),Gs(s),Gs(e),(a,c,u,f,l=0)=>{Lt(a),Lt(c),Lt(u);let d=u.length;if(f===void 0&&(f=new Uint8Array(d)),Lt(f),kn(l),l<0||l>=kc)throw new Error("arx: counter overflow");if(f.length<d)throw new Error(`arx: output (${f.length}) is shorter than data (${d})`);let w=[],x=a.length,m,h;if(x===32)w.push(m=Dn(a)),h=Fh;else if(x===16&&e)m=new Uint8Array(32),m.set(a),m.set(a,16),h=Vh,w.push(m);else throw new Error(`arx: invalid 32-byte key, got length=${x}`);Zs(c)||w.push(c=Dn(c));let b=ne(m);if(n){if(c.length!==24)throw new Error("arx: extended nonce must be 24 bytes");n(h,b,ne(c.subarray(0,16)),b),c=c.subarray(16)}let E=16-o;if(E!==c.length)throw new Error(`arx: nonce must be ${E} or 16 bytes`);if(E!==12){let v=new Uint8Array(12);v.set(c,s?0:12-c.length),c=v,w.push(c)}let p=ne(c);return Gh(r,h,b,p,u,f,l,i),oe(...w),f}}var Et=(r,t)=>r[t++]&255|(r[t++]&255)<<8,Xs=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=Rn(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),u=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|u<<8)&8191,this.r[9]=u>>>5&127;for(let f=0;f<8;f++)this.pad[f]=Et(t,16+2*f)}process(t,e,n=!1){let o=n?0:2048,{h:s,r:i}=this,a=i[0],c=i[1],u=i[2],f=i[3],l=i[4],d=i[5],w=i[6],x=i[7],m=i[8],h=i[9],b=Et(t,e+0),E=Et(t,e+2),p=Et(t,e+4),v=Et(t,e+6),k=Et(t,e+8),P=Et(t,e+10),L=Et(t,e+12),C=Et(t,e+14),I=s[0]+(b&8191),M=s[1]+((b>>>13|E<<3)&8191),R=s[2]+((E>>>10|p<<6)&8191),N=s[3]+((p>>>7|v<<9)&8191),O=s[4]+((v>>>4|k<<12)&8191),A=s[5]+(k>>>1&8191),B=s[6]+((k>>>14|P<<2)&8191),T=s[7]+((P>>>11|L<<5)&8191),S=s[8]+((L>>>8|C<<8)&8191),y=s[9]+(C>>>5|o),g=0,_=g+I*a+M*(5*h)+R*(5*m)+N*(5*x)+O*(5*w);g=_>>>13,_&=8191,_+=A*(5*d)+B*(5*l)+T*(5*f)+S*(5*u)+y*(5*c),g+=_>>>13,_&=8191;let U=g+I*c+M*a+R*(5*h)+N*(5*m)+O*(5*x);g=U>>>13,U&=8191,U+=A*(5*w)+B*(5*d)+T*(5*l)+S*(5*f)+y*(5*u),g+=U>>>13,U&=8191;let D=g+I*u+M*c+R*a+N*(5*h)+O*(5*m);g=D>>>13,D&=8191,D+=A*(5*x)+B*(5*w)+T*(5*d)+S*(5*l)+y*(5*f),g+=D>>>13,D&=8191;let H=g+I*f+M*u+R*c+N*a+O*(5*h);g=H>>>13,H&=8191,H+=A*(5*m)+B*(5*x)+T*(5*w)+S*(5*d)+y*(5*l),g+=H>>>13,H&=8191;let V=g+I*l+M*f+R*u+N*c+O*a;g=V>>>13,V&=8191,V+=A*(5*h)+B*(5*m)+T*(5*x)+S*(5*w)+y*(5*d),g+=V>>>13,V&=8191;let F=g+I*d+M*l+R*f+N*u+O*c;g=F>>>13,F&=8191,F+=A*a+B*(5*h)+T*(5*m)+S*(5*x)+y*(5*w),g+=F>>>13,F&=8191;let G=g+I*w+M*d+R*l+N*f+O*u;g=G>>>13,G&=8191,G+=A*c+B*a+T*(5*h)+S*(5*m)+y*(5*x),g+=G>>>13,G&=8191;let nt=g+I*x+M*w+R*d+N*l+O*f;g=nt>>>13,nt&=8191,nt+=A*u+B*c+T*a+S*(5*h)+y*(5*m),g+=nt>>>13,nt&=8191;let et=g+I*m+M*x+R*w+N*d+O*l;g=et>>>13,et&=8191,et+=A*f+B*u+T*c+S*a+y*(5*h),g+=et>>>13,et&=8191;let it=g+I*h+M*m+R*x+N*w+O*d;g=it>>>13,it&=8191,it+=A*l+B*f+T*u+S*c+y*a,g+=it>>>13,it&=8191,g=(g<<2)+g|0,g=g+_|0,_=g&8191,g=g>>>13,U+=g,s[0]=_,s[1]=U,s[2]=D,s[3]=H,s[4]=V,s[5]=F,s[6]=G,s[7]=nt,s[8]=et,s[9]=it}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;oe(n)}update(t){zs(this);let{buffer:e,blockLen:n}=this;t=Rn(t);let 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(){oe(this.h,this.r,this.buffer,this.pad)}digestInto(t){zs(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 Wh(r){let t=(n,o)=>r(o).update(Rn(n)).digest(),e=r(new Uint8Array(32));return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=n=>r(n),t}var Rc=Wh(r=>new Xs(r));function Nc(r,t,e,n,o,s=20){let i=r[0],a=r[1],c=r[2],u=r[3],f=t[0],l=t[1],d=t[2],w=t[3],x=t[4],m=t[5],h=t[6],b=t[7],E=o,p=e[0],v=e[1],k=e[2],P=i,L=a,C=c,I=u,M=f,R=l,N=d,O=w,A=x,B=m,T=h,S=b,y=E,g=p,_=v,U=k;for(let H=0;H<s;H+=2)P=P+M|0,y=K(y^P,16),A=A+y|0,M=K(M^A,12),P=P+M|0,y=K(y^P,8),A=A+y|0,M=K(M^A,7),L=L+R|0,g=K(g^L,16),B=B+g|0,R=K(R^B,12),L=L+R|0,g=K(g^L,8),B=B+g|0,R=K(R^B,7),C=C+N|0,_=K(_^C,16),T=T+_|0,N=K(N^T,12),C=C+N|0,_=K(_^C,8),T=T+_|0,N=K(N^T,7),I=I+O|0,U=K(U^I,16),S=S+U|0,O=K(O^S,12),I=I+O|0,U=K(U^I,8),S=S+U|0,O=K(O^S,7),P=P+R|0,U=K(U^P,16),T=T+U|0,R=K(R^T,12),P=P+R|0,U=K(U^P,8),T=T+U|0,R=K(R^T,7),L=L+N|0,y=K(y^L,16),S=S+y|0,N=K(N^S,12),L=L+N|0,y=K(y^L,8),S=S+y|0,N=K(N^S,7),C=C+O|0,g=K(g^C,16),A=A+g|0,O=K(O^A,12),C=C+O|0,g=K(g^C,8),A=A+g|0,O=K(O^A,7),I=I+M|0,_=K(_^I,16),B=B+_|0,M=K(M^B,12),I=I+M|0,_=K(_^I,8),B=B+_|0,M=K(M^B,7);let D=0;n[D++]=i+P|0,n[D++]=a+L|0,n[D++]=c+C|0,n[D++]=u+I|0,n[D++]=f+M|0,n[D++]=l+R|0,n[D++]=d+N|0,n[D++]=w+O|0,n[D++]=x+A|0,n[D++]=m+B|0,n[D++]=h+T|0,n[D++]=b+S|0,n[D++]=E+y|0,n[D++]=p+g|0,n[D++]=v+_|0,n[D++]=k+U|0}function jh(r,t,e,n){let o=r[0],s=r[1],i=r[2],a=r[3],c=t[0],u=t[1],f=t[2],l=t[3],d=t[4],w=t[5],x=t[6],m=t[7],h=e[0],b=e[1],E=e[2],p=e[3];for(let k=0;k<20;k+=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+u|0,b=K(b^s,16),w=w+b|0,u=K(u^w,12),s=s+u|0,b=K(b^s,8),w=w+b|0,u=K(u^w,7),i=i+f|0,E=K(E^i,16),x=x+E|0,f=K(f^x,12),i=i+f|0,E=K(E^i,8),x=x+E|0,f=K(f^x,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+u|0,p=K(p^o,16),x=x+p|0,u=K(u^x,12),o=o+u|0,p=K(p^o,8),x=x+p|0,u=K(u^x,7),s=s+f|0,h=K(h^s,16),m=m+h|0,f=K(f^m,12),s=s+f|0,h=K(h^s,8),m=m+h|0,f=K(f^m,7),i=i+l|0,b=K(b^i,16),d=d+b|0,l=K(l^d,12),i=i+l|0,b=K(b^i,8),d=d+b|0,l=K(l^d,7),a=a+c|0,E=K(E^a,16),w=w+E|0,c=K(c^w,12),a=a+c|0,E=K(E^a,8),w=w+E|0,c=K(c^w,7);let v=0;n[v++]=o,n[v++]=s,n[v++]=i,n[v++]=a,n[v++]=h,n[v++]=b,n[v++]=E,n[v++]=p}var $h=Ys(Nc,{counterRight:!1,counterLength:4,allowShortKeys:!1}),Zh=Ys(Nc,{counterRight:!1,counterLength:8,extendNonceFn:jh,allowShortKeys:!1});var Yh=new Uint8Array(16),Dc=(r,t)=>{r.update(t);let e=t.length%16;e&&r.update(Yh.subarray(e))},Xh=new Uint8Array(32);function Kc(r,t,e,n,o){let s=r(t,e,Xh),i=Rc.create(s);o&&Dc(i,o),Dc(i,n);let a=new Uint8Array(16),c=Lc(a);$s(c,0,BigInt(o?o.length:0),!0),$s(c,8,BigInt(n.length),!0),i.update(a);let u=i.digest();return oe(s,a),u}var Mc=r=>(t,e,n)=>({encrypt(s,i){let a=s.length;i=js(a+16,i,!1),i.set(s);let c=i.subarray(0,-16);r(t,e,c,c,1);let u=Kc(r,t,e,c,n);return i.set(u,a),oe(u),i},decrypt(s,i){i=js(s.length-16,i,!1);let a=s.subarray(0,-16),c=s.subarray(-16),u=Kc(r,t,e,a,n);if(!Cc(c,u))throw new Error("invalid tag");return i.set(s.subarray(0,-16)),r(t,e,i,i,1),oe(u),i}}),Js=Ws({blockSize:64,nonceLength:12,tagLength:16},Mc($h)),gx=Ws({blockSize:64,nonceLength:24,tagLength:16},Mc(Zh));function Hc(r,t,e){return gr(r),e===void 0&&(e=new Uint8Array(r.outputLen)),Qe(r,fe(e),fe(t))}var Qs=new Uint8Array([0]),Oc=new Uint8Array;function qc(r,t,e,n=32){if(gr(r),nn(n),n>255*r.outputLen)throw new Error("Length should be <= 255*HashLen");let o=Math.ceil(n/r.outputLen);e===void 0&&(e=Oc);let s=new Uint8Array(o*r.outputLen),i=Qe.create(r,t),a=i._cloneInto(),c=new Uint8Array(i.outputLen);for(let u=0;u<o;u++)Qs[0]=u+1,a.update(u===0?Oc:c).update(e).update(Qs).digestInto(c),s.set(c,r.outputLen*u),i._cloneInto(a);return i.destroy(),a.destroy(),c.fill(0),Qs.fill(0),s.slice(0,n)}var ti={hashSHA256(r){return Ht(r.subarray())},getHKDF(r,t){let e=Hc(Ht,t,r),o=qc(Ht,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=Ar.utils.randomPrivateKey();return{publicKey:Ar.getPublicKey(r),privateKey:r}},generateX25519KeyPairFromSeed(r){return{publicKey:Ar.getPublicKey(r),privateKey:r}},generateX25519SharedKey(r,t){return Ar.getSharedSecret(r.subarray(),t.subarray())},chaCha20Poly1305Encrypt(r,t,e,n){return Js(n,t,e).encrypt(r.subarray())},chaCha20Poly1305Decrypt(r,t,e,n,o){return Js(n,t,e).decrypt(r.subarray(),o)}};var Vc=ti;function Fc(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 nr=r=>{let t=yt(2);return t[0]=r>>8,t[1]=r,t};nr.bytes=2;var Or=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)};Or.bytes=2;function zc(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 ei(r,t){!t.enabled||!rr||(r?(t(`LOCAL_STATIC_PUBLIC_KEY ${q(r.publicKey,"hex")}`),t(`LOCAL_STATIC_PRIVATE_KEY ${q(r.privateKey,"hex")}`)):t("Missing local static keys."))}function ri(r,t){!t.enabled||!rr||(r?(t(`LOCAL_PUBLIC_EPHEMERAL_KEY ${q(r.publicKey,"hex")}`),t(`LOCAL_PRIVATE_EPHEMERAL_KEY ${q(r.privateKey,"hex")}`)):t("Missing local ephemeral keys."))}function Gc(r,t){!t.enabled||!rr||t(r?`REMOTE_STATIC_PUBLIC_KEY ${q(r.subarray(),"hex")}`:"Missing remote static public key.")}function ni(r,t){!t.enabled||!rr||t(r?`REMOTE_EPHEMERAL_PUBLIC_KEY ${q(r.subarray(),"hex")}`:"Missing remote ephemeral keys.")}function oi(r,t,e){!e.enabled||!rr||(e(`CIPHER_STATE_1 ${r.n.getUint64()} ${r.k&&q(r.k,"hex")}`),e(`CIPHER_STATE_2 ${t.n.getUint64()} ${t.k&&q(t.k,"hex")}`))}var or=class r extends Error{code;constructor(t="Invalid crypto exchange"){super(t),this.code=r.code}static code="ERR_INVALID_CRYPTO_EXCHANGE"};var Jh=0,Qh=4294967295,td="Cipherstate has reached maximum n, a new handshake must be performed",Nn=class{n;bytes;view;constructor(t=Jh){this.n=t,this.bytes=mt(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>Qh)throw new Error(td)}};var Ke=mt(0),sr=class{k;n;crypto;constructor(t,e=void 0,n=0){this.crypto=t,this.k=e,this.n=new Nn(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}},si=class{cs;ck;h;crypto;constructor(t,e){this.crypto=t;let n=X(e,"utf-8");this.h=ed(t,n),this.ck=this.h,this.cs=new sr(t)}mixKey(t){let[e,n]=this.crypto.hkdf(this.ck,t);this.ck=e,this.cs=new sr(this.crypto,n)}mixHash(t){this.h=this.crypto.hash(new W(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,Ke);return[new sr(this.crypto,t),new sr(this.crypto,e)]}},ii=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:u}=t;this.crypto=e,this.ss=new si(e,n),this.ss.mixHash(o),this.initiator=s,this.s=i,this.e=a,this.rs=c,this.re=u}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()}},Hr=class extends ii{writeMessageA(t){return new W(this.writeE(),this.ss.encryptAndHash(t))}writeMessageB(t){let e=this.writeE();this.writeEE();let n=this.writeS();return this.writeES(),new W(e,n,this.ss.encryptAndHash(t))}writeMessageC(t){let e=this.writeS();return this.writeSE(),new W(e,this.ss.encryptAndHash(t))}readMessageA(t){try{return this.readE(t),this.ss.decryptAndHash(t.sublist(32))}catch(e){throw new or(`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 or(`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 or(`handshake stage 2 validation fail: ${e.message}`)}}};function ed(r,t){if(t.length<=32){let e=mt(32);return e.set(t),e}else return r.hash(t)}var Mn;(function(r){let t;r.codec=()=>(t==null&&(t=ke((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 _r('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 _r('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=>Ue(e,r.codec()),r.decode=(e,n)=>Ce(e,r.codec(),n)})(Mn||(Mn={}));var qr;(function(r){let t;r.codec=()=>(t==null&&(t=ke((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),Mn.codec().encode(e.extensions,n)),o.lengthDelimited!==!1&&n.ldelim()},(e,n,o={})=>{let s={identityKey:mt(0),identitySig:mt(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=Mn.codec().decode(e,e.uint32(),{limits:o.limits?.extensions});break}default:{e.skipType(a&7);break}}}return s})),t),r.encode=e=>Ue(e,r.codec()),r.decode=(e,n)=>Ce(e,r.codec(),n)})(qr||(qr={}));async function ai(r,t,e){let n=await r.sign(Wc(t));return qr.encode({identityKey:ue(r.publicKey),identitySig:n,extensions:e})}async function ci(r,t,e){try{let n=qr.decode(r),o=Pr(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=Wc(t);if(!await o.verify(s,n.identitySig))throw new Error("Invalid payload signature");return n}catch(n){throw new Wr(n.message)}}function Wc(r){let t=X("noise-libp2p-static-key:");return r instanceof Uint8Array?At([t,r],t.length+r.length):(r.prepend(t),r)}async function jc(r,t){let{log:e,connection:n,crypto:o,privateKey:s,prologue:i,s:a,remoteIdentityKey:c,extensions:u}=r,f=await ai(s,a.publicKey,u),l=new Hr({crypto:o,protocolName:"Noise_XX_25519_ChaChaPoly_SHA256",initiator:!0,prologue:i,s:a});ei(l.s,e),e.trace("Stage 0 - Initiator starting to send first message."),await n.write(l.writeMessageA(Ke),t),e.trace("Stage 0 - Initiator finished sending first message."),ri(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."),ni(l.re,e),Gc(l.rs,e),e.trace("Initiator going to check remote's signature...");let w=await ci(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(f),t),e.trace("Stage 2 - Initiator sent message with signed payload.");let[x,m]=l.ss.split();return oi(x,m,e),{payload:w,encrypt:h=>x.encryptWithAd(Ke,h),decrypt:(h,b)=>m.decryptWithAd(Ke,h,b)}}async function $c(r,t){let{log:e,connection:n,crypto:o,privateKey:s,prologue:i,s:a,remoteIdentityKey:c,extensions:u}=r,f=await ai(s,a.publicKey,u),l=new Hr({crypto:o,protocolName:"Noise_XX_25519_ChaChaPoly_SHA256",initiator:!1,prologue:i,s:a});ei(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."),ni(l.re,e),e.trace("Stage 1 - Responder sending out first message with signed payload and static key."),await n.write(l.writeMessageB(f),t),e.trace("Stage 1 - Responder sent the second handshake message with signed payload."),ri(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 w=await ci(d,l.rs,c),[x,m]=l.ss.split();return oi(x,m,e),{payload:w,encrypt:h=>m.encryptWithAd(Ke,h),decrypt:(h,b)=>x.decryptWithAd(Ke,h,b)}}var Yc=16;function Xc(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 W(nr(i.byteLength),i)}}}function Jc(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-Yc<o)throw new Error("Invalid chunk");let i=n.sublist(o,s),a=n.subarray(o,s-Yc);try{let c=r.decrypt(i,a);t?.decryptedPackets.increment(),yield c}catch(c){throw t?.decryptErrors.increment(),c}}}}var On=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??Vc;this.crypto=Fc(c),this.extensions={webtransportCerthashes:[],...o},this.metrics=a?zc(a):void 0,n?this.staticKey=c.generateX25519KeyPairFromSeed(n):this.staticKey=c.generateX25519KeyPair(),this.prologue=i??mt(0)}[Symbol.toStringTag]="@chainsafe/libp2p-noise";[Jr]=["@libp2p/connection-encryption","@chainsafe/libp2p-noise"];async secureOutbound(t,e){let n=Os(t,{lengthEncoder:nr,lengthDecoder:Or,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=Pr(o.payload.identityKey);return{conn:t,remoteExtensions:o.payload.extensions,remotePeer:Ks(i),streamMuxer:this.getStreamMuxer(o.payload.extensions?.streamMuxers)}}getStreamMuxer(t){if(t==null)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 Oe("Early muxer negotiation was requested but the initiator and responder had no common muxers")}async secureInbound(t,e){let n=Os(t,{lengthEncoder:nr,lengthDecoder:Or,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=Pr(o.payload.identityKey);return{conn:t,remoteExtensions:o.payload.extensions,remotePeer:Ks(i),streamMuxer:this.getStreamMuxer(o.payload.extensions?.streamMuxers)}}async performHandshakeInitiator(t,e,n,o){let s;try{s=await jc({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:[...this.components.upgrader.getStreamMuxers().keys()],webtransportCerthashes:[],...this.extensions}},o),this.metrics?.xxHandshakeSuccesses.increment()}catch(i){throw this.metrics?.xxHandshakeErrors.increment(),i}return s}async performHandshakeResponder(t,e,n,o){let s;try{s=await $c({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:[...this.components.upgrader.getStreamMuxers().keys()],webtransportCerthashes:[],...this.extensions}},o),this.metrics?.xxHandshakeSuccesses.increment()}catch(i){throw this.metrics?.xxHandshakeErrors.increment(),i}return s}async createSecureConnection(t,e){let[n,o]=Sc(),s=t.unwrap();return await vc(n,Xc(e,this.metrics),s,i=>Mr(i,{lengthDecoder:Or}),Jc(e,this.metrics),n),o}};function Qc(r={}){return t=>new On(t,r)}var Hn=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",u=2**(8*o)-1;for(;;){let f=this.readAtomically(()=>{let l=this.readChar();if(l===void 0)return;let d=Number.parseInt(l,t);if(!Number.isNaN(d))return d});if(f===void 0)break;if(s*=t,s+=f,s>u||(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 tu=45,rd=15,ir=new Hn;function ui(r){if(!(r.length>rd))return ir.new(r).parseWith(()=>ir.readIPv4Addr())}function fi(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>tu))return ir.new(r).parseWith(()=>ir.readIPv6Addr())}function qn(r,t=!1){if(r.includes("%")&&(r=r.split("%")[0]),r.length>tu)return;let e=ir.new(r).parseWith(()=>ir.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 Vn(r){return!!ui(r)}function Fn(r){return!!fi(r)}function zn(r){return!!qn(r)}var nd=r=>r.toString().split("/").slice(1),ar=r=>({match:t=>t.length<1?!1:r(t[0])?t.slice(1):!1,pattern:"fn"}),j=r=>({match:t=>ar(e=>e===r).match(t),pattern:r}),Ne=()=>({match:r=>ar(t=>typeof t=="string").match(r),pattern:"{string}"}),Fr=()=>({match:r=>ar(t=>!isNaN(parseInt(t))).match(r),pattern:"{number}"}),tt=()=>({match:r=>{if(r.length<2||r[0]!=="p2p"&&r[0]!=="ipfs")return!1;if(r[1].startsWith("Q")||r[1].startsWith("1"))try{rt.decode(`z${r[1]}`)}catch{return!1}else return!1;return r.slice(2)},pattern:"/p2p/{peerid}"}),zr=()=>({match:r=>{if(r.length<2||r[0]!=="certhash")return!1;try{bo.decode(r[1])}catch{return!1}return r.slice(2)},pattern:"/certhash/{certhash}"}),Y=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(", ")})`}),$=(...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 ct(...r){function t(o){let s=nd(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 od=tt(),Qb=ct(od),Wn=$(j("dns4"),Ne()),jn=$(j("dns6"),Ne()),$n=$(j("dnsaddr"),Ne()),hi=$(j("dns"),Ne()),t1=ct(Wn,Y(tt())),e1=ct(jn,Y(tt())),r1=ct($n,Y(tt())),n1=ct(Tt(hi,$n,Wn,jn),Y(tt())),eu=$(j("ip4"),ar(Vn)),ru=$(j("ip6"),ar(Fn)),di=Tt(eu,ru),se=Tt(di,hi,Wn,jn,$n),o1=ct(Tt(di,$(Tt(hi,$n,Wn,jn),Y(tt())))),s1=ct(eu),i1=ct(ru),a1=ct(di),pi=$(se,j("tcp"),Fr()),Gr=$(se,j("udp"),Fr()),c1=ct($(pi,Y(tt()))),u1=ct(Gr),mi=$(Gr,j("quic"),Y(tt())),Zn=$(Gr,j("quic-v1"),Y(tt())),sd=Tt(mi,Zn),f1=ct(mi),l1=ct(Zn),li=Tt(se,pi,Gr,mi,Zn),nu=Tt($(li,j("ws"),Y(tt()))),h1=ct(nu),ou=Tt($(li,j("wss"),Y(tt())),$(li,j("tls"),Y($(j("sni"),Ne())),j("ws"),Y(tt()))),d1=ct(ou),su=$(Gr,j("webrtc-direct"),Y(zr()),Y(zr()),Y(tt())),p1=ct(su),iu=$(Zn,j("webtransport"),Y(zr()),Y(zr()),Y(tt())),Yn=ct(iu),Gn=Tt(nu,ou,$(pi,Y(tt())),$(sd,Y(tt())),$(se,Y(tt())),su,iu,tt()),m1=ct(Gn),id=$(Gn,j("p2p-circuit"),tt()),y1=ct(id),ad=Tt($(Gn,j("p2p-circuit"),j("webrtc"),Y(tt())),$(Gn,j("webrtc"),Y(tt())),$(j("webrtc"),Y(tt()))),g1=ct(ad),cd=Tt($(se,j("tcp"),Fr(),j("http"),Y(tt())),$(se,j("http"),Y(tt()))),w1=ct(cd),ud=Tt($(se,j("tcp"),Tt($(j("443"),j("http")),$(Fr(),j("https"))),Y(tt())),$(se,j("tls"),j("http"),Y(tt())),$(se,j("https"),Y(tt()))),x1=ct(ud),fd=Tt($(j("memory"),Ne(),Y(tt()))),b1=ct(fd);var Me=class extends Event{type;detail;constructor(t,e){super(t),this.type=t,this.detail=e}};function yi(r){throw new Error("Not implemented")}function au(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 cu(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function uu(r,t){let e=au(r).return?.();cu(e)&&e.catch(n=>{t.error("could not cause iterator to return",n)})}var ld=5e3;function gi(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}var Xn=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??ld,this.onEnd=t.onEnd,this.onCloseRead=t?.onCloseRead,this.onCloseWrite=t?.onCloseWrite,this.onReset=t?.onReset,this.onAbort=t?.onAbort,this.source=this.streamSource=Un({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 $r(`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);gi(o)&&await o}let n=()=>{uu(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 W(o):o;let s=this.sendData(o,e);gi(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 bt(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 bt(this.sink([]),t.signal)),this.writeStatus==="writing"&&(this.sendingData!=null&&await bt(this.sendingData.promise,t.signal),this.log.trace("aborting source passed to .sink"),this.sinkController.abort(),await bt(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();gi(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 jr("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 wi=class extends Xn{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 W(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 bt(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 bt(this.writer.abort(),t?.signal),this.log("sendReset aborted writer")}async sendCloseWrite(t){this.log("sendCloseWrite closing writer"),await bt(this.writer.close(),t?.signal),this.log("sendCloseWrite closed writer")}async sendCloseRead(t){this.log("sendCloseRead cancelling reader"),await bt(this.reader.cancel(),t?.signal),this.log("sendCloseRead cancelled reader")}};async function xi(r,t,e,n,o,s){let i=s.forComponent(`libp2p:webtransport:stream:${e}:${t}`),a=new wi({bidiStream:r,id:t,direction:e,log:i,onEnd:()=>{let c=n.findIndex(u=>u===a);c!==-1&&n.splice(c,1),o?.(a)}});return a}function Jn(){return{source:{[Symbol.asyncIterator](){return{async next(){return new Promise(()=>{})}}}},sink:async r=>new Promise(()=>{})}}function fu(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:u,value:f}=await t.read();if(u)break;if(a.length>=n.maxInboundStreams)s(`too many inbound streams open - ${a.length}/${n.maxInboundStreams}, closing new incoming stream`),f.writable.close().catch(l=>{s.error(`failed to close inbound stream that crossed our maxInboundStream limit: ${l.message}`)}),f.readable.cancel().catch(l=>{s.error(`failed to close inbound stream that crossed our maxInboundStream limit: ${l.message}`)});else{let l=await xi(f,String(o++),"inbound",a,i?.onStreamEnd,e);a.push(l),i?.onIncomingStream?.(l)}}}).catch(u=>{s.error("could not create a new stream",u)});let c={protocol:"webtransport",streams:a,newStream:async u=>{s("new outgoing stream",u);let f=await r.createBidirectionalStream(),l=await xi(f,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(u){c.abort(u)}},abort:u=>{s("closing webtransport muxer with err:",u);try{r.close()}catch(f){s.error("webtransport session threw error during close",f)}},...Jn()};return c}}}function lu(r,t){return t.filter(n=>!!r.find(o=>pt(n,o))).length===t.length}var Q1=parseInt("0xFFFF",16),t2=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);var pu=Vn,yd=Fn,bi=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(yd(r)){let e=r.split(":",8),n;for(n=0;n<e.length;n++){let s=pu(e[n]),i;s&&(i=bi(e[n]),e[n]=q(i.slice(0,2),"base16")),i!=null&&++n<8&&e.splice(n,0,q(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")},mu=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 cr={},Ei={},wd=[[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"]];wd.forEach(r=>{let t=xd(...r);Ei[t.code]=t,cr[t.name]=t});function xd(r,t,e,n,o){return{code:r,size:t,name:e,resolvable:!!n,path:!!o}}function Q(r){if(typeof r=="number"){if(Ei[r]!=null)return Ei[r];throw new Error(`no protocol with code: ${r}`)}else if(typeof r=="string"){if(cr[r]!=null)return cr[r];throw new Error(`no protocol with name: ${r}`)}throw new Error(`invalid protocol id type: ${typeof r}`)}var D2=Q("ip4"),K2=Q("ip6"),N2=Q("ipcidr");function Ii(r,t){switch(Q(r).code){case 4:case 41:return Ed(t);case 42:return vi(t);case 43:return q(t,"base10");case 6:case 273:case 33:case 132:return wu(t).toString();case 53:case 54:case 55:case 56:case 400:case 449:case 777:return vi(t);case 421:return Id(t);case 444:return gu(t);case 445:return gu(t);case 466:return vd(t);case 481:return globalThis.encodeURIComponent(vi(t));default:return q(t,"base16")}}function Bi(r,t){switch(Q(r).code){case 4:return yu(t);case 41:return yu(t);case 42:return Ai(t);case 43:return X(t,"base10");case 6:case 273:case 33:case 132:return _i(parseInt(t,10));case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Ai(t);case 421:return Sd(t);case 444:return Bd(t);case 445:return _d(t);case 466:return Ad(t);case 481:return Ai(globalThis.decodeURIComponent(t));default:return X(t,"base16")}}var Si=Object.values(Ae).map(r=>r.decoder),bd=function(){let r=Si[0].or(Si[1]);return Si.slice(2).forEach(t=>r=r.or(t)),r}();function yu(r){if(!zn(r))throw new Error("invalid ip address");return bi(r)}function Ed(r){let t=mu(r,0,r.length);if(t==null)throw new Error("ipBuff is required");if(!zn(t))throw new Error("invalid ip address");return t}function _i(r){let t=new ArrayBuffer(2);return new DataView(t).setUint16(0,r),new Uint8Array(t)}function wu(r){return new DataView(r.buffer).getUint16(r.byteOffset)}function Ai(r){let t=X(r),e=Uint8Array.from($t(t.length));return At([e,t],e.length+t.length)}function vi(r){let t=Vt(r);if(r=r.slice(dt(t)),r.length!==t)throw new Error("inconsistent lengths");return q(r)}function Sd(r){let t;r[0]==="Q"||r[0]==="1"?t=ae(rt.decode(`z${r}`)).bytes:t=lt.parse(r).multihash.bytes;let e=Uint8Array.from($t(t.length));return At([e,t],e.length+t.length)}function Ad(r){let t=bd.decode(r),e=Uint8Array.from($t(t.length));return At([e,t],e.length+t.length)}function vd(r){let t=Vt(r),e=r.slice(dt(t));if(e.length!==t)throw new Error("inconsistent lengths");return"u"+q(e,"base64url")}function Id(r){let t=Vt(r),e=r.slice(dt(t));if(e.length!==t)throw new Error("inconsistent lengths");return q(e,"base58btc")}function Bd(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=Xt.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=_i(n);return At([e,o],e.length+o.length)}function _d(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=Xt.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=_i(n);return At([e,o],e.length+o.length)}function gu(r){let t=r.slice(0,r.length-2),e=r.slice(r.length-2),n=q(t,"base32"),o=wu(e);return`${n}:${o}`}function xu(r){r=Li(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=Q(i);if(a.size===0){t.push([a.code]),e.push([a.code]);continue}if(s++,s>=o.length)throw new Qn("invalid address: "+r);if(a.path===!0){n=Li(o.slice(s).join("/")),t.push([a.code,Bi(a.code,n)]),e.push([a.code,n]);break}let c=Bi(a.code,o[s]);t.push([a.code,c]),e.push([a.code,Ii(a.code,c)])}return{string:bu(e),bytes:to(t),tuples:t,stringTuples:e,path:n}}function Ti(r){let t=[],e=[],n=null,o=0;for(;o<r.length;){let s=Vt(r,o),i=dt(s),a=Q(s),c=Ld(a,r.slice(o+i));if(c===0){t.push([s]),e.push([s]),o+=i;continue}let u=r.slice(o+i,o+i+c);if(o+=c+i,o>r.length)throw new Qn("Invalid address Uint8Array: "+q(r,"base16"));t.push([s,u]);let f=Ii(s,u);if(e.push([s,f]),a.path===!0){n=f;break}}return{bytes:Uint8Array.from(r),string:bu(e),tuples:t,stringTuples:e,path:n}}function bu(r){let t=[];return r.map(e=>{let n=Q(e[0]);return t.push(n.name),e.length>1&&e[1]!=null&&t.push(e[1]),null}),Li(t.join("/"))}function to(r){return At(r.map(t=>{let e=Q(t[0]),n=Uint8Array.from($t(e.code));return t.length>1&&t[1]!=null&&(n=At([n,t[1]])),n}))}function Ld(r,t){if(r.size>0)return r.size/8;if(r.size===0)return 0;{let e=Vt(t instanceof Uint8Array?t:Uint8Array.from(t));return e+dt(e)}}function Li(r){return"/"+r.trim().split("/").filter(t=>t).join("/")}var Qn=class extends Error{static name="ParseError";name="ParseError";constructor(t){super(`Error parsing address: ${t}`)}};var Td=Symbol.for("nodejs.util.inspect.custom"),Pi=Symbol.for("@multiformats/js-multiaddr/multiaddr"),Cd=[Q("dns").code,Q("dns4").code,Q("dns6").code,Q("dnsaddr").code],Ci=class extends Error{constructor(t="No available resolver"){super(t),this.name="NoAvailableResolverError"}},eo=class r{bytes;#e;#t;#r;#n;[Pi]=!0;constructor(t){t==null&&(t="");let e;if(t instanceof Uint8Array)e=Ti(t);else if(typeof t=="string"){if(t.length>0&&t.charAt(0)!=="/")throw new Error(`multiaddr "${t}" must start with a "/"`);e=xu(t)}else if(Su(t))e=Ti(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=Q("tcp"),a=Q("udp"),c=Q("ip4"),u=Q("ip6"),f=Q("dns6"),l=Q("ip6zone");for(let[w,x]of this.stringTuples())w===l.code&&(s=`%${x??""}`),Cd.includes(w)&&(e=i.name==="tcp"?"tcp":"udp",o=443,n=`${x??""}${s}`,t=w===f.code?6:4),(w===i.code||w===a.code)&&(e=Q(w).name==="tcp"?"tcp":"udp",o=parseInt(x??"")),(w===c.code||w===u.code)&&(e=Q(w).name==="tcp"?"tcp":"udp",n=`${x??""}${s}`,t=w===u.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({},Q(t)))}protoCodes(){return this.#t.map(([t])=>t)}protoNames(){return this.#t.map(([t])=>Q(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(to(e.slice(0,n)));return this}getPeerId(){try{let t=[];this.stringTuples().forEach(([n,o])=>{n===cr.p2p.code&&t.push([n,o]),n===cr["p2p-circuit"].code&&(t=[])});let e=t.pop();if(e?.[1]!=null){let n=e[1];return n[0]==="Q"||n[0]==="1"?q(rt.decode(`z${n}`),"base58btc"):q(lt.parse(n).multihash.bytes,"base58btc")}return null}catch{return null}}getPath(){return this.#n}equals(t){return pt(this.bytes,t.bytes)}async resolve(t){let e=this.protos().find(s=>s.resolvable);if(e==null)return[this];let n=Eu.get(e.name);if(n==null)throw new Ci(`no available resolver for ${e.name}`);return(await n(this,t)).map(s=>Ui(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)}[Td](){return`Multiaddr(${this.#e})`}};var Eu=new Map;function Su(r){return!!r?.[Pi]}function Ui(r){return new eo(r)}var Pd=Object.values(Ae).map(r=>r.decoder).reduce((r,t)=>r.or(t));function Ud(r){return zt.decode(Pd.decode(r))}function ki(r){if(!Yn.matches(r))throw new Zr("Invalid multiaddr, was not a WebTransport address");let t=r.stringTuples(),e=t.filter(([i,a])=>i===Q("certhash").code).map(([i,a])=>Ud(a??"")),n=t.filter(([i,a])=>i===Q("p2p").code).map(([i,a])=>gc(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 Au=globalThis.WebTransport;var Ri=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";[Ni]=!0;[Jr]=["@libp2p/transport"];async dial(t,e){e.signal.throwIfAborted(),this.log("dialing %s",t),e=e??{};let{url:n,certhashes:o,remotePeer:s}=ki(t),i,a,c=()=>{},u=!1,f=!1,l=!1;try{this.metrics?.dialerEvents.increment({pending:!0});let d=new Au(`${n}/.well-known/libp2p-webtransport?type=noise`,{serverCertificateHashes:o.map(w=>({algorithm:"sha-256",value:w.digest}))});if(c=w=>{if(!u)try{this.metrics?.dialerEvents.increment({[w]:!0}),d.close()}catch(x){this.log.error("error closing wt session",x)}finally{a!=null&&(a.timeline.close=Date.now()),u=!0}},i=()=>{c(f?"noise_timeout":"ready_timeout")},e.signal.addEventListener("abort",i,{once:!0}),this.log("wait for session to be ready"),e.onProgress?.(new Me("webtransport:wait-for-session")),await Promise.race([d.closed,d.ready]),this.log("session became ready"),f=!0,this.metrics?.dialerEvents.increment({ready:!0}),d.closed.catch(w=>{this.log.error("error on remote wt session close",w)}).finally(()=>{c("remote_close")}),l=await bt(this.authenticateWebTransport({wt:d,remotePeer:s,certhashes:o,...e}),e.signal),!l)throw new Oe("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"),...Jn()},await e.upgrader.upgradeOutbound(a,{...e,skipEncryption:!0,muxerFactory:fu(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":f?"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 Me("webtransport:open-authentication-stream"));let i=await t.createBidirectionalStream(),a=i.writable.getWriter(),c=i.readable.getReader(),u={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 w of d){await bt(a.ready,s);let x=w instanceof Uint8Array?w:w.subarray();a.write(x).catch(m=>{this.log.error("could not write chunk during authentication of WebTransport stream",m)})}}},f=Qc()(this.components);o?.(new Me("webtransport:secure-outbound-connection"));let{remoteExtensions:l}=await f.secureOutbound(u,{signal:s,remotePeer:e});if(o?.(new Me("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 ut("Our certhashes are not a subset of the remote's reported certhashes");return!0}createListener(t){return yi(this.components,{...t,certificates:this.config.certificates,maxInboundStreams:this.config.maxInboundStreams})}listenFilter(){return[]}dialFilter(t){return globalThis.WebTransport==null?[]:t.filter(e=>{if(!Yn.exactMatch(e))return!1;let{url:n,certhashes:o}=ki(e);return n!=null&&o.length>0})}};function kd(r={}){return t=>new Ri(t,r)}return Uu(Rd);})();
|
|
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>&&(C=C.add(M)),B>&&(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;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>),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);})();
|
|
3
3
|
//! TODO unclear how to add backpressure here?
|
|
4
4
|
/*! Bundled license information:
|
|
5
5
|
|
|
@@ -7,29 +7,13 @@
|
|
|
7
7
|
(*! noble-hashes - MIT License (c) 2022 Paul Miller (paulmillr.com) *)
|
|
8
8
|
|
|
9
9
|
@noble/curves/esm/abstract/utils.js:
|
|
10
|
-
(*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) *)
|
|
11
|
-
|
|
12
10
|
@noble/curves/esm/abstract/modular.js:
|
|
13
|
-
(*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) *)
|
|
14
|
-
|
|
15
11
|
@noble/curves/esm/abstract/curve.js:
|
|
16
|
-
(*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) *)
|
|
17
|
-
|
|
18
12
|
@noble/curves/esm/abstract/edwards.js:
|
|
19
|
-
(*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) *)
|
|
20
|
-
|
|
21
13
|
@noble/curves/esm/abstract/montgomery.js:
|
|
22
|
-
(*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) *)
|
|
23
|
-
|
|
24
14
|
@noble/curves/esm/ed25519.js:
|
|
25
|
-
(*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) *)
|
|
26
|
-
|
|
27
15
|
@noble/curves/esm/abstract/weierstrass.js:
|
|
28
|
-
(*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) *)
|
|
29
|
-
|
|
30
16
|
@noble/curves/esm/_shortw_utils.js:
|
|
31
|
-
(*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) *)
|
|
32
|
-
|
|
33
17
|
@noble/curves/esm/secp256k1.js:
|
|
34
18
|
(*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) *)
|
|
35
19
|
|
|
@@ -37,3 +21,4 @@
|
|
|
37
21
|
(*! noble-ciphers - MIT License (c) 2023 Paul Miller (paulmillr.com) *)
|
|
38
22
|
*/
|
|
39
23
|
return Libp2PWebtransport}));
|
|
24
|
+
//# sourceMappingURL=index.min.js.map
|