@libp2p/crypto 4.1.9-3c8dd5bbf → 4.1.9-737b3ea5b

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,10 +1,10 @@
1
1
  (function (root, factory) {(typeof module === 'object' && module.exports) ? module.exports = factory() : root.Libp2PCrypto = factory()}(typeof self !== 'undefined' ? self : this, function () {
2
- "use strict";var Libp2PCrypto=(()=>{var oc=Object.create;var Tr=Object.defineProperty;var ic=Object.getOwnPropertyDescriptor;var ac=Object.getOwnPropertyNames;var cc=Object.getPrototypeOf,lc=Object.prototype.hasOwnProperty;var uc=(r,e)=>()=>(e||r((e={exports:{}}).exports,e),e.exports),Q=(r,e)=>{for(var t in e)Tr(r,t,{get:e[t],enumerable:!0})},Io=(r,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of ac(e))!lc.call(r,s)&&s!==t&&Tr(r,s,{get:()=>e[s],enumerable:!(n=ic(e,s))||n.enumerable});return r};var fc=(r,e,t)=>(t=r!=null?oc(cc(r)):{},Io(e||!r||!r.__esModule?Tr(t,"default",{value:r,enumerable:!0}):t,r)),hc=r=>Io(Tr({},"__esModule",{value:!0}),r);var qi=uc(sr=>{"use strict";var qu="[object ArrayBuffer]",We=class r{static isArrayBuffer(e){return Object.prototype.toString.call(e)===qu}static toArrayBuffer(e){return this.isArrayBuffer(e)?e:e.byteLength===e.buffer.byteLength||e.byteOffset===0&&e.byteLength===e.buffer.byteLength?e.buffer:this.toUint8Array(e.buffer).slice(e.byteOffset,e.byteOffset+e.byteLength).buffer}static toUint8Array(e){return this.toView(e,Uint8Array)}static toView(e,t){if(e.constructor===t)return e;if(this.isArrayBuffer(e))return new t(e);if(this.isArrayBufferView(e))return new t(e.buffer,e.byteOffset,e.byteLength);throw new TypeError("The provided value is not of type '(ArrayBuffer or ArrayBufferView)'")}static isBufferSource(e){return this.isArrayBufferView(e)||this.isArrayBuffer(e)}static isArrayBufferView(e){return ArrayBuffer.isView(e)||e&&this.isArrayBuffer(e.buffer)}static isEqual(e,t){let n=r.toUint8Array(e),s=r.toUint8Array(t);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(...e){let t;Array.isArray(e[0])&&!(e[1]instanceof Function)||Array.isArray(e[0])&&e[1]instanceof Function?t=e[0]:e[e.length-1]instanceof Function?t=e.slice(0,e.length-1):t=e;let n=0;for(let i of t)n+=i.byteLength;let s=new Uint8Array(n),o=0;for(let i of t){let a=this.toUint8Array(i);s.set(a,o),o+=a.length}return e[e.length-1]instanceof Function?this.toView(s,e[e.length-1]):s.buffer}},Qs="string",ju=/^[0-9a-f]+$/i,zu=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,Gu=/^[a-zA-Z0-9-_]+$/,nn=class{static fromString(e){let t=unescape(encodeURIComponent(e)),n=new Uint8Array(t.length);for(let s=0;s<t.length;s++)n[s]=t.charCodeAt(s);return n.buffer}static toString(e){let t=We.toUint8Array(e),n="";for(let o=0;o<t.length;o++)n+=String.fromCharCode(t[o]);return decodeURIComponent(escape(n))}},Ee=class{static toString(e,t=!1){let n=We.toArrayBuffer(e),s=new DataView(n),o="";for(let i=0;i<n.byteLength;i+=2){let a=s.getUint16(i,t);o+=String.fromCharCode(a)}return o}static fromString(e,t=!1){let n=new ArrayBuffer(e.length*2),s=new DataView(n);for(let o=0;o<e.length;o++)s.setUint16(o*2,e.charCodeAt(o),t);return n}},sn=class r{static isHex(e){return typeof e===Qs&&ju.test(e)}static isBase64(e){return typeof e===Qs&&zu.test(e)}static isBase64Url(e){return typeof e===Qs&&Gu.test(e)}static ToString(e,t="utf8"){let n=We.toUint8Array(e);switch(t.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 Ee.toString(n,!0);case"utf16":case"utf16be":return Ee.toString(n);default:throw new Error(`Unknown type of encoding '${t}'`)}}static FromString(e,t="utf8"){if(!e)return new ArrayBuffer(0);switch(t.toLowerCase()){case"utf8":return this.FromUtf8String(e);case"binary":return this.FromBinary(e);case"hex":return this.FromHex(e);case"base64":return this.FromBase64(e);case"base64url":return this.FromBase64Url(e);case"utf16le":return Ee.fromString(e,!0);case"utf16":case"utf16be":return Ee.fromString(e);default:throw new Error(`Unknown type of encoding '${t}'`)}}static ToBase64(e){let t=We.toUint8Array(e);if(typeof btoa<"u"){let n=this.ToString(t,"binary");return btoa(n)}else return Buffer.from(t).toString("base64")}static FromBase64(e){let t=this.formatString(e);if(!t)return new ArrayBuffer(0);if(!r.isBase64(t))throw new TypeError("Argument 'base64Text' is not Base64 encoded");return typeof atob<"u"?this.FromBinary(atob(t)):new Uint8Array(Buffer.from(t,"base64")).buffer}static FromBase64Url(e){let t=this.formatString(e);if(!t)return new ArrayBuffer(0);if(!r.isBase64Url(t))throw new TypeError("Argument 'base64url' is not Base64Url encoded");return this.FromBase64(this.Base64Padding(t.replace(/\-/g,"+").replace(/\_/g,"/")))}static ToBase64Url(e){return this.ToBase64(e).replace(/\+/g,"-").replace(/\//g,"_").replace(/\=/g,"")}static FromUtf8String(e,t=r.DEFAULT_UTF8_ENCODING){switch(t){case"ascii":return this.FromBinary(e);case"utf8":return nn.fromString(e);case"utf16":case"utf16be":return Ee.fromString(e);case"utf16le":case"usc2":return Ee.fromString(e,!0);default:throw new Error(`Unknown type of encoding '${t}'`)}}static ToUtf8String(e,t=r.DEFAULT_UTF8_ENCODING){switch(t){case"ascii":return this.ToBinary(e);case"utf8":return nn.toString(e);case"utf16":case"utf16be":return Ee.toString(e);case"utf16le":case"usc2":return Ee.toString(e,!0);default:throw new Error(`Unknown type of encoding '${t}'`)}}static FromBinary(e){let t=e.length,n=new Uint8Array(t);for(let s=0;s<t;s++)n[s]=e.charCodeAt(s);return n.buffer}static ToBinary(e){let t=We.toUint8Array(e),n="";for(let s=0;s<t.length;s++)n+=String.fromCharCode(t[s]);return n}static ToHex(e){let t=We.toUint8Array(e),n="",s=t.length;for(let o=0;o<s;o++){let i=t[o];i<16&&(n+="0"),n+=i.toString(16)}return n}static FromHex(e){let t=this.formatString(e);if(!t)return new ArrayBuffer(0);if(!r.isHex(t))throw new TypeError("Argument 'hexString' is not HEX encoded");t.length%2&&(t=`0${t}`);let n=new Uint8Array(t.length/2);for(let s=0;s<t.length;s=s+2){let o=t.slice(s,s+2);n[s/2]=parseInt(o,16)}return n.buffer}static ToUtf16String(e,t=!1){return Ee.toString(e,t)}static FromUtf16String(e,t=!1){return Ee.fromString(e,t)}static Base64Padding(e){let t=4-e.length%4;if(t<4)for(let n=0;n<t;n++)e+="=";return e}static formatString(e){return e?.replace(/[\n\r\t ]/g,"")||""}};sn.DEFAULT_UTF8_ENCODING="utf8";function Zu(r,...e){let t=arguments[0];for(let n=1;n<arguments.length;n++){let s=arguments[n];for(let o in s)t[o]=s[o]}return t}function Yu(...r){let e=r.map(s=>s.byteLength).reduce((s,o)=>s+o),t=new Uint8Array(e),n=0;return r.map(s=>new Uint8Array(s)).forEach(s=>{for(let o of s)t[n++]=o}),t.buffer}function Wu(r,e){if(!(r&&e)||r.byteLength!==e.byteLength)return!1;let t=new Uint8Array(r),n=new Uint8Array(e);for(let s=0;s<r.byteLength;s++)if(t[s]!==n[s])return!1;return!0}sr.BufferSourceConverter=We;sr.Convert=sn;sr.assign=Zu;sr.combine=Yu;sr.isEqual=Wu});var Vf={};Q(Vf,{hmac:()=>_r,keys:()=>mo,pbkdf2:()=>wo,randomBytes:()=>Ye});var _r={};Q(_r,{create:()=>Yn});var j={get(r=globalThis){let e=r.crypto;if(e?.subtle==null)throw Object.assign(new Error("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"),{code:"ERR_MISSING_WEB_CRYPTO"});return e}};var No={SHA1:20,SHA256:32,SHA512:64};var dc={SHA1:"SHA-1",SHA256:"SHA-256",SHA512:"SHA-512"},gc=async(r,e)=>{let t=await j.get().subtle.sign({name:"HMAC"},r,e);return new Uint8Array(t,0,t.byteLength)};async function Yn(r,e){let t=dc[r],n=await j.get().subtle.importKey("raw",e,{name:"HMAC",hash:{name:t}},!1,["sign"]);return{async digest(s){return gc(n,s)},length:No[r]}}var mo={};Q(mo,{Ed25519PrivateKey:()=>Ze,Ed25519PublicKey:()=>Ut,MAX_RSA_KEY_SIZE:()=>Ht,RsaPrivateKey:()=>mt,RsaPublicKey:()=>Vt,Secp256k1PrivateKey:()=>Pt,Secp256k1PublicKey:()=>Ot,generateEphemeralKeyPair:()=>Di,generateKeyPair:()=>Rf,generateKeyPairFromSeed:()=>Cf,importKey:()=>Lf,keyStretcher:()=>Mi,keysPBM:()=>rr,marshalPrivateKey:()=>Uf,marshalPublicKey:()=>_f,supportedKeys:()=>rt,unmarshalPrivateKey:()=>Ya,unmarshalPublicKey:()=>Tf});var _=class extends Error{code;props;constructor(e,t,n){super(e),this.code=t,this.name=n?.name??"CodeError",this.props=n??{}}};var Ws={};Q(Ws,{Ed25519PrivateKey:()=>Ze,Ed25519PublicKey:()=>Ut,generateKeyPair:()=>Mu,generateKeyPairFromSeed:()=>Ys,unmarshalEd25519PrivateKey:()=>Ou,unmarshalEd25519PublicKey:()=>Pu});var es={};Q(es,{base58btc:()=>Be,base58flickr:()=>xc});var Ff=new Uint8Array(0);function Ro(r,e){if(r===e)return!0;if(r.byteLength!==e.byteLength)return!1;for(let t=0;t<r.byteLength;t++)if(r[t]!==e[t])return!1;return!0}function Ke(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 Co(r){return new TextEncoder().encode(r)}function To(r){return new TextDecoder().decode(r)}function pc(r,e){if(r.length>=255)throw new TypeError("Alphabet too long");for(var t=new Uint8Array(256),n=0;n<t.length;n++)t[n]=255;for(var s=0;s<r.length;s++){var o=r.charAt(s),i=o.charCodeAt(0);if(t[i]!==255)throw new TypeError(o+" is ambiguous");t[i]=s}var a=r.length,c=r.charAt(0),f=Math.log(a)/Math.log(256),u=Math.log(256)/Math.log(a);function l(g){if(g instanceof Uint8Array||(ArrayBuffer.isView(g)?g=new Uint8Array(g.buffer,g.byteOffset,g.byteLength):Array.isArray(g)&&(g=Uint8Array.from(g))),!(g instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(g.length===0)return"";for(var h=0,m=0,w=0,b=g.length;w!==b&&g[w]===0;)w++,h++;for(var x=(b-w)*u+1>>>0,C=new Uint8Array(x);w!==b;){for(var S=g[w],k=0,R=x-1;(S!==0||k<m)&&R!==-1;R--,k++)S+=256*C[R]>>>0,C[R]=S%a>>>0,S=S/a>>>0;if(S!==0)throw new Error("Non-zero carry");m=k,w++}for(var I=x-m;I!==x&&C[I]===0;)I++;for(var F=c.repeat(h);I<x;++I)F+=r.charAt(C[I]);return F}function p(g){if(typeof g!="string")throw new TypeError("Expected String");if(g.length===0)return new Uint8Array;var h=0;if(g[h]!==" "){for(var m=0,w=0;g[h]===c;)m++,h++;for(var b=(g.length-h)*f+1>>>0,x=new Uint8Array(b);g[h];){var C=t[g.charCodeAt(h)];if(C===255)return;for(var S=0,k=b-1;(C!==0||S<w)&&k!==-1;k--,S++)C+=a*x[k]>>>0,x[k]=C%256>>>0,C=C/256>>>0;if(C!==0)throw new Error("Non-zero carry");w=S,h++}if(g[h]!==" "){for(var R=b-w;R!==b&&x[R]===0;)R++;for(var I=new Uint8Array(m+(b-R)),F=m;R!==b;)I[F++]=x[R++];return I}}}function B(g){var h=p(g);if(h)return h;throw new Error(`Non-${e} character`)}return{encode:l,decodeUnsafe:p,decode:B}}var yc=pc,mc=yc,Uo=mc;var Wn=class{name;prefix;baseEncode;constructor(e,t,n){this.name=e,this.prefix=t,this.baseEncode=n}encode(e){if(e instanceof Uint8Array)return`${this.prefix}${this.baseEncode(e)}`;throw Error("Unknown type, must be binary type")}},Jn=class{name;prefix;baseDecode;prefixCodePoint;constructor(e,t,n){if(this.name=e,this.prefix=t,t.codePointAt(0)===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=t.codePointAt(0),this.baseDecode=n}decode(e){if(typeof e=="string"){if(e.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(e)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(e.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(e){return Lo(this,e)}},Xn=class{decoders;constructor(e){this.decoders=e}or(e){return Lo(this,e)}decode(e){let t=e[0],n=this.decoders[t];if(n!=null)return n.decode(e);throw RangeError(`Unable to decode multibase string ${JSON.stringify(e)}, only inputs prefixed with ${Object.keys(this.decoders)} are supported`)}};function Lo(r,e){return new Xn({...r.decoders??{[r.prefix]:r},...e.decoders??{[e.prefix]:e}})}var Qn=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(e,t,n,s){this.name=e,this.prefix=t,this.baseEncode=n,this.baseDecode=s,this.encoder=new Wn(e,t,n),this.decoder=new Jn(e,t,s)}encode(e){return this.encoder.encode(e)}decode(e){return this.decoder.decode(e)}};function Mt({name:r,prefix:e,encode:t,decode:n}){return new Qn(r,e,t,n)}function nt({name:r,prefix:e,alphabet:t}){let{encode:n,decode:s}=Uo(t,r);return Mt({prefix:e,name:r,encode:n,decode:o=>Ke(s(o))})}function bc(r,e,t,n){let s={};for(let u=0;u<e.length;++u)s[e[u]]=u;let o=r.length;for(;r[o-1]==="=";)--o;let i=new Uint8Array(o*t/8|0),a=0,c=0,f=0;for(let u=0;u<o;++u){let l=s[r[u]];if(l===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<t|l,a+=t,a>=8&&(a-=8,i[f++]=255&c>>a)}if(a>=t||255&c<<8-a)throw new SyntaxError("Unexpected end of data");return i}function wc(r,e,t){let n=e[e.length-1]==="=",s=(1<<t)-1,o="",i=0,a=0;for(let c=0;c<r.length;++c)for(a=a<<8|r[c],i+=8;i>t;)i-=t,o+=e[s&a>>i];if(i!==0&&(o+=e[s&a<<t-i]),n)for(;o.length*t&7;)o+="=";return o}function J({name:r,prefix:e,bitsPerChar:t,alphabet:n}){return Mt({prefix:e,name:r,encode(s){return wc(s,n,t)},decode(s){return bc(s,n,t,r)}})}var Be=nt({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),xc=nt({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var ns={};Q(ns,{identity:()=>rs});var Bc=Do,Vo=128,vc=127,Ec=~vc,Ac=Math.pow(2,31);function Do(r,e,t){e=e||[],t=t||0;for(var n=t;r>=Ac;)e[t++]=r&255|Vo,r/=128;for(;r&Ec;)e[t++]=r&255|Vo,r>>>=7;return e[t]=r|0,Do.bytes=t-n+1,e}var kc=ts,Sc=128,Ho=127;function ts(r,n){var t=0,n=n||0,s=0,o=n,i,a=r.length;do{if(o>=a)throw ts.bytes=0,new RangeError("Could not decode varint");i=r[o++],t+=s<28?(i&Ho)<<s:(i&Ho)*Math.pow(2,s),s+=7}while(i>=Sc);return ts.bytes=o-n,t}var Ic=Math.pow(2,7),Nc=Math.pow(2,14),Rc=Math.pow(2,21),Cc=Math.pow(2,28),Tc=Math.pow(2,35),_c=Math.pow(2,42),Uc=Math.pow(2,49),Lc=Math.pow(2,56),Vc=Math.pow(2,63),Hc=function(r){return r<Ic?1:r<Nc?2:r<Rc?3:r<Cc?4:r<Tc?5:r<_c?6:r<Uc?7:r<Lc?8:r<Vc?9:10},Dc={encode:Bc,decode:kc,encodingLength:Hc},Oc=Dc,lr=Oc;function ur(r,e=0){return[lr.decode(r,e),lr.decode.bytes]}function Kt(r,e,t=0){return lr.encode(r,e,t),e}function Ft(r){return lr.encodingLength(r)}function Et(r,e){let t=e.byteLength,n=Ft(r),s=n+Ft(t),o=new Uint8Array(s+t);return Kt(r,o,0),Kt(t,o,n),o.set(e,s),new $t(r,t,e,o)}function Oo(r){let e=Ke(r),[t,n]=ur(e),[s,o]=ur(e.subarray(n)),i=e.subarray(n+o);if(i.byteLength!==s)throw new Error("Incorrect length");return new $t(t,s,i,e)}function Po(r,e){if(r===e)return!0;{let t=e;return r.code===t.code&&r.size===t.size&&t.bytes instanceof Uint8Array&&Ro(r.bytes,t.bytes)}}var $t=class{code;size;digest;bytes;constructor(e,t,n,s){this.code=e,this.size=t,this.digest=n,this.bytes=s}};var Mo=0,Pc="identity",Ko=Ke;function Mc(r){return Et(Mo,Ko(r))}var rs={code:Mo,name:Pc,encode:Ko,digest:Mc};var is={};Q(is,{sha256:()=>we,sha512:()=>Kc});function os({name:r,code:e,encode:t}){return new ss(r,e,t)}var ss=class{name;code;encode;constructor(e,t,n){this.name=e,this.code=t,this.encode=n}digest(e){if(e instanceof Uint8Array){let t=this.encode(e);return t instanceof Uint8Array?Et(this.code,t):t.then(n=>Et(this.code,n))}else throw Error("Unknown type, must be binary type")}};function $o(r){return async e=>new Uint8Array(await crypto.subtle.digest(r,e))}var we=os({name:"sha2-256",code:18,encode:$o("SHA-256")}),Kc=os({name:"sha2-512",code:19,encode:$o("SHA-512")});function Se(r,e){if(r===e)return!0;if(r.byteLength!==e.byteLength)return!1;for(let t=0;t<r.byteLength;t++)if(r[t]!==e[t])return!1;return!0}function He(r=0){return new Uint8Array(r)}function Fe(r,e){e==null&&(e=r.reduce((s,o)=>s+o.length,0));let t=He(e),n=0;for(let s of r)t.set(s,n),n+=s.length;return t}var as={};Q(as,{base10:()=>Fc});var Fc=nt({prefix:"9",name:"base10",alphabet:"0123456789"});var cs={};Q(cs,{base16:()=>$c,base16upper:()=>qc});var $c=J({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),qc=J({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var ls={};Q(ls,{base2:()=>jc});var jc=J({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var us={};Q(us,{base256emoji:()=>Wc});var qo=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}"),zc=qo.reduce((r,e,t)=>(r[t]=e,r),[]),Gc=qo.reduce((r,e,t)=>(r[e.codePointAt(0)]=t,r),[]);function Zc(r){return r.reduce((e,t)=>(e+=zc[t],e),"")}function Yc(r){let e=[];for(let t of r){let n=Gc[t.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${t}`);e.push(n)}return new Uint8Array(e)}var Wc=Mt({prefix:"\u{1F680}",name:"base256emoji",encode:Zc,decode:Yc});var fs={};Q(fs,{base32:()=>qt,base32hex:()=>el,base32hexpad:()=>rl,base32hexpadupper:()=>nl,base32hexupper:()=>tl,base32pad:()=>Xc,base32padupper:()=>Qc,base32upper:()=>Jc,base32z:()=>sl});var qt=J({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),Jc=J({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Xc=J({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),Qc=J({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),el=J({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),tl=J({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),rl=J({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),nl=J({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),sl=J({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var hs={};Q(hs,{base36:()=>ol,base36upper:()=>il});var ol=nt({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),il=nt({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var ds={};Q(ds,{base64:()=>At,base64pad:()=>al,base64url:()=>cl,base64urlpad:()=>ll});var At=J({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),al=J({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),cl=J({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),ll=J({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var gs={};Q(gs,{base8:()=>ul});var ul=J({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var ps={};Q(ps,{identity:()=>fl});var fl=Mt({prefix:"\0",name:"identity",encode:r=>To(r),decode:r=>Co(r)});var yh=new TextEncoder,mh=new TextDecoder;function jo(r,e){let{bytes:t,version:n}=r;switch(n){case 0:return pl(t,ys(r),e??Be.encoder);default:return yl(t,ys(r),e??qt.encoder)}}var zo=new WeakMap;function ys(r){let e=zo.get(r);if(e==null){let t=new Map;return zo.set(r,t),t}return e}var Lr=class r{code;version;multihash;bytes;"/";constructor(e,t,n,s){this.code=t,this.version=e,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:e,multihash:t}=this;if(e!==hr)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(t.code!==ml)throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");return r.createV0(t)}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:e,digest:t}=this.multihash,n=Et(e,t);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(e){return r.equals(this,e)}static equals(e,t){let n=t;return n!=null&&e.code===n.code&&e.version===n.version&&Po(e.multihash,n.multihash)}toString(e){return jo(this,e)}toJSON(){return{"/":jo(this)}}link(){return this}[Symbol.toStringTag]="CID";[Symbol.for("nodejs.util.inspect.custom")](){return`CID(${this.toString()})`}static asCID(e){if(e==null)return null;let t=e;if(t instanceof r)return t;if(t["/"]!=null&&t["/"]===t.bytes||t.asCID===t){let{version:n,code:s,multihash:o,bytes:i}=t;return new r(n,s,o,i??Go(n,s,o.bytes))}else if(t[bl]===!0){let{version:n,multihash:s,code:o}=t,i=Oo(s);return r.create(n,o,i)}else return null}static create(e,t,n){if(typeof t!="number")throw new Error("String codecs are no longer supported");if(!(n.bytes instanceof Uint8Array))throw new Error("Invalid digest");switch(e){case 0:{if(t!==hr)throw new Error(`Version 0 CID must use dag-pb (code: ${hr}) block encoding`);return new r(e,t,n,n.bytes)}case 1:{let s=Go(e,t,n.bytes);return new r(e,t,n,s)}default:throw new Error("Invalid version")}}static createV0(e){return r.create(0,hr,e)}static createV1(e,t){return r.create(1,e,t)}static decode(e){let[t,n]=r.decodeFirst(e);if(n.length!==0)throw new Error("Incorrect length");return t}static decodeFirst(e){let t=r.inspectBytes(e),n=t.size-t.multihashSize,s=Ke(e.subarray(n,n+t.multihashSize));if(s.byteLength!==t.multihashSize)throw new Error("Incorrect length");let o=s.subarray(t.multihashSize-t.digestSize),i=new $t(t.multihashCode,t.digestSize,o,s);return[t.version===0?r.createV0(i):r.createV1(t.codec,i),e.subarray(t.size)]}static inspectBytes(e){let t=0,n=()=>{let[l,p]=ur(e.subarray(t));return t+=p,l},s=n(),o=hr;if(s===18?(s=0,t=0):o=n(),s!==0&&s!==1)throw new RangeError(`Invalid CID version ${s}`);let i=t,a=n(),c=n(),f=t+c,u=f-i;return{version:s,codec:o,multihashCode:a,digestSize:c,multihashSize:u,size:f}}static parse(e,t){let[n,s]=gl(e,t),o=r.decode(s);if(o.version===0&&e[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return ys(o).set(n,e),o}};function gl(r,e){switch(r[0]){case"Q":{let t=e??Be;return[Be.prefix,t.decode(`${Be.prefix}${r}`)]}case Be.prefix:{let t=e??Be;return[Be.prefix,t.decode(r)]}case qt.prefix:{let t=e??qt;return[qt.prefix,t.decode(r)]}default:{if(e==null)throw Error("To parse non base32 or base58btc encoded CID multibase decoder must be provided");return[r[0],e.decode(r)]}}}function pl(r,e,t){let{prefix:n}=t;if(n!==Be.prefix)throw Error(`Cannot string encode V0 in ${t.name} encoding`);let s=e.get(n);if(s==null){let o=t.encode(r).slice(1);return e.set(n,o),o}else return s}function yl(r,e,t){let{prefix:n}=t,s=e.get(n);if(s==null){let o=t.encode(r);return e.set(n,o),o}else return s}var hr=112,ml=18;function Go(r,e,t){let n=Ft(r),s=n+Ft(e),o=new Uint8Array(s+t.byteLength);return Kt(r,o,0),Kt(e,o,n),o.set(t,s),o}var bl=Symbol.for("@ipld/js-cid/CID");var ms={...ps,...ls,...gs,...as,...cs,...fs,...hs,...es,...ds,...us},Uh={...is,...ns};function Yo(r,e,t,n){return{name:r,prefix:e,encoder:{name:r,prefix:e,encode:t},decoder:{decode:n}}}var Zo=Yo("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),bs=Yo("ascii","a",r=>{let e="a";for(let t=0;t<r.length;t++)e+=String.fromCharCode(r[t]);return e},r=>{r=r.substring(1);let e=He(r.length);for(let t=0;t<r.length;t++)e[t]=r.charCodeAt(t);return e}),wl={utf8:Zo,"utf-8":Zo,hex:ms.base16,latin1:bs,ascii:bs,binary:bs,...ms},Vr=wl;function z(r,e="utf8"){let t=Vr[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return t.decoder.decode(`${t.prefix}${r}`)}function ws(r,e){let t=z(r,"base64urlpad");if(e!=null){if(t.length>e)throw new Error("byte array longer than desired length");t=Fe([new Uint8Array(e-t.length),t])}return t}function ve(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function jt(r){if(!Number.isSafeInteger(r)||r<0)throw new Error(`positive integer expected, not ${r}`)}function xl(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function zt(r,...e){if(!xl(r))throw new Error("Uint8Array expected");if(e.length>0&&!e.includes(r.length))throw new Error(`Uint8Array expected of length ${e}, not of length=${r.length}`)}function Hr(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");jt(r.outputLen),jt(r.blockLen)}function Gt(r,e=!0){if(r.destroyed)throw new Error("Hash instance has been destroyed");if(e&&r.finished)throw new Error("Hash#digest() has already been called")}function Wo(r,e){zt(r);let t=e.outputLen;if(r.length<t)throw new Error(`digestInto() expects output buffer of length at least ${t}`)}var Dr=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;var kt=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),Ie=(r,e)=>r<<32-e|r>>>e,Or=(r,e)=>r<<e|r>>>32-e>>>0,Gh=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;var Bl=async()=>{};async function Jo(r,e,t){let n=Date.now();for(let s=0;s<r;s++){t(s);let o=Date.now()-n;o>=0&&o<e||(await Bl(),n+=o)}}function Xo(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function st(r){return typeof r=="string"&&(r=Xo(r)),zt(r),r}function xs(...r){let e=0;for(let n=0;n<r.length;n++){let s=r[n];zt(s),e+=s.length}let t=new Uint8Array(e);for(let n=0,s=0;n<r.length;n++){let o=r[n];t.set(o,s),s+=o.length}return t}var Zt=class{clone(){return this._cloneInto()}},vl={}.toString;function Qo(r,e){if(e!==void 0&&vl.call(e)!=="[object Object]")throw new Error("Options should be object or undefined");return Object.assign(r,e)}function Yt(r){let e=n=>r().update(st(n)).digest(),t=r();return e.outputLen=t.outputLen,e.blockLen=t.blockLen,e.create=()=>r(),e}function Wt(r=32){if(Dr&&typeof Dr.getRandomValues=="function")return Dr.getRandomValues(new Uint8Array(r));throw new Error("crypto.getRandomValues must be defined")}function El(r,e,t,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(e,t,n);let s=BigInt(32),o=BigInt(4294967295),i=Number(t>>s&o),a=Number(t&o),c=n?4:0,f=n?0:4;r.setUint32(e+c,i,n),r.setUint32(e+f,a,n)}var Pr=(r,e,t)=>r&e^~r&t,Mr=(r,e,t)=>r&e^r&t^e&t,ot=class extends Zt{constructor(e,t,n,s){super(),this.blockLen=e,this.outputLen=t,this.padOffset=n,this.isLE=s,this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.buffer=new Uint8Array(e),this.view=kt(this.buffer)}update(e){Gt(this);let{view:t,buffer:n,blockLen:s}=this;e=st(e);let o=e.length;for(let i=0;i<o;){let a=Math.min(s-this.pos,o-i);if(a===s){let c=kt(e);for(;s<=o-i;i+=s)this.process(c,i);continue}n.set(e.subarray(i,i+a),this.pos),this.pos+=a,i+=a,this.pos===s&&(this.process(t,0),this.pos=0)}return this.length+=e.length,this.roundClean(),this}digestInto(e){Gt(this),Wo(e,this),this.finished=!0;let{buffer:t,view:n,blockLen:s,isLE:o}=this,{pos:i}=this;t[i++]=128,this.buffer.subarray(i).fill(0),this.padOffset>s-i&&(this.process(n,0),i=0);for(let l=i;l<s;l++)t[l]=0;El(n,s-8,BigInt(this.length*8),o),this.process(n,0);let a=kt(e),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let f=c/4,u=this.get();if(f>u.length)throw new Error("_sha2: outputLen bigger than state");for(let l=0;l<f;l++)a.setUint32(4*l,u[l],o)}digest(){let{buffer:e,outputLen:t}=this;this.digestInto(e);let n=e.slice(0,t);return this.destroy(),n}_cloneInto(e){e||(e=new this.constructor),e.set(...this.get());let{blockLen:t,buffer:n,length:s,finished:o,destroyed:i,pos:a}=this;return e.length=s,e.pos=a,e.finished=o,e.destroyed=i,s%t&&e.buffer.set(n),e}};var Kr=BigInt(4294967295),Bs=BigInt(32);function ei(r,e=!1){return e?{h:Number(r&Kr),l:Number(r>>Bs&Kr)}:{h:Number(r>>Bs&Kr)|0,l:Number(r&Kr)|0}}function Al(r,e=!1){let t=new Uint32Array(r.length),n=new Uint32Array(r.length);for(let s=0;s<r.length;s++){let{h:o,l:i}=ei(r[s],e);[t[s],n[s]]=[o,i]}return[t,n]}var kl=(r,e)=>BigInt(r>>>0)<<Bs|BigInt(e>>>0),Sl=(r,e,t)=>r>>>t,Il=(r,e,t)=>r<<32-t|e>>>t,Nl=(r,e,t)=>r>>>t|e<<32-t,Rl=(r,e,t)=>r<<32-t|e>>>t,Cl=(r,e,t)=>r<<64-t|e>>>t-32,Tl=(r,e,t)=>r>>>t-32|e<<64-t,_l=(r,e)=>e,Ul=(r,e)=>r,Ll=(r,e,t)=>r<<t|e>>>32-t,Vl=(r,e,t)=>e<<t|r>>>32-t,Hl=(r,e,t)=>e<<t-32|r>>>64-t,Dl=(r,e,t)=>r<<t-32|e>>>64-t;function Ol(r,e,t,n){let s=(e>>>0)+(n>>>0);return{h:r+t+(s/2**32|0)|0,l:s|0}}var Pl=(r,e,t)=>(r>>>0)+(e>>>0)+(t>>>0),Ml=(r,e,t,n)=>e+t+n+(r/2**32|0)|0,Kl=(r,e,t,n)=>(r>>>0)+(e>>>0)+(t>>>0)+(n>>>0),Fl=(r,e,t,n,s)=>e+t+n+s+(r/2**32|0)|0,$l=(r,e,t,n,s)=>(r>>>0)+(e>>>0)+(t>>>0)+(n>>>0)+(s>>>0),ql=(r,e,t,n,s,o)=>e+t+n+s+o+(r/2**32|0)|0;var jl={fromBig:ei,split:Al,toBig:kl,shrSH:Sl,shrSL:Il,rotrSH:Nl,rotrSL:Rl,rotrBH:Cl,rotrBL:Tl,rotr32H:_l,rotr32L:Ul,rotlSH:Ll,rotlSL:Vl,rotlBH:Hl,rotlBL:Dl,add:Ol,add3L:Pl,add3H:Ml,add4L:Kl,add4H:Fl,add5H:ql,add5L:$l},V=jl;var[zl,Gl]=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))),it=new Uint32Array(80),at=new Uint32Array(80),vs=class extends ot{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:e,Al:t,Bh:n,Bl:s,Ch:o,Cl:i,Dh:a,Dl:c,Eh:f,El:u,Fh:l,Fl:p,Gh:B,Gl:g,Hh:h,Hl:m}=this;return[e,t,n,s,o,i,a,c,f,u,l,p,B,g,h,m]}set(e,t,n,s,o,i,a,c,f,u,l,p,B,g,h,m){this.Ah=e|0,this.Al=t|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=u|0,this.Fh=l|0,this.Fl=p|0,this.Gh=B|0,this.Gl=g|0,this.Hh=h|0,this.Hl=m|0}process(e,t){for(let x=0;x<16;x++,t+=4)it[x]=e.getUint32(t),at[x]=e.getUint32(t+=4);for(let x=16;x<80;x++){let C=it[x-15]|0,S=at[x-15]|0,k=V.rotrSH(C,S,1)^V.rotrSH(C,S,8)^V.shrSH(C,S,7),R=V.rotrSL(C,S,1)^V.rotrSL(C,S,8)^V.shrSL(C,S,7),I=it[x-2]|0,F=at[x-2]|0,O=V.rotrSH(I,F,19)^V.rotrBH(I,F,61)^V.shrSH(I,F,6),P=V.rotrSL(I,F,19)^V.rotrBL(I,F,61)^V.shrSL(I,F,6),ee=V.add4L(R,P,at[x-7],at[x-16]),ne=V.add4H(ee,k,O,it[x-7],it[x-16]);it[x]=ne|0,at[x]=ee|0}let{Ah:n,Al:s,Bh:o,Bl:i,Ch:a,Cl:c,Dh:f,Dl:u,Eh:l,El:p,Fh:B,Fl:g,Gh:h,Gl:m,Hh:w,Hl:b}=this;for(let x=0;x<80;x++){let C=V.rotrSH(l,p,14)^V.rotrSH(l,p,18)^V.rotrBH(l,p,41),S=V.rotrSL(l,p,14)^V.rotrSL(l,p,18)^V.rotrBL(l,p,41),k=l&B^~l&h,R=p&g^~p&m,I=V.add5L(b,S,R,Gl[x],at[x]),F=V.add5H(I,w,C,k,zl[x],it[x]),O=I|0,P=V.rotrSH(n,s,28)^V.rotrBH(n,s,34)^V.rotrBH(n,s,39),ee=V.rotrSL(n,s,28)^V.rotrBL(n,s,34)^V.rotrBL(n,s,39),ne=n&o^n&a^o&a,N=s&i^s&c^i&c;w=h|0,b=m|0,h=B|0,m=g|0,B=l|0,g=p|0,{h:l,l:p}=V.add(f|0,u|0,F|0,O|0),f=a|0,u=c|0,a=o|0,c=i|0,o=n|0,i=s|0;let y=V.add3L(O,ee,N);n=V.add3H(y,F,P,ne),s=y|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:u}=V.add(this.Dh|0,this.Dl|0,f|0,u|0),{h:l,l:p}=V.add(this.Eh|0,this.El|0,l|0,p|0),{h:B,l:g}=V.add(this.Fh|0,this.Fl|0,B|0,g|0),{h,l:m}=V.add(this.Gh|0,this.Gl|0,h|0,m|0),{h:w,l:b}=V.add(this.Hh|0,this.Hl|0,w|0,b|0),this.set(n,s,o,i,a,c,f,u,l,p,B,g,h,m,w,b)}roundClean(){it.fill(0),at.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 St=Yt(()=>new vs);var $r={};Q($r,{aInRange:()=>ye,abool:()=>Ne,abytes:()=>Jt,bitGet:()=>eu,bitLen:()=>Ql,bitMask:()=>gr,bitSet:()=>tu,bytesToHex:()=>qe,bytesToNumberBE:()=>je,bytesToNumberLE:()=>lt,concatBytes:()=>ze,createHmacDrbg:()=>Is,ensureBytes:()=>X,equalBytes:()=>Jl,hexToBytes:()=>It,hexToNumber:()=>Ss,inRange:()=>dr,isBytes:()=>ct,memoized:()=>Rt,notImplemented:()=>nu,numberToBytesBE:()=>ut,numberToBytesLE:()=>Nt,numberToHexUnpadded:()=>ni,numberToVarBytesBE:()=>Wl,utf8ToBytes:()=>Xl,validateObject:()=>De});var ks=BigInt(0),Fr=BigInt(1),Zl=BigInt(2);function ct(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function Jt(r){if(!ct(r))throw new Error("Uint8Array expected")}function Ne(r,e){if(typeof e!="boolean")throw new Error(`${r} must be valid boolean, got "${e}".`)}var Yl=Array.from({length:256},(r,e)=>e.toString(16).padStart(2,"0"));function qe(r){Jt(r);let e="";for(let t=0;t<r.length;t++)e+=Yl[r[t]];return e}function ni(r){let e=r.toString(16);return e.length&1?`0${e}`:e}function Ss(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return BigInt(r===""?"0":`0x${r}`)}var $e={_0:48,_9:57,_A:65,_F:70,_a:97,_f:102};function ti(r){if(r>=$e._0&&r<=$e._9)return r-$e._0;if(r>=$e._A&&r<=$e._F)return r-($e._A-10);if(r>=$e._a&&r<=$e._f)return r-($e._a-10)}function It(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);let e=r.length,t=e/2;if(e%2)throw new Error("padded hex string expected, got unpadded hex of length "+e);let n=new Uint8Array(t);for(let s=0,o=0;s<t;s++,o+=2){let i=ti(r.charCodeAt(o)),a=ti(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 je(r){return Ss(qe(r))}function lt(r){return Jt(r),Ss(qe(Uint8Array.from(r).reverse()))}function ut(r,e){return It(r.toString(16).padStart(e*2,"0"))}function Nt(r,e){return ut(r,e).reverse()}function Wl(r){return It(ni(r))}function X(r,e,t){let n;if(typeof e=="string")try{n=It(e)}catch(o){throw new Error(`${r} must be valid hex string, got "${e}". Cause: ${o}`)}else if(ct(e))n=Uint8Array.from(e);else throw new Error(`${r} must be hex string or Uint8Array`);let s=n.length;if(typeof t=="number"&&s!==t)throw new Error(`${r} expected ${t} bytes, got ${s}`);return n}function ze(...r){let e=0;for(let n=0;n<r.length;n++){let s=r[n];Jt(s),e+=s.length}let t=new Uint8Array(e);for(let n=0,s=0;n<r.length;n++){let o=r[n];t.set(o,s),s+=o.length}return t}function Jl(r,e){if(r.length!==e.length)return!1;let t=0;for(let n=0;n<r.length;n++)t|=r[n]^e[n];return t===0}function Xl(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}var Es=r=>typeof r=="bigint"&&ks<=r;function dr(r,e,t){return Es(r)&&Es(e)&&Es(t)&&e<=r&&r<t}function ye(r,e,t,n){if(!dr(e,t,n))throw new Error(`expected valid ${r}: ${t} <= n < ${n}, got ${typeof e} ${e}`)}function Ql(r){let e;for(e=0;r>ks;r>>=Fr,e+=1);return e}function eu(r,e){return r>>BigInt(e)&Fr}function tu(r,e,t){return r|(t?Fr:ks)<<BigInt(e)}var gr=r=>(Zl<<BigInt(r-1))-Fr,As=r=>new Uint8Array(r),ri=r=>Uint8Array.from(r);function Is(r,e,t){if(typeof r!="number"||r<2)throw new Error("hashLen must be a number");if(typeof e!="number"||e<2)throw new Error("qByteLen must be a number");if(typeof t!="function")throw new Error("hmacFn must be a function");let n=As(r),s=As(r),o=0,i=()=>{n.fill(1),s.fill(0),o=0},a=(...l)=>t(s,n,...l),c=(l=As())=>{s=a(ri([0]),l),n=a(),l.length!==0&&(s=a(ri([1]),l),n=a())},f=()=>{if(o++>=1e3)throw new Error("drbg: tried 1000 values");let l=0,p=[];for(;l<e;){n=a();let B=n.slice();p.push(B),l+=n.length}return ze(...p)};return(l,p)=>{i(),c(l);let B;for(;!(B=p(f()));)c();return i(),B}}var ru={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"||ct(r),isSafeInteger:r=>Number.isSafeInteger(r),array:r=>Array.isArray(r),field:(r,e)=>e.Fp.isValid(r),hash:r=>typeof r=="function"&&Number.isSafeInteger(r.outputLen)};function De(r,e,t={}){let n=(s,o,i)=>{let a=ru[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(e))n(s,o,!1);for(let[s,o]of Object.entries(t))n(s,o,!0);return r}var nu=()=>{throw new Error("not implemented")};function Rt(r){let e=new WeakMap;return(t,...n)=>{let s=e.get(t);if(s!==void 0)return s;let o=r(t,...n);return e.set(t,o),o}}var oe=BigInt(0),G=BigInt(1),Ct=BigInt(2),su=BigInt(3),Ns=BigInt(4),si=BigInt(5),oi=BigInt(8),ou=BigInt(9),iu=BigInt(16);function $(r,e){let t=r%e;return t>=oe?t:e+t}function au(r,e,t){if(t<=oe||e<oe)throw new Error("Expected power/modulo > 0");if(t===G)return oe;let n=G;for(;e>oe;)e&G&&(n=n*r%t),r=r*r%t,e>>=G;return n}function Z(r,e,t){let n=r;for(;e-- >oe;)n*=n,n%=t;return n}function qr(r,e){if(r===oe||e<=oe)throw new Error(`invert: expected positive integers, got n=${r} mod=${e}`);let t=$(r,e),n=e,s=oe,o=G,i=G,a=oe;for(;t!==oe;){let f=n/t,u=n%t,l=s-i*f,p=o-a*f;n=t,t=u,s=i,o=a,i=l,a=p}if(n!==G)throw new Error("invert: does not exist");return $(s,e)}function cu(r){let e=(r-G)/Ct,t,n,s;for(t=r-G,n=0;t%Ct===oe;t/=Ct,n++);for(s=Ct;s<r&&au(s,e,r)!==r-G;s++);if(n===1){let i=(r+G)/Ns;return function(c,f){let u=c.pow(f,i);if(!c.eql(c.sqr(u),f))throw new Error("Cannot find square root");return u}}let o=(t+G)/Ct;return function(a,c){if(a.pow(c,e)===a.neg(a.ONE))throw new Error("Cannot find square root");let f=n,u=a.pow(a.mul(a.ONE,s),t),l=a.pow(c,o),p=a.pow(c,t);for(;!a.eql(p,a.ONE);){if(a.eql(p,a.ZERO))return a.ZERO;let B=1;for(let h=a.sqr(p);B<f&&!a.eql(h,a.ONE);B++)h=a.sqr(h);let g=a.pow(u,G<<BigInt(f-B-1));u=a.sqr(g),l=a.mul(l,g),p=a.mul(p,u),f=B}return l}}function lu(r){if(r%Ns===su){let e=(r+G)/Ns;return function(n,s){let o=n.pow(s,e);if(!n.eql(n.sqr(o),s))throw new Error("Cannot find square root");return o}}if(r%oi===si){let e=(r-si)/oi;return function(n,s){let o=n.mul(s,Ct),i=n.pow(o,e),a=n.mul(s,i),c=n.mul(n.mul(a,Ct),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%iu,cu(r)}var ii=(r,e)=>($(r,e)&G)===G,uu=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function Rs(r){let e={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},t=uu.reduce((n,s)=>(n[s]="function",n),e);return De(r,t)}function fu(r,e,t){if(t<oe)throw new Error("Expected power > 0");if(t===oe)return r.ONE;if(t===G)return e;let n=r.ONE,s=e;for(;t>oe;)t&G&&(n=r.mul(n,s)),s=r.sqr(s),t>>=G;return n}function hu(r,e){let t=new Array(e.length),n=e.reduce((o,i,a)=>r.is0(i)?o:(t[a]=o,r.mul(o,i)),r.ONE),s=r.inv(n);return e.reduceRight((o,i,a)=>r.is0(i)?o:(t[a]=r.mul(o,t[a]),r.mul(o,i)),s),t}function Cs(r,e){let t=e!==void 0?e:r.toString(2).length,n=Math.ceil(t/8);return{nBitLength:t,nByteLength:n}}function jr(r,e,t=!1,n={}){if(r<=oe)throw new Error(`Expected Field ORDER > 0, got ${r}`);let{nBitLength:s,nByteLength:o}=Cs(r,e);if(o>2048)throw new Error("Field lengths over 2048 bytes are not supported");let i=lu(r),a=Object.freeze({ORDER:r,BITS:s,BYTES:o,MASK:gr(s),ZERO:oe,ONE:G,create:c=>$(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error(`Invalid field element: expected bigint, got ${typeof c}`);return oe<=c&&c<r},is0:c=>c===oe,isOdd:c=>(c&G)===G,neg:c=>$(-c,r),eql:(c,f)=>c===f,sqr:c=>$(c*c,r),add:(c,f)=>$(c+f,r),sub:(c,f)=>$(c-f,r),mul:(c,f)=>$(c*f,r),pow:(c,f)=>fu(a,c,f),div:(c,f)=>$(c*qr(f,r),r),sqrN:c=>c*c,addN:(c,f)=>c+f,subN:(c,f)=>c-f,mulN:(c,f)=>c*f,inv:c=>qr(c,r),sqrt:n.sqrt||(c=>i(a,c)),invertBatch:c=>hu(a,c),cmov:(c,f,u)=>u?f:c,toBytes:c=>t?Nt(c,o):ut(c,o),fromBytes:c=>{if(c.length!==o)throw new Error(`Fp.fromBytes: expected ${o}, got ${c.length}`);return t?lt(c):je(c)}});return Object.freeze(a)}function ai(r){if(typeof r!="bigint")throw new Error("field order must be bigint");let e=r.toString(2).length;return Math.ceil(e/8)}function Ts(r){let e=ai(r);return e+Math.ceil(e/2)}function ci(r,e,t=!1){let n=r.length,s=ai(e),o=Ts(e);if(n<16||n<o||n>1024)throw new Error(`expected ${o}-1024 bytes of input, got ${n}`);let i=t?je(r):lt(r),a=$(i,e-G)+G;return t?Nt(a,s):ut(a,s)}var gu=BigInt(0),_s=BigInt(1),Us=new WeakMap,li=new WeakMap;function zr(r,e){let t=(o,i)=>{let a=i.negate();return o?a:i},n=o=>{if(!Number.isSafeInteger(o)||o<=0||o>e)throw new Error(`Wrong window size=${o}, should be [1..${e}]`)},s=o=>{n(o);let i=Math.ceil(e/o)+1,a=2**(o-1);return{windows:i,windowSize:a}};return{constTimeNegate:t,unsafeLadder(o,i){let a=r.ZERO,c=o;for(;i>gu;)i&_s&&(a=a.add(c)),c=c.double(),i>>=_s;return a},precomputeWindow(o,i){let{windows:a,windowSize:c}=s(i),f=[],u=o,l=u;for(let p=0;p<a;p++){l=u,f.push(l);for(let B=1;B<c;B++)l=l.add(u),f.push(l);u=l.double()}return f},wNAF(o,i,a){let{windows:c,windowSize:f}=s(o),u=r.ZERO,l=r.BASE,p=BigInt(2**o-1),B=2**o,g=BigInt(o);for(let h=0;h<c;h++){let m=h*f,w=Number(a&p);a>>=g,w>f&&(w-=B,a+=_s);let b=m,x=m+Math.abs(w)-1,C=h%2!==0,S=w<0;w===0?l=l.add(t(C,i[b])):u=u.add(t(S,i[x]))}return{p:u,f:l}},wNAFCached(o,i,a){let c=li.get(o)||1,f=Us.get(o);return f||(f=this.precomputeWindow(o,c),c!==1&&Us.set(o,a(f))),this.wNAF(c,f,i)},setWindowSize(o,i){n(i),li.set(o,i),Us.delete(o)}}}function pr(r){return Rs(r.Fp),De(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...Cs(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Re=BigInt(0),me=BigInt(1),Gr=BigInt(2),pu=BigInt(8),yu={zip215:!0};function mu(r){let e=pr(r);return De(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...e})}function ui(r){let e=mu(r),{Fp:t,n,prehash:s,hash:o,randomBytes:i,nByteLength:a,h:c}=e,f=Gr<<BigInt(a*8)-me,u=t.create,l=e.uvRatio||((y,d)=>{try{return{isValid:!0,value:t.sqrt(y*t.inv(d))}}catch{return{isValid:!1,value:Re}}}),p=e.adjustScalarBytes||(y=>y),B=e.domain||((y,d,v)=>{if(Ne("phflag",v),d.length||v)throw new Error("Contexts/pre-hash are not supported");return y});function g(y,d){ye("coordinate "+y,d,Re,f)}function h(y){if(!(y instanceof b))throw new Error("ExtendedPoint expected")}let m=Rt((y,d)=>{let{ex:v,ey:E,ez:T}=y,U=y.is0();d==null&&(d=U?pu:t.inv(T));let L=u(v*d),M=u(E*d),H=u(T*d);if(U)return{x:Re,y:me};if(H!==me)throw new Error("invZ was invalid");return{x:L,y:M}}),w=Rt(y=>{let{a:d,d:v}=e;if(y.is0())throw new Error("bad point: ZERO");let{ex:E,ey:T,ez:U,et:L}=y,M=u(E*E),H=u(T*T),K=u(U*U),Y=u(K*K),W=u(M*d),pe=u(K*u(W+H)),ie=u(Y+u(v*u(M*H)));if(pe!==ie)throw new Error("bad point: equation left != right (1)");let se=u(E*T),Ae=u(U*L);if(se!==Ae)throw new Error("bad point: equation left != right (2)");return!0});class b{constructor(d,v,E,T){this.ex=d,this.ey=v,this.ez=E,this.et=T,g("x",d),g("y",v),g("z",E),g("t",T),Object.freeze(this)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(d){if(d instanceof b)throw new Error("extended point not allowed");let{x:v,y:E}=d||{};return g("x",v),g("y",E),new b(v,E,me,u(v*E))}static normalizeZ(d){let v=t.invertBatch(d.map(E=>E.ez));return d.map((E,T)=>E.toAffine(v[T])).map(b.fromAffine)}_setWindowSize(d){S.setWindowSize(this,d)}assertValidity(){w(this)}equals(d){h(d);let{ex:v,ey:E,ez:T}=this,{ex:U,ey:L,ez:M}=d,H=u(v*M),K=u(U*T),Y=u(E*M),W=u(L*T);return H===K&&Y===W}is0(){return this.equals(b.ZERO)}negate(){return new b(u(-this.ex),this.ey,this.ez,u(-this.et))}double(){let{a:d}=e,{ex:v,ey:E,ez:T}=this,U=u(v*v),L=u(E*E),M=u(Gr*u(T*T)),H=u(d*U),K=v+E,Y=u(u(K*K)-U-L),W=H+L,pe=W-M,ie=H-L,se=u(Y*pe),Ae=u(W*ie),ae=u(Y*ie),ke=u(pe*W);return new b(se,Ae,ke,ae)}add(d){h(d);let{a:v,d:E}=e,{ex:T,ey:U,ez:L,et:M}=this,{ex:H,ey:K,ez:Y,et:W}=d;if(v===BigInt(-1)){let xo=u((U-T)*(K+H)),Bo=u((U+T)*(K-H)),Zn=u(Bo-xo);if(Zn===Re)return this.double();let vo=u(L*Gr*W),Eo=u(M*Gr*Y),Ao=Eo+vo,ko=Bo+xo,So=Eo-vo,tc=u(Ao*Zn),rc=u(ko*So),nc=u(Ao*So),sc=u(Zn*ko);return new b(tc,rc,sc,nc)}let pe=u(T*H),ie=u(U*K),se=u(M*E*W),Ae=u(L*Y),ae=u((T+U)*(H+K)-pe-ie),ke=Ae-se,vt=Ae+se,cr=u(ie-v*pe),Cr=u(ae*ke),Xa=u(vt*cr),Qa=u(ae*cr),ec=u(ke*vt);return new b(Cr,Xa,ec,Qa)}subtract(d){return this.add(d.negate())}wNAF(d){return S.wNAFCached(this,d,b.normalizeZ)}multiply(d){let v=d;ye("scalar",v,me,n);let{p:E,f:T}=this.wNAF(v);return b.normalizeZ([E,T])[0]}multiplyUnsafe(d){let v=d;return ye("scalar",v,Re,n),v===Re?C:this.equals(C)||v===me?this:this.equals(x)?this.wNAF(v).p:S.unsafeLadder(this,v)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return S.unsafeLadder(this,n).is0()}toAffine(d){return m(this,d)}clearCofactor(){let{h:d}=e;return d===me?this:this.multiplyUnsafe(d)}static fromHex(d,v=!1){let{d:E,a:T}=e,U=t.BYTES;d=X("pointHex",d,U),Ne("zip215",v);let L=d.slice(),M=d[U-1];L[U-1]=M&-129;let H=lt(L),K=v?f:t.ORDER;ye("pointHex.y",H,Re,K);let Y=u(H*H),W=u(Y-me),pe=u(E*Y-T),{isValid:ie,value:se}=l(W,pe);if(!ie)throw new Error("Point.fromHex: invalid y coordinate");let Ae=(se&me)===me,ae=(M&128)!==0;if(!v&&se===Re&&ae)throw new Error("Point.fromHex: x=0 and x_0=1");return ae!==Ae&&(se=u(-se)),b.fromAffine({x:se,y:H})}static fromPrivateKey(d){return I(d).point}toRawBytes(){let{x:d,y:v}=this.toAffine(),E=Nt(v,t.BYTES);return E[E.length-1]|=d&me?128:0,E}toHex(){return qe(this.toRawBytes())}}b.BASE=new b(e.Gx,e.Gy,me,u(e.Gx*e.Gy)),b.ZERO=new b(Re,me,me,Re);let{BASE:x,ZERO:C}=b,S=zr(b,a*8);function k(y){return $(y,n)}function R(y){return k(lt(y))}function I(y){let d=a;y=X("private key",y,d);let v=X("hashed private key",o(y),2*d),E=p(v.slice(0,d)),T=v.slice(d,2*d),U=R(E),L=x.multiply(U),M=L.toRawBytes();return{head:E,prefix:T,scalar:U,point:L,pointBytes:M}}function F(y){return I(y).pointBytes}function O(y=new Uint8Array,...d){let v=ze(...d);return R(o(B(v,X("context",y),!!s)))}function P(y,d,v={}){y=X("message",y),s&&(y=s(y));let{prefix:E,scalar:T,pointBytes:U}=I(d),L=O(v.context,E,y),M=x.multiply(L).toRawBytes(),H=O(v.context,M,U,y),K=k(L+H*T);ye("signature.s",K,Re,n);let Y=ze(M,Nt(K,t.BYTES));return X("result",Y,a*2)}let ee=yu;function ne(y,d,v,E=ee){let{context:T,zip215:U}=E,L=t.BYTES;y=X("signature",y,2*L),d=X("message",d),U!==void 0&&Ne("zip215",U),s&&(d=s(d));let M=lt(y.slice(L,2*L)),H,K,Y;try{H=b.fromHex(v,U),K=b.fromHex(y.slice(0,L),U),Y=x.multiplyUnsafe(M)}catch{return!1}if(!U&&H.isSmallOrder())return!1;let W=O(T,K.toRawBytes(),H.toRawBytes(),d);return K.add(H.multiplyUnsafe(W)).subtract(Y).clearCofactor().equals(b.ZERO)}return x._setWindowSize(8),{CURVE:e,getPublicKey:F,sign:P,verify:ne,ExtendedPoint:b,utils:{getExtendedPublicKey:I,randomPrivateKey:()=>i(t.BYTES),precompute(y=8,d=b.BASE){return d._setWindowSize(y),d.multiply(BigInt(3)),d}}}}var Ls=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),fi=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),yd=BigInt(0),bu=BigInt(1),hi=BigInt(2),md=BigInt(3),wu=BigInt(5),xu=BigInt(8);function Bu(r){let e=BigInt(10),t=BigInt(20),n=BigInt(40),s=BigInt(80),o=Ls,a=r*r%o*r%o,c=Z(a,hi,o)*a%o,f=Z(c,bu,o)*r%o,u=Z(f,wu,o)*f%o,l=Z(u,e,o)*u%o,p=Z(l,t,o)*l%o,B=Z(p,n,o)*p%o,g=Z(B,s,o)*B%o,h=Z(g,s,o)*B%o,m=Z(h,e,o)*u%o;return{pow_p_5_8:Z(m,hi,o)*r%o,b2:a}}function vu(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function Eu(r,e){let t=Ls,n=$(e*e*e,t),s=$(n*n*e,t),o=Bu(r*s).pow_p_5_8,i=$(r*n*o,t),a=$(e*i*i,t),c=i,f=$(i*fi,t),u=a===r,l=a===$(-r,t),p=a===$(-r*fi,t);return u&&(i=c),(l||p)&&(i=f),ii(i,t)&&(i=$(-i,t)),{isValid:u||l,value:i}}var Au=jr(Ls,void 0,!0),ku={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:Au,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:xu,Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:St,randomBytes:Wt,adjustScalarBytes:vu,uvRatio:Eu},Xt=ui(ku);var Qt=32,Ge=64,Zr=32;function di(){let r=Xt.utils.randomPrivateKey(),e=Xt.getPublicKey(r);return{privateKey:mi(r,e),publicKey:e}}function gi(r){if(r.length!==Zr)throw new TypeError('"seed" must be 32 bytes in length.');if(!(r instanceof Uint8Array))throw new TypeError('"seed" must be a node.js Buffer, or Uint8Array.');let e=r,t=Xt.getPublicKey(e);return{privateKey:mi(e,t),publicKey:t}}function pi(r,e){let t=r.subarray(0,Zr);return Xt.sign(e instanceof Uint8Array?e:e.subarray(),t)}function yi(r,e,t){return Xt.verify(e,t instanceof Uint8Array?t:t.subarray(),r)}function mi(r,e){let t=new Uint8Array(Ge);for(let n=0;n<Zr;n++)t[n]=r[n],t[Zr+n]=e[n];return t}var Vs={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function Yr(r){let e=r?.algorithm??"AES-GCM",t=r?.keyLength??16,n=r?.nonceLength??12,s=r?.digest??"SHA-256",o=r?.saltLength??16,i=r?.iterations??32767,a=j.get();t*=8;async function c(l,p){let B=a.getRandomValues(new Uint8Array(o)),g=a.getRandomValues(new Uint8Array(n)),h={name:e,iv:g};typeof p=="string"&&(p=z(p));let m;if(p.length===0){m=await a.subtle.importKey("jwk",Vs,{name:"AES-GCM"},!0,["encrypt"]);try{let b={name:"PBKDF2",salt:B,iterations:i,hash:{name:s}},x=await a.subtle.importKey("raw",p,{name:"PBKDF2"},!1,["deriveKey"]);m=await a.subtle.deriveKey(b,x,{name:e,length:t},!0,["encrypt"])}catch{m=await a.subtle.importKey("jwk",Vs,{name:"AES-GCM"},!0,["encrypt"])}}else{let b={name:"PBKDF2",salt:B,iterations:i,hash:{name:s}},x=await a.subtle.importKey("raw",p,{name:"PBKDF2"},!1,["deriveKey"]);m=await a.subtle.deriveKey(b,x,{name:e,length:t},!0,["encrypt"])}let w=await a.subtle.encrypt(h,m,l);return Fe([B,h.iv,new Uint8Array(w)])}async function f(l,p){let B=l.subarray(0,o),g=l.subarray(o,o+n),h=l.subarray(o+n),m={name:e,iv:g};typeof p=="string"&&(p=z(p));let w;if(p.length===0)try{let x={name:"PBKDF2",salt:B,iterations:i,hash:{name:s}},C=await a.subtle.importKey("raw",p,{name:"PBKDF2"},!1,["deriveKey"]);w=await a.subtle.deriveKey(x,C,{name:e,length:t},!0,["decrypt"])}catch{w=await a.subtle.importKey("jwk",Vs,{name:"AES-GCM"},!0,["decrypt"])}else{let x={name:"PBKDF2",salt:B,iterations:i,hash:{name:s}},C=await a.subtle.importKey("raw",p,{name:"PBKDF2"},!1,["deriveKey"]);w=await a.subtle.deriveKey(x,C,{name:e,length:t},!0,["decrypt"])}let b=await a.subtle.decrypt(m,w,h);return new Uint8Array(b)}return{encrypt:c,decrypt:f}}async function er(r,e){let n=await Yr().encrypt(r,e);return At.encode(n)}var rr={};Q(rr,{KeyType:()=>q,PrivateKey:()=>_e,PublicKey:()=>Te});var Iu=Math.pow(2,7),Nu=Math.pow(2,14),Ru=Math.pow(2,21),wi=Math.pow(2,28),xi=Math.pow(2,35),Bi=Math.pow(2,42),vi=Math.pow(2,49),de=128,ft=127;function yr(r){if(r<Iu)return 1;if(r<Nu)return 2;if(r<Ru)return 3;if(r<wi)return 4;if(r<xi)return 5;if(r<Bi)return 6;if(r<vi)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function Ei(r,e,t=0){switch(yr(r)){case 8:e[t++]=r&255|de,r/=128;case 7:e[t++]=r&255|de,r/=128;case 6:e[t++]=r&255|de,r/=128;case 5:e[t++]=r&255|de,r/=128;case 4:e[t++]=r&255|de,r>>>=7;case 3:e[t++]=r&255|de,r>>>=7;case 2:e[t++]=r&255|de,r>>>=7;case 1:{e[t++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return e}function Ai(r,e){let t=r[e],n=0;if(n+=t&ft,t<de||(t=r[e+1],n+=(t&ft)<<7,t<de)||(t=r[e+2],n+=(t&ft)<<14,t<de)||(t=r[e+3],n+=(t&ft)<<21,t<de)||(t=r[e+4],n+=(t&ft)*wi,t<de)||(t=r[e+5],n+=(t&ft)*xi,t<de)||(t=r[e+6],n+=(t&ft)*Bi,t<de)||(t=r[e+7],n+=(t&ft)*vi,t<de))return n;throw new RangeError("Could not decode varint")}var Hs=new Float32Array([-0]),ht=new Uint8Array(Hs.buffer);function ki(r,e,t){Hs[0]=r,e[t]=ht[0],e[t+1]=ht[1],e[t+2]=ht[2],e[t+3]=ht[3]}function Si(r,e){return ht[0]=r[e],ht[1]=r[e+1],ht[2]=r[e+2],ht[3]=r[e+3],Hs[0]}var Ds=new Float64Array([-0]),fe=new Uint8Array(Ds.buffer);function Ii(r,e,t){Ds[0]=r,e[t]=fe[0],e[t+1]=fe[1],e[t+2]=fe[2],e[t+3]=fe[3],e[t+4]=fe[4],e[t+5]=fe[5],e[t+6]=fe[6],e[t+7]=fe[7]}function Ni(r,e){return fe[0]=r[e],fe[1]=r[e+1],fe[2]=r[e+2],fe[3]=r[e+3],fe[4]=r[e+4],fe[5]=r[e+5],fe[6]=r[e+6],fe[7]=r[e+7],Ds[0]}var Cu=BigInt(Number.MAX_SAFE_INTEGER),Tu=BigInt(Number.MIN_SAFE_INTEGER),xe=class r{lo;hi;constructor(e,t){this.lo=e|0,this.hi=t|0}toNumber(e=!1){if(!e&&this.hi>>>31>0){let t=~this.lo+1>>>0,n=~this.hi>>>0;return t===0&&(n=n+1>>>0),-(t+n*4294967296)}return this.lo+this.hi*4294967296}toBigInt(e=!1){if(e)return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n);if(this.hi>>>31){let t=~this.lo+1>>>0,n=~this.hi>>>0;return t===0&&(n=n+1>>>0),-(BigInt(t)+(BigInt(n)<<32n))}return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n)}toString(e=!1){return this.toBigInt(e).toString()}zzEncode(){let e=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^e)>>>0,this.lo=(this.lo<<1^e)>>>0,this}zzDecode(){let e=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^e)>>>0,this.hi=(this.hi>>>1^e)>>>0,this}length(){let e=this.lo,t=(this.lo>>>28|this.hi<<4)>>>0,n=this.hi>>>24;return n===0?t===0?e<16384?e<128?1:2:e<2097152?3:4:t<16384?t<128?5:6:t<2097152?7:8:n<128?9:10}static fromBigInt(e){if(e===0n)return Tt;if(e<Cu&&e>Tu)return this.fromNumber(Number(e));let t=e<0n;t&&(e=-e);let n=e>>32n,s=e-(n<<32n);return t&&(n=~n|0n,s=~s|0n,++s>Ri&&(s=0n,++n>Ri&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(e){if(e===0)return Tt;let t=e<0;t&&(e=-e);let n=e>>>0,s=(e-n)/4294967296>>>0;return t&&(s=~s>>>0,n=~n>>>0,++n>4294967295&&(n=0,++s>4294967295&&(s=0))),new r(n,s)}static from(e){return typeof e=="number"?r.fromNumber(e):typeof e=="bigint"?r.fromBigInt(e):typeof e=="string"?r.fromBigInt(BigInt(e)):e.low!=null||e.high!=null?new r(e.low>>>0,e.high>>>0):Tt}},Tt=new xe(0,0);Tt.toBigInt=function(){return 0n};Tt.zzEncode=Tt.zzDecode=function(){return this};Tt.length=function(){return 1};var Ri=4294967296n;function Ci(r){let e=0,t=0;for(let n=0;n<r.length;++n)t=r.charCodeAt(n),t<128?e+=1:t<2048?e+=2:(t&64512)===55296&&(r.charCodeAt(n+1)&64512)===56320?(++n,e+=4):e+=3;return e}function Ti(r,e,t){if(t-e<1)return"";let s,o=[],i=0,a;for(;e<t;)a=r[e++],a<128?o[i++]=a:a>191&&a<224?o[i++]=(a&31)<<6|r[e++]&63:a>239&&a<365?(a=((a&7)<<18|(r[e++]&63)<<12|(r[e++]&63)<<6|r[e++]&63)-65536,o[i++]=55296+(a>>10),o[i++]=56320+(a&1023)):o[i++]=(a&15)<<12|(r[e++]&63)<<6|r[e++]&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 Os(r,e,t){let n=t,s,o;for(let i=0;i<r.length;++i)s=r.charCodeAt(i),s<128?e[t++]=s:s<2048?(e[t++]=s>>6|192,e[t++]=s&63|128):(s&64512)===55296&&((o=r.charCodeAt(i+1))&64512)===56320?(s=65536+((s&1023)<<10)+(o&1023),++i,e[t++]=s>>18|240,e[t++]=s>>12&63|128,e[t++]=s>>6&63|128,e[t++]=s&63|128):(e[t++]=s>>12|224,e[t++]=s>>6&63|128,e[t++]=s&63|128);return t-n}function Ce(r,e){return RangeError(`index out of range: ${r.pos} + ${e??1} > ${r.len}`)}function Wr(r,e){return(r[e-4]|r[e-3]<<8|r[e-2]<<16|r[e-1]<<24)>>>0}var Ps=class{buf;pos;len;_slice=Uint8Array.prototype.subarray;constructor(e){this.buf=e,this.pos=0,this.len=e.length}uint32(){let e=4294967295;if(e=(this.buf[this.pos]&127)>>>0,this.buf[this.pos++]<128||(e=(e|(this.buf[this.pos]&127)<<7)>>>0,this.buf[this.pos++]<128)||(e=(e|(this.buf[this.pos]&127)<<14)>>>0,this.buf[this.pos++]<128)||(e=(e|(this.buf[this.pos]&127)<<21)>>>0,this.buf[this.pos++]<128)||(e=(e|(this.buf[this.pos]&15)<<28)>>>0,this.buf[this.pos++]<128))return e;if((this.pos+=5)>this.len)throw this.pos=this.len,Ce(this,10);return e}int32(){return this.uint32()|0}sint32(){let e=this.uint32();return e>>>1^-(e&1)|0}bool(){return this.uint32()!==0}fixed32(){if(this.pos+4>this.len)throw Ce(this,4);return Wr(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Ce(this,4);return Wr(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Ce(this,4);let e=Si(this.buf,this.pos);return this.pos+=4,e}double(){if(this.pos+8>this.len)throw Ce(this,4);let e=Ni(this.buf,this.pos);return this.pos+=8,e}bytes(){let e=this.uint32(),t=this.pos,n=this.pos+e;if(n>this.len)throw Ce(this,e);return this.pos+=e,t===n?new Uint8Array(0):this.buf.subarray(t,n)}string(){let e=this.bytes();return Ti(e,0,e.length)}skip(e){if(typeof e=="number"){if(this.pos+e>this.len)throw Ce(this,e);this.pos+=e}else do if(this.pos>=this.len)throw Ce(this);while(this.buf[this.pos++]&128);return this}skipType(e){switch(e){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;(e=this.uint32()&7)!==4;)this.skipType(e);break;case 5:this.skip(4);break;default:throw Error(`invalid wire type ${e} at offset ${this.pos}`)}return this}readLongVarint(){let e=new xe(0,0),t=0;if(this.len-this.pos>4){for(;t<4;++t)if(e.lo=(e.lo|(this.buf[this.pos]&127)<<t*7)>>>0,this.buf[this.pos++]<128)return e;if(e.lo=(e.lo|(this.buf[this.pos]&127)<<28)>>>0,e.hi=(e.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return e;t=0}else{for(;t<3;++t){if(this.pos>=this.len)throw Ce(this);if(e.lo=(e.lo|(this.buf[this.pos]&127)<<t*7)>>>0,this.buf[this.pos++]<128)return e}return e.lo=(e.lo|(this.buf[this.pos++]&127)<<t*7)>>>0,e}if(this.len-this.pos>4){for(;t<5;++t)if(e.hi=(e.hi|(this.buf[this.pos]&127)<<t*7+3)>>>0,this.buf[this.pos++]<128)return e}else for(;t<5;++t){if(this.pos>=this.len)throw Ce(this);if(e.hi=(e.hi|(this.buf[this.pos]&127)<<t*7+3)>>>0,this.buf[this.pos++]<128)return e}throw Error("invalid varint encoding")}readFixed64(){if(this.pos+8>this.len)throw Ce(this,8);let e=Wr(this.buf,this.pos+=4),t=Wr(this.buf,this.pos+=4);return new xe(e,t)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){let e=Ai(this.buf,this.pos);return this.pos+=yr(e),e}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 Ms(r){return new Ps(r instanceof Uint8Array?r:r.subarray())}function Jr(r,e,t){let n=Ms(r);return e.decode(n,void 0,t)}function Ks(r){let e=r??8192,t=e>>>1,n,s=e;return function(i){if(i<1||i>t)return He(i);s+i>e&&(n=He(e),s=0);let a=n.subarray(s,s+=i);return s&7&&(s=(s|7)+1),a}}var _t=class{fn;len;next;val;constructor(e,t,n){this.fn=e,this.len=t,this.next=void 0,this.val=n}};function Fs(){}var qs=class{head;tail;len;next;constructor(e){this.head=e.head,this.tail=e.tail,this.len=e.len,this.next=e.states}},_u=Ks();function Uu(r){return globalThis.Buffer!=null?He(r):_u(r)}var br=class{len;head;tail;states;constructor(){this.len=0,this.head=new _t(Fs,0,0),this.tail=this.head,this.states=null}_push(e,t,n){return this.tail=this.tail.next=new _t(e,t,n),this.len+=t,this}uint32(e){return this.len+=(this.tail=this.tail.next=new js((e=e>>>0)<128?1:e<16384?2:e<2097152?3:e<268435456?4:5,e)).len,this}int32(e){return e<0?this._push(Xr,10,xe.fromNumber(e)):this.uint32(e)}sint32(e){return this.uint32((e<<1^e>>31)>>>0)}uint64(e){let t=xe.fromBigInt(e);return this._push(Xr,t.length(),t)}uint64Number(e){return this._push(Ei,yr(e),e)}uint64String(e){return this.uint64(BigInt(e))}int64(e){return this.uint64(e)}int64Number(e){return this.uint64Number(e)}int64String(e){return this.uint64String(e)}sint64(e){let t=xe.fromBigInt(e).zzEncode();return this._push(Xr,t.length(),t)}sint64Number(e){let t=xe.fromNumber(e).zzEncode();return this._push(Xr,t.length(),t)}sint64String(e){return this.sint64(BigInt(e))}bool(e){return this._push($s,1,e?1:0)}fixed32(e){return this._push(mr,4,e>>>0)}sfixed32(e){return this.fixed32(e)}fixed64(e){let t=xe.fromBigInt(e);return this._push(mr,4,t.lo)._push(mr,4,t.hi)}fixed64Number(e){let t=xe.fromNumber(e);return this._push(mr,4,t.lo)._push(mr,4,t.hi)}fixed64String(e){return this.fixed64(BigInt(e))}sfixed64(e){return this.fixed64(e)}sfixed64Number(e){return this.fixed64Number(e)}sfixed64String(e){return this.fixed64String(e)}float(e){return this._push(ki,4,e)}double(e){return this._push(Ii,8,e)}bytes(e){let t=e.length>>>0;return t===0?this._push($s,1,0):this.uint32(t)._push(Vu,t,e)}string(e){let t=Ci(e);return t!==0?this.uint32(t)._push(Os,t,e):this._push($s,1,0)}fork(){return this.states=new qs(this),this.head=this.tail=new _t(Fs,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 _t(Fs,0,0),this.len=0),this}ldelim(){let e=this.head,t=this.tail,n=this.len;return this.reset().uint32(n),n!==0&&(this.tail.next=e.next,this.tail=t,this.len+=n),this}finish(){let e=this.head.next,t=Uu(this.len),n=0;for(;e!=null;)e.fn(e.val,t,n),n+=e.len,e=e.next;return t}};function $s(r,e,t){e[t]=r&255}function Lu(r,e,t){for(;r>127;)e[t++]=r&127|128,r>>>=7;e[t]=r}var js=class extends _t{next;constructor(e,t){super(Lu,e,t),this.next=void 0}};function Xr(r,e,t){for(;r.hi!==0;)e[t++]=r.lo&127|128,r.lo=(r.lo>>>7|r.hi<<25)>>>0,r.hi>>>=7;for(;r.lo>127;)e[t++]=r.lo&127|128,r.lo=r.lo>>>7;e[t++]=r.lo}function mr(r,e,t){e[t]=r&255,e[t+1]=r>>>8&255,e[t+2]=r>>>16&255,e[t+3]=r>>>24}function Vu(r,e,t){e.set(r,t)}globalThis.Buffer!=null&&(br.prototype.bytes=function(r){let e=r.length>>>0;return this.uint32(e),e>0&&this._push(Hu,e,r),this},br.prototype.string=function(r){let e=globalThis.Buffer.byteLength(r);return this.uint32(e),e>0&&this._push(Du,e,r),this});function Hu(r,e,t){e.set(r,t)}function Du(r,e,t){r.length<40?Os(r,e,t):e.utf8Write!=null?e.utf8Write(r,t):e.set(z(r),t)}function zs(){return new br}function Qr(r,e){let t=zs();return e.encode(r,t,{lengthDelimited:!1}),t.finish()}var tr;(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"})(tr||(tr={}));function en(r,e,t,n){return{name:r,type:e,encode:t,decode:n}}function Gs(r){function e(s){if(r[s.toString()]==null)throw new Error("Invalid enum value");return r[s]}let t=function(o,i){let a=e(o);i.int32(a)},n=function(o){let i=o.int32();return e(i)};return en("enum",tr.VARINT,t,n)}function tn(r,e){return en("message",tr.LENGTH_DELIMITED,r,e)}var q;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.Secp256k1="Secp256k1"})(q||(q={}));var Zs;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.Secp256k1=2]="Secp256k1"})(Zs||(Zs={}));(function(r){r.codec=()=>Gs(Zs)})(q||(q={}));var Te;(function(r){let e;r.codec=()=>(e==null&&(e=tn((t,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),t.Type!=null&&(n.uint32(8),q.codec().encode(t.Type,n)),t.Data!=null&&(n.uint32(18),n.bytes(t.Data)),s.lengthDelimited!==!1&&n.ldelim()},(t,n)=>{let s={},o=n==null?t.len:t.pos+n;for(;t.pos<o;){let i=t.uint32();switch(i>>>3){case 1:s.Type=q.codec().decode(t);break;case 2:s.Data=t.bytes();break;default:t.skipType(i&7);break}}return s})),e),r.encode=t=>Qr(t,r.codec()),r.decode=t=>Jr(t,r.codec())})(Te||(Te={}));var _e;(function(r){let e;r.codec=()=>(e==null&&(e=tn((t,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),t.Type!=null&&(n.uint32(8),q.codec().encode(t.Type,n)),t.Data!=null&&(n.uint32(18),n.bytes(t.Data)),s.lengthDelimited!==!1&&n.ldelim()},(t,n)=>{let s={},o=n==null?t.len:t.pos+n;for(;t.pos<o;){let i=t.uint32();switch(i>>>3){case 1:s.Type=q.codec().decode(t);break;case 2:s.Data=t.bytes();break;default:t.skipType(i&7);break}}return s})),e),r.encode=t=>Qr(t,r.codec()),r.decode=t=>Jr(t,r.codec())})(_e||(_e={}));var Ut=class{_key;constructor(e){this._key=nr(e,Qt)}verify(e,t){return yi(this._key,t,e)}marshal(){return this._key}get bytes(){return Te.encode({Type:q.Ed25519,Data:this.marshal()}).subarray()}equals(e){return Se(this.bytes,e.bytes)}hash(){let e=we.digest(this.bytes);return ve(e)?e.then(({bytes:t})=>t):e.bytes}},Ze=class{_key;_publicKey;constructor(e,t){this._key=nr(e,Ge),this._publicKey=nr(t,Qt)}sign(e){return pi(this._key,e)}get public(){return new Ut(this._publicKey)}marshal(){return this._key}get bytes(){return _e.encode({Type:q.Ed25519,Data:this.marshal()}).subarray()}equals(e){return Se(this.bytes,e.bytes)}async hash(){let e=we.digest(this.bytes),t;return ve(e)?{bytes:t}=await e:t=e.bytes,t}async id(){let e=rs.digest(this.public.bytes);return Be.encode(e.bytes).substring(1)}async export(e,t="libp2p-key"){if(t==="libp2p-key")return er(this.bytes,e);throw new _(`export format '${t}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function Ou(r){if(r.length>Ge){r=nr(r,Ge+Qt);let n=r.subarray(0,Ge),s=r.subarray(Ge,r.length);return new Ze(n,s)}r=nr(r,Ge);let e=r.subarray(0,Ge),t=r.subarray(Qt);return new Ze(e,t)}function Pu(r){return r=nr(r,Qt),new Ut(r)}async function Mu(){let{privateKey:r,publicKey:e}=di();return new Ze(r,e)}async function Ys(r){let{privateKey:e,publicKey:t}=gi(r);return new Ze(e,t)}function nr(r,e){if(r=Uint8Array.from(r??[]),r.length!==e)throw new _(`Key must be a Uint8Array of length ${e}, got ${r.length}`,"ERR_INVALID_KEY_TYPE");return r}function te(r,e="utf8"){let t=Vr[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return t.encoder.encode(r).substring(1)}var Ui={"P-256":256,"P-384":384,"P-521":521},Ku=Object.keys(Ui),Js=Ku.join(" / ");async function Li(r){if(r!=="P-256"&&r!=="P-384"&&r!=="P-521")throw new _(`Unknown curve: ${r}. Must be ${Js}`,"ERR_INVALID_CURVE");let e=await j.get().subtle.generateKey({name:"ECDH",namedCurve:r},!0,["deriveBits"]),t=async(o,i)=>{let a;i!=null?a=await j.get().subtle.importKey("jwk",$u(r,i),{name:"ECDH",namedCurve:r},!1,["deriveBits"]):a=e.privateKey;let c=await j.get().subtle.importKey("jwk",Hi(r,o),{name:"ECDH",namedCurve:r},!1,[]),f=await j.get().subtle.deriveBits({name:"ECDH",namedCurve:r,public:c},a,Ui[r]);return new Uint8Array(f,0,f.byteLength)},n=await j.get().subtle.exportKey("jwk",e.publicKey);return{key:Fu(n),genSharedKey:t}}var Vi={"P-256":32,"P-384":48,"P-521":66};function Fu(r){if(r.crv==null||r.x==null||r.y==null)throw new _("JWK was missing components","ERR_INVALID_PARAMETERS");if(r.crv!=="P-256"&&r.crv!=="P-384"&&r.crv!=="P-521")throw new _(`Unknown curve: ${r.crv}. Must be ${Js}`,"ERR_INVALID_CURVE");let e=Vi[r.crv];return Fe([Uint8Array.from([4]),ws(r.x,e),ws(r.y,e)],1+e*2)}function Hi(r,e){if(r!=="P-256"&&r!=="P-384"&&r!=="P-521")throw new _(`Unknown curve: ${r}. Must be ${Js}`,"ERR_INVALID_CURVE");let t=Vi[r];if(!Se(e.subarray(0,1),Uint8Array.from([4])))throw new _("Cannot unmarshal public key - invalid key format","ERR_INVALID_KEY_FORMAT");return{kty:"EC",crv:r,x:te(e.subarray(1,t+1),"base64url"),y:te(e.subarray(1+t),"base64url"),ext:!0}}var $u=(r,e)=>({...Hi(r,e.public),d:te(e.private,"base64url")});var Di=Li;async function Oi(r,e){let t=At.decode(r);return Yr().decrypt(t,e)}var Pi={"AES-128":{ivSize:16,keySize:16},"AES-256":{ivSize:16,keySize:32},Blowfish:{ivSize:8,keySize:32}};async function Mi(r,e,t){let n=Pi[r];if(n==null){let b=Object.keys(Pi).join(" / ");throw new _(`unknown cipher type '${r}'. Must be ${b}`,"ERR_INVALID_CIPHER_TYPE")}if(e==null)throw new _("missing hash type","ERR_MISSING_HASH_TYPE");let s=n.keySize,o=n.ivSize,i=20,a=z("key expansion"),c=2*(o+s+i),f=await Yn(e,t),u=await f.digest(a),l=[],p=0;for(;p<c;){let b=await f.digest(Fe([u,a])),x=b.length;p+x>c&&(x=c-p),l.push(b),p+=x,u=await f.digest(u)}let B=c/2,g=Fe(l),h=g.subarray(0,B),m=g.subarray(B,c),w=b=>({iv:b.subarray(0,o),cipherKey:b.subarray(o,o+s),macKey:b.subarray(o+s)});return{k1:w(h),k2:w(m)}}var co={};Q(co,{MAX_RSA_KEY_SIZE:()=>Ht,RsaPrivateKey:()=>mt,RsaPublicKey:()=>Vt,fromJwk:()=>gf,generateKeyPair:()=>pf,unmarshalRsaPrivateKey:()=>io,unmarshalRsaPublicKey:()=>df});function Ye(r){if(isNaN(r)||r<=0)throw new _("random bytes length must be a Number bigger than 0","ERR_INVALID_LENGTH");return Wt(r)}var yt={};Q(yt,{exportToPem:()=>lf,importFromPem:()=>oo,jwkToPkcs1:()=>sf,jwkToPkix:()=>af,pkcs1ToJwk:()=>nf,pkixToJwk:()=>of});var rn=class extends Zt{constructor(e,t){super(),this.finished=!1,this.destroyed=!1,Hr(e);let n=st(t);if(this.iHash=e.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?e.create().update(n).digest():n);for(let i=0;i<o.length;i++)o[i]^=54;this.iHash.update(o),this.oHash=e.create();for(let i=0;i<o.length;i++)o[i]^=106;this.oHash.update(o),o.fill(0)}update(e){return Gt(this),this.iHash.update(e),this}digestInto(e){Gt(this),zt(e,this.outputLen),this.finished=!0,this.iHash.digestInto(e),this.oHash.update(e),this.oHash.digestInto(e),this.destroy()}digest(){let e=new Uint8Array(this.oHash.outputLen);return this.digestInto(e),e}_cloneInto(e){e||(e=Object.create(Object.getPrototypeOf(this),{}));let{oHash:t,iHash:n,finished:s,destroyed:o,blockLen:i,outputLen:a}=this;return e=e,e.finished=s,e.destroyed=o,e.blockLen=i,e.outputLen=a,e.oHash=t._cloneInto(e.oHash),e.iHash=n._cloneInto(e.iHash),e}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},wr=(r,e,t)=>new rn(r,e).update(t).digest();wr.create=(r,e)=>new rn(r,e);function Ki(r,e,t,n){Hr(r);let s=Qo({dkLen:32,asyncTick:10},n),{c:o,dkLen:i,asyncTick:a}=s;if(jt(o),jt(i),jt(a),o<1)throw new Error("PBKDF2: iterations (c) should be >= 1");let c=st(e),f=st(t),u=new Uint8Array(i),l=wr.create(r,c),p=l._cloneInto().update(f);return{c:o,dkLen:i,asyncTick:a,DK:u,PRF:l,PRFSalt:p}}function Fi(r,e,t,n,s){return r.destroy(),e.destroy(),n&&n.destroy(),s.fill(0),t}function $i(r,e,t,n){let{c:s,dkLen:o,DK:i,PRF:a,PRFSalt:c}=Ki(r,e,t,n),f,u=new Uint8Array(4),l=kt(u),p=new Uint8Array(a.outputLen);for(let B=1,g=0;g<o;B++,g+=a.outputLen){let h=i.subarray(g,g+a.outputLen);l.setInt32(0,B,!1),(f=c._cloneInto(f)).update(u).digestInto(p),h.set(p.subarray(0,h.length));for(let m=1;m<s;m++){a._cloneInto(f).update(p).digestInto(p);for(let w=0;w<h.length;w++)h[w]^=p[w]}}return Fi(a,c,i,f,p)}async function Xs(r,e,t,n){let{c:s,dkLen:o,asyncTick:i,DK:a,PRF:c,PRFSalt:f}=Ki(r,e,t,n),u,l=new Uint8Array(4),p=kt(l),B=new Uint8Array(c.outputLen);for(let g=1,h=0;h<o;g++,h+=c.outputLen){let m=a.subarray(h,h+c.outputLen);p.setInt32(0,g,!1),(u=f._cloneInto(u)).update(l).digestInto(B),m.set(B.subarray(0,m.length)),await Jo(s-1,i,()=>{c._cloneInto(u).update(B).digestInto(B);for(let w=0;w<m.length;w++)m[w]^=B[w]})}return Fi(c,f,a,u,B)}var D=fc(qi());function Lt(r,e){let t=0;if(r.length===1)return r[0];for(let n=r.length-1;n>=0;n--)t+=r[r.length-1-n]*Math.pow(2,e*n);return t}function dt(r,e,t=-1){let n=t,s=r,o=0,i=Math.pow(2,e);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 u=a-1;u>=0;u--){let l=Math.pow(2,u*e);f[o-u-1]=Math.floor(s/l),s-=f[o-u-1]*l}return c}i*=Math.pow(2,e)}return new ArrayBuffer(0)}function on(...r){let e=0,t=0;for(let o of r)e+=o.length;let n=new ArrayBuffer(e),s=new Uint8Array(n);for(let o of r)s.set(o,t),t+=o.length;return s}function eo(){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 e=new ArrayBuffer(this.valueHex.byteLength),t=new Uint8Array(e);for(let a=0;a<this.valueHex.byteLength;a++)t[a]=0;t[0]=r[0]&128;let n=Lt(t,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,Lt(o,8)-n}function ji(r){let e=r<0?r*-1:r,t=128;for(let n=1;n<8;n++){if(e<=t){if(r<0){let i=t-e,a=dt(i,8,n),c=new Uint8Array(a);return c[0]|=128,a}let s=dt(e,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}t*=Math.pow(2,8)}return new ArrayBuffer(0)}function zi(r,e){if(r.byteLength!==e.byteLength)return!1;let t=new Uint8Array(r),n=new Uint8Array(e);for(let s=0;s<t.length;s++)if(t[s]!==n[s])return!1;return!0}function be(r,e){let t=r.toString(10);if(e<t.length)return"";let n=e-t.length,s=new Array(n);for(let i=0;i<n;i++)s[i]="0";return s.join("").concat(t)}var M0=Math.log(2);function an(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function to(r){let e=0,t=0;for(let s=0;s<r.length;s++){let o=r[s];e+=o.byteLength}let n=new Uint8Array(e);for(let s=0;s<r.length;s++){let o=r[s];n.set(new Uint8Array(o),t),t+=o.byteLength}return n.buffer}function et(r,e,t,n){return e instanceof Uint8Array?e.byteLength?t<0?(r.error="Wrong parameter: inputOffset less than zero",!1):n<0?(r.error="Wrong parameter: inputLength less than zero",!1):e.byteLength-t-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 Br=class{constructor(){this.items=[]}write(e){this.items.push(e)}final(){return to(this.items)}},xr=[new Uint8Array([1])],Gi="0123456789";var ir="",Le=new ArrayBuffer(0),ro=new Uint8Array(0),vr="EndOfContent",Yi="OCTET STRING",Wi="BIT STRING";function tt(r){var e;return e=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?D.BufferSourceConverter.toUint8Array(o.valueHex):ro}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(!et(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",Le)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:D.Convert.ToHex(this.valueHexView)}}},e.NAME="hexBlock",e}var Je=class{constructor({blockLength:e=0,error:t=ir,warnings:n=[],valueBeforeDecode:s=ro}={}){this.blockLength=e,this.error=t,this.warnings=n,this.valueBeforeDecodeView=D.BufferSourceConverter.toUint8Array(s)}static blockName(){return this.NAME}get valueBeforeDecode(){return this.valueBeforeDecodeView.slice().buffer}set valueBeforeDecode(e){this.valueBeforeDecodeView=new Uint8Array(e)}toJSON(){return{blockName:this.constructor.NAME,blockLength:this.blockLength,error:this.error,warnings:this.warnings,valueBeforeDecode:D.Convert.ToHex(this.valueBeforeDecodeView)}}};Je.NAME="baseBlock";var he=class extends Je{fromBER(e,t,n){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}toBER(e,t){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}};he.NAME="valueBlock";var cn=class extends tt(Je){constructor({idBlock:e={}}={}){var t,n,s,o;super(),e?(this.isHexOnly=(t=e.isHexOnly)!==null&&t!==void 0?t:!1,this.valueHexView=e.valueHex?D.BufferSourceConverter.toUint8Array(e.valueHex):ro,this.tagClass=(n=e.tagClass)!==null&&n!==void 0?n:-1,this.tagNumber=(s=e.tagNumber)!==null&&s!==void 0?s:-1,this.isConstructed=(o=e.isConstructed)!==null&&o!==void 0?o:!1):(this.tagClass=-1,this.tagNumber=-1,this.isConstructed=!1)}toBER(e=!1){let t=0;switch(this.tagClass){case 1:t|=0;break;case 2:t|=64;break;case 3:t|=128;break;case 4:t|=192;break;default:return this.error="Unknown tag class",Le}if(this.isConstructed&&(t|=32),this.tagNumber<31&&!this.isHexOnly){let s=new Uint8Array(1);if(!e){let o=this.tagNumber;o&=31,t|=o,s[0]=t}return s.buffer}if(!this.isHexOnly){let s=dt(this.tagNumber,7),o=new Uint8Array(s),i=s.byteLength,a=new Uint8Array(i+1);if(a[0]=t|31,!e){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]=t|31,!e){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(e,t,n){let s=D.BufferSourceConverter.toUint8Array(e);if(!et(this,s,t,n))return-1;let o=s.subarray(t,t+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),u=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===u){u+=255;let p=new Uint8Array(u);for(let B=0;B<f.length;B++)p[B]=f[B];f=this.valueHexView=new Uint8Array(u)}}this.blockLength=c+1,f[c-1]=o[c]&127;let l=new Uint8Array(c);for(let p=0;p<c;p++)l[p]=f[p];f=this.valueHexView=new Uint8Array(c),f.set(l),this.blockLength<=9?this.tagNumber=Lt(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 t+this.blockLength}toJSON(){return{...super.toJSON(),tagClass:this.tagClass,tagNumber:this.tagNumber,isConstructed:this.isConstructed}}};cn.NAME="identificationBlock";var ln=class extends Je{constructor({lenBlock:e={}}={}){var t,n,s;super(),this.isIndefiniteForm=(t=e.isIndefiniteForm)!==null&&t!==void 0?t:!1,this.longFormUsed=(n=e.longFormUsed)!==null&&n!==void 0?n:!1,this.length=(s=e.length)!==null&&s!==void 0?s:0}fromBER(e,t,n){let s=D.BufferSourceConverter.toUint8Array(e);if(!et(this,s,t,n))return-1;let o=s.subarray(t,t+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,t+this.blockLength;if(this.longFormUsed=!!(o[0]&128),this.longFormUsed===!1)return this.length=o[0],this.blockLength=1,t+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=t+1,c=s.subarray(a,a+i);return c[i-1]===0&&this.warnings.push("Needlessly long encoded length"),this.length=Lt(c,8),this.longFormUsed&&this.length<=127&&this.warnings.push("Unnecessary usage of long length form"),this.blockLength=i+1,t+this.blockLength}toBER(e=!1){let t,n;if(this.length>127&&(this.longFormUsed=!0),this.isIndefiniteForm)return t=new ArrayBuffer(1),e===!1&&(n=new Uint8Array(t),n[0]=128),t;if(this.longFormUsed){let s=dt(this.length,8);if(s.byteLength>127)return this.error="Too big length",Le;if(t=new ArrayBuffer(s.byteLength+1),e)return t;let o=new Uint8Array(s);n=new Uint8Array(t),n[0]=s.byteLength|128;for(let i=0;i<s.byteLength;i++)n[i+1]=o[i];return t}return t=new ArrayBuffer(1),e===!1&&(n=new Uint8Array(t),n[0]=this.length),t}toJSON(){return{...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,longFormUsed:this.longFormUsed,length:this.length}}};ln.NAME="lengthBlock";var A={},ue=class extends Je{constructor({name:e=ir,optional:t=!1,primitiveSchema:n,...s}={},o){super(s),this.name=e,this.optional=t,n&&(this.primitiveSchema=n),this.idBlock=new cn(s),this.lenBlock=new ln(s),this.valueBlock=o?new o(s):new he(s)}fromBER(e,t,n){let s=this.valueBlock.fromBER(e,t,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(e,t){let n=t||new Br;t||Ji(this);let s=this.idBlock.toBER(e);if(n.write(s),this.lenBlock.isIndefiniteForm)n.write(new Uint8Array([128]).buffer),this.valueBlock.toBER(e,n),n.write(new ArrayBuffer(2));else{let o=this.valueBlock.toBER(e);this.lenBlock.length=o.byteLength;let i=this.lenBlock.toBER(e);n.write(i),n.write(o)}return t?Le:n.final()}toJSON(){let e={...super.toJSON(),idBlock:this.idBlock.toJSON(),lenBlock:this.lenBlock.toJSON(),valueBlock:this.valueBlock.toJSON(),name:this.name,optional:this.optional};return this.primitiveSchema&&(e.primitiveSchema=this.primitiveSchema.toJSON()),e}toString(e="ascii"){return e==="ascii"?this.onAsciiEncoding():D.Convert.ToHex(this.toBER())}onAsciiEncoding(){return`${this.constructor.NAME} : ${D.Convert.ToHex(this.valueBlock.valueBeforeDecodeView)}`}isEqual(e){if(this===e)return!0;if(!(e instanceof this.constructor))return!1;let t=this.toBER(),n=e.toBER();return zi(t,n)}};ue.NAME="BaseBlock";function Ji(r){if(r instanceof A.Constructed)for(let e of r.valueBlock.value)Ji(e)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var un=class extends ue{constructor({value:e=ir,...t}={},n){super(t,n),e&&this.fromString(e)}getValue(){return this.valueBlock.value}setValue(e){this.valueBlock.value=e}fromBER(e,t,n){let s=this.valueBlock.fromBER(e,t,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}'`}};un.NAME="BaseStringBlock";var fn=class extends tt(he){constructor({isHexOnly:e=!0,...t}={}){super(t),this.isHexOnly=e}};fn.NAME="PrimitiveValueBlock";var Xi,hn=class extends ue{constructor(e={}){super(e,fn),this.idBlock.isConstructed=!1}};Xi=hn;A.Primitive=Xi;hn.NAME="PRIMITIVE";function Xu(r,e){if(r instanceof e)return r;let t=new e;return t.idBlock=r.idBlock,t.lenBlock=r.lenBlock,t.warnings=r.warnings,t.valueBeforeDecodeView=r.valueBeforeDecodeView,t}function jn(r,e=0,t=r.length){let n=e,s=new ue({},he),o=new Je;if(!et(o,r,e,t))return s.error=o.error,{offset:-1,result:s};if(!r.subarray(e,e+t).length)return s.error="Zero buffer length",{offset:-1,result:s};let a=s.idBlock.fromBER(r,e,t);if(s.idBlock.warnings.length&&s.warnings.concat(s.idBlock.warnings),a===-1)return s.error=s.idBlock.error,{offset:-1,result:s};if(e=a,t-=s.idBlock.blockLength,a=s.lenBlock.fromBER(r,e,t),s.lenBlock.warnings.length&&s.warnings.concat(s.lenBlock.warnings),a===-1)return s.error=s.lenBlock.error,{offset:-1,result:s};if(e=a,t-=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=ue;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=Xu(s,c),a=s.fromBER(r,e,s.lenBlock.isIndefiniteForm?t:s.lenBlock.length),s.valueBeforeDecodeView=r.subarray(n,n+s.blockLength),{offset:a,result:s}}function ar(r){if(!r.byteLength){let e=new ue({},he);return e.error="Input buffer has zero length",{offset:-1,result:e}}return jn(D.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function Qu(r,e){return r?1:e}var Oe=class extends he{constructor({value:e=[],isIndefiniteForm:t=!1,...n}={}){super(n),this.value=e,this.isIndefiniteForm=t}fromBER(e,t,n){let s=D.BufferSourceConverter.toUint8Array(e);if(!et(this,s,t,n))return-1;if(this.valueBeforeDecodeView=s.subarray(t,t+n),this.valueBeforeDecodeView.length===0)return this.warnings.push("Zero buffer length"),t;let o=t;for(;Qu(this.isIndefiniteForm,n)>0;){let i=jn(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===vr)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===vr?this.value.pop():this.warnings.push("No EndOfContent block encoded")),o}toBER(e,t){let n=t||new Br;for(let s=0;s<this.value.length;s++)this.value[s].toBER(e,n);return t?Le:n.final()}toJSON(){let e={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let t of this.value)e.value.push(t.toJSON());return e}};Oe.NAME="ConstructedValueBlock";var Qi,gt=class extends ue{constructor(e={}){super(e,Oe),this.idBlock.isConstructed=!0}fromBER(e,t,n){this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm;let s=this.valueBlock.fromBER(e,t,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 e=[];for(let n of this.valueBlock.value)e.push(n.toString("ascii").split(`
2
+ "use strict";var Libp2PCrypto=(()=>{var cc=Object.create;var Lr=Object.defineProperty;var lc=Object.getOwnPropertyDescriptor;var uc=Object.getOwnPropertyNames;var fc=Object.getPrototypeOf,hc=Object.prototype.hasOwnProperty;var dc=(r,e)=>()=>(e||r((e={exports:{}}).exports,e),e.exports),Q=(r,e)=>{for(var t in e)Lr(r,t,{get:e[t],enumerable:!0})},Co=(r,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of uc(e))!hc.call(r,s)&&s!==t&&Lr(r,s,{get:()=>e[s],enumerable:!(n=lc(e,s))||n.enumerable});return r};var gc=(r,e,t)=>(t=r!=null?cc(fc(r)):{},Co(e||!r||!r.__esModule?Lr(t,"default",{value:r,enumerable:!0}):t,r)),pc=r=>Co(Lr({},"__esModule",{value:!0}),r);var zi=dc(ar=>{"use strict";var zu="[object ArrayBuffer]",Je=class r{static isArrayBuffer(e){return Object.prototype.toString.call(e)===zu}static toArrayBuffer(e){return this.isArrayBuffer(e)?e:e.byteLength===e.buffer.byteLength||e.byteOffset===0&&e.byteLength===e.buffer.byteLength?e.buffer:this.toUint8Array(e.buffer).slice(e.byteOffset,e.byteOffset+e.byteLength).buffer}static toUint8Array(e){return this.toView(e,Uint8Array)}static toView(e,t){if(e.constructor===t)return e;if(this.isArrayBuffer(e))return new t(e);if(this.isArrayBufferView(e))return new t(e.buffer,e.byteOffset,e.byteLength);throw new TypeError("The provided value is not of type '(ArrayBuffer or ArrayBufferView)'")}static isBufferSource(e){return this.isArrayBufferView(e)||this.isArrayBuffer(e)}static isArrayBufferView(e){return ArrayBuffer.isView(e)||e&&this.isArrayBuffer(e.buffer)}static isEqual(e,t){let n=r.toUint8Array(e),s=r.toUint8Array(t);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(...e){let t;Array.isArray(e[0])&&!(e[1]instanceof Function)||Array.isArray(e[0])&&e[1]instanceof Function?t=e[0]:e[e.length-1]instanceof Function?t=e.slice(0,e.length-1):t=e;let n=0;for(let i of t)n+=i.byteLength;let s=new Uint8Array(n),o=0;for(let i of t){let a=this.toUint8Array(i);s.set(a,o),o+=a.length}return e[e.length-1]instanceof Function?this.toView(s,e[e.length-1]):s.buffer}},ro="string",Gu=/^[0-9a-f]+$/i,Zu=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,Yu=/^[a-zA-Z0-9-_]+$/,on=class{static fromString(e){let t=unescape(encodeURIComponent(e)),n=new Uint8Array(t.length);for(let s=0;s<t.length;s++)n[s]=t.charCodeAt(s);return n.buffer}static toString(e){let t=Je.toUint8Array(e),n="";for(let o=0;o<t.length;o++)n+=String.fromCharCode(t[o]);return decodeURIComponent(escape(n))}},ke=class{static toString(e,t=!1){let n=Je.toArrayBuffer(e),s=new DataView(n),o="";for(let i=0;i<n.byteLength;i+=2){let a=s.getUint16(i,t);o+=String.fromCharCode(a)}return o}static fromString(e,t=!1){let n=new ArrayBuffer(e.length*2),s=new DataView(n);for(let o=0;o<e.length;o++)s.setUint16(o*2,e.charCodeAt(o),t);return n}},an=class r{static isHex(e){return typeof e===ro&&Gu.test(e)}static isBase64(e){return typeof e===ro&&Zu.test(e)}static isBase64Url(e){return typeof e===ro&&Yu.test(e)}static ToString(e,t="utf8"){let n=Je.toUint8Array(e);switch(t.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 ke.toString(n,!0);case"utf16":case"utf16be":return ke.toString(n);default:throw new Error(`Unknown type of encoding '${t}'`)}}static FromString(e,t="utf8"){if(!e)return new ArrayBuffer(0);switch(t.toLowerCase()){case"utf8":return this.FromUtf8String(e);case"binary":return this.FromBinary(e);case"hex":return this.FromHex(e);case"base64":return this.FromBase64(e);case"base64url":return this.FromBase64Url(e);case"utf16le":return ke.fromString(e,!0);case"utf16":case"utf16be":return ke.fromString(e);default:throw new Error(`Unknown type of encoding '${t}'`)}}static ToBase64(e){let t=Je.toUint8Array(e);if(typeof btoa<"u"){let n=this.ToString(t,"binary");return btoa(n)}else return Buffer.from(t).toString("base64")}static FromBase64(e){let t=this.formatString(e);if(!t)return new ArrayBuffer(0);if(!r.isBase64(t))throw new TypeError("Argument 'base64Text' is not Base64 encoded");return typeof atob<"u"?this.FromBinary(atob(t)):new Uint8Array(Buffer.from(t,"base64")).buffer}static FromBase64Url(e){let t=this.formatString(e);if(!t)return new ArrayBuffer(0);if(!r.isBase64Url(t))throw new TypeError("Argument 'base64url' is not Base64Url encoded");return this.FromBase64(this.Base64Padding(t.replace(/\-/g,"+").replace(/\_/g,"/")))}static ToBase64Url(e){return this.ToBase64(e).replace(/\+/g,"-").replace(/\//g,"_").replace(/\=/g,"")}static FromUtf8String(e,t=r.DEFAULT_UTF8_ENCODING){switch(t){case"ascii":return this.FromBinary(e);case"utf8":return on.fromString(e);case"utf16":case"utf16be":return ke.fromString(e);case"utf16le":case"usc2":return ke.fromString(e,!0);default:throw new Error(`Unknown type of encoding '${t}'`)}}static ToUtf8String(e,t=r.DEFAULT_UTF8_ENCODING){switch(t){case"ascii":return this.ToBinary(e);case"utf8":return on.toString(e);case"utf16":case"utf16be":return ke.toString(e);case"utf16le":case"usc2":return ke.toString(e,!0);default:throw new Error(`Unknown type of encoding '${t}'`)}}static FromBinary(e){let t=e.length,n=new Uint8Array(t);for(let s=0;s<t;s++)n[s]=e.charCodeAt(s);return n.buffer}static ToBinary(e){let t=Je.toUint8Array(e),n="";for(let s=0;s<t.length;s++)n+=String.fromCharCode(t[s]);return n}static ToHex(e){let t=Je.toUint8Array(e),n="",s=t.length;for(let o=0;o<s;o++){let i=t[o];i<16&&(n+="0"),n+=i.toString(16)}return n}static FromHex(e){let t=this.formatString(e);if(!t)return new ArrayBuffer(0);if(!r.isHex(t))throw new TypeError("Argument 'hexString' is not HEX encoded");t.length%2&&(t=`0${t}`);let n=new Uint8Array(t.length/2);for(let s=0;s<t.length;s=s+2){let o=t.slice(s,s+2);n[s/2]=parseInt(o,16)}return n.buffer}static ToUtf16String(e,t=!1){return ke.toString(e,t)}static FromUtf16String(e,t=!1){return ke.fromString(e,t)}static Base64Padding(e){let t=4-e.length%4;if(t<4)for(let n=0;n<t;n++)e+="=";return e}static formatString(e){return e?.replace(/[\n\r\t ]/g,"")||""}};an.DEFAULT_UTF8_ENCODING="utf8";function Wu(r,...e){let t=arguments[0];for(let n=1;n<arguments.length;n++){let s=arguments[n];for(let o in s)t[o]=s[o]}return t}function Ju(...r){let e=r.map(s=>s.byteLength).reduce((s,o)=>s+o),t=new Uint8Array(e),n=0;return r.map(s=>new Uint8Array(s)).forEach(s=>{for(let o of s)t[n++]=o}),t.buffer}function Xu(r,e){if(!(r&&e)||r.byteLength!==e.byteLength)return!1;let t=new Uint8Array(r),n=new Uint8Array(e);for(let s=0;s<r.byteLength;s++)if(t[s]!==n[s])return!1;return!0}ar.BufferSourceConverter=Je;ar.Convert=an;ar.assign=Wu;ar.combine=Ju;ar.isEqual=Xu});var Of={};Q(Of,{hmac:()=>Vr,keys:()=>xo,pbkdf2:()=>Bo,randomBytes:()=>We});var Vr={};Q(Vr,{create:()=>Jn});var G={get(r=globalThis){let e=r.crypto;if(e?.subtle==null)throw Object.assign(new Error("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"),{code:"ERR_MISSING_WEB_CRYPTO"});return e}};var To={SHA1:20,SHA256:32,SHA512:64};var yc={SHA1:"SHA-1",SHA256:"SHA-256",SHA512:"SHA-512"},mc=async(r,e)=>{let t=await G.get().subtle.sign({name:"HMAC"},r,e);return new Uint8Array(t,0,t.byteLength)};async function Jn(r,e){let t=yc[r],n=await G.get().subtle.importKey("raw",e,{name:"HMAC",hash:{name:t}},!1,["sign"]);return{async digest(s){return mc(n,s)},length:To[r]}}var xo={};Q(xo,{Ed25519PrivateKey:()=>Ye,Ed25519PublicKey:()=>Ot,MAX_RSA_KEY_SIZE:()=>Mt,RsaPrivateKey:()=>vt,RsaPublicKey:()=>Pt,Secp256k1PrivateKey:()=>Ft,Secp256k1PublicKey:()=>Kt,generateEphemeralKeyPair:()=>Pi,generateKeyPair:()=>Tf,generateKeyPairFromSeed:()=>_f,importKey:()=>Hf,keyStretcher:()=>Fi,keysPBM:()=>or,marshalPrivateKey:()=>Vf,marshalPublicKey:()=>Lf,supportedKeys:()=>ot,unmarshalPrivateKey:()=>Ja,unmarshalPublicKey:()=>Uf});var U=class extends Error{code;props;constructor(e,t,n){super(e),this.code=t,this.name=n?.name??"CodeError",this.props=n??{}}};var Qs={};Q(Qs,{Ed25519PrivateKey:()=>Ye,Ed25519PublicKey:()=>Ot,generateKeyPair:()=>Fu,generateKeyPairFromSeed:()=>Xs,unmarshalEd25519PrivateKey:()=>Mu,unmarshalEd25519PublicKey:()=>Ku});var rs={};Q(rs,{base58btc:()=>Ee,base58flickr:()=>Ec});var qf=new Uint8Array(0);function _o(r,e){if(r===e)return!0;if(r.byteLength!==e.byteLength)return!1;for(let t=0;t<r.byteLength;t++)if(r[t]!==e[t])return!1;return!0}function Fe(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 Uo(r){return new TextEncoder().encode(r)}function Lo(r){return new TextDecoder().decode(r)}function bc(r,e){if(r.length>=255)throw new TypeError("Alphabet too long");for(var t=new Uint8Array(256),n=0;n<t.length;n++)t[n]=255;for(var s=0;s<r.length;s++){var o=r.charAt(s),i=o.charCodeAt(0);if(t[i]!==255)throw new TypeError(o+" is ambiguous");t[i]=s}var a=r.length,c=r.charAt(0),u=Math.log(a)/Math.log(256),l=Math.log(256)/Math.log(a);function f(x){if(x instanceof Uint8Array||(ArrayBuffer.isView(x)?x=new Uint8Array(x.buffer,x.byteOffset,x.byteLength):Array.isArray(x)&&(x=Uint8Array.from(x))),!(x instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(x.length===0)return"";for(var y=0,d=0,m=0,v=x.length;m!==v&&x[m]===0;)m++,y++;for(var g=(v-m)*l+1>>>0,E=new Uint8Array(g);m!==v;){for(var _=x[m],T=0,S=g-1;(_!==0||T<d)&&S!==-1;S--,T++)_+=256*E[S]>>>0,E[S]=_%a>>>0,_=_/a>>>0;if(_!==0)throw new Error("Non-zero carry");d=T,m++}for(var I=g-d;I!==g&&E[I]===0;)I++;for(var C=c.repeat(y);I<g;++I)C+=r.charAt(E[I]);return C}function h(x){if(typeof x!="string")throw new TypeError("Expected String");if(x.length===0)return new Uint8Array;var y=0;if(x[y]!==" "){for(var d=0,m=0;x[y]===c;)d++,y++;for(var v=(x.length-y)*u+1>>>0,g=new Uint8Array(v);x[y];){var E=t[x.charCodeAt(y)];if(E===255)return;for(var _=0,T=v-1;(E!==0||_<m)&&T!==-1;T--,_++)E+=a*g[T]>>>0,g[T]=E%256>>>0,E=E/256>>>0;if(E!==0)throw new Error("Non-zero carry");m=_,y++}if(x[y]!==" "){for(var S=v-m;S!==v&&g[S]===0;)S++;for(var I=new Uint8Array(d+(v-S)),C=d;S!==v;)I[C++]=g[S++];return I}}}function w(x){var y=h(x);if(y)return y;throw new Error(`Non-${e} character`)}return{encode:f,decodeUnsafe:h,decode:w}}var wc=bc,xc=wc,Ho=xc;var Xn=class{name;prefix;baseEncode;constructor(e,t,n){this.name=e,this.prefix=t,this.baseEncode=n}encode(e){if(e instanceof Uint8Array)return`${this.prefix}${this.baseEncode(e)}`;throw Error("Unknown type, must be binary type")}},Qn=class{name;prefix;baseDecode;prefixCodePoint;constructor(e,t,n){if(this.name=e,this.prefix=t,t.codePointAt(0)===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=t.codePointAt(0),this.baseDecode=n}decode(e){if(typeof e=="string"){if(e.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(e)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(e.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(e){return Oo(this,e)}},es=class{decoders;constructor(e){this.decoders=e}or(e){return Oo(this,e)}decode(e){let t=e[0],n=this.decoders[t];if(n!=null)return n.decode(e);throw RangeError(`Unable to decode multibase string ${JSON.stringify(e)}, only inputs prefixed with ${Object.keys(this.decoders)} are supported`)}};function Oo(r,e){return new es({...r.decoders??{[r.prefix]:r},...e.decoders??{[e.prefix]:e}})}var ts=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(e,t,n,s){this.name=e,this.prefix=t,this.baseEncode=n,this.baseDecode=s,this.encoder=new Xn(e,t,n),this.decoder=new Qn(e,t,s)}encode(e){return this.encoder.encode(e)}decode(e){return this.decoder.decode(e)}};function $t({name:r,prefix:e,encode:t,decode:n}){return new ts(r,e,t,n)}function it({name:r,prefix:e,alphabet:t}){let{encode:n,decode:s}=Ho(t,r);return $t({prefix:e,name:r,encode:n,decode:o=>Fe(s(o))})}function vc(r,e,t,n){let s={};for(let l=0;l<e.length;++l)s[e[l]]=l;let o=r.length;for(;r[o-1]==="=";)--o;let i=new Uint8Array(o*t/8|0),a=0,c=0,u=0;for(let l=0;l<o;++l){let f=s[r[l]];if(f===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<t|f,a+=t,a>=8&&(a-=8,i[u++]=255&c>>a)}if(a>=t||255&c<<8-a)throw new SyntaxError("Unexpected end of data");return i}function Bc(r,e,t){let n=e[e.length-1]==="=",s=(1<<t)-1,o="",i=0,a=0;for(let c=0;c<r.length;++c)for(a=a<<8|r[c],i+=8;i>t;)i-=t,o+=e[s&a>>i];if(i!==0&&(o+=e[s&a<<t-i]),n)for(;o.length*t&7;)o+="=";return o}function J({name:r,prefix:e,bitsPerChar:t,alphabet:n}){return $t({prefix:e,name:r,encode(s){return Bc(s,n,t)},decode(s){return vc(s,n,t,r)}})}var Ee=it({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),Ec=it({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var os={};Q(os,{identity:()=>ss});var Ac=Mo,Do=128,kc=127,Sc=~kc,Ic=Math.pow(2,31);function Mo(r,e,t){e=e||[],t=t||0;for(var n=t;r>=Ic;)e[t++]=r&255|Do,r/=128;for(;r&Sc;)e[t++]=r&255|Do,r>>>=7;return e[t]=r|0,Mo.bytes=t-n+1,e}var Nc=ns,Rc=128,Po=127;function ns(r,n){var t=0,n=n||0,s=0,o=n,i,a=r.length;do{if(o>=a)throw ns.bytes=0,new RangeError("Could not decode varint");i=r[o++],t+=s<28?(i&Po)<<s:(i&Po)*Math.pow(2,s),s+=7}while(i>=Rc);return ns.bytes=o-n,t}var Cc=Math.pow(2,7),Tc=Math.pow(2,14),_c=Math.pow(2,21),Uc=Math.pow(2,28),Lc=Math.pow(2,35),Vc=Math.pow(2,42),Hc=Math.pow(2,49),Oc=Math.pow(2,56),Dc=Math.pow(2,63),Pc=function(r){return r<Cc?1:r<Tc?2:r<_c?3:r<Uc?4:r<Lc?5:r<Vc?6:r<Hc?7:r<Oc?8:r<Dc?9:10},Mc={encode:Ac,decode:Nc,encodingLength:Pc},Kc=Mc,dr=Kc;function gr(r,e=0){return[dr.decode(r,e),dr.decode.bytes]}function qt(r,e,t=0){return dr.encode(r,e,t),e}function jt(r){return dr.encodingLength(r)}function kt(r,e){let t=e.byteLength,n=jt(r),s=n+jt(t),o=new Uint8Array(s+t);return qt(r,o,0),qt(t,o,n),o.set(e,s),new zt(r,t,e,o)}function Ko(r){let e=Fe(r),[t,n]=gr(e),[s,o]=gr(e.subarray(n)),i=e.subarray(n+o);if(i.byteLength!==s)throw new Error("Incorrect length");return new zt(t,s,i,e)}function Fo(r,e){if(r===e)return!0;{let t=e;return r.code===t.code&&r.size===t.size&&t.bytes instanceof Uint8Array&&_o(r.bytes,t.bytes)}}var zt=class{code;size;digest;bytes;constructor(e,t,n,s){this.code=e,this.size=t,this.digest=n,this.bytes=s}};var $o=0,Fc="identity",qo=Fe;function $c(r){return kt($o,qo(r))}var ss={code:$o,name:Fc,encode:qo,digest:$c};var cs={};Q(cs,{sha256:()=>ve,sha512:()=>qc});function as({name:r,code:e,encode:t}){return new is(r,e,t)}var is=class{name;code;encode;constructor(e,t,n){this.name=e,this.code=t,this.encode=n}digest(e){if(e instanceof Uint8Array){let t=this.encode(e);return t instanceof Uint8Array?kt(this.code,t):t.then(n=>kt(this.code,n))}else throw Error("Unknown type, must be binary type")}};function zo(r){return async e=>new Uint8Array(await crypto.subtle.digest(r,e))}var ve=as({name:"sha2-256",code:18,encode:zo("SHA-256")}),qc=as({name:"sha2-512",code:19,encode:zo("SHA-512")});function Se(r,e){if(r===e)return!0;if(r.byteLength!==e.byteLength)return!1;for(let t=0;t<r.byteLength;t++)if(r[t]!==e[t])return!1;return!0}function He(r=0){return new Uint8Array(r)}function $e(r,e){e==null&&(e=r.reduce((s,o)=>s+o.length,0));let t=He(e),n=0;for(let s of r)t.set(s,n),n+=s.length;return t}var ls={};Q(ls,{base10:()=>jc});var jc=it({prefix:"9",name:"base10",alphabet:"0123456789"});var us={};Q(us,{base16:()=>zc,base16upper:()=>Gc});var zc=J({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Gc=J({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var fs={};Q(fs,{base2:()=>Zc});var Zc=J({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var hs={};Q(hs,{base256emoji:()=>Qc});var Go=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}"),Yc=Go.reduce((r,e,t)=>(r[t]=e,r),[]),Wc=Go.reduce((r,e,t)=>(r[e.codePointAt(0)]=t,r),[]);function Jc(r){return r.reduce((e,t)=>(e+=Yc[t],e),"")}function Xc(r){let e=[];for(let t of r){let n=Wc[t.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${t}`);e.push(n)}return new Uint8Array(e)}var Qc=$t({prefix:"\u{1F680}",name:"base256emoji",encode:Jc,decode:Xc});var ds={};Q(ds,{base32:()=>Gt,base32hex:()=>nl,base32hexpad:()=>ol,base32hexpadupper:()=>il,base32hexupper:()=>sl,base32pad:()=>tl,base32padupper:()=>rl,base32upper:()=>el,base32z:()=>al});var Gt=J({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),el=J({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),tl=J({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),rl=J({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),nl=J({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),sl=J({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),ol=J({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),il=J({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),al=J({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var gs={};Q(gs,{base36:()=>cl,base36upper:()=>ll});var cl=it({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),ll=it({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var ps={};Q(ps,{base64:()=>St,base64pad:()=>ul,base64url:()=>fl,base64urlpad:()=>hl});var St=J({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),ul=J({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),fl=J({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),hl=J({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var ys={};Q(ys,{base8:()=>dl});var dl=J({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var ms={};Q(ms,{identity:()=>gl});var gl=$t({prefix:"\0",name:"identity",encode:r=>Lo(r),decode:r=>Uo(r)});var bh=new TextEncoder,wh=new TextDecoder;function Zo(r,e){let{bytes:t,version:n}=r;switch(n){case 0:return bl(t,bs(r),e??Ee.encoder);default:return wl(t,bs(r),e??Gt.encoder)}}var Yo=new WeakMap;function bs(r){let e=Yo.get(r);if(e==null){let t=new Map;return Yo.set(r,t),t}return e}var Or=class r{code;version;multihash;bytes;"/";constructor(e,t,n,s){this.code=t,this.version=e,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:e,multihash:t}=this;if(e!==yr)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(t.code!==xl)throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");return r.createV0(t)}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:e,digest:t}=this.multihash,n=kt(e,t);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(e){return r.equals(this,e)}static equals(e,t){let n=t;return n!=null&&e.code===n.code&&e.version===n.version&&Fo(e.multihash,n.multihash)}toString(e){return Zo(this,e)}toJSON(){return{"/":Zo(this)}}link(){return this}[Symbol.toStringTag]="CID";[Symbol.for("nodejs.util.inspect.custom")](){return`CID(${this.toString()})`}static asCID(e){if(e==null)return null;let t=e;if(t instanceof r)return t;if(t["/"]!=null&&t["/"]===t.bytes||t.asCID===t){let{version:n,code:s,multihash:o,bytes:i}=t;return new r(n,s,o,i??Wo(n,s,o.bytes))}else if(t[vl]===!0){let{version:n,multihash:s,code:o}=t,i=Ko(s);return r.create(n,o,i)}else return null}static create(e,t,n){if(typeof t!="number")throw new Error("String codecs are no longer supported");if(!(n.bytes instanceof Uint8Array))throw new Error("Invalid digest");switch(e){case 0:{if(t!==yr)throw new Error(`Version 0 CID must use dag-pb (code: ${yr}) block encoding`);return new r(e,t,n,n.bytes)}case 1:{let s=Wo(e,t,n.bytes);return new r(e,t,n,s)}default:throw new Error("Invalid version")}}static createV0(e){return r.create(0,yr,e)}static createV1(e,t){return r.create(1,e,t)}static decode(e){let[t,n]=r.decodeFirst(e);if(n.length!==0)throw new Error("Incorrect length");return t}static decodeFirst(e){let t=r.inspectBytes(e),n=t.size-t.multihashSize,s=Fe(e.subarray(n,n+t.multihashSize));if(s.byteLength!==t.multihashSize)throw new Error("Incorrect length");let o=s.subarray(t.multihashSize-t.digestSize),i=new zt(t.multihashCode,t.digestSize,o,s);return[t.version===0?r.createV0(i):r.createV1(t.codec,i),e.subarray(t.size)]}static inspectBytes(e){let t=0,n=()=>{let[f,h]=gr(e.subarray(t));return t+=h,f},s=n(),o=yr;if(s===18?(s=0,t=0):o=n(),s!==0&&s!==1)throw new RangeError(`Invalid CID version ${s}`);let i=t,a=n(),c=n(),u=t+c,l=u-i;return{version:s,codec:o,multihashCode:a,digestSize:c,multihashSize:l,size:u}}static parse(e,t){let[n,s]=ml(e,t),o=r.decode(s);if(o.version===0&&e[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return bs(o).set(n,e),o}};function ml(r,e){switch(r[0]){case"Q":{let t=e??Ee;return[Ee.prefix,t.decode(`${Ee.prefix}${r}`)]}case Ee.prefix:{let t=e??Ee;return[Ee.prefix,t.decode(r)]}case Gt.prefix:{let t=e??Gt;return[Gt.prefix,t.decode(r)]}default:{if(e==null)throw Error("To parse non base32 or base58btc encoded CID multibase decoder must be provided");return[r[0],e.decode(r)]}}}function bl(r,e,t){let{prefix:n}=t;if(n!==Ee.prefix)throw Error(`Cannot string encode V0 in ${t.name} encoding`);let s=e.get(n);if(s==null){let o=t.encode(r).slice(1);return e.set(n,o),o}else return s}function wl(r,e,t){let{prefix:n}=t,s=e.get(n);if(s==null){let o=t.encode(r);return e.set(n,o),o}else return s}var yr=112,xl=18;function Wo(r,e,t){let n=jt(r),s=n+jt(e),o=new Uint8Array(s+t.byteLength);return qt(r,o,0),qt(e,o,n),o.set(t,s),o}var vl=Symbol.for("@ipld/js-cid/CID");var ws={...ms,...fs,...ys,...ls,...us,...ds,...gs,...rs,...ps,...hs},Vh={...cs,...os};function Xo(r,e,t,n){return{name:r,prefix:e,encoder:{name:r,prefix:e,encode:t},decoder:{decode:n}}}var Jo=Xo("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),xs=Xo("ascii","a",r=>{let e="a";for(let t=0;t<r.length;t++)e+=String.fromCharCode(r[t]);return e},r=>{r=r.substring(1);let e=He(r.length);for(let t=0;t<r.length;t++)e[t]=r.charCodeAt(t);return e}),Bl={utf8:Jo,"utf-8":Jo,hex:ws.base16,latin1:xs,ascii:xs,binary:xs,...ws},Dr=Bl;function Z(r,e="utf8"){let t=Dr[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return t.decoder.decode(`${t.prefix}${r}`)}function vs(r,e){let t=Z(r,"base64urlpad");if(e!=null){if(t.length>e)throw new Error("byte array longer than desired length");t=$e([new Uint8Array(e-t.length),t])}return t}function Ae(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function Zt(r){if(!Number.isSafeInteger(r)||r<0)throw new Error(`positive integer expected, not ${r}`)}function El(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function Yt(r,...e){if(!El(r))throw new Error("Uint8Array expected");if(e.length>0&&!e.includes(r.length))throw new Error(`Uint8Array expected of length ${e}, not of length=${r.length}`)}function Pr(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");Zt(r.outputLen),Zt(r.blockLen)}function Wt(r,e=!0){if(r.destroyed)throw new Error("Hash instance has been destroyed");if(e&&r.finished)throw new Error("Hash#digest() has already been called")}function Qo(r,e){Yt(r);let t=e.outputLen;if(r.length<t)throw new Error(`digestInto() expects output buffer of length at least ${t}`)}var It=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;var Nt=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),Ie=(r,e)=>r<<32-e|r>>>e,Mr=(r,e)=>r<<e|r>>>32-e>>>0,Yh=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;var Al=async()=>{};async function ei(r,e,t){let n=Date.now();for(let s=0;s<r;s++){t(s);let o=Date.now()-n;o>=0&&o<e||(await Al(),n+=o)}}function ti(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function at(r){return typeof r=="string"&&(r=ti(r)),Yt(r),r}function Bs(...r){let e=0;for(let n=0;n<r.length;n++){let s=r[n];Yt(s),e+=s.length}let t=new Uint8Array(e);for(let n=0,s=0;n<r.length;n++){let o=r[n];t.set(o,s),s+=o.length}return t}var Jt=class{clone(){return this._cloneInto()}},kl={}.toString;function ri(r,e){if(e!==void 0&&kl.call(e)!=="[object Object]")throw new Error("Options should be object or undefined");return Object.assign(r,e)}function Xt(r){let e=n=>r().update(at(n)).digest(),t=r();return e.outputLen=t.outputLen,e.blockLen=t.blockLen,e.create=()=>r(),e}function Qt(r=32){if(It&&typeof It.getRandomValues=="function")return It.getRandomValues(new Uint8Array(r));if(It&&typeof It.randomBytes=="function")return It.randomBytes(r);throw new Error("crypto.getRandomValues must be defined")}function Sl(r,e,t,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(e,t,n);let s=BigInt(32),o=BigInt(4294967295),i=Number(t>>s&o),a=Number(t&o),c=n?4:0,u=n?0:4;r.setUint32(e+c,i,n),r.setUint32(e+u,a,n)}var Kr=(r,e,t)=>r&e^~r&t,Fr=(r,e,t)=>r&e^r&t^e&t,ct=class extends Jt{constructor(e,t,n,s){super(),this.blockLen=e,this.outputLen=t,this.padOffset=n,this.isLE=s,this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.buffer=new Uint8Array(e),this.view=Nt(this.buffer)}update(e){Wt(this);let{view:t,buffer:n,blockLen:s}=this;e=at(e);let o=e.length;for(let i=0;i<o;){let a=Math.min(s-this.pos,o-i);if(a===s){let c=Nt(e);for(;s<=o-i;i+=s)this.process(c,i);continue}n.set(e.subarray(i,i+a),this.pos),this.pos+=a,i+=a,this.pos===s&&(this.process(t,0),this.pos=0)}return this.length+=e.length,this.roundClean(),this}digestInto(e){Wt(this),Qo(e,this),this.finished=!0;let{buffer:t,view:n,blockLen:s,isLE:o}=this,{pos:i}=this;t[i++]=128,this.buffer.subarray(i).fill(0),this.padOffset>s-i&&(this.process(n,0),i=0);for(let f=i;f<s;f++)t[f]=0;Sl(n,s-8,BigInt(this.length*8),o),this.process(n,0);let a=Nt(e),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let u=c/4,l=this.get();if(u>l.length)throw new Error("_sha2: outputLen bigger than state");for(let f=0;f<u;f++)a.setUint32(4*f,l[f],o)}digest(){let{buffer:e,outputLen:t}=this;this.digestInto(e);let n=e.slice(0,t);return this.destroy(),n}_cloneInto(e){e||(e=new this.constructor),e.set(...this.get());let{blockLen:t,buffer:n,length:s,finished:o,destroyed:i,pos:a}=this;return e.length=s,e.pos=a,e.finished=o,e.destroyed=i,s%t&&e.buffer.set(n),e}};var $r=BigInt(4294967295),Es=BigInt(32);function ni(r,e=!1){return e?{h:Number(r&$r),l:Number(r>>Es&$r)}:{h:Number(r>>Es&$r)|0,l:Number(r&$r)|0}}function Il(r,e=!1){let t=new Uint32Array(r.length),n=new Uint32Array(r.length);for(let s=0;s<r.length;s++){let{h:o,l:i}=ni(r[s],e);[t[s],n[s]]=[o,i]}return[t,n]}var Nl=(r,e)=>BigInt(r>>>0)<<Es|BigInt(e>>>0),Rl=(r,e,t)=>r>>>t,Cl=(r,e,t)=>r<<32-t|e>>>t,Tl=(r,e,t)=>r>>>t|e<<32-t,_l=(r,e,t)=>r<<32-t|e>>>t,Ul=(r,e,t)=>r<<64-t|e>>>t-32,Ll=(r,e,t)=>r>>>t-32|e<<64-t,Vl=(r,e)=>e,Hl=(r,e)=>r,Ol=(r,e,t)=>r<<t|e>>>32-t,Dl=(r,e,t)=>e<<t|r>>>32-t,Pl=(r,e,t)=>e<<t-32|r>>>64-t,Ml=(r,e,t)=>r<<t-32|e>>>64-t;function Kl(r,e,t,n){let s=(e>>>0)+(n>>>0);return{h:r+t+(s/2**32|0)|0,l:s|0}}var Fl=(r,e,t)=>(r>>>0)+(e>>>0)+(t>>>0),$l=(r,e,t,n)=>e+t+n+(r/2**32|0)|0,ql=(r,e,t,n)=>(r>>>0)+(e>>>0)+(t>>>0)+(n>>>0),jl=(r,e,t,n,s)=>e+t+n+s+(r/2**32|0)|0,zl=(r,e,t,n,s)=>(r>>>0)+(e>>>0)+(t>>>0)+(n>>>0)+(s>>>0),Gl=(r,e,t,n,s,o)=>e+t+n+s+o+(r/2**32|0)|0;var Zl={fromBig:ni,split:Il,toBig:Nl,shrSH:Rl,shrSL:Cl,rotrSH:Tl,rotrSL:_l,rotrBH:Ul,rotrBL:Ll,rotr32H:Vl,rotr32L:Hl,rotlSH:Ol,rotlSL:Dl,rotlBH:Pl,rotlBL:Ml,add:Kl,add3L:Fl,add3H:$l,add4L:ql,add4H:jl,add5H:Gl,add5L:zl},H=Zl;var[Yl,Wl]=H.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))),lt=new Uint32Array(80),ut=new Uint32Array(80),As=class extends ct{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:e,Al:t,Bh:n,Bl:s,Ch:o,Cl:i,Dh:a,Dl:c,Eh:u,El:l,Fh:f,Fl:h,Gh:w,Gl:x,Hh:y,Hl:d}=this;return[e,t,n,s,o,i,a,c,u,l,f,h,w,x,y,d]}set(e,t,n,s,o,i,a,c,u,l,f,h,w,x,y,d){this.Ah=e|0,this.Al=t|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=u|0,this.El=l|0,this.Fh=f|0,this.Fl=h|0,this.Gh=w|0,this.Gl=x|0,this.Hh=y|0,this.Hl=d|0}process(e,t){for(let g=0;g<16;g++,t+=4)lt[g]=e.getUint32(t),ut[g]=e.getUint32(t+=4);for(let g=16;g<80;g++){let E=lt[g-15]|0,_=ut[g-15]|0,T=H.rotrSH(E,_,1)^H.rotrSH(E,_,8)^H.shrSH(E,_,7),S=H.rotrSL(E,_,1)^H.rotrSL(E,_,8)^H.shrSL(E,_,7),I=lt[g-2]|0,C=ut[g-2]|0,re=H.rotrSH(I,C,19)^H.rotrBH(I,C,61)^H.shrSH(I,C,6),F=H.rotrSL(I,C,19)^H.rotrBL(I,C,61)^H.shrSL(I,C,6),O=H.add4L(S,F,ut[g-7],ut[g-16]),ne=H.add4H(O,T,re,lt[g-7],lt[g-16]);lt[g]=ne|0,ut[g]=O|0}let{Ah:n,Al:s,Bh:o,Bl:i,Ch:a,Cl:c,Dh:u,Dl:l,Eh:f,El:h,Fh:w,Fl:x,Gh:y,Gl:d,Hh:m,Hl:v}=this;for(let g=0;g<80;g++){let E=H.rotrSH(f,h,14)^H.rotrSH(f,h,18)^H.rotrBH(f,h,41),_=H.rotrSL(f,h,14)^H.rotrSL(f,h,18)^H.rotrBL(f,h,41),T=f&w^~f&y,S=h&x^~h&d,I=H.add5L(v,_,S,Wl[g],ut[g]),C=H.add5H(I,m,E,T,Yl[g],lt[g]),re=I|0,F=H.rotrSH(n,s,28)^H.rotrBH(n,s,34)^H.rotrBH(n,s,39),O=H.rotrSL(n,s,28)^H.rotrBL(n,s,34)^H.rotrBL(n,s,39),ne=n&o^n&a^o&a,A=s&i^s&c^i&c;m=y|0,v=d|0,y=w|0,d=x|0,w=f|0,x=h|0,{h:f,l:h}=H.add(u|0,l|0,C|0,re|0),u=a|0,l=c|0,a=o|0,c=i|0,o=n|0,i=s|0;let N=H.add3L(re,O,A);n=H.add3H(N,C,F,ne),s=N|0}({h:n,l:s}=H.add(this.Ah|0,this.Al|0,n|0,s|0)),{h:o,l:i}=H.add(this.Bh|0,this.Bl|0,o|0,i|0),{h:a,l:c}=H.add(this.Ch|0,this.Cl|0,a|0,c|0),{h:u,l}=H.add(this.Dh|0,this.Dl|0,u|0,l|0),{h:f,l:h}=H.add(this.Eh|0,this.El|0,f|0,h|0),{h:w,l:x}=H.add(this.Fh|0,this.Fl|0,w|0,x|0),{h:y,l:d}=H.add(this.Gh|0,this.Gl|0,y|0,d|0),{h:m,l:v}=H.add(this.Hh|0,this.Hl|0,m|0,v|0),this.set(n,s,o,i,a,c,u,l,f,h,w,x,y,d,m,v)}roundClean(){lt.fill(0),ut.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 Rt=Xt(()=>new As);var jr={};Q(jr,{aInRange:()=>be,abool:()=>Ne,abytes:()=>er,bitGet:()=>ru,bitLen:()=>Rs,bitMask:()=>br,bitSet:()=>nu,bytesToHex:()=>je,bytesToNumberBE:()=>ze,bytesToNumberLE:()=>ht,concatBytes:()=>Ge,createHmacDrbg:()=>Cs,ensureBytes:()=>X,equalBytes:()=>eu,hexToBytes:()=>Tt,hexToNumber:()=>Ns,inRange:()=>mr,isBytes:()=>ft,memoized:()=>Ut,notImplemented:()=>ou,numberToBytesBE:()=>dt,numberToBytesLE:()=>_t,numberToHexUnpadded:()=>Ct,numberToVarBytesBE:()=>Ql,utf8ToBytes:()=>tu,validateObject:()=>Oe});var Is=BigInt(0),qr=BigInt(1),Jl=BigInt(2);function ft(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function er(r){if(!ft(r))throw new Error("Uint8Array expected")}function Ne(r,e){if(typeof e!="boolean")throw new Error(`${r} must be valid boolean, got "${e}".`)}var Xl=Array.from({length:256},(r,e)=>e.toString(16).padStart(2,"0"));function je(r){er(r);let e="";for(let t=0;t<r.length;t++)e+=Xl[r[t]];return e}function Ct(r){let e=r.toString(16);return e.length&1?`0${e}`:e}function Ns(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return BigInt(r===""?"0":`0x${r}`)}var qe={_0:48,_9:57,_A:65,_F:70,_a:97,_f:102};function si(r){if(r>=qe._0&&r<=qe._9)return r-qe._0;if(r>=qe._A&&r<=qe._F)return r-(qe._A-10);if(r>=qe._a&&r<=qe._f)return r-(qe._a-10)}function Tt(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);let e=r.length,t=e/2;if(e%2)throw new Error("padded hex string expected, got unpadded hex of length "+e);let n=new Uint8Array(t);for(let s=0,o=0;s<t;s++,o+=2){let i=si(r.charCodeAt(o)),a=si(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 ze(r){return Ns(je(r))}function ht(r){return er(r),Ns(je(Uint8Array.from(r).reverse()))}function dt(r,e){return Tt(r.toString(16).padStart(e*2,"0"))}function _t(r,e){return dt(r,e).reverse()}function Ql(r){return Tt(Ct(r))}function X(r,e,t){let n;if(typeof e=="string")try{n=Tt(e)}catch(o){throw new Error(`${r} must be valid hex string, got "${e}". Cause: ${o}`)}else if(ft(e))n=Uint8Array.from(e);else throw new Error(`${r} must be hex string or Uint8Array`);let s=n.length;if(typeof t=="number"&&s!==t)throw new Error(`${r} expected ${t} bytes, got ${s}`);return n}function Ge(...r){let e=0;for(let n=0;n<r.length;n++){let s=r[n];er(s),e+=s.length}let t=new Uint8Array(e);for(let n=0,s=0;n<r.length;n++){let o=r[n];t.set(o,s),s+=o.length}return t}function eu(r,e){if(r.length!==e.length)return!1;let t=0;for(let n=0;n<r.length;n++)t|=r[n]^e[n];return t===0}function tu(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}var ks=r=>typeof r=="bigint"&&Is<=r;function mr(r,e,t){return ks(r)&&ks(e)&&ks(t)&&e<=r&&r<t}function be(r,e,t,n){if(!mr(e,t,n))throw new Error(`expected valid ${r}: ${t} <= n < ${n}, got ${typeof e} ${e}`)}function Rs(r){let e;for(e=0;r>Is;r>>=qr,e+=1);return e}function ru(r,e){return r>>BigInt(e)&qr}function nu(r,e,t){return r|(t?qr:Is)<<BigInt(e)}var br=r=>(Jl<<BigInt(r-1))-qr,Ss=r=>new Uint8Array(r),oi=r=>Uint8Array.from(r);function Cs(r,e,t){if(typeof r!="number"||r<2)throw new Error("hashLen must be a number");if(typeof e!="number"||e<2)throw new Error("qByteLen must be a number");if(typeof t!="function")throw new Error("hmacFn must be a function");let n=Ss(r),s=Ss(r),o=0,i=()=>{n.fill(1),s.fill(0),o=0},a=(...f)=>t(s,n,...f),c=(f=Ss())=>{s=a(oi([0]),f),n=a(),f.length!==0&&(s=a(oi([1]),f),n=a())},u=()=>{if(o++>=1e3)throw new Error("drbg: tried 1000 values");let f=0,h=[];for(;f<e;){n=a();let w=n.slice();h.push(w),f+=n.length}return Ge(...h)};return(f,h)=>{i(),c(f);let w;for(;!(w=h(u()));)c();return i(),w}}var su={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"||ft(r),isSafeInteger:r=>Number.isSafeInteger(r),array:r=>Array.isArray(r),field:(r,e)=>e.Fp.isValid(r),hash:r=>typeof r=="function"&&Number.isSafeInteger(r.outputLen)};function Oe(r,e,t={}){let n=(s,o,i)=>{let a=su[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(e))n(s,o,!1);for(let[s,o]of Object.entries(t))n(s,o,!0);return r}var ou=()=>{throw new Error("not implemented")};function Ut(r){let e=new WeakMap;return(t,...n)=>{let s=e.get(t);if(s!==void 0)return s;let o=r(t,...n);return e.set(t,o),o}}var oe=BigInt(0),Y=BigInt(1),Lt=BigInt(2),iu=BigInt(3),Ts=BigInt(4),ii=BigInt(5),ai=BigInt(8),au=BigInt(9),cu=BigInt(16);function q(r,e){let t=r%e;return t>=oe?t:e+t}function lu(r,e,t){if(t<=oe||e<oe)throw new Error("Expected power/modulo > 0");if(t===Y)return oe;let n=Y;for(;e>oe;)e&Y&&(n=n*r%t),r=r*r%t,e>>=Y;return n}function W(r,e,t){let n=r;for(;e-- >oe;)n*=n,n%=t;return n}function zr(r,e){if(r===oe||e<=oe)throw new Error(`invert: expected positive integers, got n=${r} mod=${e}`);let t=q(r,e),n=e,s=oe,o=Y,i=Y,a=oe;for(;t!==oe;){let u=n/t,l=n%t,f=s-i*u,h=o-a*u;n=t,t=l,s=i,o=a,i=f,a=h}if(n!==Y)throw new Error("invert: does not exist");return q(s,e)}function uu(r){let e=(r-Y)/Lt,t,n,s;for(t=r-Y,n=0;t%Lt===oe;t/=Lt,n++);for(s=Lt;s<r&&lu(s,e,r)!==r-Y;s++);if(n===1){let i=(r+Y)/Ts;return function(c,u){let l=c.pow(u,i);if(!c.eql(c.sqr(l),u))throw new Error("Cannot find square root");return l}}let o=(t+Y)/Lt;return function(a,c){if(a.pow(c,e)===a.neg(a.ONE))throw new Error("Cannot find square root");let u=n,l=a.pow(a.mul(a.ONE,s),t),f=a.pow(c,o),h=a.pow(c,t);for(;!a.eql(h,a.ONE);){if(a.eql(h,a.ZERO))return a.ZERO;let w=1;for(let y=a.sqr(h);w<u&&!a.eql(y,a.ONE);w++)y=a.sqr(y);let x=a.pow(l,Y<<BigInt(u-w-1));l=a.sqr(x),f=a.mul(f,x),h=a.mul(h,l),u=w}return f}}function fu(r){if(r%Ts===iu){let e=(r+Y)/Ts;return function(n,s){let o=n.pow(s,e);if(!n.eql(n.sqr(o),s))throw new Error("Cannot find square root");return o}}if(r%ai===ii){let e=(r-ii)/ai;return function(n,s){let o=n.mul(s,Lt),i=n.pow(o,e),a=n.mul(s,i),c=n.mul(n.mul(a,Lt),i),u=n.mul(a,n.sub(c,n.ONE));if(!n.eql(n.sqr(u),s))throw new Error("Cannot find square root");return u}}return r%cu,uu(r)}var ci=(r,e)=>(q(r,e)&Y)===Y,hu=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function _s(r){let e={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},t=hu.reduce((n,s)=>(n[s]="function",n),e);return Oe(r,t)}function du(r,e,t){if(t<oe)throw new Error("Expected power > 0");if(t===oe)return r.ONE;if(t===Y)return e;let n=r.ONE,s=e;for(;t>oe;)t&Y&&(n=r.mul(n,s)),s=r.sqr(s),t>>=Y;return n}function gu(r,e){let t=new Array(e.length),n=e.reduce((o,i,a)=>r.is0(i)?o:(t[a]=o,r.mul(o,i)),r.ONE),s=r.inv(n);return e.reduceRight((o,i,a)=>r.is0(i)?o:(t[a]=r.mul(o,t[a]),r.mul(o,i)),s),t}function Us(r,e){let t=e!==void 0?e:r.toString(2).length,n=Math.ceil(t/8);return{nBitLength:t,nByteLength:n}}function gt(r,e,t=!1,n={}){if(r<=oe)throw new Error(`Expected Field ORDER > 0, got ${r}`);let{nBitLength:s,nByteLength:o}=Us(r,e);if(o>2048)throw new Error("Field lengths over 2048 bytes are not supported");let i=fu(r),a=Object.freeze({ORDER:r,BITS:s,BYTES:o,MASK:br(s),ZERO:oe,ONE:Y,create:c=>q(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error(`Invalid field element: expected bigint, got ${typeof c}`);return oe<=c&&c<r},is0:c=>c===oe,isOdd:c=>(c&Y)===Y,neg:c=>q(-c,r),eql:(c,u)=>c===u,sqr:c=>q(c*c,r),add:(c,u)=>q(c+u,r),sub:(c,u)=>q(c-u,r),mul:(c,u)=>q(c*u,r),pow:(c,u)=>du(a,c,u),div:(c,u)=>q(c*zr(u,r),r),sqrN:c=>c*c,addN:(c,u)=>c+u,subN:(c,u)=>c-u,mulN:(c,u)=>c*u,inv:c=>zr(c,r),sqrt:n.sqrt||(c=>i(a,c)),invertBatch:c=>gu(a,c),cmov:(c,u,l)=>l?u:c,toBytes:c=>t?_t(c,o):dt(c,o),fromBytes:c=>{if(c.length!==o)throw new Error(`Fp.fromBytes: expected ${o}, got ${c.length}`);return t?ht(c):ze(c)}});return Object.freeze(a)}function li(r){if(typeof r!="bigint")throw new Error("field order must be bigint");let e=r.toString(2).length;return Math.ceil(e/8)}function Ls(r){let e=li(r);return e+Math.ceil(e/2)}function ui(r,e,t=!1){let n=r.length,s=li(e),o=Ls(e);if(n<16||n<o||n>1024)throw new Error(`expected ${o}-1024 bytes of input, got ${n}`);let i=t?ze(r):ht(r),a=q(i,e-Y)+Y;return t?_t(a,s):dt(a,s)}var yu=BigInt(0),Vs=BigInt(1),Hs=new WeakMap,fi=new WeakMap;function Gr(r,e){let t=(o,i)=>{let a=i.negate();return o?a:i},n=o=>{if(!Number.isSafeInteger(o)||o<=0||o>e)throw new Error(`Wrong window size=${o}, should be [1..${e}]`)},s=o=>{n(o);let i=Math.ceil(e/o)+1,a=2**(o-1);return{windows:i,windowSize:a}};return{constTimeNegate:t,unsafeLadder(o,i){let a=r.ZERO,c=o;for(;i>yu;)i&Vs&&(a=a.add(c)),c=c.double(),i>>=Vs;return a},precomputeWindow(o,i){let{windows:a,windowSize:c}=s(i),u=[],l=o,f=l;for(let h=0;h<a;h++){f=l,u.push(f);for(let w=1;w<c;w++)f=f.add(l),u.push(f);l=f.double()}return u},wNAF(o,i,a){let{windows:c,windowSize:u}=s(o),l=r.ZERO,f=r.BASE,h=BigInt(2**o-1),w=2**o,x=BigInt(o);for(let y=0;y<c;y++){let d=y*u,m=Number(a&h);a>>=x,m>u&&(m-=w,a+=Vs);let v=d,g=d+Math.abs(m)-1,E=y%2!==0,_=m<0;m===0?f=f.add(t(E,i[v])):l=l.add(t(_,i[g]))}return{p:l,f}},wNAFCached(o,i,a){let c=fi.get(o)||1,u=Hs.get(o);return u||(u=this.precomputeWindow(o,c),c!==1&&Hs.set(o,a(u))),this.wNAF(c,u,i)},setWindowSize(o,i){n(i),fi.set(o,i),Hs.delete(o)}}}function Zr(r,e,t,n){if(!Array.isArray(t)||!Array.isArray(n)||n.length!==t.length)throw new Error("arrays of points and scalars must have equal length");n.forEach((l,f)=>{if(!e.isValid(l))throw new Error(`wrong scalar at index ${f}`)}),t.forEach((l,f)=>{if(!(l instanceof r))throw new Error(`wrong point at index ${f}`)});let s=Rs(BigInt(t.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((e.BITS-1)/o)*o,u=r.ZERO;for(let l=c;l>=0;l-=o){a.fill(r.ZERO);for(let h=0;h<n.length;h++){let w=n[h],x=Number(w>>BigInt(l)&BigInt(i));a[x]=a[x].add(t[h])}let f=r.ZERO;for(let h=a.length-1,w=r.ZERO;h>0;h--)w=w.add(a[h]),f=f.add(w);if(u=u.add(f),l!==0)for(let h=0;h<o;h++)u=u.double()}return u}function wr(r){return _s(r.Fp),Oe(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...Us(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Re=BigInt(0),we=BigInt(1),Yr=BigInt(2),mu=BigInt(8),bu={zip215:!0};function wu(r){let e=wr(r);return Oe(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...e})}function hi(r){let e=wu(r),{Fp:t,n,prehash:s,hash:o,randomBytes:i,nByteLength:a,h:c}=e,u=Yr<<BigInt(a*8)-we,l=t.create,f=gt(e.n,e.nBitLength),h=e.uvRatio||((b,p)=>{try{return{isValid:!0,value:t.sqrt(b*t.inv(p))}}catch{return{isValid:!1,value:Re}}}),w=e.adjustScalarBytes||(b=>b),x=e.domain||((b,p,B)=>{if(Ne("phflag",B),p.length||B)throw new Error("Contexts/pre-hash are not supported");return b});function y(b,p){be("coordinate "+b,p,Re,u)}function d(b){if(!(b instanceof g))throw new Error("ExtendedPoint expected")}let m=Ut((b,p)=>{let{ex:B,ey:R,ez:L}=b,V=b.is0();p==null&&(p=V?mu:t.inv(L));let D=l(B*p),K=l(R*p),P=l(L*p);if(V)return{x:Re,y:we};if(P!==we)throw new Error("invZ was invalid");return{x:D,y:K}}),v=Ut(b=>{let{a:p,d:B}=e;if(b.is0())throw new Error("bad point: ZERO");let{ex:R,ey:L,ez:V,et:D}=b,K=l(R*R),P=l(L*L),$=l(V*V),j=l($*$),ie=l(K*p),ae=l($*l(ie+P)),ue=l(j+l(B*l(K*P)));if(ae!==ue)throw new Error("bad point: equation left != right (1)");let ge=l(R*L),se=l(V*D);if(ge!==se)throw new Error("bad point: equation left != right (2)");return!0});class g{constructor(p,B,R,L){this.ex=p,this.ey=B,this.ez=R,this.et=L,y("x",p),y("y",B),y("z",R),y("t",L),Object.freeze(this)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(p){if(p instanceof g)throw new Error("extended point not allowed");let{x:B,y:R}=p||{};return y("x",B),y("y",R),new g(B,R,we,l(B*R))}static normalizeZ(p){let B=t.invertBatch(p.map(R=>R.ez));return p.map((R,L)=>R.toAffine(B[L])).map(g.fromAffine)}static msm(p,B){return Zr(g,f,p,B)}_setWindowSize(p){T.setWindowSize(this,p)}assertValidity(){v(this)}equals(p){d(p);let{ex:B,ey:R,ez:L}=this,{ex:V,ey:D,ez:K}=p,P=l(B*K),$=l(V*L),j=l(R*K),ie=l(D*L);return P===$&&j===ie}is0(){return this.equals(g.ZERO)}negate(){return new g(l(-this.ex),this.ey,this.ez,l(-this.et))}double(){let{a:p}=e,{ex:B,ey:R,ez:L}=this,V=l(B*B),D=l(R*R),K=l(Yr*l(L*L)),P=l(p*V),$=B+R,j=l(l($*$)-V-D),ie=P+D,ae=ie-K,ue=P-D,ge=l(j*ae),se=l(ie*ue),me=l(j*ue),Ke=l(ae*ie);return new g(ge,se,Ke,me)}add(p){d(p);let{a:B,d:R}=e,{ex:L,ey:V,ez:D,et:K}=this,{ex:P,ey:$,ez:j,et:ie}=p;if(B===BigInt(-1)){let Eo=l((V-L)*($+P)),Ao=l((V+L)*($-P)),Wn=l(Ao-Eo);if(Wn===Re)return this.double();let ko=l(D*Yr*ie),So=l(K*Yr*j),Io=So+ko,No=Ao+Eo,Ro=So-ko,sc=l(Io*Wn),oc=l(No*Ro),ic=l(Io*Ro),ac=l(Wn*No);return new g(sc,oc,ac,ic)}let ae=l(L*P),ue=l(V*$),ge=l(K*R*ie),se=l(D*j),me=l((L+V)*(P+$)-ae-ue),Ke=se-ge,fr=se+ge,hr=l(ue-B*ae),ec=l(me*Ke),tc=l(fr*hr),rc=l(me*hr),nc=l(Ke*fr);return new g(ec,tc,nc,rc)}subtract(p){return this.add(p.negate())}wNAF(p){return T.wNAFCached(this,p,g.normalizeZ)}multiply(p){let B=p;be("scalar",B,we,n);let{p:R,f:L}=this.wNAF(B);return g.normalizeZ([R,L])[0]}multiplyUnsafe(p){let B=p;return be("scalar",B,Re,n),B===Re?_:this.equals(_)||B===we?this:this.equals(E)?this.wNAF(B).p:T.unsafeLadder(this,B)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return T.unsafeLadder(this,n).is0()}toAffine(p){return m(this,p)}clearCofactor(){let{h:p}=e;return p===we?this:this.multiplyUnsafe(p)}static fromHex(p,B=!1){let{d:R,a:L}=e,V=t.BYTES;p=X("pointHex",p,V),Ne("zip215",B);let D=p.slice(),K=p[V-1];D[V-1]=K&-129;let P=ht(D),$=B?u:t.ORDER;be("pointHex.y",P,Re,$);let j=l(P*P),ie=l(j-we),ae=l(R*j-L),{isValid:ue,value:ge}=h(ie,ae);if(!ue)throw new Error("Point.fromHex: invalid y coordinate");let se=(ge&we)===we,me=(K&128)!==0;if(!B&&ge===Re&&me)throw new Error("Point.fromHex: x=0 and x_0=1");return me!==se&&(ge=l(-ge)),g.fromAffine({x:ge,y:P})}static fromPrivateKey(p){return C(p).point}toRawBytes(){let{x:p,y:B}=this.toAffine(),R=_t(B,t.BYTES);return R[R.length-1]|=p&we?128:0,R}toHex(){return je(this.toRawBytes())}}g.BASE=new g(e.Gx,e.Gy,we,l(e.Gx*e.Gy)),g.ZERO=new g(Re,we,we,Re);let{BASE:E,ZERO:_}=g,T=Gr(g,a*8);function S(b){return q(b,n)}function I(b){return S(ht(b))}function C(b){let p=a;b=X("private key",b,p);let B=X("hashed private key",o(b),2*p),R=w(B.slice(0,p)),L=B.slice(p,2*p),V=I(R),D=E.multiply(V),K=D.toRawBytes();return{head:R,prefix:L,scalar:V,point:D,pointBytes:K}}function re(b){return C(b).pointBytes}function F(b=new Uint8Array,...p){let B=Ge(...p);return I(o(x(B,X("context",b),!!s)))}function O(b,p,B={}){b=X("message",b),s&&(b=s(b));let{prefix:R,scalar:L,pointBytes:V}=C(p),D=F(B.context,R,b),K=E.multiply(D).toRawBytes(),P=F(B.context,K,V,b),$=S(D+P*L);be("signature.s",$,Re,n);let j=Ge(K,_t($,t.BYTES));return X("result",j,a*2)}let ne=bu;function A(b,p,B,R=ne){let{context:L,zip215:V}=R,D=t.BYTES;b=X("signature",b,2*D),p=X("message",p),V!==void 0&&Ne("zip215",V),s&&(p=s(p));let K=ht(b.slice(D,2*D)),P,$,j;try{P=g.fromHex(B,V),$=g.fromHex(b.slice(0,D),V),j=E.multiplyUnsafe(K)}catch{return!1}if(!V&&P.isSmallOrder())return!1;let ie=F(L,$.toRawBytes(),P.toRawBytes(),p);return $.add(P.multiplyUnsafe(ie)).subtract(j).clearCofactor().equals(g.ZERO)}return E._setWindowSize(8),{CURVE:e,getPublicKey:re,sign:O,verify:A,ExtendedPoint:g,utils:{getExtendedPublicKey:C,randomPrivateKey:()=>i(t.BYTES),precompute(b=8,p=g.BASE){return p._setWindowSize(b),p.multiply(BigInt(3)),p}}}}var Os=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),di=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),bd=BigInt(0),xu=BigInt(1),gi=BigInt(2),wd=BigInt(3),vu=BigInt(5),Bu=BigInt(8);function Eu(r){let e=BigInt(10),t=BigInt(20),n=BigInt(40),s=BigInt(80),o=Os,a=r*r%o*r%o,c=W(a,gi,o)*a%o,u=W(c,xu,o)*r%o,l=W(u,vu,o)*u%o,f=W(l,e,o)*l%o,h=W(f,t,o)*f%o,w=W(h,n,o)*h%o,x=W(w,s,o)*w%o,y=W(x,s,o)*w%o,d=W(y,e,o)*l%o;return{pow_p_5_8:W(d,gi,o)*r%o,b2:a}}function Au(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function ku(r,e){let t=Os,n=q(e*e*e,t),s=q(n*n*e,t),o=Eu(r*s).pow_p_5_8,i=q(r*n*o,t),a=q(e*i*i,t),c=i,u=q(i*di,t),l=a===r,f=a===q(-r,t),h=a===q(-r*di,t);return l&&(i=c),(f||h)&&(i=u),ci(i,t)&&(i=q(-i,t)),{isValid:l||f,value:i}}var Su=gt(Os,void 0,!0),Iu={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:Su,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:Bu,Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:Rt,randomBytes:Qt,adjustScalarBytes:Au,uvRatio:ku},tr=hi(Iu);var rr=32,Ze=64,Wr=32;function pi(){let r=tr.utils.randomPrivateKey(),e=tr.getPublicKey(r);return{privateKey:wi(r,e),publicKey:e}}function yi(r){if(r.length!==Wr)throw new TypeError('"seed" must be 32 bytes in length.');if(!(r instanceof Uint8Array))throw new TypeError('"seed" must be a node.js Buffer, or Uint8Array.');let e=r,t=tr.getPublicKey(e);return{privateKey:wi(e,t),publicKey:t}}function mi(r,e){let t=r.subarray(0,Wr);return tr.sign(e instanceof Uint8Array?e:e.subarray(),t)}function bi(r,e,t){return tr.verify(e,t instanceof Uint8Array?t:t.subarray(),r)}function wi(r,e){let t=new Uint8Array(Ze);for(let n=0;n<Wr;n++)t[n]=r[n],t[Wr+n]=e[n];return t}var Ds={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function Jr(r){let e=r?.algorithm??"AES-GCM",t=r?.keyLength??16,n=r?.nonceLength??12,s=r?.digest??"SHA-256",o=r?.saltLength??16,i=r?.iterations??32767,a=G.get();t*=8;async function c(f,h){let w=a.getRandomValues(new Uint8Array(o)),x=a.getRandomValues(new Uint8Array(n)),y={name:e,iv:x};typeof h=="string"&&(h=Z(h));let d;if(h.length===0){d=await a.subtle.importKey("jwk",Ds,{name:"AES-GCM"},!0,["encrypt"]);try{let v={name:"PBKDF2",salt:w,iterations:i,hash:{name:s}},g=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);d=await a.subtle.deriveKey(v,g,{name:e,length:t},!0,["encrypt"])}catch{d=await a.subtle.importKey("jwk",Ds,{name:"AES-GCM"},!0,["encrypt"])}}else{let v={name:"PBKDF2",salt:w,iterations:i,hash:{name:s}},g=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);d=await a.subtle.deriveKey(v,g,{name:e,length:t},!0,["encrypt"])}let m=await a.subtle.encrypt(y,d,f);return $e([w,y.iv,new Uint8Array(m)])}async function u(f,h){let w=f.subarray(0,o),x=f.subarray(o,o+n),y=f.subarray(o+n),d={name:e,iv:x};typeof h=="string"&&(h=Z(h));let m;if(h.length===0)try{let g={name:"PBKDF2",salt:w,iterations:i,hash:{name:s}},E=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);m=await a.subtle.deriveKey(g,E,{name:e,length:t},!0,["decrypt"])}catch{m=await a.subtle.importKey("jwk",Ds,{name:"AES-GCM"},!0,["decrypt"])}else{let g={name:"PBKDF2",salt:w,iterations:i,hash:{name:s}},E=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);m=await a.subtle.deriveKey(g,E,{name:e,length:t},!0,["decrypt"])}let v=await a.subtle.decrypt(d,m,y);return new Uint8Array(v)}return{encrypt:c,decrypt:u}}async function nr(r,e){let n=await Jr().encrypt(r,e);return St.encode(n)}var or={};Q(or,{KeyType:()=>z,PrivateKey:()=>_e,PublicKey:()=>Te});var Ru=Math.pow(2,7),Cu=Math.pow(2,14),Tu=Math.pow(2,21),vi=Math.pow(2,28),Bi=Math.pow(2,35),Ei=Math.pow(2,42),Ai=Math.pow(2,49),pe=128,pt=127;function xr(r){if(r<Ru)return 1;if(r<Cu)return 2;if(r<Tu)return 3;if(r<vi)return 4;if(r<Bi)return 5;if(r<Ei)return 6;if(r<Ai)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function ki(r,e,t=0){switch(xr(r)){case 8:e[t++]=r&255|pe,r/=128;case 7:e[t++]=r&255|pe,r/=128;case 6:e[t++]=r&255|pe,r/=128;case 5:e[t++]=r&255|pe,r/=128;case 4:e[t++]=r&255|pe,r>>>=7;case 3:e[t++]=r&255|pe,r>>>=7;case 2:e[t++]=r&255|pe,r>>>=7;case 1:{e[t++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return e}function Si(r,e){let t=r[e],n=0;if(n+=t&pt,t<pe||(t=r[e+1],n+=(t&pt)<<7,t<pe)||(t=r[e+2],n+=(t&pt)<<14,t<pe)||(t=r[e+3],n+=(t&pt)<<21,t<pe)||(t=r[e+4],n+=(t&pt)*vi,t<pe)||(t=r[e+5],n+=(t&pt)*Bi,t<pe)||(t=r[e+6],n+=(t&pt)*Ei,t<pe)||(t=r[e+7],n+=(t&pt)*Ai,t<pe))return n;throw new RangeError("Could not decode varint")}var Ps=new Float32Array([-0]),yt=new Uint8Array(Ps.buffer);function Ii(r,e,t){Ps[0]=r,e[t]=yt[0],e[t+1]=yt[1],e[t+2]=yt[2],e[t+3]=yt[3]}function Ni(r,e){return yt[0]=r[e],yt[1]=r[e+1],yt[2]=r[e+2],yt[3]=r[e+3],Ps[0]}var Ms=new Float64Array([-0]),he=new Uint8Array(Ms.buffer);function Ri(r,e,t){Ms[0]=r,e[t]=he[0],e[t+1]=he[1],e[t+2]=he[2],e[t+3]=he[3],e[t+4]=he[4],e[t+5]=he[5],e[t+6]=he[6],e[t+7]=he[7]}function Ci(r,e){return he[0]=r[e],he[1]=r[e+1],he[2]=r[e+2],he[3]=r[e+3],he[4]=r[e+4],he[5]=r[e+5],he[6]=r[e+6],he[7]=r[e+7],Ms[0]}var _u=BigInt(Number.MAX_SAFE_INTEGER),Uu=BigInt(Number.MIN_SAFE_INTEGER),Be=class r{lo;hi;constructor(e,t){this.lo=e|0,this.hi=t|0}toNumber(e=!1){if(!e&&this.hi>>>31>0){let t=~this.lo+1>>>0,n=~this.hi>>>0;return t===0&&(n=n+1>>>0),-(t+n*4294967296)}return this.lo+this.hi*4294967296}toBigInt(e=!1){if(e)return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n);if(this.hi>>>31){let t=~this.lo+1>>>0,n=~this.hi>>>0;return t===0&&(n=n+1>>>0),-(BigInt(t)+(BigInt(n)<<32n))}return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n)}toString(e=!1){return this.toBigInt(e).toString()}zzEncode(){let e=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^e)>>>0,this.lo=(this.lo<<1^e)>>>0,this}zzDecode(){let e=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^e)>>>0,this.hi=(this.hi>>>1^e)>>>0,this}length(){let e=this.lo,t=(this.lo>>>28|this.hi<<4)>>>0,n=this.hi>>>24;return n===0?t===0?e<16384?e<128?1:2:e<2097152?3:4:t<16384?t<128?5:6:t<2097152?7:8:n<128?9:10}static fromBigInt(e){if(e===0n)return Vt;if(e<_u&&e>Uu)return this.fromNumber(Number(e));let t=e<0n;t&&(e=-e);let n=e>>32n,s=e-(n<<32n);return t&&(n=~n|0n,s=~s|0n,++s>Ti&&(s=0n,++n>Ti&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(e){if(e===0)return Vt;let t=e<0;t&&(e=-e);let n=e>>>0,s=(e-n)/4294967296>>>0;return t&&(s=~s>>>0,n=~n>>>0,++n>4294967295&&(n=0,++s>4294967295&&(s=0))),new r(n,s)}static from(e){return typeof e=="number"?r.fromNumber(e):typeof e=="bigint"?r.fromBigInt(e):typeof e=="string"?r.fromBigInt(BigInt(e)):e.low!=null||e.high!=null?new r(e.low>>>0,e.high>>>0):Vt}},Vt=new Be(0,0);Vt.toBigInt=function(){return 0n};Vt.zzEncode=Vt.zzDecode=function(){return this};Vt.length=function(){return 1};var Ti=4294967296n;function _i(r){let e=0,t=0;for(let n=0;n<r.length;++n)t=r.charCodeAt(n),t<128?e+=1:t<2048?e+=2:(t&64512)===55296&&(r.charCodeAt(n+1)&64512)===56320?(++n,e+=4):e+=3;return e}function Ui(r,e,t){if(t-e<1)return"";let s,o=[],i=0,a;for(;e<t;)a=r[e++],a<128?o[i++]=a:a>191&&a<224?o[i++]=(a&31)<<6|r[e++]&63:a>239&&a<365?(a=((a&7)<<18|(r[e++]&63)<<12|(r[e++]&63)<<6|r[e++]&63)-65536,o[i++]=55296+(a>>10),o[i++]=56320+(a&1023)):o[i++]=(a&15)<<12|(r[e++]&63)<<6|r[e++]&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 Ks(r,e,t){let n=t,s,o;for(let i=0;i<r.length;++i)s=r.charCodeAt(i),s<128?e[t++]=s:s<2048?(e[t++]=s>>6|192,e[t++]=s&63|128):(s&64512)===55296&&((o=r.charCodeAt(i+1))&64512)===56320?(s=65536+((s&1023)<<10)+(o&1023),++i,e[t++]=s>>18|240,e[t++]=s>>12&63|128,e[t++]=s>>6&63|128,e[t++]=s&63|128):(e[t++]=s>>12|224,e[t++]=s>>6&63|128,e[t++]=s&63|128);return t-n}function Ce(r,e){return RangeError(`index out of range: ${r.pos} + ${e??1} > ${r.len}`)}function Xr(r,e){return(r[e-4]|r[e-3]<<8|r[e-2]<<16|r[e-1]<<24)>>>0}var Fs=class{buf;pos;len;_slice=Uint8Array.prototype.subarray;constructor(e){this.buf=e,this.pos=0,this.len=e.length}uint32(){let e=4294967295;if(e=(this.buf[this.pos]&127)>>>0,this.buf[this.pos++]<128||(e=(e|(this.buf[this.pos]&127)<<7)>>>0,this.buf[this.pos++]<128)||(e=(e|(this.buf[this.pos]&127)<<14)>>>0,this.buf[this.pos++]<128)||(e=(e|(this.buf[this.pos]&127)<<21)>>>0,this.buf[this.pos++]<128)||(e=(e|(this.buf[this.pos]&15)<<28)>>>0,this.buf[this.pos++]<128))return e;if((this.pos+=5)>this.len)throw this.pos=this.len,Ce(this,10);return e}int32(){return this.uint32()|0}sint32(){let e=this.uint32();return e>>>1^-(e&1)|0}bool(){return this.uint32()!==0}fixed32(){if(this.pos+4>this.len)throw Ce(this,4);return Xr(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Ce(this,4);return Xr(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Ce(this,4);let e=Ni(this.buf,this.pos);return this.pos+=4,e}double(){if(this.pos+8>this.len)throw Ce(this,4);let e=Ci(this.buf,this.pos);return this.pos+=8,e}bytes(){let e=this.uint32(),t=this.pos,n=this.pos+e;if(n>this.len)throw Ce(this,e);return this.pos+=e,t===n?new Uint8Array(0):this.buf.subarray(t,n)}string(){let e=this.bytes();return Ui(e,0,e.length)}skip(e){if(typeof e=="number"){if(this.pos+e>this.len)throw Ce(this,e);this.pos+=e}else do if(this.pos>=this.len)throw Ce(this);while(this.buf[this.pos++]&128);return this}skipType(e){switch(e){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;(e=this.uint32()&7)!==4;)this.skipType(e);break;case 5:this.skip(4);break;default:throw Error(`invalid wire type ${e} at offset ${this.pos}`)}return this}readLongVarint(){let e=new Be(0,0),t=0;if(this.len-this.pos>4){for(;t<4;++t)if(e.lo=(e.lo|(this.buf[this.pos]&127)<<t*7)>>>0,this.buf[this.pos++]<128)return e;if(e.lo=(e.lo|(this.buf[this.pos]&127)<<28)>>>0,e.hi=(e.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return e;t=0}else{for(;t<3;++t){if(this.pos>=this.len)throw Ce(this);if(e.lo=(e.lo|(this.buf[this.pos]&127)<<t*7)>>>0,this.buf[this.pos++]<128)return e}return e.lo=(e.lo|(this.buf[this.pos++]&127)<<t*7)>>>0,e}if(this.len-this.pos>4){for(;t<5;++t)if(e.hi=(e.hi|(this.buf[this.pos]&127)<<t*7+3)>>>0,this.buf[this.pos++]<128)return e}else for(;t<5;++t){if(this.pos>=this.len)throw Ce(this);if(e.hi=(e.hi|(this.buf[this.pos]&127)<<t*7+3)>>>0,this.buf[this.pos++]<128)return e}throw Error("invalid varint encoding")}readFixed64(){if(this.pos+8>this.len)throw Ce(this,8);let e=Xr(this.buf,this.pos+=4),t=Xr(this.buf,this.pos+=4);return new Be(e,t)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){let e=Si(this.buf,this.pos);return this.pos+=xr(e),e}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 $s(r){return new Fs(r instanceof Uint8Array?r:r.subarray())}function Qr(r,e,t){let n=$s(r);return e.decode(n,void 0,t)}function qs(r){let e=r??8192,t=e>>>1,n,s=e;return function(i){if(i<1||i>t)return He(i);s+i>e&&(n=He(e),s=0);let a=n.subarray(s,s+=i);return s&7&&(s=(s|7)+1),a}}var Ht=class{fn;len;next;val;constructor(e,t,n){this.fn=e,this.len=t,this.next=void 0,this.val=n}};function js(){}var Gs=class{head;tail;len;next;constructor(e){this.head=e.head,this.tail=e.tail,this.len=e.len,this.next=e.states}},Lu=qs();function Vu(r){return globalThis.Buffer!=null?He(r):Lu(r)}var Br=class{len;head;tail;states;constructor(){this.len=0,this.head=new Ht(js,0,0),this.tail=this.head,this.states=null}_push(e,t,n){return this.tail=this.tail.next=new Ht(e,t,n),this.len+=t,this}uint32(e){return this.len+=(this.tail=this.tail.next=new Zs((e=e>>>0)<128?1:e<16384?2:e<2097152?3:e<268435456?4:5,e)).len,this}int32(e){return e<0?this._push(en,10,Be.fromNumber(e)):this.uint32(e)}sint32(e){return this.uint32((e<<1^e>>31)>>>0)}uint64(e){let t=Be.fromBigInt(e);return this._push(en,t.length(),t)}uint64Number(e){return this._push(ki,xr(e),e)}uint64String(e){return this.uint64(BigInt(e))}int64(e){return this.uint64(e)}int64Number(e){return this.uint64Number(e)}int64String(e){return this.uint64String(e)}sint64(e){let t=Be.fromBigInt(e).zzEncode();return this._push(en,t.length(),t)}sint64Number(e){let t=Be.fromNumber(e).zzEncode();return this._push(en,t.length(),t)}sint64String(e){return this.sint64(BigInt(e))}bool(e){return this._push(zs,1,e?1:0)}fixed32(e){return this._push(vr,4,e>>>0)}sfixed32(e){return this.fixed32(e)}fixed64(e){let t=Be.fromBigInt(e);return this._push(vr,4,t.lo)._push(vr,4,t.hi)}fixed64Number(e){let t=Be.fromNumber(e);return this._push(vr,4,t.lo)._push(vr,4,t.hi)}fixed64String(e){return this.fixed64(BigInt(e))}sfixed64(e){return this.fixed64(e)}sfixed64Number(e){return this.fixed64Number(e)}sfixed64String(e){return this.fixed64String(e)}float(e){return this._push(Ii,4,e)}double(e){return this._push(Ri,8,e)}bytes(e){let t=e.length>>>0;return t===0?this._push(zs,1,0):this.uint32(t)._push(Ou,t,e)}string(e){let t=_i(e);return t!==0?this.uint32(t)._push(Ks,t,e):this._push(zs,1,0)}fork(){return this.states=new Gs(this),this.head=this.tail=new Ht(js,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 Ht(js,0,0),this.len=0),this}ldelim(){let e=this.head,t=this.tail,n=this.len;return this.reset().uint32(n),n!==0&&(this.tail.next=e.next,this.tail=t,this.len+=n),this}finish(){let e=this.head.next,t=Vu(this.len),n=0;for(;e!=null;)e.fn(e.val,t,n),n+=e.len,e=e.next;return t}};function zs(r,e,t){e[t]=r&255}function Hu(r,e,t){for(;r>127;)e[t++]=r&127|128,r>>>=7;e[t]=r}var Zs=class extends Ht{next;constructor(e,t){super(Hu,e,t),this.next=void 0}};function en(r,e,t){for(;r.hi!==0;)e[t++]=r.lo&127|128,r.lo=(r.lo>>>7|r.hi<<25)>>>0,r.hi>>>=7;for(;r.lo>127;)e[t++]=r.lo&127|128,r.lo=r.lo>>>7;e[t++]=r.lo}function vr(r,e,t){e[t]=r&255,e[t+1]=r>>>8&255,e[t+2]=r>>>16&255,e[t+3]=r>>>24}function Ou(r,e,t){e.set(r,t)}globalThis.Buffer!=null&&(Br.prototype.bytes=function(r){let e=r.length>>>0;return this.uint32(e),e>0&&this._push(Du,e,r),this},Br.prototype.string=function(r){let e=globalThis.Buffer.byteLength(r);return this.uint32(e),e>0&&this._push(Pu,e,r),this});function Du(r,e,t){e.set(r,t)}function Pu(r,e,t){r.length<40?Ks(r,e,t):e.utf8Write!=null?e.utf8Write(r,t):e.set(Z(r),t)}function Ys(){return new Br}function tn(r,e){let t=Ys();return e.encode(r,t,{lengthDelimited:!1}),t.finish()}var sr;(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"})(sr||(sr={}));function rn(r,e,t,n){return{name:r,type:e,encode:t,decode:n}}function Ws(r){function e(s){if(r[s.toString()]==null)throw new Error("Invalid enum value");return r[s]}let t=function(o,i){let a=e(o);i.int32(a)},n=function(o){let i=o.int32();return e(i)};return rn("enum",sr.VARINT,t,n)}function nn(r,e){return rn("message",sr.LENGTH_DELIMITED,r,e)}var z;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.Secp256k1="Secp256k1"})(z||(z={}));var Js;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.Secp256k1=2]="Secp256k1"})(Js||(Js={}));(function(r){r.codec=()=>Ws(Js)})(z||(z={}));var Te;(function(r){let e;r.codec=()=>(e==null&&(e=nn((t,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),t.Type!=null&&(n.uint32(8),z.codec().encode(t.Type,n)),t.Data!=null&&(n.uint32(18),n.bytes(t.Data)),s.lengthDelimited!==!1&&n.ldelim()},(t,n)=>{let s={},o=n==null?t.len:t.pos+n;for(;t.pos<o;){let i=t.uint32();switch(i>>>3){case 1:s.Type=z.codec().decode(t);break;case 2:s.Data=t.bytes();break;default:t.skipType(i&7);break}}return s})),e),r.encode=t=>tn(t,r.codec()),r.decode=t=>Qr(t,r.codec())})(Te||(Te={}));var _e;(function(r){let e;r.codec=()=>(e==null&&(e=nn((t,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),t.Type!=null&&(n.uint32(8),z.codec().encode(t.Type,n)),t.Data!=null&&(n.uint32(18),n.bytes(t.Data)),s.lengthDelimited!==!1&&n.ldelim()},(t,n)=>{let s={},o=n==null?t.len:t.pos+n;for(;t.pos<o;){let i=t.uint32();switch(i>>>3){case 1:s.Type=z.codec().decode(t);break;case 2:s.Data=t.bytes();break;default:t.skipType(i&7);break}}return s})),e),r.encode=t=>tn(t,r.codec()),r.decode=t=>Qr(t,r.codec())})(_e||(_e={}));var Ot=class{_key;constructor(e){this._key=ir(e,rr)}verify(e,t){return bi(this._key,t,e)}marshal(){return this._key}get bytes(){return Te.encode({Type:z.Ed25519,Data:this.marshal()}).subarray()}equals(e){return Se(this.bytes,e.bytes)}hash(){let e=ve.digest(this.bytes);return Ae(e)?e.then(({bytes:t})=>t):e.bytes}},Ye=class{_key;_publicKey;constructor(e,t){this._key=ir(e,Ze),this._publicKey=ir(t,rr)}sign(e){return mi(this._key,e)}get public(){return new Ot(this._publicKey)}marshal(){return this._key}get bytes(){return _e.encode({Type:z.Ed25519,Data:this.marshal()}).subarray()}equals(e){return Se(this.bytes,e.bytes)}async hash(){let e=ve.digest(this.bytes),t;return Ae(e)?{bytes:t}=await e:t=e.bytes,t}async id(){let e=ss.digest(this.public.bytes);return Ee.encode(e.bytes).substring(1)}async export(e,t="libp2p-key"){if(t==="libp2p-key")return nr(this.bytes,e);throw new U(`export format '${t}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function Mu(r){if(r.length>Ze){r=ir(r,Ze+rr);let n=r.subarray(0,Ze),s=r.subarray(Ze,r.length);return new Ye(n,s)}r=ir(r,Ze);let e=r.subarray(0,Ze),t=r.subarray(rr);return new Ye(e,t)}function Ku(r){return r=ir(r,rr),new Ot(r)}async function Fu(){let{privateKey:r,publicKey:e}=pi();return new Ye(r,e)}async function Xs(r){let{privateKey:e,publicKey:t}=yi(r);return new Ye(e,t)}function ir(r,e){if(r=Uint8Array.from(r??[]),r.length!==e)throw new U(`Key must be a Uint8Array of length ${e}, got ${r.length}`,"ERR_INVALID_KEY_TYPE");return r}function ee(r,e="utf8"){let t=Dr[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return t.encoder.encode(r).substring(1)}var Vi={"P-256":256,"P-384":384,"P-521":521},$u=Object.keys(Vi),eo=$u.join(" / ");async function Hi(r){if(r!=="P-256"&&r!=="P-384"&&r!=="P-521")throw new U(`Unknown curve: ${r}. Must be ${eo}`,"ERR_INVALID_CURVE");let e=await G.get().subtle.generateKey({name:"ECDH",namedCurve:r},!0,["deriveBits"]),t=async(o,i)=>{let a;i!=null?a=await G.get().subtle.importKey("jwk",ju(r,i),{name:"ECDH",namedCurve:r},!1,["deriveBits"]):a=e.privateKey;let c=await G.get().subtle.importKey("jwk",Di(r,o),{name:"ECDH",namedCurve:r},!1,[]),u=await G.get().subtle.deriveBits({name:"ECDH",namedCurve:r,public:c},a,Vi[r]);return new Uint8Array(u,0,u.byteLength)},n=await G.get().subtle.exportKey("jwk",e.publicKey);return{key:qu(n),genSharedKey:t}}var Oi={"P-256":32,"P-384":48,"P-521":66};function qu(r){if(r.crv==null||r.x==null||r.y==null)throw new U("JWK was missing components","ERR_INVALID_PARAMETERS");if(r.crv!=="P-256"&&r.crv!=="P-384"&&r.crv!=="P-521")throw new U(`Unknown curve: ${r.crv}. Must be ${eo}`,"ERR_INVALID_CURVE");let e=Oi[r.crv];return $e([Uint8Array.from([4]),vs(r.x,e),vs(r.y,e)],1+e*2)}function Di(r,e){if(r!=="P-256"&&r!=="P-384"&&r!=="P-521")throw new U(`Unknown curve: ${r}. Must be ${eo}`,"ERR_INVALID_CURVE");let t=Oi[r];if(!Se(e.subarray(0,1),Uint8Array.from([4])))throw new U("Cannot unmarshal public key - invalid key format","ERR_INVALID_KEY_FORMAT");return{kty:"EC",crv:r,x:ee(e.subarray(1,t+1),"base64url"),y:ee(e.subarray(1+t),"base64url"),ext:!0}}var ju=(r,e)=>({...Di(r,e.public),d:ee(e.private,"base64url")});var Pi=Hi;async function Mi(r,e){let t=St.decode(r);return Jr().decrypt(t,e)}var Ki={"AES-128":{ivSize:16,keySize:16},"AES-256":{ivSize:16,keySize:32},Blowfish:{ivSize:8,keySize:32}};async function Fi(r,e,t){let n=Ki[r];if(n==null){let v=Object.keys(Ki).join(" / ");throw new U(`unknown cipher type '${r}'. Must be ${v}`,"ERR_INVALID_CIPHER_TYPE")}if(e==null)throw new U("missing hash type","ERR_MISSING_HASH_TYPE");let s=n.keySize,o=n.ivSize,i=20,a=Z("key expansion"),c=2*(o+s+i),u=await Jn(e,t),l=await u.digest(a),f=[],h=0;for(;h<c;){let v=await u.digest($e([l,a])),g=v.length;h+g>c&&(g=c-h),f.push(v),h+=g,l=await u.digest(l)}let w=c/2,x=$e(f),y=x.subarray(0,w),d=x.subarray(w,c),m=v=>({iv:v.subarray(0,o),cipherKey:v.subarray(o,o+s),macKey:v.subarray(o+s)});return{k1:m(y),k2:m(d)}}var fo={};Q(fo,{MAX_RSA_KEY_SIZE:()=>Mt,RsaPrivateKey:()=>vt,RsaPublicKey:()=>Pt,fromJwk:()=>yf,generateKeyPair:()=>mf,unmarshalRsaPrivateKey:()=>lo,unmarshalRsaPublicKey:()=>pf});function We(r){if(isNaN(r)||r<=0)throw new U("random bytes length must be a Number bigger than 0","ERR_INVALID_LENGTH");return Qt(r)}var xt={};Q(xt,{exportToPem:()=>ff,importFromPem:()=>co,jwkToPkcs1:()=>af,jwkToPkix:()=>lf,pkcs1ToJwk:()=>of,pkixToJwk:()=>cf});var sn=class extends Jt{constructor(e,t){super(),this.finished=!1,this.destroyed=!1,Pr(e);let n=at(t);if(this.iHash=e.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?e.create().update(n).digest():n);for(let i=0;i<o.length;i++)o[i]^=54;this.iHash.update(o),this.oHash=e.create();for(let i=0;i<o.length;i++)o[i]^=106;this.oHash.update(o),o.fill(0)}update(e){return Wt(this),this.iHash.update(e),this}digestInto(e){Wt(this),Yt(e,this.outputLen),this.finished=!0,this.iHash.digestInto(e),this.oHash.update(e),this.oHash.digestInto(e),this.destroy()}digest(){let e=new Uint8Array(this.oHash.outputLen);return this.digestInto(e),e}_cloneInto(e){e||(e=Object.create(Object.getPrototypeOf(this),{}));let{oHash:t,iHash:n,finished:s,destroyed:o,blockLen:i,outputLen:a}=this;return e=e,e.finished=s,e.destroyed=o,e.blockLen=i,e.outputLen=a,e.oHash=t._cloneInto(e.oHash),e.iHash=n._cloneInto(e.iHash),e}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},Er=(r,e,t)=>new sn(r,e).update(t).digest();Er.create=(r,e)=>new sn(r,e);function $i(r,e,t,n){Pr(r);let s=ri({dkLen:32,asyncTick:10},n),{c:o,dkLen:i,asyncTick:a}=s;if(Zt(o),Zt(i),Zt(a),o<1)throw new Error("PBKDF2: iterations (c) should be >= 1");let c=at(e),u=at(t),l=new Uint8Array(i),f=Er.create(r,c),h=f._cloneInto().update(u);return{c:o,dkLen:i,asyncTick:a,DK:l,PRF:f,PRFSalt:h}}function qi(r,e,t,n,s){return r.destroy(),e.destroy(),n&&n.destroy(),s.fill(0),t}function ji(r,e,t,n){let{c:s,dkLen:o,DK:i,PRF:a,PRFSalt:c}=$i(r,e,t,n),u,l=new Uint8Array(4),f=Nt(l),h=new Uint8Array(a.outputLen);for(let w=1,x=0;x<o;w++,x+=a.outputLen){let y=i.subarray(x,x+a.outputLen);f.setInt32(0,w,!1),(u=c._cloneInto(u)).update(l).digestInto(h),y.set(h.subarray(0,y.length));for(let d=1;d<s;d++){a._cloneInto(u).update(h).digestInto(h);for(let m=0;m<y.length;m++)y[m]^=h[m]}}return qi(a,c,i,u,h)}async function to(r,e,t,n){let{c:s,dkLen:o,asyncTick:i,DK:a,PRF:c,PRFSalt:u}=$i(r,e,t,n),l,f=new Uint8Array(4),h=Nt(f),w=new Uint8Array(c.outputLen);for(let x=1,y=0;y<o;x++,y+=c.outputLen){let d=a.subarray(y,y+c.outputLen);h.setInt32(0,x,!1),(l=u._cloneInto(l)).update(f).digestInto(w),d.set(w.subarray(0,d.length)),await ei(s-1,i,()=>{c._cloneInto(l).update(w).digestInto(w);for(let m=0;m<d.length;m++)d[m]^=w[m]})}return qi(c,u,a,l,w)}var M=gc(zi());function Dt(r,e){let t=0;if(r.length===1)return r[0];for(let n=r.length-1;n>=0;n--)t+=r[r.length-1-n]*Math.pow(2,e*n);return t}function mt(r,e,t=-1){let n=t,s=r,o=0,i=Math.pow(2,e);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 u=new Uint8Array(c);for(let l=a-1;l>=0;l--){let f=Math.pow(2,l*e);u[o-l-1]=Math.floor(s/f),s-=u[o-l-1]*f}return c}i*=Math.pow(2,e)}return new ArrayBuffer(0)}function cn(...r){let e=0,t=0;for(let o of r)e+=o.length;let n=new ArrayBuffer(e),s=new Uint8Array(n);for(let o of r)s.set(o,t),t+=o.length;return s}function no(){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 e=new ArrayBuffer(this.valueHex.byteLength),t=new Uint8Array(e);for(let a=0;a<this.valueHex.byteLength;a++)t[a]=0;t[0]=r[0]&128;let n=Dt(t,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,Dt(o,8)-n}function Gi(r){let e=r<0?r*-1:r,t=128;for(let n=1;n<8;n++){if(e<=t){if(r<0){let i=t-e,a=mt(i,8,n),c=new Uint8Array(a);return c[0]|=128,a}let s=mt(e,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}t*=Math.pow(2,8)}return new ArrayBuffer(0)}function Zi(r,e){if(r.byteLength!==e.byteLength)return!1;let t=new Uint8Array(r),n=new Uint8Array(e);for(let s=0;s<t.length;s++)if(t[s]!==n[s])return!1;return!0}function xe(r,e){let t=r.toString(10);if(e<t.length)return"";let n=e-t.length,s=new Array(n);for(let i=0;i<n;i++)s[i]="0";return s.join("").concat(t)}var F0=Math.log(2);function ln(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function so(r){let e=0,t=0;for(let s=0;s<r.length;s++){let o=r[s];e+=o.byteLength}let n=new Uint8Array(e);for(let s=0;s<r.length;s++){let o=r[s];n.set(new Uint8Array(o),t),t+=o.byteLength}return n.buffer}function tt(r,e,t,n){return e instanceof Uint8Array?e.byteLength?t<0?(r.error="Wrong parameter: inputOffset less than zero",!1):n<0?(r.error="Wrong parameter: inputLength less than zero",!1):e.byteLength-t-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 kr=class{constructor(){this.items=[]}write(e){this.items.push(e)}final(){return so(this.items)}},Ar=[new Uint8Array([1])],Yi="0123456789";var lr="",Le=new ArrayBuffer(0),oo=new Uint8Array(0),Sr="EndOfContent",Ji="OCTET STRING",Xi="BIT STRING";function rt(r){var e;return e=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):oo}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(!tt(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",Le)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:M.Convert.ToHex(this.valueHexView)}}},e.NAME="hexBlock",e}var Xe=class{constructor({blockLength:e=0,error:t=lr,warnings:n=[],valueBeforeDecode:s=oo}={}){this.blockLength=e,this.error=t,this.warnings=n,this.valueBeforeDecodeView=M.BufferSourceConverter.toUint8Array(s)}static blockName(){return this.NAME}get valueBeforeDecode(){return this.valueBeforeDecodeView.slice().buffer}set valueBeforeDecode(e){this.valueBeforeDecodeView=new Uint8Array(e)}toJSON(){return{blockName:this.constructor.NAME,blockLength:this.blockLength,error:this.error,warnings:this.warnings,valueBeforeDecode:M.Convert.ToHex(this.valueBeforeDecodeView)}}};Xe.NAME="baseBlock";var de=class extends Xe{fromBER(e,t,n){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}toBER(e,t){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}};de.NAME="valueBlock";var un=class extends rt(Xe){constructor({idBlock:e={}}={}){var t,n,s,o;super(),e?(this.isHexOnly=(t=e.isHexOnly)!==null&&t!==void 0?t:!1,this.valueHexView=e.valueHex?M.BufferSourceConverter.toUint8Array(e.valueHex):oo,this.tagClass=(n=e.tagClass)!==null&&n!==void 0?n:-1,this.tagNumber=(s=e.tagNumber)!==null&&s!==void 0?s:-1,this.isConstructed=(o=e.isConstructed)!==null&&o!==void 0?o:!1):(this.tagClass=-1,this.tagNumber=-1,this.isConstructed=!1)}toBER(e=!1){let t=0;switch(this.tagClass){case 1:t|=0;break;case 2:t|=64;break;case 3:t|=128;break;case 4:t|=192;break;default:return this.error="Unknown tag class",Le}if(this.isConstructed&&(t|=32),this.tagNumber<31&&!this.isHexOnly){let s=new Uint8Array(1);if(!e){let o=this.tagNumber;o&=31,t|=o,s[0]=t}return s.buffer}if(!this.isHexOnly){let s=mt(this.tagNumber,7),o=new Uint8Array(s),i=s.byteLength,a=new Uint8Array(i+1);if(a[0]=t|31,!e){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]=t|31,!e){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(e,t,n){let s=M.BufferSourceConverter.toUint8Array(e);if(!tt(this,s,t,n))return-1;let o=s.subarray(t,t+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,u=this.valueHexView=new Uint8Array(255),l=255;for(;o[c]&128;){if(u[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 w=0;w<u.length;w++)h[w]=u[w];u=this.valueHexView=new Uint8Array(l)}}this.blockLength=c+1,u[c-1]=o[c]&127;let f=new Uint8Array(c);for(let h=0;h<c;h++)f[h]=u[h];u=this.valueHexView=new Uint8Array(c),u.set(f),this.blockLength<=9?this.tagNumber=Dt(u,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 t+this.blockLength}toJSON(){return{...super.toJSON(),tagClass:this.tagClass,tagNumber:this.tagNumber,isConstructed:this.isConstructed}}};un.NAME="identificationBlock";var fn=class extends Xe{constructor({lenBlock:e={}}={}){var t,n,s;super(),this.isIndefiniteForm=(t=e.isIndefiniteForm)!==null&&t!==void 0?t:!1,this.longFormUsed=(n=e.longFormUsed)!==null&&n!==void 0?n:!1,this.length=(s=e.length)!==null&&s!==void 0?s:0}fromBER(e,t,n){let s=M.BufferSourceConverter.toUint8Array(e);if(!tt(this,s,t,n))return-1;let o=s.subarray(t,t+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,t+this.blockLength;if(this.longFormUsed=!!(o[0]&128),this.longFormUsed===!1)return this.length=o[0],this.blockLength=1,t+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=t+1,c=s.subarray(a,a+i);return c[i-1]===0&&this.warnings.push("Needlessly long encoded length"),this.length=Dt(c,8),this.longFormUsed&&this.length<=127&&this.warnings.push("Unnecessary usage of long length form"),this.blockLength=i+1,t+this.blockLength}toBER(e=!1){let t,n;if(this.length>127&&(this.longFormUsed=!0),this.isIndefiniteForm)return t=new ArrayBuffer(1),e===!1&&(n=new Uint8Array(t),n[0]=128),t;if(this.longFormUsed){let s=mt(this.length,8);if(s.byteLength>127)return this.error="Too big length",Le;if(t=new ArrayBuffer(s.byteLength+1),e)return t;let o=new Uint8Array(s);n=new Uint8Array(t),n[0]=s.byteLength|128;for(let i=0;i<s.byteLength;i++)n[i+1]=o[i];return t}return t=new ArrayBuffer(1),e===!1&&(n=new Uint8Array(t),n[0]=this.length),t}toJSON(){return{...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,longFormUsed:this.longFormUsed,length:this.length}}};fn.NAME="lengthBlock";var k={},fe=class extends Xe{constructor({name:e=lr,optional:t=!1,primitiveSchema:n,...s}={},o){super(s),this.name=e,this.optional=t,n&&(this.primitiveSchema=n),this.idBlock=new un(s),this.lenBlock=new fn(s),this.valueBlock=o?new o(s):new de(s)}fromBER(e,t,n){let s=this.valueBlock.fromBER(e,t,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(e,t){let n=t||new kr;t||Qi(this);let s=this.idBlock.toBER(e);if(n.write(s),this.lenBlock.isIndefiniteForm)n.write(new Uint8Array([128]).buffer),this.valueBlock.toBER(e,n),n.write(new ArrayBuffer(2));else{let o=this.valueBlock.toBER(e);this.lenBlock.length=o.byteLength;let i=this.lenBlock.toBER(e);n.write(i),n.write(o)}return t?Le:n.final()}toJSON(){let e={...super.toJSON(),idBlock:this.idBlock.toJSON(),lenBlock:this.lenBlock.toJSON(),valueBlock:this.valueBlock.toJSON(),name:this.name,optional:this.optional};return this.primitiveSchema&&(e.primitiveSchema=this.primitiveSchema.toJSON()),e}toString(e="ascii"){return e==="ascii"?this.onAsciiEncoding():M.Convert.ToHex(this.toBER())}onAsciiEncoding(){return`${this.constructor.NAME} : ${M.Convert.ToHex(this.valueBlock.valueBeforeDecodeView)}`}isEqual(e){if(this===e)return!0;if(!(e instanceof this.constructor))return!1;let t=this.toBER(),n=e.toBER();return Zi(t,n)}};fe.NAME="BaseBlock";function Qi(r){if(r instanceof k.Constructed)for(let e of r.valueBlock.value)Qi(e)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var hn=class extends fe{constructor({value:e=lr,...t}={},n){super(t,n),e&&this.fromString(e)}getValue(){return this.valueBlock.value}setValue(e){this.valueBlock.value=e}fromBER(e,t,n){let s=this.valueBlock.fromBER(e,t,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}'`}};hn.NAME="BaseStringBlock";var dn=class extends rt(de){constructor({isHexOnly:e=!0,...t}={}){super(t),this.isHexOnly=e}};dn.NAME="PrimitiveValueBlock";var ea,gn=class extends fe{constructor(e={}){super(e,dn),this.idBlock.isConstructed=!1}};ea=gn;k.Primitive=ea;gn.NAME="PRIMITIVE";function ef(r,e){if(r instanceof e)return r;let t=new e;return t.idBlock=r.idBlock,t.lenBlock=r.lenBlock,t.warnings=r.warnings,t.valueBeforeDecodeView=r.valueBeforeDecodeView,t}function Gn(r,e=0,t=r.length){let n=e,s=new fe({},de),o=new Xe;if(!tt(o,r,e,t))return s.error=o.error,{offset:-1,result:s};if(!r.subarray(e,e+t).length)return s.error="Zero buffer length",{offset:-1,result:s};let a=s.idBlock.fromBER(r,e,t);if(s.idBlock.warnings.length&&s.warnings.concat(s.idBlock.warnings),a===-1)return s.error=s.idBlock.error,{offset:-1,result:s};if(e=a,t-=s.idBlock.blockLength,a=s.lenBlock.fromBER(r,e,t),s.lenBlock.warnings.length&&s.warnings.concat(s.lenBlock.warnings),a===-1)return s.error=s.lenBlock.error,{offset:-1,result:s};if(e=a,t-=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=fe;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=k.EndOfContent;break;case 1:c=k.Boolean;break;case 2:c=k.Integer;break;case 3:c=k.BitString;break;case 4:c=k.OctetString;break;case 5:c=k.Null;break;case 6:c=k.ObjectIdentifier;break;case 10:c=k.Enumerated;break;case 12:c=k.Utf8String;break;case 13:c=k.RelativeObjectIdentifier;break;case 14:c=k.TIME;break;case 15:return s.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:s};case 16:c=k.Sequence;break;case 17:c=k.Set;break;case 18:c=k.NumericString;break;case 19:c=k.PrintableString;break;case 20:c=k.TeletexString;break;case 21:c=k.VideotexString;break;case 22:c=k.IA5String;break;case 23:c=k.UTCTime;break;case 24:c=k.GeneralizedTime;break;case 25:c=k.GraphicString;break;case 26:c=k.VisibleString;break;case 27:c=k.GeneralString;break;case 28:c=k.UniversalString;break;case 29:c=k.CharacterString;break;case 30:c=k.BmpString;break;case 31:c=k.DATE;break;case 32:c=k.TimeOfDay;break;case 33:c=k.DateTime;break;case 34:c=k.Duration;break;default:{let u=s.idBlock.isConstructed?new k.Constructed:new k.Primitive;u.idBlock=s.idBlock,u.lenBlock=s.lenBlock,u.warnings=s.warnings,s=u}}break;case 2:case 3:case 4:default:c=s.idBlock.isConstructed?k.Constructed:k.Primitive}return s=ef(s,c),a=s.fromBER(r,e,s.lenBlock.isIndefiniteForm?t:s.lenBlock.length),s.valueBeforeDecodeView=r.subarray(n,n+s.blockLength),{offset:a,result:s}}function ur(r){if(!r.byteLength){let e=new fe({},de);return e.error="Input buffer has zero length",{offset:-1,result:e}}return Gn(M.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function tf(r,e){return r?1:e}var De=class extends de{constructor({value:e=[],isIndefiniteForm:t=!1,...n}={}){super(n),this.value=e,this.isIndefiniteForm=t}fromBER(e,t,n){let s=M.BufferSourceConverter.toUint8Array(e);if(!tt(this,s,t,n))return-1;if(this.valueBeforeDecodeView=s.subarray(t,t+n),this.valueBeforeDecodeView.length===0)return this.warnings.push("Zero buffer length"),t;let o=t;for(;tf(this.isIndefiniteForm,n)>0;){let i=Gn(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===Sr)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===Sr?this.value.pop():this.warnings.push("No EndOfContent block encoded")),o}toBER(e,t){let n=t||new kr;for(let s=0;s<this.value.length;s++)this.value[s].toBER(e,n);return t?Le:n.final()}toJSON(){let e={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let t of this.value)e.value.push(t.toJSON());return e}};De.NAME="ConstructedValueBlock";var ta,bt=class extends fe{constructor(e={}){super(e,De),this.idBlock.isConstructed=!0}fromBER(e,t,n){this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm;let s=this.valueBlock.fromBER(e,t,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 e=[];for(let n of this.valueBlock.value)e.push(n.toString("ascii").split(`
3
3
  `).map(s=>` ${s}`).join(`
4
4
  `));let t=this.idBlock.tagClass===3?`[${this.idBlock.tagNumber}]`:this.constructor.NAME;return e.length?`${t} :
5
5
  ${e.join(`
6
- `)}`:`${t} :`}};Qi=gt;A.Constructed=Qi;gt.NAME="CONSTRUCTED";var dn=class extends he{fromBER(e,t,n){return t}toBER(e){return Le}};dn.override="EndOfContentValueBlock";var ea,gn=class extends ue{constructor(e={}){super(e,dn),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};ea=gn;A.EndOfContent=ea;gn.NAME=vr;var ta,pt=class extends ue{constructor(e={}){super(e,he),this.idBlock.tagClass=1,this.idBlock.tagNumber=5}fromBER(e,t,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,t+n>e.byteLength?(this.error="End of input reached before message was fully decoded (inconsistent offset and length values)",-1):t+n}toBER(e,t){let n=new ArrayBuffer(2);if(!e){let s=new Uint8Array(n);s[0]=5,s[1]=0}return t&&t.write(n),n}onAsciiEncoding(){return`${this.constructor.NAME}`}};ta=pt;A.Null=ta;pt.NAME="NULL";var pn=class extends tt(he){constructor({value:e,...t}={}){super(t),t.valueHex?this.valueHexView=D.BufferSourceConverter.toUint8Array(t.valueHex):this.valueHexView=new Uint8Array(1),e&&(this.value=e)}get value(){for(let e of this.valueHexView)if(e>0)return!0;return!1}set value(e){this.valueHexView[0]=e?255:0}fromBER(e,t,n){let s=D.BufferSourceConverter.toUint8Array(e);return et(this,s,t,n)?(this.valueHexView=s.subarray(t,t+n),n>1&&this.warnings.push("Boolean value encoded in more then 1 octet"),this.isHexOnly=!0,eo.call(this),this.blockLength=n,t+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};pn.NAME="BooleanValueBlock";var ra,yn=class extends ue{constructor(e={}){super(e,pn),this.idBlock.tagClass=1,this.idBlock.tagNumber=1}getValue(){return this.valueBlock.value}setValue(e){this.valueBlock.value=e}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.getValue}`}};ra=yn;A.Boolean=ra;yn.NAME="BOOLEAN";var mn=class extends tt(Oe){constructor({isConstructed:e=!1,...t}={}){super(t),this.isConstructed=e}fromBER(e,t,n){let s=0;if(this.isConstructed){if(this.isHexOnly=!1,s=Oe.prototype.fromBER.call(this,e,t,n),s===-1)return s;for(let o=0;o<this.value.length;o++){let i=this.value[o].constructor.NAME;if(i===vr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(i!==Yi)return this.error="OCTET STRING may consists of OCTET STRINGs only",-1}}else this.isHexOnly=!0,s=super.fromBER(e,t,n),this.blockLength=n;return s}toBER(e,t){return this.isConstructed?Oe.prototype.toBER.call(this,e,t):e?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};mn.NAME="OctetStringValueBlock";var na,Xe=class r extends ue{constructor({idBlock:e={},lenBlock:t={},...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,...e},lenBlock:{...t,isIndefiniteForm:!!n.isIndefiniteForm},...n},mn),this.idBlock.tagClass=1,this.idBlock.tagNumber=4}fromBER(e,t,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),t;if(!this.valueBlock.isConstructed){let o=(e instanceof ArrayBuffer?new Uint8Array(e):e).subarray(t,t+n);try{if(o.byteLength){let i=jn(o,0,o.byteLength);i.offset!==-1&&i.offset===n&&(this.valueBlock.value=[i.result])}}catch{}}return super.fromBER(e,t,n)}onAsciiEncoding(){return this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length?gt.prototype.onAsciiEncoding.call(this):`${this.constructor.NAME} : ${D.Convert.ToHex(this.valueBlock.valueHexView)}`}getValue(){if(!this.idBlock.isConstructed)return this.valueBlock.valueHexView.slice().buffer;let e=[];for(let t of this.valueBlock.value)t instanceof r&&e.push(t.valueBlock.valueHexView);return D.BufferSourceConverter.concat(e)}};na=Xe;A.OctetString=na;Xe.NAME=Yi;var bn=class extends tt(Oe){constructor({unusedBits:e=0,isConstructed:t=!1,...n}={}){super(n),this.unusedBits=e,this.isConstructed=t,this.blockLength=this.valueHexView.byteLength}fromBER(e,t,n){if(!n)return t;let s=-1;if(this.isConstructed){if(s=Oe.prototype.fromBER.call(this,e,t,n),s===-1)return s;for(let a of this.value){let c=a.constructor.NAME;if(c===vr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==Wi)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=D.BufferSourceConverter.toUint8Array(e);if(!et(this,o,t,n))return-1;let i=o.subarray(t,t+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=jn(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,t+n}toBER(e,t){if(this.isConstructed)return Oe.prototype.toBER.call(this,e,t);if(e)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return Le;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}}};bn.NAME="BitStringValueBlock";var sa,or=class extends ue{constructor({idBlock:e={},lenBlock:t={},...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,...e},lenBlock:{...t,isIndefiniteForm:!!n.isIndefiniteForm},...n},bn),this.idBlock.tagClass=1,this.idBlock.tagNumber=3}fromBER(e,t,n){return this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,super.fromBER(e,t,n)}onAsciiEncoding(){if(this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length)return gt.prototype.onAsciiEncoding.call(this);{let e=[],t=this.valueBlock.valueHexView;for(let s of t)e.push(s.toString(2).padStart(8,"0"));let n=e.join("");return`${this.constructor.NAME} : ${n.substring(0,n.length-this.valueBlock.unusedBits)}`}}};sa=or;A.BitString=sa;or.NAME=Wi;var oa;function ef(r,e){let t=new Uint8Array([0]),n=new Uint8Array(r),s=new Uint8Array(e),o=n.slice(0),i=o.length-1,a=s.slice(0),c=a.length-1,f=0,u=c<i?i:c,l=0;for(let p=u;p>=0;p--,l++){switch(!0){case l<a.length:f=o[i-l]+a[c-l]+t[0];break;default:f=o[i-l]+t[0]}switch(t[0]=f/10,!0){case l>=o.length:o=on(new Uint8Array([f%10]),o);break;default:o[i-l]=f%10}}return t[0]>0&&(o=on(t,o)),o}function Zi(r){if(r>=xr.length)for(let e=xr.length;e<=r;e++){let t=new Uint8Array([0]),n=xr[e-1].slice(0);for(let s=n.length-1;s>=0;s--){let o=new Uint8Array([(n[s]<<1)+t[0]]);t[0]=o[0]/10,n[s]=o[0]%10}t[0]>0&&(n=on(t,n)),xr.push(n)}return xr[r]}function tf(r,e){let t=0,n=new Uint8Array(r),s=new Uint8Array(e),o=n.slice(0),i=o.length-1,a=s.slice(0),c=a.length-1,f,u=0;for(let l=c;l>=0;l--,u++)switch(f=o[i-u]-a[c-u]-t,!0){case f<0:t=1,o[i-u]=f+10;break;default:t=0,o[i-u]=f}if(t>0)for(let l=i-c+1;l>=0;l--,u++)if(f=o[i-u]-t,f<0)t=1,o[i-u]=f+10;else{t=0,o[i-u]=f;break}return o.slice()}var Er=class extends tt(he){constructor({value:e,...t}={}){super(t),this._valueDec=0,t.valueHex&&this.setValueHex(),e!==void 0&&(this.valueDec=e)}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=eo.call(this)))}set valueDec(e){this._valueDec=e,this.isHexOnly=!1,this.valueHexView=new Uint8Array(ji(e))}get valueDec(){return this._valueDec}fromDER(e,t,n,s=0){let o=this.fromBER(e,t,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(e=!1){let t=this.valueHexView;switch(!0){case(t[0]&128)!==0:{let n=new Uint8Array(this.valueHexView.length+1);n[0]=0,n.set(t,1),this.valueHexView=n}break;case(t[0]===0&&(t[1]&128)===0):this.valueHexView=this.valueHexView.subarray(1);break}return this.toBER(e)}fromBER(e,t,n){let s=super.fromBER(e,t,n);return s===-1||this.setValueHex(),s}toBER(e){return e?new ArrayBuffer(this.valueHexView.length):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}toString(){let e=this.valueHexView.length*8-1,t=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 e:t=tf(Zi(n),t),i="-";break;default:t=ef(t,Zi(n))}n++,s>>=1}}for(let c=0;c<t.length;c++)t[c]&&(a=!0),a&&(i+=Gi.charAt(t[c]));return a===!1&&(i+=Gi.charAt(0)),i}};oa=Er;Er.NAME="IntegerValueBlock";Object.defineProperty(oa.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var ia,re=class r extends ue{constructor(e={}){super(e,Er),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return an(),BigInt(this.valueBlock.toString())}static fromBigInt(e){an();let t=BigInt(e),n=new Br,s=t.toString(16).replace(/^-/,""),o=new Uint8Array(D.Convert.FromHex(s));if(t<0){let a=new Uint8Array(o.length+(o[0]&128?1:0));a[0]|=128;let f=BigInt(`0x${D.Convert.ToHex(a)}`)+t,u=D.BufferSourceConverter.toUint8Array(D.Convert.FromHex(f.toString(16)));u[0]|=128,n.write(u)}else o[0]&128&&n.write(new Uint8Array([0])),n.write(o);return new r({valueHex:n.final()})}convertToDER(){let e=new r({valueHex:this.valueBlock.valueHexView});return e.valueBlock.toDER(),e}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()}`}};ia=re;A.Integer=ia;re.NAME="INTEGER";var aa,wn=class extends re{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};aa=wn;A.Enumerated=aa;wn.NAME="ENUMERATED";var Ar=class extends tt(he){constructor({valueDec:e=-1,isFirstSid:t=!1,...n}={}){super(n),this.valueDec=e,this.isFirstSid=t}fromBER(e,t,n){if(!n)return t;let s=D.BufferSourceConverter.toUint8Array(e);if(!et(this,s,t,n))return-1;let o=s.subarray(t,t+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=Lt(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),t+this.blockLength)}set valueBigInt(e){an();let t=BigInt(e).toString(2);for(;t.length%7;)t="0"+t;let n=new Uint8Array(t.length/7);for(let s=0;s<n.length;s++)n[s]=parseInt(t.slice(s*7,s*7+7),2)+(s+1<n.length?128:0);this.fromBER(n.buffer,0,n.length)}toBER(e){if(this.isHexOnly){if(e)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 t=dt(this.valueDec,7);if(t.byteLength===0)return this.error="Error during encoding SID value",Le;let n=new Uint8Array(t.byteLength);if(!e){let s=new Uint8Array(t),o=t.byteLength-1;for(let i=0;i<o;i++)n[i]=s[i]|128;n[o]=s[o]}return n}toString(){let e="";if(this.isHexOnly)e=D.Convert.ToHex(this.valueHexView);else if(this.isFirstSid){let t=this.valueDec;this.valueDec<=39?e="0.":this.valueDec<=79?(e="1.",t-=40):(e="2.",t-=80),e+=t.toString()}else e=this.valueDec.toString();return e}toJSON(){return{...super.toJSON(),valueDec:this.valueDec,isFirstSid:this.isFirstSid}}};Ar.NAME="sidBlock";var xn=class extends he{constructor({value:e=ir,...t}={}){super(t),this.value=[],e&&this.fromString(e)}fromBER(e,t,n){let s=t;for(;n>0;){let o=new Ar;if(s=o.fromBER(e,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(e){let t=[];for(let n=0;n<this.value.length;n++){let s=this.value[n].toBER(e);if(s.byteLength===0)return this.error=this.value[n].error,Le;t.push(s)}return to(t)}fromString(e){this.value=[];let t=0,n=0,s="",o=!1;do if(n=e.indexOf(".",t),n===-1?s=e.substring(t):s=e.substring(t,n),t=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 Ar;if(s>Number.MAX_SAFE_INTEGER){an();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 e="",t=!1;for(let n=0;n<this.value.length;n++){t=this.value[n].isHexOnly;let s=this.value[n].toString();n!==0&&(e=`${e}.`),t?(s=`{${s}}`,this.value[n].isFirstSid?e=`2.{${s} - 80}`:e+=s):e+=s}return e}toJSON(){let e={...super.toJSON(),value:this.toString(),sidArray:[]};for(let t=0;t<this.value.length;t++)e.sidArray.push(this.value[t].toJSON());return e}};xn.NAME="ObjectIdentifierValueBlock";var ca,Ue=class extends ue{constructor(e={}){super(e,xn),this.idBlock.tagClass=1,this.idBlock.tagNumber=6}getValue(){return this.valueBlock.toString()}setValue(e){this.valueBlock.fromString(e)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};ca=Ue;A.ObjectIdentifier=ca;Ue.NAME="OBJECT IDENTIFIER";var kr=class extends tt(Je){constructor({valueDec:e=0,...t}={}){super(t),this.valueDec=e}fromBER(e,t,n){if(n===0)return t;let s=D.BufferSourceConverter.toUint8Array(e);if(!et(this,s,t,n))return-1;let o=s.subarray(t,t+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=Lt(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),t+this.blockLength)}toBER(e){if(this.isHexOnly){if(e)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 t=dt(this.valueDec,7);if(t.byteLength===0)return this.error="Error during encoding SID value",Le;let n=new Uint8Array(t.byteLength);if(!e){let s=new Uint8Array(t),o=t.byteLength-1;for(let i=0;i<o;i++)n[i]=s[i]|128;n[o]=s[o]}return n.buffer}toString(){let e="";return this.isHexOnly?e=D.Convert.ToHex(this.valueHexView):e=this.valueDec.toString(),e}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};kr.NAME="relativeSidBlock";var Bn=class extends he{constructor({value:e=ir,...t}={}){super(t),this.value=[],e&&this.fromString(e)}fromBER(e,t,n){let s=t;for(;n>0;){let o=new kr;if(s=o.fromBER(e,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(e,t){let n=[];for(let s=0;s<this.value.length;s++){let o=this.value[s].toBER(e);if(o.byteLength===0)return this.error=this.value[s].error,Le;n.push(o)}return to(n)}fromString(e){this.value=[];let t=0,n=0,s="";do{n=e.indexOf(".",t),n===-1?s=e.substring(t):s=e.substring(t,n),t=n+1;let o=new kr;if(o.valueDec=parseInt(s,10),isNaN(o.valueDec))return!0;this.value.push(o)}while(n!==-1);return!0}toString(){let e="",t=!1;for(let n=0;n<this.value.length;n++){t=this.value[n].isHexOnly;let s=this.value[n].toString();n!==0&&(e=`${e}.`),t&&(s=`{${s}}`),e+=s}return e}toJSON(){let e={...super.toJSON(),value:this.toString(),sidArray:[]};for(let t=0;t<this.value.length;t++)e.sidArray.push(this.value[t].toJSON());return e}};Bn.NAME="RelativeObjectIdentifierValueBlock";var la,vn=class extends ue{constructor(e={}){super(e,Bn),this.idBlock.tagClass=1,this.idBlock.tagNumber=13}getValue(){return this.valueBlock.toString()}setValue(e){this.valueBlock.fromString(e)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};la=vn;A.RelativeObjectIdentifier=la;vn.NAME="RelativeObjectIdentifier";var ua,ce=class extends gt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};ua=ce;A.Sequence=ua;ce.NAME="SEQUENCE";var fa,En=class extends gt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};fa=En;A.Set=fa;En.NAME="SET";var An=class extends tt(he){constructor({...e}={}){super(e),this.isHexOnly=!0,this.value=ir}toJSON(){return{...super.toJSON(),value:this.value}}};An.NAME="StringValueBlock";var kn=class extends An{};kn.NAME="SimpleStringValueBlock";var ge=class extends un{constructor({...e}={}){super(e,kn)}fromBuffer(e){this.valueBlock.value=String.fromCharCode.apply(null,D.BufferSourceConverter.toUint8Array(e))}fromString(e){let t=e.length,n=this.valueBlock.valueHexView=new Uint8Array(t);for(let s=0;s<t;s++)n[s]=e.charCodeAt(s);this.valueBlock.value=e}};ge.NAME="SIMPLE STRING";var Sn=class extends ge{fromBuffer(e){this.valueBlock.valueHexView=D.BufferSourceConverter.toUint8Array(e);try{this.valueBlock.value=D.Convert.ToUtf8String(e)}catch(t){this.warnings.push(`Error during "decodeURIComponent": ${t}, using raw string`),this.valueBlock.value=D.Convert.ToBinary(e)}}fromString(e){this.valueBlock.valueHexView=new Uint8Array(D.Convert.FromUtf8String(e)),this.valueBlock.value=e}};Sn.NAME="Utf8StringValueBlock";var ha,Qe=class extends Sn{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};ha=Qe;A.Utf8String=ha;Qe.NAME="UTF8String";var In=class extends ge{fromBuffer(e){this.valueBlock.value=D.Convert.ToUtf16String(e),this.valueBlock.valueHexView=D.BufferSourceConverter.toUint8Array(e)}fromString(e){this.valueBlock.value=e,this.valueBlock.valueHexView=new Uint8Array(D.Convert.FromUtf16String(e))}};In.NAME="BmpStringValueBlock";var da,Nn=class extends In{constructor({...e}={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};da=Nn;A.BmpString=da;Nn.NAME="BMPString";var Rn=class extends ge{fromBuffer(e){let t=ArrayBuffer.isView(e)?e.slice().buffer:e.slice(0),n=new Uint8Array(t);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(t))}fromString(e){let t=e.length,n=this.valueBlock.valueHexView=new Uint8Array(t*4);for(let s=0;s<t;s++){let o=dt(e.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=e}};Rn.NAME="UniversalStringValueBlock";var ga,Cn=class extends Rn{constructor({...e}={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};ga=Cn;A.UniversalString=ga;Cn.NAME="UniversalString";var pa,Tn=class extends ge{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};pa=Tn;A.NumericString=pa;Tn.NAME="NumericString";var ya,_n=class extends ge{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};ya=_n;A.PrintableString=ya;_n.NAME="PrintableString";var ma,Un=class extends ge{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};ma=Un;A.TeletexString=ma;Un.NAME="TeletexString";var ba,Ln=class extends ge{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};ba=Ln;A.VideotexString=ba;Ln.NAME="VideotexString";var wa,Vn=class extends ge{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};wa=Vn;A.IA5String=wa;Vn.NAME="IA5String";var xa,Hn=class extends ge{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};xa=Hn;A.GraphicString=xa;Hn.NAME="GraphicString";var Ba,Sr=class extends ge{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};Ba=Sr;A.VisibleString=Ba;Sr.NAME="VisibleString";var va,Dn=class extends ge{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};va=Dn;A.GeneralString=va;Dn.NAME="GeneralString";var Ea,On=class extends ge{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};Ea=On;A.CharacterString=Ea;On.NAME="CharacterString";var Aa,Ir=class extends Sr{constructor({value:e,valueDate:t,...n}={}){if(super(n),this.year=0,this.month=0,this.day=0,this.hour=0,this.minute=0,this.second=0,e){this.fromString(e),this.valueBlock.valueHexView=new Uint8Array(e.length);for(let s=0;s<e.length;s++)this.valueBlock.valueHexView[s]=e.charCodeAt(s)}t&&(this.fromDate(t),this.valueBlock.valueHexView=new Uint8Array(this.toBuffer())),this.idBlock.tagClass=1,this.idBlock.tagNumber=23}fromBuffer(e){this.fromString(String.fromCharCode.apply(null,D.BufferSourceConverter.toUint8Array(e)))}toBuffer(){let e=this.toString(),t=new ArrayBuffer(e.length),n=new Uint8Array(t);for(let s=0;s<e.length;s++)n[s]=e.charCodeAt(s);return t}fromDate(e){this.year=e.getUTCFullYear(),this.month=e.getUTCMonth()+1,this.day=e.getUTCDate(),this.hour=e.getUTCHours(),this.minute=e.getUTCMinutes(),this.second=e.getUTCSeconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second))}fromString(e){let n=/(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})Z/ig.exec(e);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(e="iso"){if(e==="iso"){let t=new Array(7);return t[0]=be(this.year<2e3?this.year-1900:this.year-2e3,2),t[1]=be(this.month,2),t[2]=be(this.day,2),t[3]=be(this.hour,2),t[4]=be(this.minute,2),t[5]=be(this.second,2),t[6]="Z",t.join("")}return super.toString(e)}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}}};Aa=Ir;A.UTCTime=Aa;Ir.NAME="UTCTime";var ka,Pn=class extends Ir{constructor(e={}){var t;super(e),(t=this.millisecond)!==null&&t!==void 0||(this.millisecond=0),this.idBlock.tagClass=1,this.idBlock.tagNumber=24}fromDate(e){super.fromDate(e),this.millisecond=e.getUTCMilliseconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second,this.millisecond))}fromString(e){let t=!1,n="",s="",o=0,i,a=0,c=0;if(e[e.length-1]==="Z")n=e.substring(0,e.length-1),t=!0;else{let l=new Number(e[e.length-1]);if(isNaN(l.valueOf()))throw new Error("Wrong input string for conversion");n=e}if(t){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 l=1,p=n.indexOf("+"),B="";if(p===-1&&(p=n.indexOf("-"),l=-1),p!==-1){if(B=n.substring(p+1),n=n.substring(0,p),B.length!==2&&B.length!==4)throw new Error("Wrong input string for conversion");let g=parseInt(B.substring(0,2),10);if(isNaN(g.valueOf()))throw new Error("Wrong input string for conversion");if(a=l*g,B.length===4){if(g=parseInt(B.substring(2,4),10),isNaN(g.valueOf()))throw new Error("Wrong input string for conversion");c=l*g}}}let f=n.indexOf(".");if(f===-1&&(f=n.indexOf(",")),f!==-1){let l=new Number(`0${n.substring(f)}`);if(isNaN(l.valueOf()))throw new Error("Wrong input string for conversion");o=l.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 l=60*o;this.minute=Math.floor(l),l=60*(l-this.minute),this.second=Math.floor(l),l=1e3*(l-this.second),this.millisecond=Math.floor(l)}break;case s.length===12:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let l=60*o;this.second=Math.floor(l),l=1e3*(l-this.second),this.millisecond=Math.floor(l)}break;case s.length===14:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let l=1e3*o;this.millisecond=Math.floor(l)}break;default:throw new Error("Wrong input string for conversion")}let u=i.exec(s);if(u===null)throw new Error("Wrong input string for conversion");for(let l=1;l<u.length;l++)switch(l){case 1:this.year=parseInt(u[l],10);break;case 2:this.month=parseInt(u[l],10);break;case 3:this.day=parseInt(u[l],10);break;case 4:this.hour=parseInt(u[l],10)+a;break;case 5:this.minute=parseInt(u[l],10)+c;break;case 6:this.second=parseInt(u[l],10);break;default:throw new Error("Wrong input string for conversion")}if(t===!1){let l=new Date(this.year,this.month,this.day,this.hour,this.minute,this.second,this.millisecond);this.year=l.getUTCFullYear(),this.month=l.getUTCMonth(),this.day=l.getUTCDay(),this.hour=l.getUTCHours(),this.minute=l.getUTCMinutes(),this.second=l.getUTCSeconds(),this.millisecond=l.getUTCMilliseconds()}}toString(e="iso"){if(e==="iso"){let t=[];return t.push(be(this.year,4)),t.push(be(this.month,2)),t.push(be(this.day,2)),t.push(be(this.hour,2)),t.push(be(this.minute,2)),t.push(be(this.second,2)),this.millisecond!==0&&(t.push("."),t.push(be(this.millisecond,3))),t.push("Z"),t.join("")}return super.toString(e)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};ka=Pn;A.GeneralizedTime=ka;Pn.NAME="GeneralizedTime";var Sa,Mn=class extends Qe{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};Sa=Mn;A.DATE=Sa;Mn.NAME="DATE";var Ia,Kn=class extends Qe{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};Ia=Kn;A.TimeOfDay=Ia;Kn.NAME="TimeOfDay";var Na,Fn=class extends Qe{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};Na=Fn;A.DateTime=Na;Fn.NAME="DateTime";var Ra,$n=class extends Qe{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};Ra=$n;A.Duration=Ra;$n.NAME="Duration";var Ca,qn=class extends Qe{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};Ca=qn;A.TIME=Ca;qn.NAME="TIME";function nf(r){let{result:e}=ar(r),t=e.valueBlock.value;return{n:te(Pe(t[1].toBigInt()),"base64url"),e:te(Pe(t[2].toBigInt()),"base64url"),d:te(Pe(t[3].toBigInt()),"base64url"),p:te(Pe(t[4].toBigInt()),"base64url"),q:te(Pe(t[5].toBigInt()),"base64url"),dp:te(Pe(t[6].toBigInt()),"base64url"),dq:te(Pe(t[7].toBigInt()),"base64url"),qi:te(Pe(t[8].toBigInt()),"base64url"),kty:"RSA",alg:"RS256"}}function sf(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 _("JWK was missing components","ERR_INVALID_PARAMETERS");let t=new ce({value:[new re({value:0}),re.fromBigInt(Me(z(r.n,"base64url"))),re.fromBigInt(Me(z(r.e,"base64url"))),re.fromBigInt(Me(z(r.d,"base64url"))),re.fromBigInt(Me(z(r.p,"base64url"))),re.fromBigInt(Me(z(r.q,"base64url"))),re.fromBigInt(Me(z(r.dp,"base64url"))),re.fromBigInt(Me(z(r.dq,"base64url"))),re.fromBigInt(Me(z(r.qi,"base64url")))]}).toBER();return new Uint8Array(t,0,t.byteLength)}function of(r){let{result:e}=ar(r),t=e.valueBlock.value[1].valueBlock.value[0].valueBlock.value;return{kty:"RSA",n:te(Pe(t[0].toBigInt()),"base64url"),e:te(Pe(t[1].toBigInt()),"base64url")}}function af(r){if(r.n==null||r.e==null)throw new _("JWK was missing components","ERR_INVALID_PARAMETERS");let t=new ce({value:[new ce({value:[new Ue({value:"1.2.840.113549.1.1.1"}),new pt]}),new or({valueHex:new ce({value:[re.fromBigInt(Me(z(r.n,"base64url"))),re.fromBigInt(Me(z(r.e,"base64url")))]}).toBER()})]}).toBER();return new Uint8Array(t,0,t.byteLength)}function Pe(r){let e=r.toString(16);e.length%2>0&&(e=`0${e}`);let t=e.length/2,n=new Uint8Array(t),s=0,o=0;for(;s<t;)n[s]=parseInt(e.slice(o,o+2),16),s+=1,o+=2;return n}function Me(r){let e=[];return r.forEach(function(t){let n=t.toString(16);n.length%2>0&&(n=`0${n}`),e.push(n)}),BigInt("0x"+e.join(""))}var cf=16,no=32,so=1e4;async function lf(r,e){let t=j.get(),s=new ce({value:[new re({value:0}),new ce({value:[new Ue({value:"1.2.840.113549.1.1.1"}),new pt]}),new Xe({valueHex:r.marshal()})]}).toBER(),o=new Uint8Array(s,0,s.byteLength),i=Ye(cf),a=await Xs(St,e,i,{c:so,dkLen:no}),c=Ye(16),f=await t.subtle.importKey("raw",a,"AES-CBC",!1,["encrypt"]),u=await t.subtle.encrypt({name:"AES-CBC",iv:c},f,o),l=new ce({value:[new Xe({valueHex:i}),new re({value:so}),new re({value:no}),new ce({value:[new Ue({value:"1.2.840.113549.2.11"}),new pt]})]}),p=new ce({value:[new Ue({value:"1.2.840.113549.1.5.13"}),new ce({value:[new ce({value:[new Ue({value:"1.2.840.113549.1.5.12"}),l]}),new ce({value:[new Ue({value:"2.16.840.1.101.3.4.1.42"}),new Xe({valueHex:c})]})]})]}),g=new ce({value:[p,new Xe({valueHex:u})]}).toBER(),h=new Uint8Array(g,0,g.byteLength);return["-----BEGIN ENCRYPTED PRIVATE KEY-----",...te(h,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
7
- `)}async function oo(r,e){let t=j.get(),n;if(r.includes("-----BEGIN ENCRYPTED PRIVATE KEY-----")){let s=z(r.replace("-----BEGIN ENCRYPTED PRIVATE KEY-----","").replace("-----END ENCRYPTED PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:o}=ar(s),{iv:i,salt:a,iterations:c,keySize:f,cipherText:u}=uf(o),l=await Xs(St,e,a,{c,dkLen:f}),p=await t.subtle.importKey("raw",l,"AES-CBC",!1,["decrypt"]),B=Nr(await t.subtle.decrypt({name:"AES-CBC",iv:i},p,u)),{result:g}=ar(B);n=Ta(g)}else if(r.includes("-----BEGIN PRIVATE KEY-----")){let s=z(r.replace("-----BEGIN PRIVATE KEY-----","").replace("-----END PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:o}=ar(s);n=Ta(o)}else throw new _("Could not parse private key from PEM data","ERR_INVALID_PARAMETERS");return io(n)}function uf(r){let e=r.valueBlock.value[0];if(e.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.13")throw new _("Only pkcs5PBES2 encrypted private keys are supported","ERR_INVALID_PARAMS");let n=e.valueBlock.value[1].valueBlock.value[0];if(n.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.12")throw new _("Only pkcs5PBKDF2 key derivation functions are supported","ERR_INVALID_PARAMS");let o=n.valueBlock.value[1],i=Nr(o.valueBlock.value[0].getValue()),a=so,c=no;if(o.valueBlock.value.length===3)a=Number(o.valueBlock.value[1].toBigInt()),c=Number(o.valueBlock.value[2].toBigInt());else if(o.valueBlock.value.length===2)throw new _("Could not derive key size and iterations from PEM file - please use @libp2p/rsa to re-import your key","ERR_INVALID_PARAMS");let f=e.valueBlock.value[1].valueBlock.value[1],u=f.valueBlock.value[0].toString();if(u!=="OBJECT IDENTIFIER : 1.2.840.113549.3.7"){if(u!=="OBJECT IDENTIFIER : 1.3.14.3.2.7"){if(u!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.2"){if(u!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.22"){if(u!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.42")throw new _("Only AES-CBC encryption schemes are supported","ERR_INVALID_PARAMS")}}}}let l=Nr(f.valueBlock.value[1].getValue());return{cipherText:Nr(r.valueBlock.value[1].getValue()),salt:i,iterations:a,keySize:c,iv:l}}function Ta(r){return Nr(r.valueBlock.value[2].getValue())}function Nr(r){return new Uint8Array(r,0,r.byteLength)}async function _a(r){let e=await j.get().subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:r,publicExponent:new Uint8Array([1,0,1]),hash:{name:"SHA-256"}},!0,["sign","verify"]),t=await Va(e);return{privateKey:t[0],publicKey:t[1]}}async function ao(r){let t=[await j.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["sign"]),await ff(r)],n=await Va({privateKey:t[0],publicKey:t[1]});return{privateKey:n[0],publicKey:n[1]}}async function Ua(r,e){let t=await j.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await j.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},t,e instanceof Uint8Array?e:e.subarray());return new Uint8Array(n,0,n.byteLength)}async function La(r,e,t){let n=await j.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return j.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,e,t instanceof Uint8Array?t:t.subarray())}async function Va(r){if(r.privateKey==null||r.publicKey==null)throw new _("Private and public key are required","ERR_INVALID_PARAMETERS");return Promise.all([j.get().subtle.exportKey("jwk",r.privateKey),j.get().subtle.exportKey("jwk",r.publicKey)])}async function ff(r){return j.get().subtle.importKey("jwk",{kty:r.kty,n:r.n,e:r.e},{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["verify"])}function zn(r){if(r.kty!=="RSA")throw new _("invalid key type","ERR_INVALID_KEY_TYPE");if(r.n==null)throw new _("invalid key modulus","ERR_INVALID_KEY_MODULUS");return z(r.n,"base64url").length*8}var Ht=8192,Vt=class{_key;constructor(e){this._key=e}verify(e,t){return La(this._key,t,e)}marshal(){return yt.jwkToPkix(this._key)}get bytes(){return Te.encode({Type:q.RSA,Data:this.marshal()}).subarray()}equals(e){return Se(this.bytes,e.bytes)}hash(){let e=we.digest(this.bytes);return ve(e)?e.then(({bytes:t})=>t):e.bytes}},mt=class{_key;_publicKey;constructor(e,t){this._key=e,this._publicKey=t}genSecret(){return Ye(16)}sign(e){return Ua(this._key,e)}get public(){if(this._publicKey==null)throw new _("public key not provided","ERR_PUBKEY_NOT_PROVIDED");return new Vt(this._publicKey)}marshal(){return yt.jwkToPkcs1(this._key)}get bytes(){return _e.encode({Type:q.RSA,Data:this.marshal()}).subarray()}equals(e){return Se(this.bytes,e.bytes)}hash(){let e=we.digest(this.bytes);return ve(e)?e.then(({bytes:t})=>t):e.bytes}async id(){let e=await this.public.hash();return te(e,"base58btc")}async export(e,t="pkcs-8"){if(t==="pkcs-8")return yt.exportToPem(this,e);if(t==="libp2p-key")return er(this.bytes,e);throw new _(`export format '${t}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};async function io(r){let e=yt.pkcs1ToJwk(r);if(zn(e)>Ht)throw new _("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await ao(e);return new mt(t.privateKey,t.publicKey)}function df(r){let e=yt.pkixToJwk(r);if(zn(e)>Ht)throw new _("key size is too large","ERR_KEY_SIZE_TOO_LARGE");return new Vt(e)}async function gf(r){if(zn(r)>Ht)throw new _("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await ao(r);return new mt(e.privateKey,e.publicKey)}async function pf(r){if(r>Ht)throw new _("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await _a(r);return new mt(e.privateKey,e.publicKey)}var go={};Q(go,{Secp256k1PrivateKey:()=>Pt,Secp256k1PublicKey:()=>Ot,generateKeyPair:()=>Nf,unmarshalSecp256k1PrivateKey:()=>Sf,unmarshalSecp256k1PublicKey:()=>If});var yf=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]),bt=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),wt=new Uint32Array(64),lo=class extends ot{constructor(){super(64,32,8,!1),this.A=bt[0]|0,this.B=bt[1]|0,this.C=bt[2]|0,this.D=bt[3]|0,this.E=bt[4]|0,this.F=bt[5]|0,this.G=bt[6]|0,this.H=bt[7]|0}get(){let{A:e,B:t,C:n,D:s,E:o,F:i,G:a,H:c}=this;return[e,t,n,s,o,i,a,c]}set(e,t,n,s,o,i,a,c){this.A=e|0,this.B=t|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(e,t){for(let l=0;l<16;l++,t+=4)wt[l]=e.getUint32(t,!1);for(let l=16;l<64;l++){let p=wt[l-15],B=wt[l-2],g=Ie(p,7)^Ie(p,18)^p>>>3,h=Ie(B,17)^Ie(B,19)^B>>>10;wt[l]=h+wt[l-7]+g+wt[l-16]|0}let{A:n,B:s,C:o,D:i,E:a,F:c,G:f,H:u}=this;for(let l=0;l<64;l++){let p=Ie(a,6)^Ie(a,11)^Ie(a,25),B=u+p+Pr(a,c,f)+yf[l]+wt[l]|0,h=(Ie(n,2)^Ie(n,13)^Ie(n,22))+Mr(n,s,o)|0;u=f,f=c,c=a,a=i+B|0,i=o,o=s,s=n,n=B+h|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,u=u+this.H|0,this.set(n,s,o,i,a,c,f,u)}roundClean(){wt.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var Gn=Yt(()=>new lo);function Ha(r){r.lowS!==void 0&&Ne("lowS",r.lowS),r.prehash!==void 0&&Ne("prehash",r.prehash)}function mf(r){let e=pr(r);De(e,{a:"field",b:"field"},{allowedPrivateKeyLengths:"array",wrapPrivateKey:"boolean",isTorsionFree:"function",clearCofactor:"function",allowInfinityPoint:"boolean",fromBytes:"function",toBytes:"function"});let{endo:t,Fp:n,a:s}=e;if(t){if(!n.eql(s,n.ZERO))throw new Error("Endomorphism can only be defined for Koblitz curves that have a=0");if(typeof t!="object"||typeof t.beta!="bigint"||typeof t.splitScalar!="function")throw new Error("Expected endomorphism with beta: bigint and splitScalar: function")}return Object.freeze({...e})}var{bytesToNumberBE:bf,hexToBytes:wf}=$r,Dt={Err:class extends Error{constructor(e=""){super(e)}},_parseInt(r){let{Err:e}=Dt;if(r.length<2||r[0]!==2)throw new e("Invalid signature integer tag");let t=r[1],n=r.subarray(2,t+2);if(!t||n.length!==t)throw new e("Invalid signature integer: wrong length");if(n[0]&128)throw new e("Invalid signature integer: negative");if(n[0]===0&&!(n[1]&128))throw new e("Invalid signature integer: unnecessary leading zero");return{d:bf(n),l:r.subarray(t+2)}},toSig(r){let{Err:e}=Dt,t=typeof r=="string"?wf(r):r;Jt(t);let n=t.length;if(n<2||t[0]!=48)throw new e("Invalid signature tag");if(t[1]!==n-2)throw new e("Invalid signature: incorrect length");let{d:s,l:o}=Dt._parseInt(t.subarray(2)),{d:i,l:a}=Dt._parseInt(o);if(a.length)throw new e("Invalid signature: left bytes after parsing");return{r:s,s:i}},hexFromSig(r){let e=f=>Number.parseInt(f[0],16)&8?"00"+f:f,t=f=>{let u=f.toString(16);return u.length&1?`0${u}`:u},n=e(t(r.s)),s=e(t(r.r)),o=n.length/2,i=s.length/2,a=t(o),c=t(i);return`30${t(i+o+4)}02${c}${s}02${a}${n}`}},xt=BigInt(0),le=BigInt(1),hg=BigInt(2),Da=BigInt(3),dg=BigInt(4);function xf(r){let e=mf(r),{Fp:t}=e,n=e.toBytes||((g,h,m)=>{let w=h.toAffine();return ze(Uint8Array.from([4]),t.toBytes(w.x),t.toBytes(w.y))}),s=e.fromBytes||(g=>{let h=g.subarray(1),m=t.fromBytes(h.subarray(0,t.BYTES)),w=t.fromBytes(h.subarray(t.BYTES,2*t.BYTES));return{x:m,y:w}});function o(g){let{a:h,b:m}=e,w=t.sqr(g),b=t.mul(w,g);return t.add(t.add(b,t.mul(g,h)),m)}if(!t.eql(t.sqr(e.Gy),o(e.Gx)))throw new Error("bad generator point: equation left != right");function i(g){return dr(g,le,e.n)}function a(g){let{allowedPrivateKeyLengths:h,nByteLength:m,wrapPrivateKey:w,n:b}=e;if(h&&typeof g!="bigint"){if(ct(g)&&(g=qe(g)),typeof g!="string"||!h.includes(g.length))throw new Error("Invalid key");g=g.padStart(m*2,"0")}let x;try{x=typeof g=="bigint"?g:je(X("private key",g,m))}catch{throw new Error(`private key must be ${m} bytes, hex or bigint, not ${typeof g}`)}return w&&(x=$(x,b)),ye("private key",x,le,b),x}function c(g){if(!(g instanceof l))throw new Error("ProjectivePoint expected")}let f=Rt((g,h)=>{let{px:m,py:w,pz:b}=g;if(t.eql(b,t.ONE))return{x:m,y:w};let x=g.is0();h==null&&(h=x?t.ONE:t.inv(b));let C=t.mul(m,h),S=t.mul(w,h),k=t.mul(b,h);if(x)return{x:t.ZERO,y:t.ZERO};if(!t.eql(k,t.ONE))throw new Error("invZ was invalid");return{x:C,y:S}}),u=Rt(g=>{if(g.is0()){if(e.allowInfinityPoint&&!t.is0(g.py))return;throw new Error("bad point: ZERO")}let{x:h,y:m}=g.toAffine();if(!t.isValid(h)||!t.isValid(m))throw new Error("bad point: x or y not FE");let w=t.sqr(m),b=o(h);if(!t.eql(w,b))throw new Error("bad point: equation left != right");if(!g.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});class l{constructor(h,m,w){if(this.px=h,this.py=m,this.pz=w,h==null||!t.isValid(h))throw new Error("x required");if(m==null||!t.isValid(m))throw new Error("y required");if(w==null||!t.isValid(w))throw new Error("z required");Object.freeze(this)}static fromAffine(h){let{x:m,y:w}=h||{};if(!h||!t.isValid(m)||!t.isValid(w))throw new Error("invalid affine point");if(h instanceof l)throw new Error("projective point not allowed");let b=x=>t.eql(x,t.ZERO);return b(m)&&b(w)?l.ZERO:new l(m,w,t.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(h){let m=t.invertBatch(h.map(w=>w.pz));return h.map((w,b)=>w.toAffine(m[b])).map(l.fromAffine)}static fromHex(h){let m=l.fromAffine(s(X("pointHex",h)));return m.assertValidity(),m}static fromPrivateKey(h){return l.BASE.multiply(a(h))}_setWindowSize(h){B.setWindowSize(this,h)}assertValidity(){u(this)}hasEvenY(){let{y:h}=this.toAffine();if(t.isOdd)return!t.isOdd(h);throw new Error("Field doesn't support isOdd")}equals(h){c(h);let{px:m,py:w,pz:b}=this,{px:x,py:C,pz:S}=h,k=t.eql(t.mul(m,S),t.mul(x,b)),R=t.eql(t.mul(w,S),t.mul(C,b));return k&&R}negate(){return new l(this.px,t.neg(this.py),this.pz)}double(){let{a:h,b:m}=e,w=t.mul(m,Da),{px:b,py:x,pz:C}=this,S=t.ZERO,k=t.ZERO,R=t.ZERO,I=t.mul(b,b),F=t.mul(x,x),O=t.mul(C,C),P=t.mul(b,x);return P=t.add(P,P),R=t.mul(b,C),R=t.add(R,R),S=t.mul(h,R),k=t.mul(w,O),k=t.add(S,k),S=t.sub(F,k),k=t.add(F,k),k=t.mul(S,k),S=t.mul(P,S),R=t.mul(w,R),O=t.mul(h,O),P=t.sub(I,O),P=t.mul(h,P),P=t.add(P,R),R=t.add(I,I),I=t.add(R,I),I=t.add(I,O),I=t.mul(I,P),k=t.add(k,I),O=t.mul(x,C),O=t.add(O,O),I=t.mul(O,P),S=t.sub(S,I),R=t.mul(O,F),R=t.add(R,R),R=t.add(R,R),new l(S,k,R)}add(h){c(h);let{px:m,py:w,pz:b}=this,{px:x,py:C,pz:S}=h,k=t.ZERO,R=t.ZERO,I=t.ZERO,F=e.a,O=t.mul(e.b,Da),P=t.mul(m,x),ee=t.mul(w,C),ne=t.mul(b,S),N=t.add(m,w),y=t.add(x,C);N=t.mul(N,y),y=t.add(P,ee),N=t.sub(N,y),y=t.add(m,b);let d=t.add(x,S);return y=t.mul(y,d),d=t.add(P,ne),y=t.sub(y,d),d=t.add(w,b),k=t.add(C,S),d=t.mul(d,k),k=t.add(ee,ne),d=t.sub(d,k),I=t.mul(F,y),k=t.mul(O,ne),I=t.add(k,I),k=t.sub(ee,I),I=t.add(ee,I),R=t.mul(k,I),ee=t.add(P,P),ee=t.add(ee,P),ne=t.mul(F,ne),y=t.mul(O,y),ee=t.add(ee,ne),ne=t.sub(P,ne),ne=t.mul(F,ne),y=t.add(y,ne),P=t.mul(ee,y),R=t.add(R,P),P=t.mul(d,y),k=t.mul(N,k),k=t.sub(k,P),P=t.mul(N,ee),I=t.mul(d,I),I=t.add(I,P),new l(k,R,I)}subtract(h){return this.add(h.negate())}is0(){return this.equals(l.ZERO)}wNAF(h){return B.wNAFCached(this,h,l.normalizeZ)}multiplyUnsafe(h){ye("scalar",h,xt,e.n);let m=l.ZERO;if(h===xt)return m;if(h===le)return this;let{endo:w}=e;if(!w)return B.unsafeLadder(this,h);let{k1neg:b,k1:x,k2neg:C,k2:S}=w.splitScalar(h),k=m,R=m,I=this;for(;x>xt||S>xt;)x&le&&(k=k.add(I)),S&le&&(R=R.add(I)),I=I.double(),x>>=le,S>>=le;return b&&(k=k.negate()),C&&(R=R.negate()),R=new l(t.mul(R.px,w.beta),R.py,R.pz),k.add(R)}multiply(h){let{endo:m,n:w}=e;ye("scalar",h,le,w);let b,x;if(m){let{k1neg:C,k1:S,k2neg:k,k2:R}=m.splitScalar(h),{p:I,f:F}=this.wNAF(S),{p:O,f:P}=this.wNAF(R);I=B.constTimeNegate(C,I),O=B.constTimeNegate(k,O),O=new l(t.mul(O.px,m.beta),O.py,O.pz),b=I.add(O),x=F.add(P)}else{let{p:C,f:S}=this.wNAF(h);b=C,x=S}return l.normalizeZ([b,x])[0]}multiplyAndAddUnsafe(h,m,w){let b=l.BASE,x=(S,k)=>k===xt||k===le||!S.equals(b)?S.multiplyUnsafe(k):S.multiply(k),C=x(this,m).add(x(h,w));return C.is0()?void 0:C}toAffine(h){return f(this,h)}isTorsionFree(){let{h,isTorsionFree:m}=e;if(h===le)return!0;if(m)return m(l,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h,clearCofactor:m}=e;return h===le?this:m?m(l,this):this.multiplyUnsafe(e.h)}toRawBytes(h=!0){return Ne("isCompressed",h),this.assertValidity(),n(l,this,h)}toHex(h=!0){return Ne("isCompressed",h),qe(this.toRawBytes(h))}}l.BASE=new l(e.Gx,e.Gy,t.ONE),l.ZERO=new l(t.ZERO,t.ONE,t.ZERO);let p=e.nBitLength,B=zr(l,e.endo?Math.ceil(p/2):p);return{CURVE:e,ProjectivePoint:l,normPrivateKeyToScalar:a,weierstrassEquation:o,isWithinCurveOrder:i}}function Bf(r){let e=pr(r);return De(e,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...e})}function Oa(r){let e=Bf(r),{Fp:t,n}=e,s=t.BYTES+1,o=2*t.BYTES+1;function i(N){return $(N,n)}function a(N){return qr(N,n)}let{ProjectivePoint:c,normPrivateKeyToScalar:f,weierstrassEquation:u,isWithinCurveOrder:l}=xf({...e,toBytes(N,y,d){let v=y.toAffine(),E=t.toBytes(v.x),T=ze;return Ne("isCompressed",d),d?T(Uint8Array.from([y.hasEvenY()?2:3]),E):T(Uint8Array.from([4]),E,t.toBytes(v.y))},fromBytes(N){let y=N.length,d=N[0],v=N.subarray(1);if(y===s&&(d===2||d===3)){let E=je(v);if(!dr(E,le,t.ORDER))throw new Error("Point is not on curve");let T=u(E),U;try{U=t.sqrt(T)}catch(H){let K=H instanceof Error?": "+H.message:"";throw new Error("Point is not on curve"+K)}let L=(U&le)===le;return(d&1)===1!==L&&(U=t.neg(U)),{x:E,y:U}}else if(y===o&&d===4){let E=t.fromBytes(v.subarray(0,t.BYTES)),T=t.fromBytes(v.subarray(t.BYTES,2*t.BYTES));return{x:E,y:T}}else throw new Error(`Point of length ${y} was invalid. Expected ${s} compressed bytes or ${o} uncompressed bytes`)}}),p=N=>qe(ut(N,e.nByteLength));function B(N){let y=n>>le;return N>y}function g(N){return B(N)?i(-N):N}let h=(N,y,d)=>je(N.slice(y,d));class m{constructor(y,d,v){this.r=y,this.s=d,this.recovery=v,this.assertValidity()}static fromCompact(y){let d=e.nByteLength;return y=X("compactSignature",y,d*2),new m(h(y,0,d),h(y,d,2*d))}static fromDER(y){let{r:d,s:v}=Dt.toSig(X("DER",y));return new m(d,v)}assertValidity(){ye("r",this.r,le,n),ye("s",this.s,le,n)}addRecoveryBit(y){return new m(this.r,this.s,y)}recoverPublicKey(y){let{r:d,s:v,recovery:E}=this,T=k(X("msgHash",y));if(E==null||![0,1,2,3].includes(E))throw new Error("recovery id invalid");let U=E===2||E===3?d+e.n:d;if(U>=t.ORDER)throw new Error("recovery id 2 or 3 invalid");let L=E&1?"03":"02",M=c.fromHex(L+p(U)),H=a(U),K=i(-T*H),Y=i(v*H),W=c.BASE.multiplyAndAddUnsafe(M,K,Y);if(!W)throw new Error("point at infinify");return W.assertValidity(),W}hasHighS(){return B(this.s)}normalizeS(){return this.hasHighS()?new m(this.r,i(-this.s),this.recovery):this}toDERRawBytes(){return It(this.toDERHex())}toDERHex(){return Dt.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return It(this.toCompactHex())}toCompactHex(){return p(this.r)+p(this.s)}}let w={isValidPrivateKey(N){try{return f(N),!0}catch{return!1}},normPrivateKeyToScalar:f,randomPrivateKey:()=>{let N=Ts(e.n);return ci(e.randomBytes(N),e.n)},precompute(N=8,y=c.BASE){return y._setWindowSize(N),y.multiply(BigInt(3)),y}};function b(N,y=!0){return c.fromPrivateKey(N).toRawBytes(y)}function x(N){let y=ct(N),d=typeof N=="string",v=(y||d)&&N.length;return y?v===s||v===o:d?v===2*s||v===2*o:N instanceof c}function C(N,y,d=!0){if(x(N))throw new Error("first arg must be private key");if(!x(y))throw new Error("second arg must be public key");return c.fromHex(y).multiply(f(N)).toRawBytes(d)}let S=e.bits2int||function(N){let y=je(N),d=N.length*8-e.nBitLength;return d>0?y>>BigInt(d):y},k=e.bits2int_modN||function(N){return i(S(N))},R=gr(e.nBitLength);function I(N){return ye(`num < 2^${e.nBitLength}`,N,xt,R),ut(N,e.nByteLength)}function F(N,y,d=O){if(["recovered","canonical"].some(ie=>ie in d))throw new Error("sign() legacy options not supported");let{hash:v,randomBytes:E}=e,{lowS:T,prehash:U,extraEntropy:L}=d;T==null&&(T=!0),N=X("msgHash",N),Ha(d),U&&(N=X("prehashed msgHash",v(N)));let M=k(N),H=f(y),K=[I(H),I(M)];if(L!=null&&L!==!1){let ie=L===!0?E(t.BYTES):L;K.push(X("extraEntropy",ie))}let Y=ze(...K),W=M;function pe(ie){let se=S(ie);if(!l(se))return;let Ae=a(se),ae=c.BASE.multiply(se).toAffine(),ke=i(ae.x);if(ke===xt)return;let vt=i(Ae*i(W+ke*H));if(vt===xt)return;let cr=(ae.x===ke?0:2)|Number(ae.y&le),Cr=vt;return T&&B(vt)&&(Cr=g(vt),cr^=1),new m(ke,Cr,cr)}return{seed:Y,k2sig:pe}}let O={lowS:e.lowS,prehash:!1},P={lowS:e.lowS,prehash:!1};function ee(N,y,d=O){let{seed:v,k2sig:E}=F(N,y,d),T=e;return Is(T.hash.outputLen,T.nByteLength,T.hmac)(v,E)}c.BASE._setWindowSize(8);function ne(N,y,d,v=P){let E=N;if(y=X("msgHash",y),d=X("publicKey",d),"strict"in v)throw new Error("options.strict was renamed to lowS");Ha(v);let{lowS:T,prehash:U}=v,L,M;try{if(typeof E=="string"||ct(E))try{L=m.fromDER(E)}catch(ae){if(!(ae instanceof Dt.Err))throw ae;L=m.fromCompact(E)}else if(typeof E=="object"&&typeof E.r=="bigint"&&typeof E.s=="bigint"){let{r:ae,s:ke}=E;L=new m(ae,ke)}else throw new Error("PARSE");M=c.fromHex(d)}catch(ae){if(ae.message==="PARSE")throw new Error("signature must be Signature instance, Uint8Array or hex string");return!1}if(T&&L.hasHighS())return!1;U&&(y=e.hash(y));let{r:H,s:K}=L,Y=k(y),W=a(K),pe=i(Y*W),ie=i(H*W),se=c.BASE.multiplyAndAddUnsafe(M,pe,ie)?.toAffine();return se?i(se.x)===H:!1}return{CURVE:e,getPublicKey:b,getSharedSecret:C,sign:ee,verify:ne,ProjectivePoint:c,Signature:m,utils:w}}function vf(r){return{hash:r,hmac:(e,...t)=>wr(r,e,xs(...t)),randomBytes:Wt}}function Pa(r,e){let t=n=>Oa({...r,...vf(n)});return Object.freeze({...t(e),create:t})}var Fa=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),Ma=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),Ef=BigInt(1),uo=BigInt(2),Ka=(r,e)=>(r+e/uo)/e;function Af(r){let e=Fa,t=BigInt(3),n=BigInt(6),s=BigInt(11),o=BigInt(22),i=BigInt(23),a=BigInt(44),c=BigInt(88),f=r*r*r%e,u=f*f*r%e,l=Z(u,t,e)*u%e,p=Z(l,t,e)*u%e,B=Z(p,uo,e)*f%e,g=Z(B,s,e)*B%e,h=Z(g,o,e)*g%e,m=Z(h,a,e)*h%e,w=Z(m,c,e)*m%e,b=Z(w,a,e)*h%e,x=Z(b,t,e)*u%e,C=Z(x,i,e)*g%e,S=Z(C,n,e)*f%e,k=Z(S,uo,e);if(!fo.eql(fo.sqr(k),r))throw new Error("Cannot find square root");return k}var fo=jr(Fa,void 0,void 0,{sqrt:Af}),Ve=Pa({a:BigInt(0),b:BigInt(7),Fp:fo,n:Ma,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let e=Ma,t=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-Ef*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),s=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),o=t,i=BigInt("0x100000000000000000000000000000000"),a=Ka(o*r,e),c=Ka(-n*r,e),f=$(r-a*t-c*s,e),u=$(-a*n-c*o,e),l=f>i,p=u>i;if(l&&(f=e-f),p&&(u=e-u),f>i||u>i)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:l,k1:f,k2neg:p,k2:u}}}},Gn),vg=BigInt(0);var Eg=Ve.ProjectivePoint;function $a(){return Ve.utils.randomPrivateKey()}function qa(r,e){let t=we.digest(e instanceof Uint8Array?e:e.subarray());if(ve(t))return t.then(({digest:n})=>Ve.sign(n,r).toDERRawBytes()).catch(n=>{throw new _(String(n),"ERR_INVALID_INPUT")});try{return Ve.sign(t.digest,r).toDERRawBytes()}catch(n){throw new _(String(n),"ERR_INVALID_INPUT")}}function ja(r,e,t){let n=we.digest(t instanceof Uint8Array?t:t.subarray());if(ve(n))return n.then(({digest:s})=>Ve.verify(e,s,r)).catch(s=>{throw new _(String(s),"ERR_INVALID_INPUT")});try{return Ve.verify(e,n.digest,r)}catch(s){throw new _(String(s),"ERR_INVALID_INPUT")}}function za(r){return Ve.ProjectivePoint.fromHex(r).toRawBytes(!0)}function Ga(r){try{Ve.getPublicKey(r,!0)}catch(e){throw new _(String(e),"ERR_INVALID_PRIVATE_KEY")}}function ho(r){try{Ve.ProjectivePoint.fromHex(r)}catch(e){throw new _(String(e),"ERR_INVALID_PUBLIC_KEY")}}function Za(r){try{return Ve.getPublicKey(r,!0)}catch(e){throw new _(String(e),"ERR_INVALID_PRIVATE_KEY")}}var Ot=class{_key;constructor(e){ho(e),this._key=e}verify(e,t){return ja(this._key,t,e)}marshal(){return za(this._key)}get bytes(){return Te.encode({Type:q.Secp256k1,Data:this.marshal()}).subarray()}equals(e){return Se(this.bytes,e.bytes)}async hash(){let e=we.digest(this.bytes),t;return ve(e)?{bytes:t}=await e:t=e.bytes,t}},Pt=class{_key;_publicKey;constructor(e,t){this._key=e,this._publicKey=t??Za(e),Ga(this._key),ho(this._publicKey)}sign(e){return qa(this._key,e)}get public(){return new Ot(this._publicKey)}marshal(){return this._key}get bytes(){return _e.encode({Type:q.Secp256k1,Data:this.marshal()}).subarray()}equals(e){return Se(this.bytes,e.bytes)}hash(){let e=we.digest(this.bytes);return ve(e)?e.then(({bytes:t})=>t):e.bytes}async id(){let e=await this.public.hash();return te(e,"base58btc")}async export(e,t="libp2p-key"){if(t==="libp2p-key")return er(this.bytes,e);throw new _(`export format '${t}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function Sf(r){return new Pt(r)}function If(r){return new Ot(r)}async function Nf(){let r=$a();return new Pt(r)}var rt={rsa:co,ed25519:Ws,secp256k1:go};function po(r){let e=Object.keys(rt).join(" / ");return new _(`invalid or unsupported key type ${r}. Must be ${e}`,"ERR_UNSUPPORTED_KEY_TYPE")}function yo(r){if(r=r.toLowerCase(),r==="rsa"||r==="ed25519"||r==="secp256k1")return rt[r];throw po(r)}async function Rf(r,e){return yo(r).generateKeyPair(e??2048)}async function Cf(r,e,t){if(r.toLowerCase()!=="ed25519")throw new _("Seed key derivation is unimplemented for RSA or secp256k1","ERR_UNSUPPORTED_KEY_DERIVATION_TYPE");return Ys(e)}function Tf(r){let e=Te.decode(r),t=e.Data??new Uint8Array;switch(e.Type){case q.RSA:return rt.rsa.unmarshalRsaPublicKey(t);case q.Ed25519:return rt.ed25519.unmarshalEd25519PublicKey(t);case q.Secp256k1:return rt.secp256k1.unmarshalSecp256k1PublicKey(t);default:throw po(e.Type??"unknown")}}function _f(r,e){return e=(e??"rsa").toLowerCase(),yo(e),r.bytes}async function Ya(r){let e=_e.decode(r),t=e.Data??new Uint8Array;switch(e.Type){case q.RSA:return rt.rsa.unmarshalRsaPrivateKey(t);case q.Ed25519:return rt.ed25519.unmarshalEd25519PrivateKey(t);case q.Secp256k1:return rt.secp256k1.unmarshalSecp256k1PrivateKey(t);default:throw po(e.Type??"RSA")}}function Uf(r,e){return e=(e??"rsa").toLowerCase(),yo(e),r.bytes}async function Lf(r,e){try{let t=await Oi(r,e);return await Ya(t)}catch{}if(!r.includes("BEGIN"))throw new _("Encrypted key was not a libp2p-key or a PEM file","ERR_INVALID_IMPORT_FORMAT");return oo(r,e)}var Rr=new Uint32Array([1732584193,4023233417,2562383102,271733878,3285377520]),Bt=new Uint32Array(80),bo=class extends ot{constructor(){super(64,20,8,!1),this.A=Rr[0]|0,this.B=Rr[1]|0,this.C=Rr[2]|0,this.D=Rr[3]|0,this.E=Rr[4]|0}get(){let{A:e,B:t,C:n,D:s,E:o}=this;return[e,t,n,s,o]}set(e,t,n,s,o){this.A=e|0,this.B=t|0,this.C=n|0,this.D=s|0,this.E=o|0}process(e,t){for(let c=0;c<16;c++,t+=4)Bt[c]=e.getUint32(t,!1);for(let c=16;c<80;c++)Bt[c]=Or(Bt[c-3]^Bt[c-8]^Bt[c-14]^Bt[c-16],1);let{A:n,B:s,C:o,D:i,E:a}=this;for(let c=0;c<80;c++){let f,u;c<20?(f=Pr(s,o,i),u=1518500249):c<40?(f=s^o^i,u=1859775393):c<60?(f=Mr(s,o,i),u=2400959708):(f=s^o^i,u=3395469782);let l=Or(n,5)+f+a+u+Bt[c]|0;a=i,i=o,o=Or(s,30),s=n,n=l}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,this.set(n,s,o,i,a)}roundClean(){Bt.fill(0)}destroy(){this.set(0,0,0,0,0),this.buffer.fill(0)}},Wa=Yt(()=>new bo);var Ja={sha1:Wa,"sha2-256":Gn,"sha2-512":St};function wo(r,e,t,n,s){if(s!=="sha1"&&s!=="sha2-256"&&s!=="sha2-512"){let a=Object.keys(Ja).join(" / ");throw new _(`Hash '${s}' is unknown or not supported. Must be ${a}`,"ERR_UNSUPPORTED_HASH_TYPE")}let o=Ja[s],i=$i(o,r,e,{c:t,dkLen:n});return At.encode(i).substring(1)}return hc(Vf);})();
6
+ `)}`:`${t} :`}};ta=bt;k.Constructed=ta;bt.NAME="CONSTRUCTED";var pn=class extends de{fromBER(e,t,n){return t}toBER(e){return Le}};pn.override="EndOfContentValueBlock";var ra,yn=class extends fe{constructor(e={}){super(e,pn),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};ra=yn;k.EndOfContent=ra;yn.NAME=Sr;var na,wt=class extends fe{constructor(e={}){super(e,de),this.idBlock.tagClass=1,this.idBlock.tagNumber=5}fromBER(e,t,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,t+n>e.byteLength?(this.error="End of input reached before message was fully decoded (inconsistent offset and length values)",-1):t+n}toBER(e,t){let n=new ArrayBuffer(2);if(!e){let s=new Uint8Array(n);s[0]=5,s[1]=0}return t&&t.write(n),n}onAsciiEncoding(){return`${this.constructor.NAME}`}};na=wt;k.Null=na;wt.NAME="NULL";var mn=class extends rt(de){constructor({value:e,...t}={}){super(t),t.valueHex?this.valueHexView=M.BufferSourceConverter.toUint8Array(t.valueHex):this.valueHexView=new Uint8Array(1),e&&(this.value=e)}get value(){for(let e of this.valueHexView)if(e>0)return!0;return!1}set value(e){this.valueHexView[0]=e?255:0}fromBER(e,t,n){let s=M.BufferSourceConverter.toUint8Array(e);return tt(this,s,t,n)?(this.valueHexView=s.subarray(t,t+n),n>1&&this.warnings.push("Boolean value encoded in more then 1 octet"),this.isHexOnly=!0,no.call(this),this.blockLength=n,t+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};mn.NAME="BooleanValueBlock";var sa,bn=class extends fe{constructor(e={}){super(e,mn),this.idBlock.tagClass=1,this.idBlock.tagNumber=1}getValue(){return this.valueBlock.value}setValue(e){this.valueBlock.value=e}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.getValue}`}};sa=bn;k.Boolean=sa;bn.NAME="BOOLEAN";var wn=class extends rt(De){constructor({isConstructed:e=!1,...t}={}){super(t),this.isConstructed=e}fromBER(e,t,n){let s=0;if(this.isConstructed){if(this.isHexOnly=!1,s=De.prototype.fromBER.call(this,e,t,n),s===-1)return s;for(let o=0;o<this.value.length;o++){let i=this.value[o].constructor.NAME;if(i===Sr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(i!==Ji)return this.error="OCTET STRING may consists of OCTET STRINGs only",-1}}else this.isHexOnly=!0,s=super.fromBER(e,t,n),this.blockLength=n;return s}toBER(e,t){return this.isConstructed?De.prototype.toBER.call(this,e,t):e?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};wn.NAME="OctetStringValueBlock";var oa,Qe=class r extends fe{constructor({idBlock:e={},lenBlock:t={},...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,...e},lenBlock:{...t,isIndefiniteForm:!!n.isIndefiniteForm},...n},wn),this.idBlock.tagClass=1,this.idBlock.tagNumber=4}fromBER(e,t,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),t;if(!this.valueBlock.isConstructed){let o=(e instanceof ArrayBuffer?new Uint8Array(e):e).subarray(t,t+n);try{if(o.byteLength){let i=Gn(o,0,o.byteLength);i.offset!==-1&&i.offset===n&&(this.valueBlock.value=[i.result])}}catch{}}return super.fromBER(e,t,n)}onAsciiEncoding(){return this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length?bt.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 e=[];for(let t of this.valueBlock.value)t instanceof r&&e.push(t.valueBlock.valueHexView);return M.BufferSourceConverter.concat(e)}};oa=Qe;k.OctetString=oa;Qe.NAME=Ji;var xn=class extends rt(De){constructor({unusedBits:e=0,isConstructed:t=!1,...n}={}){super(n),this.unusedBits=e,this.isConstructed=t,this.blockLength=this.valueHexView.byteLength}fromBER(e,t,n){if(!n)return t;let s=-1;if(this.isConstructed){if(s=De.prototype.fromBER.call(this,e,t,n),s===-1)return s;for(let a of this.value){let c=a.constructor.NAME;if(c===Sr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==Xi)return this.error="BIT STRING may consists of BIT STRINGs only",-1;let u=a.valueBlock;if(this.unusedBits>0&&u.unusedBits>0)return this.error='Using of "unused bits" inside constructive BIT STRING allowed for least one only',-1;this.unusedBits=u.unusedBits}return s}let o=M.BufferSourceConverter.toUint8Array(e);if(!tt(this,o,t,n))return-1;let i=o.subarray(t,t+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=Gn(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,t+n}toBER(e,t){if(this.isConstructed)return De.prototype.toBER.call(this,e,t);if(e)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return Le;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}}};xn.NAME="BitStringValueBlock";var ia,cr=class extends fe{constructor({idBlock:e={},lenBlock:t={},...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,...e},lenBlock:{...t,isIndefiniteForm:!!n.isIndefiniteForm},...n},xn),this.idBlock.tagClass=1,this.idBlock.tagNumber=3}fromBER(e,t,n){return this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,super.fromBER(e,t,n)}onAsciiEncoding(){if(this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length)return bt.prototype.onAsciiEncoding.call(this);{let e=[],t=this.valueBlock.valueHexView;for(let s of t)e.push(s.toString(2).padStart(8,"0"));let n=e.join("");return`${this.constructor.NAME} : ${n.substring(0,n.length-this.valueBlock.unusedBits)}`}}};ia=cr;k.BitString=ia;cr.NAME=Xi;var aa;function rf(r,e){let t=new Uint8Array([0]),n=new Uint8Array(r),s=new Uint8Array(e),o=n.slice(0),i=o.length-1,a=s.slice(0),c=a.length-1,u=0,l=c<i?i:c,f=0;for(let h=l;h>=0;h--,f++){switch(!0){case f<a.length:u=o[i-f]+a[c-f]+t[0];break;default:u=o[i-f]+t[0]}switch(t[0]=u/10,!0){case f>=o.length:o=cn(new Uint8Array([u%10]),o);break;default:o[i-f]=u%10}}return t[0]>0&&(o=cn(t,o)),o}function Wi(r){if(r>=Ar.length)for(let e=Ar.length;e<=r;e++){let t=new Uint8Array([0]),n=Ar[e-1].slice(0);for(let s=n.length-1;s>=0;s--){let o=new Uint8Array([(n[s]<<1)+t[0]]);t[0]=o[0]/10,n[s]=o[0]%10}t[0]>0&&(n=cn(t,n)),Ar.push(n)}return Ar[r]}function nf(r,e){let t=0,n=new Uint8Array(r),s=new Uint8Array(e),o=n.slice(0),i=o.length-1,a=s.slice(0),c=a.length-1,u,l=0;for(let f=c;f>=0;f--,l++)switch(u=o[i-l]-a[c-l]-t,!0){case u<0:t=1,o[i-l]=u+10;break;default:t=0,o[i-l]=u}if(t>0)for(let f=i-c+1;f>=0;f--,l++)if(u=o[i-l]-t,u<0)t=1,o[i-l]=u+10;else{t=0,o[i-l]=u;break}return o.slice()}var Ir=class extends rt(de){constructor({value:e,...t}={}){super(t),this._valueDec=0,t.valueHex&&this.setValueHex(),e!==void 0&&(this.valueDec=e)}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=no.call(this)))}set valueDec(e){this._valueDec=e,this.isHexOnly=!1,this.valueHexView=new Uint8Array(Gi(e))}get valueDec(){return this._valueDec}fromDER(e,t,n,s=0){let o=this.fromBER(e,t,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(e=!1){let t=this.valueHexView;switch(!0){case(t[0]&128)!==0:{let n=new Uint8Array(this.valueHexView.length+1);n[0]=0,n.set(t,1),this.valueHexView=n}break;case(t[0]===0&&(t[1]&128)===0):this.valueHexView=this.valueHexView.subarray(1);break}return this.toBER(e)}fromBER(e,t,n){let s=super.fromBER(e,t,n);return s===-1||this.setValueHex(),s}toBER(e){return e?new ArrayBuffer(this.valueHexView.length):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}toString(){let e=this.valueHexView.length*8-1,t=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 u=0;u<8;u++){if((s&1)===1)switch(n){case e:t=nf(Wi(n),t),i="-";break;default:t=rf(t,Wi(n))}n++,s>>=1}}for(let c=0;c<t.length;c++)t[c]&&(a=!0),a&&(i+=Yi.charAt(t[c]));return a===!1&&(i+=Yi.charAt(0)),i}};aa=Ir;Ir.NAME="IntegerValueBlock";Object.defineProperty(aa.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var ca,te=class r extends fe{constructor(e={}){super(e,Ir),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return ln(),BigInt(this.valueBlock.toString())}static fromBigInt(e){ln();let t=BigInt(e),n=new kr,s=t.toString(16).replace(/^-/,""),o=new Uint8Array(M.Convert.FromHex(s));if(t<0){let a=new Uint8Array(o.length+(o[0]&128?1:0));a[0]|=128;let u=BigInt(`0x${M.Convert.ToHex(a)}`)+t,l=M.BufferSourceConverter.toUint8Array(M.Convert.FromHex(u.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 e=new r({valueHex:this.valueBlock.valueHexView});return e.valueBlock.toDER(),e}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()}`}};ca=te;k.Integer=ca;te.NAME="INTEGER";var la,vn=class extends te{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};la=vn;k.Enumerated=la;vn.NAME="ENUMERATED";var Nr=class extends rt(de){constructor({valueDec:e=-1,isFirstSid:t=!1,...n}={}){super(n),this.valueDec=e,this.isFirstSid=t}fromBER(e,t,n){if(!n)return t;let s=M.BufferSourceConverter.toUint8Array(e);if(!tt(this,s,t,n))return-1;let o=s.subarray(t,t+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=Dt(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),t+this.blockLength)}set valueBigInt(e){ln();let t=BigInt(e).toString(2);for(;t.length%7;)t="0"+t;let n=new Uint8Array(t.length/7);for(let s=0;s<n.length;s++)n[s]=parseInt(t.slice(s*7,s*7+7),2)+(s+1<n.length?128:0);this.fromBER(n.buffer,0,n.length)}toBER(e){if(this.isHexOnly){if(e)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 t=mt(this.valueDec,7);if(t.byteLength===0)return this.error="Error during encoding SID value",Le;let n=new Uint8Array(t.byteLength);if(!e){let s=new Uint8Array(t),o=t.byteLength-1;for(let i=0;i<o;i++)n[i]=s[i]|128;n[o]=s[o]}return n}toString(){let e="";if(this.isHexOnly)e=M.Convert.ToHex(this.valueHexView);else if(this.isFirstSid){let t=this.valueDec;this.valueDec<=39?e="0.":this.valueDec<=79?(e="1.",t-=40):(e="2.",t-=80),e+=t.toString()}else e=this.valueDec.toString();return e}toJSON(){return{...super.toJSON(),valueDec:this.valueDec,isFirstSid:this.isFirstSid}}};Nr.NAME="sidBlock";var Bn=class extends de{constructor({value:e=lr,...t}={}){super(t),this.value=[],e&&this.fromString(e)}fromBER(e,t,n){let s=t;for(;n>0;){let o=new Nr;if(s=o.fromBER(e,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(e){let t=[];for(let n=0;n<this.value.length;n++){let s=this.value[n].toBER(e);if(s.byteLength===0)return this.error=this.value[n].error,Le;t.push(s)}return so(t)}fromString(e){this.value=[];let t=0,n=0,s="",o=!1;do if(n=e.indexOf(".",t),n===-1?s=e.substring(t):s=e.substring(t,n),t=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 Nr;if(s>Number.MAX_SAFE_INTEGER){ln();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 e="",t=!1;for(let n=0;n<this.value.length;n++){t=this.value[n].isHexOnly;let s=this.value[n].toString();n!==0&&(e=`${e}.`),t?(s=`{${s}}`,this.value[n].isFirstSid?e=`2.{${s} - 80}`:e+=s):e+=s}return e}toJSON(){let e={...super.toJSON(),value:this.toString(),sidArray:[]};for(let t=0;t<this.value.length;t++)e.sidArray.push(this.value[t].toJSON());return e}};Bn.NAME="ObjectIdentifierValueBlock";var ua,Ue=class extends fe{constructor(e={}){super(e,Bn),this.idBlock.tagClass=1,this.idBlock.tagNumber=6}getValue(){return this.valueBlock.toString()}setValue(e){this.valueBlock.fromString(e)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};ua=Ue;k.ObjectIdentifier=ua;Ue.NAME="OBJECT IDENTIFIER";var Rr=class extends rt(Xe){constructor({valueDec:e=0,...t}={}){super(t),this.valueDec=e}fromBER(e,t,n){if(n===0)return t;let s=M.BufferSourceConverter.toUint8Array(e);if(!tt(this,s,t,n))return-1;let o=s.subarray(t,t+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=Dt(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),t+this.blockLength)}toBER(e){if(this.isHexOnly){if(e)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 t=mt(this.valueDec,7);if(t.byteLength===0)return this.error="Error during encoding SID value",Le;let n=new Uint8Array(t.byteLength);if(!e){let s=new Uint8Array(t),o=t.byteLength-1;for(let i=0;i<o;i++)n[i]=s[i]|128;n[o]=s[o]}return n.buffer}toString(){let e="";return this.isHexOnly?e=M.Convert.ToHex(this.valueHexView):e=this.valueDec.toString(),e}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};Rr.NAME="relativeSidBlock";var En=class extends de{constructor({value:e=lr,...t}={}){super(t),this.value=[],e&&this.fromString(e)}fromBER(e,t,n){let s=t;for(;n>0;){let o=new Rr;if(s=o.fromBER(e,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(e,t){let n=[];for(let s=0;s<this.value.length;s++){let o=this.value[s].toBER(e);if(o.byteLength===0)return this.error=this.value[s].error,Le;n.push(o)}return so(n)}fromString(e){this.value=[];let t=0,n=0,s="";do{n=e.indexOf(".",t),n===-1?s=e.substring(t):s=e.substring(t,n),t=n+1;let o=new Rr;if(o.valueDec=parseInt(s,10),isNaN(o.valueDec))return!0;this.value.push(o)}while(n!==-1);return!0}toString(){let e="",t=!1;for(let n=0;n<this.value.length;n++){t=this.value[n].isHexOnly;let s=this.value[n].toString();n!==0&&(e=`${e}.`),t&&(s=`{${s}}`),e+=s}return e}toJSON(){let e={...super.toJSON(),value:this.toString(),sidArray:[]};for(let t=0;t<this.value.length;t++)e.sidArray.push(this.value[t].toJSON());return e}};En.NAME="RelativeObjectIdentifierValueBlock";var fa,An=class extends fe{constructor(e={}){super(e,En),this.idBlock.tagClass=1,this.idBlock.tagNumber=13}getValue(){return this.valueBlock.toString()}setValue(e){this.valueBlock.fromString(e)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};fa=An;k.RelativeObjectIdentifier=fa;An.NAME="RelativeObjectIdentifier";var ha,ce=class extends bt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};ha=ce;k.Sequence=ha;ce.NAME="SEQUENCE";var da,kn=class extends bt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};da=kn;k.Set=da;kn.NAME="SET";var Sn=class extends rt(de){constructor({...e}={}){super(e),this.isHexOnly=!0,this.value=lr}toJSON(){return{...super.toJSON(),value:this.value}}};Sn.NAME="StringValueBlock";var In=class extends Sn{};In.NAME="SimpleStringValueBlock";var ye=class extends hn{constructor({...e}={}){super(e,In)}fromBuffer(e){this.valueBlock.value=String.fromCharCode.apply(null,M.BufferSourceConverter.toUint8Array(e))}fromString(e){let t=e.length,n=this.valueBlock.valueHexView=new Uint8Array(t);for(let s=0;s<t;s++)n[s]=e.charCodeAt(s);this.valueBlock.value=e}};ye.NAME="SIMPLE STRING";var Nn=class extends ye{fromBuffer(e){this.valueBlock.valueHexView=M.BufferSourceConverter.toUint8Array(e);try{this.valueBlock.value=M.Convert.ToUtf8String(e)}catch(t){this.warnings.push(`Error during "decodeURIComponent": ${t}, using raw string`),this.valueBlock.value=M.Convert.ToBinary(e)}}fromString(e){this.valueBlock.valueHexView=new Uint8Array(M.Convert.FromUtf8String(e)),this.valueBlock.value=e}};Nn.NAME="Utf8StringValueBlock";var ga,et=class extends Nn{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};ga=et;k.Utf8String=ga;et.NAME="UTF8String";var Rn=class extends ye{fromBuffer(e){this.valueBlock.value=M.Convert.ToUtf16String(e),this.valueBlock.valueHexView=M.BufferSourceConverter.toUint8Array(e)}fromString(e){this.valueBlock.value=e,this.valueBlock.valueHexView=new Uint8Array(M.Convert.FromUtf16String(e))}};Rn.NAME="BmpStringValueBlock";var pa,Cn=class extends Rn{constructor({...e}={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};pa=Cn;k.BmpString=pa;Cn.NAME="BMPString";var Tn=class extends ye{fromBuffer(e){let t=ArrayBuffer.isView(e)?e.slice().buffer:e.slice(0),n=new Uint8Array(t);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(t))}fromString(e){let t=e.length,n=this.valueBlock.valueHexView=new Uint8Array(t*4);for(let s=0;s<t;s++){let o=mt(e.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=e}};Tn.NAME="UniversalStringValueBlock";var ya,_n=class extends Tn{constructor({...e}={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};ya=_n;k.UniversalString=ya;_n.NAME="UniversalString";var ma,Un=class extends ye{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};ma=Un;k.NumericString=ma;Un.NAME="NumericString";var ba,Ln=class extends ye{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};ba=Ln;k.PrintableString=ba;Ln.NAME="PrintableString";var wa,Vn=class extends ye{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};wa=Vn;k.TeletexString=wa;Vn.NAME="TeletexString";var xa,Hn=class extends ye{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};xa=Hn;k.VideotexString=xa;Hn.NAME="VideotexString";var va,On=class extends ye{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};va=On;k.IA5String=va;On.NAME="IA5String";var Ba,Dn=class extends ye{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};Ba=Dn;k.GraphicString=Ba;Dn.NAME="GraphicString";var Ea,Cr=class extends ye{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};Ea=Cr;k.VisibleString=Ea;Cr.NAME="VisibleString";var Aa,Pn=class extends ye{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};Aa=Pn;k.GeneralString=Aa;Pn.NAME="GeneralString";var ka,Mn=class extends ye{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};ka=Mn;k.CharacterString=ka;Mn.NAME="CharacterString";var Sa,Tr=class extends Cr{constructor({value:e,valueDate:t,...n}={}){if(super(n),this.year=0,this.month=0,this.day=0,this.hour=0,this.minute=0,this.second=0,e){this.fromString(e),this.valueBlock.valueHexView=new Uint8Array(e.length);for(let s=0;s<e.length;s++)this.valueBlock.valueHexView[s]=e.charCodeAt(s)}t&&(this.fromDate(t),this.valueBlock.valueHexView=new Uint8Array(this.toBuffer())),this.idBlock.tagClass=1,this.idBlock.tagNumber=23}fromBuffer(e){this.fromString(String.fromCharCode.apply(null,M.BufferSourceConverter.toUint8Array(e)))}toBuffer(){let e=this.toString(),t=new ArrayBuffer(e.length),n=new Uint8Array(t);for(let s=0;s<e.length;s++)n[s]=e.charCodeAt(s);return t}fromDate(e){this.year=e.getUTCFullYear(),this.month=e.getUTCMonth()+1,this.day=e.getUTCDate(),this.hour=e.getUTCHours(),this.minute=e.getUTCMinutes(),this.second=e.getUTCSeconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second))}fromString(e){let n=/(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})Z/ig.exec(e);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(e="iso"){if(e==="iso"){let t=new Array(7);return t[0]=xe(this.year<2e3?this.year-1900:this.year-2e3,2),t[1]=xe(this.month,2),t[2]=xe(this.day,2),t[3]=xe(this.hour,2),t[4]=xe(this.minute,2),t[5]=xe(this.second,2),t[6]="Z",t.join("")}return super.toString(e)}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}}};Sa=Tr;k.UTCTime=Sa;Tr.NAME="UTCTime";var Ia,Kn=class extends Tr{constructor(e={}){var t;super(e),(t=this.millisecond)!==null&&t!==void 0||(this.millisecond=0),this.idBlock.tagClass=1,this.idBlock.tagNumber=24}fromDate(e){super.fromDate(e),this.millisecond=e.getUTCMilliseconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second,this.millisecond))}fromString(e){let t=!1,n="",s="",o=0,i,a=0,c=0;if(e[e.length-1]==="Z")n=e.substring(0,e.length-1),t=!0;else{let f=new Number(e[e.length-1]);if(isNaN(f.valueOf()))throw new Error("Wrong input string for conversion");n=e}if(t){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 f=1,h=n.indexOf("+"),w="";if(h===-1&&(h=n.indexOf("-"),f=-1),h!==-1){if(w=n.substring(h+1),n=n.substring(0,h),w.length!==2&&w.length!==4)throw new Error("Wrong input string for conversion");let x=parseInt(w.substring(0,2),10);if(isNaN(x.valueOf()))throw new Error("Wrong input string for conversion");if(a=f*x,w.length===4){if(x=parseInt(w.substring(2,4),10),isNaN(x.valueOf()))throw new Error("Wrong input string for conversion");c=f*x}}}let u=n.indexOf(".");if(u===-1&&(u=n.indexOf(",")),u!==-1){let f=new Number(`0${n.substring(u)}`);if(isNaN(f.valueOf()))throw new Error("Wrong input string for conversion");o=f.valueOf(),s=n.substring(0,u)}else s=n;switch(!0){case s.length===8:if(i=/(\d{4})(\d{2})(\d{2})/ig,u!==-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,u!==-1){let f=60*o;this.minute=Math.floor(f),f=60*(f-this.minute),this.second=Math.floor(f),f=1e3*(f-this.second),this.millisecond=Math.floor(f)}break;case s.length===12:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})/ig,u!==-1){let f=60*o;this.second=Math.floor(f),f=1e3*(f-this.second),this.millisecond=Math.floor(f)}break;case s.length===14:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})/ig,u!==-1){let f=1e3*o;this.millisecond=Math.floor(f)}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 f=1;f<l.length;f++)switch(f){case 1:this.year=parseInt(l[f],10);break;case 2:this.month=parseInt(l[f],10);break;case 3:this.day=parseInt(l[f],10);break;case 4:this.hour=parseInt(l[f],10)+a;break;case 5:this.minute=parseInt(l[f],10)+c;break;case 6:this.second=parseInt(l[f],10);break;default:throw new Error("Wrong input string for conversion")}if(t===!1){let f=new Date(this.year,this.month,this.day,this.hour,this.minute,this.second,this.millisecond);this.year=f.getUTCFullYear(),this.month=f.getUTCMonth(),this.day=f.getUTCDay(),this.hour=f.getUTCHours(),this.minute=f.getUTCMinutes(),this.second=f.getUTCSeconds(),this.millisecond=f.getUTCMilliseconds()}}toString(e="iso"){if(e==="iso"){let t=[];return t.push(xe(this.year,4)),t.push(xe(this.month,2)),t.push(xe(this.day,2)),t.push(xe(this.hour,2)),t.push(xe(this.minute,2)),t.push(xe(this.second,2)),this.millisecond!==0&&(t.push("."),t.push(xe(this.millisecond,3))),t.push("Z"),t.join("")}return super.toString(e)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};Ia=Kn;k.GeneralizedTime=Ia;Kn.NAME="GeneralizedTime";var Na,Fn=class extends et{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};Na=Fn;k.DATE=Na;Fn.NAME="DATE";var Ra,$n=class extends et{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};Ra=$n;k.TimeOfDay=Ra;$n.NAME="TimeOfDay";var Ca,qn=class extends et{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};Ca=qn;k.DateTime=Ca;qn.NAME="DateTime";var Ta,jn=class extends et{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};Ta=jn;k.Duration=Ta;jn.NAME="Duration";var _a,zn=class extends et{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};_a=zn;k.TIME=_a;zn.NAME="TIME";function of(r){let{result:e}=ur(r),t=e.valueBlock.value;return{n:ee(Pe(t[1].toBigInt()),"base64url"),e:ee(Pe(t[2].toBigInt()),"base64url"),d:ee(Pe(t[3].toBigInt()),"base64url"),p:ee(Pe(t[4].toBigInt()),"base64url"),q:ee(Pe(t[5].toBigInt()),"base64url"),dp:ee(Pe(t[6].toBigInt()),"base64url"),dq:ee(Pe(t[7].toBigInt()),"base64url"),qi:ee(Pe(t[8].toBigInt()),"base64url"),kty:"RSA",alg:"RS256"}}function af(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 U("JWK was missing components","ERR_INVALID_PARAMETERS");let t=new ce({value:[new te({value:0}),te.fromBigInt(Me(Z(r.n,"base64url"))),te.fromBigInt(Me(Z(r.e,"base64url"))),te.fromBigInt(Me(Z(r.d,"base64url"))),te.fromBigInt(Me(Z(r.p,"base64url"))),te.fromBigInt(Me(Z(r.q,"base64url"))),te.fromBigInt(Me(Z(r.dp,"base64url"))),te.fromBigInt(Me(Z(r.dq,"base64url"))),te.fromBigInt(Me(Z(r.qi,"base64url")))]}).toBER();return new Uint8Array(t,0,t.byteLength)}function cf(r){let{result:e}=ur(r),t=e.valueBlock.value[1].valueBlock.value[0].valueBlock.value;return{kty:"RSA",n:ee(Pe(t[0].toBigInt()),"base64url"),e:ee(Pe(t[1].toBigInt()),"base64url")}}function lf(r){if(r.n==null||r.e==null)throw new U("JWK was missing components","ERR_INVALID_PARAMETERS");let t=new ce({value:[new ce({value:[new Ue({value:"1.2.840.113549.1.1.1"}),new wt]}),new cr({valueHex:new ce({value:[te.fromBigInt(Me(Z(r.n,"base64url"))),te.fromBigInt(Me(Z(r.e,"base64url")))]}).toBER()})]}).toBER();return new Uint8Array(t,0,t.byteLength)}function Pe(r){let e=r.toString(16);e.length%2>0&&(e=`0${e}`);let t=e.length/2,n=new Uint8Array(t),s=0,o=0;for(;s<t;)n[s]=parseInt(e.slice(o,o+2),16),s+=1,o+=2;return n}function Me(r){let e=[];return r.forEach(function(t){let n=t.toString(16);n.length%2>0&&(n=`0${n}`),e.push(n)}),BigInt("0x"+e.join(""))}var uf=16,io=32,ao=1e4;async function ff(r,e){let t=G.get(),s=new ce({value:[new te({value:0}),new ce({value:[new Ue({value:"1.2.840.113549.1.1.1"}),new wt]}),new Qe({valueHex:r.marshal()})]}).toBER(),o=new Uint8Array(s,0,s.byteLength),i=We(uf),a=await to(Rt,e,i,{c:ao,dkLen:io}),c=We(16),u=await t.subtle.importKey("raw",a,"AES-CBC",!1,["encrypt"]),l=await t.subtle.encrypt({name:"AES-CBC",iv:c},u,o),f=new ce({value:[new Qe({valueHex:i}),new te({value:ao}),new te({value:io}),new ce({value:[new Ue({value:"1.2.840.113549.2.11"}),new wt]})]}),h=new ce({value:[new Ue({value:"1.2.840.113549.1.5.13"}),new ce({value:[new ce({value:[new Ue({value:"1.2.840.113549.1.5.12"}),f]}),new ce({value:[new Ue({value:"2.16.840.1.101.3.4.1.42"}),new Qe({valueHex:c})]})]})]}),x=new ce({value:[h,new Qe({valueHex:l})]}).toBER(),y=new Uint8Array(x,0,x.byteLength);return["-----BEGIN ENCRYPTED PRIVATE KEY-----",...ee(y,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
7
+ `)}async function co(r,e){let t=G.get(),n;if(r.includes("-----BEGIN ENCRYPTED PRIVATE KEY-----")){let s=Z(r.replace("-----BEGIN ENCRYPTED PRIVATE KEY-----","").replace("-----END ENCRYPTED PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:o}=ur(s),{iv:i,salt:a,iterations:c,keySize:u,cipherText:l}=hf(o),f=await to(Rt,e,a,{c,dkLen:u}),h=await t.subtle.importKey("raw",f,"AES-CBC",!1,["decrypt"]),w=_r(await t.subtle.decrypt({name:"AES-CBC",iv:i},h,l)),{result:x}=ur(w);n=Ua(x)}else if(r.includes("-----BEGIN PRIVATE KEY-----")){let s=Z(r.replace("-----BEGIN PRIVATE KEY-----","").replace("-----END PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:o}=ur(s);n=Ua(o)}else throw new U("Could not parse private key from PEM data","ERR_INVALID_PARAMETERS");return lo(n)}function hf(r){let e=r.valueBlock.value[0];if(e.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.13")throw new U("Only pkcs5PBES2 encrypted private keys are supported","ERR_INVALID_PARAMS");let n=e.valueBlock.value[1].valueBlock.value[0];if(n.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.12")throw new U("Only pkcs5PBKDF2 key derivation functions are supported","ERR_INVALID_PARAMS");let o=n.valueBlock.value[1],i=_r(o.valueBlock.value[0].getValue()),a=ao,c=io;if(o.valueBlock.value.length===3)a=Number(o.valueBlock.value[1].toBigInt()),c=Number(o.valueBlock.value[2].toBigInt());else if(o.valueBlock.value.length===2)throw new U("Could not derive key size and iterations from PEM file - please use @libp2p/rsa to re-import your key","ERR_INVALID_PARAMS");let u=e.valueBlock.value[1].valueBlock.value[1],l=u.valueBlock.value[0].toString();if(l!=="OBJECT IDENTIFIER : 1.2.840.113549.3.7"){if(l!=="OBJECT IDENTIFIER : 1.3.14.3.2.7"){if(l!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.2"){if(l!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.22"){if(l!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.42")throw new U("Only AES-CBC encryption schemes are supported","ERR_INVALID_PARAMS")}}}}let f=_r(u.valueBlock.value[1].getValue());return{cipherText:_r(r.valueBlock.value[1].getValue()),salt:i,iterations:a,keySize:c,iv:f}}function Ua(r){return _r(r.valueBlock.value[2].getValue())}function _r(r){return new Uint8Array(r,0,r.byteLength)}async function La(r){let e=await G.get().subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:r,publicExponent:new Uint8Array([1,0,1]),hash:{name:"SHA-256"}},!0,["sign","verify"]),t=await Oa(e);return{privateKey:t[0],publicKey:t[1]}}async function uo(r){let t=[await G.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["sign"]),await df(r)],n=await Oa({privateKey:t[0],publicKey:t[1]});return{privateKey:n[0],publicKey:n[1]}}async function Va(r,e){let t=await G.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await G.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},t,e instanceof Uint8Array?e:e.subarray());return new Uint8Array(n,0,n.byteLength)}async function Ha(r,e,t){let n=await G.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return G.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,e,t instanceof Uint8Array?t:t.subarray())}async function Oa(r){if(r.privateKey==null||r.publicKey==null)throw new U("Private and public key are required","ERR_INVALID_PARAMETERS");return Promise.all([G.get().subtle.exportKey("jwk",r.privateKey),G.get().subtle.exportKey("jwk",r.publicKey)])}async function df(r){return G.get().subtle.importKey("jwk",{kty:r.kty,n:r.n,e:r.e},{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["verify"])}function Zn(r){if(r.kty!=="RSA")throw new U("invalid key type","ERR_INVALID_KEY_TYPE");if(r.n==null)throw new U("invalid key modulus","ERR_INVALID_KEY_MODULUS");return Z(r.n,"base64url").length*8}var Mt=8192,Pt=class{_key;constructor(e){this._key=e}verify(e,t){return Ha(this._key,t,e)}marshal(){return xt.jwkToPkix(this._key)}get bytes(){return Te.encode({Type:z.RSA,Data:this.marshal()}).subarray()}equals(e){return Se(this.bytes,e.bytes)}hash(){let e=ve.digest(this.bytes);return Ae(e)?e.then(({bytes:t})=>t):e.bytes}},vt=class{_key;_publicKey;constructor(e,t){this._key=e,this._publicKey=t}genSecret(){return We(16)}sign(e){return Va(this._key,e)}get public(){if(this._publicKey==null)throw new U("public key not provided","ERR_PUBKEY_NOT_PROVIDED");return new Pt(this._publicKey)}marshal(){return xt.jwkToPkcs1(this._key)}get bytes(){return _e.encode({Type:z.RSA,Data:this.marshal()}).subarray()}equals(e){return Se(this.bytes,e.bytes)}hash(){let e=ve.digest(this.bytes);return Ae(e)?e.then(({bytes:t})=>t):e.bytes}async id(){let e=await this.public.hash();return ee(e,"base58btc")}async export(e,t="pkcs-8"){if(t==="pkcs-8")return xt.exportToPem(this,e);if(t==="libp2p-key")return nr(this.bytes,e);throw new U(`export format '${t}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};async function lo(r){let e=xt.pkcs1ToJwk(r);if(Zn(e)>Mt)throw new U("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await uo(e);return new vt(t.privateKey,t.publicKey)}function pf(r){let e=xt.pkixToJwk(r);if(Zn(e)>Mt)throw new U("key size is too large","ERR_KEY_SIZE_TOO_LARGE");return new Pt(e)}async function yf(r){if(Zn(r)>Mt)throw new U("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await uo(r);return new vt(e.privateKey,e.publicKey)}async function mf(r){if(r>Mt)throw new U("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await La(r);return new vt(e.privateKey,e.publicKey)}var mo={};Q(mo,{Secp256k1PrivateKey:()=>Ft,Secp256k1PublicKey:()=>Kt,generateKeyPair:()=>Cf,unmarshalSecp256k1PrivateKey:()=>Nf,unmarshalSecp256k1PublicKey:()=>Rf});var bf=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]),Bt=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),Et=new Uint32Array(64),ho=class extends ct{constructor(){super(64,32,8,!1),this.A=Bt[0]|0,this.B=Bt[1]|0,this.C=Bt[2]|0,this.D=Bt[3]|0,this.E=Bt[4]|0,this.F=Bt[5]|0,this.G=Bt[6]|0,this.H=Bt[7]|0}get(){let{A:e,B:t,C:n,D:s,E:o,F:i,G:a,H:c}=this;return[e,t,n,s,o,i,a,c]}set(e,t,n,s,o,i,a,c){this.A=e|0,this.B=t|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(e,t){for(let f=0;f<16;f++,t+=4)Et[f]=e.getUint32(t,!1);for(let f=16;f<64;f++){let h=Et[f-15],w=Et[f-2],x=Ie(h,7)^Ie(h,18)^h>>>3,y=Ie(w,17)^Ie(w,19)^w>>>10;Et[f]=y+Et[f-7]+x+Et[f-16]|0}let{A:n,B:s,C:o,D:i,E:a,F:c,G:u,H:l}=this;for(let f=0;f<64;f++){let h=Ie(a,6)^Ie(a,11)^Ie(a,25),w=l+h+Kr(a,c,u)+bf[f]+Et[f]|0,y=(Ie(n,2)^Ie(n,13)^Ie(n,22))+Fr(n,s,o)|0;l=u,u=c,c=a,a=i+w|0,i=o,o=s,s=n,n=w+y|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,u=u+this.G|0,l=l+this.H|0,this.set(n,s,o,i,a,c,u,l)}roundClean(){Et.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var Yn=Xt(()=>new ho);function Da(r){r.lowS!==void 0&&Ne("lowS",r.lowS),r.prehash!==void 0&&Ne("prehash",r.prehash)}function wf(r){let e=wr(r);Oe(e,{a:"field",b:"field"},{allowedPrivateKeyLengths:"array",wrapPrivateKey:"boolean",isTorsionFree:"function",clearCofactor:"function",allowInfinityPoint:"boolean",fromBytes:"function",toBytes:"function"});let{endo:t,Fp:n,a:s}=e;if(t){if(!n.eql(s,n.ZERO))throw new Error("Endomorphism can only be defined for Koblitz curves that have a=0");if(typeof t!="object"||typeof t.beta!="bigint"||typeof t.splitScalar!="function")throw new Error("Expected endomorphism with beta: bigint and splitScalar: function")}return Object.freeze({...e})}var{bytesToNumberBE:xf,hexToBytes:vf}=jr,nt={Err:class extends Error{constructor(e=""){super(e)}},_tlv:{encode:(r,e)=>{let{Err:t}=nt;if(r<0||r>256)throw new t("tlv.encode: wrong tag");if(e.length&1)throw new t("tlv.encode: unpadded data");let n=e.length/2,s=Ct(n);if(s.length/2&128)throw new t("tlv.encode: long form length too big");let o=n>127?Ct(s.length/2|128):"";return`${Ct(r)}${o}${s}${e}`},decode(r,e){let{Err:t}=nt,n=0;if(r<0||r>256)throw new t("tlv.encode: wrong tag");if(e.length<2||e[n++]!==r)throw new t("tlv.decode: wrong tlv");let s=e[n++],o=!!(s&128),i=0;if(!o)i=s;else{let c=s&127;if(!c)throw new t("tlv.decode(long): indefinite length not supported");if(c>4)throw new t("tlv.decode(long): byte length is too big");let u=e.subarray(n,n+c);if(u.length!==c)throw new t("tlv.decode: length bytes not complete");if(u[0]===0)throw new t("tlv.decode(long): zero leftmost byte");for(let l of u)i=i<<8|l;if(n+=c,i<128)throw new t("tlv.decode(long): not minimal encoding")}let a=e.subarray(n,n+i);if(a.length!==i)throw new t("tlv.decode: wrong value length");return{v:a,l:e.subarray(n+i)}}},_int:{encode(r){let{Err:e}=nt;if(r<st)throw new e("integer: negative integers are not allowed");let t=Ct(r);if(Number.parseInt(t[0],16)&8&&(t="00"+t),t.length&1)throw new e("unexpected assertion");return t},decode(r){let{Err:e}=nt;if(r[0]&128)throw new e("Invalid signature integer: negative");if(r[0]===0&&!(r[1]&128))throw new e("Invalid signature integer: unnecessary leading zero");return xf(r)}},toSig(r){let{Err:e,_int:t,_tlv:n}=nt,s=typeof r=="string"?vf(r):r;er(s);let{v:o,l:i}=n.decode(48,s);if(i.length)throw new e("Invalid signature: left bytes after parsing");let{v:a,l:c}=n.decode(2,o),{v:u,l}=n.decode(2,c);if(l.length)throw new e("Invalid signature: left bytes after parsing");return{r:t.decode(a),s:t.decode(u)}},hexFromSig(r){let{_tlv:e,_int:t}=nt,n=`${e.encode(2,t.encode(r.r))}${e.encode(2,t.encode(r.s))}`;return e.encode(48,n)}},st=BigInt(0),le=BigInt(1),gg=BigInt(2),Pa=BigInt(3),pg=BigInt(4);function Bf(r){let e=wf(r),{Fp:t}=e,n=gt(e.n,e.nBitLength),s=e.toBytes||((y,d,m)=>{let v=d.toAffine();return Ge(Uint8Array.from([4]),t.toBytes(v.x),t.toBytes(v.y))}),o=e.fromBytes||(y=>{let d=y.subarray(1),m=t.fromBytes(d.subarray(0,t.BYTES)),v=t.fromBytes(d.subarray(t.BYTES,2*t.BYTES));return{x:m,y:v}});function i(y){let{a:d,b:m}=e,v=t.sqr(y),g=t.mul(v,y);return t.add(t.add(g,t.mul(y,d)),m)}if(!t.eql(t.sqr(e.Gy),i(e.Gx)))throw new Error("bad generator point: equation left != right");function a(y){return mr(y,le,e.n)}function c(y){let{allowedPrivateKeyLengths:d,nByteLength:m,wrapPrivateKey:v,n:g}=e;if(d&&typeof y!="bigint"){if(ft(y)&&(y=je(y)),typeof y!="string"||!d.includes(y.length))throw new Error("Invalid key");y=y.padStart(m*2,"0")}let E;try{E=typeof y=="bigint"?y:ze(X("private key",y,m))}catch{throw new Error(`private key must be ${m} bytes, hex or bigint, not ${typeof y}`)}return v&&(E=q(E,g)),be("private key",E,le,g),E}function u(y){if(!(y instanceof h))throw new Error("ProjectivePoint expected")}let l=Ut((y,d)=>{let{px:m,py:v,pz:g}=y;if(t.eql(g,t.ONE))return{x:m,y:v};let E=y.is0();d==null&&(d=E?t.ONE:t.inv(g));let _=t.mul(m,d),T=t.mul(v,d),S=t.mul(g,d);if(E)return{x:t.ZERO,y:t.ZERO};if(!t.eql(S,t.ONE))throw new Error("invZ was invalid");return{x:_,y:T}}),f=Ut(y=>{if(y.is0()){if(e.allowInfinityPoint&&!t.is0(y.py))return;throw new Error("bad point: ZERO")}let{x:d,y:m}=y.toAffine();if(!t.isValid(d)||!t.isValid(m))throw new Error("bad point: x or y not FE");let v=t.sqr(m),g=i(d);if(!t.eql(v,g))throw new Error("bad point: equation left != right");if(!y.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});class h{constructor(d,m,v){if(this.px=d,this.py=m,this.pz=v,d==null||!t.isValid(d))throw new Error("x required");if(m==null||!t.isValid(m))throw new Error("y required");if(v==null||!t.isValid(v))throw new Error("z required");Object.freeze(this)}static fromAffine(d){let{x:m,y:v}=d||{};if(!d||!t.isValid(m)||!t.isValid(v))throw new Error("invalid affine point");if(d instanceof h)throw new Error("projective point not allowed");let g=E=>t.eql(E,t.ZERO);return g(m)&&g(v)?h.ZERO:new h(m,v,t.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(d){let m=t.invertBatch(d.map(v=>v.pz));return d.map((v,g)=>v.toAffine(m[g])).map(h.fromAffine)}static fromHex(d){let m=h.fromAffine(o(X("pointHex",d)));return m.assertValidity(),m}static fromPrivateKey(d){return h.BASE.multiply(c(d))}static msm(d,m){return Zr(h,n,d,m)}_setWindowSize(d){x.setWindowSize(this,d)}assertValidity(){f(this)}hasEvenY(){let{y:d}=this.toAffine();if(t.isOdd)return!t.isOdd(d);throw new Error("Field doesn't support isOdd")}equals(d){u(d);let{px:m,py:v,pz:g}=this,{px:E,py:_,pz:T}=d,S=t.eql(t.mul(m,T),t.mul(E,g)),I=t.eql(t.mul(v,T),t.mul(_,g));return S&&I}negate(){return new h(this.px,t.neg(this.py),this.pz)}double(){let{a:d,b:m}=e,v=t.mul(m,Pa),{px:g,py:E,pz:_}=this,T=t.ZERO,S=t.ZERO,I=t.ZERO,C=t.mul(g,g),re=t.mul(E,E),F=t.mul(_,_),O=t.mul(g,E);return O=t.add(O,O),I=t.mul(g,_),I=t.add(I,I),T=t.mul(d,I),S=t.mul(v,F),S=t.add(T,S),T=t.sub(re,S),S=t.add(re,S),S=t.mul(T,S),T=t.mul(O,T),I=t.mul(v,I),F=t.mul(d,F),O=t.sub(C,F),O=t.mul(d,O),O=t.add(O,I),I=t.add(C,C),C=t.add(I,C),C=t.add(C,F),C=t.mul(C,O),S=t.add(S,C),F=t.mul(E,_),F=t.add(F,F),C=t.mul(F,O),T=t.sub(T,C),I=t.mul(F,re),I=t.add(I,I),I=t.add(I,I),new h(T,S,I)}add(d){u(d);let{px:m,py:v,pz:g}=this,{px:E,py:_,pz:T}=d,S=t.ZERO,I=t.ZERO,C=t.ZERO,re=e.a,F=t.mul(e.b,Pa),O=t.mul(m,E),ne=t.mul(v,_),A=t.mul(g,T),N=t.add(m,v),b=t.add(E,_);N=t.mul(N,b),b=t.add(O,ne),N=t.sub(N,b),b=t.add(m,g);let p=t.add(E,T);return b=t.mul(b,p),p=t.add(O,A),b=t.sub(b,p),p=t.add(v,g),S=t.add(_,T),p=t.mul(p,S),S=t.add(ne,A),p=t.sub(p,S),C=t.mul(re,b),S=t.mul(F,A),C=t.add(S,C),S=t.sub(ne,C),C=t.add(ne,C),I=t.mul(S,C),ne=t.add(O,O),ne=t.add(ne,O),A=t.mul(re,A),b=t.mul(F,b),ne=t.add(ne,A),A=t.sub(O,A),A=t.mul(re,A),b=t.add(b,A),O=t.mul(ne,b),I=t.add(I,O),O=t.mul(p,b),S=t.mul(N,S),S=t.sub(S,O),O=t.mul(N,ne),C=t.mul(p,C),C=t.add(C,O),new h(S,I,C)}subtract(d){return this.add(d.negate())}is0(){return this.equals(h.ZERO)}wNAF(d){return x.wNAFCached(this,d,h.normalizeZ)}multiplyUnsafe(d){be("scalar",d,st,e.n);let m=h.ZERO;if(d===st)return m;if(d===le)return this;let{endo:v}=e;if(!v)return x.unsafeLadder(this,d);let{k1neg:g,k1:E,k2neg:_,k2:T}=v.splitScalar(d),S=m,I=m,C=this;for(;E>st||T>st;)E&le&&(S=S.add(C)),T&le&&(I=I.add(C)),C=C.double(),E>>=le,T>>=le;return g&&(S=S.negate()),_&&(I=I.negate()),I=new h(t.mul(I.px,v.beta),I.py,I.pz),S.add(I)}multiply(d){let{endo:m,n:v}=e;be("scalar",d,le,v);let g,E;if(m){let{k1neg:_,k1:T,k2neg:S,k2:I}=m.splitScalar(d),{p:C,f:re}=this.wNAF(T),{p:F,f:O}=this.wNAF(I);C=x.constTimeNegate(_,C),F=x.constTimeNegate(S,F),F=new h(t.mul(F.px,m.beta),F.py,F.pz),g=C.add(F),E=re.add(O)}else{let{p:_,f:T}=this.wNAF(d);g=_,E=T}return h.normalizeZ([g,E])[0]}multiplyAndAddUnsafe(d,m,v){let g=h.BASE,E=(T,S)=>S===st||S===le||!T.equals(g)?T.multiplyUnsafe(S):T.multiply(S),_=E(this,m).add(E(d,v));return _.is0()?void 0:_}toAffine(d){return l(this,d)}isTorsionFree(){let{h:d,isTorsionFree:m}=e;if(d===le)return!0;if(m)return m(h,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h:d,clearCofactor:m}=e;return d===le?this:m?m(h,this):this.multiplyUnsafe(e.h)}toRawBytes(d=!0){return Ne("isCompressed",d),this.assertValidity(),s(h,this,d)}toHex(d=!0){return Ne("isCompressed",d),je(this.toRawBytes(d))}}h.BASE=new h(e.Gx,e.Gy,t.ONE),h.ZERO=new h(t.ZERO,t.ONE,t.ZERO);let w=e.nBitLength,x=Gr(h,e.endo?Math.ceil(w/2):w);return{CURVE:e,ProjectivePoint:h,normPrivateKeyToScalar:c,weierstrassEquation:i,isWithinCurveOrder:a}}function Ef(r){let e=wr(r);return Oe(e,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...e})}function Ma(r){let e=Ef(r),{Fp:t,n}=e,s=t.BYTES+1,o=2*t.BYTES+1;function i(A){return q(A,n)}function a(A){return zr(A,n)}let{ProjectivePoint:c,normPrivateKeyToScalar:u,weierstrassEquation:l,isWithinCurveOrder:f}=Bf({...e,toBytes(A,N,b){let p=N.toAffine(),B=t.toBytes(p.x),R=Ge;return Ne("isCompressed",b),b?R(Uint8Array.from([N.hasEvenY()?2:3]),B):R(Uint8Array.from([4]),B,t.toBytes(p.y))},fromBytes(A){let N=A.length,b=A[0],p=A.subarray(1);if(N===s&&(b===2||b===3)){let B=ze(p);if(!mr(B,le,t.ORDER))throw new Error("Point is not on curve");let R=l(B),L;try{L=t.sqrt(R)}catch(K){let P=K instanceof Error?": "+K.message:"";throw new Error("Point is not on curve"+P)}let V=(L&le)===le;return(b&1)===1!==V&&(L=t.neg(L)),{x:B,y:L}}else if(N===o&&b===4){let B=t.fromBytes(p.subarray(0,t.BYTES)),R=t.fromBytes(p.subarray(t.BYTES,2*t.BYTES));return{x:B,y:R}}else throw new Error(`Point of length ${N} was invalid. Expected ${s} compressed bytes or ${o} uncompressed bytes`)}}),h=A=>je(dt(A,e.nByteLength));function w(A){let N=n>>le;return A>N}function x(A){return w(A)?i(-A):A}let y=(A,N,b)=>ze(A.slice(N,b));class d{constructor(N,b,p){this.r=N,this.s=b,this.recovery=p,this.assertValidity()}static fromCompact(N){let b=e.nByteLength;return N=X("compactSignature",N,b*2),new d(y(N,0,b),y(N,b,2*b))}static fromDER(N){let{r:b,s:p}=nt.toSig(X("DER",N));return new d(b,p)}assertValidity(){be("r",this.r,le,n),be("s",this.s,le,n)}addRecoveryBit(N){return new d(this.r,this.s,N)}recoverPublicKey(N){let{r:b,s:p,recovery:B}=this,R=T(X("msgHash",N));if(B==null||![0,1,2,3].includes(B))throw new Error("recovery id invalid");let L=B===2||B===3?b+e.n:b;if(L>=t.ORDER)throw new Error("recovery id 2 or 3 invalid");let V=B&1?"03":"02",D=c.fromHex(V+h(L)),K=a(L),P=i(-R*K),$=i(p*K),j=c.BASE.multiplyAndAddUnsafe(D,P,$);if(!j)throw new Error("point at infinify");return j.assertValidity(),j}hasHighS(){return w(this.s)}normalizeS(){return this.hasHighS()?new d(this.r,i(-this.s),this.recovery):this}toDERRawBytes(){return Tt(this.toDERHex())}toDERHex(){return nt.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return Tt(this.toCompactHex())}toCompactHex(){return h(this.r)+h(this.s)}}let m={isValidPrivateKey(A){try{return u(A),!0}catch{return!1}},normPrivateKeyToScalar:u,randomPrivateKey:()=>{let A=Ls(e.n);return ui(e.randomBytes(A),e.n)},precompute(A=8,N=c.BASE){return N._setWindowSize(A),N.multiply(BigInt(3)),N}};function v(A,N=!0){return c.fromPrivateKey(A).toRawBytes(N)}function g(A){let N=ft(A),b=typeof A=="string",p=(N||b)&&A.length;return N?p===s||p===o:b?p===2*s||p===2*o:A instanceof c}function E(A,N,b=!0){if(g(A))throw new Error("first arg must be private key");if(!g(N))throw new Error("second arg must be public key");return c.fromHex(N).multiply(u(A)).toRawBytes(b)}let _=e.bits2int||function(A){let N=ze(A),b=A.length*8-e.nBitLength;return b>0?N>>BigInt(b):N},T=e.bits2int_modN||function(A){return i(_(A))},S=br(e.nBitLength);function I(A){return be(`num < 2^${e.nBitLength}`,A,st,S),dt(A,e.nByteLength)}function C(A,N,b=re){if(["recovered","canonical"].some(ae=>ae in b))throw new Error("sign() legacy options not supported");let{hash:p,randomBytes:B}=e,{lowS:R,prehash:L,extraEntropy:V}=b;R==null&&(R=!0),A=X("msgHash",A),Da(b),L&&(A=X("prehashed msgHash",p(A)));let D=T(A),K=u(N),P=[I(K),I(D)];if(V!=null&&V!==!1){let ae=V===!0?B(t.BYTES):V;P.push(X("extraEntropy",ae))}let $=Ge(...P),j=D;function ie(ae){let ue=_(ae);if(!f(ue))return;let ge=a(ue),se=c.BASE.multiply(ue).toAffine(),me=i(se.x);if(me===st)return;let Ke=i(ge*i(j+me*K));if(Ke===st)return;let fr=(se.x===me?0:2)|Number(se.y&le),hr=Ke;return R&&w(Ke)&&(hr=x(Ke),fr^=1),new d(me,hr,fr)}return{seed:$,k2sig:ie}}let re={lowS:e.lowS,prehash:!1},F={lowS:e.lowS,prehash:!1};function O(A,N,b=re){let{seed:p,k2sig:B}=C(A,N,b),R=e;return Cs(R.hash.outputLen,R.nByteLength,R.hmac)(p,B)}c.BASE._setWindowSize(8);function ne(A,N,b,p=F){let B=A;if(N=X("msgHash",N),b=X("publicKey",b),"strict"in p)throw new Error("options.strict was renamed to lowS");Da(p);let{lowS:R,prehash:L}=p,V,D;try{if(typeof B=="string"||ft(B))try{V=d.fromDER(B)}catch(se){if(!(se instanceof nt.Err))throw se;V=d.fromCompact(B)}else if(typeof B=="object"&&typeof B.r=="bigint"&&typeof B.s=="bigint"){let{r:se,s:me}=B;V=new d(se,me)}else throw new Error("PARSE");D=c.fromHex(b)}catch(se){if(se.message==="PARSE")throw new Error("signature must be Signature instance, Uint8Array or hex string");return!1}if(R&&V.hasHighS())return!1;L&&(N=e.hash(N));let{r:K,s:P}=V,$=T(N),j=a(P),ie=i($*j),ae=i(K*j),ue=c.BASE.multiplyAndAddUnsafe(D,ie,ae)?.toAffine();return ue?i(ue.x)===K:!1}return{CURVE:e,getPublicKey:v,getSharedSecret:E,sign:O,verify:ne,ProjectivePoint:c,Signature:d,utils:m}}function Af(r){return{hash:r,hmac:(e,...t)=>Er(r,e,Bs(...t)),randomBytes:Qt}}function Ka(r,e){let t=n=>Ma({...r,...Af(n)});return Object.freeze({...t(e),create:t})}var qa=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),Fa=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),kf=BigInt(1),go=BigInt(2),$a=(r,e)=>(r+e/go)/e;function Sf(r){let e=qa,t=BigInt(3),n=BigInt(6),s=BigInt(11),o=BigInt(22),i=BigInt(23),a=BigInt(44),c=BigInt(88),u=r*r*r%e,l=u*u*r%e,f=W(l,t,e)*l%e,h=W(f,t,e)*l%e,w=W(h,go,e)*u%e,x=W(w,s,e)*w%e,y=W(x,o,e)*x%e,d=W(y,a,e)*y%e,m=W(d,c,e)*d%e,v=W(m,a,e)*y%e,g=W(v,t,e)*l%e,E=W(g,i,e)*x%e,_=W(E,n,e)*u%e,T=W(_,go,e);if(!po.eql(po.sqr(T),r))throw new Error("Cannot find square root");return T}var po=gt(qa,void 0,void 0,{sqrt:Sf}),Ve=Ka({a:BigInt(0),b:BigInt(7),Fp:po,n:Fa,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let e=Fa,t=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-kf*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),s=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),o=t,i=BigInt("0x100000000000000000000000000000000"),a=$a(o*r,e),c=$a(-n*r,e),u=q(r-a*t-c*s,e),l=q(-a*n-c*o,e),f=u>i,h=l>i;if(f&&(u=e-u),h&&(l=e-l),u>i||l>i)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:f,k1:u,k2neg:h,k2:l}}}},Yn),Ag=BigInt(0);var kg=Ve.ProjectivePoint;function ja(){return Ve.utils.randomPrivateKey()}function za(r,e){let t=ve.digest(e instanceof Uint8Array?e:e.subarray());if(Ae(t))return t.then(({digest:n})=>Ve.sign(n,r).toDERRawBytes()).catch(n=>{throw new U(String(n),"ERR_INVALID_INPUT")});try{return Ve.sign(t.digest,r).toDERRawBytes()}catch(n){throw new U(String(n),"ERR_INVALID_INPUT")}}function Ga(r,e,t){let n=ve.digest(t instanceof Uint8Array?t:t.subarray());if(Ae(n))return n.then(({digest:s})=>Ve.verify(e,s,r)).catch(s=>{throw new U(String(s),"ERR_INVALID_INPUT")});try{return Ve.verify(e,n.digest,r)}catch(s){throw new U(String(s),"ERR_INVALID_INPUT")}}function Za(r){return Ve.ProjectivePoint.fromHex(r).toRawBytes(!0)}function Ya(r){try{Ve.getPublicKey(r,!0)}catch(e){throw new U(String(e),"ERR_INVALID_PRIVATE_KEY")}}function yo(r){try{Ve.ProjectivePoint.fromHex(r)}catch(e){throw new U(String(e),"ERR_INVALID_PUBLIC_KEY")}}function Wa(r){try{return Ve.getPublicKey(r,!0)}catch(e){throw new U(String(e),"ERR_INVALID_PRIVATE_KEY")}}var Kt=class{_key;constructor(e){yo(e),this._key=e}verify(e,t){return Ga(this._key,t,e)}marshal(){return Za(this._key)}get bytes(){return Te.encode({Type:z.Secp256k1,Data:this.marshal()}).subarray()}equals(e){return Se(this.bytes,e.bytes)}async hash(){let e=ve.digest(this.bytes),t;return Ae(e)?{bytes:t}=await e:t=e.bytes,t}},Ft=class{_key;_publicKey;constructor(e,t){this._key=e,this._publicKey=t??Wa(e),Ya(this._key),yo(this._publicKey)}sign(e){return za(this._key,e)}get public(){return new Kt(this._publicKey)}marshal(){return this._key}get bytes(){return _e.encode({Type:z.Secp256k1,Data:this.marshal()}).subarray()}equals(e){return Se(this.bytes,e.bytes)}hash(){let e=ve.digest(this.bytes);return Ae(e)?e.then(({bytes:t})=>t):e.bytes}async id(){let e=await this.public.hash();return ee(e,"base58btc")}async export(e,t="libp2p-key"){if(t==="libp2p-key")return nr(this.bytes,e);throw new U(`export format '${t}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function Nf(r){return new Ft(r)}function Rf(r){return new Kt(r)}async function Cf(){let r=ja();return new Ft(r)}var ot={rsa:fo,ed25519:Qs,secp256k1:mo};function bo(r){let e=Object.keys(ot).join(" / ");return new U(`invalid or unsupported key type ${r}. Must be ${e}`,"ERR_UNSUPPORTED_KEY_TYPE")}function wo(r){if(r=r.toLowerCase(),r==="rsa"||r==="ed25519"||r==="secp256k1")return ot[r];throw bo(r)}async function Tf(r,e){return wo(r).generateKeyPair(e??2048)}async function _f(r,e,t){if(r.toLowerCase()!=="ed25519")throw new U("Seed key derivation is unimplemented for RSA or secp256k1","ERR_UNSUPPORTED_KEY_DERIVATION_TYPE");return Xs(e)}function Uf(r){let e=Te.decode(r),t=e.Data??new Uint8Array;switch(e.Type){case z.RSA:return ot.rsa.unmarshalRsaPublicKey(t);case z.Ed25519:return ot.ed25519.unmarshalEd25519PublicKey(t);case z.Secp256k1:return ot.secp256k1.unmarshalSecp256k1PublicKey(t);default:throw bo(e.Type??"unknown")}}function Lf(r,e){return e=(e??"rsa").toLowerCase(),wo(e),r.bytes}async function Ja(r){let e=_e.decode(r),t=e.Data??new Uint8Array;switch(e.Type){case z.RSA:return ot.rsa.unmarshalRsaPrivateKey(t);case z.Ed25519:return ot.ed25519.unmarshalEd25519PrivateKey(t);case z.Secp256k1:return ot.secp256k1.unmarshalSecp256k1PrivateKey(t);default:throw bo(e.Type??"RSA")}}function Vf(r,e){return e=(e??"rsa").toLowerCase(),wo(e),r.bytes}async function Hf(r,e){try{let t=await Mi(r,e);return await Ja(t)}catch{}if(!r.includes("BEGIN"))throw new U("Encrypted key was not a libp2p-key or a PEM file","ERR_INVALID_IMPORT_FORMAT");return co(r,e)}var Ur=new Uint32Array([1732584193,4023233417,2562383102,271733878,3285377520]),At=new Uint32Array(80),vo=class extends ct{constructor(){super(64,20,8,!1),this.A=Ur[0]|0,this.B=Ur[1]|0,this.C=Ur[2]|0,this.D=Ur[3]|0,this.E=Ur[4]|0}get(){let{A:e,B:t,C:n,D:s,E:o}=this;return[e,t,n,s,o]}set(e,t,n,s,o){this.A=e|0,this.B=t|0,this.C=n|0,this.D=s|0,this.E=o|0}process(e,t){for(let c=0;c<16;c++,t+=4)At[c]=e.getUint32(t,!1);for(let c=16;c<80;c++)At[c]=Mr(At[c-3]^At[c-8]^At[c-14]^At[c-16],1);let{A:n,B:s,C:o,D:i,E:a}=this;for(let c=0;c<80;c++){let u,l;c<20?(u=Kr(s,o,i),l=1518500249):c<40?(u=s^o^i,l=1859775393):c<60?(u=Fr(s,o,i),l=2400959708):(u=s^o^i,l=3395469782);let f=Mr(n,5)+u+a+l+At[c]|0;a=i,i=o,o=Mr(s,30),s=n,n=f}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,this.set(n,s,o,i,a)}roundClean(){At.fill(0)}destroy(){this.set(0,0,0,0,0),this.buffer.fill(0)}},Xa=Xt(()=>new vo);var Qa={sha1:Xa,"sha2-256":Yn,"sha2-512":Rt};function Bo(r,e,t,n,s){if(s!=="sha1"&&s!=="sha2-256"&&s!=="sha2-512"){let a=Object.keys(Qa).join(" / ");throw new U(`Hash '${s}' is unknown or not supported. Must be ${a}`,"ERR_UNSUPPORTED_HASH_TYPE")}let o=Qa[s],i=ji(o,r,e,{c:t,dkLen:n});return St.encode(i).substring(1)}return pc(Of);})();
8
8
  /*! Bundled license information:
9
9
 
10
10
  pvtsutils/build/index.js:
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@libp2p/crypto",
3
- "version": "4.1.9-3c8dd5bbf",
3
+ "version": "4.1.9-737b3ea5b",
4
4
  "description": "Crypto primitives for libp2p",
5
5
  "license": "Apache-2.0 OR MIT",
6
6
  "homepage": "https://github.com/libp2p/js-libp2p/tree/main/packages/crypto#readme",
@@ -84,7 +84,7 @@
84
84
  "generate": "protons ./src/keys/keys.proto"
85
85
  },
86
86
  "dependencies": {
87
- "@libp2p/interface": "1.7.0-3c8dd5bbf",
87
+ "@libp2p/interface": "1.7.0-737b3ea5b",
88
88
  "@noble/curves": "^1.4.0",
89
89
  "@noble/hashes": "^1.4.0",
90
90
  "asn1js": "^3.0.5",