@libp2p/keychain 5.2.8-79473c99a → 5.2.8-cb1c14e62

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 on=Object.defineProperty;var Nl=Object.getOwnPropertyDescriptor;var Tl=Object.getOwnPropertyNames;var Ul=Object.getPrototypeOf,_l=Object.prototype.hasOwnProperty;var gr=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),ct=(r,t)=>{for(var e in t)on(r,e,{get:t[e],enumerable:!0})},ui=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of Tl(t))!_l.call(r,s)&&s!==e&&on(r,s,{get:()=>t[s],enumerable:!(n=Nl(t,s))||n.enumerable});return r};var fi=(r,t,e)=>(e=r!=null?Cl(Ul(r)):{},ui(t||!r||!r.__esModule?on(e,"default",{value:r,enumerable:!0}):e,r)),Ll=r=>ui(on({},"__esModule",{value:!0}),r);var Tc=gr((Im,Nc)=>{"use strict";function mh(r){return r>=55296&&r<=56319}function bh(r){return r>=56320&&r<=57343}Nc.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],mh(i)&&bh(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 _c=gr((Cm,Uc)=>{"use strict";function wh(r){return r>=55296&&r<=56319}function xh(r){return r>=56320&&r<=57343}Uc.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),xh(s)?o!=null&&wh(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 Rc=gr((Nm,Lc)=>{"use strict";var vh=Tc(),Eh=_c();Lc.exports=vh.bind(null,Eh)});var Kc=gr((Tm,Hc)=>{"use strict";var Bh=Rc(),Ah=/[\/\?<>\\:\*\|"]/g,Sh=/[\x00-\x1f\x80-\x9f]/g,kh=/^\.+$/,Ih=/^(con|prn|aux|nul|com[0-9]|lpt[0-9])(\..*)?$/i,Ch=/[\. ]+$/;function Dc(r,t){if(typeof r!="string")throw new Error("Input must be string");var e=r.replace(Ah,t).replace(Sh,t).replace(kh,t).replace(Ih,t).replace(Ch,t);return Bh(e,255)}Hc.exports=function(r,t){var e=t&&t.replacement||"",n=Dc(r,e);return e===""?n:Dc(n,"")}});var Vc=gr(fr=>{"use strict";var Th="[object ArrayBuffer]",Gt=class r{static isArrayBuffer(t){return Object.prototype.toString.call(t)===Th}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",Uh=/^[0-9a-f\s]+$/i,_h=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,Lh=/^[a-zA-Z0-9-_]+$/,zn=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=Gt.toUint8Array(t),n="";for(let o=0;o<e.length;o++)n+=String.fromCharCode(e[o]);return decodeURIComponent(escape(n))}},At=class{static toString(t,e=!1){let n=Gt.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}},Wn=class r{static isHex(t){return typeof t===ei&&Uh.test(t)}static isBase64(t){return typeof t===ei&&_h.test(t)}static isBase64Url(t){return typeof t===ei&&Lh.test(t)}static ToString(t,e="utf8"){let n=Gt.toUint8Array(t);switch(e.toLowerCase()){case"utf8":return this.ToUtf8String(n);case"binary":return this.ToBinary(n);case"hex":return this.ToHex(n);case"base64":return this.ToBase64(n);case"base64url":return this.ToBase64Url(n);case"utf16le":return At.toString(n,!0);case"utf16":case"utf16be":return At.toString(n);default:throw new Error(`Unknown type of encoding '${e}'`)}}static FromString(t,e="utf8"){if(!t)return new ArrayBuffer(0);switch(e.toLowerCase()){case"utf8":return this.FromUtf8String(t);case"binary":return this.FromBinary(t);case"hex":return this.FromHex(t);case"base64":return this.FromBase64(t);case"base64url":return this.FromBase64Url(t);case"utf16le":return At.fromString(t,!0);case"utf16":case"utf16be":return At.fromString(t);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToBase64(t){let e=Gt.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 zn.fromString(t);case"utf16":case"utf16be":return At.fromString(t);case"utf16le":case"usc2":return At.fromString(t,!0);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToUtf8String(t,e=r.DEFAULT_UTF8_ENCODING){switch(e){case"ascii":return this.ToBinary(t);case"utf8":return zn.toString(t);case"utf16":case"utf16be":return At.toString(t);case"utf16le":case"usc2":return At.toString(t,!0);default:throw new Error(`Unknown type of encoding '${e}'`)}}static FromBinary(t){let e=t.length,n=new Uint8Array(e);for(let s=0;s<e;s++)n[s]=t.charCodeAt(s);return n.buffer}static ToBinary(t){let e=Gt.toUint8Array(t),n="";for(let s=0;s<e.length;s++)n+=String.fromCharCode(e[s]);return n}static ToHex(t){let e=Gt.toUint8Array(t),n="",s=e.length;for(let o=0;o<s;o++){let i=e[o];i<16&&(n+="0"),n+=i.toString(16)}return n}static FromHex(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isHex(e))throw new TypeError("Argument 'hexString' is not HEX encoded");e.length%2&&(e=`0${e}`);let n=new Uint8Array(e.length/2);for(let s=0;s<e.length;s=s+2){let o=e.slice(s,s+2);n[s/2]=parseInt(o,16)}return n.buffer}static ToUtf16String(t,e=!1){return At.toString(t,e)}static FromUtf16String(t,e=!1){return At.fromString(t,e)}static Base64Padding(t){let e=4-t.length%4;if(e<4)for(let n=0;n<e;n++)t+="=";return t}static formatString(t){return t?.replace(/[\n\r\t ]/g,"")||""}};Wn.DEFAULT_UTF8_ENCODING="utf8";function Rh(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 Dh(...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 Hh(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}fr.BufferSourceConverter=Gt;fr.Convert=Wn;fr.assign=Rh;fr.combine=Dh;fr.isEqual=Hh});var Qh={};ct(Qh,{keychain:()=>Xh});var mr=class extends Error{constructor(t="An error occurred while signing a message"){super(t),this.name="SigningError"}},br=class extends Error{constructor(t="An error occurred while verifying a message"){super(t),this.name="VerificationError"}},an=class extends Error{constructor(t="Missing Web Crypto API"){super(t),this.name="WebCryptoMissingError"}};var hi={get(r=globalThis){let t=r.crypto;if(t?.subtle==null)throw new an("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 Z=hi;var L=class extends Error{static name="InvalidParametersError";constructor(t="Invalid parameters"){super(t),this.name="InvalidParametersError"}},Re=class extends Error{static name="InvalidPublicKeyError";constructor(t="Invalid public key"){super(t),this.name="InvalidPublicKeyError"}},wr=class extends Error{static name="InvalidPrivateKeyError";constructor(t="Invalid private key"){super(t),this.name="InvalidPrivateKeyError"}};var cn=class extends Error{static name="NotFoundError";constructor(t="Not found"){super(t),this.name="NotFoundError"}};var De=class extends Error{static name="UnsupportedKeyTypeError";constructor(t="Unsupported key type"){super(t),this.name="UnsupportedKeyTypeError"}};var di=Symbol.for("@libp2p/service-capabilities"),ad=Symbol.for("@libp2p/service-dependencies");var qs={};ct(qs,{base58btc:()=>J,base58flickr:()=>Pl});var Nd=new Uint8Array(0);function pi(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function Vt(r){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 yi(r){return new TextEncoder().encode(r)}function gi(r){return new TextDecoder().decode(r)}function Rl(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 w=0,y=0,v=0,N=b.length;v!==N&&b[v]===0;)v++,w++;for(var A=(N-v)*l+1>>>0,R=new Uint8Array(A);v!==N;){for(var m=b[v],_=0,U=A-1;(m!==0||_<y)&&U!==-1;U--,_++)m+=256*R[U]>>>0,R[U]=m%a>>>0,m=m/a>>>0;if(m!==0)throw new Error("Non-zero carry");y=_,v++}for(var k=A-y;k!==A&&R[k]===0;)k++;for(var p=c.repeat(w);k<A;++k)p+=r.charAt(R[k]);return p}function h(b){if(typeof b!="string")throw new TypeError("Expected String");if(b.length===0)return new Uint8Array;var w=0;if(b[w]!==" "){for(var y=0,v=0;b[w]===c;)y++,w++;for(var N=(b.length-w)*f+1>>>0,A=new Uint8Array(N);b[w];){var R=e[b.charCodeAt(w)];if(R===255)return;for(var m=0,_=N-1;(R!==0||m<v)&&_!==-1;_--,m++)R+=a*A[_]>>>0,A[_]=R%256>>>0,R=R/256>>>0;if(R!==0)throw new Error("Non-zero carry");v=m,w++}if(b[w]!==" "){for(var U=N-v;U!==N&&A[U]===0;)U++;for(var k=new Uint8Array(y+(N-U)),p=y;U!==N;)k[p++]=A[U++];return k}}}function d(b){var w=h(b);if(w)return w;throw new Error(`Non-${t} character`)}return{encode:u,decodeUnsafe:h,decode:d}}var Dl=Rl,Hl=Dl,bi=Hl;var Ps=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")}},Ms=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 wi(this,t)}},Fs=class{decoders;constructor(t){this.decoders=t}or(t){return wi(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 wi(r,t){return new Fs({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var js=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 Ps(t,e,n),this.decoder=new Ms(t,e,s)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function He({name:r,prefix:t,encode:e,decode:n}){return new js(r,t,e,n)}function Qt({name:r,prefix:t,alphabet:e}){let{encode:n,decode:s}=bi(e,r);return He({prefix:t,name:r,encode:n,decode:o=>Vt(s(o))})}function Kl(r,t,e,n){let s=r.length;for(;r[s-1]==="=";)--s;let o=new Uint8Array(s*e/8|0),i=0,a=0,c=0;for(let f=0;f<s;++f){let l=t[r[f]];if(l===void 0)throw new SyntaxError(`Non-${n} character`);a=a<<e|l,i+=e,i>=8&&(i-=8,o[c++]=255&a>>i)}if(i>=e||(255&a<<8-i)!==0)throw new SyntaxError("Unexpected end of data");return o}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 Ol(r){let t={};for(let e=0;e<r.length;++e)t[r[e]]=e;return t}function G({name:r,prefix:t,bitsPerChar:e,alphabet:n}){let s=Ol(n);return He({prefix:t,name:r,encode(o){return Vl(o,n,e)},decode(o){return Kl(o,s,e,r)}})}var J=Qt({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),Pl=Qt({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var $s={};ct($s,{base32:()=>Ke,base32hex:()=>ql,base32hexpad:()=>Gl,base32hexpadupper:()=>zl,base32hexupper:()=>$l,base32pad:()=>Fl,base32padupper:()=>jl,base32upper:()=>Ml,base32z:()=>Wl});var Ke=G({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),Ml=G({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Fl=G({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),jl=G({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),ql=G({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),$l=G({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),Gl=G({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),zl=G({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),Wl=G({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Gs={};ct(Gs,{base36:()=>xr,base36upper:()=>Zl});var xr=Qt({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),Zl=Qt({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Jl=Ei,xi=128,Yl=127,Xl=~Yl,Ql=Math.pow(2,31);function Ei(r,t,e){t=t||[],e=e||0;for(var n=e;r>=Ql;)t[e++]=r&255|xi,r/=128;for(;r&Xl;)t[e++]=r&255|xi,r>>>=7;return t[e]=r|0,Ei.bytes=e-n+1,t}var tu=zs,eu=128,vi=127;function zs(r,n){var e=0,n=n||0,s=0,o=n,i,a=r.length;do{if(o>=a)throw zs.bytes=0,new RangeError("Could not decode varint");i=r[o++],e+=s<28?(i&vi)<<s:(i&vi)*Math.pow(2,s),s+=7}while(i>=eu);return zs.bytes=o-n,e}var ru=Math.pow(2,7),nu=Math.pow(2,14),su=Math.pow(2,21),ou=Math.pow(2,28),iu=Math.pow(2,35),au=Math.pow(2,42),cu=Math.pow(2,49),lu=Math.pow(2,56),uu=Math.pow(2,63),fu=function(r){return r<ru?1:r<nu?2:r<su?3:r<ou?4:r<iu?5:r<au?6:r<cu?7:r<lu?8:r<uu?9:10},hu={encode:Jl,decode:tu,encodingLength:fu},du=hu,vr=du;function Er(r,t=0){return[vr.decode(r,t),vr.decode.bytes]}function Ve(r,t,e=0){return vr.encode(r,t,e),t}function Oe(r){return vr.encodingLength(r)}function St(r,t){let e=t.byteLength,n=Oe(r),s=n+Oe(e),o=new Uint8Array(s+e);return Ve(r,o,0),Ve(e,o,n),o.set(t,s),new Pe(r,e,t,o)}function Bi(r){let t=Vt(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 Pe(e,s,i,t)}function Ai(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&pi(r.bytes,e.bytes)}}var Pe=class{code;size;digest;bytes;constructor(t,e,n,s){this.code=t,this.size=e,this.digest=n,this.bytes=s}};function Si(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return yu(e,Ws(r),t??J.encoder);default:return gu(e,Ws(r),t??Ke.encoder)}}var ki=new WeakMap;function Ws(r){let t=ki.get(r);if(t==null){let e=new Map;return ki.set(r,e),e}return t}var Et=class r{code;version;multihash;bytes;"/";constructor(t,e,n,s){this.code=e,this.version=t,this.multihash=n,this.bytes=s,this["/"]=s}get asCID(){return this}get byteOffset(){return this.bytes.byteOffset}get byteLength(){return this.bytes.byteLength}toV0(){switch(this.version){case 0:return this;case 1:{let{code:t,multihash:e}=this;if(t!==Ar)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==mu)throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");return r.createV0(e)}default:throw Error(`Can not convert CID version ${this.version} to version 0. This is a bug please report`)}}toV1(){switch(this.version){case 0:{let{code:t,digest:e}=this.multihash,n=St(t,e);return r.createV1(this.code,n)}case 1:return this;default:throw Error(`Can not convert CID version ${this.version} to version 1. This is a bug please report`)}}equals(t){return r.equals(this,t)}static equals(t,e){let n=e;return n!=null&&t.code===n.code&&t.version===n.version&&Ai(t.multihash,n.multihash)}toString(t){return Si(this,t)}toJSON(){return{"/":Si(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??Ii(n,s,o.bytes))}else if(e[bu]===!0){let{version:n,multihash:s,code:o}=e,i=Bi(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!==Ar)throw new Error(`Version 0 CID must use dag-pb (code: ${Ar}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let s=Ii(t,e,n.bytes);return new r(t,e,n,s)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,Ar,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=Vt(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 Pe(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=Ar;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]=pu(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 Ws(o).set(n,t),o}};function pu(r,t){switch(r[0]){case"Q":{let e=t??J;return[J.prefix,e.decode(`${J.prefix}${r}`)]}case J.prefix:{let e=t??J;return[J.prefix,e.decode(r)]}case Ke.prefix:{let e=t??Ke;return[Ke.prefix,e.decode(r)]}case xr.prefix:{let e=t??xr;return[xr.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 yu(r,t,e){let{prefix:n}=e;if(n!==J.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 Ar=112,mu=18;function Ii(r,t,e){let n=Oe(r),s=n+Oe(t),o=new Uint8Array(s+e.byteLength);return Ve(r,o,0),Ve(t,o,n),o.set(e,s),o}var bu=Symbol.for("@ipld/js-cid/CID");var Zs={};ct(Zs,{identity:()=>he});var Ci=0,wu="identity",Ni=Vt;function xu(r){return St(Ci,Ni(r))}var he={code:Ci,name:wu,encode:Ni,digest:xu};function yt(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function Ot(r=0){return new Uint8Array(r)}function wt(r=0){return new Uint8Array(r)}function Me(r,t){t==null&&(t=r.reduce((s,o)=>s+o.length,0));let e=wt(t),n=0;for(let s of r)e.set(s,n),n+=s.length;return e}var Ui=Symbol.for("@achingbrain/uint8arraylist");function Ti(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 un(r){return!!r?.[Ui]}var lt=class r{bufs;length;[Ui]=!0;constructor(...t){this.bufs=[],this.length=0,t.length>0&&this.appendAll(t)}*[Symbol.iterator](){yield*this.bufs}get byteLength(){return this.length}append(...t){this.appendAll(t)}appendAll(t){let e=0;for(let n of t)if(n instanceof Uint8Array)e+=n.byteLength,this.bufs.push(n);else if(un(n))e+=n.byteLength,this.bufs.push(...n.bufs);else throw new Error("Could not append value, must be an Uint8Array or a Uint8ArrayList");this.length+=e}prepend(...t){this.prependAll(t)}prependAll(t){let e=0;for(let n of t.reverse())if(n instanceof Uint8Array)e+=n.byteLength,this.bufs.unshift(n);else if(un(n))e+=n.byteLength,this.bufs.unshift(...n.bufs);else throw new Error("Could not prepend value, must be an Uint8Array or a Uint8ArrayList");this.length+=e}get(t){let e=Ti(this.bufs,t);return e.buf[e.index]}set(t,e){let n=Ti(this.bufs,t);n.buf[n.index]=e}write(t,e=0){if(t instanceof Uint8Array)for(let n=0;n<t.length;n++)this.set(e+n,t[n]);else if(un(t))for(let n=0;n<t.length;n++)this.set(e+n,t.get(n));else throw new Error("Could not write value, must be an Uint8Array or a Uint8ArrayList")}consume(t){if(t=Math.trunc(t),!(Number.isNaN(t)||t<=0)){if(t===this.byteLength){this.bufs=[],this.length=0;return}for(;this.bufs.length>0;)if(t>=this.bufs[0].byteLength)t-=this.bufs[0].byteLength,this.length-=this.bufs[0].byteLength,this.bufs.shift();else{this.bufs[0]=this.bufs[0].subarray(t),this.length-=t;break}}}slice(t,e){let{bufs:n,length:s}=this._subList(t,e);return Me(n,s)}subarray(t,e){let{bufs:n,length:s}=this._subList(t,e);return n.length===1?n[0]:Me(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(!un(t)&&!(t instanceof Uint8Array))throw new TypeError('The "value" argument must be a Uint8ArrayList or Uint8Array');let n=t instanceof Uint8Array?t:t.subarray();if(e=Number(e??0),isNaN(e)&&(e=0),e<0&&(e=this.length+e),e<0&&(e=0),t.length===0)return e>this.length?this.length:e;let 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 d=this.get(u+h);if(n[h]!==d){l=Math.max(1,h-a[d]);break}}if(l===0)return u}return-1}getInt8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getInt8(0)}setInt8(t,e){let n=wt(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setInt8(0,e),this.write(n,t)}getInt16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt16(0,e)}setInt16(t,e,n){let s=Ot(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=Ot(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=Ot(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigInt64(0,e,n),this.write(s,t)}getUint8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getUint8(0)}setUint8(t,e){let n=wt(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setUint8(0,e),this.write(n,t)}getUint16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint16(0,e)}setUint16(t,e,n){let s=Ot(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=Ot(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=Ot(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=Ot(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=Ot(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(!yt(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 Js={};ct(Js,{base10:()=>vu});var vu=Qt({prefix:"9",name:"base10",alphabet:"0123456789"});var Ys={};ct(Ys,{base16:()=>Eu,base16upper:()=>Bu});var Eu=G({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Bu=G({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Xs={};ct(Xs,{base2:()=>Au});var Au=G({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Qs={};ct(Qs,{base256emoji:()=>Nu});var _i=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}"),Su=_i.reduce((r,t,e)=>(r[e]=t,r),[]),ku=_i.reduce((r,t,e)=>{let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);return r[n]=e,r},[]);function Iu(r){return r.reduce((t,e)=>(t+=Su[e],t),"")}function Cu(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 Nu=He({prefix:"\u{1F680}",name:"base256emoji",encode:Iu,decode:Cu});var to={};ct(to,{base64:()=>de,base64pad:()=>Tu,base64url:()=>Uu,base64urlpad:()=>_u});var de=G({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),Tu=G({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Uu=G({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),_u=G({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var eo={};ct(eo,{base8:()=>Lu});var Lu=G({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var ro={};ct(ro,{identity:()=>Ru});var Ru=He({prefix:"\0",name:"identity",encode:r=>gi(r),decode:r=>yi(r)});var h0=new TextEncoder,d0=new TextDecoder;var oo={};ct(oo,{sha256:()=>Fe,sha512:()=>Ku});function so({name:r,code:t,encode:e}){return new no(r,t,e)}var no=class{name;code;encode;constructor(t,e,n){this.name=t,this.code=e,this.encode=n}digest(t){if(t instanceof Uint8Array){let e=this.encode(t);return e instanceof Uint8Array?St(this.code,e):e.then(n=>St(this.code,n))}else throw Error("Unknown type, must be binary type")}};function Ri(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var Fe=so({name:"sha2-256",code:18,encode:Ri("SHA-256")}),Ku=so({name:"sha2-512",code:19,encode:Ri("SHA-512")});var io={...ro,...Xs,...eo,...Js,...Ys,...$s,...Gs,...qs,...to,...Qs},S0={...oo,...Zs};function Hi(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var Di=Hi("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),ao=Hi("ascii","a",r=>{let t="a";for(let e=0;e<r.length;e++)t+=String.fromCharCode(r[e]);return t},r=>{r=r.substring(1);let t=wt(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),Vu={utf8:Di,"utf-8":Di,hex:io.base16,latin1:ao,ascii:ao,binary:ao,...io},fn=Vu;function V(r,t="utf8"){let e=fn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function P(r,t="utf8"){let e=fn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}var Ou=parseInt("11111",2),co=parseInt("10000000",2),Pu=parseInt("01111111",2),Ki={0:Sr,1:Sr,2:Mu,3:qu,4:$u,5:ju,6:Fu,16:Sr,22:Sr,48:Sr};function kt(r,t={offset:0}){let e=r[t.offset]&Ou;if(t.offset++,Ki[e]!=null)return Ki[e](r,t);throw new Error("No decoder for tag "+e)}function kr(r,t){let e=0;if((r[t.offset]&co)===co){let n=r[t.offset]&Pu,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 Sr(r,t){kr(r,t);let e=[];for(;!(t.offset>=r.byteLength);){let n=kt(r,t);if(n===null)break;e.push(n)}return e}function Mu(r,t){let e=kr(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 Fu(r,t){let e=kr(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 ju(r,t){return t.offset++,null}function qu(r,t){let e=kr(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 $u(r,t){let e=kr(r,t),n=r.subarray(t.offset,t.offset+e);return t.offset+=e,n}function Gu(r){let t=r.toString(16);t.length%2===1&&(t="0"+t);let e=new lt;for(let n=0;n<t.length;n+=2)e.append(Uint8Array.from([parseInt(`${t[n]}${t[n+1]}`,16)]));return e}function hn(r){if(r.byteLength<128)return Uint8Array.from([r.byteLength]);let t=Gu(r.byteLength);return new lt(Uint8Array.from([t.byteLength|co]),t)}function ut(r){let t=new lt,e=128;return(r.subarray()[0]&e)===e&&t.append(Uint8Array.from([0])),t.append(r),new lt(Uint8Array.from([2]),hn(t),t)}function Ir(r){let t=Uint8Array.from([0]),e=new lt(t,r);return new lt(Uint8Array.from([3]),hn(e),e)}function Vi(r){return new lt(Uint8Array.from([4]),hn(r),r)}function It(r,t=48){let e=new lt;for(let n of r)e.append(n);return new lt(Uint8Array.from([t]),hn(e),e)}var Oi="1.2.840.10045.3.1.7",Pi="1.3.132.0.34",Mi="1.3.132.0.35";async function Fi(r,t,e){let n=await crypto.subtle.importKey("jwk",r,{name:"ECDSA",namedCurve:r.crv??"P-256"},!1,["sign"]);e?.signal?.throwIfAborted();let s=await crypto.subtle.sign({name:"ECDSA",hash:{name:"SHA-256"}},n,t.subarray());return e?.signal?.throwIfAborted(),new Uint8Array(s,0,s.byteLength)}async function ji(r,t,e,n){let s=await crypto.subtle.importKey("jwk",r,{name:"ECDSA",namedCurve:r.crv??"P-256"},!1,["verify"]);n?.signal?.throwIfAborted();let o=await crypto.subtle.verify({name:"ECDSA",hash:{name:"SHA-256"}},s,t,e.subarray());return n?.signal?.throwIfAborted(),o}var zu=Uint8Array.from([6,8,42,134,72,206,61,3,1,7]),Wu=Uint8Array.from([6,5,43,129,4,0,34]),Zu=Uint8Array.from([6,5,43,129,4,0,35]),Ju={ext:!0,kty:"EC",crv:"P-256"},Yu={ext:!0,kty:"EC",crv:"P-384"},Xu={ext:!0,kty:"EC",crv:"P-521"},lo=32,uo=48,fo=66;function qi(r){let t=kt(r);return ho(t)}function ho(r){let t=r[1],e=P(t,"base64url"),n=r[2][1][0],s=1,o,i;if(t.byteLength===lo)return o=P(n.subarray(s,s+lo),"base64url"),i=P(n.subarray(s+lo),"base64url"),new je({...Ju,key_ops:["sign"],d:e,x:o,y:i});if(t.byteLength===uo)return o=P(n.subarray(s,s+uo),"base64url"),i=P(n.subarray(s+uo),"base64url"),new je({...Yu,key_ops:["sign"],d:e,x:o,y:i});if(t.byteLength===fo)return o=P(n.subarray(s,s+fo),"base64url"),i=P(n.subarray(s+fo),"base64url"),new je({...Xu,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 $i(r){return It([ut(Uint8Array.from([1])),Vi(V(r.d??"","base64url")),It([zi(r.crv)],160),It([Ir(new lt(Uint8Array.from([4]),V(r.x??"","base64url"),V(r.y??"","base64url")))],161)]).subarray()}function Gi(r){return It([ut(Uint8Array.from([1])),It([zi(r.crv)],160),It([Ir(new lt(Uint8Array.from([4]),V(r.x??"","base64url"),V(r.y??"","base64url")))],161)]).subarray()}function zi(r){if(r==="P-256")return zu;if(r==="P-384")return Wu;if(r==="P-521")return Zu;throw new L(`Invalid curve ${r}`)}var dn=class{type="ECDSA";jwk;_raw;constructor(t){this.jwk=t}get raw(){return this._raw==null&&(this._raw=Gi(this.jwk)),this._raw}toMultihash(){return he.digest(qe(this))}toCID(){return Et.createV1(114,this.toMultihash())}toString(){return J.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:yt(this.raw,t.raw)}async verify(t,e,n){return ji(this.jwk,e,t,n)}},je=class{type="ECDSA";jwk;publicKey;_raw;constructor(t){this.jwk=t,this.publicKey=new dn({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=$i(this.jwk)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:yt(this.raw,t.raw)}async sign(t,e){return Fi(this.jwk,t,e)}};var pe=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;function Ge(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function Mt(r){if(!Number.isSafeInteger(r)||r<0)throw new Error("positive integer expected, got "+r)}function tt(r,...t){if(!Ge(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 pn(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.createHasher");Mt(r.outputLen),Mt(r.blockLen)}function ze(r,t=!0){if(r.destroyed)throw new Error("Hash instance has been destroyed");if(t&&r.finished)throw new Error("Hash#digest() has already been called")}function Zi(r,t){tt(r);let e=t.outputLen;if(r.length<e)throw new Error("digestInto() expects output buffer of length at least "+e)}function gt(...r){for(let t=0;t<r.length;t++)r[t].fill(0)}function ye(r){return new DataView(r.buffer,r.byteOffset,r.byteLength)}function Ct(r,t){return r<<32-t|r>>>t}function yn(r,t){return r<<t|r>>>32-t>>>0}var Ji=typeof Uint8Array.from([]).toHex=="function"&&typeof Uint8Array.fromHex=="function",Qu=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function _t(r){if(tt(r),Ji)return r.toHex();let t="";for(let e=0;e<r.length;e++)t+=Qu[r[e]];return t}var Pt={_0:48,_9:57,A:65,F:70,a:97,f:102};function Wi(r){if(r>=Pt._0&&r<=Pt._9)return r-Pt._0;if(r>=Pt.A&&r<=Pt.F)return r-(Pt.A-10);if(r>=Pt.a&&r<=Pt.f)return r-(Pt.a-10)}function We(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);if(Ji)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=Wi(r.charCodeAt(o)),a=Wi(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}var tf=async()=>{};async function Yi(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 tf(),n+=o)}}function po(r){if(typeof r!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(r))}function Cr(r){return typeof r=="string"&&(r=po(r)),tt(r),r}function yo(r){return typeof r=="string"&&(r=po(r)),tt(r),r}function xt(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];tt(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 Xi(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 $e=class{};function Nr(r){let t=n=>r().update(Cr(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function ge(r=32){if(pe&&typeof pe.getRandomValues=="function")return pe.getRandomValues(new Uint8Array(r));if(pe&&typeof pe.randomBytes=="function")return Uint8Array.from(pe.randomBytes(r));throw new Error("crypto.getRandomValues must be defined")}function ef(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 gn(r,t,e){return r&t^~r&e}function mn(r,t,e){return r&t^r&e^t&e}var me=class extends $e{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=ye(this.buffer)}update(t){ze(this),t=Cr(t),tt(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=ye(t);for(;s<=o-i;i+=s)this.process(c,i);continue}n.set(t.subarray(i,i+a),this.pos),this.pos+=a,i+=a,this.pos===s&&(this.process(e,0),this.pos=0)}return this.length+=t.length,this.roundClean(),this}digestInto(t){ze(this),Zi(t,this),this.finished=!0;let{buffer:e,view:n,blockLen:s,isLE:o}=this,{pos:i}=this;e[i++]=128,gt(this.buffer.subarray(i)),this.padOffset>s-i&&(this.process(n,0),i=0);for(let u=i;u<s;u++)e[u]=0;ef(n,s-8,BigInt(this.length*8),o),this.process(n,0);let a=ye(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()}},Ft=Uint32Array.from([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]);var et=Uint32Array.from([1779033703,4089235720,3144134277,2227873595,1013904242,4271175723,2773480762,1595750129,1359893119,2917565137,2600822924,725511199,528734635,4215389547,1541459225,327033209]);var bn=BigInt(4294967295),Qi=BigInt(32);function rf(r,t=!1){return t?{h:Number(r&bn),l:Number(r>>Qi&bn)}:{h:Number(r>>Qi&bn)|0,l:Number(r&bn)|0}}function ta(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}=rf(r[o],t);[n[o],s[o]]=[i,a]}return[n,s]}var go=(r,t,e)=>r>>>e,mo=(r,t,e)=>r<<32-e|t>>>e,be=(r,t,e)=>r>>>e|t<<32-e,we=(r,t,e)=>r<<32-e|t>>>e,Tr=(r,t,e)=>r<<64-e|t>>>e-32,Ur=(r,t,e)=>r>>>e-32|t<<64-e;function Lt(r,t,e,n){let s=(t>>>0)+(n>>>0);return{h:r+e+(s/2**32|0)|0,l:s|0}}var ea=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),ra=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,na=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),sa=(r,t,e,n,s)=>t+e+n+s+(r/2**32|0)|0,oa=(r,t,e,n,s)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(s>>>0),ia=(r,t,e,n,s,o)=>t+e+n+s+o+(r/2**32|0)|0;var sf=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]),te=new Uint32Array(64),wn=class extends me{constructor(t=32){super(64,t,8,!1),this.A=Ft[0]|0,this.B=Ft[1]|0,this.C=Ft[2]|0,this.D=Ft[3]|0,this.E=Ft[4]|0,this.F=Ft[5]|0,this.G=Ft[6]|0,this.H=Ft[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)te[u]=t.getUint32(e,!1);for(let u=16;u<64;u++){let h=te[u-15],d=te[u-2],b=Ct(h,7)^Ct(h,18)^h>>>3,w=Ct(d,17)^Ct(d,19)^d>>>10;te[u]=w+te[u-7]+b+te[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=Ct(a,6)^Ct(a,11)^Ct(a,25),d=l+h+gn(a,c,f)+sf[u]+te[u]|0,w=(Ct(n,2)^Ct(n,13)^Ct(n,22))+mn(n,s,o)|0;l=f,f=c,c=a,a=i+d|0,i=o,o=s,s=n,n=d+w|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(){gt(te)}destroy(){this.set(0,0,0,0,0,0,0,0),gt(this.buffer)}};var aa=ta(["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))),of=aa[0],af=aa[1],ee=new Uint32Array(80),re=new Uint32Array(80),xn=class extends me{constructor(t=64){super(128,t,16,!1),this.Ah=et[0]|0,this.Al=et[1]|0,this.Bh=et[2]|0,this.Bl=et[3]|0,this.Ch=et[4]|0,this.Cl=et[5]|0,this.Dh=et[6]|0,this.Dl=et[7]|0,this.Eh=et[8]|0,this.El=et[9]|0,this.Fh=et[10]|0,this.Fl=et[11]|0,this.Gh=et[12]|0,this.Gl=et[13]|0,this.Hh=et[14]|0,this.Hl=et[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:d,Gl:b,Hh:w,Hl:y}=this;return[t,e,n,s,o,i,a,c,f,l,u,h,d,b,w,y]}set(t,e,n,s,o,i,a,c,f,l,u,h,d,b,w,y){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=d|0,this.Gl=b|0,this.Hh=w|0,this.Hl=y|0}process(t,e){for(let A=0;A<16;A++,e+=4)ee[A]=t.getUint32(e),re[A]=t.getUint32(e+=4);for(let A=16;A<80;A++){let R=ee[A-15]|0,m=re[A-15]|0,_=be(R,m,1)^be(R,m,8)^go(R,m,7),U=we(R,m,1)^we(R,m,8)^mo(R,m,7),k=ee[A-2]|0,p=re[A-2]|0,E=be(k,p,19)^Tr(k,p,61)^go(k,p,6),g=we(k,p,19)^Ur(k,p,61)^mo(k,p,6),x=na(U,g,re[A-7],re[A-16]),B=sa(x,_,E,ee[A-7],ee[A-16]);ee[A]=B|0,re[A]=x|0}let{Ah:n,Al:s,Bh:o,Bl:i,Ch:a,Cl:c,Dh:f,Dl:l,Eh:u,El:h,Fh:d,Fl:b,Gh:w,Gl:y,Hh:v,Hl:N}=this;for(let A=0;A<80;A++){let R=be(u,h,14)^be(u,h,18)^Tr(u,h,41),m=we(u,h,14)^we(u,h,18)^Ur(u,h,41),_=u&d^~u&w,U=h&b^~h&y,k=oa(N,m,U,af[A],re[A]),p=ia(k,v,R,_,of[A],ee[A]),E=k|0,g=be(n,s,28)^Tr(n,s,34)^Tr(n,s,39),x=we(n,s,28)^Ur(n,s,34)^Ur(n,s,39),B=n&o^n&a^o&a,I=s&i^s&c^i&c;v=w|0,N=y|0,w=d|0,y=b|0,d=u|0,b=h|0,{h:u,l:h}=Lt(f|0,l|0,p|0,E|0),f=a|0,l=c|0,a=o|0,c=i|0,o=n|0,i=s|0;let S=ea(E,x,I);n=ra(S,p,g,B),s=S|0}({h:n,l:s}=Lt(this.Ah|0,this.Al|0,n|0,s|0)),{h:o,l:i}=Lt(this.Bh|0,this.Bl|0,o|0,i|0),{h:a,l:c}=Lt(this.Ch|0,this.Cl|0,a|0,c|0),{h:f,l}=Lt(this.Dh|0,this.Dl|0,f|0,l|0),{h:u,l:h}=Lt(this.Eh|0,this.El|0,u|0,h|0),{h:d,l:b}=Lt(this.Fh|0,this.Fl|0,d|0,b|0),{h:w,l:y}=Lt(this.Gh|0,this.Gl|0,w|0,y|0),{h:v,l:N}=Lt(this.Hh|0,this.Hl|0,v|0,N|0),this.set(n,s,o,i,a,c,f,l,u,h,d,b,w,y,v,N)}roundClean(){gt(ee,re)}destroy(){gt(this.buffer),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}};var vn=Nr(()=>new wn);var En=Nr(()=>new xn);var xo=BigInt(0),wo=BigInt(1);function jt(r,t){if(typeof t!="boolean")throw new Error(r+" boolean expected, got "+t)}function _r(r){let t=r.toString(16);return t.length&1?"0"+t:t}function ca(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return r===""?xo:BigInt("0x"+r)}function Ze(r){return ca(_t(r))}function xe(r){return tt(r),ca(_t(Uint8Array.from(r).reverse()))}function Bn(r,t){return We(r.toString(16).padStart(t*2,"0"))}function Je(r,t){return Bn(r,t).reverse()}function j(r,t,e){let n;if(typeof t=="string")try{n=We(t)}catch(o){throw new Error(r+" must be hex string or Uint8Array, cause: "+o)}else if(Ge(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}var bo=r=>typeof r=="bigint"&&xo<=r;function la(r,t,e){return bo(r)&&bo(t)&&bo(e)&&t<=r&&r<e}function ne(r,t,e,n){if(!la(t,e,n))throw new Error("expected valid "+r+": "+e+" <= n < "+n+", got "+t)}function ua(r){let t;for(t=0;r>xo;r>>=wo,t+=1);return t}var ve=r=>(wo<<BigInt(r))-wo;function fa(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=d=>new Uint8Array(d),s=d=>Uint8Array.of(d),o=n(r),i=n(r),a=0,c=()=>{o.fill(1),i.fill(0),a=0},f=(...d)=>e(i,o,...d),l=(d=n(0))=>{i=f(s(0),d),o=f(),d.length!==0&&(i=f(s(1),d),o=f())},u=()=>{if(a++>=1e3)throw new Error("drbg: tried 1000 values");let d=0,b=[];for(;d<t;){o=f();let w=o.slice();b.push(w),d+=o.length}return xt(...b)};return(d,b)=>{c(),l(d);let w;for(;!(w=b(u()));)l();return c(),w}}function se(r,t,e={}){if(!r||typeof r!="object")throw new Error("expected valid options object");function n(s,o,i){let a=r[s];if(i&&a===void 0)return;let c=typeof a;if(c!==o||a===null)throw new Error(`param "${s}" is invalid: expected ${o}, got ${c}`)}Object.entries(t).forEach(([s,o])=>n(s,o,!1)),Object.entries(e).forEach(([s,o])=>n(s,o,!0))}function Ye(r){let t=new WeakMap;return(e,...n)=>{let s=t.get(e);if(s!==void 0)return s;let o=r(e,...n);return t.set(e,o),o}}var ft=BigInt(0),Q=BigInt(1),Ee=BigInt(2),cf=BigInt(3),pa=BigInt(4),ya=BigInt(5),ga=BigInt(8);function $(r,t){let e=r%t;return e>=ft?e:t+e}function q(r,t,e){let n=r;for(;t-- >ft;)n*=n,n%=e;return n}function ha(r,t){if(r===ft)throw new Error("invert: expected non-zero number");if(t<=ft)throw new Error("invert: expected positive modulus, got "+t);let e=$(r,t),n=t,s=ft,o=Q,i=Q,a=ft;for(;e!==ft;){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!==Q)throw new Error("invert: does not exist");return $(s,t)}function ma(r,t){let e=(r.ORDER+Q)/pa,n=r.pow(t,e);if(!r.eql(r.sqr(n),t))throw new Error("Cannot find square root");return n}function lf(r,t){let e=(r.ORDER-ya)/ga,n=r.mul(t,Ee),s=r.pow(n,e),o=r.mul(t,s),i=r.mul(r.mul(o,Ee),s),a=r.mul(o,r.sub(i,r.ONE));if(!r.eql(r.sqr(a),t))throw new Error("Cannot find square root");return a}function uf(r){if(r<BigInt(3))throw new Error("sqrt is not defined for small field");let t=r-Q,e=0;for(;t%Ee===ft;)t/=Ee,e++;let n=Ee,s=Nt(r);for(;da(s,n)===1;)if(n++>1e3)throw new Error("Cannot find square root: probably non-prime P");if(e===1)return ma;let o=s.pow(n,t),i=(t+Q)/Ee;return function(c,f){if(c.is0(f))return f;if(da(c,f)!==1)throw new Error("Cannot find square root");let l=e,u=c.mul(c.ONE,o),h=c.pow(f,t),d=c.pow(f,i);for(;!c.eql(h,c.ONE);){if(c.is0(h))return c.ZERO;let b=1,w=c.sqr(h);for(;!c.eql(w,c.ONE);)if(b++,w=c.sqr(w),b===l)throw new Error("Cannot find square root");let y=Q<<BigInt(l-b-1),v=c.pow(u,y);l=b,u=c.sqr(v),h=c.mul(h,u),d=c.mul(d,v)}return d}}function ff(r){return r%pa===cf?ma:r%ga===ya?lf:uf(r)}var ba=(r,t)=>($(r,t)&Q)===Q,hf=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function vo(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"number",BITS:"number"},e=hf.reduce((n,s)=>(n[s]="function",n),t);return se(r,e),r}function df(r,t,e){if(e<ft)throw new Error("invalid exponent, negatives unsupported");if(e===ft)return r.ONE;if(e===Q)return t;let n=r.ONE,s=t;for(;e>ft;)e&Q&&(n=r.mul(n,s)),s=r.sqr(s),e>>=Q;return n}function Lr(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 da(r,t){let e=(r.ORDER-Q)/Ee,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("invalid Legendre symbol result");return s?1:o?0:-1}function wa(r,t){t!==void 0&&Mt(t);let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function Nt(r,t,e=!1,n={}){if(r<=ft)throw new Error("invalid field: expected ORDER > 0, got "+r);let s,o;if(typeof t=="object"&&t!=null){if(n.sqrt||e)throw new Error("cannot specify opts in two arguments");let l=t;l.BITS&&(s=l.BITS),l.sqrt&&(o=l.sqrt),typeof l.isLE=="boolean"&&(e=l.isLE)}else typeof t=="number"&&(s=t),n.sqrt&&(o=n.sqrt);let{nBitLength:i,nByteLength:a}=wa(r,s);if(a>2048)throw new Error("invalid field: expected ORDER of <= 2048 bytes");let c,f=Object.freeze({ORDER:r,isLE:e,BITS:i,BYTES:a,MASK:ve(i),ZERO:ft,ONE:Q,create:l=>$(l,r),isValid:l=>{if(typeof l!="bigint")throw new Error("invalid field element: expected bigint, got "+typeof l);return ft<=l&&l<r},is0:l=>l===ft,isValidNot0:l=>!f.is0(l)&&f.isValid(l),isOdd:l=>(l&Q)===Q,neg:l=>$(-l,r),eql:(l,u)=>l===u,sqr:l=>$(l*l,r),add:(l,u)=>$(l+u,r),sub:(l,u)=>$(l-u,r),mul:(l,u)=>$(l*u,r),pow:(l,u)=>df(f,l,u),div:(l,u)=>$(l*ha(u,r),r),sqrN:l=>l*l,addN:(l,u)=>l+u,subN:(l,u)=>l-u,mulN:(l,u)=>l*u,inv:l=>ha(l,r),sqrt:o||(l=>(c||(c=ff(r)),c(f,l))),toBytes:l=>e?Je(l,a):Bn(l,a),fromBytes:l=>{if(l.length!==a)throw new Error("Field.fromBytes: expected "+a+" bytes, got "+l.length);return e?xe(l):Ze(l)},invertBatch:l=>Lr(f,l),cmov:(l,u,h)=>h?u:l});return Object.freeze(f)}function xa(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 Eo(r){let t=xa(r);return t+Math.ceil(t/2)}function va(r,t,e=!1){let n=r.length,s=xa(t),o=Eo(t);if(n<16||n<o||n>1024)throw new Error("expected "+o+"-1024 bytes of input, got "+n);let i=e?xe(r):Ze(r),a=$(i,t-Q)+Q;return e?Je(a,s):Bn(a,s)}var Qe=BigInt(0),Be=BigInt(1);function Xe(r,t){let e=t.negate();return r?e:t}function An(r,t,e){let n=t==="pz"?i=>i.pz:i=>i.ez,s=Lr(r.Fp,e.map(n));return e.map((i,a)=>i.toAffine(s[a])).map(r.fromAffine)}function Sa(r,t){if(!Number.isSafeInteger(r)||r<=0||r>t)throw new Error("invalid window size, expected [1.."+t+"], got W="+r)}function Bo(r,t){Sa(r,t);let e=Math.ceil(t/r)+1,n=2**(r-1),s=2**r,o=ve(r),i=BigInt(r);return{windows:e,windowSize:n,mask:o,maxNumber:s,shiftBy:i}}function Ea(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+=Be);let f=t*n,l=f+Math.abs(a)-1,u=a===0,h=a<0,d=t%2!==0;return{nextN:c,offset:l,isZero:u,isNeg:h,isNegF:d,offsetF:f}}function pf(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 yf(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 Ao=new WeakMap,ka=new WeakMap;function So(r){return ka.get(r)||1}function Ba(r){if(r!==Qe)throw new Error("invalid wNAF")}function Sn(r,t){return{constTimeNegate:Xe,hasPrecomputes(e){return So(e)!==1},unsafeLadder(e,n,s=r.ZERO){let o=e;for(;n>Qe;)n&Be&&(s=s.add(o)),o=o.double(),n>>=Be;return s},precomputeWindow(e,n){let{windows:s,windowSize:o}=Bo(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=Bo(e,t);for(let c=0;c<a.windows;c++){let{nextN:f,offset:l,isZero:u,isNeg:h,isNegF:d,offsetF:b}=Ea(s,c,a);s=f,u?i=i.add(Xe(d,n[b])):o=o.add(Xe(h,n[l]))}return Ba(s),{p:o,f:i}},wNAFUnsafe(e,n,s,o=r.ZERO){let i=Bo(e,t);for(let a=0;a<i.windows&&s!==Qe;a++){let{nextN:c,offset:f,isZero:l,isNeg:u}=Ea(s,a,i);if(s=c,!l){let h=n[f];o=o.add(u?h.negate():h)}}return Ba(s),o},getPrecomputes(e,n,s){let o=Ao.get(n);return o||(o=this.precomputeWindow(n,e),e!==1&&(typeof s=="function"&&(o=s(o)),Ao.set(n,o))),o},wNAFCached(e,n,s){let o=So(e);return this.wNAF(o,this.getPrecomputes(o,e,s),n)},wNAFCachedUnsafe(e,n,s,o){let i=So(e);return i===1?this.unsafeLadder(e,n,o):this.wNAFUnsafe(i,this.getPrecomputes(i,e,s),n,o)},setWindowSize(e,n){Sa(n,t),ka.set(e,n),Ao.delete(e)}}}function Ia(r,t,e,n){let s=t,o=r.ZERO,i=r.ZERO;for(;e>Qe||n>Qe;)e&Be&&(o=o.add(s)),n&Be&&(i=i.add(s)),s=s.double(),e>>=Be,n>>=Be;return{p1:o,p2:i}}function kn(r,t,e,n){pf(e,r),yf(n,t);let s=e.length,o=n.length;if(s!==o)throw new Error("arrays of points and scalars must have equal length");let i=r.ZERO,a=ua(BigInt(s)),c=1;a>12?c=a-3:a>4?c=a-2:a>0&&(c=2);let f=ve(c),l=new Array(Number(f)+1).fill(i),u=Math.floor((t.BITS-1)/c)*c,h=i;for(let d=u;d>=0;d-=c){l.fill(i);for(let w=0;w<o;w++){let y=n[w],v=Number(y>>BigInt(d)&f);l[v]=l[v].add(e[w])}let b=i;for(let w=l.length-1,y=i;w>0;w--)y=y.add(l[w]),b=b.add(y);if(h=h.add(b),d!==0)for(let w=0;w<c;w++)h=h.double()}return h}function Aa(r,t){if(t){if(t.ORDER!==r)throw new Error("Field.ORDER must match order: Fp == p, Fn == n");return vo(t),t}else return Nt(r)}function In(r,t,e={}){if(!t||typeof t!="object")throw new Error(`expected valid ${r} CURVE object`);for(let a of["p","n","h"]){let c=t[a];if(!(typeof c=="bigint"&&c>Qe))throw new Error(`CURVE.${a} must be positive bigint`)}let n=Aa(t.p,e.Fp),s=Aa(t.n,e.Fn),i=["Gx","Gy","a",r==="weierstrass"?"b":"d"];for(let a of i)if(!n.isValid(t[a]))throw new Error(`CURVE.${a} must be valid field element of CURVE.Fp`);return{Fp:n,Fn:s}}var Rt=BigInt(0),ht=BigInt(1),ko=BigInt(2),gf=BigInt(8),mf={zip215:!0};function bf(r,t,e,n){let s=r.sqr(e),o=r.sqr(n),i=r.add(r.mul(t.a,s),o),a=r.add(r.ONE,r.mul(t.d,r.mul(s,o)));return r.eql(i,a)}function wf(r,t={}){let{Fp:e,Fn:n}=In("edwards",r,t),{h:s,n:o}=r;se(t,{},{uvRatio:"function"});let i=ko<<BigInt(n.BYTES*8)-ht,a=w=>e.create(w),c=t.uvRatio||((w,y)=>{try{return{isValid:!0,value:e.sqrt(e.div(w,y))}}catch{return{isValid:!1,value:Rt}}});if(!bf(e,r,r.Gx,r.Gy))throw new Error("bad curve params: generator point");function f(w,y,v=!1){let N=v?ht:Rt;return ne("coordinate "+w,y,N,i),y}function l(w){if(!(w instanceof d))throw new Error("ExtendedPoint expected")}let u=Ye((w,y)=>{let{ex:v,ey:N,ez:A}=w,R=w.is0();y==null&&(y=R?gf:e.inv(A));let m=a(v*y),_=a(N*y),U=a(A*y);if(R)return{x:Rt,y:ht};if(U!==ht)throw new Error("invZ was invalid");return{x:m,y:_}}),h=Ye(w=>{let{a:y,d:v}=r;if(w.is0())throw new Error("bad point: ZERO");let{ex:N,ey:A,ez:R,et:m}=w,_=a(N*N),U=a(A*A),k=a(R*R),p=a(k*k),E=a(_*y),g=a(k*a(E+U)),x=a(p+a(v*a(_*U)));if(g!==x)throw new Error("bad point: equation left != right (1)");let B=a(N*A),I=a(R*m);if(B!==I)throw new Error("bad point: equation left != right (2)");return!0});class d{constructor(y,v,N,A){this.ex=f("x",y),this.ey=f("y",v),this.ez=f("z",N,!0),this.et=f("t",A),Object.freeze(this)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(y){if(y instanceof d)throw new Error("extended point not allowed");let{x:v,y:N}=y||{};return f("x",v),f("y",N),new d(v,N,ht,a(v*N))}static normalizeZ(y){return An(d,"ez",y)}static msm(y,v){return kn(d,n,y,v)}_setWindowSize(y){this.precompute(y)}precompute(y=8,v=!0){return b.setWindowSize(this,y),v||this.multiply(ko),this}assertValidity(){h(this)}equals(y){l(y);let{ex:v,ey:N,ez:A}=this,{ex:R,ey:m,ez:_}=y,U=a(v*_),k=a(R*A),p=a(N*_),E=a(m*A);return U===k&&p===E}is0(){return this.equals(d.ZERO)}negate(){return new d(a(-this.ex),this.ey,this.ez,a(-this.et))}double(){let{a:y}=r,{ex:v,ey:N,ez:A}=this,R=a(v*v),m=a(N*N),_=a(ko*a(A*A)),U=a(y*R),k=v+N,p=a(a(k*k)-R-m),E=U+m,g=E-_,x=U-m,B=a(p*g),I=a(E*x),S=a(p*x),T=a(g*E);return new d(B,I,T,S)}add(y){l(y);let{a:v,d:N}=r,{ex:A,ey:R,ez:m,et:_}=this,{ex:U,ey:k,ez:p,et:E}=y,g=a(A*U),x=a(R*k),B=a(_*N*E),I=a(m*p),S=a((A+R)*(U+k)-g-x),T=I-B,H=I+B,D=a(x-v*g),z=a(S*T),M=a(H*D),K=a(S*D),W=a(T*H);return new d(z,M,W,K)}subtract(y){return this.add(y.negate())}multiply(y){let v=y;ne("scalar",v,ht,o);let{p:N,f:A}=b.wNAFCached(this,v,d.normalizeZ);return d.normalizeZ([N,A])[0]}multiplyUnsafe(y,v=d.ZERO){let N=y;return ne("scalar",N,Rt,o),N===Rt?d.ZERO:this.is0()||N===ht?this:b.wNAFCachedUnsafe(this,N,d.normalizeZ,v)}isSmallOrder(){return this.multiplyUnsafe(s).is0()}isTorsionFree(){return b.wNAFCachedUnsafe(this,o).is0()}toAffine(y){return u(this,y)}clearCofactor(){return s===ht?this:this.multiplyUnsafe(s)}static fromBytes(y,v=!1){return tt(y),this.fromHex(y,v)}static fromHex(y,v=!1){let{d:N,a:A}=r,R=e.BYTES;y=j("pointHex",y,R),jt("zip215",v);let m=y.slice(),_=y[R-1];m[R-1]=_&-129;let U=xe(m),k=v?i:e.ORDER;ne("pointHex.y",U,Rt,k);let p=a(U*U),E=a(p-ht),g=a(N*p-A),{isValid:x,value:B}=c(E,g);if(!x)throw new Error("Point.fromHex: invalid y coordinate");let I=(B&ht)===ht,S=(_&128)!==0;if(!v&&B===Rt&&S)throw new Error("Point.fromHex: x=0 and x_0=1");return S!==I&&(B=a(-B)),d.fromAffine({x:B,y:U})}static fromPrivateScalar(y){return d.BASE.multiply(y)}toBytes(){let{x:y,y:v}=this.toAffine(),N=Je(v,e.BYTES);return N[N.length-1]|=y&ht?128:0,N}toRawBytes(){return this.toBytes()}toHex(){return _t(this.toBytes())}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}}d.BASE=new d(r.Gx,r.Gy,ht,a(r.Gx*r.Gy)),d.ZERO=new d(Rt,ht,ht,Rt),d.Fp=e,d.Fn=n;let b=Sn(d,n.BYTES*8);return d}function xf(r,t){se(t,{hash:"function"},{adjustScalarBytes:"function",randomBytes:"function",domain:"function",prehash:"function",mapToCurve:"function"});let{prehash:e,hash:n}=t,{BASE:s,Fp:o,Fn:i}=r,a=i.ORDER,c=t.randomBytes||ge,f=t.adjustScalarBytes||(m=>m),l=t.domain||((m,_,U)=>{if(jt("phflag",U),_.length||U)throw new Error("Contexts/pre-hash are not supported");return m});function u(m){return i.create(m)}function h(m){return u(xe(m))}function d(m){let _=o.BYTES;m=j("private key",m,_);let U=j("hashed private key",n(m),2*_),k=f(U.slice(0,_)),p=U.slice(_,2*_),E=h(k);return{head:k,prefix:p,scalar:E}}function b(m){let{head:_,prefix:U,scalar:k}=d(m),p=s.multiply(k),E=p.toBytes();return{head:_,prefix:U,scalar:k,point:p,pointBytes:E}}function w(m){return b(m).pointBytes}function y(m=Uint8Array.of(),..._){let U=xt(..._);return h(n(l(U,j("context",m),!!e)))}function v(m,_,U={}){m=j("message",m),e&&(m=e(m));let{prefix:k,scalar:p,pointBytes:E}=b(_),g=y(U.context,k,m),x=s.multiply(g).toBytes(),B=y(U.context,x,E,m),I=u(g+B*p);ne("signature.s",I,Rt,a);let S=o.BYTES,T=xt(x,Je(I,S));return j("result",T,S*2)}let N=mf;function A(m,_,U,k=N){let{context:p,zip215:E}=k,g=o.BYTES;m=j("signature",m,2*g),_=j("message",_),U=j("publicKey",U,g),E!==void 0&&jt("zip215",E),e&&(_=e(_));let x=xe(m.slice(g,2*g)),B,I,S;try{B=r.fromHex(U,E),I=r.fromHex(m.slice(0,g),E),S=s.multiplyUnsafe(x)}catch{return!1}if(!E&&B.isSmallOrder())return!1;let T=y(p,I.toBytes(),B.toBytes(),_);return I.add(B.multiplyUnsafe(T)).subtract(S).clearCofactor().is0()}return s.precompute(8),{getPublicKey:w,sign:v,verify:A,utils:{getExtendedPublicKey:b,randomPrivateKey:()=>c(o.BYTES),precompute(m=8,_=r.BASE){return _.precompute(m,!1)}},Point:r}}function vf(r){let t={a:r.a,d:r.d,p:r.Fp.ORDER,n:r.n,h:r.h,Gx:r.Gx,Gy:r.Gy},e=r.Fp,n=Nt(t.n,r.nBitLength,!0),s={Fp:e,Fn:n,uvRatio:r.uvRatio},o={hash:r.hash,randomBytes:r.randomBytes,adjustScalarBytes:r.adjustScalarBytes,domain:r.domain,prehash:r.prehash,mapToCurve:r.mapToCurve};return{CURVE:t,curveOpts:s,eddsaOpts:o}}function Ef(r,t){return Object.assign({},t,{ExtendedPoint:t.Point,CURVE:r})}function Ca(r){let{CURVE:t,curveOpts:e,eddsaOpts:n}=vf(r),s=wf(t,e),o=xf(s,n);return Ef(r,o)}var kp=BigInt(0),Bf=BigInt(1),Na=BigInt(2),Ip=BigInt(3),Af=BigInt(5),Sf=BigInt(8),Cn={p:BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffed"),n:BigInt("0x1000000000000000000000000000000014def9dea2f79cd65812631a5cf5d3ed"),h:Sf,a:BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffec"),d:BigInt("0x52036cee2b6ffe738cc740797779e89800700a4d4141d8ab75eb4dca135978a3"),Gx:BigInt("0x216936d3cd6e53fec0a4e231fdd6dc5c692cc7609525a7b2c9562d608f25d51a"),Gy:BigInt("0x6666666666666666666666666666666666666666666666666666666666666658")};function kf(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),s=BigInt(80),o=Cn.p,a=r*r%o*r%o,c=q(a,Na,o)*a%o,f=q(c,Bf,o)*r%o,l=q(f,Af,o)*f%o,u=q(l,t,o)*l%o,h=q(u,e,o)*u%o,d=q(h,n,o)*h%o,b=q(d,s,o)*d%o,w=q(b,s,o)*d%o,y=q(w,t,o)*l%o;return{pow_p_5_8:q(y,Na,o)*r%o,b2:a}}function If(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}var Ta=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752");function Cf(r,t){let e=Cn.p,n=$(t*t*t,e),s=$(n*n*t,e),o=kf(r*s).pow_p_5_8,i=$(r*n*o,e),a=$(t*i*i,e),c=i,f=$(i*Ta,e),l=a===r,u=a===$(-r,e),h=a===$(-r*Ta,e);return l&&(i=c),(u||h)&&(i=f),ba(i,e)&&(i=$(-i,e)),{isValid:l||u,value:i}}var Nf=Nt(Cn.p,void 0,!0),Tf={...Cn,Fp:Nf,hash:En,adjustScalarBytes:If,uvRatio:Cf},Io=Ca(Tf);var er=32,Bt=64,Uf=32;var tr,Ua=(async()=>{try{return await Z.get().subtle.generateKey({name:"Ed25519"},!0,["sign","verify"]),!0}catch{return!1}})();async function _f(r,t){let e;r.length===Bt?e=r.subarray(0,32):e=r;let n={crv:"Ed25519",kty:"OKP",x:P(r.subarray(32),"base64url"),d:P(e,"base64url"),ext:!0,key_ops:["sign"]},s=await Z.get().subtle.importKey("jwk",n,{name:"Ed25519"},!0,["sign"]),o=await Z.get().subtle.sign({name:"Ed25519"},s,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(o,0,o.byteLength)}function Lf(r,t){let e=r.subarray(0,Uf);return Io.sign(t instanceof Uint8Array?t:t.subarray(),e)}async function _a(r,t){return tr==null&&(tr=await Ua),tr?_f(r,t):Lf(r,t)}async function Rf(r,t,e){if(r.buffer instanceof ArrayBuffer){let n=await Z.get().subtle.importKey("raw",r.buffer,{name:"Ed25519"},!1,["verify"]);return await Z.get().subtle.verify({name:"Ed25519"},n,t,e instanceof Uint8Array?e:e.subarray())}throw new TypeError("WebCrypto does not support SharedArrayBuffer for Ed25519 keys")}function Df(r,t,e){return Io.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}async function La(r,t,e){return tr==null&&(tr=await Ua),tr?Rf(r,t,e):Df(r,t,e)}function rr(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}var Nn=class{type="Ed25519";raw;constructor(t){this.raw=Dr(t,er)}toMultihash(){return he.digest(qe(this))}toCID(){return Et.createV1(114,this.toMultihash())}toString(){return J.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:yt(this.raw,t.raw)}verify(t,e,n){n?.signal?.throwIfAborted();let s=La(this.raw,e,t);return rr(s)?s.then(o=>(n?.signal?.throwIfAborted(),o)):s}},Rr=class{type="Ed25519";raw;publicKey;constructor(t,e){this.raw=Dr(t,Bt),this.publicKey=new Nn(e)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:yt(this.raw,t.raw)}sign(t,e){e?.signal?.throwIfAborted();let n=_a(this.raw,t);return rr(n)?n.then(s=>(e?.signal?.throwIfAborted(),s)):(e?.signal?.throwIfAborted(),n)}};function Co(r){if(r.length>Bt){r=Dr(r,Bt+er);let n=r.subarray(0,Bt),s=r.subarray(Bt,r.length);return new Rr(n,s)}r=Dr(r,Bt);let t=r.subarray(0,Bt),e=r.subarray(er);return new Rr(t,e)}function Dr(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 Hf=Math.pow(2,7),Kf=Math.pow(2,14),Vf=Math.pow(2,21),Da=Math.pow(2,28),Ha=Math.pow(2,35),Ka=Math.pow(2,42),Va=Math.pow(2,49),dt=128,oe=127;function Hr(r){if(r<Hf)return 1;if(r<Kf)return 2;if(r<Vf)return 3;if(r<Da)return 4;if(r<Ha)return 5;if(r<Ka)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 Oa(r,t,e=0){switch(Hr(r)){case 8:t[e++]=r&255|dt,r/=128;case 7:t[e++]=r&255|dt,r/=128;case 6:t[e++]=r&255|dt,r/=128;case 5:t[e++]=r&255|dt,r/=128;case 4:t[e++]=r&255|dt,r>>>=7;case 3:t[e++]=r&255|dt,r>>>=7;case 2:t[e++]=r&255|dt,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function Pa(r,t){let e=r[t],n=0;if(n+=e&oe,e<dt||(e=r[t+1],n+=(e&oe)<<7,e<dt)||(e=r[t+2],n+=(e&oe)<<14,e<dt)||(e=r[t+3],n+=(e&oe)<<21,e<dt)||(e=r[t+4],n+=(e&oe)*Da,e<dt)||(e=r[t+5],n+=(e&oe)*Ha,e<dt)||(e=r[t+6],n+=(e&oe)*Ka,e<dt)||(e=r[t+7],n+=(e&oe)*Va,e<dt))return n;throw new RangeError("Could not decode varint")}var No=new Float32Array([-0]),ie=new Uint8Array(No.buffer);function Ma(r,t,e){No[0]=r,t[e]=ie[0],t[e+1]=ie[1],t[e+2]=ie[2],t[e+3]=ie[3]}function Fa(r,t){return ie[0]=r[t],ie[1]=r[t+1],ie[2]=r[t+2],ie[3]=r[t+3],No[0]}var To=new Float64Array([-0]),ot=new Uint8Array(To.buffer);function ja(r,t,e){To[0]=r,t[e]=ot[0],t[e+1]=ot[1],t[e+2]=ot[2],t[e+3]=ot[3],t[e+4]=ot[4],t[e+5]=ot[5],t[e+6]=ot[6],t[e+7]=ot[7]}function qa(r,t){return ot[0]=r[t],ot[1]=r[t+1],ot[2]=r[t+2],ot[3]=r[t+3],ot[4]=r[t+4],ot[5]=r[t+5],ot[6]=r[t+6],ot[7]=r[t+7],To[0]}var Of=BigInt(Number.MAX_SAFE_INTEGER),Pf=BigInt(Number.MIN_SAFE_INTEGER),vt=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 Ae;if(t<Of&&t>Pf)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>$a&&(s=0n,++n>$a&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(t){if(t===0)return Ae;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):Ae}},Ae=new vt(0,0);Ae.toBigInt=function(){return 0n};Ae.zzEncode=Ae.zzDecode=function(){return this};Ae.length=function(){return 1};var $a=4294967296n;function Ga(r){let t=0,e=0;for(let n=0;n<r.length;++n)e=r.charCodeAt(n),e<128?t+=1:e<2048?t+=2:(e&64512)===55296&&(r.charCodeAt(n+1)&64512)===56320?(++n,t+=4):t+=3;return t}function za(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 Uo(r,t,e){let n=e,s,o;for(let i=0;i<r.length;++i)s=r.charCodeAt(i),s<128?t[e++]=s:s<2048?(t[e++]=s>>6|192,t[e++]=s&63|128):(s&64512)===55296&&((o=r.charCodeAt(i+1))&64512)===56320?(s=65536+((s&1023)<<10)+(o&1023),++i,t[e++]=s>>18|240,t[e++]=s>>12&63|128,t[e++]=s>>6&63|128,t[e++]=s&63|128):(t[e++]=s>>12|224,t[e++]=s>>6&63|128,t[e++]=s&63|128);return e-n}function Tt(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function Tn(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var _o=class{buf;pos;len;_slice=Uint8Array.prototype.subarray;constructor(t){this.buf=t,this.pos=0,this.len=t.length}uint32(){let t=4294967295;if(t=(this.buf[this.pos]&127)>>>0,this.buf[this.pos++]<128||(t=(t|(this.buf[this.pos]&127)<<7)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<14)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<21)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&15)<<28)>>>0,this.buf[this.pos++]<128))return t;if((this.pos+=5)>this.len)throw this.pos=this.len,Tt(this,10);return t}int32(){return this.uint32()|0}sint32(){let t=this.uint32();return t>>>1^-(t&1)|0}bool(){return this.uint32()!==0}fixed32(){if(this.pos+4>this.len)throw Tt(this,4);return Tn(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Tt(this,4);return Tn(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Tt(this,4);let t=Fa(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Tt(this,4);let t=qa(this.buf,this.pos);return this.pos+=8,t}bytes(){let t=this.uint32(),e=this.pos,n=this.pos+t;if(n>this.len)throw Tt(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return za(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw Tt(this,t);this.pos+=t}else do if(this.pos>=this.len)throw Tt(this);while((this.buf[this.pos++]&128)!==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 vt(0,0),e=0;if(this.len-this.pos>4){for(;e<4;++e)if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t;if(t.lo=(t.lo|(this.buf[this.pos]&127)<<28)>>>0,t.hi=(t.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return t;e=0}else{for(;e<3;++e){if(this.pos>=this.len)throw Tt(this);if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t}return t.lo=(t.lo|(this.buf[this.pos++]&127)<<e*7)>>>0,t}if(this.len-this.pos>4){for(;e<5;++e)if(t.hi=(t.hi|(this.buf[this.pos]&127)<<e*7+3)>>>0,this.buf[this.pos++]<128)return t}else for(;e<5;++e){if(this.pos>=this.len)throw Tt(this);if(t.hi=(t.hi|(this.buf[this.pos]&127)<<e*7+3)>>>0,this.buf[this.pos++]<128)return t}throw Error("invalid varint encoding")}readFixed64(){if(this.pos+8>this.len)throw Tt(this,8);let t=Tn(this.buf,this.pos+=4),e=Tn(this.buf,this.pos+=4);return new vt(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=Pa(this.buf,this.pos);return this.pos+=Hr(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 Lo(r){return new _o(r instanceof Uint8Array?r:r.subarray())}function Un(r,t,e){let n=Lo(r);return t.decode(n,void 0,e)}function Ro(r){let t=r??8192,e=t>>>1,n,s=t;return function(i){if(i<1||i>e)return wt(i);s+i>t&&(n=wt(t),s=0);let a=n.subarray(s,s+=i);return(s&7)!==0&&(s=(s|7)+1),a}}var Se=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function Do(){}var Ko=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},Mf=Ro();function Ff(r){return globalThis.Buffer!=null?wt(r):Mf(r)}var Vr=class{len;head;tail;states;constructor(){this.len=0,this.head=new Se(Do,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new Se(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new Vo((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(_n,10,vt.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=vt.fromBigInt(t);return this._push(_n,e.length(),e)}uint64Number(t){return this._push(Oa,Hr(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=vt.fromBigInt(t).zzEncode();return this._push(_n,e.length(),e)}sint64Number(t){let e=vt.fromNumber(t).zzEncode();return this._push(_n,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(Ho,1,t?1:0)}fixed32(t){return this._push(Kr,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=vt.fromBigInt(t);return this._push(Kr,4,e.lo)._push(Kr,4,e.hi)}fixed64Number(t){let e=vt.fromNumber(t);return this._push(Kr,4,e.lo)._push(Kr,4,e.hi)}fixed64String(t){return this.fixed64(BigInt(t))}sfixed64(t){return this.fixed64(t)}sfixed64Number(t){return this.fixed64Number(t)}sfixed64String(t){return this.fixed64String(t)}float(t){return this._push(Ma,4,t)}double(t){return this._push(ja,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(Ho,1,0):this.uint32(e)._push(qf,e,t)}string(t){let e=Ga(t);return e!==0?this.uint32(e)._push(Uo,e,t):this._push(Ho,1,0)}fork(){return this.states=new Ko(this),this.head=this.tail=new Se(Do,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 Se(Do,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=Ff(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function Ho(r,t,e){t[e]=r&255}function jf(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var Vo=class extends Se{next;constructor(t,e){super(jf,t,e),this.next=void 0}};function _n(r,t,e){for(;r.hi!==0;)t[e++]=r.lo&127|128,r.lo=(r.lo>>>7|r.hi<<25)>>>0,r.hi>>>=7;for(;r.lo>127;)t[e++]=r.lo&127|128,r.lo=r.lo>>>7;t[e++]=r.lo}function Kr(r,t,e){t[e]=r&255,t[e+1]=r>>>8&255,t[e+2]=r>>>16&255,t[e+3]=r>>>24}function qf(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(Vr.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push($f,t,r),this},Vr.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(Gf,t,r),this});function $f(r,t,e){t.set(r,e)}function Gf(r,t,e){r.length<40?Uo(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(V(r),e)}function Oo(){return new Vr}function Ln(r,t){let e=Oo();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var nr;(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"})(nr||(nr={}));function Rn(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function Po(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 Rn("enum",nr.VARINT,e,n)}function Dn(r,t){return Rn("message",nr.LENGTH_DELIMITED,r,t)}var Y;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.secp256k1="secp256k1",r.ECDSA="ECDSA"})(Y||(Y={}));var Mo;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1",r[r.ECDSA=3]="ECDSA"})(Mo||(Mo={}));(function(r){r.codec=()=>Po(Mo)})(Y||(Y={}));var ae;(function(r){let t;r.codec=()=>(t==null&&(t=Dn((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),Y.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=Y.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)})(ae||(ae={}));var Or;(function(r){let t;r.codec=()=>(t==null&&(t=Dn((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),Y.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=Y.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)})(Or||(Or={}));function ke(r){if(isNaN(r)||r<=0)throw new L("random bytes length must be a Number bigger than 0");return ge(r)}var Mr={};ct(Mr,{MAX_RSA_KEY_SIZE:()=>Fo,generateRSAKeyPair:()=>Qa,jwkToJWKKeyPair:()=>tc,jwkToPkcs1:()=>Jf,jwkToPkix:()=>Go,jwkToRSAPrivateKey:()=>Zo,pkcs1MessageToJwk:()=>qo,pkcs1MessageToRSAPrivateKey:()=>Hn,pkcs1ToJwk:()=>Zf,pkcs1ToRSAPrivateKey:()=>zo,pkixMessageToJwk:()=>$o,pkixMessageToRSAPublicKey:()=>Wo,pkixToJwk:()=>Yf,pkixToRSAPublicKey:()=>Xa});var sr=vn;var or=class{type="RSA";jwk;_raw;_multihash;constructor(t,e){this.jwk=t,this._multihash=e}get raw(){return this._raw==null&&(this._raw=Mr.jwkToPkix(this.jwk)),this._raw}toMultihash(){return this._multihash}toCID(){return Et.createV1(114,this._multihash)}toString(){return J.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:yt(this.raw,t.raw)}verify(t,e,n){return Ya(this.jwk,e,t,n)}},Pr=class{type="RSA";jwk;_raw;publicKey;constructor(t,e){this.jwk=t,this.publicKey=e}get raw(){return this._raw==null&&(this._raw=Mr.jwkToPkcs1(this.jwk)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:yt(this.raw,t.raw)}sign(t,e){return Ja(this.jwk,t,e)}};var Fo=8192,jo=18,zf=1062,Wf=Uint8Array.from([48,13,6,9,42,134,72,134,247,13,1,1,1,5,0]);function Zf(r){let t=kt(r);return qo(t)}function qo(r){return{n:P(r[1],"base64url"),e:P(r[2],"base64url"),d:P(r[3],"base64url"),p:P(r[4],"base64url"),q:P(r[5],"base64url"),dp:P(r[6],"base64url"),dq:P(r[7],"base64url"),qi:P(r[8],"base64url"),kty:"RSA"}}function Jf(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 It([ut(Uint8Array.from([0])),ut(V(r.n,"base64url")),ut(V(r.e,"base64url")),ut(V(r.d,"base64url")),ut(V(r.p,"base64url")),ut(V(r.q,"base64url")),ut(V(r.dp,"base64url")),ut(V(r.dq,"base64url")),ut(V(r.qi,"base64url"))]).subarray()}function Yf(r){let t=kt(r,{offset:0});return $o(t)}function $o(r){let t=kt(r[1],{offset:0});return{kty:"RSA",n:P(t[0],"base64url"),e:P(t[1],"base64url")}}function Go(r){if(r.n==null||r.e==null)throw new L("JWK was missing components");return It([Wf,Ir(It([ut(V(r.n,"base64url")),ut(V(r.e,"base64url"))]))]).subarray()}function zo(r){let t=kt(r);return Hn(t)}function Hn(r){let t=qo(r);return Zo(t)}function Xa(r,t){if(r.byteLength>=zf)throw new Re("Key size is too large");let e=kt(r,{offset:0});return Wo(e,r,t)}function Wo(r,t,e){let n=$o(r);if(e==null){let s=sr(ae.encode({Type:Y.RSA,Data:t}));e=St(jo,s)}return new or(n,e)}function Zo(r){if(rc(r)>Fo)throw new L("Key size is too large");let t=tc(r),e=sr(ae.encode({Type:Y.RSA,Data:Go(t.publicKey)})),n=St(jo,e);return new Pr(t.privateKey,new or(t.publicKey,n))}async function Qa(r){if(r>Fo)throw new L("Key size is too large");let t=await ec(r),e=sr(ae.encode({Type:Y.RSA,Data:Go(t.publicKey)})),n=St(jo,e);return new Pr(t.privateKey,new or(t.publicKey,n))}function tc(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 ec(r,t){let e=await Z.get().subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:r,publicExponent:new Uint8Array([1,0,1]),hash:{name:"SHA-256"}},!0,["sign","verify"]);t?.signal?.throwIfAborted();let n=await Xf(e,t);return{privateKey:n[0],publicKey:n[1]}}async function Ja(r,t,e){let n=await Z.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]);e?.signal?.throwIfAborted();let s=await Z.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},n,t instanceof Uint8Array?t:t.subarray());return e?.signal?.throwIfAborted(),new Uint8Array(s,0,s.byteLength)}async function Ya(r,t,e,n){let s=await Z.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);n?.signal?.throwIfAborted();let o=await Z.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},s,t,e instanceof Uint8Array?e:e.subarray());return n?.signal?.throwIfAborted(),o}async function Xf(r,t){if(r.privateKey==null||r.publicKey==null)throw new L("Private and public key are required");let e=await Promise.all([Z.get().subtle.exportKey("jwk",r.privateKey),Z.get().subtle.exportKey("jwk",r.publicKey)]);return t?.signal?.throwIfAborted(),e}function rc(r){if(r.kty!=="RSA")throw new L("invalid key type");if(r.n==null)throw new L("invalid key modulus");return V(r.n,"base64url").length*8}var Kn=class extends $e{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,pn(t);let n=Cr(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),gt(o)}update(t){return ze(this),this.iHash.update(t),this}digestInto(t){ze(this),tt(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()}},Fr=(r,t,e)=>new Kn(r,t).update(e).digest();Fr.create=(r,t)=>new Kn(r,t);function nc(r){r.lowS!==void 0&&jt("lowS",r.lowS),r.prehash!==void 0&&jt("prehash",r.prehash)}var Jo=class extends Error{constructor(t=""){super(t)}},qt={Err:Jo,_tlv:{encode:(r,t)=>{let{Err:e}=qt;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=_r(n);if(s.length/2&128)throw new e("tlv.encode: long form length too big");let o=n>127?_r(s.length/2|128):"";return _r(r)+o+s+t},decode(r,t){let{Err:e}=qt,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}=qt;if(r<jr)throw new t("integer: negative integers are not allowed");let e=_r(r);if(Number.parseInt(e[0],16)&8&&(e="00"+e),e.length&1)throw new t("unexpected DER parsing assertion: unpadded hex");return e},decode(r){let{Err:t}=qt;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 Ze(r)}},toSig(r){let{Err:t,_int:e,_tlv:n}=qt,s=j("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}=qt,n=t.encode(2,e.encode(r.r)),s=t.encode(2,e.encode(r.s)),o=n+s;return t.encode(48,o)}},jr=BigInt(0),qr=BigInt(1),Qf=BigInt(2),Vn=BigInt(3),th=BigInt(4);function eh(r,t,e){function n(s){let o=r.sqr(s),i=r.mul(o,s);return r.add(r.add(i,r.mul(s,t)),e)}return n}function sc(r,t,e){let{BYTES:n}=r;function s(o){let i;if(typeof o=="bigint")i=o;else{let a=j("private key",o);if(t){if(!t.includes(a.length*2))throw new Error("invalid private key");let c=new Uint8Array(n);c.set(a,c.length-a.length),a=c}try{i=r.fromBytes(a)}catch{throw new Error(`invalid private key: expected ui8a of size ${n}, got ${typeof o}`)}}if(e&&(i=r.create(i)),!r.isValidNot0(i))throw new Error("invalid private key: out of range [1..N-1]");return i}return s}function rh(r,t={}){let{Fp:e,Fn:n}=In("weierstrass",r,t),{h:s,n:o}=r;se(t,{},{allowInfinityPoint:"boolean",clearCofactor:"function",isTorsionFree:"function",fromBytes:"function",toBytes:"function",endo:"object",wrapPrivateKey:"boolean"});let{endo:i}=t;if(i&&(!e.is0(r.a)||typeof i.beta!="bigint"||typeof i.splitScalar!="function"))throw new Error('invalid endo: expected "beta": bigint and "splitScalar": function');function a(){if(!e.isOdd)throw new Error("compression is not supported: Field does not have .isOdd()")}function c(k,p,E){let{x:g,y:x}=p.toAffine(),B=e.toBytes(g);if(jt("isCompressed",E),E){a();let I=!e.isOdd(x);return xt(oc(I),B)}else return xt(Uint8Array.of(4),B,e.toBytes(x))}function f(k){tt(k);let p=e.BYTES,E=p+1,g=2*p+1,x=k.length,B=k[0],I=k.subarray(1);if(x===E&&(B===2||B===3)){let S=e.fromBytes(I);if(!e.isValid(S))throw new Error("bad point: is not on curve, wrong x");let T=h(S),H;try{H=e.sqrt(T)}catch(M){let K=M instanceof Error?": "+M.message:"";throw new Error("bad point: is not on curve, sqrt error"+K)}a();let D=e.isOdd(H);return(B&1)===1!==D&&(H=e.neg(H)),{x:S,y:H}}else if(x===g&&B===4){let S=e.fromBytes(I.subarray(p*0,p*1)),T=e.fromBytes(I.subarray(p*1,p*2));if(!d(S,T))throw new Error("bad point: is not on curve");return{x:S,y:T}}else throw new Error(`bad point: got length ${x}, expected compressed=${E} or uncompressed=${g}`)}let l=t.toBytes||c,u=t.fromBytes||f,h=eh(e,r.a,r.b);function d(k,p){let E=e.sqr(p),g=h(k);return e.eql(E,g)}if(!d(r.Gx,r.Gy))throw new Error("bad curve params: generator point");let b=e.mul(e.pow(r.a,Vn),th),w=e.mul(e.sqr(r.b),BigInt(27));if(e.is0(e.add(b,w)))throw new Error("bad curve params: a or b");function y(k,p,E=!1){if(!e.isValid(p)||E&&e.is0(p))throw new Error(`bad point coordinate ${k}`);return p}function v(k){if(!(k instanceof m))throw new Error("ProjectivePoint expected")}let N=Ye((k,p)=>{let{px:E,py:g,pz:x}=k;if(e.eql(x,e.ONE))return{x:E,y:g};let B=k.is0();p==null&&(p=B?e.ONE:e.inv(x));let I=e.mul(E,p),S=e.mul(g,p),T=e.mul(x,p);if(B)return{x:e.ZERO,y:e.ZERO};if(!e.eql(T,e.ONE))throw new Error("invZ was invalid");return{x:I,y:S}}),A=Ye(k=>{if(k.is0()){if(t.allowInfinityPoint&&!e.is0(k.py))return;throw new Error("bad point: ZERO")}let{x:p,y:E}=k.toAffine();if(!e.isValid(p)||!e.isValid(E))throw new Error("bad point: x or y not field elements");if(!d(p,E))throw new Error("bad point: equation left != right");if(!k.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});function R(k,p,E,g,x){return E=new m(e.mul(E.px,k),E.py,E.pz),p=Xe(g,p),E=Xe(x,E),p.add(E)}class m{constructor(p,E,g){this.px=y("x",p),this.py=y("y",E,!0),this.pz=y("z",g),Object.freeze(this)}static fromAffine(p){let{x:E,y:g}=p||{};if(!p||!e.isValid(E)||!e.isValid(g))throw new Error("invalid affine point");if(p instanceof m)throw new Error("projective point not allowed");return e.is0(E)&&e.is0(g)?m.ZERO:new m(E,g,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(p){return An(m,"pz",p)}static fromBytes(p){return tt(p),m.fromHex(p)}static fromHex(p){let E=m.fromAffine(u(j("pointHex",p)));return E.assertValidity(),E}static fromPrivateKey(p){let E=sc(n,t.allowedPrivateKeyLengths,t.wrapPrivateKey);return m.BASE.multiply(E(p))}static msm(p,E){return kn(m,n,p,E)}precompute(p=8,E=!0){return U.setWindowSize(this,p),E||this.multiply(Vn),this}_setWindowSize(p){this.precompute(p)}assertValidity(){A(this)}hasEvenY(){let{y:p}=this.toAffine();if(!e.isOdd)throw new Error("Field doesn't support isOdd");return!e.isOdd(p)}equals(p){v(p);let{px:E,py:g,pz:x}=this,{px:B,py:I,pz:S}=p,T=e.eql(e.mul(E,S),e.mul(B,x)),H=e.eql(e.mul(g,S),e.mul(I,x));return T&&H}negate(){return new m(this.px,e.neg(this.py),this.pz)}double(){let{a:p,b:E}=r,g=e.mul(E,Vn),{px:x,py:B,pz:I}=this,S=e.ZERO,T=e.ZERO,H=e.ZERO,D=e.mul(x,x),z=e.mul(B,B),M=e.mul(I,I),K=e.mul(x,B);return K=e.add(K,K),H=e.mul(x,I),H=e.add(H,H),S=e.mul(p,H),T=e.mul(g,M),T=e.add(S,T),S=e.sub(z,T),T=e.add(z,T),T=e.mul(S,T),S=e.mul(K,S),H=e.mul(g,H),M=e.mul(p,M),K=e.sub(D,M),K=e.mul(p,K),K=e.add(K,H),H=e.add(D,D),D=e.add(H,D),D=e.add(D,M),D=e.mul(D,K),T=e.add(T,D),M=e.mul(B,I),M=e.add(M,M),D=e.mul(M,K),S=e.sub(S,D),H=e.mul(M,z),H=e.add(H,H),H=e.add(H,H),new m(S,T,H)}add(p){v(p);let{px:E,py:g,pz:x}=this,{px:B,py:I,pz:S}=p,T=e.ZERO,H=e.ZERO,D=e.ZERO,z=r.a,M=e.mul(r.b,Vn),K=e.mul(E,B),W=e.mul(g,I),X=e.mul(x,S),st=e.add(E,g),F=e.add(B,I);st=e.mul(st,F),F=e.add(K,W),st=e.sub(st,F),F=e.add(E,x);let at=e.add(B,S);return F=e.mul(F,at),at=e.add(K,X),F=e.sub(F,at),at=e.add(g,x),T=e.add(I,S),at=e.mul(at,T),T=e.add(W,X),at=e.sub(at,T),D=e.mul(z,F),T=e.mul(M,X),D=e.add(T,D),T=e.sub(W,D),D=e.add(W,D),H=e.mul(T,D),W=e.add(K,K),W=e.add(W,K),X=e.mul(z,X),F=e.mul(M,F),W=e.add(W,X),X=e.sub(K,X),X=e.mul(z,X),F=e.add(F,X),K=e.mul(W,F),H=e.add(H,K),K=e.mul(at,F),T=e.mul(st,T),T=e.sub(T,K),K=e.mul(st,W),D=e.mul(at,D),D=e.add(D,K),new m(T,H,D)}subtract(p){return this.add(p.negate())}is0(){return this.equals(m.ZERO)}multiply(p){let{endo:E}=t;if(!n.isValidNot0(p))throw new Error("invalid scalar: out of range");let g,x,B=I=>U.wNAFCached(this,I,m.normalizeZ);if(E){let{k1neg:I,k1:S,k2neg:T,k2:H}=E.splitScalar(p),{p:D,f:z}=B(S),{p:M,f:K}=B(H);x=z.add(K),g=R(E.beta,D,M,I,T)}else{let{p:I,f:S}=B(p);g=I,x=S}return m.normalizeZ([g,x])[0]}multiplyUnsafe(p){let{endo:E}=t,g=this;if(!n.isValid(p))throw new Error("invalid scalar: out of range");if(p===jr||g.is0())return m.ZERO;if(p===qr)return g;if(U.hasPrecomputes(this))return this.multiply(p);if(E){let{k1neg:x,k1:B,k2neg:I,k2:S}=E.splitScalar(p),{p1:T,p2:H}=Ia(m,g,B,S);return R(E.beta,T,H,x,I)}else return U.wNAFCachedUnsafe(g,p)}multiplyAndAddUnsafe(p,E,g){let x=this.multiplyUnsafe(E).add(p.multiplyUnsafe(g));return x.is0()?void 0:x}toAffine(p){return N(this,p)}isTorsionFree(){let{isTorsionFree:p}=t;return s===qr?!0:p?p(m,this):U.wNAFCachedUnsafe(this,o).is0()}clearCofactor(){let{clearCofactor:p}=t;return s===qr?this:p?p(m,this):this.multiplyUnsafe(s)}toBytes(p=!0){return jt("isCompressed",p),this.assertValidity(),l(m,this,p)}toRawBytes(p=!0){return this.toBytes(p)}toHex(p=!0){return _t(this.toBytes(p))}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}}m.BASE=new m(r.Gx,r.Gy,e.ONE),m.ZERO=new m(e.ZERO,e.ONE,e.ZERO),m.Fp=e,m.Fn=n;let _=n.BITS,U=Sn(m,t.endo?Math.ceil(_/2):_);return m}function oc(r){return Uint8Array.of(r?2:3)}function nh(r,t,e={}){se(t,{hash:"function"},{hmac:"function",lowS:"boolean",randomBytes:"function",bits2int:"function",bits2int_modN:"function"});let n=t.randomBytes||ge,s=t.hmac||((g,...x)=>Fr(t.hash,g,xt(...x))),{Fp:o,Fn:i}=r,{ORDER:a,BITS:c}=i;function f(g){let x=a>>qr;return g>x}function l(g){return f(g)?i.neg(g):g}function u(g,x){if(!i.isValidNot0(x))throw new Error(`invalid signature ${g}: out of range 1..CURVE.n`)}class h{constructor(x,B,I){u("r",x),u("s",B),this.r=x,this.s=B,I!=null&&(this.recovery=I),Object.freeze(this)}static fromCompact(x){let B=i.BYTES,I=j("compactSignature",x,B*2);return new h(i.fromBytes(I.subarray(0,B)),i.fromBytes(I.subarray(B,B*2)))}static fromDER(x){let{r:B,s:I}=qt.toSig(j("DER",x));return new h(B,I)}assertValidity(){}addRecoveryBit(x){return new h(this.r,this.s,x)}recoverPublicKey(x){let B=o.ORDER,{r:I,s:S,recovery:T}=this;if(T==null||![0,1,2,3].includes(T))throw new Error("recovery id invalid");if(a*Qf<B&&T>1)throw new Error("recovery id is ambiguous for h>1 curve");let D=T===2||T===3?I+a:I;if(!o.isValid(D))throw new Error("recovery id 2 or 3 invalid");let z=o.toBytes(D),M=r.fromHex(xt(oc((T&1)===0),z)),K=i.inv(D),W=A(j("msgHash",x)),X=i.create(-W*K),st=i.create(S*K),F=r.BASE.multiplyUnsafe(X).add(M.multiplyUnsafe(st));if(F.is0())throw new Error("point at infinify");return F.assertValidity(),F}hasHighS(){return f(this.s)}normalizeS(){return this.hasHighS()?new h(this.r,i.neg(this.s),this.recovery):this}toBytes(x){if(x==="compact")return xt(i.toBytes(this.r),i.toBytes(this.s));if(x==="der")return We(qt.hexFromSig(this));throw new Error("invalid format")}toDERRawBytes(){return this.toBytes("der")}toDERHex(){return _t(this.toBytes("der"))}toCompactRawBytes(){return this.toBytes("compact")}toCompactHex(){return _t(this.toBytes("compact"))}}let d=sc(i,e.allowedPrivateKeyLengths,e.wrapPrivateKey),b={isValidPrivateKey(g){try{return d(g),!0}catch{return!1}},normPrivateKeyToScalar:d,randomPrivateKey:()=>{let g=a;return va(n(Eo(g)),g)},precompute(g=8,x=r.BASE){return x.precompute(g,!1)}};function w(g,x=!0){return r.fromPrivateKey(g).toBytes(x)}function y(g){if(typeof g=="bigint")return!1;if(g instanceof r)return!0;let B=j("key",g).length,I=o.BYTES,S=I+1,T=2*I+1;if(!(e.allowedPrivateKeyLengths||i.BYTES===S))return B===S||B===T}function v(g,x,B=!0){if(y(g)===!0)throw new Error("first arg must be private key");if(y(x)===!1)throw new Error("second arg must be public key");return r.fromHex(x).multiply(d(g)).toBytes(B)}let N=t.bits2int||function(g){if(g.length>8192)throw new Error("input is too large");let x=Ze(g),B=g.length*8-c;return B>0?x>>BigInt(B):x},A=t.bits2int_modN||function(g){return i.create(N(g))},R=ve(c);function m(g){return ne("num < 2^"+c,g,jr,R),i.toBytes(g)}function _(g,x,B=U){if(["recovered","canonical"].some(st=>st in B))throw new Error("sign() legacy options not supported");let{hash:I}=t,{lowS:S,prehash:T,extraEntropy:H}=B;S==null&&(S=!0),g=j("msgHash",g),nc(B),T&&(g=j("prehashed msgHash",I(g)));let D=A(g),z=d(x),M=[m(z),m(D)];if(H!=null&&H!==!1){let st=H===!0?n(o.BYTES):H;M.push(j("extraEntropy",st))}let K=xt(...M),W=D;function X(st){let F=N(st);if(!i.isValidNot0(F))return;let at=i.inv(F),yr=r.BASE.multiply(F).toAffine(),_e=i.create(yr.x);if(_e===jr)return;let fe=i.create(at*i.create(W+_e*z));if(fe===jr)return;let Os=(yr.x===_e?0:2)|Number(yr.y&qr),Le=fe;return S&&f(fe)&&(Le=l(fe),Os^=1),new h(_e,Le,Os)}return{seed:K,k2sig:X}}let U={lowS:t.lowS,prehash:!1},k={lowS:t.lowS,prehash:!1};function p(g,x,B=U){let{seed:I,k2sig:S}=_(g,x,B);return fa(t.hash.outputLen,i.BYTES,s)(I,S)}r.BASE.precompute(8);function E(g,x,B,I=k){let S=g;x=j("msgHash",x),B=j("publicKey",B),nc(I);let{lowS:T,prehash:H,format:D}=I;if("strict"in I)throw new Error("options.strict was renamed to lowS");if(D!==void 0&&!["compact","der","js"].includes(D))throw new Error('format must be "compact", "der" or "js"');let z=typeof S=="string"||Ge(S),M=!z&&!D&&typeof S=="object"&&S!==null&&typeof S.r=="bigint"&&typeof S.s=="bigint";if(!z&&!M)throw new Error("invalid signature, expected Uint8Array, hex string or Signature instance");let K,W;try{if(M)if(D===void 0||D==="js")K=new h(S.r,S.s);else throw new Error("invalid format");if(z){try{D!=="compact"&&(K=h.fromDER(S))}catch(Le){if(!(Le instanceof qt.Err))throw Le}!K&&D!=="der"&&(K=h.fromCompact(S))}W=r.fromHex(B)}catch{return!1}if(!K||T&&K.hasHighS())return!1;H&&(x=t.hash(x));let{r:X,s:st}=K,F=A(x),at=i.inv(st),yr=i.create(F*at),_e=i.create(X*at),fe=r.BASE.multiplyUnsafe(yr).add(W.multiplyUnsafe(_e));return fe.is0()?!1:i.create(fe.x)===X}return Object.freeze({getPublicKey:w,getSharedSecret:v,sign:p,verify:E,utils:b,Point:r,Signature:h})}function sh(r){let t={a:r.a,b:r.b,p:r.Fp.ORDER,n:r.n,h:r.h,Gx:r.Gx,Gy:r.Gy},e=r.Fp,n=Nt(t.n,r.nBitLength),s={Fp:e,Fn:n,allowedPrivateKeyLengths:r.allowedPrivateKeyLengths,allowInfinityPoint:r.allowInfinityPoint,endo:r.endo,wrapPrivateKey:r.wrapPrivateKey,isTorsionFree:r.isTorsionFree,clearCofactor:r.clearCofactor,fromBytes:r.fromBytes,toBytes:r.toBytes};return{CURVE:t,curveOpts:s}}function oh(r){let{CURVE:t,curveOpts:e}=sh(r),n={hash:r.hash,hmac:r.hmac,randomBytes:r.randomBytes,lowS:r.lowS,bits2int:r.bits2int,bits2int_modN:r.bits2int_modN};return{CURVE:t,curveOpts:e,ecdsaOpts:n}}function ih(r,t){return Object.assign({},t,{ProjectivePoint:t.Point,CURVE:r})}function ic(r){let{CURVE:t,curveOpts:e,ecdsaOpts:n}=oh(r),s=rh(t,e),o=nh(s,n,e);return ih(r,o)}function ac(r,t){let e=n=>ic({...r,hash:n});return{...e(t),create:e}}var On={p:BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),n:BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),h:BigInt(1),a:BigInt(0),b:BigInt(7),Gx:BigInt("0x79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798"),Gy:BigInt("0x483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8")},ug=BigInt(0),ah=BigInt(1),Yo=BigInt(2),cc=(r,t)=>(r+t/Yo)/t;function ch(r){let t=On.p,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=q(l,e,t)*l%t,h=q(u,e,t)*l%t,d=q(h,Yo,t)*f%t,b=q(d,s,t)*d%t,w=q(b,o,t)*b%t,y=q(w,a,t)*w%t,v=q(y,c,t)*y%t,N=q(v,a,t)*w%t,A=q(N,e,t)*l%t,R=q(A,i,t)*b%t,m=q(R,n,t)*f%t,_=q(m,Yo,t);if(!Xo.eql(Xo.sqr(_),r))throw new Error("Cannot find square root");return _}var Xo=Nt(On.p,void 0,void 0,{sqrt:ch}),Dt=ac({...On,Fp:Xo,lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=On.n,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-ah*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),s=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),o=e,i=BigInt("0x100000000000000000000000000000000"),a=cc(o*r,t),c=cc(-n*r,t),f=$(r-a*e-c*s,t),l=$(-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}}}},vn);var lc=32;function uc(r,t,e){let n=Fe.digest(t instanceof Uint8Array?t:t.subarray());if(rr(n))return n.then(({digest:s})=>(e?.signal?.throwIfAborted(),Dt.sign(s,r).toDERRawBytes())).catch(s=>{throw s.name==="AbortError"?s:new mr(String(s))});try{return Dt.sign(n.digest,r).toDERRawBytes()}catch(s){throw new mr(String(s))}}function fc(r,t,e,n){let s=Fe.digest(e instanceof Uint8Array?e:e.subarray());if(rr(s))return s.then(({digest:o})=>(n?.signal?.throwIfAborted(),Dt.verify(t,o,r))).catch(o=>{throw o.name==="AbortError"?o:new br(String(o))});try{return n?.signal?.throwIfAborted(),Dt.verify(t,s.digest,r)}catch(o){throw new br(String(o))}}var Pn=class{type="secp256k1";raw;_key;constructor(t){this._key=pc(t),this.raw=hc(this._key)}toMultihash(){return he.digest(qe(this))}toCID(){return Et.createV1(114,this.toMultihash())}toString(){return J.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:yt(this.raw,t.raw)}verify(t,e,n){return fc(this._key,e,t,n)}},Mn=class{type="secp256k1";raw;publicKey;constructor(t,e){this.raw=dc(t),this.publicKey=new Pn(e??yc(t))}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:yt(this.raw,t.raw)}sign(t,e){return uc(this.raw,t,e)}};function Qo(r){return new Mn(r)}function hc(r){return Dt.ProjectivePoint.fromHex(r).toRawBytes(!0)}function dc(r){try{return Dt.getPublicKey(r,!0),r}catch(t){throw new wr(String(t))}}function pc(r){try{return Dt.ProjectivePoint.fromHex(r),r}catch(t){throw new Re(String(t))}}function yc(r){try{return Dt.getPublicKey(r,!0)}catch(t){throw new wr(String(t))}}function qe(r){return ae.encode({Type:Y[r.type],Data:r.raw})}function gc(r){let t=Or.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case Y.RSA:return zo(e);case Y.Ed25519:return Co(e);case Y.secp256k1:return Qo(e);case Y.ECDSA:return qi(e);default:throw new De}}function mc(r){if(r.byteLength===Bt)return Co(r);if(r.byteLength===lc)return Qo(r);let t=kt(r),e=t[2]?.[0];if(e===Oi||e===Pi||e===Mi)return ho(t);if(t.length>8)return Hn(t);throw new L("Could not extract private key from raw bytes")}function Ie(r){return Or.encode({Type:Y[r.type],Data:r.raw})}function bc(r,t,e,n){pn(r);let s=Xi({dkLen:32,asyncTick:10},n),{c:o,dkLen:i,asyncTick:a}=s;if(Mt(o),Mt(i),Mt(a),o<1)throw new Error("iterations (c) should be >= 1");let c=yo(t),f=yo(e),l=new Uint8Array(i),u=Fr.create(r,c),h=u._cloneInto().update(f);return{c:o,dkLen:i,asyncTick:a,DK:l,PRF:u,PRFSalt:h}}function wc(r,t,e,n,s){return r.destroy(),t.destroy(),n&&n.destroy(),gt(s),e}function xc(r,t,e,n){let{c:s,dkLen:o,DK:i,PRF:a,PRFSalt:c}=bc(r,t,e,n),f,l=new Uint8Array(4),u=ye(l),h=new Uint8Array(a.outputLen);for(let d=1,b=0;b<o;d++,b+=a.outputLen){let w=i.subarray(b,b+a.outputLen);u.setInt32(0,d,!1),(f=c._cloneInto(f)).update(l).digestInto(h),w.set(h.subarray(0,w.length));for(let y=1;y<s;y++){a._cloneInto(f).update(h).digestInto(h);for(let v=0;v<w.length;v++)w[v]^=h[v]}}return wc(a,c,i,f,h)}async function Fn(r,t,e,n){let{c:s,dkLen:o,asyncTick:i,DK:a,PRF:c,PRFSalt:f}=bc(r,t,e,n),l,u=new Uint8Array(4),h=ye(u),d=new Uint8Array(c.outputLen);for(let b=1,w=0;w<o;b++,w+=c.outputLen){let y=a.subarray(w,w+c.outputLen);h.setInt32(0,b,!1),(l=f._cloneInto(l)).update(u).digestInto(d),y.set(d.subarray(0,y.length)),await Yi(s-1,i,()=>{c._cloneInto(l).update(d).digestInto(d);for(let v=0;v<y.length;v++)y[v]^=d[v]})}return wc(c,f,a,l,d)}var $r=Uint32Array.from([1732584193,4023233417,2562383102,271733878,3285377520]),ce=new Uint32Array(80),jn=class extends me{constructor(){super(64,20,8,!1),this.A=$r[0]|0,this.B=$r[1]|0,this.C=$r[2]|0,this.D=$r[3]|0,this.E=$r[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)ce[c]=t.getUint32(e,!1);for(let c=16;c<80;c++)ce[c]=yn(ce[c-3]^ce[c-8]^ce[c-14]^ce[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=gn(s,o,i),l=1518500249):c<40?(f=s^o^i,l=1859775393):c<60?(f=mn(s,o,i),l=2400959708):(f=s^o^i,l=3395469782);let u=yn(n,5)+f+a+l+ce[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(){gt(ce)}destroy(){this.set(0,0,0,0,0),gt(this.buffer)}},vc=Nr(()=>new jn);var Ec=vc;var ir=En;var Bc={sha1:Ec,"sha2-256":sr,"sha2-512":ir};function Gr(r,t,e,n,s){if(s!=="sha1"&&s!=="sha2-256"&&s!=="sha2-512"){let a=Object.keys(Bc).join(" / ");throw new L(`Hash '${s}' is unknown or not supported. Must be ${a}`)}let o=Bc[s],i=xc(o,r,t,{c:e,dkLen:n});return de.encode(i).substring(1)}function ar(r){if(typeof r!="object"||r===null)return!1;let t=Object.getPrototypeOf(r);return(t===null||t===Object.prototype||Object.getPrototypeOf(t)===null)&&!(Symbol.toStringTag in r)&&!(Symbol.iterator in r)}var{hasOwnProperty:Sc}=Object.prototype,{propertyIsEnumerable:lh}=Object,cr=(r,t,e)=>{Object.defineProperty(r,t,{value:e,writable:!0,enumerable:!0,configurable:!0})},uh=void 0,Ac={concatArrays:!1,ignoreUndefined:!1},qn=r=>{let t=[];for(let e in r)Sc.call(r,e)&&t.push(e);if(Object.getOwnPropertySymbols){let e=Object.getOwnPropertySymbols(r);for(let n of e)lh.call(r,n)&&t.push(n)}return t};function lr(r){return Array.isArray(r)?fh(r):ar(r)?hh(r):r}function fh(r){let t=r.slice(0,0);return qn(r).forEach(e=>{cr(t,e,lr(r[e]))}),t}function hh(r){let t=Object.getPrototypeOf(r)===null?Object.create(null):{};return qn(r).forEach(e=>{cr(t,e,lr(r[e]))}),t}var kc=(r,t,e,n)=>(e.forEach(s=>{typeof t[s]>"u"&&n.ignoreUndefined||(s in r&&r[s]!==Object.getPrototypeOf(r)?cr(r,s,ti(r[s],t[s],n)):cr(r,s,lr(t[s])))}),r),dh=(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++)Sc.call(o,a)&&(i.push(String(a)),o===r?cr(n,s++,o[a]):cr(n,s++,lr(o[a])));n=kc(n,o,qn(o).filter(a=>!i.includes(a)),e)}),n};function ti(r,t,e){return e.concatArrays&&Array.isArray(r)&&Array.isArray(t)?dh(r,t,e):!ar(t)||!ar(r)?lr(t):kc(r,t,qn(t),e)}function Ic(...r){let t=ti(lr(Ac),this!==uh&&this||{},Ac),e={_:{}};for(let n of r)if(n!==void 0){if(!ar(n))throw new TypeError("`"+n+"` is not an Option Object");e=ti(e,{_:n},t)}return e._}var $t="/",Cc=new TextEncoder().encode($t),$n=Cc[0],zr=class r{_buf;constructor(t,e){if(typeof t=="string")this._buf=V(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]!==$n)throw new Error("Invalid key")}toString(t="utf8"){return P(this._buf,t)}uint8Array(){return this._buf}get[Symbol.toStringTag](){return`Key(${this.toString()})`}static withNamespaces(t){return new r(t.join($t))}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=Cc),this._buf[0]!==$n){let t=new Uint8Array(this._buf.byteLength+1);t.fill($n,0,1),t.set(this._buf,1),this._buf=t}for(;this._buf.byteLength>1&&this._buf[this._buf.byteLength-1]===$n;)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($t).slice(1)}type(){return ph(this.baseNamespace())}name(){return yh(this.baseNamespace())}instance(t){return new r(this.toString()+":"+t)}path(){let t=this.parent().toString();return t.endsWith($t)||(t+=$t),t+=this.type(),new r(t)}parent(){let t=this.list();return t.length===1?new r($t):new r(t.slice(0,-1).join($t))}child(t){return this.toString()===$t?t:t.toString()===$t?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(),...gh(t.map(e=>e.namespaces()))])}};function ph(r){let t=r.split(":");return t.length<2?"":t.slice(0,-1).join(":")}function yh(r){let t=r.split(":");return t[t.length-1]}function gh(r){return[].concat(...r)}var Il=fi(Kc(),1);var ur={};ct(ur,{create:()=>Nh,derivedEmptyPasswordKey:()=>Gn});var Gn={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function Nh(r){let t=r?.algorithm??"AES-GCM",e=r?.keyLength??16,n=r?.nonceLength??12,s=r?.digest??"SHA-256",o=r?.saltLength??16,i=r?.iterations??32767,a=Z.get();e*=8;async function c(u,h){let d=a.getRandomValues(new Uint8Array(o)),b=a.getRandomValues(new Uint8Array(n)),w={name:t,iv:b};typeof h=="string"&&(h=V(h));let y;if(h.length===0){y=await a.subtle.importKey("jwk",Gn,{name:"AES-GCM"},!0,["encrypt"]);try{let N={name:"PBKDF2",salt:d,iterations:i,hash:{name:s}},A=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);y=await a.subtle.deriveKey(N,A,{name:t,length:e},!0,["encrypt"])}catch{y=await a.subtle.importKey("jwk",Gn,{name:"AES-GCM"},!0,["encrypt"])}}else{let N={name:"PBKDF2",salt:d,iterations:i,hash:{name:s}},A=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);y=await a.subtle.deriveKey(N,A,{name:t,length:e},!0,["encrypt"])}let v=await a.subtle.encrypt(w,y,u);return Me([d,w.iv,new Uint8Array(v)])}async function f(u,h){let d=u.subarray(0,o),b=u.subarray(o,o+n),w=u.subarray(o+n),y={name:t,iv:b};typeof h=="string"&&(h=V(h));let v;if(h.length===0)try{let A={name:"PBKDF2",salt:d,iterations:i,hash:{name:s}},R=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);v=await a.subtle.deriveKey(A,R,{name:t,length:e},!0,["decrypt"])}catch{v=await a.subtle.importKey("jwk",Gn,{name:"AES-GCM"},!0,["decrypt"])}else{let A={name:"PBKDF2",salt:d,iterations:i,hash:{name:s}},R=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);v=await a.subtle.deriveKey(A,R,{name:t,length:e},!0,["decrypt"])}let N=await a.subtle.decrypt(y,v,w);return new Uint8Array(N)}return{encrypt:c,decrypt:f}}var O=fi(Vc());function Ce(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 le(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 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=Ce(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,Ce(o,8)-n}function Oc(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=le(i,8,n),c=new Uint8Array(a);return c[0]|=128,a}let s=le(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 Pc(r,t){if(r.byteLength!==t.byteLength)return!1;let e=new Uint8Array(r),n=new Uint8Array(t);for(let s=0;s<e.length;s++)if(e[s]!==n[s])return!1;return!0}function mt(r,t){let e=r.toString(10);if(t<e.length)return"";let n=t-e.length,s=new Array(n);for(let i=0;i<n;i++)s[i]="0";return s.join("").concat(e)}var Hm=Math.log(2);function Jn(){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 Yt(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 Jr=class{constructor(){this.items=[]}write(t){this.items.push(t)}final(){return ni(this.items)}},Wr=[new Uint8Array([1])],Mc="0123456789";var hr="",Ut=new ArrayBuffer(0),si=new Uint8Array(0),Yr="EndOfContent",jc="OCTET STRING",qc="BIT STRING";function Xt(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?O.BufferSourceConverter.toUint8Array(o.valueHex):si}fromBER(n,s,o){let i=n instanceof ArrayBuffer?new Uint8Array(n):n;if(!Yt(this,i,s,o))return-1;let a=s+o;return this.valueHexView=i.subarray(s,a),this.valueHexView.length?(this.blockLength=o,a):(this.warnings.push("Zero buffer length"),s)}toBER(n=!1){return this.isHexOnly?n?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.byteLength===this.valueHexView.buffer.byteLength?this.valueHexView.buffer:this.valueHexView.slice().buffer:(this.error="Flag 'isHexOnly' is not set, abort",Ut)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:O.Convert.ToHex(this.valueHexView)}}},t.NAME="hexBlock",t}var zt=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=hr,warnings:n=[],valueBeforeDecode:s=si}={}){this.blockLength=t,this.error=e,this.warnings=n,this.valueBeforeDecodeView=O.BufferSourceConverter.toUint8Array(s)}toJSON(){return{blockName:this.constructor.NAME,blockLength:this.blockLength,error:this.error,warnings:this.warnings,valueBeforeDecode:O.Convert.ToHex(this.valueBeforeDecodeView)}}};zt.NAME="baseBlock";var it=class extends zt{fromBER(t,e,n){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}toBER(t,e){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}};it.NAME="valueBlock";var Yn=class extends Xt(zt){constructor({idBlock:t={}}={}){var e,n,s,o;super(),t?(this.isHexOnly=(e=t.isHexOnly)!==null&&e!==void 0?e:!1,this.valueHexView=t.valueHex?O.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",Ut}if(this.isConstructed&&(e|=32),this.tagNumber<31&&!this.isHexOnly){let s=new Uint8Array(1);if(!t){let o=this.tagNumber;o&=31,e|=o,s[0]=e}return s.buffer}if(!this.isHexOnly){let s=le(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=O.BufferSourceConverter.toUint8Array(t);if(!Yt(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 d=0;d<f.length;d++)h[d]=f[d];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=Ce(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}}};Yn.NAME="identificationBlock";var Xn=class extends zt{constructor({lenBlock:t={}}={}){var e,n,s;super(),this.isIndefiniteForm=(e=t.isIndefiniteForm)!==null&&e!==void 0?e:!1,this.longFormUsed=(n=t.longFormUsed)!==null&&n!==void 0?n:!1,this.length=(s=t.length)!==null&&s!==void 0?s:0}fromBER(t,e,n){let s=O.BufferSourceConverter.toUint8Array(t);if(!Yt(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=Ce(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=le(this.length,8);if(s.byteLength>127)return this.error="Too big length",Ut;if(e=new ArrayBuffer(s.byteLength+1),t)return e;let o=new Uint8Array(s);n=new Uint8Array(e),n[0]=s.byteLength|128;for(let i=0;i<s.byteLength;i++)n[i+1]=o[i];return e}return e=new ArrayBuffer(1),t===!1&&(n=new Uint8Array(e),n[0]=this.length),e}toJSON(){return{...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,longFormUsed:this.longFormUsed,length:this.length}}};Xn.NAME="lengthBlock";var C={},rt=class extends zt{constructor({name:t=hr,optional:e=!1,primitiveSchema:n,...s}={},o){super(s),this.name=t,this.optional=e,n&&(this.primitiveSchema=n),this.idBlock=new Yn(s),this.lenBlock=new Xn(s),this.valueBlock=o?new o(s):new it(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 Jr;e||$c(this);let s=this.idBlock.toBER(t);if(n.write(s),this.lenBlock.isIndefiniteForm)n.write(new Uint8Array([128]).buffer),this.valueBlock.toBER(t,n),n.write(new ArrayBuffer(2));else{let o=this.valueBlock.toBER(t);this.lenBlock.length=o.byteLength;let i=this.lenBlock.toBER(t);n.write(i),n.write(o)}return e?Ut:n.final()}toJSON(){let t={...super.toJSON(),idBlock:this.idBlock.toJSON(),lenBlock:this.lenBlock.toJSON(),valueBlock:this.valueBlock.toJSON(),name:this.name,optional:this.optional};return this.primitiveSchema&&(t.primitiveSchema=this.primitiveSchema.toJSON()),t}toString(t="ascii"){return t==="ascii"?this.onAsciiEncoding():O.Convert.ToHex(this.toBER())}onAsciiEncoding(){let t=this.constructor.NAME,e=O.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 Pc(e,n)}};rt.NAME="BaseBlock";function $c(r){var t;if(r instanceof C.Constructed)for(let e of r.valueBlock.value)$c(e)&&(r.lenBlock.isIndefiniteForm=!0);return!!(!((t=r.lenBlock)===null||t===void 0)&&t.isIndefiniteForm)}var Qn=class extends rt{getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}constructor({value:t=hr,...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}'`}};Qn.NAME="BaseStringBlock";var ts=class extends Xt(it){constructor({isHexOnly:t=!0,...e}={}){super(e),this.isHexOnly=t}};ts.NAME="PrimitiveValueBlock";var Gc,es=class extends rt{constructor(t={}){super(t,ts),this.idBlock.isConstructed=!1}};Gc=es;C.Primitive=Gc;es.NAME="PRIMITIVE";function Vh(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 Ds(r,t=0,e=r.length){let n=t,s=new rt({},it),o=new zt;if(!Yt(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=rt;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=C.EndOfContent;break;case 1:c=C.Boolean;break;case 2:c=C.Integer;break;case 3:c=C.BitString;break;case 4:c=C.OctetString;break;case 5:c=C.Null;break;case 6:c=C.ObjectIdentifier;break;case 10:c=C.Enumerated;break;case 12:c=C.Utf8String;break;case 13:c=C.RelativeObjectIdentifier;break;case 14:c=C.TIME;break;case 15:return s.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:s};case 16:c=C.Sequence;break;case 17:c=C.Set;break;case 18:c=C.NumericString;break;case 19:c=C.PrintableString;break;case 20:c=C.TeletexString;break;case 21:c=C.VideotexString;break;case 22:c=C.IA5String;break;case 23:c=C.UTCTime;break;case 24:c=C.GeneralizedTime;break;case 25:c=C.GraphicString;break;case 26:c=C.VisibleString;break;case 27:c=C.GeneralString;break;case 28:c=C.UniversalString;break;case 29:c=C.CharacterString;break;case 30:c=C.BmpString;break;case 31:c=C.DATE;break;case 32:c=C.TimeOfDay;break;case 33:c=C.DateTime;break;case 34:c=C.Duration;break;default:{let f=s.idBlock.isConstructed?new C.Constructed:new C.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?C.Constructed:C.Primitive}return s=Vh(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 Hs(r){if(!r.byteLength){let t=new rt({},it);return t.error="Input buffer has zero length",{offset:-1,result:t}}return Ds(O.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function Oh(r,t){return r?1:t}var Ht=class extends it{constructor({value:t=[],isIndefiniteForm:e=!1,...n}={}){super(n),this.value=t,this.isIndefiniteForm=e}fromBER(t,e,n){let s=O.BufferSourceConverter.toUint8Array(t);if(!Yt(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(;Oh(this.isIndefiniteForm,n)>0;){let i=Ds(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===Yr)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===Yr?this.value.pop():this.warnings.push("No EndOfContent block encoded")),o}toBER(t,e){let n=e||new Jr;for(let s=0;s<this.value.length;s++)this.value[s].toBER(t,n);return e?Ut:n.final()}toJSON(){let t={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let e of this.value)t.value.push(e.toJSON());return t}};Ht.NAME="ConstructedValueBlock";var zc,ue=class extends rt{constructor(t={}){super(t,Ht),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 Zu=Object.create;var xn=Object.defineProperty;var Yu=Object.getOwnPropertyDescriptor;var zu=Object.getOwnPropertyNames;var Wu=Object.getPrototypeOf,Ju=Object.prototype.hasOwnProperty;var Tr=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),ut=(r,t)=>{for(var e in t)xn(r,e,{get:t[e],enumerable:!0})},ki=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of zu(t))!Ju.call(r,s)&&s!==e&&xn(r,s,{get:()=>t[s],enumerable:!(n=Yu(t,s))||n.enumerable});return r};var Ii=(r,t,e)=>(e=r!=null?Zu(Wu(r)):{},ki(t||!r||!r.__esModule?xn(e,"default",{value:r,enumerable:!0}):e,r)),Xu=r=>ki(xn({},"__esModule",{value:!0}),r);var zc=Tr((Qm,Yc)=>{"use strict";function Mh(r){return r>=55296&&r<=56319}function Fh(r){return r>=56320&&r<=57343}Yc.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],Mh(i)&&Fh(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 Jc=Tr((tb,Wc)=>{"use strict";function qh(r){return r>=55296&&r<=56319}function jh(r){return r>=56320&&r<=57343}Wc.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),jh(s)?o!=null&&qh(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 Qc=Tr((eb,Xc)=>{"use strict";var $h=zc(),Gh=Jc();Xc.exports=$h.bind(null,Gh)});var ru=Tr((rb,eu)=>{"use strict";var Zh=Qc(),Yh=/[\/\?<>\\:\*\|"]/g,zh=/[\x00-\x1f\x80-\x9f]/g,Wh=/^\.+$/,Jh=/^(con|prn|aux|nul|com[0-9]|lpt[0-9])(\..*)?$/i,Xh=/[\. ]+$/;function tu(r,t){if(typeof r!="string")throw new Error("Input must be string");var e=r.replace(Yh,t).replace(zh,t).replace(Wh,t).replace(Jh,t).replace(Xh,t);return Zh(e,255)}eu.exports=function(r,t){var e=t&&t.replacement||"",n=tu(r,e);return e===""?n:tu(n,"")}});var nu=Tr(Ar=>{"use strict";var td="[object ArrayBuffer]",re=class r{static isArrayBuffer(t){return Object.prototype.toString.call(t)===td}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}},gi="string",ed=/^[0-9a-f\s]+$/i,rd=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,nd=/^[a-zA-Z0-9-_]+$/,ss=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=re.toUint8Array(t),n="";for(let o=0;o<e.length;o++)n+=String.fromCharCode(e[o]);return decodeURIComponent(escape(n))}},Nt=class{static toString(t,e=!1){let n=re.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}},os=class r{static isHex(t){return typeof t===gi&&ed.test(t)}static isBase64(t){return typeof t===gi&&rd.test(t)}static isBase64Url(t){return typeof t===gi&&nd.test(t)}static ToString(t,e="utf8"){let n=re.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 Nt.toString(n,!0);case"utf16":case"utf16be":return Nt.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 Nt.fromString(t,!0);case"utf16":case"utf16be":return Nt.fromString(t);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToBase64(t){let e=re.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 ss.fromString(t);case"utf16":case"utf16be":return Nt.fromString(t);case"utf16le":case"usc2":return Nt.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 ss.toString(t);case"utf16":case"utf16be":return Nt.toString(t);case"utf16le":case"usc2":return Nt.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=re.toUint8Array(t),n="";for(let s=0;s<e.length;s++)n+=String.fromCharCode(e[s]);return n}static ToHex(t){let e=re.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 Nt.toString(t,e)}static FromUtf16String(t,e=!1){return Nt.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,"")||""}};os.DEFAULT_UTF8_ENCODING="utf8";function sd(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 od(...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 id(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}Ar.BufferSourceConverter=re;Ar.Convert=os;Ar.assign=sd;Ar.combine=od;Ar.isEqual=id});var Bd={};ut(Bd,{keychain:()=>Ed});var _r=class extends Error{constructor(t="An error occurred while signing a message"){super(t),this.name="SigningError"}},Ur=class extends Error{constructor(t="An error occurred while verifying a message"){super(t),this.name="VerificationError"}},vn=class extends Error{constructor(t="Missing Web Crypto API"){super(t),this.name="WebCryptoMissingError"}};var Ci={get(r=globalThis){let t=r.crypto;if(t?.subtle==null)throw new vn("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 X=Ci;var U=class extends Error{static name="InvalidParametersError";constructor(t="Invalid parameters"){super(t),this.name="InvalidParametersError"}},Ge=class extends Error{static name="InvalidPublicKeyError";constructor(t="Invalid public key"){super(t),this.name="InvalidPublicKeyError"}},Lr=class extends Error{static name="InvalidPrivateKeyError";constructor(t="Invalid private key"){super(t),this.name="InvalidPrivateKeyError"}};var En=class extends Error{static name="NotFoundError";constructor(t="Not found"){super(t),this.name="NotFoundError"}};var Ze=class extends Error{static name="UnsupportedKeyTypeError";constructor(t="Unsupported key type"){super(t),this.name="UnsupportedKeyTypeError"}};var Ni=Symbol.for("@libp2p/service-capabilities"),_d=Symbol.for("@libp2p/service-dependencies");var to={};ut(to,{base58btc:()=>Q,base58flickr:()=>ol});var Qd=new Uint8Array(0);function Ti(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function Mt(r){if(r instanceof Uint8Array&&r.constructor.name==="Uint8Array")return r;if(r instanceof ArrayBuffer)return new Uint8Array(r);if(ArrayBuffer.isView(r))return new Uint8Array(r.buffer,r.byteOffset,r.byteLength);throw new Error("Unknown type, must be binary type")}function _i(r){return new TextEncoder().encode(r)}function Ui(r){return new TextDecoder().decode(r)}function Qu(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),l=Math.log(a)/Math.log(256),h=Math.log(256)/Math.log(a);function u(p){if(p instanceof Uint8Array||(ArrayBuffer.isView(p)?p=new Uint8Array(p.buffer,p.byteOffset,p.byteLength):Array.isArray(p)&&(p=Uint8Array.from(p))),!(p instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(p.length===0)return"";for(var y=0,g=0,v=0,k=p.length;v!==k&&p[v]===0;)v++,y++;for(var B=(k-v)*h+1>>>0,N=new Uint8Array(B);v!==k;){for(var H=p[v],I=0,O=B-1;(H!==0||I<g)&&O!==-1;O--,I++)H+=256*N[O]>>>0,N[O]=H%a>>>0,H=H/a>>>0;if(H!==0)throw new Error("Non-zero carry");g=I,v++}for(var V=B-g;V!==B&&N[V]===0;)V++;for(var _=c.repeat(y);V<B;++V)_+=r.charAt(N[V]);return _}function f(p){if(typeof p!="string")throw new TypeError("Expected String");if(p.length===0)return new Uint8Array;var y=0;if(p[y]!==" "){for(var g=0,v=0;p[y]===c;)g++,y++;for(var k=(p.length-y)*l+1>>>0,B=new Uint8Array(k);p[y];){var N=e[p.charCodeAt(y)];if(N===255)return;for(var H=0,I=k-1;(N!==0||H<v)&&I!==-1;I--,H++)N+=a*B[I]>>>0,B[I]=N%256>>>0,N=N/256>>>0;if(N!==0)throw new Error("Non-zero carry");v=H,y++}if(p[y]!==" "){for(var O=k-v;O!==k&&B[O]===0;)O++;for(var V=new Uint8Array(g+(k-O)),_=g;O!==k;)V[_++]=B[O++];return V}}}function d(p){var y=f(p);if(y)return y;throw new Error(`Non-${t} character`)}return{encode:u,decodeUnsafe:f,decode:d}}var tl=Qu,el=tl,Ri=el;var Ws=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")}},Js=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 Di(this,t)}},Xs=class{decoders;constructor(t){this.decoders=t}or(t){return Di(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 Di(r,t){return new Xs({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var Qs=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 Ws(t,e,n),this.decoder=new Js(t,e,s)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function Ye({name:r,prefix:t,encode:e,decode:n}){return new Qs(r,t,e,n)}function le({name:r,prefix:t,alphabet:e}){let{encode:n,decode:s}=Ri(e,r);return Ye({prefix:t,name:r,encode:n,decode:o=>Mt(s(o))})}function rl(r,t,e,n){let s=r.length;for(;r[s-1]==="=";)--s;let o=new Uint8Array(s*e/8|0),i=0,a=0,c=0;for(let l=0;l<s;++l){let h=t[r[l]];if(h===void 0)throw new SyntaxError(`Non-${n} character`);a=a<<e|h,i+=e,i>=8&&(i-=8,o[c++]=255&a>>i)}if(i>=e||(255&a<<8-i)!==0)throw new SyntaxError("Unexpected end of data");return o}function nl(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 sl(r){let t={};for(let e=0;e<r.length;++e)t[r[e]]=e;return t}function W({name:r,prefix:t,bitsPerChar:e,alphabet:n}){let s=sl(n);return Ye({prefix:t,name:r,encode(o){return nl(o,n,e)},decode(o){return rl(o,s,e,r)}})}var Q=le({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),ol=le({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var eo={};ut(eo,{base32:()=>ze,base32hex:()=>ul,base32hexpad:()=>fl,base32hexpadupper:()=>hl,base32hexupper:()=>ll,base32pad:()=>al,base32padupper:()=>cl,base32upper:()=>il,base32z:()=>dl});var ze=W({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),il=W({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),al=W({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),cl=W({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),ul=W({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),ll=W({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),fl=W({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),hl=W({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),dl=W({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var ro={};ut(ro,{base36:()=>Rr,base36upper:()=>pl});var Rr=le({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),pl=le({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var gl=Oi,Hi=128,yl=127,ml=~yl,bl=Math.pow(2,31);function Oi(r,t,e){t=t||[],e=e||0;for(var n=e;r>=bl;)t[e++]=r&255|Hi,r/=128;for(;r&ml;)t[e++]=r&255|Hi,r>>>=7;return t[e]=r|0,Oi.bytes=e-n+1,t}var wl=no,xl=128,Ki=127;function no(r,n){var e=0,n=n||0,s=0,o=n,i,a=r.length;do{if(o>=a)throw no.bytes=0,new RangeError("Could not decode varint");i=r[o++],e+=s<28?(i&Ki)<<s:(i&Ki)*Math.pow(2,s),s+=7}while(i>=xl);return no.bytes=o-n,e}var vl=Math.pow(2,7),El=Math.pow(2,14),Bl=Math.pow(2,21),Al=Math.pow(2,28),Sl=Math.pow(2,35),kl=Math.pow(2,42),Il=Math.pow(2,49),Cl=Math.pow(2,56),Nl=Math.pow(2,63),Tl=function(r){return r<vl?1:r<El?2:r<Bl?3:r<Al?4:r<Sl?5:r<kl?6:r<Il?7:r<Cl?8:r<Nl?9:10},_l={encode:gl,decode:wl,encodingLength:Tl},Ul=_l,Dr=Ul;function Hr(r,t=0){return[Dr.decode(r,t),Dr.decode.bytes]}function We(r,t,e=0){return Dr.encode(r,t,e),t}function Je(r){return Dr.encodingLength(r)}function Tt(r,t){let e=t.byteLength,n=Je(r),s=n+Je(e),o=new Uint8Array(s+e);return We(r,o,0),We(e,o,n),o.set(t,s),new Xe(r,e,t,o)}function Vi(r){let t=Mt(r),[e,n]=Hr(t),[s,o]=Hr(t.subarray(n)),i=t.subarray(n+o);if(i.byteLength!==s)throw new Error("Incorrect length");return new Xe(e,s,i,t)}function Pi(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&Ti(r.bytes,e.bytes)}}var Xe=class{code;size;digest;bytes;constructor(t,e,n,s){this.code=t,this.size=e,this.digest=n,this.bytes=s}};function Mi(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return Rl(e,so(r),t??Q.encoder);default:return Dl(e,so(r),t??ze.encoder)}}var Fi=new WeakMap;function so(r){let t=Fi.get(r);if(t==null){let e=new Map;return Fi.set(r,e),e}return t}var kt=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!==Or)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==Hl)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=Tt(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&&Pi(t.multihash,n.multihash)}toString(t){return Mi(this,t)}toJSON(){return{"/":Mi(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??qi(n,s,o.bytes))}else if(e[Kl]===!0){let{version:n,multihash:s,code:o}=e,i=Vi(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!==Or)throw new Error(`Version 0 CID must use dag-pb (code: ${Or}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let s=qi(t,e,n.bytes);return new r(t,e,n,s)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,Or,t)}static createV1(t,e){return r.create(1,t,e)}static decode(t){let[e,n]=r.decodeFirst(t);if(n.length!==0)throw new Error("Incorrect length");return e}static decodeFirst(t){let e=r.inspectBytes(t),n=e.size-e.multihashSize,s=Mt(t.subarray(n,n+e.multihashSize));if(s.byteLength!==e.multihashSize)throw new Error("Incorrect length");let o=s.subarray(e.multihashSize-e.digestSize),i=new Xe(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,f]=Hr(t.subarray(e));return e+=f,u},s=n(),o=Or;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(),l=e+c,h=l-i;return{version:s,codec:o,multihashCode:a,digestSize:c,multihashSize:h,size:l}}static parse(t,e){let[n,s]=Ll(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 so(o).set(n,t),o}};function Ll(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 ze.prefix:{let e=t??ze;return[ze.prefix,e.decode(r)]}case Rr.prefix:{let e=t??Rr;return[Rr.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 Rl(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 Dl(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 Or=112,Hl=18;function qi(r,t,e){let n=Je(r),s=n+Je(t),o=new Uint8Array(s+e.byteLength);return We(r,o,0),We(t,o,n),o.set(e,s),o}var Kl=Symbol.for("@ipld/js-cid/CID");var oo={};ut(oo,{identity:()=>Se});var ji=0,Ol="identity",$i=Mt;function Vl(r){return Tt(ji,$i(r))}var Se={code:ji,name:Ol,encode:$i,digest:Vl};function gt(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function Ft(r=0){return new Uint8Array(r)}function Bt(r=0){return new Uint8Array(r)}function Qe(r,t){t==null&&(t=r.reduce((s,o)=>s+o.length,0));let e=Bt(t),n=0;for(let s of r)e.set(s,n),n+=s.length;return e}var Zi=Symbol.for("@achingbrain/uint8arraylist");function Gi(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 An(r){return!!r?.[Zi]}var lt=class r{bufs;length;[Zi]=!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(An(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(An(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=Gi(this.bufs,t);return e.buf[e.index]}set(t,e){let n=Gi(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(An(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 Qe(n,s)}subarray(t,e){let{bufs:n,length:s}=this._subList(t,e);return n.length===1?n[0]:Qe(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 l=t>=a&&t<c,h=e>a&&e<=c;if(l&&h){if(t===a&&e===c){n.push(i);break}let u=t-a;n.push(i.subarray(u,u+(e-t)));break}if(l){if(t===0){n.push(i);continue}n.push(i.subarray(t-a));continue}if(h){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(!An(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,l=n.byteLength-1,h;for(let u=e;u<=c;u+=h){h=0;for(let f=l;f>=0;f--){let d=this.get(u+f);if(n[f]!==d){h=Math.max(1,f-a[d]);break}}if(h===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=Bt(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=Ft(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=Ft(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=Ft(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=Bt(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=Ft(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=Ft(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=Ft(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=Ft(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=Ft(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(!gt(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 io={};ut(io,{base10:()=>Pl});var Pl=le({prefix:"9",name:"base10",alphabet:"0123456789"});var ao={};ut(ao,{base16:()=>Ml,base16upper:()=>Fl});var Ml=W({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Fl=W({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var co={};ut(co,{base2:()=>ql});var ql=W({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var uo={};ut(uo,{base256emoji:()=>Yl});var Yi=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}"),jl=Yi.reduce((r,t,e)=>(r[e]=t,r),[]),$l=Yi.reduce((r,t,e)=>{let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);return r[n]=e,r},[]);function Gl(r){return r.reduce((t,e)=>(t+=jl[e],t),"")}function Zl(r){let t=[];for(let e of r){let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);let s=$l[n];if(s==null)throw new Error(`Non-base256emoji character: ${e}`);t.push(s)}return new Uint8Array(t)}var Yl=Ye({prefix:"\u{1F680}",name:"base256emoji",encode:Gl,decode:Zl});var lo={};ut(lo,{base64:()=>ke,base64pad:()=>zl,base64url:()=>Wl,base64urlpad:()=>Jl});var ke=W({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),zl=W({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Wl=W({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Jl=W({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var fo={};ut(fo,{base8:()=>Xl});var Xl=W({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var ho={};ut(ho,{identity:()=>Ql});var Ql=Ye({prefix:"\0",name:"identity",encode:r=>Ui(r),decode:r=>_i(r)});var H0=new TextEncoder,K0=new TextDecoder;var yo={};ut(yo,{sha256:()=>tr,sha512:()=>rf});function go({name:r,code:t,encode:e}){return new po(r,t,e)}var po=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?Tt(this.code,e):e.then(n=>Tt(this.code,n))}else throw Error("Unknown type, must be binary type")}};function Wi(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var tr=go({name:"sha2-256",code:18,encode:Wi("SHA-256")}),rf=go({name:"sha2-512",code:19,encode:Wi("SHA-512")});var mo={...ho,...co,...fo,...io,...ao,...eo,...ro,...to,...lo,...uo},z0={...yo,...oo};function Xi(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var Ji=Xi("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),bo=Xi("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=Bt(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),nf={utf8:Ji,"utf-8":Ji,hex:mo.base16,latin1:bo,ascii:bo,binary:bo,...mo},Sn=nf;function M(r,t="utf8"){let e=Sn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function q(r,t="utf8"){let e=Sn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}var sf=parseInt("11111",2),wo=parseInt("10000000",2),of=parseInt("01111111",2),Qi={0:Vr,1:Vr,2:af,3:lf,4:ff,5:uf,6:cf,16:Vr,22:Vr,48:Vr};function _t(r,t={offset:0}){let e=r[t.offset]&sf;if(t.offset++,Qi[e]!=null)return Qi[e](r,t);throw new Error("No decoder for tag "+e)}function Pr(r,t){let e=0;if((r[t.offset]&wo)===wo){let n=r[t.offset]&of,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 Vr(r,t){Pr(r,t);let e=[];for(;!(t.offset>=r.byteLength);){let n=_t(r,t);if(n===null)break;e.push(n)}return e}function af(r,t){let e=Pr(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 cf(r,t){let e=Pr(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 l=r[t.offset];if(t.offset++,c.push(l&127),l<128){c.reverse();let h=0;for(let u=0;u<c.length;u++)h+=c[u]<<u*7;a+=`.${h}`,c=[]}}return a}function uf(r,t){return t.offset++,null}function lf(r,t){let e=Pr(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 ff(r,t){let e=Pr(r,t),n=r.subarray(t.offset,t.offset+e);return t.offset+=e,n}function hf(r){let t=r.toString(16);t.length%2===1&&(t="0"+t);let e=new lt;for(let n=0;n<t.length;n+=2)e.append(Uint8Array.from([parseInt(`${t[n]}${t[n+1]}`,16)]));return e}function kn(r){if(r.byteLength<128)return Uint8Array.from([r.byteLength]);let t=hf(r.byteLength);return new lt(Uint8Array.from([t.byteLength|wo]),t)}function ft(r){let t=new lt,e=128;return(r.subarray()[0]&e)===e&&t.append(Uint8Array.from([0])),t.append(r),new lt(Uint8Array.from([2]),kn(t),t)}function Mr(r){let t=Uint8Array.from([0]),e=new lt(t,r);return new lt(Uint8Array.from([3]),kn(e),e)}function ta(r){return new lt(Uint8Array.from([4]),kn(r),r)}function Ut(r,t=48){let e=new lt;for(let n of r)e.append(n);return new lt(Uint8Array.from([t]),kn(e),e)}var ea="1.2.840.10045.3.1.7",ra="1.3.132.0.34",na="1.3.132.0.35";async function sa(r,t,e){let n=await crypto.subtle.importKey("jwk",r,{name:"ECDSA",namedCurve:r.crv??"P-256"},!1,["sign"]);e?.signal?.throwIfAborted();let s=await crypto.subtle.sign({name:"ECDSA",hash:{name:"SHA-256"}},n,t.subarray());return e?.signal?.throwIfAborted(),new Uint8Array(s,0,s.byteLength)}async function oa(r,t,e,n){let s=await crypto.subtle.importKey("jwk",r,{name:"ECDSA",namedCurve:r.crv??"P-256"},!1,["verify"]);n?.signal?.throwIfAborted();let o=await crypto.subtle.verify({name:"ECDSA",hash:{name:"SHA-256"}},s,t,e.subarray());return n?.signal?.throwIfAborted(),o}var df=Uint8Array.from([6,8,42,134,72,206,61,3,1,7]),pf=Uint8Array.from([6,5,43,129,4,0,34]),gf=Uint8Array.from([6,5,43,129,4,0,35]),yf={ext:!0,kty:"EC",crv:"P-256"},mf={ext:!0,kty:"EC",crv:"P-384"},bf={ext:!0,kty:"EC",crv:"P-521"},xo=32,vo=48,Eo=66;function ia(r){let t=_t(r);return Bo(t)}function Bo(r){let t=r[1],e=q(t,"base64url"),n=r[2][1][0],s=1,o,i;if(t.byteLength===xo)return o=q(n.subarray(s,s+xo),"base64url"),i=q(n.subarray(s+xo),"base64url"),new er({...yf,key_ops:["sign"],d:e,x:o,y:i});if(t.byteLength===vo)return o=q(n.subarray(s,s+vo),"base64url"),i=q(n.subarray(s+vo),"base64url"),new er({...mf,key_ops:["sign"],d:e,x:o,y:i});if(t.byteLength===Eo)return o=q(n.subarray(s,s+Eo),"base64url"),i=q(n.subarray(s+Eo),"base64url"),new er({...bf,key_ops:["sign"],d:e,x:o,y:i});throw new U(`Private key length was wrong length, got ${t.byteLength}, expected 32, 48 or 66`)}function aa(r){return Ut([ft(Uint8Array.from([1])),ta(M(r.d??"","base64url")),Ut([ua(r.crv)],160),Ut([Mr(new lt(Uint8Array.from([4]),M(r.x??"","base64url"),M(r.y??"","base64url")))],161)]).subarray()}function ca(r){return Ut([ft(Uint8Array.from([1])),Ut([ua(r.crv)],160),Ut([Mr(new lt(Uint8Array.from([4]),M(r.x??"","base64url"),M(r.y??"","base64url")))],161)]).subarray()}function ua(r){if(r==="P-256")return df;if(r==="P-384")return pf;if(r==="P-521")return gf;throw new U(`Invalid curve ${r}`)}var In=class{type="ECDSA";jwk;_raw;constructor(t){this.jwk=t}get raw(){return this._raw==null&&(this._raw=ca(this.jwk)),this._raw}toMultihash(){return Se.digest(rr(this))}toCID(){return kt.createV1(114,this.toMultihash())}toString(){return Q.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:gt(this.raw,t.raw)}async verify(t,e,n){return oa(this.jwk,e,t,n)}},er=class{type="ECDSA";jwk;publicKey;_raw;constructor(t){this.jwk=t,this.publicKey=new In({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=aa(this.jwk)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:gt(this.raw,t.raw)}async sign(t,e){return sa(this.jwk,t,e)}};var Ie=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;function Ce(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function jt(r){if(!Number.isSafeInteger(r)||r<0)throw new Error("positive integer expected, got "+r)}function z(r,...t){if(!Ce(r))throw new Error("Uint8Array expected");if(t.length>0&&!t.includes(r.length))throw new Error("Uint8Array expected of length "+t+", got length="+r.length)}function sr(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.createHasher");jt(r.outputLen),jt(r.blockLen)}function or(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 fa(r,t){z(r);let e=t.outputLen;if(r.length<e)throw new Error("digestInto() expects output buffer of length at least "+e)}function yt(...r){for(let t=0;t<r.length;t++)r[t].fill(0)}function Ne(r){return new DataView(r.buffer,r.byteOffset,r.byteLength)}function Lt(r,t){return r<<32-t|r>>>t}function Cn(r,t){return r<<t|r>>>32-t>>>0}var ha=typeof Uint8Array.from([]).toHex=="function"&&typeof Uint8Array.fromHex=="function",wf=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function It(r){if(z(r),ha)return r.toHex();let t="";for(let e=0;e<r.length;e++)t+=wf[r[e]];return t}var qt={_0:48,_9:57,A:65,F:70,a:97,f:102};function la(r){if(r>=qt._0&&r<=qt._9)return r-qt._0;if(r>=qt.A&&r<=qt.F)return r-(qt.A-10);if(r>=qt.a&&r<=qt.f)return r-(qt.a-10)}function Te(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);if(ha)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=la(r.charCodeAt(o)),a=la(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}var xf=async()=>{};async function da(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 xf(),n+=o)}}function Nn(r){if(typeof r!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(r))}function Fr(r){return typeof r=="string"&&(r=Nn(r)),z(r),r}function Ao(r){return typeof r=="string"&&(r=Nn(r)),z(r),r}function mt(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];z(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 pa(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 nr=class{};function qr(r){let t=n=>r().update(Fr(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function _e(r=32){if(Ie&&typeof Ie.getRandomValues=="function")return Ie.getRandomValues(new Uint8Array(r));if(Ie&&typeof Ie.randomBytes=="function")return Uint8Array.from(Ie.randomBytes(r));throw new Error("crypto.getRandomValues must be defined")}function vf(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,l=n?0:4;r.setUint32(t+c,i,n),r.setUint32(t+l,a,n)}function Tn(r,t,e){return r&t^~r&e}function _n(r,t,e){return r&t^r&e^t&e}var Ue=class extends nr{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=Ne(this.buffer)}update(t){or(this),t=Fr(t),z(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=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){or(this),fa(t,this),this.finished=!0;let{buffer:e,view:n,blockLen:s,isLE:o}=this,{pos:i}=this;e[i++]=128,yt(this.buffer.subarray(i)),this.padOffset>s-i&&(this.process(n,0),i=0);for(let u=i;u<s;u++)e[u]=0;vf(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 l=c/4,h=this.get();if(l>h.length)throw new Error("_sha2: outputLen bigger than state");for(let u=0;u<l;u++)a.setUint32(4*u,h[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()}},$t=Uint32Array.from([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]);var st=Uint32Array.from([1779033703,4089235720,3144134277,2227873595,1013904242,4271175723,2773480762,1595750129,1359893119,2917565137,2600822924,725511199,528734635,4215389547,1541459225,327033209]);var Un=BigInt(4294967295),ga=BigInt(32);function Ef(r,t=!1){return t?{h:Number(r&Un),l:Number(r>>ga&Un)}:{h:Number(r>>ga&Un)|0,l:Number(r&Un)|0}}function ya(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}=Ef(r[o],t);[n[o],s[o]]=[i,a]}return[n,s]}var So=(r,t,e)=>r>>>e,ko=(r,t,e)=>r<<32-e|t>>>e,Le=(r,t,e)=>r>>>e|t<<32-e,Re=(r,t,e)=>r<<32-e|t>>>e,jr=(r,t,e)=>r<<64-e|t>>>e-32,$r=(r,t,e)=>r>>>e-32|t<<64-e;function Ht(r,t,e,n){let s=(t>>>0)+(n>>>0);return{h:r+e+(s/2**32|0)|0,l:s|0}}var ma=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),ba=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,wa=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),xa=(r,t,e,n,s)=>t+e+n+s+(r/2**32|0)|0,va=(r,t,e,n,s)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(s>>>0),Ea=(r,t,e,n,s,o)=>t+e+n+s+o+(r/2**32|0)|0;var Af=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),Ln=class extends Ue{constructor(t=32){super(64,t,8,!1),this.A=$t[0]|0,this.B=$t[1]|0,this.C=$t[2]|0,this.D=$t[3]|0,this.E=$t[4]|0,this.F=$t[5]|0,this.G=$t[6]|0,this.H=$t[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 f=fe[u-15],d=fe[u-2],p=Lt(f,7)^Lt(f,18)^f>>>3,y=Lt(d,17)^Lt(d,19)^d>>>10;fe[u]=y+fe[u-7]+p+fe[u-16]|0}let{A:n,B:s,C:o,D:i,E:a,F:c,G:l,H:h}=this;for(let u=0;u<64;u++){let f=Lt(a,6)^Lt(a,11)^Lt(a,25),d=h+f+Tn(a,c,l)+Af[u]+fe[u]|0,y=(Lt(n,2)^Lt(n,13)^Lt(n,22))+_n(n,s,o)|0;h=l,l=c,c=a,a=i+d|0,i=o,o=s,s=n,n=d+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,l=l+this.G|0,h=h+this.H|0,this.set(n,s,o,i,a,c,l,h)}roundClean(){yt(fe)}destroy(){this.set(0,0,0,0,0,0,0,0),yt(this.buffer)}};var Ba=ya(["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))),Sf=Ba[0],kf=Ba[1],he=new Uint32Array(80),de=new Uint32Array(80),Rn=class extends Ue{constructor(t=64){super(128,t,16,!1),this.Ah=st[0]|0,this.Al=st[1]|0,this.Bh=st[2]|0,this.Bl=st[3]|0,this.Ch=st[4]|0,this.Cl=st[5]|0,this.Dh=st[6]|0,this.Dl=st[7]|0,this.Eh=st[8]|0,this.El=st[9]|0,this.Fh=st[10]|0,this.Fl=st[11]|0,this.Gh=st[12]|0,this.Gl=st[13]|0,this.Hh=st[14]|0,this.Hl=st[15]|0}get(){let{Ah:t,Al:e,Bh:n,Bl:s,Ch:o,Cl:i,Dh:a,Dl:c,Eh:l,El:h,Fh:u,Fl:f,Gh:d,Gl:p,Hh:y,Hl:g}=this;return[t,e,n,s,o,i,a,c,l,h,u,f,d,p,y,g]}set(t,e,n,s,o,i,a,c,l,h,u,f,d,p,y,g){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=l|0,this.El=h|0,this.Fh=u|0,this.Fl=f|0,this.Gh=d|0,this.Gl=p|0,this.Hh=y|0,this.Hl=g|0}process(t,e){for(let B=0;B<16;B++,e+=4)he[B]=t.getUint32(e),de[B]=t.getUint32(e+=4);for(let B=16;B<80;B++){let N=he[B-15]|0,H=de[B-15]|0,I=Le(N,H,1)^Le(N,H,8)^So(N,H,7),O=Re(N,H,1)^Re(N,H,8)^ko(N,H,7),V=he[B-2]|0,_=de[B-2]|0,b=Le(V,_,19)^jr(V,_,61)^So(V,_,6),m=Re(V,_,19)^$r(V,_,61)^ko(V,_,6),E=wa(O,m,de[B-7],de[B-16]),A=xa(E,I,b,he[B-7],he[B-16]);he[B]=A|0,de[B]=E|0}let{Ah:n,Al:s,Bh:o,Bl:i,Ch:a,Cl:c,Dh:l,Dl:h,Eh:u,El:f,Fh:d,Fl:p,Gh:y,Gl:g,Hh:v,Hl:k}=this;for(let B=0;B<80;B++){let N=Le(u,f,14)^Le(u,f,18)^jr(u,f,41),H=Re(u,f,14)^Re(u,f,18)^$r(u,f,41),I=u&d^~u&y,O=f&p^~f&g,V=va(k,H,O,kf[B],de[B]),_=Ea(V,v,N,I,Sf[B],he[B]),b=V|0,m=Le(n,s,28)^jr(n,s,34)^jr(n,s,39),E=Re(n,s,28)^$r(n,s,34)^$r(n,s,39),A=n&o^n&a^o&a,L=s&i^s&c^i&c;v=y|0,k=g|0,y=d|0,g=p|0,d=u|0,p=f|0,{h:u,l:f}=Ht(l|0,h|0,_|0,b|0),l=a|0,h=c|0,a=o|0,c=i|0,o=n|0,i=s|0;let R=ma(b,E,L);n=ba(R,_,m,A),s=R|0}({h:n,l:s}=Ht(this.Ah|0,this.Al|0,n|0,s|0)),{h:o,l:i}=Ht(this.Bh|0,this.Bl|0,o|0,i|0),{h:a,l:c}=Ht(this.Ch|0,this.Cl|0,a|0,c|0),{h:l,l:h}=Ht(this.Dh|0,this.Dl|0,l|0,h|0),{h:u,l:f}=Ht(this.Eh|0,this.El|0,u|0,f|0),{h:d,l:p}=Ht(this.Fh|0,this.Fl|0,d|0,p|0),{h:y,l:g}=Ht(this.Gh|0,this.Gl|0,y|0,g|0),{h:v,l:k}=Ht(this.Hh|0,this.Hl|0,v|0,k|0),this.set(n,s,o,i,a,c,l,h,u,f,d,p,y,g,v,k)}roundClean(){yt(he,de)}destroy(){yt(this.buffer),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}};var Dn=qr(()=>new Ln);var Hn=qr(()=>new Rn);var No=BigInt(0),Co=BigInt(1);function Gt(r,t){if(typeof t!="boolean")throw new Error(r+" boolean expected, got "+t)}function Gr(r){let t=r.toString(16);return t.length&1?"0"+t:t}function Aa(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return r===""?No:BigInt("0x"+r)}function ir(r){return Aa(It(r))}function Zt(r){return z(r),Aa(It(Uint8Array.from(r).reverse()))}function Kn(r,t){return Te(r.toString(16).padStart(t*2,"0"))}function Yt(r,t){return Kn(r,t).reverse()}function $(r,t,e){let n;if(typeof t=="string")try{n=Te(t)}catch(o){throw new Error(r+" must be hex string or Uint8Array, cause: "+o)}else if(Ce(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 Sa(r,t){if(r.length!==t.length)return!1;let e=0;for(let n=0;n<r.length;n++)e|=r[n]^t[n];return e===0}var Io=r=>typeof r=="bigint"&&No<=r;function ka(r,t,e){return Io(r)&&Io(t)&&Io(e)&&t<=r&&r<e}function pe(r,t,e,n){if(!ka(t,e,n))throw new Error("expected valid "+r+": "+e+" <= n < "+n+", got "+t)}function On(r){let t;for(t=0;r>No;r>>=Co,t+=1);return t}var ge=r=>(Co<<BigInt(r))-Co;function Ia(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=d=>new Uint8Array(d),s=d=>Uint8Array.of(d),o=n(r),i=n(r),a=0,c=()=>{o.fill(1),i.fill(0),a=0},l=(...d)=>e(i,o,...d),h=(d=n(0))=>{i=l(s(0),d),o=l(),d.length!==0&&(i=l(s(1),d),o=l())},u=()=>{if(a++>=1e3)throw new Error("drbg: tried 1000 values");let d=0,p=[];for(;d<t;){o=l();let y=o.slice();p.push(y),d+=o.length}return mt(...p)};return(d,p)=>{c(),h(d);let y;for(;!(y=p(u()));)h();return c(),y}}function ye(r,t,e={}){if(!r||typeof r!="object")throw new Error("expected valid options object");function n(s,o,i){let a=r[s];if(i&&a===void 0)return;let c=typeof a;if(c!==o||a===null)throw new Error(`param "${s}" is invalid: expected ${o}, got ${c}`)}Object.entries(t).forEach(([s,o])=>n(s,o,!1)),Object.entries(e).forEach(([s,o])=>n(s,o,!0))}function ar(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 ht=BigInt(0),nt=BigInt(1),De=BigInt(2),Ta=BigInt(3),_a=BigInt(4),Ua=BigInt(5),If=BigInt(7),La=BigInt(8),Cf=BigInt(9),Ra=BigInt(16);function J(r,t){let e=r%t;return e>=ht?e:t+e}function Y(r,t,e){let n=r;for(;t-- >ht;)n*=n,n%=e;return n}function Ca(r,t){if(r===ht)throw new Error("invert: expected non-zero number");if(t<=ht)throw new Error("invert: expected positive modulus, got "+t);let e=J(r,t),n=t,s=ht,o=nt,i=nt,a=ht;for(;e!==ht;){let l=n/e,h=n%e,u=s-i*l,f=o-a*l;n=e,e=h,s=i,o=a,i=u,a=f}if(n!==nt)throw new Error("invert: does not exist");return J(s,t)}function To(r,t,e){if(!r.eql(r.sqr(t),e))throw new Error("Cannot find square root")}function Da(r,t){let e=(r.ORDER+nt)/_a,n=r.pow(t,e);return To(r,n,t),n}function Nf(r,t){let e=(r.ORDER-Ua)/La,n=r.mul(t,De),s=r.pow(n,e),o=r.mul(t,s),i=r.mul(r.mul(o,De),s),a=r.mul(o,r.sub(i,r.ONE));return To(r,a,t),a}function Tf(r){let t=At(r),e=Ha(r),n=e(t,t.neg(t.ONE)),s=e(t,n),o=e(t,t.neg(n)),i=(r+If)/Ra;return(a,c)=>{let l=a.pow(c,i),h=a.mul(l,n),u=a.mul(l,s),f=a.mul(l,o),d=a.eql(a.sqr(h),c),p=a.eql(a.sqr(u),c);l=a.cmov(l,h,d),h=a.cmov(f,u,p);let y=a.eql(a.sqr(h),c),g=a.cmov(l,h,y);return To(a,g,c),g}}function Ha(r){if(r<Ta)throw new Error("sqrt is not defined for small field");let t=r-nt,e=0;for(;t%De===ht;)t/=De,e++;let n=De,s=At(r);for(;Na(s,n)===1;)if(n++>1e3)throw new Error("Cannot find square root: probably non-prime P");if(e===1)return Da;let o=s.pow(n,t),i=(t+nt)/De;return function(c,l){if(c.is0(l))return l;if(Na(c,l)!==1)throw new Error("Cannot find square root");let h=e,u=c.mul(c.ONE,o),f=c.pow(l,t),d=c.pow(l,i);for(;!c.eql(f,c.ONE);){if(c.is0(f))return c.ZERO;let p=1,y=c.sqr(f);for(;!c.eql(y,c.ONE);)if(p++,y=c.sqr(y),p===h)throw new Error("Cannot find square root");let g=nt<<BigInt(h-p-1),v=c.pow(u,g);h=p,u=c.sqr(v),f=c.mul(f,u),d=c.mul(d,v)}return d}}function _f(r){return r%_a===Ta?Da:r%La===Ua?Nf:r%Ra===Cf?Tf(r):Ha(r)}var zt=(r,t)=>(J(r,t)&nt)===nt,Uf=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function _o(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"number",BITS:"number"},e=Uf.reduce((n,s)=>(n[s]="function",n),t);return ye(r,e),r}function Lf(r,t,e){if(e<ht)throw new Error("invalid exponent, negatives unsupported");if(e===ht)return r.ONE;if(e===nt)return t;let n=r.ONE,s=t;for(;e>ht;)e&nt&&(n=r.mul(n,s)),s=r.sqr(s),e>>=nt;return n}function Zr(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 Na(r,t){let e=(r.ORDER-nt)/De,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("invalid Legendre symbol result");return s?1:o?0:-1}function Ka(r,t){t!==void 0&&jt(t);let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function At(r,t,e=!1,n={}){if(r<=ht)throw new Error("invalid field: expected ORDER > 0, got "+r);let s,o,i=!1,a;if(typeof t=="object"&&t!=null){if(n.sqrt||e)throw new Error("cannot specify opts in two arguments");let f=t;f.BITS&&(s=f.BITS),f.sqrt&&(o=f.sqrt),typeof f.isLE=="boolean"&&(e=f.isLE),typeof f.modOnDecode=="boolean"&&(i=f.modOnDecode),a=f.allowedLengths}else typeof t=="number"&&(s=t),n.sqrt&&(o=n.sqrt);let{nBitLength:c,nByteLength:l}=Ka(r,s);if(l>2048)throw new Error("invalid field: expected ORDER of <= 2048 bytes");let h,u=Object.freeze({ORDER:r,isLE:e,BITS:c,BYTES:l,MASK:ge(c),ZERO:ht,ONE:nt,allowedLengths:a,create:f=>J(f,r),isValid:f=>{if(typeof f!="bigint")throw new Error("invalid field element: expected bigint, got "+typeof f);return ht<=f&&f<r},is0:f=>f===ht,isValidNot0:f=>!u.is0(f)&&u.isValid(f),isOdd:f=>(f&nt)===nt,neg:f=>J(-f,r),eql:(f,d)=>f===d,sqr:f=>J(f*f,r),add:(f,d)=>J(f+d,r),sub:(f,d)=>J(f-d,r),mul:(f,d)=>J(f*d,r),pow:(f,d)=>Lf(u,f,d),div:(f,d)=>J(f*Ca(d,r),r),sqrN:f=>f*f,addN:(f,d)=>f+d,subN:(f,d)=>f-d,mulN:(f,d)=>f*d,inv:f=>Ca(f,r),sqrt:o||(f=>(h||(h=_f(r)),h(u,f))),toBytes:f=>e?Yt(f,l):Kn(f,l),fromBytes:(f,d=!0)=>{if(a){if(!a.includes(f.length)||f.length>l)throw new Error("Field.fromBytes: expected "+a+" bytes, got "+f.length);let y=new Uint8Array(l);y.set(f,e?0:y.length-f.length),f=y}if(f.length!==l)throw new Error("Field.fromBytes: expected "+l+" bytes, got "+f.length);let p=e?Zt(f):ir(f);if(i&&(p=J(p,r)),!d&&!u.isValid(p))throw new Error("invalid field element: outside of range 0..ORDER");return p},invertBatch:f=>Zr(u,f),cmov:(f,d,p)=>p?d:f});return Object.freeze(u)}function Oa(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 Uo(r){let t=Oa(r);return t+Math.ceil(t/2)}function Lo(r,t,e=!1){let n=r.length,s=Oa(t),o=Uo(t);if(n<16||n<o||n>1024)throw new Error("expected "+o+"-1024 bytes of input, got "+n);let i=e?Zt(r):ir(r),a=J(i,t-nt)+nt;return e?Yt(a,s):Kn(a,s)}var cr=BigInt(0),He=BigInt(1);function Yr(r,t){let e=t.negate();return r?e:t}function Wt(r,t){let e=Zr(r.Fp,t.map(n=>n.Z));return t.map((n,s)=>r.fromAffine(n.toAffine(e[s])))}function Fa(r,t){if(!Number.isSafeInteger(r)||r<=0||r>t)throw new Error("invalid window size, expected [1.."+t+"], got W="+r)}function Ro(r,t){Fa(r,t);let e=Math.ceil(t/r)+1,n=2**(r-1),s=2**r,o=ge(r),i=BigInt(r);return{windows:e,windowSize:n,mask:o,maxNumber:s,shiftBy:i}}function Va(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+=He);let l=t*n,h=l+Math.abs(a)-1,u=a===0,f=a<0,d=t%2!==0;return{nextN:c,offset:h,isZero:u,isNeg:f,isNegF:d,offsetF:l}}function Rf(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 Df(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 Do=new WeakMap,qa=new WeakMap;function Ho(r){return qa.get(r)||1}function Pa(r){if(r!==cr)throw new Error("invalid wNAF")}var ur=class{constructor(t,e){this.BASE=t.BASE,this.ZERO=t.ZERO,this.Fn=t.Fn,this.bits=e}_unsafeLadder(t,e,n=this.ZERO){let s=t;for(;e>cr;)e&He&&(n=n.add(s)),s=s.double(),e>>=He;return n}precomputeWindow(t,e){let{windows:n,windowSize:s}=Ro(e,this.bits),o=[],i=t,a=i;for(let c=0;c<n;c++){a=i,o.push(a);for(let l=1;l<s;l++)a=a.add(i),o.push(a);i=a.double()}return o}wNAF(t,e,n){if(!this.Fn.isValid(n))throw new Error("invalid scalar");let s=this.ZERO,o=this.BASE,i=Ro(t,this.bits);for(let a=0;a<i.windows;a++){let{nextN:c,offset:l,isZero:h,isNeg:u,isNegF:f,offsetF:d}=Va(n,a,i);n=c,h?o=o.add(Yr(f,e[d])):s=s.add(Yr(u,e[l]))}return Pa(n),{p:s,f:o}}wNAFUnsafe(t,e,n,s=this.ZERO){let o=Ro(t,this.bits);for(let i=0;i<o.windows&&n!==cr;i++){let{nextN:a,offset:c,isZero:l,isNeg:h}=Va(n,i,o);if(n=a,!l){let u=e[c];s=s.add(h?u.negate():u)}}return Pa(n),s}getPrecomputes(t,e,n){let s=Do.get(e);return s||(s=this.precomputeWindow(e,t),t!==1&&(typeof n=="function"&&(s=n(s)),Do.set(e,s))),s}cached(t,e,n){let s=Ho(t);return this.wNAF(s,this.getPrecomputes(s,t,n),e)}unsafe(t,e,n,s){let o=Ho(t);return o===1?this._unsafeLadder(t,e,s):this.wNAFUnsafe(o,this.getPrecomputes(o,t,n),e,s)}createCache(t,e){Fa(e,this.bits),qa.set(t,e),Do.delete(t)}hasCache(t){return Ho(t)!==1}};function ja(r,t,e,n){let s=t,o=r.ZERO,i=r.ZERO;for(;e>cr||n>cr;)e&He&&(o=o.add(s)),n&He&&(i=i.add(s)),s=s.double(),e>>=He,n>>=He;return{p1:o,p2:i}}function lr(r,t,e,n){Rf(e,r),Df(n,t);let s=e.length,o=n.length;if(s!==o)throw new Error("arrays of points and scalars must have equal length");let i=r.ZERO,a=On(BigInt(s)),c=1;a>12?c=a-3:a>4?c=a-2:a>0&&(c=2);let l=ge(c),h=new Array(Number(l)+1).fill(i),u=Math.floor((t.BITS-1)/c)*c,f=i;for(let d=u;d>=0;d-=c){h.fill(i);for(let y=0;y<o;y++){let g=n[y],v=Number(g>>BigInt(d)&l);h[v]=h[v].add(e[y])}let p=i;for(let y=h.length-1,g=i;y>0;y--)g=g.add(h[y]),p=p.add(g);if(f=f.add(p),d!==0)for(let y=0;y<c;y++)f=f.double()}return f}function Ma(r,t){if(t){if(t.ORDER!==r)throw new Error("Field.ORDER must match order: Fp == p, Fn == n");return _o(t),t}else return At(r)}function Vn(r,t,e={}){if(!t||typeof t!="object")throw new Error(`expected valid ${r} CURVE object`);for(let a of["p","n","h"]){let c=t[a];if(!(typeof c=="bigint"&&c>cr))throw new Error(`CURVE.${a} must be positive bigint`)}let n=Ma(t.p,e.Fp),s=Ma(t.n,e.Fn),i=["Gx","Gy","a",r==="weierstrass"?"b":"d"];for(let a of i)if(!n.isValid(t[a]))throw new Error(`CURVE.${a} must be valid field element of CURVE.Fp`);return{Fp:n,Fn:s}}var Kt=BigInt(0),et=BigInt(1),Ko=BigInt(2),Hf=BigInt(8);function Kf(r,t,e,n){let s=r.sqr(e),o=r.sqr(n),i=r.add(r.mul(t.a,s),o),a=r.add(r.ONE,r.mul(t.d,r.mul(s,o)));return r.eql(i,a)}function Of(r,t={}){let{Fp:e,Fn:n}=Vn("edwards",r,t),{h:s,n:o}=r;ye(t,{},{uvRatio:"function"});let i=Ko<<BigInt(n.BYTES*8)-et,a=y=>e.create(y),c=t.uvRatio||((y,g)=>{try{return{isValid:!0,value:e.sqrt(e.div(y,g))}}catch{return{isValid:!1,value:Kt}}});if(!Kf(e,r,r.Gx,r.Gy))throw new Error("bad curve params: generator point");function l(y,g,v=!1){let k=v?et:Kt;return pe("coordinate "+y,g,k,i),g}function h(y){if(!(y instanceof d))throw new Error("ExtendedPoint expected")}let u=ar((y,g)=>{let{X:v,Y:k,Z:B}=y,N=y.is0();g==null&&(g=N?Hf:e.inv(B));let H=a(v*g),I=a(k*g),O=e.mul(B,g);if(N)return{x:Kt,y:et};if(O!==et)throw new Error("invZ was invalid");return{x:H,y:I}}),f=ar(y=>{let{a:g,d:v}=r;if(y.is0())throw new Error("bad point: ZERO");let{X:k,Y:B,Z:N,T:H}=y,I=a(k*k),O=a(B*B),V=a(N*N),_=a(V*V),b=a(I*g),m=a(V*a(b+O)),E=a(_+a(v*a(I*O)));if(m!==E)throw new Error("bad point: equation left != right (1)");let A=a(k*B),L=a(N*H);if(A!==L)throw new Error("bad point: equation left != right (2)");return!0});class d{constructor(g,v,k,B){this.X=l("x",g),this.Y=l("y",v),this.Z=l("z",k,!0),this.T=l("t",B),Object.freeze(this)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}get ex(){return this.X}get ey(){return this.Y}get ez(){return this.Z}get et(){return this.T}static normalizeZ(g){return Wt(d,g)}static msm(g,v){return lr(d,n,g,v)}_setWindowSize(g){this.precompute(g)}static fromAffine(g){if(g instanceof d)throw new Error("extended point not allowed");let{x:v,y:k}=g||{};return l("x",v),l("y",k),new d(v,k,et,a(v*k))}precompute(g=8,v=!0){return p.createCache(this,g),v||this.multiply(Ko),this}assertValidity(){f(this)}equals(g){h(g);let{X:v,Y:k,Z:B}=this,{X:N,Y:H,Z:I}=g,O=a(v*I),V=a(N*B),_=a(k*I),b=a(H*B);return O===V&&_===b}is0(){return this.equals(d.ZERO)}negate(){return new d(a(-this.X),this.Y,this.Z,a(-this.T))}double(){let{a:g}=r,{X:v,Y:k,Z:B}=this,N=a(v*v),H=a(k*k),I=a(Ko*a(B*B)),O=a(g*N),V=v+k,_=a(a(V*V)-N-H),b=O+H,m=b-I,E=O-H,A=a(_*m),L=a(b*E),R=a(_*E),x=a(m*b);return new d(A,L,x,R)}add(g){h(g);let{a:v,d:k}=r,{X:B,Y:N,Z:H,T:I}=this,{X:O,Y:V,Z:_,T:b}=g,m=a(B*O),E=a(N*V),A=a(I*k*b),L=a(H*_),R=a((B+N)*(O+V)-m-E),x=L-A,w=L+A,S=a(E-v*m),T=a(R*x),D=a(w*S),K=a(R*S),P=a(x*w);return new d(T,D,P,K)}subtract(g){return this.add(g.negate())}multiply(g){let v=g;pe("scalar",v,et,o);let{p:k,f:B}=p.cached(this,v,N=>Wt(d,N));return Wt(d,[k,B])[0]}multiplyUnsafe(g,v=d.ZERO){let k=g;return pe("scalar",k,Kt,o),k===Kt?d.ZERO:this.is0()||k===et?this:p.unsafe(this,k,B=>Wt(d,B),v)}isSmallOrder(){return this.multiplyUnsafe(s).is0()}isTorsionFree(){return p.unsafe(this,o).is0()}toAffine(g){return u(this,g)}clearCofactor(){return s===et?this:this.multiplyUnsafe(s)}static fromBytes(g,v=!1){return z(g),d.fromHex(g,v)}static fromHex(g,v=!1){let{d:k,a:B}=r,N=e.BYTES;g=$("pointHex",g,N),Gt("zip215",v);let H=g.slice(),I=g[N-1];H[N-1]=I&-129;let O=Zt(H),V=v?i:e.ORDER;pe("pointHex.y",O,Kt,V);let _=a(O*O),b=a(_-et),m=a(k*_-B),{isValid:E,value:A}=c(b,m);if(!E)throw new Error("Point.fromHex: invalid y coordinate");let L=(A&et)===et,R=(I&128)!==0;if(!v&&A===Kt&&R)throw new Error("Point.fromHex: x=0 and x_0=1");return R!==L&&(A=a(-A)),d.fromAffine({x:A,y:O})}toBytes(){let{x:g,y:v}=this.toAffine(),k=Yt(v,e.BYTES);return k[k.length-1]|=g&et?128:0,k}toRawBytes(){return this.toBytes()}toHex(){return It(this.toBytes())}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}}d.BASE=new d(r.Gx,r.Gy,et,a(r.Gx*r.Gy)),d.ZERO=new d(Kt,et,et,Kt),d.Fp=e,d.Fn=n;let p=new ur(d,n.BYTES*8);return d}var Pn=class{constructor(t){this.ep=t}static fromBytes(t){throw new Error("fromBytes must be implemented by subclass")}static fromHex(t){throw new Error("fromHex must be implemented by subclass")}get x(){return this.toAffine().x}get y(){return this.toAffine().y}clearCofactor(){return this}assertValidity(){this.ep.assertValidity()}toAffine(t){return this.ep.toAffine(t)}toRawBytes(){return this.toBytes()}toHex(){return It(this.toBytes())}toString(){return this.toHex()}isTorsionFree(){return!0}isSmallOrder(){return!1}add(t){return this.assertSame(t),this.init(this.ep.add(t.ep))}subtract(t){return this.assertSame(t),this.init(this.ep.subtract(t.ep))}multiply(t){return this.init(this.ep.multiply(t))}multiplyUnsafe(t){return this.init(this.ep.multiplyUnsafe(t))}double(){return this.init(this.ep.double())}negate(){return this.init(this.ep.negate())}precompute(t,e){return this.init(this.ep.precompute(t,e))}};function Vf(r,t,e){if(typeof t!="function")throw new Error('"hash" function param is required');ye(e,{},{adjustScalarBytes:"function",randomBytes:"function",domain:"function",prehash:"function",mapToCurve:"function"});let{prehash:n}=e,{BASE:s,Fp:o,Fn:i}=r,a=i.ORDER,c=e.randomBytes||_e,l=e.adjustScalarBytes||(m=>m),h=e.domain||((m,E,A)=>{if(Gt("phflag",A),E.length||A)throw new Error("Contexts/pre-hash are not supported");return m});function u(m){return i.create(m)}function f(m){return u(Zt(m))}function d(m){let E=o.BYTES;m=$("private key",m,E);let A=$("hashed private key",t(m),2*E),L=l(A.slice(0,E)),R=A.slice(E,2*E),x=f(L);return{head:L,prefix:R,scalar:x}}function p(m){let{head:E,prefix:A,scalar:L}=d(m),R=s.multiply(L),x=R.toBytes();return{head:E,prefix:A,scalar:L,point:R,pointBytes:x}}function y(m){return p(m).pointBytes}function g(m=Uint8Array.of(),...E){let A=mt(...E);return f(t(h(A,$("context",m),!!n)))}function v(m,E,A={}){m=$("message",m),n&&(m=n(m));let{prefix:L,scalar:R,pointBytes:x}=p(E),w=g(A.context,L,m),S=s.multiply(w).toBytes(),T=g(A.context,S,x,m),D=u(w+T*R);pe("signature.s",D,Kt,a);let K=o.BYTES,P=mt(S,Yt(D,K));return $("result",P,K*2)}let k={zip215:!0};function B(m,E,A,L=k){let{context:R,zip215:x}=L,w=o.BYTES;m=$("signature",m,2*w),E=$("message",E),A=$("publicKey",A,w),x!==void 0&&Gt("zip215",x),n&&(E=n(E));let S=Zt(m.slice(w,2*w)),T,D,K;try{T=r.fromHex(A,x),D=r.fromHex(m.slice(0,w),x),K=s.multiplyUnsafe(S)}catch{return!1}if(!x&&T.isSmallOrder())return!1;let P=g(R,D.toBytes(),T.toBytes(),E);return D.add(T.multiplyUnsafe(P)).subtract(K).clearCofactor().is0()}s.precompute(8);let N=o.BYTES,H={secret:N,public:N,signature:2*N,seed:N};function I(m=c(H.seed)){return m}let O={getExtendedPublicKey:p,randomSecretKey:I,isValidSecretKey:_,isValidPublicKey:b,randomPrivateKey:I,toMontgomery(m){let{y:E}=r.fromBytes(m),A=N===32;if(!A&&N!==57)throw new Error("only defined for 25519 and 448");let L=A?o.div(et+E,et-E):o.div(E-et,E+et);return o.toBytes(L)},toMontgomeryPriv(m){z(m,N);let E=t(m.subarray(0,N));return l(E).subarray(0,N)},precompute(m=8,E=r.BASE){return E.precompute(m,!1)}};function V(m){let E=O.randomSecretKey(m);return{secretKey:E,publicKey:y(E)}}function _(m){try{return!!i.fromBytes(m,!1)}catch{return!1}}function b(m,E){try{return!!r.fromBytes(m,E)}catch{return!1}}return Object.freeze({keygen:V,getPublicKey:y,sign:v,verify:B,utils:O,Point:r,info:{type:"edwards",lengths:H}})}function Pf(r){let t={a:r.a,d:r.d,p:r.Fp.ORDER,n:r.n,h:r.h,Gx:r.Gx,Gy:r.Gy},e=r.Fp,n=At(t.n,r.nBitLength,!0),s={Fp:e,Fn:n,uvRatio:r.uvRatio},o={randomBytes:r.randomBytes,adjustScalarBytes:r.adjustScalarBytes,domain:r.domain,prehash:r.prehash,mapToCurve:r.mapToCurve};return{CURVE:t,curveOpts:s,hash:r.hash,eddsaOpts:o}}function Mf(r,t){return Object.assign({},t,{ExtendedPoint:t.Point,CURVE:r})}function $a(r){let{CURVE:t,curveOpts:e,hash:n,eddsaOpts:s}=Pf(r),o=Of(t,e),i=Vf(o,n,s);return Mf(r,i)}var Ff=BigInt(0),Jt=BigInt(1),Ga=BigInt(2),Qp=BigInt(3),qf=BigInt(5),jf=BigInt(8),zr={p:BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffed"),n:BigInt("0x1000000000000000000000000000000014def9dea2f79cd65812631a5cf5d3ed"),h:jf,a:BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffec"),d:BigInt("0x52036cee2b6ffe738cc740797779e89800700a4d4141d8ab75eb4dca135978a3"),Gx:BigInt("0x216936d3cd6e53fec0a4e231fdd6dc5c692cc7609525a7b2c9562d608f25d51a"),Gy:BigInt("0x6666666666666666666666666666666666666666666666666666666666666658")};function $f(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),s=BigInt(80),o=zr.p,a=r*r%o*r%o,c=Y(a,Ga,o)*a%o,l=Y(c,Jt,o)*r%o,h=Y(l,qf,o)*l%o,u=Y(h,t,o)*h%o,f=Y(u,e,o)*u%o,d=Y(f,n,o)*f%o,p=Y(d,s,o)*d%o,y=Y(p,s,o)*d%o,g=Y(y,t,o)*h%o;return{pow_p_5_8:Y(g,Ga,o)*r%o,b2:a}}function Gf(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}var Oo=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752");function Mo(r,t){let e=zr.p,n=J(t*t*t,e),s=J(n*n*t,e),o=$f(r*s).pow_p_5_8,i=J(r*n*o,e),a=J(t*i*i,e),c=i,l=J(i*Oo,e),h=a===r,u=a===J(-r,e),f=a===J(-r*Oo,e);return h&&(i=c),(u||f)&&(i=l),zt(i,e)&&(i=J(-i,e)),{isValid:h||u,value:i}}var Ke=At(zr.p,{isLE:!0}),Zf=At(zr.n,{isLE:!0}),Yf={...zr,Fp:Ke,hash:Hn,adjustScalarBytes:Gf,uvRatio:Mo},bt=$a(Yf);var Vo=Oo,zf=BigInt("25063068953384623474111414158702152701244531502492656460079210482610430750235"),Wf=BigInt("54469307008909316920995813868745141605393597292927456921205312896311721017578"),Jf=BigInt("1159843021668779879193775521855586647937357759715417654439879720876111806838"),Xf=BigInt("40440834346308536858101042469323190826248399146238708352240133220865137265952"),Za=r=>Mo(Jt,r),Qf=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"),Po=r=>bt.CURVE.Fp.create(Zt(r)&Qf);function Ya(r){let{d:t}=bt.CURVE,e=bt.CURVE.Fp.ORDER,n=bt.CURVE.Fp.create,s=n(Vo*r*r),o=n((s+Jt)*Jf),i=BigInt(-1),a=n((i-t*s)*n(s+t)),{isValid:c,value:l}=Mo(o,a),h=n(l*r);zt(h,e)||(h=n(-h)),c||(l=h),c||(i=s);let u=n(i*(s-Jt)*Xf-a),f=l*l,d=n((l+l)*a),p=n(u*zf),y=n(Jt-f),g=n(Jt+f);return new bt.Point(n(d*g),n(y*p),n(p*g),n(d*y))}function th(r){z(r,64);let t=Po(r.subarray(0,32)),e=Ya(t),n=Po(r.subarray(32,64)),s=Ya(n);return new Xt(e.add(s))}var Xt=class r extends Pn{constructor(t){super(t)}static fromAffine(t){return new r(bt.Point.fromAffine(t))}assertSame(t){if(!(t instanceof r))throw new Error("RistrettoPoint expected")}init(t){return new r(t)}static hashToCurve(t){return th($("ristrettoHash",t,64))}static fromBytes(t){z(t,32);let{a:e,d:n}=bt.CURVE,s=Ke.ORDER,o=Ke.create,i=Po(t);if(!Sa(Yt(i,32),t)||zt(i,s))throw new Error("invalid ristretto255 encoding 1");let a=o(i*i),c=o(Jt+e*a),l=o(Jt-e*a),h=o(c*c),u=o(l*l),f=o(e*n*h-u),{isValid:d,value:p}=Za(o(f*u)),y=o(p*l),g=o(p*y*f),v=o((i+i)*y);zt(v,s)&&(v=o(-v));let k=o(c*g),B=o(v*k);if(!d||zt(B,s)||k===Ff)throw new Error("invalid ristretto255 encoding 2");return new r(new bt.Point(v,k,Jt,B))}static fromHex(t){return r.fromBytes($("ristrettoHex",t,32))}static msm(t,e){return lr(r,bt.Point.Fn,t,e)}toBytes(){let{X:t,Y:e,Z:n,T:s}=this.ep,o=Ke.ORDER,i=Ke.create,a=i(i(n+e)*i(n-e)),c=i(t*e),l=i(c*c),{value:h}=Za(i(a*l)),u=i(h*a),f=i(h*c),d=i(u*f*s),p;if(zt(s*d,o)){let g=i(e*Vo),v=i(t*Vo);t=g,e=v,p=i(u*Wf)}else p=f;zt(t*d,o)&&(e=i(-e));let y=i((n-e)*p);return zt(y,o)&&(y=i(-y)),Yt(y,32)}equals(t){this.assertSame(t);let{X:e,Y:n}=this.ep,{X:s,Y:o}=t.ep,i=Ke.create,a=i(e*o)===i(n*s),c=i(n*o)===i(e*s);return a||c}is0(){return this.equals(r.ZERO)}};Xt.BASE=new Xt(bt.Point.BASE);Xt.ZERO=new Xt(bt.Point.ZERO);Xt.Fp=Ke;Xt.Fn=Zf;var hr=32,Ct=64,eh=32;var fr,za=(async()=>{try{return await X.get().subtle.generateKey({name:"Ed25519"},!0,["sign","verify"]),!0}catch{return!1}})();async function rh(r,t){let e;r.length===Ct?e=r.subarray(0,32):e=r;let n={crv:"Ed25519",kty:"OKP",x:q(r.subarray(32),"base64url"),d:q(e,"base64url"),ext:!0,key_ops:["sign"]},s=await X.get().subtle.importKey("jwk",n,{name:"Ed25519"},!0,["sign"]),o=await X.get().subtle.sign({name:"Ed25519"},s,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(o,0,o.byteLength)}function nh(r,t){let e=r.subarray(0,eh);return bt.sign(t instanceof Uint8Array?t:t.subarray(),e)}async function Wa(r,t){return fr==null&&(fr=await za),fr?rh(r,t):nh(r,t)}async function sh(r,t,e){if(r.buffer instanceof ArrayBuffer){let n=await X.get().subtle.importKey("raw",r.buffer,{name:"Ed25519"},!1,["verify"]);return await X.get().subtle.verify({name:"Ed25519"},n,t,e instanceof Uint8Array?e:e.subarray())}throw new TypeError("WebCrypto does not support SharedArrayBuffer for Ed25519 keys")}function oh(r,t,e){return bt.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}async function Ja(r,t,e){return fr==null&&(fr=await za),fr?sh(r,t,e):oh(r,t,e)}function dr(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}var Mn=class{type="Ed25519";raw;constructor(t){this.raw=Jr(t,hr)}toMultihash(){return Se.digest(rr(this))}toCID(){return kt.createV1(114,this.toMultihash())}toString(){return Q.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:gt(this.raw,t.raw)}verify(t,e,n){n?.signal?.throwIfAborted();let s=Ja(this.raw,e,t);return dr(s)?s.then(o=>(n?.signal?.throwIfAborted(),o)):s}},Wr=class{type="Ed25519";raw;publicKey;constructor(t,e){this.raw=Jr(t,Ct),this.publicKey=new Mn(e)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:gt(this.raw,t.raw)}sign(t,e){e?.signal?.throwIfAborted();let n=Wa(this.raw,t);return dr(n)?n.then(s=>(e?.signal?.throwIfAborted(),s)):(e?.signal?.throwIfAborted(),n)}};function Fo(r){if(r.length>Ct){r=Jr(r,Ct+hr);let n=r.subarray(0,Ct),s=r.subarray(Ct,r.length);return new Wr(n,s)}r=Jr(r,Ct);let t=r.subarray(0,Ct),e=r.subarray(hr);return new Wr(t,e)}function Jr(r,t){if(r=Uint8Array.from(r??[]),r.length!==t)throw new U(`Key must be a Uint8Array of length ${t}, got ${r.length}`);return r}var ih=Math.pow(2,7),ah=Math.pow(2,14),ch=Math.pow(2,21),Qa=Math.pow(2,28),tc=Math.pow(2,35),ec=Math.pow(2,42),rc=Math.pow(2,49),dt=128,me=127;function Xr(r){if(r<ih)return 1;if(r<ah)return 2;if(r<ch)return 3;if(r<Qa)return 4;if(r<tc)return 5;if(r<ec)return 6;if(r<rc)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function nc(r,t,e=0){switch(Xr(r)){case 8:t[e++]=r&255|dt,r/=128;case 7:t[e++]=r&255|dt,r/=128;case 6:t[e++]=r&255|dt,r/=128;case 5:t[e++]=r&255|dt,r/=128;case 4:t[e++]=r&255|dt,r>>>=7;case 3:t[e++]=r&255|dt,r>>>=7;case 2:t[e++]=r&255|dt,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function sc(r,t){let e=r[t],n=0;if(n+=e&me,e<dt||(e=r[t+1],n+=(e&me)<<7,e<dt)||(e=r[t+2],n+=(e&me)<<14,e<dt)||(e=r[t+3],n+=(e&me)<<21,e<dt)||(e=r[t+4],n+=(e&me)*Qa,e<dt)||(e=r[t+5],n+=(e&me)*tc,e<dt)||(e=r[t+6],n+=(e&me)*ec,e<dt)||(e=r[t+7],n+=(e&me)*rc,e<dt))return n;throw new RangeError("Could not decode varint")}var qo=new Float32Array([-0]),be=new Uint8Array(qo.buffer);function oc(r,t,e){qo[0]=r,t[e]=be[0],t[e+1]=be[1],t[e+2]=be[2],t[e+3]=be[3]}function ic(r,t){return be[0]=r[t],be[1]=r[t+1],be[2]=r[t+2],be[3]=r[t+3],qo[0]}var jo=new Float64Array([-0]),at=new Uint8Array(jo.buffer);function ac(r,t,e){jo[0]=r,t[e]=at[0],t[e+1]=at[1],t[e+2]=at[2],t[e+3]=at[3],t[e+4]=at[4],t[e+5]=at[5],t[e+6]=at[6],t[e+7]=at[7]}function cc(r,t){return at[0]=r[t],at[1]=r[t+1],at[2]=r[t+2],at[3]=r[t+3],at[4]=r[t+4],at[5]=r[t+5],at[6]=r[t+6],at[7]=r[t+7],jo[0]}var uh=BigInt(Number.MAX_SAFE_INTEGER),lh=BigInt(Number.MIN_SAFE_INTEGER),St=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 Oe;if(t<uh&&t>lh)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>uc&&(s=0n,++n>uc&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(t){if(t===0)return Oe;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):Oe}},Oe=new St(0,0);Oe.toBigInt=function(){return 0n};Oe.zzEncode=Oe.zzDecode=function(){return this};Oe.length=function(){return 1};var uc=4294967296n;function lc(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 fc(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 $o(r,t,e){let n=e,s,o;for(let i=0;i<r.length;++i)s=r.charCodeAt(i),s<128?t[e++]=s:s<2048?(t[e++]=s>>6|192,t[e++]=s&63|128):(s&64512)===55296&&((o=r.charCodeAt(i+1))&64512)===56320?(s=65536+((s&1023)<<10)+(o&1023),++i,t[e++]=s>>18|240,t[e++]=s>>12&63|128,t[e++]=s>>6&63|128,t[e++]=s&63|128):(t[e++]=s>>12|224,t[e++]=s>>6&63|128,t[e++]=s&63|128);return e-n}function Rt(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function Fn(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var Go=class{buf;pos;len;_slice=Uint8Array.prototype.subarray;constructor(t){this.buf=t,this.pos=0,this.len=t.length}uint32(){let t=4294967295;if(t=(this.buf[this.pos]&127)>>>0,this.buf[this.pos++]<128||(t=(t|(this.buf[this.pos]&127)<<7)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<14)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<21)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&15)<<28)>>>0,this.buf[this.pos++]<128))return t;if((this.pos+=5)>this.len)throw this.pos=this.len,Rt(this,10);return t}int32(){return this.uint32()|0}sint32(){let t=this.uint32();return t>>>1^-(t&1)|0}bool(){return this.uint32()!==0}fixed32(){if(this.pos+4>this.len)throw Rt(this,4);return Fn(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Rt(this,4);return Fn(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Rt(this,4);let t=ic(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Rt(this,4);let t=cc(this.buf,this.pos);return this.pos+=8,t}bytes(){let t=this.uint32(),e=this.pos,n=this.pos+t;if(n>this.len)throw Rt(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return fc(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw Rt(this,t);this.pos+=t}else do if(this.pos>=this.len)throw Rt(this);while((this.buf[this.pos++]&128)!==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 St(0,0),e=0;if(this.len-this.pos>4){for(;e<4;++e)if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t;if(t.lo=(t.lo|(this.buf[this.pos]&127)<<28)>>>0,t.hi=(t.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return t;e=0}else{for(;e<3;++e){if(this.pos>=this.len)throw Rt(this);if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t}return t.lo=(t.lo|(this.buf[this.pos++]&127)<<e*7)>>>0,t}if(this.len-this.pos>4){for(;e<5;++e)if(t.hi=(t.hi|(this.buf[this.pos]&127)<<e*7+3)>>>0,this.buf[this.pos++]<128)return t}else for(;e<5;++e){if(this.pos>=this.len)throw Rt(this);if(t.hi=(t.hi|(this.buf[this.pos]&127)<<e*7+3)>>>0,this.buf[this.pos++]<128)return t}throw Error("invalid varint encoding")}readFixed64(){if(this.pos+8>this.len)throw Rt(this,8);let t=Fn(this.buf,this.pos+=4),e=Fn(this.buf,this.pos+=4);return new St(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=sc(this.buf,this.pos);return this.pos+=Xr(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 Zo(r){return new Go(r instanceof Uint8Array?r:r.subarray())}function qn(r,t,e){let n=Zo(r);return t.decode(n,void 0,e)}function Yo(r){let t=r??8192,e=t>>>1,n,s=t;return function(i){if(i<1||i>e)return Bt(i);s+i>t&&(n=Bt(t),s=0);let a=n.subarray(s,s+=i);return(s&7)!==0&&(s=(s|7)+1),a}}var Ve=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function zo(){}var Jo=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},fh=Yo();function hh(r){return globalThis.Buffer!=null?Bt(r):fh(r)}var tn=class{len;head;tail;states;constructor(){this.len=0,this.head=new Ve(zo,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new Ve(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new Xo((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(jn,10,St.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=St.fromBigInt(t);return this._push(jn,e.length(),e)}uint64Number(t){return this._push(nc,Xr(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=St.fromBigInt(t).zzEncode();return this._push(jn,e.length(),e)}sint64Number(t){let e=St.fromNumber(t).zzEncode();return this._push(jn,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(Wo,1,t?1:0)}fixed32(t){return this._push(Qr,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=St.fromBigInt(t);return this._push(Qr,4,e.lo)._push(Qr,4,e.hi)}fixed64Number(t){let e=St.fromNumber(t);return this._push(Qr,4,e.lo)._push(Qr,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(oc,4,t)}double(t){return this._push(ac,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(Wo,1,0):this.uint32(e)._push(ph,e,t)}string(t){let e=lc(t);return e!==0?this.uint32(e)._push($o,e,t):this._push(Wo,1,0)}fork(){return this.states=new Jo(this),this.head=this.tail=new Ve(zo,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 Ve(zo,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=hh(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function Wo(r,t,e){t[e]=r&255}function dh(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var Xo=class extends Ve{next;constructor(t,e){super(dh,t,e),this.next=void 0}};function jn(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 Qr(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 ph(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(tn.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(gh,t,r),this},tn.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(yh,t,r),this});function gh(r,t,e){t.set(r,e)}function yh(r,t,e){r.length<40?$o(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(M(r),e)}function Qo(){return new tn}function $n(r,t){let e=Qo();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var pr;(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"})(pr||(pr={}));function Gn(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function ti(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 Gn("enum",pr.VARINT,e,n)}function Zn(r,t){return Gn("message",pr.LENGTH_DELIMITED,r,t)}var rt;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.secp256k1="secp256k1",r.ECDSA="ECDSA"})(rt||(rt={}));var ei;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1",r[r.ECDSA=3]="ECDSA"})(ei||(ei={}));(function(r){r.codec=()=>ti(ei)})(rt||(rt={}));var we;(function(r){let t;r.codec=()=>(t==null&&(t=Zn((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=>$n(e,r.codec()),r.decode=(e,n)=>qn(e,r.codec(),n)})(we||(we={}));var en;(function(r){let t;r.codec=()=>(t==null&&(t=Zn((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=>$n(e,r.codec()),r.decode=(e,n)=>qn(e,r.codec(),n)})(en||(en={}));function Pe(r){if(isNaN(r)||r<=0)throw new U("random bytes length must be a Number bigger than 0");return _e(r)}var nn={};ut(nn,{MAX_RSA_KEY_SIZE:()=>ri,generateRSAKeyPair:()=>mc,jwkToJWKKeyPair:()=>bc,jwkToPkcs1:()=>xh,jwkToPkix:()=>ii,jwkToRSAPrivateKey:()=>ui,pkcs1MessageToJwk:()=>si,pkcs1MessageToRSAPrivateKey:()=>Yn,pkcs1ToJwk:()=>wh,pkcs1ToRSAPrivateKey:()=>ai,pkixMessageToJwk:()=>oi,pkixMessageToRSAPublicKey:()=>ci,pkixToJwk:()=>vh,pkixToRSAPublicKey:()=>yc});var gr=Dn;var yr=class{type="RSA";jwk;_raw;_multihash;constructor(t,e){this.jwk=t,this._multihash=e}get raw(){return this._raw==null&&(this._raw=nn.jwkToPkix(this.jwk)),this._raw}toMultihash(){return this._multihash}toCID(){return kt.createV1(114,this._multihash)}toString(){return Q.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:gt(this.raw,t.raw)}verify(t,e,n){return gc(this.jwk,e,t,n)}},rn=class{type="RSA";jwk;_raw;publicKey;constructor(t,e){this.jwk=t,this.publicKey=e}get raw(){return this._raw==null&&(this._raw=nn.jwkToPkcs1(this.jwk)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:gt(this.raw,t.raw)}sign(t,e){return pc(this.jwk,t,e)}};var ri=8192,ni=18,mh=1062,bh=Uint8Array.from([48,13,6,9,42,134,72,134,247,13,1,1,1,5,0]);function wh(r){let t=_t(r);return si(t)}function si(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 xh(r){if(r.n==null||r.e==null||r.d==null||r.p==null||r.q==null||r.dp==null||r.dq==null||r.qi==null)throw new U("JWK was missing components");return Ut([ft(Uint8Array.from([0])),ft(M(r.n,"base64url")),ft(M(r.e,"base64url")),ft(M(r.d,"base64url")),ft(M(r.p,"base64url")),ft(M(r.q,"base64url")),ft(M(r.dp,"base64url")),ft(M(r.dq,"base64url")),ft(M(r.qi,"base64url"))]).subarray()}function vh(r){let t=_t(r,{offset:0});return oi(t)}function oi(r){let t=_t(r[1],{offset:0});return{kty:"RSA",n:q(t[0],"base64url"),e:q(t[1],"base64url")}}function ii(r){if(r.n==null||r.e==null)throw new U("JWK was missing components");return Ut([bh,Mr(Ut([ft(M(r.n,"base64url")),ft(M(r.e,"base64url"))]))]).subarray()}function ai(r){let t=_t(r);return Yn(t)}function Yn(r){let t=si(r);return ui(t)}function yc(r,t){if(r.byteLength>=mh)throw new Ge("Key size is too large");let e=_t(r,{offset:0});return ci(e,r,t)}function ci(r,t,e){let n=oi(r);if(e==null){let s=gr(we.encode({Type:rt.RSA,Data:t}));e=Tt(ni,s)}return new yr(n,e)}function ui(r){if(xc(r)>ri)throw new U("Key size is too large");let t=bc(r),e=gr(we.encode({Type:rt.RSA,Data:ii(t.publicKey)})),n=Tt(ni,e);return new rn(t.privateKey,new yr(t.publicKey,n))}async function mc(r){if(r>ri)throw new U("Key size is too large");let t=await wc(r),e=gr(we.encode({Type:rt.RSA,Data:ii(t.publicKey)})),n=Tt(ni,e);return new rn(t.privateKey,new yr(t.publicKey,n))}function bc(r){if(r==null)throw new U("Missing key parameter");return{privateKey:r,publicKey:{kty:r.kty,n:r.n,e:r.e}}}async function wc(r,t){let e=await X.get().subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:r,publicExponent:new Uint8Array([1,0,1]),hash:{name:"SHA-256"}},!0,["sign","verify"]);t?.signal?.throwIfAborted();let n=await Eh(e,t);return{privateKey:n[0],publicKey:n[1]}}async function pc(r,t,e){let n=await X.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]);e?.signal?.throwIfAborted();let s=await X.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},n,t instanceof Uint8Array?t:t.subarray());return e?.signal?.throwIfAborted(),new Uint8Array(s,0,s.byteLength)}async function gc(r,t,e,n){let s=await X.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);n?.signal?.throwIfAborted();let o=await X.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},s,t,e instanceof Uint8Array?e:e.subarray());return n?.signal?.throwIfAborted(),o}async function Eh(r,t){if(r.privateKey==null||r.publicKey==null)throw new U("Private and public key are required");let e=await Promise.all([X.get().subtle.exportKey("jwk",r.privateKey),X.get().subtle.exportKey("jwk",r.publicKey)]);return t?.signal?.throwIfAborted(),e}function xc(r){if(r.kty!=="RSA")throw new U("invalid key type");if(r.n==null)throw new U("invalid key modulus");return M(r.n,"base64url").length*8}var zn=class extends nr{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,sr(t);let n=Fr(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),yt(o)}update(t){return or(this),this.iHash.update(t),this}digestInto(t){or(this),z(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()}},sn=(r,t,e)=>new zn(r,t).update(e).digest();sn.create=(r,t)=>new zn(r,t);var vc=(r,t)=>(r+(r>=0?t:-t)/Bc)/t;function Bh(r,t,e){let[[n,s],[o,i]]=t,a=vc(i*r,e),c=vc(-s*r,e),l=r-a*n-c*o,h=-a*s-c*i,u=l<te,f=h<te;u&&(l=-l),f&&(h=-h);let d=ge(Math.ceil(On(e)/2))+br;if(l<te||l>=d||h<te||h>=d)throw new Error("splitScalar (endomorphism): failed, k="+r);return{k1neg:u,k1:l,k2neg:f,k2:h}}function Ec(r){r.lowS!==void 0&&Gt("lowS",r.lowS),r.prehash!==void 0&&Gt("prehash",r.prehash)}var li=class extends Error{constructor(t=""){super(t)}},Qt={Err:li,_tlv:{encode:(r,t)=>{let{Err:e}=Qt;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=Gr(n);if(s.length/2&128)throw new e("tlv.encode: long form length too big");let o=n>127?Gr(s.length/2|128):"";return Gr(r)+o+s+t},decode(r,t){let{Err:e}=Qt,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 l=t.subarray(n,n+c);if(l.length!==c)throw new e("tlv.decode: length bytes not complete");if(l[0]===0)throw new e("tlv.decode(long): zero leftmost byte");for(let h of l)i=i<<8|h;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}=Qt;if(r<te)throw new t("integer: negative integers are not allowed");let e=Gr(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}=Qt;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 ir(r)}},toSig(r){let{Err:t,_int:e,_tlv:n}=Qt,s=$("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:l,l:h}=n.decode(2,c);if(h.length)throw new t("invalid signature: left bytes after parsing");return{r:e.decode(a),s:e.decode(l)}},hexFromSig(r){let{_tlv:t,_int:e}=Qt,n=t.encode(2,e.encode(r.r)),s=t.encode(2,e.encode(r.s)),o=n+s;return t.encode(48,o)}},te=BigInt(0),br=BigInt(1),Bc=BigInt(2),Wn=BigInt(3),Ah=BigInt(4);function Sh(r,t,e){function n(s){let o=r.sqr(s),i=r.mul(o,s);return r.add(r.add(i,r.mul(s,t)),e)}return n}function mr(r,t){let{BYTES:e}=r,n;if(typeof t=="bigint")n=t;else{let s=$("private key",t);try{n=r.fromBytes(s)}catch{throw new Error(`invalid private key: expected ui8a of size ${e}, got ${typeof t}`)}}if(!r.isValidNot0(n))throw new Error("invalid private key: out of range [1..N-1]");return n}function kh(r,t={}){let{Fp:e,Fn:n}=Vn("weierstrass",r,t),{h:s,n:o}=r;ye(t,{},{allowInfinityPoint:"boolean",clearCofactor:"function",isTorsionFree:"function",fromBytes:"function",toBytes:"function",endo:"object",wrapPrivateKey:"boolean"});let{endo:i}=t;if(i&&(!e.is0(r.a)||typeof i.beta!="bigint"||!Array.isArray(i.basises)))throw new Error('invalid endo: expected "beta": bigint and "basises": array');function a(){if(!e.isOdd)throw new Error("compression is not supported: Field does not have .isOdd()")}function c(_,b,m){let{x:E,y:A}=b.toAffine(),L=e.toBytes(E);if(Gt("isCompressed",m),m){a();let R=!e.isOdd(A);return mt(Ac(R),L)}else return mt(Uint8Array.of(4),L,e.toBytes(A))}function l(_){z(_);let b=e.BYTES,m=b+1,E=2*b+1,A=_.length,L=_[0],R=_.subarray(1);if(A===m&&(L===2||L===3)){let x=e.fromBytes(R);if(!e.isValid(x))throw new Error("bad point: is not on curve, wrong x");let w=f(x),S;try{S=e.sqrt(w)}catch(K){let P=K instanceof Error?": "+K.message:"";throw new Error("bad point: is not on curve, sqrt error"+P)}a();let T=e.isOdd(S);return(L&1)===1!==T&&(S=e.neg(S)),{x,y:S}}else if(A===E&&L===4){let x=e.fromBytes(R.subarray(b*0,b*1)),w=e.fromBytes(R.subarray(b*1,b*2));if(!d(x,w))throw new Error("bad point: is not on curve");return{x,y:w}}else throw new Error(`bad point: got length ${A}, expected compressed=${m} or uncompressed=${E}`)}let h=t.toBytes||c,u=t.fromBytes||l,f=Sh(e,r.a,r.b);function d(_,b){let m=e.sqr(b),E=f(_);return e.eql(m,E)}if(!d(r.Gx,r.Gy))throw new Error("bad curve params: generator point");let p=e.mul(e.pow(r.a,Wn),Ah),y=e.mul(e.sqr(r.b),BigInt(27));if(e.is0(e.add(p,y)))throw new Error("bad curve params: a or b");function g(_,b,m=!1){if(!e.isValid(b)||m&&e.is0(b))throw new Error(`bad point coordinate ${_}`);return b}function v(_){if(!(_ instanceof I))throw new Error("ProjectivePoint expected")}function k(_){if(!i||!i.basises)throw new Error("no endo");return Bh(_,i.basises,n.ORDER)}let B=ar((_,b)=>{let{X:m,Y:E,Z:A}=_;if(e.eql(A,e.ONE))return{x:m,y:E};let L=_.is0();b==null&&(b=L?e.ONE:e.inv(A));let R=e.mul(m,b),x=e.mul(E,b),w=e.mul(A,b);if(L)return{x:e.ZERO,y:e.ZERO};if(!e.eql(w,e.ONE))throw new Error("invZ was invalid");return{x:R,y:x}}),N=ar(_=>{if(_.is0()){if(t.allowInfinityPoint&&!e.is0(_.Y))return;throw new Error("bad point: ZERO")}let{x:b,y:m}=_.toAffine();if(!e.isValid(b)||!e.isValid(m))throw new Error("bad point: x or y not field elements");if(!d(b,m))throw new Error("bad point: equation left != right");if(!_.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});function H(_,b,m,E,A){return m=new I(e.mul(m.X,_),m.Y,m.Z),b=Yr(E,b),m=Yr(A,m),b.add(m)}class I{constructor(b,m,E){this.X=g("x",b),this.Y=g("y",m,!0),this.Z=g("z",E),Object.freeze(this)}static fromAffine(b){let{x:m,y:E}=b||{};if(!b||!e.isValid(m)||!e.isValid(E))throw new Error("invalid affine point");if(b instanceof I)throw new Error("projective point not allowed");return e.is0(m)&&e.is0(E)?I.ZERO:new I(m,E,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}get px(){return this.X}get py(){return this.X}get pz(){return this.Z}static normalizeZ(b){return Wt(I,b)}static fromBytes(b){return z(b),I.fromHex(b)}static fromHex(b){let m=I.fromAffine(u($("pointHex",b)));return m.assertValidity(),m}static fromPrivateKey(b){return I.BASE.multiply(mr(n,b))}static msm(b,m){return lr(I,n,b,m)}_setWindowSize(b){this.precompute(b)}precompute(b=8,m=!0){return V.createCache(this,b),m||this.multiply(Wn),this}assertValidity(){N(this)}hasEvenY(){let{y:b}=this.toAffine();if(!e.isOdd)throw new Error("Field doesn't support isOdd");return!e.isOdd(b)}equals(b){v(b);let{X:m,Y:E,Z:A}=this,{X:L,Y:R,Z:x}=b,w=e.eql(e.mul(m,x),e.mul(L,A)),S=e.eql(e.mul(E,x),e.mul(R,A));return w&&S}negate(){return new I(this.X,e.neg(this.Y),this.Z)}double(){let{a:b,b:m}=r,E=e.mul(m,Wn),{X:A,Y:L,Z:R}=this,x=e.ZERO,w=e.ZERO,S=e.ZERO,T=e.mul(A,A),D=e.mul(L,L),K=e.mul(R,R),P=e.mul(A,L);return P=e.add(P,P),S=e.mul(A,R),S=e.add(S,S),x=e.mul(b,S),w=e.mul(E,K),w=e.add(x,w),x=e.sub(D,w),w=e.add(D,w),w=e.mul(x,w),x=e.mul(P,x),S=e.mul(E,S),K=e.mul(b,K),P=e.sub(T,K),P=e.mul(b,P),P=e.add(P,S),S=e.add(T,T),T=e.add(S,T),T=e.add(T,K),T=e.mul(T,P),w=e.add(w,T),K=e.mul(L,R),K=e.add(K,K),T=e.mul(K,P),x=e.sub(x,T),S=e.mul(K,D),S=e.add(S,S),S=e.add(S,S),new I(x,w,S)}add(b){v(b);let{X:m,Y:E,Z:A}=this,{X:L,Y:R,Z:x}=b,w=e.ZERO,S=e.ZERO,T=e.ZERO,D=r.a,K=e.mul(r.b,Wn),P=e.mul(m,L),Z=e.mul(E,R),G=e.mul(A,x),vt=e.add(m,E),j=e.add(L,R);vt=e.mul(vt,j),j=e.add(P,Z),vt=e.sub(vt,j),j=e.add(m,A);let tt=e.add(L,x);return j=e.mul(j,tt),tt=e.add(P,G),j=e.sub(j,tt),tt=e.add(E,A),w=e.add(R,x),tt=e.mul(tt,w),w=e.add(Z,G),tt=e.sub(tt,w),T=e.mul(D,j),w=e.mul(K,G),T=e.add(w,T),w=e.sub(Z,T),T=e.add(Z,T),S=e.mul(w,T),Z=e.add(P,P),Z=e.add(Z,P),G=e.mul(D,G),j=e.mul(K,j),Z=e.add(Z,G),G=e.sub(P,G),G=e.mul(D,G),j=e.add(j,G),P=e.mul(Z,j),S=e.add(S,P),P=e.mul(tt,j),w=e.mul(vt,w),w=e.sub(w,P),P=e.mul(vt,Z),T=e.mul(tt,T),T=e.add(T,P),new I(w,S,T)}subtract(b){return this.add(b.negate())}is0(){return this.equals(I.ZERO)}multiply(b){let{endo:m}=t;if(!n.isValidNot0(b))throw new Error("invalid scalar: out of range");let E,A,L=R=>V.cached(this,R,x=>Wt(I,x));if(m){let{k1neg:R,k1:x,k2neg:w,k2:S}=k(b),{p:T,f:D}=L(x),{p:K,f:P}=L(S);A=D.add(P),E=H(m.beta,T,K,R,w)}else{let{p:R,f:x}=L(b);E=R,A=x}return Wt(I,[E,A])[0]}multiplyUnsafe(b){let{endo:m}=t,E=this;if(!n.isValid(b))throw new Error("invalid scalar: out of range");if(b===te||E.is0())return I.ZERO;if(b===br)return E;if(V.hasCache(this))return this.multiply(b);if(m){let{k1neg:A,k1:L,k2neg:R,k2:x}=k(b),{p1:w,p2:S}=ja(I,E,L,x);return H(m.beta,w,S,A,R)}else return V.unsafe(E,b)}multiplyAndAddUnsafe(b,m,E){let A=this.multiplyUnsafe(m).add(b.multiplyUnsafe(E));return A.is0()?void 0:A}toAffine(b){return B(this,b)}isTorsionFree(){let{isTorsionFree:b}=t;return s===br?!0:b?b(I,this):V.unsafe(this,o).is0()}clearCofactor(){let{clearCofactor:b}=t;return s===br?this:b?b(I,this):this.multiplyUnsafe(s)}isSmallOrder(){return this.multiplyUnsafe(s).is0()}toBytes(b=!0){return Gt("isCompressed",b),this.assertValidity(),h(I,this,b)}toRawBytes(b=!0){return this.toBytes(b)}toHex(b=!0){return It(this.toBytes(b))}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}}I.BASE=new I(r.Gx,r.Gy,e.ONE),I.ZERO=new I(e.ZERO,e.ONE,e.ZERO),I.Fp=e,I.Fn=n;let O=n.BITS,V=new ur(I,t.endo?Math.ceil(O/2):O);return I}function Ac(r){return Uint8Array.of(r?2:3)}function Ih(r,t,e={}){sr(t),ye(e,{},{hmac:"function",lowS:"boolean",randomBytes:"function",bits2int:"function",bits2int_modN:"function"});let n=e.randomBytes||_e,s=e.hmac||((x,...w)=>sn(t,x,mt(...w))),{Fp:o,Fn:i}=r,{ORDER:a,BITS:c}=i,l=Uo(a),h={secret:i.BYTES,public:1+o.BYTES,publicUncompressed:1+2*o.BYTES,signature:2*i.BYTES,seed:l};function u(x){let w=a>>br;return x>w}function f(x){return u(x)?i.neg(x):x}function d(x,w){if(!i.isValidNot0(w))throw new Error(`invalid signature ${x}: out of range 1..CURVE.n`)}class p{constructor(w,S,T){d("r",w),d("s",S),this.r=w,this.s=S,T!=null&&(this.recovery=T),Object.freeze(this)}static fromBytes(w,S="compact"){if(S==="compact"){let T=i.BYTES;z(w,T*2);let D=w.subarray(0,T),K=w.subarray(T,T*2);return new p(i.fromBytes(D),i.fromBytes(K))}if(S==="der"){z(w);let{r:T,s:D}=Qt.toSig(w);return new p(T,D)}throw new Error("invalid format")}static fromHex(w,S){return this.fromBytes(Te(w),S)}addRecoveryBit(w){return new p(this.r,this.s,w)}recoverPublicKey(w){let S=o.ORDER,{r:T,s:D,recovery:K}=this;if(K==null||![0,1,2,3].includes(K))throw new Error("recovery id invalid");if(a*Bc<S&&K>1)throw new Error("recovery id is ambiguous for h>1 curve");let Z=K===2||K===3?T+a:T;if(!o.isValid(Z))throw new Error("recovery id 2 or 3 invalid");let G=o.toBytes(Z),vt=r.fromHex(mt(Ac((K&1)===0),G)),j=i.inv(Z),tt=O($("msgHash",w)),Et=i.create(-tt*j),ue=i.create(D*j),Be=r.BASE.multiplyUnsafe(Et).add(vt.multiplyUnsafe(ue));if(Be.is0())throw new Error("point at infinify");return Be.assertValidity(),Be}hasHighS(){return u(this.s)}normalizeS(){return this.hasHighS()?new p(this.r,i.neg(this.s),this.recovery):this}toBytes(w="compact"){if(w==="compact")return mt(i.toBytes(this.r),i.toBytes(this.s));if(w==="der")return Te(Qt.hexFromSig(this));throw new Error("invalid format")}toHex(w){return It(this.toBytes(w))}assertValidity(){}static fromCompact(w){return p.fromBytes($("sig",w),"compact")}static fromDER(w){return p.fromBytes($("sig",w),"der")}toDERRawBytes(){return this.toBytes("der")}toDERHex(){return It(this.toBytes("der"))}toCompactRawBytes(){return this.toBytes("compact")}toCompactHex(){return It(this.toBytes("compact"))}}function y(x){try{return!!mr(i,x)}catch{return!1}}function g(x,w){try{let S=x.length;return w===!0&&S!==h.public||w===!1&&S!==h.publicUncompressed?!1:!!r.fromBytes(x)}catch{return!1}}function v(x=n(l)){return Lo(x,a)}let k={isValidSecretKey:y,isValidPublicKey:g,randomSecretKey:v,isValidPrivateKey:y,randomPrivateKey:v,normPrivateKeyToScalar:x=>mr(i,x),precompute(x=8,w=r.BASE){return w.precompute(x,!1)}};function B(x,w=!0){return r.BASE.multiply(mr(i,x)).toBytes(w)}function N(x){if(typeof x=="bigint")return!1;if(x instanceof r)return!0;if(i.allowedLengths||h.secret===h.public)return;let w=$("key",x).length;return w===h.public||w===h.publicUncompressed}function H(x,w,S=!0){if(N(x)===!0)throw new Error("first arg must be private key");if(N(w)===!1)throw new Error("second arg must be public key");let T=mr(i,x);return r.fromHex(w).multiply(T).toBytes(S)}let I=e.bits2int||function(x){if(x.length>8192)throw new Error("input is too large");let w=ir(x),S=x.length*8-c;return S>0?w>>BigInt(S):w},O=e.bits2int_modN||function(x){return i.create(I(x))},V=ge(c);function _(x){return pe("num < 2^"+c,x,te,V),i.toBytes(x)}function b(x,w,S=m){if(["recovered","canonical"].some(Et=>Et in S))throw new Error("sign() legacy options not supported");let{lowS:T,prehash:D,extraEntropy:K}=S;T==null&&(T=!0),x=$("msgHash",x),Ec(S),D&&(x=$("prehashed msgHash",t(x)));let P=O(x),Z=mr(i,w),G=[_(Z),_(P)];if(K!=null&&K!==!1){let Et=K===!0?n(h.secret):K;G.push($("extraEntropy",Et))}let vt=mt(...G),j=P;function tt(Et){let ue=I(Et);if(!i.isValidNot0(ue))return;let Be=i.inv(ue),Cr=r.BASE.multiply(ue).toAffine(),Ae=i.create(Cr.x);if(Ae===te)return;let Nr=i.create(Be*i.create(j+Ae*Z));if(Nr===te)return;let Ai=(Cr.x===Ae?0:2)|Number(Cr.y&br),Si=Nr;return T&&u(Nr)&&(Si=f(Nr),Ai^=1),new p(Ae,Si,Ai)}return{seed:vt,k2sig:tt}}let m={lowS:e.lowS,prehash:!1},E={lowS:e.lowS,prehash:!1};function A(x,w,S=m){let{seed:T,k2sig:D}=b(x,w,S);return Ia(t.outputLen,i.BYTES,s)(T,D)}r.BASE.precompute(8);function L(x,w,S,T=E){let D=x;w=$("msgHash",w),S=$("publicKey",S),Ec(T);let{lowS:K,prehash:P,format:Z}=T;if("strict"in T)throw new Error("options.strict was renamed to lowS");let G,vt;if(Z===void 0){let j=typeof D=="string"||Ce(D),tt=!j&&D!==null&&typeof D=="object"&&typeof D.r=="bigint"&&typeof D.s=="bigint";if(!j&&!tt)throw new Error("invalid signature, expected Uint8Array, hex string or Signature instance");if(tt)G=new p(D.r,D.s);else if(j){try{G=p.fromDER(D)}catch(Et){if(!(Et instanceof Qt.Err))throw Et}if(!G)try{G=p.fromCompact(D)}catch{return!1}}}else if(Z==="compact"||Z==="der"){if(typeof D!="string"&&!Ce(D))throw new Error('"der" / "compact" format expects Uint8Array signature');G=p.fromBytes($("sig",D),Z)}else if(Z==="js"){if(!(D instanceof p))throw new Error('"js" format expects Signature instance');G=D}else throw new Error('format must be "compact", "der" or "js"');if(!G)return!1;try{if(vt=r.fromHex(S),K&&G.hasHighS())return!1;P&&(w=t(w));let{r:j,s:tt}=G,Et=O(w),ue=i.inv(tt),Be=i.create(Et*ue),Cr=i.create(j*ue),Ae=r.BASE.multiplyUnsafe(Be).add(vt.multiplyUnsafe(Cr));return Ae.is0()?!1:i.create(Ae.x)===j}catch{return!1}}function R(x){let w=k.randomSecretKey(x);return{secretKey:w,publicKey:B(w)}}return Object.freeze({keygen:R,getPublicKey:B,sign:A,verify:L,getSharedSecret:H,utils:k,Point:r,Signature:p,info:{type:"weierstrass",lengths:h,publicKeyHasPrefix:!0}})}function Ch(r){let t={a:r.a,b:r.b,p:r.Fp.ORDER,n:r.n,h:r.h,Gx:r.Gx,Gy:r.Gy},e=r.Fp,n=r.allowedPrivateKeyLengths?Array.from(new Set(r.allowedPrivateKeyLengths.map(i=>Math.ceil(i/2)))):void 0,s=At(t.n,{BITS:r.nBitLength,allowedLengths:n,modOnDecode:r.wrapPrivateKey}),o={Fp:e,Fn:s,allowInfinityPoint:r.allowInfinityPoint,endo:r.endo,isTorsionFree:r.isTorsionFree,clearCofactor:r.clearCofactor,fromBytes:r.fromBytes,toBytes:r.toBytes};return{CURVE:t,curveOpts:o}}function Nh(r){let{CURVE:t,curveOpts:e}=Ch(r),n={hmac:r.hmac,randomBytes:r.randomBytes,lowS:r.lowS,bits2int:r.bits2int,bits2int_modN:r.bits2int_modN};return{CURVE:t,curveOpts:e,hash:r.hash,ecdsaOpts:n}}function Th(r,t){return Object.assign({},t,{ProjectivePoint:t.Point,CURVE:r})}function Sc(r){let{CURVE:t,curveOpts:e,hash:n,ecdsaOpts:s}=Nh(r),o=kh(t,e),i=Ih(o,n,s);return Th(r,i)}function kc(r,t){let e=n=>Sc({...r,hash:n});return{...e(t),create:e}}var hi={p:BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),n:BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),h:BigInt(1),a:BigInt(0),b:BigInt(7),Gx:BigInt("0x79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798"),Gy:BigInt("0x483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8")},_h={beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),basises:[[BigInt("0x3086d221a7d46bcde86c90e49284eb15"),-BigInt("0xe4437ed6010e88286f547fa90abfe4c3")],[BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),BigInt("0x3086d221a7d46bcde86c90e49284eb15")]]};var Ic=BigInt(2);function Uh(r){let t=hi.p,e=BigInt(3),n=BigInt(6),s=BigInt(11),o=BigInt(22),i=BigInt(23),a=BigInt(44),c=BigInt(88),l=r*r*r%t,h=l*l*r%t,u=Y(h,e,t)*h%t,f=Y(u,e,t)*h%t,d=Y(f,Ic,t)*l%t,p=Y(d,s,t)*d%t,y=Y(p,o,t)*p%t,g=Y(y,a,t)*y%t,v=Y(g,c,t)*g%t,k=Y(v,a,t)*y%t,B=Y(k,e,t)*h%t,N=Y(B,i,t)*p%t,H=Y(N,n,t)*l%t,I=Y(H,Ic,t);if(!fi.eql(fi.sqr(I),r))throw new Error("Cannot find square root");return I}var fi=At(hi.p,void 0,void 0,{sqrt:Uh}),Ot=kc({...hi,Fp:fi,lowS:!0,endo:_h},Dn);var Cc=32;function Nc(r,t,e){let n=tr.digest(t instanceof Uint8Array?t:t.subarray());if(dr(n))return n.then(({digest:s})=>(e?.signal?.throwIfAborted(),Ot.sign(s,r).toDERRawBytes())).catch(s=>{throw s.name==="AbortError"?s:new _r(String(s))});try{return Ot.sign(n.digest,r).toDERRawBytes()}catch(s){throw new _r(String(s))}}function Tc(r,t,e,n){let s=tr.digest(e instanceof Uint8Array?e:e.subarray());if(dr(s))return s.then(({digest:o})=>(n?.signal?.throwIfAborted(),Ot.verify(t,o,r))).catch(o=>{throw o.name==="AbortError"?o:new Ur(String(o))});try{return n?.signal?.throwIfAborted(),Ot.verify(t,s.digest,r)}catch(o){throw new Ur(String(o))}}var Jn=class{type="secp256k1";raw;_key;constructor(t){this._key=Lc(t),this.raw=_c(this._key)}toMultihash(){return Se.digest(rr(this))}toCID(){return kt.createV1(114,this.toMultihash())}toString(){return Q.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:gt(this.raw,t.raw)}verify(t,e,n){return Tc(this._key,e,t,n)}},Xn=class{type="secp256k1";raw;publicKey;constructor(t,e){this.raw=Uc(t),this.publicKey=new Jn(e??Rc(t))}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:gt(this.raw,t.raw)}sign(t,e){return Nc(this.raw,t,e)}};function di(r){return new Xn(r)}function _c(r){return Ot.ProjectivePoint.fromHex(r).toRawBytes(!0)}function Uc(r){try{return Ot.getPublicKey(r,!0),r}catch(t){throw new Lr(String(t))}}function Lc(r){try{return Ot.ProjectivePoint.fromHex(r),r}catch(t){throw new Ge(String(t))}}function Rc(r){try{return Ot.getPublicKey(r,!0)}catch(t){throw new Lr(String(t))}}function rr(r){return we.encode({Type:rt[r.type],Data:r.raw})}function Dc(r){let t=en.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case rt.RSA:return ai(e);case rt.Ed25519:return Fo(e);case rt.secp256k1:return di(e);case rt.ECDSA:return ia(e);default:throw new Ze}}function Hc(r){if(r.byteLength===Ct)return Fo(r);if(r.byteLength===Cc)return di(r);let t=_t(r),e=t[2]?.[0];if(e===ea||e===ra||e===na)return Bo(t);if(t.length>8)return Yn(t);throw new U("Could not extract private key from raw bytes")}function Me(r){return en.encode({Type:rt[r.type],Data:r.raw})}function Kc(r,t,e,n){sr(r);let s=pa({dkLen:32,asyncTick:10},n),{c:o,dkLen:i,asyncTick:a}=s;if(jt(o),jt(i),jt(a),o<1)throw new Error("iterations (c) should be >= 1");let c=Ao(t),l=Ao(e),h=new Uint8Array(i),u=sn.create(r,c),f=u._cloneInto().update(l);return{c:o,dkLen:i,asyncTick:a,DK:h,PRF:u,PRFSalt:f}}function Oc(r,t,e,n,s){return r.destroy(),t.destroy(),n&&n.destroy(),yt(s),e}function Vc(r,t,e,n){let{c:s,dkLen:o,DK:i,PRF:a,PRFSalt:c}=Kc(r,t,e,n),l,h=new Uint8Array(4),u=Ne(h),f=new Uint8Array(a.outputLen);for(let d=1,p=0;p<o;d++,p+=a.outputLen){let y=i.subarray(p,p+a.outputLen);u.setInt32(0,d,!1),(l=c._cloneInto(l)).update(h).digestInto(f),y.set(f.subarray(0,y.length));for(let g=1;g<s;g++){a._cloneInto(l).update(f).digestInto(f);for(let v=0;v<y.length;v++)y[v]^=f[v]}}return Oc(a,c,i,l,f)}async function Qn(r,t,e,n){let{c:s,dkLen:o,asyncTick:i,DK:a,PRF:c,PRFSalt:l}=Kc(r,t,e,n),h,u=new Uint8Array(4),f=Ne(u),d=new Uint8Array(c.outputLen);for(let p=1,y=0;y<o;p++,y+=c.outputLen){let g=a.subarray(y,y+c.outputLen);f.setInt32(0,p,!1),(h=l._cloneInto(h)).update(u).digestInto(d),g.set(d.subarray(0,g.length)),await da(s-1,i,()=>{c._cloneInto(h).update(d).digestInto(d);for(let v=0;v<g.length;v++)g[v]^=d[v]})}return Oc(c,l,a,h,d)}var on=Uint32Array.from([1732584193,4023233417,2562383102,271733878,3285377520]),xe=new Uint32Array(80),ts=class extends Ue{constructor(){super(64,20,8,!1),this.A=on[0]|0,this.B=on[1]|0,this.C=on[2]|0,this.D=on[3]|0,this.E=on[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)xe[c]=t.getUint32(e,!1);for(let c=16;c<80;c++)xe[c]=Cn(xe[c-3]^xe[c-8]^xe[c-14]^xe[c-16],1);let{A:n,B:s,C:o,D:i,E:a}=this;for(let c=0;c<80;c++){let l,h;c<20?(l=Tn(s,o,i),h=1518500249):c<40?(l=s^o^i,h=1859775393):c<60?(l=_n(s,o,i),h=2400959708):(l=s^o^i,h=3395469782);let u=Cn(n,5)+l+a+h+xe[c]|0;a=i,i=o,o=Cn(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(){yt(xe)}destroy(){this.set(0,0,0,0,0),yt(this.buffer)}},Pc=qr(()=>new ts);var Mc=Pc;var wr=Hn;var Fc={sha1:Mc,"sha2-256":gr,"sha2-512":wr};function an(r,t,e,n,s){if(s!=="sha1"&&s!=="sha2-256"&&s!=="sha2-512"){let a=Object.keys(Fc).join(" / ");throw new U(`Hash '${s}' is unknown or not supported. Must be ${a}`)}let o=Fc[s],i=Vc(o,r,t,{c:e,dkLen:n});return ke.encode(i).substring(1)}function xr(r){if(typeof r!="object"||r===null)return!1;let t=Object.getPrototypeOf(r);return(t===null||t===Object.prototype||Object.getPrototypeOf(t)===null)&&!(Symbol.toStringTag in r)&&!(Symbol.iterator in r)}var{hasOwnProperty:jc}=Object.prototype,{propertyIsEnumerable:Lh}=Object,vr=(r,t,e)=>{Object.defineProperty(r,t,{value:e,writable:!0,enumerable:!0,configurable:!0})},Rh=void 0,qc={concatArrays:!1,ignoreUndefined:!1},es=r=>{let t=[];for(let e in r)jc.call(r,e)&&t.push(e);if(Object.getOwnPropertySymbols){let e=Object.getOwnPropertySymbols(r);for(let n of e)Lh.call(r,n)&&t.push(n)}return t};function Er(r){return Array.isArray(r)?Dh(r):xr(r)?Hh(r):r}function Dh(r){let t=r.slice(0,0);return es(r).forEach(e=>{vr(t,e,Er(r[e]))}),t}function Hh(r){let t=Object.getPrototypeOf(r)===null?Object.create(null):{};return es(r).forEach(e=>{vr(t,e,Er(r[e]))}),t}var $c=(r,t,e,n)=>(e.forEach(s=>{typeof t[s]>"u"&&n.ignoreUndefined||(s in r&&r[s]!==Object.getPrototypeOf(r)?vr(r,s,pi(r[s],t[s],n)):vr(r,s,Er(t[s])))}),r),Kh=(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++)jc.call(o,a)&&(i.push(String(a)),o===r?vr(n,s++,o[a]):vr(n,s++,Er(o[a])));n=$c(n,o,es(o).filter(a=>!i.includes(a)),e)}),n};function pi(r,t,e){return e.concatArrays&&Array.isArray(r)&&Array.isArray(t)?Kh(r,t,e):!xr(t)||!xr(r)?Er(t):$c(r,t,es(t),e)}function Gc(...r){let t=pi(Er(qc),this!==Rh&&this||{},qc),e={_:{}};for(let n of r)if(n!==void 0){if(!xr(n))throw new TypeError("`"+n+"` is not an Option Object");e=pi(e,{_:n},t)}return e._}var ee="/",Zc=new TextEncoder().encode(ee),rs=Zc[0],cn=class r{_buf;constructor(t,e){if(typeof t=="string")this._buf=M(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]!==rs)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(ee))}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=Zc),this._buf[0]!==rs){let t=new Uint8Array(this._buf.byteLength+1);t.fill(rs,0,1),t.set(this._buf,1),this._buf=t}for(;this._buf.byteLength>1&&this._buf[this._buf.byteLength-1]===rs;)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(ee).slice(1)}type(){return Oh(this.baseNamespace())}name(){return Vh(this.baseNamespace())}instance(t){return new r(this.toString()+":"+t)}path(){let t=this.parent().toString();return t.endsWith(ee)||(t+=ee),t+=this.type(),new r(t)}parent(){let t=this.list();return t.length===1?new r(ee):new r(t.slice(0,-1).join(ee))}child(t){return this.toString()===ee?t:t.toString()===ee?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(),...Ph(t.map(e=>e.namespaces()))])}};function Oh(r){let t=r.split(":");return t.length<2?"":t.slice(0,-1).join(":")}function Vh(r){let t=r.split(":");return t[t.length-1]}function Ph(r){return[].concat(...r)}var Gu=Ii(ru(),1);var Br={};ut(Br,{create:()=>Qh,derivedEmptyPasswordKey:()=>ns});var ns={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function Qh(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=X.get();e*=8;async function c(u,f){let d=a.getRandomValues(new Uint8Array(o)),p=a.getRandomValues(new Uint8Array(n)),y={name:t,iv:p};typeof f=="string"&&(f=M(f));let g;if(f.length===0){g=await a.subtle.importKey("jwk",ns,{name:"AES-GCM"},!0,["encrypt"]);try{let k={name:"PBKDF2",salt:d,iterations:i,hash:{name:s}},B=await a.subtle.importKey("raw",f,{name:"PBKDF2"},!1,["deriveKey"]);g=await a.subtle.deriveKey(k,B,{name:t,length:e},!0,["encrypt"])}catch{g=await a.subtle.importKey("jwk",ns,{name:"AES-GCM"},!0,["encrypt"])}}else{let k={name:"PBKDF2",salt:d,iterations:i,hash:{name:s}},B=await a.subtle.importKey("raw",f,{name:"PBKDF2"},!1,["deriveKey"]);g=await a.subtle.deriveKey(k,B,{name:t,length:e},!0,["encrypt"])}let v=await a.subtle.encrypt(y,g,u);return Qe([d,y.iv,new Uint8Array(v)])}async function l(u,f){let d=u.subarray(0,o),p=u.subarray(o,o+n),y=u.subarray(o+n),g={name:t,iv:p};typeof f=="string"&&(f=M(f));let v;if(f.length===0)try{let B={name:"PBKDF2",salt:d,iterations:i,hash:{name:s}},N=await a.subtle.importKey("raw",f,{name:"PBKDF2"},!1,["deriveKey"]);v=await a.subtle.deriveKey(B,N,{name:t,length:e},!0,["decrypt"])}catch{v=await a.subtle.importKey("jwk",ns,{name:"AES-GCM"},!0,["decrypt"])}else{let B={name:"PBKDF2",salt:d,iterations:i,hash:{name:s}},N=await a.subtle.importKey("raw",f,{name:"PBKDF2"},!1,["deriveKey"]);v=await a.subtle.deriveKey(B,N,{name:t,length:e},!0,["decrypt"])}let k=await a.subtle.decrypt(g,v,y);return new Uint8Array(k)}return{encrypt:c,decrypt:l}}var F=Ii(nu());function Fe(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 ve(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 l=new Uint8Array(c);for(let h=a-1;h>=0;h--){let u=Math.pow(2,h*t);l[o-h-1]=Math.floor(s/u),s-=l[o-h-1]*u}return c}i*=Math.pow(2,t)}return new ArrayBuffer(0)}function is(...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 yi(){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=Fe(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,Fe(o,8)-n}function su(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=ve(i,8,n),c=new Uint8Array(a);return c[0]|=128,a}let s=ve(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 ou(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 wt(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 cb=Math.log(2);function as(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function mi(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 ae(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 fn=class{constructor(){this.items=[]}write(t){this.items.push(t)}final(){return mi(this.items)}},un=[new Uint8Array([1])],iu="0123456789";var Sr="",Dt=new ArrayBuffer(0),bi=new Uint8Array(0),hn="EndOfContent",cu="OCTET STRING",uu="BIT STRING";function ce(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?F.BufferSourceConverter.toUint8Array(o.valueHex):bi}fromBER(n,s,o){let i=n instanceof ArrayBuffer?new Uint8Array(n):n;if(!ae(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",Dt)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:F.Convert.ToHex(this.valueHexView)}}},t.NAME="hexBlock",t}var ne=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=Sr,warnings:n=[],valueBeforeDecode:s=bi}={}){this.blockLength=t,this.error=e,this.warnings=n,this.valueBeforeDecodeView=F.BufferSourceConverter.toUint8Array(s)}toJSON(){return{blockName:this.constructor.NAME,blockLength:this.blockLength,error:this.error,warnings:this.warnings,valueBeforeDecode:F.Convert.ToHex(this.valueBeforeDecodeView)}}};ne.NAME="baseBlock";var ct=class extends ne{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'")}};ct.NAME="valueBlock";var cs=class extends ce(ne){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?F.BufferSourceConverter.toUint8Array(t.valueHex):bi,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",Dt}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=ve(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=F.BufferSourceConverter.toUint8Array(t);if(!ae(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,l=this.valueHexView=new Uint8Array(255),h=255;for(;o[c]&128;){if(l[c-1]=o[c]&127,c++,c>=o.length)return this.error="End of input reached before message was fully decoded",-1;if(c===h){h+=255;let f=new Uint8Array(h);for(let d=0;d<l.length;d++)f[d]=l[d];l=this.valueHexView=new Uint8Array(h)}}this.blockLength=c+1,l[c-1]=o[c]&127;let u=new Uint8Array(c);for(let f=0;f<c;f++)u[f]=l[f];l=this.valueHexView=new Uint8Array(c),l.set(u),this.blockLength<=9?this.tagNumber=Fe(l,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}}};cs.NAME="identificationBlock";var us=class extends ne{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=F.BufferSourceConverter.toUint8Array(t);if(!ae(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=Fe(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=ve(this.length,8);if(s.byteLength>127)return this.error="Too big length",Dt;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}}};us.NAME="lengthBlock";var C={},ot=class extends ne{constructor({name:t=Sr,optional:e=!1,primitiveSchema:n,...s}={},o){super(s),this.name=t,this.optional=e,n&&(this.primitiveSchema=n),this.idBlock=new cs(s),this.lenBlock=new us(s),this.valueBlock=o?new o(s):new ct(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 fn;e||lu(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?Dt: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():F.Convert.ToHex(this.toBER())}onAsciiEncoding(){let t=this.constructor.NAME,e=F.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 ou(e,n)}};ot.NAME="BaseBlock";function lu(r){var t;if(r instanceof C.Constructed)for(let e of r.valueBlock.value)lu(e)&&(r.lenBlock.isIndefiniteForm=!0);return!!(!((t=r.lenBlock)===null||t===void 0)&&t.isIndefiniteForm)}var ls=class extends ot{getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}constructor({value:t=Sr,...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}'`}};ls.NAME="BaseStringBlock";var fs=class extends ce(ct){constructor({isHexOnly:t=!0,...e}={}){super(e),this.isHexOnly=t}};fs.NAME="PrimitiveValueBlock";var fu,hs=class extends ot{constructor(t={}){super(t,fs),this.idBlock.isConstructed=!1}};fu=hs;C.Primitive=fu;hs.NAME="PRIMITIVE";function cd(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 Gs(r,t=0,e=r.length){let n=t,s=new ot({},ct),o=new ne;if(!ae(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=ot;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=C.EndOfContent;break;case 1:c=C.Boolean;break;case 2:c=C.Integer;break;case 3:c=C.BitString;break;case 4:c=C.OctetString;break;case 5:c=C.Null;break;case 6:c=C.ObjectIdentifier;break;case 10:c=C.Enumerated;break;case 12:c=C.Utf8String;break;case 13:c=C.RelativeObjectIdentifier;break;case 14:c=C.TIME;break;case 15:return s.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:s};case 16:c=C.Sequence;break;case 17:c=C.Set;break;case 18:c=C.NumericString;break;case 19:c=C.PrintableString;break;case 20:c=C.TeletexString;break;case 21:c=C.VideotexString;break;case 22:c=C.IA5String;break;case 23:c=C.UTCTime;break;case 24:c=C.GeneralizedTime;break;case 25:c=C.GraphicString;break;case 26:c=C.VisibleString;break;case 27:c=C.GeneralString;break;case 28:c=C.UniversalString;break;case 29:c=C.CharacterString;break;case 30:c=C.BmpString;break;case 31:c=C.DATE;break;case 32:c=C.TimeOfDay;break;case 33:c=C.DateTime;break;case 34:c=C.Duration;break;default:{let l=s.idBlock.isConstructed?new C.Constructed:new C.Primitive;l.idBlock=s.idBlock,l.lenBlock=s.lenBlock,l.warnings=s.warnings,s=l}}break;case 2:case 3:case 4:default:c=s.idBlock.isConstructed?C.Constructed:C.Primitive}return s=cd(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 Zs(r){if(!r.byteLength){let t=new ot({},ct);return t.error="Input buffer has zero length",{offset:-1,result:t}}return Gs(F.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function ud(r,t){return r?1:t}var Vt=class extends ct{constructor({value:t=[],isIndefiniteForm:e=!1,...n}={}){super(n),this.value=t,this.isIndefiniteForm=e}fromBER(t,e,n){let s=F.BufferSourceConverter.toUint8Array(t);if(!ae(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(;ud(this.isIndefiniteForm,n)>0;){let i=Gs(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===hn)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===hn?this.value.pop():this.warnings.push("No EndOfContent block encoded")),o}toBER(t,e){let n=e||new fn;for(let s=0;s<this.value.length;s++)this.value[s].toBER(t,n);return e?Dt:n.final()}toJSON(){let t={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let e of this.value)t.value.push(e.toJSON());return t}};Vt.NAME="ConstructedValueBlock";var hu,Ee=class extends ot{constructor(t={}){super(t,Vt),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} :`}};zc=ue;C.Constructed=zc;ue.NAME="CONSTRUCTED";var rs=class extends it{fromBER(t,e,n){return e}toBER(t){return Ut}};rs.override="EndOfContentValueBlock";var Wc,ns=class extends rt{constructor(t={}){super(t,rs),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};Wc=ns;C.EndOfContent=Wc;ns.NAME=Yr;var Zc,Ne=class extends rt{constructor(t={}){super(t,it),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}`}};Zc=Ne;C.Null=Zc;Ne.NAME="NULL";var ss=class extends Xt(it){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=O.BufferSourceConverter.toUint8Array(e.valueHex):this.valueHexView=new Uint8Array(1),t&&(this.value=t)}fromBER(t,e,n){let s=O.BufferSourceConverter.toUint8Array(t);return Yt(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}}};ss.NAME="BooleanValueBlock";var Jc,os=class extends rt{getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}constructor(t={}){super(t,ss),this.idBlock.tagClass=1,this.idBlock.tagNumber=1}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.getValue}`}};Jc=os;C.Boolean=Jc;os.NAME="BOOLEAN";var is=class extends Xt(Ht){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=Ht.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===Yr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(i!==jc)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?Ht.prototype.toBER.call(this,t,e):t?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};is.NAME="OctetStringValueBlock";var oi,Wt=class extends rt{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},is),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=Ds(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 ue.prototype.onAsciiEncoding.call(this);let t=this.constructor.NAME,e=O.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 O.BufferSourceConverter.concat(t)}};oi=Wt;C.OctetString=oi;Wt.NAME=jc;var as=class extends Xt(Ht){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=Ht.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let a of this.value){let c=a.constructor.NAME;if(c===Yr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==qc)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=O.BufferSourceConverter.toUint8Array(t);if(!Yt(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=Ds(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 Ht.prototype.toBER.call(this,t,e);if(t)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return Ut;let n=new Uint8Array(this.valueHexView.length+1);return n[0]=this.unusedBits,n.set(this.valueHexView,1),n.buffer}toJSON(){return{...super.toJSON(),unusedBits:this.unusedBits,isConstructed:this.isConstructed}}};as.NAME="BitStringValueBlock";var Yc,cs=class extends rt{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},as),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 ue.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}`}}};Yc=cs;C.BitString=Yc;cs.NAME=qc;var Xc;function Ph(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 Fc(r){if(r>=Wr.length)for(let t=Wr.length;t<=r;t++){let e=new Uint8Array([0]),n=Wr[t-1].slice(0);for(let s=n.length-1;s>=0;s--){let o=new Uint8Array([(n[s]<<1)+e[0]]);e[0]=o[0]/10,n[s]=o[0]%10}e[0]>0&&(n=Zn(e,n)),Wr.push(n)}return Wr[r]}function Mh(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 Xr=class extends Xt(it){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(Oc(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=Mh(Fc(n),e),i="-";break;default:e=Ph(e,Fc(n))}n++,s>>=1}}for(let c=0;c<e.length;c++)e[c]&&(a=!0),a&&(i+=Mc.charAt(e[c]));return a===!1&&(i+=Mc.charAt(0)),i}};Xc=Xr;Xr.NAME="IntegerValueBlock";Object.defineProperty(Xc.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var Zr,Zt=class extends rt{constructor(t={}){super(t,Xr),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return Jn(),BigInt(this.valueBlock.toString())}static fromBigInt(t){Jn();let e=BigInt(t),n=new Jr,s=e.toString(16).replace(/^-/,""),o=new Uint8Array(O.Convert.FromHex(s));if(e<0){let a=new Uint8Array(o.length+(o[0]&128?1:0));a[0]|=128;let f=BigInt(`0x${O.Convert.ToHex(a)}`)+e,l=O.BufferSourceConverter.toUint8Array(O.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 Zr({valueHex:n.final()})}convertToDER(){let t=new Zr({valueHex:this.valueBlock.valueHexView});return t.valueBlock.toDER(),t}convertFromDER(){return new Zr({valueHex:this.valueBlock.valueHexView[0]===0?this.valueBlock.valueHexView.subarray(1):this.valueBlock.valueHexView})}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()}`}};Zr=Zt;C.Integer=Zr;Zt.NAME="INTEGER";var Qc,ls=class extends Zt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};Qc=ls;C.Enumerated=Qc;ls.NAME="ENUMERATED";var Qr=class extends Xt(it){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=O.BufferSourceConverter.toUint8Array(t);if(!Yt(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=Ce(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}set valueBigInt(t){Jn();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=le(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Ut;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),o=e.byteLength-1;for(let i=0;i<o;i++)n[i]=s[i]|128;n[o]=s[o]}return n}toString(){let t="";if(this.isHexOnly)t=O.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}}};Qr.NAME="sidBlock";var us=class extends it{constructor({value:t=hr,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new Qr;if(s=o.fromBER(t,s,n),s===-1)return this.blockLength=0,this.error=o.error,s;this.value.length===0&&(o.isFirstSid=!0),this.blockLength+=o.blockLength,n-=o.blockLength,this.value.push(o)}return s}toBER(t){let e=[];for(let n=0;n<this.value.length;n++){let s=this.value[n].toBER(t);if(s.byteLength===0)return this.error=this.value[n].error,Ut;e.push(s)}return 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 Qr;if(s>Number.MAX_SAFE_INTEGER){Jn();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}};us.NAME="ObjectIdentifierValueBlock";var tl,Kt=class extends rt{getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}constructor(t={}){super(t,us),this.idBlock.tagClass=1,this.idBlock.tagNumber=6}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};tl=Kt;C.ObjectIdentifier=tl;Kt.NAME="OBJECT IDENTIFIER";var tn=class extends Xt(zt){constructor({valueDec:t=0,...e}={}){super(e),this.valueDec=t}fromBER(t,e,n){if(n===0)return e;let s=O.BufferSourceConverter.toUint8Array(t);if(!Yt(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=Ce(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=le(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Ut;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),o=e.byteLength-1;for(let i=0;i<o;i++)n[i]=s[i]|128;n[o]=s[o]}return n.buffer}toString(){let t="";return this.isHexOnly?t=O.Convert.ToHex(this.valueHexView):t=this.valueDec.toString(),t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};tn.NAME="relativeSidBlock";var fs=class extends it{constructor({value:t=hr,...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.blockLength+=o.blockLength,n-=o.blockLength,this.value.push(o)}return s}toBER(t,e){let n=[];for(let s=0;s<this.value.length;s++){let o=this.value[s].toBER(t);if(o.byteLength===0)return this.error=this.value[s].error,Ut;n.push(o)}return 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 tn;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}};fs.NAME="RelativeObjectIdentifierValueBlock";var el,hs=class extends rt{getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}constructor(t={}){super(t,fs),this.idBlock.tagClass=1,this.idBlock.tagNumber=13}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};el=hs;C.RelativeObjectIdentifier=el;hs.NAME="RelativeObjectIdentifier";var rl,bt=class extends ue{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};rl=bt;C.Sequence=rl;bt.NAME="SEQUENCE";var nl,ds=class extends ue{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};nl=ds;C.Set=nl;ds.NAME="SET";var ps=class extends Xt(it){constructor({...t}={}){super(t),this.isHexOnly=!0,this.value=hr}toJSON(){return{...super.toJSON(),value:this.value}}};ps.NAME="StringValueBlock";var ys=class extends ps{};ys.NAME="SimpleStringValueBlock";var pt=class extends Qn{constructor({...t}={}){super(t,ys)}fromBuffer(t){this.valueBlock.value=String.fromCharCode.apply(null,O.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}};pt.NAME="SIMPLE STRING";var gs=class extends pt{fromBuffer(t){this.valueBlock.valueHexView=O.BufferSourceConverter.toUint8Array(t);try{this.valueBlock.value=O.Convert.ToUtf8String(t)}catch(e){this.warnings.push(`Error during "decodeURIComponent": ${e}, using raw string`),this.valueBlock.value=O.Convert.ToBinary(t)}}fromString(t){this.valueBlock.valueHexView=new Uint8Array(O.Convert.FromUtf8String(t)),this.valueBlock.value=t}};gs.NAME="Utf8StringValueBlock";var sl,Jt=class extends gs{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};sl=Jt;C.Utf8String=sl;Jt.NAME="UTF8String";var ms=class extends pt{fromBuffer(t){this.valueBlock.value=O.Convert.ToUtf16String(t),this.valueBlock.valueHexView=O.BufferSourceConverter.toUint8Array(t)}fromString(t){this.valueBlock.value=t,this.valueBlock.valueHexView=new Uint8Array(O.Convert.FromUtf16String(t))}};ms.NAME="BmpStringValueBlock";var ol,bs=class extends ms{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};ol=bs;C.BmpString=ol;bs.NAME="BMPString";var ws=class extends pt{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=le(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}};ws.NAME="UniversalStringValueBlock";var il,xs=class extends ws{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};il=xs;C.UniversalString=il;xs.NAME="UniversalString";var al,vs=class extends pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};al=vs;C.NumericString=al;vs.NAME="NumericString";var cl,Es=class extends pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};cl=Es;C.PrintableString=cl;Es.NAME="PrintableString";var ll,Bs=class extends pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};ll=Bs;C.TeletexString=ll;Bs.NAME="TeletexString";var ul,As=class extends pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};ul=As;C.VideotexString=ul;As.NAME="VideotexString";var fl,Ss=class extends pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};fl=Ss;C.IA5String=fl;Ss.NAME="IA5String";var hl,ks=class extends pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};hl=ks;C.GraphicString=hl;ks.NAME="GraphicString";var dl,en=class extends pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};dl=en;C.VisibleString=dl;en.NAME="VisibleString";var pl,Is=class extends pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};pl=Is;C.GeneralString=pl;Is.NAME="GeneralString";var yl,Cs=class extends pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};yl=Cs;C.CharacterString=yl;Cs.NAME="CharacterString";var gl,rn=class extends en{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,O.BufferSourceConverter.toUint8Array(t)))}toBuffer(){let t=this.toString(),e=new ArrayBuffer(t.length),n=new Uint8Array(e);for(let s=0;s<t.length;s++)n[s]=t.charCodeAt(s);return e}fromDate(t){this.year=t.getUTCFullYear(),this.month=t.getUTCMonth()+1,this.day=t.getUTCDate(),this.hour=t.getUTCHours(),this.minute=t.getUTCMinutes(),this.second=t.getUTCSeconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second))}fromString(t){let n=/(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})Z/ig.exec(t);if(n===null){this.error="Wrong input string for conversion";return}let s=parseInt(n[1],10);s>=50?this.year=1900+s:this.year=2e3+s,this.month=parseInt(n[2],10),this.day=parseInt(n[3],10),this.hour=parseInt(n[4],10),this.minute=parseInt(n[5],10),this.second=parseInt(n[6],10)}toString(t="iso"){if(t==="iso"){let e=new Array(7);return e[0]=mt(this.year<2e3?this.year-1900:this.year-2e3,2),e[1]=mt(this.month,2),e[2]=mt(this.day,2),e[3]=mt(this.hour,2),e[4]=mt(this.minute,2),e[5]=mt(this.second,2),e[6]="Z",e.join("")}return super.toString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.toDate().toISOString()}`}toJSON(){return{...super.toJSON(),year:this.year,month:this.month,day:this.day,hour:this.hour,minute:this.minute,second:this.second}}};gl=rn;C.UTCTime=gl;rn.NAME="UTCTime";var ml,Ns=class extends rn{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("+"),d="";if(h===-1&&(h=n.indexOf("-"),u=-1),h!==-1){if(d=n.substring(h+1),n=n.substring(0,h),d.length!==2&&d.length!==4)throw new Error("Wrong input string for conversion");let b=parseInt(d.substring(0,2),10);if(isNaN(b.valueOf()))throw new Error("Wrong input string for conversion");if(a=u*b,d.length===4){if(b=parseInt(d.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(mt(this.year,4)),e.push(mt(this.month,2)),e.push(mt(this.day,2)),e.push(mt(this.hour,2)),e.push(mt(this.minute,2)),e.push(mt(this.second,2)),this.millisecond!==0&&(e.push("."),e.push(mt(this.millisecond,3))),e.push("Z"),e.join("")}return super.toString(t)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};ml=Ns;C.GeneralizedTime=ml;Ns.NAME="GeneralizedTime";var bl,Ts=class extends Jt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};bl=Ts;C.DATE=bl;Ts.NAME="DATE";var wl,Us=class extends Jt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};wl=Us;C.TimeOfDay=wl;Us.NAME="TimeOfDay";var xl,_s=class extends Jt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};xl=_s;C.DateTime=xl;_s.NAME="DateTime";var vl,Ls=class extends Jt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};vl=Ls;C.Duration=vl;Ls.NAME="Duration";var El,Rs=class extends Jt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};El=Rs;C.TIME=El;Rs.NAME="TIME";async function Ks(r,t){let n=await ur.create().encrypt(r,t);return de.encode(n)}async function ii(r,t,e){if(r.type==="RSA")return $h(r,t,e);if(r.type==="Ed25519")return Fh(r,t,e);if(r.type==="secp256k1")return jh(r,t,e);if(r.type==="ECDSA")return qh(r,t,e);throw new De}async function Fh(r,t,e="libp2p-key"){if(e==="libp2p-key")return Ks(Ie(r),t);throw new L(`export format '${e}' is not supported`)}async function jh(r,t,e="libp2p-key"){if(e==="libp2p-key")return Ks(Ie(r),t);throw new L("Export format is not supported")}async function qh(r,t,e="libp2p-key"){if(e==="libp2p-key")return Ks(Ie(r),t);throw new L(`export format '${e}' is not supported`)}async function $h(r,t,e="pkcs-8"){if(e==="pkcs-8")return Gh(r,t);if(e==="libp2p-key")return Ks(Ie(r),t);throw new L("Export format is not supported")}async function Gh(r,t){let e=Z.get(),s=new bt({value:[new Zt({value:0}),new bt({value:[new Kt({value:"1.2.840.113549.1.1.1"}),new Ne]}),new Wt({valueHex:r.raw})]}).toBER(),o=new Uint8Array(s,0,s.byteLength),i=ke(16),a=await Fn(ir,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 bt({value:[new Wt({valueHex:i}),new Zt({value:1e4}),new Zt({value:32}),new bt({value:[new Kt({value:"1.2.840.113549.2.11"}),new Ne]})]}),h=new bt({value:[new Kt({value:"1.2.840.113549.1.5.13"}),new bt({value:[new bt({value:[new Kt({value:"1.2.840.113549.1.5.12"}),u]}),new bt({value:[new Kt({value:"2.16.840.1.101.3.4.1.42"}),new Wt({valueHex:c})]})]})]}),b=new bt({value:[h,new Wt({valueHex:l})]}).toBER(),w=new Uint8Array(b,0,b.byteLength);return["-----BEGIN ENCRYPTED PRIVATE KEY-----",...P(w,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
7
- `)}async function ai(r,t){try{let e=await zh(r,t);return gc(e)}catch{}if(!r.includes("BEGIN"))throw new L("Encrypted key was not a libp2p-key or a PEM file");return Wh(r,t)}async function zh(r,t){let e=de.decode(r);return ur.create().decrypt(e,t)}async function Wh(r,t){let e=Z.get(),n;if(r.includes("-----BEGIN ENCRYPTED PRIVATE KEY-----")){let o=V(r.replace("-----BEGIN ENCRYPTED PRIVATE KEY-----","").replace("-----END ENCRYPTED PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:i}=Hs(o),{iv:a,salt:c,iterations:f,keySize:l,cipherText:u}=Zh(i),h=await Fn(ir,t,c,{c:f,dkLen:l}),d=await e.subtle.importKey("raw",h,"AES-CBC",!1,["decrypt"]),b=nn(await e.subtle.decrypt({name:"AES-CBC",iv:a},d,u)),{result:w}=Hs(b);n=kl(w)}else if(r.includes("-----BEGIN PRIVATE KEY-----")){let o=V(r.replace("-----BEGIN PRIVATE KEY-----","").replace("-----END PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:i}=Hs(o);n=kl(i)}else throw new L("Could not parse private key from PEM data");let s=mc(n);if(s.type!=="RSA")throw new L("Could not parse RSA private key from PEM data");return s}function Zh(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=nn(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=nn(f.valueBlock.value[1].getValue());return{cipherText:nn(r.valueBlock.value[1].getValue()),salt:i,iterations:a,keySize:c,iv:u}}function kl(r){return nn(r.valueBlock.value[2].getValue())}function nn(r){return new Uint8Array(r,0,r.byteLength)}var Jh="/pkcs8/",li="/info/",sn=new WeakMap,Te={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 dr(r){return r==null||typeof r!="string"?!1:r===(0,Il.default)(r.trim())&&r.length>0}async function nt(){let e=Math.random()*800+200;await new Promise(n=>setTimeout(n,e))}function Ue(r){return new zr(Jh+r)}function pr(r){return new zr(li+r)}async function Yh(r){let t=Ie(r),e=await Fe.digest(t);return J.encode(e.bytes).substring(1)}var Vs=class{components;init;log;self;constructor(t,e){if(this.components=t,this.log=t.logger.forComponent("libp2p:keychain"),this.init=Ic(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<Te.minKeyLength)throw new Error(`dek.keyLength must be least ${Te.minKeyLength} bytes`);if(this.init.dek?.salt?.length!=null&&this.init.dek.salt.length<Te.minSaltLength)throw new Error(`dek.saltLength must be least ${Te.minSaltLength} bytes`);if(this.init.dek?.iterationCount!=null&&this.init.dek.iterationCount<Te.minIterationCount)throw new Error(`dek.iterationCount must be least ${Te.minIterationCount}`);let n=this.init.pass!=null&&this.init.dek?.salt!=null?Gr(this.init.pass,this.init.dek?.salt,this.init.dek?.iterationCount,this.init.dek?.keyLength,this.init.dek?.hash):"";sn.set(this,{dek:n})}[Symbol.toStringTag]="@libp2p/keychain";[di]=["@libp2p/keychain"];static generateOptions(){let t=Object.assign({},ci),e=Math.ceil(Te.minSaltLength/3)*3;return t.dek.salt=P(ke(e),"base64"),t}static get options(){return ci}async findKeyByName(t){if(!dr(t))throw await nt(),new L(`Invalid key name '${t}'`);let e=pr(t);try{let n=await this.components.datastore.get(e);return JSON.parse(P(n))}catch(n){throw await nt(),this.log.error(n),new cn(`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(P(n.value));if(s.id===t)return s}throw new L(`Key with id '${t}' does not exist.`)}catch(e){throw await nt(),e}}async importKey(t,e){if(!dr(t))throw await nt(),new L(`Invalid key name '${t}'`);if(e==null)throw await nt(),new L("Key is required");let n=Ue(t);if(await this.components.datastore.has(n))throw await nt(),new L(`Key '${t}' already exists`);let o,i;try{o=await Yh(e);let f=sn.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 nt(),f}let a={name:t,id:o},c=this.components.datastore.batch();return c.put(n,V(i)),c.put(pr(t),V(JSON.stringify(a))),await c.commit(),a}async exportKey(t){if(!dr(t))throw await nt(),new L(`Invalid key name '${t}'`);let e=Ue(t);try{let n=await this.components.datastore.get(e),s=P(n),o=sn.get(this);if(o==null)throw new L("dek missing");let i=o.dek;return await ai(s,i)}catch(n){throw await nt(),n}}async removeKey(t){if(!dr(t)||t===this.self)throw await nt(),new L(`Invalid key name '${t}'`);let e=Ue(t),n=await this.findKeyByName(t),s=this.components.datastore.batch();return s.delete(e),s.delete(pr(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(P(n.value)));return e}async renameKey(t,e){if(!dr(t)||t===this.self)throw await nt(),new L(`Invalid old key name '${t}'`);if(!dr(e)||e===this.self)throw await nt(),new L(`Invalid new key name '${e}'`);let n=Ue(t),s=Ue(e),o=pr(t),i=pr(e);if(await this.components.datastore.has(s))throw await nt(),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(P(f));l.name=e;let u=this.components.datastore.batch();return u.put(s,c),u.put(i,V(JSON.stringify(l))),u.delete(n),u.delete(o),await u.commit(),l}catch(c){throw await nt(),c}}async rotateKeychainPass(t,e){if(typeof t!="string")throw await nt(),new L(`Invalid old pass type '${typeof t}'`);if(typeof e!="string")throw await nt(),new L(`Invalid new pass type '${typeof e}'`);if(e.length<20)throw await nt(),new L(`Invalid pass length ${e.length}`);this.log("recreating keychain");let n=sn.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?Gr(e,this.init.dek.salt,this.init.dek?.iterationCount,this.init.dek?.keyLength,this.init.dek?.hash):"";sn.set(this,{dek:o});let i=await this.listKeys();for(let a of i){let c=await this.components.datastore.get(Ue(a.name)),f=P(c),l=await ai(f,s),u=o.toString(),h=await ii(l,u,l.type==="RSA"?"pkcs-8":"libp2p-key"),d=this.components.datastore.batch(),b={name:a.name,id:a.id};d.put(Ue(a.name),V(h)),d.put(pr(a.name),V(JSON.stringify(b))),await d.commit()}this.log("keychain reconstructed")}};function Xh(r={}){return t=>new Vs(t,r)}return Ll(Qh);})();
6
+ `)}`:`${e} :`}};hu=Ee;C.Constructed=hu;Ee.NAME="CONSTRUCTED";var ds=class extends ct{fromBER(t,e,n){return e}toBER(t){return Dt}};ds.override="EndOfContentValueBlock";var du,ps=class extends ot{constructor(t={}){super(t,ds),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};du=ps;C.EndOfContent=du;ps.NAME=hn;var pu,qe=class extends ot{constructor(t={}){super(t,ct),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}`}};pu=qe;C.Null=pu;qe.NAME="NULL";var gs=class extends ce(ct){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=F.BufferSourceConverter.toUint8Array(e.valueHex):this.valueHexView=new Uint8Array(1),t&&(this.value=t)}fromBER(t,e,n){let s=F.BufferSourceConverter.toUint8Array(t);return ae(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,yi.call(this),this.blockLength=n,e+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};gs.NAME="BooleanValueBlock";var gu,ys=class extends ot{getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}constructor(t={}){super(t,gs),this.idBlock.tagClass=1,this.idBlock.tagNumber=1}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.getValue}`}};gu=ys;C.Boolean=gu;ys.NAME="BOOLEAN";var ms=class extends ce(Vt){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=Vt.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===hn){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(i!==cu)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?Vt.prototype.toBER.call(this,t,e):t?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};ms.NAME="OctetStringValueBlock";var wi,se=class extends ot{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},ms),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=Gs(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 Ee.prototype.onAsciiEncoding.call(this);let t=this.constructor.NAME,e=F.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 wi&&t.push(e.valueBlock.valueHexView);return F.BufferSourceConverter.concat(t)}};wi=se;C.OctetString=wi;se.NAME=cu;var bs=class extends ce(Vt){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=Vt.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let a of this.value){let c=a.constructor.NAME;if(c===hn){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==uu)return this.error="BIT STRING may consists of BIT STRINGs only",-1;let l=a.valueBlock;if(this.unusedBits>0&&l.unusedBits>0)return this.error='Using of "unused bits" inside constructive BIT STRING allowed for least one only',-1;this.unusedBits=l.unusedBits}return s}let o=F.BufferSourceConverter.toUint8Array(t);if(!ae(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=Gs(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 Vt.prototype.toBER.call(this,t,e);if(t)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return Dt;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}}};bs.NAME="BitStringValueBlock";var yu,ws=class extends ot{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},bs),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 Ee.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}`}}};yu=ws;C.BitString=yu;ws.NAME=uu;var mu;function ld(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,l=0,h=c<i?i:c,u=0;for(let f=h;f>=0;f--,u++){switch(!0){case u<a.length:l=o[i-u]+a[c-u]+e[0];break;default:l=o[i-u]+e[0]}switch(e[0]=l/10,!0){case u>=o.length:o=is(new Uint8Array([l%10]),o);break;default:o[i-u]=l%10}}return e[0]>0&&(o=is(e,o)),o}function au(r){if(r>=un.length)for(let t=un.length;t<=r;t++){let e=new Uint8Array([0]),n=un[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=is(e,n)),un.push(n)}return un[r]}function fd(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,l,h=0;for(let u=c;u>=0;u--,h++)switch(l=o[i-h]-a[c-h]-e,!0){case l<0:e=1,o[i-h]=l+10;break;default:e=0,o[i-h]=l}if(e>0)for(let u=i-c+1;u>=0;u--,h++)if(l=o[i-h]-e,l<0)e=1,o[i-h]=l+10;else{e=0,o[i-h]=l;break}return o.slice()}var dn=class extends ce(ct){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=yi.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(su(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 l=0;l<8;l++){if((s&1)===1)switch(n){case t:e=fd(au(n),e),i="-";break;default:e=ld(e,au(n))}n++,s>>=1}}for(let c=0;c<e.length;c++)e[c]&&(a=!0),a&&(i+=iu.charAt(e[c]));return a===!1&&(i+=iu.charAt(0)),i}};mu=dn;dn.NAME="IntegerValueBlock";Object.defineProperty(mu.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var ln,oe=class extends ot{constructor(t={}){super(t,dn),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return as(),BigInt(this.valueBlock.toString())}static fromBigInt(t){as();let e=BigInt(t),n=new fn,s=e.toString(16).replace(/^-/,""),o=new Uint8Array(F.Convert.FromHex(s));if(e<0){let a=new Uint8Array(o.length+(o[0]&128?1:0));a[0]|=128;let l=BigInt(`0x${F.Convert.ToHex(a)}`)+e,h=F.BufferSourceConverter.toUint8Array(F.Convert.FromHex(l.toString(16)));h[0]|=128,n.write(h)}else o[0]&128&&n.write(new Uint8Array([0])),n.write(o);return new ln({valueHex:n.final()})}convertToDER(){let t=new ln({valueHex:this.valueBlock.valueHexView});return t.valueBlock.toDER(),t}convertFromDER(){return new ln({valueHex:this.valueBlock.valueHexView[0]===0?this.valueBlock.valueHexView.subarray(1):this.valueBlock.valueHexView})}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()}`}};ln=oe;C.Integer=ln;oe.NAME="INTEGER";var bu,xs=class extends oe{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};bu=xs;C.Enumerated=bu;xs.NAME="ENUMERATED";var pn=class extends ce(ct){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=F.BufferSourceConverter.toUint8Array(t);if(!ae(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=Fe(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}set valueBigInt(t){as();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=ve(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Dt;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=F.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}}};pn.NAME="sidBlock";var vs=class extends ct{constructor({value:t=Sr,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new pn;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,Dt;e.push(s)}return mi(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 pn;if(s>Number.MAX_SAFE_INTEGER){as();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}};vs.NAME="ObjectIdentifierValueBlock";var wu,Pt=class extends ot{getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}constructor(t={}){super(t,vs),this.idBlock.tagClass=1,this.idBlock.tagNumber=6}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};wu=Pt;C.ObjectIdentifier=wu;Pt.NAME="OBJECT IDENTIFIER";var gn=class extends ce(ne){constructor({valueDec:t=0,...e}={}){super(e),this.valueDec=t}fromBER(t,e,n){if(n===0)return e;let s=F.BufferSourceConverter.toUint8Array(t);if(!ae(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=Fe(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=ve(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Dt;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=F.Convert.ToHex(this.valueHexView):t=this.valueDec.toString(),t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};gn.NAME="relativeSidBlock";var Es=class extends ct{constructor({value:t=Sr,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new gn;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,Dt;n.push(o)}return mi(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 gn;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}};Es.NAME="RelativeObjectIdentifierValueBlock";var xu,Bs=class extends ot{getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}constructor(t={}){super(t,Es),this.idBlock.tagClass=1,this.idBlock.tagNumber=13}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};xu=Bs;C.RelativeObjectIdentifier=xu;Bs.NAME="RelativeObjectIdentifier";var vu,xt=class extends Ee{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};vu=xt;C.Sequence=vu;xt.NAME="SEQUENCE";var Eu,As=class extends Ee{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};Eu=As;C.Set=Eu;As.NAME="SET";var Ss=class extends ce(ct){constructor({...t}={}){super(t),this.isHexOnly=!0,this.value=Sr}toJSON(){return{...super.toJSON(),value:this.value}}};Ss.NAME="StringValueBlock";var ks=class extends Ss{};ks.NAME="SimpleStringValueBlock";var pt=class extends ls{constructor({...t}={}){super(t,ks)}fromBuffer(t){this.valueBlock.value=String.fromCharCode.apply(null,F.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}};pt.NAME="SIMPLE STRING";var Is=class extends pt{fromBuffer(t){this.valueBlock.valueHexView=F.BufferSourceConverter.toUint8Array(t);try{this.valueBlock.value=F.Convert.ToUtf8String(t)}catch(e){this.warnings.push(`Error during "decodeURIComponent": ${e}, using raw string`),this.valueBlock.value=F.Convert.ToBinary(t)}}fromString(t){this.valueBlock.valueHexView=new Uint8Array(F.Convert.FromUtf8String(t)),this.valueBlock.value=t}};Is.NAME="Utf8StringValueBlock";var Bu,ie=class extends Is{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};Bu=ie;C.Utf8String=Bu;ie.NAME="UTF8String";var Cs=class extends pt{fromBuffer(t){this.valueBlock.value=F.Convert.ToUtf16String(t),this.valueBlock.valueHexView=F.BufferSourceConverter.toUint8Array(t)}fromString(t){this.valueBlock.value=t,this.valueBlock.valueHexView=new Uint8Array(F.Convert.FromUtf16String(t))}};Cs.NAME="BmpStringValueBlock";var Au,Ns=class extends Cs{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};Au=Ns;C.BmpString=Au;Ns.NAME="BMPString";var Ts=class extends pt{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=ve(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}};Ts.NAME="UniversalStringValueBlock";var Su,_s=class extends Ts{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};Su=_s;C.UniversalString=Su;_s.NAME="UniversalString";var ku,Us=class extends pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};ku=Us;C.NumericString=ku;Us.NAME="NumericString";var Iu,Ls=class extends pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};Iu=Ls;C.PrintableString=Iu;Ls.NAME="PrintableString";var Cu,Rs=class extends pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};Cu=Rs;C.TeletexString=Cu;Rs.NAME="TeletexString";var Nu,Ds=class extends pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};Nu=Ds;C.VideotexString=Nu;Ds.NAME="VideotexString";var Tu,Hs=class extends pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};Tu=Hs;C.IA5String=Tu;Hs.NAME="IA5String";var _u,Ks=class extends pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};_u=Ks;C.GraphicString=_u;Ks.NAME="GraphicString";var Uu,yn=class extends pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};Uu=yn;C.VisibleString=Uu;yn.NAME="VisibleString";var Lu,Os=class extends pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};Lu=Os;C.GeneralString=Lu;Os.NAME="GeneralString";var Ru,Vs=class extends pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};Ru=Vs;C.CharacterString=Ru;Vs.NAME="CharacterString";var Du,mn=class extends yn{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,F.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]=wt(this.year<2e3?this.year-1900:this.year-2e3,2),e[1]=wt(this.month,2),e[2]=wt(this.day,2),e[3]=wt(this.hour,2),e[4]=wt(this.minute,2),e[5]=wt(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}}};Du=mn;C.UTCTime=Du;mn.NAME="UTCTime";var Hu,Ps=class extends mn{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,f=n.indexOf("+"),d="";if(f===-1&&(f=n.indexOf("-"),u=-1),f!==-1){if(d=n.substring(f+1),n=n.substring(0,f),d.length!==2&&d.length!==4)throw new Error("Wrong input string for conversion");let p=parseInt(d.substring(0,2),10);if(isNaN(p.valueOf()))throw new Error("Wrong input string for conversion");if(a=u*p,d.length===4){if(p=parseInt(d.substring(2,4),10),isNaN(p.valueOf()))throw new Error("Wrong input string for conversion");c=u*p}}}let l=n.indexOf(".");if(l===-1&&(l=n.indexOf(",")),l!==-1){let u=new Number(`0${n.substring(l)}`);if(isNaN(u.valueOf()))throw new Error("Wrong input string for conversion");o=u.valueOf(),s=n.substring(0,l)}else s=n;switch(!0){case s.length===8:if(i=/(\d{4})(\d{2})(\d{2})/ig,l!==-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,l!==-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,l!==-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,l!==-1){let u=1e3*o;this.millisecond=Math.floor(u)}break;default:throw new Error("Wrong input string for conversion")}let h=i.exec(s);if(h===null)throw new Error("Wrong input string for conversion");for(let u=1;u<h.length;u++)switch(u){case 1:this.year=parseInt(h[u],10);break;case 2:this.month=parseInt(h[u],10);break;case 3:this.day=parseInt(h[u],10);break;case 4:this.hour=parseInt(h[u],10)+a;break;case 5:this.minute=parseInt(h[u],10)+c;break;case 6:this.second=parseInt(h[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(wt(this.year,4)),e.push(wt(this.month,2)),e.push(wt(this.day,2)),e.push(wt(this.hour,2)),e.push(wt(this.minute,2)),e.push(wt(this.second,2)),this.millisecond!==0&&(e.push("."),e.push(wt(this.millisecond,3))),e.push("Z"),e.join("")}return super.toString(t)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};Hu=Ps;C.GeneralizedTime=Hu;Ps.NAME="GeneralizedTime";var Ku,Ms=class extends ie{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};Ku=Ms;C.DATE=Ku;Ms.NAME="DATE";var Ou,Fs=class extends ie{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};Ou=Fs;C.TimeOfDay=Ou;Fs.NAME="TimeOfDay";var Vu,qs=class extends ie{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};Vu=qs;C.DateTime=Vu;qs.NAME="DateTime";var Pu,js=class extends ie{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};Pu=js;C.Duration=Pu;js.NAME="Duration";var Mu,$s=class extends ie{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};Mu=$s;C.TIME=Mu;$s.NAME="TIME";async function Ys(r,t){let n=await Br.create().encrypt(r,t);return ke.encode(n)}async function xi(r,t,e){if(r.type==="RSA")return gd(r,t,e);if(r.type==="Ed25519")return hd(r,t,e);if(r.type==="secp256k1")return dd(r,t,e);if(r.type==="ECDSA")return pd(r,t,e);throw new Ze}async function hd(r,t,e="libp2p-key"){if(e==="libp2p-key")return Ys(Me(r),t);throw new U(`export format '${e}' is not supported`)}async function dd(r,t,e="libp2p-key"){if(e==="libp2p-key")return Ys(Me(r),t);throw new U("Export format is not supported")}async function pd(r,t,e="libp2p-key"){if(e==="libp2p-key")return Ys(Me(r),t);throw new U(`export format '${e}' is not supported`)}async function gd(r,t,e="pkcs-8"){if(e==="pkcs-8")return yd(r,t);if(e==="libp2p-key")return Ys(Me(r),t);throw new U("Export format is not supported")}async function yd(r,t){let e=X.get(),s=new xt({value:[new oe({value:0}),new xt({value:[new Pt({value:"1.2.840.113549.1.1.1"}),new qe]}),new se({valueHex:r.raw})]}).toBER(),o=new Uint8Array(s,0,s.byteLength),i=Pe(16),a=await Qn(wr,t,i,{c:1e4,dkLen:32}),c=Pe(16),l=await e.subtle.importKey("raw",a,"AES-CBC",!1,["encrypt"]),h=await e.subtle.encrypt({name:"AES-CBC",iv:c},l,o),u=new xt({value:[new se({valueHex:i}),new oe({value:1e4}),new oe({value:32}),new xt({value:[new Pt({value:"1.2.840.113549.2.11"}),new qe]})]}),f=new xt({value:[new Pt({value:"1.2.840.113549.1.5.13"}),new xt({value:[new xt({value:[new Pt({value:"1.2.840.113549.1.5.12"}),u]}),new xt({value:[new Pt({value:"2.16.840.1.101.3.4.1.42"}),new se({valueHex:c})]})]})]}),p=new xt({value:[f,new se({valueHex:h})]}).toBER(),y=new Uint8Array(p,0,p.byteLength);return["-----BEGIN ENCRYPTED PRIVATE KEY-----",...q(y,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
7
+ `)}async function vi(r,t){try{let e=await md(r,t);return Dc(e)}catch{}if(!r.includes("BEGIN"))throw new U("Encrypted key was not a libp2p-key or a PEM file");return bd(r,t)}async function md(r,t){let e=ke.decode(r);return Br.create().decrypt(e,t)}async function bd(r,t){let e=X.get(),n;if(r.includes("-----BEGIN ENCRYPTED PRIVATE KEY-----")){let o=M(r.replace("-----BEGIN ENCRYPTED PRIVATE KEY-----","").replace("-----END ENCRYPTED PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:i}=Zs(o),{iv:a,salt:c,iterations:l,keySize:h,cipherText:u}=wd(i),f=await Qn(wr,t,c,{c:l,dkLen:h}),d=await e.subtle.importKey("raw",f,"AES-CBC",!1,["decrypt"]),p=bn(await e.subtle.decrypt({name:"AES-CBC",iv:a},d,u)),{result:y}=Zs(p);n=$u(y)}else if(r.includes("-----BEGIN PRIVATE KEY-----")){let o=M(r.replace("-----BEGIN PRIVATE KEY-----","").replace("-----END PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:i}=Zs(o);n=$u(i)}else throw new U("Could not parse private key from PEM data");let s=Hc(n);if(s.type!=="RSA")throw new U("Could not parse RSA private key from PEM data");return s}function wd(r){let t=r.valueBlock.value[0];if(t.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.13")throw new U("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 U("Only pkcs5PBKDF2 key derivation functions are supported");let o=n.valueBlock.value[1],i=bn(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 U("Could not derive key size and iterations from PEM file - please use @libp2p/rsa to re-import your key");let l=t.valueBlock.value[1].valueBlock.value[1],h=l.valueBlock.value[0].toString();if(h!=="OBJECT IDENTIFIER : 1.2.840.113549.3.7"){if(h!=="OBJECT IDENTIFIER : 1.3.14.3.2.7"){if(h!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.2"){if(h!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.22"){if(h!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.42")throw new U("Only AES-CBC encryption schemes are supported")}}}}let u=bn(l.valueBlock.value[1].getValue());return{cipherText:bn(r.valueBlock.value[1].getValue()),salt:i,iterations:a,keySize:c,iv:u}}function $u(r){return bn(r.valueBlock.value[2].getValue())}function bn(r){return new Uint8Array(r,0,r.byteLength)}var xd="/pkcs8/",Bi="/info/",wn=new WeakMap,je={minKeyLength:112/8,minSaltLength:128/8,minIterationCount:1e3},Ei={dek:{keyLength:512/8,iterationCount:1e4,salt:"you should override this value with a crypto secure random number",hash:"sha2-512"}};function kr(r){return r==null||typeof r!="string"?!1:r===(0,Gu.default)(r.trim())&&r.length>0}async function it(){let e=Math.random()*800+200;await new Promise(n=>setTimeout(n,e))}function $e(r){return new cn(xd+r)}function Ir(r){return new cn(Bi+r)}async function vd(r){let t=Me(r),e=await tr.digest(t);return Q.encode(e.bytes).substring(1)}var zs=class{components;init;log;self;constructor(t,e){if(this.components=t,this.log=t.logger.forComponent("libp2p:keychain"),this.init=Gc(Ei,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<je.minKeyLength)throw new Error(`dek.keyLength must be least ${je.minKeyLength} bytes`);if(this.init.dek?.salt?.length!=null&&this.init.dek.salt.length<je.minSaltLength)throw new Error(`dek.saltLength must be least ${je.minSaltLength} bytes`);if(this.init.dek?.iterationCount!=null&&this.init.dek.iterationCount<je.minIterationCount)throw new Error(`dek.iterationCount must be least ${je.minIterationCount}`);let n=this.init.pass!=null&&this.init.dek?.salt!=null?an(this.init.pass,this.init.dek?.salt,this.init.dek?.iterationCount,this.init.dek?.keyLength,this.init.dek?.hash):"";wn.set(this,{dek:n})}[Symbol.toStringTag]="@libp2p/keychain";[Ni]=["@libp2p/keychain"];static generateOptions(){let t=Object.assign({},Ei),e=Math.ceil(je.minSaltLength/3)*3;return t.dek.salt=q(Pe(e),"base64"),t}static get options(){return Ei}async findKeyByName(t){if(!kr(t))throw await it(),new U(`Invalid key name '${t}'`);let e=Ir(t);try{let n=await this.components.datastore.get(e);return JSON.parse(q(n))}catch(n){throw await it(),this.log.error(n),new En(`Key '${t}' does not exist.`)}}async findKeyById(t){try{let e={prefix:Bi};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 U(`Key with id '${t}' does not exist.`)}catch(e){throw await it(),e}}async importKey(t,e){if(!kr(t))throw await it(),new U(`Invalid key name '${t}'`);if(e==null)throw await it(),new U("Key is required");let n=$e(t);if(await this.components.datastore.has(n))throw await it(),new U(`Key '${t}' already exists`);let o,i;try{o=await vd(e);let l=wn.get(this);if(l==null)throw new U("dek missing");let h=l.dek;i=await xi(e,h,e.type==="RSA"?"pkcs-8":"libp2p-key")}catch(l){throw await it(),l}let a={name:t,id:o},c=this.components.datastore.batch();return c.put(n,M(i)),c.put(Ir(t),M(JSON.stringify(a))),await c.commit(),a}async exportKey(t){if(!kr(t))throw await it(),new U(`Invalid key name '${t}'`);let e=$e(t);try{let n=await this.components.datastore.get(e),s=q(n),o=wn.get(this);if(o==null)throw new U("dek missing");let i=o.dek;return await vi(s,i)}catch(n){throw await it(),n}}async removeKey(t){if(!kr(t)||t===this.self)throw await it(),new U(`Invalid key name '${t}'`);let e=$e(t),n=await this.findKeyByName(t),s=this.components.datastore.batch();return s.delete(e),s.delete(Ir(t)),await s.commit(),n}async listKeys(){let t={prefix:Bi},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(!kr(t)||t===this.self)throw await it(),new U(`Invalid old key name '${t}'`);if(!kr(e)||e===this.self)throw await it(),new U(`Invalid new key name '${e}'`);let n=$e(t),s=$e(e),o=Ir(t),i=Ir(e);if(await this.components.datastore.has(s))throw await it(),new U(`Key '${e}' already exists`);try{let c=await this.components.datastore.get(n),l=await this.components.datastore.get(o),h=JSON.parse(q(l));h.name=e;let u=this.components.datastore.batch();return u.put(s,c),u.put(i,M(JSON.stringify(h))),u.delete(n),u.delete(o),await u.commit(),h}catch(c){throw await it(),c}}async rotateKeychainPass(t,e){if(typeof t!="string")throw await it(),new U(`Invalid old pass type '${typeof t}'`);if(typeof e!="string")throw await it(),new U(`Invalid new pass type '${typeof e}'`);if(e.length<20)throw await it(),new U(`Invalid pass length ${e.length}`);this.log("recreating keychain");let n=wn.get(this);if(n==null)throw new U("dek missing");let s=n.dek;this.init.pass=e;let o=e!=null&&this.init.dek?.salt!=null?an(e,this.init.dek.salt,this.init.dek?.iterationCount,this.init.dek?.keyLength,this.init.dek?.hash):"";wn.set(this,{dek:o});let i=await this.listKeys();for(let a of i){let c=await this.components.datastore.get($e(a.name)),l=q(c),h=await vi(l,s),u=o.toString(),f=await xi(h,u,h.type==="RSA"?"pkcs-8":"libp2p-key"),d=this.components.datastore.batch(),p={name:a.name,id:a.id};d.put($e(a.name),M(f)),d.put(Ir(a.name),M(JSON.stringify(p))),await d.commit()}this.log("keychain reconstructed")}};function Ed(r={}){return t=>new zs(t,r)}return Xu(Bd);})();
8
8
  /*! Bundled license information:
9
9
 
10
10
  pvtsutils/build/index.js: