@libp2p/keychain 5.1.4-d53ef170c → 5.1.4-da4e9da82

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 Ul=Object.create;var nn=Object.defineProperty;var Ll=Object.getOwnPropertyDescriptor;var Rl=Object.getOwnPropertyNames;var _l=Object.getPrototypeOf,Dl=Object.prototype.hasOwnProperty;var Ie=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),ut=(r,t)=>{for(var e in t)nn(r,e,{get:t[e],enumerable:!0})},wi=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of Rl(t))!Dl.call(r,s)&&s!==e&&nn(r,s,{get:()=>t[s],enumerable:!(n=Ll(t,s))||n.enumerable});return r};var _s=(r,t,e)=>(e=r!=null?Ul(_l(r)):{},wi(t||!r||!r.__esModule?nn(e,"default",{value:r,enumerable:!0}):e,r)),Kl=r=>wi(nn({},"__esModule",{value:!0}),r);var dc=Ie((Pm,hc)=>{"use strict";hc.exports=r=>{if(Object.prototype.toString.call(r)!=="[object Object]")return!1;let t=Object.getPrototypeOf(r);return t===null||t===Object.prototype}});var bc=Ie((mc,wc)=>{"use strict";var Vn=dc(),{hasOwnProperty:gc}=Object.prototype,{propertyIsEnumerable:Kh}=Object,gr=(r,t,e)=>Object.defineProperty(r,t,{value:e,writable:!0,enumerable:!0,configurable:!0}),Oh=mc,pc={concatArrays:!1,ignoreUndefined:!1},Hn=r=>{let t=[];for(let e in r)gc.call(r,e)&&t.push(e);if(Object.getOwnPropertySymbols){let e=Object.getOwnPropertySymbols(r);for(let n of e)Kh.call(r,n)&&t.push(n)}return t};function yr(r){return Array.isArray(r)?Vh(r):Vn(r)?Hh(r):r}function Vh(r){let t=r.slice(0,0);return Hn(r).forEach(e=>{gr(t,e,yr(r[e]))}),t}function Hh(r){let t=Object.getPrototypeOf(r)===null?Object.create(null):{};return Hn(r).forEach(e=>{gr(t,e,yr(r[e]))}),t}var yc=(r,t,e,n)=>(e.forEach(s=>{typeof t[s]>"u"&&n.ignoreUndefined||(s in r&&r[s]!==Object.getPrototypeOf(r)?gr(r,s,ri(r[s],t[s],n)):gr(r,s,yr(t[s])))}),r),Ph=(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++)gc.call(o,a)&&(i.push(String(a)),o===r?gr(n,s++,o[a]):gr(n,s++,yr(o[a])));n=yc(n,o,Hn(o).filter(a=>!i.includes(a)),e)}),n};function ri(r,t,e){return e.concatArrays&&Array.isArray(r)&&Array.isArray(t)?Ph(r,t,e):!Vn(t)||!Vn(r)?yr(t):yc(r,t,Hn(t),e)}wc.exports=function(...r){let t=ri(yr(pc),this!==Oh&&this||{},pc),e={_:{}};for(let n of r)if(n!==void 0){if(!Vn(n))throw new TypeError("`"+n+"` is not an Option Object");e=ri(e,{_:n},t)}return e._}});var Bc=Ie((Fm,Ec)=>{"use strict";function Mh(r){return r>=55296&&r<=56319}function Fh(r){return r>=56320&&r<=57343}Ec.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 Sc=Ie((qm,Ac)=>{"use strict";function qh(r){return r>=55296&&r<=56319}function jh(r){return r>=56320&&r<=57343}Ac.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 Ic=Ie((jm,kc)=>{"use strict";var $h=Bc(),Gh=Sc();kc.exports=$h.bind(null,Gh)});var Tc=Ie(($m,Nc)=>{"use strict";var zh=Ic(),Wh=/[\/\?<>\\:\*\|"]/g,Zh=/[\x00-\x1f\x80-\x9f]/g,Jh=/^\.+$/,Yh=/^(con|prn|aux|nul|com[0-9]|lpt[0-9])(\..*)?$/i,Xh=/[\. ]+$/;function Cc(r,t){if(typeof r!="string")throw new Error("Input must be string");var e=r.replace(Wh,t).replace(Zh,t).replace(Jh,t).replace(Yh,t).replace(Xh,t);return zh(e,255)}Nc.exports=function(r,t){var e=t&&t.replacement||"",n=Cc(r,e);return e===""?n:Cc(n,"")}});var Uc=Ie(wr=>{"use strict";var td="[object ArrayBuffer]",te=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}},ni="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-_]+$/,Mn=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=te.toUint8Array(t),n="";for(let o=0;o<e.length;o++)n+=String.fromCharCode(e[o]);return decodeURIComponent(escape(n))}},Ct=class{static toString(t,e=!1){let n=te.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}},Fn=class r{static isHex(t){return typeof t===ni&&ed.test(t)}static isBase64(t){return typeof t===ni&&rd.test(t)}static isBase64Url(t){return typeof t===ni&&nd.test(t)}static ToString(t,e="utf8"){let n=te.toUint8Array(t);switch(e.toLowerCase()){case"utf8":return this.ToUtf8String(n);case"binary":return this.ToBinary(n);case"hex":return this.ToHex(n);case"base64":return this.ToBase64(n);case"base64url":return this.ToBase64Url(n);case"utf16le":return Ct.toString(n,!0);case"utf16":case"utf16be":return Ct.toString(n);default:throw new Error(`Unknown type of encoding '${e}'`)}}static FromString(t,e="utf8"){if(!t)return new ArrayBuffer(0);switch(e.toLowerCase()){case"utf8":return this.FromUtf8String(t);case"binary":return this.FromBinary(t);case"hex":return this.FromHex(t);case"base64":return this.FromBase64(t);case"base64url":return this.FromBase64Url(t);case"utf16le":return Ct.fromString(t,!0);case"utf16":case"utf16be":return Ct.fromString(t);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToBase64(t){let e=te.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 Mn.fromString(t);case"utf16":case"utf16be":return Ct.fromString(t);case"utf16le":case"usc2":return Ct.fromString(t,!0);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToUtf8String(t,e=r.DEFAULT_UTF8_ENCODING){switch(e){case"ascii":return this.ToBinary(t);case"utf8":return Mn.toString(t);case"utf16":case"utf16be":return Ct.toString(t);case"utf16le":case"usc2":return Ct.toString(t,!0);default:throw new Error(`Unknown type of encoding '${e}'`)}}static FromBinary(t){let e=t.length,n=new Uint8Array(e);for(let s=0;s<e;s++)n[s]=t.charCodeAt(s);return n.buffer}static ToBinary(t){let e=te.toUint8Array(t),n="";for(let s=0;s<e.length;s++)n+=String.fromCharCode(e[s]);return n}static ToHex(t){let e=te.toUint8Array(t),n="",s=e.length;for(let o=0;o<s;o++){let i=e[o];i<16&&(n+="0"),n+=i.toString(16)}return n}static FromHex(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isHex(e))throw new TypeError("Argument 'hexString' is not HEX encoded");e.length%2&&(e=`0${e}`);let n=new Uint8Array(e.length/2);for(let s=0;s<e.length;s=s+2){let o=e.slice(s,s+2);n[s/2]=parseInt(o,16)}return n.buffer}static ToUtf16String(t,e=!1){return Ct.toString(t,e)}static FromUtf16String(t,e=!1){return Ct.fromString(t,e)}static Base64Padding(t){let e=4-t.length%4;if(e<4)for(let n=0;n<e;n++)t+="=";return t}static formatString(t){return t?.replace(/[\n\r\t ]/g,"")||""}};Fn.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}wr.BufferSourceConverter=te;wr.Convert=Fn;wr.assign=sd;wr.combine=od;wr.isEqual=id});var vd={};ut(vd,{keychain:()=>xd});var vr=class extends Error{constructor(t="An error occurred while signing a message"){super(t),this.name="SigningError"}},Er=class extends Error{constructor(t="An error occurred while verifying a message"){super(t),this.name="VerificationError"}},sn=class extends Error{constructor(t="Missing Web Crypto API"){super(t),this.name="WebCryptoMissingError"}};var bi={get(r=globalThis){let t=r.crypto;if(t?.subtle==null)throw new sn("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 bt=bi;var N=class extends Error{static name="InvalidParametersError";constructor(t="Invalid parameters"){super(t),this.name="InvalidParametersError"}},We=class extends Error{static name="InvalidPublicKeyError";constructor(t="Invalid public key"){super(t),this.name="InvalidPublicKeyError"}},Br=class extends Error{static name="InvalidPrivateKeyError";constructor(t="Invalid private key"){super(t),this.name="InvalidPrivateKeyError"}};var on=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 xi=Symbol.for("@libp2p/service-capabilities"),Nd=Symbol.for("@libp2p/service-dependencies");var Hs={};ut(Hs,{base58btc:()=>Q,base58flickr:()=>Fl});var Xd=new Uint8Array(0);function vi(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function $t(r){if(r instanceof Uint8Array&&r.constructor.name==="Uint8Array")return r;if(r instanceof ArrayBuffer)return new Uint8Array(r);if(ArrayBuffer.isView(r))return new Uint8Array(r.buffer,r.byteOffset,r.byteLength);throw new Error("Unknown type, must be binary type")}function Ei(r){return new TextEncoder().encode(r)}function Bi(r){return new TextDecoder().decode(r)}function Ol(r,t){if(r.length>=255)throw new TypeError("Alphabet too long");for(var e=new Uint8Array(256),n=0;n<e.length;n++)e[n]=255;for(var s=0;s<r.length;s++){var o=r.charAt(s),i=o.charCodeAt(0);if(e[i]!==255)throw new TypeError(o+" is ambiguous");e[i]=s}var a=r.length,c=r.charAt(0),f=Math.log(a)/Math.log(256),l=Math.log(256)/Math.log(a);function u(w){if(w instanceof Uint8Array||(ArrayBuffer.isView(w)?w=new Uint8Array(w.buffer,w.byteOffset,w.byteLength):Array.isArray(w)&&(w=Uint8Array.from(w))),!(w instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(w.length===0)return"";for(var y=0,d=0,b=0,E=w.length;b!==E&&w[b]===0;)b++,y++;for(var p=(E-b)*l+1>>>0,S=new Uint8Array(p);b!==E;){for(var R=w[b],L=0,I=p-1;(R!==0||L<d)&&I!==-1;I--,L++)R+=256*S[I]>>>0,S[I]=R%a>>>0,R=R/a>>>0;if(R!==0)throw new Error("Non-zero carry");d=L,b++}for(var U=p-d;U!==p&&S[U]===0;)U++;for(var C=c.repeat(y);U<p;++U)C+=r.charAt(S[U]);return C}function h(w){if(typeof w!="string")throw new TypeError("Expected String");if(w.length===0)return new Uint8Array;var y=0;if(w[y]!==" "){for(var d=0,b=0;w[y]===c;)d++,y++;for(var E=(w.length-y)*f+1>>>0,p=new Uint8Array(E);w[y];){var S=e[w.charCodeAt(y)];if(S===255)return;for(var R=0,L=E-1;(S!==0||R<b)&&L!==-1;L--,R++)S+=a*p[L]>>>0,p[L]=S%256>>>0,S=S/256>>>0;if(S!==0)throw new Error("Non-zero carry");b=R,y++}if(w[y]!==" "){for(var I=E-b;I!==E&&p[I]===0;)I++;for(var U=new Uint8Array(d+(E-I)),C=d;I!==E;)U[C++]=p[I++];return U}}}function m(w){var y=h(w);if(y)return y;throw new Error(`Non-${t} character`)}return{encode:u,decodeUnsafe:h,decode:m}}var Vl=Ol,Hl=Vl,Si=Hl;var Ds=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")}},Ks=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 ki(this,t)}},Os=class{decoders;constructor(t){this.decoders=t}or(t){return ki(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 ki(r,t){return new Os({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var Vs=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 Ds(t,e,n),this.decoder=new Ks(t,e,s)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function Je({name:r,prefix:t,encode:e,decode:n}){return new Vs(r,t,e,n)}function ce({name:r,prefix:t,alphabet:e}){let{encode:n,decode:s}=Si(e,r);return Je({prefix:t,name:r,encode:n,decode:o=>$t(s(o))})}function Pl(r,t,e,n){let s={};for(let l=0;l<t.length;++l)s[t[l]]=l;let o=r.length;for(;r[o-1]==="=";)--o;let i=new Uint8Array(o*e/8|0),a=0,c=0,f=0;for(let l=0;l<o;++l){let u=s[r[l]];if(u===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<e|u,a+=e,a>=8&&(a-=8,i[f++]=255&c>>a)}if(a>=e||(255&c<<8-a)!==0)throw new SyntaxError("Unexpected end of data");return i}function Ml(r,t,e){let n=t[t.length-1]==="=",s=(1<<e)-1,o="",i=0,a=0;for(let c=0;c<r.length;++c)for(a=a<<8|r[c],i+=8;i>e;)i-=e,o+=t[s&a>>i];if(i!==0&&(o+=t[s&a<<e-i]),n)for(;(o.length*e&7)!==0;)o+="=";return o}function X({name:r,prefix:t,bitsPerChar:e,alphabet:n}){return Je({prefix:t,name:r,encode(s){return Ml(s,n,e)},decode(s){return Pl(s,n,e,r)}})}var Q=ce({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),Fl=ce({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Ps={};ut(Ps,{base32:()=>Ye,base32hex:()=>Gl,base32hexpad:()=>Wl,base32hexpadupper:()=>Zl,base32hexupper:()=>zl,base32pad:()=>jl,base32padupper:()=>$l,base32upper:()=>ql,base32z:()=>Jl});var Ye=X({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),ql=X({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),jl=X({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),$l=X({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),Gl=X({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),zl=X({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),Wl=X({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),Zl=X({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),Jl=X({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Ms={};ut(Ms,{base36:()=>Ar,base36upper:()=>Yl});var Ar=ce({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),Yl=ce({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Xl=Ni,Ii=128,Ql=127,tu=~Ql,eu=Math.pow(2,31);function Ni(r,t,e){t=t||[],e=e||0;for(var n=e;r>=eu;)t[e++]=r&255|Ii,r/=128;for(;r&tu;)t[e++]=r&255|Ii,r>>>=7;return t[e]=r|0,Ni.bytes=e-n+1,t}var ru=Fs,nu=128,Ci=127;function Fs(r,n){var e=0,n=n||0,s=0,o=n,i,a=r.length;do{if(o>=a)throw Fs.bytes=0,new RangeError("Could not decode varint");i=r[o++],e+=s<28?(i&Ci)<<s:(i&Ci)*Math.pow(2,s),s+=7}while(i>=nu);return Fs.bytes=o-n,e}var su=Math.pow(2,7),ou=Math.pow(2,14),iu=Math.pow(2,21),au=Math.pow(2,28),cu=Math.pow(2,35),lu=Math.pow(2,42),uu=Math.pow(2,49),fu=Math.pow(2,56),hu=Math.pow(2,63),du=function(r){return r<su?1:r<ou?2:r<iu?3:r<au?4:r<cu?5:r<lu?6:r<uu?7:r<fu?8:r<hu?9:10},pu={encode:Xl,decode:ru,encodingLength:du},gu=pu,Sr=gu;function kr(r,t=0){return[Sr.decode(r,t),Sr.decode.bytes]}function Xe(r,t,e=0){return Sr.encode(r,t,e),t}function Qe(r){return Sr.encodingLength(r)}function Tt(r,t){let e=t.byteLength,n=Qe(r),s=n+Qe(e),o=new Uint8Array(s+e);return Xe(r,o,0),Xe(e,o,n),o.set(t,s),new tr(r,e,t,o)}function Ti(r){let t=$t(r),[e,n]=kr(t),[s,o]=kr(t.subarray(n)),i=t.subarray(n+o);if(i.byteLength!==s)throw new Error("Incorrect length");return new tr(e,s,i,t)}function Ui(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&vi(r.bytes,e.bytes)}}var tr=class{code;size;digest;bytes;constructor(t,e,n,s){this.code=t,this.size=e,this.digest=n,this.bytes=s}};function Li(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return mu(e,qs(r),t??Q.encoder);default:return wu(e,qs(r),t??Ye.encoder)}}var Ri=new WeakMap;function qs(r){let t=Ri.get(r);if(t==null){let e=new Map;return Ri.set(r,e),e}return t}var It=class r{code;version;multihash;bytes;"/";constructor(t,e,n,s){this.code=e,this.version=t,this.multihash=n,this.bytes=s,this["/"]=s}get asCID(){return this}get byteOffset(){return this.bytes.byteOffset}get byteLength(){return this.bytes.byteLength}toV0(){switch(this.version){case 0:return this;case 1:{let{code:t,multihash:e}=this;if(t!==Cr)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==bu)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&&Ui(t.multihash,n.multihash)}toString(t){return Li(this,t)}toJSON(){return{"/":Li(this)}}link(){return this}[Symbol.toStringTag]="CID";[Symbol.for("nodejs.util.inspect.custom")](){return`CID(${this.toString()})`}static asCID(t){if(t==null)return null;let e=t;if(e instanceof r)return e;if(e["/"]!=null&&e["/"]===e.bytes||e.asCID===e){let{version:n,code:s,multihash:o,bytes:i}=e;return new r(n,s,o,i??_i(n,s,o.bytes))}else if(e[xu]===!0){let{version:n,multihash:s,code:o}=e,i=Ti(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!==Cr)throw new Error(`Version 0 CID must use dag-pb (code: ${Cr}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let s=_i(t,e,n.bytes);return new r(t,e,n,s)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,Cr,t)}static createV1(t,e){return r.create(1,t,e)}static decode(t){let[e,n]=r.decodeFirst(t);if(n.length!==0)throw new Error("Incorrect length");return e}static decodeFirst(t){let e=r.inspectBytes(t),n=e.size-e.multihashSize,s=$t(t.subarray(n,n+e.multihashSize));if(s.byteLength!==e.multihashSize)throw new Error("Incorrect length");let o=s.subarray(e.multihashSize-e.digestSize),i=new tr(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]=kr(t.subarray(e));return e+=h,u},s=n(),o=Cr;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]=yu(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 qs(o).set(n,t),o}};function yu(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 Ye.prefix:{let e=t??Ye;return[Ye.prefix,e.decode(r)]}case Ar.prefix:{let e=t??Ar;return[Ar.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 mu(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 wu(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 Cr=112,bu=18;function _i(r,t,e){let n=Qe(r),s=n+Qe(t),o=new Uint8Array(s+e.byteLength);return Xe(r,o,0),Xe(t,o,n),o.set(e,s),o}var xu=Symbol.for("@ipld/js-cid/CID");var js={};ut(js,{identity:()=>Ce});var Di=0,vu="identity",Ki=$t;function Eu(r){return Tt(Di,Ki(r))}var Ce={code:Di,name:vu,encode:Ki,digest:Eu};function xt(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function Gt(r=0){return new Uint8Array(r)}function St(r=0){return new Uint8Array(r)}function er(r,t){t==null&&(t=r.reduce((s,o)=>s+o.length,0));let e=St(t),n=0;for(let s of r)e.set(s,n),n+=s.length;return e}var Vi=Symbol.for("@achingbrain/uint8arraylist");function Oi(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 cn(r){return!!r?.[Vi]}var pt=class r{bufs;length;[Vi]=!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(cn(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(cn(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=Oi(this.bufs,t);return e.buf[e.index]}set(t,e){let n=Oi(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(cn(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 er(n,s)}subarray(t,e){let{bufs:n,length:s}=this._subList(t,e);return n.length===1?n[0]:er(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(!cn(t)&&!(t instanceof Uint8Array))throw new TypeError('The "value" argument must be a Uint8ArrayList or Uint8Array');let n=t instanceof Uint8Array?t:t.subarray();if(e=Number(e??0),isNaN(e)&&(e=0),e<0&&(e=this.length+e),e<0&&(e=0),t.length===0)return e>this.length?this.length:e;let s=n.byteLength;if(s===0)throw new TypeError("search must be at least 1 byte long");let o=256,i=new Int32Array(o);for(let u=0;u<o;u++)i[u]=-1;for(let u=0;u<s;u++)i[n[u]]=u;let a=i,c=this.byteLength-n.byteLength,f=n.byteLength-1,l;for(let u=e;u<=c;u+=l){l=0;for(let h=f;h>=0;h--){let m=this.get(u+h);if(n[h]!==m){l=Math.max(1,h-a[m]);break}}if(l===0)return u}return-1}getInt8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getInt8(0)}setInt8(t,e){let n=St(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setInt8(0,e),this.write(n,t)}getInt16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt16(0,e)}setInt16(t,e,n){let s=Gt(2);new DataView(s.buffer,s.byteOffset,s.byteLength).setInt16(0,e,n),this.write(s,t)}getInt32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt32(0,e)}setInt32(t,e,n){let s=Gt(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setInt32(0,e,n),this.write(s,t)}getBigInt64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigInt64(0,e)}setBigInt64(t,e,n){let s=Gt(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigInt64(0,e,n),this.write(s,t)}getUint8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getUint8(0)}setUint8(t,e){let n=St(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setUint8(0,e),this.write(n,t)}getUint16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint16(0,e)}setUint16(t,e,n){let s=Gt(2);new DataView(s.buffer,s.byteOffset,s.byteLength).setUint16(0,e,n),this.write(s,t)}getUint32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint32(0,e)}setUint32(t,e,n){let s=Gt(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setUint32(0,e,n),this.write(s,t)}getBigUint64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigUint64(0,e)}setBigUint64(t,e,n){let s=Gt(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigUint64(0,e,n),this.write(s,t)}getFloat32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat32(0,e)}setFloat32(t,e,n){let s=Gt(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setFloat32(0,e,n),this.write(s,t)}getFloat64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat64(0,e)}setFloat64(t,e,n){let s=Gt(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setFloat64(0,e,n),this.write(s,t)}equals(t){if(t==null||!(t instanceof r)||t.bufs.length!==this.bufs.length)return!1;for(let e=0;e<this.bufs.length;e++)if(!xt(this.bufs[e],t.bufs[e]))return!1;return!0}static fromUint8Arrays(t,e){let n=new r;return n.bufs=t,e==null&&(e=t.reduce((s,o)=>s+o.byteLength,0)),n.length=e,n}};var $s={};ut($s,{base10:()=>Bu});var Bu=ce({prefix:"9",name:"base10",alphabet:"0123456789"});var Gs={};ut(Gs,{base16:()=>Au,base16upper:()=>Su});var Au=X({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Su=X({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var zs={};ut(zs,{base2:()=>ku});var ku=X({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Ws={};ut(Ws,{base256emoji:()=>Uu});var Hi=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}"),Iu=Hi.reduce((r,t,e)=>(r[e]=t,r),[]),Cu=Hi.reduce((r,t,e)=>{let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);return r[n]=e,r},[]);function Nu(r){return r.reduce((t,e)=>(t+=Iu[e],t),"")}function Tu(r){let t=[];for(let e of r){let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);let s=Cu[n];if(s==null)throw new Error(`Non-base256emoji character: ${e}`);t.push(s)}return new Uint8Array(t)}var Uu=Je({prefix:"\u{1F680}",name:"base256emoji",encode:Nu,decode:Tu});var Zs={};ut(Zs,{base64:()=>Ne,base64pad:()=>Lu,base64url:()=>Ru,base64urlpad:()=>_u});var Ne=X({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),Lu=X({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Ru=X({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),_u=X({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Js={};ut(Js,{base8:()=>Du});var Du=X({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Ys={};ut(Ys,{identity:()=>Ku});var Ku=Je({prefix:"\0",name:"identity",encode:r=>Bi(r),decode:r=>Ei(r)});var D0=new TextEncoder,K0=new TextDecoder;var to={};ut(to,{sha256:()=>rr,sha512:()=>Hu});function Qs({name:r,code:t,encode:e}){return new Xs(r,t,e)}var Xs=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 Mi(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var rr=Qs({name:"sha2-256",code:18,encode:Mi("SHA-256")}),Hu=Qs({name:"sha2-512",code:19,encode:Mi("SHA-512")});var eo={...Ys,...zs,...Js,...$s,...Gs,...Ps,...Ms,...Hs,...Zs,...Ws},W0={...to,...js};function qi(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var Fi=qi("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),ro=qi("ascii","a",r=>{let t="a";for(let e=0;e<r.length;e++)t+=String.fromCharCode(r[e]);return t},r=>{r=r.substring(1);let t=St(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),Pu={utf8:Fi,"utf-8":Fi,hex:eo.base16,latin1:ro,ascii:ro,binary:ro,...eo},ln=Pu;function V(r,t="utf8"){let e=ln[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function q(r,t="utf8"){let e=ln[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}var Mu=parseInt("11111",2),no=parseInt("10000000",2),Fu=parseInt("01111111",2),ji={0:Nr,1:Nr,2:qu,3:Gu,4:zu,5:$u,6:ju,16:Nr,22:Nr,48:Nr};function Ut(r,t={offset:0}){let e=r[t.offset]&Mu;if(t.offset++,ji[e]!=null)return ji[e](r,t);throw new Error("No decoder for tag "+e)}function Tr(r,t){let e=0;if((r[t.offset]&no)===no){let n=r[t.offset]&Fu,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 Nr(r,t){Tr(r,t);let e=[];for(;!(t.offset>=r.byteLength);){let n=Ut(r,t);if(n===null)break;e.push(n)}return e}function qu(r,t){let e=Tr(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 ju(r,t){let e=Tr(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 $u(r,t){return t.offset++,null}function Gu(r,t){let e=Tr(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 zu(r,t){let e=Tr(r,t),n=r.subarray(t.offset,t.offset+e);return t.offset+=e,n}function Wu(r){let t=r.toString(16);t.length%2===1&&(t="0"+t);let e=new pt;for(let n=0;n<t.length;n+=2)e.append(Uint8Array.from([parseInt(`${t[n]}${t[n+1]}`,16)]));return e}function un(r){if(r.byteLength<128)return Uint8Array.from([r.byteLength]);let t=Wu(r.byteLength);return new pt(Uint8Array.from([t.byteLength|no]),t)}function gt(r){let t=new pt,e=128;return(r.subarray()[0]&e)===e&&t.append(Uint8Array.from([0])),t.append(r),new pt(Uint8Array.from([2]),un(t),t)}function Ur(r){let t=Uint8Array.from([0]),e=new pt(t,r);return new pt(Uint8Array.from([3]),un(e),e)}function $i(r){return new pt(Uint8Array.from([4]),un(r),r)}function Lt(r,t=48){let e=new pt;for(let n of r)e.append(n);return new pt(Uint8Array.from([t]),un(e),e)}var Gi="1.2.840.10045.3.1.7",zi="1.3.132.0.34",Wi="1.3.132.0.35";async function Zi(r,t){let e=await crypto.subtle.importKey("jwk",r,{name:"ECDSA",namedCurve:r.crv??"P-256"},!1,["sign"]),n=await crypto.subtle.sign({name:"ECDSA",hash:{name:"SHA-256"}},e,t.subarray());return new Uint8Array(n,0,n.byteLength)}async function Ji(r,t,e){let n=await crypto.subtle.importKey("jwk",r,{name:"ECDSA",namedCurve:r.crv??"P-256"},!1,["verify"]);return crypto.subtle.verify({name:"ECDSA",hash:{name:"SHA-256"}},n,t,e.subarray())}var Zu=Uint8Array.from([6,8,42,134,72,206,61,3,1,7]),Ju=Uint8Array.from([6,5,43,129,4,0,34]),Yu=Uint8Array.from([6,5,43,129,4,0,35]),Xu={ext:!0,kty:"EC",crv:"P-256"},Qu={ext:!0,kty:"EC",crv:"P-384"},tf={ext:!0,kty:"EC",crv:"P-521"},so=32,oo=48,io=66;function Yi(r){let t=Ut(r);return ao(t)}function ao(r){let t=r[1],e=q(t,"base64url"),n=r[2][1][0],s=1,o,i;if(t.byteLength===so)return o=q(n.subarray(s,s+so),"base64url"),i=q(n.subarray(s+so),"base64url"),new nr({...Xu,key_ops:["sign"],d:e,x:o,y:i});if(t.byteLength===oo)return o=q(n.subarray(s,s+oo),"base64url"),i=q(n.subarray(s+oo),"base64url"),new nr({...Qu,key_ops:["sign"],d:e,x:o,y:i});if(t.byteLength===io)return o=q(n.subarray(s,s+io),"base64url"),i=q(n.subarray(s+io),"base64url"),new nr({...tf,key_ops:["sign"],d:e,x:o,y:i});throw new N(`Private key length was wrong length, got ${t.byteLength}, expected 32, 48 or 66`)}function Xi(r){return Lt([gt(Uint8Array.from([1])),$i(V(r.d??"","base64url")),Lt([ta(r.crv)],160),Lt([Ur(new pt(Uint8Array.from([4]),V(r.x??"","base64url"),V(r.y??"","base64url")))],161)]).subarray()}function Qi(r){return Lt([gt(Uint8Array.from([1])),Lt([ta(r.crv)],160),Lt([Ur(new pt(Uint8Array.from([4]),V(r.x??"","base64url"),V(r.y??"","base64url")))],161)]).subarray()}function ta(r){if(r==="P-256")return Zu;if(r==="P-384")return Ju;if(r==="P-521")return Yu;throw new N(`Invalid curve ${r}`)}var fn=class{type="ECDSA";jwk;_raw;constructor(t){this.jwk=t}get raw(){return this._raw==null&&(this._raw=Qi(this.jwk)),this._raw}toMultihash(){return Ce.digest(sr(this))}toCID(){return It.createV1(114,this.toMultihash())}toString(){return Q.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:xt(this.raw,t.raw)}async verify(t,e){return Ji(this.jwk,e,t)}},nr=class{type="ECDSA";jwk;publicKey;_raw;constructor(t){this.jwk=t,this.publicKey=new fn({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=Xi(this.jwk)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:xt(this.raw,t.raw)}async sign(t){return Zi(this.jwk,t)}};function or(r){if(!Number.isSafeInteger(r)||r<0)throw new Error("positive integer expected, got "+r)}function ef(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function ir(r,...t){if(!ef(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 hn(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");or(r.outputLen),or(r.blockLen)}function ar(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 ea(r,t){ir(r);let e=t.outputLen;if(r.length<e)throw new Error("digestInto() expects output buffer of length at least "+e)}var Te=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;function Ue(r){return new DataView(r.buffer,r.byteOffset,r.byteLength)}function Rt(r,t){return r<<32-t|r>>>t}function dn(r,t){return r<<t|r>>>32-t>>>0}var rf=async()=>{};async function ra(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 rf(),n+=o)}}function na(r){if(typeof r!="string")throw new Error("utf8ToBytes expected string, got "+typeof r);return new Uint8Array(new TextEncoder().encode(r))}function le(r){return typeof r=="string"&&(r=na(r)),ir(r),r}function co(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];ir(s),t+=s.length}let e=new Uint8Array(t);for(let n=0,s=0;n<r.length;n++){let o=r[n];e.set(o,s),s+=o.length}return e}var cr=class{clone(){return this._cloneInto()}};function sa(r,t){if(t!==void 0&&{}.toString.call(t)!=="[object Object]")throw new Error("Options should be object or undefined");return Object.assign(r,t)}function lr(r){let t=n=>r().update(le(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function ur(r=32){if(Te&&typeof Te.getRandomValues=="function")return Te.getRandomValues(new Uint8Array(r));if(Te&&typeof Te.randomBytes=="function")return Te.randomBytes(r);throw new Error("crypto.getRandomValues must be defined")}function nf(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 pn(r,t,e){return r&t^~r&e}function gn(r,t,e){return r&t^r&e^t&e}var ue=class extends cr{constructor(t,e,n,s){super(),this.blockLen=t,this.outputLen=e,this.padOffset=n,this.isLE=s,this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.buffer=new Uint8Array(t),this.view=Ue(this.buffer)}update(t){ar(this);let{view:e,buffer:n,blockLen:s}=this;t=le(t);let o=t.length;for(let i=0;i<o;){let a=Math.min(s-this.pos,o-i);if(a===s){let c=Ue(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){ar(this),ea(t,this),this.finished=!0;let{buffer:e,view:n,blockLen:s,isLE:o}=this,{pos:i}=this;e[i++]=128,this.buffer.subarray(i).fill(0),this.padOffset>s-i&&(this.process(n,0),i=0);for(let u=i;u<s;u++)e[u]=0;nf(n,s-8,BigInt(this.length*8),o),this.process(n,0);let a=Ue(t),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let f=c/4,l=this.get();if(f>l.length)throw new Error("_sha2: outputLen bigger than state");for(let u=0;u<f;u++)a.setUint32(4*u,l[u],o)}digest(){let{buffer:t,outputLen:e}=this;this.digestInto(t);let n=t.slice(0,e);return this.destroy(),n}_cloneInto(t){t||(t=new this.constructor),t.set(...this.get());let{blockLen:e,buffer:n,length:s,finished:o,destroyed:i,pos:a}=this;return t.length=s,t.pos=a,t.finished=o,t.destroyed=i,s%e&&t.buffer.set(n),t}};var yn=BigInt(4294967295),lo=BigInt(32);function oa(r,t=!1){return t?{h:Number(r&yn),l:Number(r>>lo&yn)}:{h:Number(r>>lo&yn)|0,l:Number(r&yn)|0}}function sf(r,t=!1){let e=new Uint32Array(r.length),n=new Uint32Array(r.length);for(let s=0;s<r.length;s++){let{h:o,l:i}=oa(r[s],t);[e[s],n[s]]=[o,i]}return[e,n]}var of=(r,t)=>BigInt(r>>>0)<<lo|BigInt(t>>>0),af=(r,t,e)=>r>>>e,cf=(r,t,e)=>r<<32-e|t>>>e,lf=(r,t,e)=>r>>>e|t<<32-e,uf=(r,t,e)=>r<<32-e|t>>>e,ff=(r,t,e)=>r<<64-e|t>>>e-32,hf=(r,t,e)=>r>>>e-32|t<<64-e,df=(r,t)=>t,pf=(r,t)=>r,gf=(r,t,e)=>r<<e|t>>>32-e,yf=(r,t,e)=>t<<e|r>>>32-e,mf=(r,t,e)=>t<<e-32|r>>>64-e,wf=(r,t,e)=>r<<e-32|t>>>64-e;function bf(r,t,e,n){let s=(t>>>0)+(n>>>0);return{h:r+e+(s/2**32|0)|0,l:s|0}}var xf=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),vf=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,Ef=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),Bf=(r,t,e,n,s)=>t+e+n+s+(r/2**32|0)|0,Af=(r,t,e,n,s)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(s>>>0),Sf=(r,t,e,n,s,o)=>t+e+n+s+o+(r/2**32|0)|0;var kf={fromBig:oa,split:sf,toBig:of,shrSH:af,shrSL:cf,rotrSH:lf,rotrSL:uf,rotrBH:ff,rotrBL:hf,rotr32H:df,rotr32L:pf,rotlSH:gf,rotlSL:yf,rotlBH:mf,rotlBL:wf,add:bf,add3L:xf,add3H:vf,add4L:Ef,add4H:Bf,add5H:Sf,add5L:Af},O=kf;var[If,Cf]=O.split(["0x428a2f98d728ae22","0x7137449123ef65cd","0xb5c0fbcfec4d3b2f","0xe9b5dba58189dbbc","0x3956c25bf348b538","0x59f111f1b605d019","0x923f82a4af194f9b","0xab1c5ed5da6d8118","0xd807aa98a3030242","0x12835b0145706fbe","0x243185be4ee4b28c","0x550c7dc3d5ffb4e2","0x72be5d74f27b896f","0x80deb1fe3b1696b1","0x9bdc06a725c71235","0xc19bf174cf692694","0xe49b69c19ef14ad2","0xefbe4786384f25e3","0x0fc19dc68b8cd5b5","0x240ca1cc77ac9c65","0x2de92c6f592b0275","0x4a7484aa6ea6e483","0x5cb0a9dcbd41fbd4","0x76f988da831153b5","0x983e5152ee66dfab","0xa831c66d2db43210","0xb00327c898fb213f","0xbf597fc7beef0ee4","0xc6e00bf33da88fc2","0xd5a79147930aa725","0x06ca6351e003826f","0x142929670a0e6e70","0x27b70a8546d22ffc","0x2e1b21385c26c926","0x4d2c6dfc5ac42aed","0x53380d139d95b3df","0x650a73548baf63de","0x766a0abb3c77b2a8","0x81c2c92e47edaee6","0x92722c851482353b","0xa2bfe8a14cf10364","0xa81a664bbc423001","0xc24b8b70d0f89791","0xc76c51a30654be30","0xd192e819d6ef5218","0xd69906245565a910","0xf40e35855771202a","0x106aa07032bbd1b8","0x19a4c116b8d2d0c8","0x1e376c085141ab53","0x2748774cdf8eeb99","0x34b0bcb5e19b48a8","0x391c0cb3c5c95a63","0x4ed8aa4ae3418acb","0x5b9cca4f7763e373","0x682e6ff3d6b2b8a3","0x748f82ee5defb2fc","0x78a5636f43172f60","0x84c87814a1f0ab72","0x8cc702081a6439ec","0x90befffa23631e28","0xa4506cebde82bde9","0xbef9a3f7b2c67915","0xc67178f2e372532b","0xca273eceea26619c","0xd186b8c721c0c207","0xeada7dd6cde0eb1e","0xf57d4f7fee6ed178","0x06f067aa72176fba","0x0a637dc5a2c898a6","0x113f9804bef90dae","0x1b710b35131c471b","0x28db77f523047d84","0x32caab7b40c72493","0x3c9ebe0a15c9bebc","0x431d67c49c100d4c","0x4cc5d4becb3e42b6","0x597f299cfc657e2a","0x5fcb6fab3ad6faec","0x6c44198c4a475817"].map(r=>BigInt(r))),fe=new Uint32Array(80),he=new Uint32Array(80),uo=class extends ue{constructor(){super(128,64,16,!1),this.Ah=1779033703,this.Al=-205731576,this.Bh=-1150833019,this.Bl=-2067093701,this.Ch=1013904242,this.Cl=-23791573,this.Dh=-1521486534,this.Dl=1595750129,this.Eh=1359893119,this.El=-1377402159,this.Fh=-1694144372,this.Fl=725511199,this.Gh=528734635,this.Gl=-79577749,this.Hh=1541459225,this.Hl=327033209}get(){let{Ah:t,Al:e,Bh:n,Bl:s,Ch:o,Cl:i,Dh:a,Dl:c,Eh:f,El:l,Fh:u,Fl:h,Gh:m,Gl:w,Hh:y,Hl:d}=this;return[t,e,n,s,o,i,a,c,f,l,u,h,m,w,y,d]}set(t,e,n,s,o,i,a,c,f,l,u,h,m,w,y,d){this.Ah=t|0,this.Al=e|0,this.Bh=n|0,this.Bl=s|0,this.Ch=o|0,this.Cl=i|0,this.Dh=a|0,this.Dl=c|0,this.Eh=f|0,this.El=l|0,this.Fh=u|0,this.Fl=h|0,this.Gh=m|0,this.Gl=w|0,this.Hh=y|0,this.Hl=d|0}process(t,e){for(let p=0;p<16;p++,e+=4)fe[p]=t.getUint32(e),he[p]=t.getUint32(e+=4);for(let p=16;p<80;p++){let S=fe[p-15]|0,R=he[p-15]|0,L=O.rotrSH(S,R,1)^O.rotrSH(S,R,8)^O.shrSH(S,R,7),I=O.rotrSL(S,R,1)^O.rotrSL(S,R,8)^O.shrSL(S,R,7),U=fe[p-2]|0,C=he[p-2]|0,W=O.rotrSH(U,C,19)^O.rotrBH(U,C,61)^O.shrSH(U,C,6),j=O.rotrSL(U,C,19)^O.rotrBL(U,C,61)^O.shrSL(U,C,6),P=O.add4L(I,j,he[p-7],he[p-16]),et=O.add4H(P,L,W,fe[p-7],fe[p-16]);fe[p]=et|0,he[p]=P|0}let{Ah:n,Al:s,Bh:o,Bl:i,Ch:a,Cl:c,Dh:f,Dl:l,Eh:u,El:h,Fh:m,Fl:w,Gh:y,Gl:d,Hh:b,Hl:E}=this;for(let p=0;p<80;p++){let S=O.rotrSH(u,h,14)^O.rotrSH(u,h,18)^O.rotrBH(u,h,41),R=O.rotrSL(u,h,14)^O.rotrSL(u,h,18)^O.rotrBL(u,h,41),L=u&m^~u&y,I=h&w^~h&d,U=O.add5L(E,R,I,Cf[p],he[p]),C=O.add5H(U,b,S,L,If[p],fe[p]),W=U|0,j=O.rotrSH(n,s,28)^O.rotrBH(n,s,34)^O.rotrBH(n,s,39),P=O.rotrSL(n,s,28)^O.rotrBL(n,s,34)^O.rotrBL(n,s,39),et=n&o^n&a^o&a,B=s&i^s&c^i&c;b=y|0,E=d|0,y=m|0,d=w|0,m=u|0,w=h|0,{h:u,l:h}=O.add(f|0,l|0,C|0,W|0),f=a|0,l=c|0,a=o|0,c=i|0,o=n|0,i=s|0;let T=O.add3L(W,P,B);n=O.add3H(T,C,j,et),s=T|0}({h:n,l:s}=O.add(this.Ah|0,this.Al|0,n|0,s|0)),{h:o,l:i}=O.add(this.Bh|0,this.Bl|0,o|0,i|0),{h:a,l:c}=O.add(this.Ch|0,this.Cl|0,a|0,c|0),{h:f,l}=O.add(this.Dh|0,this.Dl|0,f|0,l|0),{h:u,l:h}=O.add(this.Eh|0,this.El|0,u|0,h|0),{h:m,l:w}=O.add(this.Fh|0,this.Fl|0,m|0,w|0),{h:y,l:d}=O.add(this.Gh|0,this.Gl|0,y|0,d|0),{h:b,l:E}=O.add(this.Hh|0,this.Hl|0,b|0,E|0),this.set(n,s,o,i,a,c,f,l,u,h,m,w,y,d,b,E)}roundClean(){fe.fill(0),he.fill(0)}destroy(){this.buffer.fill(0),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}};var de=lr(()=>new uo);var bn={};ut(bn,{aInRange:()=>vt,abool:()=>_t,abytes:()=>fr,bitGet:()=>_f,bitLen:()=>go,bitMask:()=>Rr,bitSet:()=>Df,bytesToHex:()=>Wt,bytesToNumberBE:()=>Zt,bytesToNumberLE:()=>ge,concatBytes:()=>Jt,createHmacDrbg:()=>yo,ensureBytes:()=>Y,equalBytes:()=>Lf,hexToBytes:()=>Re,hexToNumber:()=>po,inRange:()=>Lr,isBytes:()=>pe,memoized:()=>De,notImplemented:()=>Of,numberToBytesBE:()=>ye,numberToBytesLE:()=>_e,numberToHexUnpadded:()=>Le,numberToVarBytesBE:()=>Uf,utf8ToBytes:()=>Rf,validateObject:()=>Mt});var mn=BigInt(0),wn=BigInt(1),Nf=BigInt(2);function pe(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function fr(r){if(!pe(r))throw new Error("Uint8Array expected")}function _t(r,t){if(typeof t!="boolean")throw new Error(r+" boolean expected, got "+t)}var Tf=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function Wt(r){fr(r);let t="";for(let e=0;e<r.length;e++)t+=Tf[r[e]];return t}function Le(r){let t=r.toString(16);return t.length&1?"0"+t:t}function po(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return r===""?mn:BigInt("0x"+r)}var zt={_0:48,_9:57,A:65,F:70,a:97,f:102};function ia(r){if(r>=zt._0&&r<=zt._9)return r-zt._0;if(r>=zt.A&&r<=zt.F)return r-(zt.A-10);if(r>=zt.a&&r<=zt.f)return r-(zt.a-10)}function Re(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);let t=r.length,e=t/2;if(t%2)throw new Error("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=ia(r.charCodeAt(o)),a=ia(r.charCodeAt(o+1));if(i===void 0||a===void 0){let c=r[o]+r[o+1];throw new Error('hex string expected, got non-hex character "'+c+'" at index '+o)}n[s]=i*16+a}return n}function Zt(r){return po(Wt(r))}function ge(r){return fr(r),po(Wt(Uint8Array.from(r).reverse()))}function ye(r,t){return Re(r.toString(16).padStart(t*2,"0"))}function _e(r,t){return ye(r,t).reverse()}function Uf(r){return Re(Le(r))}function Y(r,t,e){let n;if(typeof t=="string")try{n=Re(t)}catch(o){throw new Error(r+" must be hex string or Uint8Array, cause: "+o)}else if(pe(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 Jt(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];fr(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 Lf(r,t){if(r.length!==t.length)return!1;let e=0;for(let n=0;n<r.length;n++)e|=r[n]^t[n];return e===0}function Rf(r){if(typeof r!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(r))}var fo=r=>typeof r=="bigint"&&mn<=r;function Lr(r,t,e){return fo(r)&&fo(t)&&fo(e)&&t<=r&&r<e}function vt(r,t,e,n){if(!Lr(t,e,n))throw new Error("expected valid "+r+": "+e+" <= n < "+n+", got "+t)}function go(r){let t;for(t=0;r>mn;r>>=wn,t+=1);return t}function _f(r,t){return r>>BigInt(t)&wn}function Df(r,t,e){return r|(e?wn:mn)<<BigInt(t)}var Rr=r=>(Nf<<BigInt(r-1))-wn,ho=r=>new Uint8Array(r),aa=r=>Uint8Array.from(r);function yo(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=ho(r),s=ho(r),o=0,i=()=>{n.fill(1),s.fill(0),o=0},a=(...u)=>e(s,n,...u),c=(u=ho())=>{s=a(aa([0]),u),n=a(),u.length!==0&&(s=a(aa([1]),u),n=a())},f=()=>{if(o++>=1e3)throw new Error("drbg: tried 1000 values");let u=0,h=[];for(;u<t;){n=a();let m=n.slice();h.push(m),u+=n.length}return Jt(...h)};return(u,h)=>{i(),c(u);let m;for(;!(m=h(f()));)c();return i(),m}}var Kf={bigint:r=>typeof r=="bigint",function:r=>typeof r=="function",boolean:r=>typeof r=="boolean",string:r=>typeof r=="string",stringOrUint8Array:r=>typeof r=="string"||pe(r),isSafeInteger:r=>Number.isSafeInteger(r),array:r=>Array.isArray(r),field:(r,t)=>t.Fp.isValid(r),hash:r=>typeof r=="function"&&Number.isSafeInteger(r.outputLen)};function Mt(r,t,e={}){let n=(s,o,i)=>{let a=Kf[o];if(typeof a!="function")throw new Error("invalid validator function");let c=r[s];if(!(i&&c===void 0)&&!a(c,r))throw new Error("param "+String(s)+" is invalid. Expected "+o+", got "+c)};for(let[s,o]of Object.entries(t))n(s,o,!1);for(let[s,o]of Object.entries(e))n(s,o,!0);return r}var Of=()=>{throw new Error("not implemented")};function De(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 rt=BigInt(0),Z=BigInt(1),Ke=BigInt(2),Vf=BigInt(3),mo=BigInt(4),ca=BigInt(5),la=BigInt(8),Hf=BigInt(9),Pf=BigInt(16);function G(r,t){let e=r%t;return e>=rt?e:t+e}function Mf(r,t,e){if(t<rt)throw new Error("invalid exponent, negatives unsupported");if(e<=rt)throw new Error("invalid modulus");if(e===Z)return rt;let n=Z;for(;t>rt;)t&Z&&(n=n*r%e),r=r*r%e,t>>=Z;return n}function J(r,t,e){let n=r;for(;t-- >rt;)n*=n,n%=e;return n}function xn(r,t){if(r===rt)throw new Error("invert: expected non-zero number");if(t<=rt)throw new Error("invert: expected positive modulus, got "+t);let e=G(r,t),n=t,s=rt,o=Z,i=Z,a=rt;for(;e!==rt;){let f=n/e,l=n%e,u=s-i*f,h=o-a*f;n=e,e=l,s=i,o=a,i=u,a=h}if(n!==Z)throw new Error("invert: does not exist");return G(s,t)}function Ff(r){let t=(r-Z)/Ke,e,n,s;for(e=r-Z,n=0;e%Ke===rt;e/=Ke,n++);for(s=Ke;s<r&&Mf(s,t,r)!==r-Z;s++)if(s>1e3)throw new Error("Cannot find square root: likely non-prime P");if(n===1){let i=(r+Z)/mo;return function(c,f){let l=c.pow(f,i);if(!c.eql(c.sqr(l),f))throw new Error("Cannot find square root");return l}}let o=(e+Z)/Ke;return function(a,c){if(a.pow(c,t)===a.neg(a.ONE))throw new Error("Cannot find square root");let f=n,l=a.pow(a.mul(a.ONE,s),e),u=a.pow(c,o),h=a.pow(c,e);for(;!a.eql(h,a.ONE);){if(a.eql(h,a.ZERO))return a.ZERO;let m=1;for(let y=a.sqr(h);m<f&&!a.eql(y,a.ONE);m++)y=a.sqr(y);let w=a.pow(l,Z<<BigInt(f-m-1));l=a.sqr(w),u=a.mul(u,w),h=a.mul(h,l),f=m}return u}}function qf(r){if(r%mo===Vf){let t=(r+Z)/mo;return function(n,s){let o=n.pow(s,t);if(!n.eql(n.sqr(o),s))throw new Error("Cannot find square root");return o}}if(r%la===ca){let t=(r-ca)/la;return function(n,s){let o=n.mul(s,Ke),i=n.pow(o,t),a=n.mul(s,i),c=n.mul(n.mul(a,Ke),i),f=n.mul(a,n.sub(c,n.ONE));if(!n.eql(n.sqr(f),s))throw new Error("Cannot find square root");return f}}return r%Pf,Ff(r)}var ua=(r,t)=>(G(r,t)&Z)===Z,jf=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function wo(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=jf.reduce((n,s)=>(n[s]="function",n),t);return Mt(r,e)}function $f(r,t,e){if(e<rt)throw new Error("invalid exponent, negatives unsupported");if(e===rt)return r.ONE;if(e===Z)return t;let n=r.ONE,s=t;for(;e>rt;)e&Z&&(n=r.mul(n,s)),s=r.sqr(s),e>>=Z;return n}function Gf(r,t){let e=new Array(t.length),n=t.reduce((o,i,a)=>r.is0(i)?o:(e[a]=o,r.mul(o,i)),r.ONE),s=r.inv(n);return t.reduceRight((o,i,a)=>r.is0(i)?o:(e[a]=r.mul(o,e[a]),r.mul(o,i)),s),e}function bo(r,t){let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function me(r,t,e=!1,n={}){if(r<=rt)throw new Error("invalid field: expected ORDER > 0, got "+r);let{nBitLength:s,nByteLength:o}=bo(r,t);if(o>2048)throw new Error("invalid field: expected ORDER of <= 2048 bytes");let i,a=Object.freeze({ORDER:r,isLE:e,BITS:s,BYTES:o,MASK:Rr(s),ZERO:rt,ONE:Z,create:c=>G(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error("invalid field element: expected bigint, got "+typeof c);return rt<=c&&c<r},is0:c=>c===rt,isOdd:c=>(c&Z)===Z,neg:c=>G(-c,r),eql:(c,f)=>c===f,sqr:c=>G(c*c,r),add:(c,f)=>G(c+f,r),sub:(c,f)=>G(c-f,r),mul:(c,f)=>G(c*f,r),pow:(c,f)=>$f(a,c,f),div:(c,f)=>G(c*xn(f,r),r),sqrN:c=>c*c,addN:(c,f)=>c+f,subN:(c,f)=>c-f,mulN:(c,f)=>c*f,inv:c=>xn(c,r),sqrt:n.sqrt||(c=>(i||(i=qf(r)),i(a,c))),invertBatch:c=>Gf(a,c),cmov:(c,f,l)=>l?f:c,toBytes:c=>e?_e(c,o):ye(c,o),fromBytes:c=>{if(c.length!==o)throw new Error("Field.fromBytes: expected "+o+" bytes, got "+c.length);return e?ge(c):Zt(c)}});return Object.freeze(a)}function fa(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 xo(r){let t=fa(r);return t+Math.ceil(t/2)}function ha(r,t,e=!1){let n=r.length,s=fa(t),o=xo(t);if(n<16||n<o||n>1024)throw new Error("expected "+o+"-1024 bytes of input, got "+n);let i=e?ge(r):Zt(r),a=G(i,t-Z)+Z;return e?_e(a,s):ye(a,s)}var da=BigInt(0),vn=BigInt(1);function vo(r,t){let e=t.negate();return r?e:t}function pa(r,t){if(!Number.isSafeInteger(r)||r<=0||r>t)throw new Error("invalid window size, expected [1.."+t+"], got W="+r)}function Eo(r,t){pa(r,t);let e=Math.ceil(t/r)+1,n=2**(r-1);return{windows:e,windowSize:n}}function zf(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 Wf(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 Bo=new WeakMap,ga=new WeakMap;function Ao(r){return ga.get(r)||1}function En(r,t){return{constTimeNegate:vo,hasPrecomputes(e){return Ao(e)!==1},unsafeLadder(e,n,s=r.ZERO){let o=e;for(;n>da;)n&vn&&(s=s.add(o)),o=o.double(),n>>=vn;return s},precomputeWindow(e,n){let{windows:s,windowSize:o}=Eo(n,t),i=[],a=e,c=a;for(let f=0;f<s;f++){c=a,i.push(c);for(let l=1;l<o;l++)c=c.add(a),i.push(c);a=c.double()}return i},wNAF(e,n,s){let{windows:o,windowSize:i}=Eo(e,t),a=r.ZERO,c=r.BASE,f=BigInt(2**e-1),l=2**e,u=BigInt(e);for(let h=0;h<o;h++){let m=h*i,w=Number(s&f);s>>=u,w>i&&(w-=l,s+=vn);let y=m,d=m+Math.abs(w)-1,b=h%2!==0,E=w<0;w===0?c=c.add(vo(b,n[y])):a=a.add(vo(E,n[d]))}return{p:a,f:c}},wNAFUnsafe(e,n,s,o=r.ZERO){let{windows:i,windowSize:a}=Eo(e,t),c=BigInt(2**e-1),f=2**e,l=BigInt(e);for(let u=0;u<i;u++){let h=u*a;if(s===da)break;let m=Number(s&c);if(s>>=l,m>a&&(m-=f,s+=vn),m===0)continue;let w=n[h+Math.abs(m)-1];m<0&&(w=w.negate()),o=o.add(w)}return o},getPrecomputes(e,n,s){let o=Bo.get(n);return o||(o=this.precomputeWindow(n,e),e!==1&&Bo.set(n,s(o))),o},wNAFCached(e,n,s){let o=Ao(e);return this.wNAF(o,this.getPrecomputes(o,e,s),n)},wNAFCachedUnsafe(e,n,s,o){let i=Ao(e);return i===1?this.unsafeLadder(e,n,o):this.wNAFUnsafe(i,this.getPrecomputes(i,e,s),n,o)},setWindowSize(e,n){pa(n,t),ga.set(e,n),Bo.delete(e)}}}function Bn(r,t,e,n){if(zf(e,r),Wf(n,t),e.length!==n.length)throw new Error("arrays of points and scalars must have equal length");let s=r.ZERO,o=go(BigInt(e.length)),i=o>12?o-3:o>4?o-2:o?2:1,a=(1<<i)-1,c=new Array(a+1).fill(s),f=Math.floor((t.BITS-1)/i)*i,l=s;for(let u=f;u>=0;u-=i){c.fill(s);for(let m=0;m<n.length;m++){let w=n[m],y=Number(w>>BigInt(u)&BigInt(a));c[y]=c[y].add(e[m])}let h=s;for(let m=c.length-1,w=s;m>0;m--)w=w.add(c[m]),h=h.add(w);if(l=l.add(h),u!==0)for(let m=0;m<i;m++)l=l.double()}return l}function _r(r){return wo(r.Fp),Mt(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...bo(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Dt=BigInt(0),Et=BigInt(1),An=BigInt(2),Zf=BigInt(8),Jf={zip215:!0};function Yf(r){let t=_r(r);return Mt(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function ya(r){let t=Yf(r),{Fp:e,n,prehash:s,hash:o,randomBytes:i,nByteLength:a,h:c}=t,f=An<<BigInt(a*8)-Et,l=e.create,u=me(t.n,t.nBitLength),h=t.uvRatio||((x,g)=>{try{return{isValid:!0,value:e.sqrt(x*e.inv(g))}}catch{return{isValid:!1,value:Dt}}}),m=t.adjustScalarBytes||(x=>x),w=t.domain||((x,g,v)=>{if(_t("phflag",v),g.length||v)throw new Error("Contexts/pre-hash are not supported");return x});function y(x,g){vt("coordinate "+x,g,Dt,f)}function d(x){if(!(x instanceof p))throw new Error("ExtendedPoint expected")}let b=De((x,g)=>{let{ex:v,ey:k,ez:_}=x,D=x.is0();g==null&&(g=D?Zf:e.inv(_));let H=l(v*g),F=l(k*g),K=l(_*g);if(D)return{x:Dt,y:Et};if(K!==Et)throw new Error("invZ was invalid");return{x:H,y:F}}),E=De(x=>{let{a:g,d:v}=t;if(x.is0())throw new Error("bad point: ZERO");let{ex:k,ey:_,ez:D,et:H}=x,F=l(k*k),K=l(_*_),$=l(D*D),z=l($*$),st=l(F*g),ot=l($*l(st+K)),at=l(z+l(v*l(F*K)));if(ot!==at)throw new Error("bad point: equation left != right (1)");let lt=l(k*_),wt=l(D*H);if(lt!==wt)throw new Error("bad point: equation left != right (2)");return!0});class p{constructor(g,v,k,_){this.ex=g,this.ey=v,this.ez=k,this.et=_,y("x",g),y("y",v),y("z",k),y("t",_),Object.freeze(this)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(g){if(g instanceof p)throw new Error("extended point not allowed");let{x:v,y:k}=g||{};return y("x",v),y("y",k),new p(v,k,Et,l(v*k))}static normalizeZ(g){let v=e.invertBatch(g.map(k=>k.ez));return g.map((k,_)=>k.toAffine(v[_])).map(p.fromAffine)}static msm(g,v){return Bn(p,u,g,v)}_setWindowSize(g){L.setWindowSize(this,g)}assertValidity(){E(this)}equals(g){d(g);let{ex:v,ey:k,ez:_}=this,{ex:D,ey:H,ez:F}=g,K=l(v*F),$=l(D*_),z=l(k*F),st=l(H*_);return K===$&&z===st}is0(){return this.equals(p.ZERO)}negate(){return new p(l(-this.ex),this.ey,this.ez,l(-this.et))}double(){let{a:g}=t,{ex:v,ey:k,ez:_}=this,D=l(v*v),H=l(k*k),F=l(An*l(_*_)),K=l(g*D),$=v+k,z=l(l($*$)-D-H),st=K+H,ot=st-F,at=K-H,lt=l(z*ot),wt=l(st*at),dt=l(z*at),Pt=l(ot*st);return new p(lt,wt,Pt,dt)}add(g){d(g);let{a:v,d:k}=t,{ex:_,ey:D,ez:H,et:F}=this,{ex:K,ey:$,ez:z,et:st}=g;if(v===BigInt(-1)){let fi=l((D-_)*($+K)),hi=l((D+_)*($-K)),Rs=l(hi-fi);if(Rs===Dt)return this.double();let di=l(H*An*st),pi=l(F*An*z),gi=pi+di,yi=hi+fi,mi=pi-di,Il=l(gi*Rs),Cl=l(yi*mi),Nl=l(gi*mi),Tl=l(Rs*yi);return new p(Il,Cl,Tl,Nl)}let ot=l(_*K),at=l(D*$),lt=l(F*k*st),wt=l(H*z),dt=l((_+D)*(K+$)-ot-at),Pt=wt-lt,jt=wt+lt,xr=l(at-v*ot),Bl=l(dt*Pt),Al=l(jt*xr),Sl=l(dt*xr),kl=l(Pt*jt);return new p(Bl,Al,kl,Sl)}subtract(g){return this.add(g.negate())}wNAF(g){return L.wNAFCached(this,g,p.normalizeZ)}multiply(g){let v=g;vt("scalar",v,Et,n);let{p:k,f:_}=this.wNAF(v);return p.normalizeZ([k,_])[0]}multiplyUnsafe(g,v=p.ZERO){let k=g;return vt("scalar",k,Dt,n),k===Dt?R:this.is0()||k===Et?this:L.wNAFCachedUnsafe(this,k,p.normalizeZ,v)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return L.unsafeLadder(this,n).is0()}toAffine(g){return b(this,g)}clearCofactor(){let{h:g}=t;return g===Et?this:this.multiplyUnsafe(g)}static fromHex(g,v=!1){let{d:k,a:_}=t,D=e.BYTES;g=Y("pointHex",g,D),_t("zip215",v);let H=g.slice(),F=g[D-1];H[D-1]=F&-129;let K=ge(H),$=v?f:e.ORDER;vt("pointHex.y",K,Dt,$);let z=l(K*K),st=l(z-Et),ot=l(k*z-_),{isValid:at,value:lt}=h(st,ot);if(!at)throw new Error("Point.fromHex: invalid y coordinate");let wt=(lt&Et)===Et,dt=(F&128)!==0;if(!v&&lt===Dt&&dt)throw new Error("Point.fromHex: x=0 and x_0=1");return dt!==wt&&(lt=l(-lt)),p.fromAffine({x:lt,y:K})}static fromPrivateKey(g){return C(g).point}toRawBytes(){let{x:g,y:v}=this.toAffine(),k=_e(v,e.BYTES);return k[k.length-1]|=g&Et?128:0,k}toHex(){return Wt(this.toRawBytes())}}p.BASE=new p(t.Gx,t.Gy,Et,l(t.Gx*t.Gy)),p.ZERO=new p(Dt,Et,Et,Dt);let{BASE:S,ZERO:R}=p,L=En(p,a*8);function I(x){return G(x,n)}function U(x){return I(ge(x))}function C(x){let g=e.BYTES;x=Y("private key",x,g);let v=Y("hashed private key",o(x),2*g),k=m(v.slice(0,g)),_=v.slice(g,2*g),D=U(k),H=S.multiply(D),F=H.toRawBytes();return{head:k,prefix:_,scalar:D,point:H,pointBytes:F}}function W(x){return C(x).pointBytes}function j(x=new Uint8Array,...g){let v=Jt(...g);return U(o(w(v,Y("context",x),!!s)))}function P(x,g,v={}){x=Y("message",x),s&&(x=s(x));let{prefix:k,scalar:_,pointBytes:D}=C(g),H=j(v.context,k,x),F=S.multiply(H).toRawBytes(),K=j(v.context,F,D,x),$=I(H+K*_);vt("signature.s",$,Dt,n);let z=Jt(F,_e($,e.BYTES));return Y("result",z,e.BYTES*2)}let et=Jf;function B(x,g,v,k=et){let{context:_,zip215:D}=k,H=e.BYTES;x=Y("signature",x,2*H),g=Y("message",g),v=Y("publicKey",v,H),D!==void 0&&_t("zip215",D),s&&(g=s(g));let F=ge(x.slice(H,2*H)),K,$,z;try{K=p.fromHex(v,D),$=p.fromHex(x.slice(0,H),D),z=S.multiplyUnsafe(F)}catch{return!1}if(!D&&K.isSmallOrder())return!1;let st=j(_,$.toRawBytes(),K.toRawBytes(),g);return $.add(K.multiplyUnsafe(st)).subtract(z).clearCofactor().equals(p.ZERO)}return S._setWindowSize(8),{CURVE:t,getPublicKey:W,sign:P,verify:B,ExtendedPoint:p,utils:{getExtendedPublicKey:C,randomPrivateKey:()=>i(e.BYTES),precompute(x=8,g=p.BASE){return g._setWindowSize(x),g.multiply(BigInt(3)),g}}}}var So=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),ma=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),Wp=BigInt(0),Xf=BigInt(1),wa=BigInt(2),Zp=BigInt(3),Qf=BigInt(5),th=BigInt(8);function eh(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),s=BigInt(80),o=So,a=r*r%o*r%o,c=J(a,wa,o)*a%o,f=J(c,Xf,o)*r%o,l=J(f,Qf,o)*f%o,u=J(l,t,o)*l%o,h=J(u,e,o)*u%o,m=J(h,n,o)*h%o,w=J(m,s,o)*m%o,y=J(w,s,o)*m%o,d=J(y,t,o)*l%o;return{pow_p_5_8:J(d,wa,o)*r%o,b2:a}}function rh(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function nh(r,t){let e=So,n=G(t*t*t,e),s=G(n*n*t,e),o=eh(r*s).pow_p_5_8,i=G(r*n*o,e),a=G(t*i*i,e),c=i,f=G(i*ma,e),l=a===r,u=a===G(-r,e),h=a===G(-r*ma,e);return l&&(i=c),(u||h)&&(i=f),ua(i,e)&&(i=G(-i,e)),{isValid:l||u,value:i}}var sh=me(So,void 0,!0),oh={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:sh,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:th,Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:de,randomBytes:ur,adjustScalarBytes:rh,uvRatio:nh},ko=ya(oh);var hr=32,Kt=64,ih=32;function ba(r,t){let e=r.subarray(0,ih);return ko.sign(t instanceof Uint8Array?t:t.subarray(),e)}function xa(r,t,e){return ko.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}var Sn=class{type="Ed25519";raw;constructor(t){this.raw=Kr(t,hr)}toMultihash(){return Ce.digest(sr(this))}toCID(){return It.createV1(114,this.toMultihash())}toString(){return Q.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:xt(this.raw,t.raw)}verify(t,e){return xa(this.raw,e,t)}},Dr=class{type="Ed25519";raw;publicKey;constructor(t,e){this.raw=Kr(t,Kt),this.publicKey=new Sn(e)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:xt(this.raw,t.raw)}sign(t){return ba(this.raw,t)}};function Io(r){if(r.length>Kt){r=Kr(r,Kt+hr);let n=r.subarray(0,Kt),s=r.subarray(Kt,r.length);return new Dr(n,s)}r=Kr(r,Kt);let t=r.subarray(0,Kt),e=r.subarray(hr);return new Dr(t,e)}function Kr(r,t){if(r=Uint8Array.from(r??[]),r.length!==t)throw new N(`Key must be a Uint8Array of length ${t}, got ${r.length}`);return r}var ah=Math.pow(2,7),ch=Math.pow(2,14),lh=Math.pow(2,21),Ea=Math.pow(2,28),Ba=Math.pow(2,35),Aa=Math.pow(2,42),Sa=Math.pow(2,49),yt=128,we=127;function Or(r){if(r<ah)return 1;if(r<ch)return 2;if(r<lh)return 3;if(r<Ea)return 4;if(r<Ba)return 5;if(r<Aa)return 6;if(r<Sa)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function ka(r,t,e=0){switch(Or(r)){case 8:t[e++]=r&255|yt,r/=128;case 7:t[e++]=r&255|yt,r/=128;case 6:t[e++]=r&255|yt,r/=128;case 5:t[e++]=r&255|yt,r/=128;case 4:t[e++]=r&255|yt,r>>>=7;case 3:t[e++]=r&255|yt,r>>>=7;case 2:t[e++]=r&255|yt,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function Ia(r,t){let e=r[t],n=0;if(n+=e&we,e<yt||(e=r[t+1],n+=(e&we)<<7,e<yt)||(e=r[t+2],n+=(e&we)<<14,e<yt)||(e=r[t+3],n+=(e&we)<<21,e<yt)||(e=r[t+4],n+=(e&we)*Ea,e<yt)||(e=r[t+5],n+=(e&we)*Ba,e<yt)||(e=r[t+6],n+=(e&we)*Aa,e<yt)||(e=r[t+7],n+=(e&we)*Sa,e<yt))return n;throw new RangeError("Could not decode varint")}var Co=new Float32Array([-0]),be=new Uint8Array(Co.buffer);function Ca(r,t,e){Co[0]=r,t[e]=be[0],t[e+1]=be[1],t[e+2]=be[2],t[e+3]=be[3]}function Na(r,t){return be[0]=r[t],be[1]=r[t+1],be[2]=r[t+2],be[3]=r[t+3],Co[0]}var No=new Float64Array([-0]),ft=new Uint8Array(No.buffer);function Ta(r,t,e){No[0]=r,t[e]=ft[0],t[e+1]=ft[1],t[e+2]=ft[2],t[e+3]=ft[3],t[e+4]=ft[4],t[e+5]=ft[5],t[e+6]=ft[6],t[e+7]=ft[7]}function Ua(r,t){return ft[0]=r[t],ft[1]=r[t+1],ft[2]=r[t+2],ft[3]=r[t+3],ft[4]=r[t+4],ft[5]=r[t+5],ft[6]=r[t+6],ft[7]=r[t+7],No[0]}var uh=BigInt(Number.MAX_SAFE_INTEGER),fh=BigInt(Number.MIN_SAFE_INTEGER),kt=class r{lo;hi;constructor(t,e){this.lo=t|0,this.hi=e|0}toNumber(t=!1){if(!t&&this.hi>>>31>0){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(e+n*4294967296)}return this.lo+this.hi*4294967296}toBigInt(t=!1){if(t)return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n);if(this.hi>>>31){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(BigInt(e)+(BigInt(n)<<32n))}return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n)}toString(t=!1){return this.toBigInt(t).toString()}zzEncode(){let t=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^t)>>>0,this.lo=(this.lo<<1^t)>>>0,this}zzDecode(){let t=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^t)>>>0,this.hi=(this.hi>>>1^t)>>>0,this}length(){let t=this.lo,e=(this.lo>>>28|this.hi<<4)>>>0,n=this.hi>>>24;return n===0?e===0?t<16384?t<128?1:2:t<2097152?3:4:e<16384?e<128?5:6:e<2097152?7:8:n<128?9:10}static fromBigInt(t){if(t===0n)return Oe;if(t<uh&&t>fh)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>La&&(s=0n,++n>La&&(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 kt(0,0);Oe.toBigInt=function(){return 0n};Oe.zzEncode=Oe.zzDecode=function(){return this};Oe.length=function(){return 1};var La=4294967296n;function Ra(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 _a(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 To(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 Ot(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function kn(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var Uo=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,Ot(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 Ot(this,4);return kn(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Ot(this,4);return kn(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Ot(this,4);let t=Na(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Ot(this,4);let t=Ua(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 Ot(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return _a(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw Ot(this,t);this.pos+=t}else do if(this.pos>=this.len)throw Ot(this);while((this.buf[this.pos++]&128)!==0);return this}skipType(t){switch(t){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;(t=this.uint32()&7)!==4;)this.skipType(t);break;case 5:this.skip(4);break;default:throw Error(`invalid wire type ${t} at offset ${this.pos}`)}return this}readLongVarint(){let t=new kt(0,0),e=0;if(this.len-this.pos>4){for(;e<4;++e)if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t;if(t.lo=(t.lo|(this.buf[this.pos]&127)<<28)>>>0,t.hi=(t.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return t;e=0}else{for(;e<3;++e){if(this.pos>=this.len)throw Ot(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 Ot(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 Ot(this,8);let t=kn(this.buf,this.pos+=4),e=kn(this.buf,this.pos+=4);return new kt(t,e)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){let t=Ia(this.buf,this.pos);return this.pos+=Or(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 Uo(r instanceof Uint8Array?r:r.subarray())}function In(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 St(i);s+i>t&&(n=St(t),s=0);let a=n.subarray(s,s+=i);return(s&7)!==0&&(s=(s|7)+1),a}}var Ve=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function _o(){}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}},hh=Ro();function dh(r){return globalThis.Buffer!=null?St(r):hh(r)}var Hr=class{len;head;tail;states;constructor(){this.len=0,this.head=new Ve(_o,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 Oo((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(Cn,10,kt.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=kt.fromBigInt(t);return this._push(Cn,e.length(),e)}uint64Number(t){return this._push(ka,Or(t),t)}uint64String(t){return this.uint64(BigInt(t))}int64(t){return this.uint64(t)}int64Number(t){return this.uint64Number(t)}int64String(t){return this.uint64String(t)}sint64(t){let e=kt.fromBigInt(t).zzEncode();return this._push(Cn,e.length(),e)}sint64Number(t){let e=kt.fromNumber(t).zzEncode();return this._push(Cn,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(Do,1,t?1:0)}fixed32(t){return this._push(Vr,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=kt.fromBigInt(t);return this._push(Vr,4,e.lo)._push(Vr,4,e.hi)}fixed64Number(t){let e=kt.fromNumber(t);return this._push(Vr,4,e.lo)._push(Vr,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(Ca,4,t)}double(t){return this._push(Ta,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(Do,1,0):this.uint32(e)._push(gh,e,t)}string(t){let e=Ra(t);return e!==0?this.uint32(e)._push(To,e,t):this._push(Do,1,0)}fork(){return this.states=new Ko(this),this.head=this.tail=new Ve(_o,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(_o,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=dh(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function Do(r,t,e){t[e]=r&255}function ph(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var Oo=class extends Ve{next;constructor(t,e){super(ph,t,e),this.next=void 0}};function Cn(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 Vr(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 gh(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(Hr.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(yh,t,r),this},Hr.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(mh,t,r),this});function yh(r,t,e){t.set(r,e)}function mh(r,t,e){r.length<40?To(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(V(r),e)}function Vo(){return new Hr}function Nn(r,t){let e=Vo();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var dr;(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"})(dr||(dr={}));function Tn(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function Ho(r){function t(s){if(r[s.toString()]==null)throw new Error("Invalid enum value");return r[s]}let e=function(o,i){let a=t(o);i.int32(a)},n=function(o){let i=o.int32();return t(i)};return Tn("enum",dr.VARINT,e,n)}function Un(r,t){return Tn("message",dr.LENGTH_DELIMITED,r,t)}var nt;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.secp256k1="secp256k1",r.ECDSA="ECDSA"})(nt||(nt={}));var Po;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1",r[r.ECDSA=3]="ECDSA"})(Po||(Po={}));(function(r){r.codec=()=>Ho(Po)})(nt||(nt={}));var xe;(function(r){let t;r.codec=()=>(t==null&&(t=Un((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),nt.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=nt.codec().decode(e);break}case 2:{o.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return o})),t),r.encode=e=>Nn(e,r.codec()),r.decode=(e,n)=>In(e,r.codec(),n)})(xe||(xe={}));var Pr;(function(r){let t;r.codec=()=>(t==null&&(t=Un((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),nt.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=nt.codec().decode(e);break}case 2:{o.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return o})),t),r.encode=e=>Nn(e,r.codec()),r.decode=(e,n)=>In(e,r.codec(),n)})(Pr||(Pr={}));function He(r){if(isNaN(r)||r<=0)throw new N("random bytes length must be a Number bigger than 0");return ur(r)}var Fr={};ut(Fr,{MAX_RSA_KEY_SIZE:()=>Fo,generateRSAKeyPair:()=>Pa,jwkToJWKKeyPair:()=>Ma,jwkToPkcs1:()=>Eh,jwkToPkix:()=>Go,jwkToRSAPrivateKey:()=>Zo,pkcs1MessageToJwk:()=>jo,pkcs1MessageToRSAPrivateKey:()=>Ln,pkcs1ToJwk:()=>vh,pkcs1ToRSAPrivateKey:()=>zo,pkixMessageToJwk:()=>$o,pkixMessageToRSAPublicKey:()=>Wo,pkixToJwk:()=>Bh,pkixToRSAPublicKey:()=>Ha});var wh=new Uint32Array([1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298]),ve=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),Ee=new Uint32Array(64),Mo=class extends ue{constructor(){super(64,32,8,!1),this.A=ve[0]|0,this.B=ve[1]|0,this.C=ve[2]|0,this.D=ve[3]|0,this.E=ve[4]|0,this.F=ve[5]|0,this.G=ve[6]|0,this.H=ve[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)Ee[u]=t.getUint32(e,!1);for(let u=16;u<64;u++){let h=Ee[u-15],m=Ee[u-2],w=Rt(h,7)^Rt(h,18)^h>>>3,y=Rt(m,17)^Rt(m,19)^m>>>10;Ee[u]=y+Ee[u-7]+w+Ee[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=Rt(a,6)^Rt(a,11)^Rt(a,25),m=l+h+pn(a,c,f)+wh[u]+Ee[u]|0,y=(Rt(n,2)^Rt(n,13)^Rt(n,22))+gn(n,s,o)|0;l=f,f=c,c=a,a=i+m|0,i=o,o=s,s=n,n=m+y|0}n=n+this.A|0,s=s+this.B|0,o=o+this.C|0,i=i+this.D|0,a=a+this.E|0,c=c+this.F|0,f=f+this.G|0,l=l+this.H|0,this.set(n,s,o,i,a,c,f,l)}roundClean(){Ee.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var Be=lr(()=>new Mo);var pr=class{type="RSA";jwk;_raw;_multihash;constructor(t,e){this.jwk=t,this._multihash=e}get raw(){return this._raw==null&&(this._raw=Fr.jwkToPkix(this.jwk)),this._raw}toMultihash(){return this._multihash}toCID(){return It.createV1(114,this._multihash)}toString(){return Q.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:xt(this.raw,t.raw)}verify(t,e){return Va(this.jwk,e,t)}},Mr=class{type="RSA";jwk;_raw;publicKey;constructor(t,e){this.jwk=t,this.publicKey=e}get raw(){return this._raw==null&&(this._raw=Fr.jwkToPkcs1(this.jwk)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:xt(this.raw,t.raw)}sign(t){return Oa(this.jwk,t)}};var Fo=8192,qo=18,bh=1062,xh=Uint8Array.from([48,13,6,9,42,134,72,134,247,13,1,1,1,5,0]);function vh(r){let t=Ut(r);return jo(t)}function jo(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 Eh(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 N("JWK was missing components");return Lt([gt(Uint8Array.from([0])),gt(V(r.n,"base64url")),gt(V(r.e,"base64url")),gt(V(r.d,"base64url")),gt(V(r.p,"base64url")),gt(V(r.q,"base64url")),gt(V(r.dp,"base64url")),gt(V(r.dq,"base64url")),gt(V(r.qi,"base64url"))]).subarray()}function Bh(r){let t=Ut(r,{offset:0});return $o(t)}function $o(r){let t=Ut(r[1],{offset:0});return{kty:"RSA",n:q(t[0],"base64url"),e:q(t[1],"base64url")}}function Go(r){if(r.n==null||r.e==null)throw new N("JWK was missing components");return Lt([xh,Ur(Lt([gt(V(r.n,"base64url")),gt(V(r.e,"base64url"))]))]).subarray()}function zo(r){let t=Ut(r);return Ln(t)}function Ln(r){let t=jo(r);return Zo(t)}function Ha(r,t){if(r.byteLength>=bh)throw new We("Key size is too large");let e=Ut(r,{offset:0});return Wo(e,r,t)}function Wo(r,t,e){let n=$o(r);if(e==null){let s=Be(xe.encode({Type:nt.RSA,Data:t}));e=Tt(qo,s)}return new pr(n,e)}function Zo(r){if(qa(r)>Fo)throw new N("Key size is too large");let t=Ma(r),e=Be(xe.encode({Type:nt.RSA,Data:Go(t.publicKey)})),n=Tt(qo,e);return new Mr(t.privateKey,new pr(t.publicKey,n))}async function Pa(r){if(r>Fo)throw new N("Key size is too large");let t=await Fa(r),e=Be(xe.encode({Type:nt.RSA,Data:Go(t.publicKey)})),n=Tt(qo,e);return new Mr(t.privateKey,new pr(t.publicKey,n))}function Ma(r){if(r==null)throw new N("Missing key parameter");return{privateKey:r,publicKey:{kty:r.kty,n:r.n,e:r.e}}}async function Fa(r){let t=await bt.get().subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:r,publicExponent:new Uint8Array([1,0,1]),hash:{name:"SHA-256"}},!0,["sign","verify"]),e=await Ah(t);return{privateKey:e[0],publicKey:e[1]}}async function Oa(r,t){let e=await bt.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await bt.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},e,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(n,0,n.byteLength)}async function Va(r,t,e){let n=await bt.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return bt.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,t,e instanceof Uint8Array?e:e.subarray())}async function Ah(r){if(r.privateKey==null||r.publicKey==null)throw new N("Private and public key are required");return Promise.all([bt.get().subtle.exportKey("jwk",r.privateKey),bt.get().subtle.exportKey("jwk",r.publicKey)])}function qa(r){if(r.kty!=="RSA")throw new N("invalid key type");if(r.n==null)throw new N("invalid key modulus");return V(r.n,"base64url").length*8}var Rn=class extends cr{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,hn(t);let n=le(e);if(this.iHash=t.create(),typeof this.iHash.update!="function")throw new Error("Expected instance of class which extends utils.Hash");this.blockLen=this.iHash.blockLen,this.outputLen=this.iHash.outputLen;let s=this.blockLen,o=new Uint8Array(s);o.set(n.length>s?t.create().update(n).digest():n);for(let i=0;i<o.length;i++)o[i]^=54;this.iHash.update(o),this.oHash=t.create();for(let i=0;i<o.length;i++)o[i]^=106;this.oHash.update(o),o.fill(0)}update(t){return ar(this),this.iHash.update(t),this}digestInto(t){ar(this),ir(t,this.outputLen),this.finished=!0,this.iHash.digestInto(t),this.oHash.update(t),this.oHash.digestInto(t),this.destroy()}digest(){let t=new Uint8Array(this.oHash.outputLen);return this.digestInto(t),t}_cloneInto(t){t||(t=Object.create(Object.getPrototypeOf(this),{}));let{oHash:e,iHash:n,finished:s,destroyed:o,blockLen:i,outputLen:a}=this;return t=t,t.finished=s,t.destroyed=o,t.blockLen=i,t.outputLen=a,t.oHash=e._cloneInto(t.oHash),t.iHash=n._cloneInto(t.iHash),t}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},qr=(r,t,e)=>new Rn(r,t).update(e).digest();qr.create=(r,t)=>new Rn(r,t);function ja(r){r.lowS!==void 0&&_t("lowS",r.lowS),r.prehash!==void 0&&_t("prehash",r.prehash)}function Sh(r){let t=_r(r);Mt(t,{a:"field",b:"field"},{allowedPrivateKeyLengths:"array",wrapPrivateKey:"boolean",isTorsionFree:"function",clearCofactor:"function",allowInfinityPoint:"boolean",fromBytes:"function",toBytes:"function"});let{endo:e,Fp:n,a:s}=t;if(e){if(!n.eql(s,n.ZERO))throw new Error("invalid endomorphism, can only be defined for Koblitz curves that have a=0");if(typeof e!="object"||typeof e.beta!="bigint"||typeof e.splitScalar!="function")throw new Error("invalid endomorphism, expected beta: bigint and splitScalar: function")}return Object.freeze({...t})}var{bytesToNumberBE:kh,hexToBytes:Ih}=bn,Jo=class extends Error{constructor(t=""){super(t)}},Yt={Err:Jo,_tlv:{encode:(r,t)=>{let{Err:e}=Yt;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=Le(n);if(s.length/2&128)throw new e("tlv.encode: long form length too big");let o=n>127?Le(s.length/2|128):"";return Le(r)+o+s+t},decode(r,t){let{Err:e}=Yt,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}=Yt;if(r<Xt)throw new t("integer: negative integers are not allowed");let e=Le(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}=Yt;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 kh(r)}},toSig(r){let{Err:t,_int:e,_tlv:n}=Yt,s=typeof r=="string"?Ih(r):r;fr(s);let{v:o,l:i}=n.decode(48,s);if(i.length)throw new t("invalid signature: left bytes after parsing");let{v:a,l:c}=n.decode(2,o),{v:f,l}=n.decode(2,c);if(l.length)throw new t("invalid signature: left bytes after parsing");return{r:e.decode(a),s:e.decode(f)}},hexFromSig(r){let{_tlv:t,_int:e}=Yt,n=t.encode(2,e.encode(r.r)),s=t.encode(2,e.encode(r.s)),o=n+s;return t.encode(48,o)}},Xt=BigInt(0),it=BigInt(1),vy=BigInt(2),$a=BigInt(3),Ey=BigInt(4);function Ch(r){let t=Sh(r),{Fp:e}=t,n=me(t.n,t.nBitLength),s=t.toBytes||((y,d,b)=>{let E=d.toAffine();return Jt(Uint8Array.from([4]),e.toBytes(E.x),e.toBytes(E.y))}),o=t.fromBytes||(y=>{let d=y.subarray(1),b=e.fromBytes(d.subarray(0,e.BYTES)),E=e.fromBytes(d.subarray(e.BYTES,2*e.BYTES));return{x:b,y:E}});function i(y){let{a:d,b}=t,E=e.sqr(y),p=e.mul(E,y);return e.add(e.add(p,e.mul(y,d)),b)}if(!e.eql(e.sqr(t.Gy),i(t.Gx)))throw new Error("bad generator point: equation left != right");function a(y){return Lr(y,it,t.n)}function c(y){let{allowedPrivateKeyLengths:d,nByteLength:b,wrapPrivateKey:E,n:p}=t;if(d&&typeof y!="bigint"){if(pe(y)&&(y=Wt(y)),typeof y!="string"||!d.includes(y.length))throw new Error("invalid private key");y=y.padStart(b*2,"0")}let S;try{S=typeof y=="bigint"?y:Zt(Y("private key",y,b))}catch{throw new Error("invalid private key, expected hex or "+b+" bytes, got "+typeof y)}return E&&(S=G(S,p)),vt("private key",S,it,p),S}function f(y){if(!(y instanceof h))throw new Error("ProjectivePoint expected")}let l=De((y,d)=>{let{px:b,py:E,pz:p}=y;if(e.eql(p,e.ONE))return{x:b,y:E};let S=y.is0();d==null&&(d=S?e.ONE:e.inv(p));let R=e.mul(b,d),L=e.mul(E,d),I=e.mul(p,d);if(S)return{x:e.ZERO,y:e.ZERO};if(!e.eql(I,e.ONE))throw new Error("invZ was invalid");return{x:R,y:L}}),u=De(y=>{if(y.is0()){if(t.allowInfinityPoint&&!e.is0(y.py))return;throw new Error("bad point: ZERO")}let{x:d,y:b}=y.toAffine();if(!e.isValid(d)||!e.isValid(b))throw new Error("bad point: x or y not FE");let E=e.sqr(b),p=i(d);if(!e.eql(E,p))throw new Error("bad point: equation left != right");if(!y.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});class h{constructor(d,b,E){if(this.px=d,this.py=b,this.pz=E,d==null||!e.isValid(d))throw new Error("x required");if(b==null||!e.isValid(b))throw new Error("y required");if(E==null||!e.isValid(E))throw new Error("z required");Object.freeze(this)}static fromAffine(d){let{x:b,y:E}=d||{};if(!d||!e.isValid(b)||!e.isValid(E))throw new Error("invalid affine point");if(d instanceof h)throw new Error("projective point not allowed");let p=S=>e.eql(S,e.ZERO);return p(b)&&p(E)?h.ZERO:new h(b,E,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(d){let b=e.invertBatch(d.map(E=>E.pz));return d.map((E,p)=>E.toAffine(b[p])).map(h.fromAffine)}static fromHex(d){let b=h.fromAffine(o(Y("pointHex",d)));return b.assertValidity(),b}static fromPrivateKey(d){return h.BASE.multiply(c(d))}static msm(d,b){return Bn(h,n,d,b)}_setWindowSize(d){w.setWindowSize(this,d)}assertValidity(){u(this)}hasEvenY(){let{y:d}=this.toAffine();if(e.isOdd)return!e.isOdd(d);throw new Error("Field doesn't support isOdd")}equals(d){f(d);let{px:b,py:E,pz:p}=this,{px:S,py:R,pz:L}=d,I=e.eql(e.mul(b,L),e.mul(S,p)),U=e.eql(e.mul(E,L),e.mul(R,p));return I&&U}negate(){return new h(this.px,e.neg(this.py),this.pz)}double(){let{a:d,b}=t,E=e.mul(b,$a),{px:p,py:S,pz:R}=this,L=e.ZERO,I=e.ZERO,U=e.ZERO,C=e.mul(p,p),W=e.mul(S,S),j=e.mul(R,R),P=e.mul(p,S);return P=e.add(P,P),U=e.mul(p,R),U=e.add(U,U),L=e.mul(d,U),I=e.mul(E,j),I=e.add(L,I),L=e.sub(W,I),I=e.add(W,I),I=e.mul(L,I),L=e.mul(P,L),U=e.mul(E,U),j=e.mul(d,j),P=e.sub(C,j),P=e.mul(d,P),P=e.add(P,U),U=e.add(C,C),C=e.add(U,C),C=e.add(C,j),C=e.mul(C,P),I=e.add(I,C),j=e.mul(S,R),j=e.add(j,j),C=e.mul(j,P),L=e.sub(L,C),U=e.mul(j,W),U=e.add(U,U),U=e.add(U,U),new h(L,I,U)}add(d){f(d);let{px:b,py:E,pz:p}=this,{px:S,py:R,pz:L}=d,I=e.ZERO,U=e.ZERO,C=e.ZERO,W=t.a,j=e.mul(t.b,$a),P=e.mul(b,S),et=e.mul(E,R),B=e.mul(p,L),T=e.add(b,E),x=e.add(S,R);T=e.mul(T,x),x=e.add(P,et),T=e.sub(T,x),x=e.add(b,p);let g=e.add(S,L);return x=e.mul(x,g),g=e.add(P,B),x=e.sub(x,g),g=e.add(E,p),I=e.add(R,L),g=e.mul(g,I),I=e.add(et,B),g=e.sub(g,I),C=e.mul(W,x),I=e.mul(j,B),C=e.add(I,C),I=e.sub(et,C),C=e.add(et,C),U=e.mul(I,C),et=e.add(P,P),et=e.add(et,P),B=e.mul(W,B),x=e.mul(j,x),et=e.add(et,B),B=e.sub(P,B),B=e.mul(W,B),x=e.add(x,B),P=e.mul(et,x),U=e.add(U,P),P=e.mul(g,x),I=e.mul(T,I),I=e.sub(I,P),P=e.mul(T,et),C=e.mul(g,C),C=e.add(C,P),new h(I,U,C)}subtract(d){return this.add(d.negate())}is0(){return this.equals(h.ZERO)}wNAF(d){return w.wNAFCached(this,d,h.normalizeZ)}multiplyUnsafe(d){let{endo:b,n:E}=t;vt("scalar",d,Xt,E);let p=h.ZERO;if(d===Xt)return p;if(this.is0()||d===it)return this;if(!b||w.hasPrecomputes(this))return w.wNAFCachedUnsafe(this,d,h.normalizeZ);let{k1neg:S,k1:R,k2neg:L,k2:I}=b.splitScalar(d),U=p,C=p,W=this;for(;R>Xt||I>Xt;)R&it&&(U=U.add(W)),I&it&&(C=C.add(W)),W=W.double(),R>>=it,I>>=it;return S&&(U=U.negate()),L&&(C=C.negate()),C=new h(e.mul(C.px,b.beta),C.py,C.pz),U.add(C)}multiply(d){let{endo:b,n:E}=t;vt("scalar",d,it,E);let p,S;if(b){let{k1neg:R,k1:L,k2neg:I,k2:U}=b.splitScalar(d),{p:C,f:W}=this.wNAF(L),{p:j,f:P}=this.wNAF(U);C=w.constTimeNegate(R,C),j=w.constTimeNegate(I,j),j=new h(e.mul(j.px,b.beta),j.py,j.pz),p=C.add(j),S=W.add(P)}else{let{p:R,f:L}=this.wNAF(d);p=R,S=L}return h.normalizeZ([p,S])[0]}multiplyAndAddUnsafe(d,b,E){let p=h.BASE,S=(L,I)=>I===Xt||I===it||!L.equals(p)?L.multiplyUnsafe(I):L.multiply(I),R=S(this,b).add(S(d,E));return R.is0()?void 0:R}toAffine(d){return l(this,d)}isTorsionFree(){let{h:d,isTorsionFree:b}=t;if(d===it)return!0;if(b)return b(h,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h:d,clearCofactor:b}=t;return d===it?this:b?b(h,this):this.multiplyUnsafe(t.h)}toRawBytes(d=!0){return _t("isCompressed",d),this.assertValidity(),s(h,this,d)}toHex(d=!0){return _t("isCompressed",d),Wt(this.toRawBytes(d))}}h.BASE=new h(t.Gx,t.Gy,e.ONE),h.ZERO=new h(e.ZERO,e.ONE,e.ZERO);let m=t.nBitLength,w=En(h,t.endo?Math.ceil(m/2):m);return{CURVE:t,ProjectivePoint:h,normPrivateKeyToScalar:c,weierstrassEquation:i,isWithinCurveOrder:a}}function Nh(r){let t=_r(r);return Mt(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function Ga(r){let t=Nh(r),{Fp:e,n}=t,s=e.BYTES+1,o=2*e.BYTES+1;function i(B){return G(B,n)}function a(B){return xn(B,n)}let{ProjectivePoint:c,normPrivateKeyToScalar:f,weierstrassEquation:l,isWithinCurveOrder:u}=Ch({...t,toBytes(B,T,x){let g=T.toAffine(),v=e.toBytes(g.x),k=Jt;return _t("isCompressed",x),x?k(Uint8Array.from([T.hasEvenY()?2:3]),v):k(Uint8Array.from([4]),v,e.toBytes(g.y))},fromBytes(B){let T=B.length,x=B[0],g=B.subarray(1);if(T===s&&(x===2||x===3)){let v=Zt(g);if(!Lr(v,it,e.ORDER))throw new Error("Point is not on curve");let k=l(v),_;try{_=e.sqrt(k)}catch(F){let K=F instanceof Error?": "+F.message:"";throw new Error("Point is not on curve"+K)}let D=(_&it)===it;return(x&1)===1!==D&&(_=e.neg(_)),{x:v,y:_}}else if(T===o&&x===4){let v=e.fromBytes(g.subarray(0,e.BYTES)),k=e.fromBytes(g.subarray(e.BYTES,2*e.BYTES));return{x:v,y:k}}else{let v=s,k=o;throw new Error("invalid Point, expected length of "+v+", or uncompressed "+k+", got "+T)}}}),h=B=>Wt(ye(B,t.nByteLength));function m(B){let T=n>>it;return B>T}function w(B){return m(B)?i(-B):B}let y=(B,T,x)=>Zt(B.slice(T,x));class d{constructor(T,x,g){this.r=T,this.s=x,this.recovery=g,this.assertValidity()}static fromCompact(T){let x=t.nByteLength;return T=Y("compactSignature",T,x*2),new d(y(T,0,x),y(T,x,2*x))}static fromDER(T){let{r:x,s:g}=Yt.toSig(Y("DER",T));return new d(x,g)}assertValidity(){vt("r",this.r,it,n),vt("s",this.s,it,n)}addRecoveryBit(T){return new d(this.r,this.s,T)}recoverPublicKey(T){let{r:x,s:g,recovery:v}=this,k=L(Y("msgHash",T));if(v==null||![0,1,2,3].includes(v))throw new Error("recovery id invalid");let _=v===2||v===3?x+t.n:x;if(_>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let D=(v&1)===0?"02":"03",H=c.fromHex(D+h(_)),F=a(_),K=i(-k*F),$=i(g*F),z=c.BASE.multiplyAndAddUnsafe(H,K,$);if(!z)throw new Error("point at infinify");return z.assertValidity(),z}hasHighS(){return m(this.s)}normalizeS(){return this.hasHighS()?new d(this.r,i(-this.s),this.recovery):this}toDERRawBytes(){return Re(this.toDERHex())}toDERHex(){return Yt.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return Re(this.toCompactHex())}toCompactHex(){return h(this.r)+h(this.s)}}let b={isValidPrivateKey(B){try{return f(B),!0}catch{return!1}},normPrivateKeyToScalar:f,randomPrivateKey:()=>{let B=xo(t.n);return ha(t.randomBytes(B),t.n)},precompute(B=8,T=c.BASE){return T._setWindowSize(B),T.multiply(BigInt(3)),T}};function E(B,T=!0){return c.fromPrivateKey(B).toRawBytes(T)}function p(B){let T=pe(B),x=typeof B=="string",g=(T||x)&&B.length;return T?g===s||g===o:x?g===2*s||g===2*o:B instanceof c}function S(B,T,x=!0){if(p(B))throw new Error("first arg must be private key");if(!p(T))throw new Error("second arg must be public key");return c.fromHex(T).multiply(f(B)).toRawBytes(x)}let R=t.bits2int||function(B){if(B.length>8192)throw new Error("input is too large");let T=Zt(B),x=B.length*8-t.nBitLength;return x>0?T>>BigInt(x):T},L=t.bits2int_modN||function(B){return i(R(B))},I=Rr(t.nBitLength);function U(B){return vt("num < 2^"+t.nBitLength,B,Xt,I),ye(B,t.nByteLength)}function C(B,T,x=W){if(["recovered","canonical"].some(ot=>ot in x))throw new Error("sign() legacy options not supported");let{hash:g,randomBytes:v}=t,{lowS:k,prehash:_,extraEntropy:D}=x;k==null&&(k=!0),B=Y("msgHash",B),ja(x),_&&(B=Y("prehashed msgHash",g(B)));let H=L(B),F=f(T),K=[U(F),U(H)];if(D!=null&&D!==!1){let ot=D===!0?v(e.BYTES):D;K.push(Y("extraEntropy",ot))}let $=Jt(...K),z=H;function st(ot){let at=R(ot);if(!u(at))return;let lt=a(at),wt=c.BASE.multiply(at).toAffine(),dt=i(wt.x);if(dt===Xt)return;let Pt=i(lt*i(z+dt*F));if(Pt===Xt)return;let jt=(wt.x===dt?0:2)|Number(wt.y&it),xr=Pt;return k&&m(Pt)&&(xr=w(Pt),jt^=1),new d(dt,xr,jt)}return{seed:$,k2sig:st}}let W={lowS:t.lowS,prehash:!1},j={lowS:t.lowS,prehash:!1};function P(B,T,x=W){let{seed:g,k2sig:v}=C(B,T,x),k=t;return yo(k.hash.outputLen,k.nByteLength,k.hmac)(g,v)}c.BASE._setWindowSize(8);function et(B,T,x,g=j){let v=B;T=Y("msgHash",T),x=Y("publicKey",x);let{lowS:k,prehash:_,format:D}=g;if(ja(g),"strict"in g)throw new Error("options.strict was renamed to lowS");if(D!==void 0&&D!=="compact"&&D!=="der")throw new Error("format must be compact or der");let H=typeof v=="string"||pe(v),F=!H&&!D&&typeof v=="object"&&v!==null&&typeof v.r=="bigint"&&typeof v.s=="bigint";if(!H&&!F)throw new Error("invalid signature, expected Uint8Array, hex string or Signature instance");let K,$;try{if(F&&(K=new d(v.r,v.s)),H){try{D!=="compact"&&(K=d.fromDER(v))}catch(jt){if(!(jt instanceof Yt.Err))throw jt}!K&&D!=="der"&&(K=d.fromCompact(v))}$=c.fromHex(x)}catch{return!1}if(!K||k&&K.hasHighS())return!1;_&&(T=t.hash(T));let{r:z,s:st}=K,ot=L(T),at=a(st),lt=i(ot*at),wt=i(z*at),dt=c.BASE.multiplyAndAddUnsafe($,lt,wt)?.toAffine();return dt?i(dt.x)===z:!1}return{CURVE:t,getPublicKey:E,getSharedSecret:S,sign:P,verify:et,ProjectivePoint:c,Signature:d,utils:b}}function Th(r){return{hash:r,hmac:(t,...e)=>qr(r,t,co(...e)),randomBytes:ur}}function za(r,t){let e=n=>Ga({...r,...Th(n)});return{...e(t),create:e}}var Ja=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),Wa=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),Uh=BigInt(1),Yo=BigInt(2),Za=(r,t)=>(r+t/Yo)/t;function Lh(r){let t=Ja,e=BigInt(3),n=BigInt(6),s=BigInt(11),o=BigInt(22),i=BigInt(23),a=BigInt(44),c=BigInt(88),f=r*r*r%t,l=f*f*r%t,u=J(l,e,t)*l%t,h=J(u,e,t)*l%t,m=J(h,Yo,t)*f%t,w=J(m,s,t)*m%t,y=J(w,o,t)*w%t,d=J(y,a,t)*y%t,b=J(d,c,t)*d%t,E=J(b,a,t)*y%t,p=J(E,e,t)*l%t,S=J(p,i,t)*w%t,R=J(S,n,t)*f%t,L=J(R,Yo,t);if(!Xo.eql(Xo.sqr(L),r))throw new Error("Cannot find square root");return L}var Xo=me(Ja,void 0,void 0,{sqrt:Lh}),Vt=za({a:BigInt(0),b:BigInt(7),Fp:Xo,n:Wa,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=Wa,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-Uh*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),s=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),o=e,i=BigInt("0x100000000000000000000000000000000"),a=Za(o*r,t),c=Za(-n*r,t),f=G(r-a*e-c*s,t),l=G(-a*n-c*o,t),u=f>i,h=l>i;if(u&&(f=t-f),h&&(l=t-l),f>i||l>i)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:u,k1:f,k2neg:h,k2:l}}}},Be),Uy=BigInt(0);var Ly=Vt.ProjectivePoint;function Qo(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}var Ya=32;function Xa(r,t){let e=rr.digest(t instanceof Uint8Array?t:t.subarray());if(Qo(e))return e.then(({digest:n})=>Vt.sign(n,r).toDERRawBytes()).catch(n=>{throw new vr(String(n))});try{return Vt.sign(e.digest,r).toDERRawBytes()}catch(n){throw new vr(String(n))}}function Qa(r,t,e){let n=rr.digest(e instanceof Uint8Array?e:e.subarray());if(Qo(n))return n.then(({digest:s})=>Vt.verify(t,s,r)).catch(s=>{throw new Er(String(s))});try{return Vt.verify(t,n.digest,r)}catch(s){throw new Er(String(s))}}var _n=class{type="secp256k1";raw;_key;constructor(t){this._key=rc(t),this.raw=tc(this._key)}toMultihash(){return Ce.digest(sr(this))}toCID(){return It.createV1(114,this.toMultihash())}toString(){return Q.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:xt(this.raw,t.raw)}verify(t,e){return Qa(this._key,e,t)}},Dn=class{type="secp256k1";raw;publicKey;constructor(t,e){this.raw=ec(t),this.publicKey=new _n(e??nc(t))}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:xt(this.raw,t.raw)}sign(t){return Xa(this.raw,t)}};function ti(r){return new Dn(r)}function tc(r){return Vt.ProjectivePoint.fromHex(r).toRawBytes(!0)}function ec(r){try{return Vt.getPublicKey(r,!0),r}catch(t){throw new Br(String(t))}}function rc(r){try{return Vt.ProjectivePoint.fromHex(r),r}catch(t){throw new We(String(t))}}function nc(r){try{return Vt.getPublicKey(r,!0)}catch(t){throw new Br(String(t))}}function sr(r){return xe.encode({Type:nt[r.type],Data:r.raw})}function sc(r){let t=Pr.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case nt.RSA:return zo(e);case nt.Ed25519:return Io(e);case nt.secp256k1:return ti(e);case nt.ECDSA:return Yi(e);default:throw new Ze}}function oc(r){if(r.byteLength===Kt)return Io(r);if(r.byteLength===Ya)return ti(r);let t=Ut(r),e=t[2]?.[0];if(e===Gi||e===zi||e===Wi)return ao(t);if(t.length>8)return Ln(t);throw new N("Could not extract private key from raw bytes")}function Pe(r){return Pr.encode({Type:nt[r.type],Data:r.raw})}function ic(r,t,e,n){hn(r);let s=sa({dkLen:32,asyncTick:10},n),{c:o,dkLen:i,asyncTick:a}=s;if(or(o),or(i),or(a),o<1)throw new Error("PBKDF2: iterations (c) should be >= 1");let c=le(t),f=le(e),l=new Uint8Array(i),u=qr.create(r,c),h=u._cloneInto().update(f);return{c:o,dkLen:i,asyncTick:a,DK:l,PRF:u,PRFSalt:h}}function ac(r,t,e,n,s){return r.destroy(),t.destroy(),n&&n.destroy(),s.fill(0),e}function cc(r,t,e,n){let{c:s,dkLen:o,DK:i,PRF:a,PRFSalt:c}=ic(r,t,e,n),f,l=new Uint8Array(4),u=Ue(l),h=new Uint8Array(a.outputLen);for(let m=1,w=0;w<o;m++,w+=a.outputLen){let y=i.subarray(w,w+a.outputLen);u.setInt32(0,m,!1),(f=c._cloneInto(f)).update(l).digestInto(h),y.set(h.subarray(0,y.length));for(let d=1;d<s;d++){a._cloneInto(f).update(h).digestInto(h);for(let b=0;b<y.length;b++)y[b]^=h[b]}}return ac(a,c,i,f,h)}async function Kn(r,t,e,n){let{c:s,dkLen:o,asyncTick:i,DK:a,PRF:c,PRFSalt:f}=ic(r,t,e,n),l,u=new Uint8Array(4),h=Ue(u),m=new Uint8Array(c.outputLen);for(let w=1,y=0;y<o;w++,y+=c.outputLen){let d=a.subarray(y,y+c.outputLen);h.setInt32(0,w,!1),(l=f._cloneInto(l)).update(u).digestInto(m),d.set(m.subarray(0,d.length)),await ra(s-1,i,()=>{c._cloneInto(l).update(m).digestInto(m);for(let b=0;b<d.length;b++)d[b]^=m[b]})}return ac(c,f,a,l,m)}var jr=new Uint32Array([1732584193,4023233417,2562383102,271733878,3285377520]),Ae=new Uint32Array(80),ei=class extends ue{constructor(){super(64,20,8,!1),this.A=jr[0]|0,this.B=jr[1]|0,this.C=jr[2]|0,this.D=jr[3]|0,this.E=jr[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)Ae[c]=t.getUint32(e,!1);for(let c=16;c<80;c++)Ae[c]=dn(Ae[c-3]^Ae[c-8]^Ae[c-14]^Ae[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=pn(s,o,i),l=1518500249):c<40?(f=s^o^i,l=1859775393):c<60?(f=gn(s,o,i),l=2400959708):(f=s^o^i,l=3395469782);let u=dn(n,5)+f+a+l+Ae[c]|0;a=i,i=o,o=dn(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(){Ae.fill(0)}destroy(){this.set(0,0,0,0,0),this.buffer.fill(0)}},lc=lr(()=>new ei);var uc={sha1:lc,"sha2-256":Be,"sha2-512":de};function $r(r,t,e,n,s){if(s!=="sha1"&&s!=="sha2-256"&&s!=="sha2-512"){let a=Object.keys(uc).join(" / ");throw new N(`Hash '${s}' is unknown or not supported. Must be ${a}`)}let o=uc[s],i=cc(o,r,t,{c:e,dkLen:n});return Ne.encode(i).substring(1)}var Qt="/",fc=new TextEncoder().encode(Qt),On=fc[0],Gr=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]!==On)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(Qt))}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=fc),this._buf[0]!==On){let t=new Uint8Array(this._buf.byteLength+1);t.fill(On,0,1),t.set(this._buf,1),this._buf=t}for(;this._buf.byteLength>1&&this._buf[this._buf.byteLength-1]===On;)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(Qt).slice(1)}type(){return Rh(this.baseNamespace())}name(){return _h(this.baseNamespace())}instance(t){return new r(this.toString()+":"+t)}path(){let t=this.parent().toString();return t.endsWith(Qt)||(t+=Qt),t+=this.type(),new r(t)}parent(){let t=this.list();return t.length===1?new r(Qt):new r(t.slice(0,-1).join(Qt))}child(t){return this.toString()===Qt?t:t.toString()===Qt?this:new r(this.toString()+t.toString(),!1)}isAncestorOf(t){return t.toString()===this.toString()?!1:t.toString().startsWith(this.toString())}isDecendantOf(t){return t.toString()===this.toString()?!1:this.toString().startsWith(t.toString())}isTopLevel(){return this.list().length===1}concat(...t){return r.withNamespaces([...this.namespaces(),...Dh(t.map(e=>e.namespaces()))])}};function Rh(r){let t=r.split(":");return t.length<2?"":t.slice(0,-1).join(":")}function _h(r){let t=r.split(":");return t[t.length-1]}function Dh(r){return[].concat(...r)}var xc=_s(bc(),1),vc=xc.default;var El=_s(Tc(),1);var mr={};ut(mr,{create:()=>Qh,derivedEmptyPasswordKey:()=>Pn});var Pn={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=bt.get();e*=8;async function c(u,h){let m=a.getRandomValues(new Uint8Array(o)),w=a.getRandomValues(new Uint8Array(n)),y={name:t,iv:w};typeof h=="string"&&(h=V(h));let d;if(h.length===0){d=await a.subtle.importKey("jwk",Pn,{name:"AES-GCM"},!0,["encrypt"]);try{let E={name:"PBKDF2",salt:m,iterations:i,hash:{name:s}},p=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);d=await a.subtle.deriveKey(E,p,{name:t,length:e},!0,["encrypt"])}catch{d=await a.subtle.importKey("jwk",Pn,{name:"AES-GCM"},!0,["encrypt"])}}else{let E={name:"PBKDF2",salt:m,iterations:i,hash:{name:s}},p=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);d=await a.subtle.deriveKey(E,p,{name:t,length:e},!0,["encrypt"])}let b=await a.subtle.encrypt(y,d,u);return er([m,y.iv,new Uint8Array(b)])}async function f(u,h){let m=u.subarray(0,o),w=u.subarray(o,o+n),y=u.subarray(o+n),d={name:t,iv:w};typeof h=="string"&&(h=V(h));let b;if(h.length===0)try{let p={name:"PBKDF2",salt:m,iterations:i,hash:{name:s}},S=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);b=await a.subtle.deriveKey(p,S,{name:t,length:e},!0,["decrypt"])}catch{b=await a.subtle.importKey("jwk",Pn,{name:"AES-GCM"},!0,["decrypt"])}else{let p={name:"PBKDF2",salt:m,iterations:i,hash:{name:s}},S=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);b=await a.subtle.deriveKey(p,S,{name:t,length:e},!0,["decrypt"])}let E=await a.subtle.decrypt(d,b,y);return new Uint8Array(E)}return{encrypt:c,decrypt:f}}var M=_s(Uc());function Me(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 Se(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 qn(...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 si(){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=Me(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,Me(o,8)-n}function Lc(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=Se(i,8,n),c=new Uint8Array(a);return c[0]|=128,a}let s=Se(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 Rc(r,t){if(r.byteLength!==t.byteLength)return!1;let e=new Uint8Array(r),n=new Uint8Array(t);for(let s=0;s<e.length;s++)if(e[s]!==n[s])return!1;return!0}function Bt(r,t){let e=r.toString(10);if(t<e.length)return"";let n=t-e.length,s=new Array(n);for(let i=0;i<n;i++)s[i]="0";return s.join("").concat(e)}var Ym=Math.log(2);function jn(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function oi(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 oe(r,t,e,n){return t instanceof Uint8Array?t.byteLength?e<0?(r.error="Wrong parameter: inputOffset less than zero",!1):n<0?(r.error="Wrong parameter: inputLength less than zero",!1):t.byteLength-e-n<0?(r.error="End of input reached before message was fully decoded (inconsistent offset and length values)",!1):!0:(r.error="Wrong parameter: inputBuffer has zero length",!1):(r.error="Wrong parameter: inputBuffer must be 'Uint8Array'",!1)}var Wr=class{constructor(){this.items=[]}write(t){this.items.push(t)}final(){return oi(this.items)}},zr=[new Uint8Array([1])],_c="0123456789";var br="",Ht=new ArrayBuffer(0),ii=new Uint8Array(0),Zr="EndOfContent",Kc="OCTET STRING",Oc="BIT STRING";function ie(r){var t;return t=class extends r{constructor(...n){var s;super(...n);let o=n[0]||{};this.isHexOnly=(s=o.isHexOnly)!==null&&s!==void 0?s:!1,this.valueHexView=o.valueHex?M.BufferSourceConverter.toUint8Array(o.valueHex):ii}get valueHex(){return this.valueHexView.slice().buffer}set valueHex(n){this.valueHexView=new Uint8Array(n)}fromBER(n,s,o){let i=n instanceof ArrayBuffer?new Uint8Array(n):n;if(!oe(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",Ht)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:M.Convert.ToHex(this.valueHexView)}}},t.NAME="hexBlock",t}var ee=class{constructor({blockLength:t=0,error:e=br,warnings:n=[],valueBeforeDecode:s=ii}={}){this.blockLength=t,this.error=e,this.warnings=n,this.valueBeforeDecodeView=M.BufferSourceConverter.toUint8Array(s)}static blockName(){return this.NAME}get valueBeforeDecode(){return this.valueBeforeDecodeView.slice().buffer}set valueBeforeDecode(t){this.valueBeforeDecodeView=new Uint8Array(t)}toJSON(){return{blockName:this.constructor.NAME,blockLength:this.blockLength,error:this.error,warnings:this.warnings,valueBeforeDecode:M.Convert.ToHex(this.valueBeforeDecodeView)}}};ee.NAME="baseBlock";var ht=class extends ee{fromBER(t,e,n){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}toBER(t,e){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}};ht.NAME="valueBlock";var $n=class extends ie(ee){constructor({idBlock:t={}}={}){var e,n,s,o;super(),t?(this.isHexOnly=(e=t.isHexOnly)!==null&&e!==void 0?e:!1,this.valueHexView=t.valueHex?M.BufferSourceConverter.toUint8Array(t.valueHex):ii,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",Ht}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=Se(this.tagNumber,7),o=new Uint8Array(s),i=s.byteLength,a=new Uint8Array(i+1);if(a[0]=e|31,!t){for(let c=0;c<i-1;c++)a[c+1]=o[c]|128;a[i]=o[i-1]}return a.buffer}let n=new Uint8Array(this.valueHexView.byteLength+1);if(n[0]=e|31,!t){let s=this.valueHexView;for(let o=0;o<s.length-1;o++)n[o+1]=s[o]|128;n[this.valueHexView.byteLength]=s[s.length-1]}return n.buffer}fromBER(t,e,n){let s=M.BufferSourceConverter.toUint8Array(t);if(!oe(this,s,e,n))return-1;let o=s.subarray(e,e+n);if(o.length===0)return this.error="Zero buffer length",-1;switch(o[0]&192){case 0:this.tagClass=1;break;case 64:this.tagClass=2;break;case 128:this.tagClass=3;break;case 192:this.tagClass=4;break;default:return this.error="Unknown tag class",-1}this.isConstructed=(o[0]&32)===32,this.isHexOnly=!1;let a=o[0]&31;if(a!==31)this.tagNumber=a,this.blockLength=1;else{let c=1,f=this.valueHexView=new Uint8Array(255),l=255;for(;o[c]&128;){if(f[c-1]=o[c]&127,c++,c>=o.length)return this.error="End of input reached before message was fully decoded",-1;if(c===l){l+=255;let h=new Uint8Array(l);for(let m=0;m<f.length;m++)h[m]=f[m];f=this.valueHexView=new Uint8Array(l)}}this.blockLength=c+1,f[c-1]=o[c]&127;let u=new Uint8Array(c);for(let h=0;h<c;h++)u[h]=f[h];f=this.valueHexView=new Uint8Array(c),f.set(u),this.blockLength<=9?this.tagNumber=Me(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}}};$n.NAME="identificationBlock";var Gn=class extends ee{constructor({lenBlock:t={}}={}){var e,n,s;super(),this.isIndefiniteForm=(e=t.isIndefiniteForm)!==null&&e!==void 0?e:!1,this.longFormUsed=(n=t.longFormUsed)!==null&&n!==void 0?n:!1,this.length=(s=t.length)!==null&&s!==void 0?s:0}fromBER(t,e,n){let s=M.BufferSourceConverter.toUint8Array(t);if(!oe(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=Me(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=Se(this.length,8);if(s.byteLength>127)return this.error="Too big length",Ht;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}}};Gn.NAME="lengthBlock";var A={},ct=class extends ee{constructor({name:t=br,optional:e=!1,primitiveSchema:n,...s}={},o){super(s),this.name=t,this.optional=e,n&&(this.primitiveSchema=n),this.idBlock=new $n(s),this.lenBlock=new Gn(s),this.valueBlock=o?new o(s):new ht(s)}fromBER(t,e,n){let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}toBER(t,e){let n=e||new Wr;e||Vc(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?Ht:n.final()}toJSON(){let t={...super.toJSON(),idBlock:this.idBlock.toJSON(),lenBlock:this.lenBlock.toJSON(),valueBlock:this.valueBlock.toJSON(),name:this.name,optional:this.optional};return this.primitiveSchema&&(t.primitiveSchema=this.primitiveSchema.toJSON()),t}toString(t="ascii"){return t==="ascii"?this.onAsciiEncoding():M.Convert.ToHex(this.toBER())}onAsciiEncoding(){return`${this.constructor.NAME} : ${M.Convert.ToHex(this.valueBlock.valueBeforeDecodeView)}`}isEqual(t){if(this===t)return!0;if(!(t instanceof this.constructor))return!1;let e=this.toBER(),n=t.toBER();return Rc(e,n)}};ct.NAME="BaseBlock";function Vc(r){if(r instanceof A.Constructed)for(let t of r.valueBlock.value)Vc(t)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var zn=class extends ct{constructor({value:t=br,...e}={},n){super(e,n),t&&this.fromString(t)}getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}fromBER(t,e,n){let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.fromBuffer(this.valueBlock.valueHexView),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}onAsciiEncoding(){return`${this.constructor.NAME} : '${this.valueBlock.value}'`}};zn.NAME="BaseStringBlock";var Wn=class extends ie(ht){constructor({isHexOnly:t=!0,...e}={}){super(e),this.isHexOnly=t}};Wn.NAME="PrimitiveValueBlock";var Hc,Zn=class extends ct{constructor(t={}){super(t,Wn),this.idBlock.isConstructed=!1}};Hc=Zn;A.Primitive=Hc;Zn.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 Ns(r,t=0,e=r.length){let n=t,s=new ct({},ht),o=new ee;if(!oe(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=ct;switch(s.idBlock.tagClass){case 1:if(s.idBlock.tagNumber>=37&&s.idBlock.isHexOnly===!1)return s.error="UNIVERSAL 37 and upper tags are reserved by ASN.1 standard",{offset:-1,result:s};switch(s.idBlock.tagNumber){case 0:if(s.idBlock.isConstructed&&s.lenBlock.length>0)return s.error="Type [UNIVERSAL 0] is reserved",{offset:-1,result:s};c=A.EndOfContent;break;case 1:c=A.Boolean;break;case 2:c=A.Integer;break;case 3:c=A.BitString;break;case 4:c=A.OctetString;break;case 5:c=A.Null;break;case 6:c=A.ObjectIdentifier;break;case 10:c=A.Enumerated;break;case 12:c=A.Utf8String;break;case 13:c=A.RelativeObjectIdentifier;break;case 14:c=A.TIME;break;case 15:return s.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:s};case 16:c=A.Sequence;break;case 17:c=A.Set;break;case 18:c=A.NumericString;break;case 19:c=A.PrintableString;break;case 20:c=A.TeletexString;break;case 21:c=A.VideotexString;break;case 22:c=A.IA5String;break;case 23:c=A.UTCTime;break;case 24:c=A.GeneralizedTime;break;case 25:c=A.GraphicString;break;case 26:c=A.VisibleString;break;case 27:c=A.GeneralString;break;case 28:c=A.UniversalString;break;case 29:c=A.CharacterString;break;case 30:c=A.BmpString;break;case 31:c=A.DATE;break;case 32:c=A.TimeOfDay;break;case 33:c=A.DateTime;break;case 34:c=A.Duration;break;default:{let f=s.idBlock.isConstructed?new A.Constructed:new A.Primitive;f.idBlock=s.idBlock,f.lenBlock=s.lenBlock,f.warnings=s.warnings,s=f}}break;case 2:case 3:case 4:default:c=s.idBlock.isConstructed?A.Constructed:A.Primitive}return s=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 Ts(r){if(!r.byteLength){let t=new ct({},ht);return t.error="Input buffer has zero length",{offset:-1,result:t}}return Ns(M.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function ld(r,t){return r?1:t}var Ft=class extends ht{constructor({value:t=[],isIndefiniteForm:e=!1,...n}={}){super(n),this.value=t,this.isIndefiniteForm=e}fromBER(t,e,n){let s=M.BufferSourceConverter.toUint8Array(t);if(!oe(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(;ld(this.isIndefiniteForm,n)>0;){let i=Ns(s,o,n);if(i.offset===-1)return this.error=i.result.error,this.warnings.concat(i.result.warnings),-1;if(o=i.offset,this.blockLength+=i.result.blockLength,n-=i.result.blockLength,this.value.push(i.result),this.isIndefiniteForm&&i.result.constructor.NAME===Zr)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===Zr?this.value.pop():this.warnings.push("No EndOfContent block encoded")),o}toBER(t,e){let n=e||new Wr;for(let s=0;s<this.value.length;s++)this.value[s].toBER(t,n);return e?Ht:n.final()}toJSON(){let t={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let e of this.value)t.value.push(e.toJSON());return t}};Ft.NAME="ConstructedValueBlock";var Pc,ke=class extends ct{constructor(t={}){super(t,Ft),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 Cl=Object.create;var en=Object.defineProperty;var Nl=Object.getOwnPropertyDescriptor;var Tl=Object.getOwnPropertyNames;var Ul=Object.getPrototypeOf,Ll=Object.prototype.hasOwnProperty;var Se=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),ut=(r,t)=>{for(var e in t)en(r,e,{get:t[e],enumerable:!0})},mi=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of Tl(t))!Ll.call(r,s)&&s!==e&&en(r,s,{get:()=>t[s],enumerable:!(n=Nl(t,s))||n.enumerable});return r};var Ls=(r,t,e)=>(e=r!=null?Cl(Ul(r)):{},mi(t||!r||!r.__esModule?en(e,"default",{value:r,enumerable:!0}):e,r)),Rl=r=>mi(en({},"__esModule",{value:!0}),r);var hc=Se((Hm,fc)=>{"use strict";fc.exports=r=>{if(Object.prototype.toString.call(r)!=="[object Object]")return!1;let t=Object.getPrototypeOf(r);return t===null||t===Object.prototype}});var bc=Se((yc,mc)=>{"use strict";var Kn=hc(),{hasOwnProperty:pc}=Object.prototype,{propertyIsEnumerable:Rh}=Object,ur=(r,t,e)=>Object.defineProperty(r,t,{value:e,writable:!0,enumerable:!0,configurable:!0}),_h=yc,dc={concatArrays:!1,ignoreUndefined:!1},On=r=>{let t=[];for(let e in r)pc.call(r,e)&&t.push(e);if(Object.getOwnPropertySymbols){let e=Object.getOwnPropertySymbols(r);for(let n of e)Rh.call(r,n)&&t.push(n)}return t};function fr(r){return Array.isArray(r)?Dh(r):Kn(r)?Kh(r):r}function Dh(r){let t=r.slice(0,0);return On(r).forEach(e=>{ur(t,e,fr(r[e]))}),t}function Kh(r){let t=Object.getPrototypeOf(r)===null?Object.create(null):{};return On(r).forEach(e=>{ur(t,e,fr(r[e]))}),t}var gc=(r,t,e,n)=>(e.forEach(s=>{typeof t[s]>"u"&&n.ignoreUndefined||(s in r&&r[s]!==Object.getPrototypeOf(r)?ur(r,s,ti(r[s],t[s],n)):ur(r,s,fr(t[s])))}),r),Oh=(r,t,e)=>{let n=r.slice(0,0),s=0;return[r,t].forEach(o=>{let i=[];for(let a=0;a<o.length;a++)pc.call(o,a)&&(i.push(String(a)),o===r?ur(n,s++,o[a]):ur(n,s++,fr(o[a])));n=gc(n,o,On(o).filter(a=>!i.includes(a)),e)}),n};function ti(r,t,e){return e.concatArrays&&Array.isArray(r)&&Array.isArray(t)?Oh(r,t,e):!Kn(t)||!Kn(r)?fr(t):gc(r,t,On(t),e)}mc.exports=function(...r){let t=ti(fr(dc),this!==_h&&this||{},dc),e={_:{}};for(let n of r)if(n!==void 0){if(!Kn(n))throw new TypeError("`"+n+"` is not an Option Object");e=ti(e,{_:n},t)}return e._}});var Bc=Se((Mm,vc)=>{"use strict";function Vh(r){return r>=55296&&r<=56319}function Hh(r){return r>=56320&&r<=57343}vc.exports=function(t,e,n){if(typeof e!="string")throw new Error("Input must be string");for(var s=e.length,o=0,i,a,c=0;c<s;c+=1){if(i=e.charCodeAt(c),a=e[c],Vh(i)&&Hh(e.charCodeAt(c+1))&&(c+=1,a+=e[c]),o+=t(a),o===n)return e.slice(0,c+1);if(o>n)return e.slice(0,c-a.length+1)}return e}});var Ac=Se((Fm,Ec)=>{"use strict";function Ph(r){return r>=55296&&r<=56319}function Mh(r){return r>=56320&&r<=57343}Ec.exports=function(t){if(typeof t!="string")throw new Error("Input must be string");for(var e=t.length,n=0,s=null,o=null,i=0;i<e;i++)s=t.charCodeAt(i),Mh(s)?o!=null&&Ph(o)?n+=1:n+=3:s<=127?n+=1:s>=128&&s<=2047?n+=2:s>=2048&&s<=65535&&(n+=3),o=s;return n}});var kc=Se((qm,Sc)=>{"use strict";var Fh=Bc(),qh=Ac();Sc.exports=Fh.bind(null,qh)});var Nc=Se((jm,Cc)=>{"use strict";var jh=kc(),$h=/[\/\?<>\\:\*\|"]/g,Gh=/[\x00-\x1f\x80-\x9f]/g,zh=/^\.+$/,Wh=/^(con|prn|aux|nul|com[0-9]|lpt[0-9])(\..*)?$/i,Zh=/[\. ]+$/;function Ic(r,t){if(typeof r!="string")throw new Error("Input must be string");var e=r.replace($h,t).replace(Gh,t).replace(zh,t).replace(Wh,t).replace(Zh,t);return jh(e,255)}Cc.exports=function(r,t){var e=t&&t.replacement||"",n=Ic(r,e);return e===""?n:Ic(n,"")}});var Tc=Se(dr=>{"use strict";var Yh="[object ArrayBuffer]",Qt=class r{static isArrayBuffer(t){return Object.prototype.toString.call(t)===Yh}static toArrayBuffer(t){return this.isArrayBuffer(t)?t:t.byteLength===t.buffer.byteLength||t.byteOffset===0&&t.byteLength===t.buffer.byteLength?t.buffer:this.toUint8Array(t.buffer).slice(t.byteOffset,t.byteOffset+t.byteLength).buffer}static toUint8Array(t){return this.toView(t,Uint8Array)}static toView(t,e){if(t.constructor===e)return t;if(this.isArrayBuffer(t))return new e(t);if(this.isArrayBufferView(t))return new e(t.buffer,t.byteOffset,t.byteLength);throw new TypeError("The provided value is not of type '(ArrayBuffer or ArrayBufferView)'")}static isBufferSource(t){return this.isArrayBufferView(t)||this.isArrayBuffer(t)}static isArrayBufferView(t){return ArrayBuffer.isView(t)||t&&this.isArrayBuffer(t.buffer)}static isEqual(t,e){let n=r.toUint8Array(t),s=r.toUint8Array(e);if(n.length!==s.byteLength)return!1;for(let o=0;o<n.length;o++)if(n[o]!==s[o])return!1;return!0}static concat(...t){let e;Array.isArray(t[0])&&!(t[1]instanceof Function)||Array.isArray(t[0])&&t[1]instanceof Function?e=t[0]:t[t.length-1]instanceof Function?e=t.slice(0,t.length-1):e=t;let n=0;for(let i of e)n+=i.byteLength;let s=new Uint8Array(n),o=0;for(let i of e){let a=this.toUint8Array(i);s.set(a,o),o+=a.length}return t[t.length-1]instanceof Function?this.toView(s,t[t.length-1]):s.buffer}},ei="string",Xh=/^[0-9a-f\s]+$/i,Qh=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,td=/^[a-zA-Z0-9-_]+$/,Hn=class{static fromString(t){let e=unescape(encodeURIComponent(t)),n=new Uint8Array(e.length);for(let s=0;s<e.length;s++)n[s]=e.charCodeAt(s);return n.buffer}static toString(t){let e=Qt.toUint8Array(t),n="";for(let o=0;o<e.length;o++)n+=String.fromCharCode(e[o]);return decodeURIComponent(escape(n))}},Ct=class{static toString(t,e=!1){let n=Qt.toArrayBuffer(t),s=new DataView(n),o="";for(let i=0;i<n.byteLength;i+=2){let a=s.getUint16(i,e);o+=String.fromCharCode(a)}return o}static fromString(t,e=!1){let n=new ArrayBuffer(t.length*2),s=new DataView(n);for(let o=0;o<t.length;o++)s.setUint16(o*2,t.charCodeAt(o),e);return n}},Pn=class r{static isHex(t){return typeof t===ei&&Xh.test(t)}static isBase64(t){return typeof t===ei&&Qh.test(t)}static isBase64Url(t){return typeof t===ei&&td.test(t)}static ToString(t,e="utf8"){let n=Qt.toUint8Array(t);switch(e.toLowerCase()){case"utf8":return this.ToUtf8String(n);case"binary":return this.ToBinary(n);case"hex":return this.ToHex(n);case"base64":return this.ToBase64(n);case"base64url":return this.ToBase64Url(n);case"utf16le":return Ct.toString(n,!0);case"utf16":case"utf16be":return Ct.toString(n);default:throw new Error(`Unknown type of encoding '${e}'`)}}static FromString(t,e="utf8"){if(!t)return new ArrayBuffer(0);switch(e.toLowerCase()){case"utf8":return this.FromUtf8String(t);case"binary":return this.FromBinary(t);case"hex":return this.FromHex(t);case"base64":return this.FromBase64(t);case"base64url":return this.FromBase64Url(t);case"utf16le":return Ct.fromString(t,!0);case"utf16":case"utf16be":return Ct.fromString(t);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToBase64(t){let e=Qt.toUint8Array(t);if(typeof btoa<"u"){let n=this.ToString(e,"binary");return btoa(n)}else return Buffer.from(e).toString("base64")}static FromBase64(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isBase64(e))throw new TypeError("Argument 'base64Text' is not Base64 encoded");return typeof atob<"u"?this.FromBinary(atob(e)):new Uint8Array(Buffer.from(e,"base64")).buffer}static FromBase64Url(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isBase64Url(e))throw new TypeError("Argument 'base64url' is not Base64Url encoded");return this.FromBase64(this.Base64Padding(e.replace(/\-/g,"+").replace(/\_/g,"/")))}static ToBase64Url(t){return this.ToBase64(t).replace(/\+/g,"-").replace(/\//g,"_").replace(/\=/g,"")}static FromUtf8String(t,e=r.DEFAULT_UTF8_ENCODING){switch(e){case"ascii":return this.FromBinary(t);case"utf8":return Hn.fromString(t);case"utf16":case"utf16be":return Ct.fromString(t);case"utf16le":case"usc2":return Ct.fromString(t,!0);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToUtf8String(t,e=r.DEFAULT_UTF8_ENCODING){switch(e){case"ascii":return this.ToBinary(t);case"utf8":return Hn.toString(t);case"utf16":case"utf16be":return Ct.toString(t);case"utf16le":case"usc2":return Ct.toString(t,!0);default:throw new Error(`Unknown type of encoding '${e}'`)}}static FromBinary(t){let e=t.length,n=new Uint8Array(e);for(let s=0;s<e;s++)n[s]=t.charCodeAt(s);return n.buffer}static ToBinary(t){let e=Qt.toUint8Array(t),n="";for(let s=0;s<e.length;s++)n+=String.fromCharCode(e[s]);return n}static ToHex(t){let e=Qt.toUint8Array(t),n="",s=e.length;for(let o=0;o<s;o++){let i=e[o];i<16&&(n+="0"),n+=i.toString(16)}return n}static FromHex(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isHex(e))throw new TypeError("Argument 'hexString' is not HEX encoded");e.length%2&&(e=`0${e}`);let n=new Uint8Array(e.length/2);for(let s=0;s<e.length;s=s+2){let o=e.slice(s,s+2);n[s/2]=parseInt(o,16)}return n.buffer}static ToUtf16String(t,e=!1){return Ct.toString(t,e)}static FromUtf16String(t,e=!1){return Ct.fromString(t,e)}static Base64Padding(t){let e=4-t.length%4;if(e<4)for(let n=0;n<e;n++)t+="=";return t}static formatString(t){return t?.replace(/[\n\r\t ]/g,"")||""}};Pn.DEFAULT_UTF8_ENCODING="utf8";function ed(r,...t){let e=arguments[0];for(let n=1;n<arguments.length;n++){let s=arguments[n];for(let o in s)e[o]=s[o]}return e}function rd(...r){let t=r.map(s=>s.byteLength).reduce((s,o)=>s+o),e=new Uint8Array(t),n=0;return r.map(s=>new Uint8Array(s)).forEach(s=>{for(let o of s)e[n++]=o}),e.buffer}function nd(r,t){if(!(r&&t)||r.byteLength!==t.byteLength)return!1;let e=new Uint8Array(r),n=new Uint8Array(t);for(let s=0;s<r.byteLength;s++)if(e[s]!==n[s])return!1;return!0}dr.BufferSourceConverter=Qt;dr.Convert=Pn;dr.assign=ed;dr.combine=rd;dr.isEqual=nd});var xd={};ut(xd,{keychain:()=>wd});var br=class extends Error{constructor(t="An error occurred while signing a message"){super(t),this.name="SigningError"}},wr=class extends Error{constructor(t="An error occurred while verifying a message"){super(t),this.name="VerificationError"}},rn=class extends Error{constructor(t="Missing Web Crypto API"){super(t),this.name="WebCryptoMissingError"}};var bi={get(r=globalThis){let t=r.crypto;if(t?.subtle==null)throw new rn("Missing Web Crypto API. The most likely cause of this error is that this page is being accessed from an insecure context (i.e. not HTTPS). For more information and possible resolutions see https://github.com/libp2p/js-libp2p/blob/main/packages/crypto/README.md#web-crypto-api");return t}};var wt=bi;var L=class extends Error{static name="InvalidParametersError";constructor(t="Invalid parameters"){super(t),this.name="InvalidParametersError"}},qe=class extends Error{static name="InvalidPublicKeyError";constructor(t="Invalid public key"){super(t),this.name="InvalidPublicKeyError"}},xr=class extends Error{static name="InvalidPrivateKeyError";constructor(t="Invalid private key"){super(t),this.name="InvalidPrivateKeyError"}};var nn=class extends Error{static name="NotFoundError";constructor(t="Not found"){super(t),this.name="NotFoundError"}};var je=class extends Error{static name="UnsupportedKeyTypeError";constructor(t="Unsupported key type"){super(t),this.name="UnsupportedKeyTypeError"}};var wi=Symbol.for("@libp2p/service-capabilities"),Cd=Symbol.for("@libp2p/service-dependencies");var Os={};ut(Os,{base58btc:()=>Q,base58flickr:()=>Hl});var Yd=new Uint8Array(0);function xi(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function jt(r){if(r instanceof Uint8Array&&r.constructor.name==="Uint8Array")return r;if(r instanceof ArrayBuffer)return new Uint8Array(r);if(ArrayBuffer.isView(r))return new Uint8Array(r.buffer,r.byteOffset,r.byteLength);throw new Error("Unknown type, must be binary type")}function vi(r){return new TextEncoder().encode(r)}function Bi(r){return new TextDecoder().decode(r)}function _l(r,t){if(r.length>=255)throw new TypeError("Alphabet too long");for(var e=new Uint8Array(256),n=0;n<e.length;n++)e[n]=255;for(var s=0;s<r.length;s++){var o=r.charAt(s),i=o.charCodeAt(0);if(e[i]!==255)throw new TypeError(o+" is ambiguous");e[i]=s}var a=r.length,c=r.charAt(0),f=Math.log(a)/Math.log(256),l=Math.log(256)/Math.log(a);function u(b){if(b instanceof Uint8Array||(ArrayBuffer.isView(b)?b=new Uint8Array(b.buffer,b.byteOffset,b.byteLength):Array.isArray(b)&&(b=Uint8Array.from(b))),!(b instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(b.length===0)return"";for(var m=0,d=0,w=0,B=b.length;w!==B&&b[w]===0;)w++,m++;for(var p=(B-w)*l+1>>>0,S=new Uint8Array(p);w!==B;){for(var R=b[w],U=0,I=p-1;(R!==0||U<d)&&I!==-1;I--,U++)R+=256*S[I]>>>0,S[I]=R%a>>>0,R=R/a>>>0;if(R!==0)throw new Error("Non-zero carry");d=U,w++}for(var T=p-d;T!==p&&S[T]===0;)T++;for(var C=c.repeat(m);T<p;++T)C+=r.charAt(S[T]);return C}function h(b){if(typeof b!="string")throw new TypeError("Expected String");if(b.length===0)return new Uint8Array;var m=0;if(b[m]!==" "){for(var d=0,w=0;b[m]===c;)d++,m++;for(var B=(b.length-m)*f+1>>>0,p=new Uint8Array(B);b[m];){var S=e[b.charCodeAt(m)];if(S===255)return;for(var R=0,U=B-1;(S!==0||R<w)&&U!==-1;U--,R++)S+=a*p[U]>>>0,p[U]=S%256>>>0,S=S/256>>>0;if(S!==0)throw new Error("Non-zero carry");w=R,m++}if(b[m]!==" "){for(var I=B-w;I!==B&&p[I]===0;)I++;for(var T=new Uint8Array(d+(B-I)),C=d;I!==B;)T[C++]=p[I++];return T}}}function y(b){var m=h(b);if(m)return m;throw new Error(`Non-${t} character`)}return{encode:u,decodeUnsafe:h,decode:y}}var Dl=_l,Kl=Dl,Ai=Kl;var Rs=class{name;prefix;baseEncode;constructor(t,e,n){this.name=t,this.prefix=e,this.baseEncode=n}encode(t){if(t instanceof Uint8Array)return`${this.prefix}${this.baseEncode(t)}`;throw Error("Unknown type, must be binary type")}},_s=class{name;prefix;baseDecode;prefixCodePoint;constructor(t,e,n){this.name=t,this.prefix=e;let s=e.codePointAt(0);if(s===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=s,this.baseDecode=n}decode(t){if(typeof t=="string"){if(t.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(t)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(t.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(t){return Si(this,t)}},Ds=class{decoders;constructor(t){this.decoders=t}or(t){return Si(this,t)}decode(t){let e=t[0],n=this.decoders[e];if(n!=null)return n.decode(t);throw RangeError(`Unable to decode multibase string ${JSON.stringify(t)}, only inputs prefixed with ${Object.keys(this.decoders)} are supported`)}};function Si(r,t){return new Ds({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var Ks=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(t,e,n,s){this.name=t,this.prefix=e,this.baseEncode=n,this.baseDecode=s,this.encoder=new Rs(t,e,n),this.decoder=new _s(t,e,s)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function $e({name:r,prefix:t,encode:e,decode:n}){return new Ks(r,t,e,n)}function ie({name:r,prefix:t,alphabet:e}){let{encode:n,decode:s}=Ai(e,r);return $e({prefix:t,name:r,encode:n,decode:o=>jt(s(o))})}function Ol(r,t,e,n){let s={};for(let l=0;l<t.length;++l)s[t[l]]=l;let o=r.length;for(;r[o-1]==="=";)--o;let i=new Uint8Array(o*e/8|0),a=0,c=0,f=0;for(let l=0;l<o;++l){let u=s[r[l]];if(u===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<e|u,a+=e,a>=8&&(a-=8,i[f++]=255&c>>a)}if(a>=e||(255&c<<8-a)!==0)throw new SyntaxError("Unexpected end of data");return i}function Vl(r,t,e){let n=t[t.length-1]==="=",s=(1<<e)-1,o="",i=0,a=0;for(let c=0;c<r.length;++c)for(a=a<<8|r[c],i+=8;i>e;)i-=e,o+=t[s&a>>i];if(i!==0&&(o+=t[s&a<<e-i]),n)for(;(o.length*e&7)!==0;)o+="=";return o}function X({name:r,prefix:t,bitsPerChar:e,alphabet:n}){return $e({prefix:t,name:r,encode(s){return Vl(s,n,e)},decode(s){return Ol(s,n,e,r)}})}var Q=ie({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),Hl=ie({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Vs={};ut(Vs,{base32:()=>Ge,base32hex:()=>ql,base32hexpad:()=>$l,base32hexpadupper:()=>Gl,base32hexupper:()=>jl,base32pad:()=>Ml,base32padupper:()=>Fl,base32upper:()=>Pl,base32z:()=>zl});var Ge=X({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),Pl=X({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Ml=X({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),Fl=X({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),ql=X({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),jl=X({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),$l=X({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),Gl=X({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),zl=X({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Hs={};ut(Hs,{base36:()=>vr,base36upper:()=>Wl});var vr=ie({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),Wl=ie({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Zl=Ci,ki=128,Jl=127,Yl=~Jl,Xl=Math.pow(2,31);function Ci(r,t,e){t=t||[],e=e||0;for(var n=e;r>=Xl;)t[e++]=r&255|ki,r/=128;for(;r&Yl;)t[e++]=r&255|ki,r>>>=7;return t[e]=r|0,Ci.bytes=e-n+1,t}var Ql=Ps,tu=128,Ii=127;function Ps(r,n){var e=0,n=n||0,s=0,o=n,i,a=r.length;do{if(o>=a)throw Ps.bytes=0,new RangeError("Could not decode varint");i=r[o++],e+=s<28?(i&Ii)<<s:(i&Ii)*Math.pow(2,s),s+=7}while(i>=tu);return Ps.bytes=o-n,e}var eu=Math.pow(2,7),ru=Math.pow(2,14),nu=Math.pow(2,21),su=Math.pow(2,28),ou=Math.pow(2,35),iu=Math.pow(2,42),au=Math.pow(2,49),cu=Math.pow(2,56),lu=Math.pow(2,63),uu=function(r){return r<eu?1:r<ru?2:r<nu?3:r<su?4:r<ou?5:r<iu?6:r<au?7:r<cu?8:r<lu?9:10},fu={encode:Zl,decode:Ql,encodingLength:uu},hu=fu,Br=hu;function Er(r,t=0){return[Br.decode(r,t),Br.decode.bytes]}function ze(r,t,e=0){return Br.encode(r,t,e),t}function We(r){return Br.encodingLength(r)}function Nt(r,t){let e=t.byteLength,n=We(r),s=n+We(e),o=new Uint8Array(s+e);return ze(r,o,0),ze(e,o,n),o.set(t,s),new Ze(r,e,t,o)}function Ni(r){let t=jt(r),[e,n]=Er(t),[s,o]=Er(t.subarray(n)),i=t.subarray(n+o);if(i.byteLength!==s)throw new Error("Incorrect length");return new Ze(e,s,i,t)}function Ti(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&xi(r.bytes,e.bytes)}}var Ze=class{code;size;digest;bytes;constructor(t,e,n,s){this.code=t,this.size=e,this.digest=n,this.bytes=s}};function Ui(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return pu(e,Ms(r),t??Q.encoder);default:return gu(e,Ms(r),t??Ge.encoder)}}var Li=new WeakMap;function Ms(r){let t=Li.get(r);if(t==null){let e=new Map;return Li.set(r,e),e}return t}var It=class r{code;version;multihash;bytes;"/";constructor(t,e,n,s){this.code=e,this.version=t,this.multihash=n,this.bytes=s,this["/"]=s}get asCID(){return this}get byteOffset(){return this.bytes.byteOffset}get byteLength(){return this.bytes.byteLength}toV0(){switch(this.version){case 0:return this;case 1:{let{code:t,multihash:e}=this;if(t!==Sr)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==yu)throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");return r.createV0(e)}default:throw Error(`Can not convert CID version ${this.version} to version 0. This is a bug please report`)}}toV1(){switch(this.version){case 0:{let{code:t,digest:e}=this.multihash,n=Nt(t,e);return r.createV1(this.code,n)}case 1:return this;default:throw Error(`Can not convert CID version ${this.version} to version 1. This is a bug please report`)}}equals(t){return r.equals(this,t)}static equals(t,e){let n=e;return n!=null&&t.code===n.code&&t.version===n.version&&Ti(t.multihash,n.multihash)}toString(t){return Ui(this,t)}toJSON(){return{"/":Ui(this)}}link(){return this}[Symbol.toStringTag]="CID";[Symbol.for("nodejs.util.inspect.custom")](){return`CID(${this.toString()})`}static asCID(t){if(t==null)return null;let e=t;if(e instanceof r)return e;if(e["/"]!=null&&e["/"]===e.bytes||e.asCID===e){let{version:n,code:s,multihash:o,bytes:i}=e;return new r(n,s,o,i??Ri(n,s,o.bytes))}else if(e[mu]===!0){let{version:n,multihash:s,code:o}=e,i=Ni(s);return r.create(n,o,i)}else return null}static create(t,e,n){if(typeof e!="number")throw new Error("String codecs are no longer supported");if(!(n.bytes instanceof Uint8Array))throw new Error("Invalid digest");switch(t){case 0:{if(e!==Sr)throw new Error(`Version 0 CID must use dag-pb (code: ${Sr}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let s=Ri(t,e,n.bytes);return new r(t,e,n,s)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,Sr,t)}static createV1(t,e){return r.create(1,t,e)}static decode(t){let[e,n]=r.decodeFirst(t);if(n.length!==0)throw new Error("Incorrect length");return e}static decodeFirst(t){let e=r.inspectBytes(t),n=e.size-e.multihashSize,s=jt(t.subarray(n,n+e.multihashSize));if(s.byteLength!==e.multihashSize)throw new Error("Incorrect length");let o=s.subarray(e.multihashSize-e.digestSize),i=new Ze(e.multihashCode,e.digestSize,o,s);return[e.version===0?r.createV0(i):r.createV1(e.codec,i),t.subarray(e.size)]}static inspectBytes(t){let e=0,n=()=>{let[u,h]=Er(t.subarray(e));return e+=h,u},s=n(),o=Sr;if(s===18?(s=0,e=0):o=n(),s!==0&&s!==1)throw new RangeError(`Invalid CID version ${s}`);let i=e,a=n(),c=n(),f=e+c,l=f-i;return{version:s,codec:o,multihashCode:a,digestSize:c,multihashSize:l,size:f}}static parse(t,e){let[n,s]=du(t,e),o=r.decode(s);if(o.version===0&&t[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return Ms(o).set(n,t),o}};function du(r,t){switch(r[0]){case"Q":{let e=t??Q;return[Q.prefix,e.decode(`${Q.prefix}${r}`)]}case Q.prefix:{let e=t??Q;return[Q.prefix,e.decode(r)]}case Ge.prefix:{let e=t??Ge;return[Ge.prefix,e.decode(r)]}case vr.prefix:{let e=t??vr;return[vr.prefix,e.decode(r)]}default:{if(t==null)throw Error("To parse non base32, base36 or base58btc encoded CID multibase decoder must be provided");return[r[0],t.decode(r)]}}}function pu(r,t,e){let{prefix:n}=e;if(n!==Q.prefix)throw Error(`Cannot string encode V0 in ${e.name} encoding`);let s=t.get(n);if(s==null){let o=e.encode(r).slice(1);return t.set(n,o),o}else return s}function gu(r,t,e){let{prefix:n}=e,s=t.get(n);if(s==null){let o=e.encode(r);return t.set(n,o),o}else return s}var Sr=112,yu=18;function Ri(r,t,e){let n=We(r),s=n+We(t),o=new Uint8Array(s+e.byteLength);return ze(r,o,0),ze(t,o,n),o.set(e,s),o}var mu=Symbol.for("@ipld/js-cid/CID");var Fs={};ut(Fs,{identity:()=>ke});var _i=0,bu="identity",Di=jt;function wu(r){return Nt(_i,Di(r))}var ke={code:_i,name:bu,encode:Di,digest:wu};function xt(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function $t(r=0){return new Uint8Array(r)}function St(r=0){return new Uint8Array(r)}function Je(r,t){t==null&&(t=r.reduce((s,o)=>s+o.length,0));let e=St(t),n=0;for(let s of r)e.set(s,n),n+=s.length;return e}var Oi=Symbol.for("@achingbrain/uint8arraylist");function Ki(r,t){if(t==null||t<0)throw new RangeError("index is out of bounds");let e=0;for(let n of r){let s=e+n.byteLength;if(t<s)return{buf:n,index:t-e};e=s}throw new RangeError("index is out of bounds")}function on(r){return!!r?.[Oi]}var pt=class r{bufs;length;[Oi]=!0;constructor(...t){this.bufs=[],this.length=0,t.length>0&&this.appendAll(t)}*[Symbol.iterator](){yield*this.bufs}get byteLength(){return this.length}append(...t){this.appendAll(t)}appendAll(t){let e=0;for(let n of t)if(n instanceof Uint8Array)e+=n.byteLength,this.bufs.push(n);else if(on(n))e+=n.byteLength,this.bufs.push(...n.bufs);else throw new Error("Could not append value, must be an Uint8Array or a Uint8ArrayList");this.length+=e}prepend(...t){this.prependAll(t)}prependAll(t){let e=0;for(let n of t.reverse())if(n instanceof Uint8Array)e+=n.byteLength,this.bufs.unshift(n);else if(on(n))e+=n.byteLength,this.bufs.unshift(...n.bufs);else throw new Error("Could not prepend value, must be an Uint8Array or a Uint8ArrayList");this.length+=e}get(t){let e=Ki(this.bufs,t);return e.buf[e.index]}set(t,e){let n=Ki(this.bufs,t);n.buf[n.index]=e}write(t,e=0){if(t instanceof Uint8Array)for(let n=0;n<t.length;n++)this.set(e+n,t[n]);else if(on(t))for(let n=0;n<t.length;n++)this.set(e+n,t.get(n));else throw new Error("Could not write value, must be an Uint8Array or a Uint8ArrayList")}consume(t){if(t=Math.trunc(t),!(Number.isNaN(t)||t<=0)){if(t===this.byteLength){this.bufs=[],this.length=0;return}for(;this.bufs.length>0;)if(t>=this.bufs[0].byteLength)t-=this.bufs[0].byteLength,this.length-=this.bufs[0].byteLength,this.bufs.shift();else{this.bufs[0]=this.bufs[0].subarray(t),this.length-=t;break}}}slice(t,e){let{bufs:n,length:s}=this._subList(t,e);return Je(n,s)}subarray(t,e){let{bufs:n,length:s}=this._subList(t,e);return n.length===1?n[0]:Je(n,s)}sublist(t,e){let{bufs:n,length:s}=this._subList(t,e),o=new r;return o.length=s,o.bufs=[...n],o}_subList(t,e){if(t=t??0,e=e??this.length,t<0&&(t=this.length+t),e<0&&(e=this.length+e),t<0||e>this.length)throw new RangeError("index is out of bounds");if(t===e)return{bufs:[],length:0};if(t===0&&e===this.length)return{bufs:this.bufs,length:this.length};let n=[],s=0;for(let o=0;o<this.bufs.length;o++){let i=this.bufs[o],a=s,c=a+i.byteLength;if(s=c,t>=c)continue;let f=t>=a&&t<c,l=e>a&&e<=c;if(f&&l){if(t===a&&e===c){n.push(i);break}let u=t-a;n.push(i.subarray(u,u+(e-t)));break}if(f){if(t===0){n.push(i);continue}n.push(i.subarray(t-a));continue}if(l){if(e===c){n.push(i);break}n.push(i.subarray(0,e-a));break}n.push(i)}return{bufs:n,length:e-t}}indexOf(t,e=0){if(!on(t)&&!(t instanceof Uint8Array))throw new TypeError('The "value" argument must be a Uint8ArrayList or Uint8Array');let n=t instanceof Uint8Array?t:t.subarray();if(e=Number(e??0),isNaN(e)&&(e=0),e<0&&(e=this.length+e),e<0&&(e=0),t.length===0)return e>this.length?this.length:e;let s=n.byteLength;if(s===0)throw new TypeError("search must be at least 1 byte long");let o=256,i=new Int32Array(o);for(let u=0;u<o;u++)i[u]=-1;for(let u=0;u<s;u++)i[n[u]]=u;let a=i,c=this.byteLength-n.byteLength,f=n.byteLength-1,l;for(let u=e;u<=c;u+=l){l=0;for(let h=f;h>=0;h--){let y=this.get(u+h);if(n[h]!==y){l=Math.max(1,h-a[y]);break}}if(l===0)return u}return-1}getInt8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getInt8(0)}setInt8(t,e){let n=St(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setInt8(0,e),this.write(n,t)}getInt16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt16(0,e)}setInt16(t,e,n){let s=$t(2);new DataView(s.buffer,s.byteOffset,s.byteLength).setInt16(0,e,n),this.write(s,t)}getInt32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt32(0,e)}setInt32(t,e,n){let s=$t(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setInt32(0,e,n),this.write(s,t)}getBigInt64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigInt64(0,e)}setBigInt64(t,e,n){let s=$t(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigInt64(0,e,n),this.write(s,t)}getUint8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getUint8(0)}setUint8(t,e){let n=St(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setUint8(0,e),this.write(n,t)}getUint16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint16(0,e)}setUint16(t,e,n){let s=$t(2);new DataView(s.buffer,s.byteOffset,s.byteLength).setUint16(0,e,n),this.write(s,t)}getUint32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint32(0,e)}setUint32(t,e,n){let s=$t(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setUint32(0,e,n),this.write(s,t)}getBigUint64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigUint64(0,e)}setBigUint64(t,e,n){let s=$t(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigUint64(0,e,n),this.write(s,t)}getFloat32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat32(0,e)}setFloat32(t,e,n){let s=$t(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setFloat32(0,e,n),this.write(s,t)}getFloat64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat64(0,e)}setFloat64(t,e,n){let s=$t(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setFloat64(0,e,n),this.write(s,t)}equals(t){if(t==null||!(t instanceof r)||t.bufs.length!==this.bufs.length)return!1;for(let e=0;e<this.bufs.length;e++)if(!xt(this.bufs[e],t.bufs[e]))return!1;return!0}static fromUint8Arrays(t,e){let n=new r;return n.bufs=t,e==null&&(e=t.reduce((s,o)=>s+o.byteLength,0)),n.length=e,n}};var qs={};ut(qs,{base10:()=>xu});var xu=ie({prefix:"9",name:"base10",alphabet:"0123456789"});var js={};ut(js,{base16:()=>vu,base16upper:()=>Bu});var vu=X({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Bu=X({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var $s={};ut($s,{base2:()=>Eu});var Eu=X({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Gs={};ut(Gs,{base256emoji:()=>Cu});var Vi=Array.from("\u{1F680}\u{1FA90}\u2604\u{1F6F0}\u{1F30C}\u{1F311}\u{1F312}\u{1F313}\u{1F314}\u{1F315}\u{1F316}\u{1F317}\u{1F318}\u{1F30D}\u{1F30F}\u{1F30E}\u{1F409}\u2600\u{1F4BB}\u{1F5A5}\u{1F4BE}\u{1F4BF}\u{1F602}\u2764\u{1F60D}\u{1F923}\u{1F60A}\u{1F64F}\u{1F495}\u{1F62D}\u{1F618}\u{1F44D}\u{1F605}\u{1F44F}\u{1F601}\u{1F525}\u{1F970}\u{1F494}\u{1F496}\u{1F499}\u{1F622}\u{1F914}\u{1F606}\u{1F644}\u{1F4AA}\u{1F609}\u263A\u{1F44C}\u{1F917}\u{1F49C}\u{1F614}\u{1F60E}\u{1F607}\u{1F339}\u{1F926}\u{1F389}\u{1F49E}\u270C\u2728\u{1F937}\u{1F631}\u{1F60C}\u{1F338}\u{1F64C}\u{1F60B}\u{1F497}\u{1F49A}\u{1F60F}\u{1F49B}\u{1F642}\u{1F493}\u{1F929}\u{1F604}\u{1F600}\u{1F5A4}\u{1F603}\u{1F4AF}\u{1F648}\u{1F447}\u{1F3B6}\u{1F612}\u{1F92D}\u2763\u{1F61C}\u{1F48B}\u{1F440}\u{1F62A}\u{1F611}\u{1F4A5}\u{1F64B}\u{1F61E}\u{1F629}\u{1F621}\u{1F92A}\u{1F44A}\u{1F973}\u{1F625}\u{1F924}\u{1F449}\u{1F483}\u{1F633}\u270B\u{1F61A}\u{1F61D}\u{1F634}\u{1F31F}\u{1F62C}\u{1F643}\u{1F340}\u{1F337}\u{1F63B}\u{1F613}\u2B50\u2705\u{1F97A}\u{1F308}\u{1F608}\u{1F918}\u{1F4A6}\u2714\u{1F623}\u{1F3C3}\u{1F490}\u2639\u{1F38A}\u{1F498}\u{1F620}\u261D\u{1F615}\u{1F33A}\u{1F382}\u{1F33B}\u{1F610}\u{1F595}\u{1F49D}\u{1F64A}\u{1F639}\u{1F5E3}\u{1F4AB}\u{1F480}\u{1F451}\u{1F3B5}\u{1F91E}\u{1F61B}\u{1F534}\u{1F624}\u{1F33C}\u{1F62B}\u26BD\u{1F919}\u2615\u{1F3C6}\u{1F92B}\u{1F448}\u{1F62E}\u{1F646}\u{1F37B}\u{1F343}\u{1F436}\u{1F481}\u{1F632}\u{1F33F}\u{1F9E1}\u{1F381}\u26A1\u{1F31E}\u{1F388}\u274C\u270A\u{1F44B}\u{1F630}\u{1F928}\u{1F636}\u{1F91D}\u{1F6B6}\u{1F4B0}\u{1F353}\u{1F4A2}\u{1F91F}\u{1F641}\u{1F6A8}\u{1F4A8}\u{1F92C}\u2708\u{1F380}\u{1F37A}\u{1F913}\u{1F619}\u{1F49F}\u{1F331}\u{1F616}\u{1F476}\u{1F974}\u25B6\u27A1\u2753\u{1F48E}\u{1F4B8}\u2B07\u{1F628}\u{1F31A}\u{1F98B}\u{1F637}\u{1F57A}\u26A0\u{1F645}\u{1F61F}\u{1F635}\u{1F44E}\u{1F932}\u{1F920}\u{1F927}\u{1F4CC}\u{1F535}\u{1F485}\u{1F9D0}\u{1F43E}\u{1F352}\u{1F617}\u{1F911}\u{1F30A}\u{1F92F}\u{1F437}\u260E\u{1F4A7}\u{1F62F}\u{1F486}\u{1F446}\u{1F3A4}\u{1F647}\u{1F351}\u2744\u{1F334}\u{1F4A3}\u{1F438}\u{1F48C}\u{1F4CD}\u{1F940}\u{1F922}\u{1F445}\u{1F4A1}\u{1F4A9}\u{1F450}\u{1F4F8}\u{1F47B}\u{1F910}\u{1F92E}\u{1F3BC}\u{1F975}\u{1F6A9}\u{1F34E}\u{1F34A}\u{1F47C}\u{1F48D}\u{1F4E3}\u{1F942}"),Au=Vi.reduce((r,t,e)=>(r[e]=t,r),[]),Su=Vi.reduce((r,t,e)=>{let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);return r[n]=e,r},[]);function ku(r){return r.reduce((t,e)=>(t+=Au[e],t),"")}function Iu(r){let t=[];for(let e of r){let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);let s=Su[n];if(s==null)throw new Error(`Non-base256emoji character: ${e}`);t.push(s)}return new Uint8Array(t)}var Cu=$e({prefix:"\u{1F680}",name:"base256emoji",encode:ku,decode:Iu});var zs={};ut(zs,{base64:()=>Ie,base64pad:()=>Nu,base64url:()=>Tu,base64urlpad:()=>Uu});var Ie=X({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),Nu=X({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Tu=X({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Uu=X({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Ws={};ut(Ws,{base8:()=>Lu});var Lu=X({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Zs={};ut(Zs,{identity:()=>Ru});var Ru=$e({prefix:"\0",name:"identity",encode:r=>Bi(r),decode:r=>vi(r)});var _0=new TextEncoder,D0=new TextDecoder;var Xs={};ut(Xs,{sha256:()=>Ye,sha512:()=>Ku});function Ys({name:r,code:t,encode:e}){return new Js(r,t,e)}var Js=class{name;code;encode;constructor(t,e,n){this.name=t,this.code=e,this.encode=n}digest(t){if(t instanceof Uint8Array){let e=this.encode(t);return e instanceof Uint8Array?Nt(this.code,e):e.then(n=>Nt(this.code,n))}else throw Error("Unknown type, must be binary type")}};function Pi(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var Ye=Ys({name:"sha2-256",code:18,encode:Pi("SHA-256")}),Ku=Ys({name:"sha2-512",code:19,encode:Pi("SHA-512")});var Qs={...Zs,...$s,...Ws,...qs,...js,...Vs,...Hs,...Os,...zs,...Gs},z0={...Xs,...Fs};function Fi(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var Mi=Fi("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),to=Fi("ascii","a",r=>{let t="a";for(let e=0;e<r.length;e++)t+=String.fromCharCode(r[e]);return t},r=>{r=r.substring(1);let t=St(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),Ou={utf8:Mi,"utf-8":Mi,hex:Qs.base16,latin1:to,ascii:to,binary:to,...Qs},an=Ou;function H(r,t="utf8"){let e=an[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function j(r,t="utf8"){let e=an[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}var Vu=parseInt("11111",2),eo=parseInt("10000000",2),Hu=parseInt("01111111",2),qi={0:kr,1:kr,2:Pu,3:qu,4:ju,5:Fu,6:Mu,16:kr,22:kr,48:kr};function Tt(r,t={offset:0}){let e=r[t.offset]&Vu;if(t.offset++,qi[e]!=null)return qi[e](r,t);throw new Error("No decoder for tag "+e)}function Ir(r,t){let e=0;if((r[t.offset]&eo)===eo){let n=r[t.offset]&Hu,s="0x";t.offset++;for(let o=0;o<n;o++,t.offset++)s+=r[t.offset].toString(16).padStart(2,"0");e=parseInt(s,16)}else e=r[t.offset],t.offset++;return e}function kr(r,t){Ir(r,t);let e=[];for(;!(t.offset>=r.byteLength);){let n=Tt(r,t);if(n===null)break;e.push(n)}return e}function Pu(r,t){let e=Ir(r,t),n=t.offset,s=t.offset+e,o=[];for(let i=n;i<s;i++)i===n&&r[i]===0||o.push(r[i]);return t.offset+=e,Uint8Array.from(o)}function Mu(r,t){let e=Ir(r,t),n=t.offset+e,s=r[t.offset];t.offset++;let o=0,i=0;s<40?(o=0,i=s):s<80?(o=1,i=s-40):(o=2,i=s-80);let a=`${o}.${i}`,c=[];for(;t.offset<n;){let f=r[t.offset];if(t.offset++,c.push(f&127),f<128){c.reverse();let l=0;for(let u=0;u<c.length;u++)l+=c[u]<<u*7;a+=`.${l}`,c=[]}}return a}function Fu(r,t){return t.offset++,null}function qu(r,t){let e=Ir(r,t),n=r[t.offset];t.offset++;let s=r.subarray(t.offset,t.offset+e-1);if(t.offset+=e,n!==0)throw new Error("Unused bits in bit string is unimplemented");return s}function ju(r,t){let e=Ir(r,t),n=r.subarray(t.offset,t.offset+e);return t.offset+=e,n}function $u(r){let t=r.toString(16);t.length%2===1&&(t="0"+t);let e=new pt;for(let n=0;n<t.length;n+=2)e.append(Uint8Array.from([parseInt(`${t[n]}${t[n+1]}`,16)]));return e}function cn(r){if(r.byteLength<128)return Uint8Array.from([r.byteLength]);let t=$u(r.byteLength);return new pt(Uint8Array.from([t.byteLength|eo]),t)}function gt(r){let t=new pt,e=128;return(r.subarray()[0]&e)===e&&t.append(Uint8Array.from([0])),t.append(r),new pt(Uint8Array.from([2]),cn(t),t)}function Cr(r){let t=Uint8Array.from([0]),e=new pt(t,r);return new pt(Uint8Array.from([3]),cn(e),e)}function ji(r){return new pt(Uint8Array.from([4]),cn(r),r)}function Ut(r,t=48){let e=new pt;for(let n of r)e.append(n);return new pt(Uint8Array.from([t]),cn(e),e)}var $i="1.2.840.10045.3.1.7",Gi="1.3.132.0.34",zi="1.3.132.0.35";async function Wi(r,t){let e=await crypto.subtle.importKey("jwk",r,{name:"ECDSA",namedCurve:r.crv??"P-256"},!1,["sign"]),n=await crypto.subtle.sign({name:"ECDSA",hash:{name:"SHA-256"}},e,t.subarray());return new Uint8Array(n,0,n.byteLength)}async function Zi(r,t,e){let n=await crypto.subtle.importKey("jwk",r,{name:"ECDSA",namedCurve:r.crv??"P-256"},!1,["verify"]);return crypto.subtle.verify({name:"ECDSA",hash:{name:"SHA-256"}},n,t,e.subarray())}var Gu=Uint8Array.from([6,8,42,134,72,206,61,3,1,7]),zu=Uint8Array.from([6,5,43,129,4,0,34]),Wu=Uint8Array.from([6,5,43,129,4,0,35]),Zu={ext:!0,kty:"EC",crv:"P-256"},Ju={ext:!0,kty:"EC",crv:"P-384"},Yu={ext:!0,kty:"EC",crv:"P-521"},ro=32,no=48,so=66;function Ji(r){let t=Tt(r);return oo(t)}function oo(r){let t=r[1],e=j(t,"base64url"),n=r[2][1][0],s=1,o,i;if(t.byteLength===ro)return o=j(n.subarray(s,s+ro),"base64url"),i=j(n.subarray(s+ro),"base64url"),new Xe({...Zu,key_ops:["sign"],d:e,x:o,y:i});if(t.byteLength===no)return o=j(n.subarray(s,s+no),"base64url"),i=j(n.subarray(s+no),"base64url"),new Xe({...Ju,key_ops:["sign"],d:e,x:o,y:i});if(t.byteLength===so)return o=j(n.subarray(s,s+so),"base64url"),i=j(n.subarray(s+so),"base64url"),new Xe({...Yu,key_ops:["sign"],d:e,x:o,y:i});throw new L(`Private key length was wrong length, got ${t.byteLength}, expected 32, 48 or 66`)}function Yi(r){return Ut([gt(Uint8Array.from([1])),ji(H(r.d??"","base64url")),Ut([Qi(r.crv)],160),Ut([Cr(new pt(Uint8Array.from([4]),H(r.x??"","base64url"),H(r.y??"","base64url")))],161)]).subarray()}function Xi(r){return Ut([gt(Uint8Array.from([1])),Ut([Qi(r.crv)],160),Ut([Cr(new pt(Uint8Array.from([4]),H(r.x??"","base64url"),H(r.y??"","base64url")))],161)]).subarray()}function Qi(r){if(r==="P-256")return Gu;if(r==="P-384")return zu;if(r==="P-521")return Wu;throw new L(`Invalid curve ${r}`)}var ln=class{type="ECDSA";jwk;_raw;constructor(t){this.jwk=t}get raw(){return this._raw==null&&(this._raw=Xi(this.jwk)),this._raw}toMultihash(){return ke.digest(Qe(this))}toCID(){return It.createV1(114,this.toMultihash())}toString(){return Q.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:xt(this.raw,t.raw)}async verify(t,e){return Zi(this.jwk,e,t)}},Xe=class{type="ECDSA";jwk;publicKey;_raw;constructor(t){this.jwk=t,this.publicKey=new ln({crv:t.crv,ext:t.ext,key_ops:["verify"],kty:"EC",x:t.x,y:t.y})}get raw(){return this._raw==null&&(this._raw=Yi(this.jwk)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:xt(this.raw,t.raw)}async sign(t){return Wi(this.jwk,t)}};function tr(r){if(!Number.isSafeInteger(r)||r<0)throw new Error("positive integer expected, got "+r)}function Xu(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function er(r,...t){if(!Xu(r))throw new Error("Uint8Array expected");if(t.length>0&&!t.includes(r.length))throw new Error("Uint8Array expected of length "+t+", got length="+r.length)}function un(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");tr(r.outputLen),tr(r.blockLen)}function rr(r,t=!0){if(r.destroyed)throw new Error("Hash instance has been destroyed");if(t&&r.finished)throw new Error("Hash#digest() has already been called")}function ta(r,t){er(r);let e=t.outputLen;if(r.length<e)throw new Error("digestInto() expects output buffer of length at least "+e)}var Ce=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;function Ne(r){return new DataView(r.buffer,r.byteOffset,r.byteLength)}function Lt(r,t){return r<<32-t|r>>>t}function fn(r,t){return r<<t|r>>>32-t>>>0}var Qu=async()=>{};async function ea(r,t,e){let n=Date.now();for(let s=0;s<r;s++){e(s);let o=Date.now()-n;o>=0&&o<t||(await Qu(),n+=o)}}function ra(r){if(typeof r!="string")throw new Error("utf8ToBytes expected string, got "+typeof r);return new Uint8Array(new TextEncoder().encode(r))}function ae(r){return typeof r=="string"&&(r=ra(r)),er(r),r}function io(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];er(s),t+=s.length}let e=new Uint8Array(t);for(let n=0,s=0;n<r.length;n++){let o=r[n];e.set(o,s),s+=o.length}return e}var nr=class{clone(){return this._cloneInto()}};function na(r,t){if(t!==void 0&&{}.toString.call(t)!=="[object Object]")throw new Error("Options should be object or undefined");return Object.assign(r,t)}function sr(r){let t=n=>r().update(ae(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function or(r=32){if(Ce&&typeof Ce.getRandomValues=="function")return Ce.getRandomValues(new Uint8Array(r));if(Ce&&typeof Ce.randomBytes=="function")return Ce.randomBytes(r);throw new Error("crypto.getRandomValues must be defined")}function tf(r,t,e,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(t,e,n);let s=BigInt(32),o=BigInt(4294967295),i=Number(e>>s&o),a=Number(e&o),c=n?4:0,f=n?0:4;r.setUint32(t+c,i,n),r.setUint32(t+f,a,n)}function hn(r,t,e){return r&t^~r&e}function dn(r,t,e){return r&t^r&e^t&e}var ce=class extends nr{constructor(t,e,n,s){super(),this.blockLen=t,this.outputLen=e,this.padOffset=n,this.isLE=s,this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.buffer=new Uint8Array(t),this.view=Ne(this.buffer)}update(t){rr(this);let{view:e,buffer:n,blockLen:s}=this;t=ae(t);let o=t.length;for(let i=0;i<o;){let a=Math.min(s-this.pos,o-i);if(a===s){let c=Ne(t);for(;s<=o-i;i+=s)this.process(c,i);continue}n.set(t.subarray(i,i+a),this.pos),this.pos+=a,i+=a,this.pos===s&&(this.process(e,0),this.pos=0)}return this.length+=t.length,this.roundClean(),this}digestInto(t){rr(this),ta(t,this),this.finished=!0;let{buffer:e,view:n,blockLen:s,isLE:o}=this,{pos:i}=this;e[i++]=128,this.buffer.subarray(i).fill(0),this.padOffset>s-i&&(this.process(n,0),i=0);for(let u=i;u<s;u++)e[u]=0;tf(n,s-8,BigInt(this.length*8),o),this.process(n,0);let a=Ne(t),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let f=c/4,l=this.get();if(f>l.length)throw new Error("_sha2: outputLen bigger than state");for(let u=0;u<f;u++)a.setUint32(4*u,l[u],o)}digest(){let{buffer:t,outputLen:e}=this;this.digestInto(t);let n=t.slice(0,e);return this.destroy(),n}_cloneInto(t){t||(t=new this.constructor),t.set(...this.get());let{blockLen:e,buffer:n,length:s,finished:o,destroyed:i,pos:a}=this;return t.length=s,t.pos=a,t.finished=o,t.destroyed=i,s%e&&t.buffer.set(n),t}};var pn=BigInt(4294967295),ao=BigInt(32);function sa(r,t=!1){return t?{h:Number(r&pn),l:Number(r>>ao&pn)}:{h:Number(r>>ao&pn)|0,l:Number(r&pn)|0}}function ef(r,t=!1){let e=new Uint32Array(r.length),n=new Uint32Array(r.length);for(let s=0;s<r.length;s++){let{h:o,l:i}=sa(r[s],t);[e[s],n[s]]=[o,i]}return[e,n]}var rf=(r,t)=>BigInt(r>>>0)<<ao|BigInt(t>>>0),nf=(r,t,e)=>r>>>e,sf=(r,t,e)=>r<<32-e|t>>>e,of=(r,t,e)=>r>>>e|t<<32-e,af=(r,t,e)=>r<<32-e|t>>>e,cf=(r,t,e)=>r<<64-e|t>>>e-32,lf=(r,t,e)=>r>>>e-32|t<<64-e,uf=(r,t)=>t,ff=(r,t)=>r,hf=(r,t,e)=>r<<e|t>>>32-e,df=(r,t,e)=>t<<e|r>>>32-e,pf=(r,t,e)=>t<<e-32|r>>>64-e,gf=(r,t,e)=>r<<e-32|t>>>64-e;function yf(r,t,e,n){let s=(t>>>0)+(n>>>0);return{h:r+e+(s/2**32|0)|0,l:s|0}}var mf=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),bf=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,wf=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),xf=(r,t,e,n,s)=>t+e+n+s+(r/2**32|0)|0,vf=(r,t,e,n,s)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(s>>>0),Bf=(r,t,e,n,s,o)=>t+e+n+s+o+(r/2**32|0)|0;var Ef={fromBig:sa,split:ef,toBig:rf,shrSH:nf,shrSL:sf,rotrSH:of,rotrSL:af,rotrBH:cf,rotrBL:lf,rotr32H:uf,rotr32L:ff,rotlSH:hf,rotlSL:df,rotlBH:pf,rotlBL:gf,add:yf,add3L:mf,add3H:bf,add4L:wf,add4H:xf,add5H:Bf,add5L:vf},O=Ef;var[Af,Sf]=O.split(["0x428a2f98d728ae22","0x7137449123ef65cd","0xb5c0fbcfec4d3b2f","0xe9b5dba58189dbbc","0x3956c25bf348b538","0x59f111f1b605d019","0x923f82a4af194f9b","0xab1c5ed5da6d8118","0xd807aa98a3030242","0x12835b0145706fbe","0x243185be4ee4b28c","0x550c7dc3d5ffb4e2","0x72be5d74f27b896f","0x80deb1fe3b1696b1","0x9bdc06a725c71235","0xc19bf174cf692694","0xe49b69c19ef14ad2","0xefbe4786384f25e3","0x0fc19dc68b8cd5b5","0x240ca1cc77ac9c65","0x2de92c6f592b0275","0x4a7484aa6ea6e483","0x5cb0a9dcbd41fbd4","0x76f988da831153b5","0x983e5152ee66dfab","0xa831c66d2db43210","0xb00327c898fb213f","0xbf597fc7beef0ee4","0xc6e00bf33da88fc2","0xd5a79147930aa725","0x06ca6351e003826f","0x142929670a0e6e70","0x27b70a8546d22ffc","0x2e1b21385c26c926","0x4d2c6dfc5ac42aed","0x53380d139d95b3df","0x650a73548baf63de","0x766a0abb3c77b2a8","0x81c2c92e47edaee6","0x92722c851482353b","0xa2bfe8a14cf10364","0xa81a664bbc423001","0xc24b8b70d0f89791","0xc76c51a30654be30","0xd192e819d6ef5218","0xd69906245565a910","0xf40e35855771202a","0x106aa07032bbd1b8","0x19a4c116b8d2d0c8","0x1e376c085141ab53","0x2748774cdf8eeb99","0x34b0bcb5e19b48a8","0x391c0cb3c5c95a63","0x4ed8aa4ae3418acb","0x5b9cca4f7763e373","0x682e6ff3d6b2b8a3","0x748f82ee5defb2fc","0x78a5636f43172f60","0x84c87814a1f0ab72","0x8cc702081a6439ec","0x90befffa23631e28","0xa4506cebde82bde9","0xbef9a3f7b2c67915","0xc67178f2e372532b","0xca273eceea26619c","0xd186b8c721c0c207","0xeada7dd6cde0eb1e","0xf57d4f7fee6ed178","0x06f067aa72176fba","0x0a637dc5a2c898a6","0x113f9804bef90dae","0x1b710b35131c471b","0x28db77f523047d84","0x32caab7b40c72493","0x3c9ebe0a15c9bebc","0x431d67c49c100d4c","0x4cc5d4becb3e42b6","0x597f299cfc657e2a","0x5fcb6fab3ad6faec","0x6c44198c4a475817"].map(r=>BigInt(r))),le=new Uint32Array(80),ue=new Uint32Array(80),co=class extends ce{constructor(){super(128,64,16,!1),this.Ah=1779033703,this.Al=-205731576,this.Bh=-1150833019,this.Bl=-2067093701,this.Ch=1013904242,this.Cl=-23791573,this.Dh=-1521486534,this.Dl=1595750129,this.Eh=1359893119,this.El=-1377402159,this.Fh=-1694144372,this.Fl=725511199,this.Gh=528734635,this.Gl=-79577749,this.Hh=1541459225,this.Hl=327033209}get(){let{Ah:t,Al:e,Bh:n,Bl:s,Ch:o,Cl:i,Dh:a,Dl:c,Eh:f,El:l,Fh:u,Fl:h,Gh:y,Gl:b,Hh:m,Hl:d}=this;return[t,e,n,s,o,i,a,c,f,l,u,h,y,b,m,d]}set(t,e,n,s,o,i,a,c,f,l,u,h,y,b,m,d){this.Ah=t|0,this.Al=e|0,this.Bh=n|0,this.Bl=s|0,this.Ch=o|0,this.Cl=i|0,this.Dh=a|0,this.Dl=c|0,this.Eh=f|0,this.El=l|0,this.Fh=u|0,this.Fl=h|0,this.Gh=y|0,this.Gl=b|0,this.Hh=m|0,this.Hl=d|0}process(t,e){for(let p=0;p<16;p++,e+=4)le[p]=t.getUint32(e),ue[p]=t.getUint32(e+=4);for(let p=16;p<80;p++){let S=le[p-15]|0,R=ue[p-15]|0,U=O.rotrSH(S,R,1)^O.rotrSH(S,R,8)^O.shrSH(S,R,7),I=O.rotrSL(S,R,1)^O.rotrSL(S,R,8)^O.shrSL(S,R,7),T=le[p-2]|0,C=ue[p-2]|0,W=O.rotrSH(T,C,19)^O.rotrBH(T,C,61)^O.shrSH(T,C,6),q=O.rotrSL(T,C,19)^O.rotrBL(T,C,61)^O.shrSL(T,C,6),P=O.add4L(I,q,ue[p-7],ue[p-16]),tt=O.add4H(P,U,W,le[p-7],le[p-16]);le[p]=tt|0,ue[p]=P|0}let{Ah:n,Al:s,Bh:o,Bl:i,Ch:a,Cl:c,Dh:f,Dl:l,Eh:u,El:h,Fh:y,Fl:b,Gh:m,Gl:d,Hh:w,Hl:B}=this;for(let p=0;p<80;p++){let S=O.rotrSH(u,h,14)^O.rotrSH(u,h,18)^O.rotrBH(u,h,41),R=O.rotrSL(u,h,14)^O.rotrSL(u,h,18)^O.rotrBL(u,h,41),U=u&y^~u&m,I=h&b^~h&d,T=O.add5L(B,R,I,Sf[p],ue[p]),C=O.add5H(T,w,S,U,Af[p],le[p]),W=T|0,q=O.rotrSH(n,s,28)^O.rotrBH(n,s,34)^O.rotrBH(n,s,39),P=O.rotrSL(n,s,28)^O.rotrBL(n,s,34)^O.rotrBL(n,s,39),tt=n&o^n&a^o&a,E=s&i^s&c^i&c;w=m|0,B=d|0,m=y|0,d=b|0,y=u|0,b=h|0,{h:u,l:h}=O.add(f|0,l|0,C|0,W|0),f=a|0,l=c|0,a=o|0,c=i|0,o=n|0,i=s|0;let N=O.add3L(W,P,E);n=O.add3H(N,C,q,tt),s=N|0}({h:n,l:s}=O.add(this.Ah|0,this.Al|0,n|0,s|0)),{h:o,l:i}=O.add(this.Bh|0,this.Bl|0,o|0,i|0),{h:a,l:c}=O.add(this.Ch|0,this.Cl|0,a|0,c|0),{h:f,l}=O.add(this.Dh|0,this.Dl|0,f|0,l|0),{h:u,l:h}=O.add(this.Eh|0,this.El|0,u|0,h|0),{h:y,l:b}=O.add(this.Fh|0,this.Fl|0,y|0,b|0),{h:m,l:d}=O.add(this.Gh|0,this.Gl|0,m|0,d|0),{h:w,l:B}=O.add(this.Hh|0,this.Hl|0,w|0,B|0),this.set(n,s,o,i,a,c,f,l,u,h,y,b,m,d,w,B)}roundClean(){le.fill(0),ue.fill(0)}destroy(){this.buffer.fill(0),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}};var fe=sr(()=>new co);var mn={};ut(mn,{aInRange:()=>vt,abool:()=>Rt,abytes:()=>ir,bitGet:()=>Uf,bitLen:()=>ho,bitMask:()=>Tr,bitSet:()=>Lf,bytesToHex:()=>zt,bytesToNumberBE:()=>Wt,bytesToNumberLE:()=>de,concatBytes:()=>Zt,createHmacDrbg:()=>po,ensureBytes:()=>Y,equalBytes:()=>Nf,hexToBytes:()=>Ue,hexToNumber:()=>fo,inRange:()=>Nr,isBytes:()=>he,memoized:()=>Re,notImplemented:()=>_f,numberToBytesBE:()=>pe,numberToBytesLE:()=>Le,numberToHexUnpadded:()=>Te,numberToVarBytesBE:()=>Cf,utf8ToBytes:()=>Tf,validateObject:()=>Pt});var gn=BigInt(0),yn=BigInt(1),kf=BigInt(2);function he(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function ir(r){if(!he(r))throw new Error("Uint8Array expected")}function Rt(r,t){if(typeof t!="boolean")throw new Error(r+" boolean expected, got "+t)}var If=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function zt(r){ir(r);let t="";for(let e=0;e<r.length;e++)t+=If[r[e]];return t}function Te(r){let t=r.toString(16);return t.length&1?"0"+t:t}function fo(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return r===""?gn:BigInt("0x"+r)}var Gt={_0:48,_9:57,A:65,F:70,a:97,f:102};function oa(r){if(r>=Gt._0&&r<=Gt._9)return r-Gt._0;if(r>=Gt.A&&r<=Gt.F)return r-(Gt.A-10);if(r>=Gt.a&&r<=Gt.f)return r-(Gt.a-10)}function Ue(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);let t=r.length,e=t/2;if(t%2)throw new Error("hex string expected, got unpadded hex of length "+t);let n=new Uint8Array(e);for(let s=0,o=0;s<e;s++,o+=2){let i=oa(r.charCodeAt(o)),a=oa(r.charCodeAt(o+1));if(i===void 0||a===void 0){let c=r[o]+r[o+1];throw new Error('hex string expected, got non-hex character "'+c+'" at index '+o)}n[s]=i*16+a}return n}function Wt(r){return fo(zt(r))}function de(r){return ir(r),fo(zt(Uint8Array.from(r).reverse()))}function pe(r,t){return Ue(r.toString(16).padStart(t*2,"0"))}function Le(r,t){return pe(r,t).reverse()}function Cf(r){return Ue(Te(r))}function Y(r,t,e){let n;if(typeof t=="string")try{n=Ue(t)}catch(o){throw new Error(r+" must be hex string or Uint8Array, cause: "+o)}else if(he(t))n=Uint8Array.from(t);else throw new Error(r+" must be hex string or Uint8Array");let s=n.length;if(typeof e=="number"&&s!==e)throw new Error(r+" of length "+e+" expected, got "+s);return n}function Zt(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];ir(s),t+=s.length}let e=new Uint8Array(t);for(let n=0,s=0;n<r.length;n++){let o=r[n];e.set(o,s),s+=o.length}return e}function Nf(r,t){if(r.length!==t.length)return!1;let e=0;for(let n=0;n<r.length;n++)e|=r[n]^t[n];return e===0}function Tf(r){if(typeof r!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(r))}var lo=r=>typeof r=="bigint"&&gn<=r;function Nr(r,t,e){return lo(r)&&lo(t)&&lo(e)&&t<=r&&r<e}function vt(r,t,e,n){if(!Nr(t,e,n))throw new Error("expected valid "+r+": "+e+" <= n < "+n+", got "+t)}function ho(r){let t;for(t=0;r>gn;r>>=yn,t+=1);return t}function Uf(r,t){return r>>BigInt(t)&yn}function Lf(r,t,e){return r|(e?yn:gn)<<BigInt(t)}var Tr=r=>(kf<<BigInt(r-1))-yn,uo=r=>new Uint8Array(r),ia=r=>Uint8Array.from(r);function po(r,t,e){if(typeof r!="number"||r<2)throw new Error("hashLen must be a number");if(typeof t!="number"||t<2)throw new Error("qByteLen must be a number");if(typeof e!="function")throw new Error("hmacFn must be a function");let n=uo(r),s=uo(r),o=0,i=()=>{n.fill(1),s.fill(0),o=0},a=(...u)=>e(s,n,...u),c=(u=uo())=>{s=a(ia([0]),u),n=a(),u.length!==0&&(s=a(ia([1]),u),n=a())},f=()=>{if(o++>=1e3)throw new Error("drbg: tried 1000 values");let u=0,h=[];for(;u<t;){n=a();let y=n.slice();h.push(y),u+=n.length}return Zt(...h)};return(u,h)=>{i(),c(u);let y;for(;!(y=h(f()));)c();return i(),y}}var Rf={bigint:r=>typeof r=="bigint",function:r=>typeof r=="function",boolean:r=>typeof r=="boolean",string:r=>typeof r=="string",stringOrUint8Array:r=>typeof r=="string"||he(r),isSafeInteger:r=>Number.isSafeInteger(r),array:r=>Array.isArray(r),field:(r,t)=>t.Fp.isValid(r),hash:r=>typeof r=="function"&&Number.isSafeInteger(r.outputLen)};function Pt(r,t,e={}){let n=(s,o,i)=>{let a=Rf[o];if(typeof a!="function")throw new Error("invalid validator function");let c=r[s];if(!(i&&c===void 0)&&!a(c,r))throw new Error("param "+String(s)+" is invalid. Expected "+o+", got "+c)};for(let[s,o]of Object.entries(t))n(s,o,!1);for(let[s,o]of Object.entries(e))n(s,o,!0);return r}var _f=()=>{throw new Error("not implemented")};function Re(r){let t=new WeakMap;return(e,...n)=>{let s=t.get(e);if(s!==void 0)return s;let o=r(e,...n);return t.set(e,o),o}}var et=BigInt(0),Z=BigInt(1),_e=BigInt(2),Df=BigInt(3),go=BigInt(4),aa=BigInt(5),ca=BigInt(8),Kf=BigInt(9),Of=BigInt(16);function G(r,t){let e=r%t;return e>=et?e:t+e}function Vf(r,t,e){if(t<et)throw new Error("invalid exponent, negatives unsupported");if(e<=et)throw new Error("invalid modulus");if(e===Z)return et;let n=Z;for(;t>et;)t&Z&&(n=n*r%e),r=r*r%e,t>>=Z;return n}function J(r,t,e){let n=r;for(;t-- >et;)n*=n,n%=e;return n}function bn(r,t){if(r===et)throw new Error("invert: expected non-zero number");if(t<=et)throw new Error("invert: expected positive modulus, got "+t);let e=G(r,t),n=t,s=et,o=Z,i=Z,a=et;for(;e!==et;){let f=n/e,l=n%e,u=s-i*f,h=o-a*f;n=e,e=l,s=i,o=a,i=u,a=h}if(n!==Z)throw new Error("invert: does not exist");return G(s,t)}function Hf(r){let t=(r-Z)/_e,e,n,s;for(e=r-Z,n=0;e%_e===et;e/=_e,n++);for(s=_e;s<r&&Vf(s,t,r)!==r-Z;s++)if(s>1e3)throw new Error("Cannot find square root: likely non-prime P");if(n===1){let i=(r+Z)/go;return function(c,f){let l=c.pow(f,i);if(!c.eql(c.sqr(l),f))throw new Error("Cannot find square root");return l}}let o=(e+Z)/_e;return function(a,c){if(a.pow(c,t)===a.neg(a.ONE))throw new Error("Cannot find square root");let f=n,l=a.pow(a.mul(a.ONE,s),e),u=a.pow(c,o),h=a.pow(c,e);for(;!a.eql(h,a.ONE);){if(a.eql(h,a.ZERO))return a.ZERO;let y=1;for(let m=a.sqr(h);y<f&&!a.eql(m,a.ONE);y++)m=a.sqr(m);let b=a.pow(l,Z<<BigInt(f-y-1));l=a.sqr(b),u=a.mul(u,b),h=a.mul(h,l),f=y}return u}}function Pf(r){if(r%go===Df){let t=(r+Z)/go;return function(n,s){let o=n.pow(s,t);if(!n.eql(n.sqr(o),s))throw new Error("Cannot find square root");return o}}if(r%ca===aa){let t=(r-aa)/ca;return function(n,s){let o=n.mul(s,_e),i=n.pow(o,t),a=n.mul(s,i),c=n.mul(n.mul(a,_e),i),f=n.mul(a,n.sub(c,n.ONE));if(!n.eql(n.sqr(f),s))throw new Error("Cannot find square root");return f}}return r%Of,Hf(r)}var la=(r,t)=>(G(r,t)&Z)===Z,Mf=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function yo(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=Mf.reduce((n,s)=>(n[s]="function",n),t);return Pt(r,e)}function Ff(r,t,e){if(e<et)throw new Error("invalid exponent, negatives unsupported");if(e===et)return r.ONE;if(e===Z)return t;let n=r.ONE,s=t;for(;e>et;)e&Z&&(n=r.mul(n,s)),s=r.sqr(s),e>>=Z;return n}function qf(r,t){let e=new Array(t.length),n=t.reduce((o,i,a)=>r.is0(i)?o:(e[a]=o,r.mul(o,i)),r.ONE),s=r.inv(n);return t.reduceRight((o,i,a)=>r.is0(i)?o:(e[a]=r.mul(o,e[a]),r.mul(o,i)),s),e}function mo(r,t){let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function ge(r,t,e=!1,n={}){if(r<=et)throw new Error("invalid field: expected ORDER > 0, got "+r);let{nBitLength:s,nByteLength:o}=mo(r,t);if(o>2048)throw new Error("invalid field: expected ORDER of <= 2048 bytes");let i,a=Object.freeze({ORDER:r,isLE:e,BITS:s,BYTES:o,MASK:Tr(s),ZERO:et,ONE:Z,create:c=>G(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error("invalid field element: expected bigint, got "+typeof c);return et<=c&&c<r},is0:c=>c===et,isOdd:c=>(c&Z)===Z,neg:c=>G(-c,r),eql:(c,f)=>c===f,sqr:c=>G(c*c,r),add:(c,f)=>G(c+f,r),sub:(c,f)=>G(c-f,r),mul:(c,f)=>G(c*f,r),pow:(c,f)=>Ff(a,c,f),div:(c,f)=>G(c*bn(f,r),r),sqrN:c=>c*c,addN:(c,f)=>c+f,subN:(c,f)=>c-f,mulN:(c,f)=>c*f,inv:c=>bn(c,r),sqrt:n.sqrt||(c=>(i||(i=Pf(r)),i(a,c))),invertBatch:c=>qf(a,c),cmov:(c,f,l)=>l?f:c,toBytes:c=>e?Le(c,o):pe(c,o),fromBytes:c=>{if(c.length!==o)throw new Error("Field.fromBytes: expected "+o+" bytes, got "+c.length);return e?de(c):Wt(c)}});return Object.freeze(a)}function ua(r){if(typeof r!="bigint")throw new Error("field order must be bigint");let t=r.toString(2).length;return Math.ceil(t/8)}function bo(r){let t=ua(r);return t+Math.ceil(t/2)}function fa(r,t,e=!1){let n=r.length,s=ua(t),o=bo(t);if(n<16||n<o||n>1024)throw new Error("expected "+o+"-1024 bytes of input, got "+n);let i=e?de(r):Wt(r),a=G(i,t-Z)+Z;return e?Le(a,s):pe(a,s)}var ha=BigInt(0),wn=BigInt(1);function wo(r,t){let e=t.negate();return r?e:t}function da(r,t){if(!Number.isSafeInteger(r)||r<=0||r>t)throw new Error("invalid window size, expected [1.."+t+"], got W="+r)}function xo(r,t){da(r,t);let e=Math.ceil(t/r)+1,n=2**(r-1);return{windows:e,windowSize:n}}function jf(r,t){if(!Array.isArray(r))throw new Error("array expected");r.forEach((e,n)=>{if(!(e instanceof t))throw new Error("invalid point at index "+n)})}function $f(r,t){if(!Array.isArray(r))throw new Error("array of scalars expected");r.forEach((e,n)=>{if(!t.isValid(e))throw new Error("invalid scalar at index "+n)})}var vo=new WeakMap,pa=new WeakMap;function Bo(r){return pa.get(r)||1}function xn(r,t){return{constTimeNegate:wo,hasPrecomputes(e){return Bo(e)!==1},unsafeLadder(e,n,s=r.ZERO){let o=e;for(;n>ha;)n&wn&&(s=s.add(o)),o=o.double(),n>>=wn;return s},precomputeWindow(e,n){let{windows:s,windowSize:o}=xo(n,t),i=[],a=e,c=a;for(let f=0;f<s;f++){c=a,i.push(c);for(let l=1;l<o;l++)c=c.add(a),i.push(c);a=c.double()}return i},wNAF(e,n,s){let{windows:o,windowSize:i}=xo(e,t),a=r.ZERO,c=r.BASE,f=BigInt(2**e-1),l=2**e,u=BigInt(e);for(let h=0;h<o;h++){let y=h*i,b=Number(s&f);s>>=u,b>i&&(b-=l,s+=wn);let m=y,d=y+Math.abs(b)-1,w=h%2!==0,B=b<0;b===0?c=c.add(wo(w,n[m])):a=a.add(wo(B,n[d]))}return{p:a,f:c}},wNAFUnsafe(e,n,s,o=r.ZERO){let{windows:i,windowSize:a}=xo(e,t),c=BigInt(2**e-1),f=2**e,l=BigInt(e);for(let u=0;u<i;u++){let h=u*a;if(s===ha)break;let y=Number(s&c);if(s>>=l,y>a&&(y-=f,s+=wn),y===0)continue;let b=n[h+Math.abs(y)-1];y<0&&(b=b.negate()),o=o.add(b)}return o},getPrecomputes(e,n,s){let o=vo.get(n);return o||(o=this.precomputeWindow(n,e),e!==1&&vo.set(n,s(o))),o},wNAFCached(e,n,s){let o=Bo(e);return this.wNAF(o,this.getPrecomputes(o,e,s),n)},wNAFCachedUnsafe(e,n,s,o){let i=Bo(e);return i===1?this.unsafeLadder(e,n,o):this.wNAFUnsafe(i,this.getPrecomputes(i,e,s),n,o)},setWindowSize(e,n){da(n,t),pa.set(e,n),vo.delete(e)}}}function vn(r,t,e,n){if(jf(e,r),$f(n,t),e.length!==n.length)throw new Error("arrays of points and scalars must have equal length");let s=r.ZERO,o=ho(BigInt(e.length)),i=o>12?o-3:o>4?o-2:o?2:1,a=(1<<i)-1,c=new Array(a+1).fill(s),f=Math.floor((t.BITS-1)/i)*i,l=s;for(let u=f;u>=0;u-=i){c.fill(s);for(let y=0;y<n.length;y++){let b=n[y],m=Number(b>>BigInt(u)&BigInt(a));c[m]=c[m].add(e[y])}let h=s;for(let y=c.length-1,b=s;y>0;y--)b=b.add(c[y]),h=h.add(b);if(l=l.add(h),u!==0)for(let y=0;y<i;y++)l=l.double()}return l}function Ur(r){return yo(r.Fp),Pt(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...mo(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var _t=BigInt(0),Bt=BigInt(1),Bn=BigInt(2),Gf=BigInt(8),zf={zip215:!0};function Wf(r){let t=Ur(r);return Pt(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function ga(r){let t=Wf(r),{Fp:e,n,prehash:s,hash:o,randomBytes:i,nByteLength:a,h:c}=t,f=Bn<<BigInt(a*8)-Bt,l=e.create,u=ge(t.n,t.nBitLength),h=t.uvRatio||((x,g)=>{try{return{isValid:!0,value:e.sqrt(x*e.inv(g))}}catch{return{isValid:!1,value:_t}}}),y=t.adjustScalarBytes||(x=>x),b=t.domain||((x,g,v)=>{if(Rt("phflag",v),g.length||v)throw new Error("Contexts/pre-hash are not supported");return x});function m(x,g){vt("coordinate "+x,g,_t,f)}function d(x){if(!(x instanceof p))throw new Error("ExtendedPoint expected")}let w=Re((x,g)=>{let{ex:v,ey:k,ez:_}=x,D=x.is0();g==null&&(g=D?Gf:e.inv(_));let V=l(v*g),F=l(k*g),K=l(_*g);if(D)return{x:_t,y:Bt};if(K!==Bt)throw new Error("invZ was invalid");return{x:V,y:F}}),B=Re(x=>{let{a:g,d:v}=t;if(x.is0())throw new Error("bad point: ZERO");let{ex:k,ey:_,ez:D,et:V}=x,F=l(k*k),K=l(_*_),$=l(D*D),z=l($*$),nt=l(F*g),st=l($*l(nt+K)),it=l(z+l(v*l(F*K)));if(st!==it)throw new Error("bad point: equation left != right (1)");let lt=l(k*_),bt=l(D*V);if(lt!==bt)throw new Error("bad point: equation left != right (2)");return!0});class p{constructor(g,v,k,_){this.ex=g,this.ey=v,this.ez=k,this.et=_,m("x",g),m("y",v),m("z",k),m("t",_),Object.freeze(this)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(g){if(g instanceof p)throw new Error("extended point not allowed");let{x:v,y:k}=g||{};return m("x",v),m("y",k),new p(v,k,Bt,l(v*k))}static normalizeZ(g){let v=e.invertBatch(g.map(k=>k.ez));return g.map((k,_)=>k.toAffine(v[_])).map(p.fromAffine)}static msm(g,v){return vn(p,u,g,v)}_setWindowSize(g){U.setWindowSize(this,g)}assertValidity(){B(this)}equals(g){d(g);let{ex:v,ey:k,ez:_}=this,{ex:D,ey:V,ez:F}=g,K=l(v*F),$=l(D*_),z=l(k*F),nt=l(V*_);return K===$&&z===nt}is0(){return this.equals(p.ZERO)}negate(){return new p(l(-this.ex),this.ey,this.ez,l(-this.et))}double(){let{a:g}=t,{ex:v,ey:k,ez:_}=this,D=l(v*v),V=l(k*k),F=l(Bn*l(_*_)),K=l(g*D),$=v+k,z=l(l($*$)-D-V),nt=K+V,st=nt-F,it=K-V,lt=l(z*st),bt=l(nt*it),dt=l(z*it),Ht=l(st*nt);return new p(lt,bt,Ht,dt)}add(g){d(g);let{a:v,d:k}=t,{ex:_,ey:D,ez:V,et:F}=this,{ex:K,ey:$,ez:z,et:nt}=g;if(v===BigInt(-1)){let ui=l((D-_)*($+K)),fi=l((D+_)*($-K)),Us=l(fi-ui);if(Us===_t)return this.double();let hi=l(V*Bn*nt),di=l(F*Bn*z),pi=di+hi,gi=fi+ui,yi=di-hi,Al=l(pi*Us),Sl=l(gi*yi),kl=l(pi*yi),Il=l(Us*gi);return new p(Al,Sl,Il,kl)}let st=l(_*K),it=l(D*$),lt=l(F*k*nt),bt=l(V*z),dt=l((_+D)*(K+$)-st-it),Ht=bt-lt,qt=bt+lt,mr=l(it-v*st),xl=l(dt*Ht),vl=l(qt*mr),Bl=l(dt*mr),El=l(Ht*qt);return new p(xl,vl,El,Bl)}subtract(g){return this.add(g.negate())}wNAF(g){return U.wNAFCached(this,g,p.normalizeZ)}multiply(g){let v=g;vt("scalar",v,Bt,n);let{p:k,f:_}=this.wNAF(v);return p.normalizeZ([k,_])[0]}multiplyUnsafe(g,v=p.ZERO){let k=g;return vt("scalar",k,_t,n),k===_t?R:this.is0()||k===Bt?this:U.wNAFCachedUnsafe(this,k,p.normalizeZ,v)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return U.unsafeLadder(this,n).is0()}toAffine(g){return w(this,g)}clearCofactor(){let{h:g}=t;return g===Bt?this:this.multiplyUnsafe(g)}static fromHex(g,v=!1){let{d:k,a:_}=t,D=e.BYTES;g=Y("pointHex",g,D),Rt("zip215",v);let V=g.slice(),F=g[D-1];V[D-1]=F&-129;let K=de(V),$=v?f:e.ORDER;vt("pointHex.y",K,_t,$);let z=l(K*K),nt=l(z-Bt),st=l(k*z-_),{isValid:it,value:lt}=h(nt,st);if(!it)throw new Error("Point.fromHex: invalid y coordinate");let bt=(lt&Bt)===Bt,dt=(F&128)!==0;if(!v&&lt===_t&&dt)throw new Error("Point.fromHex: x=0 and x_0=1");return dt!==bt&&(lt=l(-lt)),p.fromAffine({x:lt,y:K})}static fromPrivateKey(g){return C(g).point}toRawBytes(){let{x:g,y:v}=this.toAffine(),k=Le(v,e.BYTES);return k[k.length-1]|=g&Bt?128:0,k}toHex(){return zt(this.toRawBytes())}}p.BASE=new p(t.Gx,t.Gy,Bt,l(t.Gx*t.Gy)),p.ZERO=new p(_t,Bt,Bt,_t);let{BASE:S,ZERO:R}=p,U=xn(p,a*8);function I(x){return G(x,n)}function T(x){return I(de(x))}function C(x){let g=e.BYTES;x=Y("private key",x,g);let v=Y("hashed private key",o(x),2*g),k=y(v.slice(0,g)),_=v.slice(g,2*g),D=T(k),V=S.multiply(D),F=V.toRawBytes();return{head:k,prefix:_,scalar:D,point:V,pointBytes:F}}function W(x){return C(x).pointBytes}function q(x=new Uint8Array,...g){let v=Zt(...g);return T(o(b(v,Y("context",x),!!s)))}function P(x,g,v={}){x=Y("message",x),s&&(x=s(x));let{prefix:k,scalar:_,pointBytes:D}=C(g),V=q(v.context,k,x),F=S.multiply(V).toRawBytes(),K=q(v.context,F,D,x),$=I(V+K*_);vt("signature.s",$,_t,n);let z=Zt(F,Le($,e.BYTES));return Y("result",z,e.BYTES*2)}let tt=zf;function E(x,g,v,k=tt){let{context:_,zip215:D}=k,V=e.BYTES;x=Y("signature",x,2*V),g=Y("message",g),v=Y("publicKey",v,V),D!==void 0&&Rt("zip215",D),s&&(g=s(g));let F=de(x.slice(V,2*V)),K,$,z;try{K=p.fromHex(v,D),$=p.fromHex(x.slice(0,V),D),z=S.multiplyUnsafe(F)}catch{return!1}if(!D&&K.isSmallOrder())return!1;let nt=q(_,$.toRawBytes(),K.toRawBytes(),g);return $.add(K.multiplyUnsafe(nt)).subtract(z).clearCofactor().equals(p.ZERO)}return S._setWindowSize(8),{CURVE:t,getPublicKey:W,sign:P,verify:E,ExtendedPoint:p,utils:{getExtendedPublicKey:C,randomPrivateKey:()=>i(e.BYTES),precompute(x=8,g=p.BASE){return g._setWindowSize(x),g.multiply(BigInt(3)),g}}}}var Eo=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),ya=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),zp=BigInt(0),Zf=BigInt(1),ma=BigInt(2),Wp=BigInt(3),Jf=BigInt(5),Yf=BigInt(8);function Xf(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),s=BigInt(80),o=Eo,a=r*r%o*r%o,c=J(a,ma,o)*a%o,f=J(c,Zf,o)*r%o,l=J(f,Jf,o)*f%o,u=J(l,t,o)*l%o,h=J(u,e,o)*u%o,y=J(h,n,o)*h%o,b=J(y,s,o)*y%o,m=J(b,s,o)*y%o,d=J(m,t,o)*l%o;return{pow_p_5_8:J(d,ma,o)*r%o,b2:a}}function Qf(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function th(r,t){let e=Eo,n=G(t*t*t,e),s=G(n*n*t,e),o=Xf(r*s).pow_p_5_8,i=G(r*n*o,e),a=G(t*i*i,e),c=i,f=G(i*ya,e),l=a===r,u=a===G(-r,e),h=a===G(-r*ya,e);return l&&(i=c),(u||h)&&(i=f),la(i,e)&&(i=G(-i,e)),{isValid:l||u,value:i}}var eh=ge(Eo,void 0,!0),rh={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:eh,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:Yf,Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:fe,randomBytes:or,adjustScalarBytes:Qf,uvRatio:th},Ao=ga(rh);var ar=32,Dt=64,nh=32;function ba(r,t){let e=r.subarray(0,nh);return Ao.sign(t instanceof Uint8Array?t:t.subarray(),e)}function wa(r,t,e){return Ao.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}var En=class{type="Ed25519";raw;constructor(t){this.raw=Rr(t,ar)}toMultihash(){return ke.digest(Qe(this))}toCID(){return It.createV1(114,this.toMultihash())}toString(){return Q.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:xt(this.raw,t.raw)}verify(t,e){return wa(this.raw,e,t)}},Lr=class{type="Ed25519";raw;publicKey;constructor(t,e){this.raw=Rr(t,Dt),this.publicKey=new En(e)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:xt(this.raw,t.raw)}sign(t){return ba(this.raw,t)}};function So(r){if(r.length>Dt){r=Rr(r,Dt+ar);let n=r.subarray(0,Dt),s=r.subarray(Dt,r.length);return new Lr(n,s)}r=Rr(r,Dt);let t=r.subarray(0,Dt),e=r.subarray(ar);return new Lr(t,e)}function Rr(r,t){if(r=Uint8Array.from(r??[]),r.length!==t)throw new L(`Key must be a Uint8Array of length ${t}, got ${r.length}`);return r}var sh=Math.pow(2,7),oh=Math.pow(2,14),ih=Math.pow(2,21),va=Math.pow(2,28),Ba=Math.pow(2,35),Ea=Math.pow(2,42),Aa=Math.pow(2,49),yt=128,ye=127;function _r(r){if(r<sh)return 1;if(r<oh)return 2;if(r<ih)return 3;if(r<va)return 4;if(r<Ba)return 5;if(r<Ea)return 6;if(r<Aa)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function Sa(r,t,e=0){switch(_r(r)){case 8:t[e++]=r&255|yt,r/=128;case 7:t[e++]=r&255|yt,r/=128;case 6:t[e++]=r&255|yt,r/=128;case 5:t[e++]=r&255|yt,r/=128;case 4:t[e++]=r&255|yt,r>>>=7;case 3:t[e++]=r&255|yt,r>>>=7;case 2:t[e++]=r&255|yt,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function ka(r,t){let e=r[t],n=0;if(n+=e&ye,e<yt||(e=r[t+1],n+=(e&ye)<<7,e<yt)||(e=r[t+2],n+=(e&ye)<<14,e<yt)||(e=r[t+3],n+=(e&ye)<<21,e<yt)||(e=r[t+4],n+=(e&ye)*va,e<yt)||(e=r[t+5],n+=(e&ye)*Ba,e<yt)||(e=r[t+6],n+=(e&ye)*Ea,e<yt)||(e=r[t+7],n+=(e&ye)*Aa,e<yt))return n;throw new RangeError("Could not decode varint")}var ko=new Float32Array([-0]),me=new Uint8Array(ko.buffer);function Ia(r,t,e){ko[0]=r,t[e]=me[0],t[e+1]=me[1],t[e+2]=me[2],t[e+3]=me[3]}function Ca(r,t){return me[0]=r[t],me[1]=r[t+1],me[2]=r[t+2],me[3]=r[t+3],ko[0]}var Io=new Float64Array([-0]),ft=new Uint8Array(Io.buffer);function Na(r,t,e){Io[0]=r,t[e]=ft[0],t[e+1]=ft[1],t[e+2]=ft[2],t[e+3]=ft[3],t[e+4]=ft[4],t[e+5]=ft[5],t[e+6]=ft[6],t[e+7]=ft[7]}function Ta(r,t){return ft[0]=r[t],ft[1]=r[t+1],ft[2]=r[t+2],ft[3]=r[t+3],ft[4]=r[t+4],ft[5]=r[t+5],ft[6]=r[t+6],ft[7]=r[t+7],Io[0]}var ah=BigInt(Number.MAX_SAFE_INTEGER),ch=BigInt(Number.MIN_SAFE_INTEGER),kt=class r{lo;hi;constructor(t,e){this.lo=t|0,this.hi=e|0}toNumber(t=!1){if(!t&&this.hi>>>31>0){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(e+n*4294967296)}return this.lo+this.hi*4294967296}toBigInt(t=!1){if(t)return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n);if(this.hi>>>31){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(BigInt(e)+(BigInt(n)<<32n))}return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n)}toString(t=!1){return this.toBigInt(t).toString()}zzEncode(){let t=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^t)>>>0,this.lo=(this.lo<<1^t)>>>0,this}zzDecode(){let t=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^t)>>>0,this.hi=(this.hi>>>1^t)>>>0,this}length(){let t=this.lo,e=(this.lo>>>28|this.hi<<4)>>>0,n=this.hi>>>24;return n===0?e===0?t<16384?t<128?1:2:t<2097152?3:4:e<16384?e<128?5:6:e<2097152?7:8:n<128?9:10}static fromBigInt(t){if(t===0n)return De;if(t<ah&&t>ch)return this.fromNumber(Number(t));let e=t<0n;e&&(t=-t);let n=t>>32n,s=t-(n<<32n);return e&&(n=~n|0n,s=~s|0n,++s>Ua&&(s=0n,++n>Ua&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(t){if(t===0)return De;let e=t<0;e&&(t=-t);let n=t>>>0,s=(t-n)/4294967296>>>0;return e&&(s=~s>>>0,n=~n>>>0,++n>4294967295&&(n=0,++s>4294967295&&(s=0))),new r(n,s)}static from(t){return typeof t=="number"?r.fromNumber(t):typeof t=="bigint"?r.fromBigInt(t):typeof t=="string"?r.fromBigInt(BigInt(t)):t.low!=null||t.high!=null?new r(t.low>>>0,t.high>>>0):De}},De=new kt(0,0);De.toBigInt=function(){return 0n};De.zzEncode=De.zzDecode=function(){return this};De.length=function(){return 1};var Ua=4294967296n;function La(r){let t=0,e=0;for(let n=0;n<r.length;++n)e=r.charCodeAt(n),e<128?t+=1:e<2048?t+=2:(e&64512)===55296&&(r.charCodeAt(n+1)&64512)===56320?(++n,t+=4):t+=3;return t}function Ra(r,t,e){if(e-t<1)return"";let s,o=[],i=0,a;for(;t<e;)a=r[t++],a<128?o[i++]=a:a>191&&a<224?o[i++]=(a&31)<<6|r[t++]&63:a>239&&a<365?(a=((a&7)<<18|(r[t++]&63)<<12|(r[t++]&63)<<6|r[t++]&63)-65536,o[i++]=55296+(a>>10),o[i++]=56320+(a&1023)):o[i++]=(a&15)<<12|(r[t++]&63)<<6|r[t++]&63,i>8191&&((s??(s=[])).push(String.fromCharCode.apply(String,o)),i=0);return s!=null?(i>0&&s.push(String.fromCharCode.apply(String,o.slice(0,i))),s.join("")):String.fromCharCode.apply(String,o.slice(0,i))}function Co(r,t,e){let n=e,s,o;for(let i=0;i<r.length;++i)s=r.charCodeAt(i),s<128?t[e++]=s:s<2048?(t[e++]=s>>6|192,t[e++]=s&63|128):(s&64512)===55296&&((o=r.charCodeAt(i+1))&64512)===56320?(s=65536+((s&1023)<<10)+(o&1023),++i,t[e++]=s>>18|240,t[e++]=s>>12&63|128,t[e++]=s>>6&63|128,t[e++]=s&63|128):(t[e++]=s>>12|224,t[e++]=s>>6&63|128,t[e++]=s&63|128);return e-n}function Kt(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function An(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var No=class{buf;pos;len;_slice=Uint8Array.prototype.subarray;constructor(t){this.buf=t,this.pos=0,this.len=t.length}uint32(){let t=4294967295;if(t=(this.buf[this.pos]&127)>>>0,this.buf[this.pos++]<128||(t=(t|(this.buf[this.pos]&127)<<7)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<14)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<21)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&15)<<28)>>>0,this.buf[this.pos++]<128))return t;if((this.pos+=5)>this.len)throw this.pos=this.len,Kt(this,10);return t}int32(){return this.uint32()|0}sint32(){let t=this.uint32();return t>>>1^-(t&1)|0}bool(){return this.uint32()!==0}fixed32(){if(this.pos+4>this.len)throw Kt(this,4);return An(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Kt(this,4);return An(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Kt(this,4);let t=Ca(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Kt(this,4);let t=Ta(this.buf,this.pos);return this.pos+=8,t}bytes(){let t=this.uint32(),e=this.pos,n=this.pos+t;if(n>this.len)throw Kt(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return Ra(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw Kt(this,t);this.pos+=t}else do if(this.pos>=this.len)throw Kt(this);while((this.buf[this.pos++]&128)!==0);return this}skipType(t){switch(t){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;(t=this.uint32()&7)!==4;)this.skipType(t);break;case 5:this.skip(4);break;default:throw Error(`invalid wire type ${t} at offset ${this.pos}`)}return this}readLongVarint(){let t=new kt(0,0),e=0;if(this.len-this.pos>4){for(;e<4;++e)if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t;if(t.lo=(t.lo|(this.buf[this.pos]&127)<<28)>>>0,t.hi=(t.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return t;e=0}else{for(;e<3;++e){if(this.pos>=this.len)throw Kt(this);if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t}return t.lo=(t.lo|(this.buf[this.pos++]&127)<<e*7)>>>0,t}if(this.len-this.pos>4){for(;e<5;++e)if(t.hi=(t.hi|(this.buf[this.pos]&127)<<e*7+3)>>>0,this.buf[this.pos++]<128)return t}else for(;e<5;++e){if(this.pos>=this.len)throw Kt(this);if(t.hi=(t.hi|(this.buf[this.pos]&127)<<e*7+3)>>>0,this.buf[this.pos++]<128)return t}throw Error("invalid varint encoding")}readFixed64(){if(this.pos+8>this.len)throw Kt(this,8);let t=An(this.buf,this.pos+=4),e=An(this.buf,this.pos+=4);return new kt(t,e)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){let t=ka(this.buf,this.pos);return this.pos+=_r(t),t}uint64String(){return this.readLongVarint().toString(!0)}sint64(){return this.readLongVarint().zzDecode().toBigInt()}sint64Number(){return this.readLongVarint().zzDecode().toNumber()}sint64String(){return this.readLongVarint().zzDecode().toString()}fixed64(){return this.readFixed64().toBigInt()}fixed64Number(){return this.readFixed64().toNumber()}fixed64String(){return this.readFixed64().toString()}sfixed64(){return this.readFixed64().toBigInt()}sfixed64Number(){return this.readFixed64().toNumber()}sfixed64String(){return this.readFixed64().toString()}};function To(r){return new No(r instanceof Uint8Array?r:r.subarray())}function Sn(r,t,e){let n=To(r);return t.decode(n,void 0,e)}function Uo(r){let t=r??8192,e=t>>>1,n,s=t;return function(i){if(i<1||i>e)return St(i);s+i>t&&(n=St(t),s=0);let a=n.subarray(s,s+=i);return(s&7)!==0&&(s=(s|7)+1),a}}var Ke=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function Lo(){}var _o=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},lh=Uo();function uh(r){return globalThis.Buffer!=null?St(r):lh(r)}var Kr=class{len;head;tail;states;constructor(){this.len=0,this.head=new Ke(Lo,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new Ke(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new Do((t=t>>>0)<128?1:t<16384?2:t<2097152?3:t<268435456?4:5,t)).len,this}int32(t){return t<0?this._push(kn,10,kt.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=kt.fromBigInt(t);return this._push(kn,e.length(),e)}uint64Number(t){return this._push(Sa,_r(t),t)}uint64String(t){return this.uint64(BigInt(t))}int64(t){return this.uint64(t)}int64Number(t){return this.uint64Number(t)}int64String(t){return this.uint64String(t)}sint64(t){let e=kt.fromBigInt(t).zzEncode();return this._push(kn,e.length(),e)}sint64Number(t){let e=kt.fromNumber(t).zzEncode();return this._push(kn,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(Ro,1,t?1:0)}fixed32(t){return this._push(Dr,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=kt.fromBigInt(t);return this._push(Dr,4,e.lo)._push(Dr,4,e.hi)}fixed64Number(t){let e=kt.fromNumber(t);return this._push(Dr,4,e.lo)._push(Dr,4,e.hi)}fixed64String(t){return this.fixed64(BigInt(t))}sfixed64(t){return this.fixed64(t)}sfixed64Number(t){return this.fixed64Number(t)}sfixed64String(t){return this.fixed64String(t)}float(t){return this._push(Ia,4,t)}double(t){return this._push(Na,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(Ro,1,0):this.uint32(e)._push(hh,e,t)}string(t){let e=La(t);return e!==0?this.uint32(e)._push(Co,e,t):this._push(Ro,1,0)}fork(){return this.states=new _o(this),this.head=this.tail=new Ke(Lo,0,0),this.len=0,this}reset(){return this.states!=null?(this.head=this.states.head,this.tail=this.states.tail,this.len=this.states.len,this.states=this.states.next):(this.head=this.tail=new Ke(Lo,0,0),this.len=0),this}ldelim(){let t=this.head,e=this.tail,n=this.len;return this.reset().uint32(n),n!==0&&(this.tail.next=t.next,this.tail=e,this.len+=n),this}finish(){let t=this.head.next,e=uh(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function Ro(r,t,e){t[e]=r&255}function fh(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var Do=class extends Ke{next;constructor(t,e){super(fh,t,e),this.next=void 0}};function kn(r,t,e){for(;r.hi!==0;)t[e++]=r.lo&127|128,r.lo=(r.lo>>>7|r.hi<<25)>>>0,r.hi>>>=7;for(;r.lo>127;)t[e++]=r.lo&127|128,r.lo=r.lo>>>7;t[e++]=r.lo}function Dr(r,t,e){t[e]=r&255,t[e+1]=r>>>8&255,t[e+2]=r>>>16&255,t[e+3]=r>>>24}function hh(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(Kr.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(dh,t,r),this},Kr.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(ph,t,r),this});function dh(r,t,e){t.set(r,e)}function ph(r,t,e){r.length<40?Co(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(H(r),e)}function Ko(){return new Kr}function In(r,t){let e=Ko();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var cr;(function(r){r[r.VARINT=0]="VARINT",r[r.BIT64=1]="BIT64",r[r.LENGTH_DELIMITED=2]="LENGTH_DELIMITED",r[r.START_GROUP=3]="START_GROUP",r[r.END_GROUP=4]="END_GROUP",r[r.BIT32=5]="BIT32"})(cr||(cr={}));function Cn(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function Oo(r){function t(s){if(r[s.toString()]==null)throw new Error("Invalid enum value");return r[s]}let e=function(o,i){let a=t(o);i.int32(a)},n=function(o){let i=o.int32();return t(i)};return Cn("enum",cr.VARINT,e,n)}function Nn(r,t){return Cn("message",cr.LENGTH_DELIMITED,r,t)}var rt;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.secp256k1="secp256k1",r.ECDSA="ECDSA"})(rt||(rt={}));var Vo;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1",r[r.ECDSA=3]="ECDSA"})(Vo||(Vo={}));(function(r){r.codec=()=>Oo(Vo)})(rt||(rt={}));var be;(function(r){let t;r.codec=()=>(t==null&&(t=Nn((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),rt.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let o={},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let a=e.uint32();switch(a>>>3){case 1:{o.Type=rt.codec().decode(e);break}case 2:{o.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return o})),t),r.encode=e=>In(e,r.codec()),r.decode=(e,n)=>Sn(e,r.codec(),n)})(be||(be={}));var Or;(function(r){let t;r.codec=()=>(t==null&&(t=Nn((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),rt.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let o={},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let a=e.uint32();switch(a>>>3){case 1:{o.Type=rt.codec().decode(e);break}case 2:{o.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return o})),t),r.encode=e=>In(e,r.codec()),r.decode=(e,n)=>Sn(e,r.codec(),n)})(Or||(Or={}));function Oe(r){if(isNaN(r)||r<=0)throw new L("random bytes length must be a Number bigger than 0");return or(r)}var Hr={};ut(Hr,{MAX_RSA_KEY_SIZE:()=>Po,generateRSAKeyPair:()=>Ha,jwkToJWKKeyPair:()=>Pa,jwkToPkcs1:()=>wh,jwkToPkix:()=>jo,jwkToRSAPrivateKey:()=>zo,pkcs1MessageToJwk:()=>Fo,pkcs1MessageToRSAPrivateKey:()=>Tn,pkcs1ToJwk:()=>bh,pkcs1ToRSAPrivateKey:()=>$o,pkixMessageToJwk:()=>qo,pkixMessageToRSAPublicKey:()=>Go,pkixToJwk:()=>xh,pkixToRSAPublicKey:()=>Va});var gh=new Uint32Array([1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298]),we=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),xe=new Uint32Array(64),Ho=class extends ce{constructor(){super(64,32,8,!1),this.A=we[0]|0,this.B=we[1]|0,this.C=we[2]|0,this.D=we[3]|0,this.E=we[4]|0,this.F=we[5]|0,this.G=we[6]|0,this.H=we[7]|0}get(){let{A:t,B:e,C:n,D:s,E:o,F:i,G:a,H:c}=this;return[t,e,n,s,o,i,a,c]}set(t,e,n,s,o,i,a,c){this.A=t|0,this.B=e|0,this.C=n|0,this.D=s|0,this.E=o|0,this.F=i|0,this.G=a|0,this.H=c|0}process(t,e){for(let u=0;u<16;u++,e+=4)xe[u]=t.getUint32(e,!1);for(let u=16;u<64;u++){let h=xe[u-15],y=xe[u-2],b=Lt(h,7)^Lt(h,18)^h>>>3,m=Lt(y,17)^Lt(y,19)^y>>>10;xe[u]=m+xe[u-7]+b+xe[u-16]|0}let{A:n,B:s,C:o,D:i,E:a,F:c,G:f,H:l}=this;for(let u=0;u<64;u++){let h=Lt(a,6)^Lt(a,11)^Lt(a,25),y=l+h+hn(a,c,f)+gh[u]+xe[u]|0,m=(Lt(n,2)^Lt(n,13)^Lt(n,22))+dn(n,s,o)|0;l=f,f=c,c=a,a=i+y|0,i=o,o=s,s=n,n=y+m|0}n=n+this.A|0,s=s+this.B|0,o=o+this.C|0,i=i+this.D|0,a=a+this.E|0,c=c+this.F|0,f=f+this.G|0,l=l+this.H|0,this.set(n,s,o,i,a,c,f,l)}roundClean(){xe.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var ve=sr(()=>new Ho);var lr=class{type="RSA";jwk;_raw;_multihash;constructor(t,e){this.jwk=t,this._multihash=e}get raw(){return this._raw==null&&(this._raw=Hr.jwkToPkix(this.jwk)),this._raw}toMultihash(){return this._multihash}toCID(){return It.createV1(114,this._multihash)}toString(){return Q.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:xt(this.raw,t.raw)}verify(t,e){return Oa(this.jwk,e,t)}},Vr=class{type="RSA";jwk;_raw;publicKey;constructor(t,e){this.jwk=t,this.publicKey=e}get raw(){return this._raw==null&&(this._raw=Hr.jwkToPkcs1(this.jwk)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:xt(this.raw,t.raw)}sign(t){return Ka(this.jwk,t)}};var Po=8192,Mo=18,yh=1062,mh=Uint8Array.from([48,13,6,9,42,134,72,134,247,13,1,1,1,5,0]);function bh(r){let t=Tt(r);return Fo(t)}function Fo(r){return{n:j(r[1],"base64url"),e:j(r[2],"base64url"),d:j(r[3],"base64url"),p:j(r[4],"base64url"),q:j(r[5],"base64url"),dp:j(r[6],"base64url"),dq:j(r[7],"base64url"),qi:j(r[8],"base64url"),kty:"RSA"}}function wh(r){if(r.n==null||r.e==null||r.d==null||r.p==null||r.q==null||r.dp==null||r.dq==null||r.qi==null)throw new L("JWK was missing components");return Ut([gt(Uint8Array.from([0])),gt(H(r.n,"base64url")),gt(H(r.e,"base64url")),gt(H(r.d,"base64url")),gt(H(r.p,"base64url")),gt(H(r.q,"base64url")),gt(H(r.dp,"base64url")),gt(H(r.dq,"base64url")),gt(H(r.qi,"base64url"))]).subarray()}function xh(r){let t=Tt(r,{offset:0});return qo(t)}function qo(r){let t=Tt(r[1],{offset:0});return{kty:"RSA",n:j(t[0],"base64url"),e:j(t[1],"base64url")}}function jo(r){if(r.n==null||r.e==null)throw new L("JWK was missing components");return Ut([mh,Cr(Ut([gt(H(r.n,"base64url")),gt(H(r.e,"base64url"))]))]).subarray()}function $o(r){let t=Tt(r);return Tn(t)}function Tn(r){let t=Fo(r);return zo(t)}function Va(r,t){if(r.byteLength>=yh)throw new qe("Key size is too large");let e=Tt(r,{offset:0});return Go(e,r,t)}function Go(r,t,e){let n=qo(r);if(e==null){let s=ve(be.encode({Type:rt.RSA,Data:t}));e=Nt(Mo,s)}return new lr(n,e)}function zo(r){if(Fa(r)>Po)throw new L("Key size is too large");let t=Pa(r),e=ve(be.encode({Type:rt.RSA,Data:jo(t.publicKey)})),n=Nt(Mo,e);return new Vr(t.privateKey,new lr(t.publicKey,n))}async function Ha(r){if(r>Po)throw new L("Key size is too large");let t=await Ma(r),e=ve(be.encode({Type:rt.RSA,Data:jo(t.publicKey)})),n=Nt(Mo,e);return new Vr(t.privateKey,new lr(t.publicKey,n))}function Pa(r){if(r==null)throw new L("Missing key parameter");return{privateKey:r,publicKey:{kty:r.kty,n:r.n,e:r.e}}}async function Ma(r){let t=await wt.get().subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:r,publicExponent:new Uint8Array([1,0,1]),hash:{name:"SHA-256"}},!0,["sign","verify"]),e=await vh(t);return{privateKey:e[0],publicKey:e[1]}}async function Ka(r,t){let e=await wt.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await wt.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},e,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(n,0,n.byteLength)}async function Oa(r,t,e){let n=await wt.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return wt.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,t,e instanceof Uint8Array?e:e.subarray())}async function vh(r){if(r.privateKey==null||r.publicKey==null)throw new L("Private and public key are required");return Promise.all([wt.get().subtle.exportKey("jwk",r.privateKey),wt.get().subtle.exportKey("jwk",r.publicKey)])}function Fa(r){if(r.kty!=="RSA")throw new L("invalid key type");if(r.n==null)throw new L("invalid key modulus");return H(r.n,"base64url").length*8}var Un=class extends nr{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,un(t);let n=ae(e);if(this.iHash=t.create(),typeof this.iHash.update!="function")throw new Error("Expected instance of class which extends utils.Hash");this.blockLen=this.iHash.blockLen,this.outputLen=this.iHash.outputLen;let s=this.blockLen,o=new Uint8Array(s);o.set(n.length>s?t.create().update(n).digest():n);for(let i=0;i<o.length;i++)o[i]^=54;this.iHash.update(o),this.oHash=t.create();for(let i=0;i<o.length;i++)o[i]^=106;this.oHash.update(o),o.fill(0)}update(t){return rr(this),this.iHash.update(t),this}digestInto(t){rr(this),er(t,this.outputLen),this.finished=!0,this.iHash.digestInto(t),this.oHash.update(t),this.oHash.digestInto(t),this.destroy()}digest(){let t=new Uint8Array(this.oHash.outputLen);return this.digestInto(t),t}_cloneInto(t){t||(t=Object.create(Object.getPrototypeOf(this),{}));let{oHash:e,iHash:n,finished:s,destroyed:o,blockLen:i,outputLen:a}=this;return t=t,t.finished=s,t.destroyed=o,t.blockLen=i,t.outputLen=a,t.oHash=e._cloneInto(t.oHash),t.iHash=n._cloneInto(t.iHash),t}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},Pr=(r,t,e)=>new Un(r,t).update(e).digest();Pr.create=(r,t)=>new Un(r,t);function qa(r){r.lowS!==void 0&&Rt("lowS",r.lowS),r.prehash!==void 0&&Rt("prehash",r.prehash)}function Bh(r){let t=Ur(r);Pt(t,{a:"field",b:"field"},{allowedPrivateKeyLengths:"array",wrapPrivateKey:"boolean",isTorsionFree:"function",clearCofactor:"function",allowInfinityPoint:"boolean",fromBytes:"function",toBytes:"function"});let{endo:e,Fp:n,a:s}=t;if(e){if(!n.eql(s,n.ZERO))throw new Error("invalid endomorphism, can only be defined for Koblitz curves that have a=0");if(typeof e!="object"||typeof e.beta!="bigint"||typeof e.splitScalar!="function")throw new Error("invalid endomorphism, expected beta: bigint and splitScalar: function")}return Object.freeze({...t})}var{bytesToNumberBE:Eh,hexToBytes:Ah}=mn,Wo=class extends Error{constructor(t=""){super(t)}},Jt={Err:Wo,_tlv:{encode:(r,t)=>{let{Err:e}=Jt;if(r<0||r>256)throw new e("tlv.encode: wrong tag");if(t.length&1)throw new e("tlv.encode: unpadded data");let n=t.length/2,s=Te(n);if(s.length/2&128)throw new e("tlv.encode: long form length too big");let o=n>127?Te(s.length/2|128):"";return Te(r)+o+s+t},decode(r,t){let{Err:e}=Jt,n=0;if(r<0||r>256)throw new e("tlv.encode: wrong tag");if(t.length<2||t[n++]!==r)throw new e("tlv.decode: wrong tlv");let s=t[n++],o=!!(s&128),i=0;if(!o)i=s;else{let c=s&127;if(!c)throw new e("tlv.decode(long): indefinite length not supported");if(c>4)throw new e("tlv.decode(long): byte length is too big");let f=t.subarray(n,n+c);if(f.length!==c)throw new e("tlv.decode: length bytes not complete");if(f[0]===0)throw new e("tlv.decode(long): zero leftmost byte");for(let l of f)i=i<<8|l;if(n+=c,i<128)throw new e("tlv.decode(long): not minimal encoding")}let a=t.subarray(n,n+i);if(a.length!==i)throw new e("tlv.decode: wrong value length");return{v:a,l:t.subarray(n+i)}}},_int:{encode(r){let{Err:t}=Jt;if(r<Yt)throw new t("integer: negative integers are not allowed");let e=Te(r);if(Number.parseInt(e[0],16)&8&&(e="00"+e),e.length&1)throw new t("unexpected DER parsing assertion: unpadded hex");return e},decode(r){let{Err:t}=Jt;if(r[0]&128)throw new t("invalid signature integer: negative");if(r[0]===0&&!(r[1]&128))throw new t("invalid signature integer: unnecessary leading zero");return Eh(r)}},toSig(r){let{Err:t,_int:e,_tlv:n}=Jt,s=typeof r=="string"?Ah(r):r;ir(s);let{v:o,l:i}=n.decode(48,s);if(i.length)throw new t("invalid signature: left bytes after parsing");let{v:a,l:c}=n.decode(2,o),{v:f,l}=n.decode(2,c);if(l.length)throw new t("invalid signature: left bytes after parsing");return{r:e.decode(a),s:e.decode(f)}},hexFromSig(r){let{_tlv:t,_int:e}=Jt,n=t.encode(2,e.encode(r.r)),s=t.encode(2,e.encode(r.s)),o=n+s;return t.encode(48,o)}},Yt=BigInt(0),ot=BigInt(1),xy=BigInt(2),ja=BigInt(3),vy=BigInt(4);function Sh(r){let t=Bh(r),{Fp:e}=t,n=ge(t.n,t.nBitLength),s=t.toBytes||((m,d,w)=>{let B=d.toAffine();return Zt(Uint8Array.from([4]),e.toBytes(B.x),e.toBytes(B.y))}),o=t.fromBytes||(m=>{let d=m.subarray(1),w=e.fromBytes(d.subarray(0,e.BYTES)),B=e.fromBytes(d.subarray(e.BYTES,2*e.BYTES));return{x:w,y:B}});function i(m){let{a:d,b:w}=t,B=e.sqr(m),p=e.mul(B,m);return e.add(e.add(p,e.mul(m,d)),w)}if(!e.eql(e.sqr(t.Gy),i(t.Gx)))throw new Error("bad generator point: equation left != right");function a(m){return Nr(m,ot,t.n)}function c(m){let{allowedPrivateKeyLengths:d,nByteLength:w,wrapPrivateKey:B,n:p}=t;if(d&&typeof m!="bigint"){if(he(m)&&(m=zt(m)),typeof m!="string"||!d.includes(m.length))throw new Error("invalid private key");m=m.padStart(w*2,"0")}let S;try{S=typeof m=="bigint"?m:Wt(Y("private key",m,w))}catch{throw new Error("invalid private key, expected hex or "+w+" bytes, got "+typeof m)}return B&&(S=G(S,p)),vt("private key",S,ot,p),S}function f(m){if(!(m instanceof h))throw new Error("ProjectivePoint expected")}let l=Re((m,d)=>{let{px:w,py:B,pz:p}=m;if(e.eql(p,e.ONE))return{x:w,y:B};let S=m.is0();d==null&&(d=S?e.ONE:e.inv(p));let R=e.mul(w,d),U=e.mul(B,d),I=e.mul(p,d);if(S)return{x:e.ZERO,y:e.ZERO};if(!e.eql(I,e.ONE))throw new Error("invZ was invalid");return{x:R,y:U}}),u=Re(m=>{if(m.is0()){if(t.allowInfinityPoint&&!e.is0(m.py))return;throw new Error("bad point: ZERO")}let{x:d,y:w}=m.toAffine();if(!e.isValid(d)||!e.isValid(w))throw new Error("bad point: x or y not FE");let B=e.sqr(w),p=i(d);if(!e.eql(B,p))throw new Error("bad point: equation left != right");if(!m.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});class h{constructor(d,w,B){if(this.px=d,this.py=w,this.pz=B,d==null||!e.isValid(d))throw new Error("x required");if(w==null||!e.isValid(w))throw new Error("y required");if(B==null||!e.isValid(B))throw new Error("z required");Object.freeze(this)}static fromAffine(d){let{x:w,y:B}=d||{};if(!d||!e.isValid(w)||!e.isValid(B))throw new Error("invalid affine point");if(d instanceof h)throw new Error("projective point not allowed");let p=S=>e.eql(S,e.ZERO);return p(w)&&p(B)?h.ZERO:new h(w,B,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(d){let w=e.invertBatch(d.map(B=>B.pz));return d.map((B,p)=>B.toAffine(w[p])).map(h.fromAffine)}static fromHex(d){let w=h.fromAffine(o(Y("pointHex",d)));return w.assertValidity(),w}static fromPrivateKey(d){return h.BASE.multiply(c(d))}static msm(d,w){return vn(h,n,d,w)}_setWindowSize(d){b.setWindowSize(this,d)}assertValidity(){u(this)}hasEvenY(){let{y:d}=this.toAffine();if(e.isOdd)return!e.isOdd(d);throw new Error("Field doesn't support isOdd")}equals(d){f(d);let{px:w,py:B,pz:p}=this,{px:S,py:R,pz:U}=d,I=e.eql(e.mul(w,U),e.mul(S,p)),T=e.eql(e.mul(B,U),e.mul(R,p));return I&&T}negate(){return new h(this.px,e.neg(this.py),this.pz)}double(){let{a:d,b:w}=t,B=e.mul(w,ja),{px:p,py:S,pz:R}=this,U=e.ZERO,I=e.ZERO,T=e.ZERO,C=e.mul(p,p),W=e.mul(S,S),q=e.mul(R,R),P=e.mul(p,S);return P=e.add(P,P),T=e.mul(p,R),T=e.add(T,T),U=e.mul(d,T),I=e.mul(B,q),I=e.add(U,I),U=e.sub(W,I),I=e.add(W,I),I=e.mul(U,I),U=e.mul(P,U),T=e.mul(B,T),q=e.mul(d,q),P=e.sub(C,q),P=e.mul(d,P),P=e.add(P,T),T=e.add(C,C),C=e.add(T,C),C=e.add(C,q),C=e.mul(C,P),I=e.add(I,C),q=e.mul(S,R),q=e.add(q,q),C=e.mul(q,P),U=e.sub(U,C),T=e.mul(q,W),T=e.add(T,T),T=e.add(T,T),new h(U,I,T)}add(d){f(d);let{px:w,py:B,pz:p}=this,{px:S,py:R,pz:U}=d,I=e.ZERO,T=e.ZERO,C=e.ZERO,W=t.a,q=e.mul(t.b,ja),P=e.mul(w,S),tt=e.mul(B,R),E=e.mul(p,U),N=e.add(w,B),x=e.add(S,R);N=e.mul(N,x),x=e.add(P,tt),N=e.sub(N,x),x=e.add(w,p);let g=e.add(S,U);return x=e.mul(x,g),g=e.add(P,E),x=e.sub(x,g),g=e.add(B,p),I=e.add(R,U),g=e.mul(g,I),I=e.add(tt,E),g=e.sub(g,I),C=e.mul(W,x),I=e.mul(q,E),C=e.add(I,C),I=e.sub(tt,C),C=e.add(tt,C),T=e.mul(I,C),tt=e.add(P,P),tt=e.add(tt,P),E=e.mul(W,E),x=e.mul(q,x),tt=e.add(tt,E),E=e.sub(P,E),E=e.mul(W,E),x=e.add(x,E),P=e.mul(tt,x),T=e.add(T,P),P=e.mul(g,x),I=e.mul(N,I),I=e.sub(I,P),P=e.mul(N,tt),C=e.mul(g,C),C=e.add(C,P),new h(I,T,C)}subtract(d){return this.add(d.negate())}is0(){return this.equals(h.ZERO)}wNAF(d){return b.wNAFCached(this,d,h.normalizeZ)}multiplyUnsafe(d){let{endo:w,n:B}=t;vt("scalar",d,Yt,B);let p=h.ZERO;if(d===Yt)return p;if(this.is0()||d===ot)return this;if(!w||b.hasPrecomputes(this))return b.wNAFCachedUnsafe(this,d,h.normalizeZ);let{k1neg:S,k1:R,k2neg:U,k2:I}=w.splitScalar(d),T=p,C=p,W=this;for(;R>Yt||I>Yt;)R&ot&&(T=T.add(W)),I&ot&&(C=C.add(W)),W=W.double(),R>>=ot,I>>=ot;return S&&(T=T.negate()),U&&(C=C.negate()),C=new h(e.mul(C.px,w.beta),C.py,C.pz),T.add(C)}multiply(d){let{endo:w,n:B}=t;vt("scalar",d,ot,B);let p,S;if(w){let{k1neg:R,k1:U,k2neg:I,k2:T}=w.splitScalar(d),{p:C,f:W}=this.wNAF(U),{p:q,f:P}=this.wNAF(T);C=b.constTimeNegate(R,C),q=b.constTimeNegate(I,q),q=new h(e.mul(q.px,w.beta),q.py,q.pz),p=C.add(q),S=W.add(P)}else{let{p:R,f:U}=this.wNAF(d);p=R,S=U}return h.normalizeZ([p,S])[0]}multiplyAndAddUnsafe(d,w,B){let p=h.BASE,S=(U,I)=>I===Yt||I===ot||!U.equals(p)?U.multiplyUnsafe(I):U.multiply(I),R=S(this,w).add(S(d,B));return R.is0()?void 0:R}toAffine(d){return l(this,d)}isTorsionFree(){let{h:d,isTorsionFree:w}=t;if(d===ot)return!0;if(w)return w(h,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h:d,clearCofactor:w}=t;return d===ot?this:w?w(h,this):this.multiplyUnsafe(t.h)}toRawBytes(d=!0){return Rt("isCompressed",d),this.assertValidity(),s(h,this,d)}toHex(d=!0){return Rt("isCompressed",d),zt(this.toRawBytes(d))}}h.BASE=new h(t.Gx,t.Gy,e.ONE),h.ZERO=new h(e.ZERO,e.ONE,e.ZERO);let y=t.nBitLength,b=xn(h,t.endo?Math.ceil(y/2):y);return{CURVE:t,ProjectivePoint:h,normPrivateKeyToScalar:c,weierstrassEquation:i,isWithinCurveOrder:a}}function kh(r){let t=Ur(r);return Pt(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function $a(r){let t=kh(r),{Fp:e,n}=t,s=e.BYTES+1,o=2*e.BYTES+1;function i(E){return G(E,n)}function a(E){return bn(E,n)}let{ProjectivePoint:c,normPrivateKeyToScalar:f,weierstrassEquation:l,isWithinCurveOrder:u}=Sh({...t,toBytes(E,N,x){let g=N.toAffine(),v=e.toBytes(g.x),k=Zt;return Rt("isCompressed",x),x?k(Uint8Array.from([N.hasEvenY()?2:3]),v):k(Uint8Array.from([4]),v,e.toBytes(g.y))},fromBytes(E){let N=E.length,x=E[0],g=E.subarray(1);if(N===s&&(x===2||x===3)){let v=Wt(g);if(!Nr(v,ot,e.ORDER))throw new Error("Point is not on curve");let k=l(v),_;try{_=e.sqrt(k)}catch(F){let K=F instanceof Error?": "+F.message:"";throw new Error("Point is not on curve"+K)}let D=(_&ot)===ot;return(x&1)===1!==D&&(_=e.neg(_)),{x:v,y:_}}else if(N===o&&x===4){let v=e.fromBytes(g.subarray(0,e.BYTES)),k=e.fromBytes(g.subarray(e.BYTES,2*e.BYTES));return{x:v,y:k}}else{let v=s,k=o;throw new Error("invalid Point, expected length of "+v+", or uncompressed "+k+", got "+N)}}}),h=E=>zt(pe(E,t.nByteLength));function y(E){let N=n>>ot;return E>N}function b(E){return y(E)?i(-E):E}let m=(E,N,x)=>Wt(E.slice(N,x));class d{constructor(N,x,g){this.r=N,this.s=x,this.recovery=g,this.assertValidity()}static fromCompact(N){let x=t.nByteLength;return N=Y("compactSignature",N,x*2),new d(m(N,0,x),m(N,x,2*x))}static fromDER(N){let{r:x,s:g}=Jt.toSig(Y("DER",N));return new d(x,g)}assertValidity(){vt("r",this.r,ot,n),vt("s",this.s,ot,n)}addRecoveryBit(N){return new d(this.r,this.s,N)}recoverPublicKey(N){let{r:x,s:g,recovery:v}=this,k=U(Y("msgHash",N));if(v==null||![0,1,2,3].includes(v))throw new Error("recovery id invalid");let _=v===2||v===3?x+t.n:x;if(_>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let D=(v&1)===0?"02":"03",V=c.fromHex(D+h(_)),F=a(_),K=i(-k*F),$=i(g*F),z=c.BASE.multiplyAndAddUnsafe(V,K,$);if(!z)throw new Error("point at infinify");return z.assertValidity(),z}hasHighS(){return y(this.s)}normalizeS(){return this.hasHighS()?new d(this.r,i(-this.s),this.recovery):this}toDERRawBytes(){return Ue(this.toDERHex())}toDERHex(){return Jt.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return Ue(this.toCompactHex())}toCompactHex(){return h(this.r)+h(this.s)}}let w={isValidPrivateKey(E){try{return f(E),!0}catch{return!1}},normPrivateKeyToScalar:f,randomPrivateKey:()=>{let E=bo(t.n);return fa(t.randomBytes(E),t.n)},precompute(E=8,N=c.BASE){return N._setWindowSize(E),N.multiply(BigInt(3)),N}};function B(E,N=!0){return c.fromPrivateKey(E).toRawBytes(N)}function p(E){let N=he(E),x=typeof E=="string",g=(N||x)&&E.length;return N?g===s||g===o:x?g===2*s||g===2*o:E instanceof c}function S(E,N,x=!0){if(p(E))throw new Error("first arg must be private key");if(!p(N))throw new Error("second arg must be public key");return c.fromHex(N).multiply(f(E)).toRawBytes(x)}let R=t.bits2int||function(E){if(E.length>8192)throw new Error("input is too large");let N=Wt(E),x=E.length*8-t.nBitLength;return x>0?N>>BigInt(x):N},U=t.bits2int_modN||function(E){return i(R(E))},I=Tr(t.nBitLength);function T(E){return vt("num < 2^"+t.nBitLength,E,Yt,I),pe(E,t.nByteLength)}function C(E,N,x=W){if(["recovered","canonical"].some(st=>st in x))throw new Error("sign() legacy options not supported");let{hash:g,randomBytes:v}=t,{lowS:k,prehash:_,extraEntropy:D}=x;k==null&&(k=!0),E=Y("msgHash",E),qa(x),_&&(E=Y("prehashed msgHash",g(E)));let V=U(E),F=f(N),K=[T(F),T(V)];if(D!=null&&D!==!1){let st=D===!0?v(e.BYTES):D;K.push(Y("extraEntropy",st))}let $=Zt(...K),z=V;function nt(st){let it=R(st);if(!u(it))return;let lt=a(it),bt=c.BASE.multiply(it).toAffine(),dt=i(bt.x);if(dt===Yt)return;let Ht=i(lt*i(z+dt*F));if(Ht===Yt)return;let qt=(bt.x===dt?0:2)|Number(bt.y&ot),mr=Ht;return k&&y(Ht)&&(mr=b(Ht),qt^=1),new d(dt,mr,qt)}return{seed:$,k2sig:nt}}let W={lowS:t.lowS,prehash:!1},q={lowS:t.lowS,prehash:!1};function P(E,N,x=W){let{seed:g,k2sig:v}=C(E,N,x),k=t;return po(k.hash.outputLen,k.nByteLength,k.hmac)(g,v)}c.BASE._setWindowSize(8);function tt(E,N,x,g=q){let v=E;N=Y("msgHash",N),x=Y("publicKey",x);let{lowS:k,prehash:_,format:D}=g;if(qa(g),"strict"in g)throw new Error("options.strict was renamed to lowS");if(D!==void 0&&D!=="compact"&&D!=="der")throw new Error("format must be compact or der");let V=typeof v=="string"||he(v),F=!V&&!D&&typeof v=="object"&&v!==null&&typeof v.r=="bigint"&&typeof v.s=="bigint";if(!V&&!F)throw new Error("invalid signature, expected Uint8Array, hex string or Signature instance");let K,$;try{if(F&&(K=new d(v.r,v.s)),V){try{D!=="compact"&&(K=d.fromDER(v))}catch(qt){if(!(qt instanceof Jt.Err))throw qt}!K&&D!=="der"&&(K=d.fromCompact(v))}$=c.fromHex(x)}catch{return!1}if(!K||k&&K.hasHighS())return!1;_&&(N=t.hash(N));let{r:z,s:nt}=K,st=U(N),it=a(nt),lt=i(st*it),bt=i(z*it),dt=c.BASE.multiplyAndAddUnsafe($,lt,bt)?.toAffine();return dt?i(dt.x)===z:!1}return{CURVE:t,getPublicKey:B,getSharedSecret:S,sign:P,verify:tt,ProjectivePoint:c,Signature:d,utils:w}}function Ih(r){return{hash:r,hmac:(t,...e)=>Pr(r,t,io(...e)),randomBytes:or}}function Ga(r,t){let e=n=>$a({...r,...Ih(n)});return{...e(t),create:e}}var Za=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),za=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),Ch=BigInt(1),Zo=BigInt(2),Wa=(r,t)=>(r+t/Zo)/t;function Nh(r){let t=Za,e=BigInt(3),n=BigInt(6),s=BigInt(11),o=BigInt(22),i=BigInt(23),a=BigInt(44),c=BigInt(88),f=r*r*r%t,l=f*f*r%t,u=J(l,e,t)*l%t,h=J(u,e,t)*l%t,y=J(h,Zo,t)*f%t,b=J(y,s,t)*y%t,m=J(b,o,t)*b%t,d=J(m,a,t)*m%t,w=J(d,c,t)*d%t,B=J(w,a,t)*m%t,p=J(B,e,t)*l%t,S=J(p,i,t)*b%t,R=J(S,n,t)*f%t,U=J(R,Zo,t);if(!Jo.eql(Jo.sqr(U),r))throw new Error("Cannot find square root");return U}var Jo=ge(Za,void 0,void 0,{sqrt:Nh}),Ot=Ga({a:BigInt(0),b:BigInt(7),Fp:Jo,n:za,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=za,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-Ch*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),s=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),o=e,i=BigInt("0x100000000000000000000000000000000"),a=Wa(o*r,t),c=Wa(-n*r,t),f=G(r-a*e-c*s,t),l=G(-a*n-c*o,t),u=f>i,h=l>i;if(u&&(f=t-f),h&&(l=t-l),f>i||l>i)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:u,k1:f,k2neg:h,k2:l}}}},ve),Ty=BigInt(0);var Uy=Ot.ProjectivePoint;function Yo(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}var Ja=32;function Ya(r,t){let e=Ye.digest(t instanceof Uint8Array?t:t.subarray());if(Yo(e))return e.then(({digest:n})=>Ot.sign(n,r).toDERRawBytes()).catch(n=>{throw new br(String(n))});try{return Ot.sign(e.digest,r).toDERRawBytes()}catch(n){throw new br(String(n))}}function Xa(r,t,e){let n=Ye.digest(e instanceof Uint8Array?e:e.subarray());if(Yo(n))return n.then(({digest:s})=>Ot.verify(t,s,r)).catch(s=>{throw new wr(String(s))});try{return Ot.verify(t,n.digest,r)}catch(s){throw new wr(String(s))}}var Ln=class{type="secp256k1";raw;_key;constructor(t){this._key=ec(t),this.raw=Qa(this._key)}toMultihash(){return ke.digest(Qe(this))}toCID(){return It.createV1(114,this.toMultihash())}toString(){return Q.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:xt(this.raw,t.raw)}verify(t,e){return Xa(this._key,e,t)}},Rn=class{type="secp256k1";raw;publicKey;constructor(t,e){this.raw=tc(t),this.publicKey=new Ln(e??rc(t))}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:xt(this.raw,t.raw)}sign(t){return Ya(this.raw,t)}};function Xo(r){return new Rn(r)}function Qa(r){return Ot.ProjectivePoint.fromHex(r).toRawBytes(!0)}function tc(r){try{return Ot.getPublicKey(r,!0),r}catch(t){throw new xr(String(t))}}function ec(r){try{return Ot.ProjectivePoint.fromHex(r),r}catch(t){throw new qe(String(t))}}function rc(r){try{return Ot.getPublicKey(r,!0)}catch(t){throw new xr(String(t))}}function Qe(r){return be.encode({Type:rt[r.type],Data:r.raw})}function nc(r){let t=Or.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case rt.RSA:return $o(e);case rt.Ed25519:return So(e);case rt.secp256k1:return Xo(e);case rt.ECDSA:return Ji(e);default:throw new je}}function sc(r){if(r.byteLength===Dt)return So(r);if(r.byteLength===Ja)return Xo(r);let t=Tt(r),e=t[2]?.[0];if(e===$i||e===Gi||e===zi)return oo(t);if(t.length>8)return Tn(t);throw new L("Could not extract private key from raw bytes")}function Ve(r){return Or.encode({Type:rt[r.type],Data:r.raw})}function oc(r,t,e,n){un(r);let s=na({dkLen:32,asyncTick:10},n),{c:o,dkLen:i,asyncTick:a}=s;if(tr(o),tr(i),tr(a),o<1)throw new Error("PBKDF2: iterations (c) should be >= 1");let c=ae(t),f=ae(e),l=new Uint8Array(i),u=Pr.create(r,c),h=u._cloneInto().update(f);return{c:o,dkLen:i,asyncTick:a,DK:l,PRF:u,PRFSalt:h}}function ic(r,t,e,n,s){return r.destroy(),t.destroy(),n&&n.destroy(),s.fill(0),e}function ac(r,t,e,n){let{c:s,dkLen:o,DK:i,PRF:a,PRFSalt:c}=oc(r,t,e,n),f,l=new Uint8Array(4),u=Ne(l),h=new Uint8Array(a.outputLen);for(let y=1,b=0;b<o;y++,b+=a.outputLen){let m=i.subarray(b,b+a.outputLen);u.setInt32(0,y,!1),(f=c._cloneInto(f)).update(l).digestInto(h),m.set(h.subarray(0,m.length));for(let d=1;d<s;d++){a._cloneInto(f).update(h).digestInto(h);for(let w=0;w<m.length;w++)m[w]^=h[w]}}return ic(a,c,i,f,h)}async function _n(r,t,e,n){let{c:s,dkLen:o,asyncTick:i,DK:a,PRF:c,PRFSalt:f}=oc(r,t,e,n),l,u=new Uint8Array(4),h=Ne(u),y=new Uint8Array(c.outputLen);for(let b=1,m=0;m<o;b++,m+=c.outputLen){let d=a.subarray(m,m+c.outputLen);h.setInt32(0,b,!1),(l=f._cloneInto(l)).update(u).digestInto(y),d.set(y.subarray(0,d.length)),await ea(s-1,i,()=>{c._cloneInto(l).update(y).digestInto(y);for(let w=0;w<d.length;w++)d[w]^=y[w]})}return ic(c,f,a,l,y)}var Mr=new Uint32Array([1732584193,4023233417,2562383102,271733878,3285377520]),Be=new Uint32Array(80),Qo=class extends ce{constructor(){super(64,20,8,!1),this.A=Mr[0]|0,this.B=Mr[1]|0,this.C=Mr[2]|0,this.D=Mr[3]|0,this.E=Mr[4]|0}get(){let{A:t,B:e,C:n,D:s,E:o}=this;return[t,e,n,s,o]}set(t,e,n,s,o){this.A=t|0,this.B=e|0,this.C=n|0,this.D=s|0,this.E=o|0}process(t,e){for(let c=0;c<16;c++,e+=4)Be[c]=t.getUint32(e,!1);for(let c=16;c<80;c++)Be[c]=fn(Be[c-3]^Be[c-8]^Be[c-14]^Be[c-16],1);let{A:n,B:s,C:o,D:i,E:a}=this;for(let c=0;c<80;c++){let f,l;c<20?(f=hn(s,o,i),l=1518500249):c<40?(f=s^o^i,l=1859775393):c<60?(f=dn(s,o,i),l=2400959708):(f=s^o^i,l=3395469782);let u=fn(n,5)+f+a+l+Be[c]|0;a=i,i=o,o=fn(s,30),s=n,n=u}n=n+this.A|0,s=s+this.B|0,o=o+this.C|0,i=i+this.D|0,a=a+this.E|0,this.set(n,s,o,i,a)}roundClean(){Be.fill(0)}destroy(){this.set(0,0,0,0,0),this.buffer.fill(0)}},cc=sr(()=>new Qo);var lc={sha1:cc,"sha2-256":ve,"sha2-512":fe};function Fr(r,t,e,n,s){if(s!=="sha1"&&s!=="sha2-256"&&s!=="sha2-512"){let a=Object.keys(lc).join(" / ");throw new L(`Hash '${s}' is unknown or not supported. Must be ${a}`)}let o=lc[s],i=ac(o,r,t,{c:e,dkLen:n});return Ie.encode(i).substring(1)}var Xt="/",uc=new TextEncoder().encode(Xt),Dn=uc[0],qr=class r{_buf;constructor(t,e){if(typeof t=="string")this._buf=H(t);else if(t instanceof Uint8Array)this._buf=t;else throw new Error("Invalid key, should be String of Uint8Array");if(e==null&&(e=!0),e&&this.clean(),this._buf.byteLength===0||this._buf[0]!==Dn)throw new Error("Invalid key")}toString(t="utf8"){return j(this._buf,t)}uint8Array(){return this._buf}get[Symbol.toStringTag](){return`Key(${this.toString()})`}static withNamespaces(t){return new r(t.join(Xt))}static random(){return new r(Math.random().toString().substring(2))}static asKey(t){return t instanceof Uint8Array||typeof t=="string"?new r(t):typeof t.uint8Array=="function"?new r(t.uint8Array()):null}clean(){if((this._buf==null||this._buf.byteLength===0)&&(this._buf=uc),this._buf[0]!==Dn){let t=new Uint8Array(this._buf.byteLength+1);t.fill(Dn,0,1),t.set(this._buf,1),this._buf=t}for(;this._buf.byteLength>1&&this._buf[this._buf.byteLength-1]===Dn;)this._buf=this._buf.subarray(0,-1)}less(t){let e=this.list(),n=t.list();for(let s=0;s<e.length;s++){if(n.length<s+1)return!1;let o=e[s],i=n[s];if(o<i)return!0;if(o>i)return!1}return e.length<n.length}reverse(){return r.withNamespaces(this.list().slice().reverse())}namespaces(){return this.list()}baseNamespace(){let t=this.namespaces();return t[t.length-1]}list(){return this.toString().split(Xt).slice(1)}type(){return Th(this.baseNamespace())}name(){return Uh(this.baseNamespace())}instance(t){return new r(this.toString()+":"+t)}path(){let t=this.parent().toString();return t.endsWith(Xt)||(t+=Xt),t+=this.type(),new r(t)}parent(){let t=this.list();return t.length===1?new r(Xt):new r(t.slice(0,-1).join(Xt))}child(t){return this.toString()===Xt?t:t.toString()===Xt?this:new r(this.toString()+t.toString(),!1)}isAncestorOf(t){return t.toString()===this.toString()?!1:t.toString().startsWith(this.toString())}isDecendantOf(t){return t.toString()===this.toString()?!1:this.toString().startsWith(t.toString())}isTopLevel(){return this.list().length===1}concat(...t){return r.withNamespaces([...this.namespaces(),...Lh(t.map(e=>e.namespaces()))])}};function Th(r){let t=r.split(":");return t.length<2?"":t.slice(0,-1).join(":")}function Uh(r){let t=r.split(":");return t[t.length-1]}function Lh(r){return[].concat(...r)}var wc=Ls(bc(),1),xc=wc.default;var wl=Ls(Nc(),1);var hr={};ut(hr,{create:()=>Jh,derivedEmptyPasswordKey:()=>Vn});var Vn={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function Jh(r){let t=r?.algorithm??"AES-GCM",e=r?.keyLength??16,n=r?.nonceLength??12,s=r?.digest??"SHA-256",o=r?.saltLength??16,i=r?.iterations??32767,a=wt.get();e*=8;async function c(u,h){let y=a.getRandomValues(new Uint8Array(o)),b=a.getRandomValues(new Uint8Array(n)),m={name:t,iv:b};typeof h=="string"&&(h=H(h));let d;if(h.length===0){d=await a.subtle.importKey("jwk",Vn,{name:"AES-GCM"},!0,["encrypt"]);try{let B={name:"PBKDF2",salt:y,iterations:i,hash:{name:s}},p=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);d=await a.subtle.deriveKey(B,p,{name:t,length:e},!0,["encrypt"])}catch{d=await a.subtle.importKey("jwk",Vn,{name:"AES-GCM"},!0,["encrypt"])}}else{let B={name:"PBKDF2",salt:y,iterations:i,hash:{name:s}},p=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);d=await a.subtle.deriveKey(B,p,{name:t,length:e},!0,["encrypt"])}let w=await a.subtle.encrypt(m,d,u);return Je([y,m.iv,new Uint8Array(w)])}async function f(u,h){let y=u.subarray(0,o),b=u.subarray(o,o+n),m=u.subarray(o+n),d={name:t,iv:b};typeof h=="string"&&(h=H(h));let w;if(h.length===0)try{let p={name:"PBKDF2",salt:y,iterations:i,hash:{name:s}},S=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);w=await a.subtle.deriveKey(p,S,{name:t,length:e},!0,["decrypt"])}catch{w=await a.subtle.importKey("jwk",Vn,{name:"AES-GCM"},!0,["decrypt"])}else{let p={name:"PBKDF2",salt:y,iterations:i,hash:{name:s}},S=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);w=await a.subtle.deriveKey(p,S,{name:t,length:e},!0,["decrypt"])}let B=await a.subtle.decrypt(d,w,m);return new Uint8Array(B)}return{encrypt:c,decrypt:f}}var M=Ls(Tc());function He(r,t){let e=0;if(r.length===1)return r[0];for(let n=r.length-1;n>=0;n--)e+=r[r.length-1-n]*Math.pow(2,t*n);return e}function Ee(r,t,e=-1){let n=e,s=r,o=0,i=Math.pow(2,t);for(let a=1;a<8;a++){if(r<i){let c;if(n<0)c=new ArrayBuffer(a),o=a;else{if(n<a)return new ArrayBuffer(0);c=new ArrayBuffer(n),o=n}let f=new Uint8Array(c);for(let l=a-1;l>=0;l--){let u=Math.pow(2,l*t);f[o-l-1]=Math.floor(s/u),s-=f[o-l-1]*u}return c}i*=Math.pow(2,t)}return new ArrayBuffer(0)}function Mn(...r){let t=0,e=0;for(let o of r)t+=o.length;let n=new ArrayBuffer(t),s=new Uint8Array(n);for(let o of r)s.set(o,e),e+=o.length;return s}function ri(){let r=new Uint8Array(this.valueHex);if(this.valueHex.byteLength>=2){let a=r[0]===255&&r[1]&128,c=r[0]===0&&(r[1]&128)===0;(a||c)&&this.warnings.push("Needlessly long format")}let t=new ArrayBuffer(this.valueHex.byteLength),e=new Uint8Array(t);for(let a=0;a<this.valueHex.byteLength;a++)e[a]=0;e[0]=r[0]&128;let n=He(e,8),s=new ArrayBuffer(this.valueHex.byteLength),o=new Uint8Array(s);for(let a=0;a<this.valueHex.byteLength;a++)o[a]=r[a];return o[0]&=127,He(o,8)-n}function Uc(r){let t=r<0?r*-1:r,e=128;for(let n=1;n<8;n++){if(t<=e){if(r<0){let i=e-t,a=Ee(i,8,n),c=new Uint8Array(a);return c[0]|=128,a}let s=Ee(t,8,n),o=new Uint8Array(s);if(o[0]&128){let i=s.slice(0),a=new Uint8Array(i);s=new ArrayBuffer(s.byteLength+1),o=new Uint8Array(s);for(let c=0;c<i.byteLength;c++)o[c+1]=a[c];o[0]=0}return s}e*=Math.pow(2,8)}return new ArrayBuffer(0)}function Lc(r,t){if(r.byteLength!==t.byteLength)return!1;let e=new Uint8Array(r),n=new Uint8Array(t);for(let s=0;s<e.length;s++)if(e[s]!==n[s])return!1;return!0}function Et(r,t){let e=r.toString(10);if(t<e.length)return"";let n=t-e.length,s=new Array(n);for(let i=0;i<n;i++)s[i]="0";return s.join("").concat(e)}var Jm=Math.log(2);function Fn(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function ni(r){let t=0,e=0;for(let s=0;s<r.length;s++){let o=r[s];t+=o.byteLength}let n=new Uint8Array(t);for(let s=0;s<r.length;s++){let o=r[s];n.set(new Uint8Array(o),e),e+=o.byteLength}return n.buffer}function se(r,t,e,n){return t instanceof Uint8Array?t.byteLength?e<0?(r.error="Wrong parameter: inputOffset less than zero",!1):n<0?(r.error="Wrong parameter: inputLength less than zero",!1):t.byteLength-e-n<0?(r.error="End of input reached before message was fully decoded (inconsistent offset and length values)",!1):!0:(r.error="Wrong parameter: inputBuffer has zero length",!1):(r.error="Wrong parameter: inputBuffer must be 'Uint8Array'",!1)}var Gr=class{constructor(){this.items=[]}write(t){this.items.push(t)}final(){return ni(this.items)}},jr=[new Uint8Array([1])],Rc="0123456789";var pr="",Vt=new ArrayBuffer(0),si=new Uint8Array(0),zr="EndOfContent",Dc="OCTET STRING",Kc="BIT STRING";function oe(r){var t;return t=class extends r{get valueHex(){return this.valueHexView.slice().buffer}set valueHex(n){this.valueHexView=new Uint8Array(n)}constructor(...n){var s;super(...n);let o=n[0]||{};this.isHexOnly=(s=o.isHexOnly)!==null&&s!==void 0?s:!1,this.valueHexView=o.valueHex?M.BufferSourceConverter.toUint8Array(o.valueHex):si}fromBER(n,s,o){let i=n instanceof ArrayBuffer?new Uint8Array(n):n;if(!se(this,i,s,o))return-1;let a=s+o;return this.valueHexView=i.subarray(s,a),this.valueHexView.length?(this.blockLength=o,a):(this.warnings.push("Zero buffer length"),s)}toBER(n=!1){return this.isHexOnly?n?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.byteLength===this.valueHexView.buffer.byteLength?this.valueHexView.buffer:this.valueHexView.slice().buffer:(this.error="Flag 'isHexOnly' is not set, abort",Vt)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:M.Convert.ToHex(this.valueHexView)}}},t.NAME="hexBlock",t}var te=class{static blockName(){return this.NAME}get valueBeforeDecode(){return this.valueBeforeDecodeView.slice().buffer}set valueBeforeDecode(t){this.valueBeforeDecodeView=new Uint8Array(t)}constructor({blockLength:t=0,error:e=pr,warnings:n=[],valueBeforeDecode:s=si}={}){this.blockLength=t,this.error=e,this.warnings=n,this.valueBeforeDecodeView=M.BufferSourceConverter.toUint8Array(s)}toJSON(){return{blockName:this.constructor.NAME,blockLength:this.blockLength,error:this.error,warnings:this.warnings,valueBeforeDecode:M.Convert.ToHex(this.valueBeforeDecodeView)}}};te.NAME="baseBlock";var ht=class extends te{fromBER(t,e,n){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}toBER(t,e){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}};ht.NAME="valueBlock";var qn=class extends oe(te){constructor({idBlock:t={}}={}){var e,n,s,o;super(),t?(this.isHexOnly=(e=t.isHexOnly)!==null&&e!==void 0?e:!1,this.valueHexView=t.valueHex?M.BufferSourceConverter.toUint8Array(t.valueHex):si,this.tagClass=(n=t.tagClass)!==null&&n!==void 0?n:-1,this.tagNumber=(s=t.tagNumber)!==null&&s!==void 0?s:-1,this.isConstructed=(o=t.isConstructed)!==null&&o!==void 0?o:!1):(this.tagClass=-1,this.tagNumber=-1,this.isConstructed=!1)}toBER(t=!1){let e=0;switch(this.tagClass){case 1:e|=0;break;case 2:e|=64;break;case 3:e|=128;break;case 4:e|=192;break;default:return this.error="Unknown tag class",Vt}if(this.isConstructed&&(e|=32),this.tagNumber<31&&!this.isHexOnly){let s=new Uint8Array(1);if(!t){let o=this.tagNumber;o&=31,e|=o,s[0]=e}return s.buffer}if(!this.isHexOnly){let s=Ee(this.tagNumber,7),o=new Uint8Array(s),i=s.byteLength,a=new Uint8Array(i+1);if(a[0]=e|31,!t){for(let c=0;c<i-1;c++)a[c+1]=o[c]|128;a[i]=o[i-1]}return a.buffer}let n=new Uint8Array(this.valueHexView.byteLength+1);if(n[0]=e|31,!t){let s=this.valueHexView;for(let o=0;o<s.length-1;o++)n[o+1]=s[o]|128;n[this.valueHexView.byteLength]=s[s.length-1]}return n.buffer}fromBER(t,e,n){let s=M.BufferSourceConverter.toUint8Array(t);if(!se(this,s,e,n))return-1;let o=s.subarray(e,e+n);if(o.length===0)return this.error="Zero buffer length",-1;switch(o[0]&192){case 0:this.tagClass=1;break;case 64:this.tagClass=2;break;case 128:this.tagClass=3;break;case 192:this.tagClass=4;break;default:return this.error="Unknown tag class",-1}this.isConstructed=(o[0]&32)===32,this.isHexOnly=!1;let a=o[0]&31;if(a!==31)this.tagNumber=a,this.blockLength=1;else{let c=1,f=this.valueHexView=new Uint8Array(255),l=255;for(;o[c]&128;){if(f[c-1]=o[c]&127,c++,c>=o.length)return this.error="End of input reached before message was fully decoded",-1;if(c===l){l+=255;let h=new Uint8Array(l);for(let y=0;y<f.length;y++)h[y]=f[y];f=this.valueHexView=new Uint8Array(l)}}this.blockLength=c+1,f[c-1]=o[c]&127;let u=new Uint8Array(c);for(let h=0;h<c;h++)u[h]=f[h];f=this.valueHexView=new Uint8Array(c),f.set(u),this.blockLength<=9?this.tagNumber=He(f,7):(this.isHexOnly=!0,this.warnings.push("Tag too long, represented as hex-coded"))}if(this.tagClass===1&&this.isConstructed)switch(this.tagNumber){case 1:case 2:case 5:case 6:case 9:case 13:case 14:case 23:case 24:case 31:case 32:case 33:case 34:return this.error="Constructed encoding used for primitive type",-1}return e+this.blockLength}toJSON(){return{...super.toJSON(),tagClass:this.tagClass,tagNumber:this.tagNumber,isConstructed:this.isConstructed}}};qn.NAME="identificationBlock";var jn=class extends te{constructor({lenBlock:t={}}={}){var e,n,s;super(),this.isIndefiniteForm=(e=t.isIndefiniteForm)!==null&&e!==void 0?e:!1,this.longFormUsed=(n=t.longFormUsed)!==null&&n!==void 0?n:!1,this.length=(s=t.length)!==null&&s!==void 0?s:0}fromBER(t,e,n){let s=M.BufferSourceConverter.toUint8Array(t);if(!se(this,s,e,n))return-1;let o=s.subarray(e,e+n);if(o.length===0)return this.error="Zero buffer length",-1;if(o[0]===255)return this.error="Length block 0xFF is reserved by standard",-1;if(this.isIndefiniteForm=o[0]===128,this.isIndefiniteForm)return this.blockLength=1,e+this.blockLength;if(this.longFormUsed=!!(o[0]&128),this.longFormUsed===!1)return this.length=o[0],this.blockLength=1,e+this.blockLength;let i=o[0]&127;if(i>8)return this.error="Too big integer",-1;if(i+1>o.length)return this.error="End of input reached before message was fully decoded",-1;let a=e+1,c=s.subarray(a,a+i);return c[i-1]===0&&this.warnings.push("Needlessly long encoded length"),this.length=He(c,8),this.longFormUsed&&this.length<=127&&this.warnings.push("Unnecessary usage of long length form"),this.blockLength=i+1,e+this.blockLength}toBER(t=!1){let e,n;if(this.length>127&&(this.longFormUsed=!0),this.isIndefiniteForm)return e=new ArrayBuffer(1),t===!1&&(n=new Uint8Array(e),n[0]=128),e;if(this.longFormUsed){let s=Ee(this.length,8);if(s.byteLength>127)return this.error="Too big length",Vt;if(e=new ArrayBuffer(s.byteLength+1),t)return e;let o=new Uint8Array(s);n=new Uint8Array(e),n[0]=s.byteLength|128;for(let i=0;i<s.byteLength;i++)n[i+1]=o[i];return e}return e=new ArrayBuffer(1),t===!1&&(n=new Uint8Array(e),n[0]=this.length),e}toJSON(){return{...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,longFormUsed:this.longFormUsed,length:this.length}}};jn.NAME="lengthBlock";var A={},at=class extends te{constructor({name:t=pr,optional:e=!1,primitiveSchema:n,...s}={},o){super(s),this.name=t,this.optional=e,n&&(this.primitiveSchema=n),this.idBlock=new qn(s),this.lenBlock=new jn(s),this.valueBlock=o?new o(s):new ht(s)}fromBER(t,e,n){let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}toBER(t,e){let n=e||new Gr;e||Oc(this);let s=this.idBlock.toBER(t);if(n.write(s),this.lenBlock.isIndefiniteForm)n.write(new Uint8Array([128]).buffer),this.valueBlock.toBER(t,n),n.write(new ArrayBuffer(2));else{let o=this.valueBlock.toBER(t);this.lenBlock.length=o.byteLength;let i=this.lenBlock.toBER(t);n.write(i),n.write(o)}return e?Vt:n.final()}toJSON(){let t={...super.toJSON(),idBlock:this.idBlock.toJSON(),lenBlock:this.lenBlock.toJSON(),valueBlock:this.valueBlock.toJSON(),name:this.name,optional:this.optional};return this.primitiveSchema&&(t.primitiveSchema=this.primitiveSchema.toJSON()),t}toString(t="ascii"){return t==="ascii"?this.onAsciiEncoding():M.Convert.ToHex(this.toBER())}onAsciiEncoding(){let t=this.constructor.NAME,e=M.Convert.ToHex(this.valueBlock.valueBeforeDecodeView);return`${t} : ${e}`}isEqual(t){if(this===t)return!0;if(!(t instanceof this.constructor))return!1;let e=this.toBER(),n=t.toBER();return Lc(e,n)}};at.NAME="BaseBlock";function Oc(r){var t;if(r instanceof A.Constructed)for(let e of r.valueBlock.value)Oc(e)&&(r.lenBlock.isIndefiniteForm=!0);return!!(!((t=r.lenBlock)===null||t===void 0)&&t.isIndefiniteForm)}var $n=class extends at{getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}constructor({value:t=pr,...e}={},n){super(e,n),t&&this.fromString(t)}fromBER(t,e,n){let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.fromBuffer(this.valueBlock.valueHexView),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}onAsciiEncoding(){return`${this.constructor.NAME} : '${this.valueBlock.value}'`}};$n.NAME="BaseStringBlock";var Gn=class extends oe(ht){constructor({isHexOnly:t=!0,...e}={}){super(e),this.isHexOnly=t}};Gn.NAME="PrimitiveValueBlock";var Vc,zn=class extends at{constructor(t={}){super(t,Gn),this.idBlock.isConstructed=!1}};Vc=zn;A.Primitive=Vc;zn.NAME="PRIMITIVE";function od(r,t){if(r instanceof t)return r;let e=new t;return e.idBlock=r.idBlock,e.lenBlock=r.lenBlock,e.warnings=r.warnings,e.valueBeforeDecodeView=r.valueBeforeDecodeView,e}function Is(r,t=0,e=r.length){let n=t,s=new at({},ht),o=new te;if(!se(o,r,t,e))return s.error=o.error,{offset:-1,result:s};if(!r.subarray(t,t+e).length)return s.error="Zero buffer length",{offset:-1,result:s};let a=s.idBlock.fromBER(r,t,e);if(s.idBlock.warnings.length&&s.warnings.concat(s.idBlock.warnings),a===-1)return s.error=s.idBlock.error,{offset:-1,result:s};if(t=a,e-=s.idBlock.blockLength,a=s.lenBlock.fromBER(r,t,e),s.lenBlock.warnings.length&&s.warnings.concat(s.lenBlock.warnings),a===-1)return s.error=s.lenBlock.error,{offset:-1,result:s};if(t=a,e-=s.lenBlock.blockLength,!s.idBlock.isConstructed&&s.lenBlock.isIndefiniteForm)return s.error="Indefinite length form used for primitive encoding form",{offset:-1,result:s};let c=at;switch(s.idBlock.tagClass){case 1:if(s.idBlock.tagNumber>=37&&s.idBlock.isHexOnly===!1)return s.error="UNIVERSAL 37 and upper tags are reserved by ASN.1 standard",{offset:-1,result:s};switch(s.idBlock.tagNumber){case 0:if(s.idBlock.isConstructed&&s.lenBlock.length>0)return s.error="Type [UNIVERSAL 0] is reserved",{offset:-1,result:s};c=A.EndOfContent;break;case 1:c=A.Boolean;break;case 2:c=A.Integer;break;case 3:c=A.BitString;break;case 4:c=A.OctetString;break;case 5:c=A.Null;break;case 6:c=A.ObjectIdentifier;break;case 10:c=A.Enumerated;break;case 12:c=A.Utf8String;break;case 13:c=A.RelativeObjectIdentifier;break;case 14:c=A.TIME;break;case 15:return s.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:s};case 16:c=A.Sequence;break;case 17:c=A.Set;break;case 18:c=A.NumericString;break;case 19:c=A.PrintableString;break;case 20:c=A.TeletexString;break;case 21:c=A.VideotexString;break;case 22:c=A.IA5String;break;case 23:c=A.UTCTime;break;case 24:c=A.GeneralizedTime;break;case 25:c=A.GraphicString;break;case 26:c=A.VisibleString;break;case 27:c=A.GeneralString;break;case 28:c=A.UniversalString;break;case 29:c=A.CharacterString;break;case 30:c=A.BmpString;break;case 31:c=A.DATE;break;case 32:c=A.TimeOfDay;break;case 33:c=A.DateTime;break;case 34:c=A.Duration;break;default:{let f=s.idBlock.isConstructed?new A.Constructed:new A.Primitive;f.idBlock=s.idBlock,f.lenBlock=s.lenBlock,f.warnings=s.warnings,s=f}}break;case 2:case 3:case 4:default:c=s.idBlock.isConstructed?A.Constructed:A.Primitive}return s=od(s,c),a=s.fromBER(r,t,s.lenBlock.isIndefiniteForm?e:s.lenBlock.length),s.valueBeforeDecodeView=r.subarray(n,n+s.blockLength),{offset:a,result:s}}function Cs(r){if(!r.byteLength){let t=new at({},ht);return t.error="Input buffer has zero length",{offset:-1,result:t}}return Is(M.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function id(r,t){return r?1:t}var Mt=class extends ht{constructor({value:t=[],isIndefiniteForm:e=!1,...n}={}){super(n),this.value=t,this.isIndefiniteForm=e}fromBER(t,e,n){let s=M.BufferSourceConverter.toUint8Array(t);if(!se(this,s,e,n))return-1;if(this.valueBeforeDecodeView=s.subarray(e,e+n),this.valueBeforeDecodeView.length===0)return this.warnings.push("Zero buffer length"),e;let o=e;for(;id(this.isIndefiniteForm,n)>0;){let i=Is(s,o,n);if(i.offset===-1)return this.error=i.result.error,this.warnings.concat(i.result.warnings),-1;if(o=i.offset,this.blockLength+=i.result.blockLength,n-=i.result.blockLength,this.value.push(i.result),this.isIndefiniteForm&&i.result.constructor.NAME===zr)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===zr?this.value.pop():this.warnings.push("No EndOfContent block encoded")),o}toBER(t,e){let n=e||new Gr;for(let s=0;s<this.value.length;s++)this.value[s].toBER(t,n);return e?Vt:n.final()}toJSON(){let t={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let e of this.value)t.value.push(e.toJSON());return t}};Mt.NAME="ConstructedValueBlock";var Hc,Ae=class extends at{constructor(t={}){super(t,Mt),this.idBlock.isConstructed=!0}fromBER(t,e,n){this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm;let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}onAsciiEncoding(){let t=[];for(let n of this.valueBlock.value)t.push(n.toString("ascii").split(`
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} :`}};Pc=ke;A.Constructed=Pc;ke.NAME="CONSTRUCTED";var Jn=class extends ht{fromBER(t,e,n){return e}toBER(t){return Ht}};Jn.override="EndOfContentValueBlock";var Mc,Yn=class extends ct{constructor(t={}){super(t,Jn),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};Mc=Yn;A.EndOfContent=Mc;Yn.NAME=Zr;var Fc,Fe=class extends ct{constructor(t={}){super(t,ht),this.idBlock.tagClass=1,this.idBlock.tagNumber=5}fromBER(t,e,n){return this.lenBlock.length>0&&this.warnings.push("Non-zero length of value block for Null type"),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.blockLength+=n,e+n>t.byteLength?(this.error="End of input reached before message was fully decoded (inconsistent offset and length values)",-1):e+n}toBER(t,e){let n=new ArrayBuffer(2);if(!t){let s=new Uint8Array(n);s[0]=5,s[1]=0}return e&&e.write(n),n}onAsciiEncoding(){return`${this.constructor.NAME}`}};Fc=Fe;A.Null=Fc;Fe.NAME="NULL";var Xn=class extends ie(ht){constructor({value:t,...e}={}){super(e),e.valueHex?this.valueHexView=M.BufferSourceConverter.toUint8Array(e.valueHex):this.valueHexView=new Uint8Array(1),t&&(this.value=t)}get value(){for(let t of this.valueHexView)if(t>0)return!0;return!1}set value(t){this.valueHexView[0]=t?255:0}fromBER(t,e,n){let s=M.BufferSourceConverter.toUint8Array(t);return oe(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,si.call(this),this.blockLength=n,e+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};Xn.NAME="BooleanValueBlock";var qc,Qn=class extends ct{constructor(t={}){super(t,Xn),this.idBlock.tagClass=1,this.idBlock.tagNumber=1}getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.getValue}`}};qc=Qn;A.Boolean=qc;Qn.NAME="BOOLEAN";var ts=class extends ie(Ft){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=Ft.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let o=0;o<this.value.length;o++){let i=this.value[o].constructor.NAME;if(i===Zr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(i!==Kc)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?Ft.prototype.toBER.call(this,t,e):t?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};ts.NAME="OctetStringValueBlock";var jc,re=class r extends ct{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},ts),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=Ns(o,0,o.byteLength);i.offset!==-1&&i.offset===n&&(this.valueBlock.value=[i.result])}}catch{}}return super.fromBER(t,e,n)}onAsciiEncoding(){return this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length?ke.prototype.onAsciiEncoding.call(this):`${this.constructor.NAME} : ${M.Convert.ToHex(this.valueBlock.valueHexView)}`}getValue(){if(!this.idBlock.isConstructed)return this.valueBlock.valueHexView.slice().buffer;let t=[];for(let e of this.valueBlock.value)e instanceof r&&t.push(e.valueBlock.valueHexView);return M.BufferSourceConverter.concat(t)}};jc=re;A.OctetString=jc;re.NAME=Kc;var es=class extends ie(Ft){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=Ft.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let a of this.value){let c=a.constructor.NAME;if(c===Zr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==Oc)return this.error="BIT STRING may consists of BIT STRINGs only",-1;let f=a.valueBlock;if(this.unusedBits>0&&f.unusedBits>0)return this.error='Using of "unused bits" inside constructive BIT STRING allowed for least one only',-1;this.unusedBits=f.unusedBits}return s}let o=M.BufferSourceConverter.toUint8Array(t);if(!oe(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=Ns(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 Ft.prototype.toBER.call(this,t,e);if(t)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return Ht;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}}};es.NAME="BitStringValueBlock";var $c,rs=class extends ct{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},es),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 ke.prototype.onAsciiEncoding.call(this);{let t=[],e=this.valueBlock.valueHexView;for(let s of e)t.push(s.toString(2).padStart(8,"0"));let n=t.join("");return`${this.constructor.NAME} : ${n.substring(0,n.length-this.valueBlock.unusedBits)}`}}};$c=rs;A.BitString=$c;rs.NAME=Oc;var Gc;function ud(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=qn(new Uint8Array([f%10]),o);break;default:o[i-u]=f%10}}return e[0]>0&&(o=qn(e,o)),o}function Dc(r){if(r>=zr.length)for(let t=zr.length;t<=r;t++){let e=new Uint8Array([0]),n=zr[t-1].slice(0);for(let s=n.length-1;s>=0;s--){let o=new Uint8Array([(n[s]<<1)+e[0]]);e[0]=o[0]/10,n[s]=o[0]%10}e[0]>0&&(n=qn(e,n)),zr.push(n)}return zr[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,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 Jr=class extends ie(ht){constructor({value:t,...e}={}){super(e),this._valueDec=0,e.valueHex&&this.setValueHex(),t!==void 0&&(this.valueDec=t)}setValueHex(){this.valueHexView.length>=4?(this.warnings.push("Too big Integer for decoding, hex only"),this.isHexOnly=!0,this._valueDec=0):(this.isHexOnly=!1,this.valueHexView.length>0&&(this._valueDec=si.call(this)))}set valueDec(t){this._valueDec=t,this.isHexOnly=!1,this.valueHexView=new Uint8Array(Lc(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=fd(Dc(n),e),i="-";break;default:e=ud(e,Dc(n))}n++,s>>=1}}for(let c=0;c<e.length;c++)e[c]&&(a=!0),a&&(i+=_c.charAt(e[c]));return a===!1&&(i+=_c.charAt(0)),i}};Gc=Jr;Jr.NAME="IntegerValueBlock";Object.defineProperty(Gc.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var zc,ne=class r extends ct{constructor(t={}){super(t,Jr),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 Wr,s=e.toString(16).replace(/^-/,""),o=new Uint8Array(M.Convert.FromHex(s));if(e<0){let a=new Uint8Array(o.length+(o[0]&128?1:0));a[0]|=128;let f=BigInt(`0x${M.Convert.ToHex(a)}`)+e,l=M.BufferSourceConverter.toUint8Array(M.Convert.FromHex(f.toString(16)));l[0]|=128,n.write(l)}else o[0]&128&&n.write(new Uint8Array([0])),n.write(o);return new r({valueHex:n.final()})}convertToDER(){let t=new r({valueHex:this.valueBlock.valueHexView});return t.valueBlock.toDER(),t}convertFromDER(){return new r({valueHex:this.valueBlock.valueHexView[0]===0?this.valueBlock.valueHexView.subarray(1):this.valueBlock.valueHexView})}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()}`}};zc=ne;A.Integer=zc;ne.NAME="INTEGER";var Wc,ns=class extends ne{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};Wc=ns;A.Enumerated=Wc;ns.NAME="ENUMERATED";var Yr=class extends ie(ht){constructor({valueDec:t=-1,isFirstSid:e=!1,...n}={}){super(n),this.valueDec=t,this.isFirstSid=e}fromBER(t,e,n){if(!n)return e;let s=M.BufferSourceConverter.toUint8Array(t);if(!oe(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=Me(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=Se(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Ht;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),o=e.byteLength-1;for(let i=0;i<o;i++)n[i]=s[i]|128;n[o]=s[o]}return n}toString(){let t="";if(this.isHexOnly)t=M.Convert.ToHex(this.valueHexView);else if(this.isFirstSid){let e=this.valueDec;this.valueDec<=39?t="0.":this.valueDec<=79?(t="1.",e-=40):(t="2.",e-=80),t+=e.toString()}else t=this.valueDec.toString();return t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec,isFirstSid:this.isFirstSid}}};Yr.NAME="sidBlock";var ss=class extends ht{constructor({value:t=br,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new Yr;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,Ht;e.push(s)}return oi(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 Yr;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}};ss.NAME="ObjectIdentifierValueBlock";var Zc,qt=class extends ct{constructor(t={}){super(t,ss),this.idBlock.tagClass=1,this.idBlock.tagNumber=6}getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};Zc=qt;A.ObjectIdentifier=Zc;qt.NAME="OBJECT IDENTIFIER";var Xr=class extends ie(ee){constructor({valueDec:t=0,...e}={}){super(e),this.valueDec=t}fromBER(t,e,n){if(n===0)return e;let s=M.BufferSourceConverter.toUint8Array(t);if(!oe(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=Me(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=Se(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Ht;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),o=e.byteLength-1;for(let i=0;i<o;i++)n[i]=s[i]|128;n[o]=s[o]}return n.buffer}toString(){let t="";return this.isHexOnly?t=M.Convert.ToHex(this.valueHexView):t=this.valueDec.toString(),t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};Xr.NAME="relativeSidBlock";var os=class extends ht{constructor({value:t=br,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new Xr;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,Ht;n.push(o)}return oi(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 Xr;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}};os.NAME="RelativeObjectIdentifierValueBlock";var Jc,is=class extends ct{constructor(t={}){super(t,os),this.idBlock.tagClass=1,this.idBlock.tagNumber=13}getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};Jc=is;A.RelativeObjectIdentifier=Jc;is.NAME="RelativeObjectIdentifier";var Yc,At=class extends ke{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};Yc=At;A.Sequence=Yc;At.NAME="SEQUENCE";var Xc,as=class extends ke{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};Xc=as;A.Set=Xc;as.NAME="SET";var cs=class extends ie(ht){constructor({...t}={}){super(t),this.isHexOnly=!0,this.value=br}toJSON(){return{...super.toJSON(),value:this.value}}};cs.NAME="StringValueBlock";var ls=class extends cs{};ls.NAME="SimpleStringValueBlock";var mt=class extends zn{constructor({...t}={}){super(t,ls)}fromBuffer(t){this.valueBlock.value=String.fromCharCode.apply(null,M.BufferSourceConverter.toUint8Array(t))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e);for(let s=0;s<e;s++)n[s]=t.charCodeAt(s);this.valueBlock.value=t}};mt.NAME="SIMPLE STRING";var us=class extends mt{fromBuffer(t){this.valueBlock.valueHexView=M.BufferSourceConverter.toUint8Array(t);try{this.valueBlock.value=M.Convert.ToUtf8String(t)}catch(e){this.warnings.push(`Error during "decodeURIComponent": ${e}, using raw string`),this.valueBlock.value=M.Convert.ToBinary(t)}}fromString(t){this.valueBlock.valueHexView=new Uint8Array(M.Convert.FromUtf8String(t)),this.valueBlock.value=t}};us.NAME="Utf8StringValueBlock";var Qc,se=class extends us{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};Qc=se;A.Utf8String=Qc;se.NAME="UTF8String";var fs=class extends mt{fromBuffer(t){this.valueBlock.value=M.Convert.ToUtf16String(t),this.valueBlock.valueHexView=M.BufferSourceConverter.toUint8Array(t)}fromString(t){this.valueBlock.value=t,this.valueBlock.valueHexView=new Uint8Array(M.Convert.FromUtf16String(t))}};fs.NAME="BmpStringValueBlock";var tl,hs=class extends fs{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};tl=hs;A.BmpString=tl;hs.NAME="BMPString";var ds=class extends mt{fromBuffer(t){let e=ArrayBuffer.isView(t)?t.slice().buffer:t.slice(0),n=new Uint8Array(e);for(let s=0;s<n.length;s+=4)n[s]=n[s+3],n[s+1]=n[s+2],n[s+2]=0,n[s+3]=0;this.valueBlock.value=String.fromCharCode.apply(null,new Uint32Array(e))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e*4);for(let s=0;s<e;s++){let o=Se(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}};ds.NAME="UniversalStringValueBlock";var el,ps=class extends ds{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};el=ps;A.UniversalString=el;ps.NAME="UniversalString";var rl,gs=class extends mt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};rl=gs;A.NumericString=rl;gs.NAME="NumericString";var nl,ys=class extends mt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};nl=ys;A.PrintableString=nl;ys.NAME="PrintableString";var sl,ms=class extends mt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};sl=ms;A.TeletexString=sl;ms.NAME="TeletexString";var ol,ws=class extends mt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};ol=ws;A.VideotexString=ol;ws.NAME="VideotexString";var il,bs=class extends mt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};il=bs;A.IA5String=il;bs.NAME="IA5String";var al,xs=class extends mt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};al=xs;A.GraphicString=al;xs.NAME="GraphicString";var cl,Qr=class extends mt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};cl=Qr;A.VisibleString=cl;Qr.NAME="VisibleString";var ll,vs=class extends mt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};ll=vs;A.GeneralString=ll;vs.NAME="GeneralString";var ul,Es=class extends mt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};ul=Es;A.CharacterString=ul;Es.NAME="CharacterString";var fl,tn=class extends Qr{constructor({value:t,valueDate:e,...n}={}){if(super(n),this.year=0,this.month=0,this.day=0,this.hour=0,this.minute=0,this.second=0,t){this.fromString(t),this.valueBlock.valueHexView=new Uint8Array(t.length);for(let s=0;s<t.length;s++)this.valueBlock.valueHexView[s]=t.charCodeAt(s)}e&&(this.fromDate(e),this.valueBlock.valueHexView=new Uint8Array(this.toBuffer())),this.idBlock.tagClass=1,this.idBlock.tagNumber=23}fromBuffer(t){this.fromString(String.fromCharCode.apply(null,M.BufferSourceConverter.toUint8Array(t)))}toBuffer(){let t=this.toString(),e=new ArrayBuffer(t.length),n=new Uint8Array(e);for(let s=0;s<t.length;s++)n[s]=t.charCodeAt(s);return e}fromDate(t){this.year=t.getUTCFullYear(),this.month=t.getUTCMonth()+1,this.day=t.getUTCDate(),this.hour=t.getUTCHours(),this.minute=t.getUTCMinutes(),this.second=t.getUTCSeconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second))}fromString(t){let n=/(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})Z/ig.exec(t);if(n===null){this.error="Wrong input string for conversion";return}let s=parseInt(n[1],10);s>=50?this.year=1900+s:this.year=2e3+s,this.month=parseInt(n[2],10),this.day=parseInt(n[3],10),this.hour=parseInt(n[4],10),this.minute=parseInt(n[5],10),this.second=parseInt(n[6],10)}toString(t="iso"){if(t==="iso"){let e=new Array(7);return e[0]=Bt(this.year<2e3?this.year-1900:this.year-2e3,2),e[1]=Bt(this.month,2),e[2]=Bt(this.day,2),e[3]=Bt(this.hour,2),e[4]=Bt(this.minute,2),e[5]=Bt(this.second,2),e[6]="Z",e.join("")}return super.toString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.toDate().toISOString()}`}toJSON(){return{...super.toJSON(),year:this.year,month:this.month,day:this.day,hour:this.hour,minute:this.minute,second:this.second}}};fl=tn;A.UTCTime=fl;tn.NAME="UTCTime";var hl,Bs=class extends tn{constructor(t={}){var e;super(t),(e=this.millisecond)!==null&&e!==void 0||(this.millisecond=0),this.idBlock.tagClass=1,this.idBlock.tagNumber=24}fromDate(t){super.fromDate(t),this.millisecond=t.getUTCMilliseconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second,this.millisecond))}fromString(t){let e=!1,n="",s="",o=0,i,a=0,c=0;if(t[t.length-1]==="Z")n=t.substring(0,t.length-1),e=!0;else{let u=new Number(t[t.length-1]);if(isNaN(u.valueOf()))throw new Error("Wrong input string for conversion");n=t}if(e){if(n.indexOf("+")!==-1)throw new Error("Wrong input string for conversion");if(n.indexOf("-")!==-1)throw new Error("Wrong input string for conversion")}else{let u=1,h=n.indexOf("+"),m="";if(h===-1&&(h=n.indexOf("-"),u=-1),h!==-1){if(m=n.substring(h+1),n=n.substring(0,h),m.length!==2&&m.length!==4)throw new Error("Wrong input string for conversion");let w=parseInt(m.substring(0,2),10);if(isNaN(w.valueOf()))throw new Error("Wrong input string for conversion");if(a=u*w,m.length===4){if(w=parseInt(m.substring(2,4),10),isNaN(w.valueOf()))throw new Error("Wrong input string for conversion");c=u*w}}}let f=n.indexOf(".");if(f===-1&&(f=n.indexOf(",")),f!==-1){let u=new Number(`0${n.substring(f)}`);if(isNaN(u.valueOf()))throw new Error("Wrong input string for conversion");o=u.valueOf(),s=n.substring(0,f)}else s=n;switch(!0){case s.length===8:if(i=/(\d{4})(\d{2})(\d{2})/ig,f!==-1)throw new Error("Wrong input string for conversion");break;case s.length===10:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let u=60*o;this.minute=Math.floor(u),u=60*(u-this.minute),this.second=Math.floor(u),u=1e3*(u-this.second),this.millisecond=Math.floor(u)}break;case s.length===12:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let u=60*o;this.second=Math.floor(u),u=1e3*(u-this.second),this.millisecond=Math.floor(u)}break;case s.length===14:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let u=1e3*o;this.millisecond=Math.floor(u)}break;default:throw new Error("Wrong input string for conversion")}let l=i.exec(s);if(l===null)throw new Error("Wrong input string for conversion");for(let u=1;u<l.length;u++)switch(u){case 1:this.year=parseInt(l[u],10);break;case 2:this.month=parseInt(l[u],10);break;case 3:this.day=parseInt(l[u],10);break;case 4:this.hour=parseInt(l[u],10)+a;break;case 5:this.minute=parseInt(l[u],10)+c;break;case 6:this.second=parseInt(l[u],10);break;default:throw new Error("Wrong input string for conversion")}if(e===!1){let u=new Date(this.year,this.month,this.day,this.hour,this.minute,this.second,this.millisecond);this.year=u.getUTCFullYear(),this.month=u.getUTCMonth(),this.day=u.getUTCDay(),this.hour=u.getUTCHours(),this.minute=u.getUTCMinutes(),this.second=u.getUTCSeconds(),this.millisecond=u.getUTCMilliseconds()}}toString(t="iso"){if(t==="iso"){let e=[];return e.push(Bt(this.year,4)),e.push(Bt(this.month,2)),e.push(Bt(this.day,2)),e.push(Bt(this.hour,2)),e.push(Bt(this.minute,2)),e.push(Bt(this.second,2)),this.millisecond!==0&&(e.push("."),e.push(Bt(this.millisecond,3))),e.push("Z"),e.join("")}return super.toString(t)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};hl=Bs;A.GeneralizedTime=hl;Bs.NAME="GeneralizedTime";var dl,As=class extends se{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};dl=As;A.DATE=dl;As.NAME="DATE";var pl,Ss=class extends se{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};pl=Ss;A.TimeOfDay=pl;Ss.NAME="TimeOfDay";var gl,ks=class extends se{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};gl=ks;A.DateTime=gl;ks.NAME="DateTime";var yl,Is=class extends se{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};yl=Is;A.Duration=yl;Is.NAME="Duration";var ml,Cs=class extends se{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};ml=Cs;A.TIME=ml;Cs.NAME="TIME";async function qe(r,t){let n=await mr.create().encrypt(r,t);return Ne.encode(n)}async function ai(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 qe(Pe(r),t);throw new N(`export format '${e}' is not supported`)}async function dd(r,t,e="libp2p-key"){if(e==="libp2p-key")return qe(Pe(r),t);throw new N("Export format is not supported")}async function pd(r,t,e="libp2p-key"){if(e==="libp2p-key")return qe(Pe(r),t);throw new N(`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 qe(Pe(r),t);throw new N("Export format is not supported")}async function yd(r,t){let e=bt.get(),s=new At({value:[new ne({value:0}),new At({value:[new qt({value:"1.2.840.113549.1.1.1"}),new Fe]}),new re({valueHex:r.raw})]}).toBER(),o=new Uint8Array(s,0,s.byteLength),i=He(16),a=await Kn(de,t,i,{c:1e4,dkLen:32}),c=He(16),f=await e.subtle.importKey("raw",a,"AES-CBC",!1,["encrypt"]),l=await e.subtle.encrypt({name:"AES-CBC",iv:c},f,o),u=new At({value:[new re({valueHex:i}),new ne({value:1e4}),new ne({value:32}),new At({value:[new qt({value:"1.2.840.113549.2.11"}),new Fe]})]}),h=new At({value:[new qt({value:"1.2.840.113549.1.5.13"}),new At({value:[new At({value:[new qt({value:"1.2.840.113549.1.5.12"}),u]}),new At({value:[new qt({value:"2.16.840.1.101.3.4.1.42"}),new re({valueHex:c})]})]})]}),w=new At({value:[h,new re({valueHex:l})]}).toBER(),y=new Uint8Array(w,0,w.byteLength);return["-----BEGIN ENCRYPTED PRIVATE KEY-----",...q(y,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
7
- `)}async function ci(r,t){try{let e=await Us(r,t);return sc(e)}catch{}if(!r.includes("BEGIN"))throw new N("Encrypted key was not a libp2p-key or a PEM file");return md(r,t)}async function Us(r,t){let e=Ne.decode(r);return mr.create().decrypt(e,t)}async function md(r,t){let e=bt.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}=Ts(o),{iv:a,salt:c,iterations:f,keySize:l,cipherText:u}=wd(i),h=await Kn(de,t,c,{c:f,dkLen:l}),m=await e.subtle.importKey("raw",h,"AES-CBC",!1,["decrypt"]),w=en(await e.subtle.decrypt({name:"AES-CBC",iv:a},m,u)),{result:y}=Ts(w);n=vl(y)}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}=Ts(o);n=vl(i)}else throw new N("Could not parse private key from PEM data");let s=oc(n);if(s.type!=="RSA")throw new N("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 N("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 N("Only pkcs5PBKDF2 key derivation functions are supported");let o=n.valueBlock.value[1],i=en(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 N("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 N("Only AES-CBC encryption schemes are supported")}}}}let u=en(f.valueBlock.value[1].getValue());return{cipherText:en(r.valueBlock.value[1].getValue()),salt:i,iterations:a,keySize:c,iv:u}}function vl(r){return en(r.valueBlock.value[2].getValue())}function en(r){return new Uint8Array(r,0,r.byteLength)}var je="/pkcs8/",$e="/x509/",ui="/info/",Ge=new WeakMap,ze={minKeyLength:112/8,minSaltLength:128/8,minIterationCount:1e3},li={dek:{keyLength:512/8,iterationCount:1e4,salt:"you should override this value with a crypto secure random number",hash:"sha2-512"}};function ae(r){return r==null||typeof r!="string"?!1:r===(0,El.default)(r.trim())&&r.length>0}async function tt(){let e=Math.random()*800+200;await new Promise(n=>setTimeout(n,e))}function Nt(r,t){return new Gr(r+t)}function rn(r){return new Gr(ui+r)}async function bd(r){let t=Pe(r),e=await rr.digest(t);return Q.encode(e.bytes).substring(1)}var Ls=class{components;init;log;self;constructor(t,e){if(this.components=t,this.log=t.logger.forComponent("libp2p:keychain"),this.init=vc(li,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<ze.minKeyLength)throw new Error(`dek.keyLength must be least ${ze.minKeyLength} bytes`);if(this.init.dek?.salt?.length!=null&&this.init.dek.salt.length<ze.minSaltLength)throw new Error(`dek.saltLength must be least ${ze.minSaltLength} bytes`);if(this.init.dek?.iterationCount!=null&&this.init.dek.iterationCount<ze.minIterationCount)throw new Error(`dek.iterationCount must be least ${ze.minIterationCount}`);let n=this.init.pass!=null&&this.init.dek?.salt!=null?$r(this.init.pass,this.init.dek?.salt,this.init.dek?.iterationCount,this.init.dek?.keyLength,this.init.dek?.hash):"";Ge.set(this,{dek:n})}[Symbol.toStringTag]="@libp2p/keychain";[xi]=["@libp2p/keychain"];static generateOptions(){let t=Object.assign({},li),e=Math.ceil(ze.minSaltLength/3)*3;return t.dek.salt=q(He(e),"base64"),t}static get options(){return li}async findKeyByName(t){if(!ae(t))throw await tt(),new N(`Invalid key name '${t}'`);let e=rn(t);try{let n=await this.components.datastore.get(e);return JSON.parse(q(n))}catch(n){throw await tt(),this.log.error(n),new on(`Key '${t}' does not exist.`)}}async findKeyById(t){try{let e={prefix:ui};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 N(`Key with id '${t}' does not exist.`)}catch(e){throw await tt(),e}}async importKey(t,e){if(!ae(t))throw await tt(),new N(`Invalid key name '${t}'`);if(e==null)throw await tt(),new N("Key is required");let n=Nt(je,t);if(await this.components.datastore.has(n))throw await tt(),new N(`Key '${t}' already exists`);let o,i;try{o=await bd(e);let f=Ge.get(this);if(f==null)throw new N("dek missing");let l=f.dek;i=await ai(e,l,e.type==="RSA"?"pkcs-8":"libp2p-key")}catch(f){throw await tt(),f}let a={name:t,id:o},c=this.components.datastore.batch();return c.put(n,V(i)),c.put(rn(t),V(JSON.stringify(a))),await c.commit(),a}async exportKey(t){if(!ae(t))throw await tt(),new N(`Invalid key name '${t}'`);let e=Nt(je,t);try{let n=await this.components.datastore.get(e),s=q(n),o=Ge.get(this);if(o==null)throw new N("dek missing");let i=o.dek;return await ci(s,i)}catch(n){throw await tt(),n}}async removeKey(t){if(!ae(t)||t===this.self)throw await tt(),new N(`Invalid key name '${t}'`);let e=Nt(je,t),n=await this.findKeyByName(t),s=this.components.datastore.batch();return s.delete(e),s.delete(rn(t)),await s.commit(),n}async listKeys(){let t={prefix:ui},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(!ae(t)||t===this.self)throw await tt(),new N(`Invalid old key name '${t}'`);if(!ae(e)||e===this.self)throw await tt(),new N(`Invalid new key name '${e}'`);let n=Nt(je,t),s=Nt(je,e),o=rn(t),i=rn(e);if(await this.components.datastore.has(s))throw await tt(),new N(`Key '${e}' already exists`);try{let c=await this.components.datastore.get(n),f=await this.components.datastore.get(o),l=JSON.parse(q(f));l.name=e;let u=this.components.datastore.batch();return u.put(s,c),u.put(i,V(JSON.stringify(l))),u.delete(n),u.delete(o),await u.commit(),l}catch(c){throw await tt(),c}}async listX509(){let t={prefix:$e},e=[];for await(let n of this.components.datastore.query(t))e.push({name:n.key.toString().replace($e,"")});return e}async importX509(t,e){try{if(!ae(t))throw new N(`Invalid certificate name '${t}'`);if(e==null)throw new N("PEM is required");if(!e.includes("-----BEGIN CERTIFICATE-----")&&!e.includes("-----END CERTIFICATE-----"))throw new N("PEM was invalid");let n=Nt($e,t);if(await this.components.datastore.has(n))throw new N(`Certificate '${t}' already exists`);let o=Ge.get(this);if(o==null)throw new N("dek missing");let i=o.dek,a=await qe(V(e),i);await this.components.datastore.put(n,V(a))}catch(n){throw await tt(),n}}async exportX509(t){try{if(!ae(t))throw new N(`Invalid key name '${t}'`);let e=Nt($e,t),n=await this.components.datastore.get(e),s=q(n),o=Ge.get(this);if(o==null)throw new N("dek missing");let i=o.dek,a=await Us(s,i);return q(a)}catch(e){throw await tt(),e}}async removeX509(t){try{if(!ae(t)||t===this.self)throw new N(`Invalid key name '${t}'`);let e=Nt($e,t);await this.components.datastore.delete(e)}catch(e){throw await tt(),e}}async rotateKeychainPass(t,e){if(typeof t!="string")throw await tt(),new N(`Invalid old pass type '${typeof t}'`);if(typeof e!="string")throw await tt(),new N(`Invalid new pass type '${typeof e}'`);if(e.length<20)throw await tt(),new N(`Invalid pass length ${e.length}`);this.log("recreating keychain");let n=Ge.get(this);if(n==null)throw new N("dek missing");let s=n.dek;this.init.pass=e;let o=e!=null&&this.init.dek?.salt!=null?$r(e,this.init.dek.salt,this.init.dek?.iterationCount,this.init.dek?.keyLength,this.init.dek?.hash):"";Ge.set(this,{dek:o});let i=this.components.datastore.batch();for(let a of await this.listKeys()){let c=await this.components.datastore.get(Nt(je,a.name)),f=q(c),l=await ci(f,s),u=o.toString(),h=await ai(l,u,l.type==="RSA"?"pkcs-8":"libp2p-key");i.put(Nt(je,a.name),V(h))}for(let a of await this.listX509()){let c=await this.components.datastore.get(Nt($e,a.name)),f=q(c),l=await Us(f,s),u=await qe(l,o);i.put(Nt($e,a.name),V(u))}await i.commit(),this.log("keychain reconstructed")}};function xd(r={}){return t=>new Ls(t,r)}return Kl(vd);})();
6
+ `)}`:`${e} :`}};Hc=Ae;A.Constructed=Hc;Ae.NAME="CONSTRUCTED";var Wn=class extends ht{fromBER(t,e,n){return e}toBER(t){return Vt}};Wn.override="EndOfContentValueBlock";var Pc,Zn=class extends at{constructor(t={}){super(t,Wn),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};Pc=Zn;A.EndOfContent=Pc;Zn.NAME=zr;var Mc,Pe=class extends at{constructor(t={}){super(t,ht),this.idBlock.tagClass=1,this.idBlock.tagNumber=5}fromBER(t,e,n){return this.lenBlock.length>0&&this.warnings.push("Non-zero length of value block for Null type"),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.blockLength+=n,e+n>t.byteLength?(this.error="End of input reached before message was fully decoded (inconsistent offset and length values)",-1):e+n}toBER(t,e){let n=new ArrayBuffer(2);if(!t){let s=new Uint8Array(n);s[0]=5,s[1]=0}return e&&e.write(n),n}onAsciiEncoding(){return`${this.constructor.NAME}`}};Mc=Pe;A.Null=Mc;Pe.NAME="NULL";var Jn=class extends oe(ht){get value(){for(let t of this.valueHexView)if(t>0)return!0;return!1}set value(t){this.valueHexView[0]=t?255:0}constructor({value:t,...e}={}){super(e),e.valueHex?this.valueHexView=M.BufferSourceConverter.toUint8Array(e.valueHex):this.valueHexView=new Uint8Array(1),t&&(this.value=t)}fromBER(t,e,n){let s=M.BufferSourceConverter.toUint8Array(t);return se(this,s,e,n)?(this.valueHexView=s.subarray(e,e+n),n>1&&this.warnings.push("Boolean value encoded in more then 1 octet"),this.isHexOnly=!0,ri.call(this),this.blockLength=n,e+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};Jn.NAME="BooleanValueBlock";var Fc,Yn=class extends at{getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}constructor(t={}){super(t,Jn),this.idBlock.tagClass=1,this.idBlock.tagNumber=1}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.getValue}`}};Fc=Yn;A.Boolean=Fc;Yn.NAME="BOOLEAN";var Xn=class extends oe(Mt){constructor({isConstructed:t=!1,...e}={}){super(e),this.isConstructed=t}fromBER(t,e,n){let s=0;if(this.isConstructed){if(this.isHexOnly=!1,s=Mt.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let o=0;o<this.value.length;o++){let i=this.value[o].constructor.NAME;if(i===zr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(i!==Dc)return this.error="OCTET STRING may consists of OCTET STRINGs only",-1}}else this.isHexOnly=!0,s=super.fromBER(t,e,n),this.blockLength=n;return s}toBER(t,e){return this.isConstructed?Mt.prototype.toBER.call(this,t,e):t?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};Xn.NAME="OctetStringValueBlock";var oi,ee=class extends at{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,o;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((o=n.value)===null||o===void 0)&&o.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},Xn),this.idBlock.tagClass=1,this.idBlock.tagNumber=4}fromBER(t,e,n){if(this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,n===0)return this.idBlock.error.length===0&&(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length===0&&(this.blockLength+=this.lenBlock.blockLength),e;if(!this.valueBlock.isConstructed){let o=(t instanceof ArrayBuffer?new Uint8Array(t):t).subarray(e,e+n);try{if(o.byteLength){let i=Is(o,0,o.byteLength);i.offset!==-1&&i.offset===n&&(this.valueBlock.value=[i.result])}}catch{}}return super.fromBER(t,e,n)}onAsciiEncoding(){if(this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length)return Ae.prototype.onAsciiEncoding.call(this);let t=this.constructor.NAME,e=M.Convert.ToHex(this.valueBlock.valueHexView);return`${t} : ${e}`}getValue(){if(!this.idBlock.isConstructed)return this.valueBlock.valueHexView.slice().buffer;let t=[];for(let e of this.valueBlock.value)e instanceof oi&&t.push(e.valueBlock.valueHexView);return M.BufferSourceConverter.concat(t)}};oi=ee;A.OctetString=oi;ee.NAME=Dc;var Qn=class extends oe(Mt){constructor({unusedBits:t=0,isConstructed:e=!1,...n}={}){super(n),this.unusedBits=t,this.isConstructed=e,this.blockLength=this.valueHexView.byteLength}fromBER(t,e,n){if(!n)return e;let s=-1;if(this.isConstructed){if(s=Mt.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let a of this.value){let c=a.constructor.NAME;if(c===zr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==Kc)return this.error="BIT STRING may consists of BIT STRINGs only",-1;let f=a.valueBlock;if(this.unusedBits>0&&f.unusedBits>0)return this.error='Using of "unused bits" inside constructive BIT STRING allowed for least one only',-1;this.unusedBits=f.unusedBits}return s}let o=M.BufferSourceConverter.toUint8Array(t);if(!se(this,o,e,n))return-1;let i=o.subarray(e,e+n);if(this.unusedBits=i[0],this.unusedBits>7)return this.error="Unused bits for BitString must be in range 0-7",-1;if(!this.unusedBits){let a=i.subarray(1);try{if(a.byteLength){let c=Is(a,0,a.byteLength);c.offset!==-1&&c.offset===n-1&&(this.value=[c.result])}}catch{}}return this.valueHexView=i.subarray(1),this.blockLength=i.length,e+n}toBER(t,e){if(this.isConstructed)return Mt.prototype.toBER.call(this,t,e);if(t)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return Vt;let n=new Uint8Array(this.valueHexView.length+1);return n[0]=this.unusedBits,n.set(this.valueHexView,1),n.buffer}toJSON(){return{...super.toJSON(),unusedBits:this.unusedBits,isConstructed:this.isConstructed}}};Qn.NAME="BitStringValueBlock";var qc,ts=class extends at{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,o;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((o=n.value)===null||o===void 0)&&o.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},Qn),this.idBlock.tagClass=1,this.idBlock.tagNumber=3}fromBER(t,e,n){return this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,super.fromBER(t,e,n)}onAsciiEncoding(){if(this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length)return Ae.prototype.onAsciiEncoding.call(this);{let t=[],e=this.valueBlock.valueHexView;for(let i of e)t.push(i.toString(2).padStart(8,"0"));let n=t.join(""),s=this.constructor.NAME,o=n.substring(0,n.length-this.valueBlock.unusedBits);return`${s} : ${o}`}}};qc=ts;A.BitString=qc;ts.NAME=Kc;var jc;function ad(r,t){let e=new Uint8Array([0]),n=new Uint8Array(r),s=new Uint8Array(t),o=n.slice(0),i=o.length-1,a=s.slice(0),c=a.length-1,f=0,l=c<i?i:c,u=0;for(let h=l;h>=0;h--,u++){switch(!0){case u<a.length:f=o[i-u]+a[c-u]+e[0];break;default:f=o[i-u]+e[0]}switch(e[0]=f/10,!0){case u>=o.length:o=Mn(new Uint8Array([f%10]),o);break;default:o[i-u]=f%10}}return e[0]>0&&(o=Mn(e,o)),o}function _c(r){if(r>=jr.length)for(let t=jr.length;t<=r;t++){let e=new Uint8Array([0]),n=jr[t-1].slice(0);for(let s=n.length-1;s>=0;s--){let o=new Uint8Array([(n[s]<<1)+e[0]]);e[0]=o[0]/10,n[s]=o[0]%10}e[0]>0&&(n=Mn(e,n)),jr.push(n)}return jr[r]}function cd(r,t){let e=0,n=new Uint8Array(r),s=new Uint8Array(t),o=n.slice(0),i=o.length-1,a=s.slice(0),c=a.length-1,f,l=0;for(let u=c;u>=0;u--,l++)switch(f=o[i-l]-a[c-l]-e,!0){case f<0:e=1,o[i-l]=f+10;break;default:e=0,o[i-l]=f}if(e>0)for(let u=i-c+1;u>=0;u--,l++)if(f=o[i-l]-e,f<0)e=1,o[i-l]=f+10;else{e=0,o[i-l]=f;break}return o.slice()}var Wr=class extends oe(ht){setValueHex(){this.valueHexView.length>=4?(this.warnings.push("Too big Integer for decoding, hex only"),this.isHexOnly=!0,this._valueDec=0):(this.isHexOnly=!1,this.valueHexView.length>0&&(this._valueDec=ri.call(this)))}constructor({value:t,...e}={}){super(e),this._valueDec=0,e.valueHex&&this.setValueHex(),t!==void 0&&(this.valueDec=t)}set valueDec(t){this._valueDec=t,this.isHexOnly=!1,this.valueHexView=new Uint8Array(Uc(t))}get valueDec(){return this._valueDec}fromDER(t,e,n,s=0){let o=this.fromBER(t,e,n);if(o===-1)return o;let i=this.valueHexView;return i[0]===0&&(i[1]&128)!==0?this.valueHexView=i.subarray(1):s!==0&&i.length<s&&(s-i.length>1&&(s=i.length+1),this.valueHexView=i.subarray(s-i.length)),o}toDER(t=!1){let e=this.valueHexView;switch(!0){case(e[0]&128)!==0:{let n=new Uint8Array(this.valueHexView.length+1);n[0]=0,n.set(e,1),this.valueHexView=n}break;case(e[0]===0&&(e[1]&128)===0):this.valueHexView=this.valueHexView.subarray(1);break}return this.toBER(t)}fromBER(t,e,n){let s=super.fromBER(t,e,n);return s===-1||this.setValueHex(),s}toBER(t){return t?new ArrayBuffer(this.valueHexView.length):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}toString(){let t=this.valueHexView.length*8-1,e=new Uint8Array(this.valueHexView.length*8/3),n=0,s,o=this.valueHexView,i="",a=!1;for(let c=o.byteLength-1;c>=0;c--){s=o[c];for(let f=0;f<8;f++){if((s&1)===1)switch(n){case t:e=cd(_c(n),e),i="-";break;default:e=ad(e,_c(n))}n++,s>>=1}}for(let c=0;c<e.length;c++)e[c]&&(a=!0),a&&(i+=Rc.charAt(e[c]));return a===!1&&(i+=Rc.charAt(0)),i}};jc=Wr;Wr.NAME="IntegerValueBlock";Object.defineProperty(jc.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var $r,re=class extends at{constructor(t={}){super(t,Wr),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return Fn(),BigInt(this.valueBlock.toString())}static fromBigInt(t){Fn();let e=BigInt(t),n=new Gr,s=e.toString(16).replace(/^-/,""),o=new Uint8Array(M.Convert.FromHex(s));if(e<0){let a=new Uint8Array(o.length+(o[0]&128?1:0));a[0]|=128;let f=BigInt(`0x${M.Convert.ToHex(a)}`)+e,l=M.BufferSourceConverter.toUint8Array(M.Convert.FromHex(f.toString(16)));l[0]|=128,n.write(l)}else o[0]&128&&n.write(new Uint8Array([0])),n.write(o);return new $r({valueHex:n.final()})}convertToDER(){let t=new $r({valueHex:this.valueBlock.valueHexView});return t.valueBlock.toDER(),t}convertFromDER(){return new $r({valueHex:this.valueBlock.valueHexView[0]===0?this.valueBlock.valueHexView.subarray(1):this.valueBlock.valueHexView})}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()}`}};$r=re;A.Integer=$r;re.NAME="INTEGER";var $c,es=class extends re{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};$c=es;A.Enumerated=$c;es.NAME="ENUMERATED";var Zr=class extends oe(ht){constructor({valueDec:t=-1,isFirstSid:e=!1,...n}={}){super(n),this.valueDec=t,this.isFirstSid=e}fromBER(t,e,n){if(!n)return e;let s=M.BufferSourceConverter.toUint8Array(t);if(!se(this,s,e,n))return-1;let o=s.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=o[a]&127,this.blockLength++,(o[a]&128)!==0);a++);let i=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)i[a]=this.valueHexView[a];return this.valueHexView=i,(o[this.blockLength-1]&128)!==0?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=He(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}set valueBigInt(t){Fn();let e=BigInt(t).toString(2);for(;e.length%7;)e="0"+e;let n=new Uint8Array(e.length/7);for(let s=0;s<n.length;s++)n[s]=parseInt(e.slice(s*7,s*7+7),2)+(s+1<n.length?128:0);this.fromBER(n.buffer,0,n.length)}toBER(t){if(this.isHexOnly){if(t)return new ArrayBuffer(this.valueHexView.byteLength);let s=this.valueHexView,o=new Uint8Array(this.blockLength);for(let i=0;i<this.blockLength-1;i++)o[i]=s[i]|128;return o[this.blockLength-1]=s[this.blockLength-1],o.buffer}let e=Ee(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Vt;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),o=e.byteLength-1;for(let i=0;i<o;i++)n[i]=s[i]|128;n[o]=s[o]}return n}toString(){let t="";if(this.isHexOnly)t=M.Convert.ToHex(this.valueHexView);else if(this.isFirstSid){let e=this.valueDec;this.valueDec<=39?t="0.":this.valueDec<=79?(t="1.",e-=40):(t="2.",e-=80),t+=e.toString()}else t=this.valueDec.toString();return t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec,isFirstSid:this.isFirstSid}}};Zr.NAME="sidBlock";var rs=class extends ht{constructor({value:t=pr,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new Zr;if(s=o.fromBER(t,s,n),s===-1)return this.blockLength=0,this.error=o.error,s;this.value.length===0&&(o.isFirstSid=!0),this.blockLength+=o.blockLength,n-=o.blockLength,this.value.push(o)}return s}toBER(t){let e=[];for(let n=0;n<this.value.length;n++){let s=this.value[n].toBER(t);if(s.byteLength===0)return this.error=this.value[n].error,Vt;e.push(s)}return ni(e)}fromString(t){this.value=[];let e=0,n=0,s="",o=!1;do if(n=t.indexOf(".",e),n===-1?s=t.substring(e):s=t.substring(e,n),e=n+1,o){let i=this.value[0],a=0;switch(i.valueDec){case 0:break;case 1:a=40;break;case 2:a=80;break;default:this.value=[];return}let c=parseInt(s,10);if(isNaN(c))return;i.valueDec=c+a,o=!1}else{let i=new Zr;if(s>Number.MAX_SAFE_INTEGER){Fn();let a=BigInt(s);i.valueBigInt=a}else if(i.valueDec=parseInt(s,10),isNaN(i.valueDec))return;this.value.length||(i.isFirstSid=!0,o=!0),this.value.push(i)}while(n!==-1)}toString(){let t="",e=!1;for(let n=0;n<this.value.length;n++){e=this.value[n].isHexOnly;let s=this.value[n].toString();n!==0&&(t=`${t}.`),e?(s=`{${s}}`,this.value[n].isFirstSid?t=`2.{${s} - 80}`:t+=s):t+=s}return t}toJSON(){let t={...super.toJSON(),value:this.toString(),sidArray:[]};for(let e=0;e<this.value.length;e++)t.sidArray.push(this.value[e].toJSON());return t}};rs.NAME="ObjectIdentifierValueBlock";var Gc,Ft=class extends at{getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}constructor(t={}){super(t,rs),this.idBlock.tagClass=1,this.idBlock.tagNumber=6}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};Gc=Ft;A.ObjectIdentifier=Gc;Ft.NAME="OBJECT IDENTIFIER";var Jr=class extends oe(te){constructor({valueDec:t=0,...e}={}){super(e),this.valueDec=t}fromBER(t,e,n){if(n===0)return e;let s=M.BufferSourceConverter.toUint8Array(t);if(!se(this,s,e,n))return-1;let o=s.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=o[a]&127,this.blockLength++,(o[a]&128)!==0);a++);let i=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)i[a]=this.valueHexView[a];return this.valueHexView=i,(o[this.blockLength-1]&128)!==0?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=He(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}toBER(t){if(this.isHexOnly){if(t)return new ArrayBuffer(this.valueHexView.byteLength);let s=this.valueHexView,o=new Uint8Array(this.blockLength);for(let i=0;i<this.blockLength-1;i++)o[i]=s[i]|128;return o[this.blockLength-1]=s[this.blockLength-1],o.buffer}let e=Ee(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Vt;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),o=e.byteLength-1;for(let i=0;i<o;i++)n[i]=s[i]|128;n[o]=s[o]}return n.buffer}toString(){let t="";return this.isHexOnly?t=M.Convert.ToHex(this.valueHexView):t=this.valueDec.toString(),t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};Jr.NAME="relativeSidBlock";var ns=class extends ht{constructor({value:t=pr,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new Jr;if(s=o.fromBER(t,s,n),s===-1)return this.blockLength=0,this.error=o.error,s;this.blockLength+=o.blockLength,n-=o.blockLength,this.value.push(o)}return s}toBER(t,e){let n=[];for(let s=0;s<this.value.length;s++){let o=this.value[s].toBER(t);if(o.byteLength===0)return this.error=this.value[s].error,Vt;n.push(o)}return ni(n)}fromString(t){this.value=[];let e=0,n=0,s="";do{n=t.indexOf(".",e),n===-1?s=t.substring(e):s=t.substring(e,n),e=n+1;let o=new Jr;if(o.valueDec=parseInt(s,10),isNaN(o.valueDec))return!0;this.value.push(o)}while(n!==-1);return!0}toString(){let t="",e=!1;for(let n=0;n<this.value.length;n++){e=this.value[n].isHexOnly;let s=this.value[n].toString();n!==0&&(t=`${t}.`),e&&(s=`{${s}}`),t+=s}return t}toJSON(){let t={...super.toJSON(),value:this.toString(),sidArray:[]};for(let e=0;e<this.value.length;e++)t.sidArray.push(this.value[e].toJSON());return t}};ns.NAME="RelativeObjectIdentifierValueBlock";var zc,ss=class extends at{getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}constructor(t={}){super(t,ns),this.idBlock.tagClass=1,this.idBlock.tagNumber=13}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};zc=ss;A.RelativeObjectIdentifier=zc;ss.NAME="RelativeObjectIdentifier";var Wc,At=class extends Ae{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};Wc=At;A.Sequence=Wc;At.NAME="SEQUENCE";var Zc,os=class extends Ae{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};Zc=os;A.Set=Zc;os.NAME="SET";var is=class extends oe(ht){constructor({...t}={}){super(t),this.isHexOnly=!0,this.value=pr}toJSON(){return{...super.toJSON(),value:this.value}}};is.NAME="StringValueBlock";var as=class extends is{};as.NAME="SimpleStringValueBlock";var mt=class extends $n{constructor({...t}={}){super(t,as)}fromBuffer(t){this.valueBlock.value=String.fromCharCode.apply(null,M.BufferSourceConverter.toUint8Array(t))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e);for(let s=0;s<e;s++)n[s]=t.charCodeAt(s);this.valueBlock.value=t}};mt.NAME="SIMPLE STRING";var cs=class extends mt{fromBuffer(t){this.valueBlock.valueHexView=M.BufferSourceConverter.toUint8Array(t);try{this.valueBlock.value=M.Convert.ToUtf8String(t)}catch(e){this.warnings.push(`Error during "decodeURIComponent": ${e}, using raw string`),this.valueBlock.value=M.Convert.ToBinary(t)}}fromString(t){this.valueBlock.valueHexView=new Uint8Array(M.Convert.FromUtf8String(t)),this.valueBlock.value=t}};cs.NAME="Utf8StringValueBlock";var Jc,ne=class extends cs{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};Jc=ne;A.Utf8String=Jc;ne.NAME="UTF8String";var ls=class extends mt{fromBuffer(t){this.valueBlock.value=M.Convert.ToUtf16String(t),this.valueBlock.valueHexView=M.BufferSourceConverter.toUint8Array(t)}fromString(t){this.valueBlock.value=t,this.valueBlock.valueHexView=new Uint8Array(M.Convert.FromUtf16String(t))}};ls.NAME="BmpStringValueBlock";var Yc,us=class extends ls{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};Yc=us;A.BmpString=Yc;us.NAME="BMPString";var fs=class extends mt{fromBuffer(t){let e=ArrayBuffer.isView(t)?t.slice().buffer:t.slice(0),n=new Uint8Array(e);for(let s=0;s<n.length;s+=4)n[s]=n[s+3],n[s+1]=n[s+2],n[s+2]=0,n[s+3]=0;this.valueBlock.value=String.fromCharCode.apply(null,new Uint32Array(e))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e*4);for(let s=0;s<e;s++){let o=Ee(t.charCodeAt(s),8),i=new Uint8Array(o);if(i.length>4)continue;let a=4-i.length;for(let c=i.length-1;c>=0;c--)n[s*4+c+a]=i[c]}this.valueBlock.value=t}};fs.NAME="UniversalStringValueBlock";var Xc,hs=class extends fs{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};Xc=hs;A.UniversalString=Xc;hs.NAME="UniversalString";var Qc,ds=class extends mt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};Qc=ds;A.NumericString=Qc;ds.NAME="NumericString";var tl,ps=class extends mt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};tl=ps;A.PrintableString=tl;ps.NAME="PrintableString";var el,gs=class extends mt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};el=gs;A.TeletexString=el;gs.NAME="TeletexString";var rl,ys=class extends mt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};rl=ys;A.VideotexString=rl;ys.NAME="VideotexString";var nl,ms=class extends mt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};nl=ms;A.IA5String=nl;ms.NAME="IA5String";var sl,bs=class extends mt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};sl=bs;A.GraphicString=sl;bs.NAME="GraphicString";var ol,Yr=class extends mt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};ol=Yr;A.VisibleString=ol;Yr.NAME="VisibleString";var il,ws=class extends mt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};il=ws;A.GeneralString=il;ws.NAME="GeneralString";var al,xs=class extends mt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};al=xs;A.CharacterString=al;xs.NAME="CharacterString";var cl,Xr=class extends Yr{constructor({value:t,valueDate:e,...n}={}){if(super(n),this.year=0,this.month=0,this.day=0,this.hour=0,this.minute=0,this.second=0,t){this.fromString(t),this.valueBlock.valueHexView=new Uint8Array(t.length);for(let s=0;s<t.length;s++)this.valueBlock.valueHexView[s]=t.charCodeAt(s)}e&&(this.fromDate(e),this.valueBlock.valueHexView=new Uint8Array(this.toBuffer())),this.idBlock.tagClass=1,this.idBlock.tagNumber=23}fromBuffer(t){this.fromString(String.fromCharCode.apply(null,M.BufferSourceConverter.toUint8Array(t)))}toBuffer(){let t=this.toString(),e=new ArrayBuffer(t.length),n=new Uint8Array(e);for(let s=0;s<t.length;s++)n[s]=t.charCodeAt(s);return e}fromDate(t){this.year=t.getUTCFullYear(),this.month=t.getUTCMonth()+1,this.day=t.getUTCDate(),this.hour=t.getUTCHours(),this.minute=t.getUTCMinutes(),this.second=t.getUTCSeconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second))}fromString(t){let n=/(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})Z/ig.exec(t);if(n===null){this.error="Wrong input string for conversion";return}let s=parseInt(n[1],10);s>=50?this.year=1900+s:this.year=2e3+s,this.month=parseInt(n[2],10),this.day=parseInt(n[3],10),this.hour=parseInt(n[4],10),this.minute=parseInt(n[5],10),this.second=parseInt(n[6],10)}toString(t="iso"){if(t==="iso"){let e=new Array(7);return e[0]=Et(this.year<2e3?this.year-1900:this.year-2e3,2),e[1]=Et(this.month,2),e[2]=Et(this.day,2),e[3]=Et(this.hour,2),e[4]=Et(this.minute,2),e[5]=Et(this.second,2),e[6]="Z",e.join("")}return super.toString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.toDate().toISOString()}`}toJSON(){return{...super.toJSON(),year:this.year,month:this.month,day:this.day,hour:this.hour,minute:this.minute,second:this.second}}};cl=Xr;A.UTCTime=cl;Xr.NAME="UTCTime";var ll,vs=class extends Xr{constructor(t={}){var e;super(t),(e=this.millisecond)!==null&&e!==void 0||(this.millisecond=0),this.idBlock.tagClass=1,this.idBlock.tagNumber=24}fromDate(t){super.fromDate(t),this.millisecond=t.getUTCMilliseconds()}toDate(){let t=Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second,this.millisecond);return new Date(t)}fromString(t){let e=!1,n="",s="",o=0,i,a=0,c=0;if(t[t.length-1]==="Z")n=t.substring(0,t.length-1),e=!0;else{let u=new Number(t[t.length-1]);if(isNaN(u.valueOf()))throw new Error("Wrong input string for conversion");n=t}if(e){if(n.indexOf("+")!==-1)throw new Error("Wrong input string for conversion");if(n.indexOf("-")!==-1)throw new Error("Wrong input string for conversion")}else{let u=1,h=n.indexOf("+"),y="";if(h===-1&&(h=n.indexOf("-"),u=-1),h!==-1){if(y=n.substring(h+1),n=n.substring(0,h),y.length!==2&&y.length!==4)throw new Error("Wrong input string for conversion");let b=parseInt(y.substring(0,2),10);if(isNaN(b.valueOf()))throw new Error("Wrong input string for conversion");if(a=u*b,y.length===4){if(b=parseInt(y.substring(2,4),10),isNaN(b.valueOf()))throw new Error("Wrong input string for conversion");c=u*b}}}let f=n.indexOf(".");if(f===-1&&(f=n.indexOf(",")),f!==-1){let u=new Number(`0${n.substring(f)}`);if(isNaN(u.valueOf()))throw new Error("Wrong input string for conversion");o=u.valueOf(),s=n.substring(0,f)}else s=n;switch(!0){case s.length===8:if(i=/(\d{4})(\d{2})(\d{2})/ig,f!==-1)throw new Error("Wrong input string for conversion");break;case s.length===10:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let u=60*o;this.minute=Math.floor(u),u=60*(u-this.minute),this.second=Math.floor(u),u=1e3*(u-this.second),this.millisecond=Math.floor(u)}break;case s.length===12:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let u=60*o;this.second=Math.floor(u),u=1e3*(u-this.second),this.millisecond=Math.floor(u)}break;case s.length===14:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let u=1e3*o;this.millisecond=Math.floor(u)}break;default:throw new Error("Wrong input string for conversion")}let l=i.exec(s);if(l===null)throw new Error("Wrong input string for conversion");for(let u=1;u<l.length;u++)switch(u){case 1:this.year=parseInt(l[u],10);break;case 2:this.month=parseInt(l[u],10);break;case 3:this.day=parseInt(l[u],10);break;case 4:this.hour=parseInt(l[u],10)+a;break;case 5:this.minute=parseInt(l[u],10)+c;break;case 6:this.second=parseInt(l[u],10);break;default:throw new Error("Wrong input string for conversion")}if(e===!1){let u=new Date(this.year,this.month,this.day,this.hour,this.minute,this.second,this.millisecond);this.year=u.getUTCFullYear(),this.month=u.getUTCMonth(),this.day=u.getUTCDay(),this.hour=u.getUTCHours(),this.minute=u.getUTCMinutes(),this.second=u.getUTCSeconds(),this.millisecond=u.getUTCMilliseconds()}}toString(t="iso"){if(t==="iso"){let e=[];return e.push(Et(this.year,4)),e.push(Et(this.month,2)),e.push(Et(this.day,2)),e.push(Et(this.hour,2)),e.push(Et(this.minute,2)),e.push(Et(this.second,2)),this.millisecond!==0&&(e.push("."),e.push(Et(this.millisecond,3))),e.push("Z"),e.join("")}return super.toString(t)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};ll=vs;A.GeneralizedTime=ll;vs.NAME="GeneralizedTime";var ul,Bs=class extends ne{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};ul=Bs;A.DATE=ul;Bs.NAME="DATE";var fl,Es=class extends ne{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};fl=Es;A.TimeOfDay=fl;Es.NAME="TimeOfDay";var hl,As=class extends ne{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};hl=As;A.DateTime=hl;As.NAME="DateTime";var dl,Ss=class extends ne{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};dl=Ss;A.Duration=dl;Ss.NAME="Duration";var pl,ks=class extends ne{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};pl=ks;A.TIME=pl;ks.NAME="TIME";async function Ns(r,t){let n=await hr.create().encrypt(r,t);return Ie.encode(n)}async function ii(r,t,e){if(r.type==="RSA")return hd(r,t,e);if(r.type==="Ed25519")return ld(r,t,e);if(r.type==="secp256k1")return ud(r,t,e);if(r.type==="ECDSA")return fd(r,t,e);throw new je}async function ld(r,t,e="libp2p-key"){if(e==="libp2p-key")return Ns(Ve(r),t);throw new L(`export format '${e}' is not supported`)}async function ud(r,t,e="libp2p-key"){if(e==="libp2p-key")return Ns(Ve(r),t);throw new L("Export format is not supported")}async function fd(r,t,e="libp2p-key"){if(e==="libp2p-key")return Ns(Ve(r),t);throw new L(`export format '${e}' is not supported`)}async function hd(r,t,e="pkcs-8"){if(e==="pkcs-8")return dd(r,t);if(e==="libp2p-key")return Ns(Ve(r),t);throw new L("Export format is not supported")}async function dd(r,t){let e=wt.get(),s=new At({value:[new re({value:0}),new At({value:[new Ft({value:"1.2.840.113549.1.1.1"}),new Pe]}),new ee({valueHex:r.raw})]}).toBER(),o=new Uint8Array(s,0,s.byteLength),i=Oe(16),a=await _n(fe,t,i,{c:1e4,dkLen:32}),c=Oe(16),f=await e.subtle.importKey("raw",a,"AES-CBC",!1,["encrypt"]),l=await e.subtle.encrypt({name:"AES-CBC",iv:c},f,o),u=new At({value:[new ee({valueHex:i}),new re({value:1e4}),new re({value:32}),new At({value:[new Ft({value:"1.2.840.113549.2.11"}),new Pe]})]}),h=new At({value:[new Ft({value:"1.2.840.113549.1.5.13"}),new At({value:[new At({value:[new Ft({value:"1.2.840.113549.1.5.12"}),u]}),new At({value:[new Ft({value:"2.16.840.1.101.3.4.1.42"}),new ee({valueHex:c})]})]})]}),b=new At({value:[h,new ee({valueHex:l})]}).toBER(),m=new Uint8Array(b,0,b.byteLength);return["-----BEGIN ENCRYPTED PRIVATE KEY-----",...j(m,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
7
+ `)}async function ai(r,t){try{let e=await pd(r,t);return nc(e)}catch{}if(!r.includes("BEGIN"))throw new L("Encrypted key was not a libp2p-key or a PEM file");return gd(r,t)}async function pd(r,t){let e=Ie.decode(r);return hr.create().decrypt(e,t)}async function gd(r,t){let e=wt.get(),n;if(r.includes("-----BEGIN ENCRYPTED PRIVATE KEY-----")){let o=H(r.replace("-----BEGIN ENCRYPTED PRIVATE KEY-----","").replace("-----END ENCRYPTED PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:i}=Cs(o),{iv:a,salt:c,iterations:f,keySize:l,cipherText:u}=yd(i),h=await _n(fe,t,c,{c:f,dkLen:l}),y=await e.subtle.importKey("raw",h,"AES-CBC",!1,["decrypt"]),b=Qr(await e.subtle.decrypt({name:"AES-CBC",iv:a},y,u)),{result:m}=Cs(b);n=bl(m)}else if(r.includes("-----BEGIN PRIVATE KEY-----")){let o=H(r.replace("-----BEGIN PRIVATE KEY-----","").replace("-----END PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:i}=Cs(o);n=bl(i)}else throw new L("Could not parse private key from PEM data");let s=sc(n);if(s.type!=="RSA")throw new L("Could not parse RSA private key from PEM data");return s}function yd(r){let t=r.valueBlock.value[0];if(t.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.13")throw new L("Only pkcs5PBES2 encrypted private keys are supported");let n=t.valueBlock.value[1].valueBlock.value[0];if(n.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.12")throw new L("Only pkcs5PBKDF2 key derivation functions are supported");let o=n.valueBlock.value[1],i=Qr(o.valueBlock.value[0].getValue()),a=1e4,c=32;if(o.valueBlock.value.length===3)a=Number(o.valueBlock.value[1].toBigInt()),c=Number(o.valueBlock.value[2].toBigInt());else if(o.valueBlock.value.length===2)throw new L("Could not derive key size and iterations from PEM file - please use @libp2p/rsa to re-import your key");let f=t.valueBlock.value[1].valueBlock.value[1],l=f.valueBlock.value[0].toString();if(l!=="OBJECT IDENTIFIER : 1.2.840.113549.3.7"){if(l!=="OBJECT IDENTIFIER : 1.3.14.3.2.7"){if(l!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.2"){if(l!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.22"){if(l!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.42")throw new L("Only AES-CBC encryption schemes are supported")}}}}let u=Qr(f.valueBlock.value[1].getValue());return{cipherText:Qr(r.valueBlock.value[1].getValue()),salt:i,iterations:a,keySize:c,iv:u}}function bl(r){return Qr(r.valueBlock.value[2].getValue())}function Qr(r){return new Uint8Array(r,0,r.byteLength)}var md="/pkcs8/",li="/info/",tn=new WeakMap,Me={minKeyLength:112/8,minSaltLength:128/8,minIterationCount:1e3},ci={dek:{keyLength:512/8,iterationCount:1e4,salt:"you should override this value with a crypto secure random number",hash:"sha2-512"}};function gr(r){return r==null||typeof r!="string"?!1:r===(0,wl.default)(r.trim())&&r.length>0}async function ct(){let e=Math.random()*800+200;await new Promise(n=>setTimeout(n,e))}function Fe(r){return new qr(md+r)}function yr(r){return new qr(li+r)}async function bd(r){let t=Ve(r),e=await Ye.digest(t);return Q.encode(e.bytes).substring(1)}var Ts=class{components;init;log;self;constructor(t,e){if(this.components=t,this.log=t.logger.forComponent("libp2p:keychain"),this.init=xc(ci,e),this.self=e.selfKey??"self",this.init.pass!=null&&this.init.pass?.length<20)throw new Error("pass must be least 20 characters");if(this.init.dek?.keyLength!=null&&this.init.dek.keyLength<Me.minKeyLength)throw new Error(`dek.keyLength must be least ${Me.minKeyLength} bytes`);if(this.init.dek?.salt?.length!=null&&this.init.dek.salt.length<Me.minSaltLength)throw new Error(`dek.saltLength must be least ${Me.minSaltLength} bytes`);if(this.init.dek?.iterationCount!=null&&this.init.dek.iterationCount<Me.minIterationCount)throw new Error(`dek.iterationCount must be least ${Me.minIterationCount}`);let n=this.init.pass!=null&&this.init.dek?.salt!=null?Fr(this.init.pass,this.init.dek?.salt,this.init.dek?.iterationCount,this.init.dek?.keyLength,this.init.dek?.hash):"";tn.set(this,{dek:n})}[Symbol.toStringTag]="@libp2p/keychain";[wi]=["@libp2p/keychain"];static generateOptions(){let t=Object.assign({},ci),e=Math.ceil(Me.minSaltLength/3)*3;return t.dek.salt=j(Oe(e),"base64"),t}static get options(){return ci}async findKeyByName(t){if(!gr(t))throw await ct(),new L(`Invalid key name '${t}'`);let e=yr(t);try{let n=await this.components.datastore.get(e);return JSON.parse(j(n))}catch(n){throw await ct(),this.log.error(n),new nn(`Key '${t}' does not exist.`)}}async findKeyById(t){try{let e={prefix:li};for await(let n of this.components.datastore.query(e)){let s=JSON.parse(j(n.value));if(s.id===t)return s}throw new L(`Key with id '${t}' does not exist.`)}catch(e){throw await ct(),e}}async importKey(t,e){if(!gr(t))throw await ct(),new L(`Invalid key name '${t}'`);if(e==null)throw await ct(),new L("Key is required");let n=Fe(t);if(await this.components.datastore.has(n))throw await ct(),new L(`Key '${t}' already exists`);let o,i;try{o=await bd(e);let f=tn.get(this);if(f==null)throw new L("dek missing");let l=f.dek;i=await ii(e,l,e.type==="RSA"?"pkcs-8":"libp2p-key")}catch(f){throw await ct(),f}let a={name:t,id:o},c=this.components.datastore.batch();return c.put(n,H(i)),c.put(yr(t),H(JSON.stringify(a))),await c.commit(),a}async exportKey(t){if(!gr(t))throw await ct(),new L(`Invalid key name '${t}'`);let e=Fe(t);try{let n=await this.components.datastore.get(e),s=j(n),o=tn.get(this);if(o==null)throw new L("dek missing");let i=o.dek;return await ai(s,i)}catch(n){throw await ct(),n}}async removeKey(t){if(!gr(t)||t===this.self)throw await ct(),new L(`Invalid key name '${t}'`);let e=Fe(t),n=await this.findKeyByName(t),s=this.components.datastore.batch();return s.delete(e),s.delete(yr(t)),await s.commit(),n}async listKeys(){let t={prefix:li},e=[];for await(let n of this.components.datastore.query(t))e.push(JSON.parse(j(n.value)));return e}async renameKey(t,e){if(!gr(t)||t===this.self)throw await ct(),new L(`Invalid old key name '${t}'`);if(!gr(e)||e===this.self)throw await ct(),new L(`Invalid new key name '${e}'`);let n=Fe(t),s=Fe(e),o=yr(t),i=yr(e);if(await this.components.datastore.has(s))throw await ct(),new L(`Key '${e}' already exists`);try{let c=await this.components.datastore.get(n),f=await this.components.datastore.get(o),l=JSON.parse(j(f));l.name=e;let u=this.components.datastore.batch();return u.put(s,c),u.put(i,H(JSON.stringify(l))),u.delete(n),u.delete(o),await u.commit(),l}catch(c){throw await ct(),c}}async rotateKeychainPass(t,e){if(typeof t!="string")throw await ct(),new L(`Invalid old pass type '${typeof t}'`);if(typeof e!="string")throw await ct(),new L(`Invalid new pass type '${typeof e}'`);if(e.length<20)throw await ct(),new L(`Invalid pass length ${e.length}`);this.log("recreating keychain");let n=tn.get(this);if(n==null)throw new L("dek missing");let s=n.dek;this.init.pass=e;let o=e!=null&&this.init.dek?.salt!=null?Fr(e,this.init.dek.salt,this.init.dek?.iterationCount,this.init.dek?.keyLength,this.init.dek?.hash):"";tn.set(this,{dek:o});let i=await this.listKeys();for(let a of i){let c=await this.components.datastore.get(Fe(a.name)),f=j(c),l=await ai(f,s),u=o.toString(),h=await ii(l,u,l.type==="RSA"?"pkcs-8":"libp2p-key"),y=this.components.datastore.batch(),b={name:a.name,id:a.id};y.put(Fe(a.name),H(h)),y.put(yr(a.name),H(JSON.stringify(b))),await y.commit()}this.log("keychain reconstructed")}};function wd(r={}){return t=>new Ts(t,r)}return Rl(xd);})();
8
8
  /*! Bundled license information:
9
9
 
10
10
  pvtsutils/build/index.js: