@libp2p/keychain 5.2.3 → 5.2.4-2a7425cdb
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 +1 -1
- package/dist/index.min.js.map +3 -3
- package/package.json +7 -7
- package/dist/typedoc-urls.json +0 -14
package/dist/index.min.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
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 Kl=Object.create;var ln=Object.defineProperty;var Ol=Object.getOwnPropertyDescriptor;var Vl=Object.getOwnPropertyNames;var Pl=Object.getPrototypeOf,Ml=Object.prototype.hasOwnProperty;var xr=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),dt=(r,t)=>{for(var e in t)ln(r,e,{get:t[e],enumerable:!0})},bi=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of Vl(t))!Ml.call(r,s)&&s!==e&&ln(r,s,{get:()=>t[s],enumerable:!(n=Ol(t,s))||n.enumerable});return r};var wi=(r,t,e)=>(e=r!=null?Kl(Pl(r)):{},bi(t||!r||!r.__esModule?ln(e,"default",{value:r,enumerable:!0}):e,r)),Fl=r=>bi(ln({},"__esModule",{value:!0}),r);var Dc=xr((Ay,Rc)=>{"use strict";function yh(r){return r>=55296&&r<=56319}function bh(r){return r>=56320&&r<=57343}Rc.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],yh(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 Kc=xr((Sy,Hc)=>{"use strict";function wh(r){return r>=55296&&r<=56319}function xh(r){return r>=56320&&r<=57343}Hc.exports=function(t){if(typeof t!="string")throw new Error("Input must be string");for(var e=t.length,n=0,s=null,o=null,i=0;i<e;i++)s=t.charCodeAt(i),xh(s)?o!=null&&wh(o)?n+=1:n+=3:s<=127?n+=1:s>=128&&s<=2047?n+=2:s>=2048&&s<=65535&&(n+=3),o=s;return n}});var Vc=xr((ky,Oc)=>{"use strict";var vh=Dc(),Eh=Kc();Oc.exports=vh.bind(null,Eh)});var Fc=xr((Iy,Mc)=>{"use strict";var Bh=Vc(),Ah=/[\/\?<>\\:\*\|"]/g,Sh=/[\x00-\x1f\x80-\x9f]/g,kh=/^\.+$/,Ih=/^(con|prn|aux|nul|com[0-9]|lpt[0-9])(\..*)?$/i,Ch=/[\. ]+$/;function Pc(r,t){if(typeof r!="string")throw new Error("Input must be string");var e=r.replace(Ah,t).replace(Sh,t).replace(kh,t).replace(Ih,t).replace(Ch,t);return Bh(e,255)}Mc.exports=function(r,t){var e=t&&t.replacement||"",n=Pc(r,e);return e===""?n:Pc(n,"")}});var qc=xr(gr=>{"use strict";var Uh="[object ArrayBuffer]",re=class r{static isArrayBuffer(t){return Object.prototype.toString.call(t)===Uh}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}},ci="string",Th=/^[0-9a-f\s]+$/i,Lh=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,_h=/^[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===ci&&Th.test(t)}static isBase64(t){return typeof t===ci&&Lh.test(t)}static isBase64Url(t){return typeof t===ci&&_h.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 Rh(r,...t){let e=arguments[0];for(let n=1;n<arguments.length;n++){let s=arguments[n];for(let o in s)e[o]=s[o]}return e}function Dh(...r){let t=r.map(s=>s.byteLength).reduce((s,o)=>s+o),e=new Uint8Array(t),n=0;return r.map(s=>new Uint8Array(s)).forEach(s=>{for(let o of s)e[n++]=o}),e.buffer}function Hh(r,t){if(!(r&&t)||r.byteLength!==t.byteLength)return!1;let e=new Uint8Array(r),n=new Uint8Array(t);for(let s=0;s<r.byteLength;s++)if(e[s]!==n[s])return!1;return!0}gr.BufferSourceConverter=re;gr.Convert=zn;gr.assign=Rh;gr.combine=Dh;gr.isEqual=Hh});var Qh={};dt(Qh,{keychain:()=>Xh});var vr=class extends Error{constructor(t="An error occurred while signing a message"){super(t),this.name="SigningError"}},Er=class extends Error{constructor(t="An error occurred while verifying a message"){super(t),this.name="VerificationError"}},un=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 un("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"}},Fe=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 fn=class extends Error{static name="NotFoundError";constructor(t="Not found"){super(t),this.name="NotFoundError"}};var qe=class extends Error{static name="UnsupportedKeyTypeError";constructor(t="Unsupported key type"){super(t),this.name="UnsupportedKeyTypeError"}};var vi=Symbol.for("@libp2p/service-capabilities"),ad=Symbol.for("@libp2p/service-dependencies");var Fs={};dt(Fs,{base58btc:()=>et,base58flickr:()=>Zl});var Ud=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 ql(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 jl=ql,$l=jl,ki=$l;var Os=class{name;prefix;baseEncode;constructor(t,e,n){this.name=t,this.prefix=e,this.baseEncode=n}encode(t){if(t instanceof Uint8Array)return`${this.prefix}${this.baseEncode(t)}`;throw Error("Unknown type, must be binary type")}},Vs=class{name;prefix;baseDecode;prefixCodePoint;constructor(t,e,n){this.name=t,this.prefix=e;let s=e.codePointAt(0);if(s===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=s,this.baseDecode=n}decode(t){if(typeof t=="string"){if(t.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(t)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(t.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(t){return Ii(this,t)}},Ps=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 Ps({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var Ms=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(t,e,n,s){this.name=t,this.prefix=e,this.baseEncode=n,this.baseDecode=s,this.encoder=new Os(t,e,n),this.decoder=new Vs(t,e,s)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function je({name:r,prefix:t,encode:e,decode:n}){return new Ms(r,t,e,n)}function le({name:r,prefix:t,alphabet:e}){let{encode:n,decode:s}=ki(e,r);return je({prefix:t,name:r,encode:n,decode:o=>Gt(s(o))})}function Gl(r,t,e,n){let s=r.length;for(;r[s-1]==="=";)--s;let o=new Uint8Array(s*e/8|0),i=0,c=0,a=0;for(let f=0;f<s;++f){let l=t[r[f]];if(l===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<e|l,i+=e,i>=8&&(i-=8,o[a++]=255&c>>i)}if(i>=e||(255&c<<8-i)!==0)throw new SyntaxError("Unexpected end of data");return o}function zl(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 Wl(r){let t={};for(let e=0;e<r.length;++e)t[r[e]]=e;return t}function J({name:r,prefix:t,bitsPerChar:e,alphabet:n}){let s=Wl(n);return je({prefix:t,name:r,encode(o){return zl(o,n,e)},decode(o){return Gl(o,s,e,r)}})}var et=le({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),Zl=le({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var qs={};dt(qs,{base32:()=>$e,base32hex:()=>Ql,base32hexpad:()=>eu,base32hexpadupper:()=>ru,base32hexupper:()=>tu,base32pad:()=>Jl,base32padupper:()=>Xl,base32upper:()=>Yl,base32z:()=>nu});var $e=J({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),Yl=J({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Jl=J({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),Xl=J({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),Ql=J({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),tu=J({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),eu=J({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),ru=J({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),nu=J({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var js={};dt(js,{base36:()=>Ar,base36upper:()=>su});var Ar=le({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),su=le({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var ou=Ui,Ci=128,iu=127,au=~iu,cu=Math.pow(2,31);function Ui(r,t,e){t=t||[],e=e||0;for(var n=e;r>=cu;)t[e++]=r&255|Ci,r/=128;for(;r&au;)t[e++]=r&255|Ci,r>>>=7;return t[e]=r|0,Ui.bytes=e-n+1,t}var lu=$s,uu=128,Ni=127;function $s(r,n){var e=0,n=n||0,s=0,o=n,i,c=r.length;do{if(o>=c)throw $s.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>=uu);return $s.bytes=o-n,e}var fu=Math.pow(2,7),hu=Math.pow(2,14),du=Math.pow(2,21),pu=Math.pow(2,28),gu=Math.pow(2,35),mu=Math.pow(2,42),yu=Math.pow(2,49),bu=Math.pow(2,56),wu=Math.pow(2,63),xu=function(r){return r<fu?1:r<hu?2:r<du?3:r<pu?4:r<gu?5:r<mu?6:r<yu?7:r<bu?8:r<wu?9:10},vu={encode:ou,decode:lu,encodingLength:xu},Eu=vu,Sr=Eu;function kr(r,t=0){return[Sr.decode(r,t),Sr.decode.bytes]}function Ge(r,t,e=0){return Sr.encode(r,t,e),t}function ze(r){return Sr.encodingLength(r)}function _t(r,t){let e=t.byteLength,n=ze(r),s=n+ze(e),o=new Uint8Array(s+e);return Ge(r,o,0),Ge(e,o,n),o.set(t,s),new We(r,e,t,o)}function Ti(r){let t=Gt(r),[e,n]=kr(t),[s,o]=kr(t.subarray(n)),i=t.subarray(n+o);if(i.byteLength!==s)throw new Error("Incorrect length");return new We(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 We=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 Au(e,Gs(r),t??et.encoder);default:return Su(e,Gs(r),t??$e.encoder)}}var Ri=new WeakMap;function Gs(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!==Cr)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==ku)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[Iu]===!0){let{version:n,multihash:s,code:o}=e,i=Ti(s);return r.create(n,o,i)}else return null}static create(t,e,n){if(typeof e!="number")throw new Error("String codecs are no longer supported");if(!(n.bytes instanceof Uint8Array))throw new Error("Invalid digest");switch(t){case 0:{if(e!==Cr)throw new Error(`Version 0 CID must use dag-pb (code: ${Cr}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let s=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,Cr,t)}static createV1(t,e){return r.create(1,t,e)}static decode(t){let[e,n]=r.decodeFirst(t);if(n.length!==0)throw new Error("Incorrect length");return e}static decodeFirst(t){let e=r.inspectBytes(t),n=e.size-e.multihashSize,s=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 We(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]=kr(t.subarray(e));return e+=d,u},s=n(),o=Cr;if(s===18?(s=0,e=0):o=n(),s!==0&&s!==1)throw new RangeError(`Invalid CID version ${s}`);let i=e,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]=Bu(t,e),o=r.decode(s);if(o.version===0&&t[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return Gs(o).set(n,t),o}};function Bu(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 $e.prefix:{let e=t??$e;return[$e.prefix,e.decode(r)]}case Ar.prefix:{let e=t??Ar;return[Ar.prefix,e.decode(r)]}default:{if(t==null)throw Error("To parse non base32, base36 or base58btc encoded CID multibase decoder must be provided");return[r[0],t.decode(r)]}}}function Au(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 Su(r,t,e){let{prefix:n}=e,s=t.get(n);if(s==null){let o=e.encode(r);return t.set(n,o),o}else return s}var Cr=112,ku=18;function Di(r,t,e){let n=ze(r),s=n+ze(t),o=new Uint8Array(s+e.byteLength);return Ge(r,o,0),Ge(t,o,n),o.set(e,s),o}var Iu=Symbol.for("@ipld/js-cid/CID");var zs={};dt(zs,{identity:()=>Be});var Hi=0,Cu="identity",Ki=Gt;function Nu(r){return _t(Hi,Ki(r))}var Be={code:Hi,name:Cu,encode:Ki,digest:Nu};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 Ze(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 dn(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(dn(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(dn(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(dn(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],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(!dn(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 Ws={};dt(Ws,{base10:()=>Uu});var Uu=le({prefix:"9",name:"base10",alphabet:"0123456789"});var Zs={};dt(Zs,{base16:()=>Tu,base16upper:()=>Lu});var Tu=J({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Lu=J({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Ys={};dt(Ys,{base2:()=>_u});var _u=J({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Js={};dt(Js,{base256emoji:()=>Ou});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}"),Ru=Pi.reduce((r,t,e)=>(r[e]=t,r),[]),Du=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 Hu(r){return r.reduce((t,e)=>(t+=Ru[e],t),"")}function Ku(r){let t=[];for(let e of r){let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);let s=Du[n];if(s==null)throw new Error(`Non-base256emoji character: ${e}`);t.push(s)}return new Uint8Array(t)}var Ou=je({prefix:"\u{1F680}",name:"base256emoji",encode:Hu,decode:Ku});var Xs={};dt(Xs,{base64:()=>Ae,base64pad:()=>Vu,base64url:()=>Pu,base64urlpad:()=>Mu});var Ae=J({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),Vu=J({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Pu=J({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Mu=J({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Qs={};dt(Qs,{base8:()=>Fu});var Fu=J({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var to={};dt(to,{identity:()=>qu});var qu=je({prefix:"\0",name:"identity",encode:r=>Ai(r),decode:r=>Bi(r)});var d0=new TextEncoder,p0=new TextDecoder;var no={};dt(no,{sha256:()=>Ye,sha512:()=>Gu});function ro({name:r,code:t,encode:e}){return new eo(r,t,e)}var eo=class{name;code;encode;constructor(t,e,n){this.name=t,this.code=e,this.encode=n}digest(t){if(t instanceof Uint8Array){let e=this.encode(t);return e instanceof Uint8Array?_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 Ye=ro({name:"sha2-256",code:18,encode:Fi("SHA-256")}),Gu=ro({name:"sha2-512",code:19,encode:Fi("SHA-512")});var so={...to,...Ys,...Qs,...Ws,...Zs,...qs,...js,...Fs,...Xs,...Js},k0={...no,...zs};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))),oo=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}),zu={utf8:qi,"utf-8":qi,hex:so.base16,latin1:oo,ascii:oo,binary:oo,...so},pn=zu;function P(r,t="utf8"){let e=pn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function G(r,t="utf8"){let e=pn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}var Wu=parseInt("11111",2),io=parseInt("10000000",2),Zu=parseInt("01111111",2),$i={0:Nr,1:Nr,2:Yu,3:Qu,4:tf,5:Xu,6:Ju,16:Nr,22:Nr,48:Nr};function Rt(r,t={offset:0}){let e=r[t.offset]&Wu;if(t.offset++,$i[e]!=null)return $i[e](r,t);throw new Error("No decoder for tag "+e)}function Ur(r,t){let e=0;if((r[t.offset]&io)===io){let n=r[t.offset]&Zu,s="0x";t.offset++;for(let o=0;o<n;o++,t.offset++)s+=r[t.offset].toString(16).padStart(2,"0");e=parseInt(s,16)}else e=r[t.offset],t.offset++;return e}function Nr(r,t){Ur(r,t);let e=[];for(;!(t.offset>=r.byteLength);){let n=Rt(r,t);if(n===null)break;e.push(n)}return e}function Yu(r,t){let e=Ur(r,t),n=t.offset,s=t.offset+e,o=[];for(let i=n;i<s;i++)i===n&&r[i]===0||o.push(r[i]);return t.offset+=e,Uint8Array.from(o)}function Ju(r,t){let e=Ur(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 Xu(r,t){return t.offset++,null}function Qu(r,t){let e=Ur(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 tf(r,t){let e=Ur(r,t),n=r.subarray(t.offset,t.offset+e);return t.offset+=e,n}function ef(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 gn(r){if(r.byteLength<128)return Uint8Array.from([r.byteLength]);let t=ef(r.byteLength);return new pt(Uint8Array.from([t.byteLength|io]),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]),gn(t),t)}function Tr(r){let t=Uint8Array.from([0]),e=new pt(t,r);return new pt(Uint8Array.from([3]),gn(e),e)}function Gi(r){return new pt(Uint8Array.from([4]),gn(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]),gn(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 rf=Uint8Array.from([6,8,42,134,72,206,61,3,1,7]),nf=Uint8Array.from([6,5,43,129,4,0,34]),sf=Uint8Array.from([6,5,43,129,4,0,35]),of={ext:!0,kty:"EC",crv:"P-256"},af={ext:!0,kty:"EC",crv:"P-384"},cf={ext:!0,kty:"EC",crv:"P-521"},ao=32,co=48,lo=66;function Xi(r){let t=Rt(r);return uo(t)}function uo(r){let t=r[1],e=G(t,"base64url"),n=r[2][1][0],s=1,o,i;if(t.byteLength===ao)return o=G(n.subarray(s,s+ao),"base64url"),i=G(n.subarray(s+ao),"base64url"),new Je({...of,key_ops:["sign"],d:e,x:o,y:i});if(t.byteLength===co)return o=G(n.subarray(s,s+co),"base64url"),i=G(n.subarray(s+co),"base64url"),new Je({...af,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 Je({...cf,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([Tr(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([Tr(new pt(Uint8Array.from([4]),P(r.x??"","base64url"),P(r.y??"","base64url")))],161)]).subarray()}function ea(r){if(r==="P-256")return rf;if(r==="P-384")return nf;if(r==="P-521")return sf;throw new L(`Invalid curve ${r}`)}var mn=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 Be.digest(Xe(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)}},Je=class{type="ECDSA";jwk;publicKey;_raw;constructor(t){this.jwk=t,this.publicKey=new mn({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 Se=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;function lf(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(!lf(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 yn(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 tr(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 ke(r){return new DataView(r.buffer,r.byteOffset,r.byteLength)}function Ht(r,t){return r<<32-t|r>>>t}function bn(r,t){return r<<t|r>>>32-t>>>0}var uf=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 uf(),n+=o)}}function fo(r){if(typeof r!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(r))}function Lr(r){return typeof r=="string"&&(r=fo(r)),fe(r),r}function ho(r){return typeof r=="string"&&(r=fo(r)),fe(r),r}function po(...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 Qe=class{};function _r(r){let t=n=>r().update(Lr(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function er(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 ff(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 wn(r,t,e){return r&t^~r&e}function xn(r,t,e){return r&t^r&e^t&e}var Ie=class extends Qe{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){tr(this),t=Lr(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=ke(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){tr(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;ff(n,s-8,BigInt(this.length*8),o),this.process(n,0);let c=ke(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 vn=BigInt(4294967295),oa=BigInt(32);function hf(r,t=!1){return t?{h:Number(r&vn),l:Number(r>>oa&vn)}:{h:Number(r>>oa&vn)|0,l:Number(r&vn)|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}=hf(r[o],t);[n[o],s[o]]=[i,c]}return[n,s]}var go=(r,t,e)=>r>>>e,mo=(r,t,e)=>r<<32-e|t>>>e,Ce=(r,t,e)=>r>>>e|t<<32-e,Ne=(r,t,e)=>r<<32-e|t>>>e,Rr=(r,t,e)=>r<<64-e|t>>>e-32,Dr=(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 pf=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),En=class extends Ie{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+wn(c,a,f)+pf[u]+he[u]|0,g=(Ht(n,2)^Ht(n,13)^Ht(n,22))+xn(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))),gf=da[0],mf=da[1],de=new Uint32Array(80),pe=new Uint32Array(80),Bn=class extends Ie{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=Ce(h,w,1)^Ce(h,w,8)^go(h,w,7),C=Ne(h,w,1)^Ne(h,w,8)^mo(h,w,7),U=de[x-2]|0,H=pe[x-2]|0,V=Ce(U,H,19)^Rr(U,H,61)^go(U,H,6),_=Ne(U,H,19)^Dr(U,H,61)^mo(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=Ce(u,d,14)^Ce(u,d,18)^Rr(u,d,41),w=Ne(u,d,14)^Ne(u,d,18)^Dr(u,d,41),k=u&b^~u&g,C=d&y^~d&N,U=fa(M,w,C,mf[x],pe[x]),H=ha(U,I,h,k,gf[x],de[x]),V=U|0,_=Ce(n,s,28)^Rr(n,s,34)^Rr(n,s,39),K=Ne(n,s,28)^Dr(n,s,34)^Dr(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 An=_r(()=>new En);var Sn=_r(()=>new Bn);var xo=BigInt(0),wo=BigInt(1);function rr(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function vo(r){if(!rr(r))throw new Error("Uint8Array expected")}function Mt(r,t){if(typeof t!="boolean")throw new Error(r+" boolean expected, got "+t)}function Hr(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===""?xo:BigInt("0x"+r)}var ya=typeof Uint8Array.from([]).toHex=="function"&&typeof Uint8Array.fromHex=="function",yf=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function ge(r){if(vo(r),ya)return r.toHex();let t="";for(let e=0;e<r.length;e++)t+=yf[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 Kr(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 Ue(r){return vo(r),ma(ge(Uint8Array.from(r).reverse()))}function Te(r,t){return Kr(r.toString(16).padStart(t*2,"0"))}function nr(r,t){return Te(r,t).reverse()}function Z(r,t,e){let n;if(typeof t=="string")try{n=Kr(t)}catch(o){throw new Error(r+" must be hex string or Uint8Array, cause: "+o)}else if(rr(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];vo(s),t+=s.length}let e=new Uint8Array(t);for(let n=0,s=0;n<r.length;n++){let o=r[n];e.set(o,s),s+=o.length}return e}var yo=r=>typeof r=="bigint"&&xo<=r;function kn(r,t,e){return yo(r)&&yo(t)&&yo(e)&&t<=r&&r<e}function Ct(r,t,e,n){if(!kn(t,e,n))throw new Error("expected valid "+r+": "+e+" <= n < "+n+", got "+t)}function ba(r){let t;for(t=0;r>xo;r>>=wo,t+=1);return t}var Le=r=>(wo<<BigInt(r))-wo,bo=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=bo(r),s=bo(r),o=0,i=()=>{n.fill(1),s.fill(0),o=0},c=(...u)=>e(s,n,...u),a=(u=bo(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"||rr(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 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 mt=BigInt(0),st=BigInt(1),_e=BigInt(2),wf=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 In(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 xf(r,t){let e=(r.ORDER-Ea)/Ba,n=r.mul(t,_e),s=r.pow(n,e),o=r.mul(t,s),i=r.mul(r.mul(o,_e),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 vf(r){if(r<BigInt(3))throw new Error("sqrt is not defined for small field");let t=r-st,e=0;for(;t%_e===mt;)t/=_e,e++;let n=_e,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)/_e;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 Ef(r){return r%va===wf?Aa:r%Ba===Ea?xf:vf(r)}var Sa=(r,t)=>(W(r,t)&st)===st,Bf=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function Eo(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=Bf.reduce((n,s)=>(n[s]="function",n),t);return Jt(r,e)}function Af(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 or(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)/_e,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 Bo(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}=Bo(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:Le(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)=>Af(c,a,f),div:(a,f)=>W(a*In(f,r),r),sqrN:a=>a*a,addN:(a,f)=>a+f,subN:(a,f)=>a-f,mulN:(a,f)=>a*f,inv:a=>In(a,r),sqrt:n.sqrt||(a=>(i||(i=Ef(r)),i(c,a))),toBytes:a=>e?nr(a,o):Te(a,o),fromBytes:a=>{if(a.length!==o)throw new Error("Field.fromBytes: expected "+o+" bytes, got "+a.length);return e?Ue(a):Yt(a)},invertBatch:a=>or(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 Ao(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=Ao(t);if(n<16||n<o||n>1024)throw new Error("expected "+o+"-1024 bytes of input, got "+n);let i=e?Ue(r):Yt(r),c=W(i,t-st)+st;return e?nr(c,s):Te(c,s)}var Ca=BigInt(0),No=BigInt(1);function So(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 ko(r,t){Ua(r,t);let e=Math.ceil(t/r)+1,n=2**(r-1),s=2**r,o=Le(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+=No);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 Sf(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 kf(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 Io=new WeakMap,Ta=new WeakMap;function Co(r){return Ta.get(r)||1}function Cn(r,t){return{constTimeNegate:So,hasPrecomputes(e){return Co(e)!==1},unsafeLadder(e,n,s=r.ZERO){let o=e;for(;n>Ca;)n&No&&(s=s.add(o)),o=o.double(),n>>=No;return s},precomputeWindow(e,n){let{windows:s,windowSize:o}=ko(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=ko(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(So(b,n[y])):o=o.add(So(d,n[l]))}return{p:o,f:i}},wNAFUnsafe(e,n,s,o=r.ZERO){let i=ko(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=Io.get(n);return o||(o=this.precomputeWindow(n,e),e!==1&&Io.set(n,s(o))),o},wNAFCached(e,n,s){let o=Co(e);return this.wNAF(o,this.getPrecomputes(o,e,s),n)},wNAFCachedUnsafe(e,n,s,o){let i=Co(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),Io.delete(e)}}}function Nn(r,t,e,n){Sf(e,r),kf(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=Le(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 Or(r){return Eo(r.Fp),Jt(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...Bo(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Ft=BigInt(0),yt=BigInt(1),La=BigInt(2),If=BigInt(8),Cf={zip215:!0};function Nf(r){let t=Or(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=Nf(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=sr((v,p)=>{let{ex:m,ey:A,ez:R}=v,O=v.is0();p==null&&(p=O?If: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=sr(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=or(e,p.map(A=>A.ez));return p.map((A,R)=>A.toAffine(m[R])).map(h.fromAffine)}static msm(p,m){return Nn(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,yi=l(xt-m*it),_l=l(kt*Lt),Rl=l(wr*yi),Dl=l(kt*yi),Hl=l(Lt*wr);return new h(_l,Rl,Hl,Dl)}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 $=Ue(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=nr(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=Cn(h,c*8);function U(v){return W(v,n)}function H(v){return U(Ue(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,nr(z,e.BYTES));return Z("result",tt,e.BYTES*2)}let B=Cf;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=Ue(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 Uo=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),Ra=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),Sp=BigInt(0),Uf=BigInt(1),Da=BigInt(2),kp=BigInt(3),Tf=BigInt(5),Lf=BigInt(8);function _f(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),s=BigInt(80),o=Uo,c=r*r%o*r%o,a=Y(c,Da,o)*c%o,f=Y(a,Uf,o)*r%o,l=Y(f,Tf,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 Rf(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function Df(r,t){let e=Uo,n=W(t*t*t,e),s=W(n*n*t,e),o=_f(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(Uo,void 0,!0),Hf={a:Ha.create(BigInt(-1)),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:Ha,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:Lf,Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:Sn,randomBytes:er,adjustScalarBytes:Rf,uvRatio:Df},To=_a(Hf);var ir=32,Kt=64,Kf=32;function Ka(r,t){let e=r.subarray(0,Kf);return To.sign(t instanceof Uint8Array?t:t.subarray(),e)}function Oa(r,t,e){return To.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}var Un=class{type="Ed25519";raw;constructor(t){this.raw=Pr(t,ir)}toMultihash(){return Be.digest(Xe(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)}},Vr=class{type="Ed25519";raw;publicKey;constructor(t,e){this.raw=Pr(t,Kt),this.publicKey=new Un(e)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:Et(this.raw,t.raw)}sign(t){return Ka(this.raw,t)}};function Lo(r){if(r.length>Kt){r=Pr(r,Kt+ir);let n=r.subarray(0,Kt),s=r.subarray(Kt,r.length);return new Vr(n,s)}r=Pr(r,Kt);let t=r.subarray(0,Kt),e=r.subarray(ir);return new Vr(t,e)}function Pr(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 Of=Math.pow(2,7),Vf=Math.pow(2,14),Pf=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 Mr(r){if(r<Of)return 1;if(r<Vf)return 2;if(r<Pf)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(Mr(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 _o=new Float32Array([-0]),be=new Uint8Array(_o.buffer);function Ga(r,t,e){_o[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],_o[0]}var Ro=new Float64Array([-0]),ft=new Uint8Array(Ro.buffer);function Wa(r,t,e){Ro[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],Ro[0]}var Mf=BigInt(Number.MAX_SAFE_INTEGER),Ff=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 Re;if(t<Mf&&t>Ff)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 Re;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):Re}},Re=new Nt(0,0);Re.toBigInt=function(){return 0n};Re.zzEncode=Re.zzDecode=function(){return this};Re.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 Do(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 Tn(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var Ho=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 Tn(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Ot(this,4);return Tn(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=Tn(this.buf,this.pos+=4),e=Tn(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+=Mr(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 Ho(r instanceof Uint8Array?r:r.subarray())}function Ln(r,t,e){let n=Ko(r);return t.decode(n,void 0,e)}function Oo(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 De=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function Vo(){}var Mo=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},qf=Oo();function jf(r){return globalThis.Buffer!=null?It(r):qf(r)}var qr=class{len;head;tail;states;constructor(){this.len=0,this.head=new De(Vo,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new De(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new Fo((t=t>>>0)<128?1:t<16384?2:t<2097152?3:t<268435456?4:5,t)).len,this}int32(t){return t<0?this._push(_n,10,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(_n,e.length(),e)}uint64Number(t){return this._push(ja,Mr(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(_n,e.length(),e)}sint64Number(t){let e=Nt.fromNumber(t).zzEncode();return this._push(_n,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(Po,1,t?1:0)}fixed32(t){return this._push(Fr,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=Nt.fromBigInt(t);return this._push(Fr,4,e.lo)._push(Fr,4,e.hi)}fixed64Number(t){let e=Nt.fromNumber(t);return this._push(Fr,4,e.lo)._push(Fr,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(Po,1,0):this.uint32(e)._push(Gf,e,t)}string(t){let e=Ja(t);return e!==0?this.uint32(e)._push(Do,e,t):this._push(Po,1,0)}fork(){return this.states=new Mo(this),this.head=this.tail=new De(Vo,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 De(Vo,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=jf(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function Po(r,t,e){t[e]=r&255}function $f(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var Fo=class extends De{next;constructor(t,e){super($f,t,e),this.next=void 0}};function _n(r,t,e){for(;r.hi!==0;)t[e++]=r.lo&127|128,r.lo=(r.lo>>>7|r.hi<<25)>>>0,r.hi>>>=7;for(;r.lo>127;)t[e++]=r.lo&127|128,r.lo=r.lo>>>7;t[e++]=r.lo}function Fr(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 Gf(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(qr.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(zf,t,r),this},qr.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(Wf,t,r),this});function zf(r,t,e){t.set(r,e)}function Wf(r,t,e){r.length<40?Do(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(P(r),e)}function qo(){return new qr}function Rn(r,t){let e=qo();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var ar;(function(r){r[r.VARINT=0]="VARINT",r[r.BIT64=1]="BIT64",r[r.LENGTH_DELIMITED=2]="LENGTH_DELIMITED",r[r.START_GROUP=3]="START_GROUP",r[r.END_GROUP=4]="END_GROUP",r[r.BIT32=5]="BIT32"})(ar||(ar={}));function Dn(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function jo(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 Dn("enum",ar.VARINT,e,n)}function Hn(r,t){return Dn("message",ar.LENGTH_DELIMITED,r,t)}var rt;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.secp256k1="secp256k1",r.ECDSA="ECDSA"})(rt||(rt={}));var $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=()=>jo($o)})(rt||(rt={}));var we;(function(r){let t;r.codec=()=>(t==null&&(t=Hn((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=>Rn(e,r.codec()),r.decode=(e,n)=>Ln(e,r.codec(),n)})(we||(we={}));var jr;(function(r){let t;r.codec=()=>(t==null&&(t=Hn((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=>Rn(e,r.codec()),r.decode=(e,n)=>Ln(e,r.codec(),n)})(jr||(jr={}));function He(r){if(isNaN(r)||r<=0)throw new L("random bytes length must be a Number bigger than 0");return er(r)}var Gr={};dt(Gr,{MAX_RSA_KEY_SIZE:()=>Go,generateRSAKeyPair:()=>sc,jwkToJWKKeyPair:()=>oc,jwkToPkcs1:()=>Xf,jwkToPkix:()=>Yo,jwkToRSAPrivateKey:()=>Qo,pkcs1MessageToJwk:()=>Wo,pkcs1MessageToRSAPrivateKey:()=>Kn,pkcs1ToJwk:()=>Jf,pkcs1ToRSAPrivateKey:()=>Jo,pkixMessageToJwk:()=>Zo,pkixMessageToRSAPublicKey:()=>Xo,pkixToJwk:()=>Qf,pkixToRSAPublicKey:()=>nc});var cr=An;var lr=class{type="RSA";jwk;_raw;_multihash;constructor(t,e){this.jwk=t,this._multihash=e}get raw(){return this._raw==null&&(this._raw=Gr.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)}},$r=class{type="RSA";jwk;_raw;publicKey;constructor(t,e){this.jwk=t,this.publicKey=e}get raw(){return this._raw==null&&(this._raw=Gr.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 Go=8192,zo=18,Zf=1062,Yf=Uint8Array.from([48,13,6,9,42,134,72,134,247,13,1,1,1,5,0]);function Jf(r){let t=Rt(r);return Wo(t)}function Wo(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 Xf(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 Qf(r){let t=Rt(r,{offset:0});return Zo(t)}function Zo(r){let t=Rt(r[1],{offset:0});return{kty:"RSA",n:G(t[0],"base64url"),e:G(t[1],"base64url")}}function Yo(r){if(r.n==null||r.e==null)throw new L("JWK was missing components");return Dt([Yf,Tr(Dt([gt(P(r.n,"base64url")),gt(P(r.e,"base64url"))]))]).subarray()}function Jo(r){let t=Rt(r);return Kn(t)}function Kn(r){let t=Wo(r);return Qo(t)}function nc(r,t){if(r.byteLength>=Zf)throw new Fe("Key size is too large");let e=Rt(r,{offset:0});return Xo(e,r,t)}function Xo(r,t,e){let n=Zo(r);if(e==null){let s=cr(we.encode({Type:rt.RSA,Data:t}));e=_t(zo,s)}return new lr(n,e)}function Qo(r){if(ac(r)>Go)throw new L("Key size is too large");let t=oc(r),e=cr(we.encode({Type:rt.RSA,Data:Yo(t.publicKey)})),n=_t(zo,e);return new $r(t.privateKey,new lr(t.publicKey,n))}async function sc(r){if(r>Go)throw new L("Key size is too large");let t=await ic(r),e=cr(we.encode({Type:rt.RSA,Data:Yo(t.publicKey)})),n=_t(zo,e);return new $r(t.privateKey,new lr(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 th(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 th(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 On=class extends Qe{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,yn(t);let n=Lr(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 tr(this),this.iHash.update(t),this}digestInto(t){tr(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()}},zr=(r,t,e)=>new On(r,t).update(e).digest();zr.create=(r,t)=>new On(r,t);function cc(r){r.lowS!==void 0&&Mt("lowS",r.lowS),r.prehash!==void 0&&Mt("prehash",r.prehash)}function eh(r){let t=Or(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 ri=class extends Error{constructor(t=""){super(t)}},Qt={Err:ri,_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=Hr(n);if(s.length/2&128)throw new e("tlv.encode: long form length too big");let o=n>127?Hr(s.length/2|128):"";return Hr(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=Hr(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 ti(r,t){return ge(Te(r,t))}var te=BigInt(0),ot=BigInt(1),Yg=BigInt(2),ei=BigInt(3),rh=BigInt(4);function nh(r){let t=eh(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,ei),rh),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 kn(x,ot,t.n)}function u(x){let{allowedPrivateKeyLengths:h,nByteLength:w,wrapPrivateKey:k,n:C}=t;if(h&&typeof x!="bigint"){if(rr(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=sr((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=sr(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=or(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 Nn(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,ei),{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,ei),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=Cn(g,N?Math.ceil(I/2):I);return{CURVE:t,ProjectivePoint:g,normPrivateKeyToScalar:u,weierstrassEquation:i,isWithinCurveOrder:l}}function sh(r){let t=Or(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=sh(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 In(B,n)}let{ProjectivePoint:l,normPrivateKeyToScalar:u,weierstrassEquation:d,isWithinCurveOrder:b}=nh({...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(!kn(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+ti(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 Kr(this.toDERHex())}toDERHex(){return Qt.hexFromSig(this)}toCompactRawBytes(){return Kr(this.toCompactHex())}toCompactHex(){let E=s;return ti(this.r,E)+ti(this.s,E)}}let M={isValidPrivateKey(B){try{return u(B),!0}catch{return!1}},normPrivateKeyToScalar:u,randomPrivateKey:()=>{let B=Ao(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=Le(o);function H(B){return Ct("num < 2^"+o,B,te,U),Te(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"||rr(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 oh(r){return{hash:r,hmac:(t,...e)=>zr(r,t,po(...e)),randomBytes:er}}function uc(r,t){let e=n=>lc({...r,...oh(n)});return{...e(t),create:e}}var dc=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),fc=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),ih=BigInt(0),ah=BigInt(1),ni=BigInt(2),hc=(r,t)=>(r+t/ni)/t;function ch(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,ni,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,ni,t);if(!si.eql(si.sqr(k),r))throw new Error("Cannot find square root");return k}var si=Xt(dc,void 0,void 0,{sqrt:ch}),qt=uc({a:ih,b:BigInt(7),Fp:si,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=-ah*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}}}},An);function oi(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=Ye.digest(t instanceof Uint8Array?t:t.subarray());if(oi(e))return e.then(({digest:n})=>qt.sign(n,r).toDERRawBytes()).catch(n=>{throw new vr(String(n))});try{return qt.sign(e.digest,r).toDERRawBytes()}catch(n){throw new vr(String(n))}}function mc(r,t,e){let n=Ye.digest(e instanceof Uint8Array?e:e.subarray());if(oi(n))return n.then(({digest:s})=>qt.verify(t,s,r)).catch(s=>{throw new Er(String(s))});try{return qt.verify(t,n.digest,r)}catch(s){throw new Er(String(s))}}var Vn=class{type="secp256k1";raw;_key;constructor(t){this._key=wc(t),this.raw=yc(this._key)}toMultihash(){return Be.digest(Xe(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)}},Pn=class{type="secp256k1";raw;publicKey;constructor(t,e){this.raw=bc(t),this.publicKey=new Vn(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 ii(r){return new Pn(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 Br(String(t))}}function wc(r){try{return qt.ProjectivePoint.fromHex(r),r}catch(t){throw new Fe(String(t))}}function xc(r){try{return qt.getPublicKey(r,!0)}catch(t){throw new Br(String(t))}}function Xe(r){return we.encode({Type:rt[r.type],Data:r.raw})}function vc(r){let t=jr.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case rt.RSA:return Jo(e);case rt.Ed25519:return Lo(e);case rt.secp256k1:return ii(e);case rt.ECDSA:return Xi(e);default:throw new qe}}function Ec(r){if(r.byteLength===Kt)return Lo(r);if(r.byteLength===pc)return ii(r);let t=Rt(r),e=t[2]?.[0];if(e===zi||e===Wi||e===Zi)return uo(t);if(t.length>8)return Kn(t);throw new L("Could not extract private key from raw bytes")}function Ke(r){return jr.encode({Type:rt[r.type],Data:r.raw})}function Bc(r,t,e,n){yn(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=ho(t),f=ho(e),l=new Uint8Array(i),u=zr.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=ke(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 Mn(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=ke(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 Wr=Uint32Array.from([1732584193,4023233417,2562383102,271733878,3285377520]),xe=new Uint32Array(80),Fn=class extends Ie{constructor(){super(64,20,8,!1),this.A=Wr[0]|0,this.B=Wr[1]|0,this.C=Wr[2]|0,this.D=Wr[3]|0,this.E=Wr[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]=bn(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=wn(s,o,i),l=1518500249):a<40?(f=s^o^i,l=1859775393):a<60?(f=xn(s,o,i),l=2400959708):(f=s^o^i,l=3395469782);let u=bn(n,5)+f+c+l+xe[a]|0;c=i,i=o,o=bn(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=_r(()=>new Fn);var Ic=kc;var ur=Sn;var Cc={sha1:Ic,"sha2-256":cr,"sha2-512":ur};function Zr(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 Ae.encode(i).substring(1)}function fr(r){if(typeof r!="object"||r===null)return!1;let t=Object.getPrototypeOf(r);return(t===null||t===Object.prototype||Object.getPrototypeOf(t)===null)&&!(Symbol.toStringTag in r)&&!(Symbol.iterator in r)}var{hasOwnProperty:Uc}=Object.prototype,{propertyIsEnumerable:lh}=Object,hr=(r,t,e)=>{Object.defineProperty(r,t,{value:e,writable:!0,enumerable:!0,configurable:!0})},uh=void 0,Nc={concatArrays:!1,ignoreUndefined:!1},qn=r=>{let t=[];for(let e in r)Uc.call(r,e)&&t.push(e);if(Object.getOwnPropertySymbols){let e=Object.getOwnPropertySymbols(r);for(let n of e)lh.call(r,n)&&t.push(n)}return t};function dr(r){return Array.isArray(r)?fh(r):fr(r)?hh(r):r}function fh(r){let t=r.slice(0,0);return qn(r).forEach(e=>{hr(t,e,dr(r[e]))}),t}function hh(r){let t=Object.getPrototypeOf(r)===null?Object.create(null):{};return qn(r).forEach(e=>{hr(t,e,dr(r[e]))}),t}var Tc=(r,t,e,n)=>(e.forEach(s=>{typeof t[s]>"u"&&n.ignoreUndefined||(s in r&&r[s]!==Object.getPrototypeOf(r)?hr(r,s,ai(r[s],t[s],n)):hr(r,s,dr(t[s])))}),r),dh=(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++)Uc.call(o,c)&&(i.push(String(c)),o===r?hr(n,s++,o[c]):hr(n,s++,dr(o[c])));n=Tc(n,o,qn(o).filter(c=>!i.includes(c)),e)}),n};function ai(r,t,e){return e.concatArrays&&Array.isArray(r)&&Array.isArray(t)?dh(r,t,e):!fr(t)||!fr(r)?dr(t):Tc(r,t,qn(t),e)}function Lc(...r){let t=ai(dr(Nc),this!==uh&&this||{},Nc),e={_:{}};for(let n of r)if(n!==void 0){if(!fr(n))throw new TypeError("`"+n+"` is not an Option Object");e=ai(e,{_:n},t)}return e._}var ee="/",_c=new TextEncoder().encode(ee),jn=_c[0],Yr=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]!==jn)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=_c),this._buf[0]!==jn){let t=new Uint8Array(this._buf.byteLength+1);t.fill(jn,0,1),t.set(this._buf,1),this._buf=t}for(;this._buf.byteLength>1&&this._buf[this._buf.byteLength-1]===jn;)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 Ll=wi(Fc(),1);var pr={};dt(pr,{create:()=>Nh,derivedEmptyPasswordKey:()=>$n});var $n={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function Nh(r){let t=r?.algorithm??"AES-GCM",e=r?.keyLength??16,n=r?.nonceLength??12,s=r?.digest??"SHA-256",o=r?.saltLength??16,i=r?.iterations??32767,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 Ze([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=wi(qc());function Oe(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 li(){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=Oe(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,Oe(o,8)-n}function jc(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 $c(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 _y=Math.log(2);function Zn(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function ui(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 Qr=class{constructor(){this.items=[]}write(t){this.items.push(t)}final(){return ui(this.items)}},Jr=[new Uint8Array([1])],Gc="0123456789";var mr="",Vt=new ArrayBuffer(0),fi=new Uint8Array(0),tn="EndOfContent",Wc="OCTET STRING",Zc="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):fi}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=fi}={}){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):fi,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=Oe(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=Oe(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 Qr;e||Yc(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 $c(e,n)}};ct.NAME="BaseBlock";function Yc(r){var t;if(r instanceof S.Constructed)for(let e of r.valueBlock.value)Yc(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 Jc,ts=class extends ct{constructor(t={}){super(t,Qn),this.idBlock.isConstructed=!1}};Jc=ts;S.Primitive=Jc;ts.NAME="PRIMITIVE";function Oh(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=Oh(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 Vh(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(;Vh(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===tn)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===tn?this.value.pop():this.warnings.push("No EndOfContent block encoded")),o}toBER(t,e){let n=e||new Qr;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 Xc,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(`
|
|
2
|
+
"use strict";var Libp2PKeychain=(()=>{var Kl=Object.create;var ln=Object.defineProperty;var Ol=Object.getOwnPropertyDescriptor;var Vl=Object.getOwnPropertyNames;var Pl=Object.getPrototypeOf,Ml=Object.prototype.hasOwnProperty;var xr=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),dt=(r,t)=>{for(var e in t)ln(r,e,{get:t[e],enumerable:!0})},bi=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of Vl(t))!Ml.call(r,s)&&s!==e&&ln(r,s,{get:()=>t[s],enumerable:!(n=Ol(t,s))||n.enumerable});return r};var wi=(r,t,e)=>(e=r!=null?Kl(Pl(r)):{},bi(t||!r||!r.__esModule?ln(e,"default",{value:r,enumerable:!0}):e,r)),Fl=r=>bi(ln({},"__esModule",{value:!0}),r);var Dc=xr((Ay,Rc)=>{"use strict";function yh(r){return r>=55296&&r<=56319}function bh(r){return r>=56320&&r<=57343}Rc.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],yh(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 Kc=xr((Sy,Hc)=>{"use strict";function wh(r){return r>=55296&&r<=56319}function xh(r){return r>=56320&&r<=57343}Hc.exports=function(t){if(typeof t!="string")throw new Error("Input must be string");for(var e=t.length,n=0,s=null,o=null,i=0;i<e;i++)s=t.charCodeAt(i),xh(s)?o!=null&&wh(o)?n+=1:n+=3:s<=127?n+=1:s>=128&&s<=2047?n+=2:s>=2048&&s<=65535&&(n+=3),o=s;return n}});var Vc=xr((ky,Oc)=>{"use strict";var vh=Dc(),Eh=Kc();Oc.exports=vh.bind(null,Eh)});var Fc=xr((Iy,Mc)=>{"use strict";var Bh=Vc(),Ah=/[\/\?<>\\:\*\|"]/g,Sh=/[\x00-\x1f\x80-\x9f]/g,kh=/^\.+$/,Ih=/^(con|prn|aux|nul|com[0-9]|lpt[0-9])(\..*)?$/i,Ch=/[\. ]+$/;function Pc(r,t){if(typeof r!="string")throw new Error("Input must be string");var e=r.replace(Ah,t).replace(Sh,t).replace(kh,t).replace(Ih,t).replace(Ch,t);return Bh(e,255)}Mc.exports=function(r,t){var e=t&&t.replacement||"",n=Pc(r,e);return e===""?n:Pc(n,"")}});var qc=xr(gr=>{"use strict";var Uh="[object ArrayBuffer]",re=class r{static isArrayBuffer(t){return Object.prototype.toString.call(t)===Uh}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}},ci="string",Th=/^[0-9a-f\s]+$/i,Lh=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,_h=/^[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===ci&&Th.test(t)}static isBase64(t){return typeof t===ci&&Lh.test(t)}static isBase64Url(t){return typeof t===ci&&_h.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 Rh(r,...t){let e=arguments[0];for(let n=1;n<arguments.length;n++){let s=arguments[n];for(let o in s)e[o]=s[o]}return e}function Dh(...r){let t=r.map(s=>s.byteLength).reduce((s,o)=>s+o),e=new Uint8Array(t),n=0;return r.map(s=>new Uint8Array(s)).forEach(s=>{for(let o of s)e[n++]=o}),e.buffer}function Hh(r,t){if(!(r&&t)||r.byteLength!==t.byteLength)return!1;let e=new Uint8Array(r),n=new Uint8Array(t);for(let s=0;s<r.byteLength;s++)if(e[s]!==n[s])return!1;return!0}gr.BufferSourceConverter=re;gr.Convert=zn;gr.assign=Rh;gr.combine=Dh;gr.isEqual=Hh});var Qh={};dt(Qh,{keychain:()=>Xh});var vr=class extends Error{constructor(t="An error occurred while signing a message"){super(t),this.name="SigningError"}},Er=class extends Error{constructor(t="An error occurred while verifying a message"){super(t),this.name="VerificationError"}},un=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 un("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"}},Fe=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 fn=class extends Error{static name="NotFoundError";constructor(t="Not found"){super(t),this.name="NotFoundError"}};var qe=class extends Error{static name="UnsupportedKeyTypeError";constructor(t="Unsupported key type"){super(t),this.name="UnsupportedKeyTypeError"}};var vi=Symbol.for("@libp2p/service-capabilities"),ad=Symbol.for("@libp2p/service-dependencies");var Fs={};dt(Fs,{base58btc:()=>et,base58flickr:()=>Zl});var Ud=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 ql(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 jl=ql,$l=jl,ki=$l;var Os=class{name;prefix;baseEncode;constructor(t,e,n){this.name=t,this.prefix=e,this.baseEncode=n}encode(t){if(t instanceof Uint8Array)return`${this.prefix}${this.baseEncode(t)}`;throw Error("Unknown type, must be binary type")}},Vs=class{name;prefix;baseDecode;prefixCodePoint;constructor(t,e,n){this.name=t,this.prefix=e;let s=e.codePointAt(0);if(s===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=s,this.baseDecode=n}decode(t){if(typeof t=="string"){if(t.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(t)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(t.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(t){return Ii(this,t)}},Ps=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 Ps({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var Ms=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(t,e,n,s){this.name=t,this.prefix=e,this.baseEncode=n,this.baseDecode=s,this.encoder=new Os(t,e,n),this.decoder=new Vs(t,e,s)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function je({name:r,prefix:t,encode:e,decode:n}){return new Ms(r,t,e,n)}function le({name:r,prefix:t,alphabet:e}){let{encode:n,decode:s}=ki(e,r);return je({prefix:t,name:r,encode:n,decode:o=>Gt(s(o))})}function Gl(r,t,e,n){let s=r.length;for(;r[s-1]==="=";)--s;let o=new Uint8Array(s*e/8|0),i=0,c=0,a=0;for(let f=0;f<s;++f){let l=t[r[f]];if(l===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<e|l,i+=e,i>=8&&(i-=8,o[a++]=255&c>>i)}if(i>=e||(255&c<<8-i)!==0)throw new SyntaxError("Unexpected end of data");return o}function zl(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 Wl(r){let t={};for(let e=0;e<r.length;++e)t[r[e]]=e;return t}function J({name:r,prefix:t,bitsPerChar:e,alphabet:n}){let s=Wl(n);return je({prefix:t,name:r,encode(o){return zl(o,n,e)},decode(o){return Gl(o,s,e,r)}})}var et=le({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),Zl=le({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var qs={};dt(qs,{base32:()=>$e,base32hex:()=>Ql,base32hexpad:()=>eu,base32hexpadupper:()=>ru,base32hexupper:()=>tu,base32pad:()=>Jl,base32padupper:()=>Xl,base32upper:()=>Yl,base32z:()=>nu});var $e=J({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),Yl=J({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Jl=J({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),Xl=J({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),Ql=J({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),tu=J({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),eu=J({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),ru=J({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),nu=J({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var js={};dt(js,{base36:()=>Ar,base36upper:()=>su});var Ar=le({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),su=le({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var ou=Ui,Ci=128,iu=127,au=~iu,cu=Math.pow(2,31);function Ui(r,t,e){t=t||[],e=e||0;for(var n=e;r>=cu;)t[e++]=r&255|Ci,r/=128;for(;r&au;)t[e++]=r&255|Ci,r>>>=7;return t[e]=r|0,Ui.bytes=e-n+1,t}var lu=$s,uu=128,Ni=127;function $s(r,n){var e=0,n=n||0,s=0,o=n,i,c=r.length;do{if(o>=c)throw $s.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>=uu);return $s.bytes=o-n,e}var fu=Math.pow(2,7),hu=Math.pow(2,14),du=Math.pow(2,21),pu=Math.pow(2,28),gu=Math.pow(2,35),mu=Math.pow(2,42),yu=Math.pow(2,49),bu=Math.pow(2,56),wu=Math.pow(2,63),xu=function(r){return r<fu?1:r<hu?2:r<du?3:r<pu?4:r<gu?5:r<mu?6:r<yu?7:r<bu?8:r<wu?9:10},vu={encode:ou,decode:lu,encodingLength:xu},Eu=vu,Sr=Eu;function kr(r,t=0){return[Sr.decode(r,t),Sr.decode.bytes]}function Ge(r,t,e=0){return Sr.encode(r,t,e),t}function ze(r){return Sr.encodingLength(r)}function _t(r,t){let e=t.byteLength,n=ze(r),s=n+ze(e),o=new Uint8Array(s+e);return Ge(r,o,0),Ge(e,o,n),o.set(t,s),new We(r,e,t,o)}function Ti(r){let t=Gt(r),[e,n]=kr(t),[s,o]=kr(t.subarray(n)),i=t.subarray(n+o);if(i.byteLength!==s)throw new Error("Incorrect length");return new We(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 We=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 Au(e,Gs(r),t??et.encoder);default:return Su(e,Gs(r),t??$e.encoder)}}var Ri=new WeakMap;function Gs(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!==Cr)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==ku)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[Iu]===!0){let{version:n,multihash:s,code:o}=e,i=Ti(s);return r.create(n,o,i)}else return null}static create(t,e,n){if(typeof e!="number")throw new Error("String codecs are no longer supported");if(!(n.bytes instanceof Uint8Array))throw new Error("Invalid digest");switch(t){case 0:{if(e!==Cr)throw new Error(`Version 0 CID must use dag-pb (code: ${Cr}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let s=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,Cr,t)}static createV1(t,e){return r.create(1,t,e)}static decode(t){let[e,n]=r.decodeFirst(t);if(n.length!==0)throw new Error("Incorrect length");return e}static decodeFirst(t){let e=r.inspectBytes(t),n=e.size-e.multihashSize,s=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 We(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]=kr(t.subarray(e));return e+=d,u},s=n(),o=Cr;if(s===18?(s=0,e=0):o=n(),s!==0&&s!==1)throw new RangeError(`Invalid CID version ${s}`);let i=e,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]=Bu(t,e),o=r.decode(s);if(o.version===0&&t[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return Gs(o).set(n,t),o}};function Bu(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 $e.prefix:{let e=t??$e;return[$e.prefix,e.decode(r)]}case Ar.prefix:{let e=t??Ar;return[Ar.prefix,e.decode(r)]}default:{if(t==null)throw Error("To parse non base32, base36 or base58btc encoded CID multibase decoder must be provided");return[r[0],t.decode(r)]}}}function Au(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 Su(r,t,e){let{prefix:n}=e,s=t.get(n);if(s==null){let o=e.encode(r);return t.set(n,o),o}else return s}var Cr=112,ku=18;function Di(r,t,e){let n=ze(r),s=n+ze(t),o=new Uint8Array(s+e.byteLength);return Ge(r,o,0),Ge(t,o,n),o.set(e,s),o}var Iu=Symbol.for("@ipld/js-cid/CID");var zs={};dt(zs,{identity:()=>Be});var Hi=0,Cu="identity",Ki=Gt;function Nu(r){return _t(Hi,Ki(r))}var Be={code:Hi,name:Cu,encode:Ki,digest:Nu};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 Ze(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 dn(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(dn(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(dn(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(dn(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],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(!dn(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 Ws={};dt(Ws,{base10:()=>Uu});var Uu=le({prefix:"9",name:"base10",alphabet:"0123456789"});var Zs={};dt(Zs,{base16:()=>Tu,base16upper:()=>Lu});var Tu=J({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Lu=J({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Ys={};dt(Ys,{base2:()=>_u});var _u=J({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Js={};dt(Js,{base256emoji:()=>Ou});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}"),Ru=Pi.reduce((r,t,e)=>(r[e]=t,r),[]),Du=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 Hu(r){return r.reduce((t,e)=>(t+=Ru[e],t),"")}function Ku(r){let t=[];for(let e of r){let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);let s=Du[n];if(s==null)throw new Error(`Non-base256emoji character: ${e}`);t.push(s)}return new Uint8Array(t)}var Ou=je({prefix:"\u{1F680}",name:"base256emoji",encode:Hu,decode:Ku});var Xs={};dt(Xs,{base64:()=>Ae,base64pad:()=>Vu,base64url:()=>Pu,base64urlpad:()=>Mu});var Ae=J({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),Vu=J({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Pu=J({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Mu=J({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Qs={};dt(Qs,{base8:()=>Fu});var Fu=J({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var to={};dt(to,{identity:()=>qu});var qu=je({prefix:"\0",name:"identity",encode:r=>Ai(r),decode:r=>Bi(r)});var d0=new TextEncoder,p0=new TextDecoder;var no={};dt(no,{sha256:()=>Ye,sha512:()=>Gu});function ro({name:r,code:t,encode:e}){return new eo(r,t,e)}var eo=class{name;code;encode;constructor(t,e,n){this.name=t,this.code=e,this.encode=n}digest(t){if(t instanceof Uint8Array){let e=this.encode(t);return e instanceof Uint8Array?_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 Ye=ro({name:"sha2-256",code:18,encode:Fi("SHA-256")}),Gu=ro({name:"sha2-512",code:19,encode:Fi("SHA-512")});var so={...to,...Ys,...Qs,...Ws,...Zs,...qs,...js,...Fs,...Xs,...Js},k0={...no,...zs};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))),oo=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}),zu={utf8:qi,"utf-8":qi,hex:so.base16,latin1:oo,ascii:oo,binary:oo,...so},pn=zu;function P(r,t="utf8"){let e=pn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function G(r,t="utf8"){let e=pn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}var Wu=parseInt("11111",2),io=parseInt("10000000",2),Zu=parseInt("01111111",2),$i={0:Nr,1:Nr,2:Yu,3:Qu,4:tf,5:Xu,6:Ju,16:Nr,22:Nr,48:Nr};function Rt(r,t={offset:0}){let e=r[t.offset]&Wu;if(t.offset++,$i[e]!=null)return $i[e](r,t);throw new Error("No decoder for tag "+e)}function Ur(r,t){let e=0;if((r[t.offset]&io)===io){let n=r[t.offset]&Zu,s="0x";t.offset++;for(let o=0;o<n;o++,t.offset++)s+=r[t.offset].toString(16).padStart(2,"0");e=parseInt(s,16)}else e=r[t.offset],t.offset++;return e}function Nr(r,t){Ur(r,t);let e=[];for(;!(t.offset>=r.byteLength);){let n=Rt(r,t);if(n===null)break;e.push(n)}return e}function Yu(r,t){let e=Ur(r,t),n=t.offset,s=t.offset+e,o=[];for(let i=n;i<s;i++)i===n&&r[i]===0||o.push(r[i]);return t.offset+=e,Uint8Array.from(o)}function Ju(r,t){let e=Ur(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 Xu(r,t){return t.offset++,null}function Qu(r,t){let e=Ur(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 tf(r,t){let e=Ur(r,t),n=r.subarray(t.offset,t.offset+e);return t.offset+=e,n}function ef(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 gn(r){if(r.byteLength<128)return Uint8Array.from([r.byteLength]);let t=ef(r.byteLength);return new pt(Uint8Array.from([t.byteLength|io]),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]),gn(t),t)}function Tr(r){let t=Uint8Array.from([0]),e=new pt(t,r);return new pt(Uint8Array.from([3]),gn(e),e)}function Gi(r){return new pt(Uint8Array.from([4]),gn(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]),gn(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,e){let n=await crypto.subtle.importKey("jwk",r,{name:"ECDSA",namedCurve:r.crv??"P-256"},!1,["sign"]);e?.signal?.throwIfAborted();let s=await crypto.subtle.sign({name:"ECDSA",hash:{name:"SHA-256"}},n,t.subarray());return e?.signal?.throwIfAborted(),new Uint8Array(s,0,s.byteLength)}async function Ji(r,t,e,n){let s=await crypto.subtle.importKey("jwk",r,{name:"ECDSA",namedCurve:r.crv??"P-256"},!1,["verify"]);n?.signal?.throwIfAborted();let o=await crypto.subtle.verify({name:"ECDSA",hash:{name:"SHA-256"}},s,t,e.subarray());return n?.signal?.throwIfAborted(),o}var rf=Uint8Array.from([6,8,42,134,72,206,61,3,1,7]),nf=Uint8Array.from([6,5,43,129,4,0,34]),sf=Uint8Array.from([6,5,43,129,4,0,35]),of={ext:!0,kty:"EC",crv:"P-256"},af={ext:!0,kty:"EC",crv:"P-384"},cf={ext:!0,kty:"EC",crv:"P-521"},ao=32,co=48,lo=66;function Xi(r){let t=Rt(r);return uo(t)}function uo(r){let t=r[1],e=G(t,"base64url"),n=r[2][1][0],s=1,o,i;if(t.byteLength===ao)return o=G(n.subarray(s,s+ao),"base64url"),i=G(n.subarray(s+ao),"base64url"),new Je({...of,key_ops:["sign"],d:e,x:o,y:i});if(t.byteLength===co)return o=G(n.subarray(s,s+co),"base64url"),i=G(n.subarray(s+co),"base64url"),new Je({...af,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 Je({...cf,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([Tr(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([Tr(new pt(Uint8Array.from([4]),P(r.x??"","base64url"),P(r.y??"","base64url")))],161)]).subarray()}function ea(r){if(r==="P-256")return rf;if(r==="P-384")return nf;if(r==="P-521")return sf;throw new L(`Invalid curve ${r}`)}var mn=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 Be.digest(Xe(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,n){return Ji(this.jwk,e,t,n)}},Je=class{type="ECDSA";jwk;publicKey;_raw;constructor(t){this.jwk=t,this.publicKey=new mn({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,e){return Yi(this.jwk,t,e)}};var Se=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;function lf(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(!lf(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 yn(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 tr(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 ke(r){return new DataView(r.buffer,r.byteOffset,r.byteLength)}function Ht(r,t){return r<<32-t|r>>>t}function bn(r,t){return r<<t|r>>>32-t>>>0}var uf=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 uf(),n+=o)}}function fo(r){if(typeof r!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(r))}function Lr(r){return typeof r=="string"&&(r=fo(r)),fe(r),r}function ho(r){return typeof r=="string"&&(r=fo(r)),fe(r),r}function po(...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 Qe=class{};function _r(r){let t=n=>r().update(Lr(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function er(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 ff(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 wn(r,t,e){return r&t^~r&e}function xn(r,t,e){return r&t^r&e^t&e}var Ie=class extends Qe{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){tr(this),t=Lr(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=ke(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){tr(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;ff(n,s-8,BigInt(this.length*8),o),this.process(n,0);let c=ke(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 vn=BigInt(4294967295),oa=BigInt(32);function hf(r,t=!1){return t?{h:Number(r&vn),l:Number(r>>oa&vn)}:{h:Number(r>>oa&vn)|0,l:Number(r&vn)|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}=hf(r[o],t);[n[o],s[o]]=[i,c]}return[n,s]}var go=(r,t,e)=>r>>>e,mo=(r,t,e)=>r<<32-e|t>>>e,Ce=(r,t,e)=>r>>>e|t<<32-e,Ne=(r,t,e)=>r<<32-e|t>>>e,Rr=(r,t,e)=>r<<64-e|t>>>e-32,Dr=(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 pf=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),En=class extends Ie{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+wn(c,a,f)+pf[u]+he[u]|0,g=(Ht(n,2)^Ht(n,13)^Ht(n,22))+xn(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))),gf=da[0],mf=da[1],de=new Uint32Array(80),pe=new Uint32Array(80),Bn=class extends Ie{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=Ce(h,w,1)^Ce(h,w,8)^go(h,w,7),C=Ne(h,w,1)^Ne(h,w,8)^mo(h,w,7),U=de[x-2]|0,H=pe[x-2]|0,V=Ce(U,H,19)^Rr(U,H,61)^go(U,H,6),_=Ne(U,H,19)^Dr(U,H,61)^mo(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=Ce(u,d,14)^Ce(u,d,18)^Rr(u,d,41),w=Ne(u,d,14)^Ne(u,d,18)^Dr(u,d,41),k=u&b^~u&g,C=d&y^~d&N,U=fa(M,w,C,mf[x],pe[x]),H=ha(U,I,h,k,gf[x],de[x]),V=U|0,_=Ce(n,s,28)^Rr(n,s,34)^Rr(n,s,39),K=Ne(n,s,28)^Dr(n,s,34)^Dr(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 An=_r(()=>new En);var Sn=_r(()=>new Bn);var xo=BigInt(0),wo=BigInt(1);function rr(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function vo(r){if(!rr(r))throw new Error("Uint8Array expected")}function Mt(r,t){if(typeof t!="boolean")throw new Error(r+" boolean expected, got "+t)}function Hr(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===""?xo:BigInt("0x"+r)}var ya=typeof Uint8Array.from([]).toHex=="function"&&typeof Uint8Array.fromHex=="function",yf=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function ge(r){if(vo(r),ya)return r.toHex();let t="";for(let e=0;e<r.length;e++)t+=yf[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 Kr(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 Ue(r){return vo(r),ma(ge(Uint8Array.from(r).reverse()))}function Te(r,t){return Kr(r.toString(16).padStart(t*2,"0"))}function nr(r,t){return Te(r,t).reverse()}function Z(r,t,e){let n;if(typeof t=="string")try{n=Kr(t)}catch(o){throw new Error(r+" must be hex string or Uint8Array, cause: "+o)}else if(rr(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];vo(s),t+=s.length}let e=new Uint8Array(t);for(let n=0,s=0;n<r.length;n++){let o=r[n];e.set(o,s),s+=o.length}return e}var yo=r=>typeof r=="bigint"&&xo<=r;function kn(r,t,e){return yo(r)&&yo(t)&&yo(e)&&t<=r&&r<e}function Ct(r,t,e,n){if(!kn(t,e,n))throw new Error("expected valid "+r+": "+e+" <= n < "+n+", got "+t)}function ba(r){let t;for(t=0;r>xo;r>>=wo,t+=1);return t}var Le=r=>(wo<<BigInt(r))-wo,bo=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=bo(r),s=bo(r),o=0,i=()=>{n.fill(1),s.fill(0),o=0},c=(...u)=>e(s,n,...u),a=(u=bo(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"||rr(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 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 mt=BigInt(0),st=BigInt(1),_e=BigInt(2),wf=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 In(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 xf(r,t){let e=(r.ORDER-Ea)/Ba,n=r.mul(t,_e),s=r.pow(n,e),o=r.mul(t,s),i=r.mul(r.mul(o,_e),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 vf(r){if(r<BigInt(3))throw new Error("sqrt is not defined for small field");let t=r-st,e=0;for(;t%_e===mt;)t/=_e,e++;let n=_e,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)/_e;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 Ef(r){return r%va===wf?Aa:r%Ba===Ea?xf:vf(r)}var Sa=(r,t)=>(W(r,t)&st)===st,Bf=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function Eo(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=Bf.reduce((n,s)=>(n[s]="function",n),t);return Jt(r,e)}function Af(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 or(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)/_e,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 Bo(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}=Bo(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:Le(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)=>Af(c,a,f),div:(a,f)=>W(a*In(f,r),r),sqrN:a=>a*a,addN:(a,f)=>a+f,subN:(a,f)=>a-f,mulN:(a,f)=>a*f,inv:a=>In(a,r),sqrt:n.sqrt||(a=>(i||(i=Ef(r)),i(c,a))),toBytes:a=>e?nr(a,o):Te(a,o),fromBytes:a=>{if(a.length!==o)throw new Error("Field.fromBytes: expected "+o+" bytes, got "+a.length);return e?Ue(a):Yt(a)},invertBatch:a=>or(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 Ao(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=Ao(t);if(n<16||n<o||n>1024)throw new Error("expected "+o+"-1024 bytes of input, got "+n);let i=e?Ue(r):Yt(r),c=W(i,t-st)+st;return e?nr(c,s):Te(c,s)}var Ca=BigInt(0),No=BigInt(1);function So(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 ko(r,t){Ua(r,t);let e=Math.ceil(t/r)+1,n=2**(r-1),s=2**r,o=Le(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+=No);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 Sf(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 kf(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 Io=new WeakMap,Ta=new WeakMap;function Co(r){return Ta.get(r)||1}function Cn(r,t){return{constTimeNegate:So,hasPrecomputes(e){return Co(e)!==1},unsafeLadder(e,n,s=r.ZERO){let o=e;for(;n>Ca;)n&No&&(s=s.add(o)),o=o.double(),n>>=No;return s},precomputeWindow(e,n){let{windows:s,windowSize:o}=ko(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=ko(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(So(b,n[y])):o=o.add(So(d,n[l]))}return{p:o,f:i}},wNAFUnsafe(e,n,s,o=r.ZERO){let i=ko(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=Io.get(n);return o||(o=this.precomputeWindow(n,e),e!==1&&Io.set(n,s(o))),o},wNAFCached(e,n,s){let o=Co(e);return this.wNAF(o,this.getPrecomputes(o,e,s),n)},wNAFCachedUnsafe(e,n,s,o){let i=Co(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),Io.delete(e)}}}function Nn(r,t,e,n){Sf(e,r),kf(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=Le(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 Or(r){return Eo(r.Fp),Jt(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...Bo(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Ft=BigInt(0),yt=BigInt(1),La=BigInt(2),If=BigInt(8),Cf={zip215:!0};function Nf(r){let t=Or(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=Nf(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=sr((v,p)=>{let{ex:m,ey:A,ez:R}=v,O=v.is0();p==null&&(p=O?If: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=sr(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=or(e,p.map(A=>A.ez));return p.map((A,R)=>A.toAffine(m[R])).map(h.fromAffine)}static msm(p,m){return Nn(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,yi=l(xt-m*it),_l=l(kt*Lt),Rl=l(wr*yi),Dl=l(kt*yi),Hl=l(Lt*wr);return new h(_l,Rl,Hl,Dl)}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 $=Ue(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=nr(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=Cn(h,c*8);function U(v){return W(v,n)}function H(v){return U(Ue(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,nr(z,e.BYTES));return Z("result",tt,e.BYTES*2)}let B=Cf;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=Ue(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 Uo=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),Ra=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),Sp=BigInt(0),Uf=BigInt(1),Da=BigInt(2),kp=BigInt(3),Tf=BigInt(5),Lf=BigInt(8);function _f(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),s=BigInt(80),o=Uo,c=r*r%o*r%o,a=Y(c,Da,o)*c%o,f=Y(a,Uf,o)*r%o,l=Y(f,Tf,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 Rf(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function Df(r,t){let e=Uo,n=W(t*t*t,e),s=W(n*n*t,e),o=_f(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(Uo,void 0,!0),Hf={a:Ha.create(BigInt(-1)),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:Ha,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:Lf,Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:Sn,randomBytes:er,adjustScalarBytes:Rf,uvRatio:Df},To=_a(Hf);var ir=32,Kt=64,Kf=32;function Ka(r,t){let e=r.subarray(0,Kf);return To.sign(t instanceof Uint8Array?t:t.subarray(),e)}function Oa(r,t,e){return To.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}var Un=class{type="Ed25519";raw;constructor(t){this.raw=Pr(t,ir)}toMultihash(){return Be.digest(Xe(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,n){return n?.signal?.throwIfAborted(),Oa(this.raw,e,t)}},Vr=class{type="Ed25519";raw;publicKey;constructor(t,e){this.raw=Pr(t,Kt),this.publicKey=new Un(e)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:Et(this.raw,t.raw)}sign(t,e){return e?.signal?.throwIfAborted(),Ka(this.raw,t)}};function Lo(r){if(r.length>Kt){r=Pr(r,Kt+ir);let n=r.subarray(0,Kt),s=r.subarray(Kt,r.length);return new Vr(n,s)}r=Pr(r,Kt);let t=r.subarray(0,Kt),e=r.subarray(ir);return new Vr(t,e)}function Pr(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 Of=Math.pow(2,7),Vf=Math.pow(2,14),Pf=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 Mr(r){if(r<Of)return 1;if(r<Vf)return 2;if(r<Pf)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(Mr(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 _o=new Float32Array([-0]),be=new Uint8Array(_o.buffer);function Ga(r,t,e){_o[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],_o[0]}var Ro=new Float64Array([-0]),ft=new Uint8Array(Ro.buffer);function Wa(r,t,e){Ro[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],Ro[0]}var Mf=BigInt(Number.MAX_SAFE_INTEGER),Ff=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 Re;if(t<Mf&&t>Ff)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 Re;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):Re}},Re=new Nt(0,0);Re.toBigInt=function(){return 0n};Re.zzEncode=Re.zzDecode=function(){return this};Re.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 Do(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 Tn(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var Ho=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 Tn(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Ot(this,4);return Tn(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=Tn(this.buf,this.pos+=4),e=Tn(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+=Mr(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 Ho(r instanceof Uint8Array?r:r.subarray())}function Ln(r,t,e){let n=Ko(r);return t.decode(n,void 0,e)}function Oo(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 De=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function Vo(){}var Mo=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},qf=Oo();function jf(r){return globalThis.Buffer!=null?It(r):qf(r)}var qr=class{len;head;tail;states;constructor(){this.len=0,this.head=new De(Vo,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new De(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new Fo((t=t>>>0)<128?1:t<16384?2:t<2097152?3:t<268435456?4:5,t)).len,this}int32(t){return t<0?this._push(_n,10,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(_n,e.length(),e)}uint64Number(t){return this._push(ja,Mr(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(_n,e.length(),e)}sint64Number(t){let e=Nt.fromNumber(t).zzEncode();return this._push(_n,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(Po,1,t?1:0)}fixed32(t){return this._push(Fr,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=Nt.fromBigInt(t);return this._push(Fr,4,e.lo)._push(Fr,4,e.hi)}fixed64Number(t){let e=Nt.fromNumber(t);return this._push(Fr,4,e.lo)._push(Fr,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(Po,1,0):this.uint32(e)._push(Gf,e,t)}string(t){let e=Ja(t);return e!==0?this.uint32(e)._push(Do,e,t):this._push(Po,1,0)}fork(){return this.states=new Mo(this),this.head=this.tail=new De(Vo,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 De(Vo,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=jf(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function Po(r,t,e){t[e]=r&255}function $f(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var Fo=class extends De{next;constructor(t,e){super($f,t,e),this.next=void 0}};function _n(r,t,e){for(;r.hi!==0;)t[e++]=r.lo&127|128,r.lo=(r.lo>>>7|r.hi<<25)>>>0,r.hi>>>=7;for(;r.lo>127;)t[e++]=r.lo&127|128,r.lo=r.lo>>>7;t[e++]=r.lo}function Fr(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 Gf(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(qr.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(zf,t,r),this},qr.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(Wf,t,r),this});function zf(r,t,e){t.set(r,e)}function Wf(r,t,e){r.length<40?Do(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(P(r),e)}function qo(){return new qr}function Rn(r,t){let e=qo();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var ar;(function(r){r[r.VARINT=0]="VARINT",r[r.BIT64=1]="BIT64",r[r.LENGTH_DELIMITED=2]="LENGTH_DELIMITED",r[r.START_GROUP=3]="START_GROUP",r[r.END_GROUP=4]="END_GROUP",r[r.BIT32=5]="BIT32"})(ar||(ar={}));function Dn(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function jo(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 Dn("enum",ar.VARINT,e,n)}function Hn(r,t){return Dn("message",ar.LENGTH_DELIMITED,r,t)}var rt;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.secp256k1="secp256k1",r.ECDSA="ECDSA"})(rt||(rt={}));var $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=()=>jo($o)})(rt||(rt={}));var we;(function(r){let t;r.codec=()=>(t==null&&(t=Hn((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=>Rn(e,r.codec()),r.decode=(e,n)=>Ln(e,r.codec(),n)})(we||(we={}));var jr;(function(r){let t;r.codec=()=>(t==null&&(t=Hn((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=>Rn(e,r.codec()),r.decode=(e,n)=>Ln(e,r.codec(),n)})(jr||(jr={}));function He(r){if(isNaN(r)||r<=0)throw new L("random bytes length must be a Number bigger than 0");return er(r)}var Gr={};dt(Gr,{MAX_RSA_KEY_SIZE:()=>Go,generateRSAKeyPair:()=>sc,jwkToJWKKeyPair:()=>oc,jwkToPkcs1:()=>Xf,jwkToPkix:()=>Yo,jwkToRSAPrivateKey:()=>Qo,pkcs1MessageToJwk:()=>Wo,pkcs1MessageToRSAPrivateKey:()=>Kn,pkcs1ToJwk:()=>Jf,pkcs1ToRSAPrivateKey:()=>Jo,pkixMessageToJwk:()=>Zo,pkixMessageToRSAPublicKey:()=>Xo,pkixToJwk:()=>Qf,pkixToRSAPublicKey:()=>nc});var cr=An;var lr=class{type="RSA";jwk;_raw;_multihash;constructor(t,e){this.jwk=t,this._multihash=e}get raw(){return this._raw==null&&(this._raw=Gr.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,n){return rc(this.jwk,e,t,n)}},$r=class{type="RSA";jwk;_raw;publicKey;constructor(t,e){this.jwk=t,this.publicKey=e}get raw(){return this._raw==null&&(this._raw=Gr.jwkToPkcs1(this.jwk)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:Et(this.raw,t.raw)}sign(t,e){return ec(this.jwk,t,e)}};var Go=8192,zo=18,Zf=1062,Yf=Uint8Array.from([48,13,6,9,42,134,72,134,247,13,1,1,1,5,0]);function Jf(r){let t=Rt(r);return Wo(t)}function Wo(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 Xf(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 Qf(r){let t=Rt(r,{offset:0});return Zo(t)}function Zo(r){let t=Rt(r[1],{offset:0});return{kty:"RSA",n:G(t[0],"base64url"),e:G(t[1],"base64url")}}function Yo(r){if(r.n==null||r.e==null)throw new L("JWK was missing components");return Dt([Yf,Tr(Dt([gt(P(r.n,"base64url")),gt(P(r.e,"base64url"))]))]).subarray()}function Jo(r){let t=Rt(r);return Kn(t)}function Kn(r){let t=Wo(r);return Qo(t)}function nc(r,t){if(r.byteLength>=Zf)throw new Fe("Key size is too large");let e=Rt(r,{offset:0});return Xo(e,r,t)}function Xo(r,t,e){let n=Zo(r);if(e==null){let s=cr(we.encode({Type:rt.RSA,Data:t}));e=_t(zo,s)}return new lr(n,e)}function Qo(r){if(ac(r)>Go)throw new L("Key size is too large");let t=oc(r),e=cr(we.encode({Type:rt.RSA,Data:Yo(t.publicKey)})),n=_t(zo,e);return new $r(t.privateKey,new lr(t.publicKey,n))}async function sc(r){if(r>Go)throw new L("Key size is too large");let t=await ic(r),e=cr(we.encode({Type:rt.RSA,Data:Yo(t.publicKey)})),n=_t(zo,e);return new $r(t.privateKey,new lr(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,t){let e=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"]);t?.signal?.throwIfAborted();let n=await th(e,t);return{privateKey:n[0],publicKey:n[1]}}async function ec(r,t,e){let n=await vt.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]);e?.signal?.throwIfAborted();let s=await vt.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},n,t instanceof Uint8Array?t:t.subarray());return e?.signal?.throwIfAborted(),new Uint8Array(s,0,s.byteLength)}async function rc(r,t,e,n){let s=await vt.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);n?.signal?.throwIfAborted();let o=await vt.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},s,t,e instanceof Uint8Array?e:e.subarray());return n?.signal?.throwIfAborted(),o}async function th(r,t){if(r.privateKey==null||r.publicKey==null)throw new L("Private and public key are required");let e=await Promise.all([vt.get().subtle.exportKey("jwk",r.privateKey),vt.get().subtle.exportKey("jwk",r.publicKey)]);return t?.signal?.throwIfAborted(),e}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 On=class extends Qe{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,yn(t);let n=Lr(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 tr(this),this.iHash.update(t),this}digestInto(t){tr(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()}},zr=(r,t,e)=>new On(r,t).update(e).digest();zr.create=(r,t)=>new On(r,t);function cc(r){r.lowS!==void 0&&Mt("lowS",r.lowS),r.prehash!==void 0&&Mt("prehash",r.prehash)}function eh(r){let t=Or(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 ri=class extends Error{constructor(t=""){super(t)}},Qt={Err:ri,_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=Hr(n);if(s.length/2&128)throw new e("tlv.encode: long form length too big");let o=n>127?Hr(s.length/2|128):"";return Hr(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=Hr(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 ti(r,t){return ge(Te(r,t))}var te=BigInt(0),ot=BigInt(1),Yg=BigInt(2),ei=BigInt(3),rh=BigInt(4);function nh(r){let t=eh(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,ei),rh),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 kn(x,ot,t.n)}function u(x){let{allowedPrivateKeyLengths:h,nByteLength:w,wrapPrivateKey:k,n:C}=t;if(h&&typeof x!="bigint"){if(rr(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=sr((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=sr(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=or(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 Nn(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,ei),{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,ei),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=Cn(g,N?Math.ceil(I/2):I);return{CURVE:t,ProjectivePoint:g,normPrivateKeyToScalar:u,weierstrassEquation:i,isWithinCurveOrder:l}}function sh(r){let t=Or(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=sh(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 In(B,n)}let{ProjectivePoint:l,normPrivateKeyToScalar:u,weierstrassEquation:d,isWithinCurveOrder:b}=nh({...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(!kn(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+ti(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 Kr(this.toDERHex())}toDERHex(){return Qt.hexFromSig(this)}toCompactRawBytes(){return Kr(this.toCompactHex())}toCompactHex(){let E=s;return ti(this.r,E)+ti(this.s,E)}}let M={isValidPrivateKey(B){try{return u(B),!0}catch{return!1}},normPrivateKeyToScalar:u,randomPrivateKey:()=>{let B=Ao(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=Le(o);function H(B){return Ct("num < 2^"+o,B,te,U),Te(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"||rr(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 oh(r){return{hash:r,hmac:(t,...e)=>zr(r,t,po(...e)),randomBytes:er}}function uc(r,t){let e=n=>lc({...r,...oh(n)});return{...e(t),create:e}}var dc=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),fc=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),ih=BigInt(0),ah=BigInt(1),ni=BigInt(2),hc=(r,t)=>(r+t/ni)/t;function ch(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,ni,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,ni,t);if(!si.eql(si.sqr(k),r))throw new Error("Cannot find square root");return k}var si=Xt(dc,void 0,void 0,{sqrt:ch}),qt=uc({a:ih,b:BigInt(7),Fp:si,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=-ah*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}}}},An);function oi(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}var pc=32;function gc(r,t,e){let n=Ye.digest(t instanceof Uint8Array?t:t.subarray());if(oi(n))return n.then(({digest:s})=>(e?.signal?.throwIfAborted(),qt.sign(s,r).toDERRawBytes())).catch(s=>{throw s.name==="AbortError"?s:new vr(String(s))});try{return qt.sign(n.digest,r).toDERRawBytes()}catch(s){throw new vr(String(s))}}function mc(r,t,e,n){let s=Ye.digest(e instanceof Uint8Array?e:e.subarray());if(oi(s))return s.then(({digest:o})=>(n?.signal?.throwIfAborted(),qt.verify(t,o,r))).catch(o=>{throw o.name==="AbortError"?o:new Er(String(o))});try{return n?.signal?.throwIfAborted(),qt.verify(t,s.digest,r)}catch(o){throw new Er(String(o))}}var Vn=class{type="secp256k1";raw;_key;constructor(t){this._key=wc(t),this.raw=yc(this._key)}toMultihash(){return Be.digest(Xe(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,n){return mc(this._key,e,t,n)}},Pn=class{type="secp256k1";raw;publicKey;constructor(t,e){this.raw=bc(t),this.publicKey=new Vn(e??xc(t))}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:Et(this.raw,t.raw)}sign(t,e){return gc(this.raw,t,e)}};function ii(r){return new Pn(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 Br(String(t))}}function wc(r){try{return qt.ProjectivePoint.fromHex(r),r}catch(t){throw new Fe(String(t))}}function xc(r){try{return qt.getPublicKey(r,!0)}catch(t){throw new Br(String(t))}}function Xe(r){return we.encode({Type:rt[r.type],Data:r.raw})}function vc(r){let t=jr.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case rt.RSA:return Jo(e);case rt.Ed25519:return Lo(e);case rt.secp256k1:return ii(e);case rt.ECDSA:return Xi(e);default:throw new qe}}function Ec(r){if(r.byteLength===Kt)return Lo(r);if(r.byteLength===pc)return ii(r);let t=Rt(r),e=t[2]?.[0];if(e===zi||e===Wi||e===Zi)return uo(t);if(t.length>8)return Kn(t);throw new L("Could not extract private key from raw bytes")}function Ke(r){return jr.encode({Type:rt[r.type],Data:r.raw})}function Bc(r,t,e,n){yn(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=ho(t),f=ho(e),l=new Uint8Array(i),u=zr.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=ke(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 Mn(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=ke(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 Wr=Uint32Array.from([1732584193,4023233417,2562383102,271733878,3285377520]),xe=new Uint32Array(80),Fn=class extends Ie{constructor(){super(64,20,8,!1),this.A=Wr[0]|0,this.B=Wr[1]|0,this.C=Wr[2]|0,this.D=Wr[3]|0,this.E=Wr[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]=bn(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=wn(s,o,i),l=1518500249):a<40?(f=s^o^i,l=1859775393):a<60?(f=xn(s,o,i),l=2400959708):(f=s^o^i,l=3395469782);let u=bn(n,5)+f+c+l+xe[a]|0;c=i,i=o,o=bn(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=_r(()=>new Fn);var Ic=kc;var ur=Sn;var Cc={sha1:Ic,"sha2-256":cr,"sha2-512":ur};function Zr(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 Ae.encode(i).substring(1)}function fr(r){if(typeof r!="object"||r===null)return!1;let t=Object.getPrototypeOf(r);return(t===null||t===Object.prototype||Object.getPrototypeOf(t)===null)&&!(Symbol.toStringTag in r)&&!(Symbol.iterator in r)}var{hasOwnProperty:Uc}=Object.prototype,{propertyIsEnumerable:lh}=Object,hr=(r,t,e)=>{Object.defineProperty(r,t,{value:e,writable:!0,enumerable:!0,configurable:!0})},uh=void 0,Nc={concatArrays:!1,ignoreUndefined:!1},qn=r=>{let t=[];for(let e in r)Uc.call(r,e)&&t.push(e);if(Object.getOwnPropertySymbols){let e=Object.getOwnPropertySymbols(r);for(let n of e)lh.call(r,n)&&t.push(n)}return t};function dr(r){return Array.isArray(r)?fh(r):fr(r)?hh(r):r}function fh(r){let t=r.slice(0,0);return qn(r).forEach(e=>{hr(t,e,dr(r[e]))}),t}function hh(r){let t=Object.getPrototypeOf(r)===null?Object.create(null):{};return qn(r).forEach(e=>{hr(t,e,dr(r[e]))}),t}var Tc=(r,t,e,n)=>(e.forEach(s=>{typeof t[s]>"u"&&n.ignoreUndefined||(s in r&&r[s]!==Object.getPrototypeOf(r)?hr(r,s,ai(r[s],t[s],n)):hr(r,s,dr(t[s])))}),r),dh=(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++)Uc.call(o,c)&&(i.push(String(c)),o===r?hr(n,s++,o[c]):hr(n,s++,dr(o[c])));n=Tc(n,o,qn(o).filter(c=>!i.includes(c)),e)}),n};function ai(r,t,e){return e.concatArrays&&Array.isArray(r)&&Array.isArray(t)?dh(r,t,e):!fr(t)||!fr(r)?dr(t):Tc(r,t,qn(t),e)}function Lc(...r){let t=ai(dr(Nc),this!==uh&&this||{},Nc),e={_:{}};for(let n of r)if(n!==void 0){if(!fr(n))throw new TypeError("`"+n+"` is not an Option Object");e=ai(e,{_:n},t)}return e._}var ee="/",_c=new TextEncoder().encode(ee),jn=_c[0],Yr=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]!==jn)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=_c),this._buf[0]!==jn){let t=new Uint8Array(this._buf.byteLength+1);t.fill(jn,0,1),t.set(this._buf,1),this._buf=t}for(;this._buf.byteLength>1&&this._buf[this._buf.byteLength-1]===jn;)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 Ll=wi(Fc(),1);var pr={};dt(pr,{create:()=>Nh,derivedEmptyPasswordKey:()=>$n});var $n={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function Nh(r){let t=r?.algorithm??"AES-GCM",e=r?.keyLength??16,n=r?.nonceLength??12,s=r?.digest??"SHA-256",o=r?.saltLength??16,i=r?.iterations??32767,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 Ze([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=wi(qc());function Oe(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 li(){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=Oe(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,Oe(o,8)-n}function jc(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 $c(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 _y=Math.log(2);function Zn(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function ui(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 Qr=class{constructor(){this.items=[]}write(t){this.items.push(t)}final(){return ui(this.items)}},Jr=[new Uint8Array([1])],Gc="0123456789";var mr="",Vt=new ArrayBuffer(0),fi=new Uint8Array(0),tn="EndOfContent",Wc="OCTET STRING",Zc="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):fi}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=fi}={}){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):fi,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=Oe(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=Oe(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 Qr;e||Yc(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 $c(e,n)}};ct.NAME="BaseBlock";function Yc(r){var t;if(r instanceof S.Constructed)for(let e of r.valueBlock.value)Yc(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 Jc,ts=class extends ct{constructor(t={}){super(t,Qn),this.idBlock.isConstructed=!1}};Jc=ts;S.Primitive=Jc;ts.NAME="PRIMITIVE";function Oh(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=Oh(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 Vh(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(;Vh(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===tn)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===tn?this.value.pop():this.warnings.push("No EndOfContent block encoded")),o}toBER(t,e){let n=e||new Qr;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 Xc,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(`
|