@libp2p/crypto 4.0.3 → 4.0.4

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 Nr=Object.defineProperty;var ic=Object.getOwnPropertyDescriptor;var ac=Object.getOwnPropertyNames;var cc=Object.getPrototypeOf,lc=Object.prototype.hasOwnProperty;var uc=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),et=(r,t)=>{for(var e in t)Nr(r,e,{get:t[e],enumerable:!0})},ko=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of ac(t))!lc.call(r,s)&&s!==e&&Nr(r,s,{get:()=>t[s],enumerable:!(n=ic(t,s))||n.enumerable});return r};var fc=(r,t,e)=>(e=r!=null?oc(cc(r)):{},ko(t||!r||!r.__esModule?Nr(e,"default",{value:r,enumerable:!0}):e,r)),hc=r=>ko(Nr({},"__esModule",{value:!0}),r);var qi=uc(nr=>{"use strict";var qu="[object ArrayBuffer]",Xt=class r{static isArrayBuffer(t){return Object.prototype.toString.call(t)===qu}static toArrayBuffer(t){return this.isArrayBuffer(t)?t:t.byteLength===t.buffer.byteLength||t.byteOffset===0&&t.byteLength===t.buffer.byteLength?t.buffer:this.toUint8Array(t.buffer).slice(t.byteOffset,t.byteOffset+t.byteLength).buffer}static toUint8Array(t){return this.toView(t,Uint8Array)}static toView(t,e){if(t.constructor===e)return t;if(this.isArrayBuffer(t))return new e(t);if(this.isArrayBufferView(t))return new e(t.buffer,t.byteOffset,t.byteLength);throw new TypeError("The provided value is not of type '(ArrayBuffer or ArrayBufferView)'")}static isBufferSource(t){return this.isArrayBufferView(t)||this.isArrayBuffer(t)}static isArrayBufferView(t){return ArrayBuffer.isView(t)||t&&this.isArrayBuffer(t.buffer)}static isEqual(t,e){let n=r.toUint8Array(t),s=r.toUint8Array(e);if(n.length!==s.byteLength)return!1;for(let o=0;o<n.length;o++)if(n[o]!==s[o])return!1;return!0}static concat(...t){let e;Array.isArray(t[0])&&!(t[1]instanceof Function)||Array.isArray(t[0])&&t[1]instanceof Function?e=t[0]:t[t.length-1]instanceof Function?e=t.slice(0,t.length-1):e=t;let n=0;for(let i of e)n+=i.byteLength;let s=new Uint8Array(n),o=0;for(let i of e){let a=this.toUint8Array(i);s.set(a,o),o+=a.length}return t[t.length-1]instanceof Function?this.toView(s,t[t.length-1]):s.buffer}},Ys="string",ju=/^[0-9a-f]+$/i,Gu=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,zu=/^[a-zA-Z0-9-_]+$/,Qr=class{static fromString(t){let e=unescape(encodeURIComponent(t)),n=new Uint8Array(e.length);for(let s=0;s<e.length;s++)n[s]=e.charCodeAt(s);return n.buffer}static toString(t){let e=Xt.toUint8Array(t),n="";for(let o=0;o<e.length;o++)n+=String.fromCharCode(e[o]);return decodeURIComponent(escape(n))}},At=class{static toString(t,e=!1){let n=Xt.toArrayBuffer(t),s=new DataView(n),o="";for(let i=0;i<n.byteLength;i+=2){let a=s.getUint16(i,e);o+=String.fromCharCode(a)}return o}static fromString(t,e=!1){let n=new ArrayBuffer(t.length*2),s=new DataView(n);for(let o=0;o<t.length;o++)s.setUint16(o*2,t.charCodeAt(o),e);return n}},tn=class r{static isHex(t){return typeof t===Ys&&ju.test(t)}static isBase64(t){return typeof t===Ys&&Gu.test(t)}static isBase64Url(t){return typeof t===Ys&&zu.test(t)}static ToString(t,e="utf8"){let n=Xt.toUint8Array(t);switch(e.toLowerCase()){case"utf8":return this.ToUtf8String(n);case"binary":return this.ToBinary(n);case"hex":return this.ToHex(n);case"base64":return this.ToBase64(n);case"base64url":return this.ToBase64Url(n);case"utf16le":return At.toString(n,!0);case"utf16":case"utf16be":return At.toString(n);default:throw new Error(`Unknown type of encoding '${e}'`)}}static FromString(t,e="utf8"){if(!t)return new ArrayBuffer(0);switch(e.toLowerCase()){case"utf8":return this.FromUtf8String(t);case"binary":return this.FromBinary(t);case"hex":return this.FromHex(t);case"base64":return this.FromBase64(t);case"base64url":return this.FromBase64Url(t);case"utf16le":return At.fromString(t,!0);case"utf16":case"utf16be":return At.fromString(t);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToBase64(t){let e=Xt.toUint8Array(t);if(typeof btoa<"u"){let n=this.ToString(e,"binary");return btoa(n)}else return Buffer.from(e).toString("base64")}static FromBase64(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isBase64(e))throw new TypeError("Argument 'base64Text' is not Base64 encoded");return typeof atob<"u"?this.FromBinary(atob(e)):new Uint8Array(Buffer.from(e,"base64")).buffer}static FromBase64Url(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isBase64Url(e))throw new TypeError("Argument 'base64url' is not Base64Url encoded");return this.FromBase64(this.Base64Padding(e.replace(/\-/g,"+").replace(/\_/g,"/")))}static ToBase64Url(t){return this.ToBase64(t).replace(/\+/g,"-").replace(/\//g,"_").replace(/\=/g,"")}static FromUtf8String(t,e=r.DEFAULT_UTF8_ENCODING){switch(e){case"ascii":return this.FromBinary(t);case"utf8":return Qr.fromString(t);case"utf16":case"utf16be":return At.fromString(t);case"utf16le":case"usc2":return At.fromString(t,!0);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToUtf8String(t,e=r.DEFAULT_UTF8_ENCODING){switch(e){case"ascii":return this.ToBinary(t);case"utf8":return Qr.toString(t);case"utf16":case"utf16be":return At.toString(t);case"utf16le":case"usc2":return At.toString(t,!0);default:throw new Error(`Unknown type of encoding '${e}'`)}}static FromBinary(t){let e=t.length,n=new Uint8Array(e);for(let s=0;s<e;s++)n[s]=t.charCodeAt(s);return n.buffer}static ToBinary(t){let e=Xt.toUint8Array(t),n="";for(let s=0;s<e.length;s++)n+=String.fromCharCode(e[s]);return n}static ToHex(t){let e=Xt.toUint8Array(t),n="",s=e.length;for(let o=0;o<s;o++){let i=e[o];i<16&&(n+="0"),n+=i.toString(16)}return n}static FromHex(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isHex(e))throw new TypeError("Argument 'hexString' is not HEX encoded");e.length%2&&(e=`0${e}`);let n=new Uint8Array(e.length/2);for(let s=0;s<e.length;s=s+2){let o=e.slice(s,s+2);n[s/2]=parseInt(o,16)}return n.buffer}static ToUtf16String(t,e=!1){return At.toString(t,e)}static FromUtf16String(t,e=!1){return At.fromString(t,e)}static Base64Padding(t){let e=4-t.length%4;if(e<4)for(let n=0;n<e;n++)t+="=";return t}static formatString(t){return t?.replace(/[\n\r\t ]/g,"")||""}};tn.DEFAULT_UTF8_ENCODING="utf8";function Zu(r,...t){let e=arguments[0];for(let n=1;n<arguments.length;n++){let s=arguments[n];for(let o in s)e[o]=s[o]}return e}function Yu(...r){let t=r.map(s=>s.byteLength).reduce((s,o)=>s+o),e=new Uint8Array(t),n=0;return r.map(s=>new Uint8Array(s)).forEach(s=>{for(let o of s)e[n++]=o}),e.buffer}function Wu(r,t){if(!(r&&t)||r.byteLength!==t.byteLength)return!1;let e=new Uint8Array(r),n=new Uint8Array(t);for(let s=0;s<r.byteLength;s++)if(e[s]!==n[s])return!1;return!0}nr.BufferSourceConverter=Xt;nr.Convert=tn;nr.assign=Zu;nr.combine=Yu;nr.isEqual=Wu});var Pf={};et(Pf,{hmac:()=>Rr,keys:()=>ho,pbkdf2:()=>yo,randomBytes:()=>Jt});var Rr={};et(Rr,{create:()=>jn});var z={get(r=globalThis){let t=r.crypto;if(t==null||t.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 t}};var So={SHA1:20,SHA256:32,SHA512:64};var dc={SHA1:"SHA-1",SHA256:"SHA-256",SHA512:"SHA-512"},gc=async(r,t)=>{let e=await z.get().subtle.sign({name:"HMAC"},r,t);return new Uint8Array(e,0,e.byteLength)};async function jn(r,t){let e=dc[r],n=await z.get().subtle.importKey("raw",t,{name:"HMAC",hash:{name:e}},!1,["sign"]);return{async digest(s){return gc(n,s)},length:So[r]}}var ho={};et(ho,{Ed25519PrivateKey:()=>Wt,Ed25519PublicKey:()=>Le,MAX_RSA_KEY_SIZE:()=>De,RsaPrivateKey:()=>xe,RsaPublicKey:()=>He,Secp256k1PrivateKey:()=>Ke,Secp256k1PublicKey:()=>Pe,generateEphemeralKeyPair:()=>Di,generateKeyPair:()=>Cf,generateKeyPairFromSeed:()=>_f,importKey:()=>Hf,keyStretcher:()=>Ki,keysPBM:()=>er,marshalPrivateKey:()=>Vf,marshalPublicKey:()=>Lf,supportedKeys:()=>oe,unmarshalPrivateKey:()=>Za,unmarshalPublicKey:()=>Uf});var _=class extends Error{code;props;constructor(t,e,n){super(t),this.code=e,this.name=n?.name??"CodeError",this.props=n??{}}};var Gs={};et(Gs,{Ed25519PrivateKey:()=>Wt,Ed25519PublicKey:()=>Le,generateKeyPair:()=>Ku,generateKeyPairFromSeed:()=>js,unmarshalEd25519PrivateKey:()=>Ou,unmarshalEd25519PublicKey:()=>Pu});var Wn={};et(Wn,{base58btc:()=>vt,base58flickr:()=>xc});var Gf=new Uint8Array(0);function Io(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function Ft(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 No(r){return new TextEncoder().encode(r)}function Ro(r){return new TextDecoder().decode(r)}function pc(r,t){if(r.length>=255)throw new TypeError("Alphabet too long");for(var e=new Uint8Array(256),n=0;n<e.length;n++)e[n]=255;for(var s=0;s<r.length;s++){var o=r.charAt(s),i=o.charCodeAt(0);if(e[i]!==255)throw new TypeError(o+" is ambiguous");e[i]=s}var a=r.length,c=r.charAt(0),u=Math.log(a)/Math.log(256),l=Math.log(256)/Math.log(a);function f(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,p=0,m=0,B=g.length;m!==B&&g[m]===0;)m++,h++;for(var b=(B-m)*l+1>>>0,T=new Uint8Array(b);m!==B;){for(var x=g[m],A=0,N=b-1;(x!==0||A<p)&&N!==-1;N--,A++)x+=256*T[N]>>>0,T[N]=x%a>>>0,x=x/a>>>0;if(x!==0)throw new Error("Non-zero carry");p=A,m++}for(var R=b-p;R!==b&&T[R]===0;)R++;for(var $=c.repeat(h);R<b;++R)$+=r.charAt(T[R]);return $}function d(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 p=0,m=0;g[h]===c;)p++,h++;for(var B=(g.length-h)*u+1>>>0,b=new Uint8Array(B);g[h];){var T=e[g.charCodeAt(h)];if(T===255)return;for(var x=0,A=B-1;(T!==0||x<m)&&A!==-1;A--,x++)T+=a*b[A]>>>0,b[A]=T%256>>>0,T=T/256>>>0;if(T!==0)throw new Error("Non-zero carry");m=x,h++}if(g[h]!==" "){for(var N=B-m;N!==B&&b[N]===0;)N++;for(var R=new Uint8Array(p+(B-N)),$=p;N!==B;)R[$++]=b[N++];return R}}}function w(g){var h=d(g);if(h)return h;throw new Error(`Non-${t} character`)}return{encode:f,decodeUnsafe:d,decode:w}}var yc=pc,mc=yc,Co=mc;var Gn=class{name;prefix;baseEncode;constructor(t,e,n){this.name=t,this.prefix=e,this.baseEncode=n}encode(t){if(t instanceof Uint8Array)return`${this.prefix}${this.baseEncode(t)}`;throw Error("Unknown type, must be binary type")}},zn=class{name;prefix;baseDecode;prefixCodePoint;constructor(t,e,n){if(this.name=t,this.prefix=e,e.codePointAt(0)===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=e.codePointAt(0),this.baseDecode=n}decode(t){if(typeof t=="string"){if(t.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(t)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(t.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(t){return _o(this,t)}},Zn=class{decoders;constructor(t){this.decoders=t}or(t){return _o(this,t)}decode(t){let e=t[0],n=this.decoders[e];if(n!=null)return n.decode(t);throw RangeError(`Unable to decode multibase string ${JSON.stringify(t)}, only inputs prefixed with ${Object.keys(this.decoders)} are supported`)}};function _o(r,t){return new Zn({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var Yn=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(t,e,n,s){this.name=t,this.prefix=e,this.baseEncode=n,this.baseDecode=s,this.encoder=new Gn(t,e,n),this.decoder=new zn(t,e,s)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function Me({name:r,prefix:t,encode:e,decode:n}){return new Yn(r,t,e,n)}function ie({name:r,prefix:t,alphabet:e}){let{encode:n,decode:s}=Co(e,r);return Me({prefix:t,name:r,encode:n,decode:o=>Ft(s(o))})}function bc(r,t,e,n){let s={};for(let l=0;l<t.length;++l)s[t[l]]=l;let o=r.length;for(;r[o-1]==="=";)--o;let i=new Uint8Array(o*e/8|0),a=0,c=0,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<<e|f,a+=e,a>=8&&(a-=8,i[u++]=255&c>>a)}if(a>=e||255&c<<8-a)throw new SyntaxError("Unexpected end of data");return i}function wc(r,t,e){let n=t[t.length-1]==="=",s=(1<<e)-1,o="",i=0,a=0;for(let c=0;c<r.length;++c)for(a=a<<8|r[c],i+=8;i>e;)i-=e,o+=t[s&a>>i];if(i!==0&&(o+=t[s&a<<e-i]),n)for(;o.length*e&7;)o+="=";return o}function X({name:r,prefix:t,bitsPerChar:e,alphabet:n}){return Me({prefix:t,name:r,encode(s){return wc(s,n,e)},decode(s){return bc(s,n,e,r)}})}var vt=ie({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),xc=ie({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Qn={};et(Qn,{identity:()=>Xn});var Bc=Vo,Uo=128,vc=127,Ec=~vc,Ac=Math.pow(2,31);function Vo(r,t,e){t=t||[],e=e||0;for(var n=e;r>=Ac;)t[e++]=r&255|Uo,r/=128;for(;r&Ec;)t[e++]=r&255|Uo,r>>>=7;return t[e]=r|0,Vo.bytes=e-n+1,t}var kc=Jn,Sc=128,Lo=127;function Jn(r,n){var e=0,n=n||0,s=0,o=n,i,a=r.length;do{if(o>=a)throw Jn.bytes=0,new RangeError("Could not decode varint");i=r[o++],e+=s<28?(i&Lo)<<s:(i&Lo)*Math.pow(2,s),s+=7}while(i>=Sc);return Jn.bytes=o-n,e}var Ic=Math.pow(2,7),Nc=Math.pow(2,14),Rc=Math.pow(2,21),Tc=Math.pow(2,28),Cc=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<Tc?4:r<Cc?5:r<_c?6:r<Uc?7:r<Lc?8:r<Vc?9:10},Dc={encode:Bc,decode:kc,encodingLength:Hc},Oc=Dc,cr=Oc;function lr(r,t=0){return[cr.decode(r,t),cr.decode.bytes]}function Fe(r,t,e=0){return cr.encode(r,t,e),t}function $e(r){return cr.encodingLength(r)}function ke(r,t){let e=t.byteLength,n=$e(r),s=n+$e(e),o=new Uint8Array(s+e);return Fe(r,o,0),Fe(e,o,n),o.set(t,s),new qe(r,e,t,o)}function Ho(r){let t=Ft(r),[e,n]=lr(t),[s,o]=lr(t.subarray(n)),i=t.subarray(n+o);if(i.byteLength!==s)throw new Error("Incorrect length");return new qe(e,s,i,t)}function Do(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&Io(r.bytes,e.bytes)}}var qe=class{code;size;digest;bytes;constructor(t,e,n,s){this.code=t,this.size=e,this.digest=n,this.bytes=s}};var Oo=0,Pc="identity",Po=Ft;function Kc(r){return ke(Oo,Po(r))}var Xn={code:Oo,name:Pc,encode:Po,digest:Kc};var rs={};et(rs,{sha256:()=>bt,sha512:()=>Mc});function es({name:r,code:t,encode:e}){return new ts(r,t,e)}var ts=class{name;code;encode;constructor(t,e,n){this.name=t,this.code=e,this.encode=n}digest(t){if(t instanceof Uint8Array){let e=this.encode(t);return e instanceof Uint8Array?ke(this.code,e):e.then(n=>ke(this.code,n))}else throw Error("Unknown type, must be binary type")}};function Mo(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var bt=es({name:"sha2-256",code:18,encode:Mo("SHA-256")}),Mc=es({name:"sha2-512",code:19,encode:Mo("SHA-512")});function St(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function Se(r){return globalThis.Buffer!=null?new Uint8Array(r.buffer,r.byteOffset,r.byteLength):r}function Ht(r=0){return globalThis.Buffer?.allocUnsafe!=null?Se(globalThis.Buffer.allocUnsafe(r)):new Uint8Array(r)}function $t(r,t){if(globalThis.Buffer!=null)return Se(globalThis.Buffer.concat(r,t));t==null&&(t=r.reduce((s,o)=>s+o.length,0));let e=Ht(t),n=0;for(let s of r)e.set(s,n),n+=s.length;return Se(e)}var ns={};et(ns,{base10:()=>Fc});var Fc=ie({prefix:"9",name:"base10",alphabet:"0123456789"});var ss={};et(ss,{base16:()=>$c,base16upper:()=>qc});var $c=X({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),qc=X({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var os={};et(os,{base2:()=>jc});var jc=X({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var is={};et(is,{base256emoji:()=>Wc});var Fo=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}"),Gc=Fo.reduce((r,t,e)=>(r[e]=t,r),[]),zc=Fo.reduce((r,t,e)=>(r[t.codePointAt(0)]=e,r),[]);function Zc(r){return r.reduce((t,e)=>(t+=Gc[e],t),"")}function Yc(r){let t=[];for(let e of r){let n=zc[e.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${e}`);t.push(n)}return new Uint8Array(t)}var Wc=Me({prefix:"\u{1F680}",name:"base256emoji",encode:Zc,decode:Yc});var as={};et(as,{base32:()=>je,base32hex:()=>tl,base32hexpad:()=>rl,base32hexpadupper:()=>nl,base32hexupper:()=>el,base32pad:()=>Xc,base32padupper:()=>Qc,base32upper:()=>Jc,base32z:()=>sl});var je=X({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),Jc=X({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Xc=X({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),Qc=X({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),tl=X({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),el=X({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),rl=X({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),nl=X({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),sl=X({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var cs={};et(cs,{base36:()=>ol,base36upper:()=>il});var ol=ie({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),il=ie({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var ls={};et(ls,{base64:()=>Ie,base64pad:()=>al,base64url:()=>cl,base64urlpad:()=>ll});var Ie=X({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),al=X({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),cl=X({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),ll=X({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var us={};et(us,{base8:()=>ul});var ul=X({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var fs={};et(fs,{identity:()=>fl});var fl=Me({prefix:"\0",name:"identity",encode:r=>Ro(r),decode:r=>No(r)});var xh=new TextEncoder,Bh=new TextDecoder;function $o(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return pl(e,hs(r),t??vt.encoder);default:return yl(e,hs(r),t??je.encoder)}}var qo=new WeakMap;function hs(r){let t=qo.get(r);if(t==null){let e=new Map;return qo.set(r,e),e}return t}var Cr=class r{code;version;multihash;bytes;"/";constructor(t,e,n,s){this.code=e,this.version=t,this.multihash=n,this.bytes=s,this["/"]=s}get asCID(){return this}get byteOffset(){return this.bytes.byteOffset}get byteLength(){return this.bytes.byteLength}toV0(){switch(this.version){case 0:return this;case 1:{let{code:t,multihash:e}=this;if(t!==fr)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==ml)throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");return r.createV0(e)}default:throw Error(`Can not convert CID version ${this.version} to version 0. This is a bug please report`)}}toV1(){switch(this.version){case 0:{let{code:t,digest:e}=this.multihash,n=ke(t,e);return r.createV1(this.code,n)}case 1:return this;default:throw Error(`Can not convert CID version ${this.version} to version 1. This is a bug please report`)}}equals(t){return r.equals(this,t)}static equals(t,e){let n=e;return n!=null&&t.code===n.code&&t.version===n.version&&Do(t.multihash,n.multihash)}toString(t){return $o(this,t)}toJSON(){return{"/":$o(this)}}link(){return this}[Symbol.toStringTag]="CID";[Symbol.for("nodejs.util.inspect.custom")](){return`CID(${this.toString()})`}static asCID(t){if(t==null)return null;let e=t;if(e instanceof r)return e;if(e["/"]!=null&&e["/"]===e.bytes||e.asCID===e){let{version:n,code:s,multihash:o,bytes:i}=e;return new r(n,s,o,i??jo(n,s,o.bytes))}else if(e[bl]===!0){let{version:n,multihash:s,code:o}=e,i=Ho(s);return r.create(n,o,i)}else return null}static create(t,e,n){if(typeof e!="number")throw new Error("String codecs are no longer supported");if(!(n.bytes instanceof Uint8Array))throw new Error("Invalid digest");switch(t){case 0:{if(e!==fr)throw new Error(`Version 0 CID must use dag-pb (code: ${fr}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let s=jo(t,e,n.bytes);return new r(t,e,n,s)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,fr,t)}static createV1(t,e){return r.create(1,t,e)}static decode(t){let[e,n]=r.decodeFirst(t);if(n.length!==0)throw new Error("Incorrect length");return e}static decodeFirst(t){let e=r.inspectBytes(t),n=e.size-e.multihashSize,s=Ft(t.subarray(n,n+e.multihashSize));if(s.byteLength!==e.multihashSize)throw new Error("Incorrect length");let o=s.subarray(e.multihashSize-e.digestSize),i=new qe(e.multihashCode,e.digestSize,o,s);return[e.version===0?r.createV0(i):r.createV1(e.codec,i),t.subarray(e.size)]}static inspectBytes(t){let e=0,n=()=>{let[f,d]=lr(t.subarray(e));return e+=d,f},s=n(),o=fr;if(s===18?(s=0,e=0):o=n(),s!==0&&s!==1)throw new RangeError(`Invalid CID version ${s}`);let i=e,a=n(),c=n(),u=e+c,l=u-i;return{version:s,codec:o,multihashCode:a,digestSize:c,multihashSize:l,size:u}}static parse(t,e){let[n,s]=gl(t,e),o=r.decode(s);if(o.version===0&&t[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return hs(o).set(n,t),o}};function gl(r,t){switch(r[0]){case"Q":{let e=t??vt;return[vt.prefix,e.decode(`${vt.prefix}${r}`)]}case vt.prefix:{let e=t??vt;return[vt.prefix,e.decode(r)]}case je.prefix:{let e=t??je;return[je.prefix,e.decode(r)]}default:{if(t==null)throw Error("To parse non base32 or base58btc encoded CID multibase decoder must be provided");return[r[0],t.decode(r)]}}}function pl(r,t,e){let{prefix:n}=e;if(n!==vt.prefix)throw Error(`Cannot string encode V0 in ${e.name} encoding`);let s=t.get(n);if(s==null){let o=e.encode(r).slice(1);return t.set(n,o),o}else return s}function yl(r,t,e){let{prefix:n}=e,s=t.get(n);if(s==null){let o=e.encode(r);return t.set(n,o),o}else return s}var fr=112,ml=18;function jo(r,t,e){let n=$e(r),s=n+$e(t),o=new Uint8Array(s+e.byteLength);return Fe(r,o,0),Fe(t,o,n),o.set(e,s),o}var bl=Symbol.for("@ipld/js-cid/CID");var ds={...fs,...os,...us,...ns,...ss,...as,...cs,...Wn,...ls,...is},Dh={...rs,...Qn};function zo(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var Go=zo("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),gs=zo("ascii","a",r=>{let t="a";for(let e=0;e<r.length;e++)t+=String.fromCharCode(r[e]);return t},r=>{r=r.substring(1);let t=Ht(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),wl={utf8:Go,"utf-8":Go,hex:ds.base16,latin1:gs,ascii:gs,binary:gs,...ds},_r=wl;function Z(r,t="utf8"){let e=_r[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return(t==="utf8"||t==="utf-8")&&globalThis.Buffer!=null&&globalThis.Buffer.from!=null?Se(globalThis.Buffer.from(r,"utf-8")):e.decoder.decode(`${e.prefix}${r}`)}function ps(r,t){let e=Z(r,"base64urlpad");if(t!=null){if(e.length>t)throw new Error("byte array longer than desired length");e=$t([new Uint8Array(t-e.length),e])}return e}function Et(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function Ge(r){if(!Number.isSafeInteger(r)||r<0)throw new Error(`Wrong positive integer: ${r}`)}function xl(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function ys(r,...t){if(!xl(r))throw new Error("Expected Uint8Array");if(t.length>0&&!t.includes(r.length))throw new Error(`Expected Uint8Array of length ${t}, not of length=${r.length}`)}function Ur(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");Ge(r.outputLen),Ge(r.blockLen)}function ze(r,t=!0){if(r.destroyed)throw new Error("Hash instance has been destroyed");if(t&&r.finished)throw new Error("Hash#digest() has already been called")}function Zo(r,t){ys(r);let e=t.outputLen;if(r.length<e)throw new Error(`digestInto() expects output buffer of length at least ${e}`)}var Lr=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;function Yo(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}var Ne=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),It=(r,t)=>r<<32-t|r>>>t,Bl=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;if(!Bl)throw new Error("Non little-endian hardware is not supported");var vl=async()=>{};async function Wo(r,t,e){let n=Date.now();for(let s=0;s<r;s++){e(s);let o=Date.now()-n;o>=0&&o<t||(await vl(),n+=o)}}function ms(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function ae(r){if(typeof r=="string"&&(r=ms(r)),!Yo(r))throw new Error(`expected Uint8Array, got ${typeof r}`);return r}function Vr(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];if(!Yo(s))throw new Error("Uint8Array expected");t+=s.length}let e=new Uint8Array(t);for(let n=0,s=0;n<r.length;n++){let o=r[n];e.set(o,s),s+=o.length}return e}var Ze=class{clone(){return this._cloneInto()}},El={}.toString;function Jo(r,t){if(t!==void 0&&El.call(t)!=="[object Object]")throw new Error("Options should be object or undefined");return Object.assign(r,t)}function Ye(r){let t=n=>r().update(ae(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function We(r=32){if(Lr&&typeof Lr.getRandomValues=="function")return Lr.getRandomValues(new Uint8Array(r));throw new Error("crypto.getRandomValues must be defined")}function Al(r,t,e,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(t,e,n);let s=BigInt(32),o=BigInt(4294967295),i=Number(e>>s&o),a=Number(e&o),c=n?4:0,u=n?0:4;r.setUint32(t+c,i,n),r.setUint32(t+u,a,n)}var ce=class extends Ze{constructor(t,e,n,s){super(),this.blockLen=t,this.outputLen=e,this.padOffset=n,this.isLE=s,this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.buffer=new Uint8Array(t),this.view=Ne(this.buffer)}update(t){ze(this);let{view:e,buffer:n,blockLen:s}=this;t=ae(t);let o=t.length;for(let i=0;i<o;){let a=Math.min(s-this.pos,o-i);if(a===s){let c=Ne(t);for(;s<=o-i;i+=s)this.process(c,i);continue}n.set(t.subarray(i,i+a),this.pos),this.pos+=a,i+=a,this.pos===s&&(this.process(e,0),this.pos=0)}return this.length+=t.length,this.roundClean(),this}digestInto(t){ze(this),Zo(t,this),this.finished=!0;let{buffer:e,view:n,blockLen:s,isLE:o}=this,{pos:i}=this;e[i++]=128,this.buffer.subarray(i).fill(0),this.padOffset>s-i&&(this.process(n,0),i=0);for(let f=i;f<s;f++)e[f]=0;Al(n,s-8,BigInt(this.length*8),o),this.process(n,0);let a=Ne(t),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:t,outputLen:e}=this;this.digestInto(t);let n=t.slice(0,e);return this.destroy(),n}_cloneInto(t){t||(t=new this.constructor),t.set(...this.get());let{blockLen:e,buffer:n,length:s,finished:o,destroyed:i,pos:a}=this;return t.length=s,t.pos=a,t.finished=o,t.destroyed=i,s%e&&t.buffer.set(n),t}};var Hr=BigInt(4294967295),bs=BigInt(32);function Xo(r,t=!1){return t?{h:Number(r&Hr),l:Number(r>>bs&Hr)}:{h:Number(r>>bs&Hr)|0,l:Number(r&Hr)|0}}function kl(r,t=!1){let e=new Uint32Array(r.length),n=new Uint32Array(r.length);for(let s=0;s<r.length;s++){let{h:o,l:i}=Xo(r[s],t);[e[s],n[s]]=[o,i]}return[e,n]}var Sl=(r,t)=>BigInt(r>>>0)<<bs|BigInt(t>>>0),Il=(r,t,e)=>r>>>e,Nl=(r,t,e)=>r<<32-e|t>>>e,Rl=(r,t,e)=>r>>>e|t<<32-e,Tl=(r,t,e)=>r<<32-e|t>>>e,Cl=(r,t,e)=>r<<64-e|t>>>e-32,_l=(r,t,e)=>r>>>e-32|t<<64-e,Ul=(r,t)=>t,Ll=(r,t)=>r,Vl=(r,t,e)=>r<<e|t>>>32-e,Hl=(r,t,e)=>t<<e|r>>>32-e,Dl=(r,t,e)=>t<<e-32|r>>>64-e,Ol=(r,t,e)=>r<<e-32|t>>>64-e;function Pl(r,t,e,n){let s=(t>>>0)+(n>>>0);return{h:r+e+(s/2**32|0)|0,l:s|0}}var Kl=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),Ml=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,Fl=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),$l=(r,t,e,n,s)=>t+e+n+s+(r/2**32|0)|0,ql=(r,t,e,n,s)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(s>>>0),jl=(r,t,e,n,s,o)=>t+e+n+s+o+(r/2**32|0)|0;var Gl={fromBig:Xo,split:kl,toBig:Sl,shrSH:Il,shrSL:Nl,rotrSH:Rl,rotrSL:Tl,rotrBH:Cl,rotrBL:_l,rotr32H:Ul,rotr32L:Ll,rotlSH:Vl,rotlSL:Hl,rotlBH:Dl,rotlBL:Ol,add:Pl,add3L:Kl,add3H:Ml,add4L:Fl,add4H:$l,add5H:jl,add5L:ql},L=Gl;var[zl,Zl]=L.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))),le=new Uint32Array(80),ue=new Uint32Array(80),ws=class extends ce{constructor(){super(128,64,16,!1),this.Ah=1779033703,this.Al=-205731576,this.Bh=-1150833019,this.Bl=-2067093701,this.Ch=1013904242,this.Cl=-23791573,this.Dh=-1521486534,this.Dl=1595750129,this.Eh=1359893119,this.El=-1377402159,this.Fh=-1694144372,this.Fl=725511199,this.Gh=528734635,this.Gl=-79577749,this.Hh=1541459225,this.Hl=327033209}get(){let{Ah:t,Al:e,Bh:n,Bl:s,Ch:o,Cl:i,Dh:a,Dl:c,Eh:u,El:l,Fh:f,Fl:d,Gh:w,Gl:g,Hh:h,Hl:p}=this;return[t,e,n,s,o,i,a,c,u,l,f,d,w,g,h,p]}set(t,e,n,s,o,i,a,c,u,l,f,d,w,g,h,p){this.Ah=t|0,this.Al=e|0,this.Bh=n|0,this.Bl=s|0,this.Ch=o|0,this.Cl=i|0,this.Dh=a|0,this.Dl=c|0,this.Eh=u|0,this.El=l|0,this.Fh=f|0,this.Fl=d|0,this.Gh=w|0,this.Gl=g|0,this.Hh=h|0,this.Hl=p|0}process(t,e){for(let b=0;b<16;b++,e+=4)le[b]=t.getUint32(e),ue[b]=t.getUint32(e+=4);for(let b=16;b<80;b++){let T=le[b-15]|0,x=ue[b-15]|0,A=L.rotrSH(T,x,1)^L.rotrSH(T,x,8)^L.shrSH(T,x,7),N=L.rotrSL(T,x,1)^L.rotrSL(T,x,8)^L.shrSL(T,x,7),R=le[b-2]|0,$=ue[b-2]|0,M=L.rotrSH(R,$,19)^L.rotrBH(R,$,61)^L.shrSH(R,$,6),V=L.rotrSL(R,$,19)^L.rotrBL(R,$,61)^L.shrSL(R,$,6),rt=L.add4L(N,V,ue[b-7],ue[b-16]),tt=L.add4H(rt,A,M,le[b-7],le[b-16]);le[b]=tt|0,ue[b]=rt|0}let{Ah:n,Al:s,Bh:o,Bl:i,Ch:a,Cl:c,Dh:u,Dl:l,Eh:f,El:d,Fh:w,Fl:g,Gh:h,Gl:p,Hh:m,Hl:B}=this;for(let b=0;b<80;b++){let T=L.rotrSH(f,d,14)^L.rotrSH(f,d,18)^L.rotrBH(f,d,41),x=L.rotrSL(f,d,14)^L.rotrSL(f,d,18)^L.rotrBL(f,d,41),A=f&w^~f&h,N=d&g^~d&p,R=L.add5L(B,x,N,Zl[b],ue[b]),$=L.add5H(R,m,T,A,zl[b],le[b]),M=R|0,V=L.rotrSH(n,s,28)^L.rotrBH(n,s,34)^L.rotrBH(n,s,39),rt=L.rotrSL(n,s,28)^L.rotrBL(n,s,34)^L.rotrBL(n,s,39),tt=n&o^n&a^o&a,Bt=s&i^s&c^i&c;m=h|0,B=p|0,h=w|0,p=g|0,w=f|0,g=d|0,{h:f,l:d}=L.add(u|0,l|0,$|0,M|0),u=a|0,l=c|0,a=o|0,c=i|0,o=n|0,i=s|0;let v=L.add3L(M,rt,Bt);n=L.add3H(v,$,V,tt),s=v|0}({h:n,l:s}=L.add(this.Ah|0,this.Al|0,n|0,s|0)),{h:o,l:i}=L.add(this.Bh|0,this.Bl|0,o|0,i|0),{h:a,l:c}=L.add(this.Ch|0,this.Cl|0,a|0,c|0),{h:u,l}=L.add(this.Dh|0,this.Dl|0,u|0,l|0),{h:f,l:d}=L.add(this.Eh|0,this.El|0,f|0,d|0),{h:w,l:g}=L.add(this.Fh|0,this.Fl|0,w|0,g|0),{h,l:p}=L.add(this.Gh|0,this.Gl|0,h|0,p|0),{h:m,l:B}=L.add(this.Hh|0,this.Hl|0,m|0,B|0),this.set(n,s,o,i,a,c,u,l,f,d,w,g,h,p,m,B)}roundClean(){le.fill(0),ue.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 fe=Ye(()=>new ws);var Or={};et(Or,{bitGet:()=>eu,bitLen:()=>tu,bitMask:()=>hr,bitSet:()=>ru,bytesToHex:()=>jt,bytesToNumberBE:()=>Gt,bytesToNumberLE:()=>he,concatBytes:()=>zt,createHmacDrbg:()=>vs,ensureBytes:()=>Q,equalBytes:()=>Xl,hexToBytes:()=>Re,hexToNumber:()=>Bs,isBytes:()=>Nt,numberToBytesBE:()=>de,numberToBytesLE:()=>Te,numberToHexUnpadded:()=>ri,numberToVarBytesBE:()=>Jl,utf8ToBytes:()=>Ql,validateObject:()=>Dt});var ei=BigInt(0),Dr=BigInt(1),Yl=BigInt(2);function Nt(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}var Wl=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function jt(r){if(!Nt(r))throw new Error("Uint8Array expected");let t="";for(let e=0;e<r.length;e++)t+=Wl[r[e]];return t}function ri(r){let t=r.toString(16);return t.length&1?`0${t}`:t}function Bs(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return BigInt(r===""?"0":`0x${r}`)}var qt={_0:48,_9:57,_A:65,_F:70,_a:97,_f:102};function Qo(r){if(r>=qt._0&&r<=qt._9)return r-qt._0;if(r>=qt._A&&r<=qt._F)return r-(qt._A-10);if(r>=qt._a&&r<=qt._f)return r-(qt._a-10)}function Re(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);let t=r.length,e=t/2;if(t%2)throw new Error("padded hex string expected, got unpadded hex of length "+t);let n=new Uint8Array(e);for(let s=0,o=0;s<e;s++,o+=2){let i=Qo(r.charCodeAt(o)),a=Qo(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 Gt(r){return Bs(jt(r))}function he(r){if(!Nt(r))throw new Error("Uint8Array expected");return Bs(jt(Uint8Array.from(r).reverse()))}function de(r,t){return Re(r.toString(16).padStart(t*2,"0"))}function Te(r,t){return de(r,t).reverse()}function Jl(r){return Re(ri(r))}function Q(r,t,e){let n;if(typeof t=="string")try{n=Re(t)}catch(o){throw new Error(`${r} must be valid hex string, got "${t}". Cause: ${o}`)}else if(Nt(t))n=Uint8Array.from(t);else throw new Error(`${r} must be hex string or Uint8Array`);let s=n.length;if(typeof e=="number"&&s!==e)throw new Error(`${r} expected ${e} bytes, got ${s}`);return n}function zt(...r){let t=0;for(let s=0;s<r.length;s++){let o=r[s];if(!Nt(o))throw new Error("Uint8Array expected");t+=o.length}let e=new Uint8Array(t),n=0;for(let s=0;s<r.length;s++){let o=r[s];e.set(o,n),n+=o.length}return e}function Xl(r,t){if(r.length!==t.length)return!1;let e=0;for(let n=0;n<r.length;n++)e|=r[n]^t[n];return e===0}function Ql(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function tu(r){let t;for(t=0;r>ei;r>>=Dr,t+=1);return t}function eu(r,t){return r>>BigInt(t)&Dr}var ru=(r,t,e)=>r|(e?Dr:ei)<<BigInt(t),hr=r=>(Yl<<BigInt(r-1))-Dr,xs=r=>new Uint8Array(r),ti=r=>Uint8Array.from(r);function vs(r,t,e){if(typeof r!="number"||r<2)throw new Error("hashLen must be a number");if(typeof t!="number"||t<2)throw new Error("qByteLen must be a number");if(typeof e!="function")throw new Error("hmacFn must be a function");let n=xs(r),s=xs(r),o=0,i=()=>{n.fill(1),s.fill(0),o=0},a=(...f)=>e(s,n,...f),c=(f=xs())=>{s=a(ti([0]),f),n=a(),f.length!==0&&(s=a(ti([1]),f),n=a())},u=()=>{if(o++>=1e3)throw new Error("drbg: tried 1000 values");let f=0,d=[];for(;f<t;){n=a();let w=n.slice();d.push(w),f+=n.length}return zt(...d)};return(f,d)=>{i(),c(f);let w;for(;!(w=d(u()));)c();return i(),w}}var nu={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"||Nt(r),isSafeInteger:r=>Number.isSafeInteger(r),array:r=>Array.isArray(r),field:(r,t)=>t.Fp.isValid(r),hash:r=>typeof r=="function"&&Number.isSafeInteger(r.outputLen)};function Dt(r,t,e={}){let n=(s,o,i)=>{let a=nu[o];if(typeof a!="function")throw new Error(`Invalid validator "${o}", expected function`);let c=r[s];if(!(i&&c===void 0)&&!a(c,r))throw new Error(`Invalid param ${String(s)}=${c} (${typeof c}), expected ${o}`)};for(let[s,o]of Object.entries(t))n(s,o,!1);for(let[s,o]of Object.entries(e))n(s,o,!0);return r}var at=BigInt(0),Y=BigInt(1),Ce=BigInt(2),su=BigInt(3),Es=BigInt(4),ni=BigInt(5),si=BigInt(8),ou=BigInt(9),iu=BigInt(16);function j(r,t){let e=r%t;return e>=at?e:t+e}function au(r,t,e){if(e<=at||t<at)throw new Error("Expected power/modulo > 0");if(e===Y)return at;let n=Y;for(;t>at;)t&Y&&(n=n*r%e),r=r*r%e,t>>=Y;return n}function W(r,t,e){let n=r;for(;t-- >at;)n*=n,n%=e;return n}function Pr(r,t){if(r===at||t<=at)throw new Error(`invert: expected positive integers, got n=${r} mod=${t}`);let e=j(r,t),n=t,s=at,o=Y,i=Y,a=at;for(;e!==at;){let u=n/e,l=n%e,f=s-i*u,d=o-a*u;n=e,e=l,s=i,o=a,i=f,a=d}if(n!==Y)throw new Error("invert: does not exist");return j(s,t)}function cu(r){let t=(r-Y)/Ce,e,n,s;for(e=r-Y,n=0;e%Ce===at;e/=Ce,n++);for(s=Ce;s<r&&au(s,t,r)!==r-Y;s++);if(n===1){let i=(r+Y)/Es;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=(e+Y)/Ce;return function(a,c){if(a.pow(c,t)===a.neg(a.ONE))throw new Error("Cannot find square root");let u=n,l=a.pow(a.mul(a.ONE,s),e),f=a.pow(c,o),d=a.pow(c,e);for(;!a.eql(d,a.ONE);){if(a.eql(d,a.ZERO))return a.ZERO;let w=1;for(let h=a.sqr(d);w<u&&!a.eql(h,a.ONE);w++)h=a.sqr(h);let g=a.pow(l,Y<<BigInt(u-w-1));l=a.sqr(g),f=a.mul(f,g),d=a.mul(d,l),u=w}return f}}function lu(r){if(r%Es===su){let t=(r+Y)/Es;return function(n,s){let o=n.pow(s,t);if(!n.eql(n.sqr(o),s))throw new Error("Cannot find square root");return o}}if(r%si===ni){let t=(r-ni)/si;return function(n,s){let o=n.mul(s,Ce),i=n.pow(o,t),a=n.mul(s,i),c=n.mul(n.mul(a,Ce),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%iu,cu(r)}var oi=(r,t)=>(j(r,t)&Y)===Y,uu=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function As(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=uu.reduce((n,s)=>(n[s]="function",n),t);return Dt(r,e)}function fu(r,t,e){if(e<at)throw new Error("Expected power > 0");if(e===at)return r.ONE;if(e===Y)return t;let n=r.ONE,s=t;for(;e>at;)e&Y&&(n=r.mul(n,s)),s=r.sqr(s),e>>=Y;return n}function hu(r,t){let e=new Array(t.length),n=t.reduce((o,i,a)=>r.is0(i)?o:(e[a]=o,r.mul(o,i)),r.ONE),s=r.inv(n);return t.reduceRight((o,i,a)=>r.is0(i)?o:(e[a]=r.mul(o,e[a]),r.mul(o,i)),s),e}function ks(r,t){let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function Kr(r,t,e=!1,n={}){if(r<=at)throw new Error(`Expected Field ORDER > 0, got ${r}`);let{nBitLength:s,nByteLength:o}=ks(r,t);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:hr(s),ZERO:at,ONE:Y,create:c=>j(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error(`Invalid field element: expected bigint, got ${typeof c}`);return at<=c&&c<r},is0:c=>c===at,isOdd:c=>(c&Y)===Y,neg:c=>j(-c,r),eql:(c,u)=>c===u,sqr:c=>j(c*c,r),add:(c,u)=>j(c+u,r),sub:(c,u)=>j(c-u,r),mul:(c,u)=>j(c*u,r),pow:(c,u)=>fu(a,c,u),div:(c,u)=>j(c*Pr(u,r),r),sqrN:c=>c*c,addN:(c,u)=>c+u,subN:(c,u)=>c-u,mulN:(c,u)=>c*u,inv:c=>Pr(c,r),sqrt:n.sqrt||(c=>i(a,c)),invertBatch:c=>hu(a,c),cmov:(c,u,l)=>l?u:c,toBytes:c=>e?Te(c,o):de(c,o),fromBytes:c=>{if(c.length!==o)throw new Error(`Fp.fromBytes: expected ${o}, got ${c.length}`);return e?he(c):Gt(c)}});return Object.freeze(a)}function ii(r,t){if(!r.isOdd)throw new Error("Field doesn't have isOdd");let e=r.sqrt(t);return r.isOdd(e)?r.neg(e):e}function ai(r){if(typeof r!="bigint")throw new Error("field order must be bigint");let t=r.toString(2).length;return Math.ceil(t/8)}function Ss(r){let t=ai(r);return t+Math.ceil(t/2)}function ci(r,t,e=!1){let n=r.length,s=ai(t),o=Ss(t);if(n<16||n<o||n>1024)throw new Error(`expected ${o}-1024 bytes of input, got ${n}`);let i=e?Gt(r):he(r),a=j(i,t-Y)+Y;return e?Te(a,s):de(a,s)}var gu=BigInt(0),Is=BigInt(1);function Mr(r,t){let e=(s,o)=>{let i=o.negate();return s?i:o},n=s=>{let o=Math.ceil(t/s)+1,i=2**(s-1);return{windows:o,windowSize:i}};return{constTimeNegate:e,unsafeLadder(s,o){let i=r.ZERO,a=s;for(;o>gu;)o&Is&&(i=i.add(a)),a=a.double(),o>>=Is;return i},precomputeWindow(s,o){let{windows:i,windowSize:a}=n(o),c=[],u=s,l=u;for(let f=0;f<i;f++){l=u,c.push(l);for(let d=1;d<a;d++)l=l.add(u),c.push(l);u=l.double()}return c},wNAF(s,o,i){let{windows:a,windowSize:c}=n(s),u=r.ZERO,l=r.BASE,f=BigInt(2**s-1),d=2**s,w=BigInt(s);for(let g=0;g<a;g++){let h=g*c,p=Number(i&f);i>>=w,p>c&&(p-=d,i+=Is);let m=h,B=h+Math.abs(p)-1,b=g%2!==0,T=p<0;p===0?l=l.add(e(b,o[m])):u=u.add(e(T,o[B]))}return{p:u,f:l}},wNAFCached(s,o,i,a){let c=s._WINDOW_SIZE||1,u=o.get(s);return u||(u=this.precomputeWindow(s,c),c!==1&&o.set(s,a(u))),this.wNAF(c,u,i)}}}function dr(r){return As(r.Fp),Dt(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...ks(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Rt=BigInt(0),wt=BigInt(1),Fr=BigInt(2),pu=BigInt(8),yu={zip215:!0};function mu(r){let t=dr(r);return Dt(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function $r(r){let t=mu(r),{Fp:e,n,prehash:s,hash:o,randomBytes:i,nByteLength:a,h:c}=t,u=Fr<<BigInt(a*8)-wt,l=e.create,f=t.uvRatio||((E,y)=>{try{return{isValid:!0,value:e.sqrt(E*e.inv(y))}}catch{return{isValid:!1,value:Rt}}}),d=t.adjustScalarBytes||(E=>E),w=t.domain||((E,y,S)=>{if(y.length||S)throw new Error("Contexts/pre-hash are not supported");return E}),g=E=>typeof E=="bigint"&&Rt<E,h=(E,y)=>g(E)&&g(y)&&E<y,p=E=>E===Rt||h(E,u);function m(E,y){if(h(E,y))return E;throw new Error(`Expected valid scalar < ${y}, got ${typeof E} ${E}`)}function B(E){return E===Rt?E:m(E,n)}let b=new Map;function T(E){if(!(E instanceof x))throw new Error("ExtendedPoint expected")}class x{constructor(y,S,C,U){if(this.ex=y,this.ey=S,this.ez=C,this.et=U,!p(y))throw new Error("x required");if(!p(S))throw new Error("y required");if(!p(C))throw new Error("z required");if(!p(U))throw new Error("t required")}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(y){if(y instanceof x)throw new Error("extended point not allowed");let{x:S,y:C}=y||{};if(!p(S)||!p(C))throw new Error("invalid affine point");return new x(S,C,wt,l(S*C))}static normalizeZ(y){let S=e.invertBatch(y.map(C=>C.ez));return y.map((C,U)=>C.toAffine(S[U])).map(x.fromAffine)}_setWindowSize(y){this._WINDOW_SIZE=y,b.delete(this)}assertValidity(){let{a:y,d:S}=t;if(this.is0())throw new Error("bad point: ZERO");let{ex:C,ey:U,ez:D,et:O}=this,q=l(C*C),K=l(U*U),F=l(D*D),nt=l(F*F),J=l(q*y),lt=l(F*l(J+K)),ut=l(nt+l(S*l(q*K)));if(lt!==ut)throw new Error("bad point: equation left != right (1)");let it=l(C*U),ht=l(D*O);if(it!==ht)throw new Error("bad point: equation left != right (2)")}equals(y){T(y);let{ex:S,ey:C,ez:U}=this,{ex:D,ey:O,ez:q}=y,K=l(S*q),F=l(D*U),nt=l(C*q),J=l(O*U);return K===F&&nt===J}is0(){return this.equals(x.ZERO)}negate(){return new x(l(-this.ex),this.ey,this.ez,l(-this.et))}double(){let{a:y}=t,{ex:S,ey:C,ez:U}=this,D=l(S*S),O=l(C*C),q=l(Fr*l(U*U)),K=l(y*D),F=S+C,nt=l(l(F*F)-D-O),J=K+O,lt=J-q,ut=K-O,it=l(nt*lt),ht=l(J*ut),Mt=l(nt*ut),Ae=l(lt*J);return new x(it,ht,Ae,Mt)}add(y){T(y);let{a:S,d:C}=t,{ex:U,ey:D,ez:O,et:q}=this,{ex:K,ey:F,ez:nt,et:J}=y;if(S===BigInt(-1)){let bo=l((D-U)*(F+K)),wo=l((D+U)*(F-K)),qn=l(wo-bo);if(qn===Rt)return this.double();let xo=l(O*Fr*J),Bo=l(q*Fr*nt),vo=Bo+xo,Eo=wo+bo,Ao=Bo-xo,ec=l(vo*qn),rc=l(Eo*Ao),nc=l(vo*Ao),sc=l(qn*Eo);return new x(ec,rc,sc,nc)}let lt=l(U*K),ut=l(D*F),it=l(q*C*J),ht=l(O*nt),Mt=l((U+D)*(K+F)-lt-ut),Ae=ht-it,ar=ht+it,mo=l(ut-S*lt),Ja=l(Mt*Ae),Xa=l(ar*mo),Qa=l(Mt*mo),tc=l(Ae*ar);return new x(Ja,Xa,tc,Qa)}subtract(y){return this.add(y.negate())}wNAF(y){return R.wNAFCached(this,b,y,x.normalizeZ)}multiply(y){let{p:S,f:C}=this.wNAF(m(y,n));return x.normalizeZ([S,C])[0]}multiplyUnsafe(y){let S=B(y);return S===Rt?N:this.equals(N)||S===wt?this:this.equals(A)?this.wNAF(S).p:R.unsafeLadder(this,S)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return R.unsafeLadder(this,n).is0()}toAffine(y){let{ex:S,ey:C,ez:U}=this,D=this.is0();y==null&&(y=D?pu:e.inv(U));let O=l(S*y),q=l(C*y),K=l(U*y);if(D)return{x:Rt,y:wt};if(K!==wt)throw new Error("invZ was invalid");return{x:O,y:q}}clearCofactor(){let{h:y}=t;return y===wt?this:this.multiplyUnsafe(y)}static fromHex(y,S=!1){let{d:C,a:U}=t,D=e.BYTES;y=Q("pointHex",y,D);let O=y.slice(),q=y[D-1];O[D-1]=q&-129;let K=he(O);K===Rt||(S?m(K,u):m(K,e.ORDER));let F=l(K*K),nt=l(F-wt),J=l(C*F-U),{isValid:lt,value:ut}=f(nt,J);if(!lt)throw new Error("Point.fromHex: invalid y coordinate");let it=(ut&wt)===wt,ht=(q&128)!==0;if(!S&&ut===Rt&&ht)throw new Error("Point.fromHex: x=0 and x_0=1");return ht!==it&&(ut=l(-ut)),x.fromAffine({x:ut,y:K})}static fromPrivateKey(y){return V(y).point}toRawBytes(){let{x:y,y:S}=this.toAffine(),C=Te(S,e.BYTES);return C[C.length-1]|=y&wt?128:0,C}toHex(){return jt(this.toRawBytes())}}x.BASE=new x(t.Gx,t.Gy,wt,l(t.Gx*t.Gy)),x.ZERO=new x(Rt,wt,wt,Rt);let{BASE:A,ZERO:N}=x,R=Mr(x,a*8);function $(E){return j(E,n)}function M(E){return $(he(E))}function V(E){let y=a;E=Q("private key",E,y);let S=Q("hashed private key",o(E),2*y),C=d(S.slice(0,y)),U=S.slice(y,2*y),D=M(C),O=A.multiply(D),q=O.toRawBytes();return{head:C,prefix:U,scalar:D,point:O,pointBytes:q}}function rt(E){return V(E).pointBytes}function tt(E=new Uint8Array,...y){let S=zt(...y);return M(o(w(S,Q("context",E),!!s)))}function Bt(E,y,S={}){E=Q("message",E),s&&(E=s(E));let{prefix:C,scalar:U,pointBytes:D}=V(y),O=tt(S.context,C,E),q=A.multiply(O).toRawBytes(),K=tt(S.context,q,D,E),F=$(O+K*U);B(F);let nt=zt(q,Te(F,e.BYTES));return Q("result",nt,a*2)}let v=yu;function I(E,y,S,C=v){let{context:U,zip215:D}=C,O=e.BYTES;E=Q("signature",E,2*O),y=Q("message",y),s&&(y=s(y));let q=he(E.slice(O,2*O)),K,F,nt;try{K=x.fromHex(S,D),F=x.fromHex(E.slice(0,O),D),nt=A.multiplyUnsafe(q)}catch{return!1}if(!D&&K.isSmallOrder())return!1;let J=tt(U,F.toRawBytes(),K.toRawBytes(),y);return F.add(K.multiplyUnsafe(J)).subtract(nt).clearCofactor().equals(x.ZERO)}return A._setWindowSize(8),{CURVE:t,getPublicKey:rt,sign:Bt,verify:I,ExtendedPoint:x,utils:{getExtendedPublicKey:V,randomPrivateKey:()=>i(e.BYTES),precompute(E=8,y=x.BASE){return y._setWindowSize(E),y.multiply(BigInt(3)),y}}}}var Rs=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),li=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),bd=BigInt(0),bu=BigInt(1),Ns=BigInt(2),wu=BigInt(5),ui=BigInt(10),xu=BigInt(20),Bu=BigInt(40),fi=BigInt(80);function vu(r){let t=Rs,n=r*r%t*r%t,s=W(n,Ns,t)*n%t,o=W(s,bu,t)*r%t,i=W(o,wu,t)*o%t,a=W(i,ui,t)*i%t,c=W(a,xu,t)*a%t,u=W(c,Bu,t)*c%t,l=W(u,fi,t)*u%t,f=W(l,fi,t)*u%t,d=W(f,ui,t)*i%t;return{pow_p_5_8:W(d,Ns,t)*r%t,b2:n}}function Eu(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function Au(r,t){let e=Rs,n=j(t*t*t,e),s=j(n*n*t,e),o=vu(r*s).pow_p_5_8,i=j(r*n*o,e),a=j(t*i*i,e),c=i,u=j(i*li,e),l=a===r,f=a===j(-r,e),d=a===j(-r*li,e);return l&&(i=c),(f||d)&&(i=u),oi(i,e)&&(i=j(-i,e)),{isValid:l||f,value:i}}var Zt=Kr(Rs,void 0,!0),Ts={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:Zt,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:BigInt(8),Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:fe,randomBytes:We,adjustScalarBytes:Eu,uvRatio:Au},Je=$r(Ts);function hi(r,t,e){if(t.length>255)throw new Error("Context is too big");return Vr(ms("SigEd25519 no Ed25519 collisions"),new Uint8Array([e?1:0,t.length]),t,r)}var wd=$r({...Ts,domain:hi}),xd=$r({...Ts,domain:hi,prehash:fe});var ku=(Zt.ORDER+BigInt(3))/BigInt(8),Bd=Zt.pow(Ns,ku),vd=Zt.sqrt(Zt.neg(Zt.ONE)),Ed=(Zt.ORDER-BigInt(5))/BigInt(8),Ad=BigInt(486662);var kd=ii(Zt,Zt.neg(BigInt(486664)));var Sd=BigInt("25063068953384623474111414158702152701244531502492656460079210482610430750235"),Id=BigInt("54469307008909316920995813868745141605393597292927456921205312896311721017578"),Nd=BigInt("1159843021668779879193775521855586647937357759715417654439879720876111806838"),Rd=BigInt("40440834346308536858101042469323190826248399146238708352240133220865137265952");var Td=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff");var Xe=32,Yt=64,qr=32;function di(){let r=Je.utils.randomPrivateKey(),t=Je.getPublicKey(r);return{privateKey:mi(r,t),publicKey:t}}function gi(r){if(r.length!==qr)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 t=r,e=Je.getPublicKey(t);return{privateKey:mi(t,e),publicKey:e}}function pi(r,t){let e=r.subarray(0,qr);return Je.sign(t instanceof Uint8Array?t:t.subarray(),e)}function yi(r,t,e){return Je.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}function mi(r,t){let e=new Uint8Array(Yt);for(let n=0;n<qr;n++)e[n]=r[n],e[qr+n]=t[n];return e}var Cs={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function jr(r){let t=r?.algorithm??"AES-GCM",e=r?.keyLength??16,n=r?.nonceLength??12,s=r?.digest??"SHA-256",o=r?.saltLength??16,i=r?.iterations??32767,a=z.get();e*=8;async function c(f,d){let w=a.getRandomValues(new Uint8Array(o)),g=a.getRandomValues(new Uint8Array(n)),h={name:t,iv:g};typeof d=="string"&&(d=Z(d));let p;if(d.length===0){p=await a.subtle.importKey("jwk",Cs,{name:"AES-GCM"},!0,["encrypt"]);try{let B={name:"PBKDF2",salt:w,iterations:i,hash:{name:s}},b=await a.subtle.importKey("raw",d,{name:"PBKDF2"},!1,["deriveKey"]);p=await a.subtle.deriveKey(B,b,{name:t,length:e},!0,["encrypt"])}catch{p=await a.subtle.importKey("jwk",Cs,{name:"AES-GCM"},!0,["encrypt"])}}else{let B={name:"PBKDF2",salt:w,iterations:i,hash:{name:s}},b=await a.subtle.importKey("raw",d,{name:"PBKDF2"},!1,["deriveKey"]);p=await a.subtle.deriveKey(B,b,{name:t,length:e},!0,["encrypt"])}let m=await a.subtle.encrypt(h,p,f);return $t([w,h.iv,new Uint8Array(m)])}async function u(f,d){let w=f.subarray(0,o),g=f.subarray(o,o+n),h=f.subarray(o+n),p={name:t,iv:g};typeof d=="string"&&(d=Z(d));let m;if(d.length===0)try{let b={name:"PBKDF2",salt:w,iterations:i,hash:{name:s}},T=await a.subtle.importKey("raw",d,{name:"PBKDF2"},!1,["deriveKey"]);m=await a.subtle.deriveKey(b,T,{name:t,length:e},!0,["decrypt"])}catch{m=await a.subtle.importKey("jwk",Cs,{name:"AES-GCM"},!0,["decrypt"])}else{let b={name:"PBKDF2",salt:w,iterations:i,hash:{name:s}},T=await a.subtle.importKey("raw",d,{name:"PBKDF2"},!1,["deriveKey"]);m=await a.subtle.deriveKey(b,T,{name:t,length:e},!0,["decrypt"])}let B=await a.subtle.decrypt(p,m,h);return new Uint8Array(B)}return{encrypt:c,decrypt:u}}async function Qe(r,t){let n=await jr().encrypt(r,t);return Ie.encode(n)}var er={};et(er,{KeyType:()=>G,PrivateKey:()=>_t,PublicKey:()=>Ct});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),pt=128,ge=127;function gr(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,t,e=0){switch(gr(r)){case 8:t[e++]=r&255|pt,r/=128;case 7:t[e++]=r&255|pt,r/=128;case 6:t[e++]=r&255|pt,r/=128;case 5:t[e++]=r&255|pt,r/=128;case 4:t[e++]=r&255|pt,r>>>=7;case 3:t[e++]=r&255|pt,r>>>=7;case 2:t[e++]=r&255|pt,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function Ai(r,t){let e=r[t],n=0;if(n+=e&ge,e<pt||(e=r[t+1],n+=(e&ge)<<7,e<pt)||(e=r[t+2],n+=(e&ge)<<14,e<pt)||(e=r[t+3],n+=(e&ge)<<21,e<pt)||(e=r[t+4],n+=(e&ge)*wi,e<pt)||(e=r[t+5],n+=(e&ge)*xi,e<pt)||(e=r[t+6],n+=(e&ge)*Bi,e<pt)||(e=r[t+7],n+=(e&ge)*vi,e<pt))return n;throw new RangeError("Could not decode varint")}var _s=new Float32Array([-0]),pe=new Uint8Array(_s.buffer);function ki(r,t,e){_s[0]=r,t[e]=pe[0],t[e+1]=pe[1],t[e+2]=pe[2],t[e+3]=pe[3]}function Si(r,t){return pe[0]=r[t],pe[1]=r[t+1],pe[2]=r[t+2],pe[3]=r[t+3],_s[0]}var Us=new Float64Array([-0]),dt=new Uint8Array(Us.buffer);function Ii(r,t,e){Us[0]=r,t[e]=dt[0],t[e+1]=dt[1],t[e+2]=dt[2],t[e+3]=dt[3],t[e+4]=dt[4],t[e+5]=dt[5],t[e+6]=dt[6],t[e+7]=dt[7]}function Ni(r,t){return dt[0]=r[t],dt[1]=r[t+1],dt[2]=r[t+2],dt[3]=r[t+3],dt[4]=r[t+4],dt[5]=r[t+5],dt[6]=r[t+6],dt[7]=r[t+7],Us[0]}var Tu=BigInt(Number.MAX_SAFE_INTEGER),Cu=BigInt(Number.MIN_SAFE_INTEGER),xt=class r{lo;hi;constructor(t,e){this.lo=t|0,this.hi=e|0}toNumber(t=!1){if(!t&&this.hi>>>31>0){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(e+n*4294967296)}return this.lo+this.hi*4294967296}toBigInt(t=!1){if(t)return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n);if(this.hi>>>31){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(BigInt(e)+(BigInt(n)<<32n))}return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n)}toString(t=!1){return this.toBigInt(t).toString()}zzEncode(){let t=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^t)>>>0,this.lo=(this.lo<<1^t)>>>0,this}zzDecode(){let t=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^t)>>>0,this.hi=(this.hi>>>1^t)>>>0,this}length(){let t=this.lo,e=(this.lo>>>28|this.hi<<4)>>>0,n=this.hi>>>24;return n===0?e===0?t<16384?t<128?1:2:t<2097152?3:4:e<16384?e<128?5:6:e<2097152?7:8:n<128?9:10}static fromBigInt(t){if(t===0n)return _e;if(t<Tu&&t>Cu)return this.fromNumber(Number(t));let e=t<0n;e&&(t=-t);let n=t>>32n,s=t-(n<<32n);return e&&(n=~n|0n,s=~s|0n,++s>Ri&&(s=0n,++n>Ri&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(t){if(t===0)return _e;let e=t<0;e&&(t=-t);let n=t>>>0,s=(t-n)/4294967296>>>0;return e&&(s=~s>>>0,n=~n>>>0,++n>4294967295&&(n=0,++s>4294967295&&(s=0))),new r(n,s)}static from(t){return typeof t=="number"?r.fromNumber(t):typeof t=="bigint"?r.fromBigInt(t):typeof t=="string"?r.fromBigInt(BigInt(t)):t.low!=null||t.high!=null?new r(t.low>>>0,t.high>>>0):_e}},_e=new xt(0,0);_e.toBigInt=function(){return 0n};_e.zzEncode=_e.zzDecode=function(){return this};_e.length=function(){return 1};var Ri=4294967296n;function Ti(r){let t=0,e=0;for(let n=0;n<r.length;++n)e=r.charCodeAt(n),e<128?t+=1:e<2048?t+=2:(e&64512)===55296&&(r.charCodeAt(n+1)&64512)===56320?(++n,t+=4):t+=3;return t}function Ci(r,t,e){if(e-t<1)return"";let s,o=[],i=0,a;for(;t<e;)a=r[t++],a<128?o[i++]=a:a>191&&a<224?o[i++]=(a&31)<<6|r[t++]&63:a>239&&a<365?(a=((a&7)<<18|(r[t++]&63)<<12|(r[t++]&63)<<6|r[t++]&63)-65536,o[i++]=55296+(a>>10),o[i++]=56320+(a&1023)):o[i++]=(a&15)<<12|(r[t++]&63)<<6|r[t++]&63,i>8191&&((s??(s=[])).push(String.fromCharCode.apply(String,o)),i=0);return s!=null?(i>0&&s.push(String.fromCharCode.apply(String,o.slice(0,i))),s.join("")):String.fromCharCode.apply(String,o.slice(0,i))}function Ls(r,t,e){let n=e,s,o;for(let i=0;i<r.length;++i)s=r.charCodeAt(i),s<128?t[e++]=s:s<2048?(t[e++]=s>>6|192,t[e++]=s&63|128):(s&64512)===55296&&((o=r.charCodeAt(i+1))&64512)===56320?(s=65536+((s&1023)<<10)+(o&1023),++i,t[e++]=s>>18|240,t[e++]=s>>12&63|128,t[e++]=s>>6&63|128,t[e++]=s&63|128):(t[e++]=s>>12|224,t[e++]=s>>6&63|128,t[e++]=s&63|128);return e-n}function Tt(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function Gr(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var Vs=class{buf;pos;len;_slice=Uint8Array.prototype.subarray;constructor(t){this.buf=t,this.pos=0,this.len=t.length}uint32(){let t=4294967295;if(t=(this.buf[this.pos]&127)>>>0,this.buf[this.pos++]<128||(t=(t|(this.buf[this.pos]&127)<<7)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<14)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<21)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&15)<<28)>>>0,this.buf[this.pos++]<128))return t;if((this.pos+=5)>this.len)throw this.pos=this.len,Tt(this,10);return t}int32(){return this.uint32()|0}sint32(){let t=this.uint32();return t>>>1^-(t&1)|0}bool(){return this.uint32()!==0}fixed32(){if(this.pos+4>this.len)throw Tt(this,4);return Gr(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Tt(this,4);return Gr(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Tt(this,4);let t=Si(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Tt(this,4);let t=Ni(this.buf,this.pos);return this.pos+=8,t}bytes(){let t=this.uint32(),e=this.pos,n=this.pos+t;if(n>this.len)throw Tt(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return Ci(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw Tt(this,t);this.pos+=t}else do if(this.pos>=this.len)throw Tt(this);while(this.buf[this.pos++]&128);return this}skipType(t){switch(t){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;(t=this.uint32()&7)!==4;)this.skipType(t);break;case 5:this.skip(4);break;default:throw Error(`invalid wire type ${t} at offset ${this.pos}`)}return this}readLongVarint(){let t=new xt(0,0),e=0;if(this.len-this.pos>4){for(;e<4;++e)if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t;if(t.lo=(t.lo|(this.buf[this.pos]&127)<<28)>>>0,t.hi=(t.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return t;e=0}else{for(;e<3;++e){if(this.pos>=this.len)throw Tt(this);if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t}return t.lo=(t.lo|(this.buf[this.pos++]&127)<<e*7)>>>0,t}if(this.len-this.pos>4){for(;e<5;++e)if(t.hi=(t.hi|(this.buf[this.pos]&127)<<e*7+3)>>>0,this.buf[this.pos++]<128)return t}else for(;e<5;++e){if(this.pos>=this.len)throw Tt(this);if(t.hi=(t.hi|(this.buf[this.pos]&127)<<e*7+3)>>>0,this.buf[this.pos++]<128)return t}throw Error("invalid varint encoding")}readFixed64(){if(this.pos+8>this.len)throw Tt(this,8);let t=Gr(this.buf,this.pos+=4),e=Gr(this.buf,this.pos+=4);return new xt(t,e)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){let t=Ai(this.buf,this.pos);return this.pos+=gr(t),t}uint64String(){return this.readLongVarint().toString(!0)}sint64(){return this.readLongVarint().zzDecode().toBigInt()}sint64Number(){return this.readLongVarint().zzDecode().toNumber()}sint64String(){return this.readLongVarint().zzDecode().toString()}fixed64(){return this.readFixed64().toBigInt()}fixed64Number(){return this.readFixed64().toNumber()}fixed64String(){return this.readFixed64().toString()}sfixed64(){return this.readFixed64().toBigInt()}sfixed64Number(){return this.readFixed64().toNumber()}sfixed64String(){return this.readFixed64().toString()}};function Hs(r){return new Vs(r instanceof Uint8Array?r:r.subarray())}function zr(r,t,e){let n=Hs(r);return t.decode(n,void 0,e)}function Ds(r){let t=r??8192,e=t>>>1,n,s=t;return function(i){if(i<1||i>e)return Ht(i);s+i>t&&(n=Ht(t),s=0);let a=n.subarray(s,s+=i);return s&7&&(s=(s|7)+1),a}}var Ue=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function Os(){}var Ks=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},_u=Ds();function Uu(r){return globalThis.Buffer!=null?Ht(r):_u(r)}var yr=class{len;head;tail;states;constructor(){this.len=0,this.head=new Ue(Os,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new Ue(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new Ms((t=t>>>0)<128?1:t<16384?2:t<2097152?3:t<268435456?4:5,t)).len,this}int32(t){return t<0?this._push(Zr,10,xt.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=xt.fromBigInt(t);return this._push(Zr,e.length(),e)}uint64Number(t){return this._push(Ei,gr(t),t)}uint64String(t){return this.uint64(BigInt(t))}int64(t){return this.uint64(t)}int64Number(t){return this.uint64Number(t)}int64String(t){return this.uint64String(t)}sint64(t){let e=xt.fromBigInt(t).zzEncode();return this._push(Zr,e.length(),e)}sint64Number(t){let e=xt.fromNumber(t).zzEncode();return this._push(Zr,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(Ps,1,t?1:0)}fixed32(t){return this._push(pr,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=xt.fromBigInt(t);return this._push(pr,4,e.lo)._push(pr,4,e.hi)}fixed64Number(t){let e=xt.fromNumber(t);return this._push(pr,4,e.lo)._push(pr,4,e.hi)}fixed64String(t){return this.fixed64(BigInt(t))}sfixed64(t){return this.fixed64(t)}sfixed64Number(t){return this.fixed64Number(t)}sfixed64String(t){return this.fixed64String(t)}float(t){return this._push(ki,4,t)}double(t){return this._push(Ii,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(Ps,1,0):this.uint32(e)._push(Vu,e,t)}string(t){let e=Ti(t);return e!==0?this.uint32(e)._push(Ls,e,t):this._push(Ps,1,0)}fork(){return this.states=new Ks(this),this.head=this.tail=new Ue(Os,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 Ue(Os,0,0),this.len=0),this}ldelim(){let t=this.head,e=this.tail,n=this.len;return this.reset().uint32(n),n!==0&&(this.tail.next=t.next,this.tail=e,this.len+=n),this}finish(){let t=this.head.next,e=Uu(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function Ps(r,t,e){t[e]=r&255}function Lu(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var Ms=class extends Ue{next;constructor(t,e){super(Lu,t,e),this.next=void 0}};function Zr(r,t,e){for(;r.hi!==0;)t[e++]=r.lo&127|128,r.lo=(r.lo>>>7|r.hi<<25)>>>0,r.hi>>>=7;for(;r.lo>127;)t[e++]=r.lo&127|128,r.lo=r.lo>>>7;t[e++]=r.lo}function pr(r,t,e){t[e]=r&255,t[e+1]=r>>>8&255,t[e+2]=r>>>16&255,t[e+3]=r>>>24}function Vu(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(yr.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(Hu,t,r),this},yr.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(Du,t,r),this});function Hu(r,t,e){t.set(r,e)}function Du(r,t,e){r.length<40?Ls(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(Z(r),e)}function Fs(){return new yr}function Yr(r,t){let e=Fs();return t.encode(r,e,{lengthDelimited:!1}),e.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 Wr(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function $s(r){function t(s){if(r[s.toString()]==null)throw new Error("Invalid enum value");return r[s]}let e=function(o,i){let a=t(o);i.int32(a)},n=function(o){let i=o.int32();return t(i)};return Wr("enum",tr.VARINT,e,n)}function Jr(r,t){return Wr("message",tr.LENGTH_DELIMITED,r,t)}var G;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.Secp256k1="Secp256k1"})(G||(G={}));var qs;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.Secp256k1=2]="Secp256k1"})(qs||(qs={}));(function(r){r.codec=()=>$s(qs)})(G||(G={}));var Ct;(function(r){let t;r.codec=()=>(t==null&&(t=Jr((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),G.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let s={},o=n==null?e.len:e.pos+n;for(;e.pos<o;){let i=e.uint32();switch(i>>>3){case 1:s.Type=G.codec().decode(e);break;case 2:s.Data=e.bytes();break;default:e.skipType(i&7);break}}return s})),t),r.encode=e=>Yr(e,r.codec()),r.decode=e=>zr(e,r.codec())})(Ct||(Ct={}));var _t;(function(r){let t;r.codec=()=>(t==null&&(t=Jr((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),G.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let s={},o=n==null?e.len:e.pos+n;for(;e.pos<o;){let i=e.uint32();switch(i>>>3){case 1:s.Type=G.codec().decode(e);break;case 2:s.Data=e.bytes();break;default:e.skipType(i&7);break}}return s})),t),r.encode=e=>Yr(e,r.codec()),r.decode=e=>zr(e,r.codec())})(_t||(_t={}));var Le=class{_key;constructor(t){this._key=rr(t,Xe)}verify(t,e){return yi(this._key,e,t)}marshal(){return this._key}get bytes(){return Ct.encode({Type:G.Ed25519,Data:this.marshal()}).subarray()}equals(t){return St(this.bytes,t.bytes)}hash(){let t=bt.digest(this.bytes);return Et(t)?t.then(({bytes:e})=>e):t.bytes}},Wt=class{_key;_publicKey;constructor(t,e){this._key=rr(t,Yt),this._publicKey=rr(e,Xe)}sign(t){return pi(this._key,t)}get public(){return new Le(this._publicKey)}marshal(){return this._key}get bytes(){return _t.encode({Type:G.Ed25519,Data:this.marshal()}).subarray()}equals(t){return St(this.bytes,t.bytes)}async hash(){let t=bt.digest(this.bytes),e;return Et(t)?{bytes:e}=await t:e=t.bytes,e}async id(){let t=Xn.digest(this.public.bytes);return vt.encode(t.bytes).substring(1)}async export(t,e="libp2p-key"){if(e==="libp2p-key")return Qe(this.bytes,t);throw new _(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function Ou(r){if(r.length>Yt){r=rr(r,Yt+Xe);let n=r.subarray(0,Yt),s=r.subarray(Yt,r.length);return new Wt(n,s)}r=rr(r,Yt);let t=r.subarray(0,Yt),e=r.subarray(Xe);return new Wt(t,e)}function Pu(r){return r=rr(r,Xe),new Le(r)}async function Ku(){let{privateKey:r,publicKey:t}=di();return new Wt(r,t)}async function js(r){let{privateKey:t,publicKey:e}=gi(r);return new Wt(t,e)}function rr(r,t){if(r=Uint8Array.from(r??[]),r.length!==t)throw new _(`Key must be a Uint8Array of length ${t}, got ${r.length}`,"ERR_INVALID_KEY_TYPE");return r}function st(r,t="utf8"){let e=_r[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return(t==="utf8"||t==="utf-8")&&globalThis.Buffer!=null&&globalThis.Buffer.from!=null?globalThis.Buffer.from(r.buffer,r.byteOffset,r.byteLength).toString("utf8"):e.encoder.encode(r).substring(1)}var Ui={"P-256":256,"P-384":384,"P-521":521},Mu=Object.keys(Ui),zs=Mu.join(" / ");async function Li(r){if(r!=="P-256"&&r!=="P-384"&&r!=="P-521")throw new _(`Unknown curve: ${r}. Must be ${zs}`,"ERR_INVALID_CURVE");let t=await z.get().subtle.generateKey({name:"ECDH",namedCurve:r},!0,["deriveBits"]),e=async(o,i)=>{let a;i!=null?a=await z.get().subtle.importKey("jwk",$u(r,i),{name:"ECDH",namedCurve:r},!1,["deriveBits"]):a=t.privateKey;let c=await z.get().subtle.importKey("jwk",Hi(r,o),{name:"ECDH",namedCurve:r},!1,[]),u=await z.get().subtle.deriveBits({name:"ECDH",namedCurve:r,public:c},a,Ui[r]);return new Uint8Array(u,0,u.byteLength)},n=await z.get().subtle.exportKey("jwk",t.publicKey);return{key:Fu(n),genSharedKey:e}}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 ${zs}`,"ERR_INVALID_CURVE");let t=Vi[r.crv];return $t([Uint8Array.from([4]),ps(r.x,t),ps(r.y,t)],1+t*2)}function Hi(r,t){if(r!=="P-256"&&r!=="P-384"&&r!=="P-521")throw new _(`Unknown curve: ${r}. Must be ${zs}`,"ERR_INVALID_CURVE");let e=Vi[r];if(!St(t.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:st(t.subarray(1,e+1),"base64url"),y:st(t.subarray(1+e),"base64url"),ext:!0}}var $u=(r,t)=>({...Hi(r,t.public),d:st(t.private,"base64url")});var Di=Li;async function Oi(r,t){let e=Ie.decode(r);return jr().decrypt(e,t)}var Pi={"AES-128":{ivSize:16,keySize:16},"AES-256":{ivSize:16,keySize:32},Blowfish:{ivSize:8,keySize:32}};async function Ki(r,t,e){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(t==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),u=await jn(t,e),l=await u.digest(a),f=[],d=0;for(;d<c;){let B=await u.digest($t([l,a])),b=B.length;d+b>c&&(b=c-d),f.push(B),d+=b,l=await u.digest(l)}let w=c/2,g=$t(f),h=g.subarray(0,w),p=g.subarray(w,c),m=B=>({iv:B.subarray(0,o),cipherKey:B.subarray(o,o+s),macKey:B.subarray(o+s)});return{k1:m(h),k2:m(p)}}var so={};et(so,{MAX_RSA_KEY_SIZE:()=>De,RsaPrivateKey:()=>xe,RsaPublicKey:()=>He,fromJwk:()=>gf,generateKeyPair:()=>pf,unmarshalRsaPrivateKey:()=>ro,unmarshalRsaPublicKey:()=>df});function Jt(r){if(isNaN(r)||r<=0)throw new _("random bytes length must be a Number bigger than 0","ERR_INVALID_LENGTH");return We(r)}var we={};et(we,{exportToPem:()=>lf,importFromPem:()=>eo,jwkToPkcs1:()=>sf,jwkToPkix:()=>af,pkcs1ToJwk:()=>nf,pkixToJwk:()=>of});var Xr=class extends Ze{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,Ur(t);let n=ae(e);if(this.iHash=t.create(),typeof this.iHash.update!="function")throw new Error("Expected instance of class which extends utils.Hash");this.blockLen=this.iHash.blockLen,this.outputLen=this.iHash.outputLen;let s=this.blockLen,o=new Uint8Array(s);o.set(n.length>s?t.create().update(n).digest():n);for(let i=0;i<o.length;i++)o[i]^=54;this.iHash.update(o),this.oHash=t.create();for(let i=0;i<o.length;i++)o[i]^=106;this.oHash.update(o),o.fill(0)}update(t){return ze(this),this.iHash.update(t),this}digestInto(t){ze(this),ys(t,this.outputLen),this.finished=!0,this.iHash.digestInto(t),this.oHash.update(t),this.oHash.digestInto(t),this.destroy()}digest(){let t=new Uint8Array(this.oHash.outputLen);return this.digestInto(t),t}_cloneInto(t){t||(t=Object.create(Object.getPrototypeOf(this),{}));let{oHash:e,iHash:n,finished:s,destroyed:o,blockLen:i,outputLen:a}=this;return t=t,t.finished=s,t.destroyed=o,t.blockLen=i,t.outputLen=a,t.oHash=e._cloneInto(t.oHash),t.iHash=n._cloneInto(t.iHash),t}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},mr=(r,t,e)=>new Xr(r,t).update(e).digest();mr.create=(r,t)=>new Xr(r,t);function Mi(r,t,e,n){Ur(r);let s=Jo({dkLen:32,asyncTick:10},n),{c:o,dkLen:i,asyncTick:a}=s;if(Ge(o),Ge(i),Ge(a),o<1)throw new Error("PBKDF2: iterations (c) should be >= 1");let c=ae(t),u=ae(e),l=new Uint8Array(i),f=mr.create(r,c),d=f._cloneInto().update(u);return{c:o,dkLen:i,asyncTick:a,DK:l,PRF:f,PRFSalt:d}}function Fi(r,t,e,n,s){return r.destroy(),t.destroy(),n&&n.destroy(),s.fill(0),e}function $i(r,t,e,n){let{c:s,dkLen:o,DK:i,PRF:a,PRFSalt:c}=Mi(r,t,e,n),u,l=new Uint8Array(4),f=Ne(l),d=new Uint8Array(a.outputLen);for(let w=1,g=0;g<o;w++,g+=a.outputLen){let h=i.subarray(g,g+a.outputLen);f.setInt32(0,w,!1),(u=c._cloneInto(u)).update(l).digestInto(d),h.set(d.subarray(0,h.length));for(let p=1;p<s;p++){a._cloneInto(u).update(d).digestInto(d);for(let m=0;m<h.length;m++)h[m]^=d[m]}}return Fi(a,c,i,u,d)}async function Zs(r,t,e,n){let{c:s,dkLen:o,asyncTick:i,DK:a,PRF:c,PRFSalt:u}=Mi(r,t,e,n),l,f=new Uint8Array(4),d=Ne(f),w=new Uint8Array(c.outputLen);for(let g=1,h=0;h<o;g++,h+=c.outputLen){let p=a.subarray(h,h+c.outputLen);d.setInt32(0,g,!1),(l=u._cloneInto(l)).update(f).digestInto(w),p.set(w.subarray(0,p.length)),await Wo(s-1,i,()=>{c._cloneInto(l).update(w).digestInto(w);for(let m=0;m<p.length;m++)p[m]^=w[m]})}return Fi(c,u,a,l,w)}var P=fc(qi());function Ve(r,t){let e=0;if(r.length===1)return r[0];for(let n=r.length-1;n>=0;n--)e+=r[r.length-1-n]*Math.pow(2,t*n);return e}function ye(r,t,e=-1){let n=e,s=r,o=0,i=Math.pow(2,t);for(let a=1;a<8;a++){if(r<i){let c;if(n<0)c=new ArrayBuffer(a),o=a;else{if(n<a)return new ArrayBuffer(0);c=new ArrayBuffer(n),o=n}let u=new Uint8Array(c);for(let l=a-1;l>=0;l--){let f=Math.pow(2,l*t);u[o-l-1]=Math.floor(s/f),s-=u[o-l-1]*f}return c}i*=Math.pow(2,t)}return new ArrayBuffer(0)}function en(...r){let t=0,e=0;for(let o of r)t+=o.length;let n=new ArrayBuffer(t),s=new Uint8Array(n);for(let o of r)s.set(o,e),e+=o.length;return s}function Ws(){let r=new Uint8Array(this.valueHex);if(this.valueHex.byteLength>=2){let a=r[0]===255&&r[1]&128,c=r[0]===0&&(r[1]&128)===0;(a||c)&&this.warnings.push("Needlessly long format")}let t=new ArrayBuffer(this.valueHex.byteLength),e=new Uint8Array(t);for(let a=0;a<this.valueHex.byteLength;a++)e[a]=0;e[0]=r[0]&128;let n=Ve(e,8),s=new ArrayBuffer(this.valueHex.byteLength),o=new Uint8Array(s);for(let a=0;a<this.valueHex.byteLength;a++)o[a]=r[a];return o[0]&=127,Ve(o,8)-n}function ji(r){let t=r<0?r*-1:r,e=128;for(let n=1;n<8;n++){if(t<=e){if(r<0){let i=e-t,a=ye(i,8,n),c=new Uint8Array(a);return c[0]|=128,a}let s=ye(t,8,n),o=new Uint8Array(s);if(o[0]&128){let i=s.slice(0),a=new Uint8Array(i);s=new ArrayBuffer(s.byteLength+1),o=new Uint8Array(s);for(let c=0;c<i.byteLength;c++)o[c+1]=a[c];o[0]=0}return s}e*=Math.pow(2,8)}return new ArrayBuffer(0)}function Gi(r,t){if(r.byteLength!==t.byteLength)return!1;let e=new Uint8Array(r),n=new Uint8Array(t);for(let s=0;s<e.length;s++)if(e[s]!==n[s])return!1;return!0}function mt(r,t){let e=r.toString(10);if(t<e.length)return"";let n=t-e.length,s=new Array(n);for(let i=0;i<n;i++)s[i]="0";return s.join("").concat(e)}var Q0=Math.log(2);function rn(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function Js(r){let t=0,e=0;for(let s=0;s<r.length;s++){let o=r[s];t+=o.byteLength}let n=new Uint8Array(t);for(let s=0;s<r.length;s++){let o=r[s];n.set(new Uint8Array(o),e),e+=o.byteLength}return n.buffer}function re(r,t,e,n){return t instanceof Uint8Array?t.byteLength?e<0?(r.error="Wrong parameter: inputOffset less than zero",!1):n<0?(r.error="Wrong parameter: inputLength less than zero",!1):t.byteLength-e-n<0?(r.error="End of input reached before message was fully decoded (inconsistent offset and length values)",!1):!0:(r.error="Wrong parameter: inputBuffer has zero length",!1):(r.error="Wrong parameter: inputBuffer must be 'Uint8Array'",!1)}var wr=class{constructor(){this.items=[]}write(t){this.items.push(t)}final(){return Js(this.items)}},br=[new Uint8Array([1])],zi="0123456789";var or="",Lt=new ArrayBuffer(0),Xs=new Uint8Array(0),xr="EndOfContent",Yi="OCTET STRING",Wi="BIT STRING";function ne(r){var t;return t=class extends r{constructor(...n){var s;super(...n);let o=n[0]||{};this.isHexOnly=(s=o.isHexOnly)!==null&&s!==void 0?s:!1,this.valueHexView=o.valueHex?P.BufferSourceConverter.toUint8Array(o.valueHex):Xs}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(!re(this,i,s,o))return-1;let a=s+o;return this.valueHexView=i.subarray(s,a),this.valueHexView.length?(this.blockLength=o,a):(this.warnings.push("Zero buffer length"),s)}toBER(n=!1){return this.isHexOnly?n?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.byteLength===this.valueHexView.buffer.byteLength?this.valueHexView.buffer:this.valueHexView.slice().buffer:(this.error="Flag 'isHexOnly' is not set, abort",Lt)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:P.Convert.ToHex(this.valueHexView)}}},t.NAME="hexBlock",t}var Qt=class{constructor({blockLength:t=0,error:e=or,warnings:n=[],valueBeforeDecode:s=Xs}={}){this.blockLength=t,this.error=e,this.warnings=n,this.valueBeforeDecodeView=P.BufferSourceConverter.toUint8Array(s)}static blockName(){return this.NAME}get valueBeforeDecode(){return this.valueBeforeDecodeView.slice().buffer}set valueBeforeDecode(t){this.valueBeforeDecodeView=new Uint8Array(t)}toJSON(){return{blockName:this.constructor.NAME,blockLength:this.blockLength,error:this.error,warnings:this.warnings,valueBeforeDecode:P.Convert.ToHex(this.valueBeforeDecodeView)}}};Qt.NAME="baseBlock";var gt=class extends Qt{fromBER(t,e,n){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}toBER(t,e){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}};gt.NAME="valueBlock";var nn=class extends ne(Qt){constructor({idBlock:t={}}={}){var e,n,s,o;super(),t?(this.isHexOnly=(e=t.isHexOnly)!==null&&e!==void 0?e:!1,this.valueHexView=t.valueHex?P.BufferSourceConverter.toUint8Array(t.valueHex):Xs,this.tagClass=(n=t.tagClass)!==null&&n!==void 0?n:-1,this.tagNumber=(s=t.tagNumber)!==null&&s!==void 0?s:-1,this.isConstructed=(o=t.isConstructed)!==null&&o!==void 0?o:!1):(this.tagClass=-1,this.tagNumber=-1,this.isConstructed=!1)}toBER(t=!1){let e=0;switch(this.tagClass){case 1:e|=0;break;case 2:e|=64;break;case 3:e|=128;break;case 4:e|=192;break;default:return this.error="Unknown tag class",Lt}if(this.isConstructed&&(e|=32),this.tagNumber<31&&!this.isHexOnly){let s=new Uint8Array(1);if(!t){let o=this.tagNumber;o&=31,e|=o,s[0]=e}return s.buffer}if(!this.isHexOnly){let s=ye(this.tagNumber,7),o=new Uint8Array(s),i=s.byteLength,a=new Uint8Array(i+1);if(a[0]=e|31,!t){for(let c=0;c<i-1;c++)a[c+1]=o[c]|128;a[i]=o[i-1]}return a.buffer}let n=new Uint8Array(this.valueHexView.byteLength+1);if(n[0]=e|31,!t){let s=this.valueHexView;for(let o=0;o<s.length-1;o++)n[o+1]=s[o]|128;n[this.valueHexView.byteLength]=s[s.length-1]}return n.buffer}fromBER(t,e,n){let s=P.BufferSourceConverter.toUint8Array(t);if(!re(this,s,e,n))return-1;let o=s.subarray(e,e+n);if(o.length===0)return this.error="Zero buffer length",-1;switch(o[0]&192){case 0:this.tagClass=1;break;case 64:this.tagClass=2;break;case 128:this.tagClass=3;break;case 192:this.tagClass=4;break;default:return this.error="Unknown tag class",-1}this.isConstructed=(o[0]&32)===32,this.isHexOnly=!1;let a=o[0]&31;if(a!==31)this.tagNumber=a,this.blockLength=1;else{let c=1,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 d=new Uint8Array(l);for(let w=0;w<u.length;w++)d[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 d=0;d<c;d++)f[d]=u[d];u=this.valueHexView=new Uint8Array(c),u.set(f),this.blockLength<=9?this.tagNumber=Ve(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 e+this.blockLength}toJSON(){return{...super.toJSON(),tagClass:this.tagClass,tagNumber:this.tagNumber,isConstructed:this.isConstructed}}};nn.NAME="identificationBlock";var sn=class extends Qt{constructor({lenBlock:t={}}={}){var e,n,s;super(),this.isIndefiniteForm=(e=t.isIndefiniteForm)!==null&&e!==void 0?e:!1,this.longFormUsed=(n=t.longFormUsed)!==null&&n!==void 0?n:!1,this.length=(s=t.length)!==null&&s!==void 0?s:0}fromBER(t,e,n){let s=P.BufferSourceConverter.toUint8Array(t);if(!re(this,s,e,n))return-1;let o=s.subarray(e,e+n);if(o.length===0)return this.error="Zero buffer length",-1;if(o[0]===255)return this.error="Length block 0xFF is reserved by standard",-1;if(this.isIndefiniteForm=o[0]===128,this.isIndefiniteForm)return this.blockLength=1,e+this.blockLength;if(this.longFormUsed=!!(o[0]&128),this.longFormUsed===!1)return this.length=o[0],this.blockLength=1,e+this.blockLength;let i=o[0]&127;if(i>8)return this.error="Too big integer",-1;if(i+1>o.length)return this.error="End of input reached before message was fully decoded",-1;let a=e+1,c=s.subarray(a,a+i);return c[i-1]===0&&this.warnings.push("Needlessly long encoded length"),this.length=Ve(c,8),this.longFormUsed&&this.length<=127&&this.warnings.push("Unnecessary usage of long length form"),this.blockLength=i+1,e+this.blockLength}toBER(t=!1){let e,n;if(this.length>127&&(this.longFormUsed=!0),this.isIndefiniteForm)return e=new ArrayBuffer(1),t===!1&&(n=new Uint8Array(e),n[0]=128),e;if(this.longFormUsed){let s=ye(this.length,8);if(s.byteLength>127)return this.error="Too big length",Lt;if(e=new ArrayBuffer(s.byteLength+1),t)return e;let o=new Uint8Array(s);n=new Uint8Array(e),n[0]=s.byteLength|128;for(let i=0;i<s.byteLength;i++)n[i+1]=o[i];return e}return e=new ArrayBuffer(1),t===!1&&(n=new Uint8Array(e),n[0]=this.length),e}toJSON(){return{...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,longFormUsed:this.longFormUsed,length:this.length}}};sn.NAME="lengthBlock";var k={},ft=class extends Qt{constructor({name:t=or,optional:e=!1,primitiveSchema:n,...s}={},o){super(s),this.name=t,this.optional=e,n&&(this.primitiveSchema=n),this.idBlock=new nn(s),this.lenBlock=new sn(s),this.valueBlock=o?new o(s):new gt(s)}fromBER(t,e,n){let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}toBER(t,e){let n=e||new wr;e||Ji(this);let s=this.idBlock.toBER(t);if(n.write(s),this.lenBlock.isIndefiniteForm)n.write(new Uint8Array([128]).buffer),this.valueBlock.toBER(t,n),n.write(new ArrayBuffer(2));else{let o=this.valueBlock.toBER(t);this.lenBlock.length=o.byteLength;let i=this.lenBlock.toBER(t);n.write(i),n.write(o)}return e?Lt:n.final()}toJSON(){let t={...super.toJSON(),idBlock:this.idBlock.toJSON(),lenBlock:this.lenBlock.toJSON(),valueBlock:this.valueBlock.toJSON(),name:this.name,optional:this.optional};return this.primitiveSchema&&(t.primitiveSchema=this.primitiveSchema.toJSON()),t}toString(t="ascii"){return t==="ascii"?this.onAsciiEncoding():P.Convert.ToHex(this.toBER())}onAsciiEncoding(){return`${this.constructor.NAME} : ${P.Convert.ToHex(this.valueBlock.valueBeforeDecodeView)}`}isEqual(t){if(this===t)return!0;if(!(t instanceof this.constructor))return!1;let e=this.toBER(),n=t.toBER();return Gi(e,n)}};ft.NAME="BaseBlock";function Ji(r){if(r instanceof k.Constructed)for(let t of r.valueBlock.value)Ji(t)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var on=class extends ft{constructor({value:t=or,...e}={},n){super(e,n),t&&this.fromString(t)}getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}fromBER(t,e,n){let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.fromBuffer(this.valueBlock.valueHexView),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}onAsciiEncoding(){return`${this.constructor.NAME} : '${this.valueBlock.value}'`}};on.NAME="BaseStringBlock";var an=class extends ne(gt){constructor({isHexOnly:t=!0,...e}={}){super(e),this.isHexOnly=t}};an.NAME="PrimitiveValueBlock";var Xi,cn=class extends ft{constructor(t={}){super(t,an),this.idBlock.isConstructed=!1}};Xi=cn;k.Primitive=Xi;cn.NAME="PRIMITIVE";function Xu(r,t){if(r instanceof t)return r;let e=new t;return e.idBlock=r.idBlock,e.lenBlock=r.lenBlock,e.warnings=r.warnings,e.valueBeforeDecodeView=r.valueBeforeDecodeView,e}function Mn(r,t=0,e=r.length){let n=t,s=new ft({},gt),o=new Qt;if(!re(o,r,t,e))return s.error=o.error,{offset:-1,result:s};if(!r.subarray(t,t+e).length)return s.error="Zero buffer length",{offset:-1,result:s};let a=s.idBlock.fromBER(r,t,e);if(s.idBlock.warnings.length&&s.warnings.concat(s.idBlock.warnings),a===-1)return s.error=s.idBlock.error,{offset:-1,result:s};if(t=a,e-=s.idBlock.blockLength,a=s.lenBlock.fromBER(r,t,e),s.lenBlock.warnings.length&&s.warnings.concat(s.lenBlock.warnings),a===-1)return s.error=s.lenBlock.error,{offset:-1,result:s};if(t=a,e-=s.lenBlock.blockLength,!s.idBlock.isConstructed&&s.lenBlock.isIndefiniteForm)return s.error="Indefinite length form used for primitive encoding form",{offset:-1,result:s};let c=ft;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=Xu(s,c),a=s.fromBER(r,t,s.lenBlock.isIndefiniteForm?e:s.lenBlock.length),s.valueBeforeDecodeView=r.subarray(n,n+s.blockLength),{offset:a,result:s}}function ir(r){if(!r.byteLength){let t=new ft({},gt);return t.error="Input buffer has zero length",{offset:-1,result:t}}return Mn(P.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function Qu(r,t){return r?1:t}var Ot=class extends gt{constructor({value:t=[],isIndefiniteForm:e=!1,...n}={}){super(n),this.value=t,this.isIndefiniteForm=e}fromBER(t,e,n){let s=P.BufferSourceConverter.toUint8Array(t);if(!re(this,s,e,n))return-1;if(this.valueBeforeDecodeView=s.subarray(e,e+n),this.valueBeforeDecodeView.length===0)return this.warnings.push("Zero buffer length"),e;let o=e;for(;Qu(this.isIndefiniteForm,n)>0;){let i=Mn(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===xr)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===xr?this.value.pop():this.warnings.push("No EndOfContent block encoded")),o}toBER(t,e){let n=e||new wr;for(let s=0;s<this.value.length;s++)this.value[s].toBER(t,n);return e?Lt:n.final()}toJSON(){let t={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let e of this.value)t.value.push(e.toJSON());return t}};Ot.NAME="ConstructedValueBlock";var Qi,me=class extends ft{constructor(t={}){super(t,Ot),this.idBlock.isConstructed=!0}fromBER(t,e,n){this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm;let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}onAsciiEncoding(){let t=[];for(let n of this.valueBlock.value)t.push(n.toString("ascii").split(`
2
+ "use strict";var Libp2PCrypto=(()=>{var ic=Object.create;var Rr=Object.defineProperty;var ac=Object.getOwnPropertyDescriptor;var cc=Object.getOwnPropertyNames;var lc=Object.getPrototypeOf,uc=Object.prototype.hasOwnProperty;var fc=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),et=(r,t)=>{for(var e in t)Rr(r,e,{get:t[e],enumerable:!0})},Io=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of cc(t))!uc.call(r,s)&&s!==e&&Rr(r,s,{get:()=>t[s],enumerable:!(n=ac(t,s))||n.enumerable});return r};var hc=(r,t,e)=>(e=r!=null?ic(lc(r)):{},Io(t||!r||!r.__esModule?Rr(e,"default",{value:r,enumerable:!0}):e,r)),dc=r=>Io(Rr({},"__esModule",{value:!0}),r);var ji=fc(sr=>{"use strict";var qu="[object ArrayBuffer]",Jt=class r{static isArrayBuffer(t){return Object.prototype.toString.call(t)===qu}static toArrayBuffer(t){return this.isArrayBuffer(t)?t:t.byteLength===t.buffer.byteLength||t.byteOffset===0&&t.byteLength===t.buffer.byteLength?t.buffer:this.toUint8Array(t.buffer).slice(t.byteOffset,t.byteOffset+t.byteLength).buffer}static toUint8Array(t){return this.toView(t,Uint8Array)}static toView(t,e){if(t.constructor===e)return t;if(this.isArrayBuffer(t))return new e(t);if(this.isArrayBufferView(t))return new e(t.buffer,t.byteOffset,t.byteLength);throw new TypeError("The provided value is not of type '(ArrayBuffer or ArrayBufferView)'")}static isBufferSource(t){return this.isArrayBufferView(t)||this.isArrayBuffer(t)}static isArrayBufferView(t){return ArrayBuffer.isView(t)||t&&this.isArrayBuffer(t.buffer)}static isEqual(t,e){let n=r.toUint8Array(t),s=r.toUint8Array(e);if(n.length!==s.byteLength)return!1;for(let o=0;o<n.length;o++)if(n[o]!==s[o])return!1;return!0}static concat(...t){let e;Array.isArray(t[0])&&!(t[1]instanceof Function)||Array.isArray(t[0])&&t[1]instanceof Function?e=t[0]:t[t.length-1]instanceof Function?e=t.slice(0,t.length-1):e=t;let n=0;for(let i of e)n+=i.byteLength;let s=new Uint8Array(n),o=0;for(let i of e){let a=this.toUint8Array(i);s.set(a,o),o+=a.length}return t[t.length-1]instanceof Function?this.toView(s,t[t.length-1]):s.buffer}},Xs="string",ju=/^[0-9a-f]+$/i,Gu=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,zu=/^[a-zA-Z0-9-_]+$/,nn=class{static fromString(t){let e=unescape(encodeURIComponent(t)),n=new Uint8Array(e.length);for(let s=0;s<e.length;s++)n[s]=e.charCodeAt(s);return n.buffer}static toString(t){let e=Jt.toUint8Array(t),n="";for(let o=0;o<e.length;o++)n+=String.fromCharCode(e[o]);return decodeURIComponent(escape(n))}},At=class{static toString(t,e=!1){let n=Jt.toArrayBuffer(t),s=new DataView(n),o="";for(let i=0;i<n.byteLength;i+=2){let a=s.getUint16(i,e);o+=String.fromCharCode(a)}return o}static fromString(t,e=!1){let n=new ArrayBuffer(t.length*2),s=new DataView(n);for(let o=0;o<t.length;o++)s.setUint16(o*2,t.charCodeAt(o),e);return n}},sn=class r{static isHex(t){return typeof t===Xs&&ju.test(t)}static isBase64(t){return typeof t===Xs&&Gu.test(t)}static isBase64Url(t){return typeof t===Xs&&zu.test(t)}static ToString(t,e="utf8"){let n=Jt.toUint8Array(t);switch(e.toLowerCase()){case"utf8":return this.ToUtf8String(n);case"binary":return this.ToBinary(n);case"hex":return this.ToHex(n);case"base64":return this.ToBase64(n);case"base64url":return this.ToBase64Url(n);case"utf16le":return At.toString(n,!0);case"utf16":case"utf16be":return At.toString(n);default:throw new Error(`Unknown type of encoding '${e}'`)}}static FromString(t,e="utf8"){if(!t)return new ArrayBuffer(0);switch(e.toLowerCase()){case"utf8":return this.FromUtf8String(t);case"binary":return this.FromBinary(t);case"hex":return this.FromHex(t);case"base64":return this.FromBase64(t);case"base64url":return this.FromBase64Url(t);case"utf16le":return At.fromString(t,!0);case"utf16":case"utf16be":return At.fromString(t);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToBase64(t){let e=Jt.toUint8Array(t);if(typeof btoa<"u"){let n=this.ToString(e,"binary");return btoa(n)}else return Buffer.from(e).toString("base64")}static FromBase64(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isBase64(e))throw new TypeError("Argument 'base64Text' is not Base64 encoded");return typeof atob<"u"?this.FromBinary(atob(e)):new Uint8Array(Buffer.from(e,"base64")).buffer}static FromBase64Url(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isBase64Url(e))throw new TypeError("Argument 'base64url' is not Base64Url encoded");return this.FromBase64(this.Base64Padding(e.replace(/\-/g,"+").replace(/\_/g,"/")))}static ToBase64Url(t){return this.ToBase64(t).replace(/\+/g,"-").replace(/\//g,"_").replace(/\=/g,"")}static FromUtf8String(t,e=r.DEFAULT_UTF8_ENCODING){switch(e){case"ascii":return this.FromBinary(t);case"utf8":return nn.fromString(t);case"utf16":case"utf16be":return At.fromString(t);case"utf16le":case"usc2":return At.fromString(t,!0);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToUtf8String(t,e=r.DEFAULT_UTF8_ENCODING){switch(e){case"ascii":return this.ToBinary(t);case"utf8":return nn.toString(t);case"utf16":case"utf16be":return At.toString(t);case"utf16le":case"usc2":return At.toString(t,!0);default:throw new Error(`Unknown type of encoding '${e}'`)}}static FromBinary(t){let e=t.length,n=new Uint8Array(e);for(let s=0;s<e;s++)n[s]=t.charCodeAt(s);return n.buffer}static ToBinary(t){let e=Jt.toUint8Array(t),n="";for(let s=0;s<e.length;s++)n+=String.fromCharCode(e[s]);return n}static ToHex(t){let e=Jt.toUint8Array(t),n="",s=e.length;for(let o=0;o<s;o++){let i=e[o];i<16&&(n+="0"),n+=i.toString(16)}return n}static FromHex(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isHex(e))throw new TypeError("Argument 'hexString' is not HEX encoded");e.length%2&&(e=`0${e}`);let n=new Uint8Array(e.length/2);for(let s=0;s<e.length;s=s+2){let o=e.slice(s,s+2);n[s/2]=parseInt(o,16)}return n.buffer}static ToUtf16String(t,e=!1){return At.toString(t,e)}static FromUtf16String(t,e=!1){return At.fromString(t,e)}static Base64Padding(t){let e=4-t.length%4;if(e<4)for(let n=0;n<e;n++)t+="=";return t}static formatString(t){return t?.replace(/[\n\r\t ]/g,"")||""}};sn.DEFAULT_UTF8_ENCODING="utf8";function Zu(r,...t){let e=arguments[0];for(let n=1;n<arguments.length;n++){let s=arguments[n];for(let o in s)e[o]=s[o]}return e}function Yu(...r){let t=r.map(s=>s.byteLength).reduce((s,o)=>s+o),e=new Uint8Array(t),n=0;return r.map(s=>new Uint8Array(s)).forEach(s=>{for(let o of s)e[n++]=o}),e.buffer}function Wu(r,t){if(!(r&&t)||r.byteLength!==t.byteLength)return!1;let e=new Uint8Array(r),n=new Uint8Array(t);for(let s=0;s<r.byteLength;s++)if(e[s]!==n[s])return!1;return!0}sr.BufferSourceConverter=Jt;sr.Convert=sn;sr.assign=Zu;sr.combine=Yu;sr.isEqual=Wu});var Vf={};et(Vf,{hmac:()=>Cr,keys:()=>yo,pbkdf2:()=>bo,randomBytes:()=>Wt});var Cr={};et(Cr,{create:()=>Yn});var z={get(r=globalThis){let t=r.crypto;if(t==null||t.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 t}};var No={SHA1:20,SHA256:32,SHA512:64};var gc={SHA1:"SHA-1",SHA256:"SHA-256",SHA512:"SHA-512"},pc=async(r,t)=>{let e=await z.get().subtle.sign({name:"HMAC"},r,t);return new Uint8Array(e,0,e.byteLength)};async function Yn(r,t){let e=gc[r],n=await z.get().subtle.importKey("raw",t,{name:"HMAC",hash:{name:e}},!1,["sign"]);return{async digest(s){return pc(n,s)},length:No[r]}}var yo={};et(yo,{Ed25519PrivateKey:()=>Yt,Ed25519PublicKey:()=>Ue,MAX_RSA_KEY_SIZE:()=>He,RsaPrivateKey:()=>xe,RsaPublicKey:()=>Ve,Secp256k1PrivateKey:()=>Pe,Secp256k1PublicKey:()=>Oe,generateEphemeralKeyPair:()=>Oi,generateKeyPair:()=>Rf,generateKeyPairFromSeed:()=>Cf,importKey:()=>Lf,keyStretcher:()=>Mi,keysPBM:()=>rr,marshalPrivateKey:()=>Uf,marshalPublicKey:()=>_f,supportedKeys:()=>se,unmarshalPrivateKey:()=>Ya,unmarshalPublicKey:()=>Tf});var _=class extends Error{code;props;constructor(t,e,n){super(t),this.code=e,this.name=n?.name??"CodeError",this.props=n??{}}};var Ys={};et(Ys,{Ed25519PrivateKey:()=>Yt,Ed25519PublicKey:()=>Ue,generateKeyPair:()=>Ku,generateKeyPairFromSeed:()=>Zs,unmarshalEd25519PrivateKey:()=>Ou,unmarshalEd25519PublicKey:()=>Pu});var ts={};et(ts,{base58btc:()=>vt,base58flickr:()=>Bc});var Ff=new Uint8Array(0);function Ro(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function Mt(r){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 yc(r,t){if(r.length>=255)throw new TypeError("Alphabet too long");for(var e=new Uint8Array(256),n=0;n<e.length;n++)e[n]=255;for(var s=0;s<r.length;s++){var o=r.charAt(s),i=o.charCodeAt(0);if(e[i]!==255)throw new TypeError(o+" is ambiguous");e[i]=s}var a=r.length,c=r.charAt(0),u=Math.log(a)/Math.log(256),l=Math.log(256)/Math.log(a);function f(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,p=0,m=0,B=g.length;m!==B&&g[m]===0;)m++,h++;for(var b=(B-m)*l+1>>>0,C=new Uint8Array(b);m!==B;){for(var x=g[m],A=0,N=b-1;(x!==0||A<p)&&N!==-1;N--,A++)x+=256*C[N]>>>0,C[N]=x%a>>>0,x=x/a>>>0;if(x!==0)throw new Error("Non-zero carry");p=A,m++}for(var R=b-p;R!==b&&C[R]===0;)R++;for(var q=c.repeat(h);R<b;++R)q+=r.charAt(C[R]);return q}function d(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 p=0,m=0;g[h]===c;)p++,h++;for(var B=(g.length-h)*u+1>>>0,b=new Uint8Array(B);g[h];){var C=e[g.charCodeAt(h)];if(C===255)return;for(var x=0,A=B-1;(C!==0||x<m)&&A!==-1;A--,x++)C+=a*b[A]>>>0,b[A]=C%256>>>0,C=C/256>>>0;if(C!==0)throw new Error("Non-zero carry");m=x,h++}if(g[h]!==" "){for(var N=B-m;N!==B&&b[N]===0;)N++;for(var R=new Uint8Array(p+(B-N)),q=p;N!==B;)R[q++]=b[N++];return R}}}function w(g){var h=d(g);if(h)return h;throw new Error(`Non-${t} character`)}return{encode:f,decodeUnsafe:d,decode:w}}var mc=yc,bc=mc,Uo=bc;var Wn=class{name;prefix;baseEncode;constructor(t,e,n){this.name=t,this.prefix=e,this.baseEncode=n}encode(t){if(t instanceof Uint8Array)return`${this.prefix}${this.baseEncode(t)}`;throw Error("Unknown type, must be binary type")}},Jn=class{name;prefix;baseDecode;prefixCodePoint;constructor(t,e,n){if(this.name=t,this.prefix=e,e.codePointAt(0)===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=e.codePointAt(0),this.baseDecode=n}decode(t){if(typeof t=="string"){if(t.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(t)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(t.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(t){return Lo(this,t)}},Xn=class{decoders;constructor(t){this.decoders=t}or(t){return Lo(this,t)}decode(t){let e=t[0],n=this.decoders[e];if(n!=null)return n.decode(t);throw RangeError(`Unable to decode multibase string ${JSON.stringify(t)}, only inputs prefixed with ${Object.keys(this.decoders)} are supported`)}};function Lo(r,t){return new Xn({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var Qn=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(t,e,n,s){this.name=t,this.prefix=e,this.baseEncode=n,this.baseDecode=s,this.encoder=new Wn(t,e,n),this.decoder=new Jn(t,e,s)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function Ke({name:r,prefix:t,encode:e,decode:n}){return new Qn(r,t,e,n)}function oe({name:r,prefix:t,alphabet:e}){let{encode:n,decode:s}=Uo(e,r);return Ke({prefix:t,name:r,encode:n,decode:o=>Mt(s(o))})}function wc(r,t,e,n){let s={};for(let l=0;l<t.length;++l)s[t[l]]=l;let o=r.length;for(;r[o-1]==="=";)--o;let i=new Uint8Array(o*e/8|0),a=0,c=0,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<<e|f,a+=e,a>=8&&(a-=8,i[u++]=255&c>>a)}if(a>=e||255&c<<8-a)throw new SyntaxError("Unexpected end of data");return i}function xc(r,t,e){let n=t[t.length-1]==="=",s=(1<<e)-1,o="",i=0,a=0;for(let c=0;c<r.length;++c)for(a=a<<8|r[c],i+=8;i>e;)i-=e,o+=t[s&a>>i];if(i!==0&&(o+=t[s&a<<e-i]),n)for(;o.length*e&7;)o+="=";return o}function X({name:r,prefix:t,bitsPerChar:e,alphabet:n}){return Ke({prefix:t,name:r,encode(s){return xc(s,n,e)},decode(s){return wc(s,n,e,r)}})}var vt=oe({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),Bc=oe({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var ns={};et(ns,{identity:()=>rs});var vc=Do,Vo=128,Ec=127,Ac=~Ec,kc=Math.pow(2,31);function Do(r,t,e){t=t||[],e=e||0;for(var n=e;r>=kc;)t[e++]=r&255|Vo,r/=128;for(;r&Ac;)t[e++]=r&255|Vo,r>>>=7;return t[e]=r|0,Do.bytes=e-n+1,t}var Sc=es,Ic=128,Ho=127;function es(r,n){var e=0,n=n||0,s=0,o=n,i,a=r.length;do{if(o>=a)throw es.bytes=0,new RangeError("Could not decode varint");i=r[o++],e+=s<28?(i&Ho)<<s:(i&Ho)*Math.pow(2,s),s+=7}while(i>=Ic);return es.bytes=o-n,e}var Nc=Math.pow(2,7),Rc=Math.pow(2,14),Cc=Math.pow(2,21),Tc=Math.pow(2,28),_c=Math.pow(2,35),Uc=Math.pow(2,42),Lc=Math.pow(2,49),Vc=Math.pow(2,56),Hc=Math.pow(2,63),Dc=function(r){return r<Nc?1:r<Rc?2:r<Cc?3:r<Tc?4:r<_c?5:r<Uc?6:r<Lc?7:r<Vc?8:r<Hc?9:10},Oc={encode:vc,decode:Sc,encodingLength:Dc},Pc=Oc,lr=Pc;function ur(r,t=0){return[lr.decode(r,t),lr.decode.bytes]}function Me(r,t,e=0){return lr.encode(r,t,e),t}function Fe(r){return lr.encodingLength(r)}function ke(r,t){let e=t.byteLength,n=Fe(r),s=n+Fe(e),o=new Uint8Array(s+e);return Me(r,o,0),Me(e,o,n),o.set(t,s),new $e(r,e,t,o)}function Oo(r){let t=Mt(r),[e,n]=ur(t),[s,o]=ur(t.subarray(n)),i=t.subarray(n+o);if(i.byteLength!==s)throw new Error("Incorrect length");return new $e(e,s,i,t)}function Po(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&Ro(r.bytes,e.bytes)}}var $e=class{code;size;digest;bytes;constructor(t,e,n,s){this.code=t,this.size=e,this.digest=n,this.bytes=s}};var Ko=0,Kc="identity",Mo=Mt;function Mc(r){return ke(Ko,Mo(r))}var rs={code:Ko,name:Kc,encode:Mo,digest:Mc};var is={};et(is,{sha256:()=>bt,sha512:()=>Fc});function os({name:r,code:t,encode:e}){return new ss(r,t,e)}var ss=class{name;code;encode;constructor(t,e,n){this.name=t,this.code=e,this.encode=n}digest(t){if(t instanceof Uint8Array){let e=this.encode(t);return e instanceof Uint8Array?ke(this.code,e):e.then(n=>ke(this.code,n))}else throw Error("Unknown type, must be binary type")}};function $o(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var bt=os({name:"sha2-256",code:18,encode:$o("SHA-256")}),Fc=os({name:"sha2-512",code:19,encode:$o("SHA-512")});function St(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function Vt(r=0){return new Uint8Array(r)}function Ft(r,t){t==null&&(t=r.reduce((s,o)=>s+o.length,0));let e=Vt(t),n=0;for(let s of r)e.set(s,n),n+=s.length;return e}var as={};et(as,{base10:()=>$c});var $c=oe({prefix:"9",name:"base10",alphabet:"0123456789"});var cs={};et(cs,{base16:()=>qc,base16upper:()=>jc});var qc=X({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),jc=X({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var ls={};et(ls,{base2:()=>Gc});var Gc=X({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var us={};et(us,{base256emoji:()=>Jc});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,t,e)=>(r[e]=t,r),[]),Zc=qo.reduce((r,t,e)=>(r[t.codePointAt(0)]=e,r),[]);function Yc(r){return r.reduce((t,e)=>(t+=zc[e],t),"")}function Wc(r){let t=[];for(let e of r){let n=Zc[e.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${e}`);t.push(n)}return new Uint8Array(t)}var Jc=Ke({prefix:"\u{1F680}",name:"base256emoji",encode:Yc,decode:Wc});var fs={};et(fs,{base32:()=>qe,base32hex:()=>el,base32hexpad:()=>nl,base32hexpadupper:()=>sl,base32hexupper:()=>rl,base32pad:()=>Qc,base32padupper:()=>tl,base32upper:()=>Xc,base32z:()=>ol});var qe=X({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),Xc=X({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Qc=X({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),tl=X({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),el=X({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),rl=X({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),nl=X({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),sl=X({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),ol=X({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var hs={};et(hs,{base36:()=>il,base36upper:()=>al});var il=oe({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),al=oe({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var ds={};et(ds,{base64:()=>Se,base64pad:()=>cl,base64url:()=>ll,base64urlpad:()=>ul});var Se=X({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),cl=X({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),ll=X({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),ul=X({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var gs={};et(gs,{base8:()=>fl});var fl=X({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var ps={};et(ps,{identity:()=>hl});var hl=Ke({prefix:"\0",name:"identity",encode:r=>To(r),decode:r=>Co(r)});var yh=new TextEncoder,mh=new TextDecoder;function jo(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return yl(e,ys(r),t??vt.encoder);default:return ml(e,ys(r),t??qe.encoder)}}var Go=new WeakMap;function ys(r){let t=Go.get(r);if(t==null){let e=new Map;return Go.set(r,e),e}return t}var _r=class r{code;version;multihash;bytes;"/";constructor(t,e,n,s){this.code=e,this.version=t,this.multihash=n,this.bytes=s,this["/"]=s}get asCID(){return this}get byteOffset(){return this.bytes.byteOffset}get byteLength(){return this.bytes.byteLength}toV0(){switch(this.version){case 0:return this;case 1:{let{code:t,multihash:e}=this;if(t!==hr)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==bl)throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");return r.createV0(e)}default:throw Error(`Can not convert CID version ${this.version} to version 0. This is a bug please report`)}}toV1(){switch(this.version){case 0:{let{code:t,digest:e}=this.multihash,n=ke(t,e);return r.createV1(this.code,n)}case 1:return this;default:throw Error(`Can not convert CID version ${this.version} to version 1. This is a bug please report`)}}equals(t){return r.equals(this,t)}static equals(t,e){let n=e;return n!=null&&t.code===n.code&&t.version===n.version&&Po(t.multihash,n.multihash)}toString(t){return jo(this,t)}toJSON(){return{"/":jo(this)}}link(){return this}[Symbol.toStringTag]="CID";[Symbol.for("nodejs.util.inspect.custom")](){return`CID(${this.toString()})`}static asCID(t){if(t==null)return null;let e=t;if(e instanceof r)return e;if(e["/"]!=null&&e["/"]===e.bytes||e.asCID===e){let{version:n,code:s,multihash:o,bytes:i}=e;return new r(n,s,o,i??zo(n,s,o.bytes))}else if(e[wl]===!0){let{version:n,multihash:s,code:o}=e,i=Oo(s);return r.create(n,o,i)}else return null}static create(t,e,n){if(typeof e!="number")throw new Error("String codecs are no longer supported");if(!(n.bytes instanceof Uint8Array))throw new Error("Invalid digest");switch(t){case 0:{if(e!==hr)throw new Error(`Version 0 CID must use dag-pb (code: ${hr}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let s=zo(t,e,n.bytes);return new r(t,e,n,s)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,hr,t)}static createV1(t,e){return r.create(1,t,e)}static decode(t){let[e,n]=r.decodeFirst(t);if(n.length!==0)throw new Error("Incorrect length");return e}static decodeFirst(t){let e=r.inspectBytes(t),n=e.size-e.multihashSize,s=Mt(t.subarray(n,n+e.multihashSize));if(s.byteLength!==e.multihashSize)throw new Error("Incorrect length");let o=s.subarray(e.multihashSize-e.digestSize),i=new $e(e.multihashCode,e.digestSize,o,s);return[e.version===0?r.createV0(i):r.createV1(e.codec,i),t.subarray(e.size)]}static inspectBytes(t){let e=0,n=()=>{let[f,d]=ur(t.subarray(e));return e+=d,f},s=n(),o=hr;if(s===18?(s=0,e=0):o=n(),s!==0&&s!==1)throw new RangeError(`Invalid CID version ${s}`);let i=e,a=n(),c=n(),u=e+c,l=u-i;return{version:s,codec:o,multihashCode:a,digestSize:c,multihashSize:l,size:u}}static parse(t,e){let[n,s]=pl(t,e),o=r.decode(s);if(o.version===0&&t[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return ys(o).set(n,t),o}};function pl(r,t){switch(r[0]){case"Q":{let e=t??vt;return[vt.prefix,e.decode(`${vt.prefix}${r}`)]}case vt.prefix:{let e=t??vt;return[vt.prefix,e.decode(r)]}case qe.prefix:{let e=t??qe;return[qe.prefix,e.decode(r)]}default:{if(t==null)throw Error("To parse non base32 or base58btc encoded CID multibase decoder must be provided");return[r[0],t.decode(r)]}}}function yl(r,t,e){let{prefix:n}=e;if(n!==vt.prefix)throw Error(`Cannot string encode V0 in ${e.name} encoding`);let s=t.get(n);if(s==null){let o=e.encode(r).slice(1);return t.set(n,o),o}else return s}function ml(r,t,e){let{prefix:n}=e,s=t.get(n);if(s==null){let o=e.encode(r);return t.set(n,o),o}else return s}var hr=112,bl=18;function zo(r,t,e){let n=Fe(r),s=n+Fe(t),o=new Uint8Array(s+e.byteLength);return Me(r,o,0),Me(t,o,n),o.set(e,s),o}var wl=Symbol.for("@ipld/js-cid/CID");var ms={...ps,...ls,...gs,...as,...cs,...fs,...hs,...ts,...ds,...us},Uh={...is,...ns};function Yo(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},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 t="a";for(let e=0;e<r.length;e++)t+=String.fromCharCode(r[e]);return t},r=>{r=r.substring(1);let t=Vt(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),xl={utf8:Zo,"utf-8":Zo,hex:ms.base16,latin1:bs,ascii:bs,binary:bs,...ms},Ur=xl;function Z(r,t="utf8"){let e=Ur[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function ws(r,t){let e=Z(r,"base64urlpad");if(t!=null){if(e.length>t)throw new Error("byte array longer than desired length");e=Ft([new Uint8Array(t-e.length),e])}return e}function Et(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function je(r){if(!Number.isSafeInteger(r)||r<0)throw new Error(`positive integer expected, not ${r}`)}function Bl(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function Ge(r,...t){if(!Bl(r))throw new Error("Uint8Array expected");if(t.length>0&&!t.includes(r.length))throw new Error(`Uint8Array expected of length ${t}, not of length=${r.length}`)}function Lr(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");je(r.outputLen),je(r.blockLen)}function ze(r,t=!0){if(r.destroyed)throw new Error("Hash instance has been destroyed");if(t&&r.finished)throw new Error("Hash#digest() has already been called")}function Wo(r,t){Ge(r);let e=t.outputLen;if(r.length<e)throw new Error(`digestInto() expects output buffer of length at least ${e}`)}var Vr=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;var Ie=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),It=(r,t)=>r<<32-t|r>>>t,Hr=(r,t)=>r<<t|r>>>32-t>>>0,zh=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;var vl=async()=>{};async function Jo(r,t,e){let n=Date.now();for(let s=0;s<r;s++){e(s);let o=Date.now()-n;o>=0&&o<t||(await vl(),n+=o)}}function xs(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function ie(r){return typeof r=="string"&&(r=xs(r)),Ge(r),r}function Dr(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];Ge(s),t+=s.length}let e=new Uint8Array(t);for(let n=0,s=0;n<r.length;n++){let o=r[n];e.set(o,s),s+=o.length}return e}var Ze=class{clone(){return this._cloneInto()}},El={}.toString;function Xo(r,t){if(t!==void 0&&El.call(t)!=="[object Object]")throw new Error("Options should be object or undefined");return Object.assign(r,t)}function Ye(r){let t=n=>r().update(ie(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function We(r=32){if(Vr&&typeof Vr.getRandomValues=="function")return Vr.getRandomValues(new Uint8Array(r));throw new Error("crypto.getRandomValues must be defined")}function Al(r,t,e,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(t,e,n);let s=BigInt(32),o=BigInt(4294967295),i=Number(e>>s&o),a=Number(e&o),c=n?4:0,u=n?0:4;r.setUint32(t+c,i,n),r.setUint32(t+u,a,n)}var Or=(r,t,e)=>r&t^~r&e,Pr=(r,t,e)=>r&t^r&e^t&e,ae=class extends Ze{constructor(t,e,n,s){super(),this.blockLen=t,this.outputLen=e,this.padOffset=n,this.isLE=s,this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.buffer=new Uint8Array(t),this.view=Ie(this.buffer)}update(t){ze(this);let{view:e,buffer:n,blockLen:s}=this;t=ie(t);let o=t.length;for(let i=0;i<o;){let a=Math.min(s-this.pos,o-i);if(a===s){let c=Ie(t);for(;s<=o-i;i+=s)this.process(c,i);continue}n.set(t.subarray(i,i+a),this.pos),this.pos+=a,i+=a,this.pos===s&&(this.process(e,0),this.pos=0)}return this.length+=t.length,this.roundClean(),this}digestInto(t){ze(this),Wo(t,this),this.finished=!0;let{buffer:e,view:n,blockLen:s,isLE:o}=this,{pos:i}=this;e[i++]=128,this.buffer.subarray(i).fill(0),this.padOffset>s-i&&(this.process(n,0),i=0);for(let f=i;f<s;f++)e[f]=0;Al(n,s-8,BigInt(this.length*8),o),this.process(n,0);let a=Ie(t),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:t,outputLen:e}=this;this.digestInto(t);let n=t.slice(0,e);return this.destroy(),n}_cloneInto(t){t||(t=new this.constructor),t.set(...this.get());let{blockLen:e,buffer:n,length:s,finished:o,destroyed:i,pos:a}=this;return t.length=s,t.pos=a,t.finished=o,t.destroyed=i,s%e&&t.buffer.set(n),t}};var Kr=BigInt(4294967295),Bs=BigInt(32);function Qo(r,t=!1){return t?{h:Number(r&Kr),l:Number(r>>Bs&Kr)}:{h:Number(r>>Bs&Kr)|0,l:Number(r&Kr)|0}}function kl(r,t=!1){let e=new Uint32Array(r.length),n=new Uint32Array(r.length);for(let s=0;s<r.length;s++){let{h:o,l:i}=Qo(r[s],t);[e[s],n[s]]=[o,i]}return[e,n]}var Sl=(r,t)=>BigInt(r>>>0)<<Bs|BigInt(t>>>0),Il=(r,t,e)=>r>>>e,Nl=(r,t,e)=>r<<32-e|t>>>e,Rl=(r,t,e)=>r>>>e|t<<32-e,Cl=(r,t,e)=>r<<32-e|t>>>e,Tl=(r,t,e)=>r<<64-e|t>>>e-32,_l=(r,t,e)=>r>>>e-32|t<<64-e,Ul=(r,t)=>t,Ll=(r,t)=>r,Vl=(r,t,e)=>r<<e|t>>>32-e,Hl=(r,t,e)=>t<<e|r>>>32-e,Dl=(r,t,e)=>t<<e-32|r>>>64-e,Ol=(r,t,e)=>r<<e-32|t>>>64-e;function Pl(r,t,e,n){let s=(t>>>0)+(n>>>0);return{h:r+e+(s/2**32|0)|0,l:s|0}}var Kl=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),Ml=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,Fl=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),$l=(r,t,e,n,s)=>t+e+n+s+(r/2**32|0)|0,ql=(r,t,e,n,s)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(s>>>0),jl=(r,t,e,n,s,o)=>t+e+n+s+o+(r/2**32|0)|0;var Gl={fromBig:Qo,split:kl,toBig:Sl,shrSH:Il,shrSL:Nl,rotrSH:Rl,rotrSL:Cl,rotrBH:Tl,rotrBL:_l,rotr32H:Ul,rotr32L:Ll,rotlSH:Vl,rotlSL:Hl,rotlBH:Dl,rotlBL:Ol,add:Pl,add3L:Kl,add3H:Ml,add4L:Fl,add4H:$l,add5H:jl,add5L:ql},L=Gl;var[zl,Zl]=L.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))),ce=new Uint32Array(80),le=new Uint32Array(80),vs=class extends ae{constructor(){super(128,64,16,!1),this.Ah=1779033703,this.Al=-205731576,this.Bh=-1150833019,this.Bl=-2067093701,this.Ch=1013904242,this.Cl=-23791573,this.Dh=-1521486534,this.Dl=1595750129,this.Eh=1359893119,this.El=-1377402159,this.Fh=-1694144372,this.Fl=725511199,this.Gh=528734635,this.Gl=-79577749,this.Hh=1541459225,this.Hl=327033209}get(){let{Ah:t,Al:e,Bh:n,Bl:s,Ch:o,Cl:i,Dh:a,Dl:c,Eh:u,El:l,Fh:f,Fl:d,Gh:w,Gl:g,Hh:h,Hl:p}=this;return[t,e,n,s,o,i,a,c,u,l,f,d,w,g,h,p]}set(t,e,n,s,o,i,a,c,u,l,f,d,w,g,h,p){this.Ah=t|0,this.Al=e|0,this.Bh=n|0,this.Bl=s|0,this.Ch=o|0,this.Cl=i|0,this.Dh=a|0,this.Dl=c|0,this.Eh=u|0,this.El=l|0,this.Fh=f|0,this.Fl=d|0,this.Gh=w|0,this.Gl=g|0,this.Hh=h|0,this.Hl=p|0}process(t,e){for(let b=0;b<16;b++,e+=4)ce[b]=t.getUint32(e),le[b]=t.getUint32(e+=4);for(let b=16;b<80;b++){let C=ce[b-15]|0,x=le[b-15]|0,A=L.rotrSH(C,x,1)^L.rotrSH(C,x,8)^L.shrSH(C,x,7),N=L.rotrSL(C,x,1)^L.rotrSL(C,x,8)^L.shrSL(C,x,7),R=ce[b-2]|0,q=le[b-2]|0,M=L.rotrSH(R,q,19)^L.rotrBH(R,q,61)^L.shrSH(R,q,6),V=L.rotrSL(R,q,19)^L.rotrBL(R,q,61)^L.shrSL(R,q,6),rt=L.add4L(N,V,le[b-7],le[b-16]),tt=L.add4H(rt,A,M,ce[b-7],ce[b-16]);ce[b]=tt|0,le[b]=rt|0}let{Ah:n,Al:s,Bh:o,Bl:i,Ch:a,Cl:c,Dh:u,Dl:l,Eh:f,El:d,Fh:w,Fl:g,Gh:h,Gl:p,Hh:m,Hl:B}=this;for(let b=0;b<80;b++){let C=L.rotrSH(f,d,14)^L.rotrSH(f,d,18)^L.rotrBH(f,d,41),x=L.rotrSL(f,d,14)^L.rotrSL(f,d,18)^L.rotrBL(f,d,41),A=f&w^~f&h,N=d&g^~d&p,R=L.add5L(B,x,N,Zl[b],le[b]),q=L.add5H(R,m,C,A,zl[b],ce[b]),M=R|0,V=L.rotrSH(n,s,28)^L.rotrBH(n,s,34)^L.rotrBH(n,s,39),rt=L.rotrSL(n,s,28)^L.rotrBL(n,s,34)^L.rotrBL(n,s,39),tt=n&o^n&a^o&a,Bt=s&i^s&c^i&c;m=h|0,B=p|0,h=w|0,p=g|0,w=f|0,g=d|0,{h:f,l:d}=L.add(u|0,l|0,q|0,M|0),u=a|0,l=c|0,a=o|0,c=i|0,o=n|0,i=s|0;let v=L.add3L(M,rt,Bt);n=L.add3H(v,q,V,tt),s=v|0}({h:n,l:s}=L.add(this.Ah|0,this.Al|0,n|0,s|0)),{h:o,l:i}=L.add(this.Bh|0,this.Bl|0,o|0,i|0),{h:a,l:c}=L.add(this.Ch|0,this.Cl|0,a|0,c|0),{h:u,l}=L.add(this.Dh|0,this.Dl|0,u|0,l|0),{h:f,l:d}=L.add(this.Eh|0,this.El|0,f|0,d|0),{h:w,l:g}=L.add(this.Fh|0,this.Fl|0,w|0,g|0),{h,l:p}=L.add(this.Gh|0,this.Gl|0,h|0,p|0),{h:m,l:B}=L.add(this.Hh|0,this.Hl|0,m|0,B|0),this.set(n,s,o,i,a,c,u,l,f,d,w,g,h,p,m,B)}roundClean(){ce.fill(0),le.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 ue=Ye(()=>new vs);var Fr={};et(Fr,{abytes:()=>Je,bitGet:()=>eu,bitLen:()=>tu,bitMask:()=>dr,bitSet:()=>ru,bytesToHex:()=>qt,bytesToNumberBE:()=>jt,bytesToNumberLE:()=>he,concatBytes:()=>Gt,createHmacDrbg:()=>ks,ensureBytes:()=>Q,equalBytes:()=>Xl,hexToBytes:()=>Ne,hexToNumber:()=>As,isBytes:()=>fe,numberToBytesBE:()=>de,numberToBytesLE:()=>Re,numberToHexUnpadded:()=>ni,numberToVarBytesBE:()=>Jl,utf8ToBytes:()=>Ql,validateObject:()=>Ht});var ri=BigInt(0),Mr=BigInt(1),Yl=BigInt(2);function fe(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function Je(r){if(!fe(r))throw new Error("Uint8Array expected")}var Wl=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function qt(r){Je(r);let t="";for(let e=0;e<r.length;e++)t+=Wl[r[e]];return t}function ni(r){let t=r.toString(16);return t.length&1?`0${t}`:t}function As(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return BigInt(r===""?"0":`0x${r}`)}var $t={_0:48,_9:57,_A:65,_F:70,_a:97,_f:102};function ti(r){if(r>=$t._0&&r<=$t._9)return r-$t._0;if(r>=$t._A&&r<=$t._F)return r-($t._A-10);if(r>=$t._a&&r<=$t._f)return r-($t._a-10)}function Ne(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);let t=r.length,e=t/2;if(t%2)throw new Error("padded hex string expected, got unpadded hex of length "+t);let n=new Uint8Array(e);for(let s=0,o=0;s<e;s++,o+=2){let i=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 jt(r){return As(qt(r))}function he(r){return Je(r),As(qt(Uint8Array.from(r).reverse()))}function de(r,t){return Ne(r.toString(16).padStart(t*2,"0"))}function Re(r,t){return de(r,t).reverse()}function Jl(r){return Ne(ni(r))}function Q(r,t,e){let n;if(typeof t=="string")try{n=Ne(t)}catch(o){throw new Error(`${r} must be valid hex string, got "${t}". Cause: ${o}`)}else if(fe(t))n=Uint8Array.from(t);else throw new Error(`${r} must be hex string or Uint8Array`);let s=n.length;if(typeof e=="number"&&s!==e)throw new Error(`${r} expected ${e} bytes, got ${s}`);return n}function Gt(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];Je(s),t+=s.length}let e=new Uint8Array(t);for(let n=0,s=0;n<r.length;n++){let o=r[n];e.set(o,s),s+=o.length}return e}function Xl(r,t){if(r.length!==t.length)return!1;let e=0;for(let n=0;n<r.length;n++)e|=r[n]^t[n];return e===0}function Ql(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function tu(r){let t;for(t=0;r>ri;r>>=Mr,t+=1);return t}function eu(r,t){return r>>BigInt(t)&Mr}function ru(r,t,e){return r|(e?Mr:ri)<<BigInt(t)}var dr=r=>(Yl<<BigInt(r-1))-Mr,Es=r=>new Uint8Array(r),ei=r=>Uint8Array.from(r);function ks(r,t,e){if(typeof r!="number"||r<2)throw new Error("hashLen must be a number");if(typeof t!="number"||t<2)throw new Error("qByteLen must be a number");if(typeof e!="function")throw new Error("hmacFn must be a function");let n=Es(r),s=Es(r),o=0,i=()=>{n.fill(1),s.fill(0),o=0},a=(...f)=>e(s,n,...f),c=(f=Es())=>{s=a(ei([0]),f),n=a(),f.length!==0&&(s=a(ei([1]),f),n=a())},u=()=>{if(o++>=1e3)throw new Error("drbg: tried 1000 values");let f=0,d=[];for(;f<t;){n=a();let w=n.slice();d.push(w),f+=n.length}return Gt(...d)};return(f,d)=>{i(),c(f);let w;for(;!(w=d(u()));)c();return i(),w}}var nu={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"||fe(r),isSafeInteger:r=>Number.isSafeInteger(r),array:r=>Array.isArray(r),field:(r,t)=>t.Fp.isValid(r),hash:r=>typeof r=="function"&&Number.isSafeInteger(r.outputLen)};function Ht(r,t,e={}){let n=(s,o,i)=>{let a=nu[o];if(typeof a!="function")throw new Error(`Invalid validator "${o}", expected function`);let c=r[s];if(!(i&&c===void 0)&&!a(c,r))throw new Error(`Invalid param ${String(s)}=${c} (${typeof c}), expected ${o}`)};for(let[s,o]of Object.entries(t))n(s,o,!1);for(let[s,o]of Object.entries(e))n(s,o,!0);return r}var at=BigInt(0),Y=BigInt(1),Ce=BigInt(2),su=BigInt(3),Ss=BigInt(4),si=BigInt(5),oi=BigInt(8),ou=BigInt(9),iu=BigInt(16);function j(r,t){let e=r%t;return e>=at?e:t+e}function au(r,t,e){if(e<=at||t<at)throw new Error("Expected power/modulo > 0");if(e===Y)return at;let n=Y;for(;t>at;)t&Y&&(n=n*r%e),r=r*r%e,t>>=Y;return n}function W(r,t,e){let n=r;for(;t-- >at;)n*=n,n%=e;return n}function $r(r,t){if(r===at||t<=at)throw new Error(`invert: expected positive integers, got n=${r} mod=${t}`);let e=j(r,t),n=t,s=at,o=Y,i=Y,a=at;for(;e!==at;){let u=n/e,l=n%e,f=s-i*u,d=o-a*u;n=e,e=l,s=i,o=a,i=f,a=d}if(n!==Y)throw new Error("invert: does not exist");return j(s,t)}function cu(r){let t=(r-Y)/Ce,e,n,s;for(e=r-Y,n=0;e%Ce===at;e/=Ce,n++);for(s=Ce;s<r&&au(s,t,r)!==r-Y;s++);if(n===1){let i=(r+Y)/Ss;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=(e+Y)/Ce;return function(a,c){if(a.pow(c,t)===a.neg(a.ONE))throw new Error("Cannot find square root");let u=n,l=a.pow(a.mul(a.ONE,s),e),f=a.pow(c,o),d=a.pow(c,e);for(;!a.eql(d,a.ONE);){if(a.eql(d,a.ZERO))return a.ZERO;let w=1;for(let h=a.sqr(d);w<u&&!a.eql(h,a.ONE);w++)h=a.sqr(h);let g=a.pow(l,Y<<BigInt(u-w-1));l=a.sqr(g),f=a.mul(f,g),d=a.mul(d,l),u=w}return f}}function lu(r){if(r%Ss===su){let t=(r+Y)/Ss;return function(n,s){let o=n.pow(s,t);if(!n.eql(n.sqr(o),s))throw new Error("Cannot find square root");return o}}if(r%oi===si){let t=(r-si)/oi;return function(n,s){let o=n.mul(s,Ce),i=n.pow(o,t),a=n.mul(s,i),c=n.mul(n.mul(a,Ce),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%iu,cu(r)}var ii=(r,t)=>(j(r,t)&Y)===Y,uu=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function Is(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=uu.reduce((n,s)=>(n[s]="function",n),t);return Ht(r,e)}function fu(r,t,e){if(e<at)throw new Error("Expected power > 0");if(e===at)return r.ONE;if(e===Y)return t;let n=r.ONE,s=t;for(;e>at;)e&Y&&(n=r.mul(n,s)),s=r.sqr(s),e>>=Y;return n}function hu(r,t){let e=new Array(t.length),n=t.reduce((o,i,a)=>r.is0(i)?o:(e[a]=o,r.mul(o,i)),r.ONE),s=r.inv(n);return t.reduceRight((o,i,a)=>r.is0(i)?o:(e[a]=r.mul(o,e[a]),r.mul(o,i)),s),e}function Ns(r,t){let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function qr(r,t,e=!1,n={}){if(r<=at)throw new Error(`Expected Field ORDER > 0, got ${r}`);let{nBitLength:s,nByteLength:o}=Ns(r,t);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:dr(s),ZERO:at,ONE:Y,create:c=>j(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error(`Invalid field element: expected bigint, got ${typeof c}`);return at<=c&&c<r},is0:c=>c===at,isOdd:c=>(c&Y)===Y,neg:c=>j(-c,r),eql:(c,u)=>c===u,sqr:c=>j(c*c,r),add:(c,u)=>j(c+u,r),sub:(c,u)=>j(c-u,r),mul:(c,u)=>j(c*u,r),pow:(c,u)=>fu(a,c,u),div:(c,u)=>j(c*$r(u,r),r),sqrN:c=>c*c,addN:(c,u)=>c+u,subN:(c,u)=>c-u,mulN:(c,u)=>c*u,inv:c=>$r(c,r),sqrt:n.sqrt||(c=>i(a,c)),invertBatch:c=>hu(a,c),cmov:(c,u,l)=>l?u:c,toBytes:c=>e?Re(c,o):de(c,o),fromBytes:c=>{if(c.length!==o)throw new Error(`Fp.fromBytes: expected ${o}, got ${c.length}`);return e?he(c):jt(c)}});return Object.freeze(a)}function ai(r,t){if(!r.isOdd)throw new Error("Field doesn't have isOdd");let e=r.sqrt(t);return r.isOdd(e)?r.neg(e):e}function ci(r){if(typeof r!="bigint")throw new Error("field order must be bigint");let t=r.toString(2).length;return Math.ceil(t/8)}function Rs(r){let t=ci(r);return t+Math.ceil(t/2)}function li(r,t,e=!1){let n=r.length,s=ci(t),o=Rs(t);if(n<16||n<o||n>1024)throw new Error(`expected ${o}-1024 bytes of input, got ${n}`);let i=e?jt(r):he(r),a=j(i,t-Y)+Y;return e?Re(a,s):de(a,s)}var gu=BigInt(0),Cs=BigInt(1);function jr(r,t){let e=(s,o)=>{let i=o.negate();return s?i:o},n=s=>{let o=Math.ceil(t/s)+1,i=2**(s-1);return{windows:o,windowSize:i}};return{constTimeNegate:e,unsafeLadder(s,o){let i=r.ZERO,a=s;for(;o>gu;)o&Cs&&(i=i.add(a)),a=a.double(),o>>=Cs;return i},precomputeWindow(s,o){let{windows:i,windowSize:a}=n(o),c=[],u=s,l=u;for(let f=0;f<i;f++){l=u,c.push(l);for(let d=1;d<a;d++)l=l.add(u),c.push(l);u=l.double()}return c},wNAF(s,o,i){let{windows:a,windowSize:c}=n(s),u=r.ZERO,l=r.BASE,f=BigInt(2**s-1),d=2**s,w=BigInt(s);for(let g=0;g<a;g++){let h=g*c,p=Number(i&f);i>>=w,p>c&&(p-=d,i+=Cs);let m=h,B=h+Math.abs(p)-1,b=g%2!==0,C=p<0;p===0?l=l.add(e(b,o[m])):u=u.add(e(C,o[B]))}return{p:u,f:l}},wNAFCached(s,o,i,a){let c=s._WINDOW_SIZE||1,u=o.get(s);return u||(u=this.precomputeWindow(s,c),c!==1&&o.set(s,a(u))),this.wNAF(c,u,i)}}}function gr(r){return Is(r.Fp),Ht(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...Ns(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Nt=BigInt(0),wt=BigInt(1),Gr=BigInt(2),pu=BigInt(8),yu={zip215:!0};function mu(r){let t=gr(r);return Ht(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function zr(r){let t=mu(r),{Fp:e,n,prehash:s,hash:o,randomBytes:i,nByteLength:a,h:c}=t,u=Gr<<BigInt(a*8)-wt,l=e.create,f=t.uvRatio||((E,y)=>{try{return{isValid:!0,value:e.sqrt(E*e.inv(y))}}catch{return{isValid:!1,value:Nt}}}),d=t.adjustScalarBytes||(E=>E),w=t.domain||((E,y,S)=>{if(y.length||S)throw new Error("Contexts/pre-hash are not supported");return E}),g=E=>typeof E=="bigint"&&Nt<E,h=(E,y)=>g(E)&&g(y)&&E<y,p=E=>E===Nt||h(E,u);function m(E,y){if(h(E,y))return E;throw new Error(`Expected valid scalar < ${y}, got ${typeof E} ${E}`)}function B(E){return E===Nt?E:m(E,n)}let b=new Map;function C(E){if(!(E instanceof x))throw new Error("ExtendedPoint expected")}class x{constructor(y,S,T,U){if(this.ex=y,this.ey=S,this.ez=T,this.et=U,!p(y))throw new Error("x required");if(!p(S))throw new Error("y required");if(!p(T))throw new Error("z required");if(!p(U))throw new Error("t required")}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(y){if(y instanceof x)throw new Error("extended point not allowed");let{x:S,y:T}=y||{};if(!p(S)||!p(T))throw new Error("invalid affine point");return new x(S,T,wt,l(S*T))}static normalizeZ(y){let S=e.invertBatch(y.map(T=>T.ez));return y.map((T,U)=>T.toAffine(S[U])).map(x.fromAffine)}_setWindowSize(y){this._WINDOW_SIZE=y,b.delete(this)}assertValidity(){let{a:y,d:S}=t;if(this.is0())throw new Error("bad point: ZERO");let{ex:T,ey:U,ez:D,et:O}=this,$=l(T*T),K=l(U*U),F=l(D*D),nt=l(F*F),J=l($*y),lt=l(F*l(J+K)),ut=l(nt+l(S*l($*K)));if(lt!==ut)throw new Error("bad point: equation left != right (1)");let it=l(T*U),ht=l(D*O);if(it!==ht)throw new Error("bad point: equation left != right (2)")}equals(y){C(y);let{ex:S,ey:T,ez:U}=this,{ex:D,ey:O,ez:$}=y,K=l(S*$),F=l(D*U),nt=l(T*$),J=l(O*U);return K===F&&nt===J}is0(){return this.equals(x.ZERO)}negate(){return new x(l(-this.ex),this.ey,this.ez,l(-this.et))}double(){let{a:y}=t,{ex:S,ey:T,ez:U}=this,D=l(S*S),O=l(T*T),$=l(Gr*l(U*U)),K=l(y*D),F=S+T,nt=l(l(F*F)-D-O),J=K+O,lt=J-$,ut=K-O,it=l(nt*lt),ht=l(J*ut),Kt=l(nt*ut),Ae=l(lt*J);return new x(it,ht,Ae,Kt)}add(y){C(y);let{a:S,d:T}=t,{ex:U,ey:D,ez:O,et:$}=this,{ex:K,ey:F,ez:nt,et:J}=y;if(S===BigInt(-1)){let xo=l((D-U)*(F+K)),Bo=l((D+U)*(F-K)),Zn=l(Bo-xo);if(Zn===Nt)return this.double();let vo=l(O*Gr*J),Eo=l($*Gr*nt),Ao=Eo+vo,ko=Bo+xo,So=Eo-vo,rc=l(Ao*Zn),nc=l(ko*So),sc=l(Ao*So),oc=l(Zn*ko);return new x(rc,nc,oc,sc)}let lt=l(U*K),ut=l(D*F),it=l($*T*J),ht=l(O*nt),Kt=l((U+D)*(K+F)-lt-ut),Ae=ht-it,cr=ht+it,wo=l(ut-S*lt),Xa=l(Kt*Ae),Qa=l(cr*wo),tc=l(Kt*wo),ec=l(Ae*cr);return new x(Xa,Qa,ec,tc)}subtract(y){return this.add(y.negate())}wNAF(y){return R.wNAFCached(this,b,y,x.normalizeZ)}multiply(y){let{p:S,f:T}=this.wNAF(m(y,n));return x.normalizeZ([S,T])[0]}multiplyUnsafe(y){let S=B(y);return S===Nt?N:this.equals(N)||S===wt?this:this.equals(A)?this.wNAF(S).p:R.unsafeLadder(this,S)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return R.unsafeLadder(this,n).is0()}toAffine(y){let{ex:S,ey:T,ez:U}=this,D=this.is0();y==null&&(y=D?pu:e.inv(U));let O=l(S*y),$=l(T*y),K=l(U*y);if(D)return{x:Nt,y:wt};if(K!==wt)throw new Error("invZ was invalid");return{x:O,y:$}}clearCofactor(){let{h:y}=t;return y===wt?this:this.multiplyUnsafe(y)}static fromHex(y,S=!1){let{d:T,a:U}=t,D=e.BYTES;y=Q("pointHex",y,D);let O=y.slice(),$=y[D-1];O[D-1]=$&-129;let K=he(O);K===Nt||(S?m(K,u):m(K,e.ORDER));let F=l(K*K),nt=l(F-wt),J=l(T*F-U),{isValid:lt,value:ut}=f(nt,J);if(!lt)throw new Error("Point.fromHex: invalid y coordinate");let it=(ut&wt)===wt,ht=($&128)!==0;if(!S&&ut===Nt&&ht)throw new Error("Point.fromHex: x=0 and x_0=1");return ht!==it&&(ut=l(-ut)),x.fromAffine({x:ut,y:K})}static fromPrivateKey(y){return V(y).point}toRawBytes(){let{x:y,y:S}=this.toAffine(),T=Re(S,e.BYTES);return T[T.length-1]|=y&wt?128:0,T}toHex(){return qt(this.toRawBytes())}}x.BASE=new x(t.Gx,t.Gy,wt,l(t.Gx*t.Gy)),x.ZERO=new x(Nt,wt,wt,Nt);let{BASE:A,ZERO:N}=x,R=jr(x,a*8);function q(E){return j(E,n)}function M(E){return q(he(E))}function V(E){let y=a;E=Q("private key",E,y);let S=Q("hashed private key",o(E),2*y),T=d(S.slice(0,y)),U=S.slice(y,2*y),D=M(T),O=A.multiply(D),$=O.toRawBytes();return{head:T,prefix:U,scalar:D,point:O,pointBytes:$}}function rt(E){return V(E).pointBytes}function tt(E=new Uint8Array,...y){let S=Gt(...y);return M(o(w(S,Q("context",E),!!s)))}function Bt(E,y,S={}){E=Q("message",E),s&&(E=s(E));let{prefix:T,scalar:U,pointBytes:D}=V(y),O=tt(S.context,T,E),$=A.multiply(O).toRawBytes(),K=tt(S.context,$,D,E),F=q(O+K*U);B(F);let nt=Gt($,Re(F,e.BYTES));return Q("result",nt,a*2)}let v=yu;function I(E,y,S,T=v){let{context:U,zip215:D}=T,O=e.BYTES;E=Q("signature",E,2*O),y=Q("message",y),s&&(y=s(y));let $=he(E.slice(O,2*O)),K,F,nt;try{K=x.fromHex(S,D),F=x.fromHex(E.slice(0,O),D),nt=A.multiplyUnsafe($)}catch{return!1}if(!D&&K.isSmallOrder())return!1;let J=tt(U,F.toRawBytes(),K.toRawBytes(),y);return F.add(K.multiplyUnsafe(J)).subtract(nt).clearCofactor().equals(x.ZERO)}return A._setWindowSize(8),{CURVE:t,getPublicKey:rt,sign:Bt,verify:I,ExtendedPoint:x,utils:{getExtendedPublicKey:V,randomPrivateKey:()=>i(e.BYTES),precompute(E=8,y=x.BASE){return y._setWindowSize(E),y.multiply(BigInt(3)),y}}}}var _s=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),ui=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),pd=BigInt(0),bu=BigInt(1),Ts=BigInt(2),wu=BigInt(5),fi=BigInt(10),xu=BigInt(20),Bu=BigInt(40),hi=BigInt(80);function vu(r){let t=_s,n=r*r%t*r%t,s=W(n,Ts,t)*n%t,o=W(s,bu,t)*r%t,i=W(o,wu,t)*o%t,a=W(i,fi,t)*i%t,c=W(a,xu,t)*a%t,u=W(c,Bu,t)*c%t,l=W(u,hi,t)*u%t,f=W(l,hi,t)*u%t,d=W(f,fi,t)*i%t;return{pow_p_5_8:W(d,Ts,t)*r%t,b2:n}}function Eu(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function Au(r,t){let e=_s,n=j(t*t*t,e),s=j(n*n*t,e),o=vu(r*s).pow_p_5_8,i=j(r*n*o,e),a=j(t*i*i,e),c=i,u=j(i*ui,e),l=a===r,f=a===j(-r,e),d=a===j(-r*ui,e);return l&&(i=c),(f||d)&&(i=u),ii(i,e)&&(i=j(-i,e)),{isValid:l||f,value:i}}var zt=qr(_s,void 0,!0),Us={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:zt,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:BigInt(8),Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:ue,randomBytes:We,adjustScalarBytes:Eu,uvRatio:Au},Xe=zr(Us);function di(r,t,e){if(t.length>255)throw new Error("Context is too big");return Dr(xs("SigEd25519 no Ed25519 collisions"),new Uint8Array([e?1:0,t.length]),t,r)}var yd=zr({...Us,domain:di}),md=zr({...Us,domain:di,prehash:ue});var ku=(zt.ORDER+BigInt(3))/BigInt(8),bd=zt.pow(Ts,ku),wd=zt.sqrt(zt.neg(zt.ONE)),xd=(zt.ORDER-BigInt(5))/BigInt(8),Bd=BigInt(486662);var vd=ai(zt,zt.neg(BigInt(486664)));var Ed=BigInt("25063068953384623474111414158702152701244531502492656460079210482610430750235"),Ad=BigInt("54469307008909316920995813868745141605393597292927456921205312896311721017578"),kd=BigInt("1159843021668779879193775521855586647937357759715417654439879720876111806838"),Sd=BigInt("40440834346308536858101042469323190826248399146238708352240133220865137265952");var Id=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff");var Qe=32,Zt=64,Zr=32;function gi(){let r=Xe.utils.randomPrivateKey(),t=Xe.getPublicKey(r);return{privateKey:bi(r,t),publicKey:t}}function pi(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 t=r,e=Xe.getPublicKey(t);return{privateKey:bi(t,e),publicKey:e}}function yi(r,t){let e=r.subarray(0,Zr);return Xe.sign(t instanceof Uint8Array?t:t.subarray(),e)}function mi(r,t,e){return Xe.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}function bi(r,t){let e=new Uint8Array(Zt);for(let n=0;n<Zr;n++)e[n]=r[n],e[Zr+n]=t[n];return e}var Ls={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function Yr(r){let t=r?.algorithm??"AES-GCM",e=r?.keyLength??16,n=r?.nonceLength??12,s=r?.digest??"SHA-256",o=r?.saltLength??16,i=r?.iterations??32767,a=z.get();e*=8;async function c(f,d){let w=a.getRandomValues(new Uint8Array(o)),g=a.getRandomValues(new Uint8Array(n)),h={name:t,iv:g};typeof d=="string"&&(d=Z(d));let p;if(d.length===0){p=await a.subtle.importKey("jwk",Ls,{name:"AES-GCM"},!0,["encrypt"]);try{let B={name:"PBKDF2",salt:w,iterations:i,hash:{name:s}},b=await a.subtle.importKey("raw",d,{name:"PBKDF2"},!1,["deriveKey"]);p=await a.subtle.deriveKey(B,b,{name:t,length:e},!0,["encrypt"])}catch{p=await a.subtle.importKey("jwk",Ls,{name:"AES-GCM"},!0,["encrypt"])}}else{let B={name:"PBKDF2",salt:w,iterations:i,hash:{name:s}},b=await a.subtle.importKey("raw",d,{name:"PBKDF2"},!1,["deriveKey"]);p=await a.subtle.deriveKey(B,b,{name:t,length:e},!0,["encrypt"])}let m=await a.subtle.encrypt(h,p,f);return Ft([w,h.iv,new Uint8Array(m)])}async function u(f,d){let w=f.subarray(0,o),g=f.subarray(o,o+n),h=f.subarray(o+n),p={name:t,iv:g};typeof d=="string"&&(d=Z(d));let m;if(d.length===0)try{let b={name:"PBKDF2",salt:w,iterations:i,hash:{name:s}},C=await a.subtle.importKey("raw",d,{name:"PBKDF2"},!1,["deriveKey"]);m=await a.subtle.deriveKey(b,C,{name:t,length:e},!0,["decrypt"])}catch{m=await a.subtle.importKey("jwk",Ls,{name:"AES-GCM"},!0,["decrypt"])}else{let b={name:"PBKDF2",salt:w,iterations:i,hash:{name:s}},C=await a.subtle.importKey("raw",d,{name:"PBKDF2"},!1,["deriveKey"]);m=await a.subtle.deriveKey(b,C,{name:t,length:e},!0,["decrypt"])}let B=await a.subtle.decrypt(p,m,h);return new Uint8Array(B)}return{encrypt:c,decrypt:u}}async function tr(r,t){let n=await Yr().encrypt(r,t);return Se.encode(n)}var rr={};et(rr,{KeyType:()=>G,PrivateKey:()=>Tt,PublicKey:()=>Ct});var Iu=Math.pow(2,7),Nu=Math.pow(2,14),Ru=Math.pow(2,21),xi=Math.pow(2,28),Bi=Math.pow(2,35),vi=Math.pow(2,42),Ei=Math.pow(2,49),pt=128,ge=127;function pr(r){if(r<Iu)return 1;if(r<Nu)return 2;if(r<Ru)return 3;if(r<xi)return 4;if(r<Bi)return 5;if(r<vi)return 6;if(r<Ei)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function Ai(r,t,e=0){switch(pr(r)){case 8:t[e++]=r&255|pt,r/=128;case 7:t[e++]=r&255|pt,r/=128;case 6:t[e++]=r&255|pt,r/=128;case 5:t[e++]=r&255|pt,r/=128;case 4:t[e++]=r&255|pt,r>>>=7;case 3:t[e++]=r&255|pt,r>>>=7;case 2:t[e++]=r&255|pt,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function ki(r,t){let e=r[t],n=0;if(n+=e&ge,e<pt||(e=r[t+1],n+=(e&ge)<<7,e<pt)||(e=r[t+2],n+=(e&ge)<<14,e<pt)||(e=r[t+3],n+=(e&ge)<<21,e<pt)||(e=r[t+4],n+=(e&ge)*xi,e<pt)||(e=r[t+5],n+=(e&ge)*Bi,e<pt)||(e=r[t+6],n+=(e&ge)*vi,e<pt)||(e=r[t+7],n+=(e&ge)*Ei,e<pt))return n;throw new RangeError("Could not decode varint")}var Vs=new Float32Array([-0]),pe=new Uint8Array(Vs.buffer);function Si(r,t,e){Vs[0]=r,t[e]=pe[0],t[e+1]=pe[1],t[e+2]=pe[2],t[e+3]=pe[3]}function Ii(r,t){return pe[0]=r[t],pe[1]=r[t+1],pe[2]=r[t+2],pe[3]=r[t+3],Vs[0]}var Hs=new Float64Array([-0]),dt=new Uint8Array(Hs.buffer);function Ni(r,t,e){Hs[0]=r,t[e]=dt[0],t[e+1]=dt[1],t[e+2]=dt[2],t[e+3]=dt[3],t[e+4]=dt[4],t[e+5]=dt[5],t[e+6]=dt[6],t[e+7]=dt[7]}function Ri(r,t){return dt[0]=r[t],dt[1]=r[t+1],dt[2]=r[t+2],dt[3]=r[t+3],dt[4]=r[t+4],dt[5]=r[t+5],dt[6]=r[t+6],dt[7]=r[t+7],Hs[0]}var Cu=BigInt(Number.MAX_SAFE_INTEGER),Tu=BigInt(Number.MIN_SAFE_INTEGER),xt=class r{lo;hi;constructor(t,e){this.lo=t|0,this.hi=e|0}toNumber(t=!1){if(!t&&this.hi>>>31>0){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(e+n*4294967296)}return this.lo+this.hi*4294967296}toBigInt(t=!1){if(t)return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n);if(this.hi>>>31){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(BigInt(e)+(BigInt(n)<<32n))}return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n)}toString(t=!1){return this.toBigInt(t).toString()}zzEncode(){let t=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^t)>>>0,this.lo=(this.lo<<1^t)>>>0,this}zzDecode(){let t=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^t)>>>0,this.hi=(this.hi>>>1^t)>>>0,this}length(){let t=this.lo,e=(this.lo>>>28|this.hi<<4)>>>0,n=this.hi>>>24;return n===0?e===0?t<16384?t<128?1:2:t<2097152?3:4:e<16384?e<128?5:6:e<2097152?7:8:n<128?9:10}static fromBigInt(t){if(t===0n)return Te;if(t<Cu&&t>Tu)return this.fromNumber(Number(t));let e=t<0n;e&&(t=-t);let n=t>>32n,s=t-(n<<32n);return e&&(n=~n|0n,s=~s|0n,++s>Ci&&(s=0n,++n>Ci&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(t){if(t===0)return Te;let e=t<0;e&&(t=-t);let n=t>>>0,s=(t-n)/4294967296>>>0;return e&&(s=~s>>>0,n=~n>>>0,++n>4294967295&&(n=0,++s>4294967295&&(s=0))),new r(n,s)}static from(t){return typeof t=="number"?r.fromNumber(t):typeof t=="bigint"?r.fromBigInt(t):typeof t=="string"?r.fromBigInt(BigInt(t)):t.low!=null||t.high!=null?new r(t.low>>>0,t.high>>>0):Te}},Te=new xt(0,0);Te.toBigInt=function(){return 0n};Te.zzEncode=Te.zzDecode=function(){return this};Te.length=function(){return 1};var Ci=4294967296n;function Ti(r){let t=0,e=0;for(let n=0;n<r.length;++n)e=r.charCodeAt(n),e<128?t+=1:e<2048?t+=2:(e&64512)===55296&&(r.charCodeAt(n+1)&64512)===56320?(++n,t+=4):t+=3;return t}function _i(r,t,e){if(e-t<1)return"";let s,o=[],i=0,a;for(;t<e;)a=r[t++],a<128?o[i++]=a:a>191&&a<224?o[i++]=(a&31)<<6|r[t++]&63:a>239&&a<365?(a=((a&7)<<18|(r[t++]&63)<<12|(r[t++]&63)<<6|r[t++]&63)-65536,o[i++]=55296+(a>>10),o[i++]=56320+(a&1023)):o[i++]=(a&15)<<12|(r[t++]&63)<<6|r[t++]&63,i>8191&&((s??(s=[])).push(String.fromCharCode.apply(String,o)),i=0);return s!=null?(i>0&&s.push(String.fromCharCode.apply(String,o.slice(0,i))),s.join("")):String.fromCharCode.apply(String,o.slice(0,i))}function Ds(r,t,e){let n=e,s,o;for(let i=0;i<r.length;++i)s=r.charCodeAt(i),s<128?t[e++]=s:s<2048?(t[e++]=s>>6|192,t[e++]=s&63|128):(s&64512)===55296&&((o=r.charCodeAt(i+1))&64512)===56320?(s=65536+((s&1023)<<10)+(o&1023),++i,t[e++]=s>>18|240,t[e++]=s>>12&63|128,t[e++]=s>>6&63|128,t[e++]=s&63|128):(t[e++]=s>>12|224,t[e++]=s>>6&63|128,t[e++]=s&63|128);return e-n}function Rt(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function Wr(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var Os=class{buf;pos;len;_slice=Uint8Array.prototype.subarray;constructor(t){this.buf=t,this.pos=0,this.len=t.length}uint32(){let t=4294967295;if(t=(this.buf[this.pos]&127)>>>0,this.buf[this.pos++]<128||(t=(t|(this.buf[this.pos]&127)<<7)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<14)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<21)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&15)<<28)>>>0,this.buf[this.pos++]<128))return t;if((this.pos+=5)>this.len)throw this.pos=this.len,Rt(this,10);return t}int32(){return this.uint32()|0}sint32(){let t=this.uint32();return t>>>1^-(t&1)|0}bool(){return this.uint32()!==0}fixed32(){if(this.pos+4>this.len)throw Rt(this,4);return Wr(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Rt(this,4);return Wr(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Rt(this,4);let t=Ii(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Rt(this,4);let t=Ri(this.buf,this.pos);return this.pos+=8,t}bytes(){let t=this.uint32(),e=this.pos,n=this.pos+t;if(n>this.len)throw Rt(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return _i(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw Rt(this,t);this.pos+=t}else do if(this.pos>=this.len)throw Rt(this);while(this.buf[this.pos++]&128);return this}skipType(t){switch(t){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;(t=this.uint32()&7)!==4;)this.skipType(t);break;case 5:this.skip(4);break;default:throw Error(`invalid wire type ${t} at offset ${this.pos}`)}return this}readLongVarint(){let t=new xt(0,0),e=0;if(this.len-this.pos>4){for(;e<4;++e)if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t;if(t.lo=(t.lo|(this.buf[this.pos]&127)<<28)>>>0,t.hi=(t.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return t;e=0}else{for(;e<3;++e){if(this.pos>=this.len)throw Rt(this);if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t}return t.lo=(t.lo|(this.buf[this.pos++]&127)<<e*7)>>>0,t}if(this.len-this.pos>4){for(;e<5;++e)if(t.hi=(t.hi|(this.buf[this.pos]&127)<<e*7+3)>>>0,this.buf[this.pos++]<128)return t}else for(;e<5;++e){if(this.pos>=this.len)throw Rt(this);if(t.hi=(t.hi|(this.buf[this.pos]&127)<<e*7+3)>>>0,this.buf[this.pos++]<128)return t}throw Error("invalid varint encoding")}readFixed64(){if(this.pos+8>this.len)throw Rt(this,8);let t=Wr(this.buf,this.pos+=4),e=Wr(this.buf,this.pos+=4);return new xt(t,e)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){let t=ki(this.buf,this.pos);return this.pos+=pr(t),t}uint64String(){return this.readLongVarint().toString(!0)}sint64(){return this.readLongVarint().zzDecode().toBigInt()}sint64Number(){return this.readLongVarint().zzDecode().toNumber()}sint64String(){return this.readLongVarint().zzDecode().toString()}fixed64(){return this.readFixed64().toBigInt()}fixed64Number(){return this.readFixed64().toNumber()}fixed64String(){return this.readFixed64().toString()}sfixed64(){return this.readFixed64().toBigInt()}sfixed64Number(){return this.readFixed64().toNumber()}sfixed64String(){return this.readFixed64().toString()}};function Ps(r){return new Os(r instanceof Uint8Array?r:r.subarray())}function Jr(r,t,e){let n=Ps(r);return t.decode(n,void 0,e)}function Ks(r){let t=r??8192,e=t>>>1,n,s=t;return function(i){if(i<1||i>e)return Vt(i);s+i>t&&(n=Vt(t),s=0);let a=n.subarray(s,s+=i);return s&7&&(s=(s|7)+1),a}}var _e=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function Ms(){}var $s=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},_u=Ks();function Uu(r){return globalThis.Buffer!=null?Vt(r):_u(r)}var mr=class{len;head;tail;states;constructor(){this.len=0,this.head=new _e(Ms,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new _e(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new qs((t=t>>>0)<128?1:t<16384?2:t<2097152?3:t<268435456?4:5,t)).len,this}int32(t){return t<0?this._push(Xr,10,xt.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=xt.fromBigInt(t);return this._push(Xr,e.length(),e)}uint64Number(t){return this._push(Ai,pr(t),t)}uint64String(t){return this.uint64(BigInt(t))}int64(t){return this.uint64(t)}int64Number(t){return this.uint64Number(t)}int64String(t){return this.uint64String(t)}sint64(t){let e=xt.fromBigInt(t).zzEncode();return this._push(Xr,e.length(),e)}sint64Number(t){let e=xt.fromNumber(t).zzEncode();return this._push(Xr,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(Fs,1,t?1:0)}fixed32(t){return this._push(yr,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=xt.fromBigInt(t);return this._push(yr,4,e.lo)._push(yr,4,e.hi)}fixed64Number(t){let e=xt.fromNumber(t);return this._push(yr,4,e.lo)._push(yr,4,e.hi)}fixed64String(t){return this.fixed64(BigInt(t))}sfixed64(t){return this.fixed64(t)}sfixed64Number(t){return this.fixed64Number(t)}sfixed64String(t){return this.fixed64String(t)}float(t){return this._push(Si,4,t)}double(t){return this._push(Ni,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(Fs,1,0):this.uint32(e)._push(Vu,e,t)}string(t){let e=Ti(t);return e!==0?this.uint32(e)._push(Ds,e,t):this._push(Fs,1,0)}fork(){return this.states=new $s(this),this.head=this.tail=new _e(Ms,0,0),this.len=0,this}reset(){return this.states!=null?(this.head=this.states.head,this.tail=this.states.tail,this.len=this.states.len,this.states=this.states.next):(this.head=this.tail=new _e(Ms,0,0),this.len=0),this}ldelim(){let t=this.head,e=this.tail,n=this.len;return this.reset().uint32(n),n!==0&&(this.tail.next=t.next,this.tail=e,this.len+=n),this}finish(){let t=this.head.next,e=Uu(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function Fs(r,t,e){t[e]=r&255}function Lu(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var qs=class extends _e{next;constructor(t,e){super(Lu,t,e),this.next=void 0}};function Xr(r,t,e){for(;r.hi!==0;)t[e++]=r.lo&127|128,r.lo=(r.lo>>>7|r.hi<<25)>>>0,r.hi>>>=7;for(;r.lo>127;)t[e++]=r.lo&127|128,r.lo=r.lo>>>7;t[e++]=r.lo}function yr(r,t,e){t[e]=r&255,t[e+1]=r>>>8&255,t[e+2]=r>>>16&255,t[e+3]=r>>>24}function Vu(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(mr.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(Hu,t,r),this},mr.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(Du,t,r),this});function Hu(r,t,e){t.set(r,e)}function Du(r,t,e){r.length<40?Ds(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(Z(r),e)}function js(){return new mr}function Qr(r,t){let e=js();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var er;(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"})(er||(er={}));function tn(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function Gs(r){function t(s){if(r[s.toString()]==null)throw new Error("Invalid enum value");return r[s]}let e=function(o,i){let a=t(o);i.int32(a)},n=function(o){let i=o.int32();return t(i)};return tn("enum",er.VARINT,e,n)}function en(r,t){return tn("message",er.LENGTH_DELIMITED,r,t)}var G;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.Secp256k1="Secp256k1"})(G||(G={}));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)})(G||(G={}));var Ct;(function(r){let t;r.codec=()=>(t==null&&(t=en((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),G.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let s={},o=n==null?e.len:e.pos+n;for(;e.pos<o;){let i=e.uint32();switch(i>>>3){case 1:s.Type=G.codec().decode(e);break;case 2:s.Data=e.bytes();break;default:e.skipType(i&7);break}}return s})),t),r.encode=e=>Qr(e,r.codec()),r.decode=e=>Jr(e,r.codec())})(Ct||(Ct={}));var Tt;(function(r){let t;r.codec=()=>(t==null&&(t=en((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),G.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let s={},o=n==null?e.len:e.pos+n;for(;e.pos<o;){let i=e.uint32();switch(i>>>3){case 1:s.Type=G.codec().decode(e);break;case 2:s.Data=e.bytes();break;default:e.skipType(i&7);break}}return s})),t),r.encode=e=>Qr(e,r.codec()),r.decode=e=>Jr(e,r.codec())})(Tt||(Tt={}));var Ue=class{_key;constructor(t){this._key=nr(t,Qe)}verify(t,e){return mi(this._key,e,t)}marshal(){return this._key}get bytes(){return Ct.encode({Type:G.Ed25519,Data:this.marshal()}).subarray()}equals(t){return St(this.bytes,t.bytes)}hash(){let t=bt.digest(this.bytes);return Et(t)?t.then(({bytes:e})=>e):t.bytes}},Yt=class{_key;_publicKey;constructor(t,e){this._key=nr(t,Zt),this._publicKey=nr(e,Qe)}sign(t){return yi(this._key,t)}get public(){return new Ue(this._publicKey)}marshal(){return this._key}get bytes(){return Tt.encode({Type:G.Ed25519,Data:this.marshal()}).subarray()}equals(t){return St(this.bytes,t.bytes)}async hash(){let t=bt.digest(this.bytes),e;return Et(t)?{bytes:e}=await t:e=t.bytes,e}async id(){let t=rs.digest(this.public.bytes);return vt.encode(t.bytes).substring(1)}async export(t,e="libp2p-key"){if(e==="libp2p-key")return tr(this.bytes,t);throw new _(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function Ou(r){if(r.length>Zt){r=nr(r,Zt+Qe);let n=r.subarray(0,Zt),s=r.subarray(Zt,r.length);return new Yt(n,s)}r=nr(r,Zt);let t=r.subarray(0,Zt),e=r.subarray(Qe);return new Yt(t,e)}function Pu(r){return r=nr(r,Qe),new Ue(r)}async function Ku(){let{privateKey:r,publicKey:t}=gi();return new Yt(r,t)}async function Zs(r){let{privateKey:t,publicKey:e}=pi(r);return new Yt(t,e)}function nr(r,t){if(r=Uint8Array.from(r??[]),r.length!==t)throw new _(`Key must be a Uint8Array of length ${t}, got ${r.length}`,"ERR_INVALID_KEY_TYPE");return r}function st(r,t="utf8"){let e=Ur[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}var Li={"P-256":256,"P-384":384,"P-521":521},Mu=Object.keys(Li),Ws=Mu.join(" / ");async function Vi(r){if(r!=="P-256"&&r!=="P-384"&&r!=="P-521")throw new _(`Unknown curve: ${r}. Must be ${Ws}`,"ERR_INVALID_CURVE");let t=await z.get().subtle.generateKey({name:"ECDH",namedCurve:r},!0,["deriveBits"]),e=async(o,i)=>{let a;i!=null?a=await z.get().subtle.importKey("jwk",$u(r,i),{name:"ECDH",namedCurve:r},!1,["deriveBits"]):a=t.privateKey;let c=await z.get().subtle.importKey("jwk",Di(r,o),{name:"ECDH",namedCurve:r},!1,[]),u=await z.get().subtle.deriveBits({name:"ECDH",namedCurve:r,public:c},a,Li[r]);return new Uint8Array(u,0,u.byteLength)},n=await z.get().subtle.exportKey("jwk",t.publicKey);return{key:Fu(n),genSharedKey:e}}var Hi={"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 ${Ws}`,"ERR_INVALID_CURVE");let t=Hi[r.crv];return Ft([Uint8Array.from([4]),ws(r.x,t),ws(r.y,t)],1+t*2)}function Di(r,t){if(r!=="P-256"&&r!=="P-384"&&r!=="P-521")throw new _(`Unknown curve: ${r}. Must be ${Ws}`,"ERR_INVALID_CURVE");let e=Hi[r];if(!St(t.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:st(t.subarray(1,e+1),"base64url"),y:st(t.subarray(1+e),"base64url"),ext:!0}}var $u=(r,t)=>({...Di(r,t.public),d:st(t.private,"base64url")});var Oi=Vi;async function Pi(r,t){let e=Se.decode(r);return Yr().decrypt(e,t)}var Ki={"AES-128":{ivSize:16,keySize:16},"AES-256":{ivSize:16,keySize:32},Blowfish:{ivSize:8,keySize:32}};async function Mi(r,t,e){let n=Ki[r];if(n==null){let B=Object.keys(Ki).join(" / ");throw new _(`unknown cipher type '${r}'. Must be ${B}`,"ERR_INVALID_CIPHER_TYPE")}if(t==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),u=await Yn(t,e),l=await u.digest(a),f=[],d=0;for(;d<c;){let B=await u.digest(Ft([l,a])),b=B.length;d+b>c&&(b=c-d),f.push(B),d+=b,l=await u.digest(l)}let w=c/2,g=Ft(f),h=g.subarray(0,w),p=g.subarray(w,c),m=B=>({iv:B.subarray(0,o),cipherKey:B.subarray(o,o+s),macKey:B.subarray(o+s)});return{k1:m(h),k2:m(p)}}var ao={};et(ao,{MAX_RSA_KEY_SIZE:()=>He,RsaPrivateKey:()=>xe,RsaPublicKey:()=>Ve,fromJwk:()=>gf,generateKeyPair:()=>pf,unmarshalRsaPrivateKey:()=>oo,unmarshalRsaPublicKey:()=>df});function Wt(r){if(isNaN(r)||r<=0)throw new _("random bytes length must be a Number bigger than 0","ERR_INVALID_LENGTH");return We(r)}var we={};et(we,{exportToPem:()=>lf,importFromPem:()=>so,jwkToPkcs1:()=>sf,jwkToPkix:()=>af,pkcs1ToJwk:()=>nf,pkixToJwk:()=>of});var rn=class extends Ze{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,Lr(t);let n=ie(e);if(this.iHash=t.create(),typeof this.iHash.update!="function")throw new Error("Expected instance of class which extends utils.Hash");this.blockLen=this.iHash.blockLen,this.outputLen=this.iHash.outputLen;let s=this.blockLen,o=new Uint8Array(s);o.set(n.length>s?t.create().update(n).digest():n);for(let i=0;i<o.length;i++)o[i]^=54;this.iHash.update(o),this.oHash=t.create();for(let i=0;i<o.length;i++)o[i]^=106;this.oHash.update(o),o.fill(0)}update(t){return ze(this),this.iHash.update(t),this}digestInto(t){ze(this),Ge(t,this.outputLen),this.finished=!0,this.iHash.digestInto(t),this.oHash.update(t),this.oHash.digestInto(t),this.destroy()}digest(){let t=new Uint8Array(this.oHash.outputLen);return this.digestInto(t),t}_cloneInto(t){t||(t=Object.create(Object.getPrototypeOf(this),{}));let{oHash:e,iHash:n,finished:s,destroyed:o,blockLen:i,outputLen:a}=this;return t=t,t.finished=s,t.destroyed=o,t.blockLen=i,t.outputLen=a,t.oHash=e._cloneInto(t.oHash),t.iHash=n._cloneInto(t.iHash),t}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},br=(r,t,e)=>new rn(r,t).update(e).digest();br.create=(r,t)=>new rn(r,t);function Fi(r,t,e,n){Lr(r);let s=Xo({dkLen:32,asyncTick:10},n),{c:o,dkLen:i,asyncTick:a}=s;if(je(o),je(i),je(a),o<1)throw new Error("PBKDF2: iterations (c) should be >= 1");let c=ie(t),u=ie(e),l=new Uint8Array(i),f=br.create(r,c),d=f._cloneInto().update(u);return{c:o,dkLen:i,asyncTick:a,DK:l,PRF:f,PRFSalt:d}}function $i(r,t,e,n,s){return r.destroy(),t.destroy(),n&&n.destroy(),s.fill(0),e}function qi(r,t,e,n){let{c:s,dkLen:o,DK:i,PRF:a,PRFSalt:c}=Fi(r,t,e,n),u,l=new Uint8Array(4),f=Ie(l),d=new Uint8Array(a.outputLen);for(let w=1,g=0;g<o;w++,g+=a.outputLen){let h=i.subarray(g,g+a.outputLen);f.setInt32(0,w,!1),(u=c._cloneInto(u)).update(l).digestInto(d),h.set(d.subarray(0,h.length));for(let p=1;p<s;p++){a._cloneInto(u).update(d).digestInto(d);for(let m=0;m<h.length;m++)h[m]^=d[m]}}return $i(a,c,i,u,d)}async function Js(r,t,e,n){let{c:s,dkLen:o,asyncTick:i,DK:a,PRF:c,PRFSalt:u}=Fi(r,t,e,n),l,f=new Uint8Array(4),d=Ie(f),w=new Uint8Array(c.outputLen);for(let g=1,h=0;h<o;g++,h+=c.outputLen){let p=a.subarray(h,h+c.outputLen);d.setInt32(0,g,!1),(l=u._cloneInto(l)).update(f).digestInto(w),p.set(w.subarray(0,p.length)),await Jo(s-1,i,()=>{c._cloneInto(l).update(w).digestInto(w);for(let m=0;m<p.length;m++)p[m]^=w[m]})}return $i(c,u,a,l,w)}var P=hc(ji());function Le(r,t){let e=0;if(r.length===1)return r[0];for(let n=r.length-1;n>=0;n--)e+=r[r.length-1-n]*Math.pow(2,t*n);return e}function ye(r,t,e=-1){let n=e,s=r,o=0,i=Math.pow(2,t);for(let a=1;a<8;a++){if(r<i){let c;if(n<0)c=new ArrayBuffer(a),o=a;else{if(n<a)return new ArrayBuffer(0);c=new ArrayBuffer(n),o=n}let u=new Uint8Array(c);for(let l=a-1;l>=0;l--){let f=Math.pow(2,l*t);u[o-l-1]=Math.floor(s/f),s-=u[o-l-1]*f}return c}i*=Math.pow(2,t)}return new ArrayBuffer(0)}function on(...r){let t=0,e=0;for(let o of r)t+=o.length;let n=new ArrayBuffer(t),s=new Uint8Array(n);for(let o of r)s.set(o,e),e+=o.length;return s}function Qs(){let r=new Uint8Array(this.valueHex);if(this.valueHex.byteLength>=2){let a=r[0]===255&&r[1]&128,c=r[0]===0&&(r[1]&128)===0;(a||c)&&this.warnings.push("Needlessly long format")}let t=new ArrayBuffer(this.valueHex.byteLength),e=new Uint8Array(t);for(let a=0;a<this.valueHex.byteLength;a++)e[a]=0;e[0]=r[0]&128;let n=Le(e,8),s=new ArrayBuffer(this.valueHex.byteLength),o=new Uint8Array(s);for(let a=0;a<this.valueHex.byteLength;a++)o[a]=r[a];return o[0]&=127,Le(o,8)-n}function Gi(r){let t=r<0?r*-1:r,e=128;for(let n=1;n<8;n++){if(t<=e){if(r<0){let i=e-t,a=ye(i,8,n),c=new Uint8Array(a);return c[0]|=128,a}let s=ye(t,8,n),o=new Uint8Array(s);if(o[0]&128){let i=s.slice(0),a=new Uint8Array(i);s=new ArrayBuffer(s.byteLength+1),o=new Uint8Array(s);for(let c=0;c<i.byteLength;c++)o[c+1]=a[c];o[0]=0}return s}e*=Math.pow(2,8)}return new ArrayBuffer(0)}function zi(r,t){if(r.byteLength!==t.byteLength)return!1;let e=new Uint8Array(r),n=new Uint8Array(t);for(let s=0;s<e.length;s++)if(e[s]!==n[s])return!1;return!0}function mt(r,t){let e=r.toString(10);if(t<e.length)return"";let n=t-e.length,s=new Array(n);for(let i=0;i<n;i++)s[i]="0";return s.join("").concat(e)}var W0=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 t=0,e=0;for(let s=0;s<r.length;s++){let o=r[s];t+=o.byteLength}let n=new Uint8Array(t);for(let s=0;s<r.length;s++){let o=r[s];n.set(new Uint8Array(o),e),e+=o.byteLength}return n.buffer}function ee(r,t,e,n){return t instanceof Uint8Array?t.byteLength?e<0?(r.error="Wrong parameter: inputOffset less than zero",!1):n<0?(r.error="Wrong parameter: inputLength less than zero",!1):t.byteLength-e-n<0?(r.error="End of input reached before message was fully decoded (inconsistent offset and length values)",!1):!0:(r.error="Wrong parameter: inputBuffer has zero length",!1):(r.error="Wrong parameter: inputBuffer must be 'Uint8Array'",!1)}var xr=class{constructor(){this.items=[]}write(t){this.items.push(t)}final(){return to(this.items)}},wr=[new Uint8Array([1])],Zi="0123456789";var ir="",Ut=new ArrayBuffer(0),eo=new Uint8Array(0),Br="EndOfContent",Wi="OCTET STRING",Ji="BIT STRING";function re(r){var t;return t=class extends r{constructor(...n){var s;super(...n);let o=n[0]||{};this.isHexOnly=(s=o.isHexOnly)!==null&&s!==void 0?s:!1,this.valueHexView=o.valueHex?P.BufferSourceConverter.toUint8Array(o.valueHex):eo}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(!ee(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",Ut)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:P.Convert.ToHex(this.valueHexView)}}},t.NAME="hexBlock",t}var Xt=class{constructor({blockLength:t=0,error:e=ir,warnings:n=[],valueBeforeDecode:s=eo}={}){this.blockLength=t,this.error=e,this.warnings=n,this.valueBeforeDecodeView=P.BufferSourceConverter.toUint8Array(s)}static blockName(){return this.NAME}get valueBeforeDecode(){return this.valueBeforeDecodeView.slice().buffer}set valueBeforeDecode(t){this.valueBeforeDecodeView=new Uint8Array(t)}toJSON(){return{blockName:this.constructor.NAME,blockLength:this.blockLength,error:this.error,warnings:this.warnings,valueBeforeDecode:P.Convert.ToHex(this.valueBeforeDecodeView)}}};Xt.NAME="baseBlock";var gt=class extends Xt{fromBER(t,e,n){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}toBER(t,e){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}};gt.NAME="valueBlock";var cn=class extends re(Xt){constructor({idBlock:t={}}={}){var e,n,s,o;super(),t?(this.isHexOnly=(e=t.isHexOnly)!==null&&e!==void 0?e:!1,this.valueHexView=t.valueHex?P.BufferSourceConverter.toUint8Array(t.valueHex):eo,this.tagClass=(n=t.tagClass)!==null&&n!==void 0?n:-1,this.tagNumber=(s=t.tagNumber)!==null&&s!==void 0?s:-1,this.isConstructed=(o=t.isConstructed)!==null&&o!==void 0?o:!1):(this.tagClass=-1,this.tagNumber=-1,this.isConstructed=!1)}toBER(t=!1){let e=0;switch(this.tagClass){case 1:e|=0;break;case 2:e|=64;break;case 3:e|=128;break;case 4:e|=192;break;default:return this.error="Unknown tag class",Ut}if(this.isConstructed&&(e|=32),this.tagNumber<31&&!this.isHexOnly){let s=new Uint8Array(1);if(!t){let o=this.tagNumber;o&=31,e|=o,s[0]=e}return s.buffer}if(!this.isHexOnly){let s=ye(this.tagNumber,7),o=new Uint8Array(s),i=s.byteLength,a=new Uint8Array(i+1);if(a[0]=e|31,!t){for(let c=0;c<i-1;c++)a[c+1]=o[c]|128;a[i]=o[i-1]}return a.buffer}let n=new Uint8Array(this.valueHexView.byteLength+1);if(n[0]=e|31,!t){let s=this.valueHexView;for(let o=0;o<s.length-1;o++)n[o+1]=s[o]|128;n[this.valueHexView.byteLength]=s[s.length-1]}return n.buffer}fromBER(t,e,n){let s=P.BufferSourceConverter.toUint8Array(t);if(!ee(this,s,e,n))return-1;let o=s.subarray(e,e+n);if(o.length===0)return this.error="Zero buffer length",-1;switch(o[0]&192){case 0:this.tagClass=1;break;case 64:this.tagClass=2;break;case 128:this.tagClass=3;break;case 192:this.tagClass=4;break;default:return this.error="Unknown tag class",-1}this.isConstructed=(o[0]&32)===32,this.isHexOnly=!1;let a=o[0]&31;if(a!==31)this.tagNumber=a,this.blockLength=1;else{let c=1,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 d=new Uint8Array(l);for(let w=0;w<u.length;w++)d[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 d=0;d<c;d++)f[d]=u[d];u=this.valueHexView=new Uint8Array(c),u.set(f),this.blockLength<=9?this.tagNumber=Le(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 e+this.blockLength}toJSON(){return{...super.toJSON(),tagClass:this.tagClass,tagNumber:this.tagNumber,isConstructed:this.isConstructed}}};cn.NAME="identificationBlock";var ln=class extends Xt{constructor({lenBlock:t={}}={}){var e,n,s;super(),this.isIndefiniteForm=(e=t.isIndefiniteForm)!==null&&e!==void 0?e:!1,this.longFormUsed=(n=t.longFormUsed)!==null&&n!==void 0?n:!1,this.length=(s=t.length)!==null&&s!==void 0?s:0}fromBER(t,e,n){let s=P.BufferSourceConverter.toUint8Array(t);if(!ee(this,s,e,n))return-1;let o=s.subarray(e,e+n);if(o.length===0)return this.error="Zero buffer length",-1;if(o[0]===255)return this.error="Length block 0xFF is reserved by standard",-1;if(this.isIndefiniteForm=o[0]===128,this.isIndefiniteForm)return this.blockLength=1,e+this.blockLength;if(this.longFormUsed=!!(o[0]&128),this.longFormUsed===!1)return this.length=o[0],this.blockLength=1,e+this.blockLength;let i=o[0]&127;if(i>8)return this.error="Too big integer",-1;if(i+1>o.length)return this.error="End of input reached before message was fully decoded",-1;let a=e+1,c=s.subarray(a,a+i);return c[i-1]===0&&this.warnings.push("Needlessly long encoded length"),this.length=Le(c,8),this.longFormUsed&&this.length<=127&&this.warnings.push("Unnecessary usage of long length form"),this.blockLength=i+1,e+this.blockLength}toBER(t=!1){let e,n;if(this.length>127&&(this.longFormUsed=!0),this.isIndefiniteForm)return e=new ArrayBuffer(1),t===!1&&(n=new Uint8Array(e),n[0]=128),e;if(this.longFormUsed){let s=ye(this.length,8);if(s.byteLength>127)return this.error="Too big length",Ut;if(e=new ArrayBuffer(s.byteLength+1),t)return e;let o=new Uint8Array(s);n=new Uint8Array(e),n[0]=s.byteLength|128;for(let i=0;i<s.byteLength;i++)n[i+1]=o[i];return e}return e=new ArrayBuffer(1),t===!1&&(n=new Uint8Array(e),n[0]=this.length),e}toJSON(){return{...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,longFormUsed:this.longFormUsed,length:this.length}}};ln.NAME="lengthBlock";var k={},ft=class extends Xt{constructor({name:t=ir,optional:e=!1,primitiveSchema:n,...s}={},o){super(s),this.name=t,this.optional=e,n&&(this.primitiveSchema=n),this.idBlock=new cn(s),this.lenBlock=new ln(s),this.valueBlock=o?new o(s):new gt(s)}fromBER(t,e,n){let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}toBER(t,e){let n=e||new xr;e||Xi(this);let s=this.idBlock.toBER(t);if(n.write(s),this.lenBlock.isIndefiniteForm)n.write(new Uint8Array([128]).buffer),this.valueBlock.toBER(t,n),n.write(new ArrayBuffer(2));else{let o=this.valueBlock.toBER(t);this.lenBlock.length=o.byteLength;let i=this.lenBlock.toBER(t);n.write(i),n.write(o)}return e?Ut:n.final()}toJSON(){let t={...super.toJSON(),idBlock:this.idBlock.toJSON(),lenBlock:this.lenBlock.toJSON(),valueBlock:this.valueBlock.toJSON(),name:this.name,optional:this.optional};return this.primitiveSchema&&(t.primitiveSchema=this.primitiveSchema.toJSON()),t}toString(t="ascii"){return t==="ascii"?this.onAsciiEncoding():P.Convert.ToHex(this.toBER())}onAsciiEncoding(){return`${this.constructor.NAME} : ${P.Convert.ToHex(this.valueBlock.valueBeforeDecodeView)}`}isEqual(t){if(this===t)return!0;if(!(t instanceof this.constructor))return!1;let e=this.toBER(),n=t.toBER();return zi(e,n)}};ft.NAME="BaseBlock";function Xi(r){if(r instanceof k.Constructed)for(let t of r.valueBlock.value)Xi(t)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var un=class extends ft{constructor({value:t=ir,...e}={},n){super(e,n),t&&this.fromString(t)}getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}fromBER(t,e,n){let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.fromBuffer(this.valueBlock.valueHexView),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}onAsciiEncoding(){return`${this.constructor.NAME} : '${this.valueBlock.value}'`}};un.NAME="BaseStringBlock";var fn=class extends re(gt){constructor({isHexOnly:t=!0,...e}={}){super(e),this.isHexOnly=t}};fn.NAME="PrimitiveValueBlock";var Qi,hn=class extends ft{constructor(t={}){super(t,fn),this.idBlock.isConstructed=!1}};Qi=hn;k.Primitive=Qi;hn.NAME="PRIMITIVE";function Xu(r,t){if(r instanceof t)return r;let e=new t;return e.idBlock=r.idBlock,e.lenBlock=r.lenBlock,e.warnings=r.warnings,e.valueBeforeDecodeView=r.valueBeforeDecodeView,e}function jn(r,t=0,e=r.length){let n=t,s=new ft({},gt),o=new Xt;if(!ee(o,r,t,e))return s.error=o.error,{offset:-1,result:s};if(!r.subarray(t,t+e).length)return s.error="Zero buffer length",{offset:-1,result:s};let a=s.idBlock.fromBER(r,t,e);if(s.idBlock.warnings.length&&s.warnings.concat(s.idBlock.warnings),a===-1)return s.error=s.idBlock.error,{offset:-1,result:s};if(t=a,e-=s.idBlock.blockLength,a=s.lenBlock.fromBER(r,t,e),s.lenBlock.warnings.length&&s.warnings.concat(s.lenBlock.warnings),a===-1)return s.error=s.lenBlock.error,{offset:-1,result:s};if(t=a,e-=s.lenBlock.blockLength,!s.idBlock.isConstructed&&s.lenBlock.isIndefiniteForm)return s.error="Indefinite length form used for primitive encoding form",{offset:-1,result:s};let c=ft;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=Xu(s,c),a=s.fromBER(r,t,s.lenBlock.isIndefiniteForm?e:s.lenBlock.length),s.valueBeforeDecodeView=r.subarray(n,n+s.blockLength),{offset:a,result:s}}function ar(r){if(!r.byteLength){let t=new ft({},gt);return t.error="Input buffer has zero length",{offset:-1,result:t}}return jn(P.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function Qu(r,t){return r?1:t}var Dt=class extends gt{constructor({value:t=[],isIndefiniteForm:e=!1,...n}={}){super(n),this.value=t,this.isIndefiniteForm=e}fromBER(t,e,n){let s=P.BufferSourceConverter.toUint8Array(t);if(!ee(this,s,e,n))return-1;if(this.valueBeforeDecodeView=s.subarray(e,e+n),this.valueBeforeDecodeView.length===0)return this.warnings.push("Zero buffer length"),e;let o=e;for(;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===Br)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===Br?this.value.pop():this.warnings.push("No EndOfContent block encoded")),o}toBER(t,e){let n=e||new xr;for(let s=0;s<this.value.length;s++)this.value[s].toBER(t,n);return e?Ut:n.final()}toJSON(){let t={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let e of this.value)t.value.push(e.toJSON());return t}};Dt.NAME="ConstructedValueBlock";var ta,me=class extends ft{constructor(t={}){super(t,Dt),this.idBlock.isConstructed=!0}fromBER(t,e,n){this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm;let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}onAsciiEncoding(){let t=[];for(let n of this.valueBlock.value)t.push(n.toString("ascii").split(`
3
3
  `).map(s=>` ${s}`).join(`
4
4
  `));let e=this.idBlock.tagClass===3?`[${this.idBlock.tagNumber}]`:this.constructor.NAME;return t.length?`${e} :
5
5
  ${t.join(`
6
- `)}`:`${e} :`}};Qi=me;k.Constructed=Qi;me.NAME="CONSTRUCTED";var ln=class extends gt{fromBER(t,e,n){return e}toBER(t){return Lt}};ln.override="EndOfContentValueBlock";var ta,un=class extends ft{constructor(t={}){super(t,ln),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};ta=un;k.EndOfContent=ta;un.NAME=xr;var ea,be=class extends ft{constructor(t={}){super(t,gt),this.idBlock.tagClass=1,this.idBlock.tagNumber=5}fromBER(t,e,n){return this.lenBlock.length>0&&this.warnings.push("Non-zero length of value block for Null type"),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.blockLength+=n,e+n>t.byteLength?(this.error="End of input reached before message was fully decoded (inconsistent offset and length values)",-1):e+n}toBER(t,e){let n=new ArrayBuffer(2);if(!t){let s=new Uint8Array(n);s[0]=5,s[1]=0}return e&&e.write(n),n}onAsciiEncoding(){return`${this.constructor.NAME}`}};ea=be;k.Null=ea;be.NAME="NULL";var fn=class extends ne(gt){constructor({value:t,...e}={}){super(e),e.valueHex?this.valueHexView=P.BufferSourceConverter.toUint8Array(e.valueHex):this.valueHexView=new Uint8Array(1),t&&(this.value=t)}get value(){for(let t of this.valueHexView)if(t>0)return!0;return!1}set value(t){this.valueHexView[0]=t?255:0}fromBER(t,e,n){let s=P.BufferSourceConverter.toUint8Array(t);return re(this,s,e,n)?(this.valueHexView=s.subarray(e,e+n),n>1&&this.warnings.push("Boolean value encoded in more then 1 octet"),this.isHexOnly=!0,Ws.call(this),this.blockLength=n,e+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};fn.NAME="BooleanValueBlock";var ra,hn=class extends ft{constructor(t={}){super(t,fn),this.idBlock.tagClass=1,this.idBlock.tagNumber=1}getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.getValue}`}};ra=hn;k.Boolean=ra;hn.NAME="BOOLEAN";var dn=class extends ne(Ot){constructor({isConstructed:t=!1,...e}={}){super(e),this.isConstructed=t}fromBER(t,e,n){let s=0;if(this.isConstructed){if(this.isHexOnly=!1,s=Ot.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let o=0;o<this.value.length;o++){let i=this.value[o].constructor.NAME;if(i===xr){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(t,e,n),this.blockLength=n;return s}toBER(t,e){return this.isConstructed?Ot.prototype.toBER.call(this,t,e):t?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};dn.NAME="OctetStringValueBlock";var na,te=class r extends ft{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,o;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((o=n.value)===null||o===void 0)&&o.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},dn),this.idBlock.tagClass=1,this.idBlock.tagNumber=4}fromBER(t,e,n){if(this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,n===0)return this.idBlock.error.length===0&&(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length===0&&(this.blockLength+=this.lenBlock.blockLength),e;if(!this.valueBlock.isConstructed){let o=(t instanceof ArrayBuffer?new Uint8Array(t):t).subarray(e,e+n);try{if(o.byteLength){let i=Mn(o,0,o.byteLength);i.offset!==-1&&i.offset===n&&(this.valueBlock.value=[i.result])}}catch{}}return super.fromBER(t,e,n)}onAsciiEncoding(){return this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length?me.prototype.onAsciiEncoding.call(this):`${this.constructor.NAME} : ${P.Convert.ToHex(this.valueBlock.valueHexView)}`}getValue(){if(!this.idBlock.isConstructed)return this.valueBlock.valueHexView.slice().buffer;let t=[];for(let e of this.valueBlock.value)e instanceof r&&t.push(e.valueBlock.valueHexView);return P.BufferSourceConverter.concat(t)}};na=te;k.OctetString=na;te.NAME=Yi;var gn=class extends ne(Ot){constructor({unusedBits:t=0,isConstructed:e=!1,...n}={}){super(n),this.unusedBits=t,this.isConstructed=e,this.blockLength=this.valueHexView.byteLength}fromBER(t,e,n){if(!n)return e;let s=-1;if(this.isConstructed){if(s=Ot.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let a of this.value){let c=a.constructor.NAME;if(c===xr){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 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=P.BufferSourceConverter.toUint8Array(t);if(!re(this,o,e,n))return-1;let i=o.subarray(e,e+n);if(this.unusedBits=i[0],this.unusedBits>7)return this.error="Unused bits for BitString must be in range 0-7",-1;if(!this.unusedBits){let a=i.subarray(1);try{if(a.byteLength){let c=Mn(a,0,a.byteLength);c.offset!==-1&&c.offset===n-1&&(this.value=[c.result])}}catch{}}return this.valueHexView=i.subarray(1),this.blockLength=i.length,e+n}toBER(t,e){if(this.isConstructed)return Ot.prototype.toBER.call(this,t,e);if(t)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return Lt;let n=new Uint8Array(this.valueHexView.length+1);return n[0]=this.unusedBits,n.set(this.valueHexView,1),n.buffer}toJSON(){return{...super.toJSON(),unusedBits:this.unusedBits,isConstructed:this.isConstructed}}};gn.NAME="BitStringValueBlock";var sa,sr=class extends ft{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,o;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((o=n.value)===null||o===void 0)&&o.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},gn),this.idBlock.tagClass=1,this.idBlock.tagNumber=3}fromBER(t,e,n){return this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,super.fromBER(t,e,n)}onAsciiEncoding(){if(this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length)return me.prototype.onAsciiEncoding.call(this);{let t=[],e=this.valueBlock.valueHexView;for(let s of e)t.push(s.toString(2).padStart(8,"0"));let n=t.join("");return`${this.constructor.NAME} : ${n.substring(0,n.length-this.valueBlock.unusedBits)}`}}};sa=sr;k.BitString=sa;sr.NAME=Wi;var oa;function tf(r,t){let e=new Uint8Array([0]),n=new Uint8Array(r),s=new Uint8Array(t),o=n.slice(0),i=o.length-1,a=s.slice(0),c=a.length-1,u=0,l=c<i?i:c,f=0;for(let d=l;d>=0;d--,f++){switch(!0){case f<a.length:u=o[i-f]+a[c-f]+e[0];break;default:u=o[i-f]+e[0]}switch(e[0]=u/10,!0){case f>=o.length:o=en(new Uint8Array([u%10]),o);break;default:o[i-f]=u%10}}return e[0]>0&&(o=en(e,o)),o}function Zi(r){if(r>=br.length)for(let t=br.length;t<=r;t++){let e=new Uint8Array([0]),n=br[t-1].slice(0);for(let s=n.length-1;s>=0;s--){let o=new Uint8Array([(n[s]<<1)+e[0]]);e[0]=o[0]/10,n[s]=o[0]%10}e[0]>0&&(n=en(e,n)),br.push(n)}return br[r]}function ef(r,t){let e=0,n=new Uint8Array(r),s=new Uint8Array(t),o=n.slice(0),i=o.length-1,a=s.slice(0),c=a.length-1,u,l=0;for(let f=c;f>=0;f--,l++)switch(u=o[i-l]-a[c-l]-e,!0){case u<0:e=1,o[i-l]=u+10;break;default:e=0,o[i-l]=u}if(e>0)for(let f=i-c+1;f>=0;f--,l++)if(u=o[i-l]-e,u<0)e=1,o[i-l]=u+10;else{e=0,o[i-l]=u;break}return o.slice()}var Br=class extends ne(gt){constructor({value:t,...e}={}){super(e),this._valueDec=0,e.valueHex&&this.setValueHex(),t!==void 0&&(this.valueDec=t)}setValueHex(){this.valueHexView.length>=4?(this.warnings.push("Too big Integer for decoding, hex only"),this.isHexOnly=!0,this._valueDec=0):(this.isHexOnly=!1,this.valueHexView.length>0&&(this._valueDec=Ws.call(this)))}set valueDec(t){this._valueDec=t,this.isHexOnly=!1,this.valueHexView=new Uint8Array(ji(t))}get valueDec(){return this._valueDec}fromDER(t,e,n,s=0){let o=this.fromBER(t,e,n);if(o===-1)return o;let i=this.valueHexView;return i[0]===0&&i[1]&128?this.valueHexView=i.subarray(1):s!==0&&i.length<s&&(s-i.length>1&&(s=i.length+1),this.valueHexView=i.subarray(s-i.length)),o}toDER(t=!1){let e=this.valueHexView;switch(!0){case(e[0]&128)!==0:{let n=new Uint8Array(this.valueHexView.length+1);n[0]=0,n.set(e,1),this.valueHexView=n}break;case(e[0]===0&&(e[1]&128)===0):this.valueHexView=this.valueHexView.subarray(1);break}return this.toBER(t)}fromBER(t,e,n){let s=super.fromBER(t,e,n);return s===-1||this.setValueHex(),s}toBER(t){return t?new ArrayBuffer(this.valueHexView.length):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}toString(){let t=this.valueHexView.length*8-1,e=new Uint8Array(this.valueHexView.length*8/3),n=0,s,o=this.valueHexView,i="",a=!1;for(let c=o.byteLength-1;c>=0;c--){s=o[c];for(let u=0;u<8;u++){if((s&1)===1)switch(n){case t:e=ef(Zi(n),e),i="-";break;default:e=tf(e,Zi(n))}n++,s>>=1}}for(let c=0;c<e.length;c++)e[c]&&(a=!0),a&&(i+=zi.charAt(e[c]));return a===!1&&(i+=zi.charAt(0)),i}};oa=Br;Br.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,ot=class r extends ft{constructor(t={}){super(t,Br),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return rn(),BigInt(this.valueBlock.toString())}static fromBigInt(t){rn();let e=BigInt(t),n=new wr,s=e.toString(16).replace(/^-/,""),o=new Uint8Array(P.Convert.FromHex(s));if(e<0){let a=new Uint8Array(o.length+(o[0]&128?1:0));a[0]|=128;let u=BigInt(`0x${P.Convert.ToHex(a)}`)+e,l=P.BufferSourceConverter.toUint8Array(P.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 t=new r({valueHex:this.valueBlock.valueHexView});return t.valueBlock.toDER(),t}convertFromDER(){return new r({valueHex:this.valueBlock.valueHexView[0]===0?this.valueBlock.valueHexView.subarray(1):this.valueBlock.valueHexView})}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()}`}};ia=ot;k.Integer=ia;ot.NAME="INTEGER";var aa,pn=class extends ot{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};aa=pn;k.Enumerated=aa;pn.NAME="ENUMERATED";var vr=class extends ne(gt){constructor({valueDec:t=-1,isFirstSid:e=!1,...n}={}){super(n),this.valueDec=t,this.isFirstSid=e}fromBER(t,e,n){if(!n)return e;let s=P.BufferSourceConverter.toUint8Array(t);if(!re(this,s,e,n))return-1;let o=s.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=o[a]&127,this.blockLength++,!!(o[a]&128));a++);let i=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)i[a]=this.valueHexView[a];return this.valueHexView=i,o[this.blockLength-1]&128?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=Ve(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}set valueBigInt(t){rn();let e=BigInt(t).toString(2);for(;e.length%7;)e="0"+e;let n=new Uint8Array(e.length/7);for(let s=0;s<n.length;s++)n[s]=parseInt(e.slice(s*7,s*7+7),2)+(s+1<n.length?128:0);this.fromBER(n.buffer,0,n.length)}toBER(t){if(this.isHexOnly){if(t)return new ArrayBuffer(this.valueHexView.byteLength);let s=this.valueHexView,o=new Uint8Array(this.blockLength);for(let i=0;i<this.blockLength-1;i++)o[i]=s[i]|128;return o[this.blockLength-1]=s[this.blockLength-1],o.buffer}let e=ye(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Lt;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),o=e.byteLength-1;for(let i=0;i<o;i++)n[i]=s[i]|128;n[o]=s[o]}return n}toString(){let t="";if(this.isHexOnly)t=P.Convert.ToHex(this.valueHexView);else if(this.isFirstSid){let e=this.valueDec;this.valueDec<=39?t="0.":this.valueDec<=79?(t="1.",e-=40):(t="2.",e-=80),t+=e.toString()}else t=this.valueDec.toString();return t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec,isFirstSid:this.isFirstSid}}};vr.NAME="sidBlock";var yn=class extends gt{constructor({value:t=or,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new vr;if(s=o.fromBER(t,s,n),s===-1)return this.blockLength=0,this.error=o.error,s;this.value.length===0&&(o.isFirstSid=!0),this.blockLength+=o.blockLength,n-=o.blockLength,this.value.push(o)}return s}toBER(t){let e=[];for(let n=0;n<this.value.length;n++){let s=this.value[n].toBER(t);if(s.byteLength===0)return this.error=this.value[n].error,Lt;e.push(s)}return Js(e)}fromString(t){this.value=[];let e=0,n=0,s="",o=!1;do if(n=t.indexOf(".",e),n===-1?s=t.substring(e):s=t.substring(e,n),e=n+1,o){let i=this.value[0],a=0;switch(i.valueDec){case 0:break;case 1:a=40;break;case 2:a=80;break;default:this.value=[];return}let c=parseInt(s,10);if(isNaN(c))return;i.valueDec=c+a,o=!1}else{let i=new vr;if(s>Number.MAX_SAFE_INTEGER){rn();let a=BigInt(s);i.valueBigInt=a}else if(i.valueDec=parseInt(s,10),isNaN(i.valueDec))return;this.value.length||(i.isFirstSid=!0,o=!0),this.value.push(i)}while(n!==-1)}toString(){let t="",e=!1;for(let n=0;n<this.value.length;n++){e=this.value[n].isHexOnly;let s=this.value[n].toString();n!==0&&(t=`${t}.`),e?(s=`{${s}}`,this.value[n].isFirstSid?t=`2.{${s} - 80}`:t+=s):t+=s}return t}toJSON(){let t={...super.toJSON(),value:this.toString(),sidArray:[]};for(let e=0;e<this.value.length;e++)t.sidArray.push(this.value[e].toJSON());return t}};yn.NAME="ObjectIdentifierValueBlock";var ca,Ut=class extends ft{constructor(t={}){super(t,yn),this.idBlock.tagClass=1,this.idBlock.tagNumber=6}getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};ca=Ut;k.ObjectIdentifier=ca;Ut.NAME="OBJECT IDENTIFIER";var Er=class extends ne(Qt){constructor({valueDec:t=0,...e}={}){super(e),this.valueDec=t}fromBER(t,e,n){if(n===0)return e;let s=P.BufferSourceConverter.toUint8Array(t);if(!re(this,s,e,n))return-1;let o=s.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=o[a]&127,this.blockLength++,!!(o[a]&128));a++);let i=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)i[a]=this.valueHexView[a];return this.valueHexView=i,o[this.blockLength-1]&128?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=Ve(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}toBER(t){if(this.isHexOnly){if(t)return new ArrayBuffer(this.valueHexView.byteLength);let s=this.valueHexView,o=new Uint8Array(this.blockLength);for(let i=0;i<this.blockLength-1;i++)o[i]=s[i]|128;return o[this.blockLength-1]=s[this.blockLength-1],o.buffer}let e=ye(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Lt;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),o=e.byteLength-1;for(let i=0;i<o;i++)n[i]=s[i]|128;n[o]=s[o]}return n.buffer}toString(){let t="";return this.isHexOnly?t=P.Convert.ToHex(this.valueHexView):t=this.valueDec.toString(),t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};Er.NAME="relativeSidBlock";var mn=class extends gt{constructor({value:t=or,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new Er;if(s=o.fromBER(t,s,n),s===-1)return this.blockLength=0,this.error=o.error,s;this.blockLength+=o.blockLength,n-=o.blockLength,this.value.push(o)}return s}toBER(t,e){let n=[];for(let s=0;s<this.value.length;s++){let o=this.value[s].toBER(t);if(o.byteLength===0)return this.error=this.value[s].error,Lt;n.push(o)}return Js(n)}fromString(t){this.value=[];let e=0,n=0,s="";do{n=t.indexOf(".",e),n===-1?s=t.substring(e):s=t.substring(e,n),e=n+1;let o=new Er;if(o.valueDec=parseInt(s,10),isNaN(o.valueDec))return!0;this.value.push(o)}while(n!==-1);return!0}toString(){let t="",e=!1;for(let n=0;n<this.value.length;n++){e=this.value[n].isHexOnly;let s=this.value[n].toString();n!==0&&(t=`${t}.`),e&&(s=`{${s}}`),t+=s}return t}toJSON(){let t={...super.toJSON(),value:this.toString(),sidArray:[]};for(let e=0;e<this.value.length;e++)t.sidArray.push(this.value[e].toJSON());return t}};mn.NAME="RelativeObjectIdentifierValueBlock";var la,bn=class extends ft{constructor(t={}){super(t,mn),this.idBlock.tagClass=1,this.idBlock.tagNumber=13}getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};la=bn;k.RelativeObjectIdentifier=la;bn.NAME="RelativeObjectIdentifier";var ua,ct=class extends me{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};ua=ct;k.Sequence=ua;ct.NAME="SEQUENCE";var fa,wn=class extends me{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};fa=wn;k.Set=fa;wn.NAME="SET";var xn=class extends ne(gt){constructor({...t}={}){super(t),this.isHexOnly=!0,this.value=or}toJSON(){return{...super.toJSON(),value:this.value}}};xn.NAME="StringValueBlock";var Bn=class extends xn{};Bn.NAME="SimpleStringValueBlock";var yt=class extends on{constructor({...t}={}){super(t,Bn)}fromBuffer(t){this.valueBlock.value=String.fromCharCode.apply(null,P.BufferSourceConverter.toUint8Array(t))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e);for(let s=0;s<e;s++)n[s]=t.charCodeAt(s);this.valueBlock.value=t}};yt.NAME="SIMPLE STRING";var vn=class extends yt{fromBuffer(t){this.valueBlock.valueHexView=P.BufferSourceConverter.toUint8Array(t);try{this.valueBlock.value=P.Convert.ToUtf8String(t)}catch(e){this.warnings.push(`Error during "decodeURIComponent": ${e}, using raw string`),this.valueBlock.value=P.Convert.ToBinary(t)}}fromString(t){this.valueBlock.valueHexView=new Uint8Array(P.Convert.FromUtf8String(t)),this.valueBlock.value=t}};vn.NAME="Utf8StringValueBlock";var ha,ee=class extends vn{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};ha=ee;k.Utf8String=ha;ee.NAME="UTF8String";var En=class extends yt{fromBuffer(t){this.valueBlock.value=P.Convert.ToUtf16String(t),this.valueBlock.valueHexView=P.BufferSourceConverter.toUint8Array(t)}fromString(t){this.valueBlock.value=t,this.valueBlock.valueHexView=new Uint8Array(P.Convert.FromUtf16String(t))}};En.NAME="BmpStringValueBlock";var da,An=class extends En{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};da=An;k.BmpString=da;An.NAME="BMPString";var kn=class extends yt{fromBuffer(t){let e=ArrayBuffer.isView(t)?t.slice().buffer:t.slice(0),n=new Uint8Array(e);for(let s=0;s<n.length;s+=4)n[s]=n[s+3],n[s+1]=n[s+2],n[s+2]=0,n[s+3]=0;this.valueBlock.value=String.fromCharCode.apply(null,new Uint32Array(e))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e*4);for(let s=0;s<e;s++){let o=ye(t.charCodeAt(s),8),i=new Uint8Array(o);if(i.length>4)continue;let a=4-i.length;for(let c=i.length-1;c>=0;c--)n[s*4+c+a]=i[c]}this.valueBlock.value=t}};kn.NAME="UniversalStringValueBlock";var ga,Sn=class extends kn{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};ga=Sn;k.UniversalString=ga;Sn.NAME="UniversalString";var pa,In=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};pa=In;k.NumericString=pa;In.NAME="NumericString";var ya,Nn=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};ya=Nn;k.PrintableString=ya;Nn.NAME="PrintableString";var ma,Rn=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};ma=Rn;k.TeletexString=ma;Rn.NAME="TeletexString";var ba,Tn=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};ba=Tn;k.VideotexString=ba;Tn.NAME="VideotexString";var wa,Cn=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};wa=Cn;k.IA5String=wa;Cn.NAME="IA5String";var xa,_n=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};xa=_n;k.GraphicString=xa;_n.NAME="GraphicString";var Ba,Ar=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};Ba=Ar;k.VisibleString=Ba;Ar.NAME="VisibleString";var va,Un=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};va=Un;k.GeneralString=va;Un.NAME="GeneralString";var Ea,Ln=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};Ea=Ln;k.CharacterString=Ea;Ln.NAME="CharacterString";var Aa,kr=class extends Ar{constructor({value:t,valueDate:e,...n}={}){if(super(n),this.year=0,this.month=0,this.day=0,this.hour=0,this.minute=0,this.second=0,t){this.fromString(t),this.valueBlock.valueHexView=new Uint8Array(t.length);for(let s=0;s<t.length;s++)this.valueBlock.valueHexView[s]=t.charCodeAt(s)}e&&(this.fromDate(e),this.valueBlock.valueHexView=new Uint8Array(this.toBuffer())),this.idBlock.tagClass=1,this.idBlock.tagNumber=23}fromBuffer(t){this.fromString(String.fromCharCode.apply(null,P.BufferSourceConverter.toUint8Array(t)))}toBuffer(){let t=this.toString(),e=new ArrayBuffer(t.length),n=new Uint8Array(e);for(let s=0;s<t.length;s++)n[s]=t.charCodeAt(s);return e}fromDate(t){this.year=t.getUTCFullYear(),this.month=t.getUTCMonth()+1,this.day=t.getUTCDate(),this.hour=t.getUTCHours(),this.minute=t.getUTCMinutes(),this.second=t.getUTCSeconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second))}fromString(t){let n=/(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})Z/ig.exec(t);if(n===null){this.error="Wrong input string for conversion";return}let s=parseInt(n[1],10);s>=50?this.year=1900+s:this.year=2e3+s,this.month=parseInt(n[2],10),this.day=parseInt(n[3],10),this.hour=parseInt(n[4],10),this.minute=parseInt(n[5],10),this.second=parseInt(n[6],10)}toString(t="iso"){if(t==="iso"){let e=new Array(7);return e[0]=mt(this.year<2e3?this.year-1900:this.year-2e3,2),e[1]=mt(this.month,2),e[2]=mt(this.day,2),e[3]=mt(this.hour,2),e[4]=mt(this.minute,2),e[5]=mt(this.second,2),e[6]="Z",e.join("")}return super.toString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.toDate().toISOString()}`}toJSON(){return{...super.toJSON(),year:this.year,month:this.month,day:this.day,hour:this.hour,minute:this.minute,second:this.second}}};Aa=kr;k.UTCTime=Aa;kr.NAME="UTCTime";var ka,Vn=class extends kr{constructor(t={}){var e;super(t),(e=this.millisecond)!==null&&e!==void 0||(this.millisecond=0),this.idBlock.tagClass=1,this.idBlock.tagNumber=24}fromDate(t){super.fromDate(t),this.millisecond=t.getUTCMilliseconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second,this.millisecond))}fromString(t){let e=!1,n="",s="",o=0,i,a=0,c=0;if(t[t.length-1]==="Z")n=t.substring(0,t.length-1),e=!0;else{let f=new Number(t[t.length-1]);if(isNaN(f.valueOf()))throw new Error("Wrong input string for conversion");n=t}if(e){if(n.indexOf("+")!==-1)throw new Error("Wrong input string for conversion");if(n.indexOf("-")!==-1)throw new Error("Wrong input string for conversion")}else{let f=1,d=n.indexOf("+"),w="";if(d===-1&&(d=n.indexOf("-"),f=-1),d!==-1){if(w=n.substring(d+1),n=n.substring(0,d),w.length!==2&&w.length!==4)throw new Error("Wrong input string for conversion");let g=parseInt(w.substring(0,2),10);if(isNaN(g.valueOf()))throw new Error("Wrong input string for conversion");if(a=f*g,w.length===4){if(g=parseInt(w.substring(2,4),10),isNaN(g.valueOf()))throw new Error("Wrong input string for conversion");c=f*g}}}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(e===!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(t="iso"){if(t==="iso"){let e=[];return e.push(mt(this.year,4)),e.push(mt(this.month,2)),e.push(mt(this.day,2)),e.push(mt(this.hour,2)),e.push(mt(this.minute,2)),e.push(mt(this.second,2)),this.millisecond!==0&&(e.push("."),e.push(mt(this.millisecond,3))),e.push("Z"),e.join("")}return super.toString(t)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};ka=Vn;k.GeneralizedTime=ka;Vn.NAME="GeneralizedTime";var Sa,Hn=class extends ee{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};Sa=Hn;k.DATE=Sa;Hn.NAME="DATE";var Ia,Dn=class extends ee{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};Ia=Dn;k.TimeOfDay=Ia;Dn.NAME="TimeOfDay";var Na,On=class extends ee{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};Na=On;k.DateTime=Na;On.NAME="DateTime";var Ra,Pn=class extends ee{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};Ra=Pn;k.Duration=Ra;Pn.NAME="Duration";var Ta,Kn=class extends ee{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};Ta=Kn;k.TIME=Ta;Kn.NAME="TIME";function nf(r){let{result:t}=ir(r),e=t.valueBlock.value;return{n:st(Pt(e[1].toBigInt()),"base64url"),e:st(Pt(e[2].toBigInt()),"base64url"),d:st(Pt(e[3].toBigInt()),"base64url"),p:st(Pt(e[4].toBigInt()),"base64url"),q:st(Pt(e[5].toBigInt()),"base64url"),dp:st(Pt(e[6].toBigInt()),"base64url"),dq:st(Pt(e[7].toBigInt()),"base64url"),qi:st(Pt(e[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 e=new ct({value:[new ot({value:0}),ot.fromBigInt(Kt(Z(r.n,"base64url"))),ot.fromBigInt(Kt(Z(r.e,"base64url"))),ot.fromBigInt(Kt(Z(r.d,"base64url"))),ot.fromBigInt(Kt(Z(r.p,"base64url"))),ot.fromBigInt(Kt(Z(r.q,"base64url"))),ot.fromBigInt(Kt(Z(r.dp,"base64url"))),ot.fromBigInt(Kt(Z(r.dq,"base64url"))),ot.fromBigInt(Kt(Z(r.qi,"base64url")))]}).toBER();return new Uint8Array(e,0,e.byteLength)}function of(r){let{result:t}=ir(r),e=t.valueBlock.value[1].valueBlock.value[0].valueBlock.value;return{kty:"RSA",n:st(Pt(e[0].toBigInt()),"base64url"),e:st(Pt(e[1].toBigInt()),"base64url")}}function af(r){if(r.n==null||r.e==null)throw new _("JWK was missing components","ERR_INVALID_PARAMETERS");let e=new ct({value:[new ct({value:[new Ut({value:"1.2.840.113549.1.1.1"}),new be]}),new sr({valueHex:new ct({value:[ot.fromBigInt(Kt(Z(r.n,"base64url"))),ot.fromBigInt(Kt(Z(r.e,"base64url")))]}).toBER()})]}).toBER();return new Uint8Array(e,0,e.byteLength)}function Pt(r){let t=r.toString(16);t.length%2>0&&(t=`0${t}`);let e=t.length/2,n=new Uint8Array(e),s=0,o=0;for(;s<e;)n[s]=parseInt(t.slice(o,o+2),16),s+=1,o+=2;return n}function Kt(r){let t=[];return r.forEach(function(e){let n=e.toString(16);n.length%2>0&&(n=`0${n}`),t.push(n)}),BigInt("0x"+t.join(""))}var cf=16,Qs=32,to=1e4;async function lf(r,t){let e=z.get(),s=new ct({value:[new ot({value:0}),new ct({value:[new Ut({value:"1.2.840.113549.1.1.1"}),new be]}),new te({valueHex:r.marshal()})]}).toBER(),o=new Uint8Array(s,0,s.byteLength),i=Jt(cf),a=await Zs(fe,t,i,{c:to,dkLen:Qs}),c=Jt(16),u=await e.subtle.importKey("raw",a,"AES-CBC",!1,["encrypt"]),l=await e.subtle.encrypt({name:"AES-CBC",iv:c},u,o),f=new ct({value:[new te({valueHex:i}),new ot({value:to}),new ot({value:Qs}),new ct({value:[new Ut({value:"1.2.840.113549.2.11"}),new be]})]}),d=new ct({value:[new Ut({value:"1.2.840.113549.1.5.13"}),new ct({value:[new ct({value:[new Ut({value:"1.2.840.113549.1.5.12"}),f]}),new ct({value:[new Ut({value:"2.16.840.1.101.3.4.1.42"}),new te({valueHex:c})]})]})]}),g=new ct({value:[d,new te({valueHex:l})]}).toBER(),h=new Uint8Array(g,0,g.byteLength);return["-----BEGIN ENCRYPTED PRIVATE KEY-----",...st(h,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
7
- `)}async function eo(r,t){let e=z.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}=ir(s),{iv:i,salt:a,iterations:c,keySize:u,cipherText:l}=uf(o),f=await Zs(fe,t,a,{c,dkLen:u}),d=await e.subtle.importKey("raw",f,"AES-CBC",!1,["decrypt"]),w=Sr(await e.subtle.decrypt({name:"AES-CBC",iv:i},d,l)),{result:g}=ir(w);n=Ca(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}=ir(s);n=Ca(o)}else throw new _("Could not parse private key from PEM data","ERR_INVALID_PARAMETERS");return ro(n)}function uf(r){let t=r.valueBlock.value[0];if(t.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=t.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=Sr(o.valueBlock.value[0].getValue()),a=to,c=Qs;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 u=t.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 _("Only AES-CBC encryption schemes are supported","ERR_INVALID_PARAMS")}}}}let f=Sr(u.valueBlock.value[1].getValue());return{cipherText:Sr(r.valueBlock.value[1].getValue()),salt:i,iterations:a,keySize:c,iv:f}}function Ca(r){return Sr(r.valueBlock.value[2].getValue())}function Sr(r){return new Uint8Array(r,0,r.byteLength)}async function _a(r){let t=await z.get().subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:r,publicExponent:new Uint8Array([1,0,1]),hash:{name:"SHA-256"}},!0,["sign","verify"]),e=await Va(t);return{privateKey:e[0],publicKey:e[1]}}async function no(r){let e=[await z.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["sign"]),await ff(r)],n=await Va({privateKey:e[0],publicKey:e[1]});return{privateKey:n[0],publicKey:n[1]}}async function Ua(r,t){let e=await z.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await z.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},e,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(n,0,n.byteLength)}async function La(r,t,e){let n=await z.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return z.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,t,e instanceof Uint8Array?e:e.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([z.get().subtle.exportKey("jwk",r.privateKey),z.get().subtle.exportKey("jwk",r.publicKey)])}async function ff(r){return z.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 Fn(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 De=8192,He=class{_key;constructor(t){this._key=t}verify(t,e){return La(this._key,e,t)}marshal(){return we.jwkToPkix(this._key)}get bytes(){return Ct.encode({Type:G.RSA,Data:this.marshal()}).subarray()}equals(t){return St(this.bytes,t.bytes)}hash(){let t=bt.digest(this.bytes);return Et(t)?t.then(({bytes:e})=>e):t.bytes}},xe=class{_key;_publicKey;constructor(t,e){this._key=t,this._publicKey=e}genSecret(){return Jt(16)}sign(t){return Ua(this._key,t)}get public(){if(this._publicKey==null)throw new _("public key not provided","ERR_PUBKEY_NOT_PROVIDED");return new He(this._publicKey)}marshal(){return we.jwkToPkcs1(this._key)}get bytes(){return _t.encode({Type:G.RSA,Data:this.marshal()}).subarray()}equals(t){return St(this.bytes,t.bytes)}hash(){let t=bt.digest(this.bytes);return Et(t)?t.then(({bytes:e})=>e):t.bytes}async id(){let t=await this.public.hash();return st(t,"base58btc")}async export(t,e="pkcs-8"){if(e==="pkcs-8")return we.exportToPem(this,t);if(e==="libp2p-key")return Qe(this.bytes,t);throw new _(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};async function ro(r){let t=we.pkcs1ToJwk(r);if(Fn(t)>De)throw new _("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await no(t);return new xe(e.privateKey,e.publicKey)}function df(r){let t=we.pkixToJwk(r);if(Fn(t)>De)throw new _("key size is too large","ERR_KEY_SIZE_TOO_LARGE");return new He(t)}async function gf(r){if(Fn(r)>De)throw new _("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await no(r);return new xe(t.privateKey,t.publicKey)}async function pf(r){if(r>De)throw new _("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await _a(r);return new xe(t.privateKey,t.publicKey)}var lo={};et(lo,{Secp256k1PrivateKey:()=>Ke,Secp256k1PublicKey:()=>Pe,generateKeyPair:()=>Tf,unmarshalSecp256k1PrivateKey:()=>Nf,unmarshalSecp256k1PublicKey:()=>Rf});var yf=(r,t,e)=>r&t^~r&e,mf=(r,t,e)=>r&t^r&e^t&e,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]),Be=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),ve=new Uint32Array(64),oo=class extends ce{constructor(){super(64,32,8,!1),this.A=Be[0]|0,this.B=Be[1]|0,this.C=Be[2]|0,this.D=Be[3]|0,this.E=Be[4]|0,this.F=Be[5]|0,this.G=Be[6]|0,this.H=Be[7]|0}get(){let{A:t,B:e,C:n,D:s,E:o,F:i,G:a,H:c}=this;return[t,e,n,s,o,i,a,c]}set(t,e,n,s,o,i,a,c){this.A=t|0,this.B=e|0,this.C=n|0,this.D=s|0,this.E=o|0,this.F=i|0,this.G=a|0,this.H=c|0}process(t,e){for(let f=0;f<16;f++,e+=4)ve[f]=t.getUint32(e,!1);for(let f=16;f<64;f++){let d=ve[f-15],w=ve[f-2],g=It(d,7)^It(d,18)^d>>>3,h=It(w,17)^It(w,19)^w>>>10;ve[f]=h+ve[f-7]+g+ve[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 d=It(a,6)^It(a,11)^It(a,25),w=l+d+yf(a,c,u)+bf[f]+ve[f]|0,h=(It(n,2)^It(n,13)^It(n,22))+mf(n,s,o)|0;l=u,u=c,c=a,a=i+w|0,i=o,o=s,s=n,n=w+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,u=u+this.G|0,l=l+this.H|0,this.set(n,s,o,i,a,c,u,l)}roundClean(){ve.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var $n=Ye(()=>new oo);function wf(r){let t=dr(r);Dt(t,{a:"field",b:"field"},{allowedPrivateKeyLengths:"array",wrapPrivateKey:"boolean",isTorsionFree:"function",clearCofactor:"function",allowInfinityPoint:"boolean",fromBytes:"function",toBytes:"function"});let{endo:e,Fp:n,a:s}=t;if(e){if(!n.eql(s,n.ZERO))throw new Error("Endomorphism can only be defined for Koblitz curves that have a=0");if(typeof e!="object"||typeof e.beta!="bigint"||typeof e.splitScalar!="function")throw new Error("Expected endomorphism with beta: bigint and splitScalar: function")}return Object.freeze({...t})}var{bytesToNumberBE:xf,hexToBytes:Bf}=Or,Oe={Err:class extends Error{constructor(t=""){super(t)}},_parseInt(r){let{Err:t}=Oe;if(r.length<2||r[0]!==2)throw new t("Invalid signature integer tag");let e=r[1],n=r.subarray(2,e+2);if(!e||n.length!==e)throw new t("Invalid signature integer: wrong length");if(n[0]&128)throw new t("Invalid signature integer: negative");if(n[0]===0&&!(n[1]&128))throw new t("Invalid signature integer: unnecessary leading zero");return{d:xf(n),l:r.subarray(e+2)}},toSig(r){let{Err:t}=Oe,e=typeof r=="string"?Bf(r):r;if(!Nt(e))throw new Error("ui8a expected");let n=e.length;if(n<2||e[0]!=48)throw new t("Invalid signature tag");if(e[1]!==n-2)throw new t("Invalid signature: incorrect length");let{d:s,l:o}=Oe._parseInt(e.subarray(2)),{d:i,l:a}=Oe._parseInt(o);if(a.length)throw new t("Invalid signature: left bytes after parsing");return{r:s,s:i}},hexFromSig(r){let t=u=>Number.parseInt(u[0],16)&8?"00"+u:u,e=u=>{let l=u.toString(16);return l.length&1?`0${l}`:l},n=t(e(r.s)),s=t(e(r.r)),o=n.length/2,i=s.length/2,a=e(o),c=e(i);return`30${e(i+o+4)}02${c}${s}02${a}${n}`}},se=BigInt(0),kt=BigInt(1),kg=BigInt(2),Ha=BigInt(3),Sg=BigInt(4);function vf(r){let t=wf(r),{Fp:e}=t,n=t.toBytes||((g,h,p)=>{let m=h.toAffine();return zt(Uint8Array.from([4]),e.toBytes(m.x),e.toBytes(m.y))}),s=t.fromBytes||(g=>{let h=g.subarray(1),p=e.fromBytes(h.subarray(0,e.BYTES)),m=e.fromBytes(h.subarray(e.BYTES,2*e.BYTES));return{x:p,y:m}});function o(g){let{a:h,b:p}=t,m=e.sqr(g),B=e.mul(m,g);return e.add(e.add(B,e.mul(g,h)),p)}if(!e.eql(e.sqr(t.Gy),o(t.Gx)))throw new Error("bad generator point: equation left != right");function i(g){return typeof g=="bigint"&&se<g&&g<t.n}function a(g){if(!i(g))throw new Error("Expected valid bigint: 0 < bigint < curve.n")}function c(g){let{allowedPrivateKeyLengths:h,nByteLength:p,wrapPrivateKey:m,n:B}=t;if(h&&typeof g!="bigint"){if(Nt(g)&&(g=jt(g)),typeof g!="string"||!h.includes(g.length))throw new Error("Invalid key");g=g.padStart(p*2,"0")}let b;try{b=typeof g=="bigint"?g:Gt(Q("private key",g,p))}catch{throw new Error(`private key must be ${p} bytes, hex or bigint, not ${typeof g}`)}return m&&(b=j(b,B)),a(b),b}let u=new Map;function l(g){if(!(g instanceof f))throw new Error("ProjectivePoint expected")}class f{constructor(h,p,m){if(this.px=h,this.py=p,this.pz=m,h==null||!e.isValid(h))throw new Error("x required");if(p==null||!e.isValid(p))throw new Error("y required");if(m==null||!e.isValid(m))throw new Error("z required")}static fromAffine(h){let{x:p,y:m}=h||{};if(!h||!e.isValid(p)||!e.isValid(m))throw new Error("invalid affine point");if(h instanceof f)throw new Error("projective point not allowed");let B=b=>e.eql(b,e.ZERO);return B(p)&&B(m)?f.ZERO:new f(p,m,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(h){let p=e.invertBatch(h.map(m=>m.pz));return h.map((m,B)=>m.toAffine(p[B])).map(f.fromAffine)}static fromHex(h){let p=f.fromAffine(s(Q("pointHex",h)));return p.assertValidity(),p}static fromPrivateKey(h){return f.BASE.multiply(c(h))}_setWindowSize(h){this._WINDOW_SIZE=h,u.delete(this)}assertValidity(){if(this.is0()){if(t.allowInfinityPoint&&!e.is0(this.py))return;throw new Error("bad point: ZERO")}let{x:h,y:p}=this.toAffine();if(!e.isValid(h)||!e.isValid(p))throw new Error("bad point: x or y not FE");let m=e.sqr(p),B=o(h);if(!e.eql(m,B))throw new Error("bad point: equation left != right");if(!this.isTorsionFree())throw new Error("bad point: not in prime-order subgroup")}hasEvenY(){let{y:h}=this.toAffine();if(e.isOdd)return!e.isOdd(h);throw new Error("Field doesn't support isOdd")}equals(h){l(h);let{px:p,py:m,pz:B}=this,{px:b,py:T,pz:x}=h,A=e.eql(e.mul(p,x),e.mul(b,B)),N=e.eql(e.mul(m,x),e.mul(T,B));return A&&N}negate(){return new f(this.px,e.neg(this.py),this.pz)}double(){let{a:h,b:p}=t,m=e.mul(p,Ha),{px:B,py:b,pz:T}=this,x=e.ZERO,A=e.ZERO,N=e.ZERO,R=e.mul(B,B),$=e.mul(b,b),M=e.mul(T,T),V=e.mul(B,b);return V=e.add(V,V),N=e.mul(B,T),N=e.add(N,N),x=e.mul(h,N),A=e.mul(m,M),A=e.add(x,A),x=e.sub($,A),A=e.add($,A),A=e.mul(x,A),x=e.mul(V,x),N=e.mul(m,N),M=e.mul(h,M),V=e.sub(R,M),V=e.mul(h,V),V=e.add(V,N),N=e.add(R,R),R=e.add(N,R),R=e.add(R,M),R=e.mul(R,V),A=e.add(A,R),M=e.mul(b,T),M=e.add(M,M),R=e.mul(M,V),x=e.sub(x,R),N=e.mul(M,$),N=e.add(N,N),N=e.add(N,N),new f(x,A,N)}add(h){l(h);let{px:p,py:m,pz:B}=this,{px:b,py:T,pz:x}=h,A=e.ZERO,N=e.ZERO,R=e.ZERO,$=t.a,M=e.mul(t.b,Ha),V=e.mul(p,b),rt=e.mul(m,T),tt=e.mul(B,x),Bt=e.add(p,m),v=e.add(b,T);Bt=e.mul(Bt,v),v=e.add(V,rt),Bt=e.sub(Bt,v),v=e.add(p,B);let I=e.add(b,x);return v=e.mul(v,I),I=e.add(V,tt),v=e.sub(v,I),I=e.add(m,B),A=e.add(T,x),I=e.mul(I,A),A=e.add(rt,tt),I=e.sub(I,A),R=e.mul($,v),A=e.mul(M,tt),R=e.add(A,R),A=e.sub(rt,R),R=e.add(rt,R),N=e.mul(A,R),rt=e.add(V,V),rt=e.add(rt,V),tt=e.mul($,tt),v=e.mul(M,v),rt=e.add(rt,tt),tt=e.sub(V,tt),tt=e.mul($,tt),v=e.add(v,tt),V=e.mul(rt,v),N=e.add(N,V),V=e.mul(I,v),A=e.mul(Bt,A),A=e.sub(A,V),V=e.mul(Bt,rt),R=e.mul(I,R),R=e.add(R,V),new f(A,N,R)}subtract(h){return this.add(h.negate())}is0(){return this.equals(f.ZERO)}wNAF(h){return w.wNAFCached(this,u,h,p=>{let m=e.invertBatch(p.map(B=>B.pz));return p.map((B,b)=>B.toAffine(m[b])).map(f.fromAffine)})}multiplyUnsafe(h){let p=f.ZERO;if(h===se)return p;if(a(h),h===kt)return this;let{endo:m}=t;if(!m)return w.unsafeLadder(this,h);let{k1neg:B,k1:b,k2neg:T,k2:x}=m.splitScalar(h),A=p,N=p,R=this;for(;b>se||x>se;)b&kt&&(A=A.add(R)),x&kt&&(N=N.add(R)),R=R.double(),b>>=kt,x>>=kt;return B&&(A=A.negate()),T&&(N=N.negate()),N=new f(e.mul(N.px,m.beta),N.py,N.pz),A.add(N)}multiply(h){a(h);let p=h,m,B,{endo:b}=t;if(b){let{k1neg:T,k1:x,k2neg:A,k2:N}=b.splitScalar(p),{p:R,f:$}=this.wNAF(x),{p:M,f:V}=this.wNAF(N);R=w.constTimeNegate(T,R),M=w.constTimeNegate(A,M),M=new f(e.mul(M.px,b.beta),M.py,M.pz),m=R.add(M),B=$.add(V)}else{let{p:T,f:x}=this.wNAF(p);m=T,B=x}return f.normalizeZ([m,B])[0]}multiplyAndAddUnsafe(h,p,m){let B=f.BASE,b=(x,A)=>A===se||A===kt||!x.equals(B)?x.multiplyUnsafe(A):x.multiply(A),T=b(this,p).add(b(h,m));return T.is0()?void 0:T}toAffine(h){let{px:p,py:m,pz:B}=this,b=this.is0();h==null&&(h=b?e.ONE:e.inv(B));let T=e.mul(p,h),x=e.mul(m,h),A=e.mul(B,h);if(b)return{x:e.ZERO,y:e.ZERO};if(!e.eql(A,e.ONE))throw new Error("invZ was invalid");return{x:T,y:x}}isTorsionFree(){let{h,isTorsionFree:p}=t;if(h===kt)return!0;if(p)return p(f,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h,clearCofactor:p}=t;return h===kt?this:p?p(f,this):this.multiplyUnsafe(t.h)}toRawBytes(h=!0){return this.assertValidity(),n(f,this,h)}toHex(h=!0){return jt(this.toRawBytes(h))}}f.BASE=new f(t.Gx,t.Gy,e.ONE),f.ZERO=new f(e.ZERO,e.ONE,e.ZERO);let d=t.nBitLength,w=Mr(f,t.endo?Math.ceil(d/2):d);return{CURVE:t,ProjectivePoint:f,normPrivateKeyToScalar:c,weierstrassEquation:o,isWithinCurveOrder:i}}function Ef(r){let t=dr(r);return Dt(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function Da(r){let t=Ef(r),{Fp:e,n}=t,s=e.BYTES+1,o=2*e.BYTES+1;function i(v){return se<v&&v<e.ORDER}function a(v){return j(v,n)}function c(v){return Pr(v,n)}let{ProjectivePoint:u,normPrivateKeyToScalar:l,weierstrassEquation:f,isWithinCurveOrder:d}=vf({...t,toBytes(v,I,H){let E=I.toAffine(),y=e.toBytes(E.x),S=zt;return H?S(Uint8Array.from([I.hasEvenY()?2:3]),y):S(Uint8Array.from([4]),y,e.toBytes(E.y))},fromBytes(v){let I=v.length,H=v[0],E=v.subarray(1);if(I===s&&(H===2||H===3)){let y=Gt(E);if(!i(y))throw new Error("Point is not on curve");let S=f(y),C=e.sqrt(S),U=(C&kt)===kt;return(H&1)===1!==U&&(C=e.neg(C)),{x:y,y:C}}else if(I===o&&H===4){let y=e.fromBytes(E.subarray(0,e.BYTES)),S=e.fromBytes(E.subarray(e.BYTES,2*e.BYTES));return{x:y,y:S}}else throw new Error(`Point of length ${I} was invalid. Expected ${s} compressed bytes or ${o} uncompressed bytes`)}}),w=v=>jt(de(v,t.nByteLength));function g(v){let I=n>>kt;return v>I}function h(v){return g(v)?a(-v):v}let p=(v,I,H)=>Gt(v.slice(I,H));class m{constructor(I,H,E){this.r=I,this.s=H,this.recovery=E,this.assertValidity()}static fromCompact(I){let H=t.nByteLength;return I=Q("compactSignature",I,H*2),new m(p(I,0,H),p(I,H,2*H))}static fromDER(I){let{r:H,s:E}=Oe.toSig(Q("DER",I));return new m(H,E)}assertValidity(){if(!d(this.r))throw new Error("r must be 0 < r < CURVE.n");if(!d(this.s))throw new Error("s must be 0 < s < CURVE.n")}addRecoveryBit(I){return new m(this.r,this.s,I)}recoverPublicKey(I){let{r:H,s:E,recovery:y}=this,S=N(Q("msgHash",I));if(y==null||![0,1,2,3].includes(y))throw new Error("recovery id invalid");let C=y===2||y===3?H+t.n:H;if(C>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let U=y&1?"03":"02",D=u.fromHex(U+w(C)),O=c(C),q=a(-S*O),K=a(E*O),F=u.BASE.multiplyAndAddUnsafe(D,q,K);if(!F)throw new Error("point at infinify");return F.assertValidity(),F}hasHighS(){return g(this.s)}normalizeS(){return this.hasHighS()?new m(this.r,a(-this.s),this.recovery):this}toDERRawBytes(){return Re(this.toDERHex())}toDERHex(){return Oe.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return Re(this.toCompactHex())}toCompactHex(){return w(this.r)+w(this.s)}}let B={isValidPrivateKey(v){try{return l(v),!0}catch{return!1}},normPrivateKeyToScalar:l,randomPrivateKey:()=>{let v=Ss(t.n);return ci(t.randomBytes(v),t.n)},precompute(v=8,I=u.BASE){return I._setWindowSize(v),I.multiply(BigInt(3)),I}};function b(v,I=!0){return u.fromPrivateKey(v).toRawBytes(I)}function T(v){let I=Nt(v),H=typeof v=="string",E=(I||H)&&v.length;return I?E===s||E===o:H?E===2*s||E===2*o:v instanceof u}function x(v,I,H=!0){if(T(v))throw new Error("first arg must be private key");if(!T(I))throw new Error("second arg must be public key");return u.fromHex(I).multiply(l(v)).toRawBytes(H)}let A=t.bits2int||function(v){let I=Gt(v),H=v.length*8-t.nBitLength;return H>0?I>>BigInt(H):I},N=t.bits2int_modN||function(v){return a(A(v))},R=hr(t.nBitLength);function $(v){if(typeof v!="bigint")throw new Error("bigint expected");if(!(se<=v&&v<R))throw new Error(`bigint expected < 2^${t.nBitLength}`);return de(v,t.nByteLength)}function M(v,I,H=V){if(["recovered","canonical"].some(J=>J in H))throw new Error("sign() legacy options not supported");let{hash:E,randomBytes:y}=t,{lowS:S,prehash:C,extraEntropy:U}=H;S==null&&(S=!0),v=Q("msgHash",v),C&&(v=Q("prehashed msgHash",E(v)));let D=N(v),O=l(I),q=[$(O),$(D)];if(U!=null){let J=U===!0?y(e.BYTES):U;q.push(Q("extraEntropy",J))}let K=zt(...q),F=D;function nt(J){let lt=A(J);if(!d(lt))return;let ut=c(lt),it=u.BASE.multiply(lt).toAffine(),ht=a(it.x);if(ht===se)return;let Mt=a(ut*a(F+ht*O));if(Mt===se)return;let Ae=(it.x===ht?0:2)|Number(it.y&kt),ar=Mt;return S&&g(Mt)&&(ar=h(Mt),Ae^=1),new m(ht,ar,Ae)}return{seed:K,k2sig:nt}}let V={lowS:t.lowS,prehash:!1},rt={lowS:t.lowS,prehash:!1};function tt(v,I,H=V){let{seed:E,k2sig:y}=M(v,I,H),S=t;return vs(S.hash.outputLen,S.nByteLength,S.hmac)(E,y)}u.BASE._setWindowSize(8);function Bt(v,I,H,E=rt){let y=v;if(I=Q("msgHash",I),H=Q("publicKey",H),"strict"in E)throw new Error("options.strict was renamed to lowS");let{lowS:S,prehash:C}=E,U,D;try{if(typeof y=="string"||Nt(y))try{U=m.fromDER(y)}catch(it){if(!(it instanceof Oe.Err))throw it;U=m.fromCompact(y)}else if(typeof y=="object"&&typeof y.r=="bigint"&&typeof y.s=="bigint"){let{r:it,s:ht}=y;U=new m(it,ht)}else throw new Error("PARSE");D=u.fromHex(H)}catch(it){if(it.message==="PARSE")throw new Error("signature must be Signature instance, Uint8Array or hex string");return!1}if(S&&U.hasHighS())return!1;C&&(I=t.hash(I));let{r:O,s:q}=U,K=N(I),F=c(q),nt=a(K*F),J=a(O*F),lt=u.BASE.multiplyAndAddUnsafe(D,nt,J)?.toAffine();return lt?a(lt.x)===O:!1}return{CURVE:t,getPublicKey:b,getSharedSecret:x,sign:tt,verify:Bt,ProjectivePoint:u,Signature:m,utils:B}}function Af(r){return{hash:r,hmac:(t,...e)=>mr(r,t,Vr(...e)),randomBytes:We}}function Oa(r,t){let e=n=>Da({...r,...Af(n)});return Object.freeze({...e(t),create:e})}var Ma=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),Pa=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),kf=BigInt(1),io=BigInt(2),Ka=(r,t)=>(r+t/io)/t;function Sf(r){let t=Ma,e=BigInt(3),n=BigInt(6),s=BigInt(11),o=BigInt(22),i=BigInt(23),a=BigInt(44),c=BigInt(88),u=r*r*r%t,l=u*u*r%t,f=W(l,e,t)*l%t,d=W(f,e,t)*l%t,w=W(d,io,t)*u%t,g=W(w,s,t)*w%t,h=W(g,o,t)*g%t,p=W(h,a,t)*h%t,m=W(p,c,t)*p%t,B=W(m,a,t)*h%t,b=W(B,e,t)*l%t,T=W(b,i,t)*g%t,x=W(T,n,t)*u%t,A=W(x,io,t);if(!ao.eql(ao.sqr(A),r))throw new Error("Cannot find square root");return A}var ao=Kr(Ma,void 0,void 0,{sqrt:Sf}),Vt=Oa({a:BigInt(0),b:BigInt(7),Fp:ao,n:Pa,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=Pa,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-kf*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),s=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),o=e,i=BigInt("0x100000000000000000000000000000000"),a=Ka(o*r,t),c=Ka(-n*r,t),u=j(r-a*e-c*s,t),l=j(-a*n-c*o,t),f=u>i,d=l>i;if(f&&(u=t-u),d&&(l=t-l),u>i||l>i)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:f,k1:u,k2neg:d,k2:l}}}},$n),Vg=BigInt(0);var Hg=Vt.ProjectivePoint;function Fa(){return Vt.utils.randomPrivateKey()}function $a(r,t){let e=bt.digest(t instanceof Uint8Array?t:t.subarray());if(Et(e))return e.then(({digest:n})=>Vt.sign(n,r).toDERRawBytes()).catch(n=>{throw new _(String(n),"ERR_INVALID_INPUT")});try{return Vt.sign(e.digest,r).toDERRawBytes()}catch(n){throw new _(String(n),"ERR_INVALID_INPUT")}}function qa(r,t,e){let n=bt.digest(e instanceof Uint8Array?e:e.subarray());if(Et(n))return n.then(({digest:s})=>Vt.verify(t,s,r)).catch(s=>{throw new _(String(s),"ERR_INVALID_INPUT")});try{return Vt.verify(t,n.digest,r)}catch(s){throw new _(String(s),"ERR_INVALID_INPUT")}}function ja(r){return Vt.ProjectivePoint.fromHex(r).toRawBytes(!0)}function Ga(r){try{Vt.getPublicKey(r,!0)}catch(t){throw new _(String(t),"ERR_INVALID_PRIVATE_KEY")}}function co(r){try{Vt.ProjectivePoint.fromHex(r)}catch(t){throw new _(String(t),"ERR_INVALID_PUBLIC_KEY")}}function za(r){try{return Vt.getPublicKey(r,!0)}catch(t){throw new _(String(t),"ERR_INVALID_PRIVATE_KEY")}}var Pe=class{_key;constructor(t){co(t),this._key=t}verify(t,e){return qa(this._key,e,t)}marshal(){return ja(this._key)}get bytes(){return Ct.encode({Type:G.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return St(this.bytes,t.bytes)}async hash(){let t=bt.digest(this.bytes),e;return Et(t)?{bytes:e}=await t:e=t.bytes,e}},Ke=class{_key;_publicKey;constructor(t,e){this._key=t,this._publicKey=e??za(t),Ga(this._key),co(this._publicKey)}sign(t){return $a(this._key,t)}get public(){return new Pe(this._publicKey)}marshal(){return this._key}get bytes(){return _t.encode({Type:G.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return St(this.bytes,t.bytes)}hash(){let t=bt.digest(this.bytes);return Et(t)?t.then(({bytes:e})=>e):t.bytes}async id(){let t=await this.public.hash();return st(t,"base58btc")}async export(t,e="libp2p-key"){if(e==="libp2p-key")return Qe(this.bytes,t);throw new _(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function Nf(r){return new Ke(r)}function Rf(r){return new Pe(r)}async function Tf(){let r=Fa();return new Ke(r)}var oe={rsa:so,ed25519:Gs,secp256k1:lo};function uo(r){let t=Object.keys(oe).join(" / ");return new _(`invalid or unsupported key type ${r}. Must be ${t}`,"ERR_UNSUPPORTED_KEY_TYPE")}function fo(r){if(r=r.toLowerCase(),r==="rsa"||r==="ed25519"||r==="secp256k1")return oe[r];throw uo(r)}async function Cf(r,t){return fo(r).generateKeyPair(t??2048)}async function _f(r,t,e){if(r.toLowerCase()!=="ed25519")throw new _("Seed key derivation is unimplemented for RSA or secp256k1","ERR_UNSUPPORTED_KEY_DERIVATION_TYPE");return js(t)}function Uf(r){let t=Ct.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case G.RSA:return oe.rsa.unmarshalRsaPublicKey(e);case G.Ed25519:return oe.ed25519.unmarshalEd25519PublicKey(e);case G.Secp256k1:return oe.secp256k1.unmarshalSecp256k1PublicKey(e);default:throw uo(t.Type??"unknown")}}function Lf(r,t){return t=(t??"rsa").toLowerCase(),fo(t),r.bytes}async function Za(r){let t=_t.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case G.RSA:return oe.rsa.unmarshalRsaPrivateKey(e);case G.Ed25519:return oe.ed25519.unmarshalEd25519PrivateKey(e);case G.Secp256k1:return oe.secp256k1.unmarshalSecp256k1PrivateKey(e);default:throw uo(t.Type??"RSA")}}function Vf(r,t){return t=(t??"rsa").toLowerCase(),fo(t),r.bytes}async function Hf(r,t){try{let e=await Oi(r,t);return await Za(e)}catch{}if(!r.includes("BEGIN"))throw new _("Encrypted key was not a libp2p-key or a PEM file","ERR_INVALID_IMPORT_FORMAT");return eo(r,t)}var go=(r,t)=>r<<t|r>>>32-t>>>0,Df=(r,t,e)=>r&t^~r&e,Of=(r,t,e)=>r&t^r&e^t&e,Ir=new Uint32Array([1732584193,4023233417,2562383102,271733878,3285377520]),Ee=new Uint32Array(80),po=class extends ce{constructor(){super(64,20,8,!1),this.A=Ir[0]|0,this.B=Ir[1]|0,this.C=Ir[2]|0,this.D=Ir[3]|0,this.E=Ir[4]|0}get(){let{A:t,B:e,C:n,D:s,E:o}=this;return[t,e,n,s,o]}set(t,e,n,s,o){this.A=t|0,this.B=e|0,this.C=n|0,this.D=s|0,this.E=o|0}process(t,e){for(let c=0;c<16;c++,e+=4)Ee[c]=t.getUint32(e,!1);for(let c=16;c<80;c++)Ee[c]=go(Ee[c-3]^Ee[c-8]^Ee[c-14]^Ee[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=Df(s,o,i),l=1518500249):c<40?(u=s^o^i,l=1859775393):c<60?(u=Of(s,o,i),l=2400959708):(u=s^o^i,l=3395469782);let f=go(n,5)+u+a+l+Ee[c]|0;a=i,i=o,o=go(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(){Ee.fill(0)}destroy(){this.set(0,0,0,0,0),this.buffer.fill(0)}},Ya=Ye(()=>new po);var Wa={sha1:Ya,"sha2-256":$n,"sha2-512":fe};function yo(r,t,e,n,s){if(s!=="sha1"&&s!=="sha2-256"&&s!=="sha2-512"){let a=Object.keys(Wa).join(" / ");throw new _(`Hash '${s}' is unknown or not supported. Must be ${a}`,"ERR_UNSUPPORTED_HASH_TYPE")}let o=Wa[s],i=$i(o,r,t,{c:e,dkLen:n});return Ie.encode(i).substring(1)}return hc(Pf);})();
6
+ `)}`:`${e} :`}};ta=me;k.Constructed=ta;me.NAME="CONSTRUCTED";var dn=class extends gt{fromBER(t,e,n){return e}toBER(t){return Ut}};dn.override="EndOfContentValueBlock";var ea,gn=class extends ft{constructor(t={}){super(t,dn),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};ea=gn;k.EndOfContent=ea;gn.NAME=Br;var ra,be=class extends ft{constructor(t={}){super(t,gt),this.idBlock.tagClass=1,this.idBlock.tagNumber=5}fromBER(t,e,n){return this.lenBlock.length>0&&this.warnings.push("Non-zero length of value block for Null type"),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.blockLength+=n,e+n>t.byteLength?(this.error="End of input reached before message was fully decoded (inconsistent offset and length values)",-1):e+n}toBER(t,e){let n=new ArrayBuffer(2);if(!t){let s=new Uint8Array(n);s[0]=5,s[1]=0}return e&&e.write(n),n}onAsciiEncoding(){return`${this.constructor.NAME}`}};ra=be;k.Null=ra;be.NAME="NULL";var pn=class extends re(gt){constructor({value:t,...e}={}){super(e),e.valueHex?this.valueHexView=P.BufferSourceConverter.toUint8Array(e.valueHex):this.valueHexView=new Uint8Array(1),t&&(this.value=t)}get value(){for(let t of this.valueHexView)if(t>0)return!0;return!1}set value(t){this.valueHexView[0]=t?255:0}fromBER(t,e,n){let s=P.BufferSourceConverter.toUint8Array(t);return ee(this,s,e,n)?(this.valueHexView=s.subarray(e,e+n),n>1&&this.warnings.push("Boolean value encoded in more then 1 octet"),this.isHexOnly=!0,Qs.call(this),this.blockLength=n,e+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};pn.NAME="BooleanValueBlock";var na,yn=class extends ft{constructor(t={}){super(t,pn),this.idBlock.tagClass=1,this.idBlock.tagNumber=1}getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.getValue}`}};na=yn;k.Boolean=na;yn.NAME="BOOLEAN";var mn=class extends re(Dt){constructor({isConstructed:t=!1,...e}={}){super(e),this.isConstructed=t}fromBER(t,e,n){let s=0;if(this.isConstructed){if(this.isHexOnly=!1,s=Dt.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let o=0;o<this.value.length;o++){let i=this.value[o].constructor.NAME;if(i===Br){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(i!==Wi)return this.error="OCTET STRING may consists of OCTET STRINGs only",-1}}else this.isHexOnly=!0,s=super.fromBER(t,e,n),this.blockLength=n;return s}toBER(t,e){return this.isConstructed?Dt.prototype.toBER.call(this,t,e):t?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};mn.NAME="OctetStringValueBlock";var sa,Qt=class r extends ft{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,o;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((o=n.value)===null||o===void 0)&&o.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},mn),this.idBlock.tagClass=1,this.idBlock.tagNumber=4}fromBER(t,e,n){if(this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,n===0)return this.idBlock.error.length===0&&(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length===0&&(this.blockLength+=this.lenBlock.blockLength),e;if(!this.valueBlock.isConstructed){let o=(t instanceof ArrayBuffer?new Uint8Array(t):t).subarray(e,e+n);try{if(o.byteLength){let i=jn(o,0,o.byteLength);i.offset!==-1&&i.offset===n&&(this.valueBlock.value=[i.result])}}catch{}}return super.fromBER(t,e,n)}onAsciiEncoding(){return this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length?me.prototype.onAsciiEncoding.call(this):`${this.constructor.NAME} : ${P.Convert.ToHex(this.valueBlock.valueHexView)}`}getValue(){if(!this.idBlock.isConstructed)return this.valueBlock.valueHexView.slice().buffer;let t=[];for(let e of this.valueBlock.value)e instanceof r&&t.push(e.valueBlock.valueHexView);return P.BufferSourceConverter.concat(t)}};sa=Qt;k.OctetString=sa;Qt.NAME=Wi;var bn=class extends re(Dt){constructor({unusedBits:t=0,isConstructed:e=!1,...n}={}){super(n),this.unusedBits=t,this.isConstructed=e,this.blockLength=this.valueHexView.byteLength}fromBER(t,e,n){if(!n)return e;let s=-1;if(this.isConstructed){if(s=Dt.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let a of this.value){let c=a.constructor.NAME;if(c===Br){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==Ji)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=P.BufferSourceConverter.toUint8Array(t);if(!ee(this,o,e,n))return-1;let i=o.subarray(e,e+n);if(this.unusedBits=i[0],this.unusedBits>7)return this.error="Unused bits for BitString must be in range 0-7",-1;if(!this.unusedBits){let a=i.subarray(1);try{if(a.byteLength){let c=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,e+n}toBER(t,e){if(this.isConstructed)return Dt.prototype.toBER.call(this,t,e);if(t)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return Ut;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 oa,or=class extends ft{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,o;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((o=n.value)===null||o===void 0)&&o.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},bn),this.idBlock.tagClass=1,this.idBlock.tagNumber=3}fromBER(t,e,n){return this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,super.fromBER(t,e,n)}onAsciiEncoding(){if(this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length)return me.prototype.onAsciiEncoding.call(this);{let t=[],e=this.valueBlock.valueHexView;for(let s of e)t.push(s.toString(2).padStart(8,"0"));let n=t.join("");return`${this.constructor.NAME} : ${n.substring(0,n.length-this.valueBlock.unusedBits)}`}}};oa=or;k.BitString=oa;or.NAME=Ji;var ia;function tf(r,t){let e=new Uint8Array([0]),n=new Uint8Array(r),s=new Uint8Array(t),o=n.slice(0),i=o.length-1,a=s.slice(0),c=a.length-1,u=0,l=c<i?i:c,f=0;for(let d=l;d>=0;d--,f++){switch(!0){case f<a.length:u=o[i-f]+a[c-f]+e[0];break;default:u=o[i-f]+e[0]}switch(e[0]=u/10,!0){case f>=o.length:o=on(new Uint8Array([u%10]),o);break;default:o[i-f]=u%10}}return e[0]>0&&(o=on(e,o)),o}function Yi(r){if(r>=wr.length)for(let t=wr.length;t<=r;t++){let e=new Uint8Array([0]),n=wr[t-1].slice(0);for(let s=n.length-1;s>=0;s--){let o=new Uint8Array([(n[s]<<1)+e[0]]);e[0]=o[0]/10,n[s]=o[0]%10}e[0]>0&&(n=on(e,n)),wr.push(n)}return wr[r]}function ef(r,t){let e=0,n=new Uint8Array(r),s=new Uint8Array(t),o=n.slice(0),i=o.length-1,a=s.slice(0),c=a.length-1,u,l=0;for(let f=c;f>=0;f--,l++)switch(u=o[i-l]-a[c-l]-e,!0){case u<0:e=1,o[i-l]=u+10;break;default:e=0,o[i-l]=u}if(e>0)for(let f=i-c+1;f>=0;f--,l++)if(u=o[i-l]-e,u<0)e=1,o[i-l]=u+10;else{e=0,o[i-l]=u;break}return o.slice()}var vr=class extends re(gt){constructor({value:t,...e}={}){super(e),this._valueDec=0,e.valueHex&&this.setValueHex(),t!==void 0&&(this.valueDec=t)}setValueHex(){this.valueHexView.length>=4?(this.warnings.push("Too big Integer for decoding, hex only"),this.isHexOnly=!0,this._valueDec=0):(this.isHexOnly=!1,this.valueHexView.length>0&&(this._valueDec=Qs.call(this)))}set valueDec(t){this._valueDec=t,this.isHexOnly=!1,this.valueHexView=new Uint8Array(Gi(t))}get valueDec(){return this._valueDec}fromDER(t,e,n,s=0){let o=this.fromBER(t,e,n);if(o===-1)return o;let i=this.valueHexView;return i[0]===0&&i[1]&128?this.valueHexView=i.subarray(1):s!==0&&i.length<s&&(s-i.length>1&&(s=i.length+1),this.valueHexView=i.subarray(s-i.length)),o}toDER(t=!1){let e=this.valueHexView;switch(!0){case(e[0]&128)!==0:{let n=new Uint8Array(this.valueHexView.length+1);n[0]=0,n.set(e,1),this.valueHexView=n}break;case(e[0]===0&&(e[1]&128)===0):this.valueHexView=this.valueHexView.subarray(1);break}return this.toBER(t)}fromBER(t,e,n){let s=super.fromBER(t,e,n);return s===-1||this.setValueHex(),s}toBER(t){return t?new ArrayBuffer(this.valueHexView.length):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}toString(){let t=this.valueHexView.length*8-1,e=new Uint8Array(this.valueHexView.length*8/3),n=0,s,o=this.valueHexView,i="",a=!1;for(let c=o.byteLength-1;c>=0;c--){s=o[c];for(let u=0;u<8;u++){if((s&1)===1)switch(n){case t:e=ef(Yi(n),e),i="-";break;default:e=tf(e,Yi(n))}n++,s>>=1}}for(let c=0;c<e.length;c++)e[c]&&(a=!0),a&&(i+=Zi.charAt(e[c]));return a===!1&&(i+=Zi.charAt(0)),i}};ia=vr;vr.NAME="IntegerValueBlock";Object.defineProperty(ia.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var aa,ot=class r extends ft{constructor(t={}){super(t,vr),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return an(),BigInt(this.valueBlock.toString())}static fromBigInt(t){an();let e=BigInt(t),n=new xr,s=e.toString(16).replace(/^-/,""),o=new Uint8Array(P.Convert.FromHex(s));if(e<0){let a=new Uint8Array(o.length+(o[0]&128?1:0));a[0]|=128;let u=BigInt(`0x${P.Convert.ToHex(a)}`)+e,l=P.BufferSourceConverter.toUint8Array(P.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 t=new r({valueHex:this.valueBlock.valueHexView});return t.valueBlock.toDER(),t}convertFromDER(){return new r({valueHex:this.valueBlock.valueHexView[0]===0?this.valueBlock.valueHexView.subarray(1):this.valueBlock.valueHexView})}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()}`}};aa=ot;k.Integer=aa;ot.NAME="INTEGER";var ca,wn=class extends ot{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};ca=wn;k.Enumerated=ca;wn.NAME="ENUMERATED";var Er=class extends re(gt){constructor({valueDec:t=-1,isFirstSid:e=!1,...n}={}){super(n),this.valueDec=t,this.isFirstSid=e}fromBER(t,e,n){if(!n)return e;let s=P.BufferSourceConverter.toUint8Array(t);if(!ee(this,s,e,n))return-1;let o=s.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=o[a]&127,this.blockLength++,!!(o[a]&128));a++);let i=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)i[a]=this.valueHexView[a];return this.valueHexView=i,o[this.blockLength-1]&128?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=Le(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}set valueBigInt(t){an();let e=BigInt(t).toString(2);for(;e.length%7;)e="0"+e;let n=new Uint8Array(e.length/7);for(let s=0;s<n.length;s++)n[s]=parseInt(e.slice(s*7,s*7+7),2)+(s+1<n.length?128:0);this.fromBER(n.buffer,0,n.length)}toBER(t){if(this.isHexOnly){if(t)return new ArrayBuffer(this.valueHexView.byteLength);let s=this.valueHexView,o=new Uint8Array(this.blockLength);for(let i=0;i<this.blockLength-1;i++)o[i]=s[i]|128;return o[this.blockLength-1]=s[this.blockLength-1],o.buffer}let e=ye(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Ut;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),o=e.byteLength-1;for(let i=0;i<o;i++)n[i]=s[i]|128;n[o]=s[o]}return n}toString(){let t="";if(this.isHexOnly)t=P.Convert.ToHex(this.valueHexView);else if(this.isFirstSid){let e=this.valueDec;this.valueDec<=39?t="0.":this.valueDec<=79?(t="1.",e-=40):(t="2.",e-=80),t+=e.toString()}else t=this.valueDec.toString();return t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec,isFirstSid:this.isFirstSid}}};Er.NAME="sidBlock";var xn=class extends gt{constructor({value:t=ir,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new Er;if(s=o.fromBER(t,s,n),s===-1)return this.blockLength=0,this.error=o.error,s;this.value.length===0&&(o.isFirstSid=!0),this.blockLength+=o.blockLength,n-=o.blockLength,this.value.push(o)}return s}toBER(t){let e=[];for(let n=0;n<this.value.length;n++){let s=this.value[n].toBER(t);if(s.byteLength===0)return this.error=this.value[n].error,Ut;e.push(s)}return to(e)}fromString(t){this.value=[];let e=0,n=0,s="",o=!1;do if(n=t.indexOf(".",e),n===-1?s=t.substring(e):s=t.substring(e,n),e=n+1,o){let i=this.value[0],a=0;switch(i.valueDec){case 0:break;case 1:a=40;break;case 2:a=80;break;default:this.value=[];return}let c=parseInt(s,10);if(isNaN(c))return;i.valueDec=c+a,o=!1}else{let i=new Er;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 t="",e=!1;for(let n=0;n<this.value.length;n++){e=this.value[n].isHexOnly;let s=this.value[n].toString();n!==0&&(t=`${t}.`),e?(s=`{${s}}`,this.value[n].isFirstSid?t=`2.{${s} - 80}`:t+=s):t+=s}return t}toJSON(){let t={...super.toJSON(),value:this.toString(),sidArray:[]};for(let e=0;e<this.value.length;e++)t.sidArray.push(this.value[e].toJSON());return t}};xn.NAME="ObjectIdentifierValueBlock";var la,_t=class extends ft{constructor(t={}){super(t,xn),this.idBlock.tagClass=1,this.idBlock.tagNumber=6}getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};la=_t;k.ObjectIdentifier=la;_t.NAME="OBJECT IDENTIFIER";var Ar=class extends re(Xt){constructor({valueDec:t=0,...e}={}){super(e),this.valueDec=t}fromBER(t,e,n){if(n===0)return e;let s=P.BufferSourceConverter.toUint8Array(t);if(!ee(this,s,e,n))return-1;let o=s.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=o[a]&127,this.blockLength++,!!(o[a]&128));a++);let i=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)i[a]=this.valueHexView[a];return this.valueHexView=i,o[this.blockLength-1]&128?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=Le(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}toBER(t){if(this.isHexOnly){if(t)return new ArrayBuffer(this.valueHexView.byteLength);let s=this.valueHexView,o=new Uint8Array(this.blockLength);for(let i=0;i<this.blockLength-1;i++)o[i]=s[i]|128;return o[this.blockLength-1]=s[this.blockLength-1],o.buffer}let e=ye(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Ut;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),o=e.byteLength-1;for(let i=0;i<o;i++)n[i]=s[i]|128;n[o]=s[o]}return n.buffer}toString(){let t="";return this.isHexOnly?t=P.Convert.ToHex(this.valueHexView):t=this.valueDec.toString(),t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};Ar.NAME="relativeSidBlock";var Bn=class extends gt{constructor({value:t=ir,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new Ar;if(s=o.fromBER(t,s,n),s===-1)return this.blockLength=0,this.error=o.error,s;this.blockLength+=o.blockLength,n-=o.blockLength,this.value.push(o)}return s}toBER(t,e){let n=[];for(let s=0;s<this.value.length;s++){let o=this.value[s].toBER(t);if(o.byteLength===0)return this.error=this.value[s].error,Ut;n.push(o)}return to(n)}fromString(t){this.value=[];let e=0,n=0,s="";do{n=t.indexOf(".",e),n===-1?s=t.substring(e):s=t.substring(e,n),e=n+1;let o=new Ar;if(o.valueDec=parseInt(s,10),isNaN(o.valueDec))return!0;this.value.push(o)}while(n!==-1);return!0}toString(){let t="",e=!1;for(let n=0;n<this.value.length;n++){e=this.value[n].isHexOnly;let s=this.value[n].toString();n!==0&&(t=`${t}.`),e&&(s=`{${s}}`),t+=s}return t}toJSON(){let t={...super.toJSON(),value:this.toString(),sidArray:[]};for(let e=0;e<this.value.length;e++)t.sidArray.push(this.value[e].toJSON());return t}};Bn.NAME="RelativeObjectIdentifierValueBlock";var ua,vn=class extends ft{constructor(t={}){super(t,Bn),this.idBlock.tagClass=1,this.idBlock.tagNumber=13}getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};ua=vn;k.RelativeObjectIdentifier=ua;vn.NAME="RelativeObjectIdentifier";var fa,ct=class extends me{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};fa=ct;k.Sequence=fa;ct.NAME="SEQUENCE";var ha,En=class extends me{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};ha=En;k.Set=ha;En.NAME="SET";var An=class extends re(gt){constructor({...t}={}){super(t),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 yt=class extends un{constructor({...t}={}){super(t,kn)}fromBuffer(t){this.valueBlock.value=String.fromCharCode.apply(null,P.BufferSourceConverter.toUint8Array(t))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e);for(let s=0;s<e;s++)n[s]=t.charCodeAt(s);this.valueBlock.value=t}};yt.NAME="SIMPLE STRING";var Sn=class extends yt{fromBuffer(t){this.valueBlock.valueHexView=P.BufferSourceConverter.toUint8Array(t);try{this.valueBlock.value=P.Convert.ToUtf8String(t)}catch(e){this.warnings.push(`Error during "decodeURIComponent": ${e}, using raw string`),this.valueBlock.value=P.Convert.ToBinary(t)}}fromString(t){this.valueBlock.valueHexView=new Uint8Array(P.Convert.FromUtf8String(t)),this.valueBlock.value=t}};Sn.NAME="Utf8StringValueBlock";var da,te=class extends Sn{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};da=te;k.Utf8String=da;te.NAME="UTF8String";var In=class extends yt{fromBuffer(t){this.valueBlock.value=P.Convert.ToUtf16String(t),this.valueBlock.valueHexView=P.BufferSourceConverter.toUint8Array(t)}fromString(t){this.valueBlock.value=t,this.valueBlock.valueHexView=new Uint8Array(P.Convert.FromUtf16String(t))}};In.NAME="BmpStringValueBlock";var ga,Nn=class extends In{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};ga=Nn;k.BmpString=ga;Nn.NAME="BMPString";var Rn=class extends yt{fromBuffer(t){let e=ArrayBuffer.isView(t)?t.slice().buffer:t.slice(0),n=new Uint8Array(e);for(let s=0;s<n.length;s+=4)n[s]=n[s+3],n[s+1]=n[s+2],n[s+2]=0,n[s+3]=0;this.valueBlock.value=String.fromCharCode.apply(null,new Uint32Array(e))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e*4);for(let s=0;s<e;s++){let o=ye(t.charCodeAt(s),8),i=new Uint8Array(o);if(i.length>4)continue;let a=4-i.length;for(let c=i.length-1;c>=0;c--)n[s*4+c+a]=i[c]}this.valueBlock.value=t}};Rn.NAME="UniversalStringValueBlock";var pa,Cn=class extends Rn{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};pa=Cn;k.UniversalString=pa;Cn.NAME="UniversalString";var ya,Tn=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};ya=Tn;k.NumericString=ya;Tn.NAME="NumericString";var ma,_n=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};ma=_n;k.PrintableString=ma;_n.NAME="PrintableString";var ba,Un=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};ba=Un;k.TeletexString=ba;Un.NAME="TeletexString";var wa,Ln=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};wa=Ln;k.VideotexString=wa;Ln.NAME="VideotexString";var xa,Vn=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};xa=Vn;k.IA5String=xa;Vn.NAME="IA5String";var Ba,Hn=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};Ba=Hn;k.GraphicString=Ba;Hn.NAME="GraphicString";var va,kr=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};va=kr;k.VisibleString=va;kr.NAME="VisibleString";var Ea,Dn=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};Ea=Dn;k.GeneralString=Ea;Dn.NAME="GeneralString";var Aa,On=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};Aa=On;k.CharacterString=Aa;On.NAME="CharacterString";var ka,Sr=class extends kr{constructor({value:t,valueDate:e,...n}={}){if(super(n),this.year=0,this.month=0,this.day=0,this.hour=0,this.minute=0,this.second=0,t){this.fromString(t),this.valueBlock.valueHexView=new Uint8Array(t.length);for(let s=0;s<t.length;s++)this.valueBlock.valueHexView[s]=t.charCodeAt(s)}e&&(this.fromDate(e),this.valueBlock.valueHexView=new Uint8Array(this.toBuffer())),this.idBlock.tagClass=1,this.idBlock.tagNumber=23}fromBuffer(t){this.fromString(String.fromCharCode.apply(null,P.BufferSourceConverter.toUint8Array(t)))}toBuffer(){let t=this.toString(),e=new ArrayBuffer(t.length),n=new Uint8Array(e);for(let s=0;s<t.length;s++)n[s]=t.charCodeAt(s);return e}fromDate(t){this.year=t.getUTCFullYear(),this.month=t.getUTCMonth()+1,this.day=t.getUTCDate(),this.hour=t.getUTCHours(),this.minute=t.getUTCMinutes(),this.second=t.getUTCSeconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second))}fromString(t){let n=/(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})Z/ig.exec(t);if(n===null){this.error="Wrong input string for conversion";return}let s=parseInt(n[1],10);s>=50?this.year=1900+s:this.year=2e3+s,this.month=parseInt(n[2],10),this.day=parseInt(n[3],10),this.hour=parseInt(n[4],10),this.minute=parseInt(n[5],10),this.second=parseInt(n[6],10)}toString(t="iso"){if(t==="iso"){let e=new Array(7);return e[0]=mt(this.year<2e3?this.year-1900:this.year-2e3,2),e[1]=mt(this.month,2),e[2]=mt(this.day,2),e[3]=mt(this.hour,2),e[4]=mt(this.minute,2),e[5]=mt(this.second,2),e[6]="Z",e.join("")}return super.toString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.toDate().toISOString()}`}toJSON(){return{...super.toJSON(),year:this.year,month:this.month,day:this.day,hour:this.hour,minute:this.minute,second:this.second}}};ka=Sr;k.UTCTime=ka;Sr.NAME="UTCTime";var Sa,Pn=class extends Sr{constructor(t={}){var e;super(t),(e=this.millisecond)!==null&&e!==void 0||(this.millisecond=0),this.idBlock.tagClass=1,this.idBlock.tagNumber=24}fromDate(t){super.fromDate(t),this.millisecond=t.getUTCMilliseconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second,this.millisecond))}fromString(t){let e=!1,n="",s="",o=0,i,a=0,c=0;if(t[t.length-1]==="Z")n=t.substring(0,t.length-1),e=!0;else{let f=new Number(t[t.length-1]);if(isNaN(f.valueOf()))throw new Error("Wrong input string for conversion");n=t}if(e){if(n.indexOf("+")!==-1)throw new Error("Wrong input string for conversion");if(n.indexOf("-")!==-1)throw new Error("Wrong input string for conversion")}else{let f=1,d=n.indexOf("+"),w="";if(d===-1&&(d=n.indexOf("-"),f=-1),d!==-1){if(w=n.substring(d+1),n=n.substring(0,d),w.length!==2&&w.length!==4)throw new Error("Wrong input string for conversion");let g=parseInt(w.substring(0,2),10);if(isNaN(g.valueOf()))throw new Error("Wrong input string for conversion");if(a=f*g,w.length===4){if(g=parseInt(w.substring(2,4),10),isNaN(g.valueOf()))throw new Error("Wrong input string for conversion");c=f*g}}}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(e===!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(t="iso"){if(t==="iso"){let e=[];return e.push(mt(this.year,4)),e.push(mt(this.month,2)),e.push(mt(this.day,2)),e.push(mt(this.hour,2)),e.push(mt(this.minute,2)),e.push(mt(this.second,2)),this.millisecond!==0&&(e.push("."),e.push(mt(this.millisecond,3))),e.push("Z"),e.join("")}return super.toString(t)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};Sa=Pn;k.GeneralizedTime=Sa;Pn.NAME="GeneralizedTime";var Ia,Kn=class extends te{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};Ia=Kn;k.DATE=Ia;Kn.NAME="DATE";var Na,Mn=class extends te{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};Na=Mn;k.TimeOfDay=Na;Mn.NAME="TimeOfDay";var Ra,Fn=class extends te{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};Ra=Fn;k.DateTime=Ra;Fn.NAME="DateTime";var Ca,$n=class extends te{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};Ca=$n;k.Duration=Ca;$n.NAME="Duration";var Ta,qn=class extends te{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};Ta=qn;k.TIME=Ta;qn.NAME="TIME";function nf(r){let{result:t}=ar(r),e=t.valueBlock.value;return{n:st(Ot(e[1].toBigInt()),"base64url"),e:st(Ot(e[2].toBigInt()),"base64url"),d:st(Ot(e[3].toBigInt()),"base64url"),p:st(Ot(e[4].toBigInt()),"base64url"),q:st(Ot(e[5].toBigInt()),"base64url"),dp:st(Ot(e[6].toBigInt()),"base64url"),dq:st(Ot(e[7].toBigInt()),"base64url"),qi:st(Ot(e[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 e=new ct({value:[new ot({value:0}),ot.fromBigInt(Pt(Z(r.n,"base64url"))),ot.fromBigInt(Pt(Z(r.e,"base64url"))),ot.fromBigInt(Pt(Z(r.d,"base64url"))),ot.fromBigInt(Pt(Z(r.p,"base64url"))),ot.fromBigInt(Pt(Z(r.q,"base64url"))),ot.fromBigInt(Pt(Z(r.dp,"base64url"))),ot.fromBigInt(Pt(Z(r.dq,"base64url"))),ot.fromBigInt(Pt(Z(r.qi,"base64url")))]}).toBER();return new Uint8Array(e,0,e.byteLength)}function of(r){let{result:t}=ar(r),e=t.valueBlock.value[1].valueBlock.value[0].valueBlock.value;return{kty:"RSA",n:st(Ot(e[0].toBigInt()),"base64url"),e:st(Ot(e[1].toBigInt()),"base64url")}}function af(r){if(r.n==null||r.e==null)throw new _("JWK was missing components","ERR_INVALID_PARAMETERS");let e=new ct({value:[new ct({value:[new _t({value:"1.2.840.113549.1.1.1"}),new be]}),new or({valueHex:new ct({value:[ot.fromBigInt(Pt(Z(r.n,"base64url"))),ot.fromBigInt(Pt(Z(r.e,"base64url")))]}).toBER()})]}).toBER();return new Uint8Array(e,0,e.byteLength)}function Ot(r){let t=r.toString(16);t.length%2>0&&(t=`0${t}`);let e=t.length/2,n=new Uint8Array(e),s=0,o=0;for(;s<e;)n[s]=parseInt(t.slice(o,o+2),16),s+=1,o+=2;return n}function Pt(r){let t=[];return r.forEach(function(e){let n=e.toString(16);n.length%2>0&&(n=`0${n}`),t.push(n)}),BigInt("0x"+t.join(""))}var cf=16,ro=32,no=1e4;async function lf(r,t){let e=z.get(),s=new ct({value:[new ot({value:0}),new ct({value:[new _t({value:"1.2.840.113549.1.1.1"}),new be]}),new Qt({valueHex:r.marshal()})]}).toBER(),o=new Uint8Array(s,0,s.byteLength),i=Wt(cf),a=await Js(ue,t,i,{c:no,dkLen:ro}),c=Wt(16),u=await e.subtle.importKey("raw",a,"AES-CBC",!1,["encrypt"]),l=await e.subtle.encrypt({name:"AES-CBC",iv:c},u,o),f=new ct({value:[new Qt({valueHex:i}),new ot({value:no}),new ot({value:ro}),new ct({value:[new _t({value:"1.2.840.113549.2.11"}),new be]})]}),d=new ct({value:[new _t({value:"1.2.840.113549.1.5.13"}),new ct({value:[new ct({value:[new _t({value:"1.2.840.113549.1.5.12"}),f]}),new ct({value:[new _t({value:"2.16.840.1.101.3.4.1.42"}),new Qt({valueHex:c})]})]})]}),g=new ct({value:[d,new Qt({valueHex:l})]}).toBER(),h=new Uint8Array(g,0,g.byteLength);return["-----BEGIN ENCRYPTED PRIVATE KEY-----",...st(h,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
7
+ `)}async function so(r,t){let e=z.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:u,cipherText:l}=uf(o),f=await Js(ue,t,a,{c,dkLen:u}),d=await e.subtle.importKey("raw",f,"AES-CBC",!1,["decrypt"]),w=Ir(await e.subtle.decrypt({name:"AES-CBC",iv:i},d,l)),{result:g}=ar(w);n=_a(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=_a(o)}else throw new _("Could not parse private key from PEM data","ERR_INVALID_PARAMETERS");return oo(n)}function uf(r){let t=r.valueBlock.value[0];if(t.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=t.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=Ir(o.valueBlock.value[0].getValue()),a=no,c=ro;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 u=t.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 _("Only AES-CBC encryption schemes are supported","ERR_INVALID_PARAMS")}}}}let f=Ir(u.valueBlock.value[1].getValue());return{cipherText:Ir(r.valueBlock.value[1].getValue()),salt:i,iterations:a,keySize:c,iv:f}}function _a(r){return Ir(r.valueBlock.value[2].getValue())}function Ir(r){return new Uint8Array(r,0,r.byteLength)}async function Ua(r){let t=await z.get().subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:r,publicExponent:new Uint8Array([1,0,1]),hash:{name:"SHA-256"}},!0,["sign","verify"]),e=await Ha(t);return{privateKey:e[0],publicKey:e[1]}}async function io(r){let e=[await z.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["sign"]),await ff(r)],n=await Ha({privateKey:e[0],publicKey:e[1]});return{privateKey:n[0],publicKey:n[1]}}async function La(r,t){let e=await z.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await z.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},e,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(n,0,n.byteLength)}async function Va(r,t,e){let n=await z.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return z.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,t,e instanceof Uint8Array?e:e.subarray())}async function Ha(r){if(r.privateKey==null||r.publicKey==null)throw new _("Private and public key are required","ERR_INVALID_PARAMETERS");return Promise.all([z.get().subtle.exportKey("jwk",r.privateKey),z.get().subtle.exportKey("jwk",r.publicKey)])}async function ff(r){return z.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 Gn(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 He=8192,Ve=class{_key;constructor(t){this._key=t}verify(t,e){return Va(this._key,e,t)}marshal(){return we.jwkToPkix(this._key)}get bytes(){return Ct.encode({Type:G.RSA,Data:this.marshal()}).subarray()}equals(t){return St(this.bytes,t.bytes)}hash(){let t=bt.digest(this.bytes);return Et(t)?t.then(({bytes:e})=>e):t.bytes}},xe=class{_key;_publicKey;constructor(t,e){this._key=t,this._publicKey=e}genSecret(){return Wt(16)}sign(t){return La(this._key,t)}get public(){if(this._publicKey==null)throw new _("public key not provided","ERR_PUBKEY_NOT_PROVIDED");return new Ve(this._publicKey)}marshal(){return we.jwkToPkcs1(this._key)}get bytes(){return Tt.encode({Type:G.RSA,Data:this.marshal()}).subarray()}equals(t){return St(this.bytes,t.bytes)}hash(){let t=bt.digest(this.bytes);return Et(t)?t.then(({bytes:e})=>e):t.bytes}async id(){let t=await this.public.hash();return st(t,"base58btc")}async export(t,e="pkcs-8"){if(e==="pkcs-8")return we.exportToPem(this,t);if(e==="libp2p-key")return tr(this.bytes,t);throw new _(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};async function oo(r){let t=we.pkcs1ToJwk(r);if(Gn(t)>He)throw new _("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await io(t);return new xe(e.privateKey,e.publicKey)}function df(r){let t=we.pkixToJwk(r);if(Gn(t)>He)throw new _("key size is too large","ERR_KEY_SIZE_TOO_LARGE");return new Ve(t)}async function gf(r){if(Gn(r)>He)throw new _("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await io(r);return new xe(t.privateKey,t.publicKey)}async function pf(r){if(r>He)throw new _("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await Ua(r);return new xe(t.privateKey,t.publicKey)}var ho={};et(ho,{Secp256k1PrivateKey:()=>Pe,Secp256k1PublicKey:()=>Oe,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]),Be=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),ve=new Uint32Array(64),co=class extends ae{constructor(){super(64,32,8,!1),this.A=Be[0]|0,this.B=Be[1]|0,this.C=Be[2]|0,this.D=Be[3]|0,this.E=Be[4]|0,this.F=Be[5]|0,this.G=Be[6]|0,this.H=Be[7]|0}get(){let{A:t,B:e,C:n,D:s,E:o,F:i,G:a,H:c}=this;return[t,e,n,s,o,i,a,c]}set(t,e,n,s,o,i,a,c){this.A=t|0,this.B=e|0,this.C=n|0,this.D=s|0,this.E=o|0,this.F=i|0,this.G=a|0,this.H=c|0}process(t,e){for(let f=0;f<16;f++,e+=4)ve[f]=t.getUint32(e,!1);for(let f=16;f<64;f++){let d=ve[f-15],w=ve[f-2],g=It(d,7)^It(d,18)^d>>>3,h=It(w,17)^It(w,19)^w>>>10;ve[f]=h+ve[f-7]+g+ve[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 d=It(a,6)^It(a,11)^It(a,25),w=l+d+Or(a,c,u)+yf[f]+ve[f]|0,h=(It(n,2)^It(n,13)^It(n,22))+Pr(n,s,o)|0;l=u,u=c,c=a,a=i+w|0,i=o,o=s,s=n,n=w+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,u=u+this.G|0,l=l+this.H|0,this.set(n,s,o,i,a,c,u,l)}roundClean(){ve.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var zn=Ye(()=>new co);function mf(r){let t=gr(r);Ht(t,{a:"field",b:"field"},{allowedPrivateKeyLengths:"array",wrapPrivateKey:"boolean",isTorsionFree:"function",clearCofactor:"function",allowInfinityPoint:"boolean",fromBytes:"function",toBytes:"function"});let{endo:e,Fp:n,a:s}=t;if(e){if(!n.eql(s,n.ZERO))throw new Error("Endomorphism can only be defined for Koblitz curves that have a=0");if(typeof e!="object"||typeof e.beta!="bigint"||typeof e.splitScalar!="function")throw new Error("Expected endomorphism with beta: bigint and splitScalar: function")}return Object.freeze({...t})}var{bytesToNumberBE:bf,hexToBytes:wf}=Fr,De={Err:class extends Error{constructor(t=""){super(t)}},_parseInt(r){let{Err:t}=De;if(r.length<2||r[0]!==2)throw new t("Invalid signature integer tag");let e=r[1],n=r.subarray(2,e+2);if(!e||n.length!==e)throw new t("Invalid signature integer: wrong length");if(n[0]&128)throw new t("Invalid signature integer: negative");if(n[0]===0&&!(n[1]&128))throw new t("Invalid signature integer: unnecessary leading zero");return{d:bf(n),l:r.subarray(e+2)}},toSig(r){let{Err:t}=De,e=typeof r=="string"?wf(r):r;Je(e);let n=e.length;if(n<2||e[0]!=48)throw new t("Invalid signature tag");if(e[1]!==n-2)throw new t("Invalid signature: incorrect length");let{d:s,l:o}=De._parseInt(e.subarray(2)),{d:i,l:a}=De._parseInt(o);if(a.length)throw new t("Invalid signature: left bytes after parsing");return{r:s,s:i}},hexFromSig(r){let t=u=>Number.parseInt(u[0],16)&8?"00"+u:u,e=u=>{let l=u.toString(16);return l.length&1?`0${l}`:l},n=t(e(r.s)),s=t(e(r.r)),o=n.length/2,i=s.length/2,a=e(o),c=e(i);return`30${e(i+o+4)}02${c}${s}02${a}${n}`}},ne=BigInt(0),kt=BigInt(1),vg=BigInt(2),Da=BigInt(3),Eg=BigInt(4);function xf(r){let t=mf(r),{Fp:e}=t,n=t.toBytes||((g,h,p)=>{let m=h.toAffine();return Gt(Uint8Array.from([4]),e.toBytes(m.x),e.toBytes(m.y))}),s=t.fromBytes||(g=>{let h=g.subarray(1),p=e.fromBytes(h.subarray(0,e.BYTES)),m=e.fromBytes(h.subarray(e.BYTES,2*e.BYTES));return{x:p,y:m}});function o(g){let{a:h,b:p}=t,m=e.sqr(g),B=e.mul(m,g);return e.add(e.add(B,e.mul(g,h)),p)}if(!e.eql(e.sqr(t.Gy),o(t.Gx)))throw new Error("bad generator point: equation left != right");function i(g){return typeof g=="bigint"&&ne<g&&g<t.n}function a(g){if(!i(g))throw new Error("Expected valid bigint: 0 < bigint < curve.n")}function c(g){let{allowedPrivateKeyLengths:h,nByteLength:p,wrapPrivateKey:m,n:B}=t;if(h&&typeof g!="bigint"){if(fe(g)&&(g=qt(g)),typeof g!="string"||!h.includes(g.length))throw new Error("Invalid key");g=g.padStart(p*2,"0")}let b;try{b=typeof g=="bigint"?g:jt(Q("private key",g,p))}catch{throw new Error(`private key must be ${p} bytes, hex or bigint, not ${typeof g}`)}return m&&(b=j(b,B)),a(b),b}let u=new Map;function l(g){if(!(g instanceof f))throw new Error("ProjectivePoint expected")}class f{constructor(h,p,m){if(this.px=h,this.py=p,this.pz=m,h==null||!e.isValid(h))throw new Error("x required");if(p==null||!e.isValid(p))throw new Error("y required");if(m==null||!e.isValid(m))throw new Error("z required")}static fromAffine(h){let{x:p,y:m}=h||{};if(!h||!e.isValid(p)||!e.isValid(m))throw new Error("invalid affine point");if(h instanceof f)throw new Error("projective point not allowed");let B=b=>e.eql(b,e.ZERO);return B(p)&&B(m)?f.ZERO:new f(p,m,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(h){let p=e.invertBatch(h.map(m=>m.pz));return h.map((m,B)=>m.toAffine(p[B])).map(f.fromAffine)}static fromHex(h){let p=f.fromAffine(s(Q("pointHex",h)));return p.assertValidity(),p}static fromPrivateKey(h){return f.BASE.multiply(c(h))}_setWindowSize(h){this._WINDOW_SIZE=h,u.delete(this)}assertValidity(){if(this.is0()){if(t.allowInfinityPoint&&!e.is0(this.py))return;throw new Error("bad point: ZERO")}let{x:h,y:p}=this.toAffine();if(!e.isValid(h)||!e.isValid(p))throw new Error("bad point: x or y not FE");let m=e.sqr(p),B=o(h);if(!e.eql(m,B))throw new Error("bad point: equation left != right");if(!this.isTorsionFree())throw new Error("bad point: not in prime-order subgroup")}hasEvenY(){let{y:h}=this.toAffine();if(e.isOdd)return!e.isOdd(h);throw new Error("Field doesn't support isOdd")}equals(h){l(h);let{px:p,py:m,pz:B}=this,{px:b,py:C,pz:x}=h,A=e.eql(e.mul(p,x),e.mul(b,B)),N=e.eql(e.mul(m,x),e.mul(C,B));return A&&N}negate(){return new f(this.px,e.neg(this.py),this.pz)}double(){let{a:h,b:p}=t,m=e.mul(p,Da),{px:B,py:b,pz:C}=this,x=e.ZERO,A=e.ZERO,N=e.ZERO,R=e.mul(B,B),q=e.mul(b,b),M=e.mul(C,C),V=e.mul(B,b);return V=e.add(V,V),N=e.mul(B,C),N=e.add(N,N),x=e.mul(h,N),A=e.mul(m,M),A=e.add(x,A),x=e.sub(q,A),A=e.add(q,A),A=e.mul(x,A),x=e.mul(V,x),N=e.mul(m,N),M=e.mul(h,M),V=e.sub(R,M),V=e.mul(h,V),V=e.add(V,N),N=e.add(R,R),R=e.add(N,R),R=e.add(R,M),R=e.mul(R,V),A=e.add(A,R),M=e.mul(b,C),M=e.add(M,M),R=e.mul(M,V),x=e.sub(x,R),N=e.mul(M,q),N=e.add(N,N),N=e.add(N,N),new f(x,A,N)}add(h){l(h);let{px:p,py:m,pz:B}=this,{px:b,py:C,pz:x}=h,A=e.ZERO,N=e.ZERO,R=e.ZERO,q=t.a,M=e.mul(t.b,Da),V=e.mul(p,b),rt=e.mul(m,C),tt=e.mul(B,x),Bt=e.add(p,m),v=e.add(b,C);Bt=e.mul(Bt,v),v=e.add(V,rt),Bt=e.sub(Bt,v),v=e.add(p,B);let I=e.add(b,x);return v=e.mul(v,I),I=e.add(V,tt),v=e.sub(v,I),I=e.add(m,B),A=e.add(C,x),I=e.mul(I,A),A=e.add(rt,tt),I=e.sub(I,A),R=e.mul(q,v),A=e.mul(M,tt),R=e.add(A,R),A=e.sub(rt,R),R=e.add(rt,R),N=e.mul(A,R),rt=e.add(V,V),rt=e.add(rt,V),tt=e.mul(q,tt),v=e.mul(M,v),rt=e.add(rt,tt),tt=e.sub(V,tt),tt=e.mul(q,tt),v=e.add(v,tt),V=e.mul(rt,v),N=e.add(N,V),V=e.mul(I,v),A=e.mul(Bt,A),A=e.sub(A,V),V=e.mul(Bt,rt),R=e.mul(I,R),R=e.add(R,V),new f(A,N,R)}subtract(h){return this.add(h.negate())}is0(){return this.equals(f.ZERO)}wNAF(h){return w.wNAFCached(this,u,h,p=>{let m=e.invertBatch(p.map(B=>B.pz));return p.map((B,b)=>B.toAffine(m[b])).map(f.fromAffine)})}multiplyUnsafe(h){let p=f.ZERO;if(h===ne)return p;if(a(h),h===kt)return this;let{endo:m}=t;if(!m)return w.unsafeLadder(this,h);let{k1neg:B,k1:b,k2neg:C,k2:x}=m.splitScalar(h),A=p,N=p,R=this;for(;b>ne||x>ne;)b&kt&&(A=A.add(R)),x&kt&&(N=N.add(R)),R=R.double(),b>>=kt,x>>=kt;return B&&(A=A.negate()),C&&(N=N.negate()),N=new f(e.mul(N.px,m.beta),N.py,N.pz),A.add(N)}multiply(h){a(h);let p=h,m,B,{endo:b}=t;if(b){let{k1neg:C,k1:x,k2neg:A,k2:N}=b.splitScalar(p),{p:R,f:q}=this.wNAF(x),{p:M,f:V}=this.wNAF(N);R=w.constTimeNegate(C,R),M=w.constTimeNegate(A,M),M=new f(e.mul(M.px,b.beta),M.py,M.pz),m=R.add(M),B=q.add(V)}else{let{p:C,f:x}=this.wNAF(p);m=C,B=x}return f.normalizeZ([m,B])[0]}multiplyAndAddUnsafe(h,p,m){let B=f.BASE,b=(x,A)=>A===ne||A===kt||!x.equals(B)?x.multiplyUnsafe(A):x.multiply(A),C=b(this,p).add(b(h,m));return C.is0()?void 0:C}toAffine(h){let{px:p,py:m,pz:B}=this,b=this.is0();h==null&&(h=b?e.ONE:e.inv(B));let C=e.mul(p,h),x=e.mul(m,h),A=e.mul(B,h);if(b)return{x:e.ZERO,y:e.ZERO};if(!e.eql(A,e.ONE))throw new Error("invZ was invalid");return{x:C,y:x}}isTorsionFree(){let{h,isTorsionFree:p}=t;if(h===kt)return!0;if(p)return p(f,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h,clearCofactor:p}=t;return h===kt?this:p?p(f,this):this.multiplyUnsafe(t.h)}toRawBytes(h=!0){return this.assertValidity(),n(f,this,h)}toHex(h=!0){return qt(this.toRawBytes(h))}}f.BASE=new f(t.Gx,t.Gy,e.ONE),f.ZERO=new f(e.ZERO,e.ONE,e.ZERO);let d=t.nBitLength,w=jr(f,t.endo?Math.ceil(d/2):d);return{CURVE:t,ProjectivePoint:f,normPrivateKeyToScalar:c,weierstrassEquation:o,isWithinCurveOrder:i}}function Bf(r){let t=gr(r);return Ht(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function Oa(r){let t=Bf(r),{Fp:e,n}=t,s=e.BYTES+1,o=2*e.BYTES+1;function i(v){return ne<v&&v<e.ORDER}function a(v){return j(v,n)}function c(v){return $r(v,n)}let{ProjectivePoint:u,normPrivateKeyToScalar:l,weierstrassEquation:f,isWithinCurveOrder:d}=xf({...t,toBytes(v,I,H){let E=I.toAffine(),y=e.toBytes(E.x),S=Gt;return H?S(Uint8Array.from([I.hasEvenY()?2:3]),y):S(Uint8Array.from([4]),y,e.toBytes(E.y))},fromBytes(v){let I=v.length,H=v[0],E=v.subarray(1);if(I===s&&(H===2||H===3)){let y=jt(E);if(!i(y))throw new Error("Point is not on curve");let S=f(y),T;try{T=e.sqrt(S)}catch(O){let $=O instanceof Error?": "+O.message:"";throw new Error("Point is not on curve"+$)}let U=(T&kt)===kt;return(H&1)===1!==U&&(T=e.neg(T)),{x:y,y:T}}else if(I===o&&H===4){let y=e.fromBytes(E.subarray(0,e.BYTES)),S=e.fromBytes(E.subarray(e.BYTES,2*e.BYTES));return{x:y,y:S}}else throw new Error(`Point of length ${I} was invalid. Expected ${s} compressed bytes or ${o} uncompressed bytes`)}}),w=v=>qt(de(v,t.nByteLength));function g(v){let I=n>>kt;return v>I}function h(v){return g(v)?a(-v):v}let p=(v,I,H)=>jt(v.slice(I,H));class m{constructor(I,H,E){this.r=I,this.s=H,this.recovery=E,this.assertValidity()}static fromCompact(I){let H=t.nByteLength;return I=Q("compactSignature",I,H*2),new m(p(I,0,H),p(I,H,2*H))}static fromDER(I){let{r:H,s:E}=De.toSig(Q("DER",I));return new m(H,E)}assertValidity(){if(!d(this.r))throw new Error("r must be 0 < r < CURVE.n");if(!d(this.s))throw new Error("s must be 0 < s < CURVE.n")}addRecoveryBit(I){return new m(this.r,this.s,I)}recoverPublicKey(I){let{r:H,s:E,recovery:y}=this,S=N(Q("msgHash",I));if(y==null||![0,1,2,3].includes(y))throw new Error("recovery id invalid");let T=y===2||y===3?H+t.n:H;if(T>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let U=y&1?"03":"02",D=u.fromHex(U+w(T)),O=c(T),$=a(-S*O),K=a(E*O),F=u.BASE.multiplyAndAddUnsafe(D,$,K);if(!F)throw new Error("point at infinify");return F.assertValidity(),F}hasHighS(){return g(this.s)}normalizeS(){return this.hasHighS()?new m(this.r,a(-this.s),this.recovery):this}toDERRawBytes(){return Ne(this.toDERHex())}toDERHex(){return De.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return Ne(this.toCompactHex())}toCompactHex(){return w(this.r)+w(this.s)}}let B={isValidPrivateKey(v){try{return l(v),!0}catch{return!1}},normPrivateKeyToScalar:l,randomPrivateKey:()=>{let v=Rs(t.n);return li(t.randomBytes(v),t.n)},precompute(v=8,I=u.BASE){return I._setWindowSize(v),I.multiply(BigInt(3)),I}};function b(v,I=!0){return u.fromPrivateKey(v).toRawBytes(I)}function C(v){let I=fe(v),H=typeof v=="string",E=(I||H)&&v.length;return I?E===s||E===o:H?E===2*s||E===2*o:v instanceof u}function x(v,I,H=!0){if(C(v))throw new Error("first arg must be private key");if(!C(I))throw new Error("second arg must be public key");return u.fromHex(I).multiply(l(v)).toRawBytes(H)}let A=t.bits2int||function(v){let I=jt(v),H=v.length*8-t.nBitLength;return H>0?I>>BigInt(H):I},N=t.bits2int_modN||function(v){return a(A(v))},R=dr(t.nBitLength);function q(v){if(typeof v!="bigint")throw new Error("bigint expected");if(!(ne<=v&&v<R))throw new Error(`bigint expected < 2^${t.nBitLength}`);return de(v,t.nByteLength)}function M(v,I,H=V){if(["recovered","canonical"].some(J=>J in H))throw new Error("sign() legacy options not supported");let{hash:E,randomBytes:y}=t,{lowS:S,prehash:T,extraEntropy:U}=H;S==null&&(S=!0),v=Q("msgHash",v),T&&(v=Q("prehashed msgHash",E(v)));let D=N(v),O=l(I),$=[q(O),q(D)];if(U!=null&&U!==!1){let J=U===!0?y(e.BYTES):U;$.push(Q("extraEntropy",J))}let K=Gt(...$),F=D;function nt(J){let lt=A(J);if(!d(lt))return;let ut=c(lt),it=u.BASE.multiply(lt).toAffine(),ht=a(it.x);if(ht===ne)return;let Kt=a(ut*a(F+ht*O));if(Kt===ne)return;let Ae=(it.x===ht?0:2)|Number(it.y&kt),cr=Kt;return S&&g(Kt)&&(cr=h(Kt),Ae^=1),new m(ht,cr,Ae)}return{seed:K,k2sig:nt}}let V={lowS:t.lowS,prehash:!1},rt={lowS:t.lowS,prehash:!1};function tt(v,I,H=V){let{seed:E,k2sig:y}=M(v,I,H),S=t;return ks(S.hash.outputLen,S.nByteLength,S.hmac)(E,y)}u.BASE._setWindowSize(8);function Bt(v,I,H,E=rt){let y=v;if(I=Q("msgHash",I),H=Q("publicKey",H),"strict"in E)throw new Error("options.strict was renamed to lowS");let{lowS:S,prehash:T}=E,U,D;try{if(typeof y=="string"||fe(y))try{U=m.fromDER(y)}catch(it){if(!(it instanceof De.Err))throw it;U=m.fromCompact(y)}else if(typeof y=="object"&&typeof y.r=="bigint"&&typeof y.s=="bigint"){let{r:it,s:ht}=y;U=new m(it,ht)}else throw new Error("PARSE");D=u.fromHex(H)}catch(it){if(it.message==="PARSE")throw new Error("signature must be Signature instance, Uint8Array or hex string");return!1}if(S&&U.hasHighS())return!1;T&&(I=t.hash(I));let{r:O,s:$}=U,K=N(I),F=c($),nt=a(K*F),J=a(O*F),lt=u.BASE.multiplyAndAddUnsafe(D,nt,J)?.toAffine();return lt?a(lt.x)===O:!1}return{CURVE:t,getPublicKey:b,getSharedSecret:x,sign:tt,verify:Bt,ProjectivePoint:u,Signature:m,utils:B}}function vf(r){return{hash:r,hmac:(t,...e)=>br(r,t,Dr(...e)),randomBytes:We}}function Pa(r,t){let e=n=>Oa({...r,...vf(n)});return Object.freeze({...e(t),create:e})}var Fa=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),Ka=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),Ef=BigInt(1),lo=BigInt(2),Ma=(r,t)=>(r+t/lo)/t;function Af(r){let t=Fa,e=BigInt(3),n=BigInt(6),s=BigInt(11),o=BigInt(22),i=BigInt(23),a=BigInt(44),c=BigInt(88),u=r*r*r%t,l=u*u*r%t,f=W(l,e,t)*l%t,d=W(f,e,t)*l%t,w=W(d,lo,t)*u%t,g=W(w,s,t)*w%t,h=W(g,o,t)*g%t,p=W(h,a,t)*h%t,m=W(p,c,t)*p%t,B=W(m,a,t)*h%t,b=W(B,e,t)*l%t,C=W(b,i,t)*g%t,x=W(C,n,t)*u%t,A=W(x,lo,t);if(!uo.eql(uo.sqr(A),r))throw new Error("Cannot find square root");return A}var uo=qr(Fa,void 0,void 0,{sqrt:Af}),Lt=Pa({a:BigInt(0),b:BigInt(7),Fp:uo,n:Ka,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=Ka,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-Ef*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),s=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),o=e,i=BigInt("0x100000000000000000000000000000000"),a=Ma(o*r,t),c=Ma(-n*r,t),u=j(r-a*e-c*s,t),l=j(-a*n-c*o,t),f=u>i,d=l>i;if(f&&(u=t-u),d&&(l=t-l),u>i||l>i)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:f,k1:u,k2neg:d,k2:l}}}},zn),_g=BigInt(0);var Ug=Lt.ProjectivePoint;function $a(){return Lt.utils.randomPrivateKey()}function qa(r,t){let e=bt.digest(t instanceof Uint8Array?t:t.subarray());if(Et(e))return e.then(({digest:n})=>Lt.sign(n,r).toDERRawBytes()).catch(n=>{throw new _(String(n),"ERR_INVALID_INPUT")});try{return Lt.sign(e.digest,r).toDERRawBytes()}catch(n){throw new _(String(n),"ERR_INVALID_INPUT")}}function ja(r,t,e){let n=bt.digest(e instanceof Uint8Array?e:e.subarray());if(Et(n))return n.then(({digest:s})=>Lt.verify(t,s,r)).catch(s=>{throw new _(String(s),"ERR_INVALID_INPUT")});try{return Lt.verify(t,n.digest,r)}catch(s){throw new _(String(s),"ERR_INVALID_INPUT")}}function Ga(r){return Lt.ProjectivePoint.fromHex(r).toRawBytes(!0)}function za(r){try{Lt.getPublicKey(r,!0)}catch(t){throw new _(String(t),"ERR_INVALID_PRIVATE_KEY")}}function fo(r){try{Lt.ProjectivePoint.fromHex(r)}catch(t){throw new _(String(t),"ERR_INVALID_PUBLIC_KEY")}}function Za(r){try{return Lt.getPublicKey(r,!0)}catch(t){throw new _(String(t),"ERR_INVALID_PRIVATE_KEY")}}var Oe=class{_key;constructor(t){fo(t),this._key=t}verify(t,e){return ja(this._key,e,t)}marshal(){return Ga(this._key)}get bytes(){return Ct.encode({Type:G.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return St(this.bytes,t.bytes)}async hash(){let t=bt.digest(this.bytes),e;return Et(t)?{bytes:e}=await t:e=t.bytes,e}},Pe=class{_key;_publicKey;constructor(t,e){this._key=t,this._publicKey=e??Za(t),za(this._key),fo(this._publicKey)}sign(t){return qa(this._key,t)}get public(){return new Oe(this._publicKey)}marshal(){return this._key}get bytes(){return Tt.encode({Type:G.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return St(this.bytes,t.bytes)}hash(){let t=bt.digest(this.bytes);return Et(t)?t.then(({bytes:e})=>e):t.bytes}async id(){let t=await this.public.hash();return st(t,"base58btc")}async export(t,e="libp2p-key"){if(e==="libp2p-key")return tr(this.bytes,t);throw new _(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function Sf(r){return new Pe(r)}function If(r){return new Oe(r)}async function Nf(){let r=$a();return new Pe(r)}var se={rsa:ao,ed25519:Ys,secp256k1:ho};function go(r){let t=Object.keys(se).join(" / ");return new _(`invalid or unsupported key type ${r}. Must be ${t}`,"ERR_UNSUPPORTED_KEY_TYPE")}function po(r){if(r=r.toLowerCase(),r==="rsa"||r==="ed25519"||r==="secp256k1")return se[r];throw go(r)}async function Rf(r,t){return po(r).generateKeyPair(t??2048)}async function Cf(r,t,e){if(r.toLowerCase()!=="ed25519")throw new _("Seed key derivation is unimplemented for RSA or secp256k1","ERR_UNSUPPORTED_KEY_DERIVATION_TYPE");return Zs(t)}function Tf(r){let t=Ct.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case G.RSA:return se.rsa.unmarshalRsaPublicKey(e);case G.Ed25519:return se.ed25519.unmarshalEd25519PublicKey(e);case G.Secp256k1:return se.secp256k1.unmarshalSecp256k1PublicKey(e);default:throw go(t.Type??"unknown")}}function _f(r,t){return t=(t??"rsa").toLowerCase(),po(t),r.bytes}async function Ya(r){let t=Tt.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case G.RSA:return se.rsa.unmarshalRsaPrivateKey(e);case G.Ed25519:return se.ed25519.unmarshalEd25519PrivateKey(e);case G.Secp256k1:return se.secp256k1.unmarshalSecp256k1PrivateKey(e);default:throw go(t.Type??"RSA")}}function Uf(r,t){return t=(t??"rsa").toLowerCase(),po(t),r.bytes}async function Lf(r,t){try{let e=await Pi(r,t);return await Ya(e)}catch{}if(!r.includes("BEGIN"))throw new _("Encrypted key was not a libp2p-key or a PEM file","ERR_INVALID_IMPORT_FORMAT");return so(r,t)}var Nr=new Uint32Array([1732584193,4023233417,2562383102,271733878,3285377520]),Ee=new Uint32Array(80),mo=class extends ae{constructor(){super(64,20,8,!1),this.A=Nr[0]|0,this.B=Nr[1]|0,this.C=Nr[2]|0,this.D=Nr[3]|0,this.E=Nr[4]|0}get(){let{A:t,B:e,C:n,D:s,E:o}=this;return[t,e,n,s,o]}set(t,e,n,s,o){this.A=t|0,this.B=e|0,this.C=n|0,this.D=s|0,this.E=o|0}process(t,e){for(let c=0;c<16;c++,e+=4)Ee[c]=t.getUint32(e,!1);for(let c=16;c<80;c++)Ee[c]=Hr(Ee[c-3]^Ee[c-8]^Ee[c-14]^Ee[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=Or(s,o,i),l=1518500249):c<40?(u=s^o^i,l=1859775393):c<60?(u=Pr(s,o,i),l=2400959708):(u=s^o^i,l=3395469782);let f=Hr(n,5)+u+a+l+Ee[c]|0;a=i,i=o,o=Hr(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(){Ee.fill(0)}destroy(){this.set(0,0,0,0,0),this.buffer.fill(0)}},Wa=Ye(()=>new mo);var Ja={sha1:Wa,"sha2-256":zn,"sha2-512":ue};function bo(r,t,e,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=qi(o,r,t,{c:e,dkLen:n});return Se.encode(i).substring(1)}return dc(Vf);})();
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.0.3",
3
+ "version": "4.0.4",
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.1.4",
87
+ "@libp2p/interface": "^1.1.5",
88
88
  "@noble/curves": "^1.3.0",
89
89
  "@noble/hashes": "^1.3.3",
90
90
  "asn1js": "^3.0.5",