@libp2p/plaintext 2.0.9 → 2.0.10

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.min.js CHANGED
@@ -1,9 +1,9 @@
1
1
  (function (root, factory) {(typeof module === 'object' && module.exports) ? module.exports = factory() : root.Libp2PPlaintext = factory()}(typeof self !== 'undefined' ? self : this, function () {
2
- "use strict";var Libp2PPlaintext=(()=>{var oc=Object.create;var Br=Object.defineProperty;var ic=Object.getOwnPropertyDescriptor;var ac=Object.getOwnPropertyNames;var cc=Object.getPrototypeOf,lc=Object.prototype.hasOwnProperty;var uc=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),ht=(r,t)=>{for(var e in t)Br(r,e,{get:t[e],enumerable:!0})},Uo=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of ac(t))!lc.call(r,s)&&s!==e&&Br(r,s,{get:()=>t[s],enumerable:!(n=ic(t,s))||n.enumerable});return r};var fc=(r,t,e)=>(e=r!=null?oc(cc(r)):{},Uo(t||!r||!r.__esModule?Br(e,"default",{value:r,enumerable:!0}):e,r)),hc=r=>Uo(Br({},"__esModule",{value:!0}),r);var Li=uc($e=>{"use strict";var Du="[object ArrayBuffer]",qt=class r{static isArrayBuffer(t){return Object.prototype.toString.call(t)===Du}static toArrayBuffer(t){return this.isArrayBuffer(t)?t:t.byteLength===t.buffer.byteLength||t.byteOffset===0&&t.byteLength===t.buffer.byteLength?t.buffer:this.toUint8Array(t.buffer).slice(t.byteOffset,t.byteOffset+t.byteLength).buffer}static toUint8Array(t){return this.toView(t,Uint8Array)}static toView(t,e){if(t.constructor===e)return t;if(this.isArrayBuffer(t))return new e(t);if(this.isArrayBufferView(t))return new e(t.buffer,t.byteOffset,t.byteLength);throw new TypeError("The provided value is not of type '(ArrayBuffer or ArrayBufferView)'")}static isBufferSource(t){return this.isArrayBufferView(t)||this.isArrayBuffer(t)}static isArrayBufferView(t){return ArrayBuffer.isView(t)||t&&this.isArrayBuffer(t.buffer)}static isEqual(t,e){let n=r.toUint8Array(t),s=r.toUint8Array(e);if(n.length!==s.byteLength)return!1;for(let o=0;o<n.length;o++)if(n[o]!==s[o])return!1;return!0}static concat(...t){let e;Array.isArray(t[0])&&!(t[1]instanceof Function)||Array.isArray(t[0])&&t[1]instanceof Function?e=t[0]:t[t.length-1]instanceof Function?e=t.slice(0,t.length-1):e=t;let n=0;for(let i of e)n+=i.byteLength;let s=new Uint8Array(n),o=0;for(let i of e){let a=this.toUint8Array(i);s.set(a,o),o+=a.length}return t[t.length-1]instanceof Function?this.toView(s,t[t.length-1]):s.buffer}},oo="string",Ou=/^[0-9a-f]+$/i,Mu=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,Pu=/^[a-zA-Z0-9-_]+$/,qr=class{static fromString(t){let e=unescape(encodeURIComponent(t)),n=new Uint8Array(e.length);for(let s=0;s<e.length;s++)n[s]=e.charCodeAt(s);return n.buffer}static toString(t){let e=qt.toUint8Array(t),n="";for(let o=0;o<e.length;o++)n+=String.fromCharCode(e[o]);return decodeURIComponent(escape(n))}},St=class{static toString(t,e=!1){let n=qt.toArrayBuffer(t),s=new DataView(n),o="";for(let i=0;i<n.byteLength;i+=2){let a=s.getUint16(i,e);o+=String.fromCharCode(a)}return o}static fromString(t,e=!1){let n=new ArrayBuffer(t.length*2),s=new DataView(n);for(let o=0;o<t.length;o++)s.setUint16(o*2,t.charCodeAt(o),e);return n}},zr=class r{static isHex(t){return typeof t===oo&&Ou.test(t)}static isBase64(t){return typeof t===oo&&Mu.test(t)}static isBase64Url(t){return typeof t===oo&&Pu.test(t)}static ToString(t,e="utf8"){let n=qt.toUint8Array(t);switch(e.toLowerCase()){case"utf8":return this.ToUtf8String(n);case"binary":return this.ToBinary(n);case"hex":return this.ToHex(n);case"base64":return this.ToBase64(n);case"base64url":return this.ToBase64Url(n);case"utf16le":return St.toString(n,!0);case"utf16":case"utf16be":return St.toString(n);default:throw new Error(`Unknown type of encoding '${e}'`)}}static FromString(t,e="utf8"){if(!t)return new ArrayBuffer(0);switch(e.toLowerCase()){case"utf8":return this.FromUtf8String(t);case"binary":return this.FromBinary(t);case"hex":return this.FromHex(t);case"base64":return this.FromBase64(t);case"base64url":return this.FromBase64Url(t);case"utf16le":return St.fromString(t,!0);case"utf16":case"utf16be":return St.fromString(t);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToBase64(t){let e=qt.toUint8Array(t);if(typeof btoa<"u"){let n=this.ToString(e,"binary");return btoa(n)}else return Buffer.from(e).toString("base64")}static FromBase64(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isBase64(e))throw new TypeError("Argument 'base64Text' is not Base64 encoded");return typeof atob<"u"?this.FromBinary(atob(e)):new Uint8Array(Buffer.from(e,"base64")).buffer}static FromBase64Url(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isBase64Url(e))throw new TypeError("Argument 'base64url' is not Base64Url encoded");return this.FromBase64(this.Base64Padding(e.replace(/\-/g,"+").replace(/\_/g,"/")))}static ToBase64Url(t){return this.ToBase64(t).replace(/\+/g,"-").replace(/\//g,"_").replace(/\=/g,"")}static FromUtf8String(t,e=r.DEFAULT_UTF8_ENCODING){switch(e){case"ascii":return this.FromBinary(t);case"utf8":return qr.fromString(t);case"utf16":case"utf16be":return St.fromString(t);case"utf16le":case"usc2":return St.fromString(t,!0);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToUtf8String(t,e=r.DEFAULT_UTF8_ENCODING){switch(e){case"ascii":return this.ToBinary(t);case"utf8":return qr.toString(t);case"utf16":case"utf16be":return St.toString(t);case"utf16le":case"usc2":return St.toString(t,!0);default:throw new Error(`Unknown type of encoding '${e}'`)}}static FromBinary(t){let e=t.length,n=new Uint8Array(e);for(let s=0;s<e;s++)n[s]=t.charCodeAt(s);return n.buffer}static ToBinary(t){let e=qt.toUint8Array(t),n="";for(let s=0;s<e.length;s++)n+=String.fromCharCode(e[s]);return n}static ToHex(t){let e=qt.toUint8Array(t),n="",s=e.length;for(let o=0;o<s;o++){let i=e[o];i<16&&(n+="0"),n+=i.toString(16)}return n}static FromHex(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isHex(e))throw new TypeError("Argument 'hexString' is not HEX encoded");e.length%2&&(e=`0${e}`);let n=new Uint8Array(e.length/2);for(let s=0;s<e.length;s=s+2){let o=e.slice(s,s+2);n[s/2]=parseInt(o,16)}return n.buffer}static ToUtf16String(t,e=!1){return St.toString(t,e)}static FromUtf16String(t,e=!1){return St.fromString(t,e)}static Base64Padding(t){let e=4-t.length%4;if(e<4)for(let n=0;n<e;n++)t+="=";return t}static formatString(t){return t?.replace(/[\n\r\t ]/g,"")||""}};zr.DEFAULT_UTF8_ENCODING="utf8";function Fu(r,...t){let e=arguments[0];for(let n=1;n<arguments.length;n++){let s=arguments[n];for(let o in s)e[o]=s[o]}return e}function Ku(...r){let t=r.map(s=>s.byteLength).reduce((s,o)=>s+o),e=new Uint8Array(t),n=0;return r.map(s=>new Uint8Array(s)).forEach(s=>{for(let o of s)e[n++]=o}),e.buffer}function $u(r,t){if(!(r&&t)||r.byteLength!==t.byteLength)return!1;let e=new Uint8Array(r),n=new Uint8Array(t);for(let s=0;s<r.byteLength;s++)if(e[s]!==n[s])return!1;return!0}$e.BufferSourceConverter=qt;$e.Convert=zr;$e.assign=Fu;$e.combine=Ku;$e.isEqual=$u});var ff={};ht(ff,{plaintext:()=>uf});var Xn=Symbol.for("@libp2p/peer-id");var Er=class extends Error{static name="UnexpectedPeerError";constructor(t="Unexpected Peer"){super(t),this.name="UnexpectedPeerError"}},Xe=class extends Error{static name="InvalidCryptoExchangeError";constructor(t="Invalid crypto exchange"){super(t),this.name="InvalidCryptoExchangeError"}},dt=class extends Error{static name="InvalidParametersError";constructor(t="Invalid parameters"){super(t),this.name="InvalidParametersError"}},Ne=class extends Error{static name="InvalidPublicKeyError";constructor(t="Invalid public key"){super(t),this.name="InvalidPublicKeyError"}};var Ce=class extends Error{static name="ProtocolError";constructor(t="Protocol error"){super(t),this.name="ProtocolError"}};var Ar=class extends Error{static name="UnsupportedKeyTypeError";constructor(t="Unsupported key type"){super(t),this.name="UnsupportedKeyTypeError"}};var To=Symbol.for("@libp2p/service-capabilities"),pf=Symbol.for("@libp2p/service-dependencies");var ns={};ht(ns,{base58btc:()=>Q,base58flickr:()=>yc});var Mf=new Uint8Array(0);function Lo(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function Ot(r){if(r instanceof Uint8Array&&r.constructor.name==="Uint8Array")return r;if(r instanceof ArrayBuffer)return new Uint8Array(r);if(ArrayBuffer.isView(r))return new Uint8Array(r.buffer,r.byteOffset,r.byteLength);throw new Error("Unknown type, must be binary type")}function Ro(r){return new TextEncoder().encode(r)}function _o(r){return new TextDecoder().decode(r)}function dc(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 s=0;s<r.length;s++){var o=r.charAt(s),i=o.charCodeAt(0);if(e[i]!==255)throw new TypeError(o+" is ambiguous");e[i]=s}var a=r.length,c=r.charAt(0),f=Math.log(a)/Math.log(256),l=Math.log(256)/Math.log(a);function u(v){if(v instanceof Uint8Array||(ArrayBuffer.isView(v)?v=new Uint8Array(v.buffer,v.byteOffset,v.byteLength):Array.isArray(v)&&(v=Uint8Array.from(v))),!(v instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(v.length===0)return"";for(var b=0,d=0,y=0,E=v.length;y!==E&&v[y]===0;)y++,b++;for(var p=(E-y)*l+1>>>0,S=new Uint8Array(p);y!==E;){for(var L=v[y],T=0,k=p-1;(L!==0||T<d)&&k!==-1;k--,T++)L+=256*S[k]>>>0,S[k]=L%a>>>0,L=L/a>>>0;if(L!==0)throw new Error("Non-zero carry");d=T,y++}for(var I=p-d;I!==p&&S[I]===0;)I++;for(var U=c.repeat(b);I<p;++I)U+=r.charAt(S[I]);return U}function h(v){if(typeof v!="string")throw new TypeError("Expected String");if(v.length===0)return new Uint8Array;var b=0;if(v[b]!==" "){for(var d=0,y=0;v[b]===c;)d++,b++;for(var E=(v.length-b)*f+1>>>0,p=new Uint8Array(E);v[b];){var S=e[v.charCodeAt(b)];if(S===255)return;for(var L=0,T=E-1;(S!==0||L<y)&&T!==-1;T--,L++)S+=a*p[T]>>>0,p[T]=S%256>>>0,S=S/256>>>0;if(S!==0)throw new Error("Non-zero carry");y=L,b++}if(v[b]!==" "){for(var k=E-y;k!==E&&p[k]===0;)k++;for(var I=new Uint8Array(d+(E-k)),U=d;k!==E;)I[U++]=p[k++];return I}}}function x(v){var b=h(v);if(b)return b;throw new Error(`Non-${t} character`)}return{encode:u,decodeUnsafe:h,decode:x}}var gc=dc,pc=gc,Ho=pc;var Qn=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")}},ts=class{name;prefix;baseDecode;prefixCodePoint;constructor(t,e,n){this.name=t,this.prefix=e;let s=e.codePointAt(0);if(s===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=s,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 Do(this,t)}},es=class{decoders;constructor(t){this.decoders=t}or(t){return Do(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 Do(r,t){return new es({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var rs=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(t,e,n,s){this.name=t,this.prefix=e,this.baseEncode=n,this.baseDecode=s,this.encoder=new Qn(t,e,n),this.decoder=new ts(t,e,s)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function Ue({name:r,prefix:t,encode:e,decode:n}){return new rs(r,t,e,n)}function te({name:r,prefix:t,alphabet:e}){let{encode:n,decode:s}=Ho(e,r);return Ue({prefix:t,name:r,encode:n,decode:o=>Ot(s(o))})}function mc(r,t,e,n){let s={};for(let l=0;l<t.length;++l)s[t[l]]=l;let o=r.length;for(;r[o-1]==="=";)--o;let i=new Uint8Array(o*e/8|0),a=0,c=0,f=0;for(let l=0;l<o;++l){let u=s[r[l]];if(u===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<e|u,a+=e,a>=8&&(a-=8,i[f++]=255&c>>a)}if(a>=e||255&c<<8-a)throw new SyntaxError("Unexpected end of data");return i}function bc(r,t,e){let n=t[t.length-1]==="=",s=(1<<e)-1,o="",i=0,a=0;for(let c=0;c<r.length;++c)for(a=a<<8|r[c],i+=8;i>e;)i-=e,o+=t[s&a>>i];if(i!==0&&(o+=t[s&a<<e-i]),n)for(;o.length*e&7;)o+="=";return o}function Z({name:r,prefix:t,bitsPerChar:e,alphabet:n}){return Ue({prefix:t,name:r,encode(s){return bc(s,n,e)},decode(s){return mc(s,n,e,r)}})}var Q=te({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),yc=te({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var ss={};ht(ss,{base32:()=>Te,base32hex:()=>Bc,base32hexpad:()=>Ac,base32hexpadupper:()=>Sc,base32hexupper:()=>Ec,base32pad:()=>xc,base32padupper:()=>vc,base32upper:()=>wc,base32z:()=>kc});var Te=Z({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),wc=Z({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),xc=Z({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),vc=Z({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),Bc=Z({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),Ec=Z({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),Ac=Z({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),Sc=Z({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),kc=Z({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var os={};ht(os,{base36:()=>Qe,base36upper:()=>Ic});var Qe=te({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),Ic=te({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Nc=Po,Oo=128,Cc=127,Uc=~Cc,Tc=Math.pow(2,31);function Po(r,t,e){t=t||[],e=e||0;for(var n=e;r>=Tc;)t[e++]=r&255|Oo,r/=128;for(;r&Uc;)t[e++]=r&255|Oo,r>>>=7;return t[e]=r|0,Po.bytes=e-n+1,t}var Lc=is,Rc=128,Mo=127;function is(r,n){var e=0,n=n||0,s=0,o=n,i,a=r.length;do{if(o>=a)throw is.bytes=0,new RangeError("Could not decode varint");i=r[o++],e+=s<28?(i&Mo)<<s:(i&Mo)*Math.pow(2,s),s+=7}while(i>=Rc);return is.bytes=o-n,e}var _c=Math.pow(2,7),Vc=Math.pow(2,14),Hc=Math.pow(2,21),Dc=Math.pow(2,28),Oc=Math.pow(2,35),Mc=Math.pow(2,42),Pc=Math.pow(2,49),Fc=Math.pow(2,56),Kc=Math.pow(2,63),$c=function(r){return r<_c?1:r<Vc?2:r<Hc?3:r<Dc?4:r<Oc?5:r<Mc?6:r<Pc?7:r<Fc?8:r<Kc?9:10},qc={encode:Nc,decode:Lc,encodingLength:$c},zc=qc,tr=zc;function er(r,t=0){return[tr.decode(r,t),tr.decode.bytes]}function Le(r,t,e=0){return tr.encode(r,t,e),t}function Re(r){return tr.encodingLength(r)}function kt(r,t){let e=t.byteLength,n=Re(r),s=n+Re(e),o=new Uint8Array(s+e);return Le(r,o,0),Le(e,o,n),o.set(t,s),new _e(r,e,t,o)}function as(r){let t=Ot(r),[e,n]=er(t),[s,o]=er(t.subarray(n)),i=t.subarray(n+o);if(i.byteLength!==s)throw new Error("Incorrect length");return new _e(e,s,i,t)}function Fo(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&Lo(r.bytes,e.bytes)}}var _e=class{code;size;digest;bytes;constructor(t,e,n,s){this.code=t,this.size=e,this.digest=n,this.bytes=s}};function Ko(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return jc(e,cs(r),t??Q.encoder);default:return Zc(e,cs(r),t??Te.encoder)}}var $o=new WeakMap;function cs(r){let t=$o.get(r);if(t==null){let e=new Map;return $o.set(r,e),e}return t}var Et=class r{code;version;multihash;bytes;"/";constructor(t,e,n,s){this.code=e,this.version=t,this.multihash=n,this.bytes=s,this["/"]=s}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!==rr)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==Wc)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&&Fo(t.multihash,n.multihash)}toString(t){return Ko(this,t)}toJSON(){return{"/":Ko(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:s,multihash:o,bytes:i}=e;return new r(n,s,o,i??qo(n,s,o.bytes))}else if(e[Jc]===!0){let{version:n,multihash:s,code:o}=e,i=as(s);return r.create(n,o,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!==rr)throw new Error(`Version 0 CID must use dag-pb (code: ${rr}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let s=qo(t,e,n.bytes);return new r(t,e,n,s)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,rr,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,s=Ot(t.subarray(n,n+e.multihashSize));if(s.byteLength!==e.multihashSize)throw new Error("Incorrect length");let o=s.subarray(e.multihashSize-e.digestSize),i=new _e(e.multihashCode,e.digestSize,o,s);return[e.version===0?r.createV0(i):r.createV1(e.codec,i),t.subarray(e.size)]}static inspectBytes(t){let e=0,n=()=>{let[u,h]=er(t.subarray(e));return e+=h,u},s=n(),o=rr;if(s===18?(s=0,e=0):o=n(),s!==0&&s!==1)throw new RangeError(`Invalid CID version ${s}`);let i=e,a=n(),c=n(),f=e+c,l=f-i;return{version:s,codec:o,multihashCode:a,digestSize:c,multihashSize:l,size:f}}static parse(t,e){let[n,s]=Gc(t,e),o=r.decode(s);if(o.version===0&&t[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return cs(o).set(n,t),o}};function Gc(r,t){switch(r[0]){case"Q":{let e=t??Q;return[Q.prefix,e.decode(`${Q.prefix}${r}`)]}case Q.prefix:{let e=t??Q;return[Q.prefix,e.decode(r)]}case Te.prefix:{let e=t??Te;return[Te.prefix,e.decode(r)]}case Qe.prefix:{let e=t??Qe;return[Qe.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 jc(r,t,e){let{prefix:n}=e;if(n!==Q.prefix)throw Error(`Cannot string encode V0 in ${e.name} encoding`);let s=t.get(n);if(s==null){let o=e.encode(r).slice(1);return t.set(n,o),o}else return s}function Zc(r,t,e){let{prefix:n}=e,s=t.get(n);if(s==null){let o=e.encode(r);return t.set(n,o),o}else return s}var rr=112,Wc=18;function qo(r,t,e){let n=Re(r),s=n+Re(t),o=new Uint8Array(s+e.byteLength);return Le(r,o,0),Le(t,o,n),o.set(e,s),o}var Jc=Symbol.for("@ipld/js-cid/CID");var ls={};ht(ls,{identity:()=>ee});var zo=0,Yc="identity",Go=Ot;function Xc(r){return kt(zo,Go(r))}var ee={code:zo,name:Yc,encode:Go,digest:Xc};function mt(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 jo(r){if(!Number.isSafeInteger(r)||r<0)throw new Error(`positive integer expected, not ${r}`)}function Qc(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function He(r,...t){if(!Qc(r))throw new Error("Uint8Array expected");if(t.length>0&&!t.includes(r.length))throw new Error(`Uint8Array expected of length ${t}, not of length=${r.length}`)}function Zo(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");jo(r.outputLen),jo(r.blockLen)}function De(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 Wo(r,t){He(r);let e=t.outputLen;if(r.length<e)throw new Error(`digestInto() expects output buffer of length at least ${e}`)}var pe=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;var kr=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),It=(r,t)=>r<<32-t|r>>>t;var ch=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;function Jo(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function nr(r){return typeof r=="string"&&(r=Jo(r)),He(r),r}function us(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];He(s),t+=s.length}let e=new Uint8Array(t);for(let n=0,s=0;n<r.length;n++){let o=r[n];e.set(o,s),s+=o.length}return e}var Oe=class{clone(){return this._cloneInto()}},lh={}.toString;function Ir(r){let t=n=>r().update(nr(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function Nr(r=32){if(pe&&typeof pe.getRandomValues=="function")return pe.getRandomValues(new Uint8Array(r));if(pe&&typeof pe.randomBytes=="function")return pe.randomBytes(r);throw new Error("crypto.getRandomValues must be defined")}function tl(r,t,e,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(t,e,n);let s=BigInt(32),o=BigInt(4294967295),i=Number(e>>s&o),a=Number(e&o),c=n?4:0,f=n?0:4;r.setUint32(t+c,i,n),r.setUint32(t+f,a,n)}var Yo=(r,t,e)=>r&t^~r&e,Xo=(r,t,e)=>r&t^r&e^t&e,Me=class extends Oe{constructor(t,e,n,s){super(),this.blockLen=t,this.outputLen=e,this.padOffset=n,this.isLE=s,this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.buffer=new Uint8Array(t),this.view=kr(this.buffer)}update(t){De(this);let{view:e,buffer:n,blockLen:s}=this;t=nr(t);let o=t.length;for(let i=0;i<o;){let a=Math.min(s-this.pos,o-i);if(a===s){let c=kr(t);for(;s<=o-i;i+=s)this.process(c,i);continue}n.set(t.subarray(i,i+a),this.pos),this.pos+=a,i+=a,this.pos===s&&(this.process(e,0),this.pos=0)}return this.length+=t.length,this.roundClean(),this}digestInto(t){De(this),Wo(t,this),this.finished=!0;let{buffer:e,view:n,blockLen:s,isLE:o}=this,{pos:i}=this;e[i++]=128,this.buffer.subarray(i).fill(0),this.padOffset>s-i&&(this.process(n,0),i=0);for(let u=i;u<s;u++)e[u]=0;tl(n,s-8,BigInt(this.length*8),o),this.process(n,0);let a=kr(t),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let f=c/4,l=this.get();if(f>l.length)throw new Error("_sha2: outputLen bigger than state");for(let u=0;u<f;u++)a.setUint32(4*u,l[u],o)}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:s,finished:o,destroyed:i,pos:a}=this;return t.length=s,t.pos=a,t.finished=o,t.destroyed=i,s%e&&t.buffer.set(n),t}};var Cr=BigInt(4294967295),fs=BigInt(32);function Qo(r,t=!1){return t?{h:Number(r&Cr),l:Number(r>>fs&Cr)}:{h:Number(r>>fs&Cr)|0,l:Number(r&Cr)|0}}function el(r,t=!1){let e=new Uint32Array(r.length),n=new Uint32Array(r.length);for(let s=0;s<r.length;s++){let{h:o,l:i}=Qo(r[s],t);[e[s],n[s]]=[o,i]}return[e,n]}var rl=(r,t)=>BigInt(r>>>0)<<fs|BigInt(t>>>0),nl=(r,t,e)=>r>>>e,sl=(r,t,e)=>r<<32-e|t>>>e,ol=(r,t,e)=>r>>>e|t<<32-e,il=(r,t,e)=>r<<32-e|t>>>e,al=(r,t,e)=>r<<64-e|t>>>e-32,cl=(r,t,e)=>r>>>e-32|t<<64-e,ll=(r,t)=>t,ul=(r,t)=>r,fl=(r,t,e)=>r<<e|t>>>32-e,hl=(r,t,e)=>t<<e|r>>>32-e,dl=(r,t,e)=>t<<e-32|r>>>64-e,gl=(r,t,e)=>r<<e-32|t>>>64-e;function pl(r,t,e,n){let s=(t>>>0)+(n>>>0);return{h:r+e+(s/2**32|0)|0,l:s|0}}var ml=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),bl=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,yl=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),wl=(r,t,e,n,s)=>t+e+n+s+(r/2**32|0)|0,xl=(r,t,e,n,s)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(s>>>0),vl=(r,t,e,n,s,o)=>t+e+n+s+o+(r/2**32|0)|0;var Bl={fromBig:Qo,split:el,toBig:rl,shrSH:nl,shrSL:sl,rotrSH:ol,rotrSL:il,rotrBH:al,rotrBL:cl,rotr32H:ll,rotr32L:ul,rotlSH:fl,rotlSL:hl,rotlBH:dl,rotlBL:gl,add:pl,add3L:ml,add3H:bl,add4L:yl,add4H:wl,add5H:vl,add5L:xl},V=Bl;var[El,Al]=V.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))),re=new Uint32Array(80),ne=new Uint32Array(80),hs=class extends Me{constructor(){super(128,64,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:s,Ch:o,Cl:i,Dh:a,Dl:c,Eh:f,El:l,Fh:u,Fl:h,Gh:x,Gl:v,Hh:b,Hl:d}=this;return[t,e,n,s,o,i,a,c,f,l,u,h,x,v,b,d]}set(t,e,n,s,o,i,a,c,f,l,u,h,x,v,b,d){this.Ah=t|0,this.Al=e|0,this.Bh=n|0,this.Bl=s|0,this.Ch=o|0,this.Cl=i|0,this.Dh=a|0,this.Dl=c|0,this.Eh=f|0,this.El=l|0,this.Fh=u|0,this.Fl=h|0,this.Gh=x|0,this.Gl=v|0,this.Hh=b|0,this.Hl=d|0}process(t,e){for(let p=0;p<16;p++,e+=4)re[p]=t.getUint32(e),ne[p]=t.getUint32(e+=4);for(let p=16;p<80;p++){let S=re[p-15]|0,L=ne[p-15]|0,T=V.rotrSH(S,L,1)^V.rotrSH(S,L,8)^V.shrSH(S,L,7),k=V.rotrSL(S,L,1)^V.rotrSL(S,L,8)^V.shrSL(S,L,7),I=re[p-2]|0,U=ne[p-2]|0,J=V.rotrSH(I,U,19)^V.rotrBH(I,U,61)^V.shrSH(I,U,6),F=V.rotrSL(I,U,19)^V.rotrBL(I,U,61)^V.shrSL(I,U,6),H=V.add4L(k,F,ne[p-7],ne[p-16]),Y=V.add4H(H,T,J,re[p-7],re[p-16]);re[p]=Y|0,ne[p]=H|0}let{Ah:n,Al:s,Bh:o,Bl:i,Ch:a,Cl:c,Dh:f,Dl:l,Eh:u,El:h,Fh:x,Fl:v,Gh:b,Gl:d,Hh:y,Hl:E}=this;for(let p=0;p<80;p++){let S=V.rotrSH(u,h,14)^V.rotrSH(u,h,18)^V.rotrBH(u,h,41),L=V.rotrSL(u,h,14)^V.rotrSL(u,h,18)^V.rotrBL(u,h,41),T=u&x^~u&b,k=h&v^~h&d,I=V.add5L(E,L,k,Al[p],ne[p]),U=V.add5H(I,y,S,T,El[p],re[p]),J=I|0,F=V.rotrSH(n,s,28)^V.rotrBH(n,s,34)^V.rotrBH(n,s,39),H=V.rotrSL(n,s,28)^V.rotrBL(n,s,34)^V.rotrBL(n,s,39),Y=n&o^n&a^o&a,B=s&i^s&c^i&c;y=b|0,E=d|0,b=x|0,d=v|0,x=u|0,v=h|0,{h:u,l:h}=V.add(f|0,l|0,U|0,J|0),f=a|0,l=c|0,a=o|0,c=i|0,o=n|0,i=s|0;let N=V.add3L(J,H,B);n=V.add3H(N,U,F,Y),s=N|0}({h:n,l:s}=V.add(this.Ah|0,this.Al|0,n|0,s|0)),{h:o,l:i}=V.add(this.Bh|0,this.Bl|0,o|0,i|0),{h:a,l:c}=V.add(this.Ch|0,this.Cl|0,a|0,c|0),{h:f,l}=V.add(this.Dh|0,this.Dl|0,f|0,l|0),{h:u,l:h}=V.add(this.Eh|0,this.El|0,u|0,h|0),{h:x,l:v}=V.add(this.Fh|0,this.Fl|0,x|0,v|0),{h:b,l:d}=V.add(this.Gh|0,this.Gl|0,b|0,d|0),{h:y,l:E}=V.add(this.Hh|0,this.Hl|0,y|0,E|0),this.set(n,s,o,i,a,c,f,l,u,h,x,v,b,d,y,E)}roundClean(){re.fill(0),ne.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 ti=Ir(()=>new hs);var Tr={};ht(Tr,{aInRange:()=>bt,abool:()=>Nt,abytes:()=>Pe,bitGet:()=>Ul,bitLen:()=>bs,bitMask:()=>or,bitSet:()=>Tl,bytesToHex:()=>Pt,bytesToNumberBE:()=>Ft,bytesToNumberLE:()=>oe,concatBytes:()=>Kt,createHmacDrbg:()=>ys,ensureBytes:()=>W,equalBytes:()=>Nl,hexToBytes:()=>be,hexToNumber:()=>ms,inRange:()=>sr,isBytes:()=>se,memoized:()=>we,notImplemented:()=>Rl,numberToBytesBE:()=>ie,numberToBytesLE:()=>ye,numberToHexUnpadded:()=>me,numberToVarBytesBE:()=>Il,utf8ToBytes:()=>Cl,validateObject:()=>Rt});var ps=BigInt(0),Ur=BigInt(1),Sl=BigInt(2);function se(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function Pe(r){if(!se(r))throw new Error("Uint8Array expected")}function Nt(r,t){if(typeof t!="boolean")throw new Error(`${r} must be valid boolean, got "${t}".`)}var kl=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function Pt(r){Pe(r);let t="";for(let e=0;e<r.length;e++)t+=kl[r[e]];return t}function me(r){let t=r.toString(16);return t.length&1?`0${t}`:t}function ms(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return BigInt(r===""?"0":`0x${r}`)}var Mt={_0:48,_9:57,_A:65,_F:70,_a:97,_f:102};function ei(r){if(r>=Mt._0&&r<=Mt._9)return r-Mt._0;if(r>=Mt._A&&r<=Mt._F)return r-(Mt._A-10);if(r>=Mt._a&&r<=Mt._f)return r-(Mt._a-10)}function be(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);let t=r.length,e=t/2;if(t%2)throw new Error("padded hex string expected, got unpadded hex of length "+t);let n=new Uint8Array(e);for(let s=0,o=0;s<e;s++,o+=2){let i=ei(r.charCodeAt(o)),a=ei(r.charCodeAt(o+1));if(i===void 0||a===void 0){let c=r[o]+r[o+1];throw new Error('hex string expected, got non-hex character "'+c+'" at index '+o)}n[s]=i*16+a}return n}function Ft(r){return ms(Pt(r))}function oe(r){return Pe(r),ms(Pt(Uint8Array.from(r).reverse()))}function ie(r,t){return be(r.toString(16).padStart(t*2,"0"))}function ye(r,t){return ie(r,t).reverse()}function Il(r){return be(me(r))}function W(r,t,e){let n;if(typeof t=="string")try{n=be(t)}catch(o){throw new Error(`${r} must be valid hex string, got "${t}". Cause: ${o}`)}else if(se(t))n=Uint8Array.from(t);else throw new Error(`${r} must be hex string or Uint8Array`);let s=n.length;if(typeof e=="number"&&s!==e)throw new Error(`${r} expected ${e} bytes, got ${s}`);return n}function Kt(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];Pe(s),t+=s.length}let e=new Uint8Array(t);for(let n=0,s=0;n<r.length;n++){let o=r[n];e.set(o,s),s+=o.length}return e}function Nl(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}function Cl(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}var ds=r=>typeof r=="bigint"&&ps<=r;function sr(r,t,e){return ds(r)&&ds(t)&&ds(e)&&t<=r&&r<e}function bt(r,t,e,n){if(!sr(t,e,n))throw new Error(`expected valid ${r}: ${e} <= n < ${n}, got ${typeof t} ${t}`)}function bs(r){let t;for(t=0;r>ps;r>>=Ur,t+=1);return t}function Ul(r,t){return r>>BigInt(t)&Ur}function Tl(r,t,e){return r|(e?Ur:ps)<<BigInt(t)}var or=r=>(Sl<<BigInt(r-1))-Ur,gs=r=>new Uint8Array(r),ri=r=>Uint8Array.from(r);function ys(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=gs(r),s=gs(r),o=0,i=()=>{n.fill(1),s.fill(0),o=0},a=(...u)=>e(s,n,...u),c=(u=gs())=>{s=a(ri([0]),u),n=a(),u.length!==0&&(s=a(ri([1]),u),n=a())},f=()=>{if(o++>=1e3)throw new Error("drbg: tried 1000 values");let u=0,h=[];for(;u<t;){n=a();let x=n.slice();h.push(x),u+=n.length}return Kt(...h)};return(u,h)=>{i(),c(u);let x;for(;!(x=h(f()));)c();return i(),x}}var Ll={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"||se(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 Rt(r,t,e={}){let n=(s,o,i)=>{let a=Ll[o];if(typeof a!="function")throw new Error(`Invalid validator "${o}", expected function`);let c=r[s];if(!(i&&c===void 0)&&!a(c,r))throw new Error(`Invalid param ${String(s)}=${c} (${typeof c}), expected ${o}`)};for(let[s,o]of Object.entries(t))n(s,o,!1);for(let[s,o]of Object.entries(e))n(s,o,!0);return r}var Rl=()=>{throw new Error("not implemented")};function we(r){let t=new WeakMap;return(e,...n)=>{let s=t.get(e);if(s!==void 0)return s;let o=r(e,...n);return t.set(e,o),o}}var tt=BigInt(0),G=BigInt(1),xe=BigInt(2),_l=BigInt(3),ws=BigInt(4),ni=BigInt(5),si=BigInt(8),Vl=BigInt(9),Hl=BigInt(16);function q(r,t){let e=r%t;return e>=tt?e:t+e}function Dl(r,t,e){if(e<=tt||t<tt)throw new Error("Expected power/modulo > 0");if(e===G)return tt;let n=G;for(;t>tt;)t&G&&(n=n*r%e),r=r*r%e,t>>=G;return n}function j(r,t,e){let n=r;for(;t-- >tt;)n*=n,n%=e;return n}function Lr(r,t){if(r===tt||t<=tt)throw new Error(`invert: expected positive integers, got n=${r} mod=${t}`);let e=q(r,t),n=t,s=tt,o=G,i=G,a=tt;for(;e!==tt;){let f=n/e,l=n%e,u=s-i*f,h=o-a*f;n=e,e=l,s=i,o=a,i=u,a=h}if(n!==G)throw new Error("invert: does not exist");return q(s,t)}function Ol(r){let t=(r-G)/xe,e,n,s;for(e=r-G,n=0;e%xe===tt;e/=xe,n++);for(s=xe;s<r&&Dl(s,t,r)!==r-G;s++);if(n===1){let i=(r+G)/ws;return function(c,f){let l=c.pow(f,i);if(!c.eql(c.sqr(l),f))throw new Error("Cannot find square root");return l}}let o=(e+G)/xe;return function(a,c){if(a.pow(c,t)===a.neg(a.ONE))throw new Error("Cannot find square root");let f=n,l=a.pow(a.mul(a.ONE,s),e),u=a.pow(c,o),h=a.pow(c,e);for(;!a.eql(h,a.ONE);){if(a.eql(h,a.ZERO))return a.ZERO;let x=1;for(let b=a.sqr(h);x<f&&!a.eql(b,a.ONE);x++)b=a.sqr(b);let v=a.pow(l,G<<BigInt(f-x-1));l=a.sqr(v),u=a.mul(u,v),h=a.mul(h,l),f=x}return u}}function Ml(r){if(r%ws===_l){let t=(r+G)/ws;return function(n,s){let o=n.pow(s,t);if(!n.eql(n.sqr(o),s))throw new Error("Cannot find square root");return o}}if(r%si===ni){let t=(r-ni)/si;return function(n,s){let o=n.mul(s,xe),i=n.pow(o,t),a=n.mul(s,i),c=n.mul(n.mul(a,xe),i),f=n.mul(a,n.sub(c,n.ONE));if(!n.eql(n.sqr(f),s))throw new Error("Cannot find square root");return f}}return r%Hl,Ol(r)}var oi=(r,t)=>(q(r,t)&G)===G,Pl=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function xs(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=Pl.reduce((n,s)=>(n[s]="function",n),t);return Rt(r,e)}function Fl(r,t,e){if(e<tt)throw new Error("Expected power > 0");if(e===tt)return r.ONE;if(e===G)return t;let n=r.ONE,s=t;for(;e>tt;)e&G&&(n=r.mul(n,s)),s=r.sqr(s),e>>=G;return n}function Kl(r,t){let e=new Array(t.length),n=t.reduce((o,i,a)=>r.is0(i)?o:(e[a]=o,r.mul(o,i)),r.ONE),s=r.inv(n);return t.reduceRight((o,i,a)=>r.is0(i)?o:(e[a]=r.mul(o,e[a]),r.mul(o,i)),s),e}function vs(r,t){let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function ae(r,t,e=!1,n={}){if(r<=tt)throw new Error(`Expected Field ORDER > 0, got ${r}`);let{nBitLength:s,nByteLength:o}=vs(r,t);if(o>2048)throw new Error("Field lengths over 2048 bytes are not supported");let i=Ml(r),a=Object.freeze({ORDER:r,BITS:s,BYTES:o,MASK:or(s),ZERO:tt,ONE:G,create:c=>q(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error(`Invalid field element: expected bigint, got ${typeof c}`);return tt<=c&&c<r},is0:c=>c===tt,isOdd:c=>(c&G)===G,neg:c=>q(-c,r),eql:(c,f)=>c===f,sqr:c=>q(c*c,r),add:(c,f)=>q(c+f,r),sub:(c,f)=>q(c-f,r),mul:(c,f)=>q(c*f,r),pow:(c,f)=>Fl(a,c,f),div:(c,f)=>q(c*Lr(f,r),r),sqrN:c=>c*c,addN:(c,f)=>c+f,subN:(c,f)=>c-f,mulN:(c,f)=>c*f,inv:c=>Lr(c,r),sqrt:n.sqrt||(c=>i(a,c)),invertBatch:c=>Kl(a,c),cmov:(c,f,l)=>l?f:c,toBytes:c=>e?ye(c,o):ie(c,o),fromBytes:c=>{if(c.length!==o)throw new Error(`Fp.fromBytes: expected ${o}, got ${c.length}`);return e?oe(c):Ft(c)}});return Object.freeze(a)}function ii(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 Bs(r){let t=ii(r);return t+Math.ceil(t/2)}function ai(r,t,e=!1){let n=r.length,s=ii(t),o=Bs(t);if(n<16||n<o||n>1024)throw new Error(`expected ${o}-1024 bytes of input, got ${n}`);let i=e?Ft(r):oe(r),a=q(i,t-G)+G;return e?ye(a,s):ie(a,s)}var ql=BigInt(0),Es=BigInt(1),As=new WeakMap,ci=new WeakMap;function Rr(r,t){let e=(o,i)=>{let a=i.negate();return o?a:i},n=o=>{if(!Number.isSafeInteger(o)||o<=0||o>t)throw new Error(`Wrong window size=${o}, should be [1..${t}]`)},s=o=>{n(o);let i=Math.ceil(t/o)+1,a=2**(o-1);return{windows:i,windowSize:a}};return{constTimeNegate:e,unsafeLadder(o,i){let a=r.ZERO,c=o;for(;i>ql;)i&Es&&(a=a.add(c)),c=c.double(),i>>=Es;return a},precomputeWindow(o,i){let{windows:a,windowSize:c}=s(i),f=[],l=o,u=l;for(let h=0;h<a;h++){u=l,f.push(u);for(let x=1;x<c;x++)u=u.add(l),f.push(u);l=u.double()}return f},wNAF(o,i,a){let{windows:c,windowSize:f}=s(o),l=r.ZERO,u=r.BASE,h=BigInt(2**o-1),x=2**o,v=BigInt(o);for(let b=0;b<c;b++){let d=b*f,y=Number(a&h);a>>=v,y>f&&(y-=x,a+=Es);let E=d,p=d+Math.abs(y)-1,S=b%2!==0,L=y<0;y===0?u=u.add(e(S,i[E])):l=l.add(e(L,i[p]))}return{p:l,f:u}},wNAFCached(o,i,a){let c=ci.get(o)||1,f=As.get(o);return f||(f=this.precomputeWindow(o,c),c!==1&&As.set(o,a(f))),this.wNAF(c,f,i)},setWindowSize(o,i){n(i),ci.set(o,i),As.delete(o)}}}function _r(r,t,e,n){if(!Array.isArray(e)||!Array.isArray(n)||n.length!==e.length)throw new Error("arrays of points and scalars must have equal length");n.forEach((l,u)=>{if(!t.isValid(l))throw new Error(`wrong scalar at index ${u}`)}),e.forEach((l,u)=>{if(!(l instanceof r))throw new Error(`wrong point at index ${u}`)});let s=bs(BigInt(e.length)),o=s>12?s-3:s>4?s-2:s?2:1,i=(1<<o)-1,a=new Array(i+1).fill(r.ZERO),c=Math.floor((t.BITS-1)/o)*o,f=r.ZERO;for(let l=c;l>=0;l-=o){a.fill(r.ZERO);for(let h=0;h<n.length;h++){let x=n[h],v=Number(x>>BigInt(l)&BigInt(i));a[v]=a[v].add(e[h])}let u=r.ZERO;for(let h=a.length-1,x=r.ZERO;h>0;h--)x=x.add(a[h]),u=u.add(x);if(f=f.add(u),l!==0)for(let h=0;h<o;h++)f=f.double()}return f}function ir(r){return xs(r.Fp),Rt(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...vs(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Ct=BigInt(0),yt=BigInt(1),Vr=BigInt(2),zl=BigInt(8),Gl={zip215:!0};function jl(r){let t=ir(r);return Rt(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function li(r){let t=jl(r),{Fp:e,n,prehash:s,hash:o,randomBytes:i,nByteLength:a,h:c}=t,f=Vr<<BigInt(a*8)-yt,l=e.create,u=ae(t.n,t.nBitLength),h=t.uvRatio||((m,g)=>{try{return{isValid:!0,value:e.sqrt(m*e.inv(g))}}catch{return{isValid:!1,value:Ct}}}),x=t.adjustScalarBytes||(m=>m),v=t.domain||((m,g,w)=>{if(Nt("phflag",w),g.length||w)throw new Error("Contexts/pre-hash are not supported");return m});function b(m,g){bt("coordinate "+m,g,Ct,f)}function d(m){if(!(m instanceof p))throw new Error("ExtendedPoint expected")}let y=we((m,g)=>{let{ex:w,ey:C,ez:R}=m,_=m.is0();g==null&&(g=_?zl:e.inv(R));let D=l(w*g),P=l(C*g),O=l(R*g);if(_)return{x:Ct,y:yt};if(O!==yt)throw new Error("invZ was invalid");return{x:D,y:P}}),E=we(m=>{let{a:g,d:w}=t;if(m.is0())throw new Error("bad point: ZERO");let{ex:C,ey:R,ez:_,et:D}=m,P=l(C*C),O=l(R*R),$=l(_*_),z=l($*$),et=l(P*g),rt=l($*l(et+O)),ot=l(z+l(w*l(P*O)));if(rt!==ot)throw new Error("bad point: equation left != right (1)");let ft=l(C*R),X=l(_*D);if(ft!==X)throw new Error("bad point: equation left != right (2)");return!0});class p{constructor(g,w,C,R){this.ex=g,this.ey=w,this.ez=C,this.et=R,b("x",g),b("y",w),b("z",C),b("t",R),Object.freeze(this)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(g){if(g instanceof p)throw new Error("extended point not allowed");let{x:w,y:C}=g||{};return b("x",w),b("y",C),new p(w,C,yt,l(w*C))}static normalizeZ(g){let w=e.invertBatch(g.map(C=>C.ez));return g.map((C,R)=>C.toAffine(w[R])).map(p.fromAffine)}static msm(g,w){return _r(p,u,g,w)}_setWindowSize(g){T.setWindowSize(this,g)}assertValidity(){E(this)}equals(g){d(g);let{ex:w,ey:C,ez:R}=this,{ex:_,ey:D,ez:P}=g,O=l(w*P),$=l(_*R),z=l(C*P),et=l(D*R);return O===$&&z===et}is0(){return this.equals(p.ZERO)}negate(){return new p(l(-this.ex),this.ey,this.ez,l(-this.et))}double(){let{a:g}=t,{ex:w,ey:C,ez:R}=this,_=l(w*w),D=l(C*C),P=l(Vr*l(R*R)),O=l(g*_),$=w+C,z=l(l($*$)-_-D),et=O+D,rt=et-P,ot=O-D,ft=l(z*rt),X=l(et*ot),pt=l(z*ot),Dt=l(rt*et);return new p(ft,X,Dt,pt)}add(g){d(g);let{a:w,d:C}=t,{ex:R,ey:_,ez:D,et:P}=this,{ex:O,ey:$,ez:z,et}=g;if(w===BigInt(-1)){let Eo=l((_-R)*($+O)),Ao=l((_+R)*($-O)),Yn=l(Ao-Eo);if(Yn===Ct)return this.double();let So=l(D*Vr*et),ko=l(P*Vr*z),Io=ko+So,No=Ao+Eo,Co=ko-So,ec=l(Io*Yn),rc=l(No*Co),nc=l(Io*Co),sc=l(Yn*No);return new p(ec,rc,sc,nc)}let rt=l(R*O),ot=l(_*$),ft=l(P*C*et),X=l(D*z),pt=l((R+_)*(O+$)-rt-ot),Dt=X-ft,Je=X+ft,Ye=l(ot-w*rt),Ya=l(pt*Dt),Xa=l(Je*Ye),Qa=l(pt*Ye),tc=l(Dt*Je);return new p(Ya,Xa,tc,Qa)}subtract(g){return this.add(g.negate())}wNAF(g){return T.wNAFCached(this,g,p.normalizeZ)}multiply(g){let w=g;bt("scalar",w,yt,n);let{p:C,f:R}=this.wNAF(w);return p.normalizeZ([C,R])[0]}multiplyUnsafe(g){let w=g;return bt("scalar",w,Ct,n),w===Ct?L:this.equals(L)||w===yt?this:this.equals(S)?this.wNAF(w).p:T.unsafeLadder(this,w)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return T.unsafeLadder(this,n).is0()}toAffine(g){return y(this,g)}clearCofactor(){let{h:g}=t;return g===yt?this:this.multiplyUnsafe(g)}static fromHex(g,w=!1){let{d:C,a:R}=t,_=e.BYTES;g=W("pointHex",g,_),Nt("zip215",w);let D=g.slice(),P=g[_-1];D[_-1]=P&-129;let O=oe(D),$=w?f:e.ORDER;bt("pointHex.y",O,Ct,$);let z=l(O*O),et=l(z-yt),rt=l(C*z-R),{isValid:ot,value:ft}=h(et,rt);if(!ot)throw new Error("Point.fromHex: invalid y coordinate");let X=(ft&yt)===yt,pt=(P&128)!==0;if(!w&&ft===Ct&&pt)throw new Error("Point.fromHex: x=0 and x_0=1");return pt!==X&&(ft=l(-ft)),p.fromAffine({x:ft,y:O})}static fromPrivateKey(g){return U(g).point}toRawBytes(){let{x:g,y:w}=this.toAffine(),C=ye(w,e.BYTES);return C[C.length-1]|=g&yt?128:0,C}toHex(){return Pt(this.toRawBytes())}}p.BASE=new p(t.Gx,t.Gy,yt,l(t.Gx*t.Gy)),p.ZERO=new p(Ct,yt,yt,Ct);let{BASE:S,ZERO:L}=p,T=Rr(p,a*8);function k(m){return q(m,n)}function I(m){return k(oe(m))}function U(m){let g=a;m=W("private key",m,g);let w=W("hashed private key",o(m),2*g),C=x(w.slice(0,g)),R=w.slice(g,2*g),_=I(C),D=S.multiply(_),P=D.toRawBytes();return{head:C,prefix:R,scalar:_,point:D,pointBytes:P}}function J(m){return U(m).pointBytes}function F(m=new Uint8Array,...g){let w=Kt(...g);return I(o(v(w,W("context",m),!!s)))}function H(m,g,w={}){m=W("message",m),s&&(m=s(m));let{prefix:C,scalar:R,pointBytes:_}=U(g),D=F(w.context,C,m),P=S.multiply(D).toRawBytes(),O=F(w.context,P,_,m),$=k(D+O*R);bt("signature.s",$,Ct,n);let z=Kt(P,ye($,e.BYTES));return W("result",z,a*2)}let Y=Gl;function B(m,g,w,C=Y){let{context:R,zip215:_}=C,D=e.BYTES;m=W("signature",m,2*D),g=W("message",g),_!==void 0&&Nt("zip215",_),s&&(g=s(g));let P=oe(m.slice(D,2*D)),O,$,z;try{O=p.fromHex(w,_),$=p.fromHex(m.slice(0,D),_),z=S.multiplyUnsafe(P)}catch{return!1}if(!_&&O.isSmallOrder())return!1;let et=F(R,$.toRawBytes(),O.toRawBytes(),g);return $.add(O.multiplyUnsafe(et)).subtract(z).clearCofactor().equals(p.ZERO)}return S._setWindowSize(8),{CURVE:t,getPublicKey:J,sign:H,verify:B,ExtendedPoint:p,utils:{getExtendedPublicKey:U,randomPrivateKey:()=>i(e.BYTES),precompute(m=8,g=p.BASE){return g._setWindowSize(m),g.multiply(BigInt(3)),g}}}}var Ss=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),ui=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),Lh=BigInt(0),Zl=BigInt(1),fi=BigInt(2),Rh=BigInt(3),Wl=BigInt(5),Jl=BigInt(8);function Yl(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),s=BigInt(80),o=Ss,a=r*r%o*r%o,c=j(a,fi,o)*a%o,f=j(c,Zl,o)*r%o,l=j(f,Wl,o)*f%o,u=j(l,t,o)*l%o,h=j(u,e,o)*u%o,x=j(h,n,o)*h%o,v=j(x,s,o)*x%o,b=j(v,s,o)*x%o,d=j(b,t,o)*l%o;return{pow_p_5_8:j(d,fi,o)*r%o,b2:a}}function Xl(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function Ql(r,t){let e=Ss,n=q(t*t*t,e),s=q(n*n*t,e),o=Yl(r*s).pow_p_5_8,i=q(r*n*o,e),a=q(t*i*i,e),c=i,f=q(i*ui,e),l=a===r,u=a===q(-r,e),h=a===q(-r*ui,e);return l&&(i=c),(u||h)&&(i=f),oi(i,e)&&(i=q(-i,e)),{isValid:l||u,value:i}}var tu=ae(Ss,void 0,!0),eu={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:tu,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:Jl,Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:ti,randomBytes:Nr,adjustScalarBytes:Xl,uvRatio:Ql},hi=li(eu);var Hr=32;function di(r,t,e){return hi.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}var Dr=class{type="Ed25519";raw;constructor(t){this.raw=ks(t,Hr)}toMultihash(){return ee.digest(Or(this))}toCID(){return Et.createV1(114,this.toMultihash())}toString(){return Q.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:mt(this.raw,t.raw)}verify(t,e){return di(this.raw,e,t)}};function pi(r){return r=ks(r,Hr),new Dr(r)}function ks(r,t){if(r=Uint8Array.from(r??[]),r.length!==t)throw new dt(`Key must be a Uint8Array of length ${t}, got ${r.length}`);return r}function Ut(r=0){return new Uint8Array(r)}function wt(r=0){return new Uint8Array(r)}var nu=Math.pow(2,7),su=Math.pow(2,14),ou=Math.pow(2,21),Is=Math.pow(2,28),Ns=Math.pow(2,35),Cs=Math.pow(2,42),Us=Math.pow(2,49),K=128,ct=127;function $t(r){if(r<nu)return 1;if(r<su)return 2;if(r<ou)return 3;if(r<Is)return 4;if(r<Ns)return 5;if(r<Cs)return 6;if(r<Us)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function Ts(r,t,e=0){switch($t(r)){case 8:t[e++]=r&255|K,r/=128;case 7:t[e++]=r&255|K,r/=128;case 6:t[e++]=r&255|K,r/=128;case 5:t[e++]=r&255|K,r/=128;case 4:t[e++]=r&255|K,r>>>=7;case 3:t[e++]=r&255|K,r>>>=7;case 2:t[e++]=r&255|K,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function iu(r,t,e=0){switch($t(r)){case 8:t.set(e++,r&255|K),r/=128;case 7:t.set(e++,r&255|K),r/=128;case 6:t.set(e++,r&255|K),r/=128;case 5:t.set(e++,r&255|K),r/=128;case 4:t.set(e++,r&255|K),r>>>=7;case 3:t.set(e++,r&255|K),r>>>=7;case 2:t.set(e++,r&255|K),r>>>=7;case 1:{t.set(e++,r&255),r>>>=7;break}default:throw new Error("unreachable")}return t}function Ls(r,t){let e=r[t],n=0;if(n+=e&ct,e<K||(e=r[t+1],n+=(e&ct)<<7,e<K)||(e=r[t+2],n+=(e&ct)<<14,e<K)||(e=r[t+3],n+=(e&ct)<<21,e<K)||(e=r[t+4],n+=(e&ct)*Is,e<K)||(e=r[t+5],n+=(e&ct)*Ns,e<K)||(e=r[t+6],n+=(e&ct)*Cs,e<K)||(e=r[t+7],n+=(e&ct)*Us,e<K))return n;throw new RangeError("Could not decode varint")}function au(r,t){let e=r.get(t),n=0;if(n+=e&ct,e<K||(e=r.get(t+1),n+=(e&ct)<<7,e<K)||(e=r.get(t+2),n+=(e&ct)<<14,e<K)||(e=r.get(t+3),n+=(e&ct)<<21,e<K)||(e=r.get(t+4),n+=(e&ct)*Is,e<K)||(e=r.get(t+5),n+=(e&ct)*Ns,e<K)||(e=r.get(t+6),n+=(e&ct)*Cs,e<K)||(e=r.get(t+7),n+=(e&ct)*Us,e<K))return n;throw new RangeError("Could not decode varint")}function mi(r,t,e=0){return t==null&&(t=wt($t(r))),t instanceof Uint8Array?Ts(r,t,e):iu(r,t,e)}function bi(r,t=0){return r instanceof Uint8Array?Ls(r,t):au(r,t)}var Rs=new Float32Array([-0]),ce=new Uint8Array(Rs.buffer);function yi(r,t,e){Rs[0]=r,t[e]=ce[0],t[e+1]=ce[1],t[e+2]=ce[2],t[e+3]=ce[3]}function wi(r,t){return ce[0]=r[t],ce[1]=r[t+1],ce[2]=r[t+2],ce[3]=r[t+3],Rs[0]}var _s=new Float64Array([-0]),lt=new Uint8Array(_s.buffer);function xi(r,t,e){_s[0]=r,t[e]=lt[0],t[e+1]=lt[1],t[e+2]=lt[2],t[e+3]=lt[3],t[e+4]=lt[4],t[e+5]=lt[5],t[e+6]=lt[6],t[e+7]=lt[7]}function vi(r,t){return lt[0]=r[t],lt[1]=r[t+1],lt[2]=r[t+2],lt[3]=r[t+3],lt[4]=r[t+4],lt[5]=r[t+5],lt[6]=r[t+6],lt[7]=r[t+7],_s[0]}var lu=BigInt(Number.MAX_SAFE_INTEGER),uu=BigInt(Number.MIN_SAFE_INTEGER),At=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 ve;if(t<lu&&t>uu)return this.fromNumber(Number(t));let e=t<0n;e&&(t=-t);let n=t>>32n,s=t-(n<<32n);return e&&(n=~n|0n,s=~s|0n,++s>Bi&&(s=0n,++n>Bi&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(t){if(t===0)return ve;let e=t<0;e&&(t=-t);let n=t>>>0,s=(t-n)/4294967296>>>0;return e&&(s=~s>>>0,n=~n>>>0,++n>4294967295&&(n=0,++s>4294967295&&(s=0))),new r(n,s)}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):ve}},ve=new At(0,0);ve.toBigInt=function(){return 0n};ve.zzEncode=ve.zzDecode=function(){return this};ve.length=function(){return 1};var Bi=4294967296n;function Ei(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 Ai(r,t,e){if(e-t<1)return"";let s,o=[],i=0,a;for(;t<e;)a=r[t++],a<128?o[i++]=a:a>191&&a<224?o[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,o[i++]=55296+(a>>10),o[i++]=56320+(a&1023)):o[i++]=(a&15)<<12|(r[t++]&63)<<6|r[t++]&63,i>8191&&((s??(s=[])).push(String.fromCharCode.apply(String,o)),i=0);return s!=null?(i>0&&s.push(String.fromCharCode.apply(String,o.slice(0,i))),s.join("")):String.fromCharCode.apply(String,o.slice(0,i))}function Vs(r,t,e){let n=e,s,o;for(let i=0;i<r.length;++i)s=r.charCodeAt(i),s<128?t[e++]=s:s<2048?(t[e++]=s>>6|192,t[e++]=s&63|128):(s&64512)===55296&&((o=r.charCodeAt(i+1))&64512)===56320?(s=65536+((s&1023)<<10)+(o&1023),++i,t[e++]=s>>18|240,t[e++]=s>>12&63|128,t[e++]=s>>6&63|128,t[e++]=s&63|128):(t[e++]=s>>12|224,t[e++]=s>>6&63|128,t[e++]=s&63|128);return e-n}function Tt(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function Mr(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,Tt(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 Tt(this,4);return Mr(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Tt(this,4);return Mr(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Tt(this,4);let t=wi(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Tt(this,4);let t=vi(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 Tt(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return Ai(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw Tt(this,t);this.pos+=t}else do if(this.pos>=this.len)throw Tt(this);while(this.buf[this.pos++]&128);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 At(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 Tt(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 Tt(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 Tt(this,8);let t=Mr(this.buf,this.pos+=4),e=Mr(this.buf,this.pos+=4);return new At(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=Ls(this.buf,this.pos);return this.pos+=$t(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 Be(r,t,e){let n=Ds(r);return t.decode(n,void 0,e)}var Os={};ht(Os,{base10:()=>fu});var fu=te({prefix:"9",name:"base10",alphabet:"0123456789"});var Ms={};ht(Ms,{base16:()=>hu,base16upper:()=>du});var hu=Z({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),du=Z({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Ps={};ht(Ps,{base2:()=>gu});var gu=Z({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Fs={};ht(Fs,{base256emoji:()=>wu});var ki=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}"),pu=ki.reduce((r,t,e)=>(r[e]=t,r),[]),mu=ki.reduce((r,t,e)=>{let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);return r[n]=e,r},[]);function bu(r){return r.reduce((t,e)=>(t+=pu[e],t),"")}function yu(r){let t=[];for(let e of r){let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);let s=mu[n];if(s==null)throw new Error(`Non-base256emoji character: ${e}`);t.push(s)}return new Uint8Array(t)}var wu=Ue({prefix:"\u{1F680}",name:"base256emoji",encode:bu,decode:yu});var Ks={};ht(Ks,{base64:()=>xu,base64pad:()=>vu,base64url:()=>Bu,base64urlpad:()=>Eu});var xu=Z({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),vu=Z({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Bu=Z({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Eu=Z({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var $s={};ht($s,{base8:()=>Au});var Au=Z({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var qs={};ht(qs,{identity:()=>Su});var Su=Ue({prefix:"\0",name:"identity",encode:r=>_o(r),decode:r=>Ro(r)});var pd=new TextEncoder,md=new TextDecoder;var js={};ht(js,{sha256:()=>Pr,sha512:()=>Nu});function Gs({name:r,code:t,encode:e}){return new zs(r,t,e)}var zs=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 Ni(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var Pr=Gs({name:"sha2-256",code:18,encode:Ni("SHA-256")}),Nu=Gs({name:"sha2-512",code:19,encode:Ni("SHA-512")});var Zs={...qs,...Ps,...$s,...Os,...Ms,...ss,...os,...ns,...Ks,...Fs},Nd={...js,...ls};function Ui(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var Ci=Ui("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),Ws=Ui("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=wt(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),Cu={utf8:Ci,"utf-8":Ci,hex:Zs.base16,latin1:Ws,ascii:Ws,binary:Ws,...Zs},Fr=Cu;function nt(r,t="utf8"){let e=Fr[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function Js(r){let t=r??8192,e=t>>>1,n,s=t;return function(i){if(i<1||i>e)return wt(i);s+i>t&&(n=wt(t),s=0);let a=n.subarray(s,s+=i);return s&7&&(s=(s|7)+1),a}}var Ee=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function Ys(){}var Qs=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},Uu=Js();function Tu(r){return globalThis.Buffer!=null?wt(r):Uu(r)}var cr=class{len;head;tail;states;constructor(){this.len=0,this.head=new Ee(Ys,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new Ee(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new to((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(Kr,10,At.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=At.fromBigInt(t);return this._push(Kr,e.length(),e)}uint64Number(t){return this._push(Ts,$t(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=At.fromBigInt(t).zzEncode();return this._push(Kr,e.length(),e)}sint64Number(t){let e=At.fromNumber(t).zzEncode();return this._push(Kr,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(Xs,1,t?1:0)}fixed32(t){return this._push(ar,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=At.fromBigInt(t);return this._push(ar,4,e.lo)._push(ar,4,e.hi)}fixed64Number(t){let e=At.fromNumber(t);return this._push(ar,4,e.lo)._push(ar,4,e.hi)}fixed64String(t){return this.fixed64(BigInt(t))}sfixed64(t){return this.fixed64(t)}sfixed64Number(t){return this.fixed64Number(t)}sfixed64String(t){return this.fixed64String(t)}float(t){return this._push(yi,4,t)}double(t){return this._push(xi,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(Xs,1,0):this.uint32(e)._push(Ru,e,t)}string(t){let e=Ei(t);return e!==0?this.uint32(e)._push(Vs,e,t):this._push(Xs,1,0)}fork(){return this.states=new Qs(this),this.head=this.tail=new Ee(Ys,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 Ee(Ys,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=Tu(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function Xs(r,t,e){t[e]=r&255}function Lu(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var to=class extends Ee{next;constructor(t,e){super(Lu,t,e),this.next=void 0}};function Kr(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 ar(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 Ru(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(cr.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(_u,t,r),this},cr.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(Vu,t,r),this});function _u(r,t,e){t.set(r,e)}function Vu(r,t,e){r.length<40?Vs(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(nt(r),e)}function eo(){return new cr}function Ae(r,t){let e=eo();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var Fe;(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"})(Fe||(Fe={}));function $r(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function lr(r){function t(s){if(r[s.toString()]==null)throw new Error("Invalid enum value");return r[s]}let e=function(o,i){let a=t(o);i.int32(a)},n=function(o){let i=o.int32();return t(i)};return $r("enum",Fe.VARINT,e,n)}function Se(r,t){return $r("message",Fe.LENGTH_DELIMITED,r,t)}var xt;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.secp256k1="secp256k1"})(xt||(xt={}));var ro;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1"})(ro||(ro={}));(function(r){r.codec=()=>lr(ro)})(xt||(xt={}));var le;(function(r){let t;r.codec=()=>(t==null&&(t=Se((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),xt.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let o={},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let a=e.uint32();switch(a>>>3){case 1:{o.Type=xt.codec().decode(e);break}case 2:{o.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return o})),t),r.encode=e=>Ae(e,r.codec()),r.decode=(e,n)=>Be(e,r.codec(),n)})(le||(le={}));var no;(function(r){let t;r.codec=()=>(t==null&&(t=Se((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),xt.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let o={},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let a=e.uint32();switch(a>>>3){case 1:{o.Type=xt.codec().decode(e);break}case 2:{o.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return o})),t),r.encode=e=>Ae(e,r.codec()),r.decode=(e,n)=>Be(e,r.codec(),n)})(no||(no={}));var wr={};ht(wr,{MAX_RSA_KEY_SIZE:()=>Vn,generateRSAKeyPair:()=>Ia,jwkToJWKKeyPair:()=>Na,jwkToPkcs1:()=>Yu,jwkToPkix:()=>ho,jwkToRSAPrivateKey:()=>ka,pkcs1ToJwk:()=>Ea,pkcs1ToRSAPrivateKey:()=>Sa,pkixToJwk:()=>Aa,pkixToRSAPublicKey:()=>go});var Hu=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]),ue=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),fe=new Uint32Array(64),so=class extends Me{constructor(){super(64,32,8,!1),this.A=ue[0]|0,this.B=ue[1]|0,this.C=ue[2]|0,this.D=ue[3]|0,this.E=ue[4]|0,this.F=ue[5]|0,this.G=ue[6]|0,this.H=ue[7]|0}get(){let{A:t,B:e,C:n,D:s,E:o,F:i,G:a,H:c}=this;return[t,e,n,s,o,i,a,c]}set(t,e,n,s,o,i,a,c){this.A=t|0,this.B=e|0,this.C=n|0,this.D=s|0,this.E=o|0,this.F=i|0,this.G=a|0,this.H=c|0}process(t,e){for(let u=0;u<16;u++,e+=4)fe[u]=t.getUint32(e,!1);for(let u=16;u<64;u++){let h=fe[u-15],x=fe[u-2],v=It(h,7)^It(h,18)^h>>>3,b=It(x,17)^It(x,19)^x>>>10;fe[u]=b+fe[u-7]+v+fe[u-16]|0}let{A:n,B:s,C:o,D:i,E:a,F:c,G:f,H:l}=this;for(let u=0;u<64;u++){let h=It(a,6)^It(a,11)^It(a,25),x=l+h+Yo(a,c,f)+Hu[u]+fe[u]|0,b=(It(n,2)^It(n,13)^It(n,22))+Xo(n,s,o)|0;l=f,f=c,c=a,a=i+x|0,i=o,o=s,s=n,n=x+b|0}n=n+this.A|0,s=s+this.B|0,o=o+this.C|0,i=i+this.D|0,a=a+this.E|0,c=c+this.F|0,f=f+this.G|0,l=l+this.H|0,this.set(n,s,o,i,a,c,f,l)}roundClean(){fe.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var Ke=Ir(()=>new so);var M=fc(Li());function ke(r,t){let e=0;if(r.length===1)return r[0];for(let n=r.length-1;n>=0;n--)e+=r[r.length-1-n]*Math.pow(2,t*n);return e}function he(r,t,e=-1){let n=e,s=r,o=0,i=Math.pow(2,t);for(let a=1;a<8;a++){if(r<i){let c;if(n<0)c=new ArrayBuffer(a),o=a;else{if(n<a)return new ArrayBuffer(0);c=new ArrayBuffer(n),o=n}let f=new Uint8Array(c);for(let l=a-1;l>=0;l--){let u=Math.pow(2,l*t);f[o-l-1]=Math.floor(s/u),s-=f[o-l-1]*u}return c}i*=Math.pow(2,t)}return new ArrayBuffer(0)}function Gr(...r){let t=0,e=0;for(let o of r)t+=o.length;let n=new ArrayBuffer(t),s=new Uint8Array(n);for(let o of r)s.set(o,e),e+=o.length;return s}function io(){let r=new Uint8Array(this.valueHex);if(this.valueHex.byteLength>=2){let a=r[0]===255&&r[1]&128,c=r[0]===0&&(r[1]&128)===0;(a||c)&&this.warnings.push("Needlessly long format")}let t=new ArrayBuffer(this.valueHex.byteLength),e=new Uint8Array(t);for(let a=0;a<this.valueHex.byteLength;a++)e[a]=0;e[0]=r[0]&128;let n=ke(e,8),s=new ArrayBuffer(this.valueHex.byteLength),o=new Uint8Array(s);for(let a=0;a<this.valueHex.byteLength;a++)o[a]=r[a];return o[0]&=127,ke(o,8)-n}function Ri(r){let t=r<0?r*-1:r,e=128;for(let n=1;n<8;n++){if(t<=e){if(r<0){let i=e-t,a=he(i,8,n),c=new Uint8Array(a);return c[0]|=128,a}let s=he(t,8,n),o=new Uint8Array(s);if(o[0]&128){let i=s.slice(0),a=new Uint8Array(i);s=new ArrayBuffer(s.byteLength+1),o=new Uint8Array(s);for(let c=0;c<i.byteLength;c++)o[c+1]=a[c];o[0]=0}return s}e*=Math.pow(2,8)}return new ArrayBuffer(0)}function _i(r,t){if(r.byteLength!==t.byteLength)return!1;let e=new Uint8Array(r),n=new Uint8Array(t);for(let s=0;s<e.length;s++)if(e[s]!==n[s])return!1;return!0}function vt(r,t){let e=r.toString(10);if(t<e.length)return"";let n=t-e.length,s=new Array(n);for(let i=0;i<n;i++)s[i]="0";return s.join("").concat(e)}var l0=Math.log(2);function jr(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function ao(r){let t=0,e=0;for(let s=0;s<r.length;s++){let o=r[s];t+=o.byteLength}let n=new Uint8Array(t);for(let s=0;s<r.length;s++){let o=r[s];n.set(new Uint8Array(o),e),e+=o.byteLength}return n.buffer}function Zt(r,t,e,n){return t instanceof Uint8Array?t.byteLength?e<0?(r.error="Wrong parameter: inputOffset less than zero",!1):n<0?(r.error="Wrong parameter: inputLength less than zero",!1):t.byteLength-e-n<0?(r.error="End of input reached before message was fully decoded (inconsistent offset and length values)",!1):!0:(r.error="Wrong parameter: inputBuffer has zero length",!1):(r.error="Wrong parameter: inputBuffer must be 'Uint8Array'",!1)}var fr=class{constructor(){this.items=[]}write(t){this.items.push(t)}final(){return ao(this.items)}},ur=[new Uint8Array([1])],Vi="0123456789";var je="",Lt=new ArrayBuffer(0),co=new Uint8Array(0),hr="EndOfContent",Di="OCTET STRING",Oi="BIT STRING";function Wt(r){var t;return t=class extends r{constructor(...n){var s;super(...n);let o=n[0]||{};this.isHexOnly=(s=o.isHexOnly)!==null&&s!==void 0?s:!1,this.valueHexView=o.valueHex?M.BufferSourceConverter.toUint8Array(o.valueHex):co}get valueHex(){return this.valueHexView.slice().buffer}set valueHex(n){this.valueHexView=new Uint8Array(n)}fromBER(n,s,o){let i=n instanceof ArrayBuffer?new Uint8Array(n):n;if(!Zt(this,i,s,o))return-1;let a=s+o;return this.valueHexView=i.subarray(s,a),this.valueHexView.length?(this.blockLength=o,a):(this.warnings.push("Zero buffer length"),s)}toBER(n=!1){return this.isHexOnly?n?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.byteLength===this.valueHexView.buffer.byteLength?this.valueHexView.buffer:this.valueHexView.slice().buffer:(this.error="Flag 'isHexOnly' is not set, abort",Lt)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:M.Convert.ToHex(this.valueHexView)}}},t.NAME="hexBlock",t}var zt=class{constructor({blockLength:t=0,error:e=je,warnings:n=[],valueBeforeDecode:s=co}={}){this.blockLength=t,this.error=e,this.warnings=n,this.valueBeforeDecodeView=M.BufferSourceConverter.toUint8Array(s)}static blockName(){return this.NAME}get valueBeforeDecode(){return this.valueBeforeDecodeView.slice().buffer}set valueBeforeDecode(t){this.valueBeforeDecodeView=new Uint8Array(t)}toJSON(){return{blockName:this.constructor.NAME,blockLength:this.blockLength,error:this.error,warnings:this.warnings,valueBeforeDecode:M.Convert.ToHex(this.valueBeforeDecodeView)}}};zt.NAME="baseBlock";var ut=class extends zt{fromBER(t,e,n){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}toBER(t,e){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}};ut.NAME="valueBlock";var Zr=class extends Wt(zt){constructor({idBlock:t={}}={}){var e,n,s,o;super(),t?(this.isHexOnly=(e=t.isHexOnly)!==null&&e!==void 0?e:!1,this.valueHexView=t.valueHex?M.BufferSourceConverter.toUint8Array(t.valueHex):co,this.tagClass=(n=t.tagClass)!==null&&n!==void 0?n:-1,this.tagNumber=(s=t.tagNumber)!==null&&s!==void 0?s:-1,this.isConstructed=(o=t.isConstructed)!==null&&o!==void 0?o:!1):(this.tagClass=-1,this.tagNumber=-1,this.isConstructed=!1)}toBER(t=!1){let e=0;switch(this.tagClass){case 1:e|=0;break;case 2:e|=64;break;case 3:e|=128;break;case 4:e|=192;break;default:return this.error="Unknown tag class",Lt}if(this.isConstructed&&(e|=32),this.tagNumber<31&&!this.isHexOnly){let s=new Uint8Array(1);if(!t){let o=this.tagNumber;o&=31,e|=o,s[0]=e}return s.buffer}if(!this.isHexOnly){let s=he(this.tagNumber,7),o=new Uint8Array(s),i=s.byteLength,a=new Uint8Array(i+1);if(a[0]=e|31,!t){for(let c=0;c<i-1;c++)a[c+1]=o[c]|128;a[i]=o[i-1]}return a.buffer}let n=new Uint8Array(this.valueHexView.byteLength+1);if(n[0]=e|31,!t){let s=this.valueHexView;for(let o=0;o<s.length-1;o++)n[o+1]=s[o]|128;n[this.valueHexView.byteLength]=s[s.length-1]}return n.buffer}fromBER(t,e,n){let s=M.BufferSourceConverter.toUint8Array(t);if(!Zt(this,s,e,n))return-1;let o=s.subarray(e,e+n);if(o.length===0)return this.error="Zero buffer length",-1;switch(o[0]&192){case 0:this.tagClass=1;break;case 64:this.tagClass=2;break;case 128:this.tagClass=3;break;case 192:this.tagClass=4;break;default:return this.error="Unknown tag class",-1}this.isConstructed=(o[0]&32)===32,this.isHexOnly=!1;let a=o[0]&31;if(a!==31)this.tagNumber=a,this.blockLength=1;else{let c=1,f=this.valueHexView=new Uint8Array(255),l=255;for(;o[c]&128;){if(f[c-1]=o[c]&127,c++,c>=o.length)return this.error="End of input reached before message was fully decoded",-1;if(c===l){l+=255;let h=new Uint8Array(l);for(let x=0;x<f.length;x++)h[x]=f[x];f=this.valueHexView=new Uint8Array(l)}}this.blockLength=c+1,f[c-1]=o[c]&127;let u=new Uint8Array(c);for(let h=0;h<c;h++)u[h]=f[h];f=this.valueHexView=new Uint8Array(c),f.set(u),this.blockLength<=9?this.tagNumber=ke(f,7):(this.isHexOnly=!0,this.warnings.push("Tag too long, represented as hex-coded"))}if(this.tagClass===1&&this.isConstructed)switch(this.tagNumber){case 1:case 2:case 5:case 6:case 9:case 13:case 14:case 23:case 24:case 31:case 32:case 33:case 34:return this.error="Constructed encoding used for primitive type",-1}return e+this.blockLength}toJSON(){return{...super.toJSON(),tagClass:this.tagClass,tagNumber:this.tagNumber,isConstructed:this.isConstructed}}};Zr.NAME="identificationBlock";var Wr=class extends zt{constructor({lenBlock:t={}}={}){var e,n,s;super(),this.isIndefiniteForm=(e=t.isIndefiniteForm)!==null&&e!==void 0?e:!1,this.longFormUsed=(n=t.longFormUsed)!==null&&n!==void 0?n:!1,this.length=(s=t.length)!==null&&s!==void 0?s:0}fromBER(t,e,n){let s=M.BufferSourceConverter.toUint8Array(t);if(!Zt(this,s,e,n))return-1;let o=s.subarray(e,e+n);if(o.length===0)return this.error="Zero buffer length",-1;if(o[0]===255)return this.error="Length block 0xFF is reserved by standard",-1;if(this.isIndefiniteForm=o[0]===128,this.isIndefiniteForm)return this.blockLength=1,e+this.blockLength;if(this.longFormUsed=!!(o[0]&128),this.longFormUsed===!1)return this.length=o[0],this.blockLength=1,e+this.blockLength;let i=o[0]&127;if(i>8)return this.error="Too big integer",-1;if(i+1>o.length)return this.error="End of input reached before message was fully decoded",-1;let a=e+1,c=s.subarray(a,a+i);return c[i-1]===0&&this.warnings.push("Needlessly long encoded length"),this.length=ke(c,8),this.longFormUsed&&this.length<=127&&this.warnings.push("Unnecessary usage of long length form"),this.blockLength=i+1,e+this.blockLength}toBER(t=!1){let e,n;if(this.length>127&&(this.longFormUsed=!0),this.isIndefiniteForm)return e=new ArrayBuffer(1),t===!1&&(n=new Uint8Array(e),n[0]=128),e;if(this.longFormUsed){let s=he(this.length,8);if(s.byteLength>127)return this.error="Too big length",Lt;if(e=new ArrayBuffer(s.byteLength+1),t)return e;let o=new Uint8Array(s);n=new Uint8Array(e),n[0]=s.byteLength|128;for(let i=0;i<s.byteLength;i++)n[i+1]=o[i];return e}return e=new ArrayBuffer(1),t===!1&&(n=new Uint8Array(e),n[0]=this.length),e}toJSON(){return{...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,longFormUsed:this.longFormUsed,length:this.length}}};Wr.NAME="lengthBlock";var A={},it=class extends zt{constructor({name:t=je,optional:e=!1,primitiveSchema:n,...s}={},o){super(s),this.name=t,this.optional=e,n&&(this.primitiveSchema=n),this.idBlock=new Zr(s),this.lenBlock=new Wr(s),this.valueBlock=o?new o(s):new ut(s)}fromBER(t,e,n){let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}toBER(t,e){let n=e||new fr;e||Mi(this);let s=this.idBlock.toBER(t);if(n.write(s),this.lenBlock.isIndefiniteForm)n.write(new Uint8Array([128]).buffer),this.valueBlock.toBER(t,n),n.write(new ArrayBuffer(2));else{let o=this.valueBlock.toBER(t);this.lenBlock.length=o.byteLength;let i=this.lenBlock.toBER(t);n.write(i),n.write(o)}return e?Lt:n.final()}toJSON(){let t={...super.toJSON(),idBlock:this.idBlock.toJSON(),lenBlock:this.lenBlock.toJSON(),valueBlock:this.valueBlock.toJSON(),name:this.name,optional:this.optional};return this.primitiveSchema&&(t.primitiveSchema=this.primitiveSchema.toJSON()),t}toString(t="ascii"){return t==="ascii"?this.onAsciiEncoding():M.Convert.ToHex(this.toBER())}onAsciiEncoding(){return`${this.constructor.NAME} : ${M.Convert.ToHex(this.valueBlock.valueBeforeDecodeView)}`}isEqual(t){if(this===t)return!0;if(!(t instanceof this.constructor))return!1;let e=this.toBER(),n=t.toBER();return _i(e,n)}};it.NAME="BaseBlock";function Mi(r){if(r instanceof A.Constructed)for(let t of r.valueBlock.value)Mi(t)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var Jr=class extends it{constructor({value:t=je,...e}={},n){super(e,n),t&&this.fromString(t)}getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}fromBER(t,e,n){let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.fromBuffer(this.valueBlock.valueHexView),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}onAsciiEncoding(){return`${this.constructor.NAME} : '${this.valueBlock.value}'`}};Jr.NAME="BaseStringBlock";var Yr=class extends Wt(ut){constructor({isHexOnly:t=!0,...e}={}){super(e),this.isHexOnly=t}};Yr.NAME="PrimitiveValueBlock";var Pi,Xr=class extends it{constructor(t={}){super(t,Yr),this.idBlock.isConstructed=!1}};Pi=Xr;A.Primitive=Pi;Xr.NAME="PRIMITIVE";function zu(r,t){if(r instanceof t)return r;let e=new t;return e.idBlock=r.idBlock,e.lenBlock=r.lenBlock,e.warnings=r.warnings,e.valueBeforeDecodeView=r.valueBeforeDecodeView,e}function Rn(r,t=0,e=r.length){let n=t,s=new it({},ut),o=new zt;if(!Zt(o,r,t,e))return s.error=o.error,{offset:-1,result:s};if(!r.subarray(t,t+e).length)return s.error="Zero buffer length",{offset:-1,result:s};let a=s.idBlock.fromBER(r,t,e);if(s.idBlock.warnings.length&&s.warnings.concat(s.idBlock.warnings),a===-1)return s.error=s.idBlock.error,{offset:-1,result:s};if(t=a,e-=s.idBlock.blockLength,a=s.lenBlock.fromBER(r,t,e),s.lenBlock.warnings.length&&s.warnings.concat(s.lenBlock.warnings),a===-1)return s.error=s.lenBlock.error,{offset:-1,result:s};if(t=a,e-=s.lenBlock.blockLength,!s.idBlock.isConstructed&&s.lenBlock.isIndefiniteForm)return s.error="Indefinite length form used for primitive encoding form",{offset:-1,result:s};let c=it;switch(s.idBlock.tagClass){case 1:if(s.idBlock.tagNumber>=37&&s.idBlock.isHexOnly===!1)return s.error="UNIVERSAL 37 and upper tags are reserved by ASN.1 standard",{offset:-1,result:s};switch(s.idBlock.tagNumber){case 0:if(s.idBlock.isConstructed&&s.lenBlock.length>0)return s.error="Type [UNIVERSAL 0] is reserved",{offset:-1,result:s};c=A.EndOfContent;break;case 1:c=A.Boolean;break;case 2:c=A.Integer;break;case 3:c=A.BitString;break;case 4:c=A.OctetString;break;case 5:c=A.Null;break;case 6:c=A.ObjectIdentifier;break;case 10:c=A.Enumerated;break;case 12:c=A.Utf8String;break;case 13:c=A.RelativeObjectIdentifier;break;case 14:c=A.TIME;break;case 15:return s.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:s};case 16:c=A.Sequence;break;case 17:c=A.Set;break;case 18:c=A.NumericString;break;case 19:c=A.PrintableString;break;case 20:c=A.TeletexString;break;case 21:c=A.VideotexString;break;case 22:c=A.IA5String;break;case 23:c=A.UTCTime;break;case 24:c=A.GeneralizedTime;break;case 25:c=A.GraphicString;break;case 26:c=A.VisibleString;break;case 27:c=A.GeneralString;break;case 28:c=A.UniversalString;break;case 29:c=A.CharacterString;break;case 30:c=A.BmpString;break;case 31:c=A.DATE;break;case 32:c=A.TimeOfDay;break;case 33:c=A.DateTime;break;case 34:c=A.Duration;break;default:{let f=s.idBlock.isConstructed?new A.Constructed:new A.Primitive;f.idBlock=s.idBlock,f.lenBlock=s.lenBlock,f.warnings=s.warnings,s=f}}break;case 2:case 3:case 4:default:c=s.idBlock.isConstructed?A.Constructed:A.Primitive}return s=zu(s,c),a=s.fromBER(r,t,s.lenBlock.isIndefiniteForm?e:s.lenBlock.length),s.valueBeforeDecodeView=r.subarray(n,n+s.blockLength),{offset:a,result:s}}function lo(r){if(!r.byteLength){let t=new it({},ut);return t.error="Input buffer has zero length",{offset:-1,result:t}}return Rn(M.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function Gu(r,t){return r?1:t}var _t=class extends ut{constructor({value:t=[],isIndefiniteForm:e=!1,...n}={}){super(n),this.value=t,this.isIndefiniteForm=e}fromBER(t,e,n){let s=M.BufferSourceConverter.toUint8Array(t);if(!Zt(this,s,e,n))return-1;if(this.valueBeforeDecodeView=s.subarray(e,e+n),this.valueBeforeDecodeView.length===0)return this.warnings.push("Zero buffer length"),e;let o=e;for(;Gu(this.isIndefiniteForm,n)>0;){let i=Rn(s,o,n);if(i.offset===-1)return this.error=i.result.error,this.warnings.concat(i.result.warnings),-1;if(o=i.offset,this.blockLength+=i.result.blockLength,n-=i.result.blockLength,this.value.push(i.result),this.isIndefiniteForm&&i.result.constructor.NAME===hr)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===hr?this.value.pop():this.warnings.push("No EndOfContent block encoded")),o}toBER(t,e){let n=e||new fr;for(let s=0;s<this.value.length;s++)this.value[s].toBER(t,n);return e?Lt:n.final()}toJSON(){let t={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let e of this.value)t.value.push(e.toJSON());return t}};_t.NAME="ConstructedValueBlock";var Fi,de=class extends it{constructor(t={}){super(t,_t),this.idBlock.isConstructed=!0}fromBER(t,e,n){this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm;let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}onAsciiEncoding(){let t=[];for(let n of this.valueBlock.value)t.push(n.toString("ascii").split(`
2
+ "use strict";var Libp2PPlaintext=(()=>{var oc=Object.create;var Br=Object.defineProperty;var ic=Object.getOwnPropertyDescriptor;var ac=Object.getOwnPropertyNames;var cc=Object.getPrototypeOf,lc=Object.prototype.hasOwnProperty;var uc=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),ht=(r,t)=>{for(var e in t)Br(r,e,{get:t[e],enumerable:!0})},Uo=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of ac(t))!lc.call(r,s)&&s!==e&&Br(r,s,{get:()=>t[s],enumerable:!(n=ic(t,s))||n.enumerable});return r};var fc=(r,t,e)=>(e=r!=null?oc(cc(r)):{},Uo(t||!r||!r.__esModule?Br(e,"default",{value:r,enumerable:!0}):e,r)),hc=r=>Uo(Br({},"__esModule",{value:!0}),r);var Li=uc(Ke=>{"use strict";var Du="[object ArrayBuffer]",$t=class r{static isArrayBuffer(t){return Object.prototype.toString.call(t)===Du}static toArrayBuffer(t){return this.isArrayBuffer(t)?t:t.byteLength===t.buffer.byteLength||t.byteOffset===0&&t.byteLength===t.buffer.byteLength?t.buffer:this.toUint8Array(t.buffer).slice(t.byteOffset,t.byteOffset+t.byteLength).buffer}static toUint8Array(t){return this.toView(t,Uint8Array)}static toView(t,e){if(t.constructor===e)return t;if(this.isArrayBuffer(t))return new e(t);if(this.isArrayBufferView(t))return new e(t.buffer,t.byteOffset,t.byteLength);throw new TypeError("The provided value is not of type '(ArrayBuffer or ArrayBufferView)'")}static isBufferSource(t){return this.isArrayBufferView(t)||this.isArrayBuffer(t)}static isArrayBufferView(t){return ArrayBuffer.isView(t)||t&&this.isArrayBuffer(t.buffer)}static isEqual(t,e){let n=r.toUint8Array(t),s=r.toUint8Array(e);if(n.length!==s.byteLength)return!1;for(let o=0;o<n.length;o++)if(n[o]!==s[o])return!1;return!0}static concat(...t){let e;Array.isArray(t[0])&&!(t[1]instanceof Function)||Array.isArray(t[0])&&t[1]instanceof Function?e=t[0]:t[t.length-1]instanceof Function?e=t.slice(0,t.length-1):e=t;let n=0;for(let i of e)n+=i.byteLength;let s=new Uint8Array(n),o=0;for(let i of e){let a=this.toUint8Array(i);s.set(a,o),o+=a.length}return t[t.length-1]instanceof Function?this.toView(s,t[t.length-1]):s.buffer}},oo="string",Ou=/^[0-9a-f]+$/i,Mu=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,Pu=/^[a-zA-Z0-9-_]+$/,qr=class{static fromString(t){let e=unescape(encodeURIComponent(t)),n=new Uint8Array(e.length);for(let s=0;s<e.length;s++)n[s]=e.charCodeAt(s);return n.buffer}static toString(t){let e=$t.toUint8Array(t),n="";for(let o=0;o<e.length;o++)n+=String.fromCharCode(e[o]);return decodeURIComponent(escape(n))}},At=class{static toString(t,e=!1){let n=$t.toArrayBuffer(t),s=new DataView(n),o="";for(let i=0;i<n.byteLength;i+=2){let a=s.getUint16(i,e);o+=String.fromCharCode(a)}return o}static fromString(t,e=!1){let n=new ArrayBuffer(t.length*2),s=new DataView(n);for(let o=0;o<t.length;o++)s.setUint16(o*2,t.charCodeAt(o),e);return n}},zr=class r{static isHex(t){return typeof t===oo&&Ou.test(t)}static isBase64(t){return typeof t===oo&&Mu.test(t)}static isBase64Url(t){return typeof t===oo&&Pu.test(t)}static ToString(t,e="utf8"){let n=$t.toUint8Array(t);switch(e.toLowerCase()){case"utf8":return this.ToUtf8String(n);case"binary":return this.ToBinary(n);case"hex":return this.ToHex(n);case"base64":return this.ToBase64(n);case"base64url":return this.ToBase64Url(n);case"utf16le":return At.toString(n,!0);case"utf16":case"utf16be":return At.toString(n);default:throw new Error(`Unknown type of encoding '${e}'`)}}static FromString(t,e="utf8"){if(!t)return new ArrayBuffer(0);switch(e.toLowerCase()){case"utf8":return this.FromUtf8String(t);case"binary":return this.FromBinary(t);case"hex":return this.FromHex(t);case"base64":return this.FromBase64(t);case"base64url":return this.FromBase64Url(t);case"utf16le":return At.fromString(t,!0);case"utf16":case"utf16be":return At.fromString(t);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToBase64(t){let e=$t.toUint8Array(t);if(typeof btoa<"u"){let n=this.ToString(e,"binary");return btoa(n)}else return Buffer.from(e).toString("base64")}static FromBase64(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isBase64(e))throw new TypeError("Argument 'base64Text' is not Base64 encoded");return typeof atob<"u"?this.FromBinary(atob(e)):new Uint8Array(Buffer.from(e,"base64")).buffer}static FromBase64Url(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isBase64Url(e))throw new TypeError("Argument 'base64url' is not Base64Url encoded");return this.FromBase64(this.Base64Padding(e.replace(/\-/g,"+").replace(/\_/g,"/")))}static ToBase64Url(t){return this.ToBase64(t).replace(/\+/g,"-").replace(/\//g,"_").replace(/\=/g,"")}static FromUtf8String(t,e=r.DEFAULT_UTF8_ENCODING){switch(e){case"ascii":return this.FromBinary(t);case"utf8":return qr.fromString(t);case"utf16":case"utf16be":return At.fromString(t);case"utf16le":case"usc2":return At.fromString(t,!0);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToUtf8String(t,e=r.DEFAULT_UTF8_ENCODING){switch(e){case"ascii":return this.ToBinary(t);case"utf8":return qr.toString(t);case"utf16":case"utf16be":return At.toString(t);case"utf16le":case"usc2":return At.toString(t,!0);default:throw new Error(`Unknown type of encoding '${e}'`)}}static FromBinary(t){let e=t.length,n=new Uint8Array(e);for(let s=0;s<e;s++)n[s]=t.charCodeAt(s);return n.buffer}static ToBinary(t){let e=$t.toUint8Array(t),n="";for(let s=0;s<e.length;s++)n+=String.fromCharCode(e[s]);return n}static ToHex(t){let e=$t.toUint8Array(t),n="",s=e.length;for(let o=0;o<s;o++){let i=e[o];i<16&&(n+="0"),n+=i.toString(16)}return n}static FromHex(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isHex(e))throw new TypeError("Argument 'hexString' is not HEX encoded");e.length%2&&(e=`0${e}`);let n=new Uint8Array(e.length/2);for(let s=0;s<e.length;s=s+2){let o=e.slice(s,s+2);n[s/2]=parseInt(o,16)}return n.buffer}static ToUtf16String(t,e=!1){return At.toString(t,e)}static FromUtf16String(t,e=!1){return At.fromString(t,e)}static Base64Padding(t){let e=4-t.length%4;if(e<4)for(let n=0;n<e;n++)t+="=";return t}static formatString(t){return t?.replace(/[\n\r\t ]/g,"")||""}};zr.DEFAULT_UTF8_ENCODING="utf8";function Fu(r,...t){let e=arguments[0];for(let n=1;n<arguments.length;n++){let s=arguments[n];for(let o in s)e[o]=s[o]}return e}function Ku(...r){let t=r.map(s=>s.byteLength).reduce((s,o)=>s+o),e=new Uint8Array(t),n=0;return r.map(s=>new Uint8Array(s)).forEach(s=>{for(let o of s)e[n++]=o}),e.buffer}function $u(r,t){if(!(r&&t)||r.byteLength!==t.byteLength)return!1;let e=new Uint8Array(r),n=new Uint8Array(t);for(let s=0;s<r.byteLength;s++)if(e[s]!==n[s])return!1;return!0}Ke.BufferSourceConverter=$t;Ke.Convert=zr;Ke.assign=Fu;Ke.combine=Ku;Ke.isEqual=$u});var ff={};ht(ff,{plaintext:()=>uf});var Xn=Symbol.for("@libp2p/peer-id");var Er=class extends Error{static name="UnexpectedPeerError";constructor(t="Unexpected Peer"){super(t),this.name="UnexpectedPeerError"}},Ye=class extends Error{static name="InvalidCryptoExchangeError";constructor(t="Invalid crypto exchange"){super(t),this.name="InvalidCryptoExchangeError"}},dt=class extends Error{static name="InvalidParametersError";constructor(t="Invalid parameters"){super(t),this.name="InvalidParametersError"}},Ie=class extends Error{static name="InvalidPublicKeyError";constructor(t="Invalid public key"){super(t),this.name="InvalidPublicKeyError"}};var Ne=class extends Error{static name="ProtocolError";constructor(t="Protocol error"){super(t),this.name="ProtocolError"}};var Ar=class extends Error{static name="UnsupportedKeyTypeError";constructor(t="Unsupported key type"){super(t),this.name="UnsupportedKeyTypeError"}};var To=Symbol.for("@libp2p/service-capabilities"),pf=Symbol.for("@libp2p/service-dependencies");var ns={};ht(ns,{base58btc:()=>Q,base58flickr:()=>yc});var Mf=new Uint8Array(0);function Lo(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function Dt(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 Ro(r){return new TextEncoder().encode(r)}function _o(r){return new TextDecoder().decode(r)}function dc(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 s=0;s<r.length;s++){var o=r.charAt(s),i=o.charCodeAt(0);if(e[i]!==255)throw new TypeError(o+" is ambiguous");e[i]=s}var a=r.length,c=r.charAt(0),f=Math.log(a)/Math.log(256),l=Math.log(256)/Math.log(a);function u(v){if(v instanceof Uint8Array||(ArrayBuffer.isView(v)?v=new Uint8Array(v.buffer,v.byteOffset,v.byteLength):Array.isArray(v)&&(v=Uint8Array.from(v))),!(v instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(v.length===0)return"";for(var b=0,d=0,y=0,E=v.length;y!==E&&v[y]===0;)y++,b++;for(var p=(E-y)*l+1>>>0,S=new Uint8Array(p);y!==E;){for(var L=v[y],T=0,k=p-1;(L!==0||T<d)&&k!==-1;k--,T++)L+=256*S[k]>>>0,S[k]=L%a>>>0,L=L/a>>>0;if(L!==0)throw new Error("Non-zero carry");d=T,y++}for(var I=p-d;I!==p&&S[I]===0;)I++;for(var U=c.repeat(b);I<p;++I)U+=r.charAt(S[I]);return U}function h(v){if(typeof v!="string")throw new TypeError("Expected String");if(v.length===0)return new Uint8Array;var b=0;if(v[b]!==" "){for(var d=0,y=0;v[b]===c;)d++,b++;for(var E=(v.length-b)*f+1>>>0,p=new Uint8Array(E);v[b];){var S=e[v.charCodeAt(b)];if(S===255)return;for(var L=0,T=E-1;(S!==0||L<y)&&T!==-1;T--,L++)S+=a*p[T]>>>0,p[T]=S%256>>>0,S=S/256>>>0;if(S!==0)throw new Error("Non-zero carry");y=L,b++}if(v[b]!==" "){for(var k=E-y;k!==E&&p[k]===0;)k++;for(var I=new Uint8Array(d+(E-k)),U=d;k!==E;)I[U++]=p[k++];return I}}}function x(v){var b=h(v);if(b)return b;throw new Error(`Non-${t} character`)}return{encode:u,decodeUnsafe:h,decode:x}}var gc=dc,pc=gc,Ho=pc;var Qn=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")}},ts=class{name;prefix;baseDecode;prefixCodePoint;constructor(t,e,n){this.name=t,this.prefix=e;let s=e.codePointAt(0);if(s===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=s,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 Do(this,t)}},es=class{decoders;constructor(t){this.decoders=t}or(t){return Do(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 Do(r,t){return new es({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var rs=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(t,e,n,s){this.name=t,this.prefix=e,this.baseEncode=n,this.baseDecode=s,this.encoder=new Qn(t,e,n),this.decoder=new ts(t,e,s)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function Ce({name:r,prefix:t,encode:e,decode:n}){return new rs(r,t,e,n)}function Qt({name:r,prefix:t,alphabet:e}){let{encode:n,decode:s}=Ho(e,r);return Ce({prefix:t,name:r,encode:n,decode:o=>Dt(s(o))})}function mc(r,t,e,n){let s={};for(let l=0;l<t.length;++l)s[t[l]]=l;let o=r.length;for(;r[o-1]==="=";)--o;let i=new Uint8Array(o*e/8|0),a=0,c=0,f=0;for(let l=0;l<o;++l){let u=s[r[l]];if(u===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<e|u,a+=e,a>=8&&(a-=8,i[f++]=255&c>>a)}if(a>=e||255&c<<8-a)throw new SyntaxError("Unexpected end of data");return i}function bc(r,t,e){let n=t[t.length-1]==="=",s=(1<<e)-1,o="",i=0,a=0;for(let c=0;c<r.length;++c)for(a=a<<8|r[c],i+=8;i>e;)i-=e,o+=t[s&a>>i];if(i!==0&&(o+=t[s&a<<e-i]),n)for(;o.length*e&7;)o+="=";return o}function Z({name:r,prefix:t,bitsPerChar:e,alphabet:n}){return Ce({prefix:t,name:r,encode(s){return bc(s,n,e)},decode(s){return mc(s,n,e,r)}})}var Q=Qt({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),yc=Qt({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var ss={};ht(ss,{base32:()=>Ue,base32hex:()=>Bc,base32hexpad:()=>Ac,base32hexpadupper:()=>Sc,base32hexupper:()=>Ec,base32pad:()=>xc,base32padupper:()=>vc,base32upper:()=>wc,base32z:()=>kc});var Ue=Z({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),wc=Z({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),xc=Z({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),vc=Z({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),Bc=Z({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),Ec=Z({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),Ac=Z({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),Sc=Z({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),kc=Z({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var os={};ht(os,{base36:()=>Xe,base36upper:()=>Ic});var Xe=Qt({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),Ic=Qt({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Nc=Po,Oo=128,Cc=127,Uc=~Cc,Tc=Math.pow(2,31);function Po(r,t,e){t=t||[],e=e||0;for(var n=e;r>=Tc;)t[e++]=r&255|Oo,r/=128;for(;r&Uc;)t[e++]=r&255|Oo,r>>>=7;return t[e]=r|0,Po.bytes=e-n+1,t}var Lc=is,Rc=128,Mo=127;function is(r,n){var e=0,n=n||0,s=0,o=n,i,a=r.length;do{if(o>=a)throw is.bytes=0,new RangeError("Could not decode varint");i=r[o++],e+=s<28?(i&Mo)<<s:(i&Mo)*Math.pow(2,s),s+=7}while(i>=Rc);return is.bytes=o-n,e}var _c=Math.pow(2,7),Vc=Math.pow(2,14),Hc=Math.pow(2,21),Dc=Math.pow(2,28),Oc=Math.pow(2,35),Mc=Math.pow(2,42),Pc=Math.pow(2,49),Fc=Math.pow(2,56),Kc=Math.pow(2,63),$c=function(r){return r<_c?1:r<Vc?2:r<Hc?3:r<Dc?4:r<Oc?5:r<Mc?6:r<Pc?7:r<Fc?8:r<Kc?9:10},qc={encode:Nc,decode:Lc,encodingLength:$c},zc=qc,Qe=zc;function tr(r,t=0){return[Qe.decode(r,t),Qe.decode.bytes]}function Te(r,t,e=0){return Qe.encode(r,t,e),t}function Le(r){return Qe.encodingLength(r)}function St(r,t){let e=t.byteLength,n=Le(r),s=n+Le(e),o=new Uint8Array(s+e);return Te(r,o,0),Te(e,o,n),o.set(t,s),new Re(r,e,t,o)}function as(r){let t=Dt(r),[e,n]=tr(t),[s,o]=tr(t.subarray(n)),i=t.subarray(n+o);if(i.byteLength!==s)throw new Error("Incorrect length");return new Re(e,s,i,t)}function Fo(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&Lo(r.bytes,e.bytes)}}var Re=class{code;size;digest;bytes;constructor(t,e,n,s){this.code=t,this.size=e,this.digest=n,this.bytes=s}};function Ko(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return jc(e,cs(r),t??Q.encoder);default:return Zc(e,cs(r),t??Ue.encoder)}}var $o=new WeakMap;function cs(r){let t=$o.get(r);if(t==null){let e=new Map;return $o.set(r,e),e}return t}var Bt=class r{code;version;multihash;bytes;"/";constructor(t,e,n,s){this.code=e,this.version=t,this.multihash=n,this.bytes=s,this["/"]=s}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!==er)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==Wc)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=St(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&&Fo(t.multihash,n.multihash)}toString(t){return Ko(this,t)}toJSON(){return{"/":Ko(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:s,multihash:o,bytes:i}=e;return new r(n,s,o,i??qo(n,s,o.bytes))}else if(e[Jc]===!0){let{version:n,multihash:s,code:o}=e,i=as(s);return r.create(n,o,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!==er)throw new Error(`Version 0 CID must use dag-pb (code: ${er}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let s=qo(t,e,n.bytes);return new r(t,e,n,s)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,er,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,s=Dt(t.subarray(n,n+e.multihashSize));if(s.byteLength!==e.multihashSize)throw new Error("Incorrect length");let o=s.subarray(e.multihashSize-e.digestSize),i=new Re(e.multihashCode,e.digestSize,o,s);return[e.version===0?r.createV0(i):r.createV1(e.codec,i),t.subarray(e.size)]}static inspectBytes(t){let e=0,n=()=>{let[u,h]=tr(t.subarray(e));return e+=h,u},s=n(),o=er;if(s===18?(s=0,e=0):o=n(),s!==0&&s!==1)throw new RangeError(`Invalid CID version ${s}`);let i=e,a=n(),c=n(),f=e+c,l=f-i;return{version:s,codec:o,multihashCode:a,digestSize:c,multihashSize:l,size:f}}static parse(t,e){let[n,s]=Gc(t,e),o=r.decode(s);if(o.version===0&&t[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return cs(o).set(n,t),o}};function Gc(r,t){switch(r[0]){case"Q":{let e=t??Q;return[Q.prefix,e.decode(`${Q.prefix}${r}`)]}case Q.prefix:{let e=t??Q;return[Q.prefix,e.decode(r)]}case Ue.prefix:{let e=t??Ue;return[Ue.prefix,e.decode(r)]}case Xe.prefix:{let e=t??Xe;return[Xe.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 jc(r,t,e){let{prefix:n}=e;if(n!==Q.prefix)throw Error(`Cannot string encode V0 in ${e.name} encoding`);let s=t.get(n);if(s==null){let o=e.encode(r).slice(1);return t.set(n,o),o}else return s}function Zc(r,t,e){let{prefix:n}=e,s=t.get(n);if(s==null){let o=e.encode(r);return t.set(n,o),o}else return s}var er=112,Wc=18;function qo(r,t,e){let n=Le(r),s=n+Le(t),o=new Uint8Array(s+e.byteLength);return Te(r,o,0),Te(t,o,n),o.set(e,s),o}var Jc=Symbol.for("@ipld/js-cid/CID");var ls={};ht(ls,{identity:()=>te});var zo=0,Yc="identity",Go=Dt;function Xc(r){return St(zo,Go(r))}var te={code:zo,name:Yc,encode:Go,digest:Xc};function mt(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 jo(r){if(!Number.isSafeInteger(r)||r<0)throw new Error(`positive integer expected, not ${r}`)}function Qc(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function Ve(r,...t){if(!Qc(r))throw new Error("Uint8Array expected");if(t.length>0&&!t.includes(r.length))throw new Error(`Uint8Array expected of length ${t}, not of length=${r.length}`)}function Zo(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");jo(r.outputLen),jo(r.blockLen)}function He(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 Wo(r,t){Ve(r);let e=t.outputLen;if(r.length<e)throw new Error(`digestInto() expects output buffer of length at least ${e}`)}var ge=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;var kr=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),kt=(r,t)=>r<<32-t|r>>>t;var ch=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;function Jo(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function rr(r){return typeof r=="string"&&(r=Jo(r)),Ve(r),r}function us(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];Ve(s),t+=s.length}let e=new Uint8Array(t);for(let n=0,s=0;n<r.length;n++){let o=r[n];e.set(o,s),s+=o.length}return e}var De=class{clone(){return this._cloneInto()}},lh={}.toString;function Ir(r){let t=n=>r().update(rr(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function Nr(r=32){if(ge&&typeof ge.getRandomValues=="function")return ge.getRandomValues(new Uint8Array(r));if(ge&&typeof ge.randomBytes=="function")return ge.randomBytes(r);throw new Error("crypto.getRandomValues must be defined")}function tl(r,t,e,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(t,e,n);let s=BigInt(32),o=BigInt(4294967295),i=Number(e>>s&o),a=Number(e&o),c=n?4:0,f=n?0:4;r.setUint32(t+c,i,n),r.setUint32(t+f,a,n)}var Yo=(r,t,e)=>r&t^~r&e,Xo=(r,t,e)=>r&t^r&e^t&e,Oe=class extends De{constructor(t,e,n,s){super(),this.blockLen=t,this.outputLen=e,this.padOffset=n,this.isLE=s,this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.buffer=new Uint8Array(t),this.view=kr(this.buffer)}update(t){He(this);let{view:e,buffer:n,blockLen:s}=this;t=rr(t);let o=t.length;for(let i=0;i<o;){let a=Math.min(s-this.pos,o-i);if(a===s){let c=kr(t);for(;s<=o-i;i+=s)this.process(c,i);continue}n.set(t.subarray(i,i+a),this.pos),this.pos+=a,i+=a,this.pos===s&&(this.process(e,0),this.pos=0)}return this.length+=t.length,this.roundClean(),this}digestInto(t){He(this),Wo(t,this),this.finished=!0;let{buffer:e,view:n,blockLen:s,isLE:o}=this,{pos:i}=this;e[i++]=128,this.buffer.subarray(i).fill(0),this.padOffset>s-i&&(this.process(n,0),i=0);for(let u=i;u<s;u++)e[u]=0;tl(n,s-8,BigInt(this.length*8),o),this.process(n,0);let a=kr(t),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let f=c/4,l=this.get();if(f>l.length)throw new Error("_sha2: outputLen bigger than state");for(let u=0;u<f;u++)a.setUint32(4*u,l[u],o)}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:s,finished:o,destroyed:i,pos:a}=this;return t.length=s,t.pos=a,t.finished=o,t.destroyed=i,s%e&&t.buffer.set(n),t}};var Cr=BigInt(4294967295),fs=BigInt(32);function Qo(r,t=!1){return t?{h:Number(r&Cr),l:Number(r>>fs&Cr)}:{h:Number(r>>fs&Cr)|0,l:Number(r&Cr)|0}}function el(r,t=!1){let e=new Uint32Array(r.length),n=new Uint32Array(r.length);for(let s=0;s<r.length;s++){let{h:o,l:i}=Qo(r[s],t);[e[s],n[s]]=[o,i]}return[e,n]}var rl=(r,t)=>BigInt(r>>>0)<<fs|BigInt(t>>>0),nl=(r,t,e)=>r>>>e,sl=(r,t,e)=>r<<32-e|t>>>e,ol=(r,t,e)=>r>>>e|t<<32-e,il=(r,t,e)=>r<<32-e|t>>>e,al=(r,t,e)=>r<<64-e|t>>>e-32,cl=(r,t,e)=>r>>>e-32|t<<64-e,ll=(r,t)=>t,ul=(r,t)=>r,fl=(r,t,e)=>r<<e|t>>>32-e,hl=(r,t,e)=>t<<e|r>>>32-e,dl=(r,t,e)=>t<<e-32|r>>>64-e,gl=(r,t,e)=>r<<e-32|t>>>64-e;function pl(r,t,e,n){let s=(t>>>0)+(n>>>0);return{h:r+e+(s/2**32|0)|0,l:s|0}}var ml=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),bl=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,yl=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),wl=(r,t,e,n,s)=>t+e+n+s+(r/2**32|0)|0,xl=(r,t,e,n,s)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(s>>>0),vl=(r,t,e,n,s,o)=>t+e+n+s+o+(r/2**32|0)|0;var Bl={fromBig:Qo,split:el,toBig:rl,shrSH:nl,shrSL:sl,rotrSH:ol,rotrSL:il,rotrBH:al,rotrBL:cl,rotr32H:ll,rotr32L:ul,rotlSH:fl,rotlSL:hl,rotlBH:dl,rotlBL:gl,add:pl,add3L:ml,add3H:bl,add4L:yl,add4H:wl,add5H:vl,add5L:xl},V=Bl;var[El,Al]=V.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))),ee=new Uint32Array(80),re=new Uint32Array(80),hs=class extends Oe{constructor(){super(128,64,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:s,Ch:o,Cl:i,Dh:a,Dl:c,Eh:f,El:l,Fh:u,Fl:h,Gh:x,Gl:v,Hh:b,Hl:d}=this;return[t,e,n,s,o,i,a,c,f,l,u,h,x,v,b,d]}set(t,e,n,s,o,i,a,c,f,l,u,h,x,v,b,d){this.Ah=t|0,this.Al=e|0,this.Bh=n|0,this.Bl=s|0,this.Ch=o|0,this.Cl=i|0,this.Dh=a|0,this.Dl=c|0,this.Eh=f|0,this.El=l|0,this.Fh=u|0,this.Fl=h|0,this.Gh=x|0,this.Gl=v|0,this.Hh=b|0,this.Hl=d|0}process(t,e){for(let p=0;p<16;p++,e+=4)ee[p]=t.getUint32(e),re[p]=t.getUint32(e+=4);for(let p=16;p<80;p++){let S=ee[p-15]|0,L=re[p-15]|0,T=V.rotrSH(S,L,1)^V.rotrSH(S,L,8)^V.shrSH(S,L,7),k=V.rotrSL(S,L,1)^V.rotrSL(S,L,8)^V.shrSL(S,L,7),I=ee[p-2]|0,U=re[p-2]|0,J=V.rotrSH(I,U,19)^V.rotrBH(I,U,61)^V.shrSH(I,U,6),F=V.rotrSL(I,U,19)^V.rotrBL(I,U,61)^V.shrSL(I,U,6),H=V.add4L(k,F,re[p-7],re[p-16]),Y=V.add4H(H,T,J,ee[p-7],ee[p-16]);ee[p]=Y|0,re[p]=H|0}let{Ah:n,Al:s,Bh:o,Bl:i,Ch:a,Cl:c,Dh:f,Dl:l,Eh:u,El:h,Fh:x,Fl:v,Gh:b,Gl:d,Hh:y,Hl:E}=this;for(let p=0;p<80;p++){let S=V.rotrSH(u,h,14)^V.rotrSH(u,h,18)^V.rotrBH(u,h,41),L=V.rotrSL(u,h,14)^V.rotrSL(u,h,18)^V.rotrBL(u,h,41),T=u&x^~u&b,k=h&v^~h&d,I=V.add5L(E,L,k,Al[p],re[p]),U=V.add5H(I,y,S,T,El[p],ee[p]),J=I|0,F=V.rotrSH(n,s,28)^V.rotrBH(n,s,34)^V.rotrBH(n,s,39),H=V.rotrSL(n,s,28)^V.rotrBL(n,s,34)^V.rotrBL(n,s,39),Y=n&o^n&a^o&a,B=s&i^s&c^i&c;y=b|0,E=d|0,b=x|0,d=v|0,x=u|0,v=h|0,{h:u,l:h}=V.add(f|0,l|0,U|0,J|0),f=a|0,l=c|0,a=o|0,c=i|0,o=n|0,i=s|0;let N=V.add3L(J,H,B);n=V.add3H(N,U,F,Y),s=N|0}({h:n,l:s}=V.add(this.Ah|0,this.Al|0,n|0,s|0)),{h:o,l:i}=V.add(this.Bh|0,this.Bl|0,o|0,i|0),{h:a,l:c}=V.add(this.Ch|0,this.Cl|0,a|0,c|0),{h:f,l}=V.add(this.Dh|0,this.Dl|0,f|0,l|0),{h:u,l:h}=V.add(this.Eh|0,this.El|0,u|0,h|0),{h:x,l:v}=V.add(this.Fh|0,this.Fl|0,x|0,v|0),{h:b,l:d}=V.add(this.Gh|0,this.Gl|0,b|0,d|0),{h:y,l:E}=V.add(this.Hh|0,this.Hl|0,y|0,E|0),this.set(n,s,o,i,a,c,f,l,u,h,x,v,b,d,y,E)}roundClean(){ee.fill(0),re.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 ti=Ir(()=>new hs);var Tr={};ht(Tr,{aInRange:()=>bt,abool:()=>It,abytes:()=>Me,bitGet:()=>Ul,bitLen:()=>bs,bitMask:()=>sr,bitSet:()=>Tl,bytesToHex:()=>Mt,bytesToNumberBE:()=>Pt,bytesToNumberLE:()=>se,concatBytes:()=>Ft,createHmacDrbg:()=>ys,ensureBytes:()=>W,equalBytes:()=>Nl,hexToBytes:()=>me,hexToNumber:()=>ms,inRange:()=>nr,isBytes:()=>ne,memoized:()=>ye,notImplemented:()=>Rl,numberToBytesBE:()=>oe,numberToBytesLE:()=>be,numberToHexUnpadded:()=>pe,numberToVarBytesBE:()=>Il,utf8ToBytes:()=>Cl,validateObject:()=>Lt});var ps=BigInt(0),Ur=BigInt(1),Sl=BigInt(2);function ne(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function Me(r){if(!ne(r))throw new Error("Uint8Array expected")}function It(r,t){if(typeof t!="boolean")throw new Error(`${r} must be valid boolean, got "${t}".`)}var kl=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function Mt(r){Me(r);let t="";for(let e=0;e<r.length;e++)t+=kl[r[e]];return t}function pe(r){let t=r.toString(16);return t.length&1?`0${t}`:t}function ms(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return BigInt(r===""?"0":`0x${r}`)}var Ot={_0:48,_9:57,_A:65,_F:70,_a:97,_f:102};function ei(r){if(r>=Ot._0&&r<=Ot._9)return r-Ot._0;if(r>=Ot._A&&r<=Ot._F)return r-(Ot._A-10);if(r>=Ot._a&&r<=Ot._f)return r-(Ot._a-10)}function me(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);let t=r.length,e=t/2;if(t%2)throw new Error("padded hex string expected, got unpadded hex of length "+t);let n=new Uint8Array(e);for(let s=0,o=0;s<e;s++,o+=2){let i=ei(r.charCodeAt(o)),a=ei(r.charCodeAt(o+1));if(i===void 0||a===void 0){let c=r[o]+r[o+1];throw new Error('hex string expected, got non-hex character "'+c+'" at index '+o)}n[s]=i*16+a}return n}function Pt(r){return ms(Mt(r))}function se(r){return Me(r),ms(Mt(Uint8Array.from(r).reverse()))}function oe(r,t){return me(r.toString(16).padStart(t*2,"0"))}function be(r,t){return oe(r,t).reverse()}function Il(r){return me(pe(r))}function W(r,t,e){let n;if(typeof t=="string")try{n=me(t)}catch(o){throw new Error(`${r} must be valid hex string, got "${t}". Cause: ${o}`)}else if(ne(t))n=Uint8Array.from(t);else throw new Error(`${r} must be hex string or Uint8Array`);let s=n.length;if(typeof e=="number"&&s!==e)throw new Error(`${r} expected ${e} bytes, got ${s}`);return n}function Ft(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];Me(s),t+=s.length}let e=new Uint8Array(t);for(let n=0,s=0;n<r.length;n++){let o=r[n];e.set(o,s),s+=o.length}return e}function Nl(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}function Cl(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}var ds=r=>typeof r=="bigint"&&ps<=r;function nr(r,t,e){return ds(r)&&ds(t)&&ds(e)&&t<=r&&r<e}function bt(r,t,e,n){if(!nr(t,e,n))throw new Error(`expected valid ${r}: ${e} <= n < ${n}, got ${typeof t} ${t}`)}function bs(r){let t;for(t=0;r>ps;r>>=Ur,t+=1);return t}function Ul(r,t){return r>>BigInt(t)&Ur}function Tl(r,t,e){return r|(e?Ur:ps)<<BigInt(t)}var sr=r=>(Sl<<BigInt(r-1))-Ur,gs=r=>new Uint8Array(r),ri=r=>Uint8Array.from(r);function ys(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=gs(r),s=gs(r),o=0,i=()=>{n.fill(1),s.fill(0),o=0},a=(...u)=>e(s,n,...u),c=(u=gs())=>{s=a(ri([0]),u),n=a(),u.length!==0&&(s=a(ri([1]),u),n=a())},f=()=>{if(o++>=1e3)throw new Error("drbg: tried 1000 values");let u=0,h=[];for(;u<t;){n=a();let x=n.slice();h.push(x),u+=n.length}return Ft(...h)};return(u,h)=>{i(),c(u);let x;for(;!(x=h(f()));)c();return i(),x}}var Ll={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"||ne(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 Lt(r,t,e={}){let n=(s,o,i)=>{let a=Ll[o];if(typeof a!="function")throw new Error(`Invalid validator "${o}", expected function`);let c=r[s];if(!(i&&c===void 0)&&!a(c,r))throw new Error(`Invalid param ${String(s)}=${c} (${typeof c}), expected ${o}`)};for(let[s,o]of Object.entries(t))n(s,o,!1);for(let[s,o]of Object.entries(e))n(s,o,!0);return r}var Rl=()=>{throw new Error("not implemented")};function ye(r){let t=new WeakMap;return(e,...n)=>{let s=t.get(e);if(s!==void 0)return s;let o=r(e,...n);return t.set(e,o),o}}var tt=BigInt(0),G=BigInt(1),we=BigInt(2),_l=BigInt(3),ws=BigInt(4),ni=BigInt(5),si=BigInt(8),Vl=BigInt(9),Hl=BigInt(16);function q(r,t){let e=r%t;return e>=tt?e:t+e}function Dl(r,t,e){if(e<=tt||t<tt)throw new Error("Expected power/modulo > 0");if(e===G)return tt;let n=G;for(;t>tt;)t&G&&(n=n*r%e),r=r*r%e,t>>=G;return n}function j(r,t,e){let n=r;for(;t-- >tt;)n*=n,n%=e;return n}function Lr(r,t){if(r===tt||t<=tt)throw new Error(`invert: expected positive integers, got n=${r} mod=${t}`);let e=q(r,t),n=t,s=tt,o=G,i=G,a=tt;for(;e!==tt;){let f=n/e,l=n%e,u=s-i*f,h=o-a*f;n=e,e=l,s=i,o=a,i=u,a=h}if(n!==G)throw new Error("invert: does not exist");return q(s,t)}function Ol(r){let t=(r-G)/we,e,n,s;for(e=r-G,n=0;e%we===tt;e/=we,n++);for(s=we;s<r&&Dl(s,t,r)!==r-G;s++);if(n===1){let i=(r+G)/ws;return function(c,f){let l=c.pow(f,i);if(!c.eql(c.sqr(l),f))throw new Error("Cannot find square root");return l}}let o=(e+G)/we;return function(a,c){if(a.pow(c,t)===a.neg(a.ONE))throw new Error("Cannot find square root");let f=n,l=a.pow(a.mul(a.ONE,s),e),u=a.pow(c,o),h=a.pow(c,e);for(;!a.eql(h,a.ONE);){if(a.eql(h,a.ZERO))return a.ZERO;let x=1;for(let b=a.sqr(h);x<f&&!a.eql(b,a.ONE);x++)b=a.sqr(b);let v=a.pow(l,G<<BigInt(f-x-1));l=a.sqr(v),u=a.mul(u,v),h=a.mul(h,l),f=x}return u}}function Ml(r){if(r%ws===_l){let t=(r+G)/ws;return function(n,s){let o=n.pow(s,t);if(!n.eql(n.sqr(o),s))throw new Error("Cannot find square root");return o}}if(r%si===ni){let t=(r-ni)/si;return function(n,s){let o=n.mul(s,we),i=n.pow(o,t),a=n.mul(s,i),c=n.mul(n.mul(a,we),i),f=n.mul(a,n.sub(c,n.ONE));if(!n.eql(n.sqr(f),s))throw new Error("Cannot find square root");return f}}return r%Hl,Ol(r)}var oi=(r,t)=>(q(r,t)&G)===G,Pl=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function xs(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=Pl.reduce((n,s)=>(n[s]="function",n),t);return Lt(r,e)}function Fl(r,t,e){if(e<tt)throw new Error("Expected power > 0");if(e===tt)return r.ONE;if(e===G)return t;let n=r.ONE,s=t;for(;e>tt;)e&G&&(n=r.mul(n,s)),s=r.sqr(s),e>>=G;return n}function Kl(r,t){let e=new Array(t.length),n=t.reduce((o,i,a)=>r.is0(i)?o:(e[a]=o,r.mul(o,i)),r.ONE),s=r.inv(n);return t.reduceRight((o,i,a)=>r.is0(i)?o:(e[a]=r.mul(o,e[a]),r.mul(o,i)),s),e}function vs(r,t){let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function ie(r,t,e=!1,n={}){if(r<=tt)throw new Error(`Expected Field ORDER > 0, got ${r}`);let{nBitLength:s,nByteLength:o}=vs(r,t);if(o>2048)throw new Error("Field lengths over 2048 bytes are not supported");let i=Ml(r),a=Object.freeze({ORDER:r,BITS:s,BYTES:o,MASK:sr(s),ZERO:tt,ONE:G,create:c=>q(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error(`Invalid field element: expected bigint, got ${typeof c}`);return tt<=c&&c<r},is0:c=>c===tt,isOdd:c=>(c&G)===G,neg:c=>q(-c,r),eql:(c,f)=>c===f,sqr:c=>q(c*c,r),add:(c,f)=>q(c+f,r),sub:(c,f)=>q(c-f,r),mul:(c,f)=>q(c*f,r),pow:(c,f)=>Fl(a,c,f),div:(c,f)=>q(c*Lr(f,r),r),sqrN:c=>c*c,addN:(c,f)=>c+f,subN:(c,f)=>c-f,mulN:(c,f)=>c*f,inv:c=>Lr(c,r),sqrt:n.sqrt||(c=>i(a,c)),invertBatch:c=>Kl(a,c),cmov:(c,f,l)=>l?f:c,toBytes:c=>e?be(c,o):oe(c,o),fromBytes:c=>{if(c.length!==o)throw new Error(`Fp.fromBytes: expected ${o}, got ${c.length}`);return e?se(c):Pt(c)}});return Object.freeze(a)}function ii(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 Bs(r){let t=ii(r);return t+Math.ceil(t/2)}function ai(r,t,e=!1){let n=r.length,s=ii(t),o=Bs(t);if(n<16||n<o||n>1024)throw new Error(`expected ${o}-1024 bytes of input, got ${n}`);let i=e?Pt(r):se(r),a=q(i,t-G)+G;return e?be(a,s):oe(a,s)}var ql=BigInt(0),Es=BigInt(1),As=new WeakMap,ci=new WeakMap;function Rr(r,t){let e=(o,i)=>{let a=i.negate();return o?a:i},n=o=>{if(!Number.isSafeInteger(o)||o<=0||o>t)throw new Error(`Wrong window size=${o}, should be [1..${t}]`)},s=o=>{n(o);let i=Math.ceil(t/o)+1,a=2**(o-1);return{windows:i,windowSize:a}};return{constTimeNegate:e,unsafeLadder(o,i){let a=r.ZERO,c=o;for(;i>ql;)i&Es&&(a=a.add(c)),c=c.double(),i>>=Es;return a},precomputeWindow(o,i){let{windows:a,windowSize:c}=s(i),f=[],l=o,u=l;for(let h=0;h<a;h++){u=l,f.push(u);for(let x=1;x<c;x++)u=u.add(l),f.push(u);l=u.double()}return f},wNAF(o,i,a){let{windows:c,windowSize:f}=s(o),l=r.ZERO,u=r.BASE,h=BigInt(2**o-1),x=2**o,v=BigInt(o);for(let b=0;b<c;b++){let d=b*f,y=Number(a&h);a>>=v,y>f&&(y-=x,a+=Es);let E=d,p=d+Math.abs(y)-1,S=b%2!==0,L=y<0;y===0?u=u.add(e(S,i[E])):l=l.add(e(L,i[p]))}return{p:l,f:u}},wNAFCached(o,i,a){let c=ci.get(o)||1,f=As.get(o);return f||(f=this.precomputeWindow(o,c),c!==1&&As.set(o,a(f))),this.wNAF(c,f,i)},setWindowSize(o,i){n(i),ci.set(o,i),As.delete(o)}}}function _r(r,t,e,n){if(!Array.isArray(e)||!Array.isArray(n)||n.length!==e.length)throw new Error("arrays of points and scalars must have equal length");n.forEach((l,u)=>{if(!t.isValid(l))throw new Error(`wrong scalar at index ${u}`)}),e.forEach((l,u)=>{if(!(l instanceof r))throw new Error(`wrong point at index ${u}`)});let s=bs(BigInt(e.length)),o=s>12?s-3:s>4?s-2:s?2:1,i=(1<<o)-1,a=new Array(i+1).fill(r.ZERO),c=Math.floor((t.BITS-1)/o)*o,f=r.ZERO;for(let l=c;l>=0;l-=o){a.fill(r.ZERO);for(let h=0;h<n.length;h++){let x=n[h],v=Number(x>>BigInt(l)&BigInt(i));a[v]=a[v].add(e[h])}let u=r.ZERO;for(let h=a.length-1,x=r.ZERO;h>0;h--)x=x.add(a[h]),u=u.add(x);if(f=f.add(u),l!==0)for(let h=0;h<o;h++)f=f.double()}return f}function or(r){return xs(r.Fp),Lt(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...vs(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Nt=BigInt(0),yt=BigInt(1),Vr=BigInt(2),zl=BigInt(8),Gl={zip215:!0};function jl(r){let t=or(r);return Lt(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function li(r){let t=jl(r),{Fp:e,n,prehash:s,hash:o,randomBytes:i,nByteLength:a,h:c}=t,f=Vr<<BigInt(a*8)-yt,l=e.create,u=ie(t.n,t.nBitLength),h=t.uvRatio||((m,g)=>{try{return{isValid:!0,value:e.sqrt(m*e.inv(g))}}catch{return{isValid:!1,value:Nt}}}),x=t.adjustScalarBytes||(m=>m),v=t.domain||((m,g,w)=>{if(It("phflag",w),g.length||w)throw new Error("Contexts/pre-hash are not supported");return m});function b(m,g){bt("coordinate "+m,g,Nt,f)}function d(m){if(!(m instanceof p))throw new Error("ExtendedPoint expected")}let y=ye((m,g)=>{let{ex:w,ey:C,ez:R}=m,_=m.is0();g==null&&(g=_?zl:e.inv(R));let D=l(w*g),P=l(C*g),O=l(R*g);if(_)return{x:Nt,y:yt};if(O!==yt)throw new Error("invZ was invalid");return{x:D,y:P}}),E=ye(m=>{let{a:g,d:w}=t;if(m.is0())throw new Error("bad point: ZERO");let{ex:C,ey:R,ez:_,et:D}=m,P=l(C*C),O=l(R*R),$=l(_*_),z=l($*$),et=l(P*g),rt=l($*l(et+O)),ot=l(z+l(w*l(P*O)));if(rt!==ot)throw new Error("bad point: equation left != right (1)");let ft=l(C*R),X=l(_*D);if(ft!==X)throw new Error("bad point: equation left != right (2)");return!0});class p{constructor(g,w,C,R){this.ex=g,this.ey=w,this.ez=C,this.et=R,b("x",g),b("y",w),b("z",C),b("t",R),Object.freeze(this)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(g){if(g instanceof p)throw new Error("extended point not allowed");let{x:w,y:C}=g||{};return b("x",w),b("y",C),new p(w,C,yt,l(w*C))}static normalizeZ(g){let w=e.invertBatch(g.map(C=>C.ez));return g.map((C,R)=>C.toAffine(w[R])).map(p.fromAffine)}static msm(g,w){return _r(p,u,g,w)}_setWindowSize(g){T.setWindowSize(this,g)}assertValidity(){E(this)}equals(g){d(g);let{ex:w,ey:C,ez:R}=this,{ex:_,ey:D,ez:P}=g,O=l(w*P),$=l(_*R),z=l(C*P),et=l(D*R);return O===$&&z===et}is0(){return this.equals(p.ZERO)}negate(){return new p(l(-this.ex),this.ey,this.ez,l(-this.et))}double(){let{a:g}=t,{ex:w,ey:C,ez:R}=this,_=l(w*w),D=l(C*C),P=l(Vr*l(R*R)),O=l(g*_),$=w+C,z=l(l($*$)-_-D),et=O+D,rt=et-P,ot=O-D,ft=l(z*rt),X=l(et*ot),pt=l(z*ot),Ht=l(rt*et);return new p(ft,X,Ht,pt)}add(g){d(g);let{a:w,d:C}=t,{ex:R,ey:_,ez:D,et:P}=this,{ex:O,ey:$,ez:z,et}=g;if(w===BigInt(-1)){let Eo=l((_-R)*($+O)),Ao=l((_+R)*($-O)),Yn=l(Ao-Eo);if(Yn===Nt)return this.double();let So=l(D*Vr*et),ko=l(P*Vr*z),Io=ko+So,No=Ao+Eo,Co=ko-So,ec=l(Io*Yn),rc=l(No*Co),nc=l(Io*Co),sc=l(Yn*No);return new p(ec,rc,sc,nc)}let rt=l(R*O),ot=l(_*$),ft=l(P*C*et),X=l(D*z),pt=l((R+_)*(O+$)-rt-ot),Ht=X-ft,We=X+ft,Je=l(ot-w*rt),Ya=l(pt*Ht),Xa=l(We*Je),Qa=l(pt*Je),tc=l(Ht*We);return new p(Ya,Xa,tc,Qa)}subtract(g){return this.add(g.negate())}wNAF(g){return T.wNAFCached(this,g,p.normalizeZ)}multiply(g){let w=g;bt("scalar",w,yt,n);let{p:C,f:R}=this.wNAF(w);return p.normalizeZ([C,R])[0]}multiplyUnsafe(g){let w=g;return bt("scalar",w,Nt,n),w===Nt?L:this.equals(L)||w===yt?this:this.equals(S)?this.wNAF(w).p:T.unsafeLadder(this,w)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return T.unsafeLadder(this,n).is0()}toAffine(g){return y(this,g)}clearCofactor(){let{h:g}=t;return g===yt?this:this.multiplyUnsafe(g)}static fromHex(g,w=!1){let{d:C,a:R}=t,_=e.BYTES;g=W("pointHex",g,_),It("zip215",w);let D=g.slice(),P=g[_-1];D[_-1]=P&-129;let O=se(D),$=w?f:e.ORDER;bt("pointHex.y",O,Nt,$);let z=l(O*O),et=l(z-yt),rt=l(C*z-R),{isValid:ot,value:ft}=h(et,rt);if(!ot)throw new Error("Point.fromHex: invalid y coordinate");let X=(ft&yt)===yt,pt=(P&128)!==0;if(!w&&ft===Nt&&pt)throw new Error("Point.fromHex: x=0 and x_0=1");return pt!==X&&(ft=l(-ft)),p.fromAffine({x:ft,y:O})}static fromPrivateKey(g){return U(g).point}toRawBytes(){let{x:g,y:w}=this.toAffine(),C=be(w,e.BYTES);return C[C.length-1]|=g&yt?128:0,C}toHex(){return Mt(this.toRawBytes())}}p.BASE=new p(t.Gx,t.Gy,yt,l(t.Gx*t.Gy)),p.ZERO=new p(Nt,yt,yt,Nt);let{BASE:S,ZERO:L}=p,T=Rr(p,a*8);function k(m){return q(m,n)}function I(m){return k(se(m))}function U(m){let g=a;m=W("private key",m,g);let w=W("hashed private key",o(m),2*g),C=x(w.slice(0,g)),R=w.slice(g,2*g),_=I(C),D=S.multiply(_),P=D.toRawBytes();return{head:C,prefix:R,scalar:_,point:D,pointBytes:P}}function J(m){return U(m).pointBytes}function F(m=new Uint8Array,...g){let w=Ft(...g);return I(o(v(w,W("context",m),!!s)))}function H(m,g,w={}){m=W("message",m),s&&(m=s(m));let{prefix:C,scalar:R,pointBytes:_}=U(g),D=F(w.context,C,m),P=S.multiply(D).toRawBytes(),O=F(w.context,P,_,m),$=k(D+O*R);bt("signature.s",$,Nt,n);let z=Ft(P,be($,e.BYTES));return W("result",z,a*2)}let Y=Gl;function B(m,g,w,C=Y){let{context:R,zip215:_}=C,D=e.BYTES;m=W("signature",m,2*D),g=W("message",g),_!==void 0&&It("zip215",_),s&&(g=s(g));let P=se(m.slice(D,2*D)),O,$,z;try{O=p.fromHex(w,_),$=p.fromHex(m.slice(0,D),_),z=S.multiplyUnsafe(P)}catch{return!1}if(!_&&O.isSmallOrder())return!1;let et=F(R,$.toRawBytes(),O.toRawBytes(),g);return $.add(O.multiplyUnsafe(et)).subtract(z).clearCofactor().equals(p.ZERO)}return S._setWindowSize(8),{CURVE:t,getPublicKey:J,sign:H,verify:B,ExtendedPoint:p,utils:{getExtendedPublicKey:U,randomPrivateKey:()=>i(e.BYTES),precompute(m=8,g=p.BASE){return g._setWindowSize(m),g.multiply(BigInt(3)),g}}}}var Ss=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),ui=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),Lh=BigInt(0),Zl=BigInt(1),fi=BigInt(2),Rh=BigInt(3),Wl=BigInt(5),Jl=BigInt(8);function Yl(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),s=BigInt(80),o=Ss,a=r*r%o*r%o,c=j(a,fi,o)*a%o,f=j(c,Zl,o)*r%o,l=j(f,Wl,o)*f%o,u=j(l,t,o)*l%o,h=j(u,e,o)*u%o,x=j(h,n,o)*h%o,v=j(x,s,o)*x%o,b=j(v,s,o)*x%o,d=j(b,t,o)*l%o;return{pow_p_5_8:j(d,fi,o)*r%o,b2:a}}function Xl(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function Ql(r,t){let e=Ss,n=q(t*t*t,e),s=q(n*n*t,e),o=Yl(r*s).pow_p_5_8,i=q(r*n*o,e),a=q(t*i*i,e),c=i,f=q(i*ui,e),l=a===r,u=a===q(-r,e),h=a===q(-r*ui,e);return l&&(i=c),(u||h)&&(i=f),oi(i,e)&&(i=q(-i,e)),{isValid:l||u,value:i}}var tu=ie(Ss,void 0,!0),eu={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:tu,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:Jl,Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:ti,randomBytes:Nr,adjustScalarBytes:Xl,uvRatio:Ql},hi=li(eu);var Hr=32;function di(r,t,e){return hi.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}var Dr=class{type="Ed25519";raw;constructor(t){this.raw=ks(t,Hr)}toMultihash(){return te.digest(Or(this))}toCID(){return Bt.createV1(114,this.toMultihash())}toString(){return Q.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:mt(this.raw,t.raw)}verify(t,e){return di(this.raw,e,t)}};function pi(r){return r=ks(r,Hr),new Dr(r)}function ks(r,t){if(r=Uint8Array.from(r??[]),r.length!==t)throw new dt(`Key must be a Uint8Array of length ${t}, got ${r.length}`);return r}function Ct(r=0){return new Uint8Array(r)}function wt(r=0){return new Uint8Array(r)}var nu=Math.pow(2,7),su=Math.pow(2,14),ou=Math.pow(2,21),Is=Math.pow(2,28),Ns=Math.pow(2,35),Cs=Math.pow(2,42),Us=Math.pow(2,49),K=128,ct=127;function Kt(r){if(r<nu)return 1;if(r<su)return 2;if(r<ou)return 3;if(r<Is)return 4;if(r<Ns)return 5;if(r<Cs)return 6;if(r<Us)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function Ts(r,t,e=0){switch(Kt(r)){case 8:t[e++]=r&255|K,r/=128;case 7:t[e++]=r&255|K,r/=128;case 6:t[e++]=r&255|K,r/=128;case 5:t[e++]=r&255|K,r/=128;case 4:t[e++]=r&255|K,r>>>=7;case 3:t[e++]=r&255|K,r>>>=7;case 2:t[e++]=r&255|K,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function iu(r,t,e=0){switch(Kt(r)){case 8:t.set(e++,r&255|K),r/=128;case 7:t.set(e++,r&255|K),r/=128;case 6:t.set(e++,r&255|K),r/=128;case 5:t.set(e++,r&255|K),r/=128;case 4:t.set(e++,r&255|K),r>>>=7;case 3:t.set(e++,r&255|K),r>>>=7;case 2:t.set(e++,r&255|K),r>>>=7;case 1:{t.set(e++,r&255),r>>>=7;break}default:throw new Error("unreachable")}return t}function Ls(r,t){let e=r[t],n=0;if(n+=e&ct,e<K||(e=r[t+1],n+=(e&ct)<<7,e<K)||(e=r[t+2],n+=(e&ct)<<14,e<K)||(e=r[t+3],n+=(e&ct)<<21,e<K)||(e=r[t+4],n+=(e&ct)*Is,e<K)||(e=r[t+5],n+=(e&ct)*Ns,e<K)||(e=r[t+6],n+=(e&ct)*Cs,e<K)||(e=r[t+7],n+=(e&ct)*Us,e<K))return n;throw new RangeError("Could not decode varint")}function au(r,t){let e=r.get(t),n=0;if(n+=e&ct,e<K||(e=r.get(t+1),n+=(e&ct)<<7,e<K)||(e=r.get(t+2),n+=(e&ct)<<14,e<K)||(e=r.get(t+3),n+=(e&ct)<<21,e<K)||(e=r.get(t+4),n+=(e&ct)*Is,e<K)||(e=r.get(t+5),n+=(e&ct)*Ns,e<K)||(e=r.get(t+6),n+=(e&ct)*Cs,e<K)||(e=r.get(t+7),n+=(e&ct)*Us,e<K))return n;throw new RangeError("Could not decode varint")}function mi(r,t,e=0){return t==null&&(t=wt(Kt(r))),t instanceof Uint8Array?Ts(r,t,e):iu(r,t,e)}function bi(r,t=0){return r instanceof Uint8Array?Ls(r,t):au(r,t)}var Rs=new Float32Array([-0]),ae=new Uint8Array(Rs.buffer);function yi(r,t,e){Rs[0]=r,t[e]=ae[0],t[e+1]=ae[1],t[e+2]=ae[2],t[e+3]=ae[3]}function wi(r,t){return ae[0]=r[t],ae[1]=r[t+1],ae[2]=r[t+2],ae[3]=r[t+3],Rs[0]}var _s=new Float64Array([-0]),lt=new Uint8Array(_s.buffer);function xi(r,t,e){_s[0]=r,t[e]=lt[0],t[e+1]=lt[1],t[e+2]=lt[2],t[e+3]=lt[3],t[e+4]=lt[4],t[e+5]=lt[5],t[e+6]=lt[6],t[e+7]=lt[7]}function vi(r,t){return lt[0]=r[t],lt[1]=r[t+1],lt[2]=r[t+2],lt[3]=r[t+3],lt[4]=r[t+4],lt[5]=r[t+5],lt[6]=r[t+6],lt[7]=r[t+7],_s[0]}var lu=BigInt(Number.MAX_SAFE_INTEGER),uu=BigInt(Number.MIN_SAFE_INTEGER),Et=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 xe;if(t<lu&&t>uu)return this.fromNumber(Number(t));let e=t<0n;e&&(t=-t);let n=t>>32n,s=t-(n<<32n);return e&&(n=~n|0n,s=~s|0n,++s>Bi&&(s=0n,++n>Bi&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(t){if(t===0)return xe;let e=t<0;e&&(t=-t);let n=t>>>0,s=(t-n)/4294967296>>>0;return e&&(s=~s>>>0,n=~n>>>0,++n>4294967295&&(n=0,++s>4294967295&&(s=0))),new r(n,s)}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):xe}},xe=new Et(0,0);xe.toBigInt=function(){return 0n};xe.zzEncode=xe.zzDecode=function(){return this};xe.length=function(){return 1};var Bi=4294967296n;function Ei(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 Ai(r,t,e){if(e-t<1)return"";let s,o=[],i=0,a;for(;t<e;)a=r[t++],a<128?o[i++]=a:a>191&&a<224?o[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,o[i++]=55296+(a>>10),o[i++]=56320+(a&1023)):o[i++]=(a&15)<<12|(r[t++]&63)<<6|r[t++]&63,i>8191&&((s??(s=[])).push(String.fromCharCode.apply(String,o)),i=0);return s!=null?(i>0&&s.push(String.fromCharCode.apply(String,o.slice(0,i))),s.join("")):String.fromCharCode.apply(String,o.slice(0,i))}function Vs(r,t,e){let n=e,s,o;for(let i=0;i<r.length;++i)s=r.charCodeAt(i),s<128?t[e++]=s:s<2048?(t[e++]=s>>6|192,t[e++]=s&63|128):(s&64512)===55296&&((o=r.charCodeAt(i+1))&64512)===56320?(s=65536+((s&1023)<<10)+(o&1023),++i,t[e++]=s>>18|240,t[e++]=s>>12&63|128,t[e++]=s>>6&63|128,t[e++]=s&63|128):(t[e++]=s>>12|224,t[e++]=s>>6&63|128,t[e++]=s&63|128);return e-n}function Ut(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function Mr(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,Ut(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 Ut(this,4);return Mr(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Ut(this,4);return Mr(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Ut(this,4);let t=wi(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Ut(this,4);let t=vi(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 Ut(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return Ai(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw Ut(this,t);this.pos+=t}else do if(this.pos>=this.len)throw Ut(this);while(this.buf[this.pos++]&128);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 Et(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 Ut(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 Ut(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 Ut(this,8);let t=Mr(this.buf,this.pos+=4),e=Mr(this.buf,this.pos+=4);return new Et(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=Ls(this.buf,this.pos);return this.pos+=Kt(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 ve(r,t,e){let n=Ds(r);return t.decode(n,void 0,e)}var Os={};ht(Os,{base10:()=>fu});var fu=Qt({prefix:"9",name:"base10",alphabet:"0123456789"});var Ms={};ht(Ms,{base16:()=>hu,base16upper:()=>du});var hu=Z({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),du=Z({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Ps={};ht(Ps,{base2:()=>gu});var gu=Z({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Fs={};ht(Fs,{base256emoji:()=>wu});var ki=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}"),pu=ki.reduce((r,t,e)=>(r[e]=t,r),[]),mu=ki.reduce((r,t,e)=>{let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);return r[n]=e,r},[]);function bu(r){return r.reduce((t,e)=>(t+=pu[e],t),"")}function yu(r){let t=[];for(let e of r){let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);let s=mu[n];if(s==null)throw new Error(`Non-base256emoji character: ${e}`);t.push(s)}return new Uint8Array(t)}var wu=Ce({prefix:"\u{1F680}",name:"base256emoji",encode:bu,decode:yu});var Ks={};ht(Ks,{base64:()=>xu,base64pad:()=>vu,base64url:()=>Bu,base64urlpad:()=>Eu});var xu=Z({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),vu=Z({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Bu=Z({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Eu=Z({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var $s={};ht($s,{base8:()=>Au});var Au=Z({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var qs={};ht(qs,{identity:()=>Su});var Su=Ce({prefix:"\0",name:"identity",encode:r=>_o(r),decode:r=>Ro(r)});var pd=new TextEncoder,md=new TextDecoder;var js={};ht(js,{sha256:()=>Pr,sha512:()=>Nu});function Gs({name:r,code:t,encode:e}){return new zs(r,t,e)}var zs=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?St(this.code,e):e.then(n=>St(this.code,n))}else throw Error("Unknown type, must be binary type")}};function Ni(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var Pr=Gs({name:"sha2-256",code:18,encode:Ni("SHA-256")}),Nu=Gs({name:"sha2-512",code:19,encode:Ni("SHA-512")});var Zs={...qs,...Ps,...$s,...Os,...Ms,...ss,...os,...ns,...Ks,...Fs},Nd={...js,...ls};function Ui(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var Ci=Ui("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),Ws=Ui("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=wt(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),Cu={utf8:Ci,"utf-8":Ci,hex:Zs.base16,latin1:Ws,ascii:Ws,binary:Ws,...Zs},Fr=Cu;function nt(r,t="utf8"){let e=Fr[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function Js(r){let t=r??8192,e=t>>>1,n,s=t;return function(i){if(i<1||i>e)return wt(i);s+i>t&&(n=wt(t),s=0);let a=n.subarray(s,s+=i);return s&7&&(s=(s|7)+1),a}}var Be=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function Ys(){}var Qs=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},Uu=Js();function Tu(r){return globalThis.Buffer!=null?wt(r):Uu(r)}var ar=class{len;head;tail;states;constructor(){this.len=0,this.head=new Be(Ys,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new Be(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new to((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(Kr,10,Et.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=Et.fromBigInt(t);return this._push(Kr,e.length(),e)}uint64Number(t){return this._push(Ts,Kt(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=Et.fromBigInt(t).zzEncode();return this._push(Kr,e.length(),e)}sint64Number(t){let e=Et.fromNumber(t).zzEncode();return this._push(Kr,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(Xs,1,t?1:0)}fixed32(t){return this._push(ir,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=Et.fromBigInt(t);return this._push(ir,4,e.lo)._push(ir,4,e.hi)}fixed64Number(t){let e=Et.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(yi,4,t)}double(t){return this._push(xi,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(Xs,1,0):this.uint32(e)._push(Ru,e,t)}string(t){let e=Ei(t);return e!==0?this.uint32(e)._push(Vs,e,t):this._push(Xs,1,0)}fork(){return this.states=new Qs(this),this.head=this.tail=new Be(Ys,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 Be(Ys,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=Tu(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function Xs(r,t,e){t[e]=r&255}function Lu(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var to=class extends Be{next;constructor(t,e){super(Lu,t,e),this.next=void 0}};function Kr(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 Ru(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(ar.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(_u,t,r),this},ar.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(Vu,t,r),this});function _u(r,t,e){t.set(r,e)}function Vu(r,t,e){r.length<40?Vs(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(nt(r),e)}function eo(){return new ar}function Ee(r,t){let e=eo();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var Pe;(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"})(Pe||(Pe={}));function $r(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function cr(r){function t(s){if(r[s.toString()]==null)throw new Error("Invalid enum value");return r[s]}let e=function(o,i){let a=t(o);i.int32(a)},n=function(o){let i=o.int32();return t(i)};return $r("enum",Pe.VARINT,e,n)}function Ae(r,t){return $r("message",Pe.LENGTH_DELIMITED,r,t)}var xt;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.secp256k1="secp256k1"})(xt||(xt={}));var ro;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1"})(ro||(ro={}));(function(r){r.codec=()=>cr(ro)})(xt||(xt={}));var ce;(function(r){let t;r.codec=()=>(t==null&&(t=Ae((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),xt.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let o={},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let a=e.uint32();switch(a>>>3){case 1:{o.Type=xt.codec().decode(e);break}case 2:{o.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return o})),t),r.encode=e=>Ee(e,r.codec()),r.decode=(e,n)=>ve(e,r.codec(),n)})(ce||(ce={}));var no;(function(r){let t;r.codec=()=>(t==null&&(t=Ae((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),xt.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let o={},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let a=e.uint32();switch(a>>>3){case 1:{o.Type=xt.codec().decode(e);break}case 2:{o.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return o})),t),r.encode=e=>Ee(e,r.codec()),r.decode=(e,n)=>ve(e,r.codec(),n)})(no||(no={}));var wr={};ht(wr,{MAX_RSA_KEY_SIZE:()=>Vn,generateRSAKeyPair:()=>Ia,jwkToJWKKeyPair:()=>Na,jwkToPkcs1:()=>Yu,jwkToPkix:()=>ho,jwkToRSAPrivateKey:()=>ka,pkcs1ToJwk:()=>Ea,pkcs1ToRSAPrivateKey:()=>Sa,pkixToJwk:()=>Aa,pkixToRSAPublicKey:()=>go});var Hu=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]),ue=new Uint32Array(64),so=class extends Oe{constructor(){super(64,32,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:s,E:o,F:i,G:a,H:c}=this;return[t,e,n,s,o,i,a,c]}set(t,e,n,s,o,i,a,c){this.A=t|0,this.B=e|0,this.C=n|0,this.D=s|0,this.E=o|0,this.F=i|0,this.G=a|0,this.H=c|0}process(t,e){for(let u=0;u<16;u++,e+=4)ue[u]=t.getUint32(e,!1);for(let u=16;u<64;u++){let h=ue[u-15],x=ue[u-2],v=kt(h,7)^kt(h,18)^h>>>3,b=kt(x,17)^kt(x,19)^x>>>10;ue[u]=b+ue[u-7]+v+ue[u-16]|0}let{A:n,B:s,C:o,D:i,E:a,F:c,G:f,H:l}=this;for(let u=0;u<64;u++){let h=kt(a,6)^kt(a,11)^kt(a,25),x=l+h+Yo(a,c,f)+Hu[u]+ue[u]|0,b=(kt(n,2)^kt(n,13)^kt(n,22))+Xo(n,s,o)|0;l=f,f=c,c=a,a=i+x|0,i=o,o=s,s=n,n=x+b|0}n=n+this.A|0,s=s+this.B|0,o=o+this.C|0,i=i+this.D|0,a=a+this.E|0,c=c+this.F|0,f=f+this.G|0,l=l+this.H|0,this.set(n,s,o,i,a,c,f,l)}roundClean(){ue.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var Fe=Ir(()=>new so);var M=fc(Li());function Se(r,t){let e=0;if(r.length===1)return r[0];for(let n=r.length-1;n>=0;n--)e+=r[r.length-1-n]*Math.pow(2,t*n);return e}function fe(r,t,e=-1){let n=e,s=r,o=0,i=Math.pow(2,t);for(let a=1;a<8;a++){if(r<i){let c;if(n<0)c=new ArrayBuffer(a),o=a;else{if(n<a)return new ArrayBuffer(0);c=new ArrayBuffer(n),o=n}let f=new Uint8Array(c);for(let l=a-1;l>=0;l--){let u=Math.pow(2,l*t);f[o-l-1]=Math.floor(s/u),s-=f[o-l-1]*u}return c}i*=Math.pow(2,t)}return new ArrayBuffer(0)}function Gr(...r){let t=0,e=0;for(let o of r)t+=o.length;let n=new ArrayBuffer(t),s=new Uint8Array(n);for(let o of r)s.set(o,e),e+=o.length;return s}function io(){let r=new Uint8Array(this.valueHex);if(this.valueHex.byteLength>=2){let a=r[0]===255&&r[1]&128,c=r[0]===0&&(r[1]&128)===0;(a||c)&&this.warnings.push("Needlessly long format")}let t=new ArrayBuffer(this.valueHex.byteLength),e=new Uint8Array(t);for(let a=0;a<this.valueHex.byteLength;a++)e[a]=0;e[0]=r[0]&128;let n=Se(e,8),s=new ArrayBuffer(this.valueHex.byteLength),o=new Uint8Array(s);for(let a=0;a<this.valueHex.byteLength;a++)o[a]=r[a];return o[0]&=127,Se(o,8)-n}function Ri(r){let t=r<0?r*-1:r,e=128;for(let n=1;n<8;n++){if(t<=e){if(r<0){let i=e-t,a=fe(i,8,n),c=new Uint8Array(a);return c[0]|=128,a}let s=fe(t,8,n),o=new Uint8Array(s);if(o[0]&128){let i=s.slice(0),a=new Uint8Array(i);s=new ArrayBuffer(s.byteLength+1),o=new Uint8Array(s);for(let c=0;c<i.byteLength;c++)o[c+1]=a[c];o[0]=0}return s}e*=Math.pow(2,8)}return new ArrayBuffer(0)}function _i(r,t){if(r.byteLength!==t.byteLength)return!1;let e=new Uint8Array(r),n=new Uint8Array(t);for(let s=0;s<e.length;s++)if(e[s]!==n[s])return!1;return!0}function vt(r,t){let e=r.toString(10);if(t<e.length)return"";let n=t-e.length,s=new Array(n);for(let i=0;i<n;i++)s[i]="0";return s.join("").concat(e)}var l0=Math.log(2);function jr(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function ao(r){let t=0,e=0;for(let s=0;s<r.length;s++){let o=r[s];t+=o.byteLength}let n=new Uint8Array(t);for(let s=0;s<r.length;s++){let o=r[s];n.set(new Uint8Array(o),e),e+=o.byteLength}return n.buffer}function jt(r,t,e,n){return t instanceof Uint8Array?t.byteLength?e<0?(r.error="Wrong parameter: inputOffset less than zero",!1):n<0?(r.error="Wrong parameter: inputLength less than zero",!1):t.byteLength-e-n<0?(r.error="End of input reached before message was fully decoded (inconsistent offset and length values)",!1):!0:(r.error="Wrong parameter: inputBuffer has zero length",!1):(r.error="Wrong parameter: inputBuffer must be 'Uint8Array'",!1)}var ur=class{constructor(){this.items=[]}write(t){this.items.push(t)}final(){return ao(this.items)}},lr=[new Uint8Array([1])],Vi="0123456789";var Ge="",Tt=new ArrayBuffer(0),co=new Uint8Array(0),fr="EndOfContent",Di="OCTET STRING",Oi="BIT STRING";function Zt(r){var t;return t=class extends r{constructor(...n){var s;super(...n);let o=n[0]||{};this.isHexOnly=(s=o.isHexOnly)!==null&&s!==void 0?s:!1,this.valueHexView=o.valueHex?M.BufferSourceConverter.toUint8Array(o.valueHex):co}get valueHex(){return this.valueHexView.slice().buffer}set valueHex(n){this.valueHexView=new Uint8Array(n)}fromBER(n,s,o){let i=n instanceof ArrayBuffer?new Uint8Array(n):n;if(!jt(this,i,s,o))return-1;let a=s+o;return this.valueHexView=i.subarray(s,a),this.valueHexView.length?(this.blockLength=o,a):(this.warnings.push("Zero buffer length"),s)}toBER(n=!1){return this.isHexOnly?n?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.byteLength===this.valueHexView.buffer.byteLength?this.valueHexView.buffer:this.valueHexView.slice().buffer:(this.error="Flag 'isHexOnly' is not set, abort",Tt)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:M.Convert.ToHex(this.valueHexView)}}},t.NAME="hexBlock",t}var qt=class{constructor({blockLength:t=0,error:e=Ge,warnings:n=[],valueBeforeDecode:s=co}={}){this.blockLength=t,this.error=e,this.warnings=n,this.valueBeforeDecodeView=M.BufferSourceConverter.toUint8Array(s)}static blockName(){return this.NAME}get valueBeforeDecode(){return this.valueBeforeDecodeView.slice().buffer}set valueBeforeDecode(t){this.valueBeforeDecodeView=new Uint8Array(t)}toJSON(){return{blockName:this.constructor.NAME,blockLength:this.blockLength,error:this.error,warnings:this.warnings,valueBeforeDecode:M.Convert.ToHex(this.valueBeforeDecodeView)}}};qt.NAME="baseBlock";var ut=class extends qt{fromBER(t,e,n){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}toBER(t,e){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}};ut.NAME="valueBlock";var Zr=class extends Zt(qt){constructor({idBlock:t={}}={}){var e,n,s,o;super(),t?(this.isHexOnly=(e=t.isHexOnly)!==null&&e!==void 0?e:!1,this.valueHexView=t.valueHex?M.BufferSourceConverter.toUint8Array(t.valueHex):co,this.tagClass=(n=t.tagClass)!==null&&n!==void 0?n:-1,this.tagNumber=(s=t.tagNumber)!==null&&s!==void 0?s:-1,this.isConstructed=(o=t.isConstructed)!==null&&o!==void 0?o:!1):(this.tagClass=-1,this.tagNumber=-1,this.isConstructed=!1)}toBER(t=!1){let e=0;switch(this.tagClass){case 1:e|=0;break;case 2:e|=64;break;case 3:e|=128;break;case 4:e|=192;break;default:return this.error="Unknown tag class",Tt}if(this.isConstructed&&(e|=32),this.tagNumber<31&&!this.isHexOnly){let s=new Uint8Array(1);if(!t){let o=this.tagNumber;o&=31,e|=o,s[0]=e}return s.buffer}if(!this.isHexOnly){let s=fe(this.tagNumber,7),o=new Uint8Array(s),i=s.byteLength,a=new Uint8Array(i+1);if(a[0]=e|31,!t){for(let c=0;c<i-1;c++)a[c+1]=o[c]|128;a[i]=o[i-1]}return a.buffer}let n=new Uint8Array(this.valueHexView.byteLength+1);if(n[0]=e|31,!t){let s=this.valueHexView;for(let o=0;o<s.length-1;o++)n[o+1]=s[o]|128;n[this.valueHexView.byteLength]=s[s.length-1]}return n.buffer}fromBER(t,e,n){let s=M.BufferSourceConverter.toUint8Array(t);if(!jt(this,s,e,n))return-1;let o=s.subarray(e,e+n);if(o.length===0)return this.error="Zero buffer length",-1;switch(o[0]&192){case 0:this.tagClass=1;break;case 64:this.tagClass=2;break;case 128:this.tagClass=3;break;case 192:this.tagClass=4;break;default:return this.error="Unknown tag class",-1}this.isConstructed=(o[0]&32)===32,this.isHexOnly=!1;let a=o[0]&31;if(a!==31)this.tagNumber=a,this.blockLength=1;else{let c=1,f=this.valueHexView=new Uint8Array(255),l=255;for(;o[c]&128;){if(f[c-1]=o[c]&127,c++,c>=o.length)return this.error="End of input reached before message was fully decoded",-1;if(c===l){l+=255;let h=new Uint8Array(l);for(let x=0;x<f.length;x++)h[x]=f[x];f=this.valueHexView=new Uint8Array(l)}}this.blockLength=c+1,f[c-1]=o[c]&127;let u=new Uint8Array(c);for(let h=0;h<c;h++)u[h]=f[h];f=this.valueHexView=new Uint8Array(c),f.set(u),this.blockLength<=9?this.tagNumber=Se(f,7):(this.isHexOnly=!0,this.warnings.push("Tag too long, represented as hex-coded"))}if(this.tagClass===1&&this.isConstructed)switch(this.tagNumber){case 1:case 2:case 5:case 6:case 9:case 13:case 14:case 23:case 24:case 31:case 32:case 33:case 34:return this.error="Constructed encoding used for primitive type",-1}return e+this.blockLength}toJSON(){return{...super.toJSON(),tagClass:this.tagClass,tagNumber:this.tagNumber,isConstructed:this.isConstructed}}};Zr.NAME="identificationBlock";var Wr=class extends qt{constructor({lenBlock:t={}}={}){var e,n,s;super(),this.isIndefiniteForm=(e=t.isIndefiniteForm)!==null&&e!==void 0?e:!1,this.longFormUsed=(n=t.longFormUsed)!==null&&n!==void 0?n:!1,this.length=(s=t.length)!==null&&s!==void 0?s:0}fromBER(t,e,n){let s=M.BufferSourceConverter.toUint8Array(t);if(!jt(this,s,e,n))return-1;let o=s.subarray(e,e+n);if(o.length===0)return this.error="Zero buffer length",-1;if(o[0]===255)return this.error="Length block 0xFF is reserved by standard",-1;if(this.isIndefiniteForm=o[0]===128,this.isIndefiniteForm)return this.blockLength=1,e+this.blockLength;if(this.longFormUsed=!!(o[0]&128),this.longFormUsed===!1)return this.length=o[0],this.blockLength=1,e+this.blockLength;let i=o[0]&127;if(i>8)return this.error="Too big integer",-1;if(i+1>o.length)return this.error="End of input reached before message was fully decoded",-1;let a=e+1,c=s.subarray(a,a+i);return c[i-1]===0&&this.warnings.push("Needlessly long encoded length"),this.length=Se(c,8),this.longFormUsed&&this.length<=127&&this.warnings.push("Unnecessary usage of long length form"),this.blockLength=i+1,e+this.blockLength}toBER(t=!1){let e,n;if(this.length>127&&(this.longFormUsed=!0),this.isIndefiniteForm)return e=new ArrayBuffer(1),t===!1&&(n=new Uint8Array(e),n[0]=128),e;if(this.longFormUsed){let s=fe(this.length,8);if(s.byteLength>127)return this.error="Too big length",Tt;if(e=new ArrayBuffer(s.byteLength+1),t)return e;let o=new Uint8Array(s);n=new Uint8Array(e),n[0]=s.byteLength|128;for(let i=0;i<s.byteLength;i++)n[i+1]=o[i];return e}return e=new ArrayBuffer(1),t===!1&&(n=new Uint8Array(e),n[0]=this.length),e}toJSON(){return{...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,longFormUsed:this.longFormUsed,length:this.length}}};Wr.NAME="lengthBlock";var A={},it=class extends qt{constructor({name:t=Ge,optional:e=!1,primitiveSchema:n,...s}={},o){super(s),this.name=t,this.optional=e,n&&(this.primitiveSchema=n),this.idBlock=new Zr(s),this.lenBlock=new Wr(s),this.valueBlock=o?new o(s):new ut(s)}fromBER(t,e,n){let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}toBER(t,e){let n=e||new ur;e||Mi(this);let s=this.idBlock.toBER(t);if(n.write(s),this.lenBlock.isIndefiniteForm)n.write(new Uint8Array([128]).buffer),this.valueBlock.toBER(t,n),n.write(new ArrayBuffer(2));else{let o=this.valueBlock.toBER(t);this.lenBlock.length=o.byteLength;let i=this.lenBlock.toBER(t);n.write(i),n.write(o)}return e?Tt:n.final()}toJSON(){let t={...super.toJSON(),idBlock:this.idBlock.toJSON(),lenBlock:this.lenBlock.toJSON(),valueBlock:this.valueBlock.toJSON(),name:this.name,optional:this.optional};return this.primitiveSchema&&(t.primitiveSchema=this.primitiveSchema.toJSON()),t}toString(t="ascii"){return t==="ascii"?this.onAsciiEncoding():M.Convert.ToHex(this.toBER())}onAsciiEncoding(){return`${this.constructor.NAME} : ${M.Convert.ToHex(this.valueBlock.valueBeforeDecodeView)}`}isEqual(t){if(this===t)return!0;if(!(t instanceof this.constructor))return!1;let e=this.toBER(),n=t.toBER();return _i(e,n)}};it.NAME="BaseBlock";function Mi(r){if(r instanceof A.Constructed)for(let t of r.valueBlock.value)Mi(t)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var Jr=class extends it{constructor({value:t=Ge,...e}={},n){super(e,n),t&&this.fromString(t)}getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}fromBER(t,e,n){let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.fromBuffer(this.valueBlock.valueHexView),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}onAsciiEncoding(){return`${this.constructor.NAME} : '${this.valueBlock.value}'`}};Jr.NAME="BaseStringBlock";var Yr=class extends Zt(ut){constructor({isHexOnly:t=!0,...e}={}){super(e),this.isHexOnly=t}};Yr.NAME="PrimitiveValueBlock";var Pi,Xr=class extends it{constructor(t={}){super(t,Yr),this.idBlock.isConstructed=!1}};Pi=Xr;A.Primitive=Pi;Xr.NAME="PRIMITIVE";function zu(r,t){if(r instanceof t)return r;let e=new t;return e.idBlock=r.idBlock,e.lenBlock=r.lenBlock,e.warnings=r.warnings,e.valueBeforeDecodeView=r.valueBeforeDecodeView,e}function Rn(r,t=0,e=r.length){let n=t,s=new it({},ut),o=new qt;if(!jt(o,r,t,e))return s.error=o.error,{offset:-1,result:s};if(!r.subarray(t,t+e).length)return s.error="Zero buffer length",{offset:-1,result:s};let a=s.idBlock.fromBER(r,t,e);if(s.idBlock.warnings.length&&s.warnings.concat(s.idBlock.warnings),a===-1)return s.error=s.idBlock.error,{offset:-1,result:s};if(t=a,e-=s.idBlock.blockLength,a=s.lenBlock.fromBER(r,t,e),s.lenBlock.warnings.length&&s.warnings.concat(s.lenBlock.warnings),a===-1)return s.error=s.lenBlock.error,{offset:-1,result:s};if(t=a,e-=s.lenBlock.blockLength,!s.idBlock.isConstructed&&s.lenBlock.isIndefiniteForm)return s.error="Indefinite length form used for primitive encoding form",{offset:-1,result:s};let c=it;switch(s.idBlock.tagClass){case 1:if(s.idBlock.tagNumber>=37&&s.idBlock.isHexOnly===!1)return s.error="UNIVERSAL 37 and upper tags are reserved by ASN.1 standard",{offset:-1,result:s};switch(s.idBlock.tagNumber){case 0:if(s.idBlock.isConstructed&&s.lenBlock.length>0)return s.error="Type [UNIVERSAL 0] is reserved",{offset:-1,result:s};c=A.EndOfContent;break;case 1:c=A.Boolean;break;case 2:c=A.Integer;break;case 3:c=A.BitString;break;case 4:c=A.OctetString;break;case 5:c=A.Null;break;case 6:c=A.ObjectIdentifier;break;case 10:c=A.Enumerated;break;case 12:c=A.Utf8String;break;case 13:c=A.RelativeObjectIdentifier;break;case 14:c=A.TIME;break;case 15:return s.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:s};case 16:c=A.Sequence;break;case 17:c=A.Set;break;case 18:c=A.NumericString;break;case 19:c=A.PrintableString;break;case 20:c=A.TeletexString;break;case 21:c=A.VideotexString;break;case 22:c=A.IA5String;break;case 23:c=A.UTCTime;break;case 24:c=A.GeneralizedTime;break;case 25:c=A.GraphicString;break;case 26:c=A.VisibleString;break;case 27:c=A.GeneralString;break;case 28:c=A.UniversalString;break;case 29:c=A.CharacterString;break;case 30:c=A.BmpString;break;case 31:c=A.DATE;break;case 32:c=A.TimeOfDay;break;case 33:c=A.DateTime;break;case 34:c=A.Duration;break;default:{let f=s.idBlock.isConstructed?new A.Constructed:new A.Primitive;f.idBlock=s.idBlock,f.lenBlock=s.lenBlock,f.warnings=s.warnings,s=f}}break;case 2:case 3:case 4:default:c=s.idBlock.isConstructed?A.Constructed:A.Primitive}return s=zu(s,c),a=s.fromBER(r,t,s.lenBlock.isIndefiniteForm?e:s.lenBlock.length),s.valueBeforeDecodeView=r.subarray(n,n+s.blockLength),{offset:a,result:s}}function lo(r){if(!r.byteLength){let t=new it({},ut);return t.error="Input buffer has zero length",{offset:-1,result:t}}return Rn(M.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function Gu(r,t){return r?1:t}var Rt=class extends ut{constructor({value:t=[],isIndefiniteForm:e=!1,...n}={}){super(n),this.value=t,this.isIndefiniteForm=e}fromBER(t,e,n){let s=M.BufferSourceConverter.toUint8Array(t);if(!jt(this,s,e,n))return-1;if(this.valueBeforeDecodeView=s.subarray(e,e+n),this.valueBeforeDecodeView.length===0)return this.warnings.push("Zero buffer length"),e;let o=e;for(;Gu(this.isIndefiniteForm,n)>0;){let i=Rn(s,o,n);if(i.offset===-1)return this.error=i.result.error,this.warnings.concat(i.result.warnings),-1;if(o=i.offset,this.blockLength+=i.result.blockLength,n-=i.result.blockLength,this.value.push(i.result),this.isIndefiniteForm&&i.result.constructor.NAME===fr)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===fr?this.value.pop():this.warnings.push("No EndOfContent block encoded")),o}toBER(t,e){let n=e||new ur;for(let s=0;s<this.value.length;s++)this.value[s].toBER(t,n);return e?Tt:n.final()}toJSON(){let t={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let e of this.value)t.value.push(e.toJSON());return t}};Rt.NAME="ConstructedValueBlock";var Fi,he=class extends it{constructor(t={}){super(t,Rt),this.idBlock.isConstructed=!0}fromBER(t,e,n){this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm;let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}onAsciiEncoding(){let t=[];for(let n of this.valueBlock.value)t.push(n.toString("ascii").split(`
3
3
  `).map(s=>` ${s}`).join(`
4
4
  `));let e=this.idBlock.tagClass===3?`[${this.idBlock.tagNumber}]`:this.constructor.NAME;return t.length?`${e} :
5
5
  ${t.join(`
6
- `)}`:`${e} :`}};Fi=de;A.Constructed=Fi;de.NAME="CONSTRUCTED";var Qr=class extends ut{fromBER(t,e,n){return e}toBER(t){return Lt}};Qr.override="EndOfContentValueBlock";var Ki,tn=class extends it{constructor(t={}){super(t,Qr),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};Ki=tn;A.EndOfContent=Ki;tn.NAME=hr;var $i,qe=class extends it{constructor(t={}){super(t,ut),this.idBlock.tagClass=1,this.idBlock.tagNumber=5}fromBER(t,e,n){return this.lenBlock.length>0&&this.warnings.push("Non-zero length of value block for Null type"),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.blockLength+=n,e+n>t.byteLength?(this.error="End of input reached before message was fully decoded (inconsistent offset and length values)",-1):e+n}toBER(t,e){let n=new ArrayBuffer(2);if(!t){let s=new Uint8Array(n);s[0]=5,s[1]=0}return e&&e.write(n),n}onAsciiEncoding(){return`${this.constructor.NAME}`}};$i=qe;A.Null=$i;qe.NAME="NULL";var en=class extends Wt(ut){constructor({value:t,...e}={}){super(e),e.valueHex?this.valueHexView=M.BufferSourceConverter.toUint8Array(e.valueHex):this.valueHexView=new Uint8Array(1),t&&(this.value=t)}get value(){for(let t of this.valueHexView)if(t>0)return!0;return!1}set value(t){this.valueHexView[0]=t?255:0}fromBER(t,e,n){let s=M.BufferSourceConverter.toUint8Array(t);return Zt(this,s,e,n)?(this.valueHexView=s.subarray(e,e+n),n>1&&this.warnings.push("Boolean value encoded in more then 1 octet"),this.isHexOnly=!0,io.call(this),this.blockLength=n,e+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};en.NAME="BooleanValueBlock";var qi,rn=class extends it{constructor(t={}){super(t,en),this.idBlock.tagClass=1,this.idBlock.tagNumber=1}getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.getValue}`}};qi=rn;A.Boolean=qi;rn.NAME="BOOLEAN";var nn=class extends Wt(_t){constructor({isConstructed:t=!1,...e}={}){super(e),this.isConstructed=t}fromBER(t,e,n){let s=0;if(this.isConstructed){if(this.isHexOnly=!1,s=_t.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let o=0;o<this.value.length;o++){let i=this.value[o].constructor.NAME;if(i===hr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(i!==Di)return this.error="OCTET STRING may consists of OCTET STRINGs only",-1}}else this.isHexOnly=!0,s=super.fromBER(t,e,n),this.blockLength=n;return s}toBER(t,e){return this.isConstructed?_t.prototype.toBER.call(this,t,e):t?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};nn.NAME="OctetStringValueBlock";var zi,sn=class r extends it{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,o;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((o=n.value)===null||o===void 0)&&o.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},nn),this.idBlock.tagClass=1,this.idBlock.tagNumber=4}fromBER(t,e,n){if(this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,n===0)return this.idBlock.error.length===0&&(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length===0&&(this.blockLength+=this.lenBlock.blockLength),e;if(!this.valueBlock.isConstructed){let o=(t instanceof ArrayBuffer?new Uint8Array(t):t).subarray(e,e+n);try{if(o.byteLength){let i=Rn(o,0,o.byteLength);i.offset!==-1&&i.offset===n&&(this.valueBlock.value=[i.result])}}catch{}}return super.fromBER(t,e,n)}onAsciiEncoding(){return this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length?de.prototype.onAsciiEncoding.call(this):`${this.constructor.NAME} : ${M.Convert.ToHex(this.valueBlock.valueHexView)}`}getValue(){if(!this.idBlock.isConstructed)return this.valueBlock.valueHexView.slice().buffer;let t=[];for(let e of this.valueBlock.value)e instanceof r&&t.push(e.valueBlock.valueHexView);return M.BufferSourceConverter.concat(t)}};zi=sn;A.OctetString=zi;sn.NAME=Di;var on=class extends Wt(_t){constructor({unusedBits:t=0,isConstructed:e=!1,...n}={}){super(n),this.unusedBits=t,this.isConstructed=e,this.blockLength=this.valueHexView.byteLength}fromBER(t,e,n){if(!n)return e;let s=-1;if(this.isConstructed){if(s=_t.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let a of this.value){let c=a.constructor.NAME;if(c===hr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==Oi)return this.error="BIT STRING may consists of BIT STRINGs only",-1;let f=a.valueBlock;if(this.unusedBits>0&&f.unusedBits>0)return this.error='Using of "unused bits" inside constructive BIT STRING allowed for least one only',-1;this.unusedBits=f.unusedBits}return s}let o=M.BufferSourceConverter.toUint8Array(t);if(!Zt(this,o,e,n))return-1;let i=o.subarray(e,e+n);if(this.unusedBits=i[0],this.unusedBits>7)return this.error="Unused bits for BitString must be in range 0-7",-1;if(!this.unusedBits){let a=i.subarray(1);try{if(a.byteLength){let c=Rn(a,0,a.byteLength);c.offset!==-1&&c.offset===n-1&&(this.value=[c.result])}}catch{}}return this.valueHexView=i.subarray(1),this.blockLength=i.length,e+n}toBER(t,e){if(this.isConstructed)return _t.prototype.toBER.call(this,t,e);if(t)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return Lt;let n=new Uint8Array(this.valueHexView.length+1);return n[0]=this.unusedBits,n.set(this.valueHexView,1),n.buffer}toJSON(){return{...super.toJSON(),unusedBits:this.unusedBits,isConstructed:this.isConstructed}}};on.NAME="BitStringValueBlock";var Gi,ze=class extends it{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,o;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((o=n.value)===null||o===void 0)&&o.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},on),this.idBlock.tagClass=1,this.idBlock.tagNumber=3}fromBER(t,e,n){return this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,super.fromBER(t,e,n)}onAsciiEncoding(){if(this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length)return de.prototype.onAsciiEncoding.call(this);{let t=[],e=this.valueBlock.valueHexView;for(let s of e)t.push(s.toString(2).padStart(8,"0"));let n=t.join("");return`${this.constructor.NAME} : ${n.substring(0,n.length-this.valueBlock.unusedBits)}`}}};Gi=ze;A.BitString=Gi;ze.NAME=Oi;var ji;function ju(r,t){let e=new Uint8Array([0]),n=new Uint8Array(r),s=new Uint8Array(t),o=n.slice(0),i=o.length-1,a=s.slice(0),c=a.length-1,f=0,l=c<i?i:c,u=0;for(let h=l;h>=0;h--,u++){switch(!0){case u<a.length:f=o[i-u]+a[c-u]+e[0];break;default:f=o[i-u]+e[0]}switch(e[0]=f/10,!0){case u>=o.length:o=Gr(new Uint8Array([f%10]),o);break;default:o[i-u]=f%10}}return e[0]>0&&(o=Gr(e,o)),o}function Hi(r){if(r>=ur.length)for(let t=ur.length;t<=r;t++){let e=new Uint8Array([0]),n=ur[t-1].slice(0);for(let s=n.length-1;s>=0;s--){let o=new Uint8Array([(n[s]<<1)+e[0]]);e[0]=o[0]/10,n[s]=o[0]%10}e[0]>0&&(n=Gr(e,n)),ur.push(n)}return ur[r]}function Zu(r,t){let e=0,n=new Uint8Array(r),s=new Uint8Array(t),o=n.slice(0),i=o.length-1,a=s.slice(0),c=a.length-1,f,l=0;for(let u=c;u>=0;u--,l++)switch(f=o[i-l]-a[c-l]-e,!0){case f<0:e=1,o[i-l]=f+10;break;default:e=0,o[i-l]=f}if(e>0)for(let u=i-c+1;u>=0;u--,l++)if(f=o[i-l]-e,f<0)e=1,o[i-l]=f+10;else{e=0,o[i-l]=f;break}return o.slice()}var dr=class extends Wt(ut){constructor({value:t,...e}={}){super(e),this._valueDec=0,e.valueHex&&this.setValueHex(),t!==void 0&&(this.valueDec=t)}setValueHex(){this.valueHexView.length>=4?(this.warnings.push("Too big Integer for decoding, hex only"),this.isHexOnly=!0,this._valueDec=0):(this.isHexOnly=!1,this.valueHexView.length>0&&(this._valueDec=io.call(this)))}set valueDec(t){this._valueDec=t,this.isHexOnly=!1,this.valueHexView=new Uint8Array(Ri(t))}get valueDec(){return this._valueDec}fromDER(t,e,n,s=0){let o=this.fromBER(t,e,n);if(o===-1)return o;let i=this.valueHexView;return i[0]===0&&i[1]&128?this.valueHexView=i.subarray(1):s!==0&&i.length<s&&(s-i.length>1&&(s=i.length+1),this.valueHexView=i.subarray(s-i.length)),o}toDER(t=!1){let e=this.valueHexView;switch(!0){case(e[0]&128)!==0:{let n=new Uint8Array(this.valueHexView.length+1);n[0]=0,n.set(e,1),this.valueHexView=n}break;case(e[0]===0&&(e[1]&128)===0):this.valueHexView=this.valueHexView.subarray(1);break}return this.toBER(t)}fromBER(t,e,n){let s=super.fromBER(t,e,n);return s===-1||this.setValueHex(),s}toBER(t){return t?new ArrayBuffer(this.valueHexView.length):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}toString(){let t=this.valueHexView.length*8-1,e=new Uint8Array(this.valueHexView.length*8/3),n=0,s,o=this.valueHexView,i="",a=!1;for(let c=o.byteLength-1;c>=0;c--){s=o[c];for(let f=0;f<8;f++){if((s&1)===1)switch(n){case t:e=Zu(Hi(n),e),i="-";break;default:e=ju(e,Hi(n))}n++,s>>=1}}for(let c=0;c<e.length;c++)e[c]&&(a=!0),a&&(i+=Vi.charAt(e[c]));return a===!1&&(i+=Vi.charAt(0)),i}};ji=dr;dr.NAME="IntegerValueBlock";Object.defineProperty(ji.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var Zi,at=class r extends it{constructor(t={}){super(t,dr),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return jr(),BigInt(this.valueBlock.toString())}static fromBigInt(t){jr();let e=BigInt(t),n=new fr,s=e.toString(16).replace(/^-/,""),o=new Uint8Array(M.Convert.FromHex(s));if(e<0){let a=new Uint8Array(o.length+(o[0]&128?1:0));a[0]|=128;let f=BigInt(`0x${M.Convert.ToHex(a)}`)+e,l=M.BufferSourceConverter.toUint8Array(M.Convert.FromHex(f.toString(16)));l[0]|=128,n.write(l)}else o[0]&128&&n.write(new Uint8Array([0])),n.write(o);return new r({valueHex:n.final()})}convertToDER(){let t=new r({valueHex:this.valueBlock.valueHexView});return t.valueBlock.toDER(),t}convertFromDER(){return new r({valueHex:this.valueBlock.valueHexView[0]===0?this.valueBlock.valueHexView.subarray(1):this.valueBlock.valueHexView})}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()}`}};Zi=at;A.Integer=Zi;at.NAME="INTEGER";var Wi,an=class extends at{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};Wi=an;A.Enumerated=Wi;an.NAME="ENUMERATED";var gr=class extends Wt(ut){constructor({valueDec:t=-1,isFirstSid:e=!1,...n}={}){super(n),this.valueDec=t,this.isFirstSid=e}fromBER(t,e,n){if(!n)return e;let s=M.BufferSourceConverter.toUint8Array(t);if(!Zt(this,s,e,n))return-1;let o=s.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=o[a]&127,this.blockLength++,!!(o[a]&128));a++);let i=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)i[a]=this.valueHexView[a];return this.valueHexView=i,o[this.blockLength-1]&128?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=ke(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}set valueBigInt(t){jr();let e=BigInt(t).toString(2);for(;e.length%7;)e="0"+e;let n=new Uint8Array(e.length/7);for(let s=0;s<n.length;s++)n[s]=parseInt(e.slice(s*7,s*7+7),2)+(s+1<n.length?128:0);this.fromBER(n.buffer,0,n.length)}toBER(t){if(this.isHexOnly){if(t)return new ArrayBuffer(this.valueHexView.byteLength);let s=this.valueHexView,o=new Uint8Array(this.blockLength);for(let i=0;i<this.blockLength-1;i++)o[i]=s[i]|128;return o[this.blockLength-1]=s[this.blockLength-1],o.buffer}let e=he(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Lt;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),o=e.byteLength-1;for(let i=0;i<o;i++)n[i]=s[i]|128;n[o]=s[o]}return n}toString(){let t="";if(this.isHexOnly)t=M.Convert.ToHex(this.valueHexView);else if(this.isFirstSid){let e=this.valueDec;this.valueDec<=39?t="0.":this.valueDec<=79?(t="1.",e-=40):(t="2.",e-=80),t+=e.toString()}else t=this.valueDec.toString();return t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec,isFirstSid:this.isFirstSid}}};gr.NAME="sidBlock";var cn=class extends ut{constructor({value:t=je,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new gr;if(s=o.fromBER(t,s,n),s===-1)return this.blockLength=0,this.error=o.error,s;this.value.length===0&&(o.isFirstSid=!0),this.blockLength+=o.blockLength,n-=o.blockLength,this.value.push(o)}return s}toBER(t){let e=[];for(let n=0;n<this.value.length;n++){let s=this.value[n].toBER(t);if(s.byteLength===0)return this.error=this.value[n].error,Lt;e.push(s)}return ao(e)}fromString(t){this.value=[];let e=0,n=0,s="",o=!1;do if(n=t.indexOf(".",e),n===-1?s=t.substring(e):s=t.substring(e,n),e=n+1,o){let i=this.value[0],a=0;switch(i.valueDec){case 0:break;case 1:a=40;break;case 2:a=80;break;default:this.value=[];return}let c=parseInt(s,10);if(isNaN(c))return;i.valueDec=c+a,o=!1}else{let i=new gr;if(s>Number.MAX_SAFE_INTEGER){jr();let a=BigInt(s);i.valueBigInt=a}else if(i.valueDec=parseInt(s,10),isNaN(i.valueDec))return;this.value.length||(i.isFirstSid=!0,o=!0),this.value.push(i)}while(n!==-1)}toString(){let t="",e=!1;for(let n=0;n<this.value.length;n++){e=this.value[n].isHexOnly;let s=this.value[n].toString();n!==0&&(t=`${t}.`),e?(s=`{${s}}`,this.value[n].isFirstSid?t=`2.{${s} - 80}`:t+=s):t+=s}return t}toJSON(){let t={...super.toJSON(),value:this.toString(),sidArray:[]};for(let e=0;e<this.value.length;e++)t.sidArray.push(this.value[e].toJSON());return t}};cn.NAME="ObjectIdentifierValueBlock";var Ji,Ge=class extends it{constructor(t={}){super(t,cn),this.idBlock.tagClass=1,this.idBlock.tagNumber=6}getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};Ji=Ge;A.ObjectIdentifier=Ji;Ge.NAME="OBJECT IDENTIFIER";var pr=class extends Wt(zt){constructor({valueDec:t=0,...e}={}){super(e),this.valueDec=t}fromBER(t,e,n){if(n===0)return e;let s=M.BufferSourceConverter.toUint8Array(t);if(!Zt(this,s,e,n))return-1;let o=s.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=o[a]&127,this.blockLength++,!!(o[a]&128));a++);let i=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)i[a]=this.valueHexView[a];return this.valueHexView=i,o[this.blockLength-1]&128?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=ke(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}toBER(t){if(this.isHexOnly){if(t)return new ArrayBuffer(this.valueHexView.byteLength);let s=this.valueHexView,o=new Uint8Array(this.blockLength);for(let i=0;i<this.blockLength-1;i++)o[i]=s[i]|128;return o[this.blockLength-1]=s[this.blockLength-1],o.buffer}let e=he(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Lt;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),o=e.byteLength-1;for(let i=0;i<o;i++)n[i]=s[i]|128;n[o]=s[o]}return n.buffer}toString(){let t="";return this.isHexOnly?t=M.Convert.ToHex(this.valueHexView):t=this.valueDec.toString(),t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};pr.NAME="relativeSidBlock";var ln=class extends ut{constructor({value:t=je,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new pr;if(s=o.fromBER(t,s,n),s===-1)return this.blockLength=0,this.error=o.error,s;this.blockLength+=o.blockLength,n-=o.blockLength,this.value.push(o)}return s}toBER(t,e){let n=[];for(let s=0;s<this.value.length;s++){let o=this.value[s].toBER(t);if(o.byteLength===0)return this.error=this.value[s].error,Lt;n.push(o)}return ao(n)}fromString(t){this.value=[];let e=0,n=0,s="";do{n=t.indexOf(".",e),n===-1?s=t.substring(e):s=t.substring(e,n),e=n+1;let o=new pr;if(o.valueDec=parseInt(s,10),isNaN(o.valueDec))return!0;this.value.push(o)}while(n!==-1);return!0}toString(){let t="",e=!1;for(let n=0;n<this.value.length;n++){e=this.value[n].isHexOnly;let s=this.value[n].toString();n!==0&&(t=`${t}.`),e&&(s=`{${s}}`),t+=s}return t}toJSON(){let t={...super.toJSON(),value:this.toString(),sidArray:[]};for(let e=0;e<this.value.length;e++)t.sidArray.push(this.value[e].toJSON());return t}};ln.NAME="RelativeObjectIdentifierValueBlock";var Yi,un=class extends it{constructor(t={}){super(t,ln),this.idBlock.tagClass=1,this.idBlock.tagNumber=13}getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};Yi=un;A.RelativeObjectIdentifier=Yi;un.NAME="RelativeObjectIdentifier";var Xi,Gt=class extends de{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};Xi=Gt;A.Sequence=Xi;Gt.NAME="SEQUENCE";var Qi,fn=class extends de{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};Qi=fn;A.Set=Qi;fn.NAME="SET";var hn=class extends Wt(ut){constructor({...t}={}){super(t),this.isHexOnly=!0,this.value=je}toJSON(){return{...super.toJSON(),value:this.value}}};hn.NAME="StringValueBlock";var dn=class extends hn{};dn.NAME="SimpleStringValueBlock";var gt=class extends Jr{constructor({...t}={}){super(t,dn)}fromBuffer(t){this.valueBlock.value=String.fromCharCode.apply(null,M.BufferSourceConverter.toUint8Array(t))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e);for(let s=0;s<e;s++)n[s]=t.charCodeAt(s);this.valueBlock.value=t}};gt.NAME="SIMPLE STRING";var gn=class extends gt{fromBuffer(t){this.valueBlock.valueHexView=M.BufferSourceConverter.toUint8Array(t);try{this.valueBlock.value=M.Convert.ToUtf8String(t)}catch(e){this.warnings.push(`Error during "decodeURIComponent": ${e}, using raw string`),this.valueBlock.value=M.Convert.ToBinary(t)}}fromString(t){this.valueBlock.valueHexView=new Uint8Array(M.Convert.FromUtf8String(t)),this.valueBlock.value=t}};gn.NAME="Utf8StringValueBlock";var ta,jt=class extends gn{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};ta=jt;A.Utf8String=ta;jt.NAME="UTF8String";var pn=class extends gt{fromBuffer(t){this.valueBlock.value=M.Convert.ToUtf16String(t),this.valueBlock.valueHexView=M.BufferSourceConverter.toUint8Array(t)}fromString(t){this.valueBlock.value=t,this.valueBlock.valueHexView=new Uint8Array(M.Convert.FromUtf16String(t))}};pn.NAME="BmpStringValueBlock";var ea,mn=class extends pn{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};ea=mn;A.BmpString=ea;mn.NAME="BMPString";var bn=class extends gt{fromBuffer(t){let e=ArrayBuffer.isView(t)?t.slice().buffer:t.slice(0),n=new Uint8Array(e);for(let s=0;s<n.length;s+=4)n[s]=n[s+3],n[s+1]=n[s+2],n[s+2]=0,n[s+3]=0;this.valueBlock.value=String.fromCharCode.apply(null,new Uint32Array(e))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e*4);for(let s=0;s<e;s++){let o=he(t.charCodeAt(s),8),i=new Uint8Array(o);if(i.length>4)continue;let a=4-i.length;for(let c=i.length-1;c>=0;c--)n[s*4+c+a]=i[c]}this.valueBlock.value=t}};bn.NAME="UniversalStringValueBlock";var ra,yn=class extends bn{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};ra=yn;A.UniversalString=ra;yn.NAME="UniversalString";var na,wn=class extends gt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};na=wn;A.NumericString=na;wn.NAME="NumericString";var sa,xn=class extends gt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};sa=xn;A.PrintableString=sa;xn.NAME="PrintableString";var oa,vn=class extends gt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};oa=vn;A.TeletexString=oa;vn.NAME="TeletexString";var ia,Bn=class extends gt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};ia=Bn;A.VideotexString=ia;Bn.NAME="VideotexString";var aa,En=class extends gt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};aa=En;A.IA5String=aa;En.NAME="IA5String";var ca,An=class extends gt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};ca=An;A.GraphicString=ca;An.NAME="GraphicString";var la,mr=class extends gt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};la=mr;A.VisibleString=la;mr.NAME="VisibleString";var ua,Sn=class extends gt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};ua=Sn;A.GeneralString=ua;Sn.NAME="GeneralString";var fa,kn=class extends gt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};fa=kn;A.CharacterString=fa;kn.NAME="CharacterString";var ha,br=class extends mr{constructor({value:t,valueDate:e,...n}={}){if(super(n),this.year=0,this.month=0,this.day=0,this.hour=0,this.minute=0,this.second=0,t){this.fromString(t),this.valueBlock.valueHexView=new Uint8Array(t.length);for(let s=0;s<t.length;s++)this.valueBlock.valueHexView[s]=t.charCodeAt(s)}e&&(this.fromDate(e),this.valueBlock.valueHexView=new Uint8Array(this.toBuffer())),this.idBlock.tagClass=1,this.idBlock.tagNumber=23}fromBuffer(t){this.fromString(String.fromCharCode.apply(null,M.BufferSourceConverter.toUint8Array(t)))}toBuffer(){let t=this.toString(),e=new ArrayBuffer(t.length),n=new Uint8Array(e);for(let s=0;s<t.length;s++)n[s]=t.charCodeAt(s);return e}fromDate(t){this.year=t.getUTCFullYear(),this.month=t.getUTCMonth()+1,this.day=t.getUTCDate(),this.hour=t.getUTCHours(),this.minute=t.getUTCMinutes(),this.second=t.getUTCSeconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second))}fromString(t){let n=/(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})Z/ig.exec(t);if(n===null){this.error="Wrong input string for conversion";return}let s=parseInt(n[1],10);s>=50?this.year=1900+s:this.year=2e3+s,this.month=parseInt(n[2],10),this.day=parseInt(n[3],10),this.hour=parseInt(n[4],10),this.minute=parseInt(n[5],10),this.second=parseInt(n[6],10)}toString(t="iso"){if(t==="iso"){let e=new Array(7);return e[0]=vt(this.year<2e3?this.year-1900:this.year-2e3,2),e[1]=vt(this.month,2),e[2]=vt(this.day,2),e[3]=vt(this.hour,2),e[4]=vt(this.minute,2),e[5]=vt(this.second,2),e[6]="Z",e.join("")}return super.toString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.toDate().toISOString()}`}toJSON(){return{...super.toJSON(),year:this.year,month:this.month,day:this.day,hour:this.hour,minute:this.minute,second:this.second}}};ha=br;A.UTCTime=ha;br.NAME="UTCTime";var da,In=class extends br{constructor(t={}){var e;super(t),(e=this.millisecond)!==null&&e!==void 0||(this.millisecond=0),this.idBlock.tagClass=1,this.idBlock.tagNumber=24}fromDate(t){super.fromDate(t),this.millisecond=t.getUTCMilliseconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second,this.millisecond))}fromString(t){let e=!1,n="",s="",o=0,i,a=0,c=0;if(t[t.length-1]==="Z")n=t.substring(0,t.length-1),e=!0;else{let u=new Number(t[t.length-1]);if(isNaN(u.valueOf()))throw new Error("Wrong input string for conversion");n=t}if(e){if(n.indexOf("+")!==-1)throw new Error("Wrong input string for conversion");if(n.indexOf("-")!==-1)throw new Error("Wrong input string for conversion")}else{let u=1,h=n.indexOf("+"),x="";if(h===-1&&(h=n.indexOf("-"),u=-1),h!==-1){if(x=n.substring(h+1),n=n.substring(0,h),x.length!==2&&x.length!==4)throw new Error("Wrong input string for conversion");let v=parseInt(x.substring(0,2),10);if(isNaN(v.valueOf()))throw new Error("Wrong input string for conversion");if(a=u*v,x.length===4){if(v=parseInt(x.substring(2,4),10),isNaN(v.valueOf()))throw new Error("Wrong input string for conversion");c=u*v}}}let f=n.indexOf(".");if(f===-1&&(f=n.indexOf(",")),f!==-1){let u=new Number(`0${n.substring(f)}`);if(isNaN(u.valueOf()))throw new Error("Wrong input string for conversion");o=u.valueOf(),s=n.substring(0,f)}else s=n;switch(!0){case s.length===8:if(i=/(\d{4})(\d{2})(\d{2})/ig,f!==-1)throw new Error("Wrong input string for conversion");break;case s.length===10:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let u=60*o;this.minute=Math.floor(u),u=60*(u-this.minute),this.second=Math.floor(u),u=1e3*(u-this.second),this.millisecond=Math.floor(u)}break;case s.length===12:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let u=60*o;this.second=Math.floor(u),u=1e3*(u-this.second),this.millisecond=Math.floor(u)}break;case s.length===14:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let u=1e3*o;this.millisecond=Math.floor(u)}break;default:throw new Error("Wrong input string for conversion")}let l=i.exec(s);if(l===null)throw new Error("Wrong input string for conversion");for(let u=1;u<l.length;u++)switch(u){case 1:this.year=parseInt(l[u],10);break;case 2:this.month=parseInt(l[u],10);break;case 3:this.day=parseInt(l[u],10);break;case 4:this.hour=parseInt(l[u],10)+a;break;case 5:this.minute=parseInt(l[u],10)+c;break;case 6:this.second=parseInt(l[u],10);break;default:throw new Error("Wrong input string for conversion")}if(e===!1){let u=new Date(this.year,this.month,this.day,this.hour,this.minute,this.second,this.millisecond);this.year=u.getUTCFullYear(),this.month=u.getUTCMonth(),this.day=u.getUTCDay(),this.hour=u.getUTCHours(),this.minute=u.getUTCMinutes(),this.second=u.getUTCSeconds(),this.millisecond=u.getUTCMilliseconds()}}toString(t="iso"){if(t==="iso"){let e=[];return e.push(vt(this.year,4)),e.push(vt(this.month,2)),e.push(vt(this.day,2)),e.push(vt(this.hour,2)),e.push(vt(this.minute,2)),e.push(vt(this.second,2)),this.millisecond!==0&&(e.push("."),e.push(vt(this.millisecond,3))),e.push("Z"),e.join("")}return super.toString(t)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};da=In;A.GeneralizedTime=da;In.NAME="GeneralizedTime";var ga,Nn=class extends jt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};ga=Nn;A.DATE=ga;Nn.NAME="DATE";var pa,Cn=class extends jt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};pa=Cn;A.TimeOfDay=pa;Cn.NAME="TimeOfDay";var ma,Un=class extends jt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};ma=Un;A.DateTime=ma;Un.NAME="DateTime";var ba,Tn=class extends jt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};ba=Tn;A.Duration=ba;Tn.NAME="Duration";var ya,Ln=class extends jt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};ya=Ln;A.TIME=ya;Ln.NAME="TIME";function Bt(r,t="utf8"){let e=Fr[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}var yr=class extends Error{constructor(t="An error occurred while verifying a message"){super(t),this.name="VerificationError"}},_n=class extends Error{constructor(t="Missing Web Crypto API"){super(t),this.name="WebCryptoMissingError"}};var wa={get(r=globalThis){let t=r.crypto;if(t?.subtle==null)throw new _n("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 ge=wa;async function xa(r){let t=await ge.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 Ju(t);return{privateKey:e[0],publicKey:e[1]}}async function va(r,t){let e=await ge.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await ge.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},e,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(n,0,n.byteLength)}async function Ba(r,t,e){let n=await ge.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return ge.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,t,e instanceof Uint8Array?e:e.subarray())}async function Ju(r){if(r.privateKey==null||r.publicKey==null)throw new dt("Private and public key are required");return Promise.all([ge.get().subtle.exportKey("jwk",r.privateKey),ge.get().subtle.exportKey("jwk",r.publicKey)])}function uo(r){if(r.kty!=="RSA")throw new dt("invalid key type");if(r.n==null)throw new dt("invalid key modulus");return nt(r.n,"base64url").length*8}var Ze=class{type="RSA";_key;_raw;_multihash;constructor(t,e){this._key=t,this._multihash=e}get raw(){return this._raw==null&&(this._raw=wr.jwkToPkix(this._key)),this._raw}toMultihash(){return this._multihash}toCID(){return Et.createV1(114,this._multihash)}toString(){return Q.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:mt(this.raw,t.raw)}verify(t,e){return Ba(this._key,e,t)}},xr=class{type="RSA";_key;_raw;publicKey;constructor(t,e){this._key=t,this.publicKey=e}get raw(){return this._raw==null&&(this._raw=wr.jwkToPkcs1(this._key)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:mt(this.raw,t.raw)}sign(t){return va(this._key,t)}};var Vn=8192,fo=18;function Ea(r){let{result:t}=lo(r),e=t.valueBlock.value;return{n:Bt(Vt(e[1].toBigInt()),"base64url"),e:Bt(Vt(e[2].toBigInt()),"base64url"),d:Bt(Vt(e[3].toBigInt()),"base64url"),p:Bt(Vt(e[4].toBigInt()),"base64url"),q:Bt(Vt(e[5].toBigInt()),"base64url"),dp:Bt(Vt(e[6].toBigInt()),"base64url"),dq:Bt(Vt(e[7].toBigInt()),"base64url"),qi:Bt(Vt(e[8].toBigInt()),"base64url"),kty:"RSA",alg:"RS256"}}function Yu(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 dt("JWK was missing components");let e=new Gt({value:[new at({value:0}),at.fromBigInt(Ht(nt(r.n,"base64url"))),at.fromBigInt(Ht(nt(r.e,"base64url"))),at.fromBigInt(Ht(nt(r.d,"base64url"))),at.fromBigInt(Ht(nt(r.p,"base64url"))),at.fromBigInt(Ht(nt(r.q,"base64url"))),at.fromBigInt(Ht(nt(r.dp,"base64url"))),at.fromBigInt(Ht(nt(r.dq,"base64url"))),at.fromBigInt(Ht(nt(r.qi,"base64url")))]}).toBER();return new Uint8Array(e,0,e.byteLength)}function Aa(r){let{result:t}=lo(r),e=t.valueBlock.value[1].valueBlock.value[0].valueBlock.value;return{kty:"RSA",n:Bt(Vt(e[0].toBigInt()),"base64url"),e:Bt(Vt(e[1].toBigInt()),"base64url")}}function ho(r){if(r.n==null||r.e==null)throw new dt("JWK was missing components");let e=new Gt({value:[new Gt({value:[new Ge({value:"1.2.840.113549.1.1.1"}),new qe]}),new ze({valueHex:new Gt({value:[at.fromBigInt(Ht(nt(r.n,"base64url"))),at.fromBigInt(Ht(nt(r.e,"base64url")))]}).toBER()})]}).toBER();return new Uint8Array(e,0,e.byteLength)}function Vt(r){let t=r.toString(16);t.length%2>0&&(t=`0${t}`);let e=t.length/2,n=new Uint8Array(e),s=0,o=0;for(;s<e;)n[s]=parseInt(t.slice(o,o+2),16),s+=1,o+=2;return n}function Ht(r){let t=[];return r.forEach(function(e){let n=e.toString(16);n.length%2>0&&(n=`0${n}`),t.push(n)}),BigInt("0x"+t.join(""))}function Sa(r){let t=Ea(r);return ka(t)}function go(r){let t=Aa(r);if(uo(t)>Vn)throw new Ne("Key size is too large");let e=Ke(le.encode({Type:xt.RSA,Data:r})),n=kt(fo,e);return new Ze(t,n)}function ka(r){if(uo(r)>Vn)throw new dt("Key size is too large");let t=Na(r),e=Ke(le.encode({Type:xt.RSA,Data:ho(t.publicKey)})),n=kt(fo,e);return new xr(t.privateKey,new Ze(t.publicKey,n))}async function Ia(r){if(r>Vn)throw new dt("Key size is too large");let t=await xa(r),e=Ke(le.encode({Type:xt.RSA,Data:ho(t.publicKey)})),n=kt(fo,e);return new xr(t.privateKey,new Ze(t.publicKey,n))}function Na(r){if(r==null)throw new dt("Missing key parameter");return{privateKey:r,publicKey:{kty:r.kty,n:r.n,e:r.e}}}var Hn=class extends Oe{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,Zo(t);let n=nr(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 s=this.blockLen,o=new Uint8Array(s);o.set(n.length>s?t.create().update(n).digest():n);for(let i=0;i<o.length;i++)o[i]^=54;this.iHash.update(o),this.oHash=t.create();for(let i=0;i<o.length;i++)o[i]^=106;this.oHash.update(o),o.fill(0)}update(t){return De(this),this.iHash.update(t),this}digestInto(t){De(this),He(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:s,destroyed:o,blockLen:i,outputLen:a}=this;return t=t,t.finished=s,t.destroyed=o,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()}},po=(r,t,e)=>new Hn(r,t).update(e).digest();po.create=(r,t)=>new Hn(r,t);function Ca(r){r.lowS!==void 0&&Nt("lowS",r.lowS),r.prehash!==void 0&&Nt("prehash",r.prehash)}function Xu(r){let t=ir(r);Rt(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:s}=t;if(e){if(!n.eql(s,n.ZERO))throw new Error("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("Expected endomorphism with beta: bigint and splitScalar: function")}return Object.freeze({...t})}var{bytesToNumberBE:Qu,hexToBytes:tf}=Tr,Jt={Err:class extends Error{constructor(t=""){super(t)}},_tlv:{encode:(r,t)=>{let{Err:e}=Jt;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,s=me(n);if(s.length/2&128)throw new e("tlv.encode: long form length too big");let o=n>127?me(s.length/2|128):"";return`${me(r)}${o}${s}${t}`},decode(r,t){let{Err:e}=Jt,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 s=t[n++],o=!!(s&128),i=0;if(!o)i=s;else{let c=s&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 l of f)i=i<<8|l;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}=Jt;if(r<Yt)throw new t("integer: negative integers are not allowed");let e=me(r);if(Number.parseInt(e[0],16)&8&&(e="00"+e),e.length&1)throw new t("unexpected assertion");return e},decode(r){let{Err:t}=Jt;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 Qu(r)}},toSig(r){let{Err:t,_int:e,_tlv:n}=Jt,s=typeof r=="string"?tf(r):r;Pe(s);let{v:o,l:i}=n.decode(48,s);if(i.length)throw new t("Invalid signature: left bytes after parsing");let{v:a,l:c}=n.decode(2,o),{v:f,l}=n.decode(2,c);if(l.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}=Jt,n=`${t.encode(2,e.encode(r.r))}${t.encode(2,e.encode(r.s))}`;return t.encode(48,n)}},Yt=BigInt(0),st=BigInt(1),F0=BigInt(2),Ua=BigInt(3),K0=BigInt(4);function ef(r){let t=Xu(r),{Fp:e}=t,n=ae(t.n,t.nBitLength),s=t.toBytes||((b,d,y)=>{let E=d.toAffine();return Kt(Uint8Array.from([4]),e.toBytes(E.x),e.toBytes(E.y))}),o=t.fromBytes||(b=>{let d=b.subarray(1),y=e.fromBytes(d.subarray(0,e.BYTES)),E=e.fromBytes(d.subarray(e.BYTES,2*e.BYTES));return{x:y,y:E}});function i(b){let{a:d,b:y}=t,E=e.sqr(b),p=e.mul(E,b);return e.add(e.add(p,e.mul(b,d)),y)}if(!e.eql(e.sqr(t.Gy),i(t.Gx)))throw new Error("bad generator point: equation left != right");function a(b){return sr(b,st,t.n)}function c(b){let{allowedPrivateKeyLengths:d,nByteLength:y,wrapPrivateKey:E,n:p}=t;if(d&&typeof b!="bigint"){if(se(b)&&(b=Pt(b)),typeof b!="string"||!d.includes(b.length))throw new Error("Invalid key");b=b.padStart(y*2,"0")}let S;try{S=typeof b=="bigint"?b:Ft(W("private key",b,y))}catch{throw new Error(`private key must be ${y} bytes, hex or bigint, not ${typeof b}`)}return E&&(S=q(S,p)),bt("private key",S,st,p),S}function f(b){if(!(b instanceof h))throw new Error("ProjectivePoint expected")}let l=we((b,d)=>{let{px:y,py:E,pz:p}=b;if(e.eql(p,e.ONE))return{x:y,y:E};let S=b.is0();d==null&&(d=S?e.ONE:e.inv(p));let L=e.mul(y,d),T=e.mul(E,d),k=e.mul(p,d);if(S)return{x:e.ZERO,y:e.ZERO};if(!e.eql(k,e.ONE))throw new Error("invZ was invalid");return{x:L,y:T}}),u=we(b=>{if(b.is0()){if(t.allowInfinityPoint&&!e.is0(b.py))return;throw new Error("bad point: ZERO")}let{x:d,y}=b.toAffine();if(!e.isValid(d)||!e.isValid(y))throw new Error("bad point: x or y not FE");let E=e.sqr(y),p=i(d);if(!e.eql(E,p))throw new Error("bad point: equation left != right");if(!b.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});class h{constructor(d,y,E){if(this.px=d,this.py=y,this.pz=E,d==null||!e.isValid(d))throw new Error("x required");if(y==null||!e.isValid(y))throw new Error("y required");if(E==null||!e.isValid(E))throw new Error("z required");Object.freeze(this)}static fromAffine(d){let{x:y,y:E}=d||{};if(!d||!e.isValid(y)||!e.isValid(E))throw new Error("invalid affine point");if(d instanceof h)throw new Error("projective point not allowed");let p=S=>e.eql(S,e.ZERO);return p(y)&&p(E)?h.ZERO:new h(y,E,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(d){let y=e.invertBatch(d.map(E=>E.pz));return d.map((E,p)=>E.toAffine(y[p])).map(h.fromAffine)}static fromHex(d){let y=h.fromAffine(o(W("pointHex",d)));return y.assertValidity(),y}static fromPrivateKey(d){return h.BASE.multiply(c(d))}static msm(d,y){return _r(h,n,d,y)}_setWindowSize(d){v.setWindowSize(this,d)}assertValidity(){u(this)}hasEvenY(){let{y:d}=this.toAffine();if(e.isOdd)return!e.isOdd(d);throw new Error("Field doesn't support isOdd")}equals(d){f(d);let{px:y,py:E,pz:p}=this,{px:S,py:L,pz:T}=d,k=e.eql(e.mul(y,T),e.mul(S,p)),I=e.eql(e.mul(E,T),e.mul(L,p));return k&&I}negate(){return new h(this.px,e.neg(this.py),this.pz)}double(){let{a:d,b:y}=t,E=e.mul(y,Ua),{px:p,py:S,pz:L}=this,T=e.ZERO,k=e.ZERO,I=e.ZERO,U=e.mul(p,p),J=e.mul(S,S),F=e.mul(L,L),H=e.mul(p,S);return H=e.add(H,H),I=e.mul(p,L),I=e.add(I,I),T=e.mul(d,I),k=e.mul(E,F),k=e.add(T,k),T=e.sub(J,k),k=e.add(J,k),k=e.mul(T,k),T=e.mul(H,T),I=e.mul(E,I),F=e.mul(d,F),H=e.sub(U,F),H=e.mul(d,H),H=e.add(H,I),I=e.add(U,U),U=e.add(I,U),U=e.add(U,F),U=e.mul(U,H),k=e.add(k,U),F=e.mul(S,L),F=e.add(F,F),U=e.mul(F,H),T=e.sub(T,U),I=e.mul(F,J),I=e.add(I,I),I=e.add(I,I),new h(T,k,I)}add(d){f(d);let{px:y,py:E,pz:p}=this,{px:S,py:L,pz:T}=d,k=e.ZERO,I=e.ZERO,U=e.ZERO,J=t.a,F=e.mul(t.b,Ua),H=e.mul(y,S),Y=e.mul(E,L),B=e.mul(p,T),N=e.add(y,E),m=e.add(S,L);N=e.mul(N,m),m=e.add(H,Y),N=e.sub(N,m),m=e.add(y,p);let g=e.add(S,T);return m=e.mul(m,g),g=e.add(H,B),m=e.sub(m,g),g=e.add(E,p),k=e.add(L,T),g=e.mul(g,k),k=e.add(Y,B),g=e.sub(g,k),U=e.mul(J,m),k=e.mul(F,B),U=e.add(k,U),k=e.sub(Y,U),U=e.add(Y,U),I=e.mul(k,U),Y=e.add(H,H),Y=e.add(Y,H),B=e.mul(J,B),m=e.mul(F,m),Y=e.add(Y,B),B=e.sub(H,B),B=e.mul(J,B),m=e.add(m,B),H=e.mul(Y,m),I=e.add(I,H),H=e.mul(g,m),k=e.mul(N,k),k=e.sub(k,H),H=e.mul(N,Y),U=e.mul(g,U),U=e.add(U,H),new h(k,I,U)}subtract(d){return this.add(d.negate())}is0(){return this.equals(h.ZERO)}wNAF(d){return v.wNAFCached(this,d,h.normalizeZ)}multiplyUnsafe(d){bt("scalar",d,Yt,t.n);let y=h.ZERO;if(d===Yt)return y;if(d===st)return this;let{endo:E}=t;if(!E)return v.unsafeLadder(this,d);let{k1neg:p,k1:S,k2neg:L,k2:T}=E.splitScalar(d),k=y,I=y,U=this;for(;S>Yt||T>Yt;)S&st&&(k=k.add(U)),T&st&&(I=I.add(U)),U=U.double(),S>>=st,T>>=st;return p&&(k=k.negate()),L&&(I=I.negate()),I=new h(e.mul(I.px,E.beta),I.py,I.pz),k.add(I)}multiply(d){let{endo:y,n:E}=t;bt("scalar",d,st,E);let p,S;if(y){let{k1neg:L,k1:T,k2neg:k,k2:I}=y.splitScalar(d),{p:U,f:J}=this.wNAF(T),{p:F,f:H}=this.wNAF(I);U=v.constTimeNegate(L,U),F=v.constTimeNegate(k,F),F=new h(e.mul(F.px,y.beta),F.py,F.pz),p=U.add(F),S=J.add(H)}else{let{p:L,f:T}=this.wNAF(d);p=L,S=T}return h.normalizeZ([p,S])[0]}multiplyAndAddUnsafe(d,y,E){let p=h.BASE,S=(T,k)=>k===Yt||k===st||!T.equals(p)?T.multiplyUnsafe(k):T.multiply(k),L=S(this,y).add(S(d,E));return L.is0()?void 0:L}toAffine(d){return l(this,d)}isTorsionFree(){let{h:d,isTorsionFree:y}=t;if(d===st)return!0;if(y)return y(h,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h:d,clearCofactor:y}=t;return d===st?this:y?y(h,this):this.multiplyUnsafe(t.h)}toRawBytes(d=!0){return Nt("isCompressed",d),this.assertValidity(),s(h,this,d)}toHex(d=!0){return Nt("isCompressed",d),Pt(this.toRawBytes(d))}}h.BASE=new h(t.Gx,t.Gy,e.ONE),h.ZERO=new h(e.ZERO,e.ONE,e.ZERO);let x=t.nBitLength,v=Rr(h,t.endo?Math.ceil(x/2):x);return{CURVE:t,ProjectivePoint:h,normPrivateKeyToScalar:c,weierstrassEquation:i,isWithinCurveOrder:a}}function rf(r){let t=ir(r);return Rt(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function Ta(r){let t=rf(r),{Fp:e,n}=t,s=e.BYTES+1,o=2*e.BYTES+1;function i(B){return q(B,n)}function a(B){return Lr(B,n)}let{ProjectivePoint:c,normPrivateKeyToScalar:f,weierstrassEquation:l,isWithinCurveOrder:u}=ef({...t,toBytes(B,N,m){let g=N.toAffine(),w=e.toBytes(g.x),C=Kt;return Nt("isCompressed",m),m?C(Uint8Array.from([N.hasEvenY()?2:3]),w):C(Uint8Array.from([4]),w,e.toBytes(g.y))},fromBytes(B){let N=B.length,m=B[0],g=B.subarray(1);if(N===s&&(m===2||m===3)){let w=Ft(g);if(!sr(w,st,e.ORDER))throw new Error("Point is not on curve");let C=l(w),R;try{R=e.sqrt(C)}catch(P){let O=P instanceof Error?": "+P.message:"";throw new Error("Point is not on curve"+O)}let _=(R&st)===st;return(m&1)===1!==_&&(R=e.neg(R)),{x:w,y:R}}else if(N===o&&m===4){let w=e.fromBytes(g.subarray(0,e.BYTES)),C=e.fromBytes(g.subarray(e.BYTES,2*e.BYTES));return{x:w,y:C}}else throw new Error(`Point of length ${N} was invalid. Expected ${s} compressed bytes or ${o} uncompressed bytes`)}}),h=B=>Pt(ie(B,t.nByteLength));function x(B){let N=n>>st;return B>N}function v(B){return x(B)?i(-B):B}let b=(B,N,m)=>Ft(B.slice(N,m));class d{constructor(N,m,g){this.r=N,this.s=m,this.recovery=g,this.assertValidity()}static fromCompact(N){let m=t.nByteLength;return N=W("compactSignature",N,m*2),new d(b(N,0,m),b(N,m,2*m))}static fromDER(N){let{r:m,s:g}=Jt.toSig(W("DER",N));return new d(m,g)}assertValidity(){bt("r",this.r,st,n),bt("s",this.s,st,n)}addRecoveryBit(N){return new d(this.r,this.s,N)}recoverPublicKey(N){let{r:m,s:g,recovery:w}=this,C=T(W("msgHash",N));if(w==null||![0,1,2,3].includes(w))throw new Error("recovery id invalid");let R=w===2||w===3?m+t.n:m;if(R>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let _=w&1?"03":"02",D=c.fromHex(_+h(R)),P=a(R),O=i(-C*P),$=i(g*P),z=c.BASE.multiplyAndAddUnsafe(D,O,$);if(!z)throw new Error("point at infinify");return z.assertValidity(),z}hasHighS(){return x(this.s)}normalizeS(){return this.hasHighS()?new d(this.r,i(-this.s),this.recovery):this}toDERRawBytes(){return be(this.toDERHex())}toDERHex(){return Jt.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return be(this.toCompactHex())}toCompactHex(){return h(this.r)+h(this.s)}}let y={isValidPrivateKey(B){try{return f(B),!0}catch{return!1}},normPrivateKeyToScalar:f,randomPrivateKey:()=>{let B=Bs(t.n);return ai(t.randomBytes(B),t.n)},precompute(B=8,N=c.BASE){return N._setWindowSize(B),N.multiply(BigInt(3)),N}};function E(B,N=!0){return c.fromPrivateKey(B).toRawBytes(N)}function p(B){let N=se(B),m=typeof B=="string",g=(N||m)&&B.length;return N?g===s||g===o:m?g===2*s||g===2*o:B instanceof c}function S(B,N,m=!0){if(p(B))throw new Error("first arg must be private key");if(!p(N))throw new Error("second arg must be public key");return c.fromHex(N).multiply(f(B)).toRawBytes(m)}let L=t.bits2int||function(B){let N=Ft(B),m=B.length*8-t.nBitLength;return m>0?N>>BigInt(m):N},T=t.bits2int_modN||function(B){return i(L(B))},k=or(t.nBitLength);function I(B){return bt(`num < 2^${t.nBitLength}`,B,Yt,k),ie(B,t.nByteLength)}function U(B,N,m=J){if(["recovered","canonical"].some(rt=>rt in m))throw new Error("sign() legacy options not supported");let{hash:g,randomBytes:w}=t,{lowS:C,prehash:R,extraEntropy:_}=m;C==null&&(C=!0),B=W("msgHash",B),Ca(m),R&&(B=W("prehashed msgHash",g(B)));let D=T(B),P=f(N),O=[I(P),I(D)];if(_!=null&&_!==!1){let rt=_===!0?w(e.BYTES):_;O.push(W("extraEntropy",rt))}let $=Kt(...O),z=D;function et(rt){let ot=L(rt);if(!u(ot))return;let ft=a(ot),X=c.BASE.multiply(ot).toAffine(),pt=i(X.x);if(pt===Yt)return;let Dt=i(ft*i(z+pt*P));if(Dt===Yt)return;let Je=(X.x===pt?0:2)|Number(X.y&st),Ye=Dt;return C&&x(Dt)&&(Ye=v(Dt),Je^=1),new d(pt,Ye,Je)}return{seed:$,k2sig:et}}let J={lowS:t.lowS,prehash:!1},F={lowS:t.lowS,prehash:!1};function H(B,N,m=J){let{seed:g,k2sig:w}=U(B,N,m),C=t;return ys(C.hash.outputLen,C.nByteLength,C.hmac)(g,w)}c.BASE._setWindowSize(8);function Y(B,N,m,g=F){let w=B;if(N=W("msgHash",N),m=W("publicKey",m),"strict"in g)throw new Error("options.strict was renamed to lowS");Ca(g);let{lowS:C,prehash:R}=g,_,D;try{if(typeof w=="string"||se(w))try{_=d.fromDER(w)}catch(X){if(!(X instanceof Jt.Err))throw X;_=d.fromCompact(w)}else if(typeof w=="object"&&typeof w.r=="bigint"&&typeof w.s=="bigint"){let{r:X,s:pt}=w;_=new d(X,pt)}else throw new Error("PARSE");D=c.fromHex(m)}catch(X){if(X.message==="PARSE")throw new Error("signature must be Signature instance, Uint8Array or hex string");return!1}if(C&&_.hasHighS())return!1;R&&(N=t.hash(N));let{r:P,s:O}=_,$=T(N),z=a(O),et=i($*z),rt=i(P*z),ot=c.BASE.multiplyAndAddUnsafe(D,et,rt)?.toAffine();return ot?i(ot.x)===P:!1}return{CURVE:t,getPublicKey:E,getSharedSecret:S,sign:H,verify:Y,ProjectivePoint:c,Signature:d,utils:y}}function nf(r){return{hash:r,hmac:(t,...e)=>po(r,t,us(...e)),randomBytes:Nr}}function La(r,t){let e=n=>Ta({...r,...nf(n)});return Object.freeze({...e(t),create:e})}var Va=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),Ra=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),sf=BigInt(1),mo=BigInt(2),_a=(r,t)=>(r+t/mo)/t;function of(r){let t=Va,e=BigInt(3),n=BigInt(6),s=BigInt(11),o=BigInt(22),i=BigInt(23),a=BigInt(44),c=BigInt(88),f=r*r*r%t,l=f*f*r%t,u=j(l,e,t)*l%t,h=j(u,e,t)*l%t,x=j(h,mo,t)*f%t,v=j(x,s,t)*x%t,b=j(v,o,t)*v%t,d=j(b,a,t)*b%t,y=j(d,c,t)*d%t,E=j(y,a,t)*b%t,p=j(E,e,t)*l%t,S=j(p,i,t)*v%t,L=j(S,n,t)*f%t,T=j(L,mo,t);if(!bo.eql(bo.sqr(T),r))throw new Error("Cannot find square root");return T}var bo=ae(Va,void 0,void 0,{sqrt:of}),Ie=La({a:BigInt(0),b:BigInt(7),Fp:bo,n:Ra,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=Ra,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-sf*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),s=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),o=e,i=BigInt("0x100000000000000000000000000000000"),a=_a(o*r,t),c=_a(-n*r,t),f=q(r-a*e-c*s,t),l=q(-a*n-c*o,t),u=f>i,h=l>i;if(u&&(f=t-f),h&&(l=t-l),f>i||l>i)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:u,k1:f,k2neg:h,k2:l}}}},Ke),Y0=BigInt(0);var X0=Ie.ProjectivePoint;function Dn(r,t){t==null&&(t=r.reduce((s,o)=>s+o.length,0));let e=wt(t),n=0;for(let s of r)e.set(s,n),n+=s.length;return e}function Ha(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function Da(r,t,e){let n=Pr.digest(e instanceof Uint8Array?e:e.subarray());if(Ha(n))return n.then(({digest:s})=>Ie.verify(t,s,r)).catch(s=>{throw new yr(String(s))});try{return Ie.verify(t,n.digest,r)}catch(s){throw new yr(String(s))}}var On=class{type="secp256k1";raw;_key;constructor(t){this._key=Ma(t),this.raw=Oa(this._key)}toMultihash(){return ee.digest(Or(this))}toCID(){return Et.createV1(114,this.toMultihash())}toString(){return Q.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:mt(this.raw,t.raw)}verify(t,e){return Da(this._key,e,t)}};function Pa(r){return new On(r)}function Oa(r){return Ie.ProjectivePoint.fromHex(r).toRawBytes(!0)}function Ma(r){try{return Ie.ProjectivePoint.fromHex(r),r}catch(t){throw new Ne(String(t))}}function Fa(r){return r.byteLength===32?pi(r):r.byteLength===33?Pa(r):go(r)}function Or(r){return le.encode({Type:xt[r.type],Data:r.raw})}var Ka=Symbol.for("nodejs.util.inspect.custom"),af=114,vr=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()})`}[Xn]=!0;toString(){return this.string==null&&(this.string=Q.encode(this.multihash.bytes).slice(1)),this.string}toMultihash(){return this.multihash}toCID(){return Et.createV1(af,this.multihash)}toJSON(){return this.toString()}equals(t){if(t==null)return!1;if(t instanceof Uint8Array)return mt(this.multihash.bytes,t);if(typeof t=="string")return this.toString()===t;if(t?.toMultihash()?.bytes!=null)return mt(this.multihash.bytes,t.toMultihash().bytes);throw new Error("not valid Id")}[Ka](){return`PeerId(${this.toString()})`}},Mn=class extends vr{type="RSA";publicKey;constructor(t){super({...t,type:"RSA"}),this.publicKey=t.publicKey}},Pn=class extends vr{type="Ed25519";publicKey;constructor(t){super({...t,type:"Ed25519"}),this.publicKey=t.publicKey}},Fn=class extends vr{type="secp256k1";publicKey;constructor(t){super({...t,type:"secp256k1"}),this.publicKey=t.publicKey}},cf=2336,yo=class{type="url";multihash;publicKey;url;constructor(t){this.url=t.toString(),this.multihash=ee.digest(nt(this.url))}[Ka](){return`PeerId(${this.url})`}[Xn]=!0;toString(){return this.toCID().toString()}toMultihash(){return this.multihash}toCID(){return Et.createV1(cf,this.toMultihash())}toJSON(){return this.toString()}equals(t){return t==null?!1:(t instanceof Uint8Array&&(t=Bt(t)),t.toString()===this.toString())}};function $a(r){if(r.type==="Ed25519")return new Pn({multihash:r.toCID().multihash,publicKey:r});if(r.type==="secp256k1")return new Fn({multihash:r.toCID().multihash,publicKey:r});if(r.type==="RSA")return new Mn({multihash:r.toCID().multihash,publicKey:r});throw new Ar}function We(){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 qa(r,t,e){if(t==null)return r;if(t.aborted)return Promise.reject(new Kn(e?.errorMessage,e?.errorCode,e?.errorName));let n,s=new Kn(e?.errorMessage,e?.errorCode,e?.errorName);try{return await Promise.race([r,new Promise((o,i)=>{n=()=>{i(s)},t.addEventListener("abort",n)})])}finally{n!=null&&t.removeEventListener("abort",n)}}var wo=class{readNext;haveNext;ended;nextResult;constructor(){this.ended=!1,this.readNext=We(),this.haveNext=We()}[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=We(),t}async throw(t){return this.ended=!0,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 await this._push(void 0),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 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=We(),await qa(this.readNext.promise,e?.signal,e)}};function za(){return new wo}var ja=Symbol.for("@achingbrain/uint8arraylist");function Ga(r,t){if(t==null||t<0)throw new RangeError("index is out of bounds");let e=0;for(let n of r){let s=e+n.byteLength;if(t<s)return{buf:n,index:t-e};e=s}throw new RangeError("index is out of bounds")}function $n(r){return!!r?.[ja]}var Xt=class r{bufs;length;[ja]=!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($n(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($n(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=Ga(this.bufs,t);return e.buf[e.index]}set(t,e){let n=Ga(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($n(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:s}=this._subList(t,e);return Dn(n,s)}subarray(t,e){let{bufs:n,length:s}=this._subList(t,e);return n.length===1?n[0]:Dn(n,s)}sublist(t,e){let{bufs:n,length:s}=this._subList(t,e),o=new r;return o.length=s,o.bufs=[...n],o}_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=[],s=0;for(let o=0;o<this.bufs.length;o++){let i=this.bufs[o],a=s,c=a+i.byteLength;if(s=c,t>=c)continue;let f=t>=a&&t<c,l=e>a&&e<=c;if(f&&l){if(t===a&&e===c){n.push(i);break}let u=t-a;n.push(i.subarray(u,u+(e-t)));break}if(f){if(t===0){n.push(i);continue}n.push(i.subarray(t-a));continue}if(l){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(!$n(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 s=n.byteLength;if(s===0)throw new TypeError("search must be at least 1 byte long");let o=256,i=new Int32Array(o);for(let u=0;u<o;u++)i[u]=-1;for(let u=0;u<s;u++)i[n[u]]=u;let a=i,c=this.byteLength-n.byteLength,f=n.byteLength-1,l;for(let u=e;u<=c;u+=l){l=0;for(let h=f;h>=0;h--){let x=this.get(u+h);if(n[h]!==x){l=Math.max(1,h-a[x]);break}}if(l===0)return u}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=wt(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 s=Ut(2);new DataView(s.buffer,s.byteOffset,s.byteLength).setInt16(0,e,n),this.write(s,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 s=Ut(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setInt32(0,e,n),this.write(s,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 s=Ut(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigInt64(0,e,n),this.write(s,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=wt(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 s=Ut(2);new DataView(s.buffer,s.byteOffset,s.byteLength).setUint16(0,e,n),this.write(s,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 s=Ut(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setUint32(0,e,n),this.write(s,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 s=Ut(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigUint64(0,e,n),this.write(s,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 s=Ut(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setFloat32(0,e,n),this.write(s,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 s=Ut(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setFloat64(0,e,n),this.write(s,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(!mt(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((s,o)=>s+o.byteLength,0)),n.length=e,n}};var qn=class extends Error{name="UnexpectedEOFError";code="ERR_UNEXPECTED_EOF"};var xo=class extends Error{code;constructor(t,e){super(t),this.code=e}},vo=class extends xo{type;constructor(t){super(t,"ABORT_ERR"),this.type="aborted",this.name="AbortError"}};function Za(r,t){let e=za();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 s=new Xt;return{read:async(i,a)=>{a?.signal?.throwIfAborted();let c,f=new Promise((l,u)=>{c=()=>{u(new vo("Read aborted"))},a?.signal?.addEventListener("abort",c)});try{if(i==null){let{done:u,value:h}=await Promise.race([n.next(),f]);return u===!0?new Xt:h}for(;s.byteLength<i;){let{value:u,done:h}=await Promise.race([n.next(),f]);if(h===!0)throw new qn("unexpected end of input");s.append(u)}let l=s.sublist(0,i);return s.consume(i),l}finally{c!=null&&a?.signal?.removeEventListener("abort",c)}},write:async(i,a)=>{a?.signal?.throwIfAborted(),i instanceof Uint8Array?await e.push(i,a):await e.push(i.subarray(),a)},unwrap:()=>{if(s.byteLength>0){let i=r.source;r.source=async function*(){t?.yieldBytes===!1?yield s:yield*s,yield*i}()}return r}}}var zn=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},Gn=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},jn=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"};function Wa(r,t={}){let e=Za(r,t);t.maxDataLength!=null&&t.maxLengthLength==null&&(t.maxLengthLength=$t(t.maxDataLength));let n=t?.lengthDecoder??bi,s=t?.lengthEncoder??mi;return{read:async i=>{let a=-1,c=new Xt;for(;;){c.append(await e.read(1,i));try{a=n(c)}catch(f){if(f instanceof RangeError)continue;throw f}if(a<0)throw new zn("Invalid message length");if(t?.maxLengthLength!=null&&c.byteLength>t.maxLengthLength)throw new jn("message length length too long");if(a>-1)break}if(t?.maxDataLength!=null&&a>t.maxDataLength)throw new Gn("message length too long");return e.read(a,i)},write:async(i,a)=>{await e.write(new Xt(s(i.byteLength),i),a)},writeV:async(i,a)=>{let c=new Xt(...i.flatMap(f=>[s(f.byteLength),f]));await e.write(c,a)},unwrap:()=>e.unwrap()}}function Ja(r,t){let e=Wa(r,t),n={read:async(s,o)=>{let i=await e.read(o);return s.decode(i)},write:async(s,o,i)=>{await e.write(o.encode(s),i)},writeV:async(s,o,i)=>{await e.writeV(s.map(a=>o.encode(a)),i)},pb:s=>({read:async o=>n.read(s,o),write:async(o,i)=>n.write(o,s,i),writeV:async(o,i)=>n.writeV(o,s,i),unwrap:()=>n}),unwrap:()=>e.unwrap()};return n}var Zn;(function(r){let t;r.codec=()=>(t==null&&(t=Se((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.id!=null&&(n.uint32(10),n.bytes(e.id)),e.pubkey!=null&&(n.uint32(18),Jn.codec().encode(e.pubkey,n)),s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let o={},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let a=e.uint32();switch(a>>>3){case 1:{o.id=e.bytes();break}case 2:{o.pubkey=Jn.codec().decode(e,e.uint32(),{limits:s.limits?.pubkey});break}default:{e.skipType(a&7);break}}}return o})),t),r.encode=e=>Ae(e,r.codec()),r.decode=(e,n)=>Be(e,r.codec(),n)})(Zn||(Zn={}));var Qt;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.secp256k1="secp256k1",r.ECDSA="ECDSA"})(Qt||(Qt={}));var Wn;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1",r[r.ECDSA=3]="ECDSA"})(Wn||(Wn={}));(function(r){r.codec=()=>lr(Wn)})(Qt||(Qt={}));var Jn;(function(r){let t;r.codec=()=>(t==null&&(t=Se((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&Wn[e.Type]!==0&&(n.uint32(8),Qt.codec().encode(e.Type,n)),e.Data!=null&&e.Data.byteLength>0&&(n.uint32(18),n.bytes(e.Data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let o={Type:Qt.RSA,Data:Ut(0)},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let a=e.uint32();switch(a>>>3){case 1:{o.Type=Qt.codec().decode(e);break}case 2:{o.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return o})),t),r.encode=e=>Ae(e,r.codec()),r.decode=(e,n)=>Be(e,r.codec(),n)})(Jn||(Jn={}));var lf="/plaintext/2.0.0",Bo=class{protocol=lf;privateKey;log;constructor(t){this.privateKey=t.privateKey,this.log=t.logger.forComponent("libp2p:plaintext")}[Symbol.toStringTag]="@libp2p/plaintext";[To]=["@libp2p/connection-encryption"];async secureInbound(t,e){return this._encrypt(t,e)}async secureOutbound(t,e){return this._encrypt(t,e)}async _encrypt(t,e){let n=Ja(t).pb(Zn);this.log("write pubkey exchange to peer %p",e?.remotePeer);let s=this.privateKey.publicKey,[,o]=await Promise.all([n.write({id:s.toMultihash().bytes,pubkey:{Type:Qt[s.type],Data:s.raw}},e),n.read(e)]),i;try{if(o.pubkey==null)throw new Ce("Public key missing");if(o.pubkey.Data.byteLength===0)throw new Ce("Public key data too short");if(o.id==null)throw new Ce("Remote id missing");let a=Fa(o.pubkey.Data);if(i=$a(a),!mt(i.toMultihash().bytes,o.id))throw new Xe("Public key did not match id")}catch(a){throw this.log.error(a),new Xe("Invalid public key - "+a.message)}if(e?.remotePeer!=null&&!i.equals(e?.remotePeer))throw new Er;return this.log("plaintext key exchange completed successfully with peer %p",i),{conn:n.unwrap().unwrap(),remotePeer:i}}};function uf(){return r=>new Bo(r)}return hc(ff);})();
6
+ `)}`:`${e} :`}};Fi=he;A.Constructed=Fi;he.NAME="CONSTRUCTED";var Qr=class extends ut{fromBER(t,e,n){return e}toBER(t){return Tt}};Qr.override="EndOfContentValueBlock";var Ki,tn=class extends it{constructor(t={}){super(t,Qr),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};Ki=tn;A.EndOfContent=Ki;tn.NAME=fr;var $i,$e=class extends it{constructor(t={}){super(t,ut),this.idBlock.tagClass=1,this.idBlock.tagNumber=5}fromBER(t,e,n){return this.lenBlock.length>0&&this.warnings.push("Non-zero length of value block for Null type"),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.blockLength+=n,e+n>t.byteLength?(this.error="End of input reached before message was fully decoded (inconsistent offset and length values)",-1):e+n}toBER(t,e){let n=new ArrayBuffer(2);if(!t){let s=new Uint8Array(n);s[0]=5,s[1]=0}return e&&e.write(n),n}onAsciiEncoding(){return`${this.constructor.NAME}`}};$i=$e;A.Null=$i;$e.NAME="NULL";var en=class extends Zt(ut){constructor({value:t,...e}={}){super(e),e.valueHex?this.valueHexView=M.BufferSourceConverter.toUint8Array(e.valueHex):this.valueHexView=new Uint8Array(1),t&&(this.value=t)}get value(){for(let t of this.valueHexView)if(t>0)return!0;return!1}set value(t){this.valueHexView[0]=t?255:0}fromBER(t,e,n){let s=M.BufferSourceConverter.toUint8Array(t);return jt(this,s,e,n)?(this.valueHexView=s.subarray(e,e+n),n>1&&this.warnings.push("Boolean value encoded in more then 1 octet"),this.isHexOnly=!0,io.call(this),this.blockLength=n,e+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};en.NAME="BooleanValueBlock";var qi,rn=class extends it{constructor(t={}){super(t,en),this.idBlock.tagClass=1,this.idBlock.tagNumber=1}getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.getValue}`}};qi=rn;A.Boolean=qi;rn.NAME="BOOLEAN";var nn=class extends Zt(Rt){constructor({isConstructed:t=!1,...e}={}){super(e),this.isConstructed=t}fromBER(t,e,n){let s=0;if(this.isConstructed){if(this.isHexOnly=!1,s=Rt.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let o=0;o<this.value.length;o++){let i=this.value[o].constructor.NAME;if(i===fr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(i!==Di)return this.error="OCTET STRING may consists of OCTET STRINGs only",-1}}else this.isHexOnly=!0,s=super.fromBER(t,e,n),this.blockLength=n;return s}toBER(t,e){return this.isConstructed?Rt.prototype.toBER.call(this,t,e):t?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};nn.NAME="OctetStringValueBlock";var zi,sn=class r extends it{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,o;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((o=n.value)===null||o===void 0)&&o.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},nn),this.idBlock.tagClass=1,this.idBlock.tagNumber=4}fromBER(t,e,n){if(this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,n===0)return this.idBlock.error.length===0&&(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length===0&&(this.blockLength+=this.lenBlock.blockLength),e;if(!this.valueBlock.isConstructed){let o=(t instanceof ArrayBuffer?new Uint8Array(t):t).subarray(e,e+n);try{if(o.byteLength){let i=Rn(o,0,o.byteLength);i.offset!==-1&&i.offset===n&&(this.valueBlock.value=[i.result])}}catch{}}return super.fromBER(t,e,n)}onAsciiEncoding(){return this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length?he.prototype.onAsciiEncoding.call(this):`${this.constructor.NAME} : ${M.Convert.ToHex(this.valueBlock.valueHexView)}`}getValue(){if(!this.idBlock.isConstructed)return this.valueBlock.valueHexView.slice().buffer;let t=[];for(let e of this.valueBlock.value)e instanceof r&&t.push(e.valueBlock.valueHexView);return M.BufferSourceConverter.concat(t)}};zi=sn;A.OctetString=zi;sn.NAME=Di;var on=class extends Zt(Rt){constructor({unusedBits:t=0,isConstructed:e=!1,...n}={}){super(n),this.unusedBits=t,this.isConstructed=e,this.blockLength=this.valueHexView.byteLength}fromBER(t,e,n){if(!n)return e;let s=-1;if(this.isConstructed){if(s=Rt.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let a of this.value){let c=a.constructor.NAME;if(c===fr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==Oi)return this.error="BIT STRING may consists of BIT STRINGs only",-1;let f=a.valueBlock;if(this.unusedBits>0&&f.unusedBits>0)return this.error='Using of "unused bits" inside constructive BIT STRING allowed for least one only',-1;this.unusedBits=f.unusedBits}return s}let o=M.BufferSourceConverter.toUint8Array(t);if(!jt(this,o,e,n))return-1;let i=o.subarray(e,e+n);if(this.unusedBits=i[0],this.unusedBits>7)return this.error="Unused bits for BitString must be in range 0-7",-1;if(!this.unusedBits){let a=i.subarray(1);try{if(a.byteLength){let c=Rn(a,0,a.byteLength);c.offset!==-1&&c.offset===n-1&&(this.value=[c.result])}}catch{}}return this.valueHexView=i.subarray(1),this.blockLength=i.length,e+n}toBER(t,e){if(this.isConstructed)return Rt.prototype.toBER.call(this,t,e);if(t)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return Tt;let n=new Uint8Array(this.valueHexView.length+1);return n[0]=this.unusedBits,n.set(this.valueHexView,1),n.buffer}toJSON(){return{...super.toJSON(),unusedBits:this.unusedBits,isConstructed:this.isConstructed}}};on.NAME="BitStringValueBlock";var Gi,qe=class extends it{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,o;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((o=n.value)===null||o===void 0)&&o.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},on),this.idBlock.tagClass=1,this.idBlock.tagNumber=3}fromBER(t,e,n){return this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,super.fromBER(t,e,n)}onAsciiEncoding(){if(this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length)return he.prototype.onAsciiEncoding.call(this);{let t=[],e=this.valueBlock.valueHexView;for(let s of e)t.push(s.toString(2).padStart(8,"0"));let n=t.join("");return`${this.constructor.NAME} : ${n.substring(0,n.length-this.valueBlock.unusedBits)}`}}};Gi=qe;A.BitString=Gi;qe.NAME=Oi;var ji;function ju(r,t){let e=new Uint8Array([0]),n=new Uint8Array(r),s=new Uint8Array(t),o=n.slice(0),i=o.length-1,a=s.slice(0),c=a.length-1,f=0,l=c<i?i:c,u=0;for(let h=l;h>=0;h--,u++){switch(!0){case u<a.length:f=o[i-u]+a[c-u]+e[0];break;default:f=o[i-u]+e[0]}switch(e[0]=f/10,!0){case u>=o.length:o=Gr(new Uint8Array([f%10]),o);break;default:o[i-u]=f%10}}return e[0]>0&&(o=Gr(e,o)),o}function Hi(r){if(r>=lr.length)for(let t=lr.length;t<=r;t++){let e=new Uint8Array([0]),n=lr[t-1].slice(0);for(let s=n.length-1;s>=0;s--){let o=new Uint8Array([(n[s]<<1)+e[0]]);e[0]=o[0]/10,n[s]=o[0]%10}e[0]>0&&(n=Gr(e,n)),lr.push(n)}return lr[r]}function Zu(r,t){let e=0,n=new Uint8Array(r),s=new Uint8Array(t),o=n.slice(0),i=o.length-1,a=s.slice(0),c=a.length-1,f,l=0;for(let u=c;u>=0;u--,l++)switch(f=o[i-l]-a[c-l]-e,!0){case f<0:e=1,o[i-l]=f+10;break;default:e=0,o[i-l]=f}if(e>0)for(let u=i-c+1;u>=0;u--,l++)if(f=o[i-l]-e,f<0)e=1,o[i-l]=f+10;else{e=0,o[i-l]=f;break}return o.slice()}var hr=class extends Zt(ut){constructor({value:t,...e}={}){super(e),this._valueDec=0,e.valueHex&&this.setValueHex(),t!==void 0&&(this.valueDec=t)}setValueHex(){this.valueHexView.length>=4?(this.warnings.push("Too big Integer for decoding, hex only"),this.isHexOnly=!0,this._valueDec=0):(this.isHexOnly=!1,this.valueHexView.length>0&&(this._valueDec=io.call(this)))}set valueDec(t){this._valueDec=t,this.isHexOnly=!1,this.valueHexView=new Uint8Array(Ri(t))}get valueDec(){return this._valueDec}fromDER(t,e,n,s=0){let o=this.fromBER(t,e,n);if(o===-1)return o;let i=this.valueHexView;return i[0]===0&&i[1]&128?this.valueHexView=i.subarray(1):s!==0&&i.length<s&&(s-i.length>1&&(s=i.length+1),this.valueHexView=i.subarray(s-i.length)),o}toDER(t=!1){let e=this.valueHexView;switch(!0){case(e[0]&128)!==0:{let n=new Uint8Array(this.valueHexView.length+1);n[0]=0,n.set(e,1),this.valueHexView=n}break;case(e[0]===0&&(e[1]&128)===0):this.valueHexView=this.valueHexView.subarray(1);break}return this.toBER(t)}fromBER(t,e,n){let s=super.fromBER(t,e,n);return s===-1||this.setValueHex(),s}toBER(t){return t?new ArrayBuffer(this.valueHexView.length):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}toString(){let t=this.valueHexView.length*8-1,e=new Uint8Array(this.valueHexView.length*8/3),n=0,s,o=this.valueHexView,i="",a=!1;for(let c=o.byteLength-1;c>=0;c--){s=o[c];for(let f=0;f<8;f++){if((s&1)===1)switch(n){case t:e=Zu(Hi(n),e),i="-";break;default:e=ju(e,Hi(n))}n++,s>>=1}}for(let c=0;c<e.length;c++)e[c]&&(a=!0),a&&(i+=Vi.charAt(e[c]));return a===!1&&(i+=Vi.charAt(0)),i}};ji=hr;hr.NAME="IntegerValueBlock";Object.defineProperty(ji.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var Zi,at=class r extends it{constructor(t={}){super(t,hr),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return jr(),BigInt(this.valueBlock.toString())}static fromBigInt(t){jr();let e=BigInt(t),n=new ur,s=e.toString(16).replace(/^-/,""),o=new Uint8Array(M.Convert.FromHex(s));if(e<0){let a=new Uint8Array(o.length+(o[0]&128?1:0));a[0]|=128;let f=BigInt(`0x${M.Convert.ToHex(a)}`)+e,l=M.BufferSourceConverter.toUint8Array(M.Convert.FromHex(f.toString(16)));l[0]|=128,n.write(l)}else o[0]&128&&n.write(new Uint8Array([0])),n.write(o);return new r({valueHex:n.final()})}convertToDER(){let t=new r({valueHex:this.valueBlock.valueHexView});return t.valueBlock.toDER(),t}convertFromDER(){return new r({valueHex:this.valueBlock.valueHexView[0]===0?this.valueBlock.valueHexView.subarray(1):this.valueBlock.valueHexView})}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()}`}};Zi=at;A.Integer=Zi;at.NAME="INTEGER";var Wi,an=class extends at{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};Wi=an;A.Enumerated=Wi;an.NAME="ENUMERATED";var dr=class extends Zt(ut){constructor({valueDec:t=-1,isFirstSid:e=!1,...n}={}){super(n),this.valueDec=t,this.isFirstSid=e}fromBER(t,e,n){if(!n)return e;let s=M.BufferSourceConverter.toUint8Array(t);if(!jt(this,s,e,n))return-1;let o=s.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=o[a]&127,this.blockLength++,!!(o[a]&128));a++);let i=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)i[a]=this.valueHexView[a];return this.valueHexView=i,o[this.blockLength-1]&128?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=Se(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}set valueBigInt(t){jr();let e=BigInt(t).toString(2);for(;e.length%7;)e="0"+e;let n=new Uint8Array(e.length/7);for(let s=0;s<n.length;s++)n[s]=parseInt(e.slice(s*7,s*7+7),2)+(s+1<n.length?128:0);this.fromBER(n.buffer,0,n.length)}toBER(t){if(this.isHexOnly){if(t)return new ArrayBuffer(this.valueHexView.byteLength);let s=this.valueHexView,o=new Uint8Array(this.blockLength);for(let i=0;i<this.blockLength-1;i++)o[i]=s[i]|128;return o[this.blockLength-1]=s[this.blockLength-1],o.buffer}let e=fe(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Tt;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),o=e.byteLength-1;for(let i=0;i<o;i++)n[i]=s[i]|128;n[o]=s[o]}return n}toString(){let t="";if(this.isHexOnly)t=M.Convert.ToHex(this.valueHexView);else if(this.isFirstSid){let e=this.valueDec;this.valueDec<=39?t="0.":this.valueDec<=79?(t="1.",e-=40):(t="2.",e-=80),t+=e.toString()}else t=this.valueDec.toString();return t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec,isFirstSid:this.isFirstSid}}};dr.NAME="sidBlock";var cn=class extends ut{constructor({value:t=Ge,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new dr;if(s=o.fromBER(t,s,n),s===-1)return this.blockLength=0,this.error=o.error,s;this.value.length===0&&(o.isFirstSid=!0),this.blockLength+=o.blockLength,n-=o.blockLength,this.value.push(o)}return s}toBER(t){let e=[];for(let n=0;n<this.value.length;n++){let s=this.value[n].toBER(t);if(s.byteLength===0)return this.error=this.value[n].error,Tt;e.push(s)}return ao(e)}fromString(t){this.value=[];let e=0,n=0,s="",o=!1;do if(n=t.indexOf(".",e),n===-1?s=t.substring(e):s=t.substring(e,n),e=n+1,o){let i=this.value[0],a=0;switch(i.valueDec){case 0:break;case 1:a=40;break;case 2:a=80;break;default:this.value=[];return}let c=parseInt(s,10);if(isNaN(c))return;i.valueDec=c+a,o=!1}else{let i=new dr;if(s>Number.MAX_SAFE_INTEGER){jr();let a=BigInt(s);i.valueBigInt=a}else if(i.valueDec=parseInt(s,10),isNaN(i.valueDec))return;this.value.length||(i.isFirstSid=!0,o=!0),this.value.push(i)}while(n!==-1)}toString(){let t="",e=!1;for(let n=0;n<this.value.length;n++){e=this.value[n].isHexOnly;let s=this.value[n].toString();n!==0&&(t=`${t}.`),e?(s=`{${s}}`,this.value[n].isFirstSid?t=`2.{${s} - 80}`:t+=s):t+=s}return t}toJSON(){let t={...super.toJSON(),value:this.toString(),sidArray:[]};for(let e=0;e<this.value.length;e++)t.sidArray.push(this.value[e].toJSON());return t}};cn.NAME="ObjectIdentifierValueBlock";var Ji,ze=class extends it{constructor(t={}){super(t,cn),this.idBlock.tagClass=1,this.idBlock.tagNumber=6}getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};Ji=ze;A.ObjectIdentifier=Ji;ze.NAME="OBJECT IDENTIFIER";var gr=class extends Zt(qt){constructor({valueDec:t=0,...e}={}){super(e),this.valueDec=t}fromBER(t,e,n){if(n===0)return e;let s=M.BufferSourceConverter.toUint8Array(t);if(!jt(this,s,e,n))return-1;let o=s.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=o[a]&127,this.blockLength++,!!(o[a]&128));a++);let i=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)i[a]=this.valueHexView[a];return this.valueHexView=i,o[this.blockLength-1]&128?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=Se(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}toBER(t){if(this.isHexOnly){if(t)return new ArrayBuffer(this.valueHexView.byteLength);let s=this.valueHexView,o=new Uint8Array(this.blockLength);for(let i=0;i<this.blockLength-1;i++)o[i]=s[i]|128;return o[this.blockLength-1]=s[this.blockLength-1],o.buffer}let e=fe(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Tt;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),o=e.byteLength-1;for(let i=0;i<o;i++)n[i]=s[i]|128;n[o]=s[o]}return n.buffer}toString(){let t="";return this.isHexOnly?t=M.Convert.ToHex(this.valueHexView):t=this.valueDec.toString(),t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};gr.NAME="relativeSidBlock";var ln=class extends ut{constructor({value:t=Ge,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new gr;if(s=o.fromBER(t,s,n),s===-1)return this.blockLength=0,this.error=o.error,s;this.blockLength+=o.blockLength,n-=o.blockLength,this.value.push(o)}return s}toBER(t,e){let n=[];for(let s=0;s<this.value.length;s++){let o=this.value[s].toBER(t);if(o.byteLength===0)return this.error=this.value[s].error,Tt;n.push(o)}return ao(n)}fromString(t){this.value=[];let e=0,n=0,s="";do{n=t.indexOf(".",e),n===-1?s=t.substring(e):s=t.substring(e,n),e=n+1;let o=new gr;if(o.valueDec=parseInt(s,10),isNaN(o.valueDec))return!0;this.value.push(o)}while(n!==-1);return!0}toString(){let t="",e=!1;for(let n=0;n<this.value.length;n++){e=this.value[n].isHexOnly;let s=this.value[n].toString();n!==0&&(t=`${t}.`),e&&(s=`{${s}}`),t+=s}return t}toJSON(){let t={...super.toJSON(),value:this.toString(),sidArray:[]};for(let e=0;e<this.value.length;e++)t.sidArray.push(this.value[e].toJSON());return t}};ln.NAME="RelativeObjectIdentifierValueBlock";var Yi,un=class extends it{constructor(t={}){super(t,ln),this.idBlock.tagClass=1,this.idBlock.tagNumber=13}getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};Yi=un;A.RelativeObjectIdentifier=Yi;un.NAME="RelativeObjectIdentifier";var Xi,zt=class extends he{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};Xi=zt;A.Sequence=Xi;zt.NAME="SEQUENCE";var Qi,fn=class extends he{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};Qi=fn;A.Set=Qi;fn.NAME="SET";var hn=class extends Zt(ut){constructor({...t}={}){super(t),this.isHexOnly=!0,this.value=Ge}toJSON(){return{...super.toJSON(),value:this.value}}};hn.NAME="StringValueBlock";var dn=class extends hn{};dn.NAME="SimpleStringValueBlock";var gt=class extends Jr{constructor({...t}={}){super(t,dn)}fromBuffer(t){this.valueBlock.value=String.fromCharCode.apply(null,M.BufferSourceConverter.toUint8Array(t))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e);for(let s=0;s<e;s++)n[s]=t.charCodeAt(s);this.valueBlock.value=t}};gt.NAME="SIMPLE STRING";var gn=class extends gt{fromBuffer(t){this.valueBlock.valueHexView=M.BufferSourceConverter.toUint8Array(t);try{this.valueBlock.value=M.Convert.ToUtf8String(t)}catch(e){this.warnings.push(`Error during "decodeURIComponent": ${e}, using raw string`),this.valueBlock.value=M.Convert.ToBinary(t)}}fromString(t){this.valueBlock.valueHexView=new Uint8Array(M.Convert.FromUtf8String(t)),this.valueBlock.value=t}};gn.NAME="Utf8StringValueBlock";var ta,Gt=class extends gn{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};ta=Gt;A.Utf8String=ta;Gt.NAME="UTF8String";var pn=class extends gt{fromBuffer(t){this.valueBlock.value=M.Convert.ToUtf16String(t),this.valueBlock.valueHexView=M.BufferSourceConverter.toUint8Array(t)}fromString(t){this.valueBlock.value=t,this.valueBlock.valueHexView=new Uint8Array(M.Convert.FromUtf16String(t))}};pn.NAME="BmpStringValueBlock";var ea,mn=class extends pn{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};ea=mn;A.BmpString=ea;mn.NAME="BMPString";var bn=class extends gt{fromBuffer(t){let e=ArrayBuffer.isView(t)?t.slice().buffer:t.slice(0),n=new Uint8Array(e);for(let s=0;s<n.length;s+=4)n[s]=n[s+3],n[s+1]=n[s+2],n[s+2]=0,n[s+3]=0;this.valueBlock.value=String.fromCharCode.apply(null,new Uint32Array(e))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e*4);for(let s=0;s<e;s++){let o=fe(t.charCodeAt(s),8),i=new Uint8Array(o);if(i.length>4)continue;let a=4-i.length;for(let c=i.length-1;c>=0;c--)n[s*4+c+a]=i[c]}this.valueBlock.value=t}};bn.NAME="UniversalStringValueBlock";var ra,yn=class extends bn{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};ra=yn;A.UniversalString=ra;yn.NAME="UniversalString";var na,wn=class extends gt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};na=wn;A.NumericString=na;wn.NAME="NumericString";var sa,xn=class extends gt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};sa=xn;A.PrintableString=sa;xn.NAME="PrintableString";var oa,vn=class extends gt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};oa=vn;A.TeletexString=oa;vn.NAME="TeletexString";var ia,Bn=class extends gt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};ia=Bn;A.VideotexString=ia;Bn.NAME="VideotexString";var aa,En=class extends gt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};aa=En;A.IA5String=aa;En.NAME="IA5String";var ca,An=class extends gt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};ca=An;A.GraphicString=ca;An.NAME="GraphicString";var la,pr=class extends gt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};la=pr;A.VisibleString=la;pr.NAME="VisibleString";var ua,Sn=class extends gt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};ua=Sn;A.GeneralString=ua;Sn.NAME="GeneralString";var fa,kn=class extends gt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};fa=kn;A.CharacterString=fa;kn.NAME="CharacterString";var ha,mr=class extends pr{constructor({value:t,valueDate:e,...n}={}){if(super(n),this.year=0,this.month=0,this.day=0,this.hour=0,this.minute=0,this.second=0,t){this.fromString(t),this.valueBlock.valueHexView=new Uint8Array(t.length);for(let s=0;s<t.length;s++)this.valueBlock.valueHexView[s]=t.charCodeAt(s)}e&&(this.fromDate(e),this.valueBlock.valueHexView=new Uint8Array(this.toBuffer())),this.idBlock.tagClass=1,this.idBlock.tagNumber=23}fromBuffer(t){this.fromString(String.fromCharCode.apply(null,M.BufferSourceConverter.toUint8Array(t)))}toBuffer(){let t=this.toString(),e=new ArrayBuffer(t.length),n=new Uint8Array(e);for(let s=0;s<t.length;s++)n[s]=t.charCodeAt(s);return e}fromDate(t){this.year=t.getUTCFullYear(),this.month=t.getUTCMonth()+1,this.day=t.getUTCDate(),this.hour=t.getUTCHours(),this.minute=t.getUTCMinutes(),this.second=t.getUTCSeconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second))}fromString(t){let n=/(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})Z/ig.exec(t);if(n===null){this.error="Wrong input string for conversion";return}let s=parseInt(n[1],10);s>=50?this.year=1900+s:this.year=2e3+s,this.month=parseInt(n[2],10),this.day=parseInt(n[3],10),this.hour=parseInt(n[4],10),this.minute=parseInt(n[5],10),this.second=parseInt(n[6],10)}toString(t="iso"){if(t==="iso"){let e=new Array(7);return e[0]=vt(this.year<2e3?this.year-1900:this.year-2e3,2),e[1]=vt(this.month,2),e[2]=vt(this.day,2),e[3]=vt(this.hour,2),e[4]=vt(this.minute,2),e[5]=vt(this.second,2),e[6]="Z",e.join("")}return super.toString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.toDate().toISOString()}`}toJSON(){return{...super.toJSON(),year:this.year,month:this.month,day:this.day,hour:this.hour,minute:this.minute,second:this.second}}};ha=mr;A.UTCTime=ha;mr.NAME="UTCTime";var da,In=class extends mr{constructor(t={}){var e;super(t),(e=this.millisecond)!==null&&e!==void 0||(this.millisecond=0),this.idBlock.tagClass=1,this.idBlock.tagNumber=24}fromDate(t){super.fromDate(t),this.millisecond=t.getUTCMilliseconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second,this.millisecond))}fromString(t){let e=!1,n="",s="",o=0,i,a=0,c=0;if(t[t.length-1]==="Z")n=t.substring(0,t.length-1),e=!0;else{let u=new Number(t[t.length-1]);if(isNaN(u.valueOf()))throw new Error("Wrong input string for conversion");n=t}if(e){if(n.indexOf("+")!==-1)throw new Error("Wrong input string for conversion");if(n.indexOf("-")!==-1)throw new Error("Wrong input string for conversion")}else{let u=1,h=n.indexOf("+"),x="";if(h===-1&&(h=n.indexOf("-"),u=-1),h!==-1){if(x=n.substring(h+1),n=n.substring(0,h),x.length!==2&&x.length!==4)throw new Error("Wrong input string for conversion");let v=parseInt(x.substring(0,2),10);if(isNaN(v.valueOf()))throw new Error("Wrong input string for conversion");if(a=u*v,x.length===4){if(v=parseInt(x.substring(2,4),10),isNaN(v.valueOf()))throw new Error("Wrong input string for conversion");c=u*v}}}let f=n.indexOf(".");if(f===-1&&(f=n.indexOf(",")),f!==-1){let u=new Number(`0${n.substring(f)}`);if(isNaN(u.valueOf()))throw new Error("Wrong input string for conversion");o=u.valueOf(),s=n.substring(0,f)}else s=n;switch(!0){case s.length===8:if(i=/(\d{4})(\d{2})(\d{2})/ig,f!==-1)throw new Error("Wrong input string for conversion");break;case s.length===10:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let u=60*o;this.minute=Math.floor(u),u=60*(u-this.minute),this.second=Math.floor(u),u=1e3*(u-this.second),this.millisecond=Math.floor(u)}break;case s.length===12:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let u=60*o;this.second=Math.floor(u),u=1e3*(u-this.second),this.millisecond=Math.floor(u)}break;case s.length===14:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let u=1e3*o;this.millisecond=Math.floor(u)}break;default:throw new Error("Wrong input string for conversion")}let l=i.exec(s);if(l===null)throw new Error("Wrong input string for conversion");for(let u=1;u<l.length;u++)switch(u){case 1:this.year=parseInt(l[u],10);break;case 2:this.month=parseInt(l[u],10);break;case 3:this.day=parseInt(l[u],10);break;case 4:this.hour=parseInt(l[u],10)+a;break;case 5:this.minute=parseInt(l[u],10)+c;break;case 6:this.second=parseInt(l[u],10);break;default:throw new Error("Wrong input string for conversion")}if(e===!1){let u=new Date(this.year,this.month,this.day,this.hour,this.minute,this.second,this.millisecond);this.year=u.getUTCFullYear(),this.month=u.getUTCMonth(),this.day=u.getUTCDay(),this.hour=u.getUTCHours(),this.minute=u.getUTCMinutes(),this.second=u.getUTCSeconds(),this.millisecond=u.getUTCMilliseconds()}}toString(t="iso"){if(t==="iso"){let e=[];return e.push(vt(this.year,4)),e.push(vt(this.month,2)),e.push(vt(this.day,2)),e.push(vt(this.hour,2)),e.push(vt(this.minute,2)),e.push(vt(this.second,2)),this.millisecond!==0&&(e.push("."),e.push(vt(this.millisecond,3))),e.push("Z"),e.join("")}return super.toString(t)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};da=In;A.GeneralizedTime=da;In.NAME="GeneralizedTime";var ga,Nn=class extends Gt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};ga=Nn;A.DATE=ga;Nn.NAME="DATE";var pa,Cn=class extends Gt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};pa=Cn;A.TimeOfDay=pa;Cn.NAME="TimeOfDay";var ma,Un=class extends Gt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};ma=Un;A.DateTime=ma;Un.NAME="DateTime";var ba,Tn=class extends Gt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};ba=Tn;A.Duration=ba;Tn.NAME="Duration";var ya,Ln=class extends Gt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};ya=Ln;A.TIME=ya;Ln.NAME="TIME";function br(r,t="utf8"){let e=Fr[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}var yr=class extends Error{constructor(t="An error occurred while verifying a message"){super(t),this.name="VerificationError"}},_n=class extends Error{constructor(t="Missing Web Crypto API"){super(t),this.name="WebCryptoMissingError"}};var wa={get(r=globalThis){let t=r.crypto;if(t?.subtle==null)throw new _n("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 de=wa;async function xa(r){let t=await de.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 Ju(t);return{privateKey:e[0],publicKey:e[1]}}async function va(r,t){let e=await de.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await de.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},e,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(n,0,n.byteLength)}async function Ba(r,t,e){let n=await de.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return de.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,t,e instanceof Uint8Array?e:e.subarray())}async function Ju(r){if(r.privateKey==null||r.publicKey==null)throw new dt("Private and public key are required");return Promise.all([de.get().subtle.exportKey("jwk",r.privateKey),de.get().subtle.exportKey("jwk",r.publicKey)])}function uo(r){if(r.kty!=="RSA")throw new dt("invalid key type");if(r.n==null)throw new dt("invalid key modulus");return nt(r.n,"base64url").length*8}var je=class{type="RSA";_key;_raw;_multihash;constructor(t,e){this._key=t,this._multihash=e}get raw(){return this._raw==null&&(this._raw=wr.jwkToPkix(this._key)),this._raw}toMultihash(){return this._multihash}toCID(){return Bt.createV1(114,this._multihash)}toString(){return Q.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:mt(this.raw,t.raw)}verify(t,e){return Ba(this._key,e,t)}},xr=class{type="RSA";_key;_raw;publicKey;constructor(t,e){this._key=t,this.publicKey=e}get raw(){return this._raw==null&&(this._raw=wr.jwkToPkcs1(this._key)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:mt(this.raw,t.raw)}sign(t){return va(this._key,t)}};var Vn=8192,fo=18;function Ea(r){let{result:t}=lo(r),e=t.valueBlock.value;return{n:_t(e[1]),e:_t(e[2]),d:_t(e[3]),p:_t(e[4]),q:_t(e[5]),dp:_t(e[6]),dq:_t(e[7]),qi:_t(e[8]),kty:"RSA",alg:"RS256"}}function Yu(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 dt("JWK was missing components");let e=new zt({value:[new at({value:0}),at.fromBigInt(Vt(nt(r.n,"base64url"))),at.fromBigInt(Vt(nt(r.e,"base64url"))),at.fromBigInt(Vt(nt(r.d,"base64url"))),at.fromBigInt(Vt(nt(r.p,"base64url"))),at.fromBigInt(Vt(nt(r.q,"base64url"))),at.fromBigInt(Vt(nt(r.dp,"base64url"))),at.fromBigInt(Vt(nt(r.dq,"base64url"))),at.fromBigInt(Vt(nt(r.qi,"base64url")))]}).toBER();return new Uint8Array(e,0,e.byteLength)}function Aa(r){let{result:t}=lo(r),e=t.valueBlock.value[1].valueBlock.value[0].valueBlock.value;return{kty:"RSA",n:_t(e[0]),e:_t(e[1])}}function ho(r){if(r.n==null||r.e==null)throw new dt("JWK was missing components");let e=new zt({value:[new zt({value:[new ze({value:"1.2.840.113549.1.1.1"}),new $e]}),new qe({valueHex:new zt({value:[at.fromBigInt(Vt(nt(r.n,"base64url"))),at.fromBigInt(Vt(nt(r.e,"base64url")))]}).toBER()})]}).toBER();return new Uint8Array(e,0,e.byteLength)}function _t(r){let t=r.valueBlock.valueHexView;for(;t[0]===0;)t=t.subarray(1);return br(t,"base64url")}function Vt(r){let t=[];return r.forEach(function(e){let n=e.toString(16);n.length%2>0&&(n=`0${n}`),t.push(n)}),BigInt("0x"+t.join(""))}function Sa(r){let t=Ea(r);return ka(t)}function go(r){let t=Aa(r);if(uo(t)>Vn)throw new Ie("Key size is too large");let e=Fe(ce.encode({Type:xt.RSA,Data:r})),n=St(fo,e);return new je(t,n)}function ka(r){if(uo(r)>Vn)throw new dt("Key size is too large");let t=Na(r),e=Fe(ce.encode({Type:xt.RSA,Data:ho(t.publicKey)})),n=St(fo,e);return new xr(t.privateKey,new je(t.publicKey,n))}async function Ia(r){if(r>Vn)throw new dt("Key size is too large");let t=await xa(r),e=Fe(ce.encode({Type:xt.RSA,Data:ho(t.publicKey)})),n=St(fo,e);return new xr(t.privateKey,new je(t.publicKey,n))}function Na(r){if(r==null)throw new dt("Missing key parameter");return{privateKey:r,publicKey:{kty:r.kty,n:r.n,e:r.e}}}var Hn=class extends De{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,Zo(t);let n=rr(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 s=this.blockLen,o=new Uint8Array(s);o.set(n.length>s?t.create().update(n).digest():n);for(let i=0;i<o.length;i++)o[i]^=54;this.iHash.update(o),this.oHash=t.create();for(let i=0;i<o.length;i++)o[i]^=106;this.oHash.update(o),o.fill(0)}update(t){return He(this),this.iHash.update(t),this}digestInto(t){He(this),Ve(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:s,destroyed:o,blockLen:i,outputLen:a}=this;return t=t,t.finished=s,t.destroyed=o,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()}},po=(r,t,e)=>new Hn(r,t).update(e).digest();po.create=(r,t)=>new Hn(r,t);function Ca(r){r.lowS!==void 0&&It("lowS",r.lowS),r.prehash!==void 0&&It("prehash",r.prehash)}function Xu(r){let t=or(r);Lt(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:s}=t;if(e){if(!n.eql(s,n.ZERO))throw new Error("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("Expected endomorphism with beta: bigint and splitScalar: function")}return Object.freeze({...t})}var{bytesToNumberBE:Qu,hexToBytes:tf}=Tr,Wt={Err:class extends Error{constructor(t=""){super(t)}},_tlv:{encode:(r,t)=>{let{Err:e}=Wt;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,s=pe(n);if(s.length/2&128)throw new e("tlv.encode: long form length too big");let o=n>127?pe(s.length/2|128):"";return`${pe(r)}${o}${s}${t}`},decode(r,t){let{Err:e}=Wt,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 s=t[n++],o=!!(s&128),i=0;if(!o)i=s;else{let c=s&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 l of f)i=i<<8|l;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}=Wt;if(r<Jt)throw new t("integer: negative integers are not allowed");let e=pe(r);if(Number.parseInt(e[0],16)&8&&(e="00"+e),e.length&1)throw new t("unexpected assertion");return e},decode(r){let{Err:t}=Wt;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 Qu(r)}},toSig(r){let{Err:t,_int:e,_tlv:n}=Wt,s=typeof r=="string"?tf(r):r;Me(s);let{v:o,l:i}=n.decode(48,s);if(i.length)throw new t("Invalid signature: left bytes after parsing");let{v:a,l:c}=n.decode(2,o),{v:f,l}=n.decode(2,c);if(l.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}=Wt,n=`${t.encode(2,e.encode(r.r))}${t.encode(2,e.encode(r.s))}`;return t.encode(48,n)}},Jt=BigInt(0),st=BigInt(1),F0=BigInt(2),Ua=BigInt(3),K0=BigInt(4);function ef(r){let t=Xu(r),{Fp:e}=t,n=ie(t.n,t.nBitLength),s=t.toBytes||((b,d,y)=>{let E=d.toAffine();return Ft(Uint8Array.from([4]),e.toBytes(E.x),e.toBytes(E.y))}),o=t.fromBytes||(b=>{let d=b.subarray(1),y=e.fromBytes(d.subarray(0,e.BYTES)),E=e.fromBytes(d.subarray(e.BYTES,2*e.BYTES));return{x:y,y:E}});function i(b){let{a:d,b:y}=t,E=e.sqr(b),p=e.mul(E,b);return e.add(e.add(p,e.mul(b,d)),y)}if(!e.eql(e.sqr(t.Gy),i(t.Gx)))throw new Error("bad generator point: equation left != right");function a(b){return nr(b,st,t.n)}function c(b){let{allowedPrivateKeyLengths:d,nByteLength:y,wrapPrivateKey:E,n:p}=t;if(d&&typeof b!="bigint"){if(ne(b)&&(b=Mt(b)),typeof b!="string"||!d.includes(b.length))throw new Error("Invalid key");b=b.padStart(y*2,"0")}let S;try{S=typeof b=="bigint"?b:Pt(W("private key",b,y))}catch{throw new Error(`private key must be ${y} bytes, hex or bigint, not ${typeof b}`)}return E&&(S=q(S,p)),bt("private key",S,st,p),S}function f(b){if(!(b instanceof h))throw new Error("ProjectivePoint expected")}let l=ye((b,d)=>{let{px:y,py:E,pz:p}=b;if(e.eql(p,e.ONE))return{x:y,y:E};let S=b.is0();d==null&&(d=S?e.ONE:e.inv(p));let L=e.mul(y,d),T=e.mul(E,d),k=e.mul(p,d);if(S)return{x:e.ZERO,y:e.ZERO};if(!e.eql(k,e.ONE))throw new Error("invZ was invalid");return{x:L,y:T}}),u=ye(b=>{if(b.is0()){if(t.allowInfinityPoint&&!e.is0(b.py))return;throw new Error("bad point: ZERO")}let{x:d,y}=b.toAffine();if(!e.isValid(d)||!e.isValid(y))throw new Error("bad point: x or y not FE");let E=e.sqr(y),p=i(d);if(!e.eql(E,p))throw new Error("bad point: equation left != right");if(!b.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});class h{constructor(d,y,E){if(this.px=d,this.py=y,this.pz=E,d==null||!e.isValid(d))throw new Error("x required");if(y==null||!e.isValid(y))throw new Error("y required");if(E==null||!e.isValid(E))throw new Error("z required");Object.freeze(this)}static fromAffine(d){let{x:y,y:E}=d||{};if(!d||!e.isValid(y)||!e.isValid(E))throw new Error("invalid affine point");if(d instanceof h)throw new Error("projective point not allowed");let p=S=>e.eql(S,e.ZERO);return p(y)&&p(E)?h.ZERO:new h(y,E,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(d){let y=e.invertBatch(d.map(E=>E.pz));return d.map((E,p)=>E.toAffine(y[p])).map(h.fromAffine)}static fromHex(d){let y=h.fromAffine(o(W("pointHex",d)));return y.assertValidity(),y}static fromPrivateKey(d){return h.BASE.multiply(c(d))}static msm(d,y){return _r(h,n,d,y)}_setWindowSize(d){v.setWindowSize(this,d)}assertValidity(){u(this)}hasEvenY(){let{y:d}=this.toAffine();if(e.isOdd)return!e.isOdd(d);throw new Error("Field doesn't support isOdd")}equals(d){f(d);let{px:y,py:E,pz:p}=this,{px:S,py:L,pz:T}=d,k=e.eql(e.mul(y,T),e.mul(S,p)),I=e.eql(e.mul(E,T),e.mul(L,p));return k&&I}negate(){return new h(this.px,e.neg(this.py),this.pz)}double(){let{a:d,b:y}=t,E=e.mul(y,Ua),{px:p,py:S,pz:L}=this,T=e.ZERO,k=e.ZERO,I=e.ZERO,U=e.mul(p,p),J=e.mul(S,S),F=e.mul(L,L),H=e.mul(p,S);return H=e.add(H,H),I=e.mul(p,L),I=e.add(I,I),T=e.mul(d,I),k=e.mul(E,F),k=e.add(T,k),T=e.sub(J,k),k=e.add(J,k),k=e.mul(T,k),T=e.mul(H,T),I=e.mul(E,I),F=e.mul(d,F),H=e.sub(U,F),H=e.mul(d,H),H=e.add(H,I),I=e.add(U,U),U=e.add(I,U),U=e.add(U,F),U=e.mul(U,H),k=e.add(k,U),F=e.mul(S,L),F=e.add(F,F),U=e.mul(F,H),T=e.sub(T,U),I=e.mul(F,J),I=e.add(I,I),I=e.add(I,I),new h(T,k,I)}add(d){f(d);let{px:y,py:E,pz:p}=this,{px:S,py:L,pz:T}=d,k=e.ZERO,I=e.ZERO,U=e.ZERO,J=t.a,F=e.mul(t.b,Ua),H=e.mul(y,S),Y=e.mul(E,L),B=e.mul(p,T),N=e.add(y,E),m=e.add(S,L);N=e.mul(N,m),m=e.add(H,Y),N=e.sub(N,m),m=e.add(y,p);let g=e.add(S,T);return m=e.mul(m,g),g=e.add(H,B),m=e.sub(m,g),g=e.add(E,p),k=e.add(L,T),g=e.mul(g,k),k=e.add(Y,B),g=e.sub(g,k),U=e.mul(J,m),k=e.mul(F,B),U=e.add(k,U),k=e.sub(Y,U),U=e.add(Y,U),I=e.mul(k,U),Y=e.add(H,H),Y=e.add(Y,H),B=e.mul(J,B),m=e.mul(F,m),Y=e.add(Y,B),B=e.sub(H,B),B=e.mul(J,B),m=e.add(m,B),H=e.mul(Y,m),I=e.add(I,H),H=e.mul(g,m),k=e.mul(N,k),k=e.sub(k,H),H=e.mul(N,Y),U=e.mul(g,U),U=e.add(U,H),new h(k,I,U)}subtract(d){return this.add(d.negate())}is0(){return this.equals(h.ZERO)}wNAF(d){return v.wNAFCached(this,d,h.normalizeZ)}multiplyUnsafe(d){bt("scalar",d,Jt,t.n);let y=h.ZERO;if(d===Jt)return y;if(d===st)return this;let{endo:E}=t;if(!E)return v.unsafeLadder(this,d);let{k1neg:p,k1:S,k2neg:L,k2:T}=E.splitScalar(d),k=y,I=y,U=this;for(;S>Jt||T>Jt;)S&st&&(k=k.add(U)),T&st&&(I=I.add(U)),U=U.double(),S>>=st,T>>=st;return p&&(k=k.negate()),L&&(I=I.negate()),I=new h(e.mul(I.px,E.beta),I.py,I.pz),k.add(I)}multiply(d){let{endo:y,n:E}=t;bt("scalar",d,st,E);let p,S;if(y){let{k1neg:L,k1:T,k2neg:k,k2:I}=y.splitScalar(d),{p:U,f:J}=this.wNAF(T),{p:F,f:H}=this.wNAF(I);U=v.constTimeNegate(L,U),F=v.constTimeNegate(k,F),F=new h(e.mul(F.px,y.beta),F.py,F.pz),p=U.add(F),S=J.add(H)}else{let{p:L,f:T}=this.wNAF(d);p=L,S=T}return h.normalizeZ([p,S])[0]}multiplyAndAddUnsafe(d,y,E){let p=h.BASE,S=(T,k)=>k===Jt||k===st||!T.equals(p)?T.multiplyUnsafe(k):T.multiply(k),L=S(this,y).add(S(d,E));return L.is0()?void 0:L}toAffine(d){return l(this,d)}isTorsionFree(){let{h:d,isTorsionFree:y}=t;if(d===st)return!0;if(y)return y(h,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h:d,clearCofactor:y}=t;return d===st?this:y?y(h,this):this.multiplyUnsafe(t.h)}toRawBytes(d=!0){return It("isCompressed",d),this.assertValidity(),s(h,this,d)}toHex(d=!0){return It("isCompressed",d),Mt(this.toRawBytes(d))}}h.BASE=new h(t.Gx,t.Gy,e.ONE),h.ZERO=new h(e.ZERO,e.ONE,e.ZERO);let x=t.nBitLength,v=Rr(h,t.endo?Math.ceil(x/2):x);return{CURVE:t,ProjectivePoint:h,normPrivateKeyToScalar:c,weierstrassEquation:i,isWithinCurveOrder:a}}function rf(r){let t=or(r);return Lt(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function Ta(r){let t=rf(r),{Fp:e,n}=t,s=e.BYTES+1,o=2*e.BYTES+1;function i(B){return q(B,n)}function a(B){return Lr(B,n)}let{ProjectivePoint:c,normPrivateKeyToScalar:f,weierstrassEquation:l,isWithinCurveOrder:u}=ef({...t,toBytes(B,N,m){let g=N.toAffine(),w=e.toBytes(g.x),C=Ft;return It("isCompressed",m),m?C(Uint8Array.from([N.hasEvenY()?2:3]),w):C(Uint8Array.from([4]),w,e.toBytes(g.y))},fromBytes(B){let N=B.length,m=B[0],g=B.subarray(1);if(N===s&&(m===2||m===3)){let w=Pt(g);if(!nr(w,st,e.ORDER))throw new Error("Point is not on curve");let C=l(w),R;try{R=e.sqrt(C)}catch(P){let O=P instanceof Error?": "+P.message:"";throw new Error("Point is not on curve"+O)}let _=(R&st)===st;return(m&1)===1!==_&&(R=e.neg(R)),{x:w,y:R}}else if(N===o&&m===4){let w=e.fromBytes(g.subarray(0,e.BYTES)),C=e.fromBytes(g.subarray(e.BYTES,2*e.BYTES));return{x:w,y:C}}else throw new Error(`Point of length ${N} was invalid. Expected ${s} compressed bytes or ${o} uncompressed bytes`)}}),h=B=>Mt(oe(B,t.nByteLength));function x(B){let N=n>>st;return B>N}function v(B){return x(B)?i(-B):B}let b=(B,N,m)=>Pt(B.slice(N,m));class d{constructor(N,m,g){this.r=N,this.s=m,this.recovery=g,this.assertValidity()}static fromCompact(N){let m=t.nByteLength;return N=W("compactSignature",N,m*2),new d(b(N,0,m),b(N,m,2*m))}static fromDER(N){let{r:m,s:g}=Wt.toSig(W("DER",N));return new d(m,g)}assertValidity(){bt("r",this.r,st,n),bt("s",this.s,st,n)}addRecoveryBit(N){return new d(this.r,this.s,N)}recoverPublicKey(N){let{r:m,s:g,recovery:w}=this,C=T(W("msgHash",N));if(w==null||![0,1,2,3].includes(w))throw new Error("recovery id invalid");let R=w===2||w===3?m+t.n:m;if(R>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let _=w&1?"03":"02",D=c.fromHex(_+h(R)),P=a(R),O=i(-C*P),$=i(g*P),z=c.BASE.multiplyAndAddUnsafe(D,O,$);if(!z)throw new Error("point at infinify");return z.assertValidity(),z}hasHighS(){return x(this.s)}normalizeS(){return this.hasHighS()?new d(this.r,i(-this.s),this.recovery):this}toDERRawBytes(){return me(this.toDERHex())}toDERHex(){return Wt.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return me(this.toCompactHex())}toCompactHex(){return h(this.r)+h(this.s)}}let y={isValidPrivateKey(B){try{return f(B),!0}catch{return!1}},normPrivateKeyToScalar:f,randomPrivateKey:()=>{let B=Bs(t.n);return ai(t.randomBytes(B),t.n)},precompute(B=8,N=c.BASE){return N._setWindowSize(B),N.multiply(BigInt(3)),N}};function E(B,N=!0){return c.fromPrivateKey(B).toRawBytes(N)}function p(B){let N=ne(B),m=typeof B=="string",g=(N||m)&&B.length;return N?g===s||g===o:m?g===2*s||g===2*o:B instanceof c}function S(B,N,m=!0){if(p(B))throw new Error("first arg must be private key");if(!p(N))throw new Error("second arg must be public key");return c.fromHex(N).multiply(f(B)).toRawBytes(m)}let L=t.bits2int||function(B){let N=Pt(B),m=B.length*8-t.nBitLength;return m>0?N>>BigInt(m):N},T=t.bits2int_modN||function(B){return i(L(B))},k=sr(t.nBitLength);function I(B){return bt(`num < 2^${t.nBitLength}`,B,Jt,k),oe(B,t.nByteLength)}function U(B,N,m=J){if(["recovered","canonical"].some(rt=>rt in m))throw new Error("sign() legacy options not supported");let{hash:g,randomBytes:w}=t,{lowS:C,prehash:R,extraEntropy:_}=m;C==null&&(C=!0),B=W("msgHash",B),Ca(m),R&&(B=W("prehashed msgHash",g(B)));let D=T(B),P=f(N),O=[I(P),I(D)];if(_!=null&&_!==!1){let rt=_===!0?w(e.BYTES):_;O.push(W("extraEntropy",rt))}let $=Ft(...O),z=D;function et(rt){let ot=L(rt);if(!u(ot))return;let ft=a(ot),X=c.BASE.multiply(ot).toAffine(),pt=i(X.x);if(pt===Jt)return;let Ht=i(ft*i(z+pt*P));if(Ht===Jt)return;let We=(X.x===pt?0:2)|Number(X.y&st),Je=Ht;return C&&x(Ht)&&(Je=v(Ht),We^=1),new d(pt,Je,We)}return{seed:$,k2sig:et}}let J={lowS:t.lowS,prehash:!1},F={lowS:t.lowS,prehash:!1};function H(B,N,m=J){let{seed:g,k2sig:w}=U(B,N,m),C=t;return ys(C.hash.outputLen,C.nByteLength,C.hmac)(g,w)}c.BASE._setWindowSize(8);function Y(B,N,m,g=F){let w=B;if(N=W("msgHash",N),m=W("publicKey",m),"strict"in g)throw new Error("options.strict was renamed to lowS");Ca(g);let{lowS:C,prehash:R}=g,_,D;try{if(typeof w=="string"||ne(w))try{_=d.fromDER(w)}catch(X){if(!(X instanceof Wt.Err))throw X;_=d.fromCompact(w)}else if(typeof w=="object"&&typeof w.r=="bigint"&&typeof w.s=="bigint"){let{r:X,s:pt}=w;_=new d(X,pt)}else throw new Error("PARSE");D=c.fromHex(m)}catch(X){if(X.message==="PARSE")throw new Error("signature must be Signature instance, Uint8Array or hex string");return!1}if(C&&_.hasHighS())return!1;R&&(N=t.hash(N));let{r:P,s:O}=_,$=T(N),z=a(O),et=i($*z),rt=i(P*z),ot=c.BASE.multiplyAndAddUnsafe(D,et,rt)?.toAffine();return ot?i(ot.x)===P:!1}return{CURVE:t,getPublicKey:E,getSharedSecret:S,sign:H,verify:Y,ProjectivePoint:c,Signature:d,utils:y}}function nf(r){return{hash:r,hmac:(t,...e)=>po(r,t,us(...e)),randomBytes:Nr}}function La(r,t){let e=n=>Ta({...r,...nf(n)});return Object.freeze({...e(t),create:e})}var Va=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),Ra=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),sf=BigInt(1),mo=BigInt(2),_a=(r,t)=>(r+t/mo)/t;function of(r){let t=Va,e=BigInt(3),n=BigInt(6),s=BigInt(11),o=BigInt(22),i=BigInt(23),a=BigInt(44),c=BigInt(88),f=r*r*r%t,l=f*f*r%t,u=j(l,e,t)*l%t,h=j(u,e,t)*l%t,x=j(h,mo,t)*f%t,v=j(x,s,t)*x%t,b=j(v,o,t)*v%t,d=j(b,a,t)*b%t,y=j(d,c,t)*d%t,E=j(y,a,t)*b%t,p=j(E,e,t)*l%t,S=j(p,i,t)*v%t,L=j(S,n,t)*f%t,T=j(L,mo,t);if(!bo.eql(bo.sqr(T),r))throw new Error("Cannot find square root");return T}var bo=ie(Va,void 0,void 0,{sqrt:of}),ke=La({a:BigInt(0),b:BigInt(7),Fp:bo,n:Ra,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=Ra,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-sf*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),s=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),o=e,i=BigInt("0x100000000000000000000000000000000"),a=_a(o*r,t),c=_a(-n*r,t),f=q(r-a*e-c*s,t),l=q(-a*n-c*o,t),u=f>i,h=l>i;if(u&&(f=t-f),h&&(l=t-l),f>i||l>i)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:u,k1:f,k2neg:h,k2:l}}}},Fe),Y0=BigInt(0);var X0=ke.ProjectivePoint;function Dn(r,t){t==null&&(t=r.reduce((s,o)=>s+o.length,0));let e=wt(t),n=0;for(let s of r)e.set(s,n),n+=s.length;return e}function Ha(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function Da(r,t,e){let n=Pr.digest(e instanceof Uint8Array?e:e.subarray());if(Ha(n))return n.then(({digest:s})=>ke.verify(t,s,r)).catch(s=>{throw new yr(String(s))});try{return ke.verify(t,n.digest,r)}catch(s){throw new yr(String(s))}}var On=class{type="secp256k1";raw;_key;constructor(t){this._key=Ma(t),this.raw=Oa(this._key)}toMultihash(){return te.digest(Or(this))}toCID(){return Bt.createV1(114,this.toMultihash())}toString(){return Q.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:mt(this.raw,t.raw)}verify(t,e){return Da(this._key,e,t)}};function Pa(r){return new On(r)}function Oa(r){return ke.ProjectivePoint.fromHex(r).toRawBytes(!0)}function Ma(r){try{return ke.ProjectivePoint.fromHex(r),r}catch(t){throw new Ie(String(t))}}function Fa(r){return r.byteLength===32?pi(r):r.byteLength===33?Pa(r):go(r)}function Or(r){return ce.encode({Type:xt[r.type],Data:r.raw})}var Ka=Symbol.for("nodejs.util.inspect.custom"),af=114,vr=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()})`}[Xn]=!0;toString(){return this.string==null&&(this.string=Q.encode(this.multihash.bytes).slice(1)),this.string}toMultihash(){return this.multihash}toCID(){return Bt.createV1(af,this.multihash)}toJSON(){return this.toString()}equals(t){if(t==null)return!1;if(t instanceof Uint8Array)return mt(this.multihash.bytes,t);if(typeof t=="string")return this.toString()===t;if(t?.toMultihash()?.bytes!=null)return mt(this.multihash.bytes,t.toMultihash().bytes);throw new Error("not valid Id")}[Ka](){return`PeerId(${this.toString()})`}},Mn=class extends vr{type="RSA";publicKey;constructor(t){super({...t,type:"RSA"}),this.publicKey=t.publicKey}},Pn=class extends vr{type="Ed25519";publicKey;constructor(t){super({...t,type:"Ed25519"}),this.publicKey=t.publicKey}},Fn=class extends vr{type="secp256k1";publicKey;constructor(t){super({...t,type:"secp256k1"}),this.publicKey=t.publicKey}},cf=2336,yo=class{type="url";multihash;publicKey;url;constructor(t){this.url=t.toString(),this.multihash=te.digest(nt(this.url))}[Ka](){return`PeerId(${this.url})`}[Xn]=!0;toString(){return this.toCID().toString()}toMultihash(){return this.multihash}toCID(){return Bt.createV1(cf,this.toMultihash())}toJSON(){return this.toString()}equals(t){return t==null?!1:(t instanceof Uint8Array&&(t=br(t)),t.toString()===this.toString())}};function $a(r){if(r.type==="Ed25519")return new Pn({multihash:r.toCID().multihash,publicKey:r});if(r.type==="secp256k1")return new Fn({multihash:r.toCID().multihash,publicKey:r});if(r.type==="RSA")return new Mn({multihash:r.toCID().multihash,publicKey:r});throw new Ar}function Ze(){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 qa(r,t,e){if(t==null)return r;if(t.aborted)return Promise.reject(new Kn(e?.errorMessage,e?.errorCode,e?.errorName));let n,s=new Kn(e?.errorMessage,e?.errorCode,e?.errorName);try{return await Promise.race([r,new Promise((o,i)=>{n=()=>{i(s)},t.addEventListener("abort",n)})])}finally{n!=null&&t.removeEventListener("abort",n)}}var wo=class{readNext;haveNext;ended;nextResult;constructor(){this.ended=!1,this.readNext=Ze(),this.haveNext=Ze()}[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=Ze(),t}async throw(t){return this.ended=!0,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 await this._push(void 0),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 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=Ze(),await qa(this.readNext.promise,e?.signal,e)}};function za(){return new wo}var ja=Symbol.for("@achingbrain/uint8arraylist");function Ga(r,t){if(t==null||t<0)throw new RangeError("index is out of bounds");let e=0;for(let n of r){let s=e+n.byteLength;if(t<s)return{buf:n,index:t-e};e=s}throw new RangeError("index is out of bounds")}function $n(r){return!!r?.[ja]}var Yt=class r{bufs;length;[ja]=!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($n(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($n(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=Ga(this.bufs,t);return e.buf[e.index]}set(t,e){let n=Ga(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($n(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:s}=this._subList(t,e);return Dn(n,s)}subarray(t,e){let{bufs:n,length:s}=this._subList(t,e);return n.length===1?n[0]:Dn(n,s)}sublist(t,e){let{bufs:n,length:s}=this._subList(t,e),o=new r;return o.length=s,o.bufs=[...n],o}_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=[],s=0;for(let o=0;o<this.bufs.length;o++){let i=this.bufs[o],a=s,c=a+i.byteLength;if(s=c,t>=c)continue;let f=t>=a&&t<c,l=e>a&&e<=c;if(f&&l){if(t===a&&e===c){n.push(i);break}let u=t-a;n.push(i.subarray(u,u+(e-t)));break}if(f){if(t===0){n.push(i);continue}n.push(i.subarray(t-a));continue}if(l){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(!$n(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 s=n.byteLength;if(s===0)throw new TypeError("search must be at least 1 byte long");let o=256,i=new Int32Array(o);for(let u=0;u<o;u++)i[u]=-1;for(let u=0;u<s;u++)i[n[u]]=u;let a=i,c=this.byteLength-n.byteLength,f=n.byteLength-1,l;for(let u=e;u<=c;u+=l){l=0;for(let h=f;h>=0;h--){let x=this.get(u+h);if(n[h]!==x){l=Math.max(1,h-a[x]);break}}if(l===0)return u}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=wt(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 s=Ct(2);new DataView(s.buffer,s.byteOffset,s.byteLength).setInt16(0,e,n),this.write(s,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 s=Ct(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setInt32(0,e,n),this.write(s,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 s=Ct(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigInt64(0,e,n),this.write(s,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=wt(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 s=Ct(2);new DataView(s.buffer,s.byteOffset,s.byteLength).setUint16(0,e,n),this.write(s,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 s=Ct(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setUint32(0,e,n),this.write(s,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 s=Ct(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigUint64(0,e,n),this.write(s,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 s=Ct(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setFloat32(0,e,n),this.write(s,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 s=Ct(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setFloat64(0,e,n),this.write(s,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(!mt(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((s,o)=>s+o.byteLength,0)),n.length=e,n}};var qn=class extends Error{name="UnexpectedEOFError";code="ERR_UNEXPECTED_EOF"};var xo=class extends Error{code;constructor(t,e){super(t),this.code=e}},vo=class extends xo{type;constructor(t){super(t,"ABORT_ERR"),this.type="aborted",this.name="AbortError"}};function Za(r,t){let e=za();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 s=new Yt;return{read:async(i,a)=>{a?.signal?.throwIfAborted();let c,f=new Promise((l,u)=>{c=()=>{u(new vo("Read aborted"))},a?.signal?.addEventListener("abort",c)});try{if(i==null){let{done:u,value:h}=await Promise.race([n.next(),f]);return u===!0?new Yt:h}for(;s.byteLength<i;){let{value:u,done:h}=await Promise.race([n.next(),f]);if(h===!0)throw new qn("unexpected end of input");s.append(u)}let l=s.sublist(0,i);return s.consume(i),l}finally{c!=null&&a?.signal?.removeEventListener("abort",c)}},write:async(i,a)=>{a?.signal?.throwIfAborted(),i instanceof Uint8Array?await e.push(i,a):await e.push(i.subarray(),a)},unwrap:()=>{if(s.byteLength>0){let i=r.source;r.source=async function*(){t?.yieldBytes===!1?yield s:yield*s,yield*i}()}return r}}}var zn=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},Gn=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},jn=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"};function Wa(r,t={}){let e=Za(r,t);t.maxDataLength!=null&&t.maxLengthLength==null&&(t.maxLengthLength=Kt(t.maxDataLength));let n=t?.lengthDecoder??bi,s=t?.lengthEncoder??mi;return{read:async i=>{let a=-1,c=new Yt;for(;;){c.append(await e.read(1,i));try{a=n(c)}catch(f){if(f instanceof RangeError)continue;throw f}if(a<0)throw new zn("Invalid message length");if(t?.maxLengthLength!=null&&c.byteLength>t.maxLengthLength)throw new jn("message length length too long");if(a>-1)break}if(t?.maxDataLength!=null&&a>t.maxDataLength)throw new Gn("message length too long");return e.read(a,i)},write:async(i,a)=>{await e.write(new Yt(s(i.byteLength),i),a)},writeV:async(i,a)=>{let c=new Yt(...i.flatMap(f=>[s(f.byteLength),f]));await e.write(c,a)},unwrap:()=>e.unwrap()}}function Ja(r,t){let e=Wa(r,t),n={read:async(s,o)=>{let i=await e.read(o);return s.decode(i)},write:async(s,o,i)=>{await e.write(o.encode(s),i)},writeV:async(s,o,i)=>{await e.writeV(s.map(a=>o.encode(a)),i)},pb:s=>({read:async o=>n.read(s,o),write:async(o,i)=>n.write(o,s,i),writeV:async(o,i)=>n.writeV(o,s,i),unwrap:()=>n}),unwrap:()=>e.unwrap()};return n}var Zn;(function(r){let t;r.codec=()=>(t==null&&(t=Ae((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.id!=null&&(n.uint32(10),n.bytes(e.id)),e.pubkey!=null&&(n.uint32(18),Jn.codec().encode(e.pubkey,n)),s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let o={},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let a=e.uint32();switch(a>>>3){case 1:{o.id=e.bytes();break}case 2:{o.pubkey=Jn.codec().decode(e,e.uint32(),{limits:s.limits?.pubkey});break}default:{e.skipType(a&7);break}}}return o})),t),r.encode=e=>Ee(e,r.codec()),r.decode=(e,n)=>ve(e,r.codec(),n)})(Zn||(Zn={}));var Xt;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.secp256k1="secp256k1",r.ECDSA="ECDSA"})(Xt||(Xt={}));var Wn;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1",r[r.ECDSA=3]="ECDSA"})(Wn||(Wn={}));(function(r){r.codec=()=>cr(Wn)})(Xt||(Xt={}));var Jn;(function(r){let t;r.codec=()=>(t==null&&(t=Ae((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&Wn[e.Type]!==0&&(n.uint32(8),Xt.codec().encode(e.Type,n)),e.Data!=null&&e.Data.byteLength>0&&(n.uint32(18),n.bytes(e.Data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let o={Type:Xt.RSA,Data:Ct(0)},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let a=e.uint32();switch(a>>>3){case 1:{o.Type=Xt.codec().decode(e);break}case 2:{o.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return o})),t),r.encode=e=>Ee(e,r.codec()),r.decode=(e,n)=>ve(e,r.codec(),n)})(Jn||(Jn={}));var lf="/plaintext/2.0.0",Bo=class{protocol=lf;privateKey;log;constructor(t){this.privateKey=t.privateKey,this.log=t.logger.forComponent("libp2p:plaintext")}[Symbol.toStringTag]="@libp2p/plaintext";[To]=["@libp2p/connection-encryption"];async secureInbound(t,e){return this._encrypt(t,e)}async secureOutbound(t,e){return this._encrypt(t,e)}async _encrypt(t,e){let n=Ja(t).pb(Zn);this.log("write pubkey exchange to peer %p",e?.remotePeer);let s=this.privateKey.publicKey,[,o]=await Promise.all([n.write({id:s.toMultihash().bytes,pubkey:{Type:Xt[s.type],Data:s.raw}},e),n.read(e)]),i;try{if(o.pubkey==null)throw new Ne("Public key missing");if(o.pubkey.Data.byteLength===0)throw new Ne("Public key data too short");if(o.id==null)throw new Ne("Remote id missing");let a=Fa(o.pubkey.Data);if(i=$a(a),!mt(i.toMultihash().bytes,o.id))throw new Ye("Public key did not match id")}catch(a){throw this.log.error(a),new Ye("Invalid public key - "+a.message)}if(e?.remotePeer!=null&&!i.equals(e?.remotePeer))throw new Er;return this.log("plaintext key exchange completed successfully with peer %p",i),{conn:n.unwrap().unwrap(),remotePeer:i}}};function uf(){return r=>new Bo(r)}return hc(ff);})();
7
7
  /*! Bundled license information:
8
8
 
9
9
  pvtsutils/build/index.js:
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@libp2p/plaintext",
3
- "version": "2.0.9",
3
+ "version": "2.0.10",
4
4
  "description": "An insecure connection encrypter",
5
5
  "license": "Apache-2.0 OR MIT",
6
6
  "homepage": "https://github.com/libp2p/js-libp2p/tree/main/packages/connection-encrypter-plaintext#readme",
@@ -52,9 +52,9 @@
52
52
  "doc-check": "aegir doc-check"
53
53
  },
54
54
  "dependencies": {
55
- "@libp2p/crypto": "^5.0.5",
56
- "@libp2p/interface": "^2.1.3",
57
- "@libp2p/peer-id": "^5.0.6",
55
+ "@libp2p/crypto": "^5.0.6",
56
+ "@libp2p/interface": "^2.2.0",
57
+ "@libp2p/peer-id": "^5.0.7",
58
58
  "it-protobuf-stream": "^1.1.3",
59
59
  "it-stream-types": "^2.0.1",
60
60
  "protons-runtime": "^5.4.0",
@@ -62,9 +62,9 @@
62
62
  "uint8arrays": "^5.1.0"
63
63
  },
64
64
  "devDependencies": {
65
- "@libp2p/crypto": "^5.0.5",
66
- "@libp2p/interface-compliance-tests": "^6.1.7",
67
- "@libp2p/logger": "^5.1.2",
65
+ "@libp2p/crypto": "^5.0.6",
66
+ "@libp2p/interface-compliance-tests": "^6.1.8",
67
+ "@libp2p/logger": "^5.1.3",
68
68
  "@multiformats/multiaddr": "^12.2.3",
69
69
  "aegir": "^44.0.1",
70
70
  "protons": "^7.5.0",