@libp2p/keychain 5.2.0 → 5.2.1-4b8c0a6bd

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.Libp2PKeychain = factory()}(typeof self !== 'undefined' ? self : this, function () {
2
- "use strict";var Libp2PKeychain=(()=>{var Cl=Object.create;var en=Object.defineProperty;var Nl=Object.getOwnPropertyDescriptor;var Tl=Object.getOwnPropertyNames;var Ul=Object.getPrototypeOf,Ll=Object.prototype.hasOwnProperty;var Se=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),ut=(r,t)=>{for(var e in t)en(r,e,{get:t[e],enumerable:!0})},mi=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of Tl(t))!Ll.call(r,s)&&s!==e&&en(r,s,{get:()=>t[s],enumerable:!(n=Nl(t,s))||n.enumerable});return r};var Ls=(r,t,e)=>(e=r!=null?Cl(Ul(r)):{},mi(t||!r||!r.__esModule?en(e,"default",{value:r,enumerable:!0}):e,r)),Rl=r=>mi(en({},"__esModule",{value:!0}),r);var hc=Se((Hm,fc)=>{"use strict";fc.exports=r=>{if(Object.prototype.toString.call(r)!=="[object Object]")return!1;let t=Object.getPrototypeOf(r);return t===null||t===Object.prototype}});var bc=Se((yc,mc)=>{"use strict";var Kn=hc(),{hasOwnProperty:pc}=Object.prototype,{propertyIsEnumerable:Rh}=Object,ur=(r,t,e)=>Object.defineProperty(r,t,{value:e,writable:!0,enumerable:!0,configurable:!0}),_h=yc,dc={concatArrays:!1,ignoreUndefined:!1},On=r=>{let t=[];for(let e in r)pc.call(r,e)&&t.push(e);if(Object.getOwnPropertySymbols){let e=Object.getOwnPropertySymbols(r);for(let n of e)Rh.call(r,n)&&t.push(n)}return t};function fr(r){return Array.isArray(r)?Dh(r):Kn(r)?Kh(r):r}function Dh(r){let t=r.slice(0,0);return On(r).forEach(e=>{ur(t,e,fr(r[e]))}),t}function Kh(r){let t=Object.getPrototypeOf(r)===null?Object.create(null):{};return On(r).forEach(e=>{ur(t,e,fr(r[e]))}),t}var gc=(r,t,e,n)=>(e.forEach(s=>{typeof t[s]>"u"&&n.ignoreUndefined||(s in r&&r[s]!==Object.getPrototypeOf(r)?ur(r,s,ti(r[s],t[s],n)):ur(r,s,fr(t[s])))}),r),Oh=(r,t,e)=>{let n=r.slice(0,0),s=0;return[r,t].forEach(o=>{let i=[];for(let a=0;a<o.length;a++)pc.call(o,a)&&(i.push(String(a)),o===r?ur(n,s++,o[a]):ur(n,s++,fr(o[a])));n=gc(n,o,On(o).filter(a=>!i.includes(a)),e)}),n};function ti(r,t,e){return e.concatArrays&&Array.isArray(r)&&Array.isArray(t)?Oh(r,t,e):!Kn(t)||!Kn(r)?fr(t):gc(r,t,On(t),e)}mc.exports=function(...r){let t=ti(fr(dc),this!==_h&&this||{},dc),e={_:{}};for(let n of r)if(n!==void 0){if(!Kn(n))throw new TypeError("`"+n+"` is not an Option Object");e=ti(e,{_:n},t)}return e._}});var Bc=Se((Mm,vc)=>{"use strict";function Vh(r){return r>=55296&&r<=56319}function Hh(r){return r>=56320&&r<=57343}vc.exports=function(t,e,n){if(typeof e!="string")throw new Error("Input must be string");for(var s=e.length,o=0,i,a,c=0;c<s;c+=1){if(i=e.charCodeAt(c),a=e[c],Vh(i)&&Hh(e.charCodeAt(c+1))&&(c+=1,a+=e[c]),o+=t(a),o===n)return e.slice(0,c+1);if(o>n)return e.slice(0,c-a.length+1)}return e}});var Ac=Se((Fm,Ec)=>{"use strict";function Ph(r){return r>=55296&&r<=56319}function Mh(r){return r>=56320&&r<=57343}Ec.exports=function(t){if(typeof t!="string")throw new Error("Input must be string");for(var e=t.length,n=0,s=null,o=null,i=0;i<e;i++)s=t.charCodeAt(i),Mh(s)?o!=null&&Ph(o)?n+=1:n+=3:s<=127?n+=1:s>=128&&s<=2047?n+=2:s>=2048&&s<=65535&&(n+=3),o=s;return n}});var kc=Se((qm,Sc)=>{"use strict";var Fh=Bc(),qh=Ac();Sc.exports=Fh.bind(null,qh)});var Nc=Se((jm,Cc)=>{"use strict";var jh=kc(),$h=/[\/\?<>\\:\*\|"]/g,Gh=/[\x00-\x1f\x80-\x9f]/g,zh=/^\.+$/,Wh=/^(con|prn|aux|nul|com[0-9]|lpt[0-9])(\..*)?$/i,Zh=/[\. ]+$/;function Ic(r,t){if(typeof r!="string")throw new Error("Input must be string");var e=r.replace($h,t).replace(Gh,t).replace(zh,t).replace(Wh,t).replace(Zh,t);return jh(e,255)}Cc.exports=function(r,t){var e=t&&t.replacement||"",n=Ic(r,e);return e===""?n:Ic(n,"")}});var Tc=Se(dr=>{"use strict";var Yh="[object ArrayBuffer]",Qt=class r{static isArrayBuffer(t){return Object.prototype.toString.call(t)===Yh}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}},ei="string",Xh=/^[0-9a-f\s]+$/i,Qh=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,td=/^[a-zA-Z0-9-_]+$/,Hn=class{static fromString(t){let e=unescape(encodeURIComponent(t)),n=new Uint8Array(e.length);for(let s=0;s<e.length;s++)n[s]=e.charCodeAt(s);return n.buffer}static toString(t){let e=Qt.toUint8Array(t),n="";for(let o=0;o<e.length;o++)n+=String.fromCharCode(e[o]);return decodeURIComponent(escape(n))}},Ct=class{static toString(t,e=!1){let n=Qt.toArrayBuffer(t),s=new DataView(n),o="";for(let i=0;i<n.byteLength;i+=2){let a=s.getUint16(i,e);o+=String.fromCharCode(a)}return o}static fromString(t,e=!1){let n=new ArrayBuffer(t.length*2),s=new DataView(n);for(let o=0;o<t.length;o++)s.setUint16(o*2,t.charCodeAt(o),e);return n}},Pn=class r{static isHex(t){return typeof t===ei&&Xh.test(t)}static isBase64(t){return typeof t===ei&&Qh.test(t)}static isBase64Url(t){return typeof t===ei&&td.test(t)}static ToString(t,e="utf8"){let n=Qt.toUint8Array(t);switch(e.toLowerCase()){case"utf8":return this.ToUtf8String(n);case"binary":return this.ToBinary(n);case"hex":return this.ToHex(n);case"base64":return this.ToBase64(n);case"base64url":return this.ToBase64Url(n);case"utf16le":return Ct.toString(n,!0);case"utf16":case"utf16be":return Ct.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 Ct.fromString(t,!0);case"utf16":case"utf16be":return Ct.fromString(t);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToBase64(t){let e=Qt.toUint8Array(t);if(typeof btoa<"u"){let n=this.ToString(e,"binary");return btoa(n)}else return Buffer.from(e).toString("base64")}static FromBase64(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isBase64(e))throw new TypeError("Argument 'base64Text' is not Base64 encoded");return typeof atob<"u"?this.FromBinary(atob(e)):new Uint8Array(Buffer.from(e,"base64")).buffer}static FromBase64Url(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isBase64Url(e))throw new TypeError("Argument 'base64url' is not Base64Url encoded");return this.FromBase64(this.Base64Padding(e.replace(/\-/g,"+").replace(/\_/g,"/")))}static ToBase64Url(t){return this.ToBase64(t).replace(/\+/g,"-").replace(/\//g,"_").replace(/\=/g,"")}static FromUtf8String(t,e=r.DEFAULT_UTF8_ENCODING){switch(e){case"ascii":return this.FromBinary(t);case"utf8":return Hn.fromString(t);case"utf16":case"utf16be":return Ct.fromString(t);case"utf16le":case"usc2":return Ct.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 Hn.toString(t);case"utf16":case"utf16be":return Ct.toString(t);case"utf16le":case"usc2":return Ct.toString(t,!0);default:throw new Error(`Unknown type of encoding '${e}'`)}}static FromBinary(t){let e=t.length,n=new Uint8Array(e);for(let s=0;s<e;s++)n[s]=t.charCodeAt(s);return n.buffer}static ToBinary(t){let e=Qt.toUint8Array(t),n="";for(let s=0;s<e.length;s++)n+=String.fromCharCode(e[s]);return n}static ToHex(t){let e=Qt.toUint8Array(t),n="",s=e.length;for(let o=0;o<s;o++){let i=e[o];i<16&&(n+="0"),n+=i.toString(16)}return n}static FromHex(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isHex(e))throw new TypeError("Argument 'hexString' is not HEX encoded");e.length%2&&(e=`0${e}`);let n=new Uint8Array(e.length/2);for(let s=0;s<e.length;s=s+2){let o=e.slice(s,s+2);n[s/2]=parseInt(o,16)}return n.buffer}static ToUtf16String(t,e=!1){return Ct.toString(t,e)}static FromUtf16String(t,e=!1){return Ct.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,"")||""}};Pn.DEFAULT_UTF8_ENCODING="utf8";function ed(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 rd(...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 nd(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}dr.BufferSourceConverter=Qt;dr.Convert=Pn;dr.assign=ed;dr.combine=rd;dr.isEqual=nd});var xd={};ut(xd,{keychain:()=>wd});var br=class extends Error{constructor(t="An error occurred while signing a message"){super(t),this.name="SigningError"}},wr=class extends Error{constructor(t="An error occurred while verifying a message"){super(t),this.name="VerificationError"}},rn=class extends Error{constructor(t="Missing Web Crypto API"){super(t),this.name="WebCryptoMissingError"}};var bi={get(r=globalThis){let t=r.crypto;if(t?.subtle==null)throw new rn("Missing Web Crypto API. The most likely cause of this error is that this page is being accessed from an insecure context (i.e. not HTTPS). For more information and possible resolutions see https://github.com/libp2p/js-libp2p/blob/main/packages/crypto/README.md#web-crypto-api");return t}};var wt=bi;var L=class extends Error{static name="InvalidParametersError";constructor(t="Invalid parameters"){super(t),this.name="InvalidParametersError"}},qe=class extends Error{static name="InvalidPublicKeyError";constructor(t="Invalid public key"){super(t),this.name="InvalidPublicKeyError"}},xr=class extends Error{static name="InvalidPrivateKeyError";constructor(t="Invalid private key"){super(t),this.name="InvalidPrivateKeyError"}};var nn=class extends Error{static name="NotFoundError";constructor(t="Not found"){super(t),this.name="NotFoundError"}};var je=class extends Error{static name="UnsupportedKeyTypeError";constructor(t="Unsupported key type"){super(t),this.name="UnsupportedKeyTypeError"}};var wi=Symbol.for("@libp2p/service-capabilities"),Cd=Symbol.for("@libp2p/service-dependencies");var Os={};ut(Os,{base58btc:()=>Q,base58flickr:()=>Hl});var Yd=new Uint8Array(0);function xi(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function jt(r){if(r instanceof Uint8Array&&r.constructor.name==="Uint8Array")return r;if(r instanceof ArrayBuffer)return new Uint8Array(r);if(ArrayBuffer.isView(r))return new Uint8Array(r.buffer,r.byteOffset,r.byteLength);throw new Error("Unknown type, must be binary type")}function vi(r){return new TextEncoder().encode(r)}function Bi(r){return new TextDecoder().decode(r)}function _l(r,t){if(r.length>=255)throw new TypeError("Alphabet too long");for(var e=new Uint8Array(256),n=0;n<e.length;n++)e[n]=255;for(var s=0;s<r.length;s++){var o=r.charAt(s),i=o.charCodeAt(0);if(e[i]!==255)throw new TypeError(o+" is ambiguous");e[i]=s}var a=r.length,c=r.charAt(0),f=Math.log(a)/Math.log(256),l=Math.log(256)/Math.log(a);function u(b){if(b instanceof Uint8Array||(ArrayBuffer.isView(b)?b=new Uint8Array(b.buffer,b.byteOffset,b.byteLength):Array.isArray(b)&&(b=Uint8Array.from(b))),!(b instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(b.length===0)return"";for(var m=0,d=0,w=0,B=b.length;w!==B&&b[w]===0;)w++,m++;for(var p=(B-w)*l+1>>>0,S=new Uint8Array(p);w!==B;){for(var R=b[w],U=0,I=p-1;(R!==0||U<d)&&I!==-1;I--,U++)R+=256*S[I]>>>0,S[I]=R%a>>>0,R=R/a>>>0;if(R!==0)throw new Error("Non-zero carry");d=U,w++}for(var T=p-d;T!==p&&S[T]===0;)T++;for(var C=c.repeat(m);T<p;++T)C+=r.charAt(S[T]);return C}function h(b){if(typeof b!="string")throw new TypeError("Expected String");if(b.length===0)return new Uint8Array;var m=0;if(b[m]!==" "){for(var d=0,w=0;b[m]===c;)d++,m++;for(var B=(b.length-m)*f+1>>>0,p=new Uint8Array(B);b[m];){var S=e[b.charCodeAt(m)];if(S===255)return;for(var R=0,U=B-1;(S!==0||R<w)&&U!==-1;U--,R++)S+=a*p[U]>>>0,p[U]=S%256>>>0,S=S/256>>>0;if(S!==0)throw new Error("Non-zero carry");w=R,m++}if(b[m]!==" "){for(var I=B-w;I!==B&&p[I]===0;)I++;for(var T=new Uint8Array(d+(B-I)),C=d;I!==B;)T[C++]=p[I++];return T}}}function y(b){var m=h(b);if(m)return m;throw new Error(`Non-${t} character`)}return{encode:u,decodeUnsafe:h,decode:y}}var Dl=_l,Kl=Dl,Ai=Kl;var Rs=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")}},_s=class{name;prefix;baseDecode;prefixCodePoint;constructor(t,e,n){this.name=t,this.prefix=e;let s=e.codePointAt(0);if(s===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=s,this.baseDecode=n}decode(t){if(typeof t=="string"){if(t.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(t)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(t.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(t){return Si(this,t)}},Ds=class{decoders;constructor(t){this.decoders=t}or(t){return Si(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 Si(r,t){return new Ds({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var Ks=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 Rs(t,e,n),this.decoder=new _s(t,e,s)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function $e({name:r,prefix:t,encode:e,decode:n}){return new Ks(r,t,e,n)}function ie({name:r,prefix:t,alphabet:e}){let{encode:n,decode:s}=Ai(e,r);return $e({prefix:t,name:r,encode:n,decode:o=>jt(s(o))})}function Ol(r,t,e,n){let s={};for(let l=0;l<t.length;++l)s[t[l]]=l;let o=r.length;for(;r[o-1]==="=";)--o;let i=new Uint8Array(o*e/8|0),a=0,c=0,f=0;for(let l=0;l<o;++l){let u=s[r[l]];if(u===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<e|u,a+=e,a>=8&&(a-=8,i[f++]=255&c>>a)}if(a>=e||(255&c<<8-a)!==0)throw new SyntaxError("Unexpected end of data");return i}function Vl(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)!==0;)o+="=";return o}function X({name:r,prefix:t,bitsPerChar:e,alphabet:n}){return $e({prefix:t,name:r,encode(s){return Vl(s,n,e)},decode(s){return Ol(s,n,e,r)}})}var Q=ie({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),Hl=ie({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Vs={};ut(Vs,{base32:()=>Ge,base32hex:()=>ql,base32hexpad:()=>$l,base32hexpadupper:()=>Gl,base32hexupper:()=>jl,base32pad:()=>Ml,base32padupper:()=>Fl,base32upper:()=>Pl,base32z:()=>zl});var Ge=X({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),Pl=X({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Ml=X({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),Fl=X({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),ql=X({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),jl=X({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),$l=X({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),Gl=X({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),zl=X({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Hs={};ut(Hs,{base36:()=>vr,base36upper:()=>Wl});var vr=ie({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),Wl=ie({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Zl=Ci,ki=128,Jl=127,Yl=~Jl,Xl=Math.pow(2,31);function Ci(r,t,e){t=t||[],e=e||0;for(var n=e;r>=Xl;)t[e++]=r&255|ki,r/=128;for(;r&Yl;)t[e++]=r&255|ki,r>>>=7;return t[e]=r|0,Ci.bytes=e-n+1,t}var Ql=Ps,tu=128,Ii=127;function Ps(r,n){var e=0,n=n||0,s=0,o=n,i,a=r.length;do{if(o>=a)throw Ps.bytes=0,new RangeError("Could not decode varint");i=r[o++],e+=s<28?(i&Ii)<<s:(i&Ii)*Math.pow(2,s),s+=7}while(i>=tu);return Ps.bytes=o-n,e}var eu=Math.pow(2,7),ru=Math.pow(2,14),nu=Math.pow(2,21),su=Math.pow(2,28),ou=Math.pow(2,35),iu=Math.pow(2,42),au=Math.pow(2,49),cu=Math.pow(2,56),lu=Math.pow(2,63),uu=function(r){return r<eu?1:r<ru?2:r<nu?3:r<su?4:r<ou?5:r<iu?6:r<au?7:r<cu?8:r<lu?9:10},fu={encode:Zl,decode:Ql,encodingLength:uu},hu=fu,Br=hu;function Er(r,t=0){return[Br.decode(r,t),Br.decode.bytes]}function ze(r,t,e=0){return Br.encode(r,t,e),t}function We(r){return Br.encodingLength(r)}function Nt(r,t){let e=t.byteLength,n=We(r),s=n+We(e),o=new Uint8Array(s+e);return ze(r,o,0),ze(e,o,n),o.set(t,s),new Ze(r,e,t,o)}function Ni(r){let t=jt(r),[e,n]=Er(t),[s,o]=Er(t.subarray(n)),i=t.subarray(n+o);if(i.byteLength!==s)throw new Error("Incorrect length");return new Ze(e,s,i,t)}function Ti(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&xi(r.bytes,e.bytes)}}var Ze=class{code;size;digest;bytes;constructor(t,e,n,s){this.code=t,this.size=e,this.digest=n,this.bytes=s}};function Ui(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return pu(e,Ms(r),t??Q.encoder);default:return gu(e,Ms(r),t??Ge.encoder)}}var Li=new WeakMap;function Ms(r){let t=Li.get(r);if(t==null){let e=new Map;return Li.set(r,e),e}return t}var It=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!==Sr)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==yu)throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");return r.createV0(e)}default:throw Error(`Can not convert CID version ${this.version} to version 0. This is a bug please report`)}}toV1(){switch(this.version){case 0:{let{code:t,digest:e}=this.multihash,n=Nt(t,e);return r.createV1(this.code,n)}case 1:return this;default:throw Error(`Can not convert CID version ${this.version} to version 1. This is a bug please report`)}}equals(t){return r.equals(this,t)}static equals(t,e){let n=e;return n!=null&&t.code===n.code&&t.version===n.version&&Ti(t.multihash,n.multihash)}toString(t){return Ui(this,t)}toJSON(){return{"/":Ui(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??Ri(n,s,o.bytes))}else if(e[mu]===!0){let{version:n,multihash:s,code:o}=e,i=Ni(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!==Sr)throw new Error(`Version 0 CID must use dag-pb (code: ${Sr}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let s=Ri(t,e,n.bytes);return new r(t,e,n,s)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,Sr,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=jt(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 Ze(e.multihashCode,e.digestSize,o,s);return[e.version===0?r.createV0(i):r.createV1(e.codec,i),t.subarray(e.size)]}static inspectBytes(t){let e=0,n=()=>{let[u,h]=Er(t.subarray(e));return e+=h,u},s=n(),o=Sr;if(s===18?(s=0,e=0):o=n(),s!==0&&s!==1)throw new RangeError(`Invalid CID version ${s}`);let i=e,a=n(),c=n(),f=e+c,l=f-i;return{version:s,codec:o,multihashCode:a,digestSize:c,multihashSize:l,size:f}}static parse(t,e){let[n,s]=du(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 Ms(o).set(n,t),o}};function du(r,t){switch(r[0]){case"Q":{let e=t??Q;return[Q.prefix,e.decode(`${Q.prefix}${r}`)]}case Q.prefix:{let e=t??Q;return[Q.prefix,e.decode(r)]}case Ge.prefix:{let e=t??Ge;return[Ge.prefix,e.decode(r)]}case vr.prefix:{let e=t??vr;return[vr.prefix,e.decode(r)]}default:{if(t==null)throw Error("To parse non base32, base36 or base58btc encoded CID multibase decoder must be provided");return[r[0],t.decode(r)]}}}function pu(r,t,e){let{prefix:n}=e;if(n!==Q.prefix)throw Error(`Cannot string encode V0 in ${e.name} encoding`);let s=t.get(n);if(s==null){let o=e.encode(r).slice(1);return t.set(n,o),o}else return s}function gu(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 Sr=112,yu=18;function Ri(r,t,e){let n=We(r),s=n+We(t),o=new Uint8Array(s+e.byteLength);return ze(r,o,0),ze(t,o,n),o.set(e,s),o}var mu=Symbol.for("@ipld/js-cid/CID");var Fs={};ut(Fs,{identity:()=>ke});var _i=0,bu="identity",Di=jt;function wu(r){return Nt(_i,Di(r))}var ke={code:_i,name:bu,encode:Di,digest:wu};function xt(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 $t(r=0){return new Uint8Array(r)}function St(r=0){return new Uint8Array(r)}function Je(r,t){t==null&&(t=r.reduce((s,o)=>s+o.length,0));let e=St(t),n=0;for(let s of r)e.set(s,n),n+=s.length;return e}var Oi=Symbol.for("@achingbrain/uint8arraylist");function Ki(r,t){if(t==null||t<0)throw new RangeError("index is out of bounds");let e=0;for(let n of r){let s=e+n.byteLength;if(t<s)return{buf:n,index:t-e};e=s}throw new RangeError("index is out of bounds")}function on(r){return!!r?.[Oi]}var pt=class r{bufs;length;[Oi]=!0;constructor(...t){this.bufs=[],this.length=0,t.length>0&&this.appendAll(t)}*[Symbol.iterator](){yield*this.bufs}get byteLength(){return this.length}append(...t){this.appendAll(t)}appendAll(t){let e=0;for(let n of t)if(n instanceof Uint8Array)e+=n.byteLength,this.bufs.push(n);else if(on(n))e+=n.byteLength,this.bufs.push(...n.bufs);else throw new Error("Could not append value, must be an Uint8Array or a Uint8ArrayList");this.length+=e}prepend(...t){this.prependAll(t)}prependAll(t){let e=0;for(let n of t.reverse())if(n instanceof Uint8Array)e+=n.byteLength,this.bufs.unshift(n);else if(on(n))e+=n.byteLength,this.bufs.unshift(...n.bufs);else throw new Error("Could not prepend value, must be an Uint8Array or a Uint8ArrayList");this.length+=e}get(t){let e=Ki(this.bufs,t);return e.buf[e.index]}set(t,e){let n=Ki(this.bufs,t);n.buf[n.index]=e}write(t,e=0){if(t instanceof Uint8Array)for(let n=0;n<t.length;n++)this.set(e+n,t[n]);else if(on(t))for(let n=0;n<t.length;n++)this.set(e+n,t.get(n));else throw new Error("Could not write value, must be an Uint8Array or a Uint8ArrayList")}consume(t){if(t=Math.trunc(t),!(Number.isNaN(t)||t<=0)){if(t===this.byteLength){this.bufs=[],this.length=0;return}for(;this.bufs.length>0;)if(t>=this.bufs[0].byteLength)t-=this.bufs[0].byteLength,this.length-=this.bufs[0].byteLength,this.bufs.shift();else{this.bufs[0]=this.bufs[0].subarray(t),this.length-=t;break}}}slice(t,e){let{bufs:n,length:s}=this._subList(t,e);return Je(n,s)}subarray(t,e){let{bufs:n,length:s}=this._subList(t,e);return n.length===1?n[0]:Je(n,s)}sublist(t,e){let{bufs:n,length:s}=this._subList(t,e),o=new r;return o.length=s,o.bufs=[...n],o}_subList(t,e){if(t=t??0,e=e??this.length,t<0&&(t=this.length+t),e<0&&(e=this.length+e),t<0||e>this.length)throw new RangeError("index is out of bounds");if(t===e)return{bufs:[],length:0};if(t===0&&e===this.length)return{bufs:this.bufs,length:this.length};let n=[],s=0;for(let o=0;o<this.bufs.length;o++){let i=this.bufs[o],a=s,c=a+i.byteLength;if(s=c,t>=c)continue;let f=t>=a&&t<c,l=e>a&&e<=c;if(f&&l){if(t===a&&e===c){n.push(i);break}let u=t-a;n.push(i.subarray(u,u+(e-t)));break}if(f){if(t===0){n.push(i);continue}n.push(i.subarray(t-a));continue}if(l){if(e===c){n.push(i);break}n.push(i.subarray(0,e-a));break}n.push(i)}return{bufs:n,length:e-t}}indexOf(t,e=0){if(!on(t)&&!(t instanceof Uint8Array))throw new TypeError('The "value" argument must be a Uint8ArrayList or Uint8Array');let n=t instanceof Uint8Array?t:t.subarray();if(e=Number(e??0),isNaN(e)&&(e=0),e<0&&(e=this.length+e),e<0&&(e=0),t.length===0)return e>this.length?this.length:e;let s=n.byteLength;if(s===0)throw new TypeError("search must be at least 1 byte long");let o=256,i=new Int32Array(o);for(let u=0;u<o;u++)i[u]=-1;for(let u=0;u<s;u++)i[n[u]]=u;let a=i,c=this.byteLength-n.byteLength,f=n.byteLength-1,l;for(let u=e;u<=c;u+=l){l=0;for(let h=f;h>=0;h--){let y=this.get(u+h);if(n[h]!==y){l=Math.max(1,h-a[y]);break}}if(l===0)return u}return-1}getInt8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getInt8(0)}setInt8(t,e){let n=St(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setInt8(0,e),this.write(n,t)}getInt16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt16(0,e)}setInt16(t,e,n){let s=$t(2);new DataView(s.buffer,s.byteOffset,s.byteLength).setInt16(0,e,n),this.write(s,t)}getInt32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt32(0,e)}setInt32(t,e,n){let s=$t(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setInt32(0,e,n),this.write(s,t)}getBigInt64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigInt64(0,e)}setBigInt64(t,e,n){let s=$t(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigInt64(0,e,n),this.write(s,t)}getUint8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getUint8(0)}setUint8(t,e){let n=St(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setUint8(0,e),this.write(n,t)}getUint16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint16(0,e)}setUint16(t,e,n){let s=$t(2);new DataView(s.buffer,s.byteOffset,s.byteLength).setUint16(0,e,n),this.write(s,t)}getUint32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint32(0,e)}setUint32(t,e,n){let s=$t(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setUint32(0,e,n),this.write(s,t)}getBigUint64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigUint64(0,e)}setBigUint64(t,e,n){let s=$t(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigUint64(0,e,n),this.write(s,t)}getFloat32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat32(0,e)}setFloat32(t,e,n){let s=$t(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setFloat32(0,e,n),this.write(s,t)}getFloat64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat64(0,e)}setFloat64(t,e,n){let s=$t(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setFloat64(0,e,n),this.write(s,t)}equals(t){if(t==null||!(t instanceof r)||t.bufs.length!==this.bufs.length)return!1;for(let e=0;e<this.bufs.length;e++)if(!xt(this.bufs[e],t.bufs[e]))return!1;return!0}static fromUint8Arrays(t,e){let n=new r;return n.bufs=t,e==null&&(e=t.reduce((s,o)=>s+o.byteLength,0)),n.length=e,n}};var qs={};ut(qs,{base10:()=>xu});var xu=ie({prefix:"9",name:"base10",alphabet:"0123456789"});var js={};ut(js,{base16:()=>vu,base16upper:()=>Bu});var vu=X({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Bu=X({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var $s={};ut($s,{base2:()=>Eu});var Eu=X({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Gs={};ut(Gs,{base256emoji:()=>Cu});var Vi=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}"),Au=Vi.reduce((r,t,e)=>(r[e]=t,r),[]),Su=Vi.reduce((r,t,e)=>{let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);return r[n]=e,r},[]);function ku(r){return r.reduce((t,e)=>(t+=Au[e],t),"")}function Iu(r){let t=[];for(let e of r){let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);let s=Su[n];if(s==null)throw new Error(`Non-base256emoji character: ${e}`);t.push(s)}return new Uint8Array(t)}var Cu=$e({prefix:"\u{1F680}",name:"base256emoji",encode:ku,decode:Iu});var zs={};ut(zs,{base64:()=>Ie,base64pad:()=>Nu,base64url:()=>Tu,base64urlpad:()=>Uu});var Ie=X({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),Nu=X({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Tu=X({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Uu=X({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Ws={};ut(Ws,{base8:()=>Lu});var Lu=X({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Zs={};ut(Zs,{identity:()=>Ru});var Ru=$e({prefix:"\0",name:"identity",encode:r=>Bi(r),decode:r=>vi(r)});var _0=new TextEncoder,D0=new TextDecoder;var Xs={};ut(Xs,{sha256:()=>Ye,sha512:()=>Ku});function Ys({name:r,code:t,encode:e}){return new Js(r,t,e)}var Js=class{name;code;encode;constructor(t,e,n){this.name=t,this.code=e,this.encode=n}digest(t){if(t instanceof Uint8Array){let e=this.encode(t);return e instanceof Uint8Array?Nt(this.code,e):e.then(n=>Nt(this.code,n))}else throw Error("Unknown type, must be binary type")}};function Pi(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var Ye=Ys({name:"sha2-256",code:18,encode:Pi("SHA-256")}),Ku=Ys({name:"sha2-512",code:19,encode:Pi("SHA-512")});var Qs={...Zs,...$s,...Ws,...qs,...js,...Vs,...Hs,...Os,...zs,...Gs},z0={...Xs,...Fs};function Fi(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var Mi=Fi("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),to=Fi("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=St(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),Ou={utf8:Mi,"utf-8":Mi,hex:Qs.base16,latin1:to,ascii:to,binary:to,...Qs},an=Ou;function H(r,t="utf8"){let e=an[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function j(r,t="utf8"){let e=an[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}var Vu=parseInt("11111",2),eo=parseInt("10000000",2),Hu=parseInt("01111111",2),qi={0:kr,1:kr,2:Pu,3:qu,4:ju,5:Fu,6:Mu,16:kr,22:kr,48:kr};function Tt(r,t={offset:0}){let e=r[t.offset]&Vu;if(t.offset++,qi[e]!=null)return qi[e](r,t);throw new Error("No decoder for tag "+e)}function Ir(r,t){let e=0;if((r[t.offset]&eo)===eo){let n=r[t.offset]&Hu,s="0x";t.offset++;for(let o=0;o<n;o++,t.offset++)s+=r[t.offset].toString(16).padStart(2,"0");e=parseInt(s,16)}else e=r[t.offset],t.offset++;return e}function kr(r,t){Ir(r,t);let e=[];for(;!(t.offset>=r.byteLength);){let n=Tt(r,t);if(n===null)break;e.push(n)}return e}function Pu(r,t){let e=Ir(r,t),n=t.offset,s=t.offset+e,o=[];for(let i=n;i<s;i++)i===n&&r[i]===0||o.push(r[i]);return t.offset+=e,Uint8Array.from(o)}function Mu(r,t){let e=Ir(r,t),n=t.offset+e,s=r[t.offset];t.offset++;let o=0,i=0;s<40?(o=0,i=s):s<80?(o=1,i=s-40):(o=2,i=s-80);let a=`${o}.${i}`,c=[];for(;t.offset<n;){let f=r[t.offset];if(t.offset++,c.push(f&127),f<128){c.reverse();let l=0;for(let u=0;u<c.length;u++)l+=c[u]<<u*7;a+=`.${l}`,c=[]}}return a}function Fu(r,t){return t.offset++,null}function qu(r,t){let e=Ir(r,t),n=r[t.offset];t.offset++;let s=r.subarray(t.offset,t.offset+e-1);if(t.offset+=e,n!==0)throw new Error("Unused bits in bit string is unimplemented");return s}function ju(r,t){let e=Ir(r,t),n=r.subarray(t.offset,t.offset+e);return t.offset+=e,n}function $u(r){let t=r.toString(16);t.length%2===1&&(t="0"+t);let e=new pt;for(let n=0;n<t.length;n+=2)e.append(Uint8Array.from([parseInt(`${t[n]}${t[n+1]}`,16)]));return e}function cn(r){if(r.byteLength<128)return Uint8Array.from([r.byteLength]);let t=$u(r.byteLength);return new pt(Uint8Array.from([t.byteLength|eo]),t)}function gt(r){let t=new pt,e=128;return(r.subarray()[0]&e)===e&&t.append(Uint8Array.from([0])),t.append(r),new pt(Uint8Array.from([2]),cn(t),t)}function Cr(r){let t=Uint8Array.from([0]),e=new pt(t,r);return new pt(Uint8Array.from([3]),cn(e),e)}function ji(r){return new pt(Uint8Array.from([4]),cn(r),r)}function Ut(r,t=48){let e=new pt;for(let n of r)e.append(n);return new pt(Uint8Array.from([t]),cn(e),e)}var $i="1.2.840.10045.3.1.7",Gi="1.3.132.0.34",zi="1.3.132.0.35";async function Wi(r,t){let e=await crypto.subtle.importKey("jwk",r,{name:"ECDSA",namedCurve:r.crv??"P-256"},!1,["sign"]),n=await crypto.subtle.sign({name:"ECDSA",hash:{name:"SHA-256"}},e,t.subarray());return new Uint8Array(n,0,n.byteLength)}async function Zi(r,t,e){let n=await crypto.subtle.importKey("jwk",r,{name:"ECDSA",namedCurve:r.crv??"P-256"},!1,["verify"]);return crypto.subtle.verify({name:"ECDSA",hash:{name:"SHA-256"}},n,t,e.subarray())}var Gu=Uint8Array.from([6,8,42,134,72,206,61,3,1,7]),zu=Uint8Array.from([6,5,43,129,4,0,34]),Wu=Uint8Array.from([6,5,43,129,4,0,35]),Zu={ext:!0,kty:"EC",crv:"P-256"},Ju={ext:!0,kty:"EC",crv:"P-384"},Yu={ext:!0,kty:"EC",crv:"P-521"},ro=32,no=48,so=66;function Ji(r){let t=Tt(r);return oo(t)}function oo(r){let t=r[1],e=j(t,"base64url"),n=r[2][1][0],s=1,o,i;if(t.byteLength===ro)return o=j(n.subarray(s,s+ro),"base64url"),i=j(n.subarray(s+ro),"base64url"),new Xe({...Zu,key_ops:["sign"],d:e,x:o,y:i});if(t.byteLength===no)return o=j(n.subarray(s,s+no),"base64url"),i=j(n.subarray(s+no),"base64url"),new Xe({...Ju,key_ops:["sign"],d:e,x:o,y:i});if(t.byteLength===so)return o=j(n.subarray(s,s+so),"base64url"),i=j(n.subarray(s+so),"base64url"),new Xe({...Yu,key_ops:["sign"],d:e,x:o,y:i});throw new L(`Private key length was wrong length, got ${t.byteLength}, expected 32, 48 or 66`)}function Yi(r){return Ut([gt(Uint8Array.from([1])),ji(H(r.d??"","base64url")),Ut([Qi(r.crv)],160),Ut([Cr(new pt(Uint8Array.from([4]),H(r.x??"","base64url"),H(r.y??"","base64url")))],161)]).subarray()}function Xi(r){return Ut([gt(Uint8Array.from([1])),Ut([Qi(r.crv)],160),Ut([Cr(new pt(Uint8Array.from([4]),H(r.x??"","base64url"),H(r.y??"","base64url")))],161)]).subarray()}function Qi(r){if(r==="P-256")return Gu;if(r==="P-384")return zu;if(r==="P-521")return Wu;throw new L(`Invalid curve ${r}`)}var ln=class{type="ECDSA";jwk;_raw;constructor(t){this.jwk=t}get raw(){return this._raw==null&&(this._raw=Xi(this.jwk)),this._raw}toMultihash(){return ke.digest(Qe(this))}toCID(){return It.createV1(114,this.toMultihash())}toString(){return Q.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:xt(this.raw,t.raw)}async verify(t,e){return Zi(this.jwk,e,t)}},Xe=class{type="ECDSA";jwk;publicKey;_raw;constructor(t){this.jwk=t,this.publicKey=new ln({crv:t.crv,ext:t.ext,key_ops:["verify"],kty:"EC",x:t.x,y:t.y})}get raw(){return this._raw==null&&(this._raw=Yi(this.jwk)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:xt(this.raw,t.raw)}async sign(t){return Wi(this.jwk,t)}};function tr(r){if(!Number.isSafeInteger(r)||r<0)throw new Error("positive integer expected, got "+r)}function Xu(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function er(r,...t){if(!Xu(r))throw new Error("Uint8Array expected");if(t.length>0&&!t.includes(r.length))throw new Error("Uint8Array expected of length "+t+", got length="+r.length)}function un(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");tr(r.outputLen),tr(r.blockLen)}function rr(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 ta(r,t){er(r);let e=t.outputLen;if(r.length<e)throw new Error("digestInto() expects output buffer of length at least "+e)}var Ce=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;function Ne(r){return new DataView(r.buffer,r.byteOffset,r.byteLength)}function Lt(r,t){return r<<32-t|r>>>t}function fn(r,t){return r<<t|r>>>32-t>>>0}var Qu=async()=>{};async function ea(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 Qu(),n+=o)}}function ra(r){if(typeof r!="string")throw new Error("utf8ToBytes expected string, got "+typeof r);return new Uint8Array(new TextEncoder().encode(r))}function ae(r){return typeof r=="string"&&(r=ra(r)),er(r),r}function io(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];er(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 nr=class{clone(){return this._cloneInto()}};function na(r,t){if(t!==void 0&&{}.toString.call(t)!=="[object Object]")throw new Error("Options should be object or undefined");return Object.assign(r,t)}function sr(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 or(r=32){if(Ce&&typeof Ce.getRandomValues=="function")return Ce.getRandomValues(new Uint8Array(r));if(Ce&&typeof Ce.randomBytes=="function")return Ce.randomBytes(r);throw new Error("crypto.getRandomValues must be defined")}function tf(r,t,e,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(t,e,n);let s=BigInt(32),o=BigInt(4294967295),i=Number(e>>s&o),a=Number(e&o),c=n?4:0,f=n?0:4;r.setUint32(t+c,i,n),r.setUint32(t+f,a,n)}function hn(r,t,e){return r&t^~r&e}function dn(r,t,e){return r&t^r&e^t&e}var ce=class extends nr{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){rr(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){rr(this),ta(t,this),this.finished=!0;let{buffer:e,view:n,blockLen:s,isLE:o}=this,{pos:i}=this;e[i++]=128,this.buffer.subarray(i).fill(0),this.padOffset>s-i&&(this.process(n,0),i=0);for(let u=i;u<s;u++)e[u]=0;tf(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 f=c/4,l=this.get();if(f>l.length)throw new Error("_sha2: outputLen bigger than state");for(let u=0;u<f;u++)a.setUint32(4*u,l[u],o)}digest(){let{buffer:t,outputLen:e}=this;this.digestInto(t);let n=t.slice(0,e);return this.destroy(),n}_cloneInto(t){t||(t=new this.constructor),t.set(...this.get());let{blockLen:e,buffer:n,length:s,finished:o,destroyed:i,pos:a}=this;return t.length=s,t.pos=a,t.finished=o,t.destroyed=i,s%e&&t.buffer.set(n),t}};var pn=BigInt(4294967295),ao=BigInt(32);function sa(r,t=!1){return t?{h:Number(r&pn),l:Number(r>>ao&pn)}:{h:Number(r>>ao&pn)|0,l:Number(r&pn)|0}}function ef(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}=sa(r[s],t);[e[s],n[s]]=[o,i]}return[e,n]}var rf=(r,t)=>BigInt(r>>>0)<<ao|BigInt(t>>>0),nf=(r,t,e)=>r>>>e,sf=(r,t,e)=>r<<32-e|t>>>e,of=(r,t,e)=>r>>>e|t<<32-e,af=(r,t,e)=>r<<32-e|t>>>e,cf=(r,t,e)=>r<<64-e|t>>>e-32,lf=(r,t,e)=>r>>>e-32|t<<64-e,uf=(r,t)=>t,ff=(r,t)=>r,hf=(r,t,e)=>r<<e|t>>>32-e,df=(r,t,e)=>t<<e|r>>>32-e,pf=(r,t,e)=>t<<e-32|r>>>64-e,gf=(r,t,e)=>r<<e-32|t>>>64-e;function yf(r,t,e,n){let s=(t>>>0)+(n>>>0);return{h:r+e+(s/2**32|0)|0,l:s|0}}var mf=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),bf=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,wf=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),xf=(r,t,e,n,s)=>t+e+n+s+(r/2**32|0)|0,vf=(r,t,e,n,s)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(s>>>0),Bf=(r,t,e,n,s,o)=>t+e+n+s+o+(r/2**32|0)|0;var Ef={fromBig:sa,split:ef,toBig:rf,shrSH:nf,shrSL:sf,rotrSH:of,rotrSL:af,rotrBH:cf,rotrBL:lf,rotr32H:uf,rotr32L:ff,rotlSH:hf,rotlSL:df,rotlBH:pf,rotlBL:gf,add:yf,add3L:mf,add3H:bf,add4L:wf,add4H:xf,add5H:Bf,add5L:vf},O=Ef;var[Af,Sf]=O.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),co=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:f,El:l,Fh:u,Fl:h,Gh:y,Gl:b,Hh:m,Hl:d}=this;return[t,e,n,s,o,i,a,c,f,l,u,h,y,b,m,d]}set(t,e,n,s,o,i,a,c,f,l,u,h,y,b,m,d){this.Ah=t|0,this.Al=e|0,this.Bh=n|0,this.Bl=s|0,this.Ch=o|0,this.Cl=i|0,this.Dh=a|0,this.Dl=c|0,this.Eh=f|0,this.El=l|0,this.Fh=u|0,this.Fl=h|0,this.Gh=y|0,this.Gl=b|0,this.Hh=m|0,this.Hl=d|0}process(t,e){for(let p=0;p<16;p++,e+=4)le[p]=t.getUint32(e),ue[p]=t.getUint32(e+=4);for(let p=16;p<80;p++){let S=le[p-15]|0,R=ue[p-15]|0,U=O.rotrSH(S,R,1)^O.rotrSH(S,R,8)^O.shrSH(S,R,7),I=O.rotrSL(S,R,1)^O.rotrSL(S,R,8)^O.shrSL(S,R,7),T=le[p-2]|0,C=ue[p-2]|0,W=O.rotrSH(T,C,19)^O.rotrBH(T,C,61)^O.shrSH(T,C,6),q=O.rotrSL(T,C,19)^O.rotrBL(T,C,61)^O.shrSL(T,C,6),P=O.add4L(I,q,ue[p-7],ue[p-16]),tt=O.add4H(P,U,W,le[p-7],le[p-16]);le[p]=tt|0,ue[p]=P|0}let{Ah:n,Al:s,Bh:o,Bl:i,Ch:a,Cl:c,Dh:f,Dl:l,Eh:u,El:h,Fh:y,Fl:b,Gh:m,Gl:d,Hh:w,Hl:B}=this;for(let p=0;p<80;p++){let S=O.rotrSH(u,h,14)^O.rotrSH(u,h,18)^O.rotrBH(u,h,41),R=O.rotrSL(u,h,14)^O.rotrSL(u,h,18)^O.rotrBL(u,h,41),U=u&y^~u&m,I=h&b^~h&d,T=O.add5L(B,R,I,Sf[p],ue[p]),C=O.add5H(T,w,S,U,Af[p],le[p]),W=T|0,q=O.rotrSH(n,s,28)^O.rotrBH(n,s,34)^O.rotrBH(n,s,39),P=O.rotrSL(n,s,28)^O.rotrBL(n,s,34)^O.rotrBL(n,s,39),tt=n&o^n&a^o&a,E=s&i^s&c^i&c;w=m|0,B=d|0,m=y|0,d=b|0,y=u|0,b=h|0,{h:u,l:h}=O.add(f|0,l|0,C|0,W|0),f=a|0,l=c|0,a=o|0,c=i|0,o=n|0,i=s|0;let N=O.add3L(W,P,E);n=O.add3H(N,C,q,tt),s=N|0}({h:n,l:s}=O.add(this.Ah|0,this.Al|0,n|0,s|0)),{h:o,l:i}=O.add(this.Bh|0,this.Bl|0,o|0,i|0),{h:a,l:c}=O.add(this.Ch|0,this.Cl|0,a|0,c|0),{h:f,l}=O.add(this.Dh|0,this.Dl|0,f|0,l|0),{h:u,l:h}=O.add(this.Eh|0,this.El|0,u|0,h|0),{h:y,l:b}=O.add(this.Fh|0,this.Fl|0,y|0,b|0),{h:m,l:d}=O.add(this.Gh|0,this.Gl|0,m|0,d|0),{h:w,l:B}=O.add(this.Hh|0,this.Hl|0,w|0,B|0),this.set(n,s,o,i,a,c,f,l,u,h,y,b,m,d,w,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=sr(()=>new co);var mn={};ut(mn,{aInRange:()=>vt,abool:()=>Rt,abytes:()=>ir,bitGet:()=>Uf,bitLen:()=>ho,bitMask:()=>Tr,bitSet:()=>Lf,bytesToHex:()=>zt,bytesToNumberBE:()=>Wt,bytesToNumberLE:()=>de,concatBytes:()=>Zt,createHmacDrbg:()=>po,ensureBytes:()=>Y,equalBytes:()=>Nf,hexToBytes:()=>Ue,hexToNumber:()=>fo,inRange:()=>Nr,isBytes:()=>he,memoized:()=>Re,notImplemented:()=>_f,numberToBytesBE:()=>pe,numberToBytesLE:()=>Le,numberToHexUnpadded:()=>Te,numberToVarBytesBE:()=>Cf,utf8ToBytes:()=>Tf,validateObject:()=>Pt});var gn=BigInt(0),yn=BigInt(1),kf=BigInt(2);function he(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function ir(r){if(!he(r))throw new Error("Uint8Array expected")}function Rt(r,t){if(typeof t!="boolean")throw new Error(r+" boolean expected, got "+t)}var If=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function zt(r){ir(r);let t="";for(let e=0;e<r.length;e++)t+=If[r[e]];return t}function Te(r){let t=r.toString(16);return t.length&1?"0"+t:t}function fo(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return r===""?gn:BigInt("0x"+r)}var Gt={_0:48,_9:57,A:65,F:70,a:97,f:102};function oa(r){if(r>=Gt._0&&r<=Gt._9)return r-Gt._0;if(r>=Gt.A&&r<=Gt.F)return r-(Gt.A-10);if(r>=Gt.a&&r<=Gt.f)return r-(Gt.a-10)}function Ue(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("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=oa(r.charCodeAt(o)),a=oa(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 Wt(r){return fo(zt(r))}function de(r){return ir(r),fo(zt(Uint8Array.from(r).reverse()))}function pe(r,t){return Ue(r.toString(16).padStart(t*2,"0"))}function Le(r,t){return pe(r,t).reverse()}function Cf(r){return Ue(Te(r))}function Y(r,t,e){let n;if(typeof t=="string")try{n=Ue(t)}catch(o){throw new Error(r+" must be hex string or Uint8Array, cause: "+o)}else if(he(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+" of length "+e+" expected, got "+s);return n}function Zt(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];ir(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 Nf(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 Tf(r){if(typeof r!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(r))}var lo=r=>typeof r=="bigint"&&gn<=r;function Nr(r,t,e){return lo(r)&&lo(t)&&lo(e)&&t<=r&&r<e}function vt(r,t,e,n){if(!Nr(t,e,n))throw new Error("expected valid "+r+": "+e+" <= n < "+n+", got "+t)}function ho(r){let t;for(t=0;r>gn;r>>=yn,t+=1);return t}function Uf(r,t){return r>>BigInt(t)&yn}function Lf(r,t,e){return r|(e?yn:gn)<<BigInt(t)}var Tr=r=>(kf<<BigInt(r-1))-yn,uo=r=>new Uint8Array(r),ia=r=>Uint8Array.from(r);function po(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=uo(r),s=uo(r),o=0,i=()=>{n.fill(1),s.fill(0),o=0},a=(...u)=>e(s,n,...u),c=(u=uo())=>{s=a(ia([0]),u),n=a(),u.length!==0&&(s=a(ia([1]),u),n=a())},f=()=>{if(o++>=1e3)throw new Error("drbg: tried 1000 values");let u=0,h=[];for(;u<t;){n=a();let y=n.slice();h.push(y),u+=n.length}return Zt(...h)};return(u,h)=>{i(),c(u);let y;for(;!(y=h(f()));)c();return i(),y}}var Rf={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"||he(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 Pt(r,t,e={}){let n=(s,o,i)=>{let a=Rf[o];if(typeof a!="function")throw new Error("invalid validator function");let c=r[s];if(!(i&&c===void 0)&&!a(c,r))throw new Error("param "+String(s)+" is invalid. Expected "+o+", got "+c)};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 _f=()=>{throw new Error("not implemented")};function Re(r){let t=new WeakMap;return(e,...n)=>{let s=t.get(e);if(s!==void 0)return s;let o=r(e,...n);return t.set(e,o),o}}var et=BigInt(0),Z=BigInt(1),_e=BigInt(2),Df=BigInt(3),go=BigInt(4),aa=BigInt(5),ca=BigInt(8),Kf=BigInt(9),Of=BigInt(16);function G(r,t){let e=r%t;return e>=et?e:t+e}function Vf(r,t,e){if(t<et)throw new Error("invalid exponent, negatives unsupported");if(e<=et)throw new Error("invalid modulus");if(e===Z)return et;let n=Z;for(;t>et;)t&Z&&(n=n*r%e),r=r*r%e,t>>=Z;return n}function J(r,t,e){let n=r;for(;t-- >et;)n*=n,n%=e;return n}function bn(r,t){if(r===et)throw new Error("invert: expected non-zero number");if(t<=et)throw new Error("invert: expected positive modulus, got "+t);let e=G(r,t),n=t,s=et,o=Z,i=Z,a=et;for(;e!==et;){let f=n/e,l=n%e,u=s-i*f,h=o-a*f;n=e,e=l,s=i,o=a,i=u,a=h}if(n!==Z)throw new Error("invert: does not exist");return G(s,t)}function Hf(r){let t=(r-Z)/_e,e,n,s;for(e=r-Z,n=0;e%_e===et;e/=_e,n++);for(s=_e;s<r&&Vf(s,t,r)!==r-Z;s++)if(s>1e3)throw new Error("Cannot find square root: likely non-prime P");if(n===1){let i=(r+Z)/go;return function(c,f){let l=c.pow(f,i);if(!c.eql(c.sqr(l),f))throw new Error("Cannot find square root");return l}}let o=(e+Z)/_e;return function(a,c){if(a.pow(c,t)===a.neg(a.ONE))throw new Error("Cannot find square root");let f=n,l=a.pow(a.mul(a.ONE,s),e),u=a.pow(c,o),h=a.pow(c,e);for(;!a.eql(h,a.ONE);){if(a.eql(h,a.ZERO))return a.ZERO;let y=1;for(let m=a.sqr(h);y<f&&!a.eql(m,a.ONE);y++)m=a.sqr(m);let b=a.pow(l,Z<<BigInt(f-y-1));l=a.sqr(b),u=a.mul(u,b),h=a.mul(h,l),f=y}return u}}function Pf(r){if(r%go===Df){let t=(r+Z)/go;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%ca===aa){let t=(r-aa)/ca;return function(n,s){let o=n.mul(s,_e),i=n.pow(o,t),a=n.mul(s,i),c=n.mul(n.mul(a,_e),i),f=n.mul(a,n.sub(c,n.ONE));if(!n.eql(n.sqr(f),s))throw new Error("Cannot find square root");return f}}return r%Of,Hf(r)}var la=(r,t)=>(G(r,t)&Z)===Z,Mf=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function yo(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=Mf.reduce((n,s)=>(n[s]="function",n),t);return Pt(r,e)}function Ff(r,t,e){if(e<et)throw new Error("invalid exponent, negatives unsupported");if(e===et)return r.ONE;if(e===Z)return t;let n=r.ONE,s=t;for(;e>et;)e&Z&&(n=r.mul(n,s)),s=r.sqr(s),e>>=Z;return n}function qf(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 mo(r,t){let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function ge(r,t,e=!1,n={}){if(r<=et)throw new Error("invalid field: expected ORDER > 0, got "+r);let{nBitLength:s,nByteLength:o}=mo(r,t);if(o>2048)throw new Error("invalid field: expected ORDER of <= 2048 bytes");let i,a=Object.freeze({ORDER:r,isLE:e,BITS:s,BYTES:o,MASK:Tr(s),ZERO:et,ONE:Z,create:c=>G(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error("invalid field element: expected bigint, got "+typeof c);return et<=c&&c<r},is0:c=>c===et,isOdd:c=>(c&Z)===Z,neg:c=>G(-c,r),eql:(c,f)=>c===f,sqr:c=>G(c*c,r),add:(c,f)=>G(c+f,r),sub:(c,f)=>G(c-f,r),mul:(c,f)=>G(c*f,r),pow:(c,f)=>Ff(a,c,f),div:(c,f)=>G(c*bn(f,r),r),sqrN:c=>c*c,addN:(c,f)=>c+f,subN:(c,f)=>c-f,mulN:(c,f)=>c*f,inv:c=>bn(c,r),sqrt:n.sqrt||(c=>(i||(i=Pf(r)),i(a,c))),invertBatch:c=>qf(a,c),cmov:(c,f,l)=>l?f:c,toBytes:c=>e?Le(c,o):pe(c,o),fromBytes:c=>{if(c.length!==o)throw new Error("Field.fromBytes: expected "+o+" bytes, got "+c.length);return e?de(c):Wt(c)}});return Object.freeze(a)}function ua(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 bo(r){let t=ua(r);return t+Math.ceil(t/2)}function fa(r,t,e=!1){let n=r.length,s=ua(t),o=bo(t);if(n<16||n<o||n>1024)throw new Error("expected "+o+"-1024 bytes of input, got "+n);let i=e?de(r):Wt(r),a=G(i,t-Z)+Z;return e?Le(a,s):pe(a,s)}var ha=BigInt(0),wn=BigInt(1);function wo(r,t){let e=t.negate();return r?e:t}function da(r,t){if(!Number.isSafeInteger(r)||r<=0||r>t)throw new Error("invalid window size, expected [1.."+t+"], got W="+r)}function xo(r,t){da(r,t);let e=Math.ceil(t/r)+1,n=2**(r-1);return{windows:e,windowSize:n}}function jf(r,t){if(!Array.isArray(r))throw new Error("array expected");r.forEach((e,n)=>{if(!(e instanceof t))throw new Error("invalid point at index "+n)})}function $f(r,t){if(!Array.isArray(r))throw new Error("array of scalars expected");r.forEach((e,n)=>{if(!t.isValid(e))throw new Error("invalid scalar at index "+n)})}var vo=new WeakMap,pa=new WeakMap;function Bo(r){return pa.get(r)||1}function xn(r,t){return{constTimeNegate:wo,hasPrecomputes(e){return Bo(e)!==1},unsafeLadder(e,n,s=r.ZERO){let o=e;for(;n>ha;)n&wn&&(s=s.add(o)),o=o.double(),n>>=wn;return s},precomputeWindow(e,n){let{windows:s,windowSize:o}=xo(n,t),i=[],a=e,c=a;for(let f=0;f<s;f++){c=a,i.push(c);for(let l=1;l<o;l++)c=c.add(a),i.push(c);a=c.double()}return i},wNAF(e,n,s){let{windows:o,windowSize:i}=xo(e,t),a=r.ZERO,c=r.BASE,f=BigInt(2**e-1),l=2**e,u=BigInt(e);for(let h=0;h<o;h++){let y=h*i,b=Number(s&f);s>>=u,b>i&&(b-=l,s+=wn);let m=y,d=y+Math.abs(b)-1,w=h%2!==0,B=b<0;b===0?c=c.add(wo(w,n[m])):a=a.add(wo(B,n[d]))}return{p:a,f:c}},wNAFUnsafe(e,n,s,o=r.ZERO){let{windows:i,windowSize:a}=xo(e,t),c=BigInt(2**e-1),f=2**e,l=BigInt(e);for(let u=0;u<i;u++){let h=u*a;if(s===ha)break;let y=Number(s&c);if(s>>=l,y>a&&(y-=f,s+=wn),y===0)continue;let b=n[h+Math.abs(y)-1];y<0&&(b=b.negate()),o=o.add(b)}return o},getPrecomputes(e,n,s){let o=vo.get(n);return o||(o=this.precomputeWindow(n,e),e!==1&&vo.set(n,s(o))),o},wNAFCached(e,n,s){let o=Bo(e);return this.wNAF(o,this.getPrecomputes(o,e,s),n)},wNAFCachedUnsafe(e,n,s,o){let i=Bo(e);return i===1?this.unsafeLadder(e,n,o):this.wNAFUnsafe(i,this.getPrecomputes(i,e,s),n,o)},setWindowSize(e,n){da(n,t),pa.set(e,n),vo.delete(e)}}}function vn(r,t,e,n){if(jf(e,r),$f(n,t),e.length!==n.length)throw new Error("arrays of points and scalars must have equal length");let s=r.ZERO,o=ho(BigInt(e.length)),i=o>12?o-3:o>4?o-2:o?2:1,a=(1<<i)-1,c=new Array(a+1).fill(s),f=Math.floor((t.BITS-1)/i)*i,l=s;for(let u=f;u>=0;u-=i){c.fill(s);for(let y=0;y<n.length;y++){let b=n[y],m=Number(b>>BigInt(u)&BigInt(a));c[m]=c[m].add(e[y])}let h=s;for(let y=c.length-1,b=s;y>0;y--)b=b.add(c[y]),h=h.add(b);if(l=l.add(h),u!==0)for(let y=0;y<i;y++)l=l.double()}return l}function Ur(r){return yo(r.Fp),Pt(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...mo(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var _t=BigInt(0),Bt=BigInt(1),Bn=BigInt(2),Gf=BigInt(8),zf={zip215:!0};function Wf(r){let t=Ur(r);return Pt(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function ga(r){let t=Wf(r),{Fp:e,n,prehash:s,hash:o,randomBytes:i,nByteLength:a,h:c}=t,f=Bn<<BigInt(a*8)-Bt,l=e.create,u=ge(t.n,t.nBitLength),h=t.uvRatio||((x,g)=>{try{return{isValid:!0,value:e.sqrt(x*e.inv(g))}}catch{return{isValid:!1,value:_t}}}),y=t.adjustScalarBytes||(x=>x),b=t.domain||((x,g,v)=>{if(Rt("phflag",v),g.length||v)throw new Error("Contexts/pre-hash are not supported");return x});function m(x,g){vt("coordinate "+x,g,_t,f)}function d(x){if(!(x instanceof p))throw new Error("ExtendedPoint expected")}let w=Re((x,g)=>{let{ex:v,ey:k,ez:_}=x,D=x.is0();g==null&&(g=D?Gf:e.inv(_));let V=l(v*g),F=l(k*g),K=l(_*g);if(D)return{x:_t,y:Bt};if(K!==Bt)throw new Error("invZ was invalid");return{x:V,y:F}}),B=Re(x=>{let{a:g,d:v}=t;if(x.is0())throw new Error("bad point: ZERO");let{ex:k,ey:_,ez:D,et:V}=x,F=l(k*k),K=l(_*_),$=l(D*D),z=l($*$),nt=l(F*g),st=l($*l(nt+K)),it=l(z+l(v*l(F*K)));if(st!==it)throw new Error("bad point: equation left != right (1)");let lt=l(k*_),bt=l(D*V);if(lt!==bt)throw new Error("bad point: equation left != right (2)");return!0});class p{constructor(g,v,k,_){this.ex=g,this.ey=v,this.ez=k,this.et=_,m("x",g),m("y",v),m("z",k),m("t",_),Object.freeze(this)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(g){if(g instanceof p)throw new Error("extended point not allowed");let{x:v,y:k}=g||{};return m("x",v),m("y",k),new p(v,k,Bt,l(v*k))}static normalizeZ(g){let v=e.invertBatch(g.map(k=>k.ez));return g.map((k,_)=>k.toAffine(v[_])).map(p.fromAffine)}static msm(g,v){return vn(p,u,g,v)}_setWindowSize(g){U.setWindowSize(this,g)}assertValidity(){B(this)}equals(g){d(g);let{ex:v,ey:k,ez:_}=this,{ex:D,ey:V,ez:F}=g,K=l(v*F),$=l(D*_),z=l(k*F),nt=l(V*_);return K===$&&z===nt}is0(){return this.equals(p.ZERO)}negate(){return new p(l(-this.ex),this.ey,this.ez,l(-this.et))}double(){let{a:g}=t,{ex:v,ey:k,ez:_}=this,D=l(v*v),V=l(k*k),F=l(Bn*l(_*_)),K=l(g*D),$=v+k,z=l(l($*$)-D-V),nt=K+V,st=nt-F,it=K-V,lt=l(z*st),bt=l(nt*it),dt=l(z*it),Ht=l(st*nt);return new p(lt,bt,Ht,dt)}add(g){d(g);let{a:v,d:k}=t,{ex:_,ey:D,ez:V,et:F}=this,{ex:K,ey:$,ez:z,et:nt}=g;if(v===BigInt(-1)){let ui=l((D-_)*($+K)),fi=l((D+_)*($-K)),Us=l(fi-ui);if(Us===_t)return this.double();let hi=l(V*Bn*nt),di=l(F*Bn*z),pi=di+hi,gi=fi+ui,yi=di-hi,Al=l(pi*Us),Sl=l(gi*yi),kl=l(pi*yi),Il=l(Us*gi);return new p(Al,Sl,Il,kl)}let st=l(_*K),it=l(D*$),lt=l(F*k*nt),bt=l(V*z),dt=l((_+D)*(K+$)-st-it),Ht=bt-lt,qt=bt+lt,mr=l(it-v*st),xl=l(dt*Ht),vl=l(qt*mr),Bl=l(dt*mr),El=l(Ht*qt);return new p(xl,vl,El,Bl)}subtract(g){return this.add(g.negate())}wNAF(g){return U.wNAFCached(this,g,p.normalizeZ)}multiply(g){let v=g;vt("scalar",v,Bt,n);let{p:k,f:_}=this.wNAF(v);return p.normalizeZ([k,_])[0]}multiplyUnsafe(g,v=p.ZERO){let k=g;return vt("scalar",k,_t,n),k===_t?R:this.is0()||k===Bt?this:U.wNAFCachedUnsafe(this,k,p.normalizeZ,v)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return U.unsafeLadder(this,n).is0()}toAffine(g){return w(this,g)}clearCofactor(){let{h:g}=t;return g===Bt?this:this.multiplyUnsafe(g)}static fromHex(g,v=!1){let{d:k,a:_}=t,D=e.BYTES;g=Y("pointHex",g,D),Rt("zip215",v);let V=g.slice(),F=g[D-1];V[D-1]=F&-129;let K=de(V),$=v?f:e.ORDER;vt("pointHex.y",K,_t,$);let z=l(K*K),nt=l(z-Bt),st=l(k*z-_),{isValid:it,value:lt}=h(nt,st);if(!it)throw new Error("Point.fromHex: invalid y coordinate");let bt=(lt&Bt)===Bt,dt=(F&128)!==0;if(!v&&lt===_t&&dt)throw new Error("Point.fromHex: x=0 and x_0=1");return dt!==bt&&(lt=l(-lt)),p.fromAffine({x:lt,y:K})}static fromPrivateKey(g){return C(g).point}toRawBytes(){let{x:g,y:v}=this.toAffine(),k=Le(v,e.BYTES);return k[k.length-1]|=g&Bt?128:0,k}toHex(){return zt(this.toRawBytes())}}p.BASE=new p(t.Gx,t.Gy,Bt,l(t.Gx*t.Gy)),p.ZERO=new p(_t,Bt,Bt,_t);let{BASE:S,ZERO:R}=p,U=xn(p,a*8);function I(x){return G(x,n)}function T(x){return I(de(x))}function C(x){let g=e.BYTES;x=Y("private key",x,g);let v=Y("hashed private key",o(x),2*g),k=y(v.slice(0,g)),_=v.slice(g,2*g),D=T(k),V=S.multiply(D),F=V.toRawBytes();return{head:k,prefix:_,scalar:D,point:V,pointBytes:F}}function W(x){return C(x).pointBytes}function q(x=new Uint8Array,...g){let v=Zt(...g);return T(o(b(v,Y("context",x),!!s)))}function P(x,g,v={}){x=Y("message",x),s&&(x=s(x));let{prefix:k,scalar:_,pointBytes:D}=C(g),V=q(v.context,k,x),F=S.multiply(V).toRawBytes(),K=q(v.context,F,D,x),$=I(V+K*_);vt("signature.s",$,_t,n);let z=Zt(F,Le($,e.BYTES));return Y("result",z,e.BYTES*2)}let tt=zf;function E(x,g,v,k=tt){let{context:_,zip215:D}=k,V=e.BYTES;x=Y("signature",x,2*V),g=Y("message",g),v=Y("publicKey",v,V),D!==void 0&&Rt("zip215",D),s&&(g=s(g));let F=de(x.slice(V,2*V)),K,$,z;try{K=p.fromHex(v,D),$=p.fromHex(x.slice(0,V),D),z=S.multiplyUnsafe(F)}catch{return!1}if(!D&&K.isSmallOrder())return!1;let nt=q(_,$.toRawBytes(),K.toRawBytes(),g);return $.add(K.multiplyUnsafe(nt)).subtract(z).clearCofactor().equals(p.ZERO)}return S._setWindowSize(8),{CURVE:t,getPublicKey:W,sign:P,verify:E,ExtendedPoint:p,utils:{getExtendedPublicKey:C,randomPrivateKey:()=>i(e.BYTES),precompute(x=8,g=p.BASE){return g._setWindowSize(x),g.multiply(BigInt(3)),g}}}}var Eo=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),ya=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),zp=BigInt(0),Zf=BigInt(1),ma=BigInt(2),Wp=BigInt(3),Jf=BigInt(5),Yf=BigInt(8);function Xf(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),s=BigInt(80),o=Eo,a=r*r%o*r%o,c=J(a,ma,o)*a%o,f=J(c,Zf,o)*r%o,l=J(f,Jf,o)*f%o,u=J(l,t,o)*l%o,h=J(u,e,o)*u%o,y=J(h,n,o)*h%o,b=J(y,s,o)*y%o,m=J(b,s,o)*y%o,d=J(m,t,o)*l%o;return{pow_p_5_8:J(d,ma,o)*r%o,b2:a}}function Qf(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function th(r,t){let e=Eo,n=G(t*t*t,e),s=G(n*n*t,e),o=Xf(r*s).pow_p_5_8,i=G(r*n*o,e),a=G(t*i*i,e),c=i,f=G(i*ya,e),l=a===r,u=a===G(-r,e),h=a===G(-r*ya,e);return l&&(i=c),(u||h)&&(i=f),la(i,e)&&(i=G(-i,e)),{isValid:l||u,value:i}}var eh=ge(Eo,void 0,!0),rh={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:eh,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:Yf,Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:fe,randomBytes:or,adjustScalarBytes:Qf,uvRatio:th},Ao=ga(rh);var ar=32,Dt=64,nh=32;function ba(r,t){let e=r.subarray(0,nh);return Ao.sign(t instanceof Uint8Array?t:t.subarray(),e)}function wa(r,t,e){return Ao.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}var En=class{type="Ed25519";raw;constructor(t){this.raw=Rr(t,ar)}toMultihash(){return ke.digest(Qe(this))}toCID(){return It.createV1(114,this.toMultihash())}toString(){return Q.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:xt(this.raw,t.raw)}verify(t,e){return wa(this.raw,e,t)}},Lr=class{type="Ed25519";raw;publicKey;constructor(t,e){this.raw=Rr(t,Dt),this.publicKey=new En(e)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:xt(this.raw,t.raw)}sign(t){return ba(this.raw,t)}};function So(r){if(r.length>Dt){r=Rr(r,Dt+ar);let n=r.subarray(0,Dt),s=r.subarray(Dt,r.length);return new Lr(n,s)}r=Rr(r,Dt);let t=r.subarray(0,Dt),e=r.subarray(ar);return new Lr(t,e)}function Rr(r,t){if(r=Uint8Array.from(r??[]),r.length!==t)throw new L(`Key must be a Uint8Array of length ${t}, got ${r.length}`);return r}var sh=Math.pow(2,7),oh=Math.pow(2,14),ih=Math.pow(2,21),va=Math.pow(2,28),Ba=Math.pow(2,35),Ea=Math.pow(2,42),Aa=Math.pow(2,49),yt=128,ye=127;function _r(r){if(r<sh)return 1;if(r<oh)return 2;if(r<ih)return 3;if(r<va)return 4;if(r<Ba)return 5;if(r<Ea)return 6;if(r<Aa)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function Sa(r,t,e=0){switch(_r(r)){case 8:t[e++]=r&255|yt,r/=128;case 7:t[e++]=r&255|yt,r/=128;case 6:t[e++]=r&255|yt,r/=128;case 5:t[e++]=r&255|yt,r/=128;case 4:t[e++]=r&255|yt,r>>>=7;case 3:t[e++]=r&255|yt,r>>>=7;case 2:t[e++]=r&255|yt,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function ka(r,t){let e=r[t],n=0;if(n+=e&ye,e<yt||(e=r[t+1],n+=(e&ye)<<7,e<yt)||(e=r[t+2],n+=(e&ye)<<14,e<yt)||(e=r[t+3],n+=(e&ye)<<21,e<yt)||(e=r[t+4],n+=(e&ye)*va,e<yt)||(e=r[t+5],n+=(e&ye)*Ba,e<yt)||(e=r[t+6],n+=(e&ye)*Ea,e<yt)||(e=r[t+7],n+=(e&ye)*Aa,e<yt))return n;throw new RangeError("Could not decode varint")}var ko=new Float32Array([-0]),me=new Uint8Array(ko.buffer);function Ia(r,t,e){ko[0]=r,t[e]=me[0],t[e+1]=me[1],t[e+2]=me[2],t[e+3]=me[3]}function Ca(r,t){return me[0]=r[t],me[1]=r[t+1],me[2]=r[t+2],me[3]=r[t+3],ko[0]}var Io=new Float64Array([-0]),ft=new Uint8Array(Io.buffer);function Na(r,t,e){Io[0]=r,t[e]=ft[0],t[e+1]=ft[1],t[e+2]=ft[2],t[e+3]=ft[3],t[e+4]=ft[4],t[e+5]=ft[5],t[e+6]=ft[6],t[e+7]=ft[7]}function Ta(r,t){return ft[0]=r[t],ft[1]=r[t+1],ft[2]=r[t+2],ft[3]=r[t+3],ft[4]=r[t+4],ft[5]=r[t+5],ft[6]=r[t+6],ft[7]=r[t+7],Io[0]}var ah=BigInt(Number.MAX_SAFE_INTEGER),ch=BigInt(Number.MIN_SAFE_INTEGER),kt=class r{lo;hi;constructor(t,e){this.lo=t|0,this.hi=e|0}toNumber(t=!1){if(!t&&this.hi>>>31>0){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(e+n*4294967296)}return this.lo+this.hi*4294967296}toBigInt(t=!1){if(t)return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n);if(this.hi>>>31){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(BigInt(e)+(BigInt(n)<<32n))}return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n)}toString(t=!1){return this.toBigInt(t).toString()}zzEncode(){let t=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^t)>>>0,this.lo=(this.lo<<1^t)>>>0,this}zzDecode(){let t=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^t)>>>0,this.hi=(this.hi>>>1^t)>>>0,this}length(){let t=this.lo,e=(this.lo>>>28|this.hi<<4)>>>0,n=this.hi>>>24;return n===0?e===0?t<16384?t<128?1:2:t<2097152?3:4:e<16384?e<128?5:6:e<2097152?7:8:n<128?9:10}static fromBigInt(t){if(t===0n)return De;if(t<ah&&t>ch)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>Ua&&(s=0n,++n>Ua&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(t){if(t===0)return De;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):De}},De=new kt(0,0);De.toBigInt=function(){return 0n};De.zzEncode=De.zzDecode=function(){return this};De.length=function(){return 1};var Ua=4294967296n;function La(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 Ra(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 Co(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 Kt(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function An(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var No=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,Kt(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 Kt(this,4);return An(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Kt(this,4);return An(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Kt(this,4);let t=Ca(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Kt(this,4);let t=Ta(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 Kt(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return Ra(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw Kt(this,t);this.pos+=t}else do if(this.pos>=this.len)throw Kt(this);while((this.buf[this.pos++]&128)!==0);return this}skipType(t){switch(t){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;(t=this.uint32()&7)!==4;)this.skipType(t);break;case 5:this.skip(4);break;default:throw Error(`invalid wire type ${t} at offset ${this.pos}`)}return this}readLongVarint(){let t=new kt(0,0),e=0;if(this.len-this.pos>4){for(;e<4;++e)if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t;if(t.lo=(t.lo|(this.buf[this.pos]&127)<<28)>>>0,t.hi=(t.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return t;e=0}else{for(;e<3;++e){if(this.pos>=this.len)throw Kt(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 Kt(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 Kt(this,8);let t=An(this.buf,this.pos+=4),e=An(this.buf,this.pos+=4);return new kt(t,e)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){let t=ka(this.buf,this.pos);return this.pos+=_r(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 To(r){return new No(r instanceof Uint8Array?r:r.subarray())}function Sn(r,t,e){let n=To(r);return t.decode(n,void 0,e)}function Uo(r){let t=r??8192,e=t>>>1,n,s=t;return function(i){if(i<1||i>e)return St(i);s+i>t&&(n=St(t),s=0);let a=n.subarray(s,s+=i);return(s&7)!==0&&(s=(s|7)+1),a}}var Ke=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function Lo(){}var _o=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},lh=Uo();function uh(r){return globalThis.Buffer!=null?St(r):lh(r)}var Kr=class{len;head;tail;states;constructor(){this.len=0,this.head=new Ke(Lo,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new Ke(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new Do((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(kn,10,kt.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=kt.fromBigInt(t);return this._push(kn,e.length(),e)}uint64Number(t){return this._push(Sa,_r(t),t)}uint64String(t){return this.uint64(BigInt(t))}int64(t){return this.uint64(t)}int64Number(t){return this.uint64Number(t)}int64String(t){return this.uint64String(t)}sint64(t){let e=kt.fromBigInt(t).zzEncode();return this._push(kn,e.length(),e)}sint64Number(t){let e=kt.fromNumber(t).zzEncode();return this._push(kn,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(Ro,1,t?1:0)}fixed32(t){return this._push(Dr,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=kt.fromBigInt(t);return this._push(Dr,4,e.lo)._push(Dr,4,e.hi)}fixed64Number(t){let e=kt.fromNumber(t);return this._push(Dr,4,e.lo)._push(Dr,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(Ia,4,t)}double(t){return this._push(Na,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(Ro,1,0):this.uint32(e)._push(hh,e,t)}string(t){let e=La(t);return e!==0?this.uint32(e)._push(Co,e,t):this._push(Ro,1,0)}fork(){return this.states=new _o(this),this.head=this.tail=new Ke(Lo,0,0),this.len=0,this}reset(){return this.states!=null?(this.head=this.states.head,this.tail=this.states.tail,this.len=this.states.len,this.states=this.states.next):(this.head=this.tail=new Ke(Lo,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=uh(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function Ro(r,t,e){t[e]=r&255}function fh(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var Do=class extends Ke{next;constructor(t,e){super(fh,t,e),this.next=void 0}};function kn(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 Dr(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 hh(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(Kr.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(dh,t,r),this},Kr.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(ph,t,r),this});function dh(r,t,e){t.set(r,e)}function ph(r,t,e){r.length<40?Co(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(H(r),e)}function Ko(){return new Kr}function In(r,t){let e=Ko();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var cr;(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"})(cr||(cr={}));function Cn(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function Oo(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 Cn("enum",cr.VARINT,e,n)}function Nn(r,t){return Cn("message",cr.LENGTH_DELIMITED,r,t)}var rt;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.secp256k1="secp256k1",r.ECDSA="ECDSA"})(rt||(rt={}));var Vo;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1",r[r.ECDSA=3]="ECDSA"})(Vo||(Vo={}));(function(r){r.codec=()=>Oo(Vo)})(rt||(rt={}));var be;(function(r){let t;r.codec=()=>(t==null&&(t=Nn((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),rt.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let o={},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let a=e.uint32();switch(a>>>3){case 1:{o.Type=rt.codec().decode(e);break}case 2:{o.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return o})),t),r.encode=e=>In(e,r.codec()),r.decode=(e,n)=>Sn(e,r.codec(),n)})(be||(be={}));var Or;(function(r){let t;r.codec=()=>(t==null&&(t=Nn((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),rt.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let o={},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let a=e.uint32();switch(a>>>3){case 1:{o.Type=rt.codec().decode(e);break}case 2:{o.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return o})),t),r.encode=e=>In(e,r.codec()),r.decode=(e,n)=>Sn(e,r.codec(),n)})(Or||(Or={}));function Oe(r){if(isNaN(r)||r<=0)throw new L("random bytes length must be a Number bigger than 0");return or(r)}var Hr={};ut(Hr,{MAX_RSA_KEY_SIZE:()=>Po,generateRSAKeyPair:()=>Ha,jwkToJWKKeyPair:()=>Pa,jwkToPkcs1:()=>wh,jwkToPkix:()=>jo,jwkToRSAPrivateKey:()=>zo,pkcs1MessageToJwk:()=>Fo,pkcs1MessageToRSAPrivateKey:()=>Tn,pkcs1ToJwk:()=>bh,pkcs1ToRSAPrivateKey:()=>$o,pkixMessageToJwk:()=>qo,pkixMessageToRSAPublicKey:()=>Go,pkixToJwk:()=>xh,pkixToRSAPublicKey:()=>Va});var gh=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]),we=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),xe=new Uint32Array(64),Ho=class extends ce{constructor(){super(64,32,8,!1),this.A=we[0]|0,this.B=we[1]|0,this.C=we[2]|0,this.D=we[3]|0,this.E=we[4]|0,this.F=we[5]|0,this.G=we[6]|0,this.H=we[7]|0}get(){let{A:t,B:e,C:n,D:s,E:o,F:i,G:a,H:c}=this;return[t,e,n,s,o,i,a,c]}set(t,e,n,s,o,i,a,c){this.A=t|0,this.B=e|0,this.C=n|0,this.D=s|0,this.E=o|0,this.F=i|0,this.G=a|0,this.H=c|0}process(t,e){for(let u=0;u<16;u++,e+=4)xe[u]=t.getUint32(e,!1);for(let u=16;u<64;u++){let h=xe[u-15],y=xe[u-2],b=Lt(h,7)^Lt(h,18)^h>>>3,m=Lt(y,17)^Lt(y,19)^y>>>10;xe[u]=m+xe[u-7]+b+xe[u-16]|0}let{A:n,B:s,C:o,D:i,E:a,F:c,G:f,H:l}=this;for(let u=0;u<64;u++){let h=Lt(a,6)^Lt(a,11)^Lt(a,25),y=l+h+hn(a,c,f)+gh[u]+xe[u]|0,m=(Lt(n,2)^Lt(n,13)^Lt(n,22))+dn(n,s,o)|0;l=f,f=c,c=a,a=i+y|0,i=o,o=s,s=n,n=y+m|0}n=n+this.A|0,s=s+this.B|0,o=o+this.C|0,i=i+this.D|0,a=a+this.E|0,c=c+this.F|0,f=f+this.G|0,l=l+this.H|0,this.set(n,s,o,i,a,c,f,l)}roundClean(){xe.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var ve=sr(()=>new Ho);var lr=class{type="RSA";jwk;_raw;_multihash;constructor(t,e){this.jwk=t,this._multihash=e}get raw(){return this._raw==null&&(this._raw=Hr.jwkToPkix(this.jwk)),this._raw}toMultihash(){return this._multihash}toCID(){return It.createV1(114,this._multihash)}toString(){return Q.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:xt(this.raw,t.raw)}verify(t,e){return Oa(this.jwk,e,t)}},Vr=class{type="RSA";jwk;_raw;publicKey;constructor(t,e){this.jwk=t,this.publicKey=e}get raw(){return this._raw==null&&(this._raw=Hr.jwkToPkcs1(this.jwk)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:xt(this.raw,t.raw)}sign(t){return Ka(this.jwk,t)}};var Po=8192,Mo=18,yh=1062,mh=Uint8Array.from([48,13,6,9,42,134,72,134,247,13,1,1,1,5,0]);function bh(r){let t=Tt(r);return Fo(t)}function Fo(r){return{n:j(r[1],"base64url"),e:j(r[2],"base64url"),d:j(r[3],"base64url"),p:j(r[4],"base64url"),q:j(r[5],"base64url"),dp:j(r[6],"base64url"),dq:j(r[7],"base64url"),qi:j(r[8],"base64url"),kty:"RSA"}}function wh(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 L("JWK was missing components");return Ut([gt(Uint8Array.from([0])),gt(H(r.n,"base64url")),gt(H(r.e,"base64url")),gt(H(r.d,"base64url")),gt(H(r.p,"base64url")),gt(H(r.q,"base64url")),gt(H(r.dp,"base64url")),gt(H(r.dq,"base64url")),gt(H(r.qi,"base64url"))]).subarray()}function xh(r){let t=Tt(r,{offset:0});return qo(t)}function qo(r){let t=Tt(r[1],{offset:0});return{kty:"RSA",n:j(t[0],"base64url"),e:j(t[1],"base64url")}}function jo(r){if(r.n==null||r.e==null)throw new L("JWK was missing components");return Ut([mh,Cr(Ut([gt(H(r.n,"base64url")),gt(H(r.e,"base64url"))]))]).subarray()}function $o(r){let t=Tt(r);return Tn(t)}function Tn(r){let t=Fo(r);return zo(t)}function Va(r,t){if(r.byteLength>=yh)throw new qe("Key size is too large");let e=Tt(r,{offset:0});return Go(e,r,t)}function Go(r,t,e){let n=qo(r);if(e==null){let s=ve(be.encode({Type:rt.RSA,Data:t}));e=Nt(Mo,s)}return new lr(n,e)}function zo(r){if(Fa(r)>Po)throw new L("Key size is too large");let t=Pa(r),e=ve(be.encode({Type:rt.RSA,Data:jo(t.publicKey)})),n=Nt(Mo,e);return new Vr(t.privateKey,new lr(t.publicKey,n))}async function Ha(r){if(r>Po)throw new L("Key size is too large");let t=await Ma(r),e=ve(be.encode({Type:rt.RSA,Data:jo(t.publicKey)})),n=Nt(Mo,e);return new Vr(t.privateKey,new lr(t.publicKey,n))}function Pa(r){if(r==null)throw new L("Missing key parameter");return{privateKey:r,publicKey:{kty:r.kty,n:r.n,e:r.e}}}async function Ma(r){let t=await wt.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 vh(t);return{privateKey:e[0],publicKey:e[1]}}async function Ka(r,t){let e=await wt.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await wt.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},e,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(n,0,n.byteLength)}async function Oa(r,t,e){let n=await wt.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return wt.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,t,e instanceof Uint8Array?e:e.subarray())}async function vh(r){if(r.privateKey==null||r.publicKey==null)throw new L("Private and public key are required");return Promise.all([wt.get().subtle.exportKey("jwk",r.privateKey),wt.get().subtle.exportKey("jwk",r.publicKey)])}function Fa(r){if(r.kty!=="RSA")throw new L("invalid key type");if(r.n==null)throw new L("invalid key modulus");return H(r.n,"base64url").length*8}var Un=class extends nr{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,un(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 rr(this),this.iHash.update(t),this}digestInto(t){rr(this),er(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()}},Pr=(r,t,e)=>new Un(r,t).update(e).digest();Pr.create=(r,t)=>new Un(r,t);function qa(r){r.lowS!==void 0&&Rt("lowS",r.lowS),r.prehash!==void 0&&Rt("prehash",r.prehash)}function Bh(r){let t=Ur(r);Pt(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("invalid endomorphism, can only be defined for Koblitz curves that have a=0");if(typeof e!="object"||typeof e.beta!="bigint"||typeof e.splitScalar!="function")throw new Error("invalid endomorphism, expected beta: bigint and splitScalar: function")}return Object.freeze({...t})}var{bytesToNumberBE:Eh,hexToBytes:Ah}=mn,Wo=class extends Error{constructor(t=""){super(t)}},Jt={Err:Wo,_tlv:{encode:(r,t)=>{let{Err:e}=Jt;if(r<0||r>256)throw new e("tlv.encode: wrong tag");if(t.length&1)throw new e("tlv.encode: unpadded data");let n=t.length/2,s=Te(n);if(s.length/2&128)throw new e("tlv.encode: long form length too big");let o=n>127?Te(s.length/2|128):"";return Te(r)+o+s+t},decode(r,t){let{Err:e}=Jt,n=0;if(r<0||r>256)throw new e("tlv.encode: wrong tag");if(t.length<2||t[n++]!==r)throw new e("tlv.decode: wrong tlv");let s=t[n++],o=!!(s&128),i=0;if(!o)i=s;else{let c=s&127;if(!c)throw new e("tlv.decode(long): indefinite length not supported");if(c>4)throw new e("tlv.decode(long): byte length is too big");let f=t.subarray(n,n+c);if(f.length!==c)throw new e("tlv.decode: length bytes not complete");if(f[0]===0)throw new e("tlv.decode(long): zero leftmost byte");for(let l of f)i=i<<8|l;if(n+=c,i<128)throw new e("tlv.decode(long): not minimal encoding")}let a=t.subarray(n,n+i);if(a.length!==i)throw new e("tlv.decode: wrong value length");return{v:a,l:t.subarray(n+i)}}},_int:{encode(r){let{Err:t}=Jt;if(r<Yt)throw new t("integer: negative integers are not allowed");let e=Te(r);if(Number.parseInt(e[0],16)&8&&(e="00"+e),e.length&1)throw new t("unexpected DER parsing assertion: unpadded hex");return e},decode(r){let{Err:t}=Jt;if(r[0]&128)throw new t("invalid signature integer: negative");if(r[0]===0&&!(r[1]&128))throw new t("invalid signature integer: unnecessary leading zero");return Eh(r)}},toSig(r){let{Err:t,_int:e,_tlv:n}=Jt,s=typeof r=="string"?Ah(r):r;ir(s);let{v:o,l:i}=n.decode(48,s);if(i.length)throw new t("invalid signature: left bytes after parsing");let{v:a,l:c}=n.decode(2,o),{v:f,l}=n.decode(2,c);if(l.length)throw new t("invalid signature: left bytes after parsing");return{r:e.decode(a),s:e.decode(f)}},hexFromSig(r){let{_tlv:t,_int:e}=Jt,n=t.encode(2,e.encode(r.r)),s=t.encode(2,e.encode(r.s)),o=n+s;return t.encode(48,o)}},Yt=BigInt(0),ot=BigInt(1),xy=BigInt(2),ja=BigInt(3),vy=BigInt(4);function Sh(r){let t=Bh(r),{Fp:e}=t,n=ge(t.n,t.nBitLength),s=t.toBytes||((m,d,w)=>{let B=d.toAffine();return Zt(Uint8Array.from([4]),e.toBytes(B.x),e.toBytes(B.y))}),o=t.fromBytes||(m=>{let d=m.subarray(1),w=e.fromBytes(d.subarray(0,e.BYTES)),B=e.fromBytes(d.subarray(e.BYTES,2*e.BYTES));return{x:w,y:B}});function i(m){let{a:d,b:w}=t,B=e.sqr(m),p=e.mul(B,m);return e.add(e.add(p,e.mul(m,d)),w)}if(!e.eql(e.sqr(t.Gy),i(t.Gx)))throw new Error("bad generator point: equation left != right");function a(m){return Nr(m,ot,t.n)}function c(m){let{allowedPrivateKeyLengths:d,nByteLength:w,wrapPrivateKey:B,n:p}=t;if(d&&typeof m!="bigint"){if(he(m)&&(m=zt(m)),typeof m!="string"||!d.includes(m.length))throw new Error("invalid private key");m=m.padStart(w*2,"0")}let S;try{S=typeof m=="bigint"?m:Wt(Y("private key",m,w))}catch{throw new Error("invalid private key, expected hex or "+w+" bytes, got "+typeof m)}return B&&(S=G(S,p)),vt("private key",S,ot,p),S}function f(m){if(!(m instanceof h))throw new Error("ProjectivePoint expected")}let l=Re((m,d)=>{let{px:w,py:B,pz:p}=m;if(e.eql(p,e.ONE))return{x:w,y:B};let S=m.is0();d==null&&(d=S?e.ONE:e.inv(p));let R=e.mul(w,d),U=e.mul(B,d),I=e.mul(p,d);if(S)return{x:e.ZERO,y:e.ZERO};if(!e.eql(I,e.ONE))throw new Error("invZ was invalid");return{x:R,y:U}}),u=Re(m=>{if(m.is0()){if(t.allowInfinityPoint&&!e.is0(m.py))return;throw new Error("bad point: ZERO")}let{x:d,y:w}=m.toAffine();if(!e.isValid(d)||!e.isValid(w))throw new Error("bad point: x or y not FE");let B=e.sqr(w),p=i(d);if(!e.eql(B,p))throw new Error("bad point: equation left != right");if(!m.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});class h{constructor(d,w,B){if(this.px=d,this.py=w,this.pz=B,d==null||!e.isValid(d))throw new Error("x required");if(w==null||!e.isValid(w))throw new Error("y required");if(B==null||!e.isValid(B))throw new Error("z required");Object.freeze(this)}static fromAffine(d){let{x:w,y:B}=d||{};if(!d||!e.isValid(w)||!e.isValid(B))throw new Error("invalid affine point");if(d instanceof h)throw new Error("projective point not allowed");let p=S=>e.eql(S,e.ZERO);return p(w)&&p(B)?h.ZERO:new h(w,B,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(d){let w=e.invertBatch(d.map(B=>B.pz));return d.map((B,p)=>B.toAffine(w[p])).map(h.fromAffine)}static fromHex(d){let w=h.fromAffine(o(Y("pointHex",d)));return w.assertValidity(),w}static fromPrivateKey(d){return h.BASE.multiply(c(d))}static msm(d,w){return vn(h,n,d,w)}_setWindowSize(d){b.setWindowSize(this,d)}assertValidity(){u(this)}hasEvenY(){let{y:d}=this.toAffine();if(e.isOdd)return!e.isOdd(d);throw new Error("Field doesn't support isOdd")}equals(d){f(d);let{px:w,py:B,pz:p}=this,{px:S,py:R,pz:U}=d,I=e.eql(e.mul(w,U),e.mul(S,p)),T=e.eql(e.mul(B,U),e.mul(R,p));return I&&T}negate(){return new h(this.px,e.neg(this.py),this.pz)}double(){let{a:d,b:w}=t,B=e.mul(w,ja),{px:p,py:S,pz:R}=this,U=e.ZERO,I=e.ZERO,T=e.ZERO,C=e.mul(p,p),W=e.mul(S,S),q=e.mul(R,R),P=e.mul(p,S);return P=e.add(P,P),T=e.mul(p,R),T=e.add(T,T),U=e.mul(d,T),I=e.mul(B,q),I=e.add(U,I),U=e.sub(W,I),I=e.add(W,I),I=e.mul(U,I),U=e.mul(P,U),T=e.mul(B,T),q=e.mul(d,q),P=e.sub(C,q),P=e.mul(d,P),P=e.add(P,T),T=e.add(C,C),C=e.add(T,C),C=e.add(C,q),C=e.mul(C,P),I=e.add(I,C),q=e.mul(S,R),q=e.add(q,q),C=e.mul(q,P),U=e.sub(U,C),T=e.mul(q,W),T=e.add(T,T),T=e.add(T,T),new h(U,I,T)}add(d){f(d);let{px:w,py:B,pz:p}=this,{px:S,py:R,pz:U}=d,I=e.ZERO,T=e.ZERO,C=e.ZERO,W=t.a,q=e.mul(t.b,ja),P=e.mul(w,S),tt=e.mul(B,R),E=e.mul(p,U),N=e.add(w,B),x=e.add(S,R);N=e.mul(N,x),x=e.add(P,tt),N=e.sub(N,x),x=e.add(w,p);let g=e.add(S,U);return x=e.mul(x,g),g=e.add(P,E),x=e.sub(x,g),g=e.add(B,p),I=e.add(R,U),g=e.mul(g,I),I=e.add(tt,E),g=e.sub(g,I),C=e.mul(W,x),I=e.mul(q,E),C=e.add(I,C),I=e.sub(tt,C),C=e.add(tt,C),T=e.mul(I,C),tt=e.add(P,P),tt=e.add(tt,P),E=e.mul(W,E),x=e.mul(q,x),tt=e.add(tt,E),E=e.sub(P,E),E=e.mul(W,E),x=e.add(x,E),P=e.mul(tt,x),T=e.add(T,P),P=e.mul(g,x),I=e.mul(N,I),I=e.sub(I,P),P=e.mul(N,tt),C=e.mul(g,C),C=e.add(C,P),new h(I,T,C)}subtract(d){return this.add(d.negate())}is0(){return this.equals(h.ZERO)}wNAF(d){return b.wNAFCached(this,d,h.normalizeZ)}multiplyUnsafe(d){let{endo:w,n:B}=t;vt("scalar",d,Yt,B);let p=h.ZERO;if(d===Yt)return p;if(this.is0()||d===ot)return this;if(!w||b.hasPrecomputes(this))return b.wNAFCachedUnsafe(this,d,h.normalizeZ);let{k1neg:S,k1:R,k2neg:U,k2:I}=w.splitScalar(d),T=p,C=p,W=this;for(;R>Yt||I>Yt;)R&ot&&(T=T.add(W)),I&ot&&(C=C.add(W)),W=W.double(),R>>=ot,I>>=ot;return S&&(T=T.negate()),U&&(C=C.negate()),C=new h(e.mul(C.px,w.beta),C.py,C.pz),T.add(C)}multiply(d){let{endo:w,n:B}=t;vt("scalar",d,ot,B);let p,S;if(w){let{k1neg:R,k1:U,k2neg:I,k2:T}=w.splitScalar(d),{p:C,f:W}=this.wNAF(U),{p:q,f:P}=this.wNAF(T);C=b.constTimeNegate(R,C),q=b.constTimeNegate(I,q),q=new h(e.mul(q.px,w.beta),q.py,q.pz),p=C.add(q),S=W.add(P)}else{let{p:R,f:U}=this.wNAF(d);p=R,S=U}return h.normalizeZ([p,S])[0]}multiplyAndAddUnsafe(d,w,B){let p=h.BASE,S=(U,I)=>I===Yt||I===ot||!U.equals(p)?U.multiplyUnsafe(I):U.multiply(I),R=S(this,w).add(S(d,B));return R.is0()?void 0:R}toAffine(d){return l(this,d)}isTorsionFree(){let{h:d,isTorsionFree:w}=t;if(d===ot)return!0;if(w)return w(h,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h:d,clearCofactor:w}=t;return d===ot?this:w?w(h,this):this.multiplyUnsafe(t.h)}toRawBytes(d=!0){return Rt("isCompressed",d),this.assertValidity(),s(h,this,d)}toHex(d=!0){return Rt("isCompressed",d),zt(this.toRawBytes(d))}}h.BASE=new h(t.Gx,t.Gy,e.ONE),h.ZERO=new h(e.ZERO,e.ONE,e.ZERO);let y=t.nBitLength,b=xn(h,t.endo?Math.ceil(y/2):y);return{CURVE:t,ProjectivePoint:h,normPrivateKeyToScalar:c,weierstrassEquation:i,isWithinCurveOrder:a}}function kh(r){let t=Ur(r);return Pt(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function $a(r){let t=kh(r),{Fp:e,n}=t,s=e.BYTES+1,o=2*e.BYTES+1;function i(E){return G(E,n)}function a(E){return bn(E,n)}let{ProjectivePoint:c,normPrivateKeyToScalar:f,weierstrassEquation:l,isWithinCurveOrder:u}=Sh({...t,toBytes(E,N,x){let g=N.toAffine(),v=e.toBytes(g.x),k=Zt;return Rt("isCompressed",x),x?k(Uint8Array.from([N.hasEvenY()?2:3]),v):k(Uint8Array.from([4]),v,e.toBytes(g.y))},fromBytes(E){let N=E.length,x=E[0],g=E.subarray(1);if(N===s&&(x===2||x===3)){let v=Wt(g);if(!Nr(v,ot,e.ORDER))throw new Error("Point is not on curve");let k=l(v),_;try{_=e.sqrt(k)}catch(F){let K=F instanceof Error?": "+F.message:"";throw new Error("Point is not on curve"+K)}let D=(_&ot)===ot;return(x&1)===1!==D&&(_=e.neg(_)),{x:v,y:_}}else if(N===o&&x===4){let v=e.fromBytes(g.subarray(0,e.BYTES)),k=e.fromBytes(g.subarray(e.BYTES,2*e.BYTES));return{x:v,y:k}}else{let v=s,k=o;throw new Error("invalid Point, expected length of "+v+", or uncompressed "+k+", got "+N)}}}),h=E=>zt(pe(E,t.nByteLength));function y(E){let N=n>>ot;return E>N}function b(E){return y(E)?i(-E):E}let m=(E,N,x)=>Wt(E.slice(N,x));class d{constructor(N,x,g){this.r=N,this.s=x,this.recovery=g,this.assertValidity()}static fromCompact(N){let x=t.nByteLength;return N=Y("compactSignature",N,x*2),new d(m(N,0,x),m(N,x,2*x))}static fromDER(N){let{r:x,s:g}=Jt.toSig(Y("DER",N));return new d(x,g)}assertValidity(){vt("r",this.r,ot,n),vt("s",this.s,ot,n)}addRecoveryBit(N){return new d(this.r,this.s,N)}recoverPublicKey(N){let{r:x,s:g,recovery:v}=this,k=U(Y("msgHash",N));if(v==null||![0,1,2,3].includes(v))throw new Error("recovery id invalid");let _=v===2||v===3?x+t.n:x;if(_>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let D=(v&1)===0?"02":"03",V=c.fromHex(D+h(_)),F=a(_),K=i(-k*F),$=i(g*F),z=c.BASE.multiplyAndAddUnsafe(V,K,$);if(!z)throw new Error("point at infinify");return z.assertValidity(),z}hasHighS(){return y(this.s)}normalizeS(){return this.hasHighS()?new d(this.r,i(-this.s),this.recovery):this}toDERRawBytes(){return Ue(this.toDERHex())}toDERHex(){return Jt.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return Ue(this.toCompactHex())}toCompactHex(){return h(this.r)+h(this.s)}}let w={isValidPrivateKey(E){try{return f(E),!0}catch{return!1}},normPrivateKeyToScalar:f,randomPrivateKey:()=>{let E=bo(t.n);return fa(t.randomBytes(E),t.n)},precompute(E=8,N=c.BASE){return N._setWindowSize(E),N.multiply(BigInt(3)),N}};function B(E,N=!0){return c.fromPrivateKey(E).toRawBytes(N)}function p(E){let N=he(E),x=typeof E=="string",g=(N||x)&&E.length;return N?g===s||g===o:x?g===2*s||g===2*o:E instanceof c}function S(E,N,x=!0){if(p(E))throw new Error("first arg must be private key");if(!p(N))throw new Error("second arg must be public key");return c.fromHex(N).multiply(f(E)).toRawBytes(x)}let R=t.bits2int||function(E){if(E.length>8192)throw new Error("input is too large");let N=Wt(E),x=E.length*8-t.nBitLength;return x>0?N>>BigInt(x):N},U=t.bits2int_modN||function(E){return i(R(E))},I=Tr(t.nBitLength);function T(E){return vt("num < 2^"+t.nBitLength,E,Yt,I),pe(E,t.nByteLength)}function C(E,N,x=W){if(["recovered","canonical"].some(st=>st in x))throw new Error("sign() legacy options not supported");let{hash:g,randomBytes:v}=t,{lowS:k,prehash:_,extraEntropy:D}=x;k==null&&(k=!0),E=Y("msgHash",E),qa(x),_&&(E=Y("prehashed msgHash",g(E)));let V=U(E),F=f(N),K=[T(F),T(V)];if(D!=null&&D!==!1){let st=D===!0?v(e.BYTES):D;K.push(Y("extraEntropy",st))}let $=Zt(...K),z=V;function nt(st){let it=R(st);if(!u(it))return;let lt=a(it),bt=c.BASE.multiply(it).toAffine(),dt=i(bt.x);if(dt===Yt)return;let Ht=i(lt*i(z+dt*F));if(Ht===Yt)return;let qt=(bt.x===dt?0:2)|Number(bt.y&ot),mr=Ht;return k&&y(Ht)&&(mr=b(Ht),qt^=1),new d(dt,mr,qt)}return{seed:$,k2sig:nt}}let W={lowS:t.lowS,prehash:!1},q={lowS:t.lowS,prehash:!1};function P(E,N,x=W){let{seed:g,k2sig:v}=C(E,N,x),k=t;return po(k.hash.outputLen,k.nByteLength,k.hmac)(g,v)}c.BASE._setWindowSize(8);function tt(E,N,x,g=q){let v=E;N=Y("msgHash",N),x=Y("publicKey",x);let{lowS:k,prehash:_,format:D}=g;if(qa(g),"strict"in g)throw new Error("options.strict was renamed to lowS");if(D!==void 0&&D!=="compact"&&D!=="der")throw new Error("format must be compact or der");let V=typeof v=="string"||he(v),F=!V&&!D&&typeof v=="object"&&v!==null&&typeof v.r=="bigint"&&typeof v.s=="bigint";if(!V&&!F)throw new Error("invalid signature, expected Uint8Array, hex string or Signature instance");let K,$;try{if(F&&(K=new d(v.r,v.s)),V){try{D!=="compact"&&(K=d.fromDER(v))}catch(qt){if(!(qt instanceof Jt.Err))throw qt}!K&&D!=="der"&&(K=d.fromCompact(v))}$=c.fromHex(x)}catch{return!1}if(!K||k&&K.hasHighS())return!1;_&&(N=t.hash(N));let{r:z,s:nt}=K,st=U(N),it=a(nt),lt=i(st*it),bt=i(z*it),dt=c.BASE.multiplyAndAddUnsafe($,lt,bt)?.toAffine();return dt?i(dt.x)===z:!1}return{CURVE:t,getPublicKey:B,getSharedSecret:S,sign:P,verify:tt,ProjectivePoint:c,Signature:d,utils:w}}function Ih(r){return{hash:r,hmac:(t,...e)=>Pr(r,t,io(...e)),randomBytes:or}}function Ga(r,t){let e=n=>$a({...r,...Ih(n)});return{...e(t),create:e}}var Za=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),za=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),Ch=BigInt(1),Zo=BigInt(2),Wa=(r,t)=>(r+t/Zo)/t;function Nh(r){let t=Za,e=BigInt(3),n=BigInt(6),s=BigInt(11),o=BigInt(22),i=BigInt(23),a=BigInt(44),c=BigInt(88),f=r*r*r%t,l=f*f*r%t,u=J(l,e,t)*l%t,h=J(u,e,t)*l%t,y=J(h,Zo,t)*f%t,b=J(y,s,t)*y%t,m=J(b,o,t)*b%t,d=J(m,a,t)*m%t,w=J(d,c,t)*d%t,B=J(w,a,t)*m%t,p=J(B,e,t)*l%t,S=J(p,i,t)*b%t,R=J(S,n,t)*f%t,U=J(R,Zo,t);if(!Jo.eql(Jo.sqr(U),r))throw new Error("Cannot find square root");return U}var Jo=ge(Za,void 0,void 0,{sqrt:Nh}),Ot=Ga({a:BigInt(0),b:BigInt(7),Fp:Jo,n:za,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=za,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-Ch*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),s=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),o=e,i=BigInt("0x100000000000000000000000000000000"),a=Wa(o*r,t),c=Wa(-n*r,t),f=G(r-a*e-c*s,t),l=G(-a*n-c*o,t),u=f>i,h=l>i;if(u&&(f=t-f),h&&(l=t-l),f>i||l>i)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:u,k1:f,k2neg:h,k2:l}}}},ve),Ty=BigInt(0);var Uy=Ot.ProjectivePoint;function Yo(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}var Ja=32;function Ya(r,t){let e=Ye.digest(t instanceof Uint8Array?t:t.subarray());if(Yo(e))return e.then(({digest:n})=>Ot.sign(n,r).toDERRawBytes()).catch(n=>{throw new br(String(n))});try{return Ot.sign(e.digest,r).toDERRawBytes()}catch(n){throw new br(String(n))}}function Xa(r,t,e){let n=Ye.digest(e instanceof Uint8Array?e:e.subarray());if(Yo(n))return n.then(({digest:s})=>Ot.verify(t,s,r)).catch(s=>{throw new wr(String(s))});try{return Ot.verify(t,n.digest,r)}catch(s){throw new wr(String(s))}}var Ln=class{type="secp256k1";raw;_key;constructor(t){this._key=ec(t),this.raw=Qa(this._key)}toMultihash(){return ke.digest(Qe(this))}toCID(){return It.createV1(114,this.toMultihash())}toString(){return Q.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:xt(this.raw,t.raw)}verify(t,e){return Xa(this._key,e,t)}},Rn=class{type="secp256k1";raw;publicKey;constructor(t,e){this.raw=tc(t),this.publicKey=new Ln(e??rc(t))}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:xt(this.raw,t.raw)}sign(t){return Ya(this.raw,t)}};function Xo(r){return new Rn(r)}function Qa(r){return Ot.ProjectivePoint.fromHex(r).toRawBytes(!0)}function tc(r){try{return Ot.getPublicKey(r,!0),r}catch(t){throw new xr(String(t))}}function ec(r){try{return Ot.ProjectivePoint.fromHex(r),r}catch(t){throw new qe(String(t))}}function rc(r){try{return Ot.getPublicKey(r,!0)}catch(t){throw new xr(String(t))}}function Qe(r){return be.encode({Type:rt[r.type],Data:r.raw})}function nc(r){let t=Or.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case rt.RSA:return $o(e);case rt.Ed25519:return So(e);case rt.secp256k1:return Xo(e);case rt.ECDSA:return Ji(e);default:throw new je}}function sc(r){if(r.byteLength===Dt)return So(r);if(r.byteLength===Ja)return Xo(r);let t=Tt(r),e=t[2]?.[0];if(e===$i||e===Gi||e===zi)return oo(t);if(t.length>8)return Tn(t);throw new L("Could not extract private key from raw bytes")}function Ve(r){return Or.encode({Type:rt[r.type],Data:r.raw})}function oc(r,t,e,n){un(r);let s=na({dkLen:32,asyncTick:10},n),{c:o,dkLen:i,asyncTick:a}=s;if(tr(o),tr(i),tr(a),o<1)throw new Error("PBKDF2: iterations (c) should be >= 1");let c=ae(t),f=ae(e),l=new Uint8Array(i),u=Pr.create(r,c),h=u._cloneInto().update(f);return{c:o,dkLen:i,asyncTick:a,DK:l,PRF:u,PRFSalt:h}}function ic(r,t,e,n,s){return r.destroy(),t.destroy(),n&&n.destroy(),s.fill(0),e}function ac(r,t,e,n){let{c:s,dkLen:o,DK:i,PRF:a,PRFSalt:c}=oc(r,t,e,n),f,l=new Uint8Array(4),u=Ne(l),h=new Uint8Array(a.outputLen);for(let y=1,b=0;b<o;y++,b+=a.outputLen){let m=i.subarray(b,b+a.outputLen);u.setInt32(0,y,!1),(f=c._cloneInto(f)).update(l).digestInto(h),m.set(h.subarray(0,m.length));for(let d=1;d<s;d++){a._cloneInto(f).update(h).digestInto(h);for(let w=0;w<m.length;w++)m[w]^=h[w]}}return ic(a,c,i,f,h)}async function _n(r,t,e,n){let{c:s,dkLen:o,asyncTick:i,DK:a,PRF:c,PRFSalt:f}=oc(r,t,e,n),l,u=new Uint8Array(4),h=Ne(u),y=new Uint8Array(c.outputLen);for(let b=1,m=0;m<o;b++,m+=c.outputLen){let d=a.subarray(m,m+c.outputLen);h.setInt32(0,b,!1),(l=f._cloneInto(l)).update(u).digestInto(y),d.set(y.subarray(0,d.length)),await ea(s-1,i,()=>{c._cloneInto(l).update(y).digestInto(y);for(let w=0;w<d.length;w++)d[w]^=y[w]})}return ic(c,f,a,l,y)}var Mr=new Uint32Array([1732584193,4023233417,2562383102,271733878,3285377520]),Be=new Uint32Array(80),Qo=class extends ce{constructor(){super(64,20,8,!1),this.A=Mr[0]|0,this.B=Mr[1]|0,this.C=Mr[2]|0,this.D=Mr[3]|0,this.E=Mr[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)Be[c]=t.getUint32(e,!1);for(let c=16;c<80;c++)Be[c]=fn(Be[c-3]^Be[c-8]^Be[c-14]^Be[c-16],1);let{A:n,B:s,C:o,D:i,E:a}=this;for(let c=0;c<80;c++){let f,l;c<20?(f=hn(s,o,i),l=1518500249):c<40?(f=s^o^i,l=1859775393):c<60?(f=dn(s,o,i),l=2400959708):(f=s^o^i,l=3395469782);let u=fn(n,5)+f+a+l+Be[c]|0;a=i,i=o,o=fn(s,30),s=n,n=u}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(){Be.fill(0)}destroy(){this.set(0,0,0,0,0),this.buffer.fill(0)}},cc=sr(()=>new Qo);var lc={sha1:cc,"sha2-256":ve,"sha2-512":fe};function Fr(r,t,e,n,s){if(s!=="sha1"&&s!=="sha2-256"&&s!=="sha2-512"){let a=Object.keys(lc).join(" / ");throw new L(`Hash '${s}' is unknown or not supported. Must be ${a}`)}let o=lc[s],i=ac(o,r,t,{c:e,dkLen:n});return Ie.encode(i).substring(1)}var Xt="/",uc=new TextEncoder().encode(Xt),Dn=uc[0],qr=class r{_buf;constructor(t,e){if(typeof t=="string")this._buf=H(t);else if(t instanceof Uint8Array)this._buf=t;else throw new Error("Invalid key, should be String of Uint8Array");if(e==null&&(e=!0),e&&this.clean(),this._buf.byteLength===0||this._buf[0]!==Dn)throw new Error("Invalid key")}toString(t="utf8"){return j(this._buf,t)}uint8Array(){return this._buf}get[Symbol.toStringTag](){return`Key(${this.toString()})`}static withNamespaces(t){return new r(t.join(Xt))}static random(){return new r(Math.random().toString().substring(2))}static asKey(t){return t instanceof Uint8Array||typeof t=="string"?new r(t):typeof t.uint8Array=="function"?new r(t.uint8Array()):null}clean(){if((this._buf==null||this._buf.byteLength===0)&&(this._buf=uc),this._buf[0]!==Dn){let t=new Uint8Array(this._buf.byteLength+1);t.fill(Dn,0,1),t.set(this._buf,1),this._buf=t}for(;this._buf.byteLength>1&&this._buf[this._buf.byteLength-1]===Dn;)this._buf=this._buf.subarray(0,-1)}less(t){let e=this.list(),n=t.list();for(let s=0;s<e.length;s++){if(n.length<s+1)return!1;let o=e[s],i=n[s];if(o<i)return!0;if(o>i)return!1}return e.length<n.length}reverse(){return r.withNamespaces(this.list().slice().reverse())}namespaces(){return this.list()}baseNamespace(){let t=this.namespaces();return t[t.length-1]}list(){return this.toString().split(Xt).slice(1)}type(){return Th(this.baseNamespace())}name(){return Uh(this.baseNamespace())}instance(t){return new r(this.toString()+":"+t)}path(){let t=this.parent().toString();return t.endsWith(Xt)||(t+=Xt),t+=this.type(),new r(t)}parent(){let t=this.list();return t.length===1?new r(Xt):new r(t.slice(0,-1).join(Xt))}child(t){return this.toString()===Xt?t:t.toString()===Xt?this:new r(this.toString()+t.toString(),!1)}isAncestorOf(t){return t.toString()===this.toString()?!1:t.toString().startsWith(this.toString())}isDecendantOf(t){return t.toString()===this.toString()?!1:this.toString().startsWith(t.toString())}isTopLevel(){return this.list().length===1}concat(...t){return r.withNamespaces([...this.namespaces(),...Lh(t.map(e=>e.namespaces()))])}};function Th(r){let t=r.split(":");return t.length<2?"":t.slice(0,-1).join(":")}function Uh(r){let t=r.split(":");return t[t.length-1]}function Lh(r){return[].concat(...r)}var wc=Ls(bc(),1),xc=wc.default;var wl=Ls(Nc(),1);var hr={};ut(hr,{create:()=>Jh,derivedEmptyPasswordKey:()=>Vn});var Vn={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function Jh(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=wt.get();e*=8;async function c(u,h){let y=a.getRandomValues(new Uint8Array(o)),b=a.getRandomValues(new Uint8Array(n)),m={name:t,iv:b};typeof h=="string"&&(h=H(h));let d;if(h.length===0){d=await a.subtle.importKey("jwk",Vn,{name:"AES-GCM"},!0,["encrypt"]);try{let B={name:"PBKDF2",salt:y,iterations:i,hash:{name:s}},p=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);d=await a.subtle.deriveKey(B,p,{name:t,length:e},!0,["encrypt"])}catch{d=await a.subtle.importKey("jwk",Vn,{name:"AES-GCM"},!0,["encrypt"])}}else{let B={name:"PBKDF2",salt:y,iterations:i,hash:{name:s}},p=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);d=await a.subtle.deriveKey(B,p,{name:t,length:e},!0,["encrypt"])}let w=await a.subtle.encrypt(m,d,u);return Je([y,m.iv,new Uint8Array(w)])}async function f(u,h){let y=u.subarray(0,o),b=u.subarray(o,o+n),m=u.subarray(o+n),d={name:t,iv:b};typeof h=="string"&&(h=H(h));let w;if(h.length===0)try{let p={name:"PBKDF2",salt:y,iterations:i,hash:{name:s}},S=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);w=await a.subtle.deriveKey(p,S,{name:t,length:e},!0,["decrypt"])}catch{w=await a.subtle.importKey("jwk",Vn,{name:"AES-GCM"},!0,["decrypt"])}else{let p={name:"PBKDF2",salt:y,iterations:i,hash:{name:s}},S=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);w=await a.subtle.deriveKey(p,S,{name:t,length:e},!0,["decrypt"])}let B=await a.subtle.decrypt(d,w,m);return new Uint8Array(B)}return{encrypt:c,decrypt:f}}var M=Ls(Tc());function He(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 Ee(r,t,e=-1){let n=e,s=r,o=0,i=Math.pow(2,t);for(let a=1;a<8;a++){if(r<i){let c;if(n<0)c=new ArrayBuffer(a),o=a;else{if(n<a)return new ArrayBuffer(0);c=new ArrayBuffer(n),o=n}let f=new Uint8Array(c);for(let l=a-1;l>=0;l--){let u=Math.pow(2,l*t);f[o-l-1]=Math.floor(s/u),s-=f[o-l-1]*u}return c}i*=Math.pow(2,t)}return new ArrayBuffer(0)}function Mn(...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 ri(){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=He(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,He(o,8)-n}function Uc(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=Ee(i,8,n),c=new Uint8Array(a);return c[0]|=128,a}let s=Ee(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 Lc(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 Et(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 Jm=Math.log(2);function Fn(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function ni(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 se(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 Gr=class{constructor(){this.items=[]}write(t){this.items.push(t)}final(){return ni(this.items)}},jr=[new Uint8Array([1])],Rc="0123456789";var pr="",Vt=new ArrayBuffer(0),si=new Uint8Array(0),zr="EndOfContent",Dc="OCTET STRING",Kc="BIT STRING";function oe(r){var t;return t=class extends r{get valueHex(){return this.valueHexView.slice().buffer}set valueHex(n){this.valueHexView=new Uint8Array(n)}constructor(...n){var s;super(...n);let o=n[0]||{};this.isHexOnly=(s=o.isHexOnly)!==null&&s!==void 0?s:!1,this.valueHexView=o.valueHex?M.BufferSourceConverter.toUint8Array(o.valueHex):si}fromBER(n,s,o){let i=n instanceof ArrayBuffer?new Uint8Array(n):n;if(!se(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",Vt)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:M.Convert.ToHex(this.valueHexView)}}},t.NAME="hexBlock",t}var te=class{static blockName(){return this.NAME}get valueBeforeDecode(){return this.valueBeforeDecodeView.slice().buffer}set valueBeforeDecode(t){this.valueBeforeDecodeView=new Uint8Array(t)}constructor({blockLength:t=0,error:e=pr,warnings:n=[],valueBeforeDecode:s=si}={}){this.blockLength=t,this.error=e,this.warnings=n,this.valueBeforeDecodeView=M.BufferSourceConverter.toUint8Array(s)}toJSON(){return{blockName:this.constructor.NAME,blockLength:this.blockLength,error:this.error,warnings:this.warnings,valueBeforeDecode:M.Convert.ToHex(this.valueBeforeDecodeView)}}};te.NAME="baseBlock";var ht=class extends te{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'")}};ht.NAME="valueBlock";var qn=class extends oe(te){constructor({idBlock:t={}}={}){var e,n,s,o;super(),t?(this.isHexOnly=(e=t.isHexOnly)!==null&&e!==void 0?e:!1,this.valueHexView=t.valueHex?M.BufferSourceConverter.toUint8Array(t.valueHex):si,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",Vt}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=Ee(this.tagNumber,7),o=new Uint8Array(s),i=s.byteLength,a=new Uint8Array(i+1);if(a[0]=e|31,!t){for(let c=0;c<i-1;c++)a[c+1]=o[c]|128;a[i]=o[i-1]}return a.buffer}let n=new Uint8Array(this.valueHexView.byteLength+1);if(n[0]=e|31,!t){let s=this.valueHexView;for(let o=0;o<s.length-1;o++)n[o+1]=s[o]|128;n[this.valueHexView.byteLength]=s[s.length-1]}return n.buffer}fromBER(t,e,n){let s=M.BufferSourceConverter.toUint8Array(t);if(!se(this,s,e,n))return-1;let o=s.subarray(e,e+n);if(o.length===0)return this.error="Zero buffer length",-1;switch(o[0]&192){case 0:this.tagClass=1;break;case 64:this.tagClass=2;break;case 128:this.tagClass=3;break;case 192:this.tagClass=4;break;default:return this.error="Unknown tag class",-1}this.isConstructed=(o[0]&32)===32,this.isHexOnly=!1;let a=o[0]&31;if(a!==31)this.tagNumber=a,this.blockLength=1;else{let c=1,f=this.valueHexView=new Uint8Array(255),l=255;for(;o[c]&128;){if(f[c-1]=o[c]&127,c++,c>=o.length)return this.error="End of input reached before message was fully decoded",-1;if(c===l){l+=255;let h=new Uint8Array(l);for(let y=0;y<f.length;y++)h[y]=f[y];f=this.valueHexView=new Uint8Array(l)}}this.blockLength=c+1,f[c-1]=o[c]&127;let u=new Uint8Array(c);for(let h=0;h<c;h++)u[h]=f[h];f=this.valueHexView=new Uint8Array(c),f.set(u),this.blockLength<=9?this.tagNumber=He(f,7):(this.isHexOnly=!0,this.warnings.push("Tag too long, represented as hex-coded"))}if(this.tagClass===1&&this.isConstructed)switch(this.tagNumber){case 1:case 2:case 5:case 6:case 9:case 13:case 14:case 23:case 24:case 31:case 32:case 33:case 34:return this.error="Constructed encoding used for primitive type",-1}return e+this.blockLength}toJSON(){return{...super.toJSON(),tagClass:this.tagClass,tagNumber:this.tagNumber,isConstructed:this.isConstructed}}};qn.NAME="identificationBlock";var jn=class extends te{constructor({lenBlock:t={}}={}){var e,n,s;super(),this.isIndefiniteForm=(e=t.isIndefiniteForm)!==null&&e!==void 0?e:!1,this.longFormUsed=(n=t.longFormUsed)!==null&&n!==void 0?n:!1,this.length=(s=t.length)!==null&&s!==void 0?s:0}fromBER(t,e,n){let s=M.BufferSourceConverter.toUint8Array(t);if(!se(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=He(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=Ee(this.length,8);if(s.byteLength>127)return this.error="Too big length",Vt;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}}};jn.NAME="lengthBlock";var A={},at=class extends te{constructor({name:t=pr,optional:e=!1,primitiveSchema:n,...s}={},o){super(s),this.name=t,this.optional=e,n&&(this.primitiveSchema=n),this.idBlock=new qn(s),this.lenBlock=new jn(s),this.valueBlock=o?new o(s):new ht(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 Gr;e||Oc(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?Vt:n.final()}toJSON(){let t={...super.toJSON(),idBlock:this.idBlock.toJSON(),lenBlock:this.lenBlock.toJSON(),valueBlock:this.valueBlock.toJSON(),name:this.name,optional:this.optional};return this.primitiveSchema&&(t.primitiveSchema=this.primitiveSchema.toJSON()),t}toString(t="ascii"){return t==="ascii"?this.onAsciiEncoding():M.Convert.ToHex(this.toBER())}onAsciiEncoding(){let t=this.constructor.NAME,e=M.Convert.ToHex(this.valueBlock.valueBeforeDecodeView);return`${t} : ${e}`}isEqual(t){if(this===t)return!0;if(!(t instanceof this.constructor))return!1;let e=this.toBER(),n=t.toBER();return Lc(e,n)}};at.NAME="BaseBlock";function Oc(r){var t;if(r instanceof A.Constructed)for(let e of r.valueBlock.value)Oc(e)&&(r.lenBlock.isIndefiniteForm=!0);return!!(!((t=r.lenBlock)===null||t===void 0)&&t.isIndefiniteForm)}var $n=class extends at{getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}constructor({value:t=pr,...e}={},n){super(e,n),t&&this.fromString(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}'`}};$n.NAME="BaseStringBlock";var Gn=class extends oe(ht){constructor({isHexOnly:t=!0,...e}={}){super(e),this.isHexOnly=t}};Gn.NAME="PrimitiveValueBlock";var Vc,zn=class extends at{constructor(t={}){super(t,Gn),this.idBlock.isConstructed=!1}};Vc=zn;A.Primitive=Vc;zn.NAME="PRIMITIVE";function od(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 Is(r,t=0,e=r.length){let n=t,s=new at({},ht),o=new te;if(!se(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=at;switch(s.idBlock.tagClass){case 1:if(s.idBlock.tagNumber>=37&&s.idBlock.isHexOnly===!1)return s.error="UNIVERSAL 37 and upper tags are reserved by ASN.1 standard",{offset:-1,result:s};switch(s.idBlock.tagNumber){case 0:if(s.idBlock.isConstructed&&s.lenBlock.length>0)return s.error="Type [UNIVERSAL 0] is reserved",{offset:-1,result:s};c=A.EndOfContent;break;case 1:c=A.Boolean;break;case 2:c=A.Integer;break;case 3:c=A.BitString;break;case 4:c=A.OctetString;break;case 5:c=A.Null;break;case 6:c=A.ObjectIdentifier;break;case 10:c=A.Enumerated;break;case 12:c=A.Utf8String;break;case 13:c=A.RelativeObjectIdentifier;break;case 14:c=A.TIME;break;case 15:return s.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:s};case 16:c=A.Sequence;break;case 17:c=A.Set;break;case 18:c=A.NumericString;break;case 19:c=A.PrintableString;break;case 20:c=A.TeletexString;break;case 21:c=A.VideotexString;break;case 22:c=A.IA5String;break;case 23:c=A.UTCTime;break;case 24:c=A.GeneralizedTime;break;case 25:c=A.GraphicString;break;case 26:c=A.VisibleString;break;case 27:c=A.GeneralString;break;case 28:c=A.UniversalString;break;case 29:c=A.CharacterString;break;case 30:c=A.BmpString;break;case 31:c=A.DATE;break;case 32:c=A.TimeOfDay;break;case 33:c=A.DateTime;break;case 34:c=A.Duration;break;default:{let f=s.idBlock.isConstructed?new A.Constructed:new A.Primitive;f.idBlock=s.idBlock,f.lenBlock=s.lenBlock,f.warnings=s.warnings,s=f}}break;case 2:case 3:case 4:default:c=s.idBlock.isConstructed?A.Constructed:A.Primitive}return s=od(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 Cs(r){if(!r.byteLength){let t=new at({},ht);return t.error="Input buffer has zero length",{offset:-1,result:t}}return Is(M.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function id(r,t){return r?1:t}var Mt=class extends ht{constructor({value:t=[],isIndefiniteForm:e=!1,...n}={}){super(n),this.value=t,this.isIndefiniteForm=e}fromBER(t,e,n){let s=M.BufferSourceConverter.toUint8Array(t);if(!se(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(;id(this.isIndefiniteForm,n)>0;){let i=Is(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===zr)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===zr?this.value.pop():this.warnings.push("No EndOfContent block encoded")),o}toBER(t,e){let n=e||new Gr;for(let s=0;s<this.value.length;s++)this.value[s].toBER(t,n);return e?Vt:n.final()}toJSON(){let t={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let e of this.value)t.value.push(e.toJSON());return t}};Mt.NAME="ConstructedValueBlock";var Hc,Ae=class extends at{constructor(t={}){super(t,Mt),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 Libp2PKeychain=(()=>{var Pl=Object.create;var an=Object.defineProperty;var Ml=Object.getOwnPropertyDescriptor;var Fl=Object.getOwnPropertyNames;var ql=Object.getPrototypeOf,jl=Object.prototype.hasOwnProperty;var Ee=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),ht=(r,t)=>{for(var e in t)an(r,e,{get:t[e],enumerable:!0})},mi=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of Fl(t))!jl.call(r,s)&&s!==e&&an(r,s,{get:()=>t[s],enumerable:!(n=Ml(t,s))||n.enumerable});return r};var Ks=(r,t,e)=>(e=r!=null?Pl(ql(r)):{},mi(t||!r||!r.__esModule?an(e,"default",{value:r,enumerable:!0}):e,r)),$l=r=>mi(an({},"__esModule",{value:!0}),r);var Cc=Ee((Cm,Ic)=>{"use strict";Ic.exports=r=>{if(Object.prototype.toString.call(r)!=="[object Object]")return!1;let t=Object.getPrototypeOf(r);return t===null||t===Object.prototype}});var Rc=Ee((Lc,_c)=>{"use strict";var Fn=Cc(),{hasOwnProperty:Uc}=Object.prototype,{propertyIsEnumerable:ph}=Object,fr=(r,t,e)=>Object.defineProperty(r,t,{value:e,writable:!0,enumerable:!0,configurable:!0}),gh=Lc,Nc={concatArrays:!1,ignoreUndefined:!1},qn=r=>{let t=[];for(let e in r)Uc.call(r,e)&&t.push(e);if(Object.getOwnPropertySymbols){let e=Object.getOwnPropertySymbols(r);for(let n of e)ph.call(r,n)&&t.push(n)}return t};function hr(r){return Array.isArray(r)?yh(r):Fn(r)?mh(r):r}function yh(r){let t=r.slice(0,0);return qn(r).forEach(e=>{fr(t,e,hr(r[e]))}),t}function mh(r){let t=Object.getPrototypeOf(r)===null?Object.create(null):{};return qn(r).forEach(e=>{fr(t,e,hr(r[e]))}),t}var Tc=(r,t,e,n)=>(e.forEach(s=>{typeof t[s]>"u"&&n.ignoreUndefined||(s in r&&r[s]!==Object.getPrototypeOf(r)?fr(r,s,ii(r[s],t[s],n)):fr(r,s,hr(t[s])))}),r),bh=(r,t,e)=>{let n=r.slice(0,0),s=0;return[r,t].forEach(o=>{let i=[];for(let a=0;a<o.length;a++)Uc.call(o,a)&&(i.push(String(a)),o===r?fr(n,s++,o[a]):fr(n,s++,hr(o[a])));n=Tc(n,o,qn(o).filter(a=>!i.includes(a)),e)}),n};function ii(r,t,e){return e.concatArrays&&Array.isArray(r)&&Array.isArray(t)?bh(r,t,e):!Fn(t)||!Fn(r)?hr(t):Tc(r,t,qn(t),e)}_c.exports=function(...r){let t=ii(hr(Nc),this!==gh&&this||{},Nc),e={_:{}};for(let n of r)if(n!==void 0){if(!Fn(n))throw new TypeError("`"+n+"` is not an Option Object");e=ii(e,{_:n},t)}return e._}});var Oc=Ee((Um,Kc)=>{"use strict";function wh(r){return r>=55296&&r<=56319}function xh(r){return r>=56320&&r<=57343}Kc.exports=function(t,e,n){if(typeof e!="string")throw new Error("Input must be string");for(var s=e.length,o=0,i,a,c=0;c<s;c+=1){if(i=e.charCodeAt(c),a=e[c],wh(i)&&xh(e.charCodeAt(c+1))&&(c+=1,a+=e[c]),o+=t(a),o===n)return e.slice(0,c+1);if(o>n)return e.slice(0,c-a.length+1)}return e}});var Pc=Ee((Tm,Vc)=>{"use strict";function vh(r){return r>=55296&&r<=56319}function Eh(r){return r>=56320&&r<=57343}Vc.exports=function(t){if(typeof t!="string")throw new Error("Input must be string");for(var e=t.length,n=0,s=null,o=null,i=0;i<e;i++)s=t.charCodeAt(i),Eh(s)?o!=null&&vh(o)?n+=1:n+=3:s<=127?n+=1:s>=128&&s<=2047?n+=2:s>=2048&&s<=65535&&(n+=3),o=s;return n}});var Fc=Ee((Lm,Mc)=>{"use strict";var Bh=Oc(),Ah=Pc();Mc.exports=Bh.bind(null,Ah)});var $c=Ee((_m,jc)=>{"use strict";var Sh=Fc(),kh=/[\/\?<>\\:\*\|"]/g,Ih=/[\x00-\x1f\x80-\x9f]/g,Ch=/^\.+$/,Nh=/^(con|prn|aux|nul|com[0-9]|lpt[0-9])(\..*)?$/i,Uh=/[\. ]+$/;function qc(r,t){if(typeof r!="string")throw new Error("Input must be string");var e=r.replace(kh,t).replace(Ih,t).replace(Ch,t).replace(Nh,t).replace(Uh,t);return Sh(e,255)}jc.exports=function(r,t){var e=t&&t.replacement||"",n=qc(r,e);return e===""?n:qc(n,"")}});var Gc=Ee(pr=>{"use strict";var Lh="[object ArrayBuffer]",ee=class r{static isArrayBuffer(t){return Object.prototype.toString.call(t)===Lh}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}},ai="string",_h=/^[0-9a-f\s]+$/i,Rh=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,Dh=/^[a-zA-Z0-9-_]+$/,$n=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=ee.toUint8Array(t),n="";for(let o=0;o<e.length;o++)n+=String.fromCharCode(e[o]);return decodeURIComponent(escape(n))}},Ut=class{static toString(t,e=!1){let n=ee.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}},Gn=class r{static isHex(t){return typeof t===ai&&_h.test(t)}static isBase64(t){return typeof t===ai&&Rh.test(t)}static isBase64Url(t){return typeof t===ai&&Dh.test(t)}static ToString(t,e="utf8"){let n=ee.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 Ut.toString(n,!0);case"utf16":case"utf16be":return Ut.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 Ut.fromString(t,!0);case"utf16":case"utf16be":return Ut.fromString(t);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToBase64(t){let e=ee.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 $n.fromString(t);case"utf16":case"utf16be":return Ut.fromString(t);case"utf16le":case"usc2":return Ut.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 $n.toString(t);case"utf16":case"utf16be":return Ut.toString(t);case"utf16le":case"usc2":return Ut.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=ee.toUint8Array(t),n="";for(let s=0;s<e.length;s++)n+=String.fromCharCode(e[s]);return n}static ToHex(t){let e=ee.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 Ut.toString(t,e)}static FromUtf16String(t,e=!1){return Ut.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,"")||""}};Gn.DEFAULT_UTF8_ENCODING="utf8";function Hh(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 Kh(...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 Oh(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}pr.BufferSourceConverter=ee;pr.Convert=Gn;pr.assign=Hh;pr.combine=Kh;pr.isEqual=Oh});var ed={};ht(ed,{keychain:()=>td});var wr=class extends Error{constructor(t="An error occurred while signing a message"){super(t),this.name="SigningError"}},xr=class extends Error{constructor(t="An error occurred while verifying a message"){super(t),this.name="VerificationError"}},cn=class extends Error{constructor(t="Missing Web Crypto API"){super(t),this.name="WebCryptoMissingError"}};var bi={get(r=globalThis){let t=r.crypto;if(t?.subtle==null)throw new cn("Missing Web Crypto API. The most likely cause of this error is that this page is being accessed from an insecure context (i.e. not HTTPS). For more information and possible resolutions see https://github.com/libp2p/js-libp2p/blob/main/packages/crypto/README.md#web-crypto-api");return t}};var xt=bi;var _=class extends Error{static name="InvalidParametersError";constructor(t="Invalid parameters"){super(t),this.name="InvalidParametersError"}},qe=class extends Error{static name="InvalidPublicKeyError";constructor(t="Invalid public key"){super(t),this.name="InvalidPublicKeyError"}},vr=class extends Error{static name="InvalidPrivateKeyError";constructor(t="Invalid private key"){super(t),this.name="InvalidPrivateKeyError"}};var ln=class extends Error{static name="NotFoundError";constructor(t="Not found"){super(t),this.name="NotFoundError"}};var je=class extends Error{static name="UnsupportedKeyTypeError";constructor(t="Unsupported key type"){super(t),this.name="UnsupportedKeyTypeError"}};var wi=Symbol.for("@libp2p/service-capabilities"),ld=Symbol.for("@libp2p/service-dependencies");var Fs={};ht(Fs,{base58btc:()=>Q,base58flickr:()=>Yl});var Ld=new Uint8Array(0);function xi(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 $t(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 vi(r){return new TextEncoder().encode(r)}function Ei(r){return new TextDecoder().decode(r)}function Gl(r,t){if(r.length>=255)throw new TypeError("Alphabet too long");for(var e=new Uint8Array(256),n=0;n<e.length;n++)e[n]=255;for(var s=0;s<r.length;s++){var o=r.charAt(s),i=o.charCodeAt(0);if(e[i]!==255)throw new TypeError(o+" is ambiguous");e[i]=s}var a=r.length,c=r.charAt(0),f=Math.log(a)/Math.log(256),l=Math.log(256)/Math.log(a);function u(w){if(w instanceof Uint8Array||(ArrayBuffer.isView(w)?w=new Uint8Array(w.buffer,w.byteOffset,w.byteLength):Array.isArray(w)&&(w=Uint8Array.from(w))),!(w instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(w.length===0)return"";for(var y=0,d=0,b=0,E=w.length;b!==E&&w[b]===0;)b++,y++;for(var p=(E-b)*l+1>>>0,S=new Uint8Array(p);b!==E;){for(var R=w[b],L=0,C=p-1;(R!==0||L<d)&&C!==-1;C--,L++)R+=256*S[C]>>>0,S[C]=R%a>>>0,R=R/a>>>0;if(R!==0)throw new Error("Non-zero carry");d=L,b++}for(var N=p-d;N!==p&&S[N]===0;)N++;for(var U=c.repeat(y);N<p;++N)U+=r.charAt(S[N]);return U}function h(w){if(typeof w!="string")throw new TypeError("Expected String");if(w.length===0)return new Uint8Array;var y=0;if(w[y]!==" "){for(var d=0,b=0;w[y]===c;)d++,y++;for(var E=(w.length-y)*f+1>>>0,p=new Uint8Array(E);w[y];){var S=e[w.charCodeAt(y)];if(S===255)return;for(var R=0,L=E-1;(S!==0||R<b)&&L!==-1;L--,R++)S+=a*p[L]>>>0,p[L]=S%256>>>0,S=S/256>>>0;if(S!==0)throw new Error("Non-zero carry");b=R,y++}if(w[y]!==" "){for(var C=E-b;C!==E&&p[C]===0;)C++;for(var N=new Uint8Array(d+(E-C)),U=d;C!==E;)N[U++]=p[C++];return N}}}function m(w){var y=h(w);if(y)return y;throw new Error(`Non-${t} character`)}return{encode:u,decodeUnsafe:h,decode:m}}var zl=Gl,Wl=zl,Ai=Wl;var Os=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")}},Vs=class{name;prefix;baseDecode;prefixCodePoint;constructor(t,e,n){this.name=t,this.prefix=e;let s=e.codePointAt(0);if(s===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=s,this.baseDecode=n}decode(t){if(typeof t=="string"){if(t.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(t)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(t.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(t){return Si(this,t)}},Ps=class{decoders;constructor(t){this.decoders=t}or(t){return Si(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 Si(r,t){return new Ps({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var Ms=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 Os(t,e,n),this.decoder=new Vs(t,e,s)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function $e({name:r,prefix:t,encode:e,decode:n}){return new Ms(r,t,e,n)}function ce({name:r,prefix:t,alphabet:e}){let{encode:n,decode:s}=Ai(e,r);return $e({prefix:t,name:r,encode:n,decode:o=>$t(s(o))})}function Zl(r,t,e,n){let s={};for(let l=0;l<t.length;++l)s[t[l]]=l;let o=r.length;for(;r[o-1]==="=";)--o;let i=new Uint8Array(o*e/8|0),a=0,c=0,f=0;for(let l=0;l<o;++l){let u=s[r[l]];if(u===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<e|u,a+=e,a>=8&&(a-=8,i[f++]=255&c>>a)}if(a>=e||(255&c<<8-a)!==0)throw new SyntaxError("Unexpected end of data");return i}function Jl(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)!==0;)o+="=";return o}function J({name:r,prefix:t,bitsPerChar:e,alphabet:n}){return $e({prefix:t,name:r,encode(s){return Jl(s,n,e)},decode(s){return Zl(s,n,e,r)}})}var Q=ce({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),Yl=ce({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var qs={};ht(qs,{base32:()=>Ge,base32hex:()=>eu,base32hexpad:()=>nu,base32hexpadupper:()=>su,base32hexupper:()=>ru,base32pad:()=>Ql,base32padupper:()=>tu,base32upper:()=>Xl,base32z:()=>ou});var Ge=J({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),Xl=J({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Ql=J({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),tu=J({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),eu=J({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),ru=J({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),nu=J({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),su=J({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),ou=J({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var js={};ht(js,{base36:()=>Er,base36upper:()=>iu});var Er=ce({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),iu=ce({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var au=Ci,ki=128,cu=127,lu=~cu,uu=Math.pow(2,31);function Ci(r,t,e){t=t||[],e=e||0;for(var n=e;r>=uu;)t[e++]=r&255|ki,r/=128;for(;r&lu;)t[e++]=r&255|ki,r>>>=7;return t[e]=r|0,Ci.bytes=e-n+1,t}var fu=$s,hu=128,Ii=127;function $s(r,n){var e=0,n=n||0,s=0,o=n,i,a=r.length;do{if(o>=a)throw $s.bytes=0,new RangeError("Could not decode varint");i=r[o++],e+=s<28?(i&Ii)<<s:(i&Ii)*Math.pow(2,s),s+=7}while(i>=hu);return $s.bytes=o-n,e}var du=Math.pow(2,7),pu=Math.pow(2,14),gu=Math.pow(2,21),yu=Math.pow(2,28),mu=Math.pow(2,35),bu=Math.pow(2,42),wu=Math.pow(2,49),xu=Math.pow(2,56),vu=Math.pow(2,63),Eu=function(r){return r<du?1:r<pu?2:r<gu?3:r<yu?4:r<mu?5:r<bu?6:r<wu?7:r<xu?8:r<vu?9:10},Bu={encode:au,decode:fu,encodingLength:Eu},Au=Bu,Br=Au;function Ar(r,t=0){return[Br.decode(r,t),Br.decode.bytes]}function ze(r,t,e=0){return Br.encode(r,t,e),t}function We(r){return Br.encodingLength(r)}function Lt(r,t){let e=t.byteLength,n=We(r),s=n+We(e),o=new Uint8Array(s+e);return ze(r,o,0),ze(e,o,n),o.set(t,s),new Ze(r,e,t,o)}function Ni(r){let t=$t(r),[e,n]=Ar(t),[s,o]=Ar(t.subarray(n)),i=t.subarray(n+o);if(i.byteLength!==s)throw new Error("Incorrect length");return new Ze(e,s,i,t)}function Ui(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&xi(r.bytes,e.bytes)}}var Ze=class{code;size;digest;bytes;constructor(t,e,n,s){this.code=t,this.size=e,this.digest=n,this.bytes=s}};function Ti(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return ku(e,Gs(r),t??Q.encoder);default:return Iu(e,Gs(r),t??Ge.encoder)}}var Li=new WeakMap;function Gs(r){let t=Li.get(r);if(t==null){let e=new Map;return Li.set(r,e),e}return t}var Nt=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!==kr)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==Cu)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=Lt(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&&Ui(t.multihash,n.multihash)}toString(t){return Ti(this,t)}toJSON(){return{"/":Ti(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??_i(n,s,o.bytes))}else if(e[Nu]===!0){let{version:n,multihash:s,code:o}=e,i=Ni(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!==kr)throw new Error(`Version 0 CID must use dag-pb (code: ${kr}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let s=_i(t,e,n.bytes);return new r(t,e,n,s)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,kr,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=$t(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 Ze(e.multihashCode,e.digestSize,o,s);return[e.version===0?r.createV0(i):r.createV1(e.codec,i),t.subarray(e.size)]}static inspectBytes(t){let e=0,n=()=>{let[u,h]=Ar(t.subarray(e));return e+=h,u},s=n(),o=kr;if(s===18?(s=0,e=0):o=n(),s!==0&&s!==1)throw new RangeError(`Invalid CID version ${s}`);let i=e,a=n(),c=n(),f=e+c,l=f-i;return{version:s,codec:o,multihashCode:a,digestSize:c,multihashSize:l,size:f}}static parse(t,e){let[n,s]=Su(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 Gs(o).set(n,t),o}};function Su(r,t){switch(r[0]){case"Q":{let e=t??Q;return[Q.prefix,e.decode(`${Q.prefix}${r}`)]}case Q.prefix:{let e=t??Q;return[Q.prefix,e.decode(r)]}case Ge.prefix:{let e=t??Ge;return[Ge.prefix,e.decode(r)]}case Er.prefix:{let e=t??Er;return[Er.prefix,e.decode(r)]}default:{if(t==null)throw Error("To parse non base32, base36 or base58btc encoded CID multibase decoder must be provided");return[r[0],t.decode(r)]}}}function ku(r,t,e){let{prefix:n}=e;if(n!==Q.prefix)throw Error(`Cannot string encode V0 in ${e.name} encoding`);let s=t.get(n);if(s==null){let o=e.encode(r).slice(1);return t.set(n,o),o}else return s}function Iu(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 kr=112,Cu=18;function _i(r,t,e){let n=We(r),s=n+We(t),o=new Uint8Array(s+e.byteLength);return ze(r,o,0),ze(t,o,n),o.set(e,s),o}var Nu=Symbol.for("@ipld/js-cid/CID");var zs={};ht(zs,{identity:()=>Be});var Ri=0,Uu="identity",Di=$t;function Tu(r){return Lt(Ri,Di(r))}var Be={code:Ri,name:Uu,encode:Di,digest:Tu};function vt(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 Gt(r=0){return new Uint8Array(r)}function kt(r=0){return new Uint8Array(r)}function Je(r,t){t==null&&(t=r.reduce((s,o)=>s+o.length,0));let e=kt(t),n=0;for(let s of r)e.set(s,n),n+=s.length;return e}var Ki=Symbol.for("@achingbrain/uint8arraylist");function Hi(r,t){if(t==null||t<0)throw new RangeError("index is out of bounds");let e=0;for(let n of r){let s=e+n.byteLength;if(t<s)return{buf:n,index:t-e};e=s}throw new RangeError("index is out of bounds")}function fn(r){return!!r?.[Ki]}var dt=class r{bufs;length;[Ki]=!0;constructor(...t){this.bufs=[],this.length=0,t.length>0&&this.appendAll(t)}*[Symbol.iterator](){yield*this.bufs}get byteLength(){return this.length}append(...t){this.appendAll(t)}appendAll(t){let e=0;for(let n of t)if(n instanceof Uint8Array)e+=n.byteLength,this.bufs.push(n);else if(fn(n))e+=n.byteLength,this.bufs.push(...n.bufs);else throw new Error("Could not append value, must be an Uint8Array or a Uint8ArrayList");this.length+=e}prepend(...t){this.prependAll(t)}prependAll(t){let e=0;for(let n of t.reverse())if(n instanceof Uint8Array)e+=n.byteLength,this.bufs.unshift(n);else if(fn(n))e+=n.byteLength,this.bufs.unshift(...n.bufs);else throw new Error("Could not prepend value, must be an Uint8Array or a Uint8ArrayList");this.length+=e}get(t){let e=Hi(this.bufs,t);return e.buf[e.index]}set(t,e){let n=Hi(this.bufs,t);n.buf[n.index]=e}write(t,e=0){if(t instanceof Uint8Array)for(let n=0;n<t.length;n++)this.set(e+n,t[n]);else if(fn(t))for(let n=0;n<t.length;n++)this.set(e+n,t.get(n));else throw new Error("Could not write value, must be an Uint8Array or a Uint8ArrayList")}consume(t){if(t=Math.trunc(t),!(Number.isNaN(t)||t<=0)){if(t===this.byteLength){this.bufs=[],this.length=0;return}for(;this.bufs.length>0;)if(t>=this.bufs[0].byteLength)t-=this.bufs[0].byteLength,this.length-=this.bufs[0].byteLength,this.bufs.shift();else{this.bufs[0]=this.bufs[0].subarray(t),this.length-=t;break}}}slice(t,e){let{bufs:n,length:s}=this._subList(t,e);return Je(n,s)}subarray(t,e){let{bufs:n,length:s}=this._subList(t,e);return n.length===1?n[0]:Je(n,s)}sublist(t,e){let{bufs:n,length:s}=this._subList(t,e),o=new r;return o.length=s,o.bufs=[...n],o}_subList(t,e){if(t=t??0,e=e??this.length,t<0&&(t=this.length+t),e<0&&(e=this.length+e),t<0||e>this.length)throw new RangeError("index is out of bounds");if(t===e)return{bufs:[],length:0};if(t===0&&e===this.length)return{bufs:this.bufs,length:this.length};let n=[],s=0;for(let o=0;o<this.bufs.length;o++){let i=this.bufs[o],a=s,c=a+i.byteLength;if(s=c,t>=c)continue;let f=t>=a&&t<c,l=e>a&&e<=c;if(f&&l){if(t===a&&e===c){n.push(i);break}let u=t-a;n.push(i.subarray(u,u+(e-t)));break}if(f){if(t===0){n.push(i);continue}n.push(i.subarray(t-a));continue}if(l){if(e===c){n.push(i);break}n.push(i.subarray(0,e-a));break}n.push(i)}return{bufs:n,length:e-t}}indexOf(t,e=0){if(!fn(t)&&!(t instanceof Uint8Array))throw new TypeError('The "value" argument must be a Uint8ArrayList or Uint8Array');let n=t instanceof Uint8Array?t:t.subarray();if(e=Number(e??0),isNaN(e)&&(e=0),e<0&&(e=this.length+e),e<0&&(e=0),t.length===0)return e>this.length?this.length:e;let s=n.byteLength;if(s===0)throw new TypeError("search must be at least 1 byte long");let o=256,i=new Int32Array(o);for(let u=0;u<o;u++)i[u]=-1;for(let u=0;u<s;u++)i[n[u]]=u;let a=i,c=this.byteLength-n.byteLength,f=n.byteLength-1,l;for(let u=e;u<=c;u+=l){l=0;for(let h=f;h>=0;h--){let m=this.get(u+h);if(n[h]!==m){l=Math.max(1,h-a[m]);break}}if(l===0)return u}return-1}getInt8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getInt8(0)}setInt8(t,e){let n=kt(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setInt8(0,e),this.write(n,t)}getInt16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt16(0,e)}setInt16(t,e,n){let s=Gt(2);new DataView(s.buffer,s.byteOffset,s.byteLength).setInt16(0,e,n),this.write(s,t)}getInt32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt32(0,e)}setInt32(t,e,n){let s=Gt(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setInt32(0,e,n),this.write(s,t)}getBigInt64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigInt64(0,e)}setBigInt64(t,e,n){let s=Gt(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigInt64(0,e,n),this.write(s,t)}getUint8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getUint8(0)}setUint8(t,e){let n=kt(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setUint8(0,e),this.write(n,t)}getUint16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint16(0,e)}setUint16(t,e,n){let s=Gt(2);new DataView(s.buffer,s.byteOffset,s.byteLength).setUint16(0,e,n),this.write(s,t)}getUint32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint32(0,e)}setUint32(t,e,n){let s=Gt(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setUint32(0,e,n),this.write(s,t)}getBigUint64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigUint64(0,e)}setBigUint64(t,e,n){let s=Gt(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigUint64(0,e,n),this.write(s,t)}getFloat32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat32(0,e)}setFloat32(t,e,n){let s=Gt(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setFloat32(0,e,n),this.write(s,t)}getFloat64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat64(0,e)}setFloat64(t,e,n){let s=Gt(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setFloat64(0,e,n),this.write(s,t)}equals(t){if(t==null||!(t instanceof r)||t.bufs.length!==this.bufs.length)return!1;for(let e=0;e<this.bufs.length;e++)if(!vt(this.bufs[e],t.bufs[e]))return!1;return!0}static fromUint8Arrays(t,e){let n=new r;return n.bufs=t,e==null&&(e=t.reduce((s,o)=>s+o.byteLength,0)),n.length=e,n}};var Ws={};ht(Ws,{base10:()=>Lu});var Lu=ce({prefix:"9",name:"base10",alphabet:"0123456789"});var Zs={};ht(Zs,{base16:()=>_u,base16upper:()=>Ru});var _u=J({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Ru=J({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Js={};ht(Js,{base2:()=>Du});var Du=J({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Ys={};ht(Ys,{base256emoji:()=>Pu});var Oi=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}"),Hu=Oi.reduce((r,t,e)=>(r[e]=t,r),[]),Ku=Oi.reduce((r,t,e)=>{let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);return r[n]=e,r},[]);function Ou(r){return r.reduce((t,e)=>(t+=Hu[e],t),"")}function Vu(r){let t=[];for(let e of r){let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);let s=Ku[n];if(s==null)throw new Error(`Non-base256emoji character: ${e}`);t.push(s)}return new Uint8Array(t)}var Pu=$e({prefix:"\u{1F680}",name:"base256emoji",encode:Ou,decode:Vu});var Xs={};ht(Xs,{base64:()=>Ae,base64pad:()=>Mu,base64url:()=>Fu,base64urlpad:()=>qu});var Ae=J({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),Mu=J({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Fu=J({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),qu=J({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Qs={};ht(Qs,{base8:()=>ju});var ju=J({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var to={};ht(to,{identity:()=>$u});var $u=$e({prefix:"\0",name:"identity",encode:r=>Ei(r),decode:r=>vi(r)});var g0=new TextEncoder,y0=new TextDecoder;var no={};ht(no,{sha256:()=>Ye,sha512:()=>Wu});function ro({name:r,code:t,encode:e}){return new eo(r,t,e)}var eo=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?Lt(this.code,e):e.then(n=>Lt(this.code,n))}else throw Error("Unknown type, must be binary type")}};function Pi(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var Ye=ro({name:"sha2-256",code:18,encode:Pi("SHA-256")}),Wu=ro({name:"sha2-512",code:19,encode:Pi("SHA-512")});var so={...to,...Js,...Qs,...Ws,...Zs,...qs,...js,...Fs,...Xs,...Ys},C0={...no,...zs};function Fi(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var Mi=Fi("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),oo=Fi("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=kt(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),Zu={utf8:Mi,"utf-8":Mi,hex:so.base16,latin1:oo,ascii:oo,binary:oo,...so},hn=Zu;function O(r,t="utf8"){let e=hn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function q(r,t="utf8"){let e=hn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}var Ju=parseInt("11111",2),io=parseInt("10000000",2),Yu=parseInt("01111111",2),qi={0:Ir,1:Ir,2:Xu,3:ef,4:rf,5:tf,6:Qu,16:Ir,22:Ir,48:Ir};function _t(r,t={offset:0}){let e=r[t.offset]&Ju;if(t.offset++,qi[e]!=null)return qi[e](r,t);throw new Error("No decoder for tag "+e)}function Cr(r,t){let e=0;if((r[t.offset]&io)===io){let n=r[t.offset]&Yu,s="0x";t.offset++;for(let o=0;o<n;o++,t.offset++)s+=r[t.offset].toString(16).padStart(2,"0");e=parseInt(s,16)}else e=r[t.offset],t.offset++;return e}function Ir(r,t){Cr(r,t);let e=[];for(;!(t.offset>=r.byteLength);){let n=_t(r,t);if(n===null)break;e.push(n)}return e}function Xu(r,t){let e=Cr(r,t),n=t.offset,s=t.offset+e,o=[];for(let i=n;i<s;i++)i===n&&r[i]===0||o.push(r[i]);return t.offset+=e,Uint8Array.from(o)}function Qu(r,t){let e=Cr(r,t),n=t.offset+e,s=r[t.offset];t.offset++;let o=0,i=0;s<40?(o=0,i=s):s<80?(o=1,i=s-40):(o=2,i=s-80);let a=`${o}.${i}`,c=[];for(;t.offset<n;){let f=r[t.offset];if(t.offset++,c.push(f&127),f<128){c.reverse();let l=0;for(let u=0;u<c.length;u++)l+=c[u]<<u*7;a+=`.${l}`,c=[]}}return a}function tf(r,t){return t.offset++,null}function ef(r,t){let e=Cr(r,t),n=r[t.offset];t.offset++;let s=r.subarray(t.offset,t.offset+e-1);if(t.offset+=e,n!==0)throw new Error("Unused bits in bit string is unimplemented");return s}function rf(r,t){let e=Cr(r,t),n=r.subarray(t.offset,t.offset+e);return t.offset+=e,n}function nf(r){let t=r.toString(16);t.length%2===1&&(t="0"+t);let e=new dt;for(let n=0;n<t.length;n+=2)e.append(Uint8Array.from([parseInt(`${t[n]}${t[n+1]}`,16)]));return e}function dn(r){if(r.byteLength<128)return Uint8Array.from([r.byteLength]);let t=nf(r.byteLength);return new dt(Uint8Array.from([t.byteLength|io]),t)}function pt(r){let t=new dt,e=128;return(r.subarray()[0]&e)===e&&t.append(Uint8Array.from([0])),t.append(r),new dt(Uint8Array.from([2]),dn(t),t)}function Nr(r){let t=Uint8Array.from([0]),e=new dt(t,r);return new dt(Uint8Array.from([3]),dn(e),e)}function ji(r){return new dt(Uint8Array.from([4]),dn(r),r)}function Rt(r,t=48){let e=new dt;for(let n of r)e.append(n);return new dt(Uint8Array.from([t]),dn(e),e)}var $i="1.2.840.10045.3.1.7",Gi="1.3.132.0.34",zi="1.3.132.0.35";async function Wi(r,t){let e=await crypto.subtle.importKey("jwk",r,{name:"ECDSA",namedCurve:r.crv??"P-256"},!1,["sign"]),n=await crypto.subtle.sign({name:"ECDSA",hash:{name:"SHA-256"}},e,t.subarray());return new Uint8Array(n,0,n.byteLength)}async function Zi(r,t,e){let n=await crypto.subtle.importKey("jwk",r,{name:"ECDSA",namedCurve:r.crv??"P-256"},!1,["verify"]);return crypto.subtle.verify({name:"ECDSA",hash:{name:"SHA-256"}},n,t,e.subarray())}var sf=Uint8Array.from([6,8,42,134,72,206,61,3,1,7]),of=Uint8Array.from([6,5,43,129,4,0,34]),af=Uint8Array.from([6,5,43,129,4,0,35]),cf={ext:!0,kty:"EC",crv:"P-256"},lf={ext:!0,kty:"EC",crv:"P-384"},uf={ext:!0,kty:"EC",crv:"P-521"},ao=32,co=48,lo=66;function Ji(r){let t=_t(r);return uo(t)}function uo(r){let t=r[1],e=q(t,"base64url"),n=r[2][1][0],s=1,o,i;if(t.byteLength===ao)return o=q(n.subarray(s,s+ao),"base64url"),i=q(n.subarray(s+ao),"base64url"),new Xe({...cf,key_ops:["sign"],d:e,x:o,y:i});if(t.byteLength===co)return o=q(n.subarray(s,s+co),"base64url"),i=q(n.subarray(s+co),"base64url"),new Xe({...lf,key_ops:["sign"],d:e,x:o,y:i});if(t.byteLength===lo)return o=q(n.subarray(s,s+lo),"base64url"),i=q(n.subarray(s+lo),"base64url"),new Xe({...uf,key_ops:["sign"],d:e,x:o,y:i});throw new _(`Private key length was wrong length, got ${t.byteLength}, expected 32, 48 or 66`)}function Yi(r){return Rt([pt(Uint8Array.from([1])),ji(O(r.d??"","base64url")),Rt([Qi(r.crv)],160),Rt([Nr(new dt(Uint8Array.from([4]),O(r.x??"","base64url"),O(r.y??"","base64url")))],161)]).subarray()}function Xi(r){return Rt([pt(Uint8Array.from([1])),Rt([Qi(r.crv)],160),Rt([Nr(new dt(Uint8Array.from([4]),O(r.x??"","base64url"),O(r.y??"","base64url")))],161)]).subarray()}function Qi(r){if(r==="P-256")return sf;if(r==="P-384")return of;if(r==="P-521")return af;throw new _(`Invalid curve ${r}`)}var pn=class{type="ECDSA";jwk;_raw;constructor(t){this.jwk=t}get raw(){return this._raw==null&&(this._raw=Xi(this.jwk)),this._raw}toMultihash(){return Be.digest(Qe(this))}toCID(){return Nt.createV1(114,this.toMultihash())}toString(){return Q.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:vt(this.raw,t.raw)}async verify(t,e){return Zi(this.jwk,e,t)}},Xe=class{type="ECDSA";jwk;publicKey;_raw;constructor(t){this.jwk=t,this.publicKey=new pn({crv:t.crv,ext:t.ext,key_ops:["verify"],kty:"EC",x:t.x,y:t.y})}get raw(){return this._raw==null&&(this._raw=Yi(this.jwk)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:vt(this.raw,t.raw)}async sign(t){return Wi(this.jwk,t)}};var Se=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;function ff(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function le(r){if(!Number.isSafeInteger(r)||r<0)throw new Error("positive integer expected, got "+r)}function ue(r,...t){if(!ff(r))throw new Error("Uint8Array expected");if(t.length>0&&!t.includes(r.length))throw new Error("Uint8Array expected of length "+t+", got length="+r.length)}function gn(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.createHasher");le(r.outputLen),le(r.blockLen)}function er(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 ta(r,t){ue(r);let e=t.outputLen;if(r.length<e)throw new Error("digestInto() expects output buffer of length at least "+e)}function Et(...r){for(let t=0;t<r.length;t++)r[t].fill(0)}function ke(r){return new DataView(r.buffer,r.byteOffset,r.byteLength)}function Dt(r,t){return r<<32-t|r>>>t}function yn(r,t){return r<<t|r>>>32-t>>>0}var hf=async()=>{};async function ea(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 hf(),n+=o)}}function fo(r){if(typeof r!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(r))}function Ur(r){return typeof r=="string"&&(r=fo(r)),ue(r),r}function ho(r){return typeof r=="string"&&(r=fo(r)),ue(r),r}function po(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];ue(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 ra(r,t){if(t!==void 0&&{}.toString.call(t)!=="[object Object]")throw new Error("options should be object or undefined");return Object.assign(r,t)}var tr=class{};function Tr(r){let t=n=>r().update(Ur(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function rr(r=32){if(Se&&typeof Se.getRandomValues=="function")return Se.getRandomValues(new Uint8Array(r));if(Se&&typeof Se.randomBytes=="function")return Uint8Array.from(Se.randomBytes(r));throw new Error("crypto.getRandomValues must be defined")}function df(r,t,e,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(t,e,n);let s=BigInt(32),o=BigInt(4294967295),i=Number(e>>s&o),a=Number(e&o),c=n?4:0,f=n?0:4;r.setUint32(t+c,i,n),r.setUint32(t+f,a,n)}function mn(r,t,e){return r&t^~r&e}function bn(r,t,e){return r&t^r&e^t&e}var Ie=class extends tr{constructor(t,e,n,s){super(),this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.blockLen=t,this.outputLen=e,this.padOffset=n,this.isLE=s,this.buffer=new Uint8Array(t),this.view=ke(this.buffer)}update(t){er(this),t=Ur(t),ue(t);let{view:e,buffer:n,blockLen:s}=this,o=t.length;for(let i=0;i<o;){let a=Math.min(s-this.pos,o-i);if(a===s){let c=ke(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){er(this),ta(t,this),this.finished=!0;let{buffer:e,view:n,blockLen:s,isLE:o}=this,{pos:i}=this;e[i++]=128,Et(this.buffer.subarray(i)),this.padOffset>s-i&&(this.process(n,0),i=0);for(let u=i;u<s;u++)e[u]=0;df(n,s-8,BigInt(this.length*8),o),this.process(n,0);let a=ke(t),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let f=c/4,l=this.get();if(f>l.length)throw new Error("_sha2: outputLen bigger than state");for(let u=0;u<f;u++)a.setUint32(4*u,l[u],o)}digest(){let{buffer:t,outputLen:e}=this;this.digestInto(t);let n=t.slice(0,e);return this.destroy(),n}_cloneInto(t){t||(t=new this.constructor),t.set(...this.get());let{blockLen:e,buffer:n,length:s,finished:o,destroyed:i,pos:a}=this;return t.destroyed=i,t.finished=o,t.length=s,t.pos=a,s%e&&t.buffer.set(n),t}clone(){return this._cloneInto()}},zt=Uint32Array.from([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]);var it=Uint32Array.from([1779033703,4089235720,3144134277,2227873595,1013904242,4271175723,2773480762,1595750129,1359893119,2917565137,2600822924,725511199,528734635,4215389547,1541459225,327033209]);var wn=BigInt(4294967295),na=BigInt(32);function pf(r,t=!1){return t?{h:Number(r&wn),l:Number(r>>na&wn)}:{h:Number(r>>na&wn)|0,l:Number(r&wn)|0}}function sa(r,t=!1){let e=r.length,n=new Uint32Array(e),s=new Uint32Array(e);for(let o=0;o<e;o++){let{h:i,l:a}=pf(r[o],t);[n[o],s[o]]=[i,a]}return[n,s]}var go=(r,t,e)=>r>>>e,yo=(r,t,e)=>r<<32-e|t>>>e,Ce=(r,t,e)=>r>>>e|t<<32-e,Ne=(r,t,e)=>r<<32-e|t>>>e,Lr=(r,t,e)=>r<<64-e|t>>>e-32,_r=(r,t,e)=>r>>>e-32|t<<64-e;function Pt(r,t,e,n){let s=(t>>>0)+(n>>>0);return{h:r+e+(s/2**32|0)|0,l:s|0}}var oa=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),ia=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,aa=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),ca=(r,t,e,n,s)=>t+e+n+s+(r/2**32|0)|0,la=(r,t,e,n,s)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(s>>>0),ua=(r,t,e,n,s,o)=>t+e+n+s+o+(r/2**32|0)|0;var yf=Uint32Array.from([1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298]),fe=new Uint32Array(64),xn=class extends Ie{constructor(t=32){super(64,t,8,!1),this.A=zt[0]|0,this.B=zt[1]|0,this.C=zt[2]|0,this.D=zt[3]|0,this.E=zt[4]|0,this.F=zt[5]|0,this.G=zt[6]|0,this.H=zt[7]|0}get(){let{A:t,B:e,C:n,D:s,E:o,F:i,G:a,H:c}=this;return[t,e,n,s,o,i,a,c]}set(t,e,n,s,o,i,a,c){this.A=t|0,this.B=e|0,this.C=n|0,this.D=s|0,this.E=o|0,this.F=i|0,this.G=a|0,this.H=c|0}process(t,e){for(let u=0;u<16;u++,e+=4)fe[u]=t.getUint32(e,!1);for(let u=16;u<64;u++){let h=fe[u-15],m=fe[u-2],w=Dt(h,7)^Dt(h,18)^h>>>3,y=Dt(m,17)^Dt(m,19)^m>>>10;fe[u]=y+fe[u-7]+w+fe[u-16]|0}let{A:n,B:s,C:o,D:i,E:a,F:c,G:f,H:l}=this;for(let u=0;u<64;u++){let h=Dt(a,6)^Dt(a,11)^Dt(a,25),m=l+h+mn(a,c,f)+yf[u]+fe[u]|0,y=(Dt(n,2)^Dt(n,13)^Dt(n,22))+bn(n,s,o)|0;l=f,f=c,c=a,a=i+m|0,i=o,o=s,s=n,n=m+y|0}n=n+this.A|0,s=s+this.B|0,o=o+this.C|0,i=i+this.D|0,a=a+this.E|0,c=c+this.F|0,f=f+this.G|0,l=l+this.H|0,this.set(n,s,o,i,a,c,f,l)}roundClean(){Et(fe)}destroy(){this.set(0,0,0,0,0,0,0,0),Et(this.buffer)}};var fa=sa(["0x428a2f98d728ae22","0x7137449123ef65cd","0xb5c0fbcfec4d3b2f","0xe9b5dba58189dbbc","0x3956c25bf348b538","0x59f111f1b605d019","0x923f82a4af194f9b","0xab1c5ed5da6d8118","0xd807aa98a3030242","0x12835b0145706fbe","0x243185be4ee4b28c","0x550c7dc3d5ffb4e2","0x72be5d74f27b896f","0x80deb1fe3b1696b1","0x9bdc06a725c71235","0xc19bf174cf692694","0xe49b69c19ef14ad2","0xefbe4786384f25e3","0x0fc19dc68b8cd5b5","0x240ca1cc77ac9c65","0x2de92c6f592b0275","0x4a7484aa6ea6e483","0x5cb0a9dcbd41fbd4","0x76f988da831153b5","0x983e5152ee66dfab","0xa831c66d2db43210","0xb00327c898fb213f","0xbf597fc7beef0ee4","0xc6e00bf33da88fc2","0xd5a79147930aa725","0x06ca6351e003826f","0x142929670a0e6e70","0x27b70a8546d22ffc","0x2e1b21385c26c926","0x4d2c6dfc5ac42aed","0x53380d139d95b3df","0x650a73548baf63de","0x766a0abb3c77b2a8","0x81c2c92e47edaee6","0x92722c851482353b","0xa2bfe8a14cf10364","0xa81a664bbc423001","0xc24b8b70d0f89791","0xc76c51a30654be30","0xd192e819d6ef5218","0xd69906245565a910","0xf40e35855771202a","0x106aa07032bbd1b8","0x19a4c116b8d2d0c8","0x1e376c085141ab53","0x2748774cdf8eeb99","0x34b0bcb5e19b48a8","0x391c0cb3c5c95a63","0x4ed8aa4ae3418acb","0x5b9cca4f7763e373","0x682e6ff3d6b2b8a3","0x748f82ee5defb2fc","0x78a5636f43172f60","0x84c87814a1f0ab72","0x8cc702081a6439ec","0x90befffa23631e28","0xa4506cebde82bde9","0xbef9a3f7b2c67915","0xc67178f2e372532b","0xca273eceea26619c","0xd186b8c721c0c207","0xeada7dd6cde0eb1e","0xf57d4f7fee6ed178","0x06f067aa72176fba","0x0a637dc5a2c898a6","0x113f9804bef90dae","0x1b710b35131c471b","0x28db77f523047d84","0x32caab7b40c72493","0x3c9ebe0a15c9bebc","0x431d67c49c100d4c","0x4cc5d4becb3e42b6","0x597f299cfc657e2a","0x5fcb6fab3ad6faec","0x6c44198c4a475817"].map(r=>BigInt(r))),mf=fa[0],bf=fa[1],he=new Uint32Array(80),de=new Uint32Array(80),vn=class extends Ie{constructor(t=64){super(128,t,16,!1),this.Ah=it[0]|0,this.Al=it[1]|0,this.Bh=it[2]|0,this.Bl=it[3]|0,this.Ch=it[4]|0,this.Cl=it[5]|0,this.Dh=it[6]|0,this.Dl=it[7]|0,this.Eh=it[8]|0,this.El=it[9]|0,this.Fh=it[10]|0,this.Fl=it[11]|0,this.Gh=it[12]|0,this.Gl=it[13]|0,this.Hh=it[14]|0,this.Hl=it[15]|0}get(){let{Ah:t,Al:e,Bh:n,Bl:s,Ch:o,Cl:i,Dh:a,Dl:c,Eh:f,El:l,Fh:u,Fl:h,Gh:m,Gl:w,Hh:y,Hl:d}=this;return[t,e,n,s,o,i,a,c,f,l,u,h,m,w,y,d]}set(t,e,n,s,o,i,a,c,f,l,u,h,m,w,y,d){this.Ah=t|0,this.Al=e|0,this.Bh=n|0,this.Bl=s|0,this.Ch=o|0,this.Cl=i|0,this.Dh=a|0,this.Dl=c|0,this.Eh=f|0,this.El=l|0,this.Fh=u|0,this.Fl=h|0,this.Gh=m|0,this.Gl=w|0,this.Hh=y|0,this.Hl=d|0}process(t,e){for(let p=0;p<16;p++,e+=4)he[p]=t.getUint32(e),de[p]=t.getUint32(e+=4);for(let p=16;p<80;p++){let S=he[p-15]|0,R=de[p-15]|0,L=Ce(S,R,1)^Ce(S,R,8)^go(S,R,7),C=Ne(S,R,1)^Ne(S,R,8)^yo(S,R,7),N=he[p-2]|0,U=de[p-2]|0,z=Ce(N,U,19)^Lr(N,U,61)^go(N,U,6),j=Ne(N,U,19)^_r(N,U,61)^yo(N,U,6),K=aa(C,j,de[p-7],de[p-16]),tt=ca(K,L,z,he[p-7],he[p-16]);he[p]=tt|0,de[p]=K|0}let{Ah:n,Al:s,Bh:o,Bl:i,Ch:a,Cl:c,Dh:f,Dl:l,Eh:u,El:h,Fh:m,Fl:w,Gh:y,Gl:d,Hh:b,Hl:E}=this;for(let p=0;p<80;p++){let S=Ce(u,h,14)^Ce(u,h,18)^Lr(u,h,41),R=Ne(u,h,14)^Ne(u,h,18)^_r(u,h,41),L=u&m^~u&y,C=h&w^~h&d,N=la(E,R,C,bf[p],de[p]),U=ua(N,b,S,L,mf[p],he[p]),z=N|0,j=Ce(n,s,28)^Lr(n,s,34)^Lr(n,s,39),K=Ne(n,s,28)^_r(n,s,34)^_r(n,s,39),tt=n&o^n&a^o&a,B=s&i^s&c^i&c;b=y|0,E=d|0,y=m|0,d=w|0,m=u|0,w=h|0,{h:u,l:h}=Pt(f|0,l|0,U|0,z|0),f=a|0,l=c|0,a=o|0,c=i|0,o=n|0,i=s|0;let I=oa(z,K,B);n=ia(I,U,j,tt),s=I|0}({h:n,l:s}=Pt(this.Ah|0,this.Al|0,n|0,s|0)),{h:o,l:i}=Pt(this.Bh|0,this.Bl|0,o|0,i|0),{h:a,l:c}=Pt(this.Ch|0,this.Cl|0,a|0,c|0),{h:f,l}=Pt(this.Dh|0,this.Dl|0,f|0,l|0),{h:u,l:h}=Pt(this.Eh|0,this.El|0,u|0,h|0),{h:m,l:w}=Pt(this.Fh|0,this.Fl|0,m|0,w|0),{h:y,l:d}=Pt(this.Gh|0,this.Gl|0,y|0,d|0),{h:b,l:E}=Pt(this.Hh|0,this.Hl|0,b|0,E|0),this.set(n,s,o,i,a,c,f,l,u,h,m,w,y,d,b,E)}roundClean(){Et(he,de)}destroy(){Et(this.buffer),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}};var En=Tr(()=>new xn);var Bn=Tr(()=>new vn);var xo=BigInt(0),wo=BigInt(1);function Ue(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function vo(r){if(!Ue(r))throw new Error("Uint8Array expected")}function Mt(r,t){if(typeof t!="boolean")throw new Error(r+" boolean expected, got "+t)}function Rr(r){let t=r.toString(16);return t.length&1?"0"+t:t}function pa(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return r===""?xo:BigInt("0x"+r)}var ga=typeof Uint8Array.from([]).toHex=="function"&&typeof Uint8Array.fromHex=="function",wf=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function pe(r){if(vo(r),ga)return r.toHex();let t="";for(let e=0;e<r.length;e++)t+=wf[r[e]];return t}var Wt={_0:48,_9:57,A:65,F:70,a:97,f:102};function ha(r){if(r>=Wt._0&&r<=Wt._9)return r-Wt._0;if(r>=Wt.A&&r<=Wt.F)return r-(Wt.A-10);if(r>=Wt.a&&r<=Wt.f)return r-(Wt.a-10)}function Dr(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);if(ga)return Uint8Array.fromHex(r);let t=r.length,e=t/2;if(t%2)throw new Error("hex string expected, got unpadded hex of length "+t);let n=new Uint8Array(e);for(let s=0,o=0;s<e;s++,o+=2){let i=ha(r.charCodeAt(o)),a=ha(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 Zt(r){return pa(pe(r))}function Te(r){return vo(r),pa(pe(Uint8Array.from(r).reverse()))}function Le(r,t){return Dr(r.toString(16).padStart(t*2,"0"))}function nr(r,t){return Le(r,t).reverse()}function Z(r,t,e){let n;if(typeof t=="string")try{n=Dr(t)}catch(o){throw new Error(r+" must be hex string or Uint8Array, cause: "+o)}else if(Ue(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+" of length "+e+" expected, got "+s);return n}function ge(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];vo(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 mo=r=>typeof r=="bigint"&&xo<=r;function An(r,t,e){return mo(r)&&mo(t)&&mo(e)&&t<=r&&r<e}function It(r,t,e,n){if(!An(t,e,n))throw new Error("expected valid "+r+": "+e+" <= n < "+n+", got "+t)}function ya(r){let t;for(t=0;r>xo;r>>=wo,t+=1);return t}var _e=r=>(wo<<BigInt(r))-wo,bo=r=>new Uint8Array(r),da=r=>Uint8Array.from(r);function ma(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=bo(r),s=bo(r),o=0,i=()=>{n.fill(1),s.fill(0),o=0},a=(...u)=>e(s,n,...u),c=(u=bo(0))=>{s=a(da([0]),u),n=a(),u.length!==0&&(s=a(da([1]),u),n=a())},f=()=>{if(o++>=1e3)throw new Error("drbg: tried 1000 values");let u=0,h=[];for(;u<t;){n=a();let m=n.slice();h.push(m),u+=n.length}return ge(...h)};return(u,h)=>{i(),c(u);let m;for(;!(m=h(f()));)c();return i(),m}}var xf={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"||Ue(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 Jt(r,t,e={}){let n=(s,o,i)=>{let a=xf[o];if(typeof a!="function")throw new Error("invalid validator function");let c=r[s];if(!(i&&c===void 0)&&!a(c,r))throw new Error("param "+String(s)+" is invalid. Expected "+o+", got "+c)};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}function sr(r){let t=new WeakMap;return(e,...n)=>{let s=t.get(e);if(s!==void 0)return s;let o=r(e,...n);return t.set(e,o),o}}var gt=BigInt(0),et=BigInt(1),Re=BigInt(2),vf=BigInt(3),Eo=BigInt(4),ba=BigInt(5),wa=BigInt(8),Ef=BigInt(9),Bf=BigInt(16);function G(r,t){let e=r%t;return e>=gt?e:t+e}function W(r,t,e){let n=r;for(;t-- >gt;)n*=n,n%=e;return n}function Sn(r,t){if(r===gt)throw new Error("invert: expected non-zero number");if(t<=gt)throw new Error("invert: expected positive modulus, got "+t);let e=G(r,t),n=t,s=gt,o=et,i=et,a=gt;for(;e!==gt;){let f=n/e,l=n%e,u=s-i*f,h=o-a*f;n=e,e=l,s=i,o=a,i=u,a=h}if(n!==et)throw new Error("invert: does not exist");return G(s,t)}function Af(r){let t=r-et,e=0;for(;t%Re===gt;)t/=Re,e++;let n=Re,s=Yt(r);for(;n<r&&xa(s,n);)if(n++>1e3)throw new Error("Cannot find square root: probably non-prime P");if(e===1){let i=(r+et)/Eo;return function(c,f){let l=c.pow(f,i);if(!c.eql(c.sqr(l),f))throw new Error("Cannot find square root");return l}}let o=(t+et)/Re;return function(a,c){if(!xa(a,c))throw new Error("Cannot find square root");let f=e,l=a.pow(a.mul(a.ONE,n),t),u=a.pow(c,o),h=a.pow(c,t);for(;!a.eql(h,a.ONE);){if(a.eql(h,a.ZERO))return a.ZERO;let m=1;for(let y=a.sqr(h);m<f&&!a.eql(y,a.ONE);m++)y=a.sqr(y);let w=a.pow(l,et<<BigInt(f-m-1));l=a.sqr(w),u=a.mul(u,w),h=a.mul(h,l),f=m}return u}}function Sf(r){return r%Eo===vf?function(e,n){let s=(r+et)/Eo,o=e.pow(n,s);if(!e.eql(e.sqr(o),n))throw new Error("Cannot find square root");return o}:r%wa===ba?function(e,n){let s=e.mul(n,Re),o=(r-ba)/wa,i=e.pow(s,o),a=e.mul(n,i),c=e.mul(e.mul(a,Re),i),f=e.mul(a,e.sub(c,e.ONE));if(!e.eql(e.sqr(f),n))throw new Error("Cannot find square root");return f}:(r%Bf,Af(r))}var va=(r,t)=>(G(r,t)&et)===et,kf=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function Bo(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=kf.reduce((n,s)=>(n[s]="function",n),t);return Jt(r,e)}function If(r,t,e){if(e<gt)throw new Error("invalid exponent, negatives unsupported");if(e===gt)return r.ONE;if(e===et)return t;let n=r.ONE,s=t;for(;e>gt;)e&et&&(n=r.mul(n,s)),s=r.sqr(s),e>>=et;return n}function or(r,t,e=!1){let n=new Array(t.length).fill(e?r.ZERO:void 0),s=t.reduce((i,a,c)=>r.is0(a)?i:(n[c]=i,r.mul(i,a)),r.ONE),o=r.inv(s);return t.reduceRight((i,a,c)=>r.is0(a)?i:(n[c]=r.mul(i,n[c]),r.mul(i,a)),o),n}function Cf(r,t){let e=(r.ORDER-et)/Re,n=r.pow(t,e),s=r.eql(n,r.ONE),o=r.eql(n,r.ZERO),i=r.eql(n,r.neg(r.ONE));if(!s&&!o&&!i)throw new Error("Cannot find square root: probably non-prime P");return s?1:o?0:-1}function xa(r,t){let e=Cf(r,t);return e===0||e===1}function Ao(r,t){t!==void 0&&le(t);let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function Yt(r,t,e=!1,n={}){if(r<=gt)throw new Error("invalid field: expected ORDER > 0, got "+r);let{nBitLength:s,nByteLength:o}=Ao(r,t);if(o>2048)throw new Error("invalid field: expected ORDER of <= 2048 bytes");let i,a=Object.freeze({ORDER:r,isLE:e,BITS:s,BYTES:o,MASK:_e(s),ZERO:gt,ONE:et,create:c=>G(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error("invalid field element: expected bigint, got "+typeof c);return gt<=c&&c<r},is0:c=>c===gt,isOdd:c=>(c&et)===et,neg:c=>G(-c,r),eql:(c,f)=>c===f,sqr:c=>G(c*c,r),add:(c,f)=>G(c+f,r),sub:(c,f)=>G(c-f,r),mul:(c,f)=>G(c*f,r),pow:(c,f)=>If(a,c,f),div:(c,f)=>G(c*Sn(f,r),r),sqrN:c=>c*c,addN:(c,f)=>c+f,subN:(c,f)=>c-f,mulN:(c,f)=>c*f,inv:c=>Sn(c,r),sqrt:n.sqrt||(c=>(i||(i=Sf(r)),i(a,c))),toBytes:c=>e?nr(c,o):Le(c,o),fromBytes:c=>{if(c.length!==o)throw new Error("Field.fromBytes: expected "+o+" bytes, got "+c.length);return e?Te(c):Zt(c)},invertBatch:c=>or(a,c),cmov:(c,f,l)=>l?f:c});return Object.freeze(a)}function Ea(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 So(r){let t=Ea(r);return t+Math.ceil(t/2)}function Ba(r,t,e=!1){let n=r.length,s=Ea(t),o=So(t);if(n<16||n<o||n>1024)throw new Error("expected "+o+"-1024 bytes of input, got "+n);let i=e?Te(r):Zt(r),a=G(i,t-et)+et;return e?nr(a,s):Le(a,s)}var Aa=BigInt(0),Uo=BigInt(1);function ko(r,t){let e=t.negate();return r?e:t}function ka(r,t){if(!Number.isSafeInteger(r)||r<=0||r>t)throw new Error("invalid window size, expected [1.."+t+"], got W="+r)}function Io(r,t){ka(r,t);let e=Math.ceil(t/r)+1,n=2**(r-1),s=2**r,o=_e(r),i=BigInt(r);return{windows:e,windowSize:n,mask:o,maxNumber:s,shiftBy:i}}function Sa(r,t,e){let{windowSize:n,mask:s,maxNumber:o,shiftBy:i}=e,a=Number(r&s),c=r>>i;a>n&&(a-=o,c+=Uo);let f=t*n,l=f+Math.abs(a)-1,u=a===0,h=a<0,m=t%2!==0;return{nextN:c,offset:l,isZero:u,isNeg:h,isNegF:m,offsetF:f}}function Nf(r,t){if(!Array.isArray(r))throw new Error("array expected");r.forEach((e,n)=>{if(!(e instanceof t))throw new Error("invalid point at index "+n)})}function Uf(r,t){if(!Array.isArray(r))throw new Error("array of scalars expected");r.forEach((e,n)=>{if(!t.isValid(e))throw new Error("invalid scalar at index "+n)})}var Co=new WeakMap,Ia=new WeakMap;function No(r){return Ia.get(r)||1}function kn(r,t){return{constTimeNegate:ko,hasPrecomputes(e){return No(e)!==1},unsafeLadder(e,n,s=r.ZERO){let o=e;for(;n>Aa;)n&Uo&&(s=s.add(o)),o=o.double(),n>>=Uo;return s},precomputeWindow(e,n){let{windows:s,windowSize:o}=Io(n,t),i=[],a=e,c=a;for(let f=0;f<s;f++){c=a,i.push(c);for(let l=1;l<o;l++)c=c.add(a),i.push(c);a=c.double()}return i},wNAF(e,n,s){let o=r.ZERO,i=r.BASE,a=Io(e,t);for(let c=0;c<a.windows;c++){let{nextN:f,offset:l,isZero:u,isNeg:h,isNegF:m,offsetF:w}=Sa(s,c,a);s=f,u?i=i.add(ko(m,n[w])):o=o.add(ko(h,n[l]))}return{p:o,f:i}},wNAFUnsafe(e,n,s,o=r.ZERO){let i=Io(e,t);for(let a=0;a<i.windows&&s!==Aa;a++){let{nextN:c,offset:f,isZero:l,isNeg:u}=Sa(s,a,i);if(s=c,!l){let h=n[f];o=o.add(u?h.negate():h)}}return o},getPrecomputes(e,n,s){let o=Co.get(n);return o||(o=this.precomputeWindow(n,e),e!==1&&Co.set(n,s(o))),o},wNAFCached(e,n,s){let o=No(e);return this.wNAF(o,this.getPrecomputes(o,e,s),n)},wNAFCachedUnsafe(e,n,s,o){let i=No(e);return i===1?this.unsafeLadder(e,n,o):this.wNAFUnsafe(i,this.getPrecomputes(i,e,s),n,o)},setWindowSize(e,n){ka(n,t),Ia.set(e,n),Co.delete(e)}}}function In(r,t,e,n){if(Nf(e,r),Uf(n,t),e.length!==n.length)throw new Error("arrays of points and scalars must have equal length");let s=r.ZERO,o=ya(BigInt(e.length)),i=o>12?o-3:o>4?o-2:o?2:1,a=_e(i),c=new Array(Number(a)+1).fill(s),f=Math.floor((t.BITS-1)/i)*i,l=s;for(let u=f;u>=0;u-=i){c.fill(s);for(let m=0;m<n.length;m++){let w=n[m],y=Number(w>>BigInt(u)&a);c[y]=c[y].add(e[m])}let h=s;for(let m=c.length-1,w=s;m>0;m--)w=w.add(c[m]),h=h.add(w);if(l=l.add(h),u!==0)for(let m=0;m<i;m++)l=l.double()}return l}function Hr(r){return Bo(r.Fp),Jt(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...Ao(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Ft=BigInt(0),yt=BigInt(1),Ca=BigInt(2),Tf=BigInt(8),Lf={zip215:!0};function _f(r){let t=Hr(r);return Jt(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function Na(r){let t=_f(r),{Fp:e,n,prehash:s,hash:o,randomBytes:i,nByteLength:a,h:c}=t,f=Ca<<BigInt(a*8)-yt,l=e.create,u=Yt(t.n,t.nBitLength),h=t.uvRatio||((x,g)=>{try{return{isValid:!0,value:e.sqrt(x*e.inv(g))}}catch{return{isValid:!1,value:Ft}}}),m=t.adjustScalarBytes||(x=>x),w=t.domain||((x,g,v)=>{if(Mt("phflag",v),g.length||v)throw new Error("Contexts/pre-hash are not supported");return x});function y(x,g,v=!1){let k=v?yt:Ft;It("coordinate "+x,g,k,f)}function d(x){if(!(x instanceof p))throw new Error("ExtendedPoint expected")}let b=sr((x,g)=>{let{ex:v,ey:k,ez:D}=x,H=x.is0();g==null&&(g=H?Tf:e.inv(D));let V=l(v*g),M=l(k*g),F=l(D*g);if(H)return{x:Ft,y:yt};if(F!==yt)throw new Error("invZ was invalid");return{x:V,y:M}}),E=sr(x=>{let{a:g,d:v}=t;if(x.is0())throw new Error("bad point: ZERO");let{ex:k,ey:D,ez:H,et:V}=x,M=l(k*k),F=l(D*D),$=l(H*H),X=l($*$),Y=l(M*g),ot=l($*l(Y+F)),wt=l(X+l(v*l(M*F)));if(ot!==wt)throw new Error("bad point: equation left != right (1)");let nt=l(k*D),lt=l(H*V);if(nt!==lt)throw new Error("bad point: equation left != right (2)");return!0});class p{constructor(g,v,k,D){y("x",g),y("y",v),y("z",k,!0),y("t",D),this.ex=g,this.ey=v,this.ez=k,this.et=D,Object.freeze(this)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(g){if(g instanceof p)throw new Error("extended point not allowed");let{x:v,y:k}=g||{};return y("x",v),y("y",k),new p(v,k,yt,l(v*k))}static normalizeZ(g){let v=or(e,g.map(k=>k.ez));return g.map((k,D)=>k.toAffine(v[D])).map(p.fromAffine)}static msm(g,v){return In(p,u,g,v)}_setWindowSize(g){L.setWindowSize(this,g)}assertValidity(){E(this)}equals(g){d(g);let{ex:v,ey:k,ez:D}=this,{ex:H,ey:V,ez:M}=g,F=l(v*M),$=l(H*D),X=l(k*M),Y=l(V*D);return F===$&&X===Y}is0(){return this.equals(p.ZERO)}negate(){return new p(l(-this.ex),this.ey,this.ez,l(-this.et))}double(){let{a:g}=t,{ex:v,ey:k,ez:D}=this,H=l(v*v),V=l(k*k),M=l(Ca*l(D*D)),F=l(g*H),$=v+k,X=l(l($*$)-H-V),Y=F+V,ot=Y-M,wt=F-V,nt=l(X*ot),lt=l(Y*wt),St=l(X*wt),Tt=l(ot*Y);return new p(nt,lt,Tt,St)}add(g){d(g);let{a:v,d:k}=t,{ex:D,ey:H,ez:V,et:M}=this,{ex:F,ey:$,ez:X,et:Y}=g,ot=l(D*F),wt=l(H*$),nt=l(M*k*Y),lt=l(V*X),St=l((D+H)*(F+$)-ot-wt),Tt=lt-nt,br=lt+nt,yi=l(wt-v*ot),Hl=l(St*Tt),Kl=l(br*yi),Ol=l(St*yi),Vl=l(Tt*br);return new p(Hl,Kl,Vl,Ol)}subtract(g){return this.add(g.negate())}wNAF(g){return L.wNAFCached(this,g,p.normalizeZ)}multiply(g){let v=g;It("scalar",v,yt,n);let{p:k,f:D}=this.wNAF(v);return p.normalizeZ([k,D])[0]}multiplyUnsafe(g,v=p.ZERO){let k=g;return It("scalar",k,Ft,n),k===Ft?R:this.is0()||k===yt?this:L.wNAFCachedUnsafe(this,k,p.normalizeZ,v)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return L.unsafeLadder(this,n).is0()}toAffine(g){return b(this,g)}clearCofactor(){let{h:g}=t;return g===yt?this:this.multiplyUnsafe(g)}static fromHex(g,v=!1){let{d:k,a:D}=t,H=e.BYTES;g=Z("pointHex",g,H),Mt("zip215",v);let V=g.slice(),M=g[H-1];V[H-1]=M&-129;let F=Te(V),$=v?f:e.ORDER;It("pointHex.y",F,Ft,$);let X=l(F*F),Y=l(X-yt),ot=l(k*X-D),{isValid:wt,value:nt}=h(Y,ot);if(!wt)throw new Error("Point.fromHex: invalid y coordinate");let lt=(nt&yt)===yt,St=(M&128)!==0;if(!v&&nt===Ft&&St)throw new Error("Point.fromHex: x=0 and x_0=1");return St!==lt&&(nt=l(-nt)),p.fromAffine({x:nt,y:F})}static fromPrivateKey(g){let{scalar:v}=U(g);return S.multiply(v)}toRawBytes(){let{x:g,y:v}=this.toAffine(),k=nr(v,e.BYTES);return k[k.length-1]|=g&yt?128:0,k}toHex(){return pe(this.toRawBytes())}}p.BASE=new p(t.Gx,t.Gy,yt,l(t.Gx*t.Gy)),p.ZERO=new p(Ft,yt,yt,Ft);let{BASE:S,ZERO:R}=p,L=kn(p,a*8);function C(x){return G(x,n)}function N(x){return C(Te(x))}function U(x){let g=e.BYTES;x=Z("private key",x,g);let v=Z("hashed private key",o(x),2*g),k=m(v.slice(0,g)),D=v.slice(g,2*g),H=N(k);return{head:k,prefix:D,scalar:H}}function z(x){let{head:g,prefix:v,scalar:k}=U(x),D=S.multiply(k),H=D.toRawBytes();return{head:g,prefix:v,scalar:k,point:D,pointBytes:H}}function j(x){return z(x).pointBytes}function K(x=Uint8Array.of(),...g){let v=ge(...g);return N(o(w(v,Z("context",x),!!s)))}function tt(x,g,v={}){x=Z("message",x),s&&(x=s(x));let{prefix:k,scalar:D,pointBytes:H}=z(g),V=K(v.context,k,x),M=S.multiply(V).toRawBytes(),F=K(v.context,M,H,x),$=C(V+F*D);It("signature.s",$,Ft,n);let X=ge(M,nr($,e.BYTES));return Z("result",X,e.BYTES*2)}let B=Lf;function I(x,g,v,k=B){let{context:D,zip215:H}=k,V=e.BYTES;x=Z("signature",x,2*V),g=Z("message",g),v=Z("publicKey",v,V),H!==void 0&&Mt("zip215",H),s&&(g=s(g));let M=Te(x.slice(V,2*V)),F,$,X;try{F=p.fromHex(v,H),$=p.fromHex(x.slice(0,V),H),X=S.multiplyUnsafe(M)}catch{return!1}if(!H&&F.isSmallOrder())return!1;let Y=K(D,$.toRawBytes(),F.toRawBytes(),g);return $.add(F.multiplyUnsafe(Y)).subtract(X).clearCofactor().equals(p.ZERO)}return S._setWindowSize(8),{CURVE:t,getPublicKey:j,sign:tt,verify:I,ExtendedPoint:p,utils:{getExtendedPublicKey:z,randomPrivateKey:()=>i(e.BYTES),precompute(x=8,g=p.BASE){return g._setWindowSize(x),g.multiply(BigInt(3)),g}}}}var To=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),Ua=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),Ip=BigInt(0),Rf=BigInt(1),Ta=BigInt(2),Cp=BigInt(3),Df=BigInt(5),Hf=BigInt(8);function Kf(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),s=BigInt(80),o=To,a=r*r%o*r%o,c=W(a,Ta,o)*a%o,f=W(c,Rf,o)*r%o,l=W(f,Df,o)*f%o,u=W(l,t,o)*l%o,h=W(u,e,o)*u%o,m=W(h,n,o)*h%o,w=W(m,s,o)*m%o,y=W(w,s,o)*m%o,d=W(y,t,o)*l%o;return{pow_p_5_8:W(d,Ta,o)*r%o,b2:a}}function Of(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function Vf(r,t){let e=To,n=G(t*t*t,e),s=G(n*n*t,e),o=Kf(r*s).pow_p_5_8,i=G(r*n*o,e),a=G(t*i*i,e),c=i,f=G(i*Ua,e),l=a===r,u=a===G(-r,e),h=a===G(-r*Ua,e);return l&&(i=c),(u||h)&&(i=f),va(i,e)&&(i=G(-i,e)),{isValid:l||u,value:i}}var La=Yt(To,void 0,!0),Pf={a:La.create(BigInt(-1)),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:La,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:Hf,Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:Bn,randomBytes:rr,adjustScalarBytes:Of,uvRatio:Vf},Lo=Na(Pf);var ir=32,Ht=64,Mf=32;function _a(r,t){let e=r.subarray(0,Mf);return Lo.sign(t instanceof Uint8Array?t:t.subarray(),e)}function Ra(r,t,e){return Lo.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}var Cn=class{type="Ed25519";raw;constructor(t){this.raw=Or(t,ir)}toMultihash(){return Be.digest(Qe(this))}toCID(){return Nt.createV1(114,this.toMultihash())}toString(){return Q.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:vt(this.raw,t.raw)}verify(t,e){return Ra(this.raw,e,t)}},Kr=class{type="Ed25519";raw;publicKey;constructor(t,e){this.raw=Or(t,Ht),this.publicKey=new Cn(e)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:vt(this.raw,t.raw)}sign(t){return _a(this.raw,t)}};function _o(r){if(r.length>Ht){r=Or(r,Ht+ir);let n=r.subarray(0,Ht),s=r.subarray(Ht,r.length);return new Kr(n,s)}r=Or(r,Ht);let t=r.subarray(0,Ht),e=r.subarray(ir);return new Kr(t,e)}function Or(r,t){if(r=Uint8Array.from(r??[]),r.length!==t)throw new _(`Key must be a Uint8Array of length ${t}, got ${r.length}`);return r}var Ff=Math.pow(2,7),qf=Math.pow(2,14),jf=Math.pow(2,21),Ha=Math.pow(2,28),Ka=Math.pow(2,35),Oa=Math.pow(2,42),Va=Math.pow(2,49),mt=128,ye=127;function Vr(r){if(r<Ff)return 1;if(r<qf)return 2;if(r<jf)return 3;if(r<Ha)return 4;if(r<Ka)return 5;if(r<Oa)return 6;if(r<Va)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function Pa(r,t,e=0){switch(Vr(r)){case 8:t[e++]=r&255|mt,r/=128;case 7:t[e++]=r&255|mt,r/=128;case 6:t[e++]=r&255|mt,r/=128;case 5:t[e++]=r&255|mt,r/=128;case 4:t[e++]=r&255|mt,r>>>=7;case 3:t[e++]=r&255|mt,r>>>=7;case 2:t[e++]=r&255|mt,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function Ma(r,t){let e=r[t],n=0;if(n+=e&ye,e<mt||(e=r[t+1],n+=(e&ye)<<7,e<mt)||(e=r[t+2],n+=(e&ye)<<14,e<mt)||(e=r[t+3],n+=(e&ye)<<21,e<mt)||(e=r[t+4],n+=(e&ye)*Ha,e<mt)||(e=r[t+5],n+=(e&ye)*Ka,e<mt)||(e=r[t+6],n+=(e&ye)*Oa,e<mt)||(e=r[t+7],n+=(e&ye)*Va,e<mt))return n;throw new RangeError("Could not decode varint")}var Ro=new Float32Array([-0]),me=new Uint8Array(Ro.buffer);function Fa(r,t,e){Ro[0]=r,t[e]=me[0],t[e+1]=me[1],t[e+2]=me[2],t[e+3]=me[3]}function qa(r,t){return me[0]=r[t],me[1]=r[t+1],me[2]=r[t+2],me[3]=r[t+3],Ro[0]}var Do=new Float64Array([-0]),ut=new Uint8Array(Do.buffer);function ja(r,t,e){Do[0]=r,t[e]=ut[0],t[e+1]=ut[1],t[e+2]=ut[2],t[e+3]=ut[3],t[e+4]=ut[4],t[e+5]=ut[5],t[e+6]=ut[6],t[e+7]=ut[7]}function $a(r,t){return ut[0]=r[t],ut[1]=r[t+1],ut[2]=r[t+2],ut[3]=r[t+3],ut[4]=r[t+4],ut[5]=r[t+5],ut[6]=r[t+6],ut[7]=r[t+7],Do[0]}var $f=BigInt(Number.MAX_SAFE_INTEGER),Gf=BigInt(Number.MIN_SAFE_INTEGER),Ct=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 De;if(t<$f&&t>Gf)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>Ga&&(s=0n,++n>Ga&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(t){if(t===0)return De;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):De}},De=new Ct(0,0);De.toBigInt=function(){return 0n};De.zzEncode=De.zzDecode=function(){return this};De.length=function(){return 1};var Ga=4294967296n;function za(r){let t=0,e=0;for(let n=0;n<r.length;++n)e=r.charCodeAt(n),e<128?t+=1:e<2048?t+=2:(e&64512)===55296&&(r.charCodeAt(n+1)&64512)===56320?(++n,t+=4):t+=3;return t}function Wa(r,t,e){if(e-t<1)return"";let 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 Ho(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 Kt(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function Nn(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var Ko=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,Kt(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 Kt(this,4);return Nn(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Kt(this,4);return Nn(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Kt(this,4);let t=qa(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Kt(this,4);let t=$a(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 Kt(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return Wa(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw Kt(this,t);this.pos+=t}else do if(this.pos>=this.len)throw Kt(this);while((this.buf[this.pos++]&128)!==0);return this}skipType(t){switch(t){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;(t=this.uint32()&7)!==4;)this.skipType(t);break;case 5:this.skip(4);break;default:throw Error(`invalid wire type ${t} at offset ${this.pos}`)}return this}readLongVarint(){let t=new Ct(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 Kt(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 Kt(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 Kt(this,8);let t=Nn(this.buf,this.pos+=4),e=Nn(this.buf,this.pos+=4);return new Ct(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=Ma(this.buf,this.pos);return this.pos+=Vr(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 Oo(r){return new Ko(r instanceof Uint8Array?r:r.subarray())}function Un(r,t,e){let n=Oo(r);return t.decode(n,void 0,e)}function Vo(r){let t=r??8192,e=t>>>1,n,s=t;return function(i){if(i<1||i>e)return kt(i);s+i>t&&(n=kt(t),s=0);let a=n.subarray(s,s+=i);return(s&7)!==0&&(s=(s|7)+1),a}}var He=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function Po(){}var Fo=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},zf=Vo();function Wf(r){return globalThis.Buffer!=null?kt(r):zf(r)}var Mr=class{len;head;tail;states;constructor(){this.len=0,this.head=new He(Po,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new He(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new qo((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(Tn,10,Ct.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=Ct.fromBigInt(t);return this._push(Tn,e.length(),e)}uint64Number(t){return this._push(Pa,Vr(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=Ct.fromBigInt(t).zzEncode();return this._push(Tn,e.length(),e)}sint64Number(t){let e=Ct.fromNumber(t).zzEncode();return this._push(Tn,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(Mo,1,t?1:0)}fixed32(t){return this._push(Pr,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=Ct.fromBigInt(t);return this._push(Pr,4,e.lo)._push(Pr,4,e.hi)}fixed64Number(t){let e=Ct.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(Fa,4,t)}double(t){return this._push(ja,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(Mo,1,0):this.uint32(e)._push(Jf,e,t)}string(t){let e=za(t);return e!==0?this.uint32(e)._push(Ho,e,t):this._push(Mo,1,0)}fork(){return this.states=new Fo(this),this.head=this.tail=new He(Po,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 He(Po,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=Wf(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function Mo(r,t,e){t[e]=r&255}function Zf(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var qo=class extends He{next;constructor(t,e){super(Zf,t,e),this.next=void 0}};function Tn(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 Jf(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(Yf,t,r),this},Mr.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(Xf,t,r),this});function Yf(r,t,e){t.set(r,e)}function Xf(r,t,e){r.length<40?Ho(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(O(r),e)}function jo(){return new Mr}function Ln(r,t){let e=jo();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var ar;(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"})(ar||(ar={}));function _n(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function $o(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 _n("enum",ar.VARINT,e,n)}function Rn(r,t){return _n("message",ar.LENGTH_DELIMITED,r,t)}var rt;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.secp256k1="secp256k1",r.ECDSA="ECDSA"})(rt||(rt={}));var Go;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1",r[r.ECDSA=3]="ECDSA"})(Go||(Go={}));(function(r){r.codec=()=>$o(Go)})(rt||(rt={}));var be;(function(r){let t;r.codec=()=>(t==null&&(t=Rn((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),rt.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let o={},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let a=e.uint32();switch(a>>>3){case 1:{o.Type=rt.codec().decode(e);break}case 2:{o.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return o})),t),r.encode=e=>Ln(e,r.codec()),r.decode=(e,n)=>Un(e,r.codec(),n)})(be||(be={}));var Fr;(function(r){let t;r.codec=()=>(t==null&&(t=Rn((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),rt.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let o={},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let a=e.uint32();switch(a>>>3){case 1:{o.Type=rt.codec().decode(e);break}case 2:{o.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return o})),t),r.encode=e=>Ln(e,r.codec()),r.decode=(e,n)=>Un(e,r.codec(),n)})(Fr||(Fr={}));function Ke(r){if(isNaN(r)||r<=0)throw new _("random bytes length must be a Number bigger than 0");return rr(r)}var jr={};ht(jr,{MAX_RSA_KEY_SIZE:()=>zo,generateRSAKeyPair:()=>tc,jwkToJWKKeyPair:()=>ec,jwkToPkcs1:()=>rh,jwkToPkix:()=>Yo,jwkToRSAPrivateKey:()=>ti,pkcs1MessageToJwk:()=>Zo,pkcs1MessageToRSAPrivateKey:()=>Dn,pkcs1ToJwk:()=>eh,pkcs1ToRSAPrivateKey:()=>Xo,pkixMessageToJwk:()=>Jo,pkixMessageToRSAPublicKey:()=>Qo,pkixToJwk:()=>nh,pkixToRSAPublicKey:()=>Qa});var cr=En;var lr=class{type="RSA";jwk;_raw;_multihash;constructor(t,e){this.jwk=t,this._multihash=e}get raw(){return this._raw==null&&(this._raw=jr.jwkToPkix(this.jwk)),this._raw}toMultihash(){return this._multihash}toCID(){return Nt.createV1(114,this._multihash)}toString(){return Q.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:vt(this.raw,t.raw)}verify(t,e){return Xa(this.jwk,e,t)}},qr=class{type="RSA";jwk;_raw;publicKey;constructor(t,e){this.jwk=t,this.publicKey=e}get raw(){return this._raw==null&&(this._raw=jr.jwkToPkcs1(this.jwk)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:vt(this.raw,t.raw)}sign(t){return Ya(this.jwk,t)}};var zo=8192,Wo=18,Qf=1062,th=Uint8Array.from([48,13,6,9,42,134,72,134,247,13,1,1,1,5,0]);function eh(r){let t=_t(r);return Zo(t)}function Zo(r){return{n:q(r[1],"base64url"),e:q(r[2],"base64url"),d:q(r[3],"base64url"),p:q(r[4],"base64url"),q:q(r[5],"base64url"),dp:q(r[6],"base64url"),dq:q(r[7],"base64url"),qi:q(r[8],"base64url"),kty:"RSA"}}function rh(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");return Rt([pt(Uint8Array.from([0])),pt(O(r.n,"base64url")),pt(O(r.e,"base64url")),pt(O(r.d,"base64url")),pt(O(r.p,"base64url")),pt(O(r.q,"base64url")),pt(O(r.dp,"base64url")),pt(O(r.dq,"base64url")),pt(O(r.qi,"base64url"))]).subarray()}function nh(r){let t=_t(r,{offset:0});return Jo(t)}function Jo(r){let t=_t(r[1],{offset:0});return{kty:"RSA",n:q(t[0],"base64url"),e:q(t[1],"base64url")}}function Yo(r){if(r.n==null||r.e==null)throw new _("JWK was missing components");return Rt([th,Nr(Rt([pt(O(r.n,"base64url")),pt(O(r.e,"base64url"))]))]).subarray()}function Xo(r){let t=_t(r);return Dn(t)}function Dn(r){let t=Zo(r);return ti(t)}function Qa(r,t){if(r.byteLength>=Qf)throw new qe("Key size is too large");let e=_t(r,{offset:0});return Qo(e,r,t)}function Qo(r,t,e){let n=Jo(r);if(e==null){let s=cr(be.encode({Type:rt.RSA,Data:t}));e=Lt(Wo,s)}return new lr(n,e)}function ti(r){if(nc(r)>zo)throw new _("Key size is too large");let t=ec(r),e=cr(be.encode({Type:rt.RSA,Data:Yo(t.publicKey)})),n=Lt(Wo,e);return new qr(t.privateKey,new lr(t.publicKey,n))}async function tc(r){if(r>zo)throw new _("Key size is too large");let t=await rc(r),e=cr(be.encode({Type:rt.RSA,Data:Yo(t.publicKey)})),n=Lt(Wo,e);return new qr(t.privateKey,new lr(t.publicKey,n))}function ec(r){if(r==null)throw new _("Missing key parameter");return{privateKey:r,publicKey:{kty:r.kty,n:r.n,e:r.e}}}async function rc(r){let t=await xt.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 sh(t);return{privateKey:e[0],publicKey:e[1]}}async function Ya(r,t){let e=await xt.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await xt.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},e,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(n,0,n.byteLength)}async function Xa(r,t,e){let n=await xt.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return xt.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,t,e instanceof Uint8Array?e:e.subarray())}async function sh(r){if(r.privateKey==null||r.publicKey==null)throw new _("Private and public key are required");return Promise.all([xt.get().subtle.exportKey("jwk",r.privateKey),xt.get().subtle.exportKey("jwk",r.publicKey)])}function nc(r){if(r.kty!=="RSA")throw new _("invalid key type");if(r.n==null)throw new _("invalid key modulus");return O(r.n,"base64url").length*8}var Hn=class extends tr{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,gn(t);let n=Ur(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),Et(o)}update(t){return er(this),this.iHash.update(t),this}digestInto(t){er(this),ue(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}clone(){return this._cloneInto()}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},$r=(r,t,e)=>new Hn(r,t).update(e).digest();$r.create=(r,t)=>new Hn(r,t);function sc(r){r.lowS!==void 0&&Mt("lowS",r.lowS),r.prehash!==void 0&&Mt("prehash",r.prehash)}function oh(r){let t=Hr(r);Jt(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("invalid endomorphism, can only be defined for Koblitz curves that have a=0");if(typeof e!="object"||typeof e.beta!="bigint"||typeof e.splitScalar!="function")throw new Error("invalid endomorphism, expected beta: bigint and splitScalar: function")}return Object.freeze({...t})}var ei=class extends Error{constructor(t=""){super(t)}},Xt={Err:ei,_tlv:{encode:(r,t)=>{let{Err:e}=Xt;if(r<0||r>256)throw new e("tlv.encode: wrong tag");if(t.length&1)throw new e("tlv.encode: unpadded data");let n=t.length/2,s=Rr(n);if(s.length/2&128)throw new e("tlv.encode: long form length too big");let o=n>127?Rr(s.length/2|128):"";return Rr(r)+o+s+t},decode(r,t){let{Err:e}=Xt,n=0;if(r<0||r>256)throw new e("tlv.encode: wrong tag");if(t.length<2||t[n++]!==r)throw new e("tlv.decode: wrong tlv");let s=t[n++],o=!!(s&128),i=0;if(!o)i=s;else{let c=s&127;if(!c)throw new e("tlv.decode(long): indefinite length not supported");if(c>4)throw new e("tlv.decode(long): byte length is too big");let f=t.subarray(n,n+c);if(f.length!==c)throw new e("tlv.decode: length bytes not complete");if(f[0]===0)throw new e("tlv.decode(long): zero leftmost byte");for(let l of f)i=i<<8|l;if(n+=c,i<128)throw new e("tlv.decode(long): not minimal encoding")}let a=t.subarray(n,n+i);if(a.length!==i)throw new e("tlv.decode: wrong value length");return{v:a,l:t.subarray(n+i)}}},_int:{encode(r){let{Err:t}=Xt;if(r<Qt)throw new t("integer: negative integers are not allowed");let e=Rr(r);if(Number.parseInt(e[0],16)&8&&(e="00"+e),e.length&1)throw new t("unexpected DER parsing assertion: unpadded hex");return e},decode(r){let{Err:t}=Xt;if(r[0]&128)throw new t("invalid signature integer: negative");if(r[0]===0&&!(r[1]&128))throw new t("invalid signature integer: unnecessary leading zero");return Zt(r)}},toSig(r){let{Err:t,_int:e,_tlv:n}=Xt,s=Z("signature",r),{v:o,l:i}=n.decode(48,s);if(i.length)throw new t("invalid signature: left bytes after parsing");let{v:a,l:c}=n.decode(2,o),{v:f,l}=n.decode(2,c);if(l.length)throw new t("invalid signature: left bytes after parsing");return{r:e.decode(a),s:e.decode(f)}},hexFromSig(r){let{_tlv:t,_int:e}=Xt,n=t.encode(2,e.encode(r.r)),s=t.encode(2,e.encode(r.s)),o=n+s;return t.encode(48,o)}},Qt=BigInt(0),st=BigInt(1),ty=BigInt(2),oc=BigInt(3),ey=BigInt(4);function ih(r){let t=oh(r),{Fp:e}=t,n=Yt(t.n,t.nBitLength),s=t.toBytes||((y,d,b)=>{let E=d.toAffine();return ge(Uint8Array.from([4]),e.toBytes(E.x),e.toBytes(E.y))}),o=t.fromBytes||(y=>{let d=y.subarray(1),b=e.fromBytes(d.subarray(0,e.BYTES)),E=e.fromBytes(d.subarray(e.BYTES,2*e.BYTES));return{x:b,y:E}});function i(y){let{a:d,b}=t,E=e.sqr(y),p=e.mul(E,y);return e.add(e.add(p,e.mul(y,d)),b)}if(!e.eql(e.sqr(t.Gy),i(t.Gx)))throw new Error("bad generator point: equation left != right");function a(y){return An(y,st,t.n)}function c(y){let{allowedPrivateKeyLengths:d,nByteLength:b,wrapPrivateKey:E,n:p}=t;if(d&&typeof y!="bigint"){if(Ue(y)&&(y=pe(y)),typeof y!="string"||!d.includes(y.length))throw new Error("invalid private key");y=y.padStart(b*2,"0")}let S;try{S=typeof y=="bigint"?y:Zt(Z("private key",y,b))}catch{throw new Error("invalid private key, expected hex or "+b+" bytes, got "+typeof y)}return E&&(S=G(S,p)),It("private key",S,st,p),S}function f(y){if(!(y instanceof h))throw new Error("ProjectivePoint expected")}let l=sr((y,d)=>{let{px:b,py:E,pz:p}=y;if(e.eql(p,e.ONE))return{x:b,y:E};let S=y.is0();d==null&&(d=S?e.ONE:e.inv(p));let R=e.mul(b,d),L=e.mul(E,d),C=e.mul(p,d);if(S)return{x:e.ZERO,y:e.ZERO};if(!e.eql(C,e.ONE))throw new Error("invZ was invalid");return{x:R,y:L}}),u=sr(y=>{if(y.is0()){if(t.allowInfinityPoint&&!e.is0(y.py))return;throw new Error("bad point: ZERO")}let{x:d,y:b}=y.toAffine();if(!e.isValid(d)||!e.isValid(b))throw new Error("bad point: x or y not FE");let E=e.sqr(b),p=i(d);if(!e.eql(E,p))throw new Error("bad point: equation left != right");if(!y.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});class h{constructor(d,b,E){if(d==null||!e.isValid(d))throw new Error("x required");if(b==null||!e.isValid(b)||e.is0(b))throw new Error("y required");if(E==null||!e.isValid(E))throw new Error("z required");this.px=d,this.py=b,this.pz=E,Object.freeze(this)}static fromAffine(d){let{x:b,y:E}=d||{};if(!d||!e.isValid(b)||!e.isValid(E))throw new Error("invalid affine point");if(d instanceof h)throw new Error("projective point not allowed");let p=S=>e.eql(S,e.ZERO);return p(b)&&p(E)?h.ZERO:new h(b,E,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(d){let b=or(e,d.map(E=>E.pz));return d.map((E,p)=>E.toAffine(b[p])).map(h.fromAffine)}static fromHex(d){let b=h.fromAffine(o(Z("pointHex",d)));return b.assertValidity(),b}static fromPrivateKey(d){return h.BASE.multiply(c(d))}static msm(d,b){return In(h,n,d,b)}_setWindowSize(d){w.setWindowSize(this,d)}assertValidity(){u(this)}hasEvenY(){let{y:d}=this.toAffine();if(e.isOdd)return!e.isOdd(d);throw new Error("Field doesn't support isOdd")}equals(d){f(d);let{px:b,py:E,pz:p}=this,{px:S,py:R,pz:L}=d,C=e.eql(e.mul(b,L),e.mul(S,p)),N=e.eql(e.mul(E,L),e.mul(R,p));return C&&N}negate(){return new h(this.px,e.neg(this.py),this.pz)}double(){let{a:d,b}=t,E=e.mul(b,oc),{px:p,py:S,pz:R}=this,L=e.ZERO,C=e.ZERO,N=e.ZERO,U=e.mul(p,p),z=e.mul(S,S),j=e.mul(R,R),K=e.mul(p,S);return K=e.add(K,K),N=e.mul(p,R),N=e.add(N,N),L=e.mul(d,N),C=e.mul(E,j),C=e.add(L,C),L=e.sub(z,C),C=e.add(z,C),C=e.mul(L,C),L=e.mul(K,L),N=e.mul(E,N),j=e.mul(d,j),K=e.sub(U,j),K=e.mul(d,K),K=e.add(K,N),N=e.add(U,U),U=e.add(N,U),U=e.add(U,j),U=e.mul(U,K),C=e.add(C,U),j=e.mul(S,R),j=e.add(j,j),U=e.mul(j,K),L=e.sub(L,U),N=e.mul(j,z),N=e.add(N,N),N=e.add(N,N),new h(L,C,N)}add(d){f(d);let{px:b,py:E,pz:p}=this,{px:S,py:R,pz:L}=d,C=e.ZERO,N=e.ZERO,U=e.ZERO,z=t.a,j=e.mul(t.b,oc),K=e.mul(b,S),tt=e.mul(E,R),B=e.mul(p,L),I=e.add(b,E),T=e.add(S,R);I=e.mul(I,T),T=e.add(K,tt),I=e.sub(I,T),T=e.add(b,p);let x=e.add(S,L);return T=e.mul(T,x),x=e.add(K,B),T=e.sub(T,x),x=e.add(E,p),C=e.add(R,L),x=e.mul(x,C),C=e.add(tt,B),x=e.sub(x,C),U=e.mul(z,T),C=e.mul(j,B),U=e.add(C,U),C=e.sub(tt,U),U=e.add(tt,U),N=e.mul(C,U),tt=e.add(K,K),tt=e.add(tt,K),B=e.mul(z,B),T=e.mul(j,T),tt=e.add(tt,B),B=e.sub(K,B),B=e.mul(z,B),T=e.add(T,B),K=e.mul(tt,T),N=e.add(N,K),K=e.mul(x,T),C=e.mul(I,C),C=e.sub(C,K),K=e.mul(I,tt),U=e.mul(x,U),U=e.add(U,K),new h(C,N,U)}subtract(d){return this.add(d.negate())}is0(){return this.equals(h.ZERO)}wNAF(d){return w.wNAFCached(this,d,h.normalizeZ)}multiplyUnsafe(d){let{endo:b,n:E}=t;It("scalar",d,Qt,E);let p=h.ZERO;if(d===Qt)return p;if(this.is0()||d===st)return this;if(!b||w.hasPrecomputes(this))return w.wNAFCachedUnsafe(this,d,h.normalizeZ);let{k1neg:S,k1:R,k2neg:L,k2:C}=b.splitScalar(d),N=p,U=p,z=this;for(;R>Qt||C>Qt;)R&st&&(N=N.add(z)),C&st&&(U=U.add(z)),z=z.double(),R>>=st,C>>=st;return S&&(N=N.negate()),L&&(U=U.negate()),U=new h(e.mul(U.px,b.beta),U.py,U.pz),N.add(U)}multiply(d){let{endo:b,n:E}=t;It("scalar",d,st,E);let p,S;if(b){let{k1neg:R,k1:L,k2neg:C,k2:N}=b.splitScalar(d),{p:U,f:z}=this.wNAF(L),{p:j,f:K}=this.wNAF(N);U=w.constTimeNegate(R,U),j=w.constTimeNegate(C,j),j=new h(e.mul(j.px,b.beta),j.py,j.pz),p=U.add(j),S=z.add(K)}else{let{p:R,f:L}=this.wNAF(d);p=R,S=L}return h.normalizeZ([p,S])[0]}multiplyAndAddUnsafe(d,b,E){let p=h.BASE,S=(L,C)=>C===Qt||C===st||!L.equals(p)?L.multiplyUnsafe(C):L.multiply(C),R=S(this,b).add(S(d,E));return R.is0()?void 0:R}toAffine(d){return l(this,d)}isTorsionFree(){let{h:d,isTorsionFree:b}=t;if(d===st)return!0;if(b)return b(h,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h:d,clearCofactor:b}=t;return d===st?this:b?b(h,this):this.multiplyUnsafe(t.h)}toRawBytes(d=!0){return Mt("isCompressed",d),this.assertValidity(),s(h,this,d)}toHex(d=!0){return Mt("isCompressed",d),pe(this.toRawBytes(d))}}h.BASE=new h(t.Gx,t.Gy,e.ONE),h.ZERO=new h(e.ZERO,e.ONE,e.ZERO);let m=t.nBitLength,w=kn(h,t.endo?Math.ceil(m/2):m);return{CURVE:t,ProjectivePoint:h,normPrivateKeyToScalar:c,weierstrassEquation:i,isWithinCurveOrder:a}}function ah(r){let t=Hr(r);return Jt(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function ic(r){let t=ah(r),{Fp:e,n}=t,s=e.BYTES+1,o=2*e.BYTES+1;function i(B){return G(B,n)}function a(B){return Sn(B,n)}let{ProjectivePoint:c,normPrivateKeyToScalar:f,weierstrassEquation:l,isWithinCurveOrder:u}=ih({...t,toBytes(B,I,T){let x=I.toAffine(),g=e.toBytes(x.x),v=ge;return Mt("isCompressed",T),T?v(Uint8Array.from([I.hasEvenY()?2:3]),g):v(Uint8Array.from([4]),g,e.toBytes(x.y))},fromBytes(B){let I=B.length,T=B[0],x=B.subarray(1);if(I===s&&(T===2||T===3)){let g=Zt(x);if(!An(g,st,e.ORDER))throw new Error("Point is not on curve");let v=l(g),k;try{k=e.sqrt(v)}catch(V){let M=V instanceof Error?": "+V.message:"";throw new Error("Point is not on curve"+M)}let D=(k&st)===st;return(T&1)===1!==D&&(k=e.neg(k)),{x:g,y:k}}else if(I===o&&T===4){let g=e.fromBytes(x.subarray(0,e.BYTES)),v=e.fromBytes(x.subarray(e.BYTES,2*e.BYTES));return{x:g,y:v}}else{let g=s,v=o;throw new Error("invalid Point, expected length of "+g+", or uncompressed "+v+", got "+I)}}}),h=B=>pe(Le(B,t.nByteLength));function m(B){let I=n>>st;return B>I}function w(B){return m(B)?i(-B):B}let y=(B,I,T)=>Zt(B.slice(I,T));class d{constructor(I,T,x){It("r",I,st,n),It("s",T,st,n),this.r=I,this.s=T,x!=null&&(this.recovery=x),Object.freeze(this)}static fromCompact(I){let T=t.nByteLength;return I=Z("compactSignature",I,T*2),new d(y(I,0,T),y(I,T,2*T))}static fromDER(I){let{r:T,s:x}=Xt.toSig(Z("DER",I));return new d(T,x)}assertValidity(){}addRecoveryBit(I){return new d(this.r,this.s,I)}recoverPublicKey(I){let{r:T,s:x,recovery:g}=this,v=L(Z("msgHash",I));if(g==null||![0,1,2,3].includes(g))throw new Error("recovery id invalid");let k=g===2||g===3?T+t.n:T;if(k>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let D=(g&1)===0?"02":"03",H=c.fromHex(D+h(k)),V=a(k),M=i(-v*V),F=i(x*V),$=c.BASE.multiplyAndAddUnsafe(H,M,F);if(!$)throw new Error("point at infinify");return $.assertValidity(),$}hasHighS(){return m(this.s)}normalizeS(){return this.hasHighS()?new d(this.r,i(-this.s),this.recovery):this}toDERRawBytes(){return Dr(this.toDERHex())}toDERHex(){return Xt.hexFromSig(this)}toCompactRawBytes(){return Dr(this.toCompactHex())}toCompactHex(){return h(this.r)+h(this.s)}}let b={isValidPrivateKey(B){try{return f(B),!0}catch{return!1}},normPrivateKeyToScalar:f,randomPrivateKey:()=>{let B=So(t.n);return Ba(t.randomBytes(B),t.n)},precompute(B=8,I=c.BASE){return I._setWindowSize(B),I.multiply(BigInt(3)),I}};function E(B,I=!0){return c.fromPrivateKey(B).toRawBytes(I)}function p(B){let I=Ue(B),T=typeof B=="string",x=(I||T)&&B.length;return I?x===s||x===o:T?x===2*s||x===2*o:B instanceof c}function S(B,I,T=!0){if(p(B))throw new Error("first arg must be private key");if(!p(I))throw new Error("second arg must be public key");return c.fromHex(I).multiply(f(B)).toRawBytes(T)}let R=t.bits2int||function(B){if(B.length>8192)throw new Error("input is too large");let I=Zt(B),T=B.length*8-t.nBitLength;return T>0?I>>BigInt(T):I},L=t.bits2int_modN||function(B){return i(R(B))},C=_e(t.nBitLength);function N(B){return It("num < 2^"+t.nBitLength,B,Qt,C),Le(B,t.nByteLength)}function U(B,I,T=z){if(["recovered","canonical"].some(Y=>Y in T))throw new Error("sign() legacy options not supported");let{hash:x,randomBytes:g}=t,{lowS:v,prehash:k,extraEntropy:D}=T;v==null&&(v=!0),B=Z("msgHash",B),sc(T),k&&(B=Z("prehashed msgHash",x(B)));let H=L(B),V=f(I),M=[N(V),N(H)];if(D!=null&&D!==!1){let Y=D===!0?g(e.BYTES):D;M.push(Z("extraEntropy",Y))}let F=ge(...M),$=H;function X(Y){let ot=R(Y);if(!u(ot))return;let wt=a(ot),nt=c.BASE.multiply(ot).toAffine(),lt=i(nt.x);if(lt===Qt)return;let St=i(wt*i($+lt*V));if(St===Qt)return;let Tt=(nt.x===lt?0:2)|Number(nt.y&st),br=St;return v&&m(St)&&(br=w(St),Tt^=1),new d(lt,br,Tt)}return{seed:F,k2sig:X}}let z={lowS:t.lowS,prehash:!1},j={lowS:t.lowS,prehash:!1};function K(B,I,T=z){let{seed:x,k2sig:g}=U(B,I,T),v=t;return ma(v.hash.outputLen,v.nByteLength,v.hmac)(x,g)}c.BASE._setWindowSize(8);function tt(B,I,T,x=j){let g=B;I=Z("msgHash",I),T=Z("publicKey",T);let{lowS:v,prehash:k,format:D}=x;if(sc(x),"strict"in x)throw new Error("options.strict was renamed to lowS");if(D!==void 0&&D!=="compact"&&D!=="der")throw new Error("format must be compact or der");let H=typeof g=="string"||Ue(g),V=!H&&!D&&typeof g=="object"&&g!==null&&typeof g.r=="bigint"&&typeof g.s=="bigint";if(!H&&!V)throw new Error("invalid signature, expected Uint8Array, hex string or Signature instance");let M,F;try{if(V&&(M=new d(g.r,g.s)),H){try{D!=="compact"&&(M=d.fromDER(g))}catch(Tt){if(!(Tt instanceof Xt.Err))throw Tt}!M&&D!=="der"&&(M=d.fromCompact(g))}F=c.fromHex(T)}catch{return!1}if(!M||v&&M.hasHighS())return!1;k&&(I=t.hash(I));let{r:$,s:X}=M,Y=L(I),ot=a(X),wt=i(Y*ot),nt=i($*ot),lt=c.BASE.multiplyAndAddUnsafe(F,wt,nt)?.toAffine();return lt?i(lt.x)===$:!1}return{CURVE:t,getPublicKey:E,getSharedSecret:S,sign:K,verify:tt,ProjectivePoint:c,Signature:d,utils:b}}function ch(r){return{hash:r,hmac:(t,...e)=>$r(r,t,po(...e)),randomBytes:rr}}function ac(r,t){let e=n=>ic({...r,...ch(n)});return{...e(t),create:e}}var uc=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),cc=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),lh=BigInt(1),ri=BigInt(2),lc=(r,t)=>(r+t/ri)/t;function uh(r){let t=uc,e=BigInt(3),n=BigInt(6),s=BigInt(11),o=BigInt(22),i=BigInt(23),a=BigInt(44),c=BigInt(88),f=r*r*r%t,l=f*f*r%t,u=W(l,e,t)*l%t,h=W(u,e,t)*l%t,m=W(h,ri,t)*f%t,w=W(m,s,t)*m%t,y=W(w,o,t)*w%t,d=W(y,a,t)*y%t,b=W(d,c,t)*d%t,E=W(b,a,t)*y%t,p=W(E,e,t)*l%t,S=W(p,i,t)*w%t,R=W(S,n,t)*f%t,L=W(R,ri,t);if(!ni.eql(ni.sqr(L),r))throw new Error("Cannot find square root");return L}var ni=Yt(uc,void 0,void 0,{sqrt:uh}),Ot=ac({a:BigInt(0),b:BigInt(7),Fp:ni,n:cc,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=cc,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-lh*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),s=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),o=e,i=BigInt("0x100000000000000000000000000000000"),a=lc(o*r,t),c=lc(-n*r,t),f=G(r-a*e-c*s,t),l=G(-a*n-c*o,t),u=f>i,h=l>i;if(u&&(f=t-f),h&&(l=t-l),f>i||l>i)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:u,k1:f,k2neg:h,k2:l}}}},En),uy=BigInt(0);var fy=Ot.ProjectivePoint;function si(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}var fc=32;function hc(r,t){let e=Ye.digest(t instanceof Uint8Array?t:t.subarray());if(si(e))return e.then(({digest:n})=>Ot.sign(n,r).toDERRawBytes()).catch(n=>{throw new wr(String(n))});try{return Ot.sign(e.digest,r).toDERRawBytes()}catch(n){throw new wr(String(n))}}function dc(r,t,e){let n=Ye.digest(e instanceof Uint8Array?e:e.subarray());if(si(n))return n.then(({digest:s})=>Ot.verify(t,s,r)).catch(s=>{throw new xr(String(s))});try{return Ot.verify(t,n.digest,r)}catch(s){throw new xr(String(s))}}var Kn=class{type="secp256k1";raw;_key;constructor(t){this._key=yc(t),this.raw=pc(this._key)}toMultihash(){return Be.digest(Qe(this))}toCID(){return Nt.createV1(114,this.toMultihash())}toString(){return Q.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:vt(this.raw,t.raw)}verify(t,e){return dc(this._key,e,t)}},On=class{type="secp256k1";raw;publicKey;constructor(t,e){this.raw=gc(t),this.publicKey=new Kn(e??mc(t))}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:vt(this.raw,t.raw)}sign(t){return hc(this.raw,t)}};function oi(r){return new On(r)}function pc(r){return Ot.ProjectivePoint.fromHex(r).toRawBytes(!0)}function gc(r){try{return Ot.getPublicKey(r,!0),r}catch(t){throw new vr(String(t))}}function yc(r){try{return Ot.ProjectivePoint.fromHex(r),r}catch(t){throw new qe(String(t))}}function mc(r){try{return Ot.getPublicKey(r,!0)}catch(t){throw new vr(String(t))}}function Qe(r){return be.encode({Type:rt[r.type],Data:r.raw})}function bc(r){let t=Fr.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case rt.RSA:return Xo(e);case rt.Ed25519:return _o(e);case rt.secp256k1:return oi(e);case rt.ECDSA:return Ji(e);default:throw new je}}function wc(r){if(r.byteLength===Ht)return _o(r);if(r.byteLength===fc)return oi(r);let t=_t(r),e=t[2]?.[0];if(e===$i||e===Gi||e===zi)return uo(t);if(t.length>8)return Dn(t);throw new _("Could not extract private key from raw bytes")}function Oe(r){return Fr.encode({Type:rt[r.type],Data:r.raw})}function xc(r,t,e,n){gn(r);let s=ra({dkLen:32,asyncTick:10},n),{c:o,dkLen:i,asyncTick:a}=s;if(le(o),le(i),le(a),o<1)throw new Error("iterations (c) should be >= 1");let c=ho(t),f=ho(e),l=new Uint8Array(i),u=$r.create(r,c),h=u._cloneInto().update(f);return{c:o,dkLen:i,asyncTick:a,DK:l,PRF:u,PRFSalt:h}}function vc(r,t,e,n,s){return r.destroy(),t.destroy(),n&&n.destroy(),Et(s),e}function Ec(r,t,e,n){let{c:s,dkLen:o,DK:i,PRF:a,PRFSalt:c}=xc(r,t,e,n),f,l=new Uint8Array(4),u=ke(l),h=new Uint8Array(a.outputLen);for(let m=1,w=0;w<o;m++,w+=a.outputLen){let y=i.subarray(w,w+a.outputLen);u.setInt32(0,m,!1),(f=c._cloneInto(f)).update(l).digestInto(h),y.set(h.subarray(0,y.length));for(let d=1;d<s;d++){a._cloneInto(f).update(h).digestInto(h);for(let b=0;b<y.length;b++)y[b]^=h[b]}}return vc(a,c,i,f,h)}async function Vn(r,t,e,n){let{c:s,dkLen:o,asyncTick:i,DK:a,PRF:c,PRFSalt:f}=xc(r,t,e,n),l,u=new Uint8Array(4),h=ke(u),m=new Uint8Array(c.outputLen);for(let w=1,y=0;y<o;w++,y+=c.outputLen){let d=a.subarray(y,y+c.outputLen);h.setInt32(0,w,!1),(l=f._cloneInto(l)).update(u).digestInto(m),d.set(m.subarray(0,d.length)),await ea(s-1,i,()=>{c._cloneInto(l).update(m).digestInto(m);for(let b=0;b<d.length;b++)d[b]^=m[b]})}return vc(c,f,a,l,m)}var Gr=Uint32Array.from([1732584193,4023233417,2562383102,271733878,3285377520]),we=new Uint32Array(80),Pn=class extends Ie{constructor(){super(64,20,8,!1),this.A=Gr[0]|0,this.B=Gr[1]|0,this.C=Gr[2]|0,this.D=Gr[3]|0,this.E=Gr[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)we[c]=t.getUint32(e,!1);for(let c=16;c<80;c++)we[c]=yn(we[c-3]^we[c-8]^we[c-14]^we[c-16],1);let{A:n,B:s,C:o,D:i,E:a}=this;for(let c=0;c<80;c++){let f,l;c<20?(f=mn(s,o,i),l=1518500249):c<40?(f=s^o^i,l=1859775393):c<60?(f=bn(s,o,i),l=2400959708):(f=s^o^i,l=3395469782);let u=yn(n,5)+f+a+l+we[c]|0;a=i,i=o,o=yn(s,30),s=n,n=u}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(){Et(we)}destroy(){this.set(0,0,0,0,0),Et(this.buffer)}},Bc=Tr(()=>new Pn);var Ac=Bc;var ur=Bn;var Sc={sha1:Ac,"sha2-256":cr,"sha2-512":ur};function zr(r,t,e,n,s){if(s!=="sha1"&&s!=="sha2-256"&&s!=="sha2-512"){let a=Object.keys(Sc).join(" / ");throw new _(`Hash '${s}' is unknown or not supported. Must be ${a}`)}let o=Sc[s],i=Ec(o,r,t,{c:e,dkLen:n});return Ae.encode(i).substring(1)}var te="/",kc=new TextEncoder().encode(te),Mn=kc[0],Wr=class r{_buf;constructor(t,e){if(typeof t=="string")this._buf=O(t);else if(t instanceof Uint8Array)this._buf=t;else throw new Error("Invalid key, should be String of Uint8Array");if(e==null&&(e=!0),e&&this.clean(),this._buf.byteLength===0||this._buf[0]!==Mn)throw new Error("Invalid key")}toString(t="utf8"){return q(this._buf,t)}uint8Array(){return this._buf}get[Symbol.toStringTag](){return`Key(${this.toString()})`}static withNamespaces(t){return new r(t.join(te))}static random(){return new r(Math.random().toString().substring(2))}static asKey(t){return t instanceof Uint8Array||typeof t=="string"?new r(t):typeof t.uint8Array=="function"?new r(t.uint8Array()):null}clean(){if((this._buf==null||this._buf.byteLength===0)&&(this._buf=kc),this._buf[0]!==Mn){let t=new Uint8Array(this._buf.byteLength+1);t.fill(Mn,0,1),t.set(this._buf,1),this._buf=t}for(;this._buf.byteLength>1&&this._buf[this._buf.byteLength-1]===Mn;)this._buf=this._buf.subarray(0,-1)}less(t){let e=this.list(),n=t.list();for(let s=0;s<e.length;s++){if(n.length<s+1)return!1;let o=e[s],i=n[s];if(o<i)return!0;if(o>i)return!1}return e.length<n.length}reverse(){return r.withNamespaces(this.list().slice().reverse())}namespaces(){return this.list()}baseNamespace(){let t=this.namespaces();return t[t.length-1]}list(){return this.toString().split(te).slice(1)}type(){return fh(this.baseNamespace())}name(){return hh(this.baseNamespace())}instance(t){return new r(this.toString()+":"+t)}path(){let t=this.parent().toString();return t.endsWith(te)||(t+=te),t+=this.type(),new r(t)}parent(){let t=this.list();return t.length===1?new r(te):new r(t.slice(0,-1).join(te))}child(t){return this.toString()===te?t:t.toString()===te?this:new r(this.toString()+t.toString(),!1)}isAncestorOf(t){return t.toString()===this.toString()?!1:t.toString().startsWith(this.toString())}isDecendantOf(t){return t.toString()===this.toString()?!1:this.toString().startsWith(t.toString())}isTopLevel(){return this.list().length===1}concat(...t){return r.withNamespaces([...this.namespaces(),...dh(t.map(e=>e.namespaces()))])}};function fh(r){let t=r.split(":");return t.length<2?"":t.slice(0,-1).join(":")}function hh(r){let t=r.split(":");return t[t.length-1]}function dh(r){return[].concat(...r)}var Dc=Ks(Rc(),1),Hc=Dc.default;var Dl=Ks($c(),1);var dr={};ht(dr,{create:()=>Th,derivedEmptyPasswordKey:()=>jn});var jn={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function Th(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=xt.get();e*=8;async function c(u,h){let m=a.getRandomValues(new Uint8Array(o)),w=a.getRandomValues(new Uint8Array(n)),y={name:t,iv:w};typeof h=="string"&&(h=O(h));let d;if(h.length===0){d=await a.subtle.importKey("jwk",jn,{name:"AES-GCM"},!0,["encrypt"]);try{let E={name:"PBKDF2",salt:m,iterations:i,hash:{name:s}},p=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);d=await a.subtle.deriveKey(E,p,{name:t,length:e},!0,["encrypt"])}catch{d=await a.subtle.importKey("jwk",jn,{name:"AES-GCM"},!0,["encrypt"])}}else{let E={name:"PBKDF2",salt:m,iterations:i,hash:{name:s}},p=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);d=await a.subtle.deriveKey(E,p,{name:t,length:e},!0,["encrypt"])}let b=await a.subtle.encrypt(y,d,u);return Je([m,y.iv,new Uint8Array(b)])}async function f(u,h){let m=u.subarray(0,o),w=u.subarray(o,o+n),y=u.subarray(o+n),d={name:t,iv:w};typeof h=="string"&&(h=O(h));let b;if(h.length===0)try{let p={name:"PBKDF2",salt:m,iterations:i,hash:{name:s}},S=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);b=await a.subtle.deriveKey(p,S,{name:t,length:e},!0,["decrypt"])}catch{b=await a.subtle.importKey("jwk",jn,{name:"AES-GCM"},!0,["decrypt"])}else{let p={name:"PBKDF2",salt:m,iterations:i,hash:{name:s}},S=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);b=await a.subtle.deriveKey(p,S,{name:t,length:e},!0,["decrypt"])}let E=await a.subtle.decrypt(d,b,y);return new Uint8Array(E)}return{encrypt:c,decrypt:f}}var P=Ks(Gc());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 xe(r,t,e=-1){let n=e,s=r,o=0,i=Math.pow(2,t);for(let a=1;a<8;a++){if(r<i){let c;if(n<0)c=new ArrayBuffer(a),o=a;else{if(n<a)return new ArrayBuffer(0);c=new ArrayBuffer(n),o=n}let f=new Uint8Array(c);for(let l=a-1;l>=0;l--){let u=Math.pow(2,l*t);f[o-l-1]=Math.floor(s/u),s-=f[o-l-1]*u}return c}i*=Math.pow(2,t)}return new ArrayBuffer(0)}function zn(...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 ci(){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 zc(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=xe(i,8,n),c=new Uint8Array(a);return c[0]|=128,a}let s=xe(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 Wc(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 Bt(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 Vm=Math.log(2);function Wn(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function li(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 ie(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 Yr=class{constructor(){this.items=[]}write(t){this.items.push(t)}final(){return li(this.items)}},Zr=[new Uint8Array([1])],Zc="0123456789";var gr="",Vt=new ArrayBuffer(0),ui=new Uint8Array(0),Xr="EndOfContent",Yc="OCTET STRING",Xc="BIT STRING";function ae(r){var t;return t=class extends r{get valueHex(){return this.valueHexView.slice().buffer}set valueHex(n){this.valueHexView=new Uint8Array(n)}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):ui}fromBER(n,s,o){let i=n instanceof ArrayBuffer?new Uint8Array(n):n;if(!ie(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",Vt)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:P.Convert.ToHex(this.valueHexView)}}},t.NAME="hexBlock",t}var re=class{static blockName(){return this.NAME}get valueBeforeDecode(){return this.valueBeforeDecodeView.slice().buffer}set valueBeforeDecode(t){this.valueBeforeDecodeView=new Uint8Array(t)}constructor({blockLength:t=0,error:e=gr,warnings:n=[],valueBeforeDecode:s=ui}={}){this.blockLength=t,this.error=e,this.warnings=n,this.valueBeforeDecodeView=P.BufferSourceConverter.toUint8Array(s)}toJSON(){return{blockName:this.constructor.NAME,blockLength:this.blockLength,error:this.error,warnings:this.warnings,valueBeforeDecode:P.Convert.ToHex(this.valueBeforeDecodeView)}}};re.NAME="baseBlock";var ft=class extends re{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'")}};ft.NAME="valueBlock";var Zn=class extends ae(re){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):ui,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",Vt}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=xe(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(!ie(this,s,e,n))return-1;let o=s.subarray(e,e+n);if(o.length===0)return this.error="Zero buffer length",-1;switch(o[0]&192){case 0:this.tagClass=1;break;case 64:this.tagClass=2;break;case 128:this.tagClass=3;break;case 192:this.tagClass=4;break;default:return this.error="Unknown tag class",-1}this.isConstructed=(o[0]&32)===32,this.isHexOnly=!1;let a=o[0]&31;if(a!==31)this.tagNumber=a,this.blockLength=1;else{let c=1,f=this.valueHexView=new Uint8Array(255),l=255;for(;o[c]&128;){if(f[c-1]=o[c]&127,c++,c>=o.length)return this.error="End of input reached before message was fully decoded",-1;if(c===l){l+=255;let h=new Uint8Array(l);for(let m=0;m<f.length;m++)h[m]=f[m];f=this.valueHexView=new Uint8Array(l)}}this.blockLength=c+1,f[c-1]=o[c]&127;let u=new Uint8Array(c);for(let h=0;h<c;h++)u[h]=f[h];f=this.valueHexView=new Uint8Array(c),f.set(u),this.blockLength<=9?this.tagNumber=Ve(f,7):(this.isHexOnly=!0,this.warnings.push("Tag too long, represented as hex-coded"))}if(this.tagClass===1&&this.isConstructed)switch(this.tagNumber){case 1:case 2:case 5:case 6:case 9:case 13:case 14:case 23:case 24:case 31:case 32:case 33:case 34:return this.error="Constructed encoding used for primitive type",-1}return e+this.blockLength}toJSON(){return{...super.toJSON(),tagClass:this.tagClass,tagNumber:this.tagNumber,isConstructed:this.isConstructed}}};Zn.NAME="identificationBlock";var Jn=class extends re{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(!ie(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=xe(this.length,8);if(s.byteLength>127)return this.error="Too big length",Vt;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}}};Jn.NAME="lengthBlock";var A={},at=class extends re{constructor({name:t=gr,optional:e=!1,primitiveSchema:n,...s}={},o){super(s),this.name=t,this.optional=e,n&&(this.primitiveSchema=n),this.idBlock=new Zn(s),this.lenBlock=new Jn(s),this.valueBlock=o?new o(s):new ft(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 Yr;e||Qc(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?Vt: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(){let t=this.constructor.NAME,e=P.Convert.ToHex(this.valueBlock.valueBeforeDecodeView);return`${t} : ${e}`}isEqual(t){if(this===t)return!0;if(!(t instanceof this.constructor))return!1;let e=this.toBER(),n=t.toBER();return Wc(e,n)}};at.NAME="BaseBlock";function Qc(r){var t;if(r instanceof A.Constructed)for(let e of r.valueBlock.value)Qc(e)&&(r.lenBlock.isIndefiniteForm=!0);return!!(!((t=r.lenBlock)===null||t===void 0)&&t.isIndefiniteForm)}var Yn=class extends at{getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}constructor({value:t=gr,...e}={},n){super(e,n),t&&this.fromString(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}'`}};Yn.NAME="BaseStringBlock";var Xn=class extends ae(ft){constructor({isHexOnly:t=!0,...e}={}){super(e),this.isHexOnly=t}};Xn.NAME="PrimitiveValueBlock";var tl,Qn=class extends at{constructor(t={}){super(t,Xn),this.idBlock.isConstructed=!1}};tl=Qn;A.Primitive=tl;Qn.NAME="PRIMITIVE";function Ph(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 _s(r,t=0,e=r.length){let n=t,s=new at({},ft),o=new re;if(!ie(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=at;switch(s.idBlock.tagClass){case 1:if(s.idBlock.tagNumber>=37&&s.idBlock.isHexOnly===!1)return s.error="UNIVERSAL 37 and upper tags are reserved by ASN.1 standard",{offset:-1,result:s};switch(s.idBlock.tagNumber){case 0:if(s.idBlock.isConstructed&&s.lenBlock.length>0)return s.error="Type [UNIVERSAL 0] is reserved",{offset:-1,result:s};c=A.EndOfContent;break;case 1:c=A.Boolean;break;case 2:c=A.Integer;break;case 3:c=A.BitString;break;case 4:c=A.OctetString;break;case 5:c=A.Null;break;case 6:c=A.ObjectIdentifier;break;case 10:c=A.Enumerated;break;case 12:c=A.Utf8String;break;case 13:c=A.RelativeObjectIdentifier;break;case 14:c=A.TIME;break;case 15:return s.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:s};case 16:c=A.Sequence;break;case 17:c=A.Set;break;case 18:c=A.NumericString;break;case 19:c=A.PrintableString;break;case 20:c=A.TeletexString;break;case 21:c=A.VideotexString;break;case 22:c=A.IA5String;break;case 23:c=A.UTCTime;break;case 24:c=A.GeneralizedTime;break;case 25:c=A.GraphicString;break;case 26:c=A.VisibleString;break;case 27:c=A.GeneralString;break;case 28:c=A.UniversalString;break;case 29:c=A.CharacterString;break;case 30:c=A.BmpString;break;case 31:c=A.DATE;break;case 32:c=A.TimeOfDay;break;case 33:c=A.DateTime;break;case 34:c=A.Duration;break;default:{let f=s.idBlock.isConstructed?new A.Constructed:new A.Primitive;f.idBlock=s.idBlock,f.lenBlock=s.lenBlock,f.warnings=s.warnings,s=f}}break;case 2:case 3:case 4:default:c=s.idBlock.isConstructed?A.Constructed:A.Primitive}return s=Ph(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 Rs(r){if(!r.byteLength){let t=new at({},ft);return t.error="Input buffer has zero length",{offset:-1,result:t}}return _s(P.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function Mh(r,t){return r?1:t}var qt=class extends ft{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(!ie(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(;Mh(this.isIndefiniteForm,n)>0;){let i=_s(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 Yr;for(let s=0;s<this.value.length;s++)this.value[s].toBER(t,n);return e?Vt:n.final()}toJSON(){let t={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let e of this.value)t.value.push(e.toJSON());return t}};qt.NAME="ConstructedValueBlock";var el,ve=class extends at{constructor(t={}){super(t,qt),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} :`}};Hc=Ae;A.Constructed=Hc;Ae.NAME="CONSTRUCTED";var Wn=class extends ht{fromBER(t,e,n){return e}toBER(t){return Vt}};Wn.override="EndOfContentValueBlock";var Pc,Zn=class extends at{constructor(t={}){super(t,Wn),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};Pc=Zn;A.EndOfContent=Pc;Zn.NAME=zr;var Mc,Pe=class extends at{constructor(t={}){super(t,ht),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}`}};Mc=Pe;A.Null=Mc;Pe.NAME="NULL";var Jn=class extends oe(ht){get value(){for(let t of this.valueHexView)if(t>0)return!0;return!1}set value(t){this.valueHexView[0]=t?255:0}constructor({value:t,...e}={}){super(e),e.valueHex?this.valueHexView=M.BufferSourceConverter.toUint8Array(e.valueHex):this.valueHexView=new Uint8Array(1),t&&(this.value=t)}fromBER(t,e,n){let s=M.BufferSourceConverter.toUint8Array(t);return se(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,ri.call(this),this.blockLength=n,e+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};Jn.NAME="BooleanValueBlock";var Fc,Yn=class extends at{getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}constructor(t={}){super(t,Jn),this.idBlock.tagClass=1,this.idBlock.tagNumber=1}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.getValue}`}};Fc=Yn;A.Boolean=Fc;Yn.NAME="BOOLEAN";var Xn=class extends oe(Mt){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=Mt.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===zr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(i!==Dc)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?Mt.prototype.toBER.call(this,t,e):t?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};Xn.NAME="OctetStringValueBlock";var oi,ee=class extends at{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},Xn),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=Is(o,0,o.byteLength);i.offset!==-1&&i.offset===n&&(this.valueBlock.value=[i.result])}}catch{}}return super.fromBER(t,e,n)}onAsciiEncoding(){if(this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length)return Ae.prototype.onAsciiEncoding.call(this);let t=this.constructor.NAME,e=M.Convert.ToHex(this.valueBlock.valueHexView);return`${t} : ${e}`}getValue(){if(!this.idBlock.isConstructed)return this.valueBlock.valueHexView.slice().buffer;let t=[];for(let e of this.valueBlock.value)e instanceof oi&&t.push(e.valueBlock.valueHexView);return M.BufferSourceConverter.concat(t)}};oi=ee;A.OctetString=oi;ee.NAME=Dc;var Qn=class extends oe(Mt){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=Mt.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let a of this.value){let c=a.constructor.NAME;if(c===zr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==Kc)return this.error="BIT STRING may consists of BIT STRINGs only",-1;let f=a.valueBlock;if(this.unusedBits>0&&f.unusedBits>0)return this.error='Using of "unused bits" inside constructive BIT STRING allowed for least one only',-1;this.unusedBits=f.unusedBits}return s}let o=M.BufferSourceConverter.toUint8Array(t);if(!se(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=Is(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 Mt.prototype.toBER.call(this,t,e);if(t)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return Vt;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}}};Qn.NAME="BitStringValueBlock";var qc,ts=class extends at{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},Qn),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 Ae.prototype.onAsciiEncoding.call(this);{let t=[],e=this.valueBlock.valueHexView;for(let i of e)t.push(i.toString(2).padStart(8,"0"));let n=t.join(""),s=this.constructor.NAME,o=n.substring(0,n.length-this.valueBlock.unusedBits);return`${s} : ${o}`}}};qc=ts;A.BitString=qc;ts.NAME=Kc;var jc;function ad(r,t){let e=new Uint8Array([0]),n=new Uint8Array(r),s=new Uint8Array(t),o=n.slice(0),i=o.length-1,a=s.slice(0),c=a.length-1,f=0,l=c<i?i:c,u=0;for(let h=l;h>=0;h--,u++){switch(!0){case u<a.length:f=o[i-u]+a[c-u]+e[0];break;default:f=o[i-u]+e[0]}switch(e[0]=f/10,!0){case u>=o.length:o=Mn(new Uint8Array([f%10]),o);break;default:o[i-u]=f%10}}return e[0]>0&&(o=Mn(e,o)),o}function _c(r){if(r>=jr.length)for(let t=jr.length;t<=r;t++){let e=new Uint8Array([0]),n=jr[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=Mn(e,n)),jr.push(n)}return jr[r]}function cd(r,t){let e=0,n=new Uint8Array(r),s=new Uint8Array(t),o=n.slice(0),i=o.length-1,a=s.slice(0),c=a.length-1,f,l=0;for(let u=c;u>=0;u--,l++)switch(f=o[i-l]-a[c-l]-e,!0){case f<0:e=1,o[i-l]=f+10;break;default:e=0,o[i-l]=f}if(e>0)for(let u=i-c+1;u>=0;u--,l++)if(f=o[i-l]-e,f<0)e=1,o[i-l]=f+10;else{e=0,o[i-l]=f;break}return o.slice()}var Wr=class extends oe(ht){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=ri.call(this)))}constructor({value:t,...e}={}){super(e),this._valueDec=0,e.valueHex&&this.setValueHex(),t!==void 0&&(this.valueDec=t)}set valueDec(t){this._valueDec=t,this.isHexOnly=!1,this.valueHexView=new Uint8Array(Uc(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)!==0?this.valueHexView=i.subarray(1):s!==0&&i.length<s&&(s-i.length>1&&(s=i.length+1),this.valueHexView=i.subarray(s-i.length)),o}toDER(t=!1){let e=this.valueHexView;switch(!0){case(e[0]&128)!==0:{let n=new Uint8Array(this.valueHexView.length+1);n[0]=0,n.set(e,1),this.valueHexView=n}break;case(e[0]===0&&(e[1]&128)===0):this.valueHexView=this.valueHexView.subarray(1);break}return this.toBER(t)}fromBER(t,e,n){let s=super.fromBER(t,e,n);return s===-1||this.setValueHex(),s}toBER(t){return t?new ArrayBuffer(this.valueHexView.length):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}toString(){let t=this.valueHexView.length*8-1,e=new Uint8Array(this.valueHexView.length*8/3),n=0,s,o=this.valueHexView,i="",a=!1;for(let c=o.byteLength-1;c>=0;c--){s=o[c];for(let f=0;f<8;f++){if((s&1)===1)switch(n){case t:e=cd(_c(n),e),i="-";break;default:e=ad(e,_c(n))}n++,s>>=1}}for(let c=0;c<e.length;c++)e[c]&&(a=!0),a&&(i+=Rc.charAt(e[c]));return a===!1&&(i+=Rc.charAt(0)),i}};jc=Wr;Wr.NAME="IntegerValueBlock";Object.defineProperty(jc.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var $r,re=class extends at{constructor(t={}){super(t,Wr),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return Fn(),BigInt(this.valueBlock.toString())}static fromBigInt(t){Fn();let e=BigInt(t),n=new Gr,s=e.toString(16).replace(/^-/,""),o=new Uint8Array(M.Convert.FromHex(s));if(e<0){let a=new Uint8Array(o.length+(o[0]&128?1:0));a[0]|=128;let f=BigInt(`0x${M.Convert.ToHex(a)}`)+e,l=M.BufferSourceConverter.toUint8Array(M.Convert.FromHex(f.toString(16)));l[0]|=128,n.write(l)}else o[0]&128&&n.write(new Uint8Array([0])),n.write(o);return new $r({valueHex:n.final()})}convertToDER(){let t=new $r({valueHex:this.valueBlock.valueHexView});return t.valueBlock.toDER(),t}convertFromDER(){return new $r({valueHex:this.valueBlock.valueHexView[0]===0?this.valueBlock.valueHexView.subarray(1):this.valueBlock.valueHexView})}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()}`}};$r=re;A.Integer=$r;re.NAME="INTEGER";var $c,es=class extends re{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};$c=es;A.Enumerated=$c;es.NAME="ENUMERATED";var Zr=class extends oe(ht){constructor({valueDec:t=-1,isFirstSid:e=!1,...n}={}){super(n),this.valueDec=t,this.isFirstSid=e}fromBER(t,e,n){if(!n)return e;let s=M.BufferSourceConverter.toUint8Array(t);if(!se(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)!==0);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)!==0?(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=He(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}set valueBigInt(t){Fn();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=Ee(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Vt;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),o=e.byteLength-1;for(let i=0;i<o;i++)n[i]=s[i]|128;n[o]=s[o]}return n}toString(){let t="";if(this.isHexOnly)t=M.Convert.ToHex(this.valueHexView);else if(this.isFirstSid){let e=this.valueDec;this.valueDec<=39?t="0.":this.valueDec<=79?(t="1.",e-=40):(t="2.",e-=80),t+=e.toString()}else t=this.valueDec.toString();return t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec,isFirstSid:this.isFirstSid}}};Zr.NAME="sidBlock";var rs=class extends ht{constructor({value:t=pr,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new Zr;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,Vt;e.push(s)}return ni(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 Zr;if(s>Number.MAX_SAFE_INTEGER){Fn();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}};rs.NAME="ObjectIdentifierValueBlock";var Gc,Ft=class extends at{getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}constructor(t={}){super(t,rs),this.idBlock.tagClass=1,this.idBlock.tagNumber=6}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};Gc=Ft;A.ObjectIdentifier=Gc;Ft.NAME="OBJECT IDENTIFIER";var Jr=class extends oe(te){constructor({valueDec:t=0,...e}={}){super(e),this.valueDec=t}fromBER(t,e,n){if(n===0)return e;let s=M.BufferSourceConverter.toUint8Array(t);if(!se(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)!==0);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)!==0?(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=He(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=Ee(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Vt;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),o=e.byteLength-1;for(let i=0;i<o;i++)n[i]=s[i]|128;n[o]=s[o]}return n.buffer}toString(){let t="";return this.isHexOnly?t=M.Convert.ToHex(this.valueHexView):t=this.valueDec.toString(),t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};Jr.NAME="relativeSidBlock";var ns=class extends ht{constructor({value:t=pr,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new Jr;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,Vt;n.push(o)}return ni(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 Jr;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}};ns.NAME="RelativeObjectIdentifierValueBlock";var zc,ss=class extends at{getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}constructor(t={}){super(t,ns),this.idBlock.tagClass=1,this.idBlock.tagNumber=13}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};zc=ss;A.RelativeObjectIdentifier=zc;ss.NAME="RelativeObjectIdentifier";var Wc,At=class extends Ae{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};Wc=At;A.Sequence=Wc;At.NAME="SEQUENCE";var Zc,os=class extends Ae{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};Zc=os;A.Set=Zc;os.NAME="SET";var is=class extends oe(ht){constructor({...t}={}){super(t),this.isHexOnly=!0,this.value=pr}toJSON(){return{...super.toJSON(),value:this.value}}};is.NAME="StringValueBlock";var as=class extends is{};as.NAME="SimpleStringValueBlock";var mt=class extends $n{constructor({...t}={}){super(t,as)}fromBuffer(t){this.valueBlock.value=String.fromCharCode.apply(null,M.BufferSourceConverter.toUint8Array(t))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e);for(let s=0;s<e;s++)n[s]=t.charCodeAt(s);this.valueBlock.value=t}};mt.NAME="SIMPLE STRING";var cs=class extends mt{fromBuffer(t){this.valueBlock.valueHexView=M.BufferSourceConverter.toUint8Array(t);try{this.valueBlock.value=M.Convert.ToUtf8String(t)}catch(e){this.warnings.push(`Error during "decodeURIComponent": ${e}, using raw string`),this.valueBlock.value=M.Convert.ToBinary(t)}}fromString(t){this.valueBlock.valueHexView=new Uint8Array(M.Convert.FromUtf8String(t)),this.valueBlock.value=t}};cs.NAME="Utf8StringValueBlock";var Jc,ne=class extends cs{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};Jc=ne;A.Utf8String=Jc;ne.NAME="UTF8String";var ls=class extends mt{fromBuffer(t){this.valueBlock.value=M.Convert.ToUtf16String(t),this.valueBlock.valueHexView=M.BufferSourceConverter.toUint8Array(t)}fromString(t){this.valueBlock.value=t,this.valueBlock.valueHexView=new Uint8Array(M.Convert.FromUtf16String(t))}};ls.NAME="BmpStringValueBlock";var Yc,us=class extends ls{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};Yc=us;A.BmpString=Yc;us.NAME="BMPString";var fs=class extends mt{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=Ee(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}};fs.NAME="UniversalStringValueBlock";var Xc,hs=class extends fs{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};Xc=hs;A.UniversalString=Xc;hs.NAME="UniversalString";var Qc,ds=class extends mt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};Qc=ds;A.NumericString=Qc;ds.NAME="NumericString";var tl,ps=class extends mt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};tl=ps;A.PrintableString=tl;ps.NAME="PrintableString";var el,gs=class extends mt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};el=gs;A.TeletexString=el;gs.NAME="TeletexString";var rl,ys=class extends mt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};rl=ys;A.VideotexString=rl;ys.NAME="VideotexString";var nl,ms=class extends mt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};nl=ms;A.IA5String=nl;ms.NAME="IA5String";var sl,bs=class extends mt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};sl=bs;A.GraphicString=sl;bs.NAME="GraphicString";var ol,Yr=class extends mt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};ol=Yr;A.VisibleString=ol;Yr.NAME="VisibleString";var il,ws=class extends mt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};il=ws;A.GeneralString=il;ws.NAME="GeneralString";var al,xs=class extends mt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};al=xs;A.CharacterString=al;xs.NAME="CharacterString";var cl,Xr=class extends Yr{constructor({value:t,valueDate:e,...n}={}){if(super(n),this.year=0,this.month=0,this.day=0,this.hour=0,this.minute=0,this.second=0,t){this.fromString(t),this.valueBlock.valueHexView=new Uint8Array(t.length);for(let s=0;s<t.length;s++)this.valueBlock.valueHexView[s]=t.charCodeAt(s)}e&&(this.fromDate(e),this.valueBlock.valueHexView=new Uint8Array(this.toBuffer())),this.idBlock.tagClass=1,this.idBlock.tagNumber=23}fromBuffer(t){this.fromString(String.fromCharCode.apply(null,M.BufferSourceConverter.toUint8Array(t)))}toBuffer(){let t=this.toString(),e=new ArrayBuffer(t.length),n=new Uint8Array(e);for(let s=0;s<t.length;s++)n[s]=t.charCodeAt(s);return e}fromDate(t){this.year=t.getUTCFullYear(),this.month=t.getUTCMonth()+1,this.day=t.getUTCDate(),this.hour=t.getUTCHours(),this.minute=t.getUTCMinutes(),this.second=t.getUTCSeconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second))}fromString(t){let n=/(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})Z/ig.exec(t);if(n===null){this.error="Wrong input string for conversion";return}let s=parseInt(n[1],10);s>=50?this.year=1900+s:this.year=2e3+s,this.month=parseInt(n[2],10),this.day=parseInt(n[3],10),this.hour=parseInt(n[4],10),this.minute=parseInt(n[5],10),this.second=parseInt(n[6],10)}toString(t="iso"){if(t==="iso"){let e=new Array(7);return e[0]=Et(this.year<2e3?this.year-1900:this.year-2e3,2),e[1]=Et(this.month,2),e[2]=Et(this.day,2),e[3]=Et(this.hour,2),e[4]=Et(this.minute,2),e[5]=Et(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}}};cl=Xr;A.UTCTime=cl;Xr.NAME="UTCTime";var ll,vs=class extends Xr{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(){let t=Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second,this.millisecond);return new Date(t)}fromString(t){let e=!1,n="",s="",o=0,i,a=0,c=0;if(t[t.length-1]==="Z")n=t.substring(0,t.length-1),e=!0;else{let u=new Number(t[t.length-1]);if(isNaN(u.valueOf()))throw new Error("Wrong input string for conversion");n=t}if(e){if(n.indexOf("+")!==-1)throw new Error("Wrong input string for conversion");if(n.indexOf("-")!==-1)throw new Error("Wrong input string for conversion")}else{let u=1,h=n.indexOf("+"),y="";if(h===-1&&(h=n.indexOf("-"),u=-1),h!==-1){if(y=n.substring(h+1),n=n.substring(0,h),y.length!==2&&y.length!==4)throw new Error("Wrong input string for conversion");let b=parseInt(y.substring(0,2),10);if(isNaN(b.valueOf()))throw new Error("Wrong input string for conversion");if(a=u*b,y.length===4){if(b=parseInt(y.substring(2,4),10),isNaN(b.valueOf()))throw new Error("Wrong input string for conversion");c=u*b}}}let f=n.indexOf(".");if(f===-1&&(f=n.indexOf(",")),f!==-1){let u=new Number(`0${n.substring(f)}`);if(isNaN(u.valueOf()))throw new Error("Wrong input string for conversion");o=u.valueOf(),s=n.substring(0,f)}else s=n;switch(!0){case s.length===8:if(i=/(\d{4})(\d{2})(\d{2})/ig,f!==-1)throw new Error("Wrong input string for conversion");break;case s.length===10:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let u=60*o;this.minute=Math.floor(u),u=60*(u-this.minute),this.second=Math.floor(u),u=1e3*(u-this.second),this.millisecond=Math.floor(u)}break;case s.length===12:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let u=60*o;this.second=Math.floor(u),u=1e3*(u-this.second),this.millisecond=Math.floor(u)}break;case s.length===14:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let u=1e3*o;this.millisecond=Math.floor(u)}break;default:throw new Error("Wrong input string for conversion")}let l=i.exec(s);if(l===null)throw new Error("Wrong input string for conversion");for(let u=1;u<l.length;u++)switch(u){case 1:this.year=parseInt(l[u],10);break;case 2:this.month=parseInt(l[u],10);break;case 3:this.day=parseInt(l[u],10);break;case 4:this.hour=parseInt(l[u],10)+a;break;case 5:this.minute=parseInt(l[u],10)+c;break;case 6:this.second=parseInt(l[u],10);break;default:throw new Error("Wrong input string for conversion")}if(e===!1){let u=new Date(this.year,this.month,this.day,this.hour,this.minute,this.second,this.millisecond);this.year=u.getUTCFullYear(),this.month=u.getUTCMonth(),this.day=u.getUTCDay(),this.hour=u.getUTCHours(),this.minute=u.getUTCMinutes(),this.second=u.getUTCSeconds(),this.millisecond=u.getUTCMilliseconds()}}toString(t="iso"){if(t==="iso"){let e=[];return e.push(Et(this.year,4)),e.push(Et(this.month,2)),e.push(Et(this.day,2)),e.push(Et(this.hour,2)),e.push(Et(this.minute,2)),e.push(Et(this.second,2)),this.millisecond!==0&&(e.push("."),e.push(Et(this.millisecond,3))),e.push("Z"),e.join("")}return super.toString(t)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};ll=vs;A.GeneralizedTime=ll;vs.NAME="GeneralizedTime";var ul,Bs=class extends ne{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};ul=Bs;A.DATE=ul;Bs.NAME="DATE";var fl,Es=class extends ne{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};fl=Es;A.TimeOfDay=fl;Es.NAME="TimeOfDay";var hl,As=class extends ne{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};hl=As;A.DateTime=hl;As.NAME="DateTime";var dl,Ss=class extends ne{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};dl=Ss;A.Duration=dl;Ss.NAME="Duration";var pl,ks=class extends ne{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};pl=ks;A.TIME=pl;ks.NAME="TIME";async function Ns(r,t){let n=await hr.create().encrypt(r,t);return Ie.encode(n)}async function ii(r,t,e){if(r.type==="RSA")return hd(r,t,e);if(r.type==="Ed25519")return ld(r,t,e);if(r.type==="secp256k1")return ud(r,t,e);if(r.type==="ECDSA")return fd(r,t,e);throw new je}async function ld(r,t,e="libp2p-key"){if(e==="libp2p-key")return Ns(Ve(r),t);throw new L(`export format '${e}' is not supported`)}async function ud(r,t,e="libp2p-key"){if(e==="libp2p-key")return Ns(Ve(r),t);throw new L("Export format is not supported")}async function fd(r,t,e="libp2p-key"){if(e==="libp2p-key")return Ns(Ve(r),t);throw new L(`export format '${e}' is not supported`)}async function hd(r,t,e="pkcs-8"){if(e==="pkcs-8")return dd(r,t);if(e==="libp2p-key")return Ns(Ve(r),t);throw new L("Export format is not supported")}async function dd(r,t){let e=wt.get(),s=new At({value:[new re({value:0}),new At({value:[new Ft({value:"1.2.840.113549.1.1.1"}),new Pe]}),new ee({valueHex:r.raw})]}).toBER(),o=new Uint8Array(s,0,s.byteLength),i=Oe(16),a=await _n(fe,t,i,{c:1e4,dkLen:32}),c=Oe(16),f=await e.subtle.importKey("raw",a,"AES-CBC",!1,["encrypt"]),l=await e.subtle.encrypt({name:"AES-CBC",iv:c},f,o),u=new At({value:[new ee({valueHex:i}),new re({value:1e4}),new re({value:32}),new At({value:[new Ft({value:"1.2.840.113549.2.11"}),new Pe]})]}),h=new At({value:[new Ft({value:"1.2.840.113549.1.5.13"}),new At({value:[new At({value:[new Ft({value:"1.2.840.113549.1.5.12"}),u]}),new At({value:[new Ft({value:"2.16.840.1.101.3.4.1.42"}),new ee({valueHex:c})]})]})]}),b=new At({value:[h,new ee({valueHex:l})]}).toBER(),m=new Uint8Array(b,0,b.byteLength);return["-----BEGIN ENCRYPTED PRIVATE KEY-----",...j(m,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
7
- `)}async function ai(r,t){try{let e=await pd(r,t);return nc(e)}catch{}if(!r.includes("BEGIN"))throw new L("Encrypted key was not a libp2p-key or a PEM file");return gd(r,t)}async function pd(r,t){let e=Ie.decode(r);return hr.create().decrypt(e,t)}async function gd(r,t){let e=wt.get(),n;if(r.includes("-----BEGIN ENCRYPTED PRIVATE KEY-----")){let o=H(r.replace("-----BEGIN ENCRYPTED PRIVATE KEY-----","").replace("-----END ENCRYPTED PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:i}=Cs(o),{iv:a,salt:c,iterations:f,keySize:l,cipherText:u}=yd(i),h=await _n(fe,t,c,{c:f,dkLen:l}),y=await e.subtle.importKey("raw",h,"AES-CBC",!1,["decrypt"]),b=Qr(await e.subtle.decrypt({name:"AES-CBC",iv:a},y,u)),{result:m}=Cs(b);n=bl(m)}else if(r.includes("-----BEGIN PRIVATE KEY-----")){let o=H(r.replace("-----BEGIN PRIVATE KEY-----","").replace("-----END PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:i}=Cs(o);n=bl(i)}else throw new L("Could not parse private key from PEM data");let s=sc(n);if(s.type!=="RSA")throw new L("Could not parse RSA private key from PEM data");return s}function yd(r){let t=r.valueBlock.value[0];if(t.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.13")throw new L("Only pkcs5PBES2 encrypted private keys are supported");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 L("Only pkcs5PBKDF2 key derivation functions are supported");let o=n.valueBlock.value[1],i=Qr(o.valueBlock.value[0].getValue()),a=1e4,c=32;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 L("Could not derive key size and iterations from PEM file - please use @libp2p/rsa to re-import your key");let f=t.valueBlock.value[1].valueBlock.value[1],l=f.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 L("Only AES-CBC encryption schemes are supported")}}}}let u=Qr(f.valueBlock.value[1].getValue());return{cipherText:Qr(r.valueBlock.value[1].getValue()),salt:i,iterations:a,keySize:c,iv:u}}function bl(r){return Qr(r.valueBlock.value[2].getValue())}function Qr(r){return new Uint8Array(r,0,r.byteLength)}var md="/pkcs8/",li="/info/",tn=new WeakMap,Me={minKeyLength:112/8,minSaltLength:128/8,minIterationCount:1e3},ci={dek:{keyLength:512/8,iterationCount:1e4,salt:"you should override this value with a crypto secure random number",hash:"sha2-512"}};function gr(r){return r==null||typeof r!="string"?!1:r===(0,wl.default)(r.trim())&&r.length>0}async function ct(){let e=Math.random()*800+200;await new Promise(n=>setTimeout(n,e))}function Fe(r){return new qr(md+r)}function yr(r){return new qr(li+r)}async function bd(r){let t=Ve(r),e=await Ye.digest(t);return Q.encode(e.bytes).substring(1)}var Ts=class{components;init;log;self;constructor(t,e){if(this.components=t,this.log=t.logger.forComponent("libp2p:keychain"),this.init=xc(ci,e),this.self=e.selfKey??"self",this.init.pass!=null&&this.init.pass?.length<20)throw new Error("pass must be least 20 characters");if(this.init.dek?.keyLength!=null&&this.init.dek.keyLength<Me.minKeyLength)throw new Error(`dek.keyLength must be least ${Me.minKeyLength} bytes`);if(this.init.dek?.salt?.length!=null&&this.init.dek.salt.length<Me.minSaltLength)throw new Error(`dek.saltLength must be least ${Me.minSaltLength} bytes`);if(this.init.dek?.iterationCount!=null&&this.init.dek.iterationCount<Me.minIterationCount)throw new Error(`dek.iterationCount must be least ${Me.minIterationCount}`);let n=this.init.pass!=null&&this.init.dek?.salt!=null?Fr(this.init.pass,this.init.dek?.salt,this.init.dek?.iterationCount,this.init.dek?.keyLength,this.init.dek?.hash):"";tn.set(this,{dek:n})}[Symbol.toStringTag]="@libp2p/keychain";[wi]=["@libp2p/keychain"];static generateOptions(){let t=Object.assign({},ci),e=Math.ceil(Me.minSaltLength/3)*3;return t.dek.salt=j(Oe(e),"base64"),t}static get options(){return ci}async findKeyByName(t){if(!gr(t))throw await ct(),new L(`Invalid key name '${t}'`);let e=yr(t);try{let n=await this.components.datastore.get(e);return JSON.parse(j(n))}catch(n){throw await ct(),this.log.error(n),new nn(`Key '${t}' does not exist.`)}}async findKeyById(t){try{let e={prefix:li};for await(let n of this.components.datastore.query(e)){let s=JSON.parse(j(n.value));if(s.id===t)return s}throw new L(`Key with id '${t}' does not exist.`)}catch(e){throw await ct(),e}}async importKey(t,e){if(!gr(t))throw await ct(),new L(`Invalid key name '${t}'`);if(e==null)throw await ct(),new L("Key is required");let n=Fe(t);if(await this.components.datastore.has(n))throw await ct(),new L(`Key '${t}' already exists`);let o,i;try{o=await bd(e);let f=tn.get(this);if(f==null)throw new L("dek missing");let l=f.dek;i=await ii(e,l,e.type==="RSA"?"pkcs-8":"libp2p-key")}catch(f){throw await ct(),f}let a={name:t,id:o},c=this.components.datastore.batch();return c.put(n,H(i)),c.put(yr(t),H(JSON.stringify(a))),await c.commit(),a}async exportKey(t){if(!gr(t))throw await ct(),new L(`Invalid key name '${t}'`);let e=Fe(t);try{let n=await this.components.datastore.get(e),s=j(n),o=tn.get(this);if(o==null)throw new L("dek missing");let i=o.dek;return await ai(s,i)}catch(n){throw await ct(),n}}async removeKey(t){if(!gr(t)||t===this.self)throw await ct(),new L(`Invalid key name '${t}'`);let e=Fe(t),n=await this.findKeyByName(t),s=this.components.datastore.batch();return s.delete(e),s.delete(yr(t)),await s.commit(),n}async listKeys(){let t={prefix:li},e=[];for await(let n of this.components.datastore.query(t))e.push(JSON.parse(j(n.value)));return e}async renameKey(t,e){if(!gr(t)||t===this.self)throw await ct(),new L(`Invalid old key name '${t}'`);if(!gr(e)||e===this.self)throw await ct(),new L(`Invalid new key name '${e}'`);let n=Fe(t),s=Fe(e),o=yr(t),i=yr(e);if(await this.components.datastore.has(s))throw await ct(),new L(`Key '${e}' already exists`);try{let c=await this.components.datastore.get(n),f=await this.components.datastore.get(o),l=JSON.parse(j(f));l.name=e;let u=this.components.datastore.batch();return u.put(s,c),u.put(i,H(JSON.stringify(l))),u.delete(n),u.delete(o),await u.commit(),l}catch(c){throw await ct(),c}}async rotateKeychainPass(t,e){if(typeof t!="string")throw await ct(),new L(`Invalid old pass type '${typeof t}'`);if(typeof e!="string")throw await ct(),new L(`Invalid new pass type '${typeof e}'`);if(e.length<20)throw await ct(),new L(`Invalid pass length ${e.length}`);this.log("recreating keychain");let n=tn.get(this);if(n==null)throw new L("dek missing");let s=n.dek;this.init.pass=e;let o=e!=null&&this.init.dek?.salt!=null?Fr(e,this.init.dek.salt,this.init.dek?.iterationCount,this.init.dek?.keyLength,this.init.dek?.hash):"";tn.set(this,{dek:o});let i=await this.listKeys();for(let a of i){let c=await this.components.datastore.get(Fe(a.name)),f=j(c),l=await ai(f,s),u=o.toString(),h=await ii(l,u,l.type==="RSA"?"pkcs-8":"libp2p-key"),y=this.components.datastore.batch(),b={name:a.name,id:a.id};y.put(Fe(a.name),H(h)),y.put(yr(a.name),H(JSON.stringify(b))),await y.commit()}this.log("keychain reconstructed")}};function wd(r={}){return t=>new Ts(t,r)}return Rl(xd);})();
6
+ `)}`:`${e} :`}};el=ve;A.Constructed=el;ve.NAME="CONSTRUCTED";var ts=class extends ft{fromBER(t,e,n){return e}toBER(t){return Vt}};ts.override="EndOfContentValueBlock";var rl,es=class extends at{constructor(t={}){super(t,ts),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};rl=es;A.EndOfContent=rl;es.NAME=Xr;var nl,Pe=class extends at{constructor(t={}){super(t,ft),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}`}};nl=Pe;A.Null=nl;Pe.NAME="NULL";var rs=class extends ae(ft){get value(){for(let t of this.valueHexView)if(t>0)return!0;return!1}set value(t){this.valueHexView[0]=t?255:0}constructor({value:t,...e}={}){super(e),e.valueHex?this.valueHexView=P.BufferSourceConverter.toUint8Array(e.valueHex):this.valueHexView=new Uint8Array(1),t&&(this.value=t)}fromBER(t,e,n){let s=P.BufferSourceConverter.toUint8Array(t);return ie(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,ci.call(this),this.blockLength=n,e+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};rs.NAME="BooleanValueBlock";var sl,ns=class extends at{getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}constructor(t={}){super(t,rs),this.idBlock.tagClass=1,this.idBlock.tagNumber=1}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.getValue}`}};sl=ns;A.Boolean=sl;ns.NAME="BOOLEAN";var ss=class extends ae(qt){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=qt.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!==Yc)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?qt.prototype.toBER.call(this,t,e):t?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};ss.NAME="OctetStringValueBlock";var fi,ne=class extends at{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},ss),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=_s(o,0,o.byteLength);i.offset!==-1&&i.offset===n&&(this.valueBlock.value=[i.result])}}catch{}}return super.fromBER(t,e,n)}onAsciiEncoding(){if(this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length)return ve.prototype.onAsciiEncoding.call(this);let t=this.constructor.NAME,e=P.Convert.ToHex(this.valueBlock.valueHexView);return`${t} : ${e}`}getValue(){if(!this.idBlock.isConstructed)return this.valueBlock.valueHexView.slice().buffer;let t=[];for(let e of this.valueBlock.value)e instanceof fi&&t.push(e.valueBlock.valueHexView);return P.BufferSourceConverter.concat(t)}};fi=ne;A.OctetString=fi;ne.NAME=Yc;var os=class extends ae(qt){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=qt.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!==Xc)return this.error="BIT STRING may consists of BIT STRINGs only",-1;let f=a.valueBlock;if(this.unusedBits>0&&f.unusedBits>0)return this.error='Using of "unused bits" inside constructive BIT STRING allowed for least one only',-1;this.unusedBits=f.unusedBits}return s}let o=P.BufferSourceConverter.toUint8Array(t);if(!ie(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=_s(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 qt.prototype.toBER.call(this,t,e);if(t)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return Vt;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}}};os.NAME="BitStringValueBlock";var ol,is=class extends at{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},os),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 ve.prototype.onAsciiEncoding.call(this);{let t=[],e=this.valueBlock.valueHexView;for(let i of e)t.push(i.toString(2).padStart(8,"0"));let n=t.join(""),s=this.constructor.NAME,o=n.substring(0,n.length-this.valueBlock.unusedBits);return`${s} : ${o}`}}};ol=is;A.BitString=ol;is.NAME=Xc;var il;function Fh(r,t){let e=new Uint8Array([0]),n=new Uint8Array(r),s=new Uint8Array(t),o=n.slice(0),i=o.length-1,a=s.slice(0),c=a.length-1,f=0,l=c<i?i:c,u=0;for(let h=l;h>=0;h--,u++){switch(!0){case u<a.length:f=o[i-u]+a[c-u]+e[0];break;default:f=o[i-u]+e[0]}switch(e[0]=f/10,!0){case u>=o.length:o=zn(new Uint8Array([f%10]),o);break;default:o[i-u]=f%10}}return e[0]>0&&(o=zn(e,o)),o}function Jc(r){if(r>=Zr.length)for(let t=Zr.length;t<=r;t++){let e=new Uint8Array([0]),n=Zr[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=zn(e,n)),Zr.push(n)}return Zr[r]}function qh(r,t){let e=0,n=new Uint8Array(r),s=new Uint8Array(t),o=n.slice(0),i=o.length-1,a=s.slice(0),c=a.length-1,f,l=0;for(let u=c;u>=0;u--,l++)switch(f=o[i-l]-a[c-l]-e,!0){case f<0:e=1,o[i-l]=f+10;break;default:e=0,o[i-l]=f}if(e>0)for(let u=i-c+1;u>=0;u--,l++)if(f=o[i-l]-e,f<0)e=1,o[i-l]=f+10;else{e=0,o[i-l]=f;break}return o.slice()}var Qr=class extends ae(ft){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=ci.call(this)))}constructor({value:t,...e}={}){super(e),this._valueDec=0,e.valueHex&&this.setValueHex(),t!==void 0&&(this.valueDec=t)}set valueDec(t){this._valueDec=t,this.isHexOnly=!1,this.valueHexView=new Uint8Array(zc(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)!==0?this.valueHexView=i.subarray(1):s!==0&&i.length<s&&(s-i.length>1&&(s=i.length+1),this.valueHexView=i.subarray(s-i.length)),o}toDER(t=!1){let e=this.valueHexView;switch(!0){case(e[0]&128)!==0:{let n=new Uint8Array(this.valueHexView.length+1);n[0]=0,n.set(e,1),this.valueHexView=n}break;case(e[0]===0&&(e[1]&128)===0):this.valueHexView=this.valueHexView.subarray(1);break}return this.toBER(t)}fromBER(t,e,n){let s=super.fromBER(t,e,n);return s===-1||this.setValueHex(),s}toBER(t){return t?new ArrayBuffer(this.valueHexView.length):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}toString(){let t=this.valueHexView.length*8-1,e=new Uint8Array(this.valueHexView.length*8/3),n=0,s,o=this.valueHexView,i="",a=!1;for(let c=o.byteLength-1;c>=0;c--){s=o[c];for(let f=0;f<8;f++){if((s&1)===1)switch(n){case t:e=qh(Jc(n),e),i="-";break;default:e=Fh(e,Jc(n))}n++,s>>=1}}for(let c=0;c<e.length;c++)e[c]&&(a=!0),a&&(i+=Zc.charAt(e[c]));return a===!1&&(i+=Zc.charAt(0)),i}};il=Qr;Qr.NAME="IntegerValueBlock";Object.defineProperty(il.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var Jr,se=class extends at{constructor(t={}){super(t,Qr),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return Wn(),BigInt(this.valueBlock.toString())}static fromBigInt(t){Wn();let e=BigInt(t),n=new Yr,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 f=BigInt(`0x${P.Convert.ToHex(a)}`)+e,l=P.BufferSourceConverter.toUint8Array(P.Convert.FromHex(f.toString(16)));l[0]|=128,n.write(l)}else o[0]&128&&n.write(new Uint8Array([0])),n.write(o);return new Jr({valueHex:n.final()})}convertToDER(){let t=new Jr({valueHex:this.valueBlock.valueHexView});return t.valueBlock.toDER(),t}convertFromDER(){return new Jr({valueHex:this.valueBlock.valueHexView[0]===0?this.valueBlock.valueHexView.subarray(1):this.valueBlock.valueHexView})}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()}`}};Jr=se;A.Integer=Jr;se.NAME="INTEGER";var al,as=class extends se{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};al=as;A.Enumerated=al;as.NAME="ENUMERATED";var tn=class extends ae(ft){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(!ie(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)!==0);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)!==0?(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){Wn();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=xe(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Vt;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}}};tn.NAME="sidBlock";var cs=class extends ft{constructor({value:t=gr,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new tn;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,Vt;e.push(s)}return li(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 tn;if(s>Number.MAX_SAFE_INTEGER){Wn();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}};cs.NAME="ObjectIdentifierValueBlock";var cl,jt=class extends at{getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}constructor(t={}){super(t,cs),this.idBlock.tagClass=1,this.idBlock.tagNumber=6}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};cl=jt;A.ObjectIdentifier=cl;jt.NAME="OBJECT IDENTIFIER";var en=class extends ae(re){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(!ie(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)!==0);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)!==0?(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=xe(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Vt;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}}};en.NAME="relativeSidBlock";var ls=class extends ft{constructor({value:t=gr,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new en;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,Vt;n.push(o)}return li(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 en;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}};ls.NAME="RelativeObjectIdentifierValueBlock";var ll,us=class extends at{getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}constructor(t={}){super(t,ls),this.idBlock.tagClass=1,this.idBlock.tagNumber=13}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};ll=us;A.RelativeObjectIdentifier=ll;us.NAME="RelativeObjectIdentifier";var ul,At=class extends ve{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};ul=At;A.Sequence=ul;At.NAME="SEQUENCE";var fl,fs=class extends ve{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};fl=fs;A.Set=fl;fs.NAME="SET";var hs=class extends ae(ft){constructor({...t}={}){super(t),this.isHexOnly=!0,this.value=gr}toJSON(){return{...super.toJSON(),value:this.value}}};hs.NAME="StringValueBlock";var ds=class extends hs{};ds.NAME="SimpleStringValueBlock";var bt=class extends Yn{constructor({...t}={}){super(t,ds)}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}};bt.NAME="SIMPLE STRING";var ps=class extends bt{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}};ps.NAME="Utf8StringValueBlock";var hl,oe=class extends ps{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};hl=oe;A.Utf8String=hl;oe.NAME="UTF8String";var gs=class extends bt{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))}};gs.NAME="BmpStringValueBlock";var dl,ys=class extends gs{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};dl=ys;A.BmpString=dl;ys.NAME="BMPString";var ms=class extends bt{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=xe(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}};ms.NAME="UniversalStringValueBlock";var pl,bs=class extends ms{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};pl=bs;A.UniversalString=pl;bs.NAME="UniversalString";var gl,ws=class extends bt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};gl=ws;A.NumericString=gl;ws.NAME="NumericString";var yl,xs=class extends bt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};yl=xs;A.PrintableString=yl;xs.NAME="PrintableString";var ml,vs=class extends bt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};ml=vs;A.TeletexString=ml;vs.NAME="TeletexString";var bl,Es=class extends bt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};bl=Es;A.VideotexString=bl;Es.NAME="VideotexString";var wl,Bs=class extends bt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};wl=Bs;A.IA5String=wl;Bs.NAME="IA5String";var xl,As=class extends bt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};xl=As;A.GraphicString=xl;As.NAME="GraphicString";var vl,rn=class extends bt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};vl=rn;A.VisibleString=vl;rn.NAME="VisibleString";var El,Ss=class extends bt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};El=Ss;A.GeneralString=El;Ss.NAME="GeneralString";var Bl,ks=class extends bt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};Bl=ks;A.CharacterString=Bl;ks.NAME="CharacterString";var Al,nn=class extends rn{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]=Bt(this.year<2e3?this.year-1900:this.year-2e3,2),e[1]=Bt(this.month,2),e[2]=Bt(this.day,2),e[3]=Bt(this.hour,2),e[4]=Bt(this.minute,2),e[5]=Bt(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}}};Al=nn;A.UTCTime=Al;nn.NAME="UTCTime";var Sl,Is=class extends nn{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(){let t=Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second,this.millisecond);return new Date(t)}fromString(t){let e=!1,n="",s="",o=0,i,a=0,c=0;if(t[t.length-1]==="Z")n=t.substring(0,t.length-1),e=!0;else{let u=new Number(t[t.length-1]);if(isNaN(u.valueOf()))throw new Error("Wrong input string for conversion");n=t}if(e){if(n.indexOf("+")!==-1)throw new Error("Wrong input string for conversion");if(n.indexOf("-")!==-1)throw new Error("Wrong input string for conversion")}else{let u=1,h=n.indexOf("+"),m="";if(h===-1&&(h=n.indexOf("-"),u=-1),h!==-1){if(m=n.substring(h+1),n=n.substring(0,h),m.length!==2&&m.length!==4)throw new Error("Wrong input string for conversion");let w=parseInt(m.substring(0,2),10);if(isNaN(w.valueOf()))throw new Error("Wrong input string for conversion");if(a=u*w,m.length===4){if(w=parseInt(m.substring(2,4),10),isNaN(w.valueOf()))throw new Error("Wrong input string for conversion");c=u*w}}}let f=n.indexOf(".");if(f===-1&&(f=n.indexOf(",")),f!==-1){let u=new Number(`0${n.substring(f)}`);if(isNaN(u.valueOf()))throw new Error("Wrong input string for conversion");o=u.valueOf(),s=n.substring(0,f)}else s=n;switch(!0){case s.length===8:if(i=/(\d{4})(\d{2})(\d{2})/ig,f!==-1)throw new Error("Wrong input string for conversion");break;case s.length===10:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let u=60*o;this.minute=Math.floor(u),u=60*(u-this.minute),this.second=Math.floor(u),u=1e3*(u-this.second),this.millisecond=Math.floor(u)}break;case s.length===12:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let u=60*o;this.second=Math.floor(u),u=1e3*(u-this.second),this.millisecond=Math.floor(u)}break;case s.length===14:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let u=1e3*o;this.millisecond=Math.floor(u)}break;default:throw new Error("Wrong input string for conversion")}let l=i.exec(s);if(l===null)throw new Error("Wrong input string for conversion");for(let u=1;u<l.length;u++)switch(u){case 1:this.year=parseInt(l[u],10);break;case 2:this.month=parseInt(l[u],10);break;case 3:this.day=parseInt(l[u],10);break;case 4:this.hour=parseInt(l[u],10)+a;break;case 5:this.minute=parseInt(l[u],10)+c;break;case 6:this.second=parseInt(l[u],10);break;default:throw new Error("Wrong input string for conversion")}if(e===!1){let u=new Date(this.year,this.month,this.day,this.hour,this.minute,this.second,this.millisecond);this.year=u.getUTCFullYear(),this.month=u.getUTCMonth(),this.day=u.getUTCDay(),this.hour=u.getUTCHours(),this.minute=u.getUTCMinutes(),this.second=u.getUTCSeconds(),this.millisecond=u.getUTCMilliseconds()}}toString(t="iso"){if(t==="iso"){let e=[];return e.push(Bt(this.year,4)),e.push(Bt(this.month,2)),e.push(Bt(this.day,2)),e.push(Bt(this.hour,2)),e.push(Bt(this.minute,2)),e.push(Bt(this.second,2)),this.millisecond!==0&&(e.push("."),e.push(Bt(this.millisecond,3))),e.push("Z"),e.join("")}return super.toString(t)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};Sl=Is;A.GeneralizedTime=Sl;Is.NAME="GeneralizedTime";var kl,Cs=class extends oe{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};kl=Cs;A.DATE=kl;Cs.NAME="DATE";var Il,Ns=class extends oe{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};Il=Ns;A.TimeOfDay=Il;Ns.NAME="TimeOfDay";var Cl,Us=class extends oe{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};Cl=Us;A.DateTime=Cl;Us.NAME="DateTime";var Nl,Ts=class extends oe{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};Nl=Ts;A.Duration=Nl;Ts.NAME="Duration";var Ul,Ls=class extends oe{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};Ul=Ls;A.TIME=Ul;Ls.NAME="TIME";async function Ds(r,t){let n=await dr.create().encrypt(r,t);return Ae.encode(n)}async function hi(r,t,e){if(r.type==="RSA")return zh(r,t,e);if(r.type==="Ed25519")return jh(r,t,e);if(r.type==="secp256k1")return $h(r,t,e);if(r.type==="ECDSA")return Gh(r,t,e);throw new je}async function jh(r,t,e="libp2p-key"){if(e==="libp2p-key")return Ds(Oe(r),t);throw new _(`export format '${e}' is not supported`)}async function $h(r,t,e="libp2p-key"){if(e==="libp2p-key")return Ds(Oe(r),t);throw new _("Export format is not supported")}async function Gh(r,t,e="libp2p-key"){if(e==="libp2p-key")return Ds(Oe(r),t);throw new _(`export format '${e}' is not supported`)}async function zh(r,t,e="pkcs-8"){if(e==="pkcs-8")return Wh(r,t);if(e==="libp2p-key")return Ds(Oe(r),t);throw new _("Export format is not supported")}async function Wh(r,t){let e=xt.get(),s=new At({value:[new se({value:0}),new At({value:[new jt({value:"1.2.840.113549.1.1.1"}),new Pe]}),new ne({valueHex:r.raw})]}).toBER(),o=new Uint8Array(s,0,s.byteLength),i=Ke(16),a=await Vn(ur,t,i,{c:1e4,dkLen:32}),c=Ke(16),f=await e.subtle.importKey("raw",a,"AES-CBC",!1,["encrypt"]),l=await e.subtle.encrypt({name:"AES-CBC",iv:c},f,o),u=new At({value:[new ne({valueHex:i}),new se({value:1e4}),new se({value:32}),new At({value:[new jt({value:"1.2.840.113549.2.11"}),new Pe]})]}),h=new At({value:[new jt({value:"1.2.840.113549.1.5.13"}),new At({value:[new At({value:[new jt({value:"1.2.840.113549.1.5.12"}),u]}),new At({value:[new jt({value:"2.16.840.1.101.3.4.1.42"}),new ne({valueHex:c})]})]})]}),w=new At({value:[h,new ne({valueHex:l})]}).toBER(),y=new Uint8Array(w,0,w.byteLength);return["-----BEGIN ENCRYPTED PRIVATE KEY-----",...q(y,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
7
+ `)}async function di(r,t){try{let e=await Zh(r,t);return bc(e)}catch{}if(!r.includes("BEGIN"))throw new _("Encrypted key was not a libp2p-key or a PEM file");return Jh(r,t)}async function Zh(r,t){let e=Ae.decode(r);return dr.create().decrypt(e,t)}async function Jh(r,t){let e=xt.get(),n;if(r.includes("-----BEGIN ENCRYPTED PRIVATE KEY-----")){let o=O(r.replace("-----BEGIN ENCRYPTED PRIVATE KEY-----","").replace("-----END ENCRYPTED PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:i}=Rs(o),{iv:a,salt:c,iterations:f,keySize:l,cipherText:u}=Yh(i),h=await Vn(ur,t,c,{c:f,dkLen:l}),m=await e.subtle.importKey("raw",h,"AES-CBC",!1,["decrypt"]),w=sn(await e.subtle.decrypt({name:"AES-CBC",iv:a},m,u)),{result:y}=Rs(w);n=Rl(y)}else if(r.includes("-----BEGIN PRIVATE KEY-----")){let o=O(r.replace("-----BEGIN PRIVATE KEY-----","").replace("-----END PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:i}=Rs(o);n=Rl(i)}else throw new _("Could not parse private key from PEM data");let s=wc(n);if(s.type!=="RSA")throw new _("Could not parse RSA private key from PEM data");return s}function Yh(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");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");let o=n.valueBlock.value[1],i=sn(o.valueBlock.value[0].getValue()),a=1e4,c=32;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");let f=t.valueBlock.value[1].valueBlock.value[1],l=f.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")}}}}let u=sn(f.valueBlock.value[1].getValue());return{cipherText:sn(r.valueBlock.value[1].getValue()),salt:i,iterations:a,keySize:c,iv:u}}function Rl(r){return sn(r.valueBlock.value[2].getValue())}function sn(r){return new Uint8Array(r,0,r.byteLength)}var Xh="/pkcs8/",gi="/info/",on=new WeakMap,Me={minKeyLength:112/8,minSaltLength:128/8,minIterationCount:1e3},pi={dek:{keyLength:512/8,iterationCount:1e4,salt:"you should override this value with a crypto secure random number",hash:"sha2-512"}};function yr(r){return r==null||typeof r!="string"?!1:r===(0,Dl.default)(r.trim())&&r.length>0}async function ct(){let e=Math.random()*800+200;await new Promise(n=>setTimeout(n,e))}function Fe(r){return new Wr(Xh+r)}function mr(r){return new Wr(gi+r)}async function Qh(r){let t=Oe(r),e=await Ye.digest(t);return Q.encode(e.bytes).substring(1)}var Hs=class{components;init;log;self;constructor(t,e){if(this.components=t,this.log=t.logger.forComponent("libp2p:keychain"),this.init=Hc(pi,e),this.self=e.selfKey??"self",this.init.pass!=null&&this.init.pass?.length<20)throw new Error("pass must be least 20 characters");if(this.init.dek?.keyLength!=null&&this.init.dek.keyLength<Me.minKeyLength)throw new Error(`dek.keyLength must be least ${Me.minKeyLength} bytes`);if(this.init.dek?.salt?.length!=null&&this.init.dek.salt.length<Me.minSaltLength)throw new Error(`dek.saltLength must be least ${Me.minSaltLength} bytes`);if(this.init.dek?.iterationCount!=null&&this.init.dek.iterationCount<Me.minIterationCount)throw new Error(`dek.iterationCount must be least ${Me.minIterationCount}`);let n=this.init.pass!=null&&this.init.dek?.salt!=null?zr(this.init.pass,this.init.dek?.salt,this.init.dek?.iterationCount,this.init.dek?.keyLength,this.init.dek?.hash):"";on.set(this,{dek:n})}[Symbol.toStringTag]="@libp2p/keychain";[wi]=["@libp2p/keychain"];static generateOptions(){let t=Object.assign({},pi),e=Math.ceil(Me.minSaltLength/3)*3;return t.dek.salt=q(Ke(e),"base64"),t}static get options(){return pi}async findKeyByName(t){if(!yr(t))throw await ct(),new _(`Invalid key name '${t}'`);let e=mr(t);try{let n=await this.components.datastore.get(e);return JSON.parse(q(n))}catch(n){throw await ct(),this.log.error(n),new ln(`Key '${t}' does not exist.`)}}async findKeyById(t){try{let e={prefix:gi};for await(let n of this.components.datastore.query(e)){let s=JSON.parse(q(n.value));if(s.id===t)return s}throw new _(`Key with id '${t}' does not exist.`)}catch(e){throw await ct(),e}}async importKey(t,e){if(!yr(t))throw await ct(),new _(`Invalid key name '${t}'`);if(e==null)throw await ct(),new _("Key is required");let n=Fe(t);if(await this.components.datastore.has(n))throw await ct(),new _(`Key '${t}' already exists`);let o,i;try{o=await Qh(e);let f=on.get(this);if(f==null)throw new _("dek missing");let l=f.dek;i=await hi(e,l,e.type==="RSA"?"pkcs-8":"libp2p-key")}catch(f){throw await ct(),f}let a={name:t,id:o},c=this.components.datastore.batch();return c.put(n,O(i)),c.put(mr(t),O(JSON.stringify(a))),await c.commit(),a}async exportKey(t){if(!yr(t))throw await ct(),new _(`Invalid key name '${t}'`);let e=Fe(t);try{let n=await this.components.datastore.get(e),s=q(n),o=on.get(this);if(o==null)throw new _("dek missing");let i=o.dek;return await di(s,i)}catch(n){throw await ct(),n}}async removeKey(t){if(!yr(t)||t===this.self)throw await ct(),new _(`Invalid key name '${t}'`);let e=Fe(t),n=await this.findKeyByName(t),s=this.components.datastore.batch();return s.delete(e),s.delete(mr(t)),await s.commit(),n}async listKeys(){let t={prefix:gi},e=[];for await(let n of this.components.datastore.query(t))e.push(JSON.parse(q(n.value)));return e}async renameKey(t,e){if(!yr(t)||t===this.self)throw await ct(),new _(`Invalid old key name '${t}'`);if(!yr(e)||e===this.self)throw await ct(),new _(`Invalid new key name '${e}'`);let n=Fe(t),s=Fe(e),o=mr(t),i=mr(e);if(await this.components.datastore.has(s))throw await ct(),new _(`Key '${e}' already exists`);try{let c=await this.components.datastore.get(n),f=await this.components.datastore.get(o),l=JSON.parse(q(f));l.name=e;let u=this.components.datastore.batch();return u.put(s,c),u.put(i,O(JSON.stringify(l))),u.delete(n),u.delete(o),await u.commit(),l}catch(c){throw await ct(),c}}async rotateKeychainPass(t,e){if(typeof t!="string")throw await ct(),new _(`Invalid old pass type '${typeof t}'`);if(typeof e!="string")throw await ct(),new _(`Invalid new pass type '${typeof e}'`);if(e.length<20)throw await ct(),new _(`Invalid pass length ${e.length}`);this.log("recreating keychain");let n=on.get(this);if(n==null)throw new _("dek missing");let s=n.dek;this.init.pass=e;let o=e!=null&&this.init.dek?.salt!=null?zr(e,this.init.dek.salt,this.init.dek?.iterationCount,this.init.dek?.keyLength,this.init.dek?.hash):"";on.set(this,{dek:o});let i=await this.listKeys();for(let a of i){let c=await this.components.datastore.get(Fe(a.name)),f=q(c),l=await di(f,s),u=o.toString(),h=await hi(l,u,l.type==="RSA"?"pkcs-8":"libp2p-key"),m=this.components.datastore.batch(),w={name:a.name,id:a.id};m.put(Fe(a.name),O(h)),m.put(mr(a.name),O(JSON.stringify(w))),await m.commit()}this.log("keychain reconstructed")}};function td(r={}){return t=>new Hs(t,r)}return $l(ed);})();
8
8
  /*! Bundled license information:
9
9
 
10
10
  pvtsutils/build/index.js:
@@ -37,26 +37,12 @@ pvtsutils/build/index.js:
37
37
  (*! noble-hashes - MIT License (c) 2022 Paul Miller (paulmillr.com) *)
38
38
 
39
39
  @noble/curves/esm/abstract/utils.js:
40
- (*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) *)
41
-
42
40
  @noble/curves/esm/abstract/modular.js:
43
- (*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) *)
44
-
45
41
  @noble/curves/esm/abstract/curve.js:
46
- (*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) *)
47
-
48
42
  @noble/curves/esm/abstract/edwards.js:
49
- (*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) *)
50
-
51
43
  @noble/curves/esm/ed25519.js:
52
- (*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) *)
53
-
54
44
  @noble/curves/esm/abstract/weierstrass.js:
55
- (*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) *)
56
-
57
45
  @noble/curves/esm/_shortw_utils.js:
58
- (*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) *)
59
-
60
46
  @noble/curves/esm/secp256k1.js:
61
47
  (*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) *)
62
48
 
@@ -101,3 +87,4 @@ asn1js/build/index.es.js:
101
87
  *)
102
88
  */
103
89
  return Libp2PKeychain}));
90
+ //# sourceMappingURL=index.min.js.map