@libp2p/keychain 5.2.1 → 5.2.2

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 wl=Object.create;var Qr=Object.defineProperty;var xl=Object.getOwnPropertyDescriptor;var vl=Object.getOwnPropertyNames;var El=Object.getPrototypeOf,Bl=Object.prototype.hasOwnProperty;var Ee=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),dt=(r,t)=>{for(var e in t)Qr(r,e,{get:t[e],enumerable:!0})},ii=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of vl(t))!Bl.call(r,s)&&s!==e&&Qr(r,s,{get:()=>t[s],enumerable:!(n=xl(t,s))||n.enumerable});return r};var ks=(r,t,e)=>(e=r!=null?wl(El(r)):{},ii(t||!r||!r.__esModule?Qr(e,"default",{value:r,enumerable:!0}):e,r)),Al=r=>ii(Qr({},"__esModule",{value:!0}),r);var ac=Ee((Lm,ic)=>{"use strict";ic.exports=r=>{if(Object.prototype.toString.call(r)!=="[object Object]")return!1;let t=Object.getPrototypeOf(r);return t===null||t===Object.prototype}});var dc=Ee((fc,hc)=>{"use strict";var Tn=ac(),{hasOwnProperty:lc}=Object.prototype,{propertyIsEnumerable:ph}=Object,cr=(r,t,e)=>Object.defineProperty(r,t,{value:e,writable:!0,enumerable:!0,configurable:!0}),gh=fc,cc={concatArrays:!1,ignoreUndefined:!1},Ln=r=>{let t=[];for(let e in r)lc.call(r,e)&&t.push(e);if(Object.getOwnPropertySymbols){let e=Object.getOwnPropertySymbols(r);for(let n of e)ph.call(r,n)&&t.push(n)}return t};function lr(r){return Array.isArray(r)?yh(r):Tn(r)?mh(r):r}function yh(r){let t=r.slice(0,0);return Ln(r).forEach(e=>{cr(t,e,lr(r[e]))}),t}function mh(r){let t=Object.getPrototypeOf(r)===null?Object.create(null):{};return Ln(r).forEach(e=>{cr(t,e,lr(r[e]))}),t}var uc=(r,t,e,n)=>(e.forEach(s=>{typeof t[s]>"u"&&n.ignoreUndefined||(s in r&&r[s]!==Object.getPrototypeOf(r)?cr(r,s,Zo(r[s],t[s],n)):cr(r,s,lr(t[s])))}),r),bh=(r,t,e)=>{let n=r.slice(0,0),s=0;return[r,t].forEach(o=>{let i=[];for(let a=0;a<o.length;a++)lc.call(o,a)&&(i.push(String(a)),o===r?cr(n,s++,o[a]):cr(n,s++,lr(o[a])));n=uc(n,o,Ln(o).filter(a=>!i.includes(a)),e)}),n};function Zo(r,t,e){return e.concatArrays&&Array.isArray(r)&&Array.isArray(t)?bh(r,t,e):!Tn(t)||!Tn(r)?lr(t):uc(r,t,Ln(t),e)}hc.exports=function(...r){let t=Zo(lr(cc),this!==gh&&this||{},cc),e={_:{}};for(let n of r)if(n!==void 0){if(!Tn(n))throw new TypeError("`"+n+"` is not an Option Object");e=Zo(e,{_:n},t)}return e._}});var mc=Ee((_m,yc)=>{"use strict";function wh(r){return r>=55296&&r<=56319}function xh(r){return r>=56320&&r<=57343}yc.exports=function(t,e,n){if(typeof e!="string")throw new Error("Input must be string");for(var s=e.length,o=0,i,a,c=0;c<s;c+=1){if(i=e.charCodeAt(c),a=e[c],wh(i)&&xh(e.charCodeAt(c+1))&&(c+=1,a+=e[c]),o+=t(a),o===n)return e.slice(0,c+1);if(o>n)return e.slice(0,c-a.length+1)}return e}});var wc=Ee((Dm,bc)=>{"use strict";function vh(r){return r>=55296&&r<=56319}function Eh(r){return r>=56320&&r<=57343}bc.exports=function(t){if(typeof t!="string")throw new Error("Input must be string");for(var e=t.length,n=0,s=null,o=null,i=0;i<e;i++)s=t.charCodeAt(i),Eh(s)?o!=null&&vh(o)?n+=1:n+=3:s<=127?n+=1:s>=128&&s<=2047?n+=2:s>=2048&&s<=65535&&(n+=3),o=s;return n}});var vc=Ee((Km,xc)=>{"use strict";var Bh=mc(),Ah=wc();xc.exports=Bh.bind(null,Ah)});var Ac=Ee((Om,Bc)=>{"use strict";var Sh=vc(),kh=/[\/\?<>\\:\*\|"]/g,Ch=/[\x00-\x1f\x80-\x9f]/g,Ih=/^\.+$/,Nh=/^(con|prn|aux|nul|com[0-9]|lpt[0-9])(\..*)?$/i,Uh=/[\. ]+$/;function Ec(r,t){if(typeof r!="string")throw new Error("Input must be string");var e=r.replace(kh,t).replace(Ch,t).replace(Ih,t).replace(Nh,t).replace(Uh,t);return Sh(e,255)}Bc.exports=function(r,t){var e=t&&t.replacement||"",n=Ec(r,e);return e===""?n:Ec(n,"")}});var Sc=Ee(fr=>{"use strict";var Lh="[object ArrayBuffer]",Qt=class r{static isArrayBuffer(t){return Object.prototype.toString.call(t)===Lh}static toArrayBuffer(t){return this.isArrayBuffer(t)?t:t.byteLength===t.buffer.byteLength||t.byteOffset===0&&t.byteLength===t.buffer.byteLength?t.buffer:this.toUint8Array(t.buffer).slice(t.byteOffset,t.byteOffset+t.byteLength).buffer}static toUint8Array(t){return this.toView(t,Uint8Array)}static toView(t,e){if(t.constructor===e)return t;if(this.isArrayBuffer(t))return new e(t);if(this.isArrayBufferView(t))return new e(t.buffer,t.byteOffset,t.byteLength);throw new TypeError("The provided value is not of type '(ArrayBuffer or ArrayBufferView)'")}static isBufferSource(t){return this.isArrayBufferView(t)||this.isArrayBuffer(t)}static isArrayBufferView(t){return ArrayBuffer.isView(t)||t&&this.isArrayBuffer(t.buffer)}static isEqual(t,e){let n=r.toUint8Array(t),s=r.toUint8Array(e);if(n.length!==s.byteLength)return!1;for(let o=0;o<n.length;o++)if(n[o]!==s[o])return!1;return!0}static concat(...t){let e;Array.isArray(t[0])&&!(t[1]instanceof Function)||Array.isArray(t[0])&&t[1]instanceof Function?e=t[0]:t[t.length-1]instanceof Function?e=t.slice(0,t.length-1):e=t;let n=0;for(let i of e)n+=i.byteLength;let s=new Uint8Array(n),o=0;for(let i of e){let a=this.toUint8Array(i);s.set(a,o),o+=a.length}return t[t.length-1]instanceof Function?this.toView(s,t[t.length-1]):s.buffer}},Jo="string",Rh=/^[0-9a-f\s]+$/i,_h=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,Dh=/^[a-zA-Z0-9-_]+$/,_n=class{static fromString(t){let e=unescape(encodeURIComponent(t)),n=new Uint8Array(e.length);for(let s=0;s<e.length;s++)n[s]=e.charCodeAt(s);return n.buffer}static toString(t){let e=Qt.toUint8Array(t),n="";for(let o=0;o<e.length;o++)n+=String.fromCharCode(e[o]);return decodeURIComponent(escape(n))}},Nt=class{static toString(t,e=!1){let n=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}},Dn=class r{static isHex(t){return typeof t===Jo&&Rh.test(t)}static isBase64(t){return typeof t===Jo&&_h.test(t)}static isBase64Url(t){return typeof t===Jo&&Dh.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 Nt.toString(n,!0);case"utf16":case"utf16be":return Nt.toString(n);default:throw new Error(`Unknown type of encoding '${e}'`)}}static FromString(t,e="utf8"){if(!t)return new ArrayBuffer(0);switch(e.toLowerCase()){case"utf8":return this.FromUtf8String(t);case"binary":return this.FromBinary(t);case"hex":return this.FromHex(t);case"base64":return this.FromBase64(t);case"base64url":return this.FromBase64Url(t);case"utf16le":return Nt.fromString(t,!0);case"utf16":case"utf16be":return Nt.fromString(t);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToBase64(t){let e=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 _n.fromString(t);case"utf16":case"utf16be":return Nt.fromString(t);case"utf16le":case"usc2":return Nt.fromString(t,!0);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToUtf8String(t,e=r.DEFAULT_UTF8_ENCODING){switch(e){case"ascii":return this.ToBinary(t);case"utf8":return _n.toString(t);case"utf16":case"utf16be":return Nt.toString(t);case"utf16le":case"usc2":return Nt.toString(t,!0);default:throw new Error(`Unknown type of encoding '${e}'`)}}static FromBinary(t){let e=t.length,n=new Uint8Array(e);for(let s=0;s<e;s++)n[s]=t.charCodeAt(s);return n.buffer}static ToBinary(t){let e=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 Nt.toString(t,e)}static FromUtf16String(t,e=!1){return Nt.fromString(t,e)}static Base64Padding(t){let e=4-t.length%4;if(e<4)for(let n=0;n<e;n++)t+="=";return t}static formatString(t){return t?.replace(/[\n\r\t ]/g,"")||""}};Dn.DEFAULT_UTF8_ENCODING="utf8";function Kh(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 Oh(...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 Vh(r,t){if(!(r&&t)||r.byteLength!==t.byteLength)return!1;let e=new Uint8Array(r),n=new Uint8Array(t);for(let s=0;s<r.byteLength;s++)if(e[s]!==n[s])return!1;return!0}fr.BufferSourceConverter=Qt;fr.Convert=Dn;fr.assign=Kh;fr.combine=Oh;fr.isEqual=Vh});var ed={};dt(ed,{keychain:()=>td});var yr=class extends Error{constructor(t="An error occurred while signing a message"){super(t),this.name="SigningError"}},mr=class extends Error{constructor(t="An error occurred while verifying a message"){super(t),this.name="VerificationError"}},tn=class extends Error{constructor(t="Missing Web Crypto API"){super(t),this.name="WebCryptoMissingError"}};var ai={get(r=globalThis){let t=r.crypto;if(t?.subtle==null)throw new tn("Missing Web Crypto API. The most likely cause of this error is that this page is being accessed from an insecure context (i.e. not HTTPS). For more information and possible resolutions see https://github.com/libp2p/js-libp2p/blob/main/packages/crypto/README.md#web-crypto-api");return t}};var xt=ai;var R=class extends Error{static name="InvalidParametersError";constructor(t="Invalid parameters"){super(t),this.name="InvalidParametersError"}},Pe=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 en=class extends Error{static name="NotFoundError";constructor(t="Not found"){super(t),this.name="NotFoundError"}};var Me=class extends Error{static name="UnsupportedKeyTypeError";constructor(t="Unsupported key type"){super(t),this.name="UnsupportedKeyTypeError"}};var ci=Symbol.for("@libp2p/service-capabilities"),ld=Symbol.for("@libp2p/service-dependencies");var Ts={};dt(Ts,{base58btc:()=>et,base58flickr:()=>Ul});var Ld=new Uint8Array(0);function li(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 qt(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 ui(r){return new TextEncoder().encode(r)}function fi(r){return new TextDecoder().decode(r)}function Sl(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 _=w[b],L=0,I=p-1;(_!==0||L<d)&&I!==-1;I--,L++)_+=256*S[I]>>>0,S[I]=_%a>>>0,_=_/a>>>0;if(_!==0)throw new Error("Non-zero carry");d=L,b++}for(var N=p-d;N!==p&&S[N]===0;)N++;for(var U=c.repeat(y);N<p;++N)U+=r.charAt(S[N]);return U}function h(w){if(typeof w!="string")throw new TypeError("Expected String");if(w.length===0)return new Uint8Array;var y=0;if(w[y]!==" "){for(var d=0,b=0;w[y]===c;)d++,y++;for(var E=(w.length-y)*f+1>>>0,p=new Uint8Array(E);w[y];){var S=e[w.charCodeAt(y)];if(S===255)return;for(var _=0,L=E-1;(S!==0||_<b)&&L!==-1;L--,_++)S+=a*p[L]>>>0,p[L]=S%256>>>0,S=S/256>>>0;if(S!==0)throw new Error("Non-zero carry");b=_,y++}if(w[y]!==" "){for(var I=E-b;I!==E&&p[I]===0;)I++;for(var N=new Uint8Array(d+(E-I)),U=d;I!==E;)N[U++]=p[I++];return N}}}function m(w){var y=h(w);if(y)return y;throw new Error(`Non-${t} character`)}return{encode:u,decodeUnsafe:h,decode:m}}var kl=Sl,Cl=kl,di=Cl;var Cs=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")}},Is=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 pi(this,t)}},Ns=class{decoders;constructor(t){this.decoders=t}or(t){return pi(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 pi(r,t){return new Ns({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var Us=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 Cs(t,e,n),this.decoder=new Is(t,e,s)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function Fe({name:r,prefix:t,encode:e,decode:n}){return new Us(r,t,e,n)}function ie({name:r,prefix:t,alphabet:e}){let{encode:n,decode:s}=di(e,r);return Fe({prefix:t,name:r,encode:n,decode:o=>qt(s(o))})}function Il(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 Nl(r,t,e){let n=t[t.length-1]==="=",s=(1<<e)-1,o="",i=0,a=0;for(let c=0;c<r.length;++c)for(a=a<<8|r[c],i+=8;i>e;)i-=e,o+=t[s&a>>i];if(i!==0&&(o+=t[s&a<<e-i]),n)for(;(o.length*e&7)!==0;)o+="=";return o}function X({name:r,prefix:t,bitsPerChar:e,alphabet:n}){return Fe({prefix:t,name:r,encode(s){return Nl(s,n,e)},decode(s){return Il(s,n,e,r)}})}var et=ie({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),Ul=ie({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Ls={};dt(Ls,{base32:()=>qe,base32hex:()=>_l,base32hexpad:()=>Kl,base32hexpadupper:()=>Ol,base32hexupper:()=>Dl,base32pad:()=>Ll,base32padupper:()=>Rl,base32upper:()=>Tl,base32z:()=>Vl});var qe=X({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),Tl=X({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Ll=X({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),Rl=X({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),_l=X({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),Dl=X({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),Kl=X({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),Ol=X({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),Vl=X({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Rs={};dt(Rs,{base36:()=>wr,base36upper:()=>Hl});var wr=ie({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),Hl=ie({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Pl=mi,gi=128,Ml=127,Fl=~Ml,ql=Math.pow(2,31);function mi(r,t,e){t=t||[],e=e||0;for(var n=e;r>=ql;)t[e++]=r&255|gi,r/=128;for(;r&Fl;)t[e++]=r&255|gi,r>>>=7;return t[e]=r|0,mi.bytes=e-n+1,t}var jl=_s,$l=128,yi=127;function _s(r,n){var e=0,n=n||0,s=0,o=n,i,a=r.length;do{if(o>=a)throw _s.bytes=0,new RangeError("Could not decode varint");i=r[o++],e+=s<28?(i&yi)<<s:(i&yi)*Math.pow(2,s),s+=7}while(i>=$l);return _s.bytes=o-n,e}var Gl=Math.pow(2,7),zl=Math.pow(2,14),Wl=Math.pow(2,21),Zl=Math.pow(2,28),Jl=Math.pow(2,35),Yl=Math.pow(2,42),Xl=Math.pow(2,49),Ql=Math.pow(2,56),tu=Math.pow(2,63),eu=function(r){return r<Gl?1:r<zl?2:r<Wl?3:r<Zl?4:r<Jl?5:r<Yl?6:r<Xl?7:r<Ql?8:r<tu?9:10},ru={encode:Pl,decode:jl,encodingLength:eu},nu=ru,xr=nu;function vr(r,t=0){return[xr.decode(r,t),xr.decode.bytes]}function je(r,t,e=0){return xr.encode(r,t,e),t}function $e(r){return xr.encodingLength(r)}function Tt(r,t){let e=t.byteLength,n=$e(r),s=n+$e(e),o=new Uint8Array(s+e);return je(r,o,0),je(e,o,n),o.set(t,s),new Ge(r,e,t,o)}function bi(r){let t=qt(r),[e,n]=vr(t),[s,o]=vr(t.subarray(n)),i=t.subarray(n+o);if(i.byteLength!==s)throw new Error("Incorrect length");return new Ge(e,s,i,t)}function wi(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&li(r.bytes,e.bytes)}}var Ge=class{code;size;digest;bytes;constructor(t,e,n,s){this.code=t,this.size=e,this.digest=n,this.bytes=s}};function xi(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return ou(e,Ds(r),t??et.encoder);default:return iu(e,Ds(r),t??qe.encoder)}}var vi=new WeakMap;function Ds(r){let t=vi.get(r);if(t==null){let e=new Map;return vi.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!==Br)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==au)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&&wi(t.multihash,n.multihash)}toString(t){return xi(this,t)}toJSON(){return{"/":xi(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??Ei(n,s,o.bytes))}else if(e[cu]===!0){let{version:n,multihash:s,code:o}=e,i=bi(s);return r.create(n,o,i)}else return null}static create(t,e,n){if(typeof e!="number")throw new Error("String codecs are no longer supported");if(!(n.bytes instanceof Uint8Array))throw new Error("Invalid digest");switch(t){case 0:{if(e!==Br)throw new Error(`Version 0 CID must use dag-pb (code: ${Br}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let s=Ei(t,e,n.bytes);return new r(t,e,n,s)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,Br,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=qt(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 Ge(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]=vr(t.subarray(e));return e+=h,u},s=n(),o=Br;if(s===18?(s=0,e=0):o=n(),s!==0&&s!==1)throw new RangeError(`Invalid CID version ${s}`);let i=e,a=n(),c=n(),f=e+c,l=f-i;return{version:s,codec:o,multihashCode:a,digestSize:c,multihashSize:l,size:f}}static parse(t,e){let[n,s]=su(t,e),o=r.decode(s);if(o.version===0&&t[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return Ds(o).set(n,t),o}};function su(r,t){switch(r[0]){case"Q":{let e=t??et;return[et.prefix,e.decode(`${et.prefix}${r}`)]}case et.prefix:{let e=t??et;return[et.prefix,e.decode(r)]}case qe.prefix:{let e=t??qe;return[qe.prefix,e.decode(r)]}case wr.prefix:{let e=t??wr;return[wr.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 ou(r,t,e){let{prefix:n}=e;if(n!==et.prefix)throw Error(`Cannot string encode V0 in ${e.name} encoding`);let s=t.get(n);if(s==null){let o=e.encode(r).slice(1);return t.set(n,o),o}else return s}function iu(r,t,e){let{prefix:n}=e,s=t.get(n);if(s==null){let o=e.encode(r);return t.set(n,o),o}else return s}var Br=112,au=18;function Ei(r,t,e){let n=$e(r),s=n+$e(t),o=new Uint8Array(s+e.byteLength);return je(r,o,0),je(t,o,n),o.set(e,s),o}var cu=Symbol.for("@ipld/js-cid/CID");var Ks={};dt(Ks,{identity:()=>Be});var Bi=0,lu="identity",Ai=qt;function uu(r){return Tt(Bi,Ai(r))}var Be={code:Bi,name:lu,encode:Ai,digest:uu};function vt(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function jt(r=0){return new Uint8Array(r)}function St(r=0){return new Uint8Array(r)}function ze(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 ki=Symbol.for("@achingbrain/uint8arraylist");function Si(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 nn(r){return!!r?.[ki]}var pt=class r{bufs;length;[ki]=!0;constructor(...t){this.bufs=[],this.length=0,t.length>0&&this.appendAll(t)}*[Symbol.iterator](){yield*this.bufs}get byteLength(){return this.length}append(...t){this.appendAll(t)}appendAll(t){let e=0;for(let n of t)if(n instanceof Uint8Array)e+=n.byteLength,this.bufs.push(n);else if(nn(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(nn(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=Si(this.bufs,t);return e.buf[e.index]}set(t,e){let n=Si(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(nn(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 ze(n,s)}subarray(t,e){let{bufs:n,length:s}=this._subList(t,e);return n.length===1?n[0]:ze(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(!nn(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=jt(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=jt(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=jt(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=jt(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=jt(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=jt(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=jt(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=jt(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setFloat64(0,e,n),this.write(s,t)}equals(t){if(t==null||!(t instanceof r)||t.bufs.length!==this.bufs.length)return!1;for(let e=0;e<this.bufs.length;e++)if(!vt(this.bufs[e],t.bufs[e]))return!1;return!0}static fromUint8Arrays(t,e){let n=new r;return n.bufs=t,e==null&&(e=t.reduce((s,o)=>s+o.byteLength,0)),n.length=e,n}};var Os={};dt(Os,{base10:()=>fu});var fu=ie({prefix:"9",name:"base10",alphabet:"0123456789"});var Vs={};dt(Vs,{base16:()=>hu,base16upper:()=>du});var hu=X({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),du=X({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Hs={};dt(Hs,{base2:()=>pu});var pu=X({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Ps={};dt(Ps,{base256emoji:()=>wu});var Ci=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}"),gu=Ci.reduce((r,t,e)=>(r[e]=t,r),[]),yu=Ci.reduce((r,t,e)=>{let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);return r[n]=e,r},[]);function mu(r){return r.reduce((t,e)=>(t+=gu[e],t),"")}function bu(r){let t=[];for(let e of r){let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);let s=yu[n];if(s==null)throw new Error(`Non-base256emoji character: ${e}`);t.push(s)}return new Uint8Array(t)}var wu=Fe({prefix:"\u{1F680}",name:"base256emoji",encode:mu,decode:bu});var Ms={};dt(Ms,{base64:()=>Ae,base64pad:()=>xu,base64url:()=>vu,base64urlpad:()=>Eu});var Ae=X({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),xu=X({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),vu=X({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Eu=X({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Fs={};dt(Fs,{base8:()=>Bu});var Bu=X({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var qs={};dt(qs,{identity:()=>Au});var Au=Fe({prefix:"\0",name:"identity",encode:r=>fi(r),decode:r=>ui(r)});var g0=new TextEncoder,y0=new TextDecoder;var Gs={};dt(Gs,{sha256:()=>We,sha512:()=>Cu});function $s({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?Tt(this.code,e):e.then(n=>Tt(this.code,n))}else throw Error("Unknown type, must be binary type")}};function Ni(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var We=$s({name:"sha2-256",code:18,encode:Ni("SHA-256")}),Cu=$s({name:"sha2-512",code:19,encode:Ni("SHA-512")});var zs={...qs,...Hs,...Fs,...Os,...Vs,...Ls,...Rs,...Ts,...Ms,...Ps},I0={...Gs,...Ks};function Ti(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var Ui=Ti("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),Ws=Ti("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}),Iu={utf8:Ui,"utf-8":Ui,hex:zs.base16,latin1:Ws,ascii:Ws,binary:Ws,...zs},sn=Iu;function H(r,t="utf8"){let e=sn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function j(r,t="utf8"){let e=sn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}var Nu=parseInt("11111",2),Zs=parseInt("10000000",2),Uu=parseInt("01111111",2),Li={0:Ar,1:Ar,2:Tu,3:_u,4:Du,5:Ru,6:Lu,16:Ar,22:Ar,48:Ar};function Lt(r,t={offset:0}){let e=r[t.offset]&Nu;if(t.offset++,Li[e]!=null)return Li[e](r,t);throw new Error("No decoder for tag "+e)}function Sr(r,t){let e=0;if((r[t.offset]&Zs)===Zs){let n=r[t.offset]&Uu,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 Ar(r,t){Sr(r,t);let e=[];for(;!(t.offset>=r.byteLength);){let n=Lt(r,t);if(n===null)break;e.push(n)}return e}function Tu(r,t){let e=Sr(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 Lu(r,t){let e=Sr(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 Ru(r,t){return t.offset++,null}function _u(r,t){let e=Sr(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 Du(r,t){let e=Sr(r,t),n=r.subarray(t.offset,t.offset+e);return t.offset+=e,n}function Ku(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 on(r){if(r.byteLength<128)return Uint8Array.from([r.byteLength]);let t=Ku(r.byteLength);return new pt(Uint8Array.from([t.byteLength|Zs]),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]),on(t),t)}function kr(r){let t=Uint8Array.from([0]),e=new pt(t,r);return new pt(Uint8Array.from([3]),on(e),e)}function Ri(r){return new pt(Uint8Array.from([4]),on(r),r)}function Rt(r,t=48){let e=new pt;for(let n of r)e.append(n);return new pt(Uint8Array.from([t]),on(e),e)}var _i="1.2.840.10045.3.1.7",Di="1.3.132.0.34",Ki="1.3.132.0.35";async function Oi(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 Vi(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 Ou=Uint8Array.from([6,8,42,134,72,206,61,3,1,7]),Vu=Uint8Array.from([6,5,43,129,4,0,34]),Hu=Uint8Array.from([6,5,43,129,4,0,35]),Pu={ext:!0,kty:"EC",crv:"P-256"},Mu={ext:!0,kty:"EC",crv:"P-384"},Fu={ext:!0,kty:"EC",crv:"P-521"},Js=32,Ys=48,Xs=66;function Hi(r){let t=Lt(r);return Qs(t)}function Qs(r){let t=r[1],e=j(t,"base64url"),n=r[2][1][0],s=1,o,i;if(t.byteLength===Js)return o=j(n.subarray(s,s+Js),"base64url"),i=j(n.subarray(s+Js),"base64url"),new Ze({...Pu,key_ops:["sign"],d:e,x:o,y:i});if(t.byteLength===Ys)return o=j(n.subarray(s,s+Ys),"base64url"),i=j(n.subarray(s+Ys),"base64url"),new Ze({...Mu,key_ops:["sign"],d:e,x:o,y:i});if(t.byteLength===Xs)return o=j(n.subarray(s,s+Xs),"base64url"),i=j(n.subarray(s+Xs),"base64url"),new Ze({...Fu,key_ops:["sign"],d:e,x:o,y:i});throw new R(`Private key length was wrong length, got ${t.byteLength}, expected 32, 48 or 66`)}function Pi(r){return Rt([gt(Uint8Array.from([1])),Ri(H(r.d??"","base64url")),Rt([Fi(r.crv)],160),Rt([kr(new pt(Uint8Array.from([4]),H(r.x??"","base64url"),H(r.y??"","base64url")))],161)]).subarray()}function Mi(r){return Rt([gt(Uint8Array.from([1])),Rt([Fi(r.crv)],160),Rt([kr(new pt(Uint8Array.from([4]),H(r.x??"","base64url"),H(r.y??"","base64url")))],161)]).subarray()}function Fi(r){if(r==="P-256")return Ou;if(r==="P-384")return Vu;if(r==="P-521")return Hu;throw new R(`Invalid curve ${r}`)}var an=class{type="ECDSA";jwk;_raw;constructor(t){this.jwk=t}get raw(){return this._raw==null&&(this._raw=Mi(this.jwk)),this._raw}toMultihash(){return Be.digest(Je(this))}toCID(){return It.createV1(114,this.toMultihash())}toString(){return et.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:vt(this.raw,t.raw)}async verify(t,e){return Vi(this.jwk,e,t)}},Ze=class{type="ECDSA";jwk;publicKey;_raw;constructor(t){this.jwk=t,this.publicKey=new an({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=Pi(this.jwk)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:vt(this.raw,t.raw)}async sign(t){return Oi(this.jwk,t)}};function Ye(r){if(!Number.isSafeInteger(r)||r<0)throw new Error("positive integer expected, got "+r)}function qu(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function Xe(r,...t){if(!qu(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 cn(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");Ye(r.outputLen),Ye(r.blockLen)}function Qe(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 qi(r,t){Xe(r);let e=t.outputLen;if(r.length<e)throw new Error("digestInto() expects output buffer of length at least "+e)}var Se=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;function ke(r){return new DataView(r.buffer,r.byteOffset,r.byteLength)}function _t(r,t){return r<<32-t|r>>>t}function ln(r,t){return r<<t|r>>>32-t>>>0}var op=typeof Uint8Array.from([]).toHex=="function"&&typeof Uint8Array.fromHex=="function";var ju=async()=>{};async function ji(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 ju(),n+=o)}}function $i(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=$i(r)),Xe(r),r}function to(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];Xe(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 tr=class{clone(){return this._cloneInto()}};function Gi(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 er(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 rr(r=32){if(Se&&typeof Se.getRandomValues=="function")return Se.getRandomValues(new Uint8Array(r));if(Se&&typeof Se.randomBytes=="function")return Uint8Array.from(Se.randomBytes(r));throw new Error("crypto.getRandomValues must be defined")}function $u(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 un(r,t,e){return r&t^~r&e}function fn(r,t,e){return r&t^r&e^t&e}var ce=class extends tr{constructor(t,e,n,s){super(),this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.blockLen=t,this.outputLen=e,this.padOffset=n,this.isLE=s,this.buffer=new Uint8Array(t),this.view=ke(this.buffer)}update(t){Qe(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=ke(t);for(;s<=o-i;i+=s)this.process(c,i);continue}n.set(t.subarray(i,i+a),this.pos),this.pos+=a,i+=a,this.pos===s&&(this.process(e,0),this.pos=0)}return this.length+=t.length,this.roundClean(),this}digestInto(t){Qe(this),qi(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;$u(n,s-8,BigInt(this.length*8),o),this.process(n,0);let a=ke(t),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let f=c/4,l=this.get();if(f>l.length)throw new Error("_sha2: outputLen bigger than state");for(let u=0;u<f;u++)a.setUint32(4*u,l[u],o)}digest(){let{buffer:t,outputLen:e}=this;this.digestInto(t);let n=t.slice(0,e);return this.destroy(),n}_cloneInto(t){t||(t=new this.constructor),t.set(...this.get());let{blockLen:e,buffer:n,length:s,finished:o,destroyed:i,pos:a}=this;return t.length=s,t.pos=a,t.finished=o,t.destroyed=i,s%e&&t.buffer.set(n),t}};var Gu=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]),le=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),ue=new Uint32Array(64),eo=class extends ce{constructor(t=32){super(64,t,8,!1),this.A=le[0]|0,this.B=le[1]|0,this.C=le[2]|0,this.D=le[3]|0,this.E=le[4]|0,this.F=le[5]|0,this.G=le[6]|0,this.H=le[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)ue[u]=t.getUint32(e,!1);for(let u=16;u<64;u++){let h=ue[u-15],m=ue[u-2],w=_t(h,7)^_t(h,18)^h>>>3,y=_t(m,17)^_t(m,19)^m>>>10;ue[u]=y+ue[u-7]+w+ue[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=_t(a,6)^_t(a,11)^_t(a,25),m=l+h+un(a,c,f)+Gu[u]+ue[u]|0,y=(_t(n,2)^_t(n,13)^_t(n,22))+fn(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(){ue.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var $t=er(()=>new eo);var hn=BigInt(4294967295),ro=BigInt(32);function zi(r,t=!1){return t?{h:Number(r&hn),l:Number(r>>ro&hn)}:{h:Number(r>>ro&hn)|0,l:Number(r&hn)|0}}function zu(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}=zi(r[s],t);[e[s],n[s]]=[o,i]}return[e,n]}var Wu=(r,t)=>BigInt(r>>>0)<<ro|BigInt(t>>>0),Zu=(r,t,e)=>r>>>e,Ju=(r,t,e)=>r<<32-e|t>>>e,Yu=(r,t,e)=>r>>>e|t<<32-e,Xu=(r,t,e)=>r<<32-e|t>>>e,Qu=(r,t,e)=>r<<64-e|t>>>e-32,tf=(r,t,e)=>r>>>e-32|t<<64-e,ef=(r,t)=>t,rf=(r,t)=>r,nf=(r,t,e)=>r<<e|t>>>32-e,sf=(r,t,e)=>t<<e|r>>>32-e,of=(r,t,e)=>t<<e-32|r>>>64-e,af=(r,t,e)=>r<<e-32|t>>>64-e;function cf(r,t,e,n){let s=(t>>>0)+(n>>>0);return{h:r+e+(s/2**32|0)|0,l:s|0}}var lf=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),uf=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,ff=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),hf=(r,t,e,n,s)=>t+e+n+s+(r/2**32|0)|0,df=(r,t,e,n,s)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(s>>>0),pf=(r,t,e,n,s,o)=>t+e+n+s+o+(r/2**32|0)|0;var gf={fromBig:zi,split:zu,toBig:Wu,shrSH:Zu,shrSL:Ju,rotrSH:Yu,rotrSL:Xu,rotrBH:Qu,rotrBL:tf,rotr32H:ef,rotr32L:rf,rotlSH:nf,rotlSL:sf,rotlBH:of,rotlBL:af,add:cf,add3L:lf,add3H:uf,add4L:ff,add4H:hf,add5H:pf,add5L:df},K=gf;var[yf,mf]=K.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),no=class extends ce{constructor(t=64){super(128,t,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,_=he[p-15]|0,L=K.rotrSH(S,_,1)^K.rotrSH(S,_,8)^K.shrSH(S,_,7),I=K.rotrSL(S,_,1)^K.rotrSL(S,_,8)^K.shrSL(S,_,7),N=fe[p-2]|0,U=he[p-2]|0,W=K.rotrSH(N,U,19)^K.rotrBH(N,U,61)^K.shrSH(N,U,6),$=K.rotrSL(N,U,19)^K.rotrBL(N,U,61)^K.shrSL(N,U,6),V=K.add4L(I,$,he[p-7],he[p-16]),rt=K.add4H(V,L,W,fe[p-7],fe[p-16]);fe[p]=rt|0,he[p]=V|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=K.rotrSH(u,h,14)^K.rotrSH(u,h,18)^K.rotrBH(u,h,41),_=K.rotrSL(u,h,14)^K.rotrSL(u,h,18)^K.rotrBL(u,h,41),L=u&m^~u&y,I=h&w^~h&d,N=K.add5L(E,_,I,mf[p],he[p]),U=K.add5H(N,b,S,L,yf[p],fe[p]),W=N|0,$=K.rotrSH(n,s,28)^K.rotrBH(n,s,34)^K.rotrBH(n,s,39),V=K.rotrSL(n,s,28)^K.rotrBL(n,s,34)^K.rotrBL(n,s,39),rt=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}=K.add(f|0,l|0,U|0,W|0),f=a|0,l=c|0,a=o|0,c=i|0,o=n|0,i=s|0;let C=K.add3L(W,V,B);n=K.add3H(C,U,$,rt),s=C|0}({h:n,l:s}=K.add(this.Ah|0,this.Al|0,n|0,s|0)),{h:o,l:i}=K.add(this.Bh|0,this.Bl|0,o|0,i|0),{h:a,l:c}=K.add(this.Ch|0,this.Cl|0,a|0,c|0),{h:f,l}=K.add(this.Dh|0,this.Dl|0,f|0,l|0),{h:u,l:h}=K.add(this.Eh|0,this.El|0,u|0,h|0),{h:m,l:w}=K.add(this.Fh|0,this.Fl|0,m|0,w|0),{h:y,l:d}=K.add(this.Gh|0,this.Gl|0,y|0,d|0),{h:b,l:E}=K.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 Gt=er(()=>new no);var ao=BigInt(0),io=BigInt(1);function Ce(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function co(r){if(!Ce(r))throw new Error("Uint8Array expected")}function Ht(r,t){if(typeof t!="boolean")throw new Error(r+" boolean expected, got "+t)}function Cr(r){let t=r.toString(16);return t.length&1?"0"+t:t}function Ji(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return r===""?ao:BigInt("0x"+r)}var Yi=typeof Uint8Array.from([]).toHex=="function"&&typeof Uint8Array.fromHex=="function",bf=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function de(r){if(co(r),Yi)return r.toHex();let t="";for(let e=0;e<r.length;e++)t+=bf[r[e]];return t}var zt={_0:48,_9:57,A:65,F:70,a:97,f:102};function Wi(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 Ir(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);if(Yi)return Uint8Array.fromHex(r);let t=r.length,e=t/2;if(t%2)throw new Error("hex string expected, got unpadded hex of length "+t);let n=new Uint8Array(e);for(let s=0,o=0;s<e;s++,o+=2){let i=Wi(r.charCodeAt(o)),a=Wi(r.charCodeAt(o+1));if(i===void 0||a===void 0){let c=r[o]+r[o+1];throw new Error('hex string expected, got non-hex character "'+c+'" at index '+o)}n[s]=i*16+a}return n}function Wt(r){return Ji(de(r))}function Ie(r){return co(r),Ji(de(Uint8Array.from(r).reverse()))}function Ne(r,t){return Ir(r.toString(16).padStart(t*2,"0"))}function nr(r,t){return Ne(r,t).reverse()}function Y(r,t,e){let n;if(typeof t=="string")try{n=Ir(t)}catch(o){throw new Error(r+" must be hex string or Uint8Array, cause: "+o)}else if(Ce(t))n=Uint8Array.from(t);else throw new Error(r+" must be hex string or Uint8Array");let s=n.length;if(typeof e=="number"&&s!==e)throw new Error(r+" of length "+e+" expected, got "+s);return n}function pe(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];co(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 so=r=>typeof r=="bigint"&&ao<=r;function dn(r,t,e){return so(r)&&so(t)&&so(e)&&t<=r&&r<e}function kt(r,t,e,n){if(!dn(t,e,n))throw new Error("expected valid "+r+": "+e+" <= n < "+n+", got "+t)}function Xi(r){let t;for(t=0;r>ao;r>>=io,t+=1);return t}var Ue=r=>(io<<BigInt(r))-io,oo=r=>new Uint8Array(r),Zi=r=>Uint8Array.from(r);function Qi(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=oo(r),s=oo(r),o=0,i=()=>{n.fill(1),s.fill(0),o=0},a=(...u)=>e(s,n,...u),c=(u=oo(0))=>{s=a(Zi([0]),u),n=a(),u.length!==0&&(s=a(Zi([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 pe(...h)};return(u,h)=>{i(),c(u);let m;for(;!(m=h(f()));)c();return i(),m}}var wf={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"||Ce(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 Zt(r,t,e={}){let n=(s,o,i)=>{let a=wf[o];if(typeof a!="function")throw new Error("invalid validator function");let c=r[s];if(!(i&&c===void 0)&&!a(c,r))throw new Error("param "+String(s)+" is invalid. Expected "+o+", got "+c)};for(let[s,o]of Object.entries(t))n(s,o,!1);for(let[s,o]of Object.entries(e))n(s,o,!0);return r}function sr(r){let t=new WeakMap;return(e,...n)=>{let s=t.get(e);if(s!==void 0)return s;let o=r(e,...n);return t.set(e,o),o}}var nt=BigInt(0),Z=BigInt(1),Te=BigInt(2),xf=BigInt(3),lo=BigInt(4),ta=BigInt(5),ea=BigInt(8),vf=BigInt(9),Ef=BigInt(16);function z(r,t){let e=r%t;return e>=nt?e:t+e}function Bf(r,t,e){if(t<nt)throw new Error("invalid exponent, negatives unsupported");if(e<=nt)throw new Error("invalid modulus");if(e===Z)return nt;let n=Z;for(;t>nt;)t&Z&&(n=n*r%e),r=r*r%e,t>>=Z;return n}function J(r,t,e){let n=r;for(;t-- >nt;)n*=n,n%=e;return n}function pn(r,t){if(r===nt)throw new Error("invert: expected non-zero number");if(t<=nt)throw new Error("invert: expected positive modulus, got "+t);let e=z(r,t),n=t,s=nt,o=Z,i=Z,a=nt;for(;e!==nt;){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 z(s,t)}function Af(r){let t=(r-Z)/Te,e,n,s;for(e=r-Z,n=0;e%Te===nt;e/=Te,n++);for(s=Te;s<r&&Bf(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)/lo;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)/Te;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 Sf(r){if(r%lo===xf){let t=(r+Z)/lo;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%ea===ta){let t=(r-ta)/ea;return function(n,s){let o=n.mul(s,Te),i=n.pow(o,t),a=n.mul(s,i),c=n.mul(n.mul(a,Te),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%Ef,Af(r)}var ra=(r,t)=>(z(r,t)&Z)===Z,kf=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function uo(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=kf.reduce((n,s)=>(n[s]="function",n),t);return Zt(r,e)}function Cf(r,t,e){if(e<nt)throw new Error("invalid exponent, negatives unsupported");if(e===nt)return r.ONE;if(e===Z)return t;let n=r.ONE,s=t;for(;e>nt;)e&Z&&(n=r.mul(n,s)),s=r.sqr(s),e>>=Z;return n}function If(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 fo(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<=nt)throw new Error("invalid field: expected ORDER > 0, got "+r);let{nBitLength:s,nByteLength:o}=fo(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:Ue(s),ZERO:nt,ONE:Z,create:c=>z(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error("invalid field element: expected bigint, got "+typeof c);return nt<=c&&c<r},is0:c=>c===nt,isOdd:c=>(c&Z)===Z,neg:c=>z(-c,r),eql:(c,f)=>c===f,sqr:c=>z(c*c,r),add:(c,f)=>z(c+f,r),sub:(c,f)=>z(c-f,r),mul:(c,f)=>z(c*f,r),pow:(c,f)=>Cf(a,c,f),div:(c,f)=>z(c*pn(f,r),r),sqrN:c=>c*c,addN:(c,f)=>c+f,subN:(c,f)=>c-f,mulN:(c,f)=>c*f,inv:c=>pn(c,r),sqrt:n.sqrt||(c=>(i||(i=Sf(r)),i(a,c))),invertBatch:c=>If(a,c),cmov:(c,f,l)=>l?f:c,toBytes:c=>e?nr(c,o):Ne(c,o),fromBytes:c=>{if(c.length!==o)throw new Error("Field.fromBytes: expected "+o+" bytes, got "+c.length);return e?Ie(c):Wt(c)}});return Object.freeze(a)}function na(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 ho(r){let t=na(r);return t+Math.ceil(t/2)}function sa(r,t,e=!1){let n=r.length,s=na(t),o=ho(t);if(n<16||n<o||n>1024)throw new Error("expected "+o+"-1024 bytes of input, got "+n);let i=e?Ie(r):Wt(r),a=z(i,t-Z)+Z;return e?nr(a,s):Ne(a,s)}var oa=BigInt(0),bo=BigInt(1);function po(r,t){let e=t.negate();return r?e:t}function aa(r,t){if(!Number.isSafeInteger(r)||r<=0||r>t)throw new Error("invalid window size, expected [1.."+t+"], got W="+r)}function go(r,t){aa(r,t);let e=Math.ceil(t/r)+1,n=2**(r-1),s=2**r,o=Ue(r),i=BigInt(r);return{windows:e,windowSize:n,mask:o,maxNumber:s,shiftBy:i}}function ia(r,t,e){let{windowSize:n,mask:s,maxNumber:o,shiftBy:i}=e,a=Number(r&s),c=r>>i;a>n&&(a-=o,c+=bo);let f=t*n,l=f+Math.abs(a)-1,u=a===0,h=a<0,m=t%2!==0;return{nextN:c,offset:l,isZero:u,isNeg:h,isNegF:m,offsetF:f}}function Nf(r,t){if(!Array.isArray(r))throw new Error("array expected");r.forEach((e,n)=>{if(!(e instanceof t))throw new Error("invalid point at index "+n)})}function Uf(r,t){if(!Array.isArray(r))throw new Error("array of scalars expected");r.forEach((e,n)=>{if(!t.isValid(e))throw new Error("invalid scalar at index "+n)})}var yo=new WeakMap,ca=new WeakMap;function mo(r){return ca.get(r)||1}function gn(r,t){return{constTimeNegate:po,hasPrecomputes(e){return mo(e)!==1},unsafeLadder(e,n,s=r.ZERO){let o=e;for(;n>oa;)n&bo&&(s=s.add(o)),o=o.double(),n>>=bo;return s},precomputeWindow(e,n){let{windows:s,windowSize:o}=go(n,t),i=[],a=e,c=a;for(let f=0;f<s;f++){c=a,i.push(c);for(let l=1;l<o;l++)c=c.add(a),i.push(c);a=c.double()}return i},wNAF(e,n,s){let o=r.ZERO,i=r.BASE,a=go(e,t);for(let c=0;c<a.windows;c++){let{nextN:f,offset:l,isZero:u,isNeg:h,isNegF:m,offsetF:w}=ia(s,c,a);s=f,u?i=i.add(po(m,n[w])):o=o.add(po(h,n[l]))}return{p:o,f:i}},wNAFUnsafe(e,n,s,o=r.ZERO){let i=go(e,t);for(let a=0;a<i.windows&&s!==oa;a++){let{nextN:c,offset:f,isZero:l,isNeg:u}=ia(s,a,i);if(s=c,!l){let h=n[f];o=o.add(u?h.negate():h)}}return o},getPrecomputes(e,n,s){let o=yo.get(n);return o||(o=this.precomputeWindow(n,e),e!==1&&yo.set(n,s(o))),o},wNAFCached(e,n,s){let o=mo(e);return this.wNAF(o,this.getPrecomputes(o,e,s),n)},wNAFCachedUnsafe(e,n,s,o){let i=mo(e);return i===1?this.unsafeLadder(e,n,o):this.wNAFUnsafe(i,this.getPrecomputes(i,e,s),n,o)},setWindowSize(e,n){aa(n,t),ca.set(e,n),yo.delete(e)}}}function yn(r,t,e,n){if(Nf(e,r),Uf(n,t),e.length!==n.length)throw new Error("arrays of points and scalars must have equal length");let s=r.ZERO,o=Xi(BigInt(e.length)),i=o>12?o-3:o>4?o-2:o?2:1,a=Ue(i),c=new Array(Number(a)+1).fill(s),f=Math.floor((t.BITS-1)/i)*i,l=s;for(let u=f;u>=0;u-=i){c.fill(s);for(let m=0;m<n.length;m++){let w=n[m],y=Number(w>>BigInt(u)&a);c[y]=c[y].add(e[m])}let h=s;for(let m=c.length-1,w=s;m>0;m--)w=w.add(c[m]),h=h.add(w);if(l=l.add(h),u!==0)for(let m=0;m<i;m++)l=l.double()}return l}function Nr(r){return uo(r.Fp),Zt(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...fo(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Pt=BigInt(0),yt=BigInt(1),la=BigInt(2),Tf=BigInt(8),Lf={zip215:!0};function Rf(r){let t=Nr(r);return Zt(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function ua(r){let t=Rf(r),{Fp:e,n,prehash:s,hash:o,randomBytes:i,nByteLength:a,h:c}=t,f=la<<BigInt(a*8)-yt,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:Pt}}}),m=t.adjustScalarBytes||(x=>x),w=t.domain||((x,g,v)=>{if(Ht("phflag",v),g.length||v)throw new Error("Contexts/pre-hash are not supported");return x});function y(x,g,v=!1){let k=v?yt:Pt;kt("coordinate "+x,g,k,f)}function d(x){if(!(x instanceof p))throw new Error("ExtendedPoint expected")}let b=sr((x,g)=>{let{ex:v,ey:k,ez:D}=x,O=x.is0();g==null&&(g=O?Tf:e.inv(D));let P=l(v*g),F=l(k*g),q=l(D*g);if(O)return{x:Pt,y:yt};if(q!==yt)throw new Error("invZ was invalid");return{x:P,y:F}}),E=sr(x=>{let{a:g,d:v}=t;if(x.is0())throw new Error("bad point: ZERO");let{ex:k,ey:D,ez:O,et:P}=x,F=l(k*k),q=l(D*D),G=l(O*O),tt=l(G*G),Q=l(F*g),at=l(G*l(Q+q)),wt=l(tt+l(v*l(F*q)));if(at!==wt)throw new Error("bad point: equation left != right (1)");let ot=l(k*D),ut=l(O*P);if(ot!==ut)throw new Error("bad point: equation left != right (2)");return!0});class p{constructor(g,v,k,D){y("x",g),y("y",v),y("z",k,!0),y("t",D),this.ex=g,this.ey=v,this.ez=k,this.et=D,Object.freeze(this)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(g){if(g instanceof p)throw new Error("extended point not allowed");let{x:v,y:k}=g||{};return y("x",v),y("y",k),new p(v,k,yt,l(v*k))}static normalizeZ(g){let v=e.invertBatch(g.map(k=>k.ez));return g.map((k,D)=>k.toAffine(v[D])).map(p.fromAffine)}static msm(g,v){return yn(p,u,g,v)}_setWindowSize(g){L.setWindowSize(this,g)}assertValidity(){E(this)}equals(g){d(g);let{ex:v,ey:k,ez:D}=this,{ex:O,ey:P,ez:F}=g,q=l(v*F),G=l(O*D),tt=l(k*F),Q=l(P*D);return q===G&&tt===Q}is0(){return this.equals(p.ZERO)}negate(){return new p(l(-this.ex),this.ey,this.ez,l(-this.et))}double(){let{a:g}=t,{ex:v,ey:k,ez:D}=this,O=l(v*v),P=l(k*k),F=l(la*l(D*D)),q=l(g*O),G=v+k,tt=l(l(G*G)-O-P),Q=q+P,at=Q-F,wt=q-P,ot=l(tt*at),ut=l(Q*wt),At=l(tt*wt),Ut=l(at*Q);return new p(ot,ut,Ut,At)}add(g){d(g);let{a:v,d:k}=t,{ex:D,ey:O,ez:P,et:F}=this,{ex:q,ey:G,ez:tt,et:Q}=g,at=l(D*q),wt=l(O*G),ot=l(F*k*Q),ut=l(P*tt),At=l((D+O)*(q+G)-at-wt),Ut=ut-ot,gr=ut+ot,oi=l(wt-v*at),gl=l(At*Ut),yl=l(gr*oi),ml=l(At*oi),bl=l(Ut*gr);return new p(gl,yl,bl,ml)}subtract(g){return this.add(g.negate())}wNAF(g){return L.wNAFCached(this,g,p.normalizeZ)}multiply(g){let v=g;kt("scalar",v,yt,n);let{p:k,f:D}=this.wNAF(v);return p.normalizeZ([k,D])[0]}multiplyUnsafe(g,v=p.ZERO){let k=g;return kt("scalar",k,Pt,n),k===Pt?_:this.is0()||k===yt?this:L.wNAFCachedUnsafe(this,k,p.normalizeZ,v)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return L.unsafeLadder(this,n).is0()}toAffine(g){return b(this,g)}clearCofactor(){let{h:g}=t;return g===yt?this:this.multiplyUnsafe(g)}static fromHex(g,v=!1){let{d:k,a:D}=t,O=e.BYTES;g=Y("pointHex",g,O),Ht("zip215",v);let P=g.slice(),F=g[O-1];P[O-1]=F&-129;let q=Ie(P),G=v?f:e.ORDER;kt("pointHex.y",q,Pt,G);let tt=l(q*q),Q=l(tt-yt),at=l(k*tt-D),{isValid:wt,value:ot}=h(Q,at);if(!wt)throw new Error("Point.fromHex: invalid y coordinate");let ut=(ot&yt)===yt,At=(F&128)!==0;if(!v&&ot===Pt&&At)throw new Error("Point.fromHex: x=0 and x_0=1");return At!==ut&&(ot=l(-ot)),p.fromAffine({x:ot,y:q})}static fromPrivateKey(g){let{scalar:v}=U(g);return S.multiply(v)}toRawBytes(){let{x:g,y:v}=this.toAffine(),k=nr(v,e.BYTES);return k[k.length-1]|=g&yt?128:0,k}toHex(){return de(this.toRawBytes())}}p.BASE=new p(t.Gx,t.Gy,yt,l(t.Gx*t.Gy)),p.ZERO=new p(Pt,yt,yt,Pt);let{BASE:S,ZERO:_}=p,L=gn(p,a*8);function I(x){return z(x,n)}function N(x){return I(Ie(x))}function U(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)),D=v.slice(g,2*g),O=N(k);return{head:k,prefix:D,scalar:O}}function W(x){let{head:g,prefix:v,scalar:k}=U(x),D=S.multiply(k),O=D.toRawBytes();return{head:g,prefix:v,scalar:k,point:D,pointBytes:O}}function $(x){return W(x).pointBytes}function V(x=new Uint8Array,...g){let v=pe(...g);return N(o(w(v,Y("context",x),!!s)))}function rt(x,g,v={}){x=Y("message",x),s&&(x=s(x));let{prefix:k,scalar:D,pointBytes:O}=W(g),P=V(v.context,k,x),F=S.multiply(P).toRawBytes(),q=V(v.context,F,O,x),G=I(P+q*D);kt("signature.s",G,Pt,n);let tt=pe(F,nr(G,e.BYTES));return Y("result",tt,e.BYTES*2)}let B=Lf;function C(x,g,v,k=B){let{context:D,zip215:O}=k,P=e.BYTES;x=Y("signature",x,2*P),g=Y("message",g),v=Y("publicKey",v,P),O!==void 0&&Ht("zip215",O),s&&(g=s(g));let F=Ie(x.slice(P,2*P)),q,G,tt;try{q=p.fromHex(v,O),G=p.fromHex(x.slice(0,P),O),tt=S.multiplyUnsafe(F)}catch{return!1}if(!O&&q.isSmallOrder())return!1;let Q=V(D,G.toRawBytes(),q.toRawBytes(),g);return G.add(q.multiplyUnsafe(Q)).subtract(tt).clearCofactor().equals(p.ZERO)}return S._setWindowSize(8),{CURVE:t,getPublicKey:$,sign:rt,verify:C,ExtendedPoint:p,utils:{getExtendedPublicKey:W,randomPrivateKey:()=>i(e.BYTES),precompute(x=8,g=p.BASE){return g._setWindowSize(x),g.multiply(BigInt(3)),g}}}}var wo=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),fa=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),Pp=BigInt(0),_f=BigInt(1),ha=BigInt(2),Mp=BigInt(3),Df=BigInt(5),Kf=BigInt(8);function Of(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),s=BigInt(80),o=wo,a=r*r%o*r%o,c=J(a,ha,o)*a%o,f=J(c,_f,o)*r%o,l=J(f,Df,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,ha,o)*r%o,b2:a}}function Vf(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function Hf(r,t){let e=wo,n=z(t*t*t,e),s=z(n*n*t,e),o=Of(r*s).pow_p_5_8,i=z(r*n*o,e),a=z(t*i*i,e),c=i,f=z(i*fa,e),l=a===r,u=a===z(-r,e),h=a===z(-r*fa,e);return l&&(i=c),(u||h)&&(i=f),ra(i,e)&&(i=z(-i,e)),{isValid:l||u,value:i}}var da=ge(wo,void 0,!0),Pf={a:da.create(BigInt(-1)),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:da,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:Kf,Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:Gt,randomBytes:rr,adjustScalarBytes:Vf,uvRatio:Hf},xo=ua(Pf);var or=32,Dt=64,Mf=32;function pa(r,t){let e=r.subarray(0,Mf);return xo.sign(t instanceof Uint8Array?t:t.subarray(),e)}function ga(r,t,e){return xo.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}var mn=class{type="Ed25519";raw;constructor(t){this.raw=Tr(t,or)}toMultihash(){return Be.digest(Je(this))}toCID(){return It.createV1(114,this.toMultihash())}toString(){return et.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:vt(this.raw,t.raw)}verify(t,e){return ga(this.raw,e,t)}},Ur=class{type="Ed25519";raw;publicKey;constructor(t,e){this.raw=Tr(t,Dt),this.publicKey=new mn(e)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:vt(this.raw,t.raw)}sign(t){return pa(this.raw,t)}};function vo(r){if(r.length>Dt){r=Tr(r,Dt+or);let n=r.subarray(0,Dt),s=r.subarray(Dt,r.length);return new Ur(n,s)}r=Tr(r,Dt);let t=r.subarray(0,Dt),e=r.subarray(or);return new Ur(t,e)}function Tr(r,t){if(r=Uint8Array.from(r??[]),r.length!==t)throw new R(`Key must be a Uint8Array of length ${t}, got ${r.length}`);return r}var Ff=Math.pow(2,7),qf=Math.pow(2,14),jf=Math.pow(2,21),ma=Math.pow(2,28),ba=Math.pow(2,35),wa=Math.pow(2,42),xa=Math.pow(2,49),mt=128,ye=127;function Lr(r){if(r<Ff)return 1;if(r<qf)return 2;if(r<jf)return 3;if(r<ma)return 4;if(r<ba)return 5;if(r<wa)return 6;if(r<xa)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function va(r,t,e=0){switch(Lr(r)){case 8:t[e++]=r&255|mt,r/=128;case 7:t[e++]=r&255|mt,r/=128;case 6:t[e++]=r&255|mt,r/=128;case 5:t[e++]=r&255|mt,r/=128;case 4:t[e++]=r&255|mt,r>>>=7;case 3:t[e++]=r&255|mt,r>>>=7;case 2:t[e++]=r&255|mt,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function Ea(r,t){let e=r[t],n=0;if(n+=e&ye,e<mt||(e=r[t+1],n+=(e&ye)<<7,e<mt)||(e=r[t+2],n+=(e&ye)<<14,e<mt)||(e=r[t+3],n+=(e&ye)<<21,e<mt)||(e=r[t+4],n+=(e&ye)*ma,e<mt)||(e=r[t+5],n+=(e&ye)*ba,e<mt)||(e=r[t+6],n+=(e&ye)*wa,e<mt)||(e=r[t+7],n+=(e&ye)*xa,e<mt))return n;throw new RangeError("Could not decode varint")}var Eo=new Float32Array([-0]),me=new Uint8Array(Eo.buffer);function Ba(r,t,e){Eo[0]=r,t[e]=me[0],t[e+1]=me[1],t[e+2]=me[2],t[e+3]=me[3]}function Aa(r,t){return me[0]=r[t],me[1]=r[t+1],me[2]=r[t+2],me[3]=r[t+3],Eo[0]}var Bo=new Float64Array([-0]),ft=new Uint8Array(Bo.buffer);function Sa(r,t,e){Bo[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 ka(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],Bo[0]}var $f=BigInt(Number.MAX_SAFE_INTEGER),Gf=BigInt(Number.MIN_SAFE_INTEGER),Ct=class r{lo;hi;constructor(t,e){this.lo=t|0,this.hi=e|0}toNumber(t=!1){if(!t&&this.hi>>>31>0){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(e+n*4294967296)}return this.lo+this.hi*4294967296}toBigInt(t=!1){if(t)return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n);if(this.hi>>>31){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(BigInt(e)+(BigInt(n)<<32n))}return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n)}toString(t=!1){return this.toBigInt(t).toString()}zzEncode(){let t=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^t)>>>0,this.lo=(this.lo<<1^t)>>>0,this}zzDecode(){let t=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^t)>>>0,this.hi=(this.hi>>>1^t)>>>0,this}length(){let t=this.lo,e=(this.lo>>>28|this.hi<<4)>>>0,n=this.hi>>>24;return n===0?e===0?t<16384?t<128?1:2:t<2097152?3:4:e<16384?e<128?5:6:e<2097152?7:8:n<128?9:10}static fromBigInt(t){if(t===0n)return Le;if(t<$f&&t>Gf)return this.fromNumber(Number(t));let e=t<0n;e&&(t=-t);let n=t>>32n,s=t-(n<<32n);return e&&(n=~n|0n,s=~s|0n,++s>Ca&&(s=0n,++n>Ca&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(t){if(t===0)return Le;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):Le}},Le=new Ct(0,0);Le.toBigInt=function(){return 0n};Le.zzEncode=Le.zzDecode=function(){return this};Le.length=function(){return 1};var Ca=4294967296n;function Ia(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 Na(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 Ao(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 bn(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var So=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 bn(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Kt(this,4);return bn(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Kt(this,4);let t=Aa(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Kt(this,4);let t=ka(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 Na(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw Kt(this,t);this.pos+=t}else do if(this.pos>=this.len)throw Kt(this);while((this.buf[this.pos++]&128)!==0);return this}skipType(t){switch(t){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;(t=this.uint32()&7)!==4;)this.skipType(t);break;case 5:this.skip(4);break;default:throw Error(`invalid wire type ${t} at offset ${this.pos}`)}return this}readLongVarint(){let t=new Ct(0,0),e=0;if(this.len-this.pos>4){for(;e<4;++e)if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t;if(t.lo=(t.lo|(this.buf[this.pos]&127)<<28)>>>0,t.hi=(t.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return t;e=0}else{for(;e<3;++e){if(this.pos>=this.len)throw Kt(this);if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t}return t.lo=(t.lo|(this.buf[this.pos++]&127)<<e*7)>>>0,t}if(this.len-this.pos>4){for(;e<5;++e)if(t.hi=(t.hi|(this.buf[this.pos]&127)<<e*7+3)>>>0,this.buf[this.pos++]<128)return t}else for(;e<5;++e){if(this.pos>=this.len)throw Kt(this);if(t.hi=(t.hi|(this.buf[this.pos]&127)<<e*7+3)>>>0,this.buf[this.pos++]<128)return t}throw Error("invalid varint encoding")}readFixed64(){if(this.pos+8>this.len)throw Kt(this,8);let t=bn(this.buf,this.pos+=4),e=bn(this.buf,this.pos+=4);return new Ct(t,e)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){let t=Ea(this.buf,this.pos);return this.pos+=Lr(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 ko(r){return new So(r instanceof Uint8Array?r:r.subarray())}function wn(r,t,e){let n=ko(r);return t.decode(n,void 0,e)}function Co(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 Re=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function Io(){}var Uo=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},zf=Co();function Wf(r){return globalThis.Buffer!=null?St(r):zf(r)}var _r=class{len;head;tail;states;constructor(){this.len=0,this.head=new Re(Io,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new Re(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new To((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(xn,10,Ct.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=Ct.fromBigInt(t);return this._push(xn,e.length(),e)}uint64Number(t){return this._push(va,Lr(t),t)}uint64String(t){return this.uint64(BigInt(t))}int64(t){return this.uint64(t)}int64Number(t){return this.uint64Number(t)}int64String(t){return this.uint64String(t)}sint64(t){let e=Ct.fromBigInt(t).zzEncode();return this._push(xn,e.length(),e)}sint64Number(t){let e=Ct.fromNumber(t).zzEncode();return this._push(xn,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(No,1,t?1:0)}fixed32(t){return this._push(Rr,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=Ct.fromBigInt(t);return this._push(Rr,4,e.lo)._push(Rr,4,e.hi)}fixed64Number(t){let e=Ct.fromNumber(t);return this._push(Rr,4,e.lo)._push(Rr,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(Ba,4,t)}double(t){return this._push(Sa,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(No,1,0):this.uint32(e)._push(Jf,e,t)}string(t){let e=Ia(t);return e!==0?this.uint32(e)._push(Ao,e,t):this._push(No,1,0)}fork(){return this.states=new Uo(this),this.head=this.tail=new Re(Io,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 Re(Io,0,0),this.len=0),this}ldelim(){let t=this.head,e=this.tail,n=this.len;return this.reset().uint32(n),n!==0&&(this.tail.next=t.next,this.tail=e,this.len+=n),this}finish(){let t=this.head.next,e=Wf(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function No(r,t,e){t[e]=r&255}function Zf(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var To=class extends Re{next;constructor(t,e){super(Zf,t,e),this.next=void 0}};function xn(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 Rr(r,t,e){t[e]=r&255,t[e+1]=r>>>8&255,t[e+2]=r>>>16&255,t[e+3]=r>>>24}function Jf(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(_r.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(Yf,t,r),this},_r.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(Xf,t,r),this});function Yf(r,t,e){t.set(r,e)}function Xf(r,t,e){r.length<40?Ao(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(H(r),e)}function Lo(){return new _r}function vn(r,t){let e=Lo();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var ir;(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"})(ir||(ir={}));function En(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function Ro(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 En("enum",ir.VARINT,e,n)}function Bn(r,t){return En("message",ir.LENGTH_DELIMITED,r,t)}var st;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.secp256k1="secp256k1",r.ECDSA="ECDSA"})(st||(st={}));var _o;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1",r[r.ECDSA=3]="ECDSA"})(_o||(_o={}));(function(r){r.codec=()=>Ro(_o)})(st||(st={}));var be;(function(r){let t;r.codec=()=>(t==null&&(t=Bn((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),st.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=st.codec().decode(e);break}case 2:{o.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return o})),t),r.encode=e=>vn(e,r.codec()),r.decode=(e,n)=>wn(e,r.codec(),n)})(be||(be={}));var Dr;(function(r){let t;r.codec=()=>(t==null&&(t=Bn((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),st.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=st.codec().decode(e);break}case 2:{o.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return o})),t),r.encode=e=>vn(e,r.codec()),r.decode=(e,n)=>wn(e,r.codec(),n)})(Dr||(Dr={}));function _e(r){if(isNaN(r)||r<=0)throw new R("random bytes length must be a Number bigger than 0");return rr(r)}var Or={};dt(Or,{MAX_RSA_KEY_SIZE:()=>Do,generateRSAKeyPair:()=>Da,jwkToJWKKeyPair:()=>Ka,jwkToPkcs1:()=>rh,jwkToPkix:()=>Ho,jwkToRSAPrivateKey:()=>Fo,pkcs1MessageToJwk:()=>Oo,pkcs1MessageToRSAPrivateKey:()=>An,pkcs1ToJwk:()=>eh,pkcs1ToRSAPrivateKey:()=>Po,pkixMessageToJwk:()=>Vo,pkixMessageToRSAPublicKey:()=>Mo,pkixToJwk:()=>nh,pkixToRSAPublicKey:()=>_a});var ar=class{type="RSA";jwk;_raw;_multihash;constructor(t,e){this.jwk=t,this._multihash=e}get raw(){return this._raw==null&&(this._raw=Or.jwkToPkix(this.jwk)),this._raw}toMultihash(){return this._multihash}toCID(){return It.createV1(114,this._multihash)}toString(){return et.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:vt(this.raw,t.raw)}verify(t,e){return Ra(this.jwk,e,t)}},Kr=class{type="RSA";jwk;_raw;publicKey;constructor(t,e){this.jwk=t,this.publicKey=e}get raw(){return this._raw==null&&(this._raw=Or.jwkToPkcs1(this.jwk)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:vt(this.raw,t.raw)}sign(t){return La(this.jwk,t)}};var Do=8192,Ko=18,Qf=1062,th=Uint8Array.from([48,13,6,9,42,134,72,134,247,13,1,1,1,5,0]);function eh(r){let t=Lt(r);return Oo(t)}function Oo(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 rh(r){if(r.n==null||r.e==null||r.d==null||r.p==null||r.q==null||r.dp==null||r.dq==null||r.qi==null)throw new R("JWK was missing components");return Rt([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 nh(r){let t=Lt(r,{offset:0});return Vo(t)}function Vo(r){let t=Lt(r[1],{offset:0});return{kty:"RSA",n:j(t[0],"base64url"),e:j(t[1],"base64url")}}function Ho(r){if(r.n==null||r.e==null)throw new R("JWK was missing components");return Rt([th,kr(Rt([gt(H(r.n,"base64url")),gt(H(r.e,"base64url"))]))]).subarray()}function Po(r){let t=Lt(r);return An(t)}function An(r){let t=Oo(r);return Fo(t)}function _a(r,t){if(r.byteLength>=Qf)throw new Pe("Key size is too large");let e=Lt(r,{offset:0});return Mo(e,r,t)}function Mo(r,t,e){let n=Vo(r);if(e==null){let s=$t(be.encode({Type:st.RSA,Data:t}));e=Tt(Ko,s)}return new ar(n,e)}function Fo(r){if(Va(r)>Do)throw new R("Key size is too large");let t=Ka(r),e=$t(be.encode({Type:st.RSA,Data:Ho(t.publicKey)})),n=Tt(Ko,e);return new Kr(t.privateKey,new ar(t.publicKey,n))}async function Da(r){if(r>Do)throw new R("Key size is too large");let t=await Oa(r),e=$t(be.encode({Type:st.RSA,Data:Ho(t.publicKey)})),n=Tt(Ko,e);return new Kr(t.privateKey,new ar(t.publicKey,n))}function Ka(r){if(r==null)throw new R("Missing key parameter");return{privateKey:r,publicKey:{kty:r.kty,n:r.n,e:r.e}}}async function Oa(r){let t=await xt.get().subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:r,publicExponent:new Uint8Array([1,0,1]),hash:{name:"SHA-256"}},!0,["sign","verify"]),e=await sh(t);return{privateKey:e[0],publicKey:e[1]}}async function La(r,t){let e=await xt.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await xt.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},e,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(n,0,n.byteLength)}async function Ra(r,t,e){let n=await xt.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return xt.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,t,e instanceof Uint8Array?e:e.subarray())}async function sh(r){if(r.privateKey==null||r.publicKey==null)throw new R("Private and public key are required");return Promise.all([xt.get().subtle.exportKey("jwk",r.privateKey),xt.get().subtle.exportKey("jwk",r.publicKey)])}function Va(r){if(r.kty!=="RSA")throw new R("invalid key type");if(r.n==null)throw new R("invalid key modulus");return H(r.n,"base64url").length*8}var Sn=class extends tr{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,cn(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 Qe(this),this.iHash.update(t),this}digestInto(t){Qe(this),Xe(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()}},Vr=(r,t,e)=>new Sn(r,t).update(e).digest();Vr.create=(r,t)=>new Sn(r,t);function Ha(r){r.lowS!==void 0&&Ht("lowS",r.lowS),r.prehash!==void 0&&Ht("prehash",r.prehash)}function oh(r){let t=Nr(r);Zt(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 qo=class extends Error{constructor(t=""){super(t)}},Jt={Err:qo,_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=Cr(n);if(s.length/2&128)throw new e("tlv.encode: long form length too big");let o=n>127?Cr(s.length/2|128):"";return Cr(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=Cr(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 Wt(r)}},toSig(r){let{Err:t,_int:e,_tlv:n}=Jt,s=Y("signature",r),{v:o,l:i}=n.decode(48,s);if(i.length)throw new t("invalid signature: left bytes after parsing");let{v:a,l:c}=n.decode(2,o),{v:f,l}=n.decode(2,c);if(l.length)throw new t("invalid signature: left bytes after parsing");return{r:e.decode(a),s:e.decode(f)}},hexFromSig(r){let{_tlv:t,_int:e}=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),it=BigInt(1),uy=BigInt(2),Pa=BigInt(3),fy=BigInt(4);function ih(r){let t=oh(r),{Fp:e}=t,n=ge(t.n,t.nBitLength),s=t.toBytes||((y,d,b)=>{let E=d.toAffine();return pe(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 dn(y,it,t.n)}function c(y){let{allowedPrivateKeyLengths:d,nByteLength:b,wrapPrivateKey:E,n:p}=t;if(d&&typeof y!="bigint"){if(Ce(y)&&(y=de(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:Wt(Y("private key",y,b))}catch{throw new Error("invalid private key, expected hex or "+b+" bytes, got "+typeof y)}return E&&(S=z(S,p)),kt("private key",S,it,p),S}function f(y){if(!(y instanceof h))throw new Error("ProjectivePoint expected")}let l=sr((y,d)=>{let{px:b,py:E,pz:p}=y;if(e.eql(p,e.ONE))return{x:b,y:E};let S=y.is0();d==null&&(d=S?e.ONE:e.inv(p));let _=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:_,y:L}}),u=sr(y=>{if(y.is0()){if(t.allowInfinityPoint&&!e.is0(y.py))return;throw new Error("bad point: ZERO")}let{x:d,y:b}=y.toAffine();if(!e.isValid(d)||!e.isValid(b))throw new Error("bad point: x or y not FE");let E=e.sqr(b),p=i(d);if(!e.eql(E,p))throw new Error("bad point: equation left != right");if(!y.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});class h{constructor(d,b,E){if(d==null||!e.isValid(d))throw new Error("x required");if(b==null||!e.isValid(b))throw new Error("y required");if(E==null||!e.isValid(E))throw new Error("z required");this.px=d,this.py=b,this.pz=E,Object.freeze(this)}static fromAffine(d){let{x:b,y:E}=d||{};if(!d||!e.isValid(b)||!e.isValid(E))throw new Error("invalid affine point");if(d instanceof h)throw new Error("projective point not allowed");let p=S=>e.eql(S,e.ZERO);return p(b)&&p(E)?h.ZERO:new h(b,E,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(d){let b=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 yn(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:_,pz:L}=d,I=e.eql(e.mul(b,L),e.mul(S,p)),N=e.eql(e.mul(E,L),e.mul(_,p));return I&&N}negate(){return new h(this.px,e.neg(this.py),this.pz)}double(){let{a:d,b}=t,E=e.mul(b,Pa),{px:p,py:S,pz:_}=this,L=e.ZERO,I=e.ZERO,N=e.ZERO,U=e.mul(p,p),W=e.mul(S,S),$=e.mul(_,_),V=e.mul(p,S);return V=e.add(V,V),N=e.mul(p,_),N=e.add(N,N),L=e.mul(d,N),I=e.mul(E,$),I=e.add(L,I),L=e.sub(W,I),I=e.add(W,I),I=e.mul(L,I),L=e.mul(V,L),N=e.mul(E,N),$=e.mul(d,$),V=e.sub(U,$),V=e.mul(d,V),V=e.add(V,N),N=e.add(U,U),U=e.add(N,U),U=e.add(U,$),U=e.mul(U,V),I=e.add(I,U),$=e.mul(S,_),$=e.add($,$),U=e.mul($,V),L=e.sub(L,U),N=e.mul($,W),N=e.add(N,N),N=e.add(N,N),new h(L,I,N)}add(d){f(d);let{px:b,py:E,pz:p}=this,{px:S,py:_,pz:L}=d,I=e.ZERO,N=e.ZERO,U=e.ZERO,W=t.a,$=e.mul(t.b,Pa),V=e.mul(b,S),rt=e.mul(E,_),B=e.mul(p,L),C=e.add(b,E),T=e.add(S,_);C=e.mul(C,T),T=e.add(V,rt),C=e.sub(C,T),T=e.add(b,p);let x=e.add(S,L);return T=e.mul(T,x),x=e.add(V,B),T=e.sub(T,x),x=e.add(E,p),I=e.add(_,L),x=e.mul(x,I),I=e.add(rt,B),x=e.sub(x,I),U=e.mul(W,T),I=e.mul($,B),U=e.add(I,U),I=e.sub(rt,U),U=e.add(rt,U),N=e.mul(I,U),rt=e.add(V,V),rt=e.add(rt,V),B=e.mul(W,B),T=e.mul($,T),rt=e.add(rt,B),B=e.sub(V,B),B=e.mul(W,B),T=e.add(T,B),V=e.mul(rt,T),N=e.add(N,V),V=e.mul(x,T),I=e.mul(C,I),I=e.sub(I,V),V=e.mul(C,rt),U=e.mul(x,U),U=e.add(U,V),new h(I,N,U)}subtract(d){return this.add(d.negate())}is0(){return this.equals(h.ZERO)}wNAF(d){return w.wNAFCached(this,d,h.normalizeZ)}multiplyUnsafe(d){let{endo:b,n:E}=t;kt("scalar",d,Yt,E);let p=h.ZERO;if(d===Yt)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:_,k2neg:L,k2:I}=b.splitScalar(d),N=p,U=p,W=this;for(;_>Yt||I>Yt;)_&it&&(N=N.add(W)),I&it&&(U=U.add(W)),W=W.double(),_>>=it,I>>=it;return S&&(N=N.negate()),L&&(U=U.negate()),U=new h(e.mul(U.px,b.beta),U.py,U.pz),N.add(U)}multiply(d){let{endo:b,n:E}=t;kt("scalar",d,it,E);let p,S;if(b){let{k1neg:_,k1:L,k2neg:I,k2:N}=b.splitScalar(d),{p:U,f:W}=this.wNAF(L),{p:$,f:V}=this.wNAF(N);U=w.constTimeNegate(_,U),$=w.constTimeNegate(I,$),$=new h(e.mul($.px,b.beta),$.py,$.pz),p=U.add($),S=W.add(V)}else{let{p:_,f:L}=this.wNAF(d);p=_,S=L}return h.normalizeZ([p,S])[0]}multiplyAndAddUnsafe(d,b,E){let p=h.BASE,S=(L,I)=>I===Yt||I===it||!L.equals(p)?L.multiplyUnsafe(I):L.multiply(I),_=S(this,b).add(S(d,E));return _.is0()?void 0:_}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 Ht("isCompressed",d),this.assertValidity(),s(h,this,d)}toHex(d=!0){return Ht("isCompressed",d),de(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=gn(h,t.endo?Math.ceil(m/2):m);return{CURVE:t,ProjectivePoint:h,normPrivateKeyToScalar:c,weierstrassEquation:i,isWithinCurveOrder:a}}function ah(r){let t=Nr(r);return Zt(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function Ma(r){let t=ah(r),{Fp:e,n}=t,s=e.BYTES+1,o=2*e.BYTES+1;function i(B){return z(B,n)}function a(B){return pn(B,n)}let{ProjectivePoint:c,normPrivateKeyToScalar:f,weierstrassEquation:l,isWithinCurveOrder:u}=ih({...t,toBytes(B,C,T){let x=C.toAffine(),g=e.toBytes(x.x),v=pe;return Ht("isCompressed",T),T?v(Uint8Array.from([C.hasEvenY()?2:3]),g):v(Uint8Array.from([4]),g,e.toBytes(x.y))},fromBytes(B){let C=B.length,T=B[0],x=B.subarray(1);if(C===s&&(T===2||T===3)){let g=Wt(x);if(!dn(g,it,e.ORDER))throw new Error("Point is not on curve");let v=l(g),k;try{k=e.sqrt(v)}catch(P){let F=P instanceof Error?": "+P.message:"";throw new Error("Point is not on curve"+F)}let D=(k&it)===it;return(T&1)===1!==D&&(k=e.neg(k)),{x:g,y:k}}else if(C===o&&T===4){let g=e.fromBytes(x.subarray(0,e.BYTES)),v=e.fromBytes(x.subarray(e.BYTES,2*e.BYTES));return{x:g,y:v}}else{let g=s,v=o;throw new Error("invalid Point, expected length of "+g+", or uncompressed "+v+", got "+C)}}}),h=B=>de(Ne(B,t.nByteLength));function m(B){let C=n>>it;return B>C}function w(B){return m(B)?i(-B):B}let y=(B,C,T)=>Wt(B.slice(C,T));class d{constructor(C,T,x){kt("r",C,it,n),kt("s",T,it,n),this.r=C,this.s=T,x!=null&&(this.recovery=x),Object.freeze(this)}static fromCompact(C){let T=t.nByteLength;return C=Y("compactSignature",C,T*2),new d(y(C,0,T),y(C,T,2*T))}static fromDER(C){let{r:T,s:x}=Jt.toSig(Y("DER",C));return new d(T,x)}assertValidity(){}addRecoveryBit(C){return new d(this.r,this.s,C)}recoverPublicKey(C){let{r:T,s:x,recovery:g}=this,v=L(Y("msgHash",C));if(g==null||![0,1,2,3].includes(g))throw new Error("recovery id invalid");let k=g===2||g===3?T+t.n:T;if(k>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let D=(g&1)===0?"02":"03",O=c.fromHex(D+h(k)),P=a(k),F=i(-v*P),q=i(x*P),G=c.BASE.multiplyAndAddUnsafe(O,F,q);if(!G)throw new Error("point at infinify");return G.assertValidity(),G}hasHighS(){return m(this.s)}normalizeS(){return this.hasHighS()?new d(this.r,i(-this.s),this.recovery):this}toDERRawBytes(){return Ir(this.toDERHex())}toDERHex(){return Jt.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return Ir(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=ho(t.n);return sa(t.randomBytes(B),t.n)},precompute(B=8,C=c.BASE){return C._setWindowSize(B),C.multiply(BigInt(3)),C}};function E(B,C=!0){return c.fromPrivateKey(B).toRawBytes(C)}function p(B){let C=Ce(B),T=typeof B=="string",x=(C||T)&&B.length;return C?x===s||x===o:T?x===2*s||x===2*o:B instanceof c}function S(B,C,T=!0){if(p(B))throw new Error("first arg must be private key");if(!p(C))throw new Error("second arg must be public key");return c.fromHex(C).multiply(f(B)).toRawBytes(T)}let _=t.bits2int||function(B){if(B.length>8192)throw new Error("input is too large");let C=Wt(B),T=B.length*8-t.nBitLength;return T>0?C>>BigInt(T):C},L=t.bits2int_modN||function(B){return i(_(B))},I=Ue(t.nBitLength);function N(B){return kt("num < 2^"+t.nBitLength,B,Yt,I),Ne(B,t.nByteLength)}function U(B,C,T=W){if(["recovered","canonical"].some(Q=>Q in T))throw new Error("sign() legacy options not supported");let{hash:x,randomBytes:g}=t,{lowS:v,prehash:k,extraEntropy:D}=T;v==null&&(v=!0),B=Y("msgHash",B),Ha(T),k&&(B=Y("prehashed msgHash",x(B)));let O=L(B),P=f(C),F=[N(P),N(O)];if(D!=null&&D!==!1){let Q=D===!0?g(e.BYTES):D;F.push(Y("extraEntropy",Q))}let q=pe(...F),G=O;function tt(Q){let at=_(Q);if(!u(at))return;let wt=a(at),ot=c.BASE.multiply(at).toAffine(),ut=i(ot.x);if(ut===Yt)return;let At=i(wt*i(G+ut*P));if(At===Yt)return;let Ut=(ot.x===ut?0:2)|Number(ot.y&it),gr=At;return v&&m(At)&&(gr=w(At),Ut^=1),new d(ut,gr,Ut)}return{seed:q,k2sig:tt}}let W={lowS:t.lowS,prehash:!1},$={lowS:t.lowS,prehash:!1};function V(B,C,T=W){let{seed:x,k2sig:g}=U(B,C,T),v=t;return Qi(v.hash.outputLen,v.nByteLength,v.hmac)(x,g)}c.BASE._setWindowSize(8);function rt(B,C,T,x=$){let g=B;C=Y("msgHash",C),T=Y("publicKey",T);let{lowS:v,prehash:k,format:D}=x;if(Ha(x),"strict"in x)throw new Error("options.strict was renamed to lowS");if(D!==void 0&&D!=="compact"&&D!=="der")throw new Error("format must be compact or der");let O=typeof g=="string"||Ce(g),P=!O&&!D&&typeof g=="object"&&g!==null&&typeof g.r=="bigint"&&typeof g.s=="bigint";if(!O&&!P)throw new Error("invalid signature, expected Uint8Array, hex string or Signature instance");let F,q;try{if(P&&(F=new d(g.r,g.s)),O){try{D!=="compact"&&(F=d.fromDER(g))}catch(Ut){if(!(Ut instanceof Jt.Err))throw Ut}!F&&D!=="der"&&(F=d.fromCompact(g))}q=c.fromHex(T)}catch{return!1}if(!F||v&&F.hasHighS())return!1;k&&(C=t.hash(C));let{r:G,s:tt}=F,Q=L(C),at=a(tt),wt=i(Q*at),ot=i(G*at),ut=c.BASE.multiplyAndAddUnsafe(q,wt,ot)?.toAffine();return ut?i(ut.x)===G:!1}return{CURVE:t,getPublicKey:E,getSharedSecret:S,sign:V,verify:rt,ProjectivePoint:c,Signature:d,utils:b}}function ch(r){return{hash:r,hmac:(t,...e)=>Vr(r,t,to(...e)),randomBytes:rr}}function Fa(r,t){let e=n=>Ma({...r,...ch(n)});return{...e(t),create:e}}var $a=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),qa=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),lh=BigInt(1),jo=BigInt(2),ja=(r,t)=>(r+t/jo)/t;function uh(r){let t=$a,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,jo,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,_=J(S,n,t)*f%t,L=J(_,jo,t);if(!$o.eql($o.sqr(L),r))throw new Error("Cannot find square root");return L}var $o=ge($a,void 0,void 0,{sqrt:uh}),Ot=Fa({a:BigInt(0),b:BigInt(7),Fp:$o,n:qa,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=qa,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-lh*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),s=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),o=e,i=BigInt("0x100000000000000000000000000000000"),a=ja(o*r,t),c=ja(-n*r,t),f=z(r-a*e-c*s,t),l=z(-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}}}},$t),xy=BigInt(0);var vy=Ot.ProjectivePoint;function Go(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}var Ga=32;function za(r,t){let e=We.digest(t instanceof Uint8Array?t:t.subarray());if(Go(e))return e.then(({digest:n})=>Ot.sign(n,r).toDERRawBytes()).catch(n=>{throw new yr(String(n))});try{return Ot.sign(e.digest,r).toDERRawBytes()}catch(n){throw new yr(String(n))}}function Wa(r,t,e){let n=We.digest(e instanceof Uint8Array?e:e.subarray());if(Go(n))return n.then(({digest:s})=>Ot.verify(t,s,r)).catch(s=>{throw new mr(String(s))});try{return Ot.verify(t,n.digest,r)}catch(s){throw new mr(String(s))}}var kn=class{type="secp256k1";raw;_key;constructor(t){this._key=Ya(t),this.raw=Za(this._key)}toMultihash(){return Be.digest(Je(this))}toCID(){return It.createV1(114,this.toMultihash())}toString(){return et.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:vt(this.raw,t.raw)}verify(t,e){return Wa(this._key,e,t)}},Cn=class{type="secp256k1";raw;publicKey;constructor(t,e){this.raw=Ja(t),this.publicKey=new kn(e??Xa(t))}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:vt(this.raw,t.raw)}sign(t){return za(this.raw,t)}};function zo(r){return new Cn(r)}function Za(r){return Ot.ProjectivePoint.fromHex(r).toRawBytes(!0)}function Ja(r){try{return Ot.getPublicKey(r,!0),r}catch(t){throw new br(String(t))}}function Ya(r){try{return Ot.ProjectivePoint.fromHex(r),r}catch(t){throw new Pe(String(t))}}function Xa(r){try{return Ot.getPublicKey(r,!0)}catch(t){throw new br(String(t))}}function Je(r){return be.encode({Type:st[r.type],Data:r.raw})}function Qa(r){let t=Dr.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case st.RSA:return Po(e);case st.Ed25519:return vo(e);case st.secp256k1:return zo(e);case st.ECDSA:return Hi(e);default:throw new Me}}function tc(r){if(r.byteLength===Dt)return vo(r);if(r.byteLength===Ga)return zo(r);let t=Lt(r),e=t[2]?.[0];if(e===_i||e===Di||e===Ki)return Qs(t);if(t.length>8)return An(t);throw new R("Could not extract private key from raw bytes")}function De(r){return Dr.encode({Type:st[r.type],Data:r.raw})}function ec(r,t,e,n){cn(r);let s=Gi({dkLen:32,asyncTick:10},n),{c:o,dkLen:i,asyncTick:a}=s;if(Ye(o),Ye(i),Ye(a),o<1)throw new Error("PBKDF2: iterations (c) should be >= 1");let c=ae(t),f=ae(e),l=new Uint8Array(i),u=Vr.create(r,c),h=u._cloneInto().update(f);return{c:o,dkLen:i,asyncTick:a,DK:l,PRF:u,PRFSalt:h}}function rc(r,t,e,n,s){return r.destroy(),t.destroy(),n&&n.destroy(),s.fill(0),e}function nc(r,t,e,n){let{c:s,dkLen:o,DK:i,PRF:a,PRFSalt:c}=ec(r,t,e,n),f,l=new Uint8Array(4),u=ke(l),h=new Uint8Array(a.outputLen);for(let m=1,w=0;w<o;m++,w+=a.outputLen){let y=i.subarray(w,w+a.outputLen);u.setInt32(0,m,!1),(f=c._cloneInto(f)).update(l).digestInto(h),y.set(h.subarray(0,y.length));for(let d=1;d<s;d++){a._cloneInto(f).update(h).digestInto(h);for(let b=0;b<y.length;b++)y[b]^=h[b]}}return rc(a,c,i,f,h)}async function In(r,t,e,n){let{c:s,dkLen:o,asyncTick:i,DK:a,PRF:c,PRFSalt:f}=ec(r,t,e,n),l,u=new Uint8Array(4),h=ke(u),m=new Uint8Array(c.outputLen);for(let w=1,y=0;y<o;w++,y+=c.outputLen){let d=a.subarray(y,y+c.outputLen);h.setInt32(0,w,!1),(l=f._cloneInto(l)).update(u).digestInto(m),d.set(m.subarray(0,d.length)),await ji(s-1,i,()=>{c._cloneInto(l).update(m).digestInto(m);for(let b=0;b<d.length;b++)d[b]^=m[b]})}return rc(c,f,a,l,m)}var Hr=new Uint32Array([1732584193,4023233417,2562383102,271733878,3285377520]),we=new Uint32Array(80),Nn=class extends ce{constructor(){super(64,20,8,!1),this.A=Hr[0]|0,this.B=Hr[1]|0,this.C=Hr[2]|0,this.D=Hr[3]|0,this.E=Hr[4]|0}get(){let{A:t,B:e,C:n,D:s,E:o}=this;return[t,e,n,s,o]}set(t,e,n,s,o){this.A=t|0,this.B=e|0,this.C=n|0,this.D=s|0,this.E=o|0}process(t,e){for(let c=0;c<16;c++,e+=4)we[c]=t.getUint32(e,!1);for(let c=16;c<80;c++)we[c]=ln(we[c-3]^we[c-8]^we[c-14]^we[c-16],1);let{A:n,B:s,C:o,D:i,E:a}=this;for(let c=0;c<80;c++){let f,l;c<20?(f=un(s,o,i),l=1518500249):c<40?(f=s^o^i,l=1859775393):c<60?(f=fn(s,o,i),l=2400959708):(f=s^o^i,l=3395469782);let u=ln(n,5)+f+a+l+we[c]|0;a=i,i=o,o=ln(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(){we.fill(0)}destroy(){this.set(0,0,0,0,0),this.buffer.fill(0)}},Wo=er(()=>new Nn),gm=2**32;var sc={sha1:Wo,"sha2-256":$t,"sha2-512":Gt};function Pr(r,t,e,n,s){if(s!=="sha1"&&s!=="sha2-256"&&s!=="sha2-512"){let a=Object.keys(sc).join(" / ");throw new R(`Hash '${s}' is unknown or not supported. Must be ${a}`)}let o=sc[s],i=nc(o,r,t,{c:e,dkLen:n});return Ae.encode(i).substring(1)}var Xt="/",oc=new TextEncoder().encode(Xt),Un=oc[0],Mr=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]!==Un)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=oc),this._buf[0]!==Un){let t=new Uint8Array(this._buf.byteLength+1);t.fill(Un,0,1),t.set(this._buf,1),this._buf=t}for(;this._buf.byteLength>1&&this._buf[this._buf.byteLength-1]===Un;)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 fh(this.baseNamespace())}name(){return hh(this.baseNamespace())}instance(t){return new r(this.toString()+":"+t)}path(){let t=this.parent().toString();return t.endsWith(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(),...dh(t.map(e=>e.namespaces()))])}};function fh(r){let t=r.split(":");return t.length<2?"":t.slice(0,-1).join(":")}function hh(r){let t=r.split(":");return t[t.length-1]}function dh(r){return[].concat(...r)}var pc=ks(dc(),1),gc=pc.default;var pl=ks(Ac(),1);var ur={};dt(ur,{create:()=>Th,derivedEmptyPasswordKey:()=>Rn});var Rn={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function Th(r){let t=r?.algorithm??"AES-GCM",e=r?.keyLength??16,n=r?.nonceLength??12,s=r?.digest??"SHA-256",o=r?.saltLength??16,i=r?.iterations??32767,a=xt.get();e*=8;async function c(u,h){let m=a.getRandomValues(new Uint8Array(o)),w=a.getRandomValues(new Uint8Array(n)),y={name:t,iv:w};typeof h=="string"&&(h=H(h));let d;if(h.length===0){d=await a.subtle.importKey("jwk",Rn,{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",Rn,{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 ze([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=H(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",Rn,{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=ks(Sc());function Ke(r,t){let e=0;if(r.length===1)return r[0];for(let n=r.length-1;n>=0;n--)e+=r[r.length-1-n]*Math.pow(2,t*n);return e}function xe(r,t,e=-1){let n=e,s=r,o=0,i=Math.pow(2,t);for(let a=1;a<8;a++){if(r<i){let c;if(n<0)c=new ArrayBuffer(a),o=a;else{if(n<a)return new ArrayBuffer(0);c=new ArrayBuffer(n),o=n}let f=new Uint8Array(c);for(let l=a-1;l>=0;l--){let u=Math.pow(2,l*t);f[o-l-1]=Math.floor(s/u),s-=f[o-l-1]*u}return c}i*=Math.pow(2,t)}return new ArrayBuffer(0)}function Kn(...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 Yo(){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=Ke(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,Ke(o,8)-n}function kc(r){let t=r<0?r*-1:r,e=128;for(let n=1;n<8;n++){if(t<=e){if(r<0){let i=e-t,a=xe(i,8,n),c=new Uint8Array(a);return c[0]|=128,a}let s=xe(t,8,n),o=new Uint8Array(s);if(o[0]&128){let i=s.slice(0),a=new Uint8Array(i);s=new ArrayBuffer(s.byteLength+1),o=new Uint8Array(s);for(let c=0;c<i.byteLength;c++)o[c+1]=a[c];o[0]=0}return s}e*=Math.pow(2,8)}return new ArrayBuffer(0)}function Cc(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 qm=Math.log(2);function On(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function Xo(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 jr=class{constructor(){this.items=[]}write(t){this.items.push(t)}final(){return Xo(this.items)}},Fr=[new Uint8Array([1])],Ic="0123456789";var hr="",Vt=new ArrayBuffer(0),Qo=new Uint8Array(0),$r="EndOfContent",Uc="OCTET STRING",Tc="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):Qo}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=hr,warnings:n=[],valueBeforeDecode:s=Qo}={}){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 Vn=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):Qo,this.tagClass=(n=t.tagClass)!==null&&n!==void 0?n:-1,this.tagNumber=(s=t.tagNumber)!==null&&s!==void 0?s:-1,this.isConstructed=(o=t.isConstructed)!==null&&o!==void 0?o:!1):(this.tagClass=-1,this.tagNumber=-1,this.isConstructed=!1)}toBER(t=!1){let e=0;switch(this.tagClass){case 1:e|=0;break;case 2:e|=64;break;case 3:e|=128;break;case 4:e|=192;break;default:return this.error="Unknown tag class",Vt}if(this.isConstructed&&(e|=32),this.tagNumber<31&&!this.isHexOnly){let s=new Uint8Array(1);if(!t){let o=this.tagNumber;o&=31,e|=o,s[0]=e}return s.buffer}if(!this.isHexOnly){let s=xe(this.tagNumber,7),o=new Uint8Array(s),i=s.byteLength,a=new Uint8Array(i+1);if(a[0]=e|31,!t){for(let c=0;c<i-1;c++)a[c+1]=o[c]|128;a[i]=o[i-1]}return a.buffer}let n=new Uint8Array(this.valueHexView.byteLength+1);if(n[0]=e|31,!t){let s=this.valueHexView;for(let o=0;o<s.length-1;o++)n[o+1]=s[o]|128;n[this.valueHexView.byteLength]=s[s.length-1]}return n.buffer}fromBER(t,e,n){let s=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 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=Ke(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}}};Vn.NAME="identificationBlock";var Hn=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=Ke(c,8),this.longFormUsed&&this.length<=127&&this.warnings.push("Unnecessary usage of long length form"),this.blockLength=i+1,e+this.blockLength}toBER(t=!1){let e,n;if(this.length>127&&(this.longFormUsed=!0),this.isIndefiniteForm)return e=new ArrayBuffer(1),t===!1&&(n=new Uint8Array(e),n[0]=128),e;if(this.longFormUsed){let s=xe(this.length,8);if(s.byteLength>127)return this.error="Too big length",Vt;if(e=new ArrayBuffer(s.byteLength+1),t)return e;let o=new Uint8Array(s);n=new Uint8Array(e),n[0]=s.byteLength|128;for(let i=0;i<s.byteLength;i++)n[i+1]=o[i];return e}return e=new ArrayBuffer(1),t===!1&&(n=new Uint8Array(e),n[0]=this.length),e}toJSON(){return{...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,longFormUsed:this.longFormUsed,length:this.length}}};Hn.NAME="lengthBlock";var A={},ct=class extends te{constructor({name:t=hr,optional:e=!1,primitiveSchema:n,...s}={},o){super(s),this.name=t,this.optional=e,n&&(this.primitiveSchema=n),this.idBlock=new Vn(s),this.lenBlock=new Hn(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 jr;e||Lc(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 Cc(e,n)}};ct.NAME="BaseBlock";function Lc(r){var t;if(r instanceof A.Constructed)for(let e of r.valueBlock.value)Lc(e)&&(r.lenBlock.isIndefiniteForm=!0);return!!(!((t=r.lenBlock)===null||t===void 0)&&t.isIndefiniteForm)}var Pn=class extends ct{getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}constructor({value:t=hr,...e}={},n){super(e,n),t&&this.fromString(t)}fromBER(t,e,n){let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.fromBuffer(this.valueBlock.valueHexView),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}onAsciiEncoding(){return`${this.constructor.NAME} : '${this.valueBlock.value}'`}};Pn.NAME="BaseStringBlock";var Mn=class extends oe(ht){constructor({isHexOnly:t=!0,...e}={}){super(e),this.isHexOnly=t}};Mn.NAME="PrimitiveValueBlock";var Rc,Fn=class extends ct{constructor(t={}){super(t,Mn),this.idBlock.isConstructed=!1}};Rc=Fn;A.Primitive=Rc;Fn.NAME="PRIMITIVE";function Ph(r,t){if(r instanceof t)return r;let e=new t;return e.idBlock=r.idBlock,e.lenBlock=r.lenBlock,e.warnings=r.warnings,e.valueBeforeDecodeView=r.valueBeforeDecodeView,e}function Es(r,t=0,e=r.length){let n=t,s=new ct({},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=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=Ph(s,c),a=s.fromBER(r,t,s.lenBlock.isIndefiniteForm?e:s.lenBlock.length),s.valueBeforeDecodeView=r.subarray(n,n+s.blockLength),{offset:a,result:s}}function Bs(r){if(!r.byteLength){let t=new ct({},ht);return t.error="Input buffer has zero length",{offset:-1,result:t}}return Es(M.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function Mh(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(;Mh(this.isIndefiniteForm,n)>0;){let i=Es(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===$r)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===$r?this.value.pop():this.warnings.push("No EndOfContent block encoded")),o}toBER(t,e){let n=e||new jr;for(let s=0;s<this.value.length;s++)this.value[s].toBER(t,n);return e?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 _c,ve=class extends ct{constructor(t={}){super(t,Mt),this.idBlock.isConstructed=!0}fromBER(t,e,n){this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm;let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}onAsciiEncoding(){let t=[];for(let n of this.valueBlock.value)t.push(n.toString("ascii").split(`
2
+ "use strict";var Libp2PKeychain=(()=>{var ql=Object.create;var cn=Object.defineProperty;var jl=Object.getOwnPropertyDescriptor;var $l=Object.getOwnPropertyNames;var Gl=Object.getPrototypeOf,zl=Object.prototype.hasOwnProperty;var Be=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),dt=(r,t)=>{for(var e in t)cn(r,e,{get:t[e],enumerable:!0})},wi=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of $l(t))!zl.call(r,s)&&s!==e&&cn(r,s,{get:()=>t[s],enumerable:!(n=jl(t,s))||n.enumerable});return r};var Os=(r,t,e)=>(e=r!=null?ql(Gl(r)):{},wi(t||!r||!r.__esModule?cn(e,"default",{value:r,enumerable:!0}):e,r)),Wl=r=>wi(cn({},"__esModule",{value:!0}),r);var Tc=Be((Cy,Uc)=>{"use strict";Uc.exports=r=>{if(Object.prototype.toString.call(r)!=="[object Object]")return!1;let t=Object.getPrototypeOf(r);return t===null||t===Object.prototype}});var Kc=Be((Dc,Hc)=>{"use strict";var qn=Tc(),{hasOwnProperty:_c}=Object.prototype,{propertyIsEnumerable:yh}=Object,hr=(r,t,e)=>Object.defineProperty(r,t,{value:e,writable:!0,enumerable:!0,configurable:!0}),bh=Dc,Lc={concatArrays:!1,ignoreUndefined:!1},jn=r=>{let t=[];for(let e in r)_c.call(r,e)&&t.push(e);if(Object.getOwnPropertySymbols){let e=Object.getOwnPropertySymbols(r);for(let n of e)yh.call(r,n)&&t.push(n)}return t};function dr(r){return Array.isArray(r)?wh(r):qn(r)?xh(r):r}function wh(r){let t=r.slice(0,0);return jn(r).forEach(e=>{hr(t,e,dr(r[e]))}),t}function xh(r){let t=Object.getPrototypeOf(r)===null?Object.create(null):{};return jn(r).forEach(e=>{hr(t,e,dr(r[e]))}),t}var Rc=(r,t,e,n)=>(e.forEach(s=>{typeof t[s]>"u"&&n.ignoreUndefined||(s in r&&r[s]!==Object.getPrototypeOf(r)?hr(r,s,ci(r[s],t[s],n)):hr(r,s,dr(t[s])))}),r),vh=(r,t,e)=>{let n=r.slice(0,0),s=0;return[r,t].forEach(o=>{let i=[];for(let c=0;c<o.length;c++)_c.call(o,c)&&(i.push(String(c)),o===r?hr(n,s++,o[c]):hr(n,s++,dr(o[c])));n=Rc(n,o,jn(o).filter(c=>!i.includes(c)),e)}),n};function ci(r,t,e){return e.concatArrays&&Array.isArray(r)&&Array.isArray(t)?vh(r,t,e):!qn(t)||!qn(r)?dr(t):Rc(r,t,jn(t),e)}Hc.exports=function(...r){let t=ci(dr(Lc),this!==bh&&this||{},Lc),e={_:{}};for(let n of r)if(n!==void 0){if(!qn(n))throw new TypeError("`"+n+"` is not an Option Object");e=ci(e,{_:n},t)}return e._}});var Mc=Be((Uy,Pc)=>{"use strict";function Eh(r){return r>=55296&&r<=56319}function Bh(r){return r>=56320&&r<=57343}Pc.exports=function(t,e,n){if(typeof e!="string")throw new Error("Input must be string");for(var s=e.length,o=0,i,c,a=0;a<s;a+=1){if(i=e.charCodeAt(a),c=e[a],Eh(i)&&Bh(e.charCodeAt(a+1))&&(a+=1,c+=e[a]),o+=t(c),o===n)return e.slice(0,a+1);if(o>n)return e.slice(0,a-c.length+1)}return e}});var qc=Be((Ty,Fc)=>{"use strict";function Ah(r){return r>=55296&&r<=56319}function Sh(r){return r>=56320&&r<=57343}Fc.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),Sh(s)?o!=null&&Ah(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 $c=Be((Ly,jc)=>{"use strict";var kh=Mc(),Ih=qc();jc.exports=kh.bind(null,Ih)});var Wc=Be((_y,zc)=>{"use strict";var Ch=$c(),Nh=/[\/\?<>\\:\*\|"]/g,Uh=/[\x00-\x1f\x80-\x9f]/g,Th=/^\.+$/,Lh=/^(con|prn|aux|nul|com[0-9]|lpt[0-9])(\..*)?$/i,_h=/[\. ]+$/;function Gc(r,t){if(typeof r!="string")throw new Error("Input must be string");var e=r.replace(Nh,t).replace(Uh,t).replace(Th,t).replace(Lh,t).replace(_h,t);return Ch(e,255)}zc.exports=function(r,t){var e=t&&t.replacement||"",n=Gc(r,e);return e===""?n:Gc(n,"")}});var Zc=Be(gr=>{"use strict";var Dh="[object ArrayBuffer]",re=class r{static isArrayBuffer(t){return Object.prototype.toString.call(t)===Dh}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 c=this.toUint8Array(i);s.set(c,o),o+=c.length}return t[t.length-1]instanceof Function?this.toView(s,t[t.length-1]):s.buffer}},li="string",Hh=/^[0-9a-f\s]+$/i,Kh=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,Oh=/^[a-zA-Z0-9-_]+$/,Gn=class{static fromString(t){let e=unescape(encodeURIComponent(t)),n=new Uint8Array(e.length);for(let s=0;s<e.length;s++)n[s]=e.charCodeAt(s);return n.buffer}static toString(t){let e=re.toUint8Array(t),n="";for(let o=0;o<e.length;o++)n+=String.fromCharCode(e[o]);return decodeURIComponent(escape(n))}},Tt=class{static toString(t,e=!1){let n=re.toArrayBuffer(t),s=new DataView(n),o="";for(let i=0;i<n.byteLength;i+=2){let c=s.getUint16(i,e);o+=String.fromCharCode(c)}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}},zn=class r{static isHex(t){return typeof t===li&&Hh.test(t)}static isBase64(t){return typeof t===li&&Kh.test(t)}static isBase64Url(t){return typeof t===li&&Oh.test(t)}static ToString(t,e="utf8"){let n=re.toUint8Array(t);switch(e.toLowerCase()){case"utf8":return this.ToUtf8String(n);case"binary":return this.ToBinary(n);case"hex":return this.ToHex(n);case"base64":return this.ToBase64(n);case"base64url":return this.ToBase64Url(n);case"utf16le":return Tt.toString(n,!0);case"utf16":case"utf16be":return Tt.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 Tt.fromString(t,!0);case"utf16":case"utf16be":return Tt.fromString(t);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToBase64(t){let e=re.toUint8Array(t);if(typeof btoa<"u"){let n=this.ToString(e,"binary");return btoa(n)}else return Buffer.from(e).toString("base64")}static FromBase64(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isBase64(e))throw new TypeError("Argument 'base64Text' is not Base64 encoded");return typeof atob<"u"?this.FromBinary(atob(e)):new Uint8Array(Buffer.from(e,"base64")).buffer}static FromBase64Url(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isBase64Url(e))throw new TypeError("Argument 'base64url' is not Base64Url encoded");return this.FromBase64(this.Base64Padding(e.replace(/\-/g,"+").replace(/\_/g,"/")))}static ToBase64Url(t){return this.ToBase64(t).replace(/\+/g,"-").replace(/\//g,"_").replace(/\=/g,"")}static FromUtf8String(t,e=r.DEFAULT_UTF8_ENCODING){switch(e){case"ascii":return this.FromBinary(t);case"utf8":return Gn.fromString(t);case"utf16":case"utf16be":return Tt.fromString(t);case"utf16le":case"usc2":return Tt.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 Gn.toString(t);case"utf16":case"utf16be":return Tt.toString(t);case"utf16le":case"usc2":return Tt.toString(t,!0);default:throw new Error(`Unknown type of encoding '${e}'`)}}static FromBinary(t){let e=t.length,n=new Uint8Array(e);for(let s=0;s<e;s++)n[s]=t.charCodeAt(s);return n.buffer}static ToBinary(t){let e=re.toUint8Array(t),n="";for(let s=0;s<e.length;s++)n+=String.fromCharCode(e[s]);return n}static ToHex(t){let e=re.toUint8Array(t),n="",s=e.length;for(let o=0;o<s;o++){let i=e[o];i<16&&(n+="0"),n+=i.toString(16)}return n}static FromHex(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isHex(e))throw new TypeError("Argument 'hexString' is not HEX encoded");e.length%2&&(e=`0${e}`);let n=new Uint8Array(e.length/2);for(let s=0;s<e.length;s=s+2){let o=e.slice(s,s+2);n[s/2]=parseInt(o,16)}return n.buffer}static ToUtf16String(t,e=!1){return Tt.toString(t,e)}static FromUtf16String(t,e=!1){return Tt.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,"")||""}};zn.DEFAULT_UTF8_ENCODING="utf8";function Vh(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 Ph(...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 Mh(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}gr.BufferSourceConverter=re;gr.Convert=zn;gr.assign=Vh;gr.combine=Ph;gr.isEqual=Mh});var sd={};dt(sd,{keychain:()=>nd});var xr=class extends Error{constructor(t="An error occurred while signing a message"){super(t),this.name="SigningError"}},vr=class extends Error{constructor(t="An error occurred while verifying a message"){super(t),this.name="VerificationError"}},ln=class extends Error{constructor(t="Missing Web Crypto API"){super(t),this.name="WebCryptoMissingError"}};var xi={get(r=globalThis){let t=r.crypto;if(t?.subtle==null)throw new ln("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 vt=xi;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"}},Er=class extends Error{static name="InvalidPrivateKeyError";constructor(t="Invalid private key"){super(t),this.name="InvalidPrivateKeyError"}};var un=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 vi=Symbol.for("@libp2p/service-capabilities"),hd=Symbol.for("@libp2p/service-dependencies");var qs={};dt(qs,{base58btc:()=>et,base58flickr:()=>tu});var Dd=new Uint8Array(0);function Ei(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){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 Bi(r){return new TextEncoder().encode(r)}function Ai(r){return new TextDecoder().decode(r)}function Zl(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 c=r.length,a=r.charAt(0),f=Math.log(c)/Math.log(256),l=Math.log(256)/Math.log(c);function u(y){if(y instanceof Uint8Array||(ArrayBuffer.isView(y)?y=new Uint8Array(y.buffer,y.byteOffset,y.byteLength):Array.isArray(y)&&(y=Uint8Array.from(y))),!(y instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(y.length===0)return"";for(var g=0,N=0,I=0,M=y.length;I!==M&&y[I]===0;)I++,g++;for(var x=(M-I)*l+1>>>0,h=new Uint8Array(x);I!==M;){for(var w=y[I],k=0,C=x-1;(w!==0||k<N)&&C!==-1;C--,k++)w+=256*h[C]>>>0,h[C]=w%c>>>0,w=w/c>>>0;if(w!==0)throw new Error("Non-zero carry");N=k,I++}for(var U=x-N;U!==x&&h[U]===0;)U++;for(var H=a.repeat(g);U<x;++U)H+=r.charAt(h[U]);return H}function d(y){if(typeof y!="string")throw new TypeError("Expected String");if(y.length===0)return new Uint8Array;var g=0;if(y[g]!==" "){for(var N=0,I=0;y[g]===a;)N++,g++;for(var M=(y.length-g)*f+1>>>0,x=new Uint8Array(M);y[g];){var h=e[y.charCodeAt(g)];if(h===255)return;for(var w=0,k=M-1;(h!==0||w<I)&&k!==-1;k--,w++)h+=c*x[k]>>>0,x[k]=h%256>>>0,h=h/256>>>0;if(h!==0)throw new Error("Non-zero carry");I=w,g++}if(y[g]!==" "){for(var C=M-I;C!==M&&x[C]===0;)C++;for(var U=new Uint8Array(N+(M-C)),H=N;C!==M;)U[H++]=x[C++];return U}}}function b(y){var g=d(y);if(g)return g;throw new Error(`Non-${t} character`)}return{encode:u,decodeUnsafe:d,decode:b}}var Yl=Zl,Jl=Yl,ki=Jl;var Vs=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")}},Ps=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 Ii(this,t)}},Ms=class{decoders;constructor(t){this.decoders=t}or(t){return Ii(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 Ii(r,t){return new Ms({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var Fs=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 Vs(t,e,n),this.decoder=new Ps(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 Fs(r,t,e,n)}function le({name:r,prefix:t,alphabet:e}){let{encode:n,decode:s}=ki(e,r);return $e({prefix:t,name:r,encode:n,decode:o=>Gt(s(o))})}function Xl(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),c=0,a=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`);a=a<<e|u,c+=e,c>=8&&(c-=8,i[f++]=255&a>>c)}if(c>=e||(255&a<<8-c)!==0)throw new SyntaxError("Unexpected end of data");return i}function Ql(r,t,e){let n=t[t.length-1]==="=",s=(1<<e)-1,o="",i=0,c=0;for(let a=0;a<r.length;++a)for(c=c<<8|r[a],i+=8;i>e;)i-=e,o+=t[s&c>>i];if(i!==0&&(o+=t[s&c<<e-i]),n)for(;(o.length*e&7)!==0;)o+="=";return o}function J({name:r,prefix:t,bitsPerChar:e,alphabet:n}){return $e({prefix:t,name:r,encode(s){return Ql(s,n,e)},decode(s){return Xl(s,n,e,r)}})}var et=le({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),tu=le({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var js={};dt(js,{base32:()=>Ge,base32hex:()=>su,base32hexpad:()=>iu,base32hexpadupper:()=>au,base32hexupper:()=>ou,base32pad:()=>ru,base32padupper:()=>nu,base32upper:()=>eu,base32z:()=>cu});var Ge=J({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),eu=J({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),ru=J({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),nu=J({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),su=J({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),ou=J({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),iu=J({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),au=J({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),cu=J({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var $s={};dt($s,{base36:()=>Br,base36upper:()=>lu});var Br=le({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),lu=le({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var uu=Ui,Ci=128,fu=127,hu=~fu,du=Math.pow(2,31);function Ui(r,t,e){t=t||[],e=e||0;for(var n=e;r>=du;)t[e++]=r&255|Ci,r/=128;for(;r&hu;)t[e++]=r&255|Ci,r>>>=7;return t[e]=r|0,Ui.bytes=e-n+1,t}var pu=Gs,gu=128,Ni=127;function Gs(r,n){var e=0,n=n||0,s=0,o=n,i,c=r.length;do{if(o>=c)throw Gs.bytes=0,new RangeError("Could not decode varint");i=r[o++],e+=s<28?(i&Ni)<<s:(i&Ni)*Math.pow(2,s),s+=7}while(i>=gu);return Gs.bytes=o-n,e}var mu=Math.pow(2,7),yu=Math.pow(2,14),bu=Math.pow(2,21),wu=Math.pow(2,28),xu=Math.pow(2,35),vu=Math.pow(2,42),Eu=Math.pow(2,49),Bu=Math.pow(2,56),Au=Math.pow(2,63),Su=function(r){return r<mu?1:r<yu?2:r<bu?3:r<wu?4:r<xu?5:r<vu?6:r<Eu?7:r<Bu?8:r<Au?9:10},ku={encode:uu,decode:pu,encodingLength:Su},Iu=ku,Ar=Iu;function Sr(r,t=0){return[Ar.decode(r,t),Ar.decode.bytes]}function ze(r,t,e=0){return Ar.encode(r,t,e),t}function We(r){return Ar.encodingLength(r)}function _t(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 Ti(r){let t=Gt(r),[e,n]=Sr(t),[s,o]=Sr(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 Li(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&Ei(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 _i(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return Nu(e,zs(r),t??et.encoder);default:return Uu(e,zs(r),t??Ge.encoder)}}var Ri=new WeakMap;function zs(r){let t=Ri.get(r);if(t==null){let e=new Map;return Ri.set(r,e),e}return t}var Ut=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!==Ir)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==Tu)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=_t(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&&Li(t.multihash,n.multihash)}toString(t){return _i(this,t)}toJSON(){return{"/":_i(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??Di(n,s,o.bytes))}else if(e[Lu]===!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!==Ir)throw new Error(`Version 0 CID must use dag-pb (code: ${Ir}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let s=Di(t,e,n.bytes);return new r(t,e,n,s)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,Ir,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=Gt(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,d]=Sr(t.subarray(e));return e+=d,u},s=n(),o=Ir;if(s===18?(s=0,e=0):o=n(),s!==0&&s!==1)throw new RangeError(`Invalid CID version ${s}`);let i=e,c=n(),a=n(),f=e+a,l=f-i;return{version:s,codec:o,multihashCode:c,digestSize:a,multihashSize:l,size:f}}static parse(t,e){let[n,s]=Cu(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 zs(o).set(n,t),o}};function Cu(r,t){switch(r[0]){case"Q":{let e=t??et;return[et.prefix,e.decode(`${et.prefix}${r}`)]}case et.prefix:{let e=t??et;return[et.prefix,e.decode(r)]}case Ge.prefix:{let e=t??Ge;return[Ge.prefix,e.decode(r)]}case Br.prefix:{let e=t??Br;return[Br.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 Nu(r,t,e){let{prefix:n}=e;if(n!==et.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 Uu(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 Ir=112,Tu=18;function Di(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 Lu=Symbol.for("@ipld/js-cid/CID");var Ws={};dt(Ws,{identity:()=>Ae});var Hi=0,_u="identity",Ki=Gt;function Ru(r){return _t(Hi,Ki(r))}var Ae={code:Hi,name:_u,encode:Ki,digest:Ru};function Et(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 zt(r=0){return new Uint8Array(r)}function It(r=0){return new Uint8Array(r)}function Ye(r,t){t==null&&(t=r.reduce((s,o)=>s+o.length,0));let e=It(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 hn(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(hn(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(hn(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(hn(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 Ye(n,s)}subarray(t,e){let{bufs:n,length:s}=this._subList(t,e);return n.length===1?n[0]:Ye(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],c=s,a=c+i.byteLength;if(s=a,t>=a)continue;let f=t>=c&&t<a,l=e>c&&e<=a;if(f&&l){if(t===c&&e===a){n.push(i);break}let u=t-c;n.push(i.subarray(u,u+(e-t)));break}if(f){if(t===0){n.push(i);continue}n.push(i.subarray(t-c));continue}if(l){if(e===a){n.push(i);break}n.push(i.subarray(0,e-c));break}n.push(i)}return{bufs:n,length:e-t}}indexOf(t,e=0){if(!hn(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 c=i,a=this.byteLength-n.byteLength,f=n.byteLength-1,l;for(let u=e;u<=a;u+=l){l=0;for(let d=f;d>=0;d--){let b=this.get(u+d);if(n[d]!==b){l=Math.max(1,d-c[b]);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=It(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=zt(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=zt(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=zt(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=It(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=zt(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=zt(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=zt(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=zt(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=zt(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(!Et(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 Zs={};dt(Zs,{base10:()=>Du});var Du=le({prefix:"9",name:"base10",alphabet:"0123456789"});var Ys={};dt(Ys,{base16:()=>Hu,base16upper:()=>Ku});var Hu=J({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Ku=J({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Js={};dt(Js,{base2:()=>Ou});var Ou=J({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Xs={};dt(Xs,{base256emoji:()=>qu});var Pi=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}"),Vu=Pi.reduce((r,t,e)=>(r[e]=t,r),[]),Pu=Pi.reduce((r,t,e)=>{let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);return r[n]=e,r},[]);function Mu(r){return r.reduce((t,e)=>(t+=Vu[e],t),"")}function Fu(r){let t=[];for(let e of r){let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);let s=Pu[n];if(s==null)throw new Error(`Non-base256emoji character: ${e}`);t.push(s)}return new Uint8Array(t)}var qu=$e({prefix:"\u{1F680}",name:"base256emoji",encode:Mu,decode:Fu});var Qs={};dt(Qs,{base64:()=>Se,base64pad:()=>ju,base64url:()=>$u,base64urlpad:()=>Gu});var Se=J({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),ju=J({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),$u=J({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Gu=J({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var to={};dt(to,{base8:()=>zu});var zu=J({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var eo={};dt(eo,{identity:()=>Wu});var Wu=$e({prefix:"\0",name:"identity",encode:r=>Ai(r),decode:r=>Bi(r)});var b0=new TextEncoder,w0=new TextDecoder;var so={};dt(so,{sha256:()=>Je,sha512:()=>Ju});function no({name:r,code:t,encode:e}){return new ro(r,t,e)}var ro=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?_t(this.code,e):e.then(n=>_t(this.code,n))}else throw Error("Unknown type, must be binary type")}};function Fi(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var Je=no({name:"sha2-256",code:18,encode:Fi("SHA-256")}),Ju=no({name:"sha2-512",code:19,encode:Fi("SHA-512")});var oo={...eo,...Js,...to,...Zs,...Ys,...js,...$s,...qs,...Qs,...Xs},T0={...so,...Ws};function ji(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var qi=ji("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),io=ji("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=It(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),Xu={utf8:qi,"utf-8":qi,hex:oo.base16,latin1:io,ascii:io,binary:io,...oo},dn=Xu;function P(r,t="utf8"){let e=dn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function G(r,t="utf8"){let e=dn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}var Qu=parseInt("11111",2),ao=parseInt("10000000",2),tf=parseInt("01111111",2),$i={0:Cr,1:Cr,2:ef,3:sf,4:of,5:nf,6:rf,16:Cr,22:Cr,48:Cr};function Rt(r,t={offset:0}){let e=r[t.offset]&Qu;if(t.offset++,$i[e]!=null)return $i[e](r,t);throw new Error("No decoder for tag "+e)}function Nr(r,t){let e=0;if((r[t.offset]&ao)===ao){let n=r[t.offset]&tf,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 Cr(r,t){Nr(r,t);let e=[];for(;!(t.offset>=r.byteLength);){let n=Rt(r,t);if(n===null)break;e.push(n)}return e}function ef(r,t){let e=Nr(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 rf(r,t){let e=Nr(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 c=`${o}.${i}`,a=[];for(;t.offset<n;){let f=r[t.offset];if(t.offset++,a.push(f&127),f<128){a.reverse();let l=0;for(let u=0;u<a.length;u++)l+=a[u]<<u*7;c+=`.${l}`,a=[]}}return c}function nf(r,t){return t.offset++,null}function sf(r,t){let e=Nr(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 of(r,t){let e=Nr(r,t),n=r.subarray(t.offset,t.offset+e);return t.offset+=e,n}function af(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 pn(r){if(r.byteLength<128)return Uint8Array.from([r.byteLength]);let t=af(r.byteLength);return new pt(Uint8Array.from([t.byteLength|ao]),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]),pn(t),t)}function Ur(r){let t=Uint8Array.from([0]),e=new pt(t,r);return new pt(Uint8Array.from([3]),pn(e),e)}function Gi(r){return new pt(Uint8Array.from([4]),pn(r),r)}function Dt(r,t=48){let e=new pt;for(let n of r)e.append(n);return new pt(Uint8Array.from([t]),pn(e),e)}var zi="1.2.840.10045.3.1.7",Wi="1.3.132.0.34",Zi="1.3.132.0.35";async function Yi(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 cf=Uint8Array.from([6,8,42,134,72,206,61,3,1,7]),lf=Uint8Array.from([6,5,43,129,4,0,34]),uf=Uint8Array.from([6,5,43,129,4,0,35]),ff={ext:!0,kty:"EC",crv:"P-256"},hf={ext:!0,kty:"EC",crv:"P-384"},df={ext:!0,kty:"EC",crv:"P-521"},co=32,lo=48,uo=66;function Xi(r){let t=Rt(r);return fo(t)}function fo(r){let t=r[1],e=G(t,"base64url"),n=r[2][1][0],s=1,o,i;if(t.byteLength===co)return o=G(n.subarray(s,s+co),"base64url"),i=G(n.subarray(s+co),"base64url"),new Xe({...ff,key_ops:["sign"],d:e,x:o,y:i});if(t.byteLength===lo)return o=G(n.subarray(s,s+lo),"base64url"),i=G(n.subarray(s+lo),"base64url"),new Xe({...hf,key_ops:["sign"],d:e,x:o,y:i});if(t.byteLength===uo)return o=G(n.subarray(s,s+uo),"base64url"),i=G(n.subarray(s+uo),"base64url"),new Xe({...df,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 Qi(r){return Dt([gt(Uint8Array.from([1])),Gi(P(r.d??"","base64url")),Dt([ea(r.crv)],160),Dt([Ur(new pt(Uint8Array.from([4]),P(r.x??"","base64url"),P(r.y??"","base64url")))],161)]).subarray()}function ta(r){return Dt([gt(Uint8Array.from([1])),Dt([ea(r.crv)],160),Dt([Ur(new pt(Uint8Array.from([4]),P(r.x??"","base64url"),P(r.y??"","base64url")))],161)]).subarray()}function ea(r){if(r==="P-256")return cf;if(r==="P-384")return lf;if(r==="P-521")return uf;throw new L(`Invalid curve ${r}`)}var gn=class{type="ECDSA";jwk;_raw;constructor(t){this.jwk=t}get raw(){return this._raw==null&&(this._raw=ta(this.jwk)),this._raw}toMultihash(){return Ae.digest(Qe(this))}toCID(){return Ut.createV1(114,this.toMultihash())}toString(){return et.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:Et(this.raw,t.raw)}async verify(t,e){return Ji(this.jwk,e,t)}},Xe=class{type="ECDSA";jwk;publicKey;_raw;constructor(t){this.jwk=t,this.publicKey=new gn({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=Qi(this.jwk)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:Et(this.raw,t.raw)}async sign(t){return Yi(this.jwk,t)}};var ke=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;function pf(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function ue(r){if(!Number.isSafeInteger(r)||r<0)throw new Error("positive integer expected, got "+r)}function fe(r,...t){if(!pf(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 mn(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.createHasher");ue(r.outputLen),ue(r.blockLen)}function er(r,t=!0){if(r.destroyed)throw new Error("Hash instance has been destroyed");if(t&&r.finished)throw new Error("Hash#digest() has already been called")}function ra(r,t){fe(r);let e=t.outputLen;if(r.length<e)throw new Error("digestInto() expects output buffer of length at least "+e)}function Bt(...r){for(let t=0;t<r.length;t++)r[t].fill(0)}function Ie(r){return new DataView(r.buffer,r.byteOffset,r.byteLength)}function Ht(r,t){return r<<32-t|r>>>t}function yn(r,t){return r<<t|r>>>32-t>>>0}var gf=async()=>{};async function na(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 gf(),n+=o)}}function ho(r){if(typeof r!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(r))}function Tr(r){return typeof r=="string"&&(r=ho(r)),fe(r),r}function po(r){return typeof r=="string"&&(r=ho(r)),fe(r),r}function go(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];fe(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 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)}var tr=class{};function Lr(r){let t=n=>r().update(Tr(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function rr(r=32){if(ke&&typeof ke.getRandomValues=="function")return ke.getRandomValues(new Uint8Array(r));if(ke&&typeof ke.randomBytes=="function")return Uint8Array.from(ke.randomBytes(r));throw new Error("crypto.getRandomValues must be defined")}function mf(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),c=Number(e&o),a=n?4:0,f=n?0:4;r.setUint32(t+a,i,n),r.setUint32(t+f,c,n)}function bn(r,t,e){return r&t^~r&e}function wn(r,t,e){return r&t^r&e^t&e}var Ce=class extends tr{constructor(t,e,n,s){super(),this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.blockLen=t,this.outputLen=e,this.padOffset=n,this.isLE=s,this.buffer=new Uint8Array(t),this.view=Ie(this.buffer)}update(t){er(this),t=Tr(t),fe(t);let{view:e,buffer:n,blockLen:s}=this,o=t.length;for(let i=0;i<o;){let c=Math.min(s-this.pos,o-i);if(c===s){let a=Ie(t);for(;s<=o-i;i+=s)this.process(a,i);continue}n.set(t.subarray(i,i+c),this.pos),this.pos+=c,i+=c,this.pos===s&&(this.process(e,0),this.pos=0)}return this.length+=t.length,this.roundClean(),this}digestInto(t){er(this),ra(t,this),this.finished=!0;let{buffer:e,view:n,blockLen:s,isLE:o}=this,{pos:i}=this;e[i++]=128,Bt(this.buffer.subarray(i)),this.padOffset>s-i&&(this.process(n,0),i=0);for(let u=i;u<s;u++)e[u]=0;mf(n,s-8,BigInt(this.length*8),o),this.process(n,0);let c=Ie(t),a=this.outputLen;if(a%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let f=a/4,l=this.get();if(f>l.length)throw new Error("_sha2: outputLen bigger than state");for(let u=0;u<f;u++)c.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:c}=this;return t.destroyed=i,t.finished=o,t.length=s,t.pos=c,s%e&&t.buffer.set(n),t}clone(){return this._cloneInto()}},Wt=Uint32Array.from([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]);var at=Uint32Array.from([1779033703,4089235720,3144134277,2227873595,1013904242,4271175723,2773480762,1595750129,1359893119,2917565137,2600822924,725511199,528734635,4215389547,1541459225,327033209]);var xn=BigInt(4294967295),oa=BigInt(32);function yf(r,t=!1){return t?{h:Number(r&xn),l:Number(r>>oa&xn)}:{h:Number(r>>oa&xn)|0,l:Number(r&xn)|0}}function ia(r,t=!1){let e=r.length,n=new Uint32Array(e),s=new Uint32Array(e);for(let o=0;o<e;o++){let{h:i,l:c}=yf(r[o],t);[n[o],s[o]]=[i,c]}return[n,s]}var mo=(r,t,e)=>r>>>e,yo=(r,t,e)=>r<<32-e|t>>>e,Ne=(r,t,e)=>r>>>e|t<<32-e,Ue=(r,t,e)=>r<<32-e|t>>>e,_r=(r,t,e)=>r<<64-e|t>>>e-32,Rr=(r,t,e)=>r>>>e-32|t<<64-e;function Pt(r,t,e,n){let s=(t>>>0)+(n>>>0);return{h:r+e+(s/2**32|0)|0,l:s|0}}var aa=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),ca=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,la=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),ua=(r,t,e,n,s)=>t+e+n+s+(r/2**32|0)|0,fa=(r,t,e,n,s)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(s>>>0),ha=(r,t,e,n,s,o)=>t+e+n+s+o+(r/2**32|0)|0;var wf=Uint32Array.from([1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298]),he=new Uint32Array(64),vn=class extends Ce{constructor(t=32){super(64,t,8,!1),this.A=Wt[0]|0,this.B=Wt[1]|0,this.C=Wt[2]|0,this.D=Wt[3]|0,this.E=Wt[4]|0,this.F=Wt[5]|0,this.G=Wt[6]|0,this.H=Wt[7]|0}get(){let{A:t,B:e,C:n,D:s,E:o,F:i,G:c,H:a}=this;return[t,e,n,s,o,i,c,a]}set(t,e,n,s,o,i,c,a){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=c|0,this.H=a|0}process(t,e){for(let u=0;u<16;u++,e+=4)he[u]=t.getUint32(e,!1);for(let u=16;u<64;u++){let d=he[u-15],b=he[u-2],y=Ht(d,7)^Ht(d,18)^d>>>3,g=Ht(b,17)^Ht(b,19)^b>>>10;he[u]=g+he[u-7]+y+he[u-16]|0}let{A:n,B:s,C:o,D:i,E:c,F:a,G:f,H:l}=this;for(let u=0;u<64;u++){let d=Ht(c,6)^Ht(c,11)^Ht(c,25),b=l+d+bn(c,a,f)+wf[u]+he[u]|0,g=(Ht(n,2)^Ht(n,13)^Ht(n,22))+wn(n,s,o)|0;l=f,f=a,a=c,c=i+b|0,i=o,o=s,s=n,n=b+g|0}n=n+this.A|0,s=s+this.B|0,o=o+this.C|0,i=i+this.D|0,c=c+this.E|0,a=a+this.F|0,f=f+this.G|0,l=l+this.H|0,this.set(n,s,o,i,c,a,f,l)}roundClean(){Bt(he)}destroy(){this.set(0,0,0,0,0,0,0,0),Bt(this.buffer)}};var da=ia(["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))),xf=da[0],vf=da[1],de=new Uint32Array(80),pe=new Uint32Array(80),En=class extends Ce{constructor(t=64){super(128,t,16,!1),this.Ah=at[0]|0,this.Al=at[1]|0,this.Bh=at[2]|0,this.Bl=at[3]|0,this.Ch=at[4]|0,this.Cl=at[5]|0,this.Dh=at[6]|0,this.Dl=at[7]|0,this.Eh=at[8]|0,this.El=at[9]|0,this.Fh=at[10]|0,this.Fl=at[11]|0,this.Gh=at[12]|0,this.Gl=at[13]|0,this.Hh=at[14]|0,this.Hl=at[15]|0}get(){let{Ah:t,Al:e,Bh:n,Bl:s,Ch:o,Cl:i,Dh:c,Dl:a,Eh:f,El:l,Fh:u,Fl:d,Gh:b,Gl:y,Hh:g,Hl:N}=this;return[t,e,n,s,o,i,c,a,f,l,u,d,b,y,g,N]}set(t,e,n,s,o,i,c,a,f,l,u,d,b,y,g,N){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=c|0,this.Dl=a|0,this.Eh=f|0,this.El=l|0,this.Fh=u|0,this.Fl=d|0,this.Gh=b|0,this.Gl=y|0,this.Hh=g|0,this.Hl=N|0}process(t,e){for(let x=0;x<16;x++,e+=4)de[x]=t.getUint32(e),pe[x]=t.getUint32(e+=4);for(let x=16;x<80;x++){let h=de[x-15]|0,w=pe[x-15]|0,k=Ne(h,w,1)^Ne(h,w,8)^mo(h,w,7),C=Ue(h,w,1)^Ue(h,w,8)^yo(h,w,7),U=de[x-2]|0,H=pe[x-2]|0,V=Ne(U,H,19)^_r(U,H,61)^mo(U,H,6),_=Ue(U,H,19)^Rr(U,H,61)^yo(U,H,6),K=la(C,_,pe[x-7],pe[x-16]),D=ua(K,k,V,de[x-7],de[x-16]);de[x]=D|0,pe[x]=K|0}let{Ah:n,Al:s,Bh:o,Bl:i,Ch:c,Cl:a,Dh:f,Dl:l,Eh:u,El:d,Fh:b,Fl:y,Gh:g,Gl:N,Hh:I,Hl:M}=this;for(let x=0;x<80;x++){let h=Ne(u,d,14)^Ne(u,d,18)^_r(u,d,41),w=Ue(u,d,14)^Ue(u,d,18)^Rr(u,d,41),k=u&b^~u&g,C=d&y^~d&N,U=fa(M,w,C,vf[x],pe[x]),H=ha(U,I,h,k,xf[x],de[x]),V=U|0,_=Ne(n,s,28)^_r(n,s,34)^_r(n,s,39),K=Ue(n,s,28)^Rr(n,s,34)^Rr(n,s,39),D=n&o^n&c^o&c,Q=s&i^s&a^i&a;I=g|0,M=N|0,g=b|0,N=y|0,b=u|0,y=d|0,{h:u,l:d}=Pt(f|0,l|0,H|0,V|0),f=c|0,l=a|0,c=o|0,a=i|0,o=n|0,i=s|0;let B=aa(V,K,Q);n=ca(B,H,_,D),s=B|0}({h:n,l:s}=Pt(this.Ah|0,this.Al|0,n|0,s|0)),{h:o,l:i}=Pt(this.Bh|0,this.Bl|0,o|0,i|0),{h:c,l:a}=Pt(this.Ch|0,this.Cl|0,c|0,a|0),{h:f,l}=Pt(this.Dh|0,this.Dl|0,f|0,l|0),{h:u,l:d}=Pt(this.Eh|0,this.El|0,u|0,d|0),{h:b,l:y}=Pt(this.Fh|0,this.Fl|0,b|0,y|0),{h:g,l:N}=Pt(this.Gh|0,this.Gl|0,g|0,N|0),{h:I,l:M}=Pt(this.Hh|0,this.Hl|0,I|0,M|0),this.set(n,s,o,i,c,a,f,l,u,d,b,y,g,N,I,M)}roundClean(){Bt(de,pe)}destroy(){Bt(this.buffer),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}};var Bn=Lr(()=>new vn);var An=Lr(()=>new En);var vo=BigInt(0),xo=BigInt(1);function nr(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function Eo(r){if(!nr(r))throw new Error("Uint8Array expected")}function Mt(r,t){if(typeof t!="boolean")throw new Error(r+" boolean expected, got "+t)}function Dr(r){let t=r.toString(16);return t.length&1?"0"+t:t}function ma(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return r===""?vo:BigInt("0x"+r)}var ya=typeof Uint8Array.from([]).toHex=="function"&&typeof Uint8Array.fromHex=="function",Ef=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function ge(r){if(Eo(r),ya)return r.toHex();let t="";for(let e=0;e<r.length;e++)t+=Ef[r[e]];return t}var Zt={_0:48,_9:57,A:65,F:70,a:97,f:102};function pa(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 Hr(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);if(ya)return Uint8Array.fromHex(r);let t=r.length,e=t/2;if(t%2)throw new Error("hex string expected, got unpadded hex of length "+t);let n=new Uint8Array(e);for(let s=0,o=0;s<e;s++,o+=2){let i=pa(r.charCodeAt(o)),c=pa(r.charCodeAt(o+1));if(i===void 0||c===void 0){let a=r[o]+r[o+1];throw new Error('hex string expected, got non-hex character "'+a+'" at index '+o)}n[s]=i*16+c}return n}function Yt(r){return ma(ge(r))}function Te(r){return Eo(r),ma(ge(Uint8Array.from(r).reverse()))}function Le(r,t){return Hr(r.toString(16).padStart(t*2,"0"))}function sr(r,t){return Le(r,t).reverse()}function Z(r,t,e){let n;if(typeof t=="string")try{n=Hr(t)}catch(o){throw new Error(r+" must be hex string or Uint8Array, cause: "+o)}else if(nr(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 me(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];Eo(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 bo=r=>typeof r=="bigint"&&vo<=r;function Sn(r,t,e){return bo(r)&&bo(t)&&bo(e)&&t<=r&&r<e}function Ct(r,t,e,n){if(!Sn(t,e,n))throw new Error("expected valid "+r+": "+e+" <= n < "+n+", got "+t)}function ba(r){let t;for(t=0;r>vo;r>>=xo,t+=1);return t}var _e=r=>(xo<<BigInt(r))-xo,wo=r=>new Uint8Array(r),ga=r=>Uint8Array.from(r);function wa(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=wo(r),s=wo(r),o=0,i=()=>{n.fill(1),s.fill(0),o=0},c=(...u)=>e(s,n,...u),a=(u=wo(0))=>{s=c(ga([0]),u),n=c(),u.length!==0&&(s=c(ga([1]),u),n=c())},f=()=>{if(o++>=1e3)throw new Error("drbg: tried 1000 values");let u=0,d=[];for(;u<t;){n=c();let b=n.slice();d.push(b),u+=n.length}return me(...d)};return(u,d)=>{i(),a(u);let b;for(;!(b=d(f()));)a();return i(),b}}var Bf={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"||nr(r),isSafeInteger:r=>Number.isSafeInteger(r),array:r=>Array.isArray(r),field:(r,t)=>t.Fp.isValid(r),hash:r=>typeof r=="function"&&Number.isSafeInteger(r.outputLen)};function Jt(r,t,e={}){let n=(s,o,i)=>{let c=Bf[o];if(typeof c!="function")throw new Error("invalid validator function");let a=r[s];if(!(i&&a===void 0)&&!c(a,r))throw new Error("param "+String(s)+" is invalid. Expected "+o+", got "+a)};for(let[s,o]of Object.entries(t))n(s,o,!1);for(let[s,o]of Object.entries(e))n(s,o,!0);return r}function or(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 mt=BigInt(0),st=BigInt(1),Re=BigInt(2),Af=BigInt(3),va=BigInt(4),Ea=BigInt(5),Ba=BigInt(8);function W(r,t){let e=r%t;return e>=mt?e:t+e}function Y(r,t,e){let n=r;for(;t-- >mt;)n*=n,n%=e;return n}function kn(r,t){if(r===mt)throw new Error("invert: expected non-zero number");if(t<=mt)throw new Error("invert: expected positive modulus, got "+t);let e=W(r,t),n=t,s=mt,o=st,i=st,c=mt;for(;e!==mt;){let f=n/e,l=n%e,u=s-i*f,d=o-c*f;n=e,e=l,s=i,o=c,i=u,c=d}if(n!==st)throw new Error("invert: does not exist");return W(s,t)}function Aa(r,t){let e=(r.ORDER+st)/va,n=r.pow(t,e);if(!r.eql(r.sqr(n),t))throw new Error("Cannot find square root");return n}function Sf(r,t){let e=(r.ORDER-Ea)/Ba,n=r.mul(t,Re),s=r.pow(n,e),o=r.mul(t,s),i=r.mul(r.mul(o,Re),s),c=r.mul(o,r.sub(i,r.ONE));if(!r.eql(r.sqr(c),t))throw new Error("Cannot find square root");return c}function kf(r){if(r<BigInt(3))throw new Error("sqrt is not defined for small field");let t=r-st,e=0;for(;t%Re===mt;)t/=Re,e++;let n=Re,s=Xt(r);for(;xa(s,n)===1;)if(n++>1e3)throw new Error("Cannot find square root: probably non-prime P");if(e===1)return Aa;let o=s.pow(n,t),i=(t+st)/Re;return function(a,f){if(a.is0(f))return f;if(xa(a,f)!==1)throw new Error("Cannot find square root");let l=e,u=a.mul(a.ONE,o),d=a.pow(f,t),b=a.pow(f,i);for(;!a.eql(d,a.ONE);){if(a.is0(d))return a.ZERO;let y=1,g=a.sqr(d);for(;!a.eql(g,a.ONE);)if(y++,g=a.sqr(g),y===l)throw new Error("Cannot find square root");let N=st<<BigInt(l-y-1),I=a.pow(u,N);l=y,u=a.sqr(I),d=a.mul(d,u),b=a.mul(b,I)}return b}}function If(r){return r%va===Af?Aa:r%Ba===Ea?Sf:kf(r)}var Sa=(r,t)=>(W(r,t)&st)===st,Cf=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function Bo(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=Cf.reduce((n,s)=>(n[s]="function",n),t);return Jt(r,e)}function Nf(r,t,e){if(e<mt)throw new Error("invalid exponent, negatives unsupported");if(e===mt)return r.ONE;if(e===st)return t;let n=r.ONE,s=t;for(;e>mt;)e&st&&(n=r.mul(n,s)),s=r.sqr(s),e>>=st;return n}function ir(r,t,e=!1){let n=new Array(t.length).fill(e?r.ZERO:void 0),s=t.reduce((i,c,a)=>r.is0(c)?i:(n[a]=i,r.mul(i,c)),r.ONE),o=r.inv(s);return t.reduceRight((i,c,a)=>r.is0(c)?i:(n[a]=r.mul(i,n[a]),r.mul(i,c)),o),n}function xa(r,t){let e=(r.ORDER-st)/Re,n=r.pow(t,e),s=r.eql(n,r.ONE),o=r.eql(n,r.ZERO),i=r.eql(n,r.neg(r.ONE));if(!s&&!o&&!i)throw new Error("invalid Legendre symbol result");return s?1:o?0:-1}function Ao(r,t){t!==void 0&&ue(t);let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function Xt(r,t,e=!1,n={}){if(r<=mt)throw new Error("invalid field: expected ORDER > 0, got "+r);let{nBitLength:s,nByteLength:o}=Ao(r,t);if(o>2048)throw new Error("invalid field: expected ORDER of <= 2048 bytes");let i,c=Object.freeze({ORDER:r,isLE:e,BITS:s,BYTES:o,MASK:_e(s),ZERO:mt,ONE:st,create:a=>W(a,r),isValid:a=>{if(typeof a!="bigint")throw new Error("invalid field element: expected bigint, got "+typeof a);return mt<=a&&a<r},is0:a=>a===mt,isOdd:a=>(a&st)===st,neg:a=>W(-a,r),eql:(a,f)=>a===f,sqr:a=>W(a*a,r),add:(a,f)=>W(a+f,r),sub:(a,f)=>W(a-f,r),mul:(a,f)=>W(a*f,r),pow:(a,f)=>Nf(c,a,f),div:(a,f)=>W(a*kn(f,r),r),sqrN:a=>a*a,addN:(a,f)=>a+f,subN:(a,f)=>a-f,mulN:(a,f)=>a*f,inv:a=>kn(a,r),sqrt:n.sqrt||(a=>(i||(i=If(r)),i(c,a))),toBytes:a=>e?sr(a,o):Le(a,o),fromBytes:a=>{if(a.length!==o)throw new Error("Field.fromBytes: expected "+o+" bytes, got "+a.length);return e?Te(a):Yt(a)},invertBatch:a=>ir(c,a),cmov:(a,f,l)=>l?f:a});return Object.freeze(c)}function ka(r){if(typeof r!="bigint")throw new Error("field order must be bigint");let t=r.toString(2).length;return Math.ceil(t/8)}function So(r){let t=ka(r);return t+Math.ceil(t/2)}function Ia(r,t,e=!1){let n=r.length,s=ka(t),o=So(t);if(n<16||n<o||n>1024)throw new Error("expected "+o+"-1024 bytes of input, got "+n);let i=e?Te(r):Yt(r),c=W(i,t-st)+st;return e?sr(c,s):Le(c,s)}var Ca=BigInt(0),Uo=BigInt(1);function ko(r,t){let e=t.negate();return r?e:t}function Ua(r,t){if(!Number.isSafeInteger(r)||r<=0||r>t)throw new Error("invalid window size, expected [1.."+t+"], got W="+r)}function Io(r,t){Ua(r,t);let e=Math.ceil(t/r)+1,n=2**(r-1),s=2**r,o=_e(r),i=BigInt(r);return{windows:e,windowSize:n,mask:o,maxNumber:s,shiftBy:i}}function Na(r,t,e){let{windowSize:n,mask:s,maxNumber:o,shiftBy:i}=e,c=Number(r&s),a=r>>i;c>n&&(c-=o,a+=Uo);let f=t*n,l=f+Math.abs(c)-1,u=c===0,d=c<0,b=t%2!==0;return{nextN:a,offset:l,isZero:u,isNeg:d,isNegF:b,offsetF:f}}function Uf(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 Tf(r,t){if(!Array.isArray(r))throw new Error("array of scalars expected");r.forEach((e,n)=>{if(!t.isValid(e))throw new Error("invalid scalar at index "+n)})}var Co=new WeakMap,Ta=new WeakMap;function No(r){return Ta.get(r)||1}function In(r,t){return{constTimeNegate:ko,hasPrecomputes(e){return No(e)!==1},unsafeLadder(e,n,s=r.ZERO){let o=e;for(;n>Ca;)n&Uo&&(s=s.add(o)),o=o.double(),n>>=Uo;return s},precomputeWindow(e,n){let{windows:s,windowSize:o}=Io(n,t),i=[],c=e,a=c;for(let f=0;f<s;f++){a=c,i.push(a);for(let l=1;l<o;l++)a=a.add(c),i.push(a);c=a.double()}return i},wNAF(e,n,s){let o=r.ZERO,i=r.BASE,c=Io(e,t);for(let a=0;a<c.windows;a++){let{nextN:f,offset:l,isZero:u,isNeg:d,isNegF:b,offsetF:y}=Na(s,a,c);s=f,u?i=i.add(ko(b,n[y])):o=o.add(ko(d,n[l]))}return{p:o,f:i}},wNAFUnsafe(e,n,s,o=r.ZERO){let i=Io(e,t);for(let c=0;c<i.windows&&s!==Ca;c++){let{nextN:a,offset:f,isZero:l,isNeg:u}=Na(s,c,i);if(s=a,!l){let d=n[f];o=o.add(u?d.negate():d)}}return o},getPrecomputes(e,n,s){let o=Co.get(n);return o||(o=this.precomputeWindow(n,e),e!==1&&Co.set(n,s(o))),o},wNAFCached(e,n,s){let o=No(e);return this.wNAF(o,this.getPrecomputes(o,e,s),n)},wNAFCachedUnsafe(e,n,s,o){let i=No(e);return i===1?this.unsafeLadder(e,n,o):this.wNAFUnsafe(i,this.getPrecomputes(i,e,s),n,o)},setWindowSize(e,n){Ua(n,t),Ta.set(e,n),Co.delete(e)}}}function Cn(r,t,e,n){Uf(e,r),Tf(n,t);let s=e.length,o=n.length;if(s!==o)throw new Error("arrays of points and scalars must have equal length");let i=r.ZERO,c=ba(BigInt(s)),a=1;c>12?a=c-3:c>4?a=c-2:c>0&&(a=2);let f=_e(a),l=new Array(Number(f)+1).fill(i),u=Math.floor((t.BITS-1)/a)*a,d=i;for(let b=u;b>=0;b-=a){l.fill(i);for(let g=0;g<o;g++){let N=n[g],I=Number(N>>BigInt(b)&f);l[I]=l[I].add(e[g])}let y=i;for(let g=l.length-1,N=i;g>0;g--)N=N.add(l[g]),y=y.add(N);if(d=d.add(y),b!==0)for(let g=0;g<a;g++)d=d.double()}return d}function Kr(r){return Bo(r.Fp),Jt(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...Ao(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Ft=BigInt(0),yt=BigInt(1),La=BigInt(2),Lf=BigInt(8),_f={zip215:!0};function Rf(r){let t=Kr(r);return Jt(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function _a(r){let t=Rf(r),{Fp:e,n,prehash:s,hash:o,randomBytes:i,nByteLength:c,h:a}=t,f=La<<BigInt(c*8)-yt,l=e.create,u=Xt(t.n,t.nBitLength);function d(v,p){let m=e.sqr(v),A=e.sqr(p),R=e.add(e.mul(t.a,m),A),O=e.add(e.ONE,e.mul(t.d,e.mul(m,A)));return e.eql(R,O)}if(!d(t.Gx,t.Gy))throw new Error("bad curve params: generator point");let b=t.uvRatio||((v,p)=>{try{return{isValid:!0,value:e.sqrt(v*e.inv(p))}}catch{return{isValid:!1,value:Ft}}}),y=t.adjustScalarBytes||(v=>v),g=t.domain||((v,p,m)=>{if(Mt("phflag",m),p.length||m)throw new Error("Contexts/pre-hash are not supported");return v});function N(v,p,m=!1){let A=m?yt:Ft;Ct("coordinate "+v,p,A,f)}function I(v){if(!(v instanceof h))throw new Error("ExtendedPoint expected")}let M=or((v,p)=>{let{ex:m,ey:A,ez:R}=v,O=v.is0();p==null&&(p=O?Lf:e.inv(R));let F=l(m*p),j=l(A*p),$=l(R*p);if(O)return{x:Ft,y:yt};if($!==yt)throw new Error("invZ was invalid");return{x:F,y:j}}),x=or(v=>{let{a:p,d:m}=t;if(v.is0())throw new Error("bad point: ZERO");let{ex:A,ey:R,ez:O,et:F}=v,j=l(A*A),$=l(R*R),z=l(O*O),tt=l(z*z),X=l(j*p),it=l(z*l(X+$)),xt=l(tt+l(m*l(j*$)));if(it!==xt)throw new Error("bad point: equation left != right (1)");let nt=l(A*R),ut=l(O*F);if(nt!==ut)throw new Error("bad point: equation left != right (2)");return!0});class h{constructor(p,m,A,R){N("x",p),N("y",m),N("z",A,!0),N("t",R),this.ex=p,this.ey=m,this.ez=A,this.et=R,Object.freeze(this)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(p){if(p instanceof h)throw new Error("extended point not allowed");let{x:m,y:A}=p||{};return N("x",m),N("y",A),new h(m,A,yt,l(m*A))}static normalizeZ(p){let m=ir(e,p.map(A=>A.ez));return p.map((A,R)=>A.toAffine(m[R])).map(h.fromAffine)}static msm(p,m){return Cn(h,u,p,m)}_setWindowSize(p){C.setWindowSize(this,p)}assertValidity(){x(this)}equals(p){I(p);let{ex:m,ey:A,ez:R}=this,{ex:O,ey:F,ez:j}=p,$=l(m*j),z=l(O*R),tt=l(A*j),X=l(F*R);return $===z&&tt===X}is0(){return this.equals(h.ZERO)}negate(){return new h(l(-this.ex),this.ey,this.ez,l(-this.et))}double(){let{a:p}=t,{ex:m,ey:A,ez:R}=this,O=l(m*m),F=l(A*A),j=l(La*l(R*R)),$=l(p*O),z=m+A,tt=l(l(z*z)-O-F),X=$+F,it=X-j,xt=$-F,nt=l(tt*it),ut=l(X*xt),kt=l(tt*xt),Lt=l(it*X);return new h(nt,ut,Lt,kt)}add(p){I(p);let{a:m,d:A}=t,{ex:R,ey:O,ez:F,et:j}=this,{ex:$,ey:z,ez:tt,et:X}=p,it=l(R*$),xt=l(O*z),nt=l(j*A*X),ut=l(F*tt),kt=l((R+O)*($+z)-it-xt),Lt=ut-nt,wr=ut+nt,bi=l(xt-m*it),Vl=l(kt*Lt),Pl=l(wr*bi),Ml=l(kt*bi),Fl=l(Lt*wr);return new h(Vl,Pl,Fl,Ml)}subtract(p){return this.add(p.negate())}wNAF(p){return C.wNAFCached(this,p,h.normalizeZ)}multiply(p){let m=p;Ct("scalar",m,yt,n);let{p:A,f:R}=this.wNAF(m);return h.normalizeZ([A,R])[0]}multiplyUnsafe(p,m=h.ZERO){let A=p;return Ct("scalar",A,Ft,n),A===Ft?k:this.is0()||A===yt?this:C.wNAFCachedUnsafe(this,A,h.normalizeZ,m)}isSmallOrder(){return this.multiplyUnsafe(a).is0()}isTorsionFree(){return C.unsafeLadder(this,n).is0()}toAffine(p){return M(this,p)}clearCofactor(){let{h:p}=t;return p===yt?this:this.multiplyUnsafe(p)}static fromHex(p,m=!1){let{d:A,a:R}=t,O=e.BYTES;p=Z("pointHex",p,O),Mt("zip215",m);let F=p.slice(),j=p[O-1];F[O-1]=j&-129;let $=Te(F),z=m?f:e.ORDER;Ct("pointHex.y",$,Ft,z);let tt=l($*$),X=l(tt-yt),it=l(A*tt-R),{isValid:xt,value:nt}=b(X,it);if(!xt)throw new Error("Point.fromHex: invalid y coordinate");let ut=(nt&yt)===yt,kt=(j&128)!==0;if(!m&&nt===Ft&&kt)throw new Error("Point.fromHex: x=0 and x_0=1");return kt!==ut&&(nt=l(-nt)),h.fromAffine({x:nt,y:$})}static fromPrivateKey(p){let{scalar:m}=V(p);return w.multiply(m)}toRawBytes(){let{x:p,y:m}=this.toAffine(),A=sr(m,e.BYTES);return A[A.length-1]|=p&yt?128:0,A}toHex(){return ge(this.toRawBytes())}}h.BASE=new h(t.Gx,t.Gy,yt,l(t.Gx*t.Gy)),h.ZERO=new h(Ft,yt,yt,Ft);let{BASE:w,ZERO:k}=h,C=In(h,c*8);function U(v){return W(v,n)}function H(v){return U(Te(v))}function V(v){let p=e.BYTES;v=Z("private key",v,p);let m=Z("hashed private key",o(v),2*p),A=y(m.slice(0,p)),R=m.slice(p,2*p),O=H(A);return{head:A,prefix:R,scalar:O}}function _(v){let{head:p,prefix:m,scalar:A}=V(v),R=w.multiply(A),O=R.toRawBytes();return{head:p,prefix:m,scalar:A,point:R,pointBytes:O}}function K(v){return _(v).pointBytes}function D(v=Uint8Array.of(),...p){let m=me(...p);return H(o(g(m,Z("context",v),!!s)))}function Q(v,p,m={}){v=Z("message",v),s&&(v=s(v));let{prefix:A,scalar:R,pointBytes:O}=_(p),F=D(m.context,A,v),j=w.multiply(F).toRawBytes(),$=D(m.context,j,O,v),z=U(F+$*R);Ct("signature.s",z,Ft,n);let tt=me(j,sr(z,e.BYTES));return Z("result",tt,e.BYTES*2)}let B=_f;function E(v,p,m,A=B){let{context:R,zip215:O}=A,F=e.BYTES;v=Z("signature",v,2*F),p=Z("message",p),m=Z("publicKey",m,F),O!==void 0&&Mt("zip215",O),s&&(p=s(p));let j=Te(v.slice(F,2*F)),$,z,tt;try{$=h.fromHex(m,O),z=h.fromHex(v.slice(0,F),O),tt=w.multiplyUnsafe(j)}catch{return!1}if(!O&&$.isSmallOrder())return!1;let X=D(R,z.toRawBytes(),$.toRawBytes(),p);return z.add($.multiplyUnsafe(X)).subtract(tt).clearCofactor().equals(h.ZERO)}return w._setWindowSize(8),{CURVE:t,getPublicKey:K,sign:Q,verify:E,ExtendedPoint:h,utils:{getExtendedPublicKey:_,randomPrivateKey:()=>i(e.BYTES),precompute(v=8,p=h.BASE){return p._setWindowSize(v),p.multiply(BigInt(3)),p}}}}var To=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),Ra=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),Up=BigInt(0),Df=BigInt(1),Da=BigInt(2),Tp=BigInt(3),Hf=BigInt(5),Kf=BigInt(8);function Of(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),s=BigInt(80),o=To,c=r*r%o*r%o,a=Y(c,Da,o)*c%o,f=Y(a,Df,o)*r%o,l=Y(f,Hf,o)*f%o,u=Y(l,t,o)*l%o,d=Y(u,e,o)*u%o,b=Y(d,n,o)*d%o,y=Y(b,s,o)*b%o,g=Y(y,s,o)*b%o,N=Y(g,t,o)*l%o;return{pow_p_5_8:Y(N,Da,o)*r%o,b2:c}}function Vf(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function Pf(r,t){let e=To,n=W(t*t*t,e),s=W(n*n*t,e),o=Of(r*s).pow_p_5_8,i=W(r*n*o,e),c=W(t*i*i,e),a=i,f=W(i*Ra,e),l=c===r,u=c===W(-r,e),d=c===W(-r*Ra,e);return l&&(i=a),(u||d)&&(i=f),Sa(i,e)&&(i=W(-i,e)),{isValid:l||u,value:i}}var Ha=Xt(To,void 0,!0),Mf={a:Ha.create(BigInt(-1)),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:Ha,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:Kf,Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:An,randomBytes:rr,adjustScalarBytes:Vf,uvRatio:Pf},Lo=_a(Mf);var ar=32,Kt=64,Ff=32;function Ka(r,t){let e=r.subarray(0,Ff);return Lo.sign(t instanceof Uint8Array?t:t.subarray(),e)}function Oa(r,t,e){return Lo.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}var Nn=class{type="Ed25519";raw;constructor(t){this.raw=Vr(t,ar)}toMultihash(){return Ae.digest(Qe(this))}toCID(){return Ut.createV1(114,this.toMultihash())}toString(){return et.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:Et(this.raw,t.raw)}verify(t,e){return Oa(this.raw,e,t)}},Or=class{type="Ed25519";raw;publicKey;constructor(t,e){this.raw=Vr(t,Kt),this.publicKey=new Nn(e)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:Et(this.raw,t.raw)}sign(t){return Ka(this.raw,t)}};function _o(r){if(r.length>Kt){r=Vr(r,Kt+ar);let n=r.subarray(0,Kt),s=r.subarray(Kt,r.length);return new Or(n,s)}r=Vr(r,Kt);let t=r.subarray(0,Kt),e=r.subarray(ar);return new Or(t,e)}function Vr(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 qf=Math.pow(2,7),jf=Math.pow(2,14),$f=Math.pow(2,21),Pa=Math.pow(2,28),Ma=Math.pow(2,35),Fa=Math.pow(2,42),qa=Math.pow(2,49),bt=128,ye=127;function Pr(r){if(r<qf)return 1;if(r<jf)return 2;if(r<$f)return 3;if(r<Pa)return 4;if(r<Ma)return 5;if(r<Fa)return 6;if(r<qa)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function ja(r,t,e=0){switch(Pr(r)){case 8:t[e++]=r&255|bt,r/=128;case 7:t[e++]=r&255|bt,r/=128;case 6:t[e++]=r&255|bt,r/=128;case 5:t[e++]=r&255|bt,r/=128;case 4:t[e++]=r&255|bt,r>>>=7;case 3:t[e++]=r&255|bt,r>>>=7;case 2:t[e++]=r&255|bt,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function $a(r,t){let e=r[t],n=0;if(n+=e&ye,e<bt||(e=r[t+1],n+=(e&ye)<<7,e<bt)||(e=r[t+2],n+=(e&ye)<<14,e<bt)||(e=r[t+3],n+=(e&ye)<<21,e<bt)||(e=r[t+4],n+=(e&ye)*Pa,e<bt)||(e=r[t+5],n+=(e&ye)*Ma,e<bt)||(e=r[t+6],n+=(e&ye)*Fa,e<bt)||(e=r[t+7],n+=(e&ye)*qa,e<bt))return n;throw new RangeError("Could not decode varint")}var Ro=new Float32Array([-0]),be=new Uint8Array(Ro.buffer);function Ga(r,t,e){Ro[0]=r,t[e]=be[0],t[e+1]=be[1],t[e+2]=be[2],t[e+3]=be[3]}function za(r,t){return be[0]=r[t],be[1]=r[t+1],be[2]=r[t+2],be[3]=r[t+3],Ro[0]}var Do=new Float64Array([-0]),ft=new Uint8Array(Do.buffer);function Wa(r,t,e){Do[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 Za(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],Do[0]}var Gf=BigInt(Number.MAX_SAFE_INTEGER),zf=BigInt(Number.MIN_SAFE_INTEGER),Nt=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<Gf&&t>zf)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>Ya&&(s=0n,++n>Ya&&(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 Nt(0,0);De.toBigInt=function(){return 0n};De.zzEncode=De.zzDecode=function(){return this};De.length=function(){return 1};var Ya=4294967296n;function Ja(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 Xa(r,t,e){if(e-t<1)return"";let s,o=[],i=0,c;for(;t<e;)c=r[t++],c<128?o[i++]=c:c>191&&c<224?o[i++]=(c&31)<<6|r[t++]&63:c>239&&c<365?(c=((c&7)<<18|(r[t++]&63)<<12|(r[t++]&63)<<6|r[t++]&63)-65536,o[i++]=55296+(c>>10),o[i++]=56320+(c&1023)):o[i++]=(c&15)<<12|(r[t++]&63)<<6|r[t++]&63,i>8191&&((s??(s=[])).push(String.fromCharCode.apply(String,o)),i=0);return s!=null?(i>0&&s.push(String.fromCharCode.apply(String,o.slice(0,i))),s.join("")):String.fromCharCode.apply(String,o.slice(0,i))}function Ho(r,t,e){let n=e,s,o;for(let i=0;i<r.length;++i)s=r.charCodeAt(i),s<128?t[e++]=s:s<2048?(t[e++]=s>>6|192,t[e++]=s&63|128):(s&64512)===55296&&((o=r.charCodeAt(i+1))&64512)===56320?(s=65536+((s&1023)<<10)+(o&1023),++i,t[e++]=s>>18|240,t[e++]=s>>12&63|128,t[e++]=s>>6&63|128,t[e++]=s&63|128):(t[e++]=s>>12|224,t[e++]=s>>6&63|128,t[e++]=s&63|128);return e-n}function Ot(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function Un(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var Ko=class{buf;pos;len;_slice=Uint8Array.prototype.subarray;constructor(t){this.buf=t,this.pos=0,this.len=t.length}uint32(){let t=4294967295;if(t=(this.buf[this.pos]&127)>>>0,this.buf[this.pos++]<128||(t=(t|(this.buf[this.pos]&127)<<7)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<14)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<21)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&15)<<28)>>>0,this.buf[this.pos++]<128))return t;if((this.pos+=5)>this.len)throw this.pos=this.len,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 Un(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Ot(this,4);return Un(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Ot(this,4);let t=za(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Ot(this,4);let t=Za(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 Xa(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 Nt(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=Un(this.buf,this.pos+=4),e=Un(this.buf,this.pos+=4);return new Nt(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=$a(this.buf,this.pos);return this.pos+=Pr(t),t}uint64String(){return this.readLongVarint().toString(!0)}sint64(){return this.readLongVarint().zzDecode().toBigInt()}sint64Number(){return this.readLongVarint().zzDecode().toNumber()}sint64String(){return this.readLongVarint().zzDecode().toString()}fixed64(){return this.readFixed64().toBigInt()}fixed64Number(){return this.readFixed64().toNumber()}fixed64String(){return this.readFixed64().toString()}sfixed64(){return this.readFixed64().toBigInt()}sfixed64Number(){return this.readFixed64().toNumber()}sfixed64String(){return this.readFixed64().toString()}};function Oo(r){return new Ko(r instanceof Uint8Array?r:r.subarray())}function Tn(r,t,e){let n=Oo(r);return t.decode(n,void 0,e)}function Vo(r){let t=r??8192,e=t>>>1,n,s=t;return function(i){if(i<1||i>e)return It(i);s+i>t&&(n=It(t),s=0);let c=n.subarray(s,s+=i);return(s&7)!==0&&(s=(s|7)+1),c}}var He=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function Po(){}var Fo=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},Wf=Vo();function Zf(r){return globalThis.Buffer!=null?It(r):Wf(r)}var Fr=class{len;head;tail;states;constructor(){this.len=0,this.head=new He(Po,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new He(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new qo((t=t>>>0)<128?1:t<16384?2:t<2097152?3:t<268435456?4:5,t)).len,this}int32(t){return t<0?this._push(Ln,10,Nt.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=Nt.fromBigInt(t);return this._push(Ln,e.length(),e)}uint64Number(t){return this._push(ja,Pr(t),t)}uint64String(t){return this.uint64(BigInt(t))}int64(t){return this.uint64(t)}int64Number(t){return this.uint64Number(t)}int64String(t){return this.uint64String(t)}sint64(t){let e=Nt.fromBigInt(t).zzEncode();return this._push(Ln,e.length(),e)}sint64Number(t){let e=Nt.fromNumber(t).zzEncode();return this._push(Ln,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(Mo,1,t?1:0)}fixed32(t){return this._push(Mr,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=Nt.fromBigInt(t);return this._push(Mr,4,e.lo)._push(Mr,4,e.hi)}fixed64Number(t){let e=Nt.fromNumber(t);return this._push(Mr,4,e.lo)._push(Mr,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(Ga,4,t)}double(t){return this._push(Wa,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(Mo,1,0):this.uint32(e)._push(Jf,e,t)}string(t){let e=Ja(t);return e!==0?this.uint32(e)._push(Ho,e,t):this._push(Mo,1,0)}fork(){return this.states=new Fo(this),this.head=this.tail=new He(Po,0,0),this.len=0,this}reset(){return this.states!=null?(this.head=this.states.head,this.tail=this.states.tail,this.len=this.states.len,this.states=this.states.next):(this.head=this.tail=new He(Po,0,0),this.len=0),this}ldelim(){let t=this.head,e=this.tail,n=this.len;return this.reset().uint32(n),n!==0&&(this.tail.next=t.next,this.tail=e,this.len+=n),this}finish(){let t=this.head.next,e=Zf(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function Mo(r,t,e){t[e]=r&255}function Yf(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var qo=class extends He{next;constructor(t,e){super(Yf,t,e),this.next=void 0}};function Ln(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 Mr(r,t,e){t[e]=r&255,t[e+1]=r>>>8&255,t[e+2]=r>>>16&255,t[e+3]=r>>>24}function Jf(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(Fr.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(Xf,t,r),this},Fr.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(Qf,t,r),this});function Xf(r,t,e){t.set(r,e)}function Qf(r,t,e){r.length<40?Ho(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(P(r),e)}function jo(){return new Fr}function _n(r,t){let e=jo();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 Rn(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function $o(r){function t(s){if(r[s.toString()]==null)throw new Error("Invalid enum value");return r[s]}let e=function(o,i){let c=t(o);i.int32(c)},n=function(o){let i=o.int32();return t(i)};return Rn("enum",cr.VARINT,e,n)}function Dn(r,t){return Rn("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 Go;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1",r[r.ECDSA=3]="ECDSA"})(Go||(Go={}));(function(r){r.codec=()=>$o(Go)})(rt||(rt={}));var we;(function(r){let t;r.codec=()=>(t==null&&(t=Dn((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 c=e.uint32();switch(c>>>3){case 1:{o.Type=rt.codec().decode(e);break}case 2:{o.Data=e.bytes();break}default:{e.skipType(c&7);break}}}return o})),t),r.encode=e=>_n(e,r.codec()),r.decode=(e,n)=>Tn(e,r.codec(),n)})(we||(we={}));var qr;(function(r){let t;r.codec=()=>(t==null&&(t=Dn((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 c=e.uint32();switch(c>>>3){case 1:{o.Type=rt.codec().decode(e);break}case 2:{o.Data=e.bytes();break}default:{e.skipType(c&7);break}}}return o})),t),r.encode=e=>_n(e,r.codec()),r.decode=(e,n)=>Tn(e,r.codec(),n)})(qr||(qr={}));function Ke(r){if(isNaN(r)||r<=0)throw new L("random bytes length must be a Number bigger than 0");return rr(r)}var $r={};dt($r,{MAX_RSA_KEY_SIZE:()=>zo,generateRSAKeyPair:()=>sc,jwkToJWKKeyPair:()=>oc,jwkToPkcs1:()=>nh,jwkToPkix:()=>Jo,jwkToRSAPrivateKey:()=>ti,pkcs1MessageToJwk:()=>Zo,pkcs1MessageToRSAPrivateKey:()=>Hn,pkcs1ToJwk:()=>rh,pkcs1ToRSAPrivateKey:()=>Xo,pkixMessageToJwk:()=>Yo,pkixMessageToRSAPublicKey:()=>Qo,pkixToJwk:()=>sh,pkixToRSAPublicKey:()=>nc});var lr=Bn;var ur=class{type="RSA";jwk;_raw;_multihash;constructor(t,e){this.jwk=t,this._multihash=e}get raw(){return this._raw==null&&(this._raw=$r.jwkToPkix(this.jwk)),this._raw}toMultihash(){return this._multihash}toCID(){return Ut.createV1(114,this._multihash)}toString(){return et.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:Et(this.raw,t.raw)}verify(t,e){return rc(this.jwk,e,t)}},jr=class{type="RSA";jwk;_raw;publicKey;constructor(t,e){this.jwk=t,this.publicKey=e}get raw(){return this._raw==null&&(this._raw=$r.jwkToPkcs1(this.jwk)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:Et(this.raw,t.raw)}sign(t){return ec(this.jwk,t)}};var zo=8192,Wo=18,th=1062,eh=Uint8Array.from([48,13,6,9,42,134,72,134,247,13,1,1,1,5,0]);function rh(r){let t=Rt(r);return Zo(t)}function Zo(r){return{n:G(r[1],"base64url"),e:G(r[2],"base64url"),d:G(r[3],"base64url"),p:G(r[4],"base64url"),q:G(r[5],"base64url"),dp:G(r[6],"base64url"),dq:G(r[7],"base64url"),qi:G(r[8],"base64url"),kty:"RSA"}}function nh(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 Dt([gt(Uint8Array.from([0])),gt(P(r.n,"base64url")),gt(P(r.e,"base64url")),gt(P(r.d,"base64url")),gt(P(r.p,"base64url")),gt(P(r.q,"base64url")),gt(P(r.dp,"base64url")),gt(P(r.dq,"base64url")),gt(P(r.qi,"base64url"))]).subarray()}function sh(r){let t=Rt(r,{offset:0});return Yo(t)}function Yo(r){let t=Rt(r[1],{offset:0});return{kty:"RSA",n:G(t[0],"base64url"),e:G(t[1],"base64url")}}function Jo(r){if(r.n==null||r.e==null)throw new L("JWK was missing components");return Dt([eh,Ur(Dt([gt(P(r.n,"base64url")),gt(P(r.e,"base64url"))]))]).subarray()}function Xo(r){let t=Rt(r);return Hn(t)}function Hn(r){let t=Zo(r);return ti(t)}function nc(r,t){if(r.byteLength>=th)throw new qe("Key size is too large");let e=Rt(r,{offset:0});return Qo(e,r,t)}function Qo(r,t,e){let n=Yo(r);if(e==null){let s=lr(we.encode({Type:rt.RSA,Data:t}));e=_t(Wo,s)}return new ur(n,e)}function ti(r){if(ac(r)>zo)throw new L("Key size is too large");let t=oc(r),e=lr(we.encode({Type:rt.RSA,Data:Jo(t.publicKey)})),n=_t(Wo,e);return new jr(t.privateKey,new ur(t.publicKey,n))}async function sc(r){if(r>zo)throw new L("Key size is too large");let t=await ic(r),e=lr(we.encode({Type:rt.RSA,Data:Jo(t.publicKey)})),n=_t(Wo,e);return new jr(t.privateKey,new ur(t.publicKey,n))}function oc(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 ic(r){let t=await vt.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 oh(t);return{privateKey:e[0],publicKey:e[1]}}async function ec(r,t){let e=await vt.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await vt.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},e,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(n,0,n.byteLength)}async function rc(r,t,e){let n=await vt.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return vt.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,t,e instanceof Uint8Array?e:e.subarray())}async function oh(r){if(r.privateKey==null||r.publicKey==null)throw new L("Private and public key are required");return Promise.all([vt.get().subtle.exportKey("jwk",r.privateKey),vt.get().subtle.exportKey("jwk",r.publicKey)])}function ac(r){if(r.kty!=="RSA")throw new L("invalid key type");if(r.n==null)throw new L("invalid key modulus");return P(r.n,"base64url").length*8}var Kn=class extends tr{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,mn(t);let n=Tr(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),Bt(o)}update(t){return er(this),this.iHash.update(t),this}digestInto(t){er(this),fe(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:c}=this;return t=t,t.finished=s,t.destroyed=o,t.blockLen=i,t.outputLen=c,t.oHash=e._cloneInto(t.oHash),t.iHash=n._cloneInto(t.iHash),t}clone(){return this._cloneInto()}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},Gr=(r,t,e)=>new Kn(r,t).update(e).digest();Gr.create=(r,t)=>new Kn(r,t);function cc(r){r.lowS!==void 0&&Mt("lowS",r.lowS),r.prehash!==void 0&&Mt("prehash",r.prehash)}function ih(r){let t=Kr(r);Jt(t,{a:"field",b:"field"},{allowInfinityPoint:"boolean",allowedPrivateKeyLengths:"array",clearCofactor:"function",fromBytes:"function",isTorsionFree:"function",toBytes:"function",wrapPrivateKey:"boolean"});let{endo:e,Fp:n,a:s}=t;if(e){if(!n.eql(s,n.ZERO))throw new Error("invalid endo: CURVE.a must be 0");if(typeof e!="object"||typeof e.beta!="bigint"||typeof e.splitScalar!="function")throw new Error('invalid endo: expected "beta": bigint and "splitScalar": function')}return Object.freeze({...t})}var ni=class extends Error{constructor(t=""){super(t)}},Qt={Err:ni,_tlv:{encode:(r,t)=>{let{Err:e}=Qt;if(r<0||r>256)throw new e("tlv.encode: wrong tag");if(t.length&1)throw new e("tlv.encode: unpadded data");let n=t.length/2,s=Dr(n);if(s.length/2&128)throw new e("tlv.encode: long form length too big");let o=n>127?Dr(s.length/2|128):"";return Dr(r)+o+s+t},decode(r,t){let{Err:e}=Qt,n=0;if(r<0||r>256)throw new e("tlv.encode: wrong tag");if(t.length<2||t[n++]!==r)throw new e("tlv.decode: wrong tlv");let s=t[n++],o=!!(s&128),i=0;if(!o)i=s;else{let a=s&127;if(!a)throw new e("tlv.decode(long): indefinite length not supported");if(a>4)throw new e("tlv.decode(long): byte length is too big");let f=t.subarray(n,n+a);if(f.length!==a)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+=a,i<128)throw new e("tlv.decode(long): not minimal encoding")}let c=t.subarray(n,n+i);if(c.length!==i)throw new e("tlv.decode: wrong value length");return{v:c,l:t.subarray(n+i)}}},_int:{encode(r){let{Err:t}=Qt;if(r<te)throw new t("integer: negative integers are not allowed");let e=Dr(r);if(Number.parseInt(e[0],16)&8&&(e="00"+e),e.length&1)throw new t("unexpected DER parsing assertion: unpadded hex");return e},decode(r){let{Err:t}=Qt;if(r[0]&128)throw new t("invalid signature integer: negative");if(r[0]===0&&!(r[1]&128))throw new t("invalid signature integer: unnecessary leading zero");return Yt(r)}},toSig(r){let{Err:t,_int:e,_tlv:n}=Qt,s=Z("signature",r),{v:o,l:i}=n.decode(48,s);if(i.length)throw new t("invalid signature: left bytes after parsing");let{v:c,l:a}=n.decode(2,o),{v:f,l}=n.decode(2,a);if(l.length)throw new t("invalid signature: left bytes after parsing");return{r:e.decode(c),s:e.decode(f)}},hexFromSig(r){let{_tlv:t,_int:e}=Qt,n=t.encode(2,e.encode(r.r)),s=t.encode(2,e.encode(r.s)),o=n+s;return t.encode(48,o)}};function ei(r,t){return ge(Le(r,t))}var te=BigInt(0),ot=BigInt(1),nm=BigInt(2),ri=BigInt(3),ah=BigInt(4);function ch(r){let t=ih(r),{Fp:e}=t,n=Xt(t.n,t.nBitLength),s=t.toBytes||((x,h,w)=>{let k=h.toAffine();return me(Uint8Array.from([4]),e.toBytes(k.x),e.toBytes(k.y))}),o=t.fromBytes||(x=>{let h=x.subarray(1),w=e.fromBytes(h.subarray(0,e.BYTES)),k=e.fromBytes(h.subarray(e.BYTES,2*e.BYTES));return{x:w,y:k}});function i(x){let{a:h,b:w}=t,k=e.sqr(x),C=e.mul(k,x);return e.add(e.add(C,e.mul(x,h)),w)}function c(x,h){let w=e.sqr(h),k=i(x);return e.eql(w,k)}if(!c(t.Gx,t.Gy))throw new Error("bad curve params: generator point");let a=e.mul(e.pow(t.a,ri),ah),f=e.mul(e.sqr(t.b),BigInt(27));if(e.is0(e.add(a,f)))throw new Error("bad curve params: a or b");function l(x){return Sn(x,ot,t.n)}function u(x){let{allowedPrivateKeyLengths:h,nByteLength:w,wrapPrivateKey:k,n:C}=t;if(h&&typeof x!="bigint"){if(nr(x)&&(x=ge(x)),typeof x!="string"||!h.includes(x.length))throw new Error("invalid private key");x=x.padStart(w*2,"0")}let U;try{U=typeof x=="bigint"?x:Yt(Z("private key",x,w))}catch{throw new Error("invalid private key, expected hex or "+w+" bytes, got "+typeof x)}return k&&(U=W(U,C)),Ct("private key",U,ot,C),U}function d(x){if(!(x instanceof g))throw new Error("ProjectivePoint expected")}let b=or((x,h)=>{let{px:w,py:k,pz:C}=x;if(e.eql(C,e.ONE))return{x:w,y:k};let U=x.is0();h==null&&(h=U?e.ONE:e.inv(C));let H=e.mul(w,h),V=e.mul(k,h),_=e.mul(C,h);if(U)return{x:e.ZERO,y:e.ZERO};if(!e.eql(_,e.ONE))throw new Error("invZ was invalid");return{x:H,y:V}}),y=or(x=>{if(x.is0()){if(t.allowInfinityPoint&&!e.is0(x.py))return;throw new Error("bad point: ZERO")}let{x:h,y:w}=x.toAffine();if(!e.isValid(h)||!e.isValid(w))throw new Error("bad point: x or y not FE");if(!c(h,w))throw new Error("bad point: equation left != right");if(!x.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});class g{constructor(h,w,k){if(h==null||!e.isValid(h))throw new Error("x required");if(w==null||!e.isValid(w)||e.is0(w))throw new Error("y required");if(k==null||!e.isValid(k))throw new Error("z required");this.px=h,this.py=w,this.pz=k,Object.freeze(this)}static fromAffine(h){let{x:w,y:k}=h||{};if(!h||!e.isValid(w)||!e.isValid(k))throw new Error("invalid affine point");if(h instanceof g)throw new Error("projective point not allowed");let C=U=>e.eql(U,e.ZERO);return C(w)&&C(k)?g.ZERO:new g(w,k,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(h){let w=ir(e,h.map(k=>k.pz));return h.map((k,C)=>k.toAffine(w[C])).map(g.fromAffine)}static fromHex(h){let w=g.fromAffine(o(Z("pointHex",h)));return w.assertValidity(),w}static fromPrivateKey(h){return g.BASE.multiply(u(h))}static msm(h,w){return Cn(g,n,h,w)}_setWindowSize(h){M.setWindowSize(this,h)}assertValidity(){y(this)}hasEvenY(){let{y:h}=this.toAffine();if(e.isOdd)return!e.isOdd(h);throw new Error("Field doesn't support isOdd")}equals(h){d(h);let{px:w,py:k,pz:C}=this,{px:U,py:H,pz:V}=h,_=e.eql(e.mul(w,V),e.mul(U,C)),K=e.eql(e.mul(k,V),e.mul(H,C));return _&&K}negate(){return new g(this.px,e.neg(this.py),this.pz)}double(){let{a:h,b:w}=t,k=e.mul(w,ri),{px:C,py:U,pz:H}=this,V=e.ZERO,_=e.ZERO,K=e.ZERO,D=e.mul(C,C),Q=e.mul(U,U),B=e.mul(H,H),E=e.mul(C,U);return E=e.add(E,E),K=e.mul(C,H),K=e.add(K,K),V=e.mul(h,K),_=e.mul(k,B),_=e.add(V,_),V=e.sub(Q,_),_=e.add(Q,_),_=e.mul(V,_),V=e.mul(E,V),K=e.mul(k,K),B=e.mul(h,B),E=e.sub(D,B),E=e.mul(h,E),E=e.add(E,K),K=e.add(D,D),D=e.add(K,D),D=e.add(D,B),D=e.mul(D,E),_=e.add(_,D),B=e.mul(U,H),B=e.add(B,B),D=e.mul(B,E),V=e.sub(V,D),K=e.mul(B,Q),K=e.add(K,K),K=e.add(K,K),new g(V,_,K)}add(h){d(h);let{px:w,py:k,pz:C}=this,{px:U,py:H,pz:V}=h,_=e.ZERO,K=e.ZERO,D=e.ZERO,Q=t.a,B=e.mul(t.b,ri),E=e.mul(w,U),T=e.mul(k,H),v=e.mul(C,V),p=e.add(w,k),m=e.add(U,H);p=e.mul(p,m),m=e.add(E,T),p=e.sub(p,m),m=e.add(w,C);let A=e.add(U,V);return m=e.mul(m,A),A=e.add(E,v),m=e.sub(m,A),A=e.add(k,C),_=e.add(H,V),A=e.mul(A,_),_=e.add(T,v),A=e.sub(A,_),D=e.mul(Q,m),_=e.mul(B,v),D=e.add(_,D),_=e.sub(T,D),D=e.add(T,D),K=e.mul(_,D),T=e.add(E,E),T=e.add(T,E),v=e.mul(Q,v),m=e.mul(B,m),T=e.add(T,v),v=e.sub(E,v),v=e.mul(Q,v),m=e.add(m,v),E=e.mul(T,m),K=e.add(K,E),E=e.mul(A,m),_=e.mul(p,_),_=e.sub(_,E),E=e.mul(p,T),D=e.mul(A,D),D=e.add(D,E),new g(_,K,D)}subtract(h){return this.add(h.negate())}is0(){return this.equals(g.ZERO)}wNAF(h){return M.wNAFCached(this,h,g.normalizeZ)}multiplyUnsafe(h){let{endo:w,n:k}=t;Ct("scalar",h,te,k);let C=g.ZERO;if(h===te)return C;if(this.is0()||h===ot)return this;if(!w||M.hasPrecomputes(this))return M.wNAFCachedUnsafe(this,h,g.normalizeZ);let{k1neg:U,k1:H,k2neg:V,k2:_}=w.splitScalar(h),K=C,D=C,Q=this;for(;H>te||_>te;)H&ot&&(K=K.add(Q)),_&ot&&(D=D.add(Q)),Q=Q.double(),H>>=ot,_>>=ot;return U&&(K=K.negate()),V&&(D=D.negate()),D=new g(e.mul(D.px,w.beta),D.py,D.pz),K.add(D)}multiply(h){let{endo:w,n:k}=t;Ct("scalar",h,ot,k);let C,U;if(w){let{k1neg:H,k1:V,k2neg:_,k2:K}=w.splitScalar(h),{p:D,f:Q}=this.wNAF(V),{p:B,f:E}=this.wNAF(K);D=M.constTimeNegate(H,D),B=M.constTimeNegate(_,B),B=new g(e.mul(B.px,w.beta),B.py,B.pz),C=D.add(B),U=Q.add(E)}else{let{p:H,f:V}=this.wNAF(h);C=H,U=V}return g.normalizeZ([C,U])[0]}multiplyAndAddUnsafe(h,w,k){let C=g.BASE,U=(V,_)=>_===te||_===ot||!V.equals(C)?V.multiplyUnsafe(_):V.multiply(_),H=U(this,w).add(U(h,k));return H.is0()?void 0:H}toAffine(h){return b(this,h)}isTorsionFree(){let{h,isTorsionFree:w}=t;if(h===ot)return!0;if(w)return w(g,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h,clearCofactor:w}=t;return h===ot?this:w?w(g,this):this.multiplyUnsafe(t.h)}toRawBytes(h=!0){return Mt("isCompressed",h),this.assertValidity(),s(g,this,h)}toHex(h=!0){return Mt("isCompressed",h),ge(this.toRawBytes(h))}}g.BASE=new g(t.Gx,t.Gy,e.ONE),g.ZERO=new g(e.ZERO,e.ONE,e.ZERO);let{endo:N,nBitLength:I}=t,M=In(g,N?Math.ceil(I/2):I);return{CURVE:t,ProjectivePoint:g,normPrivateKeyToScalar:u,weierstrassEquation:i,isWithinCurveOrder:l}}function lh(r){let t=Kr(r);return Jt(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function lc(r){let t=lh(r),{Fp:e,n,nByteLength:s,nBitLength:o}=t,i=e.BYTES+1,c=2*e.BYTES+1;function a(B){return W(B,n)}function f(B){return kn(B,n)}let{ProjectivePoint:l,normPrivateKeyToScalar:u,weierstrassEquation:d,isWithinCurveOrder:b}=ch({...t,toBytes(B,E,T){let v=E.toAffine(),p=e.toBytes(v.x),m=me;return Mt("isCompressed",T),T?m(Uint8Array.from([E.hasEvenY()?2:3]),p):m(Uint8Array.from([4]),p,e.toBytes(v.y))},fromBytes(B){let E=B.length,T=B[0],v=B.subarray(1);if(E===i&&(T===2||T===3)){let p=Yt(v);if(!Sn(p,ot,e.ORDER))throw new Error("Point is not on curve");let m=d(p),A;try{A=e.sqrt(m)}catch(F){let j=F instanceof Error?": "+F.message:"";throw new Error("Point is not on curve"+j)}let R=(A&ot)===ot;return(T&1)===1!==R&&(A=e.neg(A)),{x:p,y:A}}else if(E===c&&T===4){let p=e.fromBytes(v.subarray(0,e.BYTES)),m=e.fromBytes(v.subarray(e.BYTES,2*e.BYTES));return{x:p,y:m}}else{let p=i,m=c;throw new Error("invalid Point, expected length of "+p+", or uncompressed "+m+", got "+E)}}});function y(B){let E=n>>ot;return B>E}function g(B){return y(B)?a(-B):B}let N=(B,E,T)=>Yt(B.slice(E,T));class I{constructor(E,T,v){Ct("r",E,ot,n),Ct("s",T,ot,n),this.r=E,this.s=T,v!=null&&(this.recovery=v),Object.freeze(this)}static fromCompact(E){let T=s;return E=Z("compactSignature",E,T*2),new I(N(E,0,T),N(E,T,2*T))}static fromDER(E){let{r:T,s:v}=Qt.toSig(Z("DER",E));return new I(T,v)}assertValidity(){}addRecoveryBit(E){return new I(this.r,this.s,E)}recoverPublicKey(E){let{r:T,s:v,recovery:p}=this,m=C(Z("msgHash",E));if(p==null||![0,1,2,3].includes(p))throw new Error("recovery id invalid");let A=p===2||p===3?T+t.n:T;if(A>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let R=(p&1)===0?"02":"03",O=l.fromHex(R+ei(A,e.BYTES)),F=f(A),j=a(-m*F),$=a(v*F),z=l.BASE.multiplyAndAddUnsafe(O,j,$);if(!z)throw new Error("point at infinify");return z.assertValidity(),z}hasHighS(){return y(this.s)}normalizeS(){return this.hasHighS()?new I(this.r,a(-this.s),this.recovery):this}toDERRawBytes(){return Hr(this.toDERHex())}toDERHex(){return Qt.hexFromSig(this)}toCompactRawBytes(){return Hr(this.toCompactHex())}toCompactHex(){let E=s;return ei(this.r,E)+ei(this.s,E)}}let M={isValidPrivateKey(B){try{return u(B),!0}catch{return!1}},normPrivateKeyToScalar:u,randomPrivateKey:()=>{let B=So(t.n);return Ia(t.randomBytes(B),t.n)},precompute(B=8,E=l.BASE){return E._setWindowSize(B),E.multiply(BigInt(3)),E}};function x(B,E=!0){return l.fromPrivateKey(B).toRawBytes(E)}function h(B){if(typeof B=="bigint")return!1;if(B instanceof l)return!0;let T=Z("key",B).length,v=e.BYTES,p=v+1,m=2*v+1;if(!(t.allowedPrivateKeyLengths||s===p))return T===p||T===m}function w(B,E,T=!0){if(h(B)===!0)throw new Error("first arg must be private key");if(h(E)===!1)throw new Error("second arg must be public key");return l.fromHex(E).multiply(u(B)).toRawBytes(T)}let k=t.bits2int||function(B){if(B.length>8192)throw new Error("input is too large");let E=Yt(B),T=B.length*8-o;return T>0?E>>BigInt(T):E},C=t.bits2int_modN||function(B){return a(k(B))},U=_e(o);function H(B){return Ct("num < 2^"+o,B,te,U),Le(B,s)}function V(B,E,T=_){if(["recovered","canonical"].some(X=>X in T))throw new Error("sign() legacy options not supported");let{hash:v,randomBytes:p}=t,{lowS:m,prehash:A,extraEntropy:R}=T;m==null&&(m=!0),B=Z("msgHash",B),cc(T),A&&(B=Z("prehashed msgHash",v(B)));let O=C(B),F=u(E),j=[H(F),H(O)];if(R!=null&&R!==!1){let X=R===!0?p(e.BYTES):R;j.push(Z("extraEntropy",X))}let $=me(...j),z=O;function tt(X){let it=k(X);if(!b(it))return;let xt=f(it),nt=l.BASE.multiply(it).toAffine(),ut=a(nt.x);if(ut===te)return;let kt=a(xt*a(z+ut*F));if(kt===te)return;let Lt=(nt.x===ut?0:2)|Number(nt.y&ot),wr=kt;return m&&y(kt)&&(wr=g(kt),Lt^=1),new I(ut,wr,Lt)}return{seed:$,k2sig:tt}}let _={lowS:t.lowS,prehash:!1},K={lowS:t.lowS,prehash:!1};function D(B,E,T=_){let{seed:v,k2sig:p}=V(B,E,T),m=t;return wa(m.hash.outputLen,m.nByteLength,m.hmac)(v,p)}l.BASE._setWindowSize(8);function Q(B,E,T,v=K){let p=B;E=Z("msgHash",E),T=Z("publicKey",T);let{lowS:m,prehash:A,format:R}=v;if(cc(v),"strict"in v)throw new Error("options.strict was renamed to lowS");if(R!==void 0&&R!=="compact"&&R!=="der")throw new Error("format must be compact or der");let O=typeof p=="string"||nr(p),F=!O&&!R&&typeof p=="object"&&p!==null&&typeof p.r=="bigint"&&typeof p.s=="bigint";if(!O&&!F)throw new Error("invalid signature, expected Uint8Array, hex string or Signature instance");let j,$;try{if(F&&(j=new I(p.r,p.s)),O){try{R!=="compact"&&(j=I.fromDER(p))}catch(Lt){if(!(Lt instanceof Qt.Err))throw Lt}!j&&R!=="der"&&(j=I.fromCompact(p))}$=l.fromHex(T)}catch{return!1}if(!j||m&&j.hasHighS())return!1;A&&(E=t.hash(E));let{r:z,s:tt}=j,X=C(E),it=f(tt),xt=a(X*it),nt=a(z*it),ut=l.BASE.multiplyAndAddUnsafe($,xt,nt)?.toAffine();return ut?a(ut.x)===z:!1}return{CURVE:t,getPublicKey:x,getSharedSecret:w,sign:D,verify:Q,ProjectivePoint:l,Signature:I,utils:M}}function uh(r){return{hash:r,hmac:(t,...e)=>Gr(r,t,go(...e)),randomBytes:rr}}function uc(r,t){let e=n=>lc({...r,...uh(n)});return{...e(t),create:e}}var dc=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),fc=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),fh=BigInt(0),hh=BigInt(1),si=BigInt(2),hc=(r,t)=>(r+t/si)/t;function dh(r){let t=dc,e=BigInt(3),n=BigInt(6),s=BigInt(11),o=BigInt(22),i=BigInt(23),c=BigInt(44),a=BigInt(88),f=r*r*r%t,l=f*f*r%t,u=Y(l,e,t)*l%t,d=Y(u,e,t)*l%t,b=Y(d,si,t)*f%t,y=Y(b,s,t)*b%t,g=Y(y,o,t)*y%t,N=Y(g,c,t)*g%t,I=Y(N,a,t)*N%t,M=Y(I,c,t)*g%t,x=Y(M,e,t)*l%t,h=Y(x,i,t)*y%t,w=Y(h,n,t)*f%t,k=Y(w,si,t);if(!oi.eql(oi.sqr(k),r))throw new Error("Cannot find square root");return k}var oi=Xt(dc,void 0,void 0,{sqrt:dh}),qt=uc({a:fh,b:BigInt(7),Fp:oi,n:fc,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=fc,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-hh*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),s=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),o=e,i=BigInt("0x100000000000000000000000000000000"),c=hc(o*r,t),a=hc(-n*r,t),f=W(r-c*e-a*s,t),l=W(-c*n-a*o,t),u=f>i,d=l>i;if(u&&(f=t-f),d&&(l=t-l),f>i||l>i)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:u,k1:f,k2neg:d,k2:l}}}},Bn);function ii(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}var pc=32;function gc(r,t){let e=Je.digest(t instanceof Uint8Array?t:t.subarray());if(ii(e))return e.then(({digest:n})=>qt.sign(n,r).toDERRawBytes()).catch(n=>{throw new xr(String(n))});try{return qt.sign(e.digest,r).toDERRawBytes()}catch(n){throw new xr(String(n))}}function mc(r,t,e){let n=Je.digest(e instanceof Uint8Array?e:e.subarray());if(ii(n))return n.then(({digest:s})=>qt.verify(t,s,r)).catch(s=>{throw new vr(String(s))});try{return qt.verify(t,n.digest,r)}catch(s){throw new vr(String(s))}}var On=class{type="secp256k1";raw;_key;constructor(t){this._key=wc(t),this.raw=yc(this._key)}toMultihash(){return Ae.digest(Qe(this))}toCID(){return Ut.createV1(114,this.toMultihash())}toString(){return et.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:Et(this.raw,t.raw)}verify(t,e){return mc(this._key,e,t)}},Vn=class{type="secp256k1";raw;publicKey;constructor(t,e){this.raw=bc(t),this.publicKey=new On(e??xc(t))}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:Et(this.raw,t.raw)}sign(t){return gc(this.raw,t)}};function ai(r){return new Vn(r)}function yc(r){return qt.ProjectivePoint.fromHex(r).toRawBytes(!0)}function bc(r){try{return qt.getPublicKey(r,!0),r}catch(t){throw new Er(String(t))}}function wc(r){try{return qt.ProjectivePoint.fromHex(r),r}catch(t){throw new qe(String(t))}}function xc(r){try{return qt.getPublicKey(r,!0)}catch(t){throw new Er(String(t))}}function Qe(r){return we.encode({Type:rt[r.type],Data:r.raw})}function vc(r){let t=qr.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case rt.RSA:return Xo(e);case rt.Ed25519:return _o(e);case rt.secp256k1:return ai(e);case rt.ECDSA:return Xi(e);default:throw new je}}function Ec(r){if(r.byteLength===Kt)return _o(r);if(r.byteLength===pc)return ai(r);let t=Rt(r),e=t[2]?.[0];if(e===zi||e===Wi||e===Zi)return fo(t);if(t.length>8)return Hn(t);throw new L("Could not extract private key from raw bytes")}function Oe(r){return qr.encode({Type:rt[r.type],Data:r.raw})}function Bc(r,t,e,n){mn(r);let s=sa({dkLen:32,asyncTick:10},n),{c:o,dkLen:i,asyncTick:c}=s;if(ue(o),ue(i),ue(c),o<1)throw new Error("iterations (c) should be >= 1");let a=po(t),f=po(e),l=new Uint8Array(i),u=Gr.create(r,a),d=u._cloneInto().update(f);return{c:o,dkLen:i,asyncTick:c,DK:l,PRF:u,PRFSalt:d}}function Ac(r,t,e,n,s){return r.destroy(),t.destroy(),n&&n.destroy(),Bt(s),e}function Sc(r,t,e,n){let{c:s,dkLen:o,DK:i,PRF:c,PRFSalt:a}=Bc(r,t,e,n),f,l=new Uint8Array(4),u=Ie(l),d=new Uint8Array(c.outputLen);for(let b=1,y=0;y<o;b++,y+=c.outputLen){let g=i.subarray(y,y+c.outputLen);u.setInt32(0,b,!1),(f=a._cloneInto(f)).update(l).digestInto(d),g.set(d.subarray(0,g.length));for(let N=1;N<s;N++){c._cloneInto(f).update(d).digestInto(d);for(let I=0;I<g.length;I++)g[I]^=d[I]}}return Ac(c,a,i,f,d)}async function Pn(r,t,e,n){let{c:s,dkLen:o,asyncTick:i,DK:c,PRF:a,PRFSalt:f}=Bc(r,t,e,n),l,u=new Uint8Array(4),d=Ie(u),b=new Uint8Array(a.outputLen);for(let y=1,g=0;g<o;y++,g+=a.outputLen){let N=c.subarray(g,g+a.outputLen);d.setInt32(0,y,!1),(l=f._cloneInto(l)).update(u).digestInto(b),N.set(b.subarray(0,N.length)),await na(s-1,i,()=>{a._cloneInto(l).update(b).digestInto(b);for(let I=0;I<N.length;I++)N[I]^=b[I]})}return Ac(a,f,c,l,b)}var zr=Uint32Array.from([1732584193,4023233417,2562383102,271733878,3285377520]),xe=new Uint32Array(80),Mn=class extends Ce{constructor(){super(64,20,8,!1),this.A=zr[0]|0,this.B=zr[1]|0,this.C=zr[2]|0,this.D=zr[3]|0,this.E=zr[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 a=0;a<16;a++,e+=4)xe[a]=t.getUint32(e,!1);for(let a=16;a<80;a++)xe[a]=yn(xe[a-3]^xe[a-8]^xe[a-14]^xe[a-16],1);let{A:n,B:s,C:o,D:i,E:c}=this;for(let a=0;a<80;a++){let f,l;a<20?(f=bn(s,o,i),l=1518500249):a<40?(f=s^o^i,l=1859775393):a<60?(f=wn(s,o,i),l=2400959708):(f=s^o^i,l=3395469782);let u=yn(n,5)+f+c+l+xe[a]|0;c=i,i=o,o=yn(s,30),s=n,n=u}n=n+this.A|0,s=s+this.B|0,o=o+this.C|0,i=i+this.D|0,c=c+this.E|0,this.set(n,s,o,i,c)}roundClean(){Bt(xe)}destroy(){this.set(0,0,0,0,0),Bt(this.buffer)}},kc=Lr(()=>new Mn);var Ic=kc;var fr=An;var Cc={sha1:Ic,"sha2-256":lr,"sha2-512":fr};function Wr(r,t,e,n,s){if(s!=="sha1"&&s!=="sha2-256"&&s!=="sha2-512"){let c=Object.keys(Cc).join(" / ");throw new L(`Hash '${s}' is unknown or not supported. Must be ${c}`)}let o=Cc[s],i=Sc(o,r,t,{c:e,dkLen:n});return Se.encode(i).substring(1)}var ee="/",Nc=new TextEncoder().encode(ee),Fn=Nc[0],Zr=class r{_buf;constructor(t,e){if(typeof t=="string")this._buf=P(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]!==Fn)throw new Error("Invalid key")}toString(t="utf8"){return G(this._buf,t)}uint8Array(){return this._buf}get[Symbol.toStringTag](){return`Key(${this.toString()})`}static withNamespaces(t){return new r(t.join(ee))}static random(){return new r(Math.random().toString().substring(2))}static asKey(t){return t instanceof Uint8Array||typeof t=="string"?new r(t):typeof t.uint8Array=="function"?new r(t.uint8Array()):null}clean(){if((this._buf==null||this._buf.byteLength===0)&&(this._buf=Nc),this._buf[0]!==Fn){let t=new Uint8Array(this._buf.byteLength+1);t.fill(Fn,0,1),t.set(this._buf,1),this._buf=t}for(;this._buf.byteLength>1&&this._buf[this._buf.byteLength-1]===Fn;)this._buf=this._buf.subarray(0,-1)}less(t){let e=this.list(),n=t.list();for(let s=0;s<e.length;s++){if(n.length<s+1)return!1;let o=e[s],i=n[s];if(o<i)return!0;if(o>i)return!1}return e.length<n.length}reverse(){return r.withNamespaces(this.list().slice().reverse())}namespaces(){return this.list()}baseNamespace(){let t=this.namespaces();return t[t.length-1]}list(){return this.toString().split(ee).slice(1)}type(){return ph(this.baseNamespace())}name(){return gh(this.baseNamespace())}instance(t){return new r(this.toString()+":"+t)}path(){let t=this.parent().toString();return t.endsWith(ee)||(t+=ee),t+=this.type(),new r(t)}parent(){let t=this.list();return t.length===1?new r(ee):new r(t.slice(0,-1).join(ee))}child(t){return this.toString()===ee?t:t.toString()===ee?this:new r(this.toString()+t.toString(),!1)}isAncestorOf(t){return t.toString()===this.toString()?!1:t.toString().startsWith(this.toString())}isDecendantOf(t){return t.toString()===this.toString()?!1:this.toString().startsWith(t.toString())}isTopLevel(){return this.list().length===1}concat(...t){return r.withNamespaces([...this.namespaces(),...mh(t.map(e=>e.namespaces()))])}};function ph(r){let t=r.split(":");return t.length<2?"":t.slice(0,-1).join(":")}function gh(r){let t=r.split(":");return t[t.length-1]}function mh(r){return[].concat(...r)}var Oc=Os(Kc(),1),Vc=Oc.default;var Ol=Os(Wc(),1);var pr={};dt(pr,{create:()=>Rh,derivedEmptyPasswordKey:()=>$n});var $n={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function Rh(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,c=vt.get();e*=8;async function a(u,d){let b=c.getRandomValues(new Uint8Array(o)),y=c.getRandomValues(new Uint8Array(n)),g={name:t,iv:y};typeof d=="string"&&(d=P(d));let N;if(d.length===0){N=await c.subtle.importKey("jwk",$n,{name:"AES-GCM"},!0,["encrypt"]);try{let M={name:"PBKDF2",salt:b,iterations:i,hash:{name:s}},x=await c.subtle.importKey("raw",d,{name:"PBKDF2"},!1,["deriveKey"]);N=await c.subtle.deriveKey(M,x,{name:t,length:e},!0,["encrypt"])}catch{N=await c.subtle.importKey("jwk",$n,{name:"AES-GCM"},!0,["encrypt"])}}else{let M={name:"PBKDF2",salt:b,iterations:i,hash:{name:s}},x=await c.subtle.importKey("raw",d,{name:"PBKDF2"},!1,["deriveKey"]);N=await c.subtle.deriveKey(M,x,{name:t,length:e},!0,["encrypt"])}let I=await c.subtle.encrypt(g,N,u);return Ye([b,g.iv,new Uint8Array(I)])}async function f(u,d){let b=u.subarray(0,o),y=u.subarray(o,o+n),g=u.subarray(o+n),N={name:t,iv:y};typeof d=="string"&&(d=P(d));let I;if(d.length===0)try{let x={name:"PBKDF2",salt:b,iterations:i,hash:{name:s}},h=await c.subtle.importKey("raw",d,{name:"PBKDF2"},!1,["deriveKey"]);I=await c.subtle.deriveKey(x,h,{name:t,length:e},!0,["decrypt"])}catch{I=await c.subtle.importKey("jwk",$n,{name:"AES-GCM"},!0,["decrypt"])}else{let x={name:"PBKDF2",salt:b,iterations:i,hash:{name:s}},h=await c.subtle.importKey("raw",d,{name:"PBKDF2"},!1,["deriveKey"]);I=await c.subtle.deriveKey(x,h,{name:t,length:e},!0,["decrypt"])}let M=await c.subtle.decrypt(N,I,g);return new Uint8Array(M)}return{encrypt:a,decrypt:f}}var q=Os(Zc());function Ve(r,t){let e=0;if(r.length===1)return r[0];for(let n=r.length-1;n>=0;n--)e+=r[r.length-1-n]*Math.pow(2,t*n);return e}function ve(r,t,e=-1){let n=e,s=r,o=0,i=Math.pow(2,t);for(let c=1;c<8;c++){if(r<i){let a;if(n<0)a=new ArrayBuffer(c),o=c;else{if(n<c)return new ArrayBuffer(0);a=new ArrayBuffer(n),o=n}let f=new Uint8Array(a);for(let l=c-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 a}i*=Math.pow(2,t)}return new ArrayBuffer(0)}function Wn(...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 ui(){let r=new Uint8Array(this.valueHex);if(this.valueHex.byteLength>=2){let c=r[0]===255&&r[1]&128,a=r[0]===0&&(r[1]&128)===0;(c||a)&&this.warnings.push("Needlessly long format")}let t=new ArrayBuffer(this.valueHex.byteLength),e=new Uint8Array(t);for(let c=0;c<this.valueHex.byteLength;c++)e[c]=0;e[0]=r[0]&128;let n=Ve(e,8),s=new ArrayBuffer(this.valueHex.byteLength),o=new Uint8Array(s);for(let c=0;c<this.valueHex.byteLength;c++)o[c]=r[c];return o[0]&=127,Ve(o,8)-n}function Yc(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,c=ve(i,8,n),a=new Uint8Array(c);return a[0]|=128,c}let s=ve(t,8,n),o=new Uint8Array(s);if(o[0]&128){let i=s.slice(0),c=new Uint8Array(i);s=new ArrayBuffer(s.byteLength+1),o=new Uint8Array(s);for(let a=0;a<i.byteLength;a++)o[a+1]=c[a];o[0]=0}return s}e*=Math.pow(2,8)}return new ArrayBuffer(0)}function Jc(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 At(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 Vy=Math.log(2);function Zn(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function fi(r){let t=0,e=0;for(let s=0;s<r.length;s++){let o=r[s];t+=o.byteLength}let n=new Uint8Array(t);for(let s=0;s<r.length;s++){let o=r[s];n.set(new Uint8Array(o),e),e+=o.byteLength}return n.buffer}function ae(r,t,e,n){return t instanceof Uint8Array?t.byteLength?e<0?(r.error="Wrong parameter: inputOffset less than zero",!1):n<0?(r.error="Wrong parameter: inputLength less than zero",!1):t.byteLength-e-n<0?(r.error="End of input reached before message was fully decoded (inconsistent offset and length values)",!1):!0:(r.error="Wrong parameter: inputBuffer has zero length",!1):(r.error="Wrong parameter: inputBuffer must be 'Uint8Array'",!1)}var Xr=class{constructor(){this.items=[]}write(t){this.items.push(t)}final(){return fi(this.items)}},Yr=[new Uint8Array([1])],Xc="0123456789";var mr="",Vt=new ArrayBuffer(0),hi=new Uint8Array(0),Qr="EndOfContent",tl="OCTET STRING",el="BIT STRING";function ce(r){var t;return t=class extends r{get valueHex(){return this.valueHexView.slice().buffer}set valueHex(n){this.valueHexView=new Uint8Array(n)}constructor(...n){var s;super(...n);let o=n[0]||{};this.isHexOnly=(s=o.isHexOnly)!==null&&s!==void 0?s:!1,this.valueHexView=o.valueHex?q.BufferSourceConverter.toUint8Array(o.valueHex):hi}fromBER(n,s,o){let i=n instanceof ArrayBuffer?new Uint8Array(n):n;if(!ae(this,i,s,o))return-1;let c=s+o;return this.valueHexView=i.subarray(s,c),this.valueHexView.length?(this.blockLength=o,c):(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:q.Convert.ToHex(this.valueHexView)}}},t.NAME="hexBlock",t}var ne=class{static blockName(){return this.NAME}get valueBeforeDecode(){return this.valueBeforeDecodeView.slice().buffer}set valueBeforeDecode(t){this.valueBeforeDecodeView=new Uint8Array(t)}constructor({blockLength:t=0,error:e=mr,warnings:n=[],valueBeforeDecode:s=hi}={}){this.blockLength=t,this.error=e,this.warnings=n,this.valueBeforeDecodeView=q.BufferSourceConverter.toUint8Array(s)}toJSON(){return{blockName:this.constructor.NAME,blockLength:this.blockLength,error:this.error,warnings:this.warnings,valueBeforeDecode:q.Convert.ToHex(this.valueBeforeDecodeView)}}};ne.NAME="baseBlock";var ht=class extends ne{fromBER(t,e,n){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}toBER(t,e){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}};ht.NAME="valueBlock";var Yn=class extends ce(ne){constructor({idBlock:t={}}={}){var e,n,s,o;super(),t?(this.isHexOnly=(e=t.isHexOnly)!==null&&e!==void 0?e:!1,this.valueHexView=t.valueHex?q.BufferSourceConverter.toUint8Array(t.valueHex):hi,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=ve(this.tagNumber,7),o=new Uint8Array(s),i=s.byteLength,c=new Uint8Array(i+1);if(c[0]=e|31,!t){for(let a=0;a<i-1;a++)c[a+1]=o[a]|128;c[i]=o[i-1]}return c.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=q.BufferSourceConverter.toUint8Array(t);if(!ae(this,s,e,n))return-1;let o=s.subarray(e,e+n);if(o.length===0)return this.error="Zero buffer length",-1;switch(o[0]&192){case 0:this.tagClass=1;break;case 64:this.tagClass=2;break;case 128:this.tagClass=3;break;case 192:this.tagClass=4;break;default:return this.error="Unknown tag class",-1}this.isConstructed=(o[0]&32)===32,this.isHexOnly=!1;let c=o[0]&31;if(c!==31)this.tagNumber=c,this.blockLength=1;else{let a=1,f=this.valueHexView=new Uint8Array(255),l=255;for(;o[a]&128;){if(f[a-1]=o[a]&127,a++,a>=o.length)return this.error="End of input reached before message was fully decoded",-1;if(a===l){l+=255;let d=new Uint8Array(l);for(let b=0;b<f.length;b++)d[b]=f[b];f=this.valueHexView=new Uint8Array(l)}}this.blockLength=a+1,f[a-1]=o[a]&127;let u=new Uint8Array(a);for(let d=0;d<a;d++)u[d]=f[d];f=this.valueHexView=new Uint8Array(a),f.set(u),this.blockLength<=9?this.tagNumber=Ve(f,7):(this.isHexOnly=!0,this.warnings.push("Tag too long, represented as hex-coded"))}if(this.tagClass===1&&this.isConstructed)switch(this.tagNumber){case 1:case 2:case 5:case 6:case 9:case 13:case 14:case 23:case 24:case 31:case 32:case 33:case 34:return this.error="Constructed encoding used for primitive type",-1}return e+this.blockLength}toJSON(){return{...super.toJSON(),tagClass:this.tagClass,tagNumber:this.tagNumber,isConstructed:this.isConstructed}}};Yn.NAME="identificationBlock";var Jn=class extends ne{constructor({lenBlock:t={}}={}){var e,n,s;super(),this.isIndefiniteForm=(e=t.isIndefiniteForm)!==null&&e!==void 0?e:!1,this.longFormUsed=(n=t.longFormUsed)!==null&&n!==void 0?n:!1,this.length=(s=t.length)!==null&&s!==void 0?s:0}fromBER(t,e,n){let s=q.BufferSourceConverter.toUint8Array(t);if(!ae(this,s,e,n))return-1;let o=s.subarray(e,e+n);if(o.length===0)return this.error="Zero buffer length",-1;if(o[0]===255)return this.error="Length block 0xFF is reserved by standard",-1;if(this.isIndefiniteForm=o[0]===128,this.isIndefiniteForm)return this.blockLength=1,e+this.blockLength;if(this.longFormUsed=!!(o[0]&128),this.longFormUsed===!1)return this.length=o[0],this.blockLength=1,e+this.blockLength;let i=o[0]&127;if(i>8)return this.error="Too big integer",-1;if(i+1>o.length)return this.error="End of input reached before message was fully decoded",-1;let c=e+1,a=s.subarray(c,c+i);return a[i-1]===0&&this.warnings.push("Needlessly long encoded length"),this.length=Ve(a,8),this.longFormUsed&&this.length<=127&&this.warnings.push("Unnecessary usage of long length form"),this.blockLength=i+1,e+this.blockLength}toBER(t=!1){let e,n;if(this.length>127&&(this.longFormUsed=!0),this.isIndefiniteForm)return e=new ArrayBuffer(1),t===!1&&(n=new Uint8Array(e),n[0]=128),e;if(this.longFormUsed){let s=ve(this.length,8);if(s.byteLength>127)return this.error="Too big length",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 S={},ct=class extends ne{constructor({name:t=mr,optional:e=!1,primitiveSchema:n,...s}={},o){super(s),this.name=t,this.optional=e,n&&(this.primitiveSchema=n),this.idBlock=new Yn(s),this.lenBlock=new 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 Xr;e||rl(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():q.Convert.ToHex(this.toBER())}onAsciiEncoding(){let t=this.constructor.NAME,e=q.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 Jc(e,n)}};ct.NAME="BaseBlock";function rl(r){var t;if(r instanceof S.Constructed)for(let e of r.valueBlock.value)rl(e)&&(r.lenBlock.isIndefiniteForm=!0);return!!(!((t=r.lenBlock)===null||t===void 0)&&t.isIndefiniteForm)}var Xn=class extends ct{getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}constructor({value:t=mr,...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}'`}};Xn.NAME="BaseStringBlock";var Qn=class extends ce(ht){constructor({isHexOnly:t=!0,...e}={}){super(e),this.isHexOnly=t}};Qn.NAME="PrimitiveValueBlock";var nl,ts=class extends ct{constructor(t={}){super(t,Qn),this.idBlock.isConstructed=!1}};nl=ts;S.Primitive=nl;ts.NAME="PRIMITIVE";function qh(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 Rs(r,t=0,e=r.length){let n=t,s=new ct({},ht),o=new ne;if(!ae(o,r,t,e))return s.error=o.error,{offset:-1,result:s};if(!r.subarray(t,t+e).length)return s.error="Zero buffer length",{offset:-1,result:s};let c=s.idBlock.fromBER(r,t,e);if(s.idBlock.warnings.length&&s.warnings.concat(s.idBlock.warnings),c===-1)return s.error=s.idBlock.error,{offset:-1,result:s};if(t=c,e-=s.idBlock.blockLength,c=s.lenBlock.fromBER(r,t,e),s.lenBlock.warnings.length&&s.warnings.concat(s.lenBlock.warnings),c===-1)return s.error=s.lenBlock.error,{offset:-1,result:s};if(t=c,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 a=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};a=S.EndOfContent;break;case 1:a=S.Boolean;break;case 2:a=S.Integer;break;case 3:a=S.BitString;break;case 4:a=S.OctetString;break;case 5:a=S.Null;break;case 6:a=S.ObjectIdentifier;break;case 10:a=S.Enumerated;break;case 12:a=S.Utf8String;break;case 13:a=S.RelativeObjectIdentifier;break;case 14:a=S.TIME;break;case 15:return s.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:s};case 16:a=S.Sequence;break;case 17:a=S.Set;break;case 18:a=S.NumericString;break;case 19:a=S.PrintableString;break;case 20:a=S.TeletexString;break;case 21:a=S.VideotexString;break;case 22:a=S.IA5String;break;case 23:a=S.UTCTime;break;case 24:a=S.GeneralizedTime;break;case 25:a=S.GraphicString;break;case 26:a=S.VisibleString;break;case 27:a=S.GeneralString;break;case 28:a=S.UniversalString;break;case 29:a=S.CharacterString;break;case 30:a=S.BmpString;break;case 31:a=S.DATE;break;case 32:a=S.TimeOfDay;break;case 33:a=S.DateTime;break;case 34:a=S.Duration;break;default:{let f=s.idBlock.isConstructed?new S.Constructed:new S.Primitive;f.idBlock=s.idBlock,f.lenBlock=s.lenBlock,f.warnings=s.warnings,s=f}}break;case 2:case 3:case 4:default:a=s.idBlock.isConstructed?S.Constructed:S.Primitive}return s=qh(s,a),c=s.fromBER(r,t,s.lenBlock.isIndefiniteForm?e:s.lenBlock.length),s.valueBeforeDecodeView=r.subarray(n,n+s.blockLength),{offset:c,result:s}}function Ds(r){if(!r.byteLength){let t=new ct({},ht);return t.error="Input buffer has zero length",{offset:-1,result:t}}return Rs(q.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function jh(r,t){return r?1:t}var jt=class extends ht{constructor({value:t=[],isIndefiniteForm:e=!1,...n}={}){super(n),this.value=t,this.isIndefiniteForm=e}fromBER(t,e,n){let s=q.BufferSourceConverter.toUint8Array(t);if(!ae(this,s,e,n))return-1;if(this.valueBeforeDecodeView=s.subarray(e,e+n),this.valueBeforeDecodeView.length===0)return this.warnings.push("Zero buffer length"),e;let o=e;for(;jh(this.isIndefiniteForm,n)>0;){let i=Rs(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===Qr)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===Qr?this.value.pop():this.warnings.push("No EndOfContent block encoded")),o}toBER(t,e){let n=e||new Xr;for(let s=0;s<this.value.length;s++)this.value[s].toBER(t,n);return e?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}};jt.NAME="ConstructedValueBlock";var sl,Ee=class extends ct{constructor(t={}){super(t,jt),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} :`}};_c=ve;A.Constructed=_c;ve.NAME="CONSTRUCTED";var qn=class extends ht{fromBER(t,e,n){return e}toBER(t){return Vt}};qn.override="EndOfContentValueBlock";var Dc,jn=class extends ct{constructor(t={}){super(t,qn),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};Dc=jn;A.EndOfContent=Dc;jn.NAME=$r;var Kc,Oe=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}`}};Kc=Oe;A.Null=Kc;Oe.NAME="NULL";var $n=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,Yo.call(this),this.blockLength=n,e+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};$n.NAME="BooleanValueBlock";var Oc,Gn=class extends ct{getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}constructor(t={}){super(t,$n),this.idBlock.tagClass=1,this.idBlock.tagNumber=1}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.getValue}`}};Oc=Gn;A.Boolean=Oc;Gn.NAME="BOOLEAN";var zn=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===$r){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(i!==Uc)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}}};zn.NAME="OctetStringValueBlock";var ti,ee=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},zn),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=Es(o,0,o.byteLength);i.offset!==-1&&i.offset===n&&(this.valueBlock.value=[i.result])}}catch{}}return super.fromBER(t,e,n)}onAsciiEncoding(){if(this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length)return ve.prototype.onAsciiEncoding.call(this);let t=this.constructor.NAME,e=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 ti&&t.push(e.valueBlock.valueHexView);return M.BufferSourceConverter.concat(t)}};ti=ee;A.OctetString=ti;ee.NAME=Uc;var Wn=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===$r){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==Tc)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=Es(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}}};Wn.NAME="BitStringValueBlock";var Vc,Zn=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},Wn),this.idBlock.tagClass=1,this.idBlock.tagNumber=3}fromBER(t,e,n){return this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,super.fromBER(t,e,n)}onAsciiEncoding(){if(this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length)return ve.prototype.onAsciiEncoding.call(this);{let t=[],e=this.valueBlock.valueHexView;for(let i of e)t.push(i.toString(2).padStart(8,"0"));let n=t.join(""),s=this.constructor.NAME,o=n.substring(0,n.length-this.valueBlock.unusedBits);return`${s} : ${o}`}}};Vc=Zn;A.BitString=Vc;Zn.NAME=Tc;var Hc;function Fh(r,t){let e=new Uint8Array([0]),n=new Uint8Array(r),s=new Uint8Array(t),o=n.slice(0),i=o.length-1,a=s.slice(0),c=a.length-1,f=0,l=c<i?i:c,u=0;for(let h=l;h>=0;h--,u++){switch(!0){case u<a.length:f=o[i-u]+a[c-u]+e[0];break;default:f=o[i-u]+e[0]}switch(e[0]=f/10,!0){case u>=o.length:o=Kn(new Uint8Array([f%10]),o);break;default:o[i-u]=f%10}}return e[0]>0&&(o=Kn(e,o)),o}function Nc(r){if(r>=Fr.length)for(let t=Fr.length;t<=r;t++){let e=new Uint8Array([0]),n=Fr[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=Kn(e,n)),Fr.push(n)}return Fr[r]}function qh(r,t){let e=0,n=new Uint8Array(r),s=new Uint8Array(t),o=n.slice(0),i=o.length-1,a=s.slice(0),c=a.length-1,f,l=0;for(let u=c;u>=0;u--,l++)switch(f=o[i-l]-a[c-l]-e,!0){case f<0:e=1,o[i-l]=f+10;break;default:e=0,o[i-l]=f}if(e>0)for(let u=i-c+1;u>=0;u--,l++)if(f=o[i-l]-e,f<0)e=1,o[i-l]=f+10;else{e=0,o[i-l]=f;break}return o.slice()}var Gr=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=Yo.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(kc(t))}get valueDec(){return this._valueDec}fromDER(t,e,n,s=0){let o=this.fromBER(t,e,n);if(o===-1)return o;let i=this.valueHexView;return i[0]===0&&(i[1]&128)!==0?this.valueHexView=i.subarray(1):s!==0&&i.length<s&&(s-i.length>1&&(s=i.length+1),this.valueHexView=i.subarray(s-i.length)),o}toDER(t=!1){let e=this.valueHexView;switch(!0){case(e[0]&128)!==0:{let n=new Uint8Array(this.valueHexView.length+1);n[0]=0,n.set(e,1),this.valueHexView=n}break;case(e[0]===0&&(e[1]&128)===0):this.valueHexView=this.valueHexView.subarray(1);break}return this.toBER(t)}fromBER(t,e,n){let s=super.fromBER(t,e,n);return s===-1||this.setValueHex(),s}toBER(t){return t?new ArrayBuffer(this.valueHexView.length):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}toString(){let t=this.valueHexView.length*8-1,e=new Uint8Array(this.valueHexView.length*8/3),n=0,s,o=this.valueHexView,i="",a=!1;for(let c=o.byteLength-1;c>=0;c--){s=o[c];for(let f=0;f<8;f++){if((s&1)===1)switch(n){case t:e=qh(Nc(n),e),i="-";break;default:e=Fh(e,Nc(n))}n++,s>>=1}}for(let c=0;c<e.length;c++)e[c]&&(a=!0),a&&(i+=Ic.charAt(e[c]));return a===!1&&(i+=Ic.charAt(0)),i}};Hc=Gr;Gr.NAME="IntegerValueBlock";Object.defineProperty(Hc.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var qr,re=class extends ct{constructor(t={}){super(t,Gr),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return On(),BigInt(this.valueBlock.toString())}static fromBigInt(t){On();let e=BigInt(t),n=new jr,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 qr({valueHex:n.final()})}convertToDER(){let t=new qr({valueHex:this.valueBlock.valueHexView});return t.valueBlock.toDER(),t}convertFromDER(){return new qr({valueHex:this.valueBlock.valueHexView[0]===0?this.valueBlock.valueHexView.subarray(1):this.valueBlock.valueHexView})}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()}`}};qr=re;A.Integer=qr;re.NAME="INTEGER";var Pc,Jn=class extends re{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};Pc=Jn;A.Enumerated=Pc;Jn.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=Ke(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}set valueBigInt(t){On();let e=BigInt(t).toString(2);for(;e.length%7;)e="0"+e;let n=new Uint8Array(e.length/7);for(let s=0;s<n.length;s++)n[s]=parseInt(e.slice(s*7,s*7+7),2)+(s+1<n.length?128:0);this.fromBER(n.buffer,0,n.length)}toBER(t){if(this.isHexOnly){if(t)return new ArrayBuffer(this.valueHexView.byteLength);let s=this.valueHexView,o=new Uint8Array(this.blockLength);for(let i=0;i<this.blockLength-1;i++)o[i]=s[i]|128;return o[this.blockLength-1]=s[this.blockLength-1],o.buffer}let e=xe(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Vt;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),o=e.byteLength-1;for(let i=0;i<o;i++)n[i]=s[i]|128;n[o]=s[o]}return n}toString(){let t="";if(this.isHexOnly)t=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 Yn=class extends ht{constructor({value:t=hr,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new 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 Xo(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){On();let a=BigInt(s);i.valueBigInt=a}else if(i.valueDec=parseInt(s,10),isNaN(i.valueDec))return;this.value.length||(i.isFirstSid=!0,o=!0),this.value.push(i)}while(n!==-1)}toString(){let t="",e=!1;for(let n=0;n<this.value.length;n++){e=this.value[n].isHexOnly;let s=this.value[n].toString();n!==0&&(t=`${t}.`),e?(s=`{${s}}`,this.value[n].isFirstSid?t=`2.{${s} - 80}`:t+=s):t+=s}return t}toJSON(){let t={...super.toJSON(),value:this.toString(),sidArray:[]};for(let e=0;e<this.value.length;e++)t.sidArray.push(this.value[e].toJSON());return t}};Yn.NAME="ObjectIdentifierValueBlock";var Mc,Ft=class extends ct{getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}constructor(t={}){super(t,Yn),this.idBlock.tagClass=1,this.idBlock.tagNumber=6}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};Mc=Ft;A.ObjectIdentifier=Mc;Ft.NAME="OBJECT IDENTIFIER";var Wr=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=Ke(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}toBER(t){if(this.isHexOnly){if(t)return new ArrayBuffer(this.valueHexView.byteLength);let s=this.valueHexView,o=new Uint8Array(this.blockLength);for(let i=0;i<this.blockLength-1;i++)o[i]=s[i]|128;return o[this.blockLength-1]=s[this.blockLength-1],o.buffer}let e=xe(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Vt;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),o=e.byteLength-1;for(let i=0;i<o;i++)n[i]=s[i]|128;n[o]=s[o]}return n.buffer}toString(){let t="";return this.isHexOnly?t=M.Convert.ToHex(this.valueHexView):t=this.valueDec.toString(),t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};Wr.NAME="relativeSidBlock";var Xn=class extends ht{constructor({value:t=hr,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new Wr;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 Xo(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 Wr;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}};Xn.NAME="RelativeObjectIdentifierValueBlock";var Fc,Qn=class extends ct{getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}constructor(t={}){super(t,Xn),this.idBlock.tagClass=1,this.idBlock.tagNumber=13}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};Fc=Qn;A.RelativeObjectIdentifier=Fc;Qn.NAME="RelativeObjectIdentifier";var qc,Bt=class extends ve{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};qc=Bt;A.Sequence=qc;Bt.NAME="SEQUENCE";var jc,ts=class extends ve{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};jc=ts;A.Set=jc;ts.NAME="SET";var es=class extends oe(ht){constructor({...t}={}){super(t),this.isHexOnly=!0,this.value=hr}toJSON(){return{...super.toJSON(),value:this.value}}};es.NAME="StringValueBlock";var rs=class extends es{};rs.NAME="SimpleStringValueBlock";var bt=class extends Pn{constructor({...t}={}){super(t,rs)}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}};bt.NAME="SIMPLE STRING";var ns=class extends bt{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}};ns.NAME="Utf8StringValueBlock";var $c,ne=class extends ns{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};$c=ne;A.Utf8String=$c;ne.NAME="UTF8String";var ss=class extends bt{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))}};ss.NAME="BmpStringValueBlock";var Gc,os=class extends ss{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};Gc=os;A.BmpString=Gc;os.NAME="BMPString";var is=class extends bt{fromBuffer(t){let e=ArrayBuffer.isView(t)?t.slice().buffer:t.slice(0),n=new Uint8Array(e);for(let s=0;s<n.length;s+=4)n[s]=n[s+3],n[s+1]=n[s+2],n[s+2]=0,n[s+3]=0;this.valueBlock.value=String.fromCharCode.apply(null,new Uint32Array(e))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e*4);for(let s=0;s<e;s++){let o=xe(t.charCodeAt(s),8),i=new Uint8Array(o);if(i.length>4)continue;let a=4-i.length;for(let c=i.length-1;c>=0;c--)n[s*4+c+a]=i[c]}this.valueBlock.value=t}};is.NAME="UniversalStringValueBlock";var zc,as=class extends is{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};zc=as;A.UniversalString=zc;as.NAME="UniversalString";var Wc,cs=class extends bt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};Wc=cs;A.NumericString=Wc;cs.NAME="NumericString";var Zc,ls=class extends bt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};Zc=ls;A.PrintableString=Zc;ls.NAME="PrintableString";var Jc,us=class extends bt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};Jc=us;A.TeletexString=Jc;us.NAME="TeletexString";var Yc,fs=class extends bt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};Yc=fs;A.VideotexString=Yc;fs.NAME="VideotexString";var Xc,hs=class extends bt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};Xc=hs;A.IA5String=Xc;hs.NAME="IA5String";var Qc,ds=class extends bt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};Qc=ds;A.GraphicString=Qc;ds.NAME="GraphicString";var tl,Zr=class extends bt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};tl=Zr;A.VisibleString=tl;Zr.NAME="VisibleString";var el,ps=class extends bt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};el=ps;A.GeneralString=el;ps.NAME="GeneralString";var rl,gs=class extends bt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};rl=gs;A.CharacterString=rl;gs.NAME="CharacterString";var nl,Jr=class extends Zr{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}}};nl=Jr;A.UTCTime=nl;Jr.NAME="UTCTime";var sl,ys=class extends Jr{constructor(t={}){var e;super(t),(e=this.millisecond)!==null&&e!==void 0||(this.millisecond=0),this.idBlock.tagClass=1,this.idBlock.tagNumber=24}fromDate(t){super.fromDate(t),this.millisecond=t.getUTCMilliseconds()}toDate(){let t=Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second,this.millisecond);return new Date(t)}fromString(t){let e=!1,n="",s="",o=0,i,a=0,c=0;if(t[t.length-1]==="Z")n=t.substring(0,t.length-1),e=!0;else{let u=new Number(t[t.length-1]);if(isNaN(u.valueOf()))throw new Error("Wrong input string for conversion");n=t}if(e){if(n.indexOf("+")!==-1)throw new Error("Wrong input string for conversion");if(n.indexOf("-")!==-1)throw new Error("Wrong input string for conversion")}else{let u=1,h=n.indexOf("+"),m="";if(h===-1&&(h=n.indexOf("-"),u=-1),h!==-1){if(m=n.substring(h+1),n=n.substring(0,h),m.length!==2&&m.length!==4)throw new Error("Wrong input string for conversion");let w=parseInt(m.substring(0,2),10);if(isNaN(w.valueOf()))throw new Error("Wrong input string for conversion");if(a=u*w,m.length===4){if(w=parseInt(m.substring(2,4),10),isNaN(w.valueOf()))throw new Error("Wrong input string for conversion");c=u*w}}}let f=n.indexOf(".");if(f===-1&&(f=n.indexOf(",")),f!==-1){let u=new Number(`0${n.substring(f)}`);if(isNaN(u.valueOf()))throw new Error("Wrong input string for conversion");o=u.valueOf(),s=n.substring(0,f)}else s=n;switch(!0){case s.length===8:if(i=/(\d{4})(\d{2})(\d{2})/ig,f!==-1)throw new Error("Wrong input string for conversion");break;case s.length===10:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let u=60*o;this.minute=Math.floor(u),u=60*(u-this.minute),this.second=Math.floor(u),u=1e3*(u-this.second),this.millisecond=Math.floor(u)}break;case s.length===12:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let u=60*o;this.second=Math.floor(u),u=1e3*(u-this.second),this.millisecond=Math.floor(u)}break;case s.length===14:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let u=1e3*o;this.millisecond=Math.floor(u)}break;default:throw new Error("Wrong input string for conversion")}let l=i.exec(s);if(l===null)throw new Error("Wrong input string for conversion");for(let u=1;u<l.length;u++)switch(u){case 1:this.year=parseInt(l[u],10);break;case 2:this.month=parseInt(l[u],10);break;case 3:this.day=parseInt(l[u],10);break;case 4:this.hour=parseInt(l[u],10)+a;break;case 5:this.minute=parseInt(l[u],10)+c;break;case 6:this.second=parseInt(l[u],10);break;default:throw new Error("Wrong input string for conversion")}if(e===!1){let u=new Date(this.year,this.month,this.day,this.hour,this.minute,this.second,this.millisecond);this.year=u.getUTCFullYear(),this.month=u.getUTCMonth(),this.day=u.getUTCDay(),this.hour=u.getUTCHours(),this.minute=u.getUTCMinutes(),this.second=u.getUTCSeconds(),this.millisecond=u.getUTCMilliseconds()}}toString(t="iso"){if(t==="iso"){let e=[];return e.push(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}}};sl=ys;A.GeneralizedTime=sl;ys.NAME="GeneralizedTime";var ol,ms=class extends ne{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};ol=ms;A.DATE=ol;ms.NAME="DATE";var il,bs=class extends ne{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};il=bs;A.TimeOfDay=il;bs.NAME="TimeOfDay";var al,ws=class extends ne{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};al=ws;A.DateTime=al;ws.NAME="DateTime";var cl,xs=class extends ne{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};cl=xs;A.Duration=cl;xs.NAME="Duration";var ll,vs=class extends ne{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};ll=vs;A.TIME=ll;vs.NAME="TIME";async function As(r,t){let n=await ur.create().encrypt(r,t);return Ae.encode(n)}async function ei(r,t,e){if(r.type==="RSA")return zh(r,t,e);if(r.type==="Ed25519")return jh(r,t,e);if(r.type==="secp256k1")return $h(r,t,e);if(r.type==="ECDSA")return Gh(r,t,e);throw new Me}async function jh(r,t,e="libp2p-key"){if(e==="libp2p-key")return As(De(r),t);throw new R(`export format '${e}' is not supported`)}async function $h(r,t,e="libp2p-key"){if(e==="libp2p-key")return As(De(r),t);throw new R("Export format is not supported")}async function Gh(r,t,e="libp2p-key"){if(e==="libp2p-key")return As(De(r),t);throw new R(`export format '${e}' is not supported`)}async function zh(r,t,e="pkcs-8"){if(e==="pkcs-8")return Wh(r,t);if(e==="libp2p-key")return As(De(r),t);throw new R("Export format is not supported")}async function Wh(r,t){let e=xt.get(),s=new Bt({value:[new re({value:0}),new Bt({value:[new Ft({value:"1.2.840.113549.1.1.1"}),new Oe]}),new ee({valueHex:r.raw})]}).toBER(),o=new Uint8Array(s,0,s.byteLength),i=_e(16),a=await In(Gt,t,i,{c:1e4,dkLen:32}),c=_e(16),f=await e.subtle.importKey("raw",a,"AES-CBC",!1,["encrypt"]),l=await e.subtle.encrypt({name:"AES-CBC",iv:c},f,o),u=new Bt({value:[new ee({valueHex:i}),new re({value:1e4}),new re({value:32}),new Bt({value:[new Ft({value:"1.2.840.113549.2.11"}),new Oe]})]}),h=new Bt({value:[new Ft({value:"1.2.840.113549.1.5.13"}),new Bt({value:[new Bt({value:[new Ft({value:"1.2.840.113549.1.5.12"}),u]}),new Bt({value:[new Ft({value:"2.16.840.1.101.3.4.1.42"}),new ee({valueHex:c})]})]})]}),w=new Bt({value:[h,new ee({valueHex:l})]}).toBER(),y=new Uint8Array(w,0,w.byteLength);return["-----BEGIN ENCRYPTED PRIVATE KEY-----",...j(y,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
7
- `)}async function ri(r,t){try{let e=await Zh(r,t);return Qa(e)}catch{}if(!r.includes("BEGIN"))throw new R("Encrypted key was not a libp2p-key or a PEM file");return Jh(r,t)}async function Zh(r,t){let e=Ae.decode(r);return ur.create().decrypt(e,t)}async function Jh(r,t){let e=xt.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}=Bs(o),{iv:a,salt:c,iterations:f,keySize:l,cipherText:u}=Yh(i),h=await In(Gt,t,c,{c:f,dkLen:l}),m=await e.subtle.importKey("raw",h,"AES-CBC",!1,["decrypt"]),w=Yr(await e.subtle.decrypt({name:"AES-CBC",iv:a},m,u)),{result:y}=Bs(w);n=dl(y)}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}=Bs(o);n=dl(i)}else throw new R("Could not parse private key from PEM data");let s=tc(n);if(s.type!=="RSA")throw new R("Could not parse RSA private key from PEM data");return s}function Yh(r){let t=r.valueBlock.value[0];if(t.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.13")throw new R("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 R("Only pkcs5PBKDF2 key derivation functions are supported");let o=n.valueBlock.value[1],i=Yr(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 R("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 R("Only AES-CBC encryption schemes are supported")}}}}let u=Yr(f.valueBlock.value[1].getValue());return{cipherText:Yr(r.valueBlock.value[1].getValue()),salt:i,iterations:a,keySize:c,iv:u}}function dl(r){return Yr(r.valueBlock.value[2].getValue())}function Yr(r){return new Uint8Array(r,0,r.byteLength)}var Xh="/pkcs8/",si="/info/",Xr=new WeakMap,Ve={minKeyLength:112/8,minSaltLength:128/8,minIterationCount:1e3},ni={dek:{keyLength:512/8,iterationCount:1e4,salt:"you should override this value with a crypto secure random number",hash:"sha2-512"}};function dr(r){return r==null||typeof r!="string"?!1:r===(0,pl.default)(r.trim())&&r.length>0}async function lt(){let e=Math.random()*800+200;await new Promise(n=>setTimeout(n,e))}function He(r){return new Mr(Xh+r)}function pr(r){return new Mr(si+r)}async function Qh(r){let t=De(r),e=await We.digest(t);return et.encode(e.bytes).substring(1)}var Ss=class{components;init;log;self;constructor(t,e){if(this.components=t,this.log=t.logger.forComponent("libp2p:keychain"),this.init=gc(ni,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<Ve.minKeyLength)throw new Error(`dek.keyLength must be least ${Ve.minKeyLength} bytes`);if(this.init.dek?.salt?.length!=null&&this.init.dek.salt.length<Ve.minSaltLength)throw new Error(`dek.saltLength must be least ${Ve.minSaltLength} bytes`);if(this.init.dek?.iterationCount!=null&&this.init.dek.iterationCount<Ve.minIterationCount)throw new Error(`dek.iterationCount must be least ${Ve.minIterationCount}`);let n=this.init.pass!=null&&this.init.dek?.salt!=null?Pr(this.init.pass,this.init.dek?.salt,this.init.dek?.iterationCount,this.init.dek?.keyLength,this.init.dek?.hash):"";Xr.set(this,{dek:n})}[Symbol.toStringTag]="@libp2p/keychain";[ci]=["@libp2p/keychain"];static generateOptions(){let t=Object.assign({},ni),e=Math.ceil(Ve.minSaltLength/3)*3;return t.dek.salt=j(_e(e),"base64"),t}static get options(){return ni}async findKeyByName(t){if(!dr(t))throw await lt(),new R(`Invalid key name '${t}'`);let e=pr(t);try{let n=await this.components.datastore.get(e);return JSON.parse(j(n))}catch(n){throw await lt(),this.log.error(n),new en(`Key '${t}' does not exist.`)}}async findKeyById(t){try{let e={prefix:si};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 R(`Key with id '${t}' does not exist.`)}catch(e){throw await lt(),e}}async importKey(t,e){if(!dr(t))throw await lt(),new R(`Invalid key name '${t}'`);if(e==null)throw await lt(),new R("Key is required");let n=He(t);if(await this.components.datastore.has(n))throw await lt(),new R(`Key '${t}' already exists`);let o,i;try{o=await Qh(e);let f=Xr.get(this);if(f==null)throw new R("dek missing");let l=f.dek;i=await ei(e,l,e.type==="RSA"?"pkcs-8":"libp2p-key")}catch(f){throw await lt(),f}let a={name:t,id:o},c=this.components.datastore.batch();return c.put(n,H(i)),c.put(pr(t),H(JSON.stringify(a))),await c.commit(),a}async exportKey(t){if(!dr(t))throw await lt(),new R(`Invalid key name '${t}'`);let e=He(t);try{let n=await this.components.datastore.get(e),s=j(n),o=Xr.get(this);if(o==null)throw new R("dek missing");let i=o.dek;return await ri(s,i)}catch(n){throw await lt(),n}}async removeKey(t){if(!dr(t)||t===this.self)throw await lt(),new R(`Invalid key name '${t}'`);let e=He(t),n=await this.findKeyByName(t),s=this.components.datastore.batch();return s.delete(e),s.delete(pr(t)),await s.commit(),n}async listKeys(){let t={prefix:si},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(!dr(t)||t===this.self)throw await lt(),new R(`Invalid old key name '${t}'`);if(!dr(e)||e===this.self)throw await lt(),new R(`Invalid new key name '${e}'`);let n=He(t),s=He(e),o=pr(t),i=pr(e);if(await this.components.datastore.has(s))throw await lt(),new R(`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 lt(),c}}async rotateKeychainPass(t,e){if(typeof t!="string")throw await lt(),new R(`Invalid old pass type '${typeof t}'`);if(typeof e!="string")throw await lt(),new R(`Invalid new pass type '${typeof e}'`);if(e.length<20)throw await lt(),new R(`Invalid pass length ${e.length}`);this.log("recreating keychain");let n=Xr.get(this);if(n==null)throw new R("dek missing");let s=n.dek;this.init.pass=e;let o=e!=null&&this.init.dek?.salt!=null?Pr(e,this.init.dek.salt,this.init.dek?.iterationCount,this.init.dek?.keyLength,this.init.dek?.hash):"";Xr.set(this,{dek:o});let i=await this.listKeys();for(let a of i){let c=await this.components.datastore.get(He(a.name)),f=j(c),l=await ri(f,s),u=o.toString(),h=await ei(l,u,l.type==="RSA"?"pkcs-8":"libp2p-key"),m=this.components.datastore.batch(),w={name:a.name,id:a.id};m.put(He(a.name),H(h)),m.put(pr(a.name),H(JSON.stringify(w))),await m.commit()}this.log("keychain reconstructed")}};function td(r={}){return t=>new Ss(t,r)}return Al(ed);})();
6
+ `)}`:`${e} :`}};sl=Ee;S.Constructed=sl;Ee.NAME="CONSTRUCTED";var es=class extends ht{fromBER(t,e,n){return e}toBER(t){return Vt}};es.override="EndOfContentValueBlock";var ol,rs=class extends ct{constructor(t={}){super(t,es),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};ol=rs;S.EndOfContent=ol;rs.NAME=Qr;var il,Pe=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}`}};il=Pe;S.Null=il;Pe.NAME="NULL";var ns=class extends ce(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=q.BufferSourceConverter.toUint8Array(e.valueHex):this.valueHexView=new Uint8Array(1),t&&(this.value=t)}fromBER(t,e,n){let s=q.BufferSourceConverter.toUint8Array(t);return ae(this,s,e,n)?(this.valueHexView=s.subarray(e,e+n),n>1&&this.warnings.push("Boolean value encoded in more then 1 octet"),this.isHexOnly=!0,ui.call(this),this.blockLength=n,e+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};ns.NAME="BooleanValueBlock";var al,ss=class extends ct{getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}constructor(t={}){super(t,ns),this.idBlock.tagClass=1,this.idBlock.tagNumber=1}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.getValue}`}};al=ss;S.Boolean=al;ss.NAME="BOOLEAN";var os=class extends ce(jt){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=jt.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===Qr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(i!==tl)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?jt.prototype.toBER.call(this,t,e):t?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};os.NAME="OctetStringValueBlock";var di,se=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},os),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=Rs(o,0,o.byteLength);i.offset!==-1&&i.offset===n&&(this.valueBlock.value=[i.result])}}catch{}}return super.fromBER(t,e,n)}onAsciiEncoding(){if(this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length)return Ee.prototype.onAsciiEncoding.call(this);let t=this.constructor.NAME,e=q.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 di&&t.push(e.valueBlock.valueHexView);return q.BufferSourceConverter.concat(t)}};di=se;S.OctetString=di;se.NAME=tl;var is=class extends ce(jt){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=jt.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let c of this.value){let a=c.constructor.NAME;if(a===Qr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(a!==el)return this.error="BIT STRING may consists of BIT STRINGs only",-1;let f=c.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=q.BufferSourceConverter.toUint8Array(t);if(!ae(this,o,e,n))return-1;let i=o.subarray(e,e+n);if(this.unusedBits=i[0],this.unusedBits>7)return this.error="Unused bits for BitString must be in range 0-7",-1;if(!this.unusedBits){let c=i.subarray(1);try{if(c.byteLength){let a=Rs(c,0,c.byteLength);a.offset!==-1&&a.offset===n-1&&(this.value=[a.result])}}catch{}}return this.valueHexView=i.subarray(1),this.blockLength=i.length,e+n}toBER(t,e){if(this.isConstructed)return jt.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}}};is.NAME="BitStringValueBlock";var cl,as=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},is),this.idBlock.tagClass=1,this.idBlock.tagNumber=3}fromBER(t,e,n){return this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,super.fromBER(t,e,n)}onAsciiEncoding(){if(this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length)return Ee.prototype.onAsciiEncoding.call(this);{let t=[],e=this.valueBlock.valueHexView;for(let i of e)t.push(i.toString(2).padStart(8,"0"));let n=t.join(""),s=this.constructor.NAME,o=n.substring(0,n.length-this.valueBlock.unusedBits);return`${s} : ${o}`}}};cl=as;S.BitString=cl;as.NAME=el;var ll;function $h(r,t){let e=new Uint8Array([0]),n=new Uint8Array(r),s=new Uint8Array(t),o=n.slice(0),i=o.length-1,c=s.slice(0),a=c.length-1,f=0,l=a<i?i:a,u=0;for(let d=l;d>=0;d--,u++){switch(!0){case u<c.length:f=o[i-u]+c[a-u]+e[0];break;default:f=o[i-u]+e[0]}switch(e[0]=f/10,!0){case u>=o.length:o=Wn(new Uint8Array([f%10]),o);break;default:o[i-u]=f%10}}return e[0]>0&&(o=Wn(e,o)),o}function Qc(r){if(r>=Yr.length)for(let t=Yr.length;t<=r;t++){let e=new Uint8Array([0]),n=Yr[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=Wn(e,n)),Yr.push(n)}return Yr[r]}function Gh(r,t){let e=0,n=new Uint8Array(r),s=new Uint8Array(t),o=n.slice(0),i=o.length-1,c=s.slice(0),a=c.length-1,f,l=0;for(let u=a;u>=0;u--,l++)switch(f=o[i-l]-c[a-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-a+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 tn=class extends ce(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=ui.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(Yc(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="",c=!1;for(let a=o.byteLength-1;a>=0;a--){s=o[a];for(let f=0;f<8;f++){if((s&1)===1)switch(n){case t:e=Gh(Qc(n),e),i="-";break;default:e=$h(e,Qc(n))}n++,s>>=1}}for(let a=0;a<e.length;a++)e[a]&&(c=!0),c&&(i+=Xc.charAt(e[a]));return c===!1&&(i+=Xc.charAt(0)),i}};ll=tn;tn.NAME="IntegerValueBlock";Object.defineProperty(ll.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var Jr,oe=class extends ct{constructor(t={}){super(t,tn),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return Zn(),BigInt(this.valueBlock.toString())}static fromBigInt(t){Zn();let e=BigInt(t),n=new Xr,s=e.toString(16).replace(/^-/,""),o=new Uint8Array(q.Convert.FromHex(s));if(e<0){let c=new Uint8Array(o.length+(o[0]&128?1:0));c[0]|=128;let f=BigInt(`0x${q.Convert.ToHex(c)}`)+e,l=q.BufferSourceConverter.toUint8Array(q.Convert.FromHex(f.toString(16)));l[0]|=128,n.write(l)}else o[0]&128&&n.write(new Uint8Array([0])),n.write(o);return new Jr({valueHex:n.final()})}convertToDER(){let t=new Jr({valueHex:this.valueBlock.valueHexView});return t.valueBlock.toDER(),t}convertFromDER(){return new Jr({valueHex:this.valueBlock.valueHexView[0]===0?this.valueBlock.valueHexView.subarray(1):this.valueBlock.valueHexView})}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()}`}};Jr=oe;S.Integer=Jr;oe.NAME="INTEGER";var ul,cs=class extends oe{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};ul=cs;S.Enumerated=ul;cs.NAME="ENUMERATED";var en=class extends ce(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=q.BufferSourceConverter.toUint8Array(t);if(!ae(this,s,e,n))return-1;let o=s.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let c=0;c<n&&(this.valueHexView[c]=o[c]&127,this.blockLength++,(o[c]&128)!==0);c++);let i=new Uint8Array(this.blockLength);for(let c=0;c<this.blockLength;c++)i[c]=this.valueHexView[c];return this.valueHexView=i,(o[this.blockLength-1]&128)!==0?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=Ve(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}set valueBigInt(t){Zn();let e=BigInt(t).toString(2);for(;e.length%7;)e="0"+e;let n=new Uint8Array(e.length/7);for(let s=0;s<n.length;s++)n[s]=parseInt(e.slice(s*7,s*7+7),2)+(s+1<n.length?128:0);this.fromBER(n.buffer,0,n.length)}toBER(t){if(this.isHexOnly){if(t)return new ArrayBuffer(this.valueHexView.byteLength);let s=this.valueHexView,o=new Uint8Array(this.blockLength);for(let i=0;i<this.blockLength-1;i++)o[i]=s[i]|128;return o[this.blockLength-1]=s[this.blockLength-1],o.buffer}let e=ve(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",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=q.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}}};en.NAME="sidBlock";var ls=class extends ht{constructor({value:t=mr,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new en;if(s=o.fromBER(t,s,n),s===-1)return this.blockLength=0,this.error=o.error,s;this.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 fi(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],c=0;switch(i.valueDec){case 0:break;case 1:c=40;break;case 2:c=80;break;default:this.value=[];return}let a=parseInt(s,10);if(isNaN(a))return;i.valueDec=a+c,o=!1}else{let i=new en;if(s>Number.MAX_SAFE_INTEGER){Zn();let c=BigInt(s);i.valueBigInt=c}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}};ls.NAME="ObjectIdentifierValueBlock";var fl,$t=class extends ct{getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}constructor(t={}){super(t,ls),this.idBlock.tagClass=1,this.idBlock.tagNumber=6}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};fl=$t;S.ObjectIdentifier=fl;$t.NAME="OBJECT IDENTIFIER";var rn=class extends ce(ne){constructor({valueDec:t=0,...e}={}){super(e),this.valueDec=t}fromBER(t,e,n){if(n===0)return e;let s=q.BufferSourceConverter.toUint8Array(t);if(!ae(this,s,e,n))return-1;let o=s.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let c=0;c<n&&(this.valueHexView[c]=o[c]&127,this.blockLength++,(o[c]&128)!==0);c++);let i=new Uint8Array(this.blockLength);for(let c=0;c<this.blockLength;c++)i[c]=this.valueHexView[c];return this.valueHexView=i,(o[this.blockLength-1]&128)!==0?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=Ve(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}toBER(t){if(this.isHexOnly){if(t)return new ArrayBuffer(this.valueHexView.byteLength);let s=this.valueHexView,o=new Uint8Array(this.blockLength);for(let i=0;i<this.blockLength-1;i++)o[i]=s[i]|128;return o[this.blockLength-1]=s[this.blockLength-1],o.buffer}let e=ve(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=q.Convert.ToHex(this.valueHexView):t=this.valueDec.toString(),t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};rn.NAME="relativeSidBlock";var us=class extends ht{constructor({value:t=mr,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new rn;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 fi(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 rn;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}};us.NAME="RelativeObjectIdentifierValueBlock";var hl,fs=class extends ct{getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}constructor(t={}){super(t,us),this.idBlock.tagClass=1,this.idBlock.tagNumber=13}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};hl=fs;S.RelativeObjectIdentifier=hl;fs.NAME="RelativeObjectIdentifier";var dl,St=class extends Ee{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};dl=St;S.Sequence=dl;St.NAME="SEQUENCE";var pl,hs=class extends Ee{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};pl=hs;S.Set=pl;hs.NAME="SET";var ds=class extends ce(ht){constructor({...t}={}){super(t),this.isHexOnly=!0,this.value=mr}toJSON(){return{...super.toJSON(),value:this.value}}};ds.NAME="StringValueBlock";var ps=class extends ds{};ps.NAME="SimpleStringValueBlock";var wt=class extends Xn{constructor({...t}={}){super(t,ps)}fromBuffer(t){this.valueBlock.value=String.fromCharCode.apply(null,q.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}};wt.NAME="SIMPLE STRING";var gs=class extends wt{fromBuffer(t){this.valueBlock.valueHexView=q.BufferSourceConverter.toUint8Array(t);try{this.valueBlock.value=q.Convert.ToUtf8String(t)}catch(e){this.warnings.push(`Error during "decodeURIComponent": ${e}, using raw string`),this.valueBlock.value=q.Convert.ToBinary(t)}}fromString(t){this.valueBlock.valueHexView=new Uint8Array(q.Convert.FromUtf8String(t)),this.valueBlock.value=t}};gs.NAME="Utf8StringValueBlock";var gl,ie=class extends gs{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};gl=ie;S.Utf8String=gl;ie.NAME="UTF8String";var ms=class extends wt{fromBuffer(t){this.valueBlock.value=q.Convert.ToUtf16String(t),this.valueBlock.valueHexView=q.BufferSourceConverter.toUint8Array(t)}fromString(t){this.valueBlock.value=t,this.valueBlock.valueHexView=new Uint8Array(q.Convert.FromUtf16String(t))}};ms.NAME="BmpStringValueBlock";var ml,ys=class extends ms{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};ml=ys;S.BmpString=ml;ys.NAME="BMPString";var bs=class extends wt{fromBuffer(t){let e=ArrayBuffer.isView(t)?t.slice().buffer:t.slice(0),n=new Uint8Array(e);for(let s=0;s<n.length;s+=4)n[s]=n[s+3],n[s+1]=n[s+2],n[s+2]=0,n[s+3]=0;this.valueBlock.value=String.fromCharCode.apply(null,new Uint32Array(e))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e*4);for(let s=0;s<e;s++){let o=ve(t.charCodeAt(s),8),i=new Uint8Array(o);if(i.length>4)continue;let c=4-i.length;for(let a=i.length-1;a>=0;a--)n[s*4+a+c]=i[a]}this.valueBlock.value=t}};bs.NAME="UniversalStringValueBlock";var yl,ws=class extends bs{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};yl=ws;S.UniversalString=yl;ws.NAME="UniversalString";var bl,xs=class extends wt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};bl=xs;S.NumericString=bl;xs.NAME="NumericString";var wl,vs=class extends wt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};wl=vs;S.PrintableString=wl;vs.NAME="PrintableString";var xl,Es=class extends wt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};xl=Es;S.TeletexString=xl;Es.NAME="TeletexString";var vl,Bs=class extends wt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};vl=Bs;S.VideotexString=vl;Bs.NAME="VideotexString";var El,As=class extends wt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};El=As;S.IA5String=El;As.NAME="IA5String";var Bl,Ss=class extends wt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};Bl=Ss;S.GraphicString=Bl;Ss.NAME="GraphicString";var Al,nn=class extends wt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};Al=nn;S.VisibleString=Al;nn.NAME="VisibleString";var Sl,ks=class extends wt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};Sl=ks;S.GeneralString=Sl;ks.NAME="GeneralString";var kl,Is=class extends wt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};kl=Is;S.CharacterString=kl;Is.NAME="CharacterString";var Il,sn=class extends nn{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,q.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]=At(this.year<2e3?this.year-1900:this.year-2e3,2),e[1]=At(this.month,2),e[2]=At(this.day,2),e[3]=At(this.hour,2),e[4]=At(this.minute,2),e[5]=At(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}}};Il=sn;S.UTCTime=Il;sn.NAME="UTCTime";var Cl,Cs=class extends sn{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,c=0,a=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,d=n.indexOf("+"),b="";if(d===-1&&(d=n.indexOf("-"),u=-1),d!==-1){if(b=n.substring(d+1),n=n.substring(0,d),b.length!==2&&b.length!==4)throw new Error("Wrong input string for conversion");let y=parseInt(b.substring(0,2),10);if(isNaN(y.valueOf()))throw new Error("Wrong input string for conversion");if(c=u*y,b.length===4){if(y=parseInt(b.substring(2,4),10),isNaN(y.valueOf()))throw new Error("Wrong input string for conversion");a=u*y}}}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)+c;break;case 5:this.minute=parseInt(l[u],10)+a;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(At(this.year,4)),e.push(At(this.month,2)),e.push(At(this.day,2)),e.push(At(this.hour,2)),e.push(At(this.minute,2)),e.push(At(this.second,2)),this.millisecond!==0&&(e.push("."),e.push(At(this.millisecond,3))),e.push("Z"),e.join("")}return super.toString(t)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};Cl=Cs;S.GeneralizedTime=Cl;Cs.NAME="GeneralizedTime";var Nl,Ns=class extends ie{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};Nl=Ns;S.DATE=Nl;Ns.NAME="DATE";var Ul,Us=class extends ie{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};Ul=Us;S.TimeOfDay=Ul;Us.NAME="TimeOfDay";var Tl,Ts=class extends ie{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};Tl=Ts;S.DateTime=Tl;Ts.NAME="DateTime";var Ll,Ls=class extends ie{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};Ll=Ls;S.Duration=Ll;Ls.NAME="Duration";var _l,_s=class extends ie{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};_l=_s;S.TIME=_l;_s.NAME="TIME";async function Hs(r,t){let n=await pr.create().encrypt(r,t);return Se.encode(n)}async function pi(r,t,e){if(r.type==="RSA")return Yh(r,t,e);if(r.type==="Ed25519")return zh(r,t,e);if(r.type==="secp256k1")return Wh(r,t,e);if(r.type==="ECDSA")return Zh(r,t,e);throw new je}async function zh(r,t,e="libp2p-key"){if(e==="libp2p-key")return Hs(Oe(r),t);throw new L(`export format '${e}' is not supported`)}async function Wh(r,t,e="libp2p-key"){if(e==="libp2p-key")return Hs(Oe(r),t);throw new L("Export format is not supported")}async function Zh(r,t,e="libp2p-key"){if(e==="libp2p-key")return Hs(Oe(r),t);throw new L(`export format '${e}' is not supported`)}async function Yh(r,t,e="pkcs-8"){if(e==="pkcs-8")return Jh(r,t);if(e==="libp2p-key")return Hs(Oe(r),t);throw new L("Export format is not supported")}async function Jh(r,t){let e=vt.get(),s=new St({value:[new oe({value:0}),new St({value:[new $t({value:"1.2.840.113549.1.1.1"}),new Pe]}),new se({valueHex:r.raw})]}).toBER(),o=new Uint8Array(s,0,s.byteLength),i=Ke(16),c=await Pn(fr,t,i,{c:1e4,dkLen:32}),a=Ke(16),f=await e.subtle.importKey("raw",c,"AES-CBC",!1,["encrypt"]),l=await e.subtle.encrypt({name:"AES-CBC",iv:a},f,o),u=new St({value:[new se({valueHex:i}),new oe({value:1e4}),new oe({value:32}),new St({value:[new $t({value:"1.2.840.113549.2.11"}),new Pe]})]}),d=new St({value:[new $t({value:"1.2.840.113549.1.5.13"}),new St({value:[new St({value:[new $t({value:"1.2.840.113549.1.5.12"}),u]}),new St({value:[new $t({value:"2.16.840.1.101.3.4.1.42"}),new se({valueHex:a})]})]})]}),y=new St({value:[d,new se({valueHex:l})]}).toBER(),g=new Uint8Array(y,0,y.byteLength);return["-----BEGIN ENCRYPTED PRIVATE KEY-----",...G(g,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
7
+ `)}async function gi(r,t){try{let e=await Xh(r,t);return vc(e)}catch{}if(!r.includes("BEGIN"))throw new L("Encrypted key was not a libp2p-key or a PEM file");return Qh(r,t)}async function Xh(r,t){let e=Se.decode(r);return pr.create().decrypt(e,t)}async function Qh(r,t){let e=vt.get(),n;if(r.includes("-----BEGIN ENCRYPTED PRIVATE KEY-----")){let o=P(r.replace("-----BEGIN ENCRYPTED PRIVATE KEY-----","").replace("-----END ENCRYPTED PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:i}=Ds(o),{iv:c,salt:a,iterations:f,keySize:l,cipherText:u}=td(i),d=await Pn(fr,t,a,{c:f,dkLen:l}),b=await e.subtle.importKey("raw",d,"AES-CBC",!1,["decrypt"]),y=on(await e.subtle.decrypt({name:"AES-CBC",iv:c},b,u)),{result:g}=Ds(y);n=Kl(g)}else if(r.includes("-----BEGIN PRIVATE KEY-----")){let o=P(r.replace("-----BEGIN PRIVATE KEY-----","").replace("-----END PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:i}=Ds(o);n=Kl(i)}else throw new L("Could not parse private key from PEM data");let s=Ec(n);if(s.type!=="RSA")throw new L("Could not parse RSA private key from PEM data");return s}function td(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=on(o.valueBlock.value[0].getValue()),c=1e4,a=32;if(o.valueBlock.value.length===3)c=Number(o.valueBlock.value[1].toBigInt()),a=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=on(f.valueBlock.value[1].getValue());return{cipherText:on(r.valueBlock.value[1].getValue()),salt:i,iterations:c,keySize:a,iv:u}}function Kl(r){return on(r.valueBlock.value[2].getValue())}function on(r){return new Uint8Array(r,0,r.byteLength)}var ed="/pkcs8/",yi="/info/",an=new WeakMap,Me={minKeyLength:112/8,minSaltLength:128/8,minIterationCount:1e3},mi={dek:{keyLength:512/8,iterationCount:1e4,salt:"you should override this value with a crypto secure random number",hash:"sha2-512"}};function yr(r){return r==null||typeof r!="string"?!1:r===(0,Ol.default)(r.trim())&&r.length>0}async function lt(){let e=Math.random()*800+200;await new Promise(n=>setTimeout(n,e))}function Fe(r){return new Zr(ed+r)}function br(r){return new Zr(yi+r)}async function rd(r){let t=Oe(r),e=await Je.digest(t);return et.encode(e.bytes).substring(1)}var Ks=class{components;init;log;self;constructor(t,e){if(this.components=t,this.log=t.logger.forComponent("libp2p:keychain"),this.init=Vc(mi,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?Wr(this.init.pass,this.init.dek?.salt,this.init.dek?.iterationCount,this.init.dek?.keyLength,this.init.dek?.hash):"";an.set(this,{dek:n})}[Symbol.toStringTag]="@libp2p/keychain";[vi]=["@libp2p/keychain"];static generateOptions(){let t=Object.assign({},mi),e=Math.ceil(Me.minSaltLength/3)*3;return t.dek.salt=G(Ke(e),"base64"),t}static get options(){return mi}async findKeyByName(t){if(!yr(t))throw await lt(),new L(`Invalid key name '${t}'`);let e=br(t);try{let n=await this.components.datastore.get(e);return JSON.parse(G(n))}catch(n){throw await lt(),this.log.error(n),new un(`Key '${t}' does not exist.`)}}async findKeyById(t){try{let e={prefix:yi};for await(let n of this.components.datastore.query(e)){let s=JSON.parse(G(n.value));if(s.id===t)return s}throw new L(`Key with id '${t}' does not exist.`)}catch(e){throw await lt(),e}}async importKey(t,e){if(!yr(t))throw await lt(),new L(`Invalid key name '${t}'`);if(e==null)throw await lt(),new L("Key is required");let n=Fe(t);if(await this.components.datastore.has(n))throw await lt(),new L(`Key '${t}' already exists`);let o,i;try{o=await rd(e);let f=an.get(this);if(f==null)throw new L("dek missing");let l=f.dek;i=await pi(e,l,e.type==="RSA"?"pkcs-8":"libp2p-key")}catch(f){throw await lt(),f}let c={name:t,id:o},a=this.components.datastore.batch();return a.put(n,P(i)),a.put(br(t),P(JSON.stringify(c))),await a.commit(),c}async exportKey(t){if(!yr(t))throw await lt(),new L(`Invalid key name '${t}'`);let e=Fe(t);try{let n=await this.components.datastore.get(e),s=G(n),o=an.get(this);if(o==null)throw new L("dek missing");let i=o.dek;return await gi(s,i)}catch(n){throw await lt(),n}}async removeKey(t){if(!yr(t)||t===this.self)throw await lt(),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(br(t)),await s.commit(),n}async listKeys(){let t={prefix:yi},e=[];for await(let n of this.components.datastore.query(t))e.push(JSON.parse(G(n.value)));return e}async renameKey(t,e){if(!yr(t)||t===this.self)throw await lt(),new L(`Invalid old key name '${t}'`);if(!yr(e)||e===this.self)throw await lt(),new L(`Invalid new key name '${e}'`);let n=Fe(t),s=Fe(e),o=br(t),i=br(e);if(await this.components.datastore.has(s))throw await lt(),new L(`Key '${e}' already exists`);try{let a=await this.components.datastore.get(n),f=await this.components.datastore.get(o),l=JSON.parse(G(f));l.name=e;let u=this.components.datastore.batch();return u.put(s,a),u.put(i,P(JSON.stringify(l))),u.delete(n),u.delete(o),await u.commit(),l}catch(a){throw await lt(),a}}async rotateKeychainPass(t,e){if(typeof t!="string")throw await lt(),new L(`Invalid old pass type '${typeof t}'`);if(typeof e!="string")throw await lt(),new L(`Invalid new pass type '${typeof e}'`);if(e.length<20)throw await lt(),new L(`Invalid pass length ${e.length}`);this.log("recreating keychain");let n=an.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?Wr(e,this.init.dek.salt,this.init.dek?.iterationCount,this.init.dek?.keyLength,this.init.dek?.hash):"";an.set(this,{dek:o});let i=await this.listKeys();for(let c of i){let a=await this.components.datastore.get(Fe(c.name)),f=G(a),l=await gi(f,s),u=o.toString(),d=await pi(l,u,l.type==="RSA"?"pkcs-8":"libp2p-key"),b=this.components.datastore.batch(),y={name:c.name,id:c.id};b.put(Fe(c.name),P(d)),b.put(br(c.name),P(JSON.stringify(y))),await b.commit()}this.log("keychain reconstructed")}};function nd(r={}){return t=>new Ks(t,r)}return Wl(sd);})();
8
8
  /*! Bundled license information:
9
9
 
10
10
  pvtsutils/build/index.js:
@@ -37,26 +37,12 @@ pvtsutils/build/index.js:
37
37
  (*! noble-hashes - MIT License (c) 2022 Paul Miller (paulmillr.com) *)
38
38
 
39
39
  @noble/curves/esm/abstract/utils.js:
40
- (*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) *)
41
-
42
40
  @noble/curves/esm/abstract/modular.js:
43
- (*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) *)
44
-
45
41
  @noble/curves/esm/abstract/curve.js:
46
- (*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) *)
47
-
48
42
  @noble/curves/esm/abstract/edwards.js:
49
- (*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) *)
50
-
51
43
  @noble/curves/esm/ed25519.js:
52
- (*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) *)
53
-
54
44
  @noble/curves/esm/abstract/weierstrass.js:
55
- (*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) *)
56
-
57
45
  @noble/curves/esm/_shortw_utils.js:
58
- (*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) *)
59
-
60
46
  @noble/curves/esm/secp256k1.js:
61
47
  (*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) *)
62
48
 
@@ -101,3 +87,4 @@ asn1js/build/index.es.js:
101
87
  *)
102
88
  */
103
89
  return Libp2PKeychain}));
90
+ //# sourceMappingURL=index.min.js.map