@libp2p/keychain 6.0.9 → 6.0.10
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 +2 -2
- package/dist/index.min.js.map +3 -3
- package/package.json +1 -1
package/dist/index.min.js
CHANGED
|
@@ -1,9 +1,9 @@
|
|
|
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 Su=Object.create;var en=Object.defineProperty;var ku=Object.getOwnPropertyDescriptor;var Iu=Object.getOwnPropertyNames;var Cu=Object.getPrototypeOf,Nu=Object.prototype.hasOwnProperty;var fr=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),ft=(r,t)=>{for(var e in t)en(r,e,{get:t[e],enumerable:!0})},ui=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of Iu(t))!Nu.call(r,s)&&s!==e&&en(r,s,{get:()=>t[s],enumerable:!(n=ku(t,s))||n.enumerable});return r};var li=(r,t,e)=>(e=r!=null?Su(Cu(r)):{},ui(t||!r||!r.__esModule?en(e,"default",{value:r,enumerable:!0}):e,r)),Uu=r=>ui(en({},"__esModule",{value:!0}),r);var Ic=fr((Gy,kc)=>{"use strict";function nh(r){return r>=55296&&r<=56319}function sh(r){return r>=56320&&r<=57343}kc.exports=function(t,e,n){if(typeof e!="string")throw new Error("Input must be string");for(var s=e.length,o=0,i,c,a=0;a<s;a+=1){if(i=e.charCodeAt(a),c=e[a],nh(i)&&sh(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 Nc=fr((Zy,Cc)=>{"use strict";function oh(r){return r>=55296&&r<=56319}function ih(r){return r>=56320&&r<=57343}Cc.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),ih(s)?o!=null&&oh(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 Lc=fr((Yy,Uc)=>{"use strict";var ah=Ic(),ch=Nc();Uc.exports=ah.bind(null,ch)});var _c=fr((zy,Rc)=>{"use strict";var uh=Lc(),lh=/[\/\?<>\\:\*\|"]/g,fh=/[\x00-\x1f\x80-\x9f]/g,hh=/^\.+$/,dh=/^(con|prn|aux|nul|com[0-9]|lpt[0-9])(\..*)?$/i,ph=/[\. ]+$/;function Tc(r,t){if(typeof r!="string")throw new Error("Input must be string");var e=r.replace(lh,t).replace(fh,t).replace(hh,t).replace(dh,t).replace(ph,t);return uh(e,255)}Rc.exports=function(r,t){var e=t&&t.replacement||"",n=Tc(r,e);return e===""?n:Tc(n,"")}});var Dc=fr(ar=>{"use strict";var yh="[object ArrayBuffer]",Yt=class r{static isArrayBuffer(t){return Object.prototype.toString.call(t)===yh}static toArrayBuffer(t){return this.isArrayBuffer(t)?t:t.byteLength===t.buffer.byteLength||t.byteOffset===0&&t.byteLength===t.buffer.byteLength?t.buffer:this.toUint8Array(t.buffer).slice(t.byteOffset,t.byteOffset+t.byteLength).buffer}static toUint8Array(t){return this.toView(t,Uint8Array)}static toView(t,e){if(t.constructor===e)return t;if(this.isArrayBuffer(t))return new e(t);if(this.isArrayBufferView(t))return new e(t.buffer,t.byteOffset,t.byteLength);throw new TypeError("The provided value is not of type '(ArrayBuffer or ArrayBufferView)'")}static isBufferSource(t){return this.isArrayBufferView(t)||this.isArrayBuffer(t)}static isArrayBufferView(t){return ArrayBuffer.isView(t)||t&&this.isArrayBuffer(t.buffer)}static isEqual(t,e){let n=r.toUint8Array(t),s=r.toUint8Array(e);if(n.length!==s.byteLength)return!1;for(let o=0;o<n.length;o++)if(n[o]!==s[o])return!1;return!0}static concat(...t){let e;Array.isArray(t[0])&&!(t[1]instanceof Function)||Array.isArray(t[0])&&t[1]instanceof Function?e=t[0]:t[t.length-1]instanceof Function?e=t.slice(0,t.length-1):e=t;let n=0;for(let i of e)n+=i.byteLength;let s=new Uint8Array(n),o=0;for(let i of e){let 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}},Qo="string",mh=/^[0-9a-f\s]+$/i,bh=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,wh=/^[a-zA-Z0-9-_]+$/,_n=class{static fromString(t){let e=unescape(encodeURIComponent(t)),n=new Uint8Array(e.length);for(let s=0;s<e.length;s++)n[s]=e.charCodeAt(s);return n.buffer}static toString(t){let e=Yt.toUint8Array(t),n="";for(let o=0;o<e.length;o++)n+=String.fromCharCode(e[o]);return decodeURIComponent(escape(n))}},It=class{static toString(t,e=!1){let n=Yt.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}},Dn=class r{static isHex(t){return typeof t===Qo&&mh.test(t)}static isBase64(t){return typeof t===Qo&&bh.test(t)}static isBase64Url(t){return typeof t===Qo&&wh.test(t)}static ToString(t,e="utf8"){let n=Yt.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 It.toString(n,!0);case"utf16":case"utf16be":return It.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 It.fromString(t,!0);case"utf16":case"utf16be":return It.fromString(t);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToBase64(t){let e=Yt.toUint8Array(t);if(typeof btoa<"u"){let n=this.ToString(e,"binary");return btoa(n)}else return Buffer.from(e).toString("base64")}static FromBase64(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isBase64(e))throw new TypeError("Argument 'base64Text' is not Base64 encoded");return typeof atob<"u"?this.FromBinary(atob(e)):new Uint8Array(Buffer.from(e,"base64")).buffer}static FromBase64Url(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isBase64Url(e))throw new TypeError("Argument 'base64url' is not Base64Url encoded");return this.FromBase64(this.Base64Padding(e.replace(/\-/g,"+").replace(/\_/g,"/")))}static ToBase64Url(t){return this.ToBase64(t).replace(/\+/g,"-").replace(/\//g,"_").replace(/\=/g,"")}static FromUtf8String(t,e=r.DEFAULT_UTF8_ENCODING){switch(e){case"ascii":return this.FromBinary(t);case"utf8":return _n.fromString(t);case"utf16":case"utf16be":return It.fromString(t);case"utf16le":case"usc2":return It.fromString(t,!0);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToUtf8String(t,e=r.DEFAULT_UTF8_ENCODING){switch(e){case"ascii":return this.ToBinary(t);case"utf8":return _n.toString(t);case"utf16":case"utf16be":return It.toString(t);case"utf16le":case"usc2":return It.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=Yt.toUint8Array(t),n="";for(let s=0;s<e.length;s++)n+=String.fromCharCode(e[s]);return n}static ToHex(t){let e=Yt.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 It.toString(t,e)}static FromUtf16String(t,e=!1){return It.fromString(t,e)}static Base64Padding(t){let e=4-t.length%4;if(e<4)for(let n=0;n<e;n++)t+="=";return t}static formatString(t){return t?.replace(/[\n\r\t ]/g,"")||""}};Dn.DEFAULT_UTF8_ENCODING="utf8";function xh(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 vh(...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 Eh(r,t){if(!(r&&t)||r.byteLength!==t.byteLength)return!1;let e=new Uint8Array(r),n=new Uint8Array(t);for(let s=0;s<r.byteLength;s++)if(e[s]!==n[s])return!1;return!0}ar.BufferSourceConverter=Yt;ar.Convert=Dn;ar.assign=xh;ar.combine=vh;ar.isEqual=Eh});var Hh={};ft(Hh,{keychain:()=>Oh});var hr=class extends Error{constructor(t="An error occurred while signing a message"){super(t),this.name="SigningError"}},dr=class extends Error{constructor(t="An error occurred while verifying a message"){super(t),this.name="VerificationError"}},rn=class extends Error{constructor(t="Missing Web Crypto API"){super(t),this.name="WebCryptoMissingError"}};var fi={get(r=globalThis){let t=r.crypto;if(t?.subtle==null)throw new rn("Missing Web Crypto API. The most likely cause of this error is that this page is being accessed from an insecure context (i.e. not HTTPS). For more information and possible resolutions see https://github.com/libp2p/js-libp2p/blob/main/packages/crypto/README.md#web-crypto-api");return t}};var Q=fi;var R=class extends Error{static name="InvalidParametersError";constructor(t="Invalid parameters"){super(t),this.name="InvalidParametersError"}},Ke=class extends Error{static name="InvalidPublicKeyError";constructor(t="Invalid public key"){super(t),this.name="InvalidPublicKeyError"}},pr=class extends Error{static name="InvalidPrivateKeyError";constructor(t="Invalid private key"){super(t),this.name="InvalidPrivateKeyError"}};var nn=class extends Error{static name="NotFoundError";constructor(t="Not found"){super(t),this.name="NotFoundError"}};var Ve=class extends Error{static name="UnsupportedKeyTypeError";constructor(t="Unsupported key type"){super(t),this.name="UnsupportedKeyTypeError"}};var hi=Symbol.for("@libp2p/service-capabilities"),Zh=Symbol.for("@libp2p/service-dependencies");var Us={};ft(Us,{base58btc:()=>tt,base58flickr:()=>Vu});var wd=new Uint8Array(0);function di(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 Ht(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 pi(r){return new TextEncoder().encode(r)}function gi(r){return new TextDecoder().decode(r)}function Lu(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),l=Math.log(c)/Math.log(256),f=Math.log(256)/Math.log(c);function u(h){if(h instanceof Uint8Array||(ArrayBuffer.isView(h)?h=new Uint8Array(h.buffer,h.byteOffset,h.byteLength):Array.isArray(h)&&(h=Uint8Array.from(h))),!(h instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(h.length===0)return"";for(var B=0,v=0,g=0,A=h.length;g!==A&&h[g]===0;)g++,B++;for(var w=(A-g)*f+1>>>0,I=new Uint8Array(w);g!==A;){for(var D=h[g],H=0,M=w-1;(D!==0||H<v)&&M!==-1;M--,H++)D+=256*I[M]>>>0,I[M]=D%c>>>0,D=D/c>>>0;if(D!==0)throw new Error("Non-zero carry");v=H,g++}for(var E=w-v;E!==w&&I[E]===0;)E++;for(var x=a.repeat(B);E<w;++E)x+=r.charAt(I[E]);return x}function d(h){if(typeof h!="string")throw new TypeError("Expected String");if(h.length===0)return new Uint8Array;var B=0;if(h[B]!==" "){for(var v=0,g=0;h[B]===a;)v++,B++;for(var A=(h.length-B)*l+1>>>0,w=new Uint8Array(A);h[B];){var I=e[h.charCodeAt(B)];if(I===255)return;for(var D=0,H=A-1;(I!==0||D<g)&&H!==-1;H--,D++)I+=c*w[H]>>>0,w[H]=I%256>>>0,I=I/256>>>0;if(I!==0)throw new Error("Non-zero carry");g=D,B++}if(h[B]!==" "){for(var M=A-g;M!==A&&w[M]===0;)M++;for(var E=new Uint8Array(v+(A-M)),x=v;M!==A;)E[x++]=w[M++];return E}}}function y(h){var B=d(h);if(B)return B;throw new Error(`Non-${t} character`)}return{encode:u,decodeUnsafe:d,decode:y}}var Tu=Lu,Ru=Tu,mi=Ru;var ks=class{name;prefix;baseEncode;constructor(t,e,n){this.name=t,this.prefix=e,this.baseEncode=n}encode(t){if(t instanceof Uint8Array)return`${this.prefix}${this.baseEncode(t)}`;throw Error("Unknown type, must be binary type")}},Is=class{name;prefix;baseDecode;prefixCodePoint;constructor(t,e,n){this.name=t,this.prefix=e;let s=e.codePointAt(0);if(s===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=s,this.baseDecode=n}decode(t){if(typeof t=="string"){if(t.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(t)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(t.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(t){return bi(this,t)}},Cs=class{decoders;constructor(t){this.decoders=t}or(t){return bi(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 bi(r,t){return new Cs({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var Ns=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 ks(t,e,n),this.decoder=new Is(t,e,s)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function Oe({name:r,prefix:t,encode:e,decode:n}){return new Ns(r,t,e,n)}function ee({name:r,prefix:t,alphabet:e}){let{encode:n,decode:s}=mi(e,r);return Oe({prefix:t,name:r,encode:n,decode:o=>Ht(s(o))})}function _u(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 l=0;l<s;++l){let f=t[r[l]];if(f===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<e|f,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 Du(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 Ku(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=Ku(n);return Oe({prefix:t,name:r,encode(o){return Du(o,n,e)},decode(o){return _u(o,s,e,r)}})}var tt=ee({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),Vu=ee({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Ls={};ft(Ls,{base32:()=>He,base32hex:()=>Pu,base32hexpad:()=>qu,base32hexpadupper:()=>$u,base32hexupper:()=>Fu,base32pad:()=>Hu,base32padupper:()=>Mu,base32upper:()=>Ou,base32z:()=>ju});var He=J({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),Ou=J({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Hu=J({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),Mu=J({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),Pu=J({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),Fu=J({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),qu=J({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),$u=J({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),ju=J({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Ts={};ft(Ts,{base36:()=>gr,base36upper:()=>Gu});var gr=ee({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),Gu=ee({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Zu=vi,wi=128,Yu=127,zu=~Yu,Wu=Math.pow(2,31);function vi(r,t,e){t=t||[],e=e||0;for(var n=e;r>=Wu;)t[e++]=r&255|wi,r/=128;for(;r&zu;)t[e++]=r&255|wi,r>>>=7;return t[e]=r|0,vi.bytes=e-n+1,t}var Ju=Rs,Xu=128,xi=127;function Rs(r,n){var e=0,n=n||0,s=0,o=n,i,c=r.length;do{if(o>=c)throw Rs.bytes=0,new RangeError("Could not decode varint");i=r[o++],e+=s<28?(i&xi)<<s:(i&xi)*Math.pow(2,s),s+=7}while(i>=Xu);return Rs.bytes=o-n,e}var Qu=Math.pow(2,7),tl=Math.pow(2,14),el=Math.pow(2,21),rl=Math.pow(2,28),nl=Math.pow(2,35),sl=Math.pow(2,42),ol=Math.pow(2,49),il=Math.pow(2,56),al=Math.pow(2,63),cl=function(r){return r<Qu?1:r<tl?2:r<el?3:r<rl?4:r<nl?5:r<sl?6:r<ol?7:r<il?8:r<al?9:10},ul={encode:Zu,decode:Ju,encodingLength:cl},ll=ul,yr=ll;function mr(r,t=0){return[yr.decode(r,t),yr.decode.bytes]}function Me(r,t,e=0){return yr.encode(r,t,e),t}function Pe(r){return yr.encodingLength(r)}function _t(r,t){let e=t.byteLength,n=Pe(r),s=n+Pe(e),o=new Uint8Array(s+e);return Me(r,o,0),Me(e,o,n),o.set(t,s),new Fe(r,e,t,o)}function Ei(r){let t=Ht(r),[e,n]=mr(t),[s,o]=mr(t.subarray(n)),i=t.subarray(n+o);if(i.byteLength!==s)throw new Error("Incorrect length");return new Fe(e,s,i,t)}function Bi(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&di(r.bytes,e.bytes)}}var Fe=class{code;size;digest;bytes;constructor(t,e,n,s){this.code=t,this.size=e,this.digest=n,this.bytes=s}};function Ai(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return hl(e,_s(r),t??tt.encoder);default:return dl(e,_s(r),t??He.encoder)}}var Si=new WeakMap;function _s(r){let t=Si.get(r);if(t==null){let e=new Map;return Si.set(r,e),e}return t}var St=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!==wr)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==pl)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&&Bi(t.multihash,n.multihash)}toString(t){return Ai(this,t)}toJSON(){return{"/":Ai(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??ki(n,s,o.bytes))}else if(e[gl]===!0){let{version:n,multihash:s,code:o}=e,i=Ei(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!==wr)throw new Error(`Version 0 CID must use dag-pb (code: ${wr}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let s=ki(t,e,n.bytes);return new r(t,e,n,s)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,wr,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=Ht(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 Fe(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]=mr(t.subarray(e));return e+=d,u},s=n(),o=wr;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(),l=e+a,f=l-i;return{version:s,codec:o,multihashCode:c,digestSize:a,multihashSize:f,size:l}}static parse(t,e){let[n,s]=fl(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 _s(o).set(n,t),o}};function fl(r,t){switch(r[0]){case"Q":{let e=t??tt;return[tt.prefix,e.decode(`${tt.prefix}${r}`)]}case tt.prefix:{let e=t??tt;return[tt.prefix,e.decode(r)]}case He.prefix:{let e=t??He;return[He.prefix,e.decode(r)]}case gr.prefix:{let e=t??gr;return[gr.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 hl(r,t,e){let{prefix:n}=e;if(n!==tt.prefix)throw Error(`Cannot string encode V0 in ${e.name} encoding`);let s=t.get(n);if(s==null){let o=e.encode(r).slice(1);return t.set(n,o),o}else return s}function dl(r,t,e){let{prefix:n}=e,s=t.get(n);if(s==null){let o=e.encode(r);return t.set(n,o),o}else return s}var wr=112,pl=18;function ki(r,t,e){let n=Pe(r),s=n+Pe(t),o=new Uint8Array(s+e.byteLength);return Me(r,o,0),Me(t,o,n),o.set(e,s),o}var gl=Symbol.for("@ipld/js-cid/CID");var Ds={};ft(Ds,{identity:()=>me});var Ii=0,yl="identity",Ci=Ht;function ml(r,t){if(t?.truncate!=null&&t.truncate!==r.byteLength){if(t.truncate<0||t.truncate>r.byteLength)throw new Error(`Invalid truncate option, must be less than or equal to ${r.byteLength}`);r=r.subarray(0,t.truncate)}return _t(Ii,Ci(r))}var me={code:Ii,name:yl,encode:Ci,digest:ml};function mt(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function Mt(r=0){return new Uint8Array(r)}function Bt(r=0){return new Uint8Array(r)}function qe(r,t){t==null&&(t=r.reduce((s,o)=>s+o.length,0));let e=Bt(t),n=0;for(let s of r)e.set(s,n),n+=s.length;return e}var Ui=Symbol.for("@achingbrain/uint8arraylist");function Ni(r,t){if(t==null||t<0)throw new RangeError("index is out of bounds");let e=0;for(let n of r){let s=e+n.byteLength;if(t<s)return{buf:n,index:t-e};e=s}throw new RangeError("index is out of bounds")}function on(r){return!!r?.[Ui]}var ht=class r{bufs;length;[Ui]=!0;constructor(...t){this.bufs=[],this.length=0,t.length>0&&this.appendAll(t)}*[Symbol.iterator](){yield*this.bufs}get byteLength(){return this.length}append(...t){this.appendAll(t)}appendAll(t){let e=0;for(let n of t)if(n instanceof Uint8Array)e+=n.byteLength,this.bufs.push(n);else if(on(n))e+=n.byteLength,this.bufs.push(...n.bufs);else throw new Error("Could not append value, must be an Uint8Array or a Uint8ArrayList");this.length+=e}prepend(...t){this.prependAll(t)}prependAll(t){let e=0;for(let n of t.reverse())if(n instanceof Uint8Array)e+=n.byteLength,this.bufs.unshift(n);else if(on(n))e+=n.byteLength,this.bufs.unshift(...n.bufs);else throw new Error("Could not prepend value, must be an Uint8Array or a Uint8ArrayList");this.length+=e}get(t){let e=Ni(this.bufs,t);return e.buf[e.index]}set(t,e){let n=Ni(this.bufs,t);n.buf[n.index]=e}write(t,e=0){if(t instanceof Uint8Array)for(let n=0;n<t.length;n++)this.set(e+n,t[n]);else if(on(t))for(let n=0;n<t.length;n++)this.set(e+n,t.get(n));else throw new Error("Could not write value, must be an Uint8Array or a Uint8ArrayList")}consume(t){if(t=Math.trunc(t),!(Number.isNaN(t)||t<=0)){if(t===this.byteLength){this.bufs=[],this.length=0;return}for(;this.bufs.length>0;)if(t>=this.bufs[0].byteLength)t-=this.bufs[0].byteLength,this.length-=this.bufs[0].byteLength,this.bufs.shift();else{this.bufs[0]=this.bufs[0].subarray(t),this.length-=t;break}}}slice(t,e){let{bufs:n,length:s}=this._subList(t,e);return qe(n,s)}subarray(t,e){let{bufs:n,length:s}=this._subList(t,e);return n.length===1?n[0]:qe(n,s)}sublist(t,e){let{bufs:n,length:s}=this._subList(t,e),o=new r;return o.length=s,o.bufs=[...n],o}_subList(t,e){if(t=t??0,e=e??this.length,t<0&&(t=this.length+t),e<0&&(e=this.length+e),t<0||e>this.length)throw new RangeError("index is out of bounds");if(t===e)return{bufs:[],length:0};if(t===0&&e===this.length)return{bufs:this.bufs,length:this.length};let n=[],s=0;for(let o=0;o<this.bufs.length;o++){let i=this.bufs[o],c=s,a=c+i.byteLength;if(s=a,t>=a)continue;let l=t>=c&&t<a,f=e>c&&e<=a;if(l&&f){if(t===c&&e===a){n.push(i);break}let u=t-c;n.push(i.subarray(u,u+(e-t)));break}if(l){if(t===0){n.push(i);continue}n.push(i.subarray(t-c));continue}if(f){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(!on(t)&&!(t instanceof Uint8Array))throw new TypeError('The "value" argument must be a Uint8ArrayList or Uint8Array');let n=t instanceof Uint8Array?t:t.subarray();if(e=Number(e??0),isNaN(e)&&(e=0),e<0&&(e=this.length+e),e<0&&(e=0),t.length===0)return e>this.length?this.length:e;let s=n.byteLength;if(s===0)throw new TypeError("search must be at least 1 byte long");let o=256,i=new Int32Array(o);for(let u=0;u<o;u++)i[u]=-1;for(let u=0;u<s;u++)i[n[u]]=u;let c=i,a=this.byteLength-n.byteLength,l=n.byteLength-1,f;for(let u=e;u<=a;u+=f){f=0;for(let d=l;d>=0;d--){let y=this.get(u+d);if(n[d]!==y){f=Math.max(1,d-c[y]);break}}if(f===0)return u}return-1}getInt8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getInt8(0)}setInt8(t,e){let n=Bt(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setInt8(0,e),this.write(n,t)}getInt16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt16(0,e)}setInt16(t,e,n){let s=Mt(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=Mt(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=Mt(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigInt64(0,e,n),this.write(s,t)}getUint8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getUint8(0)}setUint8(t,e){let n=Bt(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setUint8(0,e),this.write(n,t)}getUint16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint16(0,e)}setUint16(t,e,n){let s=Mt(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=Mt(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=Mt(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=Mt(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=Mt(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(!mt(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 Ks={};ft(Ks,{base10:()=>bl});var bl=ee({prefix:"9",name:"base10",alphabet:"0123456789"});var Vs={};ft(Vs,{base16:()=>wl,base16upper:()=>xl});var wl=J({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),xl=J({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Os={};ft(Os,{base2:()=>vl});var vl=J({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Hs={};ft(Hs,{base256emoji:()=>kl});var Li=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}"),El=Li.reduce((r,t,e)=>(r[e]=t,r),[]),Bl=Li.reduce((r,t,e)=>{let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);return r[n]=e,r},[]);function Al(r){return r.reduce((t,e)=>(t+=El[e],t),"")}function Sl(r){let t=[];for(let e of r){let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);let s=Bl[n];if(s==null)throw new Error(`Non-base256emoji character: ${e}`);t.push(s)}return new Uint8Array(t)}var kl=Oe({prefix:"\u{1F680}",name:"base256emoji",encode:Al,decode:Sl});var Ms={};ft(Ms,{base64:()=>be,base64pad:()=>Il,base64url:()=>Cl,base64urlpad:()=>Nl});var be=J({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),Il=J({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Cl=J({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Nl=J({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Ps={};ft(Ps,{base8:()=>Ul});var Ul=J({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Fs={};ft(Fs,{identity:()=>Ll});var Ll=Oe({prefix:"\0",name:"identity",encode:r=>gi(r),decode:r=>pi(r)});var r0=new TextEncoder,n0=new TextDecoder;var js={};ft(js,{sha256:()=>$e,sha512:()=>Dl});var _l=20;function $s({name:r,code:t,encode:e,minDigestLength:n,maxDigestLength:s}){return new qs(r,t,e,n,s)}var qs=class{name;code;encode;minDigestLength;maxDigestLength;constructor(t,e,n,s,o){this.name=t,this.code=e,this.encode=n,this.minDigestLength=s??_l,this.maxDigestLength=o}digest(t,e){if(e?.truncate!=null){if(e.truncate<this.minDigestLength)throw new Error(`Invalid truncate option, must be greater than or equal to ${this.minDigestLength}`);if(this.maxDigestLength!=null&&e.truncate>this.maxDigestLength)throw new Error(`Invalid truncate option, must be less than or equal to ${this.maxDigestLength}`)}if(t instanceof Uint8Array){let n=this.encode(t);return n instanceof Uint8Array?Ti(n,this.code,e?.truncate):n.then(s=>Ti(s,this.code,e?.truncate))}else throw Error("Unknown type, must be binary type")}};function Ti(r,t,e){if(e!=null&&e!==r.byteLength){if(e>r.byteLength)throw new Error(`Invalid truncate option, must be less than or equal to ${r.byteLength}`);r=r.subarray(0,e)}return _t(t,r)}function _i(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var $e=$s({name:"sha2-256",code:18,encode:_i("SHA-256")}),Dl=$s({name:"sha2-512",code:19,encode:_i("SHA-512")});var Gs={...Fs,...Os,...Ps,...Ks,...Vs,...Ls,...Ts,...Us,...Ms,...Hs},g0={...js,...Ds};function Ki(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var Di=Ki("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),Zs=Ki("ascii","a",r=>{let t="a";for(let e=0;e<r.length;e++)t+=String.fromCharCode(r[e]);return t},r=>{r=r.substring(1);let t=Bt(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),Kl={utf8:Di,"utf-8":Di,hex:Gs.base16,latin1:Zs,ascii:Zs,binary:Zs,...Gs},an=Kl;function F(r,t="utf8"){let e=an[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function $(r,t="utf8"){let e=an[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}var Vl=parseInt("11111",2),Ys=parseInt("10000000",2),Ol=parseInt("01111111",2),Vi={0:xr,1:xr,2:Hl,3:Fl,4:ql,5:Pl,6:Ml,16:xr,22:xr,48:xr};function Ct(r,t={offset:0}){let e=r[t.offset]&Vl;if(t.offset++,Vi[e]!=null)return Vi[e](r,t);throw new Error("No decoder for tag "+e)}function vr(r,t){let e=0;if((r[t.offset]&Ys)===Ys){let n=r[t.offset]&Ol,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 xr(r,t){vr(r,t);let e=[];for(;!(t.offset>=r.byteLength);){let n=Ct(r,t);if(n===null)break;e.push(n)}return e}function Hl(r,t){let e=vr(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 Ml(r,t){let e=vr(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 l=r[t.offset];if(t.offset++,a.push(l&127),l<128){a.reverse();let f=0;for(let u=0;u<a.length;u++)f+=a[u]<<u*7;c+=`.${f}`,a=[]}}return c}function Pl(r,t){return t.offset++,null}function Fl(r,t){let e=vr(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 ql(r,t){let e=vr(r,t),n=r.subarray(t.offset,t.offset+e);return t.offset+=e,n}function $l(r){let t=r.toString(16);t.length%2===1&&(t="0"+t);let e=new ht;for(let n=0;n<t.length;n+=2)e.append(Uint8Array.from([parseInt(`${t[n]}${t[n+1]}`,16)]));return e}function cn(r){if(r.byteLength<128)return Uint8Array.from([r.byteLength]);let t=$l(r.byteLength);return new ht(Uint8Array.from([t.byteLength|Ys]),t)}function dt(r){let t=new ht,e=128;return(r.subarray()[0]&e)===e&&t.append(Uint8Array.from([0])),t.append(r),new ht(Uint8Array.from([2]),cn(t),t)}function Er(r){let t=Uint8Array.from([0]),e=new ht(t,r);return new ht(Uint8Array.from([3]),cn(e),e)}function Oi(r){return new ht(Uint8Array.from([4]),cn(r),r)}function Nt(r,t=48){let e=new ht;for(let n of r)e.append(n);return new ht(Uint8Array.from([t]),cn(e),e)}var Hi="1.2.840.10045.3.1.7",Mi="1.3.132.0.34",Pi="1.3.132.0.35";async function Fi(r,t,e){let n=await crypto.subtle.importKey("jwk",r,{name:"ECDSA",namedCurve:r.crv??"P-256"},!1,["sign"]);e?.signal?.throwIfAborted();let s=await crypto.subtle.sign({name:"ECDSA",hash:{name:"SHA-256"}},n,t.subarray());return e?.signal?.throwIfAborted(),new Uint8Array(s,0,s.byteLength)}async function qi(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 jl=Uint8Array.from([6,8,42,134,72,206,61,3,1,7]),Gl=Uint8Array.from([6,5,43,129,4,0,34]),Zl=Uint8Array.from([6,5,43,129,4,0,35]),Yl={ext:!0,kty:"EC",crv:"P-256"},zl={ext:!0,kty:"EC",crv:"P-384"},Wl={ext:!0,kty:"EC",crv:"P-521"},zs=32,Ws=48,Js=66;function $i(r){let t=Ct(r);return Xs(t)}function Xs(r){let t=r[1],e=$(t,"base64url"),n=r[2][1][0],s=1,o,i;if(t.byteLength===zs)return o=$(n.subarray(s,s+zs),"base64url"),i=$(n.subarray(s+zs),"base64url"),new je({...Yl,key_ops:["sign"],d:e,x:o,y:i});if(t.byteLength===Ws)return o=$(n.subarray(s,s+Ws),"base64url"),i=$(n.subarray(s+Ws),"base64url"),new je({...zl,key_ops:["sign"],d:e,x:o,y:i});if(t.byteLength===Js)return o=$(n.subarray(s,s+Js),"base64url"),i=$(n.subarray(s+Js),"base64url"),new je({...Wl,key_ops:["sign"],d:e,x:o,y:i});throw new R(`Private key length was wrong length, got ${t.byteLength}, expected 32, 48 or 66`)}function ji(r){return Nt([dt(Uint8Array.from([1])),Oi(F(r.d??"","base64url")),Nt([Zi(r.crv)],160),Nt([Er(new ht(Uint8Array.from([4]),F(r.x??"","base64url"),F(r.y??"","base64url")))],161)]).subarray()}function Gi(r){return Nt([dt(Uint8Array.from([1])),Nt([Zi(r.crv)],160),Nt([Er(new ht(Uint8Array.from([4]),F(r.x??"","base64url"),F(r.y??"","base64url")))],161)]).subarray()}function Zi(r){if(r==="P-256")return jl;if(r==="P-384")return Gl;if(r==="P-521")return Zl;throw new R(`Invalid curve ${r}`)}var un=class{type="ECDSA";jwk;_raw;constructor(t){this.jwk=t}get raw(){return this._raw==null&&(this._raw=Gi(this.jwk)),this._raw}toMultihash(){return me.digest(Ge(this))}toCID(){return St.createV1(114,this.toMultihash())}toString(){return tt.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:mt(this.raw,t.raw)}async verify(t,e,n){return qi(this.jwk,e,t,n)}},je=class{type="ECDSA";jwk;publicKey;_raw;constructor(t){this.jwk=t,this.publicKey=new un({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=ji(this.jwk)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:mt(this.raw,t.raw)}async sign(t,e){return Fi(this.jwk,t,e)}};function we(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function bt(r,t=""){if(!Number.isSafeInteger(r)||r<0){let e=t&&`"${t}" `;throw new Error(`${e}expected integer >= 0, got ${r}`)}}function O(r,t,e=""){let n=we(r),s=r?.length,o=t!==void 0;if(!n||o&&s!==t){let i=e&&`"${e}" `,c=o?` of length ${t}`:"",a=n?`length=${s}`:`type=${typeof r}`;throw new Error(i+"expected Uint8Array"+c+", got "+a)}return r}function Ze(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash must wrapped by utils.createHasher");bt(r.outputLen),bt(r.blockLen)}function Ye(r,t=!0){if(r.destroyed)throw new Error("Hash instance has been destroyed");if(t&&r.finished)throw new Error("Hash#digest() has already been called")}function zi(r,t){O(r,void 0,"digestInto() output");let e=t.outputLen;if(r.length<e)throw new Error('"digestInto() output" expected to be of length >='+e)}function wt(...r){for(let t=0;t<r.length;t++)r[t].fill(0)}function xe(r){return new DataView(r.buffer,r.byteOffset,r.byteLength)}function Ut(r,t){return r<<32-t|r>>>t}function ln(r,t){return r<<t|r>>>32-t>>>0}var Wi=typeof Uint8Array.from([]).toHex=="function"&&typeof Uint8Array.fromHex=="function",Jl=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function Ft(r){if(O(r),Wi)return r.toHex();let t="";for(let e=0;e<r.length;e++)t+=Jl[r[e]];return t}var Pt={_0:48,_9:57,A:65,F:70,a:97,f:102};function Yi(r){if(r>=Pt._0&&r<=Pt._9)return r-Pt._0;if(r>=Pt.A&&r<=Pt.F)return r-(Pt.A-10);if(r>=Pt.a&&r<=Pt.f)return r-(Pt.a-10)}function qt(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);if(Wi)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=Yi(r.charCodeAt(o)),c=Yi(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}var Xl=async()=>{};async function Ji(r,t,e){let n=Date.now();for(let s=0;s<r;s++){e(s);let o=Date.now()-n;o>=0&&o<t||(await Xl(),n+=o)}}function Ql(r){if(typeof r!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(r))}function Qs(r,t=""){return typeof r=="string"?Ql(r):O(r,void 0,t)}function xt(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];O(s),t+=s.length}let e=new Uint8Array(t);for(let n=0,s=0;n<r.length;n++){let o=r[n];e.set(o,s),s+=o.length}return e}function Xi(r,t){if(t!==void 0&&{}.toString.call(t)!=="[object Object]")throw new Error("options must be object or undefined");return Object.assign(r,t)}function Br(r,t={}){let e=(s,o)=>r(o).update(s).digest(),n=r(void 0);return e.outputLen=n.outputLen,e.blockLen=n.blockLen,e.create=s=>r(s),Object.assign(e,t),Object.freeze(e)}function re(r=32){let t=typeof globalThis=="object"?globalThis.crypto:null;if(typeof t?.getRandomValues!="function")throw new Error("crypto.getRandomValues must be defined");return t.getRandomValues(new Uint8Array(r))}var to=r=>({oid:Uint8Array.from([6,9,96,134,72,1,101,3,4,2,r])});function fn(r,t,e){return r&t^~r&e}function hn(r,t,e){return r&t^r&e^t&e}var ve=class{blockLen;outputLen;padOffset;isLE;buffer;view;finished=!1;length=0;pos=0;destroyed=!1;constructor(t,e,n,s){this.blockLen=t,this.outputLen=e,this.padOffset=n,this.isLE=s,this.buffer=new Uint8Array(t),this.view=xe(this.buffer)}update(t){Ye(this),O(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=xe(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){Ye(this),zi(t,this),this.finished=!0;let{buffer:e,view:n,blockLen:s,isLE:o}=this,{pos:i}=this;e[i++]=128,wt(this.buffer.subarray(i)),this.padOffset>s-i&&(this.process(n,0),i=0);for(let u=i;u<s;u++)e[u]=0;n.setBigUint64(s-8,BigInt(this.length*8),o),this.process(n,0);let c=xe(t),a=this.outputLen;if(a%4)throw new Error("_sha2: outputLen must be aligned to 32bit");let l=a/4,f=this.get();if(l>f.length)throw new Error("_sha2: outputLen bigger than state");for(let u=0;u<l;u++)c.setUint32(4*u,f[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||=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()}},$t=Uint32Array.from([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]);var ot=Uint32Array.from([1779033703,4089235720,3144134277,2227873595,1013904242,4271175723,2773480762,1595750129,1359893119,2917565137,2600822924,725511199,528734635,4215389547,1541459225,327033209]);var dn=BigInt(4294967295),Qi=BigInt(32);function tf(r,t=!1){return t?{h:Number(r&dn),l:Number(r>>Qi&dn)}:{h:Number(r>>Qi&dn)|0,l:Number(r&dn)|0}}function ta(r,t=!1){let e=r.length,n=new Uint32Array(e),s=new Uint32Array(e);for(let o=0;o<e;o++){let{h:i,l:c}=tf(r[o],t);[n[o],s[o]]=[i,c]}return[n,s]}var eo=(r,t,e)=>r>>>e,ro=(r,t,e)=>r<<32-e|t>>>e,Ee=(r,t,e)=>r>>>e|t<<32-e,Be=(r,t,e)=>r<<32-e|t>>>e,Ar=(r,t,e)=>r<<64-e|t>>>e-32,Sr=(r,t,e)=>r>>>e-32|t<<64-e;function Dt(r,t,e,n){let s=(t>>>0)+(n>>>0);return{h:r+e+(s/2**32|0)|0,l:s|0}}var ea=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),ra=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,na=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),sa=(r,t,e,n,s)=>t+e+n+s+(r/2**32|0)|0,oa=(r,t,e,n,s)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(s>>>0),ia=(r,t,e,n,s,o)=>t+e+n+s+o+(r/2**32|0)|0;var rf=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]),ne=new Uint32Array(64),no=class extends ve{constructor(t){super(64,t,8,!1)}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)ne[u]=t.getUint32(e,!1);for(let u=16;u<64;u++){let d=ne[u-15],y=ne[u-2],h=Ut(d,7)^Ut(d,18)^d>>>3,B=Ut(y,17)^Ut(y,19)^y>>>10;ne[u]=B+ne[u-7]+h+ne[u-16]|0}let{A:n,B:s,C:o,D:i,E:c,F:a,G:l,H:f}=this;for(let u=0;u<64;u++){let d=Ut(c,6)^Ut(c,11)^Ut(c,25),y=f+d+fn(c,a,l)+rf[u]+ne[u]|0,B=(Ut(n,2)^Ut(n,13)^Ut(n,22))+hn(n,s,o)|0;f=l,l=a,a=c,c=i+y|0,i=o,o=s,s=n,n=y+B|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,l=l+this.G|0,f=f+this.H|0,this.set(n,s,o,i,c,a,l,f)}roundClean(){wt(ne)}destroy(){this.set(0,0,0,0,0,0,0,0),wt(this.buffer)}},so=class extends no{A=$t[0]|0;B=$t[1]|0;C=$t[2]|0;D=$t[3]|0;E=$t[4]|0;F=$t[5]|0;G=$t[6]|0;H=$t[7]|0;constructor(){super(32)}};var aa=ta(["0x428a2f98d728ae22","0x7137449123ef65cd","0xb5c0fbcfec4d3b2f","0xe9b5dba58189dbbc","0x3956c25bf348b538","0x59f111f1b605d019","0x923f82a4af194f9b","0xab1c5ed5da6d8118","0xd807aa98a3030242","0x12835b0145706fbe","0x243185be4ee4b28c","0x550c7dc3d5ffb4e2","0x72be5d74f27b896f","0x80deb1fe3b1696b1","0x9bdc06a725c71235","0xc19bf174cf692694","0xe49b69c19ef14ad2","0xefbe4786384f25e3","0x0fc19dc68b8cd5b5","0x240ca1cc77ac9c65","0x2de92c6f592b0275","0x4a7484aa6ea6e483","0x5cb0a9dcbd41fbd4","0x76f988da831153b5","0x983e5152ee66dfab","0xa831c66d2db43210","0xb00327c898fb213f","0xbf597fc7beef0ee4","0xc6e00bf33da88fc2","0xd5a79147930aa725","0x06ca6351e003826f","0x142929670a0e6e70","0x27b70a8546d22ffc","0x2e1b21385c26c926","0x4d2c6dfc5ac42aed","0x53380d139d95b3df","0x650a73548baf63de","0x766a0abb3c77b2a8","0x81c2c92e47edaee6","0x92722c851482353b","0xa2bfe8a14cf10364","0xa81a664bbc423001","0xc24b8b70d0f89791","0xc76c51a30654be30","0xd192e819d6ef5218","0xd69906245565a910","0xf40e35855771202a","0x106aa07032bbd1b8","0x19a4c116b8d2d0c8","0x1e376c085141ab53","0x2748774cdf8eeb99","0x34b0bcb5e19b48a8","0x391c0cb3c5c95a63","0x4ed8aa4ae3418acb","0x5b9cca4f7763e373","0x682e6ff3d6b2b8a3","0x748f82ee5defb2fc","0x78a5636f43172f60","0x84c87814a1f0ab72","0x8cc702081a6439ec","0x90befffa23631e28","0xa4506cebde82bde9","0xbef9a3f7b2c67915","0xc67178f2e372532b","0xca273eceea26619c","0xd186b8c721c0c207","0xeada7dd6cde0eb1e","0xf57d4f7fee6ed178","0x06f067aa72176fba","0x0a637dc5a2c898a6","0x113f9804bef90dae","0x1b710b35131c471b","0x28db77f523047d84","0x32caab7b40c72493","0x3c9ebe0a15c9bebc","0x431d67c49c100d4c","0x4cc5d4becb3e42b6","0x597f299cfc657e2a","0x5fcb6fab3ad6faec","0x6c44198c4a475817"].map(r=>BigInt(r))),nf=aa[0],sf=aa[1],se=new Uint32Array(80),oe=new Uint32Array(80),oo=class extends ve{constructor(t){super(128,t,16,!1)}get(){let{Ah:t,Al:e,Bh:n,Bl:s,Ch:o,Cl:i,Dh:c,Dl:a,Eh:l,El:f,Fh:u,Fl:d,Gh:y,Gl:h,Hh:B,Hl:v}=this;return[t,e,n,s,o,i,c,a,l,f,u,d,y,h,B,v]}set(t,e,n,s,o,i,c,a,l,f,u,d,y,h,B,v){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=l|0,this.El=f|0,this.Fh=u|0,this.Fl=d|0,this.Gh=y|0,this.Gl=h|0,this.Hh=B|0,this.Hl=v|0}process(t,e){for(let w=0;w<16;w++,e+=4)se[w]=t.getUint32(e),oe[w]=t.getUint32(e+=4);for(let w=16;w<80;w++){let I=se[w-15]|0,D=oe[w-15]|0,H=Ee(I,D,1)^Ee(I,D,8)^eo(I,D,7),M=Be(I,D,1)^Be(I,D,8)^ro(I,D,7),E=se[w-2]|0,x=oe[w-2]|0,K=Ee(E,x,19)^Ar(E,x,61)^eo(E,x,6),P=Be(E,x,19)^Sr(E,x,61)^ro(E,x,6),L=na(M,P,oe[w-7],oe[w-16]),m=sa(L,H,K,se[w-7],se[w-16]);se[w]=m|0,oe[w]=L|0}let{Ah:n,Al:s,Bh:o,Bl:i,Ch:c,Cl:a,Dh:l,Dl:f,Eh:u,El:d,Fh:y,Fl:h,Gh:B,Gl:v,Hh:g,Hl:A}=this;for(let w=0;w<80;w++){let I=Ee(u,d,14)^Ee(u,d,18)^Ar(u,d,41),D=Be(u,d,14)^Be(u,d,18)^Sr(u,d,41),H=u&y^~u&B,M=d&h^~d&v,E=oa(A,D,M,sf[w],oe[w]),x=ia(E,g,I,H,nf[w],se[w]),K=E|0,P=Ee(n,s,28)^Ar(n,s,34)^Ar(n,s,39),L=Be(n,s,28)^Sr(n,s,34)^Sr(n,s,39),m=n&o^n&c^o&c,b=s&i^s&a^i&a;g=B|0,A=v|0,B=y|0,v=h|0,y=u|0,h=d|0,{h:u,l:d}=Dt(l|0,f|0,x|0,K|0),l=c|0,f=a|0,c=o|0,a=i|0,o=n|0,i=s|0;let p=ea(K,L,b);n=ra(p,x,P,m),s=p|0}({h:n,l:s}=Dt(this.Ah|0,this.Al|0,n|0,s|0)),{h:o,l:i}=Dt(this.Bh|0,this.Bl|0,o|0,i|0),{h:c,l:a}=Dt(this.Ch|0,this.Cl|0,c|0,a|0),{h:l,l:f}=Dt(this.Dh|0,this.Dl|0,l|0,f|0),{h:u,l:d}=Dt(this.Eh|0,this.El|0,u|0,d|0),{h:y,l:h}=Dt(this.Fh|0,this.Fl|0,y|0,h|0),{h:B,l:v}=Dt(this.Gh|0,this.Gl|0,B|0,v|0),{h:g,l:A}=Dt(this.Hh|0,this.Hl|0,g|0,A|0),this.set(n,s,o,i,c,a,l,f,u,d,y,h,B,v,g,A)}roundClean(){wt(se,oe)}destroy(){wt(this.buffer),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}},io=class extends oo{Ah=ot[0]|0;Al=ot[1]|0;Bh=ot[2]|0;Bl=ot[3]|0;Ch=ot[4]|0;Cl=ot[5]|0;Dh=ot[6]|0;Dl=ot[7]|0;Eh=ot[8]|0;El=ot[9]|0;Fh=ot[10]|0;Fl=ot[11]|0;Gh=ot[12]|0;Gl=ot[13]|0;Hh=ot[14]|0;Hl=ot[15]|0;constructor(){super(64)}};var ie=Br(()=>new so,to(1));var ae=Br(()=>new io,to(3));var co=BigInt(0),ao=BigInt(1);function jt(r,t=""){if(typeof r!="boolean"){let e=t&&`"${t}" `;throw new Error(e+"expected boolean, got type="+typeof r)}return r}function ca(r){if(typeof r=="bigint"){if(!pn(r))throw new Error("positive bigint expected, got "+r)}else bt(r);return r}function kr(r){let t=ca(r).toString(16);return t.length&1?"0"+t:t}function ua(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return r===""?co:BigInt("0x"+r)}function ze(r){return ua(Ft(r))}function Ae(r){return ua(Ft(yn(O(r)).reverse()))}function gn(r,t){bt(t),r=ca(r);let e=qt(r.toString(16).padStart(t*2,"0"));if(e.length!==t)throw new Error("number too large");return e}function uo(r,t){return gn(r,t).reverse()}function yn(r){return Uint8Array.from(r)}var pn=r=>typeof r=="bigint"&&co<=r;function of(r,t,e){return pn(r)&&pn(t)&&pn(e)&&t<=r&&r<e}function Ir(r,t,e,n){if(!of(t,e,n))throw new Error("expected valid "+r+": "+e+" <= n < "+n+", got "+t)}function lo(r){let t;for(t=0;r>co;r>>=ao,t+=1);return t}var Cr=r=>(ao<<BigInt(r))-ao;function la(r,t,e){if(bt(r,"hashLen"),bt(t,"qByteLen"),typeof e!="function")throw new Error("hmacFn must be a function");let n=v=>new Uint8Array(v),s=Uint8Array.of(),o=Uint8Array.of(0),i=Uint8Array.of(1),c=1e3,a=n(r),l=n(r),f=0,u=()=>{a.fill(1),l.fill(0),f=0},d=(...v)=>e(l,xt(a,...v)),y=(v=s)=>{l=d(o,v),a=d(),v.length!==0&&(l=d(i,v),a=d())},h=()=>{if(f++>=c)throw new Error("drbg: tried max amount of iterations");let v=0,g=[];for(;v<t;){a=d();let A=a.slice();g.push(A),v+=a.length}return xt(...g)};return(v,g)=>{u(),y(v);let A;for(;!(A=g(h()));)y();return u(),A}}function ce(r,t={},e={}){if(!r||typeof r!="object")throw new Error("expected valid options object");function n(o,i,c){let a=r[o];if(c&&a===void 0)return;let l=typeof a;if(l!==i||a===null)throw new Error(`param "${o}" is invalid: expected ${i}, got ${l}`)}let s=(o,i)=>Object.entries(o).forEach(([c,a])=>n(c,a,i));s(t,!1),s(e,!0)}function We(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 pt=BigInt(0),rt=BigInt(1),Se=BigInt(2),da=BigInt(3),pa=BigInt(4),ga=BigInt(5),af=BigInt(7),ya=BigInt(8),cf=BigInt(9),ma=BigInt(16);function X(r,t){let e=r%t;return e>=pt?e:t+e}function Z(r,t,e){let n=r;for(;t-- >pt;)n*=n,n%=e;return n}function fa(r,t){if(r===pt)throw new Error("invert: expected non-zero number");if(t<=pt)throw new Error("invert: expected positive modulus, got "+t);let e=X(r,t),n=t,s=pt,o=rt,i=rt,c=pt;for(;e!==pt;){let l=n/e,f=n%e,u=s-i*l,d=o-c*l;n=e,e=f,s=i,o=c,i=u,c=d}if(n!==rt)throw new Error("invert: does not exist");return X(s,t)}function ho(r,t,e){if(!r.eql(r.sqr(t),e))throw new Error("Cannot find square root")}function ba(r,t){let e=(r.ORDER+rt)/pa,n=r.pow(t,e);return ho(r,n,t),n}function uf(r,t){let e=(r.ORDER-ga)/ya,n=r.mul(t,Se),s=r.pow(n,e),o=r.mul(t,s),i=r.mul(r.mul(o,Se),s),c=r.mul(o,r.sub(i,r.ONE));return ho(r,c,t),c}function lf(r){let t=Je(r),e=wa(r),n=e(t,t.neg(t.ONE)),s=e(t,n),o=e(t,t.neg(n)),i=(r+af)/ma;return(c,a)=>{let l=c.pow(a,i),f=c.mul(l,n),u=c.mul(l,s),d=c.mul(l,o),y=c.eql(c.sqr(f),a),h=c.eql(c.sqr(u),a);l=c.cmov(l,f,y),f=c.cmov(d,u,h);let B=c.eql(c.sqr(f),a),v=c.cmov(l,f,B);return ho(c,v,a),v}}function wa(r){if(r<da)throw new Error("sqrt is not defined for small field");let t=r-rt,e=0;for(;t%Se===pt;)t/=Se,e++;let n=Se,s=Je(r);for(;ha(s,n)===1;)if(n++>1e3)throw new Error("Cannot find square root: probably non-prime P");if(e===1)return ba;let o=s.pow(n,t),i=(t+rt)/Se;return function(a,l){if(a.is0(l))return l;if(ha(a,l)!==1)throw new Error("Cannot find square root");let f=e,u=a.mul(a.ONE,o),d=a.pow(l,t),y=a.pow(l,i);for(;!a.eql(d,a.ONE);){if(a.is0(d))return a.ZERO;let h=1,B=a.sqr(d);for(;!a.eql(B,a.ONE);)if(h++,B=a.sqr(B),h===f)throw new Error("Cannot find square root");let v=rt<<BigInt(f-h-1),g=a.pow(u,v);f=h,u=a.sqr(g),d=a.mul(d,u),y=a.mul(y,g)}return y}}function ff(r){return r%pa===da?ba:r%ya===ga?uf:r%ma===cf?lf(r):wa(r)}var xa=(r,t)=>(X(r,t)&rt)===rt,hf=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function po(r){let t={ORDER:"bigint",BYTES:"number",BITS:"number"},e=hf.reduce((n,s)=>(n[s]="function",n),t);return ce(r,e),r}function df(r,t,e){if(e<pt)throw new Error("invalid exponent, negatives unsupported");if(e===pt)return r.ONE;if(e===rt)return t;let n=r.ONE,s=t;for(;e>pt;)e&rt&&(n=r.mul(n,s)),s=r.sqr(s),e>>=rt;return n}function Nr(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 ha(r,t){let e=(r.ORDER-rt)/Se,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 pf(r,t){t!==void 0&&bt(t);let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}var fo=class{ORDER;BITS;BYTES;isLE;ZERO=pt;ONE=rt;_lengths;_sqrt;_mod;constructor(t,e={}){if(t<=pt)throw new Error("invalid field: expected ORDER > 0, got "+t);let n;this.isLE=!1,e!=null&&typeof e=="object"&&(typeof e.BITS=="number"&&(n=e.BITS),typeof e.sqrt=="function"&&(this.sqrt=e.sqrt),typeof e.isLE=="boolean"&&(this.isLE=e.isLE),e.allowedLengths&&(this._lengths=e.allowedLengths?.slice()),typeof e.modFromBytes=="boolean"&&(this._mod=e.modFromBytes));let{nBitLength:s,nByteLength:o}=pf(t,n);if(o>2048)throw new Error("invalid field: expected ORDER of <= 2048 bytes");this.ORDER=t,this.BITS=s,this.BYTES=o,this._sqrt=void 0,Object.preventExtensions(this)}create(t){return X(t,this.ORDER)}isValid(t){if(typeof t!="bigint")throw new Error("invalid field element: expected bigint, got "+typeof t);return pt<=t&&t<this.ORDER}is0(t){return t===pt}isValidNot0(t){return!this.is0(t)&&this.isValid(t)}isOdd(t){return(t&rt)===rt}neg(t){return X(-t,this.ORDER)}eql(t,e){return t===e}sqr(t){return X(t*t,this.ORDER)}add(t,e){return X(t+e,this.ORDER)}sub(t,e){return X(t-e,this.ORDER)}mul(t,e){return X(t*e,this.ORDER)}pow(t,e){return df(this,t,e)}div(t,e){return X(t*fa(e,this.ORDER),this.ORDER)}sqrN(t){return t*t}addN(t,e){return t+e}subN(t,e){return t-e}mulN(t,e){return t*e}inv(t){return fa(t,this.ORDER)}sqrt(t){return this._sqrt||(this._sqrt=ff(this.ORDER)),this._sqrt(this,t)}toBytes(t){return this.isLE?uo(t,this.BYTES):gn(t,this.BYTES)}fromBytes(t,e=!1){O(t);let{_lengths:n,BYTES:s,isLE:o,ORDER:i,_mod:c}=this;if(n){if(!n.includes(t.length)||t.length>s)throw new Error("Field.fromBytes: expected "+n+" bytes, got "+t.length);let l=new Uint8Array(s);l.set(t,o?0:l.length-t.length),t=l}if(t.length!==s)throw new Error("Field.fromBytes: expected "+s+" bytes, got "+t.length);let a=o?Ae(t):ze(t);if(c&&(a=X(a,i)),!e&&!this.isValid(a))throw new Error("invalid field element: outside of range 0..ORDER");return a}invertBatch(t){return Nr(this,t)}cmov(t,e,n){return n?e:t}};function Je(r,t={}){return new fo(r,t)}function va(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 go(r){let t=va(r);return t+Math.ceil(t/2)}function yo(r,t,e=!1){O(r);let n=r.length,s=va(t),o=go(t);if(n<16||n<o||n>1024)throw new Error("expected "+o+"-1024 bytes of input, got "+n);let i=e?Ae(r):ze(r),c=X(i,t-rt)+rt;return e?uo(c,s):gn(c,s)}var Xe=BigInt(0),ke=BigInt(1);function Ur(r,t){let e=t.negate();return r?e:t}function Ie(r,t){let e=Nr(r.Fp,t.map(n=>n.Z));return t.map((n,s)=>r.fromAffine(n.toAffine(e[s])))}function Sa(r,t){if(!Number.isSafeInteger(r)||r<=0||r>t)throw new Error("invalid window size, expected [1.."+t+"], got W="+r)}function mo(r,t){Sa(r,t);let e=Math.ceil(t/r)+1,n=2**(r-1),s=2**r,o=Cr(r),i=BigInt(r);return{windows:e,windowSize:n,mask:o,maxNumber:s,shiftBy:i}}function Ea(r,t,e){let{windowSize:n,mask:s,maxNumber:o,shiftBy:i}=e,c=Number(r&s),a=r>>i;c>n&&(c-=o,a+=ke);let l=t*n,f=l+Math.abs(c)-1,u=c===0,d=c<0,y=t%2!==0;return{nextN:a,offset:f,isZero:u,isNeg:d,isNegF:y,offsetF:l}}var bo=new WeakMap,ka=new WeakMap;function wo(r){return ka.get(r)||1}function Ba(r){if(r!==Xe)throw new Error("invalid wNAF")}var Qe=class{BASE;ZERO;Fn;bits;constructor(t,e){this.BASE=t.BASE,this.ZERO=t.ZERO,this.Fn=t.Fn,this.bits=e}_unsafeLadder(t,e,n=this.ZERO){let s=t;for(;e>Xe;)e&ke&&(n=n.add(s)),s=s.double(),e>>=ke;return n}precomputeWindow(t,e){let{windows:n,windowSize:s}=mo(e,this.bits),o=[],i=t,c=i;for(let a=0;a<n;a++){c=i,o.push(c);for(let l=1;l<s;l++)c=c.add(i),o.push(c);i=c.double()}return o}wNAF(t,e,n){if(!this.Fn.isValid(n))throw new Error("invalid scalar");let s=this.ZERO,o=this.BASE,i=mo(t,this.bits);for(let c=0;c<i.windows;c++){let{nextN:a,offset:l,isZero:f,isNeg:u,isNegF:d,offsetF:y}=Ea(n,c,i);n=a,f?o=o.add(Ur(d,e[y])):s=s.add(Ur(u,e[l]))}return Ba(n),{p:s,f:o}}wNAFUnsafe(t,e,n,s=this.ZERO){let o=mo(t,this.bits);for(let i=0;i<o.windows&&n!==Xe;i++){let{nextN:c,offset:a,isZero:l,isNeg:f}=Ea(n,i,o);if(n=c,!l){let u=e[a];s=s.add(f?u.negate():u)}}return Ba(n),s}getPrecomputes(t,e,n){let s=bo.get(e);return s||(s=this.precomputeWindow(e,t),t!==1&&(typeof n=="function"&&(s=n(s)),bo.set(e,s))),s}cached(t,e,n){let s=wo(t);return this.wNAF(s,this.getPrecomputes(s,t,n),e)}unsafe(t,e,n,s){let o=wo(t);return o===1?this._unsafeLadder(t,e,s):this.wNAFUnsafe(o,this.getPrecomputes(o,t,n),e,s)}createCache(t,e){Sa(e,this.bits),ka.set(t,e),bo.delete(t)}hasCache(t){return wo(t)!==1}};function Ia(r,t,e,n){let s=t,o=r.ZERO,i=r.ZERO;for(;e>Xe||n>Xe;)e&ke&&(o=o.add(s)),n&ke&&(i=i.add(s)),s=s.double(),e>>=ke,n>>=ke;return{p1:o,p2:i}}function Aa(r,t,e){if(t){if(t.ORDER!==r)throw new Error("Field.ORDER must match order: Fp == p, Fn == n");return po(t),t}else return Je(r,{isLE:e})}function mn(r,t,e={},n){if(n===void 0&&(n=r==="edwards"),!t||typeof t!="object")throw new Error(`expected valid ${r} CURVE object`);for(let a of["p","n","h"]){let l=t[a];if(!(typeof l=="bigint"&&l>Xe))throw new Error(`CURVE.${a} must be positive bigint`)}let s=Aa(t.p,e.Fp,n),o=Aa(t.n,e.Fn,n),c=["Gx","Gy","a",r==="weierstrass"?"b":"d"];for(let a of c)if(!s.isValid(t[a]))throw new Error(`CURVE.${a} must be valid field element of CURVE.Fp`);return t=Object.freeze(Object.assign({},t)),{CURVE:t,Fp:s,Fn:o}}function bn(r,t){return function(n){let s=r(n);return{secretKey:s,publicKey:t(s)}}}var ue=BigInt(0),nt=BigInt(1),xo=BigInt(2),gf=BigInt(8);function yf(r,t,e,n){let s=r.sqr(e),o=r.sqr(n),i=r.add(r.mul(t.a,s),o),c=r.add(r.ONE,r.mul(t.d,r.mul(s,o)));return r.eql(i,c)}function Ca(r,t={}){let e=mn("edwards",r,t,t.FpFnLE),{Fp:n,Fn:s}=e,o=e.CURVE,{h:i}=o;ce(t,{},{uvRatio:"function"});let c=xo<<BigInt(s.BYTES*8)-nt,a=v=>n.create(v),l=t.uvRatio||((v,g)=>{try{return{isValid:!0,value:n.sqrt(n.div(v,g))}}catch{return{isValid:!1,value:ue}}});if(!yf(n,o,o.Gx,o.Gy))throw new Error("bad curve params: generator point");function f(v,g,A=!1){let w=A?nt:ue;return Ir("coordinate "+v,g,w,c),g}function u(v){if(!(v instanceof h))throw new Error("EdwardsPoint expected")}let d=We((v,g)=>{let{X:A,Y:w,Z:I}=v,D=v.is0();g==null&&(g=D?gf:n.inv(I));let H=a(A*g),M=a(w*g),E=n.mul(I,g);if(D)return{x:ue,y:nt};if(E!==nt)throw new Error("invZ was invalid");return{x:H,y:M}}),y=We(v=>{let{a:g,d:A}=o;if(v.is0())throw new Error("bad point: ZERO");let{X:w,Y:I,Z:D,T:H}=v,M=a(w*w),E=a(I*I),x=a(D*D),K=a(x*x),P=a(M*g),L=a(x*a(P+E)),m=a(K+a(A*a(M*E)));if(L!==m)throw new Error("bad point: equation left != right (1)");let b=a(w*I),p=a(D*H);if(b!==p)throw new Error("bad point: equation left != right (2)");return!0});class h{static BASE=new h(o.Gx,o.Gy,nt,a(o.Gx*o.Gy));static ZERO=new h(ue,nt,nt,ue);static Fp=n;static Fn=s;X;Y;Z;T;constructor(g,A,w,I){this.X=f("x",g),this.Y=f("y",A),this.Z=f("z",w,!0),this.T=f("t",I),Object.freeze(this)}static CURVE(){return o}static fromAffine(g){if(g instanceof h)throw new Error("extended point not allowed");let{x:A,y:w}=g||{};return f("x",A),f("y",w),new h(A,w,nt,a(A*w))}static fromBytes(g,A=!1){let w=n.BYTES,{a:I,d:D}=o;g=yn(O(g,w,"point")),jt(A,"zip215");let H=yn(g),M=g[w-1];H[w-1]=M&-129;let E=Ae(H),x=A?c:n.ORDER;Ir("point.y",E,ue,x);let K=a(E*E),P=a(K-nt),L=a(D*K-I),{isValid:m,value:b}=l(P,L);if(!m)throw new Error("bad point: invalid y coordinate");let p=(b&nt)===nt,S=(M&128)!==0;if(!A&&b===ue&&S)throw new Error("bad point: x=0 and x_0=1");return S!==p&&(b=a(-b)),h.fromAffine({x:b,y:E})}static fromHex(g,A=!1){return h.fromBytes(qt(g),A)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}precompute(g=8,A=!0){return B.createCache(this,g),A||this.multiply(xo),this}assertValidity(){y(this)}equals(g){u(g);let{X:A,Y:w,Z:I}=this,{X:D,Y:H,Z:M}=g,E=a(A*M),x=a(D*I),K=a(w*M),P=a(H*I);return E===x&&K===P}is0(){return this.equals(h.ZERO)}negate(){return new h(a(-this.X),this.Y,this.Z,a(-this.T))}double(){let{a:g}=o,{X:A,Y:w,Z:I}=this,D=a(A*A),H=a(w*w),M=a(xo*a(I*I)),E=a(g*D),x=A+w,K=a(a(x*x)-D-H),P=E+H,L=P-M,m=E-H,b=a(K*L),p=a(P*m),S=a(K*m),C=a(L*P);return new h(b,p,C,S)}add(g){u(g);let{a:A,d:w}=o,{X:I,Y:D,Z:H,T:M}=this,{X:E,Y:x,Z:K,T:P}=g,L=a(I*E),m=a(D*x),b=a(M*w*P),p=a(H*K),S=a((I+D)*(E+x)-L-m),C=p-b,U=p+b,T=a(m-A*L),N=a(S*C),_=a(U*T),V=a(S*T),Y=a(C*U);return new h(N,_,Y,V)}subtract(g){return this.add(g.negate())}multiply(g){if(!s.isValidNot0(g))throw new Error("invalid scalar: expected 1 <= sc < curve.n");let{p:A,f:w}=B.cached(this,g,I=>Ie(h,I));return Ie(h,[A,w])[0]}multiplyUnsafe(g,A=h.ZERO){if(!s.isValid(g))throw new Error("invalid scalar: expected 0 <= sc < curve.n");return g===ue?h.ZERO:this.is0()||g===nt?this:B.unsafe(this,g,w=>Ie(h,w),A)}isSmallOrder(){return this.multiplyUnsafe(i).is0()}isTorsionFree(){return B.unsafe(this,o.n).is0()}toAffine(g){return d(this,g)}clearCofactor(){return i===nt?this:this.multiplyUnsafe(i)}toBytes(){let{x:g,y:A}=this.toAffine(),w=n.toBytes(A);return w[w.length-1]|=g&nt?128:0,w}toHex(){return Ft(this.toBytes())}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}}let B=new Qe(h,s.BITS);return h.BASE.precompute(8),h}function Na(r,t,e={}){if(typeof t!="function")throw new Error('"hash" function param is required');ce(e,{},{adjustScalarBytes:"function",randomBytes:"function",domain:"function",prehash:"function",mapToCurve:"function"});let{prehash:n}=e,{BASE:s,Fp:o,Fn:i}=r,c=e.randomBytes||re,a=e.adjustScalarBytes||(E=>E),l=e.domain||((E,x,K)=>{if(jt(K,"phflag"),x.length||K)throw new Error("Contexts/pre-hash are not supported");return E});function f(E){return i.create(Ae(E))}function u(E){let x=w.secretKey;O(E,w.secretKey,"secretKey");let K=O(t(E),2*x,"hashedSecretKey"),P=a(K.slice(0,x)),L=K.slice(x,2*x),m=f(P);return{head:P,prefix:L,scalar:m}}function d(E){let{head:x,prefix:K,scalar:P}=u(E),L=s.multiply(P),m=L.toBytes();return{head:x,prefix:K,scalar:P,point:L,pointBytes:m}}function y(E){return d(E).pointBytes}function h(E=Uint8Array.of(),...x){let K=xt(...x);return f(t(l(K,O(E,void 0,"context"),!!n)))}function B(E,x,K={}){E=O(E,void 0,"message"),n&&(E=n(E));let{prefix:P,scalar:L,pointBytes:m}=d(x),b=h(K.context,P,E),p=s.multiply(b).toBytes(),S=h(K.context,p,m,E),C=i.create(b+S*L);if(!i.isValid(C))throw new Error("sign failed: invalid s");let U=xt(p,i.toBytes(C));return O(U,w.signature,"result")}let v={zip215:!0};function g(E,x,K,P=v){let{context:L,zip215:m}=P,b=w.signature;E=O(E,b,"signature"),x=O(x,void 0,"message"),K=O(K,w.publicKey,"publicKey"),m!==void 0&&jt(m,"zip215"),n&&(x=n(x));let p=b/2,S=E.subarray(0,p),C=Ae(E.subarray(p,b)),U,T,N;try{U=r.fromBytes(K,m),T=r.fromBytes(S,m),N=s.multiplyUnsafe(C)}catch{return!1}if(!m&&U.isSmallOrder())return!1;let _=h(L,T.toBytes(),U.toBytes(),x);return T.add(U.multiplyUnsafe(_)).subtract(N).clearCofactor().is0()}let A=o.BYTES,w={secretKey:A,publicKey:A,signature:2*A,seed:A};function I(E=c(w.seed)){return O(E,w.seed,"seed")}function D(E){return we(E)&&E.length===i.BYTES}function H(E,x){try{return!!r.fromBytes(E,x)}catch{return!1}}let M={getExtendedPublicKey:d,randomSecretKey:I,isValidSecretKey:D,isValidPublicKey:H,toMontgomery(E){let{y:x}=r.fromBytes(E),K=w.publicKey,P=K===32;if(!P&&K!==57)throw new Error("only defined for 25519 and 448");let L=P?o.div(nt+x,nt-x):o.div(x-nt,x+nt);return o.toBytes(L)},toMontgomerySecret(E){let x=w.secretKey;O(E,x);let K=t(E.subarray(0,x));return a(K).subarray(0,x)}};return Object.freeze({keygen:bn(I,y),getPublicKey:y,sign:B,verify:g,utils:M,Point:r,lengths:w})}var mf=BigInt(1),Ua=BigInt(2);var bf=BigInt(5),wf=BigInt(8),vo=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffed"),xf={p:vo,n:BigInt("0x1000000000000000000000000000000014def9dea2f79cd65812631a5cf5d3ed"),h:wf,a:BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffec"),d:BigInt("0x52036cee2b6ffe738cc740797779e89800700a4d4141d8ab75eb4dca135978a3"),Gx:BigInt("0x216936d3cd6e53fec0a4e231fdd6dc5c692cc7609525a7b2c9562d608f25d51a"),Gy:BigInt("0x6666666666666666666666666666666666666666666666666666666666666658")};function vf(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),s=BigInt(80),o=vo,c=r*r%o*r%o,a=Z(c,Ua,o)*c%o,l=Z(a,mf,o)*r%o,f=Z(l,bf,o)*l%o,u=Z(f,t,o)*f%o,d=Z(u,e,o)*u%o,y=Z(d,n,o)*d%o,h=Z(y,s,o)*y%o,B=Z(h,s,o)*y%o,v=Z(B,t,o)*f%o;return{pow_p_5_8:Z(v,Ua,o)*r%o,b2:c}}function Ef(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}var La=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752");function Bf(r,t){let e=vo,n=X(t*t*t,e),s=X(n*n*t,e),o=vf(r*s).pow_p_5_8,i=X(r*n*o,e),c=X(t*i*i,e),a=i,l=X(i*La,e),f=c===r,u=c===X(-r,e),d=c===X(-r*La,e);return f&&(i=a),(u||d)&&(i=l),xa(i,e)&&(i=X(-i,e)),{isValid:f||u,value:i}}var Af=Ca(xf,{uvRatio:Bf});function Sf(r){return Na(Af,ae,Object.assign({adjustScalarBytes:Ef},r))}var Eo=Sf({});var er=32,kt=64,kf=32;var tr,Ta=(async()=>{try{return await Q.get().subtle.generateKey({name:"Ed25519"},!0,["sign","verify"]),!0}catch{return!1}})();async function If(r,t){let e;r.length===kt?e=r.subarray(0,32):e=r;let n={crv:"Ed25519",kty:"OKP",x:$(r.subarray(32),"base64url"),d:$(e,"base64url"),ext:!0,key_ops:["sign"]},s=await Q.get().subtle.importKey("jwk",n,{name:"Ed25519"},!0,["sign"]),o=await Q.get().subtle.sign({name:"Ed25519"},s,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(o,0,o.byteLength)}function Cf(r,t){let e=r.subarray(0,kf);return Eo.sign(t instanceof Uint8Array?t:t.subarray(),e)}async function Ra(r,t){return tr==null&&(tr=await Ta),tr?If(r,t):Cf(r,t)}async function Nf(r,t,e){if(r.buffer instanceof ArrayBuffer){let n=await Q.get().subtle.importKey("raw",r.buffer,{name:"Ed25519"},!1,["verify"]);return await Q.get().subtle.verify({name:"Ed25519"},n,t,e instanceof Uint8Array?e:e.subarray())}throw new TypeError("WebCrypto does not support SharedArrayBuffer for Ed25519 keys")}function Uf(r,t,e){return Eo.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}async function _a(r,t,e){return tr==null&&(tr=await Ta),tr?Nf(r,t,e):Uf(r,t,e)}function rr(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}var wn=class{type="Ed25519";raw;constructor(t){this.raw=Tr(t,er)}toMultihash(){return me.digest(Ge(this))}toCID(){return St.createV1(114,this.toMultihash())}toString(){return tt.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:mt(this.raw,t.raw)}verify(t,e,n){n?.signal?.throwIfAborted();let s=_a(this.raw,e,t);return rr(s)?s.then(o=>(n?.signal?.throwIfAborted(),o)):s}},Lr=class{type="Ed25519";raw;publicKey;constructor(t,e){this.raw=Tr(t,kt),this.publicKey=new wn(e)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:mt(this.raw,t.raw)}sign(t,e){e?.signal?.throwIfAborted();let n=Ra(this.raw,t);return rr(n)?n.then(s=>(e?.signal?.throwIfAborted(),s)):(e?.signal?.throwIfAborted(),n)}};function Bo(r){if(r.length>kt){r=Tr(r,kt+er);let n=r.subarray(0,kt),s=r.subarray(kt,r.length);return new Lr(n,s)}r=Tr(r,kt);let t=r.subarray(0,kt),e=r.subarray(er);return new Lr(t,e)}function Tr(r,t){if(r=Uint8Array.from(r??[]),r.length!==t)throw new R(`Key must be a Uint8Array of length ${t}, got ${r.length}`);return r}var Lf=Math.pow(2,7),Tf=Math.pow(2,14),Rf=Math.pow(2,21),Ka=Math.pow(2,28),Va=Math.pow(2,35),Oa=Math.pow(2,42),Ha=Math.pow(2,49),gt=128,le=127;function Rr(r){if(r<Lf)return 1;if(r<Tf)return 2;if(r<Rf)return 3;if(r<Ka)return 4;if(r<Va)return 5;if(r<Oa)return 6;if(r<Ha)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function Ma(r,t,e=0){switch(Rr(r)){case 8:t[e++]=r&255|gt,r/=128;case 7:t[e++]=r&255|gt,r/=128;case 6:t[e++]=r&255|gt,r/=128;case 5:t[e++]=r&255|gt,r/=128;case 4:t[e++]=r&255|gt,r>>>=7;case 3:t[e++]=r&255|gt,r>>>=7;case 2:t[e++]=r&255|gt,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function Pa(r,t){let e=r[t],n=0;if(n+=e&le,e<gt||(e=r[t+1],n+=(e&le)<<7,e<gt)||(e=r[t+2],n+=(e&le)<<14,e<gt)||(e=r[t+3],n+=(e&le)<<21,e<gt)||(e=r[t+4],n+=(e&le)*Ka,e<gt)||(e=r[t+5],n+=(e&le)*Va,e<gt)||(e=r[t+6],n+=(e&le)*Oa,e<gt)||(e=r[t+7],n+=(e&le)*Ha,e<gt))return n;throw new RangeError("Could not decode varint")}var Ao=new Float32Array([-0]),fe=new Uint8Array(Ao.buffer);function Fa(r,t,e){Ao[0]=r,t[e]=fe[0],t[e+1]=fe[1],t[e+2]=fe[2],t[e+3]=fe[3]}function qa(r,t){return fe[0]=r[t],fe[1]=r[t+1],fe[2]=r[t+2],fe[3]=r[t+3],Ao[0]}var So=new Float64Array([-0]),ut=new Uint8Array(So.buffer);function $a(r,t,e){So[0]=r,t[e]=ut[0],t[e+1]=ut[1],t[e+2]=ut[2],t[e+3]=ut[3],t[e+4]=ut[4],t[e+5]=ut[5],t[e+6]=ut[6],t[e+7]=ut[7]}function ja(r,t){return ut[0]=r[t],ut[1]=r[t+1],ut[2]=r[t+2],ut[3]=r[t+3],ut[4]=r[t+4],ut[5]=r[t+5],ut[6]=r[t+6],ut[7]=r[t+7],So[0]}var _f=BigInt(Number.MAX_SAFE_INTEGER),Df=BigInt(Number.MIN_SAFE_INTEGER),At=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 Ce;if(t<_f&&t>Df)return this.fromNumber(Number(t));let e=t<0n;e&&(t=-t);let n=t>>32n,s=t-(n<<32n);return e&&(n=~n|0n,s=~s|0n,++s>Ga&&(s=0n,++n>Ga&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(t){if(t===0)return Ce;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):Ce}},Ce=new At(0,0);Ce.toBigInt=function(){return 0n};Ce.zzEncode=Ce.zzDecode=function(){return this};Ce.length=function(){return 1};var Ga=4294967296n;function Za(r){let t=0,e=0;for(let n=0;n<r.length;++n)e=r.charCodeAt(n),e<128?t+=1:e<2048?t+=2:(e&64512)===55296&&(r.charCodeAt(n+1)&64512)===56320?(++n,t+=4):t+=3;return t}function Ya(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 ko(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 Lt(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function xn(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var Io=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,Lt(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 Lt(this,4);return xn(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Lt(this,4);return xn(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Lt(this,4);let t=qa(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Lt(this,4);let t=ja(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 Lt(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return Ya(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw Lt(this,t);this.pos+=t}else do if(this.pos>=this.len)throw Lt(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 At(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 Lt(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 Lt(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 Lt(this,8);let t=xn(this.buf,this.pos+=4),e=xn(this.buf,this.pos+=4);return new At(t,e)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){let t=Pa(this.buf,this.pos);return this.pos+=Rr(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 Co(r){return new Io(r instanceof Uint8Array?r:r.subarray())}function vn(r,t,e){let n=Co(r);return t.decode(n,void 0,e)}function No(r){let t=r??8192,e=t>>>1,n,s=t;return function(i){if(i<1||i>e)return Bt(i);s+i>t&&(n=Bt(t),s=0);let c=n.subarray(s,s+=i);return(s&7)!==0&&(s=(s|7)+1),c}}var Ne=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function Uo(){}var To=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},Kf=No();function Vf(r){return globalThis.Buffer!=null?Bt(r):Kf(r)}var Dr=class{len;head;tail;states;constructor(){this.len=0,this.head=new Ne(Uo,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new Ne(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new Ro((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(En,10,At.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=At.fromBigInt(t);return this._push(En,e.length(),e)}uint64Number(t){return this._push(Ma,Rr(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=At.fromBigInt(t).zzEncode();return this._push(En,e.length(),e)}sint64Number(t){let e=At.fromNumber(t).zzEncode();return this._push(En,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(Lo,1,t?1:0)}fixed32(t){return this._push(_r,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=At.fromBigInt(t);return this._push(_r,4,e.lo)._push(_r,4,e.hi)}fixed64Number(t){let e=At.fromNumber(t);return this._push(_r,4,e.lo)._push(_r,4,e.hi)}fixed64String(t){return this.fixed64(BigInt(t))}sfixed64(t){return this.fixed64(t)}sfixed64Number(t){return this.fixed64Number(t)}sfixed64String(t){return this.fixed64String(t)}float(t){return this._push(Fa,4,t)}double(t){return this._push($a,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(Lo,1,0):this.uint32(e)._push(Hf,e,t)}string(t){let e=Za(t);return e!==0?this.uint32(e)._push(ko,e,t):this._push(Lo,1,0)}fork(){return this.states=new To(this),this.head=this.tail=new Ne(Uo,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 Ne(Uo,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=Vf(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function Lo(r,t,e){t[e]=r&255}function Of(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var Ro=class extends Ne{next;constructor(t,e){super(Of,t,e),this.next=void 0}};function En(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 _r(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 Hf(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(Dr.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(Mf,t,r),this},Dr.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(Pf,t,r),this});function Mf(r,t,e){t.set(r,e)}function Pf(r,t,e){r.length<40?ko(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(F(r),e)}function _o(){return new Dr}function Bn(r,t){let e=_o();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var nr;(function(r){r[r.VARINT=0]="VARINT",r[r.BIT64=1]="BIT64",r[r.LENGTH_DELIMITED=2]="LENGTH_DELIMITED",r[r.START_GROUP=3]="START_GROUP",r[r.END_GROUP=4]="END_GROUP",r[r.BIT32=5]="BIT32"})(nr||(nr={}));function An(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function Do(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 An("enum",nr.VARINT,e,n)}function Sn(r,t){return An("message",nr.LENGTH_DELIMITED,r,t)}var et;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.secp256k1="secp256k1",r.ECDSA="ECDSA"})(et||(et={}));var Ko;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1",r[r.ECDSA=3]="ECDSA"})(Ko||(Ko={}));(function(r){r.codec=()=>Do(Ko)})(et||(et={}));var he;(function(r){let t;r.codec=()=>(t==null&&(t=Sn((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),et.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=et.codec().decode(e);break}case 2:{o.Data=e.bytes();break}default:{e.skipType(c&7);break}}}return o})),t),r.encode=e=>Bn(e,r.codec()),r.decode=(e,n)=>vn(e,r.codec(),n)})(he||(he={}));var Kr;(function(r){let t;r.codec=()=>(t==null&&(t=Sn((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),et.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=et.codec().decode(e);break}case 2:{o.Data=e.bytes();break}default:{e.skipType(c&7);break}}}return o})),t),r.encode=e=>Bn(e,r.codec()),r.decode=(e,n)=>vn(e,r.codec(),n)})(Kr||(Kr={}));function Ue(r){if(isNaN(r)||r<=0)throw new R("random bytes length must be a Number bigger than 0");return re(r)}var Or={};ft(Or,{MAX_RSA_KEY_SIZE:()=>Vo,generateRSAKeyPair:()=>tc,jwkToJWKKeyPair:()=>ec,jwkToPkcs1:()=>jf,jwkToPkix:()=>Po,jwkToRSAPrivateKey:()=>$o,pkcs1MessageToJwk:()=>Ho,pkcs1MessageToRSAPrivateKey:()=>kn,pkcs1ToJwk:()=>$f,pkcs1ToRSAPrivateKey:()=>Fo,pkixMessageToJwk:()=>Mo,pkixMessageToRSAPublicKey:()=>qo,pkixToJwk:()=>Gf,pkixToRSAPublicKey:()=>Qa});var sr=class{type="RSA";jwk;_raw;_multihash;constructor(t,e){this.jwk=t,this._multihash=e}get raw(){return this._raw==null&&(this._raw=Or.jwkToPkix(this.jwk)),this._raw}toMultihash(){return this._multihash}toCID(){return St.createV1(114,this._multihash)}toString(){return tt.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:mt(this.raw,t.raw)}verify(t,e,n){return Xa(this.jwk,e,t,n)}},Vr=class{type="RSA";jwk;_raw;publicKey;constructor(t,e){this.jwk=t,this.publicKey=e}get raw(){return this._raw==null&&(this._raw=Or.jwkToPkcs1(this.jwk)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:mt(this.raw,t.raw)}sign(t,e){return Ja(this.jwk,t,e)}};var Vo=8192,Oo=18,Ff=1062,qf=Uint8Array.from([48,13,6,9,42,134,72,134,247,13,1,1,1,5,0]);function $f(r){let t=Ct(r);return Ho(t)}function Ho(r){return{n:$(r[1],"base64url"),e:$(r[2],"base64url"),d:$(r[3],"base64url"),p:$(r[4],"base64url"),q:$(r[5],"base64url"),dp:$(r[6],"base64url"),dq:$(r[7],"base64url"),qi:$(r[8],"base64url"),kty:"RSA"}}function jf(r){if(r.n==null||r.e==null||r.d==null||r.p==null||r.q==null||r.dp==null||r.dq==null||r.qi==null)throw new R("JWK was missing components");return Nt([dt(Uint8Array.from([0])),dt(F(r.n,"base64url")),dt(F(r.e,"base64url")),dt(F(r.d,"base64url")),dt(F(r.p,"base64url")),dt(F(r.q,"base64url")),dt(F(r.dp,"base64url")),dt(F(r.dq,"base64url")),dt(F(r.qi,"base64url"))]).subarray()}function Gf(r){let t=Ct(r,{offset:0});return Mo(t)}function Mo(r){let t=Ct(r[1],{offset:0});return{kty:"RSA",n:$(t[0],"base64url"),e:$(t[1],"base64url")}}function Po(r){if(r.n==null||r.e==null)throw new R("JWK was missing components");return Nt([qf,Er(Nt([dt(F(r.n,"base64url")),dt(F(r.e,"base64url"))]))]).subarray()}function Fo(r){let t=Ct(r);return kn(t)}function kn(r){let t=Ho(r);return $o(t)}function Qa(r,t){if(r.byteLength>=Ff)throw new Ke("Key size is too large");let e=Ct(r,{offset:0});return qo(e,r,t)}function qo(r,t,e){let n=Mo(r);if(e==null){let s=ie(he.encode({Type:et.RSA,Data:t}));e=_t(Oo,s)}return new sr(n,e)}function $o(r){if(nc(r)>Vo)throw new R("Key size is too large");let t=ec(r),e=ie(he.encode({Type:et.RSA,Data:Po(t.publicKey)})),n=_t(Oo,e);return new Vr(t.privateKey,new sr(t.publicKey,n))}async function tc(r){if(r>Vo)throw new R("Key size is too large");let t=await rc(r),e=ie(he.encode({Type:et.RSA,Data:Po(t.publicKey)})),n=_t(Oo,e);return new Vr(t.privateKey,new sr(t.publicKey,n))}function ec(r){if(r==null)throw new R("Missing key parameter");return{privateKey:r,publicKey:{kty:r.kty,n:r.n,e:r.e}}}async function rc(r,t){let e=await Q.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 Zf(e,t);return{privateKey:n[0],publicKey:n[1]}}async function Ja(r,t,e){let n=await Q.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]);e?.signal?.throwIfAborted();let s=await Q.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 Xa(r,t,e,n){let s=await Q.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);n?.signal?.throwIfAborted();let o=await Q.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},s,t,e instanceof Uint8Array?e:e.subarray());return n?.signal?.throwIfAborted(),o}async function Zf(r,t){if(r.privateKey==null||r.publicKey==null)throw new R("Private and public key are required");let e=await Promise.all([Q.get().subtle.exportKey("jwk",r.privateKey),Q.get().subtle.exportKey("jwk",r.publicKey)]);return t?.signal?.throwIfAborted(),e}function nc(r){if(r.kty!=="RSA")throw new R("invalid key type");if(r.n==null)throw new R("invalid key modulus");return F(r.n,"base64url").length*8}var In=class{oHash;iHash;blockLen;outputLen;finished=!1;destroyed=!1;constructor(t,e){if(Ze(t),O(e,void 0,"key"),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 n=this.blockLen,s=new Uint8Array(n);s.set(e.length>n?t.create().update(e).digest():e);for(let o=0;o<s.length;o++)s[o]^=54;this.iHash.update(s),this.oHash=t.create();for(let o=0;o<s.length;o++)s[o]^=106;this.oHash.update(s),wt(s)}update(t){return Ye(this),this.iHash.update(t),this}digestInto(t){Ye(this),O(t,this.outputLen,"output"),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||=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()}},Hr=(r,t,e)=>new In(r,t).update(e).digest();Hr.create=(r,t)=>new In(r,t);var sc=(r,t)=>(r+(r>=0?t:-t)/oc)/t;function Yf(r,t,e){let[[n,s],[o,i]]=t,c=sc(i*r,e),a=sc(-s*r,e),l=r-c*n-a*o,f=-c*s-a*i,u=l<Gt,d=f<Gt;u&&(l=-l),d&&(f=-f);let y=Cr(Math.ceil(lo(e)/2))+or;if(l<Gt||l>=y||f<Gt||f>=y)throw new Error("splitScalar (endomorphism): failed, k="+r);return{k1neg:u,k1:l,k2neg:d,k2:f}}function Go(r){if(!["compact","recovered","der"].includes(r))throw new Error('Signature format must be "compact", "recovered", or "der"');return r}function jo(r,t){let e={};for(let n of Object.keys(t))e[n]=r[n]===void 0?t[n]:r[n];return jt(e.lowS,"lowS"),jt(e.prehash,"prehash"),e.format!==void 0&&Go(e.format),e}var Zo=class extends Error{constructor(t=""){super(t)}},de={Err:Zo,_tlv:{encode:(r,t)=>{let{Err:e}=de;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=kr(n);if(s.length/2&128)throw new e("tlv.encode: long form length too big");let o=n>127?kr(s.length/2|128):"";return kr(r)+o+s+t},decode(r,t){let{Err:e}=de,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 l=t.subarray(n,n+a);if(l.length!==a)throw new e("tlv.decode: length bytes not complete");if(l[0]===0)throw new e("tlv.decode(long): zero leftmost byte");for(let f of l)i=i<<8|f;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}=de;if(r<Gt)throw new t("integer: negative integers are not allowed");let e=kr(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}=de;if(r[0]&128)throw new t("invalid signature integer: negative");if(r[0]===0&&!(r[1]&128))throw new t("invalid signature integer: unnecessary leading zero");return ze(r)}},toSig(r){let{Err:t,_int:e,_tlv:n}=de,s=O(r,void 0,"signature"),{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:l,l:f}=n.decode(2,a);if(f.length)throw new t("invalid signature: left bytes after parsing");return{r:e.decode(c),s:e.decode(l)}},hexFromSig(r){let{_tlv:t,_int:e}=de,n=t.encode(2,e.encode(r.r)),s=t.encode(2,e.encode(r.s)),o=n+s;return t.encode(48,o)}},Gt=BigInt(0),or=BigInt(1),oc=BigInt(2),Cn=BigInt(3),zf=BigInt(4);function ic(r,t={}){let e=mn("weierstrass",r,t),{Fp:n,Fn:s}=e,o=e.CURVE,{h:i,n:c}=o;ce(t,{},{allowInfinityPoint:"boolean",clearCofactor:"function",isTorsionFree:"function",fromBytes:"function",toBytes:"function",endo:"object"});let{endo:a}=t;if(a&&(!n.is0(o.a)||typeof a.beta!="bigint"||!Array.isArray(a.basises)))throw new Error('invalid endo: expected "beta": bigint and "basises": array');let l=cc(n,s);function f(){if(!n.isOdd)throw new Error("compression is not supported: Field does not have .isOdd()")}function u(L,m,b){let{x:p,y:S}=m.toAffine(),C=n.toBytes(p);if(jt(b,"isCompressed"),b){f();let U=!n.isOdd(S);return xt(ac(U),C)}else return xt(Uint8Array.of(4),C,n.toBytes(S))}function d(L){O(L,void 0,"Point");let{publicKey:m,publicKeyUncompressed:b}=l,p=L.length,S=L[0],C=L.subarray(1);if(p===m&&(S===2||S===3)){let U=n.fromBytes(C);if(!n.isValid(U))throw new Error("bad point: is not on curve, wrong x");let T=B(U),N;try{N=n.sqrt(T)}catch(Y){let G=Y instanceof Error?": "+Y.message:"";throw new Error("bad point: is not on curve, sqrt error"+G)}f();let _=n.isOdd(N);return(S&1)===1!==_&&(N=n.neg(N)),{x:U,y:N}}else if(p===b&&S===4){let U=n.BYTES,T=n.fromBytes(C.subarray(0,U)),N=n.fromBytes(C.subarray(U,U*2));if(!v(T,N))throw new Error("bad point: is not on curve");return{x:T,y:N}}else throw new Error(`bad point: got length ${p}, expected compressed=${m} or uncompressed=${b}`)}let y=t.toBytes||u,h=t.fromBytes||d;function B(L){let m=n.sqr(L),b=n.mul(m,L);return n.add(n.add(b,n.mul(L,o.a)),o.b)}function v(L,m){let b=n.sqr(m),p=B(L);return n.eql(b,p)}if(!v(o.Gx,o.Gy))throw new Error("bad curve params: generator point");let g=n.mul(n.pow(o.a,Cn),zf),A=n.mul(n.sqr(o.b),BigInt(27));if(n.is0(n.add(g,A)))throw new Error("bad curve params: a or b");function w(L,m,b=!1){if(!n.isValid(m)||b&&n.is0(m))throw new Error(`bad point coordinate ${L}`);return m}function I(L){if(!(L instanceof x))throw new Error("Weierstrass Point expected")}function D(L){if(!a||!a.basises)throw new Error("no endo");return Yf(L,a.basises,s.ORDER)}let H=We((L,m)=>{let{X:b,Y:p,Z:S}=L;if(n.eql(S,n.ONE))return{x:b,y:p};let C=L.is0();m==null&&(m=C?n.ONE:n.inv(S));let U=n.mul(b,m),T=n.mul(p,m),N=n.mul(S,m);if(C)return{x:n.ZERO,y:n.ZERO};if(!n.eql(N,n.ONE))throw new Error("invZ was invalid");return{x:U,y:T}}),M=We(L=>{if(L.is0()){if(t.allowInfinityPoint&&!n.is0(L.Y))return;throw new Error("bad point: ZERO")}let{x:m,y:b}=L.toAffine();if(!n.isValid(m)||!n.isValid(b))throw new Error("bad point: x or y not field elements");if(!v(m,b))throw new Error("bad point: equation left != right");if(!L.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});function E(L,m,b,p,S){return b=new x(n.mul(b.X,L),b.Y,b.Z),m=Ur(p,m),b=Ur(S,b),m.add(b)}class x{static BASE=new x(o.Gx,o.Gy,n.ONE);static ZERO=new x(n.ZERO,n.ONE,n.ZERO);static Fp=n;static Fn=s;X;Y;Z;constructor(m,b,p){this.X=w("x",m),this.Y=w("y",b,!0),this.Z=w("z",p),Object.freeze(this)}static CURVE(){return o}static fromAffine(m){let{x:b,y:p}=m||{};if(!m||!n.isValid(b)||!n.isValid(p))throw new Error("invalid affine point");if(m instanceof x)throw new Error("projective point not allowed");return n.is0(b)&&n.is0(p)?x.ZERO:new x(b,p,n.ONE)}static fromBytes(m){let b=x.fromAffine(h(O(m,void 0,"point")));return b.assertValidity(),b}static fromHex(m){return x.fromBytes(qt(m))}get x(){return this.toAffine().x}get y(){return this.toAffine().y}precompute(m=8,b=!0){return P.createCache(this,m),b||this.multiply(Cn),this}assertValidity(){M(this)}hasEvenY(){let{y:m}=this.toAffine();if(!n.isOdd)throw new Error("Field doesn't support isOdd");return!n.isOdd(m)}equals(m){I(m);let{X:b,Y:p,Z:S}=this,{X:C,Y:U,Z:T}=m,N=n.eql(n.mul(b,T),n.mul(C,S)),_=n.eql(n.mul(p,T),n.mul(U,S));return N&&_}negate(){return new x(this.X,n.neg(this.Y),this.Z)}double(){let{a:m,b}=o,p=n.mul(b,Cn),{X:S,Y:C,Z:U}=this,T=n.ZERO,N=n.ZERO,_=n.ZERO,V=n.mul(S,S),Y=n.mul(C,C),G=n.mul(U,U),j=n.mul(S,C);return j=n.add(j,j),_=n.mul(S,U),_=n.add(_,_),T=n.mul(m,_),N=n.mul(p,G),N=n.add(T,N),T=n.sub(Y,N),N=n.add(Y,N),N=n.mul(T,N),T=n.mul(j,T),_=n.mul(p,_),G=n.mul(m,G),j=n.sub(V,G),j=n.mul(m,j),j=n.add(j,_),_=n.add(V,V),V=n.add(_,V),V=n.add(V,G),V=n.mul(V,j),N=n.add(N,V),G=n.mul(C,U),G=n.add(G,G),V=n.mul(G,j),T=n.sub(T,V),_=n.mul(G,Y),_=n.add(_,_),_=n.add(_,_),new x(T,N,_)}add(m){I(m);let{X:b,Y:p,Z:S}=this,{X:C,Y:U,Z:T}=m,N=n.ZERO,_=n.ZERO,V=n.ZERO,Y=o.a,G=n.mul(o.b,Cn),j=n.mul(b,C),z=n.mul(p,U),st=n.mul(S,T),Rt=n.add(b,p),W=n.add(C,U);Rt=n.mul(Rt,W),W=n.add(j,z),Rt=n.sub(Rt,W),W=n.add(b,S);let ct=n.add(C,T);return W=n.mul(W,ct),ct=n.add(j,st),W=n.sub(W,ct),ct=n.add(p,S),N=n.add(U,T),ct=n.mul(ct,N),N=n.add(z,st),ct=n.sub(ct,N),V=n.mul(Y,W),N=n.mul(G,st),V=n.add(N,V),N=n.sub(z,V),V=n.add(z,V),_=n.mul(N,V),z=n.add(j,j),z=n.add(z,j),st=n.mul(Y,st),W=n.mul(G,W),z=n.add(z,st),st=n.sub(j,st),st=n.mul(Y,st),W=n.add(W,st),j=n.mul(z,W),_=n.add(_,j),j=n.mul(ct,W),N=n.mul(Rt,N),N=n.sub(N,j),j=n.mul(Rt,z),V=n.mul(ct,V),V=n.add(V,j),new x(N,_,V)}subtract(m){return this.add(m.negate())}is0(){return this.equals(x.ZERO)}multiply(m){let{endo:b}=t;if(!s.isValidNot0(m))throw new Error("invalid scalar: out of range");let p,S,C=U=>P.cached(this,U,T=>Ie(x,T));if(b){let{k1neg:U,k1:T,k2neg:N,k2:_}=D(m),{p:V,f:Y}=C(T),{p:G,f:j}=C(_);S=Y.add(j),p=E(b.beta,V,G,U,N)}else{let{p:U,f:T}=C(m);p=U,S=T}return Ie(x,[p,S])[0]}multiplyUnsafe(m){let{endo:b}=t,p=this;if(!s.isValid(m))throw new Error("invalid scalar: out of range");if(m===Gt||p.is0())return x.ZERO;if(m===or)return p;if(P.hasCache(this))return this.multiply(m);if(b){let{k1neg:S,k1:C,k2neg:U,k2:T}=D(m),{p1:N,p2:_}=Ia(x,p,C,T);return E(b.beta,N,_,S,U)}else return P.unsafe(p,m)}toAffine(m){return H(this,m)}isTorsionFree(){let{isTorsionFree:m}=t;return i===or?!0:m?m(x,this):P.unsafe(this,c).is0()}clearCofactor(){let{clearCofactor:m}=t;return i===or?this:m?m(x,this):this.multiplyUnsafe(i)}isSmallOrder(){return this.multiplyUnsafe(i).is0()}toBytes(m=!0){return jt(m,"isCompressed"),this.assertValidity(),y(x,this,m)}toHex(m=!0){return Ft(this.toBytes(m))}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}}let K=s.BITS,P=new Qe(x,t.endo?Math.ceil(K/2):K);return x.BASE.precompute(8),x}function ac(r){return Uint8Array.of(r?2:3)}function cc(r,t){return{secretKey:t.BYTES,publicKey:1+r.BYTES,publicKeyUncompressed:1+2*r.BYTES,publicKeyHasPrefix:!0,signature:2*t.BYTES}}function Wf(r,t={}){let{Fn:e}=r,n=t.randomBytes||re,s=Object.assign(cc(r.Fp,e),{seed:go(e.ORDER)});function o(y){try{let h=e.fromBytes(y);return e.isValidNot0(h)}catch{return!1}}function i(y,h){let{publicKey:B,publicKeyUncompressed:v}=s;try{let g=y.length;return h===!0&&g!==B||h===!1&&g!==v?!1:!!r.fromBytes(y)}catch{return!1}}function c(y=n(s.seed)){return yo(O(y,s.seed,"seed"),e.ORDER)}function a(y,h=!0){return r.BASE.multiply(e.fromBytes(y)).toBytes(h)}function l(y){let{secretKey:h,publicKey:B,publicKeyUncompressed:v}=s;if(!we(y)||"_lengths"in e&&e._lengths||h===B)return;let g=O(y,void 0,"key").length;return g===B||g===v}function f(y,h,B=!0){if(l(y)===!0)throw new Error("first arg must be private key");if(l(h)===!1)throw new Error("second arg must be public key");let v=e.fromBytes(y);return r.fromBytes(h).multiply(v).toBytes(B)}let u={isValidSecretKey:o,isValidPublicKey:i,randomSecretKey:c},d=bn(c,a);return Object.freeze({getPublicKey:a,getSharedSecret:f,keygen:d,Point:r,utils:u,lengths:s})}function uc(r,t,e={}){Ze(t),ce(e,{},{hmac:"function",lowS:"boolean",randomBytes:"function",bits2int:"function",bits2int_modN:"function"}),e=Object.assign({},e);let n=e.randomBytes||re,s=e.hmac||((b,p)=>Hr(t,b,p)),{Fp:o,Fn:i}=r,{ORDER:c,BITS:a}=i,{keygen:l,getPublicKey:f,getSharedSecret:u,utils:d,lengths:y}=Wf(r,e),h={prehash:!0,lowS:typeof e.lowS=="boolean"?e.lowS:!0,format:"compact",extraEntropy:!1},B=c*oc<o.ORDER;function v(b){let p=c>>or;return b>p}function g(b,p){if(!i.isValidNot0(p))throw new Error(`invalid signature ${b}: out of range 1..Point.Fn.ORDER`);return p}function A(){if(B)throw new Error('"recovered" sig type is not supported for cofactor >2 curves')}function w(b,p){Go(p);let S=y.signature,C=p==="compact"?S:p==="recovered"?S+1:void 0;return O(b,C)}class I{r;s;recovery;constructor(p,S,C){if(this.r=g("r",p),this.s=g("s",S),C!=null){if(A(),![0,1,2,3].includes(C))throw new Error("invalid recovery id");this.recovery=C}Object.freeze(this)}static fromBytes(p,S=h.format){w(p,S);let C;if(S==="der"){let{r:_,s:V}=de.toSig(O(p));return new I(_,V)}S==="recovered"&&(C=p[0],S="compact",p=p.subarray(1));let U=y.signature/2,T=p.subarray(0,U),N=p.subarray(U,U*2);return new I(i.fromBytes(T),i.fromBytes(N),C)}static fromHex(p,S){return this.fromBytes(qt(p),S)}assertRecovery(){let{recovery:p}=this;if(p==null)throw new Error("invalid recovery id: must be present");return p}addRecoveryBit(p){return new I(this.r,this.s,p)}recoverPublicKey(p){let{r:S,s:C}=this,U=this.assertRecovery(),T=U===2||U===3?S+c:S;if(!o.isValid(T))throw new Error("invalid recovery id: sig.r+curve.n != R.x");let N=o.toBytes(T),_=r.fromBytes(xt(ac((U&1)===0),N)),V=i.inv(T),Y=H(O(p,void 0,"msgHash")),G=i.create(-Y*V),j=i.create(C*V),z=r.BASE.multiplyUnsafe(G).add(_.multiplyUnsafe(j));if(z.is0())throw new Error("invalid recovery: point at infinify");return z.assertValidity(),z}hasHighS(){return v(this.s)}toBytes(p=h.format){if(Go(p),p==="der")return qt(de.hexFromSig(this));let{r:S,s:C}=this,U=i.toBytes(S),T=i.toBytes(C);return p==="recovered"?(A(),xt(Uint8Array.of(this.assertRecovery()),U,T)):xt(U,T)}toHex(p){return Ft(this.toBytes(p))}}let D=e.bits2int||function(p){if(p.length>8192)throw new Error("input is too large");let S=ze(p),C=p.length*8-a;return C>0?S>>BigInt(C):S},H=e.bits2int_modN||function(p){return i.create(D(p))},M=Cr(a);function E(b){return Ir("num < 2^"+a,b,Gt,M),i.toBytes(b)}function x(b,p){return O(b,void 0,"message"),p?O(t(b),void 0,"prehashed message"):b}function K(b,p,S){let{lowS:C,prehash:U,extraEntropy:T}=jo(S,h);b=x(b,U);let N=H(b),_=i.fromBytes(p);if(!i.isValidNot0(_))throw new Error("invalid private key");let V=[E(_),E(N)];if(T!=null&&T!==!1){let z=T===!0?n(y.secretKey):T;V.push(O(z,void 0,"extraEntropy"))}let Y=xt(...V),G=N;function j(z){let st=D(z);if(!i.isValidNot0(st))return;let Rt=i.inv(st),W=r.BASE.multiply(st).toAffine(),ct=i.create(W.x);if(ct===Gt)return;let tn=i.create(Rt*i.create(G+ct*_));if(tn===Gt)return;let ai=(W.x===ct?0:2)|Number(W.y&or),ci=tn;return C&&v(tn)&&(ci=i.neg(tn),ai^=1),new I(ct,ci,B?void 0:ai)}return{seed:Y,k2sig:j}}function P(b,p,S={}){let{seed:C,k2sig:U}=K(b,p,S);return la(t.outputLen,i.BYTES,s)(C,U).toBytes(S.format)}function L(b,p,S,C={}){let{lowS:U,prehash:T,format:N}=jo(C,h);if(S=O(S,void 0,"publicKey"),p=x(p,T),!we(b)){let _=b instanceof I?", use sig.toBytes()":"";throw new Error("verify expects Uint8Array signature"+_)}w(b,N);try{let _=I.fromBytes(b,N),V=r.fromBytes(S);if(U&&_.hasHighS())return!1;let{r:Y,s:G}=_,j=H(p),z=i.inv(G),st=i.create(j*z),Rt=i.create(Y*z),W=r.BASE.multiplyUnsafe(st).add(V.multiplyUnsafe(Rt));return W.is0()?!1:i.create(W.x)===Y}catch{return!1}}function m(b,p,S={}){let{prehash:C}=jo(S,h);return p=x(p,C),I.fromBytes(b,"recovered").recoverPublicKey(p).toBytes()}return Object.freeze({keygen:l,getPublicKey:f,getSharedSecret:u,utils:d,lengths:y,Point:r,sign:P,verify:L,recoverPublicKey:m,Signature:I,hash:t})}var zo={p:BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),n:BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),h:BigInt(1),a:BigInt(0),b:BigInt(7),Gx:BigInt("0x79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798"),Gy:BigInt("0x483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8")},Jf={beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),basises:[[BigInt("0x3086d221a7d46bcde86c90e49284eb15"),-BigInt("0xe4437ed6010e88286f547fa90abfe4c3")],[BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),BigInt("0x3086d221a7d46bcde86c90e49284eb15")]]};var lc=BigInt(2);function Xf(r){let t=zo.p,e=BigInt(3),n=BigInt(6),s=BigInt(11),o=BigInt(22),i=BigInt(23),c=BigInt(44),a=BigInt(88),l=r*r*r%t,f=l*l*r%t,u=Z(f,e,t)*f%t,d=Z(u,e,t)*f%t,y=Z(d,lc,t)*l%t,h=Z(y,s,t)*y%t,B=Z(h,o,t)*h%t,v=Z(B,c,t)*B%t,g=Z(v,a,t)*v%t,A=Z(g,c,t)*B%t,w=Z(A,e,t)*f%t,I=Z(w,i,t)*h%t,D=Z(I,n,t)*l%t,H=Z(D,lc,t);if(!Yo.eql(Yo.sqr(H),r))throw new Error("Cannot find square root");return H}var Yo=Je(zo.p,{sqrt:Xf}),Qf=ic(zo,{Fp:Yo,endo:Jf}),Kt=uc(Qf,ie);var fc=32;function hc(r,t,e){let n=$e.digest(t instanceof Uint8Array?t:t.subarray());if(rr(n))return n.then(({digest:s})=>(e?.signal?.throwIfAborted(),Kt.sign(s,r,{prehash:!1,format:"der"}))).catch(s=>{throw s.name==="AbortError"?s:new hr(String(s))});try{return Kt.sign(n.digest,r,{prehash:!1,format:"der"})}catch(s){throw new hr(String(s))}}function dc(r,t,e,n){let s=$e.digest(e instanceof Uint8Array?e:e.subarray());if(rr(s))return s.then(({digest:o})=>(n?.signal?.throwIfAborted(),Kt.verify(t,o,r,{prehash:!1,format:"der"}))).catch(o=>{throw o.name==="AbortError"?o:new dr(String(o))});try{return n?.signal?.throwIfAborted(),Kt.verify(t,s.digest,r,{prehash:!1,format:"der"})}catch(o){throw new dr(String(o))}}var Nn=class{type="secp256k1";raw;_key;constructor(t){this._key=yc(t),this.raw=pc(this._key)}toMultihash(){return me.digest(Ge(this))}toCID(){return St.createV1(114,this.toMultihash())}toString(){return tt.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:mt(this.raw,t.raw)}verify(t,e,n){return dc(this._key,e,t,n)}},Un=class{type="secp256k1";raw;publicKey;constructor(t,e){this.raw=gc(t),this.publicKey=new Nn(e??mc(t))}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:mt(this.raw,t.raw)}sign(t,e){return hc(this.raw,t,e)}};function Wo(r){return new Un(r)}function pc(r){return Kt.Point.fromBytes(r).toBytes()}function gc(r){try{return Kt.getPublicKey(r,!0),r}catch(t){throw new pr(String(t))}}function yc(r){try{return Kt.Point.fromBytes(r),r}catch(t){throw new Ke(String(t))}}function mc(r){try{return Kt.getPublicKey(r,!0)}catch(t){throw new pr(String(t))}}function Ge(r){return he.encode({Type:et[r.type],Data:r.raw})}function bc(r){let t=Kr.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case et.RSA:return Fo(e);case et.Ed25519:return Bo(e);case et.secp256k1:return Wo(e);case et.ECDSA:return $i(e);default:throw new Ve}}function wc(r){if(r.byteLength===kt)return Bo(r);if(r.byteLength===fc)return Wo(r);let t=Ct(r),e=t[2]?.[0];if(e===Hi||e===Mi||e===Pi)return Xs(t);if(t.length>8)return kn(t);throw new R("Could not extract private key from raw bytes")}function Le(r){return Kr.encode({Type:et[r.type],Data:r.raw})}var Mr=Uint32Array.from([1732584193,4023233417,2562383102,271733878,3285377520]),pe=new Uint32Array(80),Jo=class extends ve{A=Mr[0]|0;B=Mr[1]|0;C=Mr[2]|0;D=Mr[3]|0;E=Mr[4]|0;constructor(){super(64,20,8,!1)}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)pe[a]=t.getUint32(e,!1);for(let a=16;a<80;a++)pe[a]=ln(pe[a-3]^pe[a-8]^pe[a-14]^pe[a-16],1);let{A:n,B:s,C:o,D:i,E:c}=this;for(let a=0;a<80;a++){let l,f;a<20?(l=fn(s,o,i),f=1518500249):a<40?(l=s^o^i,f=1859775393):a<60?(l=hn(s,o,i),f=2400959708):(l=s^o^i,f=3395469782);let u=ln(n,5)+l+c+f+pe[a]|0;c=i,i=o,o=ln(s,30),s=n,n=u}n=n+this.A|0,s=s+this.B|0,o=o+this.C|0,i=i+this.D|0,c=c+this.E|0,this.set(n,s,o,i,c)}roundClean(){wt(pe)}destroy(){this.set(0,0,0,0,0),wt(this.buffer)}},xc=Br(()=>new Jo);function vc(r,t,e,n){Ze(r);let s=Xi({dkLen:32,asyncTick:10},n),{c:o,dkLen:i,asyncTick:c}=s;if(bt(o,"c"),bt(i,"dkLen"),bt(c,"asyncTick"),o<1)throw new Error("iterations (c) must be >= 1");let a=Qs(t,"password"),l=Qs(e,"salt"),f=new Uint8Array(i),u=Hr.create(r,a),d=u._cloneInto().update(l);return{c:o,dkLen:i,asyncTick:c,DK:f,PRF:u,PRFSalt:d}}function Ec(r,t,e,n,s){return r.destroy(),t.destroy(),n&&n.destroy(),wt(s),e}function Bc(r,t,e,n){let{c:s,dkLen:o,DK:i,PRF:c,PRFSalt:a}=vc(r,t,e,n),l,f=new Uint8Array(4),u=xe(f),d=new Uint8Array(c.outputLen);for(let y=1,h=0;h<o;y++,h+=c.outputLen){let B=i.subarray(h,h+c.outputLen);u.setInt32(0,y,!1),(l=a._cloneInto(l)).update(f).digestInto(d),B.set(d.subarray(0,B.length));for(let v=1;v<s;v++){c._cloneInto(l).update(d).digestInto(d);for(let g=0;g<B.length;g++)B[g]^=d[g]}}return Ec(c,a,i,l,d)}async function Ln(r,t,e,n){let{c:s,dkLen:o,asyncTick:i,DK:c,PRF:a,PRFSalt:l}=vc(r,t,e,n),f,u=new Uint8Array(4),d=xe(u),y=new Uint8Array(a.outputLen);for(let h=1,B=0;B<o;h++,B+=a.outputLen){let v=c.subarray(B,B+a.outputLen);d.setInt32(0,h,!1),(f=l._cloneInto(f)).update(u).digestInto(y),v.set(y.subarray(0,v.length)),await Ji(s-1,i,()=>{a._cloneInto(f).update(y).digestInto(y);for(let g=0;g<v.length;g++)v[g]^=y[g]})}return Ec(a,l,c,f,y)}var Ac={sha1:xc,"sha2-256":ie,"sha2-512":ae};function Pr(r,t,e,n,s){if(s!=="sha1"&&s!=="sha2-256"&&s!=="sha2-512"){let c=Object.keys(Ac).join(" / ");throw new R(`Hash '${s}' is unknown or not supported. Must be ${c}`)}let o=Ac[s],i=Bc(o,r,t,{c:e,dkLen:n});return be.encode(i).substring(1)}var Zt="/",Sc=new TextEncoder().encode(Zt),Tn=Sc[0],Fr=class r{_buf;constructor(t,e){if(typeof t=="string")this._buf=F(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]!==Tn)throw new Error("Invalid key")}toString(t="utf8"){return $(this._buf,t)}uint8Array(){return this._buf}get[Symbol.toStringTag](){return`Key(${this.toString()})`}static withNamespaces(t){return new r(t.join(Zt))}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=Sc),this._buf[0]!==Tn){let t=new Uint8Array(this._buf.byteLength+1);t.fill(Tn,0,1),t.set(this._buf,1),this._buf=t}for(;this._buf.byteLength>1&&this._buf[this._buf.byteLength-1]===Tn;)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(Zt).slice(1)}type(){return th(this.baseNamespace())}name(){return eh(this.baseNamespace())}instance(t){return new r(this.toString()+":"+t)}path(){let t=this.parent().toString();return t.endsWith(Zt)||(t+=Zt),t+=this.type(),new r(t)}parent(){let t=this.list();return t.length===1?new r(Zt):new r(t.slice(0,-1).join(Zt))}child(t){return this.toString()===Zt?t:t.toString()===Zt?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(),...rh(t.map(e=>e.namespaces()))])}};function th(r){let t=r.split(":");return t.length<2?"":t.slice(0,-1).join(":")}function eh(r){let t=r.split(":");return t[t.length-1]}function rh(r){return[].concat(...r)}var Au=li(_c(),1);var Xo={keyLength:64,iterationCount:1e4,salt:"you should override this value with a crypto secure random number",hash:"sha2-512"};var ir={};ft(ir,{create:()=>gh,derivedEmptyPasswordKey:()=>Rn});var Rn={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function gh(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=Q.get();e*=8;async function a(u,d){let y=c.getRandomValues(new Uint8Array(o)),h=c.getRandomValues(new Uint8Array(n)),B={name:t,iv:h};typeof d=="string"&&(d=F(d));let v;if(d.length===0){v=await c.subtle.importKey("jwk",Rn,{name:"AES-GCM"},!0,["encrypt"]);try{let A={name:"PBKDF2",salt:y,iterations:i,hash:{name:s}},w=await c.subtle.importKey("raw",d,{name:"PBKDF2"},!1,["deriveKey"]);v=await c.subtle.deriveKey(A,w,{name:t,length:e},!0,["encrypt"])}catch{v=await c.subtle.importKey("jwk",Rn,{name:"AES-GCM"},!0,["encrypt"])}}else{let A={name:"PBKDF2",salt:y,iterations:i,hash:{name:s}},w=await c.subtle.importKey("raw",d,{name:"PBKDF2"},!1,["deriveKey"]);v=await c.subtle.deriveKey(A,w,{name:t,length:e},!0,["encrypt"])}let g=await c.subtle.encrypt(B,v,u);return qe([y,B.iv,new Uint8Array(g)])}async function l(u,d){let y=u.subarray(0,o),h=u.subarray(o,o+n),B=u.subarray(o+n),v={name:t,iv:h};typeof d=="string"&&(d=F(d));let g;if(d.length===0)try{let w={name:"PBKDF2",salt:y,iterations:i,hash:{name:s}},I=await c.subtle.importKey("raw",d,{name:"PBKDF2"},!1,["deriveKey"]);g=await c.subtle.deriveKey(w,I,{name:t,length:e},!0,["decrypt"])}catch{g=await c.subtle.importKey("jwk",Rn,{name:"AES-GCM"},!0,["decrypt"])}else{let w={name:"PBKDF2",salt:y,iterations:i,hash:{name:s}},I=await c.subtle.importKey("raw",d,{name:"PBKDF2"},!1,["deriveKey"]);g=await c.subtle.deriveKey(w,I,{name:t,length:e},!0,["decrypt"])}let A=await c.subtle.decrypt(v,g,B);return new Uint8Array(A)}return{encrypt:a,decrypt:l}}var q=li(Dc());function Te(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 ge(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 l=new Uint8Array(a);for(let f=c-1;f>=0;f--){let u=Math.pow(2,f*t);l[o-f-1]=Math.floor(s/u),s-=l[o-f-1]*u}return a}i*=Math.pow(2,t)}return new ArrayBuffer(0)}function Kn(...r){let t=0,e=0;for(let o of r)t+=o.length;let n=new ArrayBuffer(t),s=new Uint8Array(n);for(let o of r)s.set(o,e),e+=o.length;return s}function ti(){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=Te(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,Te(o,8)-n}function Kc(r){let t=r<0?r*-1:r,e=128;for(let n=1;n<8;n++){if(t<=e){if(r<0){let i=e-t,c=ge(i,8,n),a=new Uint8Array(c);return a[0]|=128,c}let s=ge(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 Vc(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 vt(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 rm=Math.log(2);function Vn(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function ei(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 Qt(r,t,e,n){return t instanceof Uint8Array?t.byteLength?e<0?(r.error="Wrong parameter: inputOffset less than zero",!1):n<0?(r.error="Wrong parameter: inputLength less than zero",!1):t.byteLength-e-n<0?(r.error="End of input reached before message was fully decoded (inconsistent offset and length values)",!1):!0:(r.error="Wrong parameter: inputBuffer has zero length",!1):(r.error="Wrong parameter: inputBuffer must be 'Uint8Array'",!1)}var jr=class{constructor(){this.items=[]}write(t){this.items.push(t)}final(){return ei(this.items)}},qr=[new Uint8Array([1])],Oc="0123456789";var cr="",Tt=new ArrayBuffer(0),ri=new Uint8Array(0),Gr="EndOfContent",Mc="OCTET STRING",Pc="BIT STRING";function te(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):ri}fromBER(n,s,o){let i=n instanceof ArrayBuffer?new Uint8Array(n):n;if(!Qt(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",Tt)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:q.Convert.ToHex(this.valueHexView)}}},t.NAME="hexBlock",t}var zt=class{static blockName(){return this.NAME}get valueBeforeDecode(){return this.valueBeforeDecodeView.slice().buffer}set valueBeforeDecode(t){this.valueBeforeDecodeView=new Uint8Array(t)}constructor({blockLength:t=0,error:e=cr,warnings:n=[],valueBeforeDecode:s=ri}={}){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)}}};zt.NAME="baseBlock";var lt=class extends zt{fromBER(t,e,n){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}toBER(t,e){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}};lt.NAME="valueBlock";var On=class extends te(zt){constructor({idBlock:t={}}={}){var e,n,s,o;super(),t?(this.isHexOnly=(e=t.isHexOnly)!==null&&e!==void 0?e:!1,this.valueHexView=t.valueHex?q.BufferSourceConverter.toUint8Array(t.valueHex):ri,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",Tt}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=ge(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(!Qt(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,l=this.valueHexView=new Uint8Array(255),f=255;for(;o[a]&128;){if(l[a-1]=o[a]&127,a++,a>=o.length)return this.error="End of input reached before message was fully decoded",-1;if(a===f){f+=255;let d=new Uint8Array(f);for(let y=0;y<l.length;y++)d[y]=l[y];l=this.valueHexView=new Uint8Array(f)}}this.blockLength=a+1,l[a-1]=o[a]&127;let u=new Uint8Array(a);for(let d=0;d<a;d++)u[d]=l[d];l=this.valueHexView=new Uint8Array(a),l.set(u),this.blockLength<=9?this.tagNumber=Te(l,7):(this.isHexOnly=!0,this.warnings.push("Tag too long, represented as hex-coded"))}if(this.tagClass===1&&this.isConstructed)switch(this.tagNumber){case 1:case 2:case 5:case 6:case 9:case 13:case 14:case 23:case 24:case 31:case 32:case 33:case 34:return this.error="Constructed encoding used for primitive type",-1}return e+this.blockLength}toJSON(){return{...super.toJSON(),tagClass:this.tagClass,tagNumber:this.tagNumber,isConstructed:this.isConstructed}}};On.NAME="identificationBlock";var Hn=class extends zt{constructor({lenBlock:t={}}={}){var e,n,s;super(),this.isIndefiniteForm=(e=t.isIndefiniteForm)!==null&&e!==void 0?e:!1,this.longFormUsed=(n=t.longFormUsed)!==null&&n!==void 0?n:!1,this.length=(s=t.length)!==null&&s!==void 0?s:0}fromBER(t,e,n){let s=q.BufferSourceConverter.toUint8Array(t);if(!Qt(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=Te(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=ge(this.length,8);if(s.byteLength>127)return this.error="Too big length",Tt;if(e=new ArrayBuffer(s.byteLength+1),t)return e;let o=new Uint8Array(s);n=new Uint8Array(e),n[0]=s.byteLength|128;for(let i=0;i<s.byteLength;i++)n[i+1]=o[i];return e}return e=new ArrayBuffer(1),t===!1&&(n=new Uint8Array(e),n[0]=this.length),e}toJSON(){return{...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,longFormUsed:this.longFormUsed,length:this.length}}};Hn.NAME="lengthBlock";var k={},it=class extends zt{constructor({name:t=cr,optional:e=!1,primitiveSchema:n,...s}={},o){super(s),this.name=t,this.optional=e,n&&(this.primitiveSchema=n),this.idBlock=new On(s),this.lenBlock=new Hn(s),this.valueBlock=o?new o(s):new lt(s)}fromBER(t,e,n){let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}toBER(t,e){let n=e||new jr;e||Fc(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?Tt: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 Vc(e,n)}};it.NAME="BaseBlock";function Fc(r){var t;if(r instanceof k.Constructed)for(let e of r.valueBlock.value)Fc(e)&&(r.lenBlock.isIndefiniteForm=!0);return!!(!((t=r.lenBlock)===null||t===void 0)&&t.isIndefiniteForm)}var Mn=class extends it{getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}constructor({value:t=cr,...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}'`}};Mn.NAME="BaseStringBlock";var Pn=class extends te(lt){constructor({isHexOnly:t=!0,...e}={}){super(e),this.isHexOnly=t}};Pn.NAME="PrimitiveValueBlock";var qc,Fn=class extends it{constructor(t={}){super(t,Pn),this.idBlock.isConstructed=!1}};qc=Fn;k.Primitive=qc;Fn.NAME="PRIMITIVE";function Ah(r,t){if(r instanceof t)return r;let e=new t;return e.idBlock=r.idBlock,e.lenBlock=r.lenBlock,e.warnings=r.warnings,e.valueBeforeDecodeView=r.valueBeforeDecodeView,e}function Es(r,t=0,e=r.length){let n=t,s=new it({},lt),o=new zt;if(!Qt(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=it;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=k.EndOfContent;break;case 1:a=k.Boolean;break;case 2:a=k.Integer;break;case 3:a=k.BitString;break;case 4:a=k.OctetString;break;case 5:a=k.Null;break;case 6:a=k.ObjectIdentifier;break;case 10:a=k.Enumerated;break;case 12:a=k.Utf8String;break;case 13:a=k.RelativeObjectIdentifier;break;case 14:a=k.TIME;break;case 15:return s.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:s};case 16:a=k.Sequence;break;case 17:a=k.Set;break;case 18:a=k.NumericString;break;case 19:a=k.PrintableString;break;case 20:a=k.TeletexString;break;case 21:a=k.VideotexString;break;case 22:a=k.IA5String;break;case 23:a=k.UTCTime;break;case 24:a=k.GeneralizedTime;break;case 25:a=k.GraphicString;break;case 26:a=k.VisibleString;break;case 27:a=k.GeneralString;break;case 28:a=k.UniversalString;break;case 29:a=k.CharacterString;break;case 30:a=k.BmpString;break;case 31:a=k.DATE;break;case 32:a=k.TimeOfDay;break;case 33:a=k.DateTime;break;case 34:a=k.Duration;break;default:{let l=s.idBlock.isConstructed?new k.Constructed:new k.Primitive;l.idBlock=s.idBlock,l.lenBlock=s.lenBlock,l.warnings=s.warnings,s=l}}break;case 2:case 3:case 4:default:a=s.idBlock.isConstructed?k.Constructed:k.Primitive}return s=Ah(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 Bs(r){if(!r.byteLength){let t=new it({},lt);return t.error="Input buffer has zero length",{offset:-1,result:t}}return Es(q.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function Sh(r,t){return r?1:t}var Vt=class extends lt{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(!Qt(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(;Sh(this.isIndefiniteForm,n)>0;){let i=Es(s,o,n);if(i.offset===-1)return this.error=i.result.error,this.warnings.concat(i.result.warnings),-1;if(o=i.offset,this.blockLength+=i.result.blockLength,n-=i.result.blockLength,this.value.push(i.result),this.isIndefiniteForm&&i.result.constructor.NAME===Gr)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===Gr?this.value.pop():this.warnings.push("No EndOfContent block encoded")),o}toBER(t,e){let n=e||new jr;for(let s=0;s<this.value.length;s++)this.value[s].toBER(t,n);return e?Tt:n.final()}toJSON(){let t={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let e of this.value)t.value.push(e.toJSON());return t}};Vt.NAME="ConstructedValueBlock";var $c,ye=class extends it{constructor(t={}){super(t,Vt),this.idBlock.isConstructed=!0}fromBER(t,e,n){this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm;let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}onAsciiEncoding(){let t=[];for(let n of this.valueBlock.value)t.push(n.toString("ascii").split(`
|
|
2
|
+
"use strict";var Libp2PKeychain=(()=>{var Su=Object.create;var en=Object.defineProperty;var ku=Object.getOwnPropertyDescriptor;var Iu=Object.getOwnPropertyNames;var Cu=Object.getPrototypeOf,Nu=Object.prototype.hasOwnProperty;var fr=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),ft=(r,t)=>{for(var e in t)en(r,e,{get:t[e],enumerable:!0})},ui=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of Iu(t))!Nu.call(r,s)&&s!==e&&en(r,s,{get:()=>t[s],enumerable:!(n=ku(t,s))||n.enumerable});return r};var li=(r,t,e)=>(e=r!=null?Su(Cu(r)):{},ui(t||!r||!r.__esModule?en(e,"default",{value:r,enumerable:!0}):e,r)),Uu=r=>ui(en({},"__esModule",{value:!0}),r);var Ic=fr((Gy,kc)=>{"use strict";function nh(r){return r>=55296&&r<=56319}function sh(r){return r>=56320&&r<=57343}kc.exports=function(t,e,n){if(typeof e!="string")throw new Error("Input must be string");for(var s=e.length,o=0,i,c,a=0;a<s;a+=1){if(i=e.charCodeAt(a),c=e[a],nh(i)&&sh(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 Nc=fr((Zy,Cc)=>{"use strict";function oh(r){return r>=55296&&r<=56319}function ih(r){return r>=56320&&r<=57343}Cc.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),ih(s)?o!=null&&oh(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 Lc=fr((Yy,Uc)=>{"use strict";var ah=Ic(),ch=Nc();Uc.exports=ah.bind(null,ch)});var _c=fr((zy,Rc)=>{"use strict";var uh=Lc(),lh=/[\/\?<>\\:\*\|"]/g,fh=/[\x00-\x1f\x80-\x9f]/g,hh=/^\.+$/,dh=/^(con|prn|aux|nul|com[0-9]|lpt[0-9])(\..*)?$/i,ph=/[\. ]+$/;function Tc(r,t){if(typeof r!="string")throw new Error("Input must be string");var e=r.replace(lh,t).replace(fh,t).replace(hh,t).replace(dh,t).replace(ph,t);return uh(e,255)}Rc.exports=function(r,t){var e=t&&t.replacement||"",n=Tc(r,e);return e===""?n:Tc(n,"")}});var Dc=fr(ar=>{"use strict";var yh="[object ArrayBuffer]",Yt=class r{static isArrayBuffer(t){return Object.prototype.toString.call(t)===yh}static toArrayBuffer(t){return this.isArrayBuffer(t)?t:t.byteLength===t.buffer.byteLength||t.byteOffset===0&&t.byteLength===t.buffer.byteLength?t.buffer:this.toUint8Array(t.buffer).slice(t.byteOffset,t.byteOffset+t.byteLength).buffer}static toUint8Array(t){return this.toView(t,Uint8Array)}static toView(t,e){if(t.constructor===e)return t;if(this.isArrayBuffer(t))return new e(t);if(this.isArrayBufferView(t))return new e(t.buffer,t.byteOffset,t.byteLength);throw new TypeError("The provided value is not of type '(ArrayBuffer or ArrayBufferView)'")}static isBufferSource(t){return this.isArrayBufferView(t)||this.isArrayBuffer(t)}static isArrayBufferView(t){return ArrayBuffer.isView(t)||t&&this.isArrayBuffer(t.buffer)}static isEqual(t,e){let n=r.toUint8Array(t),s=r.toUint8Array(e);if(n.length!==s.byteLength)return!1;for(let o=0;o<n.length;o++)if(n[o]!==s[o])return!1;return!0}static concat(...t){let e;Array.isArray(t[0])&&!(t[1]instanceof Function)||Array.isArray(t[0])&&t[1]instanceof Function?e=t[0]:t[t.length-1]instanceof Function?e=t.slice(0,t.length-1):e=t;let n=0;for(let i of e)n+=i.byteLength;let s=new Uint8Array(n),o=0;for(let i of e){let 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}},Qo="string",mh=/^[0-9a-f\s]+$/i,bh=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,wh=/^[a-zA-Z0-9-_]+$/,_n=class{static fromString(t){let e=unescape(encodeURIComponent(t)),n=new Uint8Array(e.length);for(let s=0;s<e.length;s++)n[s]=e.charCodeAt(s);return n.buffer}static toString(t){let e=Yt.toUint8Array(t),n="";for(let o=0;o<e.length;o++)n+=String.fromCharCode(e[o]);return decodeURIComponent(escape(n))}},It=class{static toString(t,e=!1){let n=Yt.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}},Dn=class r{static isHex(t){return typeof t===Qo&&mh.test(t)}static isBase64(t){return typeof t===Qo&&bh.test(t)}static isBase64Url(t){return typeof t===Qo&&wh.test(t)}static ToString(t,e="utf8"){let n=Yt.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 It.toString(n,!0);case"utf16":case"utf16be":return It.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 It.fromString(t,!0);case"utf16":case"utf16be":return It.fromString(t);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToBase64(t){let e=Yt.toUint8Array(t);if(typeof btoa<"u"){let n=this.ToString(e,"binary");return btoa(n)}else return Buffer.from(e).toString("base64")}static FromBase64(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isBase64(e))throw new TypeError("Argument 'base64Text' is not Base64 encoded");return typeof atob<"u"?this.FromBinary(atob(e)):new Uint8Array(Buffer.from(e,"base64")).buffer}static FromBase64Url(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isBase64Url(e))throw new TypeError("Argument 'base64url' is not Base64Url encoded");return this.FromBase64(this.Base64Padding(e.replace(/\-/g,"+").replace(/\_/g,"/")))}static ToBase64Url(t){return this.ToBase64(t).replace(/\+/g,"-").replace(/\//g,"_").replace(/\=/g,"")}static FromUtf8String(t,e=r.DEFAULT_UTF8_ENCODING){switch(e){case"ascii":return this.FromBinary(t);case"utf8":return _n.fromString(t);case"utf16":case"utf16be":return It.fromString(t);case"utf16le":case"usc2":return It.fromString(t,!0);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToUtf8String(t,e=r.DEFAULT_UTF8_ENCODING){switch(e){case"ascii":return this.ToBinary(t);case"utf8":return _n.toString(t);case"utf16":case"utf16be":return It.toString(t);case"utf16le":case"usc2":return It.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=Yt.toUint8Array(t),n="";for(let s=0;s<e.length;s++)n+=String.fromCharCode(e[s]);return n}static ToHex(t){let e=Yt.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 It.toString(t,e)}static FromUtf16String(t,e=!1){return It.fromString(t,e)}static Base64Padding(t){let e=4-t.length%4;if(e<4)for(let n=0;n<e;n++)t+="=";return t}static formatString(t){return t?.replace(/[\n\r\t ]/g,"")||""}};Dn.DEFAULT_UTF8_ENCODING="utf8";function xh(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 vh(...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 Eh(r,t){if(!(r&&t)||r.byteLength!==t.byteLength)return!1;let e=new Uint8Array(r),n=new Uint8Array(t);for(let s=0;s<r.byteLength;s++)if(e[s]!==n[s])return!1;return!0}ar.BufferSourceConverter=Yt;ar.Convert=Dn;ar.assign=xh;ar.combine=vh;ar.isEqual=Eh});var Hh={};ft(Hh,{keychain:()=>Oh});var hr=class extends Error{constructor(t="An error occurred while signing a message"){super(t),this.name="SigningError"}},dr=class extends Error{constructor(t="An error occurred while verifying a message"){super(t),this.name="VerificationError"}},rn=class extends Error{constructor(t="Missing Web Crypto API"){super(t),this.name="WebCryptoMissingError"}};var fi={get(r=globalThis){let t=r.crypto;if(t?.subtle==null)throw new rn("Missing Web Crypto API. The most likely cause of this error is that this page is being accessed from an insecure context (i.e. not HTTPS). For more information and possible resolutions see https://github.com/libp2p/js-libp2p/blob/main/packages/crypto/README.md#web-crypto-api");return t}};var Q=fi;var R=class extends Error{static name="InvalidParametersError";constructor(t="Invalid parameters"){super(t),this.name="InvalidParametersError"}},Ke=class extends Error{static name="InvalidPublicKeyError";constructor(t="Invalid public key"){super(t),this.name="InvalidPublicKeyError"}},pr=class extends Error{static name="InvalidPrivateKeyError";constructor(t="Invalid private key"){super(t),this.name="InvalidPrivateKeyError"}};var nn=class extends Error{static name="NotFoundError";constructor(t="Not found"){super(t),this.name="NotFoundError"}};var Ve=class extends Error{static name="UnsupportedKeyTypeError";constructor(t="Unsupported key type"){super(t),this.name="UnsupportedKeyTypeError"}};var hi=Symbol.for("@libp2p/service-capabilities"),Zh=Symbol.for("@libp2p/service-dependencies");var Us={};ft(Us,{base58btc:()=>tt,base58flickr:()=>Vu});var wd=new Uint8Array(0);function di(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 Ht(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 pi(r){return new TextEncoder().encode(r)}function gi(r){return new TextDecoder().decode(r)}function Lu(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),l=Math.log(c)/Math.log(256),f=Math.log(256)/Math.log(c);function u(h){if(h instanceof Uint8Array||(ArrayBuffer.isView(h)?h=new Uint8Array(h.buffer,h.byteOffset,h.byteLength):Array.isArray(h)&&(h=Uint8Array.from(h))),!(h instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(h.length===0)return"";for(var B=0,v=0,g=0,A=h.length;g!==A&&h[g]===0;)g++,B++;for(var w=(A-g)*f+1>>>0,I=new Uint8Array(w);g!==A;){for(var D=h[g],H=0,M=w-1;(D!==0||H<v)&&M!==-1;M--,H++)D+=256*I[M]>>>0,I[M]=D%c>>>0,D=D/c>>>0;if(D!==0)throw new Error("Non-zero carry");v=H,g++}for(var E=w-v;E!==w&&I[E]===0;)E++;for(var x=a.repeat(B);E<w;++E)x+=r.charAt(I[E]);return x}function d(h){if(typeof h!="string")throw new TypeError("Expected String");if(h.length===0)return new Uint8Array;var B=0;if(h[B]!==" "){for(var v=0,g=0;h[B]===a;)v++,B++;for(var A=(h.length-B)*l+1>>>0,w=new Uint8Array(A);h[B];){var I=e[h.charCodeAt(B)];if(I===255)return;for(var D=0,H=A-1;(I!==0||D<g)&&H!==-1;H--,D++)I+=c*w[H]>>>0,w[H]=I%256>>>0,I=I/256>>>0;if(I!==0)throw new Error("Non-zero carry");g=D,B++}if(h[B]!==" "){for(var M=A-g;M!==A&&w[M]===0;)M++;for(var E=new Uint8Array(v+(A-M)),x=v;M!==A;)E[x++]=w[M++];return E}}}function y(h){var B=d(h);if(B)return B;throw new Error(`Non-${t} character`)}return{encode:u,decodeUnsafe:d,decode:y}}var Tu=Lu,Ru=Tu,mi=Ru;var ks=class{name;prefix;baseEncode;constructor(t,e,n){this.name=t,this.prefix=e,this.baseEncode=n}encode(t){if(t instanceof Uint8Array)return`${this.prefix}${this.baseEncode(t)}`;throw Error("Unknown type, must be binary type")}},Is=class{name;prefix;baseDecode;prefixCodePoint;constructor(t,e,n){this.name=t,this.prefix=e;let s=e.codePointAt(0);if(s===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=s,this.baseDecode=n}decode(t){if(typeof t=="string"){if(t.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(t)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(t.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(t){return bi(this,t)}},Cs=class{decoders;constructor(t){this.decoders=t}or(t){return bi(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 bi(r,t){return new Cs({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var Ns=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 ks(t,e,n),this.decoder=new Is(t,e,s)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function Oe({name:r,prefix:t,encode:e,decode:n}){return new Ns(r,t,e,n)}function ee({name:r,prefix:t,alphabet:e}){let{encode:n,decode:s}=mi(e,r);return Oe({prefix:t,name:r,encode:n,decode:o=>Ht(s(o))})}function _u(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 l=0;l<s;++l){let f=t[r[l]];if(f===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<e|f,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 Du(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 Ku(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=Ku(n);return Oe({prefix:t,name:r,encode(o){return Du(o,n,e)},decode(o){return _u(o,s,e,r)}})}var tt=ee({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),Vu=ee({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Ls={};ft(Ls,{base32:()=>He,base32hex:()=>Pu,base32hexpad:()=>qu,base32hexpadupper:()=>$u,base32hexupper:()=>Fu,base32pad:()=>Hu,base32padupper:()=>Mu,base32upper:()=>Ou,base32z:()=>ju});var He=J({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),Ou=J({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Hu=J({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),Mu=J({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),Pu=J({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),Fu=J({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),qu=J({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),$u=J({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),ju=J({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Ts={};ft(Ts,{base36:()=>gr,base36upper:()=>Gu});var gr=ee({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),Gu=ee({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Zu=vi,wi=128,Yu=127,zu=~Yu,Wu=Math.pow(2,31);function vi(r,t,e){t=t||[],e=e||0;for(var n=e;r>=Wu;)t[e++]=r&255|wi,r/=128;for(;r&zu;)t[e++]=r&255|wi,r>>>=7;return t[e]=r|0,vi.bytes=e-n+1,t}var Ju=Rs,Xu=128,xi=127;function Rs(r,n){var e=0,n=n||0,s=0,o=n,i,c=r.length;do{if(o>=c)throw Rs.bytes=0,new RangeError("Could not decode varint");i=r[o++],e+=s<28?(i&xi)<<s:(i&xi)*Math.pow(2,s),s+=7}while(i>=Xu);return Rs.bytes=o-n,e}var Qu=Math.pow(2,7),tl=Math.pow(2,14),el=Math.pow(2,21),rl=Math.pow(2,28),nl=Math.pow(2,35),sl=Math.pow(2,42),ol=Math.pow(2,49),il=Math.pow(2,56),al=Math.pow(2,63),cl=function(r){return r<Qu?1:r<tl?2:r<el?3:r<rl?4:r<nl?5:r<sl?6:r<ol?7:r<il?8:r<al?9:10},ul={encode:Zu,decode:Ju,encodingLength:cl},ll=ul,yr=ll;function mr(r,t=0){return[yr.decode(r,t),yr.decode.bytes]}function Me(r,t,e=0){return yr.encode(r,t,e),t}function Pe(r){return yr.encodingLength(r)}function Rt(r,t){let e=t.byteLength,n=Pe(r),s=n+Pe(e),o=new Uint8Array(s+e);return Me(r,o,0),Me(e,o,n),o.set(t,s),new Fe(r,e,t,o)}function Ei(r){let t=Ht(r),[e,n]=mr(t),[s,o]=mr(t.subarray(n)),i=t.subarray(n+o);if(i.byteLength!==s)throw new Error("Incorrect length");return new Fe(e,s,i,t)}function Bi(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&di(r.bytes,e.bytes)}}var Fe=class{code;size;digest;bytes;constructor(t,e,n,s){this.code=t,this.size=e,this.digest=n,this.bytes=s}};function Ai(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return hl(e,_s(r),t??tt.encoder);default:return dl(e,_s(r),t??He.encoder)}}var Si=new WeakMap;function _s(r){let t=Si.get(r);if(t==null){let e=new Map;return Si.set(r,e),e}return t}var St=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!==wr)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==pl)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=Rt(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&&Bi(t.multihash,n.multihash)}toString(t){return Ai(this,t)}toJSON(){return{"/":Ai(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??ki(n,s,o.bytes))}else if(e[gl]===!0){let{version:n,multihash:s,code:o}=e,i=Ei(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!==wr)throw new Error(`Version 0 CID must use dag-pb (code: ${wr}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let s=ki(t,e,n.bytes);return new r(t,e,n,s)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,wr,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=Ht(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 Fe(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]=mr(t.subarray(e));return e+=d,u},s=n(),o=wr;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(),l=e+a,f=l-i;return{version:s,codec:o,multihashCode:c,digestSize:a,multihashSize:f,size:l}}static parse(t,e){let[n,s]=fl(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 _s(o).set(n,t),o}};function fl(r,t){switch(r[0]){case"Q":{let e=t??tt;return[tt.prefix,e.decode(`${tt.prefix}${r}`)]}case tt.prefix:{let e=t??tt;return[tt.prefix,e.decode(r)]}case He.prefix:{let e=t??He;return[He.prefix,e.decode(r)]}case gr.prefix:{let e=t??gr;return[gr.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 hl(r,t,e){let{prefix:n}=e;if(n!==tt.prefix)throw Error(`Cannot string encode V0 in ${e.name} encoding`);let s=t.get(n);if(s==null){let o=e.encode(r).slice(1);return t.set(n,o),o}else return s}function dl(r,t,e){let{prefix:n}=e,s=t.get(n);if(s==null){let o=e.encode(r);return t.set(n,o),o}else return s}var wr=112,pl=18;function ki(r,t,e){let n=Pe(r),s=n+Pe(t),o=new Uint8Array(s+e.byteLength);return Me(r,o,0),Me(t,o,n),o.set(e,s),o}var gl=Symbol.for("@ipld/js-cid/CID");var Ds={};ft(Ds,{identity:()=>me});var Ii=0,yl="identity",Ci=Ht;function ml(r,t){if(t?.truncate!=null&&t.truncate!==r.byteLength){if(t.truncate<0||t.truncate>r.byteLength)throw new Error(`Invalid truncate option, must be less than or equal to ${r.byteLength}`);r=r.subarray(0,t.truncate)}return Rt(Ii,Ci(r))}var me={code:Ii,name:yl,encode:Ci,digest:ml};function mt(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function Mt(r=0){return new Uint8Array(r)}function Bt(r=0){return new Uint8Array(r)}function qe(r,t){t==null&&(t=r.reduce((s,o)=>s+o.length,0));let e=Bt(t),n=0;for(let s of r)e.set(s,n),n+=s.length;return e}var Ui=Symbol.for("@achingbrain/uint8arraylist");function Ni(r,t){if(t==null||t<0)throw new RangeError("index is out of bounds");let e=0;for(let n of r){let s=e+n.byteLength;if(t<s)return{buf:n,index:t-e};e=s}throw new RangeError("index is out of bounds")}function on(r){return!!r?.[Ui]}var ht=class r{bufs;length;[Ui]=!0;constructor(...t){this.bufs=[],this.length=0,t.length>0&&this.appendAll(t)}*[Symbol.iterator](){yield*this.bufs}get byteLength(){return this.length}append(...t){this.appendAll(t)}appendAll(t){let e=0;for(let n of t)if(n instanceof Uint8Array)e+=n.byteLength,this.bufs.push(n);else if(on(n))e+=n.byteLength,this.bufs.push(...n.bufs);else throw new Error("Could not append value, must be an Uint8Array or a Uint8ArrayList");this.length+=e}prepend(...t){this.prependAll(t)}prependAll(t){let e=0;for(let n of t.reverse())if(n instanceof Uint8Array)e+=n.byteLength,this.bufs.unshift(n);else if(on(n))e+=n.byteLength,this.bufs.unshift(...n.bufs);else throw new Error("Could not prepend value, must be an Uint8Array or a Uint8ArrayList");this.length+=e}get(t){let e=Ni(this.bufs,t);return e.buf[e.index]}set(t,e){let n=Ni(this.bufs,t);n.buf[n.index]=e}write(t,e=0){if(t instanceof Uint8Array)for(let n=0;n<t.length;n++)this.set(e+n,t[n]);else if(on(t))for(let n=0;n<t.length;n++)this.set(e+n,t.get(n));else throw new Error("Could not write value, must be an Uint8Array or a Uint8ArrayList")}consume(t){if(t=Math.trunc(t),!(Number.isNaN(t)||t<=0)){if(t===this.byteLength){this.bufs=[],this.length=0;return}for(;this.bufs.length>0;)if(t>=this.bufs[0].byteLength)t-=this.bufs[0].byteLength,this.length-=this.bufs[0].byteLength,this.bufs.shift();else{this.bufs[0]=this.bufs[0].subarray(t),this.length-=t;break}}}slice(t,e){let{bufs:n,length:s}=this._subList(t,e);return qe(n,s)}subarray(t,e){let{bufs:n,length:s}=this._subList(t,e);return n.length===1?n[0]:qe(n,s)}sublist(t,e){let{bufs:n,length:s}=this._subList(t,e),o=new r;return o.length=s,o.bufs=[...n],o}_subList(t,e){if(t=t??0,e=e??this.length,t<0&&(t=this.length+t),e<0&&(e=this.length+e),t<0||e>this.length)throw new RangeError("index is out of bounds");if(t===e)return{bufs:[],length:0};if(t===0&&e===this.length)return{bufs:this.bufs,length:this.length};let n=[],s=0;for(let o=0;o<this.bufs.length;o++){let i=this.bufs[o],c=s,a=c+i.byteLength;if(s=a,t>=a)continue;let l=t>=c&&t<a,f=e>c&&e<=a;if(l&&f){if(t===c&&e===a){n.push(i);break}let u=t-c;n.push(i.subarray(u,u+(e-t)));break}if(l){if(t===0){n.push(i);continue}n.push(i.subarray(t-c));continue}if(f){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(!on(t)&&!(t instanceof Uint8Array))throw new TypeError('The "value" argument must be a Uint8ArrayList or Uint8Array');let n=t instanceof Uint8Array?t:t.subarray();if(e=Number(e??0),isNaN(e)&&(e=0),e<0&&(e=this.length+e),e<0&&(e=0),t.length===0)return e>this.length?this.length:e;let s=n.byteLength;if(s===0)throw new TypeError("search must be at least 1 byte long");let o=256,i=new Int32Array(o);for(let u=0;u<o;u++)i[u]=-1;for(let u=0;u<s;u++)i[n[u]]=u;let c=i,a=this.byteLength-n.byteLength,l=n.byteLength-1,f;for(let u=e;u<=a;u+=f){f=0;for(let d=l;d>=0;d--){let y=this.get(u+d);if(n[d]!==y){f=Math.max(1,d-c[y]);break}}if(f===0)return u}return-1}getInt8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getInt8(0)}setInt8(t,e){let n=Bt(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setInt8(0,e),this.write(n,t)}getInt16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt16(0,e)}setInt16(t,e,n){let s=Mt(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=Mt(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=Mt(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigInt64(0,e,n),this.write(s,t)}getUint8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getUint8(0)}setUint8(t,e){let n=Bt(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setUint8(0,e),this.write(n,t)}getUint16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint16(0,e)}setUint16(t,e,n){let s=Mt(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=Mt(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=Mt(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=Mt(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=Mt(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(!mt(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 Ks={};ft(Ks,{base10:()=>bl});var bl=ee({prefix:"9",name:"base10",alphabet:"0123456789"});var Vs={};ft(Vs,{base16:()=>wl,base16upper:()=>xl});var wl=J({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),xl=J({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Os={};ft(Os,{base2:()=>vl});var vl=J({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Hs={};ft(Hs,{base256emoji:()=>kl});var Li=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}"),El=Li.reduce((r,t,e)=>(r[e]=t,r),[]),Bl=Li.reduce((r,t,e)=>{let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);return r[n]=e,r},[]);function Al(r){return r.reduce((t,e)=>(t+=El[e],t),"")}function Sl(r){let t=[];for(let e of r){let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);let s=Bl[n];if(s==null)throw new Error(`Non-base256emoji character: ${e}`);t.push(s)}return new Uint8Array(t)}var kl=Oe({prefix:"\u{1F680}",name:"base256emoji",encode:Al,decode:Sl});var Ms={};ft(Ms,{base64:()=>be,base64pad:()=>Il,base64url:()=>Cl,base64urlpad:()=>Nl});var be=J({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),Il=J({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Cl=J({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Nl=J({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Ps={};ft(Ps,{base8:()=>Ul});var Ul=J({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Fs={};ft(Fs,{identity:()=>Ll});var Ll=Oe({prefix:"\0",name:"identity",encode:r=>gi(r),decode:r=>pi(r)});var r0=new TextEncoder,n0=new TextDecoder;var js={};ft(js,{sha256:()=>$e,sha512:()=>Dl});var _l=20;function $s({name:r,code:t,encode:e,minDigestLength:n,maxDigestLength:s}){return new qs(r,t,e,n,s)}var qs=class{name;code;encode;minDigestLength;maxDigestLength;constructor(t,e,n,s,o){this.name=t,this.code=e,this.encode=n,this.minDigestLength=s??_l,this.maxDigestLength=o}digest(t,e){if(e?.truncate!=null){if(e.truncate<this.minDigestLength)throw new Error(`Invalid truncate option, must be greater than or equal to ${this.minDigestLength}`);if(this.maxDigestLength!=null&&e.truncate>this.maxDigestLength)throw new Error(`Invalid truncate option, must be less than or equal to ${this.maxDigestLength}`)}if(t instanceof Uint8Array){let n=this.encode(t);return n instanceof Uint8Array?Ti(n,this.code,e?.truncate):n.then(s=>Ti(s,this.code,e?.truncate))}else throw Error("Unknown type, must be binary type")}};function Ti(r,t,e){if(e!=null&&e!==r.byteLength){if(e>r.byteLength)throw new Error(`Invalid truncate option, must be less than or equal to ${r.byteLength}`);r=r.subarray(0,e)}return Rt(t,r)}function _i(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var $e=$s({name:"sha2-256",code:18,encode:_i("SHA-256")}),Dl=$s({name:"sha2-512",code:19,encode:_i("SHA-512")});var Gs={...Fs,...Os,...Ps,...Ks,...Vs,...Ls,...Ts,...Us,...Ms,...Hs},g0={...js,...Ds};function Ki(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var Di=Ki("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),Zs=Ki("ascii","a",r=>{let t="a";for(let e=0;e<r.length;e++)t+=String.fromCharCode(r[e]);return t},r=>{r=r.substring(1);let t=Bt(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),Kl={utf8:Di,"utf-8":Di,hex:Gs.base16,latin1:Zs,ascii:Zs,binary:Zs,...Gs},an=Kl;function F(r,t="utf8"){let e=an[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function $(r,t="utf8"){let e=an[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}var Vl=parseInt("11111",2),Ys=parseInt("10000000",2),Ol=parseInt("01111111",2),Vi={0:xr,1:xr,2:Hl,3:Fl,4:ql,5:Pl,6:Ml,16:xr,22:xr,48:xr};function Ct(r,t={offset:0}){let e=r[t.offset]&Vl;if(t.offset++,Vi[e]!=null)return Vi[e](r,t);throw new Error("No decoder for tag "+e)}function vr(r,t){let e=0;if((r[t.offset]&Ys)===Ys){let n=r[t.offset]&Ol,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 xr(r,t){vr(r,t);let e=[];for(;!(t.offset>=r.byteLength);){let n=Ct(r,t);if(n===null)break;e.push(n)}return e}function Hl(r,t){let e=vr(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 Ml(r,t){let e=vr(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 l=r[t.offset];if(t.offset++,a.push(l&127),l<128){a.reverse();let f=0;for(let u=0;u<a.length;u++)f+=a[u]<<u*7;c+=`.${f}`,a=[]}}return c}function Pl(r,t){return t.offset++,null}function Fl(r,t){let e=vr(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 ql(r,t){let e=vr(r,t),n=r.subarray(t.offset,t.offset+e);return t.offset+=e,n}function $l(r){let t=r.toString(16);t.length%2===1&&(t="0"+t);let e=new ht;for(let n=0;n<t.length;n+=2)e.append(Uint8Array.from([parseInt(`${t[n]}${t[n+1]}`,16)]));return e}function cn(r){if(r.byteLength<128)return Uint8Array.from([r.byteLength]);let t=$l(r.byteLength);return new ht(Uint8Array.from([t.byteLength|Ys]),t)}function dt(r){let t=new ht,e=128;return(r.subarray()[0]&e)===e&&t.append(Uint8Array.from([0])),t.append(r),new ht(Uint8Array.from([2]),cn(t),t)}function Er(r){let t=Uint8Array.from([0]),e=new ht(t,r);return new ht(Uint8Array.from([3]),cn(e),e)}function Oi(r){return new ht(Uint8Array.from([4]),cn(r),r)}function Nt(r,t=48){let e=new ht;for(let n of r)e.append(n);return new ht(Uint8Array.from([t]),cn(e),e)}var Hi="1.2.840.10045.3.1.7",Mi="1.3.132.0.34",Pi="1.3.132.0.35";async function Fi(r,t,e){let n=await crypto.subtle.importKey("jwk",r,{name:"ECDSA",namedCurve:r.crv??"P-256"},!1,["sign"]);e?.signal?.throwIfAborted();let s=await crypto.subtle.sign({name:"ECDSA",hash:{name:"SHA-256"}},n,t.subarray());return e?.signal?.throwIfAborted(),new Uint8Array(s,0,s.byteLength)}async function qi(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 jl=Uint8Array.from([6,8,42,134,72,206,61,3,1,7]),Gl=Uint8Array.from([6,5,43,129,4,0,34]),Zl=Uint8Array.from([6,5,43,129,4,0,35]),Yl={ext:!0,kty:"EC",crv:"P-256"},zl={ext:!0,kty:"EC",crv:"P-384"},Wl={ext:!0,kty:"EC",crv:"P-521"},zs=32,Ws=48,Js=66;function $i(r){let t=Ct(r);return Xs(t)}function Xs(r){let t=r[1],e=$(t,"base64url"),n=r[2][1][0],s=1,o,i;if(t.byteLength===zs)return o=$(n.subarray(s,s+zs),"base64url"),i=$(n.subarray(s+zs),"base64url"),new je({...Yl,key_ops:["sign"],d:e,x:o,y:i});if(t.byteLength===Ws)return o=$(n.subarray(s,s+Ws),"base64url"),i=$(n.subarray(s+Ws),"base64url"),new je({...zl,key_ops:["sign"],d:e,x:o,y:i});if(t.byteLength===Js)return o=$(n.subarray(s,s+Js),"base64url"),i=$(n.subarray(s+Js),"base64url"),new je({...Wl,key_ops:["sign"],d:e,x:o,y:i});throw new R(`Private key length was wrong length, got ${t.byteLength}, expected 32, 48 or 66`)}function ji(r){return Nt([dt(Uint8Array.from([1])),Oi(F(r.d??"","base64url")),Nt([Zi(r.crv)],160),Nt([Er(new ht(Uint8Array.from([4]),F(r.x??"","base64url"),F(r.y??"","base64url")))],161)]).subarray()}function Gi(r){return Nt([dt(Uint8Array.from([1])),Nt([Zi(r.crv)],160),Nt([Er(new ht(Uint8Array.from([4]),F(r.x??"","base64url"),F(r.y??"","base64url")))],161)]).subarray()}function Zi(r){if(r==="P-256")return jl;if(r==="P-384")return Gl;if(r==="P-521")return Zl;throw new R(`Invalid curve ${r}`)}var un=class{type="ECDSA";jwk;_raw;constructor(t){this.jwk=t}get raw(){return this._raw==null&&(this._raw=Gi(this.jwk)),this._raw}toMultihash(){return me.digest(Ge(this))}toCID(){return St.createV1(114,this.toMultihash())}toString(){return tt.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:mt(this.raw,t.raw)}async verify(t,e,n){return qi(this.jwk,e,t,n)}},je=class{type="ECDSA";jwk;publicKey;_raw;constructor(t){this.jwk=t,this.publicKey=new un({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=ji(this.jwk)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:mt(this.raw,t.raw)}async sign(t,e){return Fi(this.jwk,t,e)}};function we(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function bt(r,t=""){if(!Number.isSafeInteger(r)||r<0){let e=t&&`"${t}" `;throw new Error(`${e}expected integer >= 0, got ${r}`)}}function O(r,t,e=""){let n=we(r),s=r?.length,o=t!==void 0;if(!n||o&&s!==t){let i=e&&`"${e}" `,c=o?` of length ${t}`:"",a=n?`length=${s}`:`type=${typeof r}`;throw new Error(i+"expected Uint8Array"+c+", got "+a)}return r}function Ze(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash must wrapped by utils.createHasher");bt(r.outputLen),bt(r.blockLen)}function Ye(r,t=!0){if(r.destroyed)throw new Error("Hash instance has been destroyed");if(t&&r.finished)throw new Error("Hash#digest() has already been called")}function zi(r,t){O(r,void 0,"digestInto() output");let e=t.outputLen;if(r.length<e)throw new Error('"digestInto() output" expected to be of length >='+e)}function wt(...r){for(let t=0;t<r.length;t++)r[t].fill(0)}function xe(r){return new DataView(r.buffer,r.byteOffset,r.byteLength)}function Ut(r,t){return r<<32-t|r>>>t}function ln(r,t){return r<<t|r>>>32-t>>>0}var Wi=typeof Uint8Array.from([]).toHex=="function"&&typeof Uint8Array.fromHex=="function",Jl=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function Ft(r){if(O(r),Wi)return r.toHex();let t="";for(let e=0;e<r.length;e++)t+=Jl[r[e]];return t}var Pt={_0:48,_9:57,A:65,F:70,a:97,f:102};function Yi(r){if(r>=Pt._0&&r<=Pt._9)return r-Pt._0;if(r>=Pt.A&&r<=Pt.F)return r-(Pt.A-10);if(r>=Pt.a&&r<=Pt.f)return r-(Pt.a-10)}function qt(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);if(Wi)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=Yi(r.charCodeAt(o)),c=Yi(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}var Xl=async()=>{};async function Ji(r,t,e){let n=Date.now();for(let s=0;s<r;s++){e(s);let o=Date.now()-n;o>=0&&o<t||(await Xl(),n+=o)}}function Ql(r){if(typeof r!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(r))}function Qs(r,t=""){return typeof r=="string"?Ql(r):O(r,void 0,t)}function xt(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];O(s),t+=s.length}let e=new Uint8Array(t);for(let n=0,s=0;n<r.length;n++){let o=r[n];e.set(o,s),s+=o.length}return e}function Xi(r,t){if(t!==void 0&&{}.toString.call(t)!=="[object Object]")throw new Error("options must be object or undefined");return Object.assign(r,t)}function Br(r,t={}){let e=(s,o)=>r(o).update(s).digest(),n=r(void 0);return e.outputLen=n.outputLen,e.blockLen=n.blockLen,e.create=s=>r(s),Object.assign(e,t),Object.freeze(e)}function re(r=32){let t=typeof globalThis=="object"?globalThis.crypto:null;if(typeof t?.getRandomValues!="function")throw new Error("crypto.getRandomValues must be defined");return t.getRandomValues(new Uint8Array(r))}var to=r=>({oid:Uint8Array.from([6,9,96,134,72,1,101,3,4,2,r])});function fn(r,t,e){return r&t^~r&e}function hn(r,t,e){return r&t^r&e^t&e}var ve=class{blockLen;outputLen;padOffset;isLE;buffer;view;finished=!1;length=0;pos=0;destroyed=!1;constructor(t,e,n,s){this.blockLen=t,this.outputLen=e,this.padOffset=n,this.isLE=s,this.buffer=new Uint8Array(t),this.view=xe(this.buffer)}update(t){Ye(this),O(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=xe(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){Ye(this),zi(t,this),this.finished=!0;let{buffer:e,view:n,blockLen:s,isLE:o}=this,{pos:i}=this;e[i++]=128,wt(this.buffer.subarray(i)),this.padOffset>s-i&&(this.process(n,0),i=0);for(let u=i;u<s;u++)e[u]=0;n.setBigUint64(s-8,BigInt(this.length*8),o),this.process(n,0);let c=xe(t),a=this.outputLen;if(a%4)throw new Error("_sha2: outputLen must be aligned to 32bit");let l=a/4,f=this.get();if(l>f.length)throw new Error("_sha2: outputLen bigger than state");for(let u=0;u<l;u++)c.setUint32(4*u,f[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||=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()}},$t=Uint32Array.from([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]);var ot=Uint32Array.from([1779033703,4089235720,3144134277,2227873595,1013904242,4271175723,2773480762,1595750129,1359893119,2917565137,2600822924,725511199,528734635,4215389547,1541459225,327033209]);var dn=BigInt(4294967295),Qi=BigInt(32);function tf(r,t=!1){return t?{h:Number(r&dn),l:Number(r>>Qi&dn)}:{h:Number(r>>Qi&dn)|0,l:Number(r&dn)|0}}function ta(r,t=!1){let e=r.length,n=new Uint32Array(e),s=new Uint32Array(e);for(let o=0;o<e;o++){let{h:i,l:c}=tf(r[o],t);[n[o],s[o]]=[i,c]}return[n,s]}var eo=(r,t,e)=>r>>>e,ro=(r,t,e)=>r<<32-e|t>>>e,Ee=(r,t,e)=>r>>>e|t<<32-e,Be=(r,t,e)=>r<<32-e|t>>>e,Ar=(r,t,e)=>r<<64-e|t>>>e-32,Sr=(r,t,e)=>r>>>e-32|t<<64-e;function _t(r,t,e,n){let s=(t>>>0)+(n>>>0);return{h:r+e+(s/2**32|0)|0,l:s|0}}var ea=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),ra=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,na=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),sa=(r,t,e,n,s)=>t+e+n+s+(r/2**32|0)|0,oa=(r,t,e,n,s)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(s>>>0),ia=(r,t,e,n,s,o)=>t+e+n+s+o+(r/2**32|0)|0;var rf=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]),ne=new Uint32Array(64),no=class extends ve{constructor(t){super(64,t,8,!1)}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)ne[u]=t.getUint32(e,!1);for(let u=16;u<64;u++){let d=ne[u-15],y=ne[u-2],h=Ut(d,7)^Ut(d,18)^d>>>3,B=Ut(y,17)^Ut(y,19)^y>>>10;ne[u]=B+ne[u-7]+h+ne[u-16]|0}let{A:n,B:s,C:o,D:i,E:c,F:a,G:l,H:f}=this;for(let u=0;u<64;u++){let d=Ut(c,6)^Ut(c,11)^Ut(c,25),y=f+d+fn(c,a,l)+rf[u]+ne[u]|0,B=(Ut(n,2)^Ut(n,13)^Ut(n,22))+hn(n,s,o)|0;f=l,l=a,a=c,c=i+y|0,i=o,o=s,s=n,n=y+B|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,l=l+this.G|0,f=f+this.H|0,this.set(n,s,o,i,c,a,l,f)}roundClean(){wt(ne)}destroy(){this.set(0,0,0,0,0,0,0,0),wt(this.buffer)}},so=class extends no{A=$t[0]|0;B=$t[1]|0;C=$t[2]|0;D=$t[3]|0;E=$t[4]|0;F=$t[5]|0;G=$t[6]|0;H=$t[7]|0;constructor(){super(32)}};var aa=ta(["0x428a2f98d728ae22","0x7137449123ef65cd","0xb5c0fbcfec4d3b2f","0xe9b5dba58189dbbc","0x3956c25bf348b538","0x59f111f1b605d019","0x923f82a4af194f9b","0xab1c5ed5da6d8118","0xd807aa98a3030242","0x12835b0145706fbe","0x243185be4ee4b28c","0x550c7dc3d5ffb4e2","0x72be5d74f27b896f","0x80deb1fe3b1696b1","0x9bdc06a725c71235","0xc19bf174cf692694","0xe49b69c19ef14ad2","0xefbe4786384f25e3","0x0fc19dc68b8cd5b5","0x240ca1cc77ac9c65","0x2de92c6f592b0275","0x4a7484aa6ea6e483","0x5cb0a9dcbd41fbd4","0x76f988da831153b5","0x983e5152ee66dfab","0xa831c66d2db43210","0xb00327c898fb213f","0xbf597fc7beef0ee4","0xc6e00bf33da88fc2","0xd5a79147930aa725","0x06ca6351e003826f","0x142929670a0e6e70","0x27b70a8546d22ffc","0x2e1b21385c26c926","0x4d2c6dfc5ac42aed","0x53380d139d95b3df","0x650a73548baf63de","0x766a0abb3c77b2a8","0x81c2c92e47edaee6","0x92722c851482353b","0xa2bfe8a14cf10364","0xa81a664bbc423001","0xc24b8b70d0f89791","0xc76c51a30654be30","0xd192e819d6ef5218","0xd69906245565a910","0xf40e35855771202a","0x106aa07032bbd1b8","0x19a4c116b8d2d0c8","0x1e376c085141ab53","0x2748774cdf8eeb99","0x34b0bcb5e19b48a8","0x391c0cb3c5c95a63","0x4ed8aa4ae3418acb","0x5b9cca4f7763e373","0x682e6ff3d6b2b8a3","0x748f82ee5defb2fc","0x78a5636f43172f60","0x84c87814a1f0ab72","0x8cc702081a6439ec","0x90befffa23631e28","0xa4506cebde82bde9","0xbef9a3f7b2c67915","0xc67178f2e372532b","0xca273eceea26619c","0xd186b8c721c0c207","0xeada7dd6cde0eb1e","0xf57d4f7fee6ed178","0x06f067aa72176fba","0x0a637dc5a2c898a6","0x113f9804bef90dae","0x1b710b35131c471b","0x28db77f523047d84","0x32caab7b40c72493","0x3c9ebe0a15c9bebc","0x431d67c49c100d4c","0x4cc5d4becb3e42b6","0x597f299cfc657e2a","0x5fcb6fab3ad6faec","0x6c44198c4a475817"].map(r=>BigInt(r))),nf=aa[0],sf=aa[1],se=new Uint32Array(80),oe=new Uint32Array(80),oo=class extends ve{constructor(t){super(128,t,16,!1)}get(){let{Ah:t,Al:e,Bh:n,Bl:s,Ch:o,Cl:i,Dh:c,Dl:a,Eh:l,El:f,Fh:u,Fl:d,Gh:y,Gl:h,Hh:B,Hl:v}=this;return[t,e,n,s,o,i,c,a,l,f,u,d,y,h,B,v]}set(t,e,n,s,o,i,c,a,l,f,u,d,y,h,B,v){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=l|0,this.El=f|0,this.Fh=u|0,this.Fl=d|0,this.Gh=y|0,this.Gl=h|0,this.Hh=B|0,this.Hl=v|0}process(t,e){for(let w=0;w<16;w++,e+=4)se[w]=t.getUint32(e),oe[w]=t.getUint32(e+=4);for(let w=16;w<80;w++){let I=se[w-15]|0,D=oe[w-15]|0,H=Ee(I,D,1)^Ee(I,D,8)^eo(I,D,7),M=Be(I,D,1)^Be(I,D,8)^ro(I,D,7),E=se[w-2]|0,x=oe[w-2]|0,K=Ee(E,x,19)^Ar(E,x,61)^eo(E,x,6),P=Be(E,x,19)^Sr(E,x,61)^ro(E,x,6),L=na(M,P,oe[w-7],oe[w-16]),m=sa(L,H,K,se[w-7],se[w-16]);se[w]=m|0,oe[w]=L|0}let{Ah:n,Al:s,Bh:o,Bl:i,Ch:c,Cl:a,Dh:l,Dl:f,Eh:u,El:d,Fh:y,Fl:h,Gh:B,Gl:v,Hh:g,Hl:A}=this;for(let w=0;w<80;w++){let I=Ee(u,d,14)^Ee(u,d,18)^Ar(u,d,41),D=Be(u,d,14)^Be(u,d,18)^Sr(u,d,41),H=u&y^~u&B,M=d&h^~d&v,E=oa(A,D,M,sf[w],oe[w]),x=ia(E,g,I,H,nf[w],se[w]),K=E|0,P=Ee(n,s,28)^Ar(n,s,34)^Ar(n,s,39),L=Be(n,s,28)^Sr(n,s,34)^Sr(n,s,39),m=n&o^n&c^o&c,b=s&i^s&a^i&a;g=B|0,A=v|0,B=y|0,v=h|0,y=u|0,h=d|0,{h:u,l:d}=_t(l|0,f|0,x|0,K|0),l=c|0,f=a|0,c=o|0,a=i|0,o=n|0,i=s|0;let p=ea(K,L,b);n=ra(p,x,P,m),s=p|0}({h:n,l:s}=_t(this.Ah|0,this.Al|0,n|0,s|0)),{h:o,l:i}=_t(this.Bh|0,this.Bl|0,o|0,i|0),{h:c,l:a}=_t(this.Ch|0,this.Cl|0,c|0,a|0),{h:l,l:f}=_t(this.Dh|0,this.Dl|0,l|0,f|0),{h:u,l:d}=_t(this.Eh|0,this.El|0,u|0,d|0),{h:y,l:h}=_t(this.Fh|0,this.Fl|0,y|0,h|0),{h:B,l:v}=_t(this.Gh|0,this.Gl|0,B|0,v|0),{h:g,l:A}=_t(this.Hh|0,this.Hl|0,g|0,A|0),this.set(n,s,o,i,c,a,l,f,u,d,y,h,B,v,g,A)}roundClean(){wt(se,oe)}destroy(){wt(this.buffer),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}},io=class extends oo{Ah=ot[0]|0;Al=ot[1]|0;Bh=ot[2]|0;Bl=ot[3]|0;Ch=ot[4]|0;Cl=ot[5]|0;Dh=ot[6]|0;Dl=ot[7]|0;Eh=ot[8]|0;El=ot[9]|0;Fh=ot[10]|0;Fl=ot[11]|0;Gh=ot[12]|0;Gl=ot[13]|0;Hh=ot[14]|0;Hl=ot[15]|0;constructor(){super(64)}};var ie=Br(()=>new so,to(1));var ae=Br(()=>new io,to(3));var co=BigInt(0),ao=BigInt(1);function jt(r,t=""){if(typeof r!="boolean"){let e=t&&`"${t}" `;throw new Error(e+"expected boolean, got type="+typeof r)}return r}function ca(r){if(typeof r=="bigint"){if(!pn(r))throw new Error("positive bigint expected, got "+r)}else bt(r);return r}function kr(r){let t=ca(r).toString(16);return t.length&1?"0"+t:t}function ua(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return r===""?co:BigInt("0x"+r)}function ze(r){return ua(Ft(r))}function Ae(r){return ua(Ft(yn(O(r)).reverse()))}function gn(r,t){bt(t),r=ca(r);let e=qt(r.toString(16).padStart(t*2,"0"));if(e.length!==t)throw new Error("number too large");return e}function uo(r,t){return gn(r,t).reverse()}function yn(r){return Uint8Array.from(r)}var pn=r=>typeof r=="bigint"&&co<=r;function of(r,t,e){return pn(r)&&pn(t)&&pn(e)&&t<=r&&r<e}function Ir(r,t,e,n){if(!of(t,e,n))throw new Error("expected valid "+r+": "+e+" <= n < "+n+", got "+t)}function lo(r){let t;for(t=0;r>co;r>>=ao,t+=1);return t}var Cr=r=>(ao<<BigInt(r))-ao;function la(r,t,e){if(bt(r,"hashLen"),bt(t,"qByteLen"),typeof e!="function")throw new Error("hmacFn must be a function");let n=v=>new Uint8Array(v),s=Uint8Array.of(),o=Uint8Array.of(0),i=Uint8Array.of(1),c=1e3,a=n(r),l=n(r),f=0,u=()=>{a.fill(1),l.fill(0),f=0},d=(...v)=>e(l,xt(a,...v)),y=(v=s)=>{l=d(o,v),a=d(),v.length!==0&&(l=d(i,v),a=d())},h=()=>{if(f++>=c)throw new Error("drbg: tried max amount of iterations");let v=0,g=[];for(;v<t;){a=d();let A=a.slice();g.push(A),v+=a.length}return xt(...g)};return(v,g)=>{u(),y(v);let A;for(;!(A=g(h()));)y();return u(),A}}function ce(r,t={},e={}){if(!r||typeof r!="object")throw new Error("expected valid options object");function n(o,i,c){let a=r[o];if(c&&a===void 0)return;let l=typeof a;if(l!==i||a===null)throw new Error(`param "${o}" is invalid: expected ${i}, got ${l}`)}let s=(o,i)=>Object.entries(o).forEach(([c,a])=>n(c,a,i));s(t,!1),s(e,!0)}function We(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 pt=BigInt(0),rt=BigInt(1),Se=BigInt(2),da=BigInt(3),pa=BigInt(4),ga=BigInt(5),af=BigInt(7),ya=BigInt(8),cf=BigInt(9),ma=BigInt(16);function X(r,t){let e=r%t;return e>=pt?e:t+e}function Z(r,t,e){let n=r;for(;t-- >pt;)n*=n,n%=e;return n}function fa(r,t){if(r===pt)throw new Error("invert: expected non-zero number");if(t<=pt)throw new Error("invert: expected positive modulus, got "+t);let e=X(r,t),n=t,s=pt,o=rt,i=rt,c=pt;for(;e!==pt;){let l=n/e,f=n%e,u=s-i*l,d=o-c*l;n=e,e=f,s=i,o=c,i=u,c=d}if(n!==rt)throw new Error("invert: does not exist");return X(s,t)}function ho(r,t,e){if(!r.eql(r.sqr(t),e))throw new Error("Cannot find square root")}function ba(r,t){let e=(r.ORDER+rt)/pa,n=r.pow(t,e);return ho(r,n,t),n}function uf(r,t){let e=(r.ORDER-ga)/ya,n=r.mul(t,Se),s=r.pow(n,e),o=r.mul(t,s),i=r.mul(r.mul(o,Se),s),c=r.mul(o,r.sub(i,r.ONE));return ho(r,c,t),c}function lf(r){let t=Je(r),e=wa(r),n=e(t,t.neg(t.ONE)),s=e(t,n),o=e(t,t.neg(n)),i=(r+af)/ma;return(c,a)=>{let l=c.pow(a,i),f=c.mul(l,n),u=c.mul(l,s),d=c.mul(l,o),y=c.eql(c.sqr(f),a),h=c.eql(c.sqr(u),a);l=c.cmov(l,f,y),f=c.cmov(d,u,h);let B=c.eql(c.sqr(f),a),v=c.cmov(l,f,B);return ho(c,v,a),v}}function wa(r){if(r<da)throw new Error("sqrt is not defined for small field");let t=r-rt,e=0;for(;t%Se===pt;)t/=Se,e++;let n=Se,s=Je(r);for(;ha(s,n)===1;)if(n++>1e3)throw new Error("Cannot find square root: probably non-prime P");if(e===1)return ba;let o=s.pow(n,t),i=(t+rt)/Se;return function(a,l){if(a.is0(l))return l;if(ha(a,l)!==1)throw new Error("Cannot find square root");let f=e,u=a.mul(a.ONE,o),d=a.pow(l,t),y=a.pow(l,i);for(;!a.eql(d,a.ONE);){if(a.is0(d))return a.ZERO;let h=1,B=a.sqr(d);for(;!a.eql(B,a.ONE);)if(h++,B=a.sqr(B),h===f)throw new Error("Cannot find square root");let v=rt<<BigInt(f-h-1),g=a.pow(u,v);f=h,u=a.sqr(g),d=a.mul(d,u),y=a.mul(y,g)}return y}}function ff(r){return r%pa===da?ba:r%ya===ga?uf:r%ma===cf?lf(r):wa(r)}var xa=(r,t)=>(X(r,t)&rt)===rt,hf=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function po(r){let t={ORDER:"bigint",BYTES:"number",BITS:"number"},e=hf.reduce((n,s)=>(n[s]="function",n),t);return ce(r,e),r}function df(r,t,e){if(e<pt)throw new Error("invalid exponent, negatives unsupported");if(e===pt)return r.ONE;if(e===rt)return t;let n=r.ONE,s=t;for(;e>pt;)e&rt&&(n=r.mul(n,s)),s=r.sqr(s),e>>=rt;return n}function Nr(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 ha(r,t){let e=(r.ORDER-rt)/Se,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 pf(r,t){t!==void 0&&bt(t);let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}var fo=class{ORDER;BITS;BYTES;isLE;ZERO=pt;ONE=rt;_lengths;_sqrt;_mod;constructor(t,e={}){if(t<=pt)throw new Error("invalid field: expected ORDER > 0, got "+t);let n;this.isLE=!1,e!=null&&typeof e=="object"&&(typeof e.BITS=="number"&&(n=e.BITS),typeof e.sqrt=="function"&&(this.sqrt=e.sqrt),typeof e.isLE=="boolean"&&(this.isLE=e.isLE),e.allowedLengths&&(this._lengths=e.allowedLengths?.slice()),typeof e.modFromBytes=="boolean"&&(this._mod=e.modFromBytes));let{nBitLength:s,nByteLength:o}=pf(t,n);if(o>2048)throw new Error("invalid field: expected ORDER of <= 2048 bytes");this.ORDER=t,this.BITS=s,this.BYTES=o,this._sqrt=void 0,Object.preventExtensions(this)}create(t){return X(t,this.ORDER)}isValid(t){if(typeof t!="bigint")throw new Error("invalid field element: expected bigint, got "+typeof t);return pt<=t&&t<this.ORDER}is0(t){return t===pt}isValidNot0(t){return!this.is0(t)&&this.isValid(t)}isOdd(t){return(t&rt)===rt}neg(t){return X(-t,this.ORDER)}eql(t,e){return t===e}sqr(t){return X(t*t,this.ORDER)}add(t,e){return X(t+e,this.ORDER)}sub(t,e){return X(t-e,this.ORDER)}mul(t,e){return X(t*e,this.ORDER)}pow(t,e){return df(this,t,e)}div(t,e){return X(t*fa(e,this.ORDER),this.ORDER)}sqrN(t){return t*t}addN(t,e){return t+e}subN(t,e){return t-e}mulN(t,e){return t*e}inv(t){return fa(t,this.ORDER)}sqrt(t){return this._sqrt||(this._sqrt=ff(this.ORDER)),this._sqrt(this,t)}toBytes(t){return this.isLE?uo(t,this.BYTES):gn(t,this.BYTES)}fromBytes(t,e=!1){O(t);let{_lengths:n,BYTES:s,isLE:o,ORDER:i,_mod:c}=this;if(n){if(!n.includes(t.length)||t.length>s)throw new Error("Field.fromBytes: expected "+n+" bytes, got "+t.length);let l=new Uint8Array(s);l.set(t,o?0:l.length-t.length),t=l}if(t.length!==s)throw new Error("Field.fromBytes: expected "+s+" bytes, got "+t.length);let a=o?Ae(t):ze(t);if(c&&(a=X(a,i)),!e&&!this.isValid(a))throw new Error("invalid field element: outside of range 0..ORDER");return a}invertBatch(t){return Nr(this,t)}cmov(t,e,n){return n?e:t}};function Je(r,t={}){return new fo(r,t)}function va(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 go(r){let t=va(r);return t+Math.ceil(t/2)}function yo(r,t,e=!1){O(r);let n=r.length,s=va(t),o=go(t);if(n<16||n<o||n>1024)throw new Error("expected "+o+"-1024 bytes of input, got "+n);let i=e?Ae(r):ze(r),c=X(i,t-rt)+rt;return e?uo(c,s):gn(c,s)}var Xe=BigInt(0),ke=BigInt(1);function Ur(r,t){let e=t.negate();return r?e:t}function Ie(r,t){let e=Nr(r.Fp,t.map(n=>n.Z));return t.map((n,s)=>r.fromAffine(n.toAffine(e[s])))}function Sa(r,t){if(!Number.isSafeInteger(r)||r<=0||r>t)throw new Error("invalid window size, expected [1.."+t+"], got W="+r)}function mo(r,t){Sa(r,t);let e=Math.ceil(t/r)+1,n=2**(r-1),s=2**r,o=Cr(r),i=BigInt(r);return{windows:e,windowSize:n,mask:o,maxNumber:s,shiftBy:i}}function Ea(r,t,e){let{windowSize:n,mask:s,maxNumber:o,shiftBy:i}=e,c=Number(r&s),a=r>>i;c>n&&(c-=o,a+=ke);let l=t*n,f=l+Math.abs(c)-1,u=c===0,d=c<0,y=t%2!==0;return{nextN:a,offset:f,isZero:u,isNeg:d,isNegF:y,offsetF:l}}var bo=new WeakMap,ka=new WeakMap;function wo(r){return ka.get(r)||1}function Ba(r){if(r!==Xe)throw new Error("invalid wNAF")}var Qe=class{BASE;ZERO;Fn;bits;constructor(t,e){this.BASE=t.BASE,this.ZERO=t.ZERO,this.Fn=t.Fn,this.bits=e}_unsafeLadder(t,e,n=this.ZERO){let s=t;for(;e>Xe;)e&ke&&(n=n.add(s)),s=s.double(),e>>=ke;return n}precomputeWindow(t,e){let{windows:n,windowSize:s}=mo(e,this.bits),o=[],i=t,c=i;for(let a=0;a<n;a++){c=i,o.push(c);for(let l=1;l<s;l++)c=c.add(i),o.push(c);i=c.double()}return o}wNAF(t,e,n){if(!this.Fn.isValid(n))throw new Error("invalid scalar");let s=this.ZERO,o=this.BASE,i=mo(t,this.bits);for(let c=0;c<i.windows;c++){let{nextN:a,offset:l,isZero:f,isNeg:u,isNegF:d,offsetF:y}=Ea(n,c,i);n=a,f?o=o.add(Ur(d,e[y])):s=s.add(Ur(u,e[l]))}return Ba(n),{p:s,f:o}}wNAFUnsafe(t,e,n,s=this.ZERO){let o=mo(t,this.bits);for(let i=0;i<o.windows&&n!==Xe;i++){let{nextN:c,offset:a,isZero:l,isNeg:f}=Ea(n,i,o);if(n=c,!l){let u=e[a];s=s.add(f?u.negate():u)}}return Ba(n),s}getPrecomputes(t,e,n){let s=bo.get(e);return s||(s=this.precomputeWindow(e,t),t!==1&&(typeof n=="function"&&(s=n(s)),bo.set(e,s))),s}cached(t,e,n){let s=wo(t);return this.wNAF(s,this.getPrecomputes(s,t,n),e)}unsafe(t,e,n,s){let o=wo(t);return o===1?this._unsafeLadder(t,e,s):this.wNAFUnsafe(o,this.getPrecomputes(o,t,n),e,s)}createCache(t,e){Sa(e,this.bits),ka.set(t,e),bo.delete(t)}hasCache(t){return wo(t)!==1}};function Ia(r,t,e,n){let s=t,o=r.ZERO,i=r.ZERO;for(;e>Xe||n>Xe;)e&ke&&(o=o.add(s)),n&ke&&(i=i.add(s)),s=s.double(),e>>=ke,n>>=ke;return{p1:o,p2:i}}function Aa(r,t,e){if(t){if(t.ORDER!==r)throw new Error("Field.ORDER must match order: Fp == p, Fn == n");return po(t),t}else return Je(r,{isLE:e})}function mn(r,t,e={},n){if(n===void 0&&(n=r==="edwards"),!t||typeof t!="object")throw new Error(`expected valid ${r} CURVE object`);for(let a of["p","n","h"]){let l=t[a];if(!(typeof l=="bigint"&&l>Xe))throw new Error(`CURVE.${a} must be positive bigint`)}let s=Aa(t.p,e.Fp,n),o=Aa(t.n,e.Fn,n),c=["Gx","Gy","a",r==="weierstrass"?"b":"d"];for(let a of c)if(!s.isValid(t[a]))throw new Error(`CURVE.${a} must be valid field element of CURVE.Fp`);return t=Object.freeze(Object.assign({},t)),{CURVE:t,Fp:s,Fn:o}}function bn(r,t){return function(n){let s=r(n);return{secretKey:s,publicKey:t(s)}}}var ue=BigInt(0),nt=BigInt(1),xo=BigInt(2),gf=BigInt(8);function yf(r,t,e,n){let s=r.sqr(e),o=r.sqr(n),i=r.add(r.mul(t.a,s),o),c=r.add(r.ONE,r.mul(t.d,r.mul(s,o)));return r.eql(i,c)}function Ca(r,t={}){let e=mn("edwards",r,t,t.FpFnLE),{Fp:n,Fn:s}=e,o=e.CURVE,{h:i}=o;ce(t,{},{uvRatio:"function"});let c=xo<<BigInt(s.BYTES*8)-nt,a=v=>n.create(v),l=t.uvRatio||((v,g)=>{try{return{isValid:!0,value:n.sqrt(n.div(v,g))}}catch{return{isValid:!1,value:ue}}});if(!yf(n,o,o.Gx,o.Gy))throw new Error("bad curve params: generator point");function f(v,g,A=!1){let w=A?nt:ue;return Ir("coordinate "+v,g,w,c),g}function u(v){if(!(v instanceof h))throw new Error("EdwardsPoint expected")}let d=We((v,g)=>{let{X:A,Y:w,Z:I}=v,D=v.is0();g==null&&(g=D?gf:n.inv(I));let H=a(A*g),M=a(w*g),E=n.mul(I,g);if(D)return{x:ue,y:nt};if(E!==nt)throw new Error("invZ was invalid");return{x:H,y:M}}),y=We(v=>{let{a:g,d:A}=o;if(v.is0())throw new Error("bad point: ZERO");let{X:w,Y:I,Z:D,T:H}=v,M=a(w*w),E=a(I*I),x=a(D*D),K=a(x*x),P=a(M*g),L=a(x*a(P+E)),m=a(K+a(A*a(M*E)));if(L!==m)throw new Error("bad point: equation left != right (1)");let b=a(w*I),p=a(D*H);if(b!==p)throw new Error("bad point: equation left != right (2)");return!0});class h{static BASE=new h(o.Gx,o.Gy,nt,a(o.Gx*o.Gy));static ZERO=new h(ue,nt,nt,ue);static Fp=n;static Fn=s;X;Y;Z;T;constructor(g,A,w,I){this.X=f("x",g),this.Y=f("y",A),this.Z=f("z",w,!0),this.T=f("t",I),Object.freeze(this)}static CURVE(){return o}static fromAffine(g){if(g instanceof h)throw new Error("extended point not allowed");let{x:A,y:w}=g||{};return f("x",A),f("y",w),new h(A,w,nt,a(A*w))}static fromBytes(g,A=!1){let w=n.BYTES,{a:I,d:D}=o;g=yn(O(g,w,"point")),jt(A,"zip215");let H=yn(g),M=g[w-1];H[w-1]=M&-129;let E=Ae(H),x=A?c:n.ORDER;Ir("point.y",E,ue,x);let K=a(E*E),P=a(K-nt),L=a(D*K-I),{isValid:m,value:b}=l(P,L);if(!m)throw new Error("bad point: invalid y coordinate");let p=(b&nt)===nt,S=(M&128)!==0;if(!A&&b===ue&&S)throw new Error("bad point: x=0 and x_0=1");return S!==p&&(b=a(-b)),h.fromAffine({x:b,y:E})}static fromHex(g,A=!1){return h.fromBytes(qt(g),A)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}precompute(g=8,A=!0){return B.createCache(this,g),A||this.multiply(xo),this}assertValidity(){y(this)}equals(g){u(g);let{X:A,Y:w,Z:I}=this,{X:D,Y:H,Z:M}=g,E=a(A*M),x=a(D*I),K=a(w*M),P=a(H*I);return E===x&&K===P}is0(){return this.equals(h.ZERO)}negate(){return new h(a(-this.X),this.Y,this.Z,a(-this.T))}double(){let{a:g}=o,{X:A,Y:w,Z:I}=this,D=a(A*A),H=a(w*w),M=a(xo*a(I*I)),E=a(g*D),x=A+w,K=a(a(x*x)-D-H),P=E+H,L=P-M,m=E-H,b=a(K*L),p=a(P*m),S=a(K*m),C=a(L*P);return new h(b,p,C,S)}add(g){u(g);let{a:A,d:w}=o,{X:I,Y:D,Z:H,T:M}=this,{X:E,Y:x,Z:K,T:P}=g,L=a(I*E),m=a(D*x),b=a(M*w*P),p=a(H*K),S=a((I+D)*(E+x)-L-m),C=p-b,U=p+b,T=a(m-A*L),N=a(S*C),_=a(U*T),V=a(S*T),Y=a(C*U);return new h(N,_,Y,V)}subtract(g){return this.add(g.negate())}multiply(g){if(!s.isValidNot0(g))throw new Error("invalid scalar: expected 1 <= sc < curve.n");let{p:A,f:w}=B.cached(this,g,I=>Ie(h,I));return Ie(h,[A,w])[0]}multiplyUnsafe(g,A=h.ZERO){if(!s.isValid(g))throw new Error("invalid scalar: expected 0 <= sc < curve.n");return g===ue?h.ZERO:this.is0()||g===nt?this:B.unsafe(this,g,w=>Ie(h,w),A)}isSmallOrder(){return this.multiplyUnsafe(i).is0()}isTorsionFree(){return B.unsafe(this,o.n).is0()}toAffine(g){return d(this,g)}clearCofactor(){return i===nt?this:this.multiplyUnsafe(i)}toBytes(){let{x:g,y:A}=this.toAffine(),w=n.toBytes(A);return w[w.length-1]|=g&nt?128:0,w}toHex(){return Ft(this.toBytes())}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}}let B=new Qe(h,s.BITS);return h.BASE.precompute(8),h}function Na(r,t,e={}){if(typeof t!="function")throw new Error('"hash" function param is required');ce(e,{},{adjustScalarBytes:"function",randomBytes:"function",domain:"function",prehash:"function",mapToCurve:"function"});let{prehash:n}=e,{BASE:s,Fp:o,Fn:i}=r,c=e.randomBytes||re,a=e.adjustScalarBytes||(E=>E),l=e.domain||((E,x,K)=>{if(jt(K,"phflag"),x.length||K)throw new Error("Contexts/pre-hash are not supported");return E});function f(E){return i.create(Ae(E))}function u(E){let x=w.secretKey;O(E,w.secretKey,"secretKey");let K=O(t(E),2*x,"hashedSecretKey"),P=a(K.slice(0,x)),L=K.slice(x,2*x),m=f(P);return{head:P,prefix:L,scalar:m}}function d(E){let{head:x,prefix:K,scalar:P}=u(E),L=s.multiply(P),m=L.toBytes();return{head:x,prefix:K,scalar:P,point:L,pointBytes:m}}function y(E){return d(E).pointBytes}function h(E=Uint8Array.of(),...x){let K=xt(...x);return f(t(l(K,O(E,void 0,"context"),!!n)))}function B(E,x,K={}){E=O(E,void 0,"message"),n&&(E=n(E));let{prefix:P,scalar:L,pointBytes:m}=d(x),b=h(K.context,P,E),p=s.multiply(b).toBytes(),S=h(K.context,p,m,E),C=i.create(b+S*L);if(!i.isValid(C))throw new Error("sign failed: invalid s");let U=xt(p,i.toBytes(C));return O(U,w.signature,"result")}let v={zip215:!0};function g(E,x,K,P=v){let{context:L,zip215:m}=P,b=w.signature;E=O(E,b,"signature"),x=O(x,void 0,"message"),K=O(K,w.publicKey,"publicKey"),m!==void 0&&jt(m,"zip215"),n&&(x=n(x));let p=b/2,S=E.subarray(0,p),C=Ae(E.subarray(p,b)),U,T,N;try{U=r.fromBytes(K,m),T=r.fromBytes(S,m),N=s.multiplyUnsafe(C)}catch{return!1}if(!m&&U.isSmallOrder())return!1;let _=h(L,T.toBytes(),U.toBytes(),x);return T.add(U.multiplyUnsafe(_)).subtract(N).clearCofactor().is0()}let A=o.BYTES,w={secretKey:A,publicKey:A,signature:2*A,seed:A};function I(E=c(w.seed)){return O(E,w.seed,"seed")}function D(E){return we(E)&&E.length===i.BYTES}function H(E,x){try{return!!r.fromBytes(E,x)}catch{return!1}}let M={getExtendedPublicKey:d,randomSecretKey:I,isValidSecretKey:D,isValidPublicKey:H,toMontgomery(E){let{y:x}=r.fromBytes(E),K=w.publicKey,P=K===32;if(!P&&K!==57)throw new Error("only defined for 25519 and 448");let L=P?o.div(nt+x,nt-x):o.div(x-nt,x+nt);return o.toBytes(L)},toMontgomerySecret(E){let x=w.secretKey;O(E,x);let K=t(E.subarray(0,x));return a(K).subarray(0,x)}};return Object.freeze({keygen:bn(I,y),getPublicKey:y,sign:B,verify:g,utils:M,Point:r,lengths:w})}var mf=BigInt(1),Ua=BigInt(2);var bf=BigInt(5),wf=BigInt(8),vo=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffed"),xf={p:vo,n:BigInt("0x1000000000000000000000000000000014def9dea2f79cd65812631a5cf5d3ed"),h:wf,a:BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffec"),d:BigInt("0x52036cee2b6ffe738cc740797779e89800700a4d4141d8ab75eb4dca135978a3"),Gx:BigInt("0x216936d3cd6e53fec0a4e231fdd6dc5c692cc7609525a7b2c9562d608f25d51a"),Gy:BigInt("0x6666666666666666666666666666666666666666666666666666666666666658")};function vf(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),s=BigInt(80),o=vo,c=r*r%o*r%o,a=Z(c,Ua,o)*c%o,l=Z(a,mf,o)*r%o,f=Z(l,bf,o)*l%o,u=Z(f,t,o)*f%o,d=Z(u,e,o)*u%o,y=Z(d,n,o)*d%o,h=Z(y,s,o)*y%o,B=Z(h,s,o)*y%o,v=Z(B,t,o)*f%o;return{pow_p_5_8:Z(v,Ua,o)*r%o,b2:c}}function Ef(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}var La=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752");function Bf(r,t){let e=vo,n=X(t*t*t,e),s=X(n*n*t,e),o=vf(r*s).pow_p_5_8,i=X(r*n*o,e),c=X(t*i*i,e),a=i,l=X(i*La,e),f=c===r,u=c===X(-r,e),d=c===X(-r*La,e);return f&&(i=a),(u||d)&&(i=l),xa(i,e)&&(i=X(-i,e)),{isValid:f||u,value:i}}var Af=Ca(xf,{uvRatio:Bf});function Sf(r){return Na(Af,ae,Object.assign({adjustScalarBytes:Ef},r))}var Eo=Sf({});var er=32,kt=64,kf=32;var tr,Ta=(async()=>{try{return await Q.get().subtle.generateKey({name:"Ed25519"},!0,["sign","verify"]),!0}catch{return!1}})();async function If(r,t){let e;r.length===kt?e=r.subarray(0,32):e=r;let n={crv:"Ed25519",kty:"OKP",x:$(r.subarray(32),"base64url"),d:$(e,"base64url"),ext:!0,key_ops:["sign"]},s=await Q.get().subtle.importKey("jwk",n,{name:"Ed25519"},!0,["sign"]),o=await Q.get().subtle.sign({name:"Ed25519"},s,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(o,0,o.byteLength)}function Cf(r,t){let e=r.subarray(0,kf);return Eo.sign(t instanceof Uint8Array?t:t.subarray(),e)}async function Ra(r,t){return tr==null&&(tr=await Ta),tr?If(r,t):Cf(r,t)}async function Nf(r,t,e){if(r.buffer instanceof ArrayBuffer){let n=await Q.get().subtle.importKey("raw",r.buffer,{name:"Ed25519"},!1,["verify"]);return await Q.get().subtle.verify({name:"Ed25519"},n,t,e instanceof Uint8Array?e:e.subarray())}throw new TypeError("WebCrypto does not support SharedArrayBuffer for Ed25519 keys")}function Uf(r,t,e){return Eo.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}async function _a(r,t,e){return tr==null&&(tr=await Ta),tr?Nf(r,t,e):Uf(r,t,e)}function rr(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}var wn=class{type="Ed25519";raw;constructor(t){this.raw=Tr(t,er)}toMultihash(){return me.digest(Ge(this))}toCID(){return St.createV1(114,this.toMultihash())}toString(){return tt.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:mt(this.raw,t.raw)}verify(t,e,n){n?.signal?.throwIfAborted();let s=_a(this.raw,e,t);return rr(s)?s.then(o=>(n?.signal?.throwIfAborted(),o)):s}},Lr=class{type="Ed25519";raw;publicKey;constructor(t,e){this.raw=Tr(t,kt),this.publicKey=new wn(e)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:mt(this.raw,t.raw)}sign(t,e){e?.signal?.throwIfAborted();let n=Ra(this.raw,t);return rr(n)?n.then(s=>(e?.signal?.throwIfAborted(),s)):(e?.signal?.throwIfAborted(),n)}};function Bo(r){if(r.length>kt){r=Tr(r,kt+er);let n=r.subarray(0,kt),s=r.subarray(kt,r.length);return new Lr(n,s)}r=Tr(r,kt);let t=r.subarray(0,kt),e=r.subarray(er);return new Lr(t,e)}function Tr(r,t){if(r=Uint8Array.from(r??[]),r.length!==t)throw new R(`Key must be a Uint8Array of length ${t}, got ${r.length}`);return r}var Lf=Math.pow(2,7),Tf=Math.pow(2,14),Rf=Math.pow(2,21),Ka=Math.pow(2,28),Va=Math.pow(2,35),Oa=Math.pow(2,42),Ha=Math.pow(2,49),gt=128,le=127;function Rr(r){if(r<Lf)return 1;if(r<Tf)return 2;if(r<Rf)return 3;if(r<Ka)return 4;if(r<Va)return 5;if(r<Oa)return 6;if(r<Ha)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function Ma(r,t,e=0){switch(Rr(r)){case 8:t[e++]=r&255|gt,r/=128;case 7:t[e++]=r&255|gt,r/=128;case 6:t[e++]=r&255|gt,r/=128;case 5:t[e++]=r&255|gt,r/=128;case 4:t[e++]=r&255|gt,r>>>=7;case 3:t[e++]=r&255|gt,r>>>=7;case 2:t[e++]=r&255|gt,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function Pa(r,t){let e=r[t],n=0;if(n+=e&le,e<gt||(e=r[t+1],n+=(e&le)<<7,e<gt)||(e=r[t+2],n+=(e&le)<<14,e<gt)||(e=r[t+3],n+=(e&le)<<21,e<gt)||(e=r[t+4],n+=(e&le)*Ka,e<gt)||(e=r[t+5],n+=(e&le)*Va,e<gt)||(e=r[t+6],n+=(e&le)*Oa,e<gt)||(e=r[t+7],n+=(e&le)*Ha,e<gt))return n;throw new RangeError("Could not decode varint")}var Ao=new Float32Array([-0]),fe=new Uint8Array(Ao.buffer);function Fa(r,t,e){Ao[0]=r,t[e]=fe[0],t[e+1]=fe[1],t[e+2]=fe[2],t[e+3]=fe[3]}function qa(r,t){return fe[0]=r[t],fe[1]=r[t+1],fe[2]=r[t+2],fe[3]=r[t+3],Ao[0]}var So=new Float64Array([-0]),ut=new Uint8Array(So.buffer);function $a(r,t,e){So[0]=r,t[e]=ut[0],t[e+1]=ut[1],t[e+2]=ut[2],t[e+3]=ut[3],t[e+4]=ut[4],t[e+5]=ut[5],t[e+6]=ut[6],t[e+7]=ut[7]}function ja(r,t){return ut[0]=r[t],ut[1]=r[t+1],ut[2]=r[t+2],ut[3]=r[t+3],ut[4]=r[t+4],ut[5]=r[t+5],ut[6]=r[t+6],ut[7]=r[t+7],So[0]}var _f=BigInt(Number.MAX_SAFE_INTEGER),Df=BigInt(Number.MIN_SAFE_INTEGER),At=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 Ce;if(t<_f&&t>Df)return this.fromNumber(Number(t));let e=t<0n;e&&(t=-t);let n=t>>32n,s=t-(n<<32n);return e&&(n=~n|0n,s=~s|0n,++s>Ga&&(s=0n,++n>Ga&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(t){if(t===0)return Ce;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):Ce}},Ce=new At(0,0);Ce.toBigInt=function(){return 0n};Ce.zzEncode=Ce.zzDecode=function(){return this};Ce.length=function(){return 1};var Ga=4294967296n;function Za(r){let t=0,e=0;for(let n=0;n<r.length;++n)e=r.charCodeAt(n),e<128?t+=1:e<2048?t+=2:(e&64512)===55296&&(r.charCodeAt(n+1)&64512)===56320?(++n,t+=4):t+=3;return t}function Ya(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 ko(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 Lt(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function xn(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var Io=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,Lt(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 Lt(this,4);return xn(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Lt(this,4);return xn(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Lt(this,4);let t=qa(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Lt(this,4);let t=ja(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 Lt(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return Ya(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw Lt(this,t);this.pos+=t}else do if(this.pos>=this.len)throw Lt(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 At(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 Lt(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 Lt(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 Lt(this,8);let t=xn(this.buf,this.pos+=4),e=xn(this.buf,this.pos+=4);return new At(t,e)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){let t=Pa(this.buf,this.pos);return this.pos+=Rr(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 Co(r){return new Io(r instanceof Uint8Array?r:r.subarray())}function vn(r,t,e){let n=Co(r);return t.decode(n,void 0,e)}function No(r){let t=r??8192,e=t>>>1,n,s=t;return function(i){if(i<1||i>e)return Bt(i);s+i>t&&(n=Bt(t),s=0);let c=n.subarray(s,s+=i);return(s&7)!==0&&(s=(s|7)+1),c}}var Ne=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function Uo(){}var To=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},Kf=No();function Vf(r){return globalThis.Buffer!=null?Bt(r):Kf(r)}var Dr=class{len;head;tail;states;constructor(){this.len=0,this.head=new Ne(Uo,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new Ne(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new Ro((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(En,10,At.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=At.fromBigInt(t);return this._push(En,e.length(),e)}uint64Number(t){return this._push(Ma,Rr(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=At.fromBigInt(t).zzEncode();return this._push(En,e.length(),e)}sint64Number(t){let e=At.fromNumber(t).zzEncode();return this._push(En,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(Lo,1,t?1:0)}fixed32(t){return this._push(_r,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=At.fromBigInt(t);return this._push(_r,4,e.lo)._push(_r,4,e.hi)}fixed64Number(t){let e=At.fromNumber(t);return this._push(_r,4,e.lo)._push(_r,4,e.hi)}fixed64String(t){return this.fixed64(BigInt(t))}sfixed64(t){return this.fixed64(t)}sfixed64Number(t){return this.fixed64Number(t)}sfixed64String(t){return this.fixed64String(t)}float(t){return this._push(Fa,4,t)}double(t){return this._push($a,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(Lo,1,0):this.uint32(e)._push(Hf,e,t)}string(t){let e=Za(t);return e!==0?this.uint32(e)._push(ko,e,t):this._push(Lo,1,0)}fork(){return this.states=new To(this),this.head=this.tail=new Ne(Uo,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 Ne(Uo,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=Vf(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function Lo(r,t,e){t[e]=r&255}function Of(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var Ro=class extends Ne{next;constructor(t,e){super(Of,t,e),this.next=void 0}};function En(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 _r(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 Hf(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(Dr.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(Mf,t,r),this},Dr.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(Pf,t,r),this});function Mf(r,t,e){t.set(r,e)}function Pf(r,t,e){r.length<40?ko(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(F(r),e)}function _o(){return new Dr}function Bn(r,t){let e=_o();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var nr;(function(r){r[r.VARINT=0]="VARINT",r[r.BIT64=1]="BIT64",r[r.LENGTH_DELIMITED=2]="LENGTH_DELIMITED",r[r.START_GROUP=3]="START_GROUP",r[r.END_GROUP=4]="END_GROUP",r[r.BIT32=5]="BIT32"})(nr||(nr={}));function An(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function Do(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 An("enum",nr.VARINT,e,n)}function Sn(r,t){return An("message",nr.LENGTH_DELIMITED,r,t)}var et;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.secp256k1="secp256k1",r.ECDSA="ECDSA"})(et||(et={}));var Ko;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1",r[r.ECDSA=3]="ECDSA"})(Ko||(Ko={}));(function(r){r.codec=()=>Do(Ko)})(et||(et={}));var he;(function(r){let t;r.codec=()=>(t==null&&(t=Sn((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),et.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=et.codec().decode(e);break}case 2:{o.Data=e.bytes();break}default:{e.skipType(c&7);break}}}return o})),t),r.encode=e=>Bn(e,r.codec()),r.decode=(e,n)=>vn(e,r.codec(),n)})(he||(he={}));var Kr;(function(r){let t;r.codec=()=>(t==null&&(t=Sn((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),et.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=et.codec().decode(e);break}case 2:{o.Data=e.bytes();break}default:{e.skipType(c&7);break}}}return o})),t),r.encode=e=>Bn(e,r.codec()),r.decode=(e,n)=>vn(e,r.codec(),n)})(Kr||(Kr={}));function Ue(r){if(isNaN(r)||r<=0)throw new R("random bytes length must be a Number bigger than 0");return re(r)}var Or={};ft(Or,{MAX_RSA_KEY_SIZE:()=>Vo,generateRSAKeyPair:()=>tc,jwkToJWKKeyPair:()=>ec,jwkToPkcs1:()=>jf,jwkToPkix:()=>Po,jwkToRSAPrivateKey:()=>$o,pkcs1MessageToJwk:()=>Ho,pkcs1MessageToRSAPrivateKey:()=>kn,pkcs1ToJwk:()=>$f,pkcs1ToRSAPrivateKey:()=>Fo,pkixMessageToJwk:()=>Mo,pkixMessageToRSAPublicKey:()=>qo,pkixToJwk:()=>Gf,pkixToRSAPublicKey:()=>Qa});var sr=class{type="RSA";jwk;_raw;_multihash;constructor(t,e){this.jwk=t,this._multihash=e}get raw(){return this._raw==null&&(this._raw=Or.jwkToPkix(this.jwk)),this._raw}toMultihash(){return this._multihash}toCID(){return St.createV1(114,this._multihash)}toString(){return tt.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:mt(this.raw,t.raw)}verify(t,e,n){return Xa(this.jwk,e,t,n)}},Vr=class{type="RSA";jwk;_raw;publicKey;constructor(t,e){this.jwk=t,this.publicKey=e}get raw(){return this._raw==null&&(this._raw=Or.jwkToPkcs1(this.jwk)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:mt(this.raw,t.raw)}sign(t,e){return Ja(this.jwk,t,e)}};var Vo=8192,Oo=18,Ff=1062,qf=Uint8Array.from([48,13,6,9,42,134,72,134,247,13,1,1,1,5,0]);function $f(r){let t=Ct(r);return Ho(t)}function Ho(r){return{n:$(r[1],"base64url"),e:$(r[2],"base64url"),d:$(r[3],"base64url"),p:$(r[4],"base64url"),q:$(r[5],"base64url"),dp:$(r[6],"base64url"),dq:$(r[7],"base64url"),qi:$(r[8],"base64url"),kty:"RSA"}}function jf(r){if(r.n==null||r.e==null||r.d==null||r.p==null||r.q==null||r.dp==null||r.dq==null||r.qi==null)throw new R("JWK was missing components");return Nt([dt(Uint8Array.from([0])),dt(F(r.n,"base64url")),dt(F(r.e,"base64url")),dt(F(r.d,"base64url")),dt(F(r.p,"base64url")),dt(F(r.q,"base64url")),dt(F(r.dp,"base64url")),dt(F(r.dq,"base64url")),dt(F(r.qi,"base64url"))]).subarray()}function Gf(r){let t=Ct(r,{offset:0});return Mo(t)}function Mo(r){let t=Ct(r[1],{offset:0});return{kty:"RSA",n:$(t[0],"base64url"),e:$(t[1],"base64url")}}function Po(r){if(r.n==null||r.e==null)throw new R("JWK was missing components");return Nt([qf,Er(Nt([dt(F(r.n,"base64url")),dt(F(r.e,"base64url"))]))]).subarray()}function Fo(r){let t=Ct(r);return kn(t)}function kn(r){let t=Ho(r);return $o(t)}function Qa(r,t){if(r.byteLength>=Ff)throw new Ke("Key size is too large");let e=Ct(r,{offset:0});return qo(e,r,t)}function qo(r,t,e){let n=Mo(r);if(e==null){let s=ie(he.encode({Type:et.RSA,Data:t}));e=Rt(Oo,s)}return new sr(n,e)}function $o(r){if(nc(r)>Vo)throw new R("Key size is too large");let t=ec(r),e=ie(he.encode({Type:et.RSA,Data:Po(t.publicKey)})),n=Rt(Oo,e);return new Vr(t.privateKey,new sr(t.publicKey,n))}async function tc(r){if(r>Vo)throw new R("Key size is too large");let t=await rc(r),e=ie(he.encode({Type:et.RSA,Data:Po(t.publicKey)})),n=Rt(Oo,e);return new Vr(t.privateKey,new sr(t.publicKey,n))}function ec(r){if(r==null)throw new R("Missing key parameter");return{privateKey:r,publicKey:{kty:r.kty,n:r.n,e:r.e}}}async function rc(r,t){let e=await Q.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 Zf(e,t);return{privateKey:n[0],publicKey:n[1]}}async function Ja(r,t,e){let n=await Q.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]);e?.signal?.throwIfAborted();let s=await Q.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 Xa(r,t,e,n){let s=await Q.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);n?.signal?.throwIfAborted();let o=await Q.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},s,t,e instanceof Uint8Array?e:e.subarray());return n?.signal?.throwIfAborted(),o}async function Zf(r,t){if(r.privateKey==null||r.publicKey==null)throw new R("Private and public key are required");let e=await Promise.all([Q.get().subtle.exportKey("jwk",r.privateKey),Q.get().subtle.exportKey("jwk",r.publicKey)]);return t?.signal?.throwIfAborted(),e}function nc(r){if(r.kty!=="RSA")throw new R("invalid key type");if(r.n==null)throw new R("invalid key modulus");return F(r.n,"base64url").length*8}var In=class{oHash;iHash;blockLen;outputLen;finished=!1;destroyed=!1;constructor(t,e){if(Ze(t),O(e,void 0,"key"),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 n=this.blockLen,s=new Uint8Array(n);s.set(e.length>n?t.create().update(e).digest():e);for(let o=0;o<s.length;o++)s[o]^=54;this.iHash.update(s),this.oHash=t.create();for(let o=0;o<s.length;o++)s[o]^=106;this.oHash.update(s),wt(s)}update(t){return Ye(this),this.iHash.update(t),this}digestInto(t){Ye(this),O(t,this.outputLen,"output"),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||=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()}},Hr=(r,t,e)=>new In(r,t).update(e).digest();Hr.create=(r,t)=>new In(r,t);var sc=(r,t)=>(r+(r>=0?t:-t)/oc)/t;function Yf(r,t,e){let[[n,s],[o,i]]=t,c=sc(i*r,e),a=sc(-s*r,e),l=r-c*n-a*o,f=-c*s-a*i,u=l<Gt,d=f<Gt;u&&(l=-l),d&&(f=-f);let y=Cr(Math.ceil(lo(e)/2))+or;if(l<Gt||l>=y||f<Gt||f>=y)throw new Error("splitScalar (endomorphism): failed, k="+r);return{k1neg:u,k1:l,k2neg:d,k2:f}}function Go(r){if(!["compact","recovered","der"].includes(r))throw new Error('Signature format must be "compact", "recovered", or "der"');return r}function jo(r,t){let e={};for(let n of Object.keys(t))e[n]=r[n]===void 0?t[n]:r[n];return jt(e.lowS,"lowS"),jt(e.prehash,"prehash"),e.format!==void 0&&Go(e.format),e}var Zo=class extends Error{constructor(t=""){super(t)}},de={Err:Zo,_tlv:{encode:(r,t)=>{let{Err:e}=de;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=kr(n);if(s.length/2&128)throw new e("tlv.encode: long form length too big");let o=n>127?kr(s.length/2|128):"";return kr(r)+o+s+t},decode(r,t){let{Err:e}=de,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 l=t.subarray(n,n+a);if(l.length!==a)throw new e("tlv.decode: length bytes not complete");if(l[0]===0)throw new e("tlv.decode(long): zero leftmost byte");for(let f of l)i=i<<8|f;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}=de;if(r<Gt)throw new t("integer: negative integers are not allowed");let e=kr(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}=de;if(r[0]&128)throw new t("invalid signature integer: negative");if(r[0]===0&&!(r[1]&128))throw new t("invalid signature integer: unnecessary leading zero");return ze(r)}},toSig(r){let{Err:t,_int:e,_tlv:n}=de,s=O(r,void 0,"signature"),{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:l,l:f}=n.decode(2,a);if(f.length)throw new t("invalid signature: left bytes after parsing");return{r:e.decode(c),s:e.decode(l)}},hexFromSig(r){let{_tlv:t,_int:e}=de,n=t.encode(2,e.encode(r.r)),s=t.encode(2,e.encode(r.s)),o=n+s;return t.encode(48,o)}},Gt=BigInt(0),or=BigInt(1),oc=BigInt(2),Cn=BigInt(3),zf=BigInt(4);function ic(r,t={}){let e=mn("weierstrass",r,t),{Fp:n,Fn:s}=e,o=e.CURVE,{h:i,n:c}=o;ce(t,{},{allowInfinityPoint:"boolean",clearCofactor:"function",isTorsionFree:"function",fromBytes:"function",toBytes:"function",endo:"object"});let{endo:a}=t;if(a&&(!n.is0(o.a)||typeof a.beta!="bigint"||!Array.isArray(a.basises)))throw new Error('invalid endo: expected "beta": bigint and "basises": array');let l=cc(n,s);function f(){if(!n.isOdd)throw new Error("compression is not supported: Field does not have .isOdd()")}function u(L,m,b){let{x:p,y:S}=m.toAffine(),C=n.toBytes(p);if(jt(b,"isCompressed"),b){f();let U=!n.isOdd(S);return xt(ac(U),C)}else return xt(Uint8Array.of(4),C,n.toBytes(S))}function d(L){O(L,void 0,"Point");let{publicKey:m,publicKeyUncompressed:b}=l,p=L.length,S=L[0],C=L.subarray(1);if(p===m&&(S===2||S===3)){let U=n.fromBytes(C);if(!n.isValid(U))throw new Error("bad point: is not on curve, wrong x");let T=B(U),N;try{N=n.sqrt(T)}catch(Y){let G=Y instanceof Error?": "+Y.message:"";throw new Error("bad point: is not on curve, sqrt error"+G)}f();let _=n.isOdd(N);return(S&1)===1!==_&&(N=n.neg(N)),{x:U,y:N}}else if(p===b&&S===4){let U=n.BYTES,T=n.fromBytes(C.subarray(0,U)),N=n.fromBytes(C.subarray(U,U*2));if(!v(T,N))throw new Error("bad point: is not on curve");return{x:T,y:N}}else throw new Error(`bad point: got length ${p}, expected compressed=${m} or uncompressed=${b}`)}let y=t.toBytes||u,h=t.fromBytes||d;function B(L){let m=n.sqr(L),b=n.mul(m,L);return n.add(n.add(b,n.mul(L,o.a)),o.b)}function v(L,m){let b=n.sqr(m),p=B(L);return n.eql(b,p)}if(!v(o.Gx,o.Gy))throw new Error("bad curve params: generator point");let g=n.mul(n.pow(o.a,Cn),zf),A=n.mul(n.sqr(o.b),BigInt(27));if(n.is0(n.add(g,A)))throw new Error("bad curve params: a or b");function w(L,m,b=!1){if(!n.isValid(m)||b&&n.is0(m))throw new Error(`bad point coordinate ${L}`);return m}function I(L){if(!(L instanceof x))throw new Error("Weierstrass Point expected")}function D(L){if(!a||!a.basises)throw new Error("no endo");return Yf(L,a.basises,s.ORDER)}let H=We((L,m)=>{let{X:b,Y:p,Z:S}=L;if(n.eql(S,n.ONE))return{x:b,y:p};let C=L.is0();m==null&&(m=C?n.ONE:n.inv(S));let U=n.mul(b,m),T=n.mul(p,m),N=n.mul(S,m);if(C)return{x:n.ZERO,y:n.ZERO};if(!n.eql(N,n.ONE))throw new Error("invZ was invalid");return{x:U,y:T}}),M=We(L=>{if(L.is0()){if(t.allowInfinityPoint&&!n.is0(L.Y))return;throw new Error("bad point: ZERO")}let{x:m,y:b}=L.toAffine();if(!n.isValid(m)||!n.isValid(b))throw new Error("bad point: x or y not field elements");if(!v(m,b))throw new Error("bad point: equation left != right");if(!L.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});function E(L,m,b,p,S){return b=new x(n.mul(b.X,L),b.Y,b.Z),m=Ur(p,m),b=Ur(S,b),m.add(b)}class x{static BASE=new x(o.Gx,o.Gy,n.ONE);static ZERO=new x(n.ZERO,n.ONE,n.ZERO);static Fp=n;static Fn=s;X;Y;Z;constructor(m,b,p){this.X=w("x",m),this.Y=w("y",b,!0),this.Z=w("z",p),Object.freeze(this)}static CURVE(){return o}static fromAffine(m){let{x:b,y:p}=m||{};if(!m||!n.isValid(b)||!n.isValid(p))throw new Error("invalid affine point");if(m instanceof x)throw new Error("projective point not allowed");return n.is0(b)&&n.is0(p)?x.ZERO:new x(b,p,n.ONE)}static fromBytes(m){let b=x.fromAffine(h(O(m,void 0,"point")));return b.assertValidity(),b}static fromHex(m){return x.fromBytes(qt(m))}get x(){return this.toAffine().x}get y(){return this.toAffine().y}precompute(m=8,b=!0){return P.createCache(this,m),b||this.multiply(Cn),this}assertValidity(){M(this)}hasEvenY(){let{y:m}=this.toAffine();if(!n.isOdd)throw new Error("Field doesn't support isOdd");return!n.isOdd(m)}equals(m){I(m);let{X:b,Y:p,Z:S}=this,{X:C,Y:U,Z:T}=m,N=n.eql(n.mul(b,T),n.mul(C,S)),_=n.eql(n.mul(p,T),n.mul(U,S));return N&&_}negate(){return new x(this.X,n.neg(this.Y),this.Z)}double(){let{a:m,b}=o,p=n.mul(b,Cn),{X:S,Y:C,Z:U}=this,T=n.ZERO,N=n.ZERO,_=n.ZERO,V=n.mul(S,S),Y=n.mul(C,C),G=n.mul(U,U),j=n.mul(S,C);return j=n.add(j,j),_=n.mul(S,U),_=n.add(_,_),T=n.mul(m,_),N=n.mul(p,G),N=n.add(T,N),T=n.sub(Y,N),N=n.add(Y,N),N=n.mul(T,N),T=n.mul(j,T),_=n.mul(p,_),G=n.mul(m,G),j=n.sub(V,G),j=n.mul(m,j),j=n.add(j,_),_=n.add(V,V),V=n.add(_,V),V=n.add(V,G),V=n.mul(V,j),N=n.add(N,V),G=n.mul(C,U),G=n.add(G,G),V=n.mul(G,j),T=n.sub(T,V),_=n.mul(G,Y),_=n.add(_,_),_=n.add(_,_),new x(T,N,_)}add(m){I(m);let{X:b,Y:p,Z:S}=this,{X:C,Y:U,Z:T}=m,N=n.ZERO,_=n.ZERO,V=n.ZERO,Y=o.a,G=n.mul(o.b,Cn),j=n.mul(b,C),z=n.mul(p,U),st=n.mul(S,T),Tt=n.add(b,p),W=n.add(C,U);Tt=n.mul(Tt,W),W=n.add(j,z),Tt=n.sub(Tt,W),W=n.add(b,S);let ct=n.add(C,T);return W=n.mul(W,ct),ct=n.add(j,st),W=n.sub(W,ct),ct=n.add(p,S),N=n.add(U,T),ct=n.mul(ct,N),N=n.add(z,st),ct=n.sub(ct,N),V=n.mul(Y,W),N=n.mul(G,st),V=n.add(N,V),N=n.sub(z,V),V=n.add(z,V),_=n.mul(N,V),z=n.add(j,j),z=n.add(z,j),st=n.mul(Y,st),W=n.mul(G,W),z=n.add(z,st),st=n.sub(j,st),st=n.mul(Y,st),W=n.add(W,st),j=n.mul(z,W),_=n.add(_,j),j=n.mul(ct,W),N=n.mul(Tt,N),N=n.sub(N,j),j=n.mul(Tt,z),V=n.mul(ct,V),V=n.add(V,j),new x(N,_,V)}subtract(m){return this.add(m.negate())}is0(){return this.equals(x.ZERO)}multiply(m){let{endo:b}=t;if(!s.isValidNot0(m))throw new Error("invalid scalar: out of range");let p,S,C=U=>P.cached(this,U,T=>Ie(x,T));if(b){let{k1neg:U,k1:T,k2neg:N,k2:_}=D(m),{p:V,f:Y}=C(T),{p:G,f:j}=C(_);S=Y.add(j),p=E(b.beta,V,G,U,N)}else{let{p:U,f:T}=C(m);p=U,S=T}return Ie(x,[p,S])[0]}multiplyUnsafe(m){let{endo:b}=t,p=this;if(!s.isValid(m))throw new Error("invalid scalar: out of range");if(m===Gt||p.is0())return x.ZERO;if(m===or)return p;if(P.hasCache(this))return this.multiply(m);if(b){let{k1neg:S,k1:C,k2neg:U,k2:T}=D(m),{p1:N,p2:_}=Ia(x,p,C,T);return E(b.beta,N,_,S,U)}else return P.unsafe(p,m)}toAffine(m){return H(this,m)}isTorsionFree(){let{isTorsionFree:m}=t;return i===or?!0:m?m(x,this):P.unsafe(this,c).is0()}clearCofactor(){let{clearCofactor:m}=t;return i===or?this:m?m(x,this):this.multiplyUnsafe(i)}isSmallOrder(){return this.multiplyUnsafe(i).is0()}toBytes(m=!0){return jt(m,"isCompressed"),this.assertValidity(),y(x,this,m)}toHex(m=!0){return Ft(this.toBytes(m))}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}}let K=s.BITS,P=new Qe(x,t.endo?Math.ceil(K/2):K);return x.BASE.precompute(8),x}function ac(r){return Uint8Array.of(r?2:3)}function cc(r,t){return{secretKey:t.BYTES,publicKey:1+r.BYTES,publicKeyUncompressed:1+2*r.BYTES,publicKeyHasPrefix:!0,signature:2*t.BYTES}}function Wf(r,t={}){let{Fn:e}=r,n=t.randomBytes||re,s=Object.assign(cc(r.Fp,e),{seed:go(e.ORDER)});function o(y){try{let h=e.fromBytes(y);return e.isValidNot0(h)}catch{return!1}}function i(y,h){let{publicKey:B,publicKeyUncompressed:v}=s;try{let g=y.length;return h===!0&&g!==B||h===!1&&g!==v?!1:!!r.fromBytes(y)}catch{return!1}}function c(y=n(s.seed)){return yo(O(y,s.seed,"seed"),e.ORDER)}function a(y,h=!0){return r.BASE.multiply(e.fromBytes(y)).toBytes(h)}function l(y){let{secretKey:h,publicKey:B,publicKeyUncompressed:v}=s;if(!we(y)||"_lengths"in e&&e._lengths||h===B)return;let g=O(y,void 0,"key").length;return g===B||g===v}function f(y,h,B=!0){if(l(y)===!0)throw new Error("first arg must be private key");if(l(h)===!1)throw new Error("second arg must be public key");let v=e.fromBytes(y);return r.fromBytes(h).multiply(v).toBytes(B)}let u={isValidSecretKey:o,isValidPublicKey:i,randomSecretKey:c},d=bn(c,a);return Object.freeze({getPublicKey:a,getSharedSecret:f,keygen:d,Point:r,utils:u,lengths:s})}function uc(r,t,e={}){Ze(t),ce(e,{},{hmac:"function",lowS:"boolean",randomBytes:"function",bits2int:"function",bits2int_modN:"function"}),e=Object.assign({},e);let n=e.randomBytes||re,s=e.hmac||((b,p)=>Hr(t,b,p)),{Fp:o,Fn:i}=r,{ORDER:c,BITS:a}=i,{keygen:l,getPublicKey:f,getSharedSecret:u,utils:d,lengths:y}=Wf(r,e),h={prehash:!0,lowS:typeof e.lowS=="boolean"?e.lowS:!0,format:"compact",extraEntropy:!1},B=c*oc<o.ORDER;function v(b){let p=c>>or;return b>p}function g(b,p){if(!i.isValidNot0(p))throw new Error(`invalid signature ${b}: out of range 1..Point.Fn.ORDER`);return p}function A(){if(B)throw new Error('"recovered" sig type is not supported for cofactor >2 curves')}function w(b,p){Go(p);let S=y.signature,C=p==="compact"?S:p==="recovered"?S+1:void 0;return O(b,C)}class I{r;s;recovery;constructor(p,S,C){if(this.r=g("r",p),this.s=g("s",S),C!=null){if(A(),![0,1,2,3].includes(C))throw new Error("invalid recovery id");this.recovery=C}Object.freeze(this)}static fromBytes(p,S=h.format){w(p,S);let C;if(S==="der"){let{r:_,s:V}=de.toSig(O(p));return new I(_,V)}S==="recovered"&&(C=p[0],S="compact",p=p.subarray(1));let U=y.signature/2,T=p.subarray(0,U),N=p.subarray(U,U*2);return new I(i.fromBytes(T),i.fromBytes(N),C)}static fromHex(p,S){return this.fromBytes(qt(p),S)}assertRecovery(){let{recovery:p}=this;if(p==null)throw new Error("invalid recovery id: must be present");return p}addRecoveryBit(p){return new I(this.r,this.s,p)}recoverPublicKey(p){let{r:S,s:C}=this,U=this.assertRecovery(),T=U===2||U===3?S+c:S;if(!o.isValid(T))throw new Error("invalid recovery id: sig.r+curve.n != R.x");let N=o.toBytes(T),_=r.fromBytes(xt(ac((U&1)===0),N)),V=i.inv(T),Y=H(O(p,void 0,"msgHash")),G=i.create(-Y*V),j=i.create(C*V),z=r.BASE.multiplyUnsafe(G).add(_.multiplyUnsafe(j));if(z.is0())throw new Error("invalid recovery: point at infinify");return z.assertValidity(),z}hasHighS(){return v(this.s)}toBytes(p=h.format){if(Go(p),p==="der")return qt(de.hexFromSig(this));let{r:S,s:C}=this,U=i.toBytes(S),T=i.toBytes(C);return p==="recovered"?(A(),xt(Uint8Array.of(this.assertRecovery()),U,T)):xt(U,T)}toHex(p){return Ft(this.toBytes(p))}}let D=e.bits2int||function(p){if(p.length>8192)throw new Error("input is too large");let S=ze(p),C=p.length*8-a;return C>0?S>>BigInt(C):S},H=e.bits2int_modN||function(p){return i.create(D(p))},M=Cr(a);function E(b){return Ir("num < 2^"+a,b,Gt,M),i.toBytes(b)}function x(b,p){return O(b,void 0,"message"),p?O(t(b),void 0,"prehashed message"):b}function K(b,p,S){let{lowS:C,prehash:U,extraEntropy:T}=jo(S,h);b=x(b,U);let N=H(b),_=i.fromBytes(p);if(!i.isValidNot0(_))throw new Error("invalid private key");let V=[E(_),E(N)];if(T!=null&&T!==!1){let z=T===!0?n(y.secretKey):T;V.push(O(z,void 0,"extraEntropy"))}let Y=xt(...V),G=N;function j(z){let st=D(z);if(!i.isValidNot0(st))return;let Tt=i.inv(st),W=r.BASE.multiply(st).toAffine(),ct=i.create(W.x);if(ct===Gt)return;let tn=i.create(Tt*i.create(G+ct*_));if(tn===Gt)return;let ai=(W.x===ct?0:2)|Number(W.y&or),ci=tn;return C&&v(tn)&&(ci=i.neg(tn),ai^=1),new I(ct,ci,B?void 0:ai)}return{seed:Y,k2sig:j}}function P(b,p,S={}){let{seed:C,k2sig:U}=K(b,p,S);return la(t.outputLen,i.BYTES,s)(C,U).toBytes(S.format)}function L(b,p,S,C={}){let{lowS:U,prehash:T,format:N}=jo(C,h);if(S=O(S,void 0,"publicKey"),p=x(p,T),!we(b)){let _=b instanceof I?", use sig.toBytes()":"";throw new Error("verify expects Uint8Array signature"+_)}w(b,N);try{let _=I.fromBytes(b,N),V=r.fromBytes(S);if(U&&_.hasHighS())return!1;let{r:Y,s:G}=_,j=H(p),z=i.inv(G),st=i.create(j*z),Tt=i.create(Y*z),W=r.BASE.multiplyUnsafe(st).add(V.multiplyUnsafe(Tt));return W.is0()?!1:i.create(W.x)===Y}catch{return!1}}function m(b,p,S={}){let{prehash:C}=jo(S,h);return p=x(p,C),I.fromBytes(b,"recovered").recoverPublicKey(p).toBytes()}return Object.freeze({keygen:l,getPublicKey:f,getSharedSecret:u,utils:d,lengths:y,Point:r,sign:P,verify:L,recoverPublicKey:m,Signature:I,hash:t})}var zo={p:BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),n:BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),h:BigInt(1),a:BigInt(0),b:BigInt(7),Gx:BigInt("0x79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798"),Gy:BigInt("0x483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8")},Jf={beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),basises:[[BigInt("0x3086d221a7d46bcde86c90e49284eb15"),-BigInt("0xe4437ed6010e88286f547fa90abfe4c3")],[BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),BigInt("0x3086d221a7d46bcde86c90e49284eb15")]]};var lc=BigInt(2);function Xf(r){let t=zo.p,e=BigInt(3),n=BigInt(6),s=BigInt(11),o=BigInt(22),i=BigInt(23),c=BigInt(44),a=BigInt(88),l=r*r*r%t,f=l*l*r%t,u=Z(f,e,t)*f%t,d=Z(u,e,t)*f%t,y=Z(d,lc,t)*l%t,h=Z(y,s,t)*y%t,B=Z(h,o,t)*h%t,v=Z(B,c,t)*B%t,g=Z(v,a,t)*v%t,A=Z(g,c,t)*B%t,w=Z(A,e,t)*f%t,I=Z(w,i,t)*h%t,D=Z(I,n,t)*l%t,H=Z(D,lc,t);if(!Yo.eql(Yo.sqr(H),r))throw new Error("Cannot find square root");return H}var Yo=Je(zo.p,{sqrt:Xf}),Qf=ic(zo,{Fp:Yo,endo:Jf}),Dt=uc(Qf,ie);var fc=32;function hc(r,t,e){let n=$e.digest(t instanceof Uint8Array?t:t.subarray());if(rr(n))return n.then(({digest:s})=>(e?.signal?.throwIfAborted(),Dt.sign(s,r,{prehash:!1,format:"der"}))).catch(s=>{throw s.name==="AbortError"?s:new hr(String(s))});try{return Dt.sign(n.digest,r,{prehash:!1,format:"der"})}catch(s){throw new hr(String(s))}}function dc(r,t,e,n){let s=$e.digest(e instanceof Uint8Array?e:e.subarray());if(rr(s))return s.then(({digest:o})=>(n?.signal?.throwIfAborted(),Dt.verify(t,o,r,{prehash:!1,format:"der"}))).catch(o=>{throw o.name==="AbortError"?o:new dr(String(o))});try{return n?.signal?.throwIfAborted(),Dt.verify(t,s.digest,r,{prehash:!1,format:"der"})}catch(o){throw new dr(String(o))}}var Nn=class{type="secp256k1";raw;_key;constructor(t){this._key=yc(t),this.raw=pc(this._key)}toMultihash(){return me.digest(Ge(this))}toCID(){return St.createV1(114,this.toMultihash())}toString(){return tt.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:mt(this.raw,t.raw)}verify(t,e,n){return dc(this._key,e,t,n)}},Un=class{type="secp256k1";raw;publicKey;constructor(t,e){this.raw=gc(t),this.publicKey=new Nn(e??mc(t))}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:mt(this.raw,t.raw)}sign(t,e){return hc(this.raw,t,e)}};function Wo(r){return new Un(r)}function pc(r){return Dt.Point.fromBytes(r).toBytes()}function gc(r){try{return Dt.getPublicKey(r,!0),r}catch(t){throw new pr(String(t))}}function yc(r){try{return Dt.Point.fromBytes(r),r}catch(t){throw new Ke(String(t))}}function mc(r){try{return Dt.getPublicKey(r,!0)}catch(t){throw new pr(String(t))}}function Ge(r){return he.encode({Type:et[r.type],Data:r.raw})}function bc(r){let t=Kr.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case et.RSA:return Fo(e);case et.Ed25519:return Bo(e);case et.secp256k1:return Wo(e);case et.ECDSA:return $i(e);default:throw new Ve}}function wc(r){if(r.byteLength===kt)return Bo(r);if(r.byteLength===fc)return Wo(r);let t=Ct(r),e=t[2]?.[0];if(e===Hi||e===Mi||e===Pi)return Xs(t);if(t.length>8)return kn(t);throw new R("Could not extract private key from raw bytes")}function Le(r){return Kr.encode({Type:et[r.type],Data:r.raw})}var Mr=Uint32Array.from([1732584193,4023233417,2562383102,271733878,3285377520]),pe=new Uint32Array(80),Jo=class extends ve{A=Mr[0]|0;B=Mr[1]|0;C=Mr[2]|0;D=Mr[3]|0;E=Mr[4]|0;constructor(){super(64,20,8,!1)}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)pe[a]=t.getUint32(e,!1);for(let a=16;a<80;a++)pe[a]=ln(pe[a-3]^pe[a-8]^pe[a-14]^pe[a-16],1);let{A:n,B:s,C:o,D:i,E:c}=this;for(let a=0;a<80;a++){let l,f;a<20?(l=fn(s,o,i),f=1518500249):a<40?(l=s^o^i,f=1859775393):a<60?(l=hn(s,o,i),f=2400959708):(l=s^o^i,f=3395469782);let u=ln(n,5)+l+c+f+pe[a]|0;c=i,i=o,o=ln(s,30),s=n,n=u}n=n+this.A|0,s=s+this.B|0,o=o+this.C|0,i=i+this.D|0,c=c+this.E|0,this.set(n,s,o,i,c)}roundClean(){wt(pe)}destroy(){this.set(0,0,0,0,0),wt(this.buffer)}},xc=Br(()=>new Jo);function vc(r,t,e,n){Ze(r);let s=Xi({dkLen:32,asyncTick:10},n),{c:o,dkLen:i,asyncTick:c}=s;if(bt(o,"c"),bt(i,"dkLen"),bt(c,"asyncTick"),o<1)throw new Error("iterations (c) must be >= 1");let a=Qs(t,"password"),l=Qs(e,"salt"),f=new Uint8Array(i),u=Hr.create(r,a),d=u._cloneInto().update(l);return{c:o,dkLen:i,asyncTick:c,DK:f,PRF:u,PRFSalt:d}}function Ec(r,t,e,n,s){return r.destroy(),t.destroy(),n&&n.destroy(),wt(s),e}function Bc(r,t,e,n){let{c:s,dkLen:o,DK:i,PRF:c,PRFSalt:a}=vc(r,t,e,n),l,f=new Uint8Array(4),u=xe(f),d=new Uint8Array(c.outputLen);for(let y=1,h=0;h<o;y++,h+=c.outputLen){let B=i.subarray(h,h+c.outputLen);u.setInt32(0,y,!1),(l=a._cloneInto(l)).update(f).digestInto(d),B.set(d.subarray(0,B.length));for(let v=1;v<s;v++){c._cloneInto(l).update(d).digestInto(d);for(let g=0;g<B.length;g++)B[g]^=d[g]}}return Ec(c,a,i,l,d)}async function Ln(r,t,e,n){let{c:s,dkLen:o,asyncTick:i,DK:c,PRF:a,PRFSalt:l}=vc(r,t,e,n),f,u=new Uint8Array(4),d=xe(u),y=new Uint8Array(a.outputLen);for(let h=1,B=0;B<o;h++,B+=a.outputLen){let v=c.subarray(B,B+a.outputLen);d.setInt32(0,h,!1),(f=l._cloneInto(f)).update(u).digestInto(y),v.set(y.subarray(0,v.length)),await Ji(s-1,i,()=>{a._cloneInto(f).update(y).digestInto(y);for(let g=0;g<v.length;g++)v[g]^=y[g]})}return Ec(a,l,c,f,y)}var Ac={sha1:xc,"sha2-256":ie,"sha2-512":ae};function Pr(r,t,e,n,s){if(s!=="sha1"&&s!=="sha2-256"&&s!=="sha2-512"){let c=Object.keys(Ac).join(" / ");throw new R(`Hash '${s}' is unknown or not supported. Must be ${c}`)}let o=Ac[s],i=Bc(o,r,t,{c:e,dkLen:n});return be.encode(i).substring(1)}var Zt="/",Sc=new TextEncoder().encode(Zt),Tn=Sc[0],Fr=class r{_buf;constructor(t,e){if(typeof t=="string")this._buf=F(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]!==Tn)throw new Error("Invalid key")}toString(t="utf8"){return $(this._buf,t)}uint8Array(){return this._buf}get[Symbol.toStringTag](){return`Key(${this.toString()})`}static withNamespaces(t){return new r(t.join(Zt))}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=Sc),this._buf[0]!==Tn){let t=new Uint8Array(this._buf.byteLength+1);t.fill(Tn,0,1),t.set(this._buf,1),this._buf=t}for(;this._buf.byteLength>1&&this._buf[this._buf.byteLength-1]===Tn;)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(Zt).slice(1)}type(){return th(this.baseNamespace())}name(){return eh(this.baseNamespace())}instance(t){return new r(this.toString()+":"+t)}path(){let t=this.parent().toString();return t.endsWith(Zt)||(t+=Zt),t+=this.type(),new r(t)}parent(){let t=this.list();return t.length===1?new r(Zt):new r(t.slice(0,-1).join(Zt))}child(t){return this.toString()===Zt?t:t.toString()===Zt?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(),...rh(t.map(e=>e.namespaces()))])}};function th(r){let t=r.split(":");return t.length<2?"":t.slice(0,-1).join(":")}function eh(r){let t=r.split(":");return t[t.length-1]}function rh(r){return[].concat(...r)}var Au=li(_c(),1);var Xo={keyLength:64,iterationCount:1e4,salt:"you should override this value with a crypto secure random number",hash:"sha2-512"};var ir={};ft(ir,{create:()=>gh,derivedEmptyPasswordKey:()=>Rn});var Rn={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function gh(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=Q.get();e*=8;async function a(u,d){let y=c.getRandomValues(new Uint8Array(o)),h=c.getRandomValues(new Uint8Array(n)),B={name:t,iv:h};typeof d=="string"&&(d=F(d));let v;if(d.length===0){v=await c.subtle.importKey("jwk",Rn,{name:"AES-GCM"},!0,["encrypt"]);try{let A={name:"PBKDF2",salt:y,iterations:i,hash:{name:s}},w=await c.subtle.importKey("raw",d,{name:"PBKDF2"},!1,["deriveKey"]);v=await c.subtle.deriveKey(A,w,{name:t,length:e},!0,["encrypt"])}catch{v=await c.subtle.importKey("jwk",Rn,{name:"AES-GCM"},!0,["encrypt"])}}else{let A={name:"PBKDF2",salt:y,iterations:i,hash:{name:s}},w=await c.subtle.importKey("raw",d,{name:"PBKDF2"},!1,["deriveKey"]);v=await c.subtle.deriveKey(A,w,{name:t,length:e},!0,["encrypt"])}let g=await c.subtle.encrypt(B,v,u);return qe([y,B.iv,new Uint8Array(g)])}async function l(u,d){let y=u.subarray(0,o),h=u.subarray(o,o+n),B=u.subarray(o+n),v={name:t,iv:h};typeof d=="string"&&(d=F(d));let g;if(d.length===0)try{let w={name:"PBKDF2",salt:y,iterations:i,hash:{name:s}},I=await c.subtle.importKey("raw",d,{name:"PBKDF2"},!1,["deriveKey"]);g=await c.subtle.deriveKey(w,I,{name:t,length:e},!0,["decrypt"])}catch{g=await c.subtle.importKey("jwk",Rn,{name:"AES-GCM"},!0,["decrypt"])}else{let w={name:"PBKDF2",salt:y,iterations:i,hash:{name:s}},I=await c.subtle.importKey("raw",d,{name:"PBKDF2"},!1,["deriveKey"]);g=await c.subtle.deriveKey(w,I,{name:t,length:e},!0,["decrypt"])}let A=await c.subtle.decrypt(v,g,B);return new Uint8Array(A)}return{encrypt:a,decrypt:l}}var q=li(Dc());function Te(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 ge(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 l=new Uint8Array(a);for(let f=c-1;f>=0;f--){let u=Math.pow(2,f*t);l[o-f-1]=Math.floor(s/u),s-=l[o-f-1]*u}return a}i*=Math.pow(2,t)}return new ArrayBuffer(0)}function Kn(...r){let t=0,e=0;for(let o of r)t+=o.length;let n=new ArrayBuffer(t),s=new Uint8Array(n);for(let o of r)s.set(o,e),e+=o.length;return s}function ti(){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=Te(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,Te(o,8)-n}function Kc(r){let t=r<0?r*-1:r,e=128;for(let n=1;n<8;n++){if(t<=e){if(r<0){let i=e-t,c=ge(i,8,n),a=new Uint8Array(c);return a[0]|=128,c}let s=ge(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 Vc(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 vt(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 rm=Math.log(2);function Vn(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function ei(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 Qt(r,t,e,n){return t instanceof Uint8Array?t.byteLength?e<0?(r.error="Wrong parameter: inputOffset less than zero",!1):n<0?(r.error="Wrong parameter: inputLength less than zero",!1):t.byteLength-e-n<0?(r.error="End of input reached before message was fully decoded (inconsistent offset and length values)",!1):!0:(r.error="Wrong parameter: inputBuffer has zero length",!1):(r.error="Wrong parameter: inputBuffer must be 'Uint8Array'",!1)}var jr=class{constructor(){this.items=[]}write(t){this.items.push(t)}final(){return ei(this.items)}},qr=[new Uint8Array([1])],Oc="0123456789";var cr="",Ot=new ArrayBuffer(0),ri=new Uint8Array(0),Gr="EndOfContent",Mc="OCTET STRING",Pc="BIT STRING";function te(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):ri}fromBER(n,s,o){let i=n instanceof ArrayBuffer?new Uint8Array(n):n;if(!Qt(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",Ot)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:q.Convert.ToHex(this.valueHexView)}}},t.NAME="hexBlock",t}var zt=class{static blockName(){return this.NAME}get valueBeforeDecode(){return this.valueBeforeDecodeView.slice().buffer}set valueBeforeDecode(t){this.valueBeforeDecodeView=new Uint8Array(t)}constructor({blockLength:t=0,error:e=cr,warnings:n=[],valueBeforeDecode:s=ri}={}){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)}}};zt.NAME="baseBlock";var lt=class extends zt{fromBER(t,e,n){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}toBER(t,e){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}};lt.NAME="valueBlock";var On=class extends te(zt){constructor({idBlock:t={}}={}){var e,n,s,o;super(),t?(this.isHexOnly=(e=t.isHexOnly)!==null&&e!==void 0?e:!1,this.valueHexView=t.valueHex?q.BufferSourceConverter.toUint8Array(t.valueHex):ri,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",Ot}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=ge(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(!Qt(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,l=this.valueHexView=new Uint8Array(255),f=255;for(;o[a]&128;){if(l[a-1]=o[a]&127,a++,a>=o.length)return this.error="End of input reached before message was fully decoded",-1;if(a===f){f+=255;let d=new Uint8Array(f);for(let y=0;y<l.length;y++)d[y]=l[y];l=this.valueHexView=new Uint8Array(f)}}this.blockLength=a+1,l[a-1]=o[a]&127;let u=new Uint8Array(a);for(let d=0;d<a;d++)u[d]=l[d];l=this.valueHexView=new Uint8Array(a),l.set(u),this.blockLength<=9?this.tagNumber=Te(l,7):(this.isHexOnly=!0,this.warnings.push("Tag too long, represented as hex-coded"))}if(this.tagClass===1&&this.isConstructed)switch(this.tagNumber){case 1:case 2:case 5:case 6:case 9:case 13:case 14:case 23:case 24:case 31:case 32:case 33:case 34:return this.error="Constructed encoding used for primitive type",-1}return e+this.blockLength}toJSON(){return{...super.toJSON(),tagClass:this.tagClass,tagNumber:this.tagNumber,isConstructed:this.isConstructed}}};On.NAME="identificationBlock";var Hn=class extends zt{constructor({lenBlock:t={}}={}){var e,n,s;super(),this.isIndefiniteForm=(e=t.isIndefiniteForm)!==null&&e!==void 0?e:!1,this.longFormUsed=(n=t.longFormUsed)!==null&&n!==void 0?n:!1,this.length=(s=t.length)!==null&&s!==void 0?s:0}fromBER(t,e,n){let s=q.BufferSourceConverter.toUint8Array(t);if(!Qt(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=Te(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=ge(this.length,8);if(s.byteLength>127)return this.error="Too big length",Ot;if(e=new ArrayBuffer(s.byteLength+1),t)return e;let o=new Uint8Array(s);n=new Uint8Array(e),n[0]=s.byteLength|128;for(let i=0;i<s.byteLength;i++)n[i+1]=o[i];return e}return e=new ArrayBuffer(1),t===!1&&(n=new Uint8Array(e),n[0]=this.length),e}toJSON(){return{...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,longFormUsed:this.longFormUsed,length:this.length}}};Hn.NAME="lengthBlock";var k={},it=class extends zt{constructor({name:t=cr,optional:e=!1,primitiveSchema:n,...s}={},o){super(s),this.name=t,this.optional=e,n&&(this.primitiveSchema=n),this.idBlock=new On(s),this.lenBlock=new Hn(s),this.valueBlock=o?new o(s):new lt(s)}fromBER(t,e,n){let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}toBER(t,e){let n=e||new jr;e||Fc(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?Ot: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 Vc(e,n)}};it.NAME="BaseBlock";function Fc(r){var t;if(r instanceof k.Constructed)for(let e of r.valueBlock.value)Fc(e)&&(r.lenBlock.isIndefiniteForm=!0);return!!(!((t=r.lenBlock)===null||t===void 0)&&t.isIndefiniteForm)}var Mn=class extends it{getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}constructor({value:t=cr,...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}'`}};Mn.NAME="BaseStringBlock";var Pn=class extends te(lt){constructor({isHexOnly:t=!0,...e}={}){super(e),this.isHexOnly=t}};Pn.NAME="PrimitiveValueBlock";var qc,Fn=class extends it{constructor(t={}){super(t,Pn),this.idBlock.isConstructed=!1}};qc=Fn;k.Primitive=qc;Fn.NAME="PRIMITIVE";function Ah(r,t){if(r instanceof t)return r;let e=new t;return e.idBlock=r.idBlock,e.lenBlock=r.lenBlock,e.warnings=r.warnings,e.valueBeforeDecodeView=r.valueBeforeDecodeView,e}function Es(r,t=0,e=r.length){let n=t,s=new it({},lt),o=new zt;if(!Qt(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=it;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=k.EndOfContent;break;case 1:a=k.Boolean;break;case 2:a=k.Integer;break;case 3:a=k.BitString;break;case 4:a=k.OctetString;break;case 5:a=k.Null;break;case 6:a=k.ObjectIdentifier;break;case 10:a=k.Enumerated;break;case 12:a=k.Utf8String;break;case 13:a=k.RelativeObjectIdentifier;break;case 14:a=k.TIME;break;case 15:return s.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:s};case 16:a=k.Sequence;break;case 17:a=k.Set;break;case 18:a=k.NumericString;break;case 19:a=k.PrintableString;break;case 20:a=k.TeletexString;break;case 21:a=k.VideotexString;break;case 22:a=k.IA5String;break;case 23:a=k.UTCTime;break;case 24:a=k.GeneralizedTime;break;case 25:a=k.GraphicString;break;case 26:a=k.VisibleString;break;case 27:a=k.GeneralString;break;case 28:a=k.UniversalString;break;case 29:a=k.CharacterString;break;case 30:a=k.BmpString;break;case 31:a=k.DATE;break;case 32:a=k.TimeOfDay;break;case 33:a=k.DateTime;break;case 34:a=k.Duration;break;default:{let l=s.idBlock.isConstructed?new k.Constructed:new k.Primitive;l.idBlock=s.idBlock,l.lenBlock=s.lenBlock,l.warnings=s.warnings,s=l}}break;case 2:case 3:case 4:default:a=s.idBlock.isConstructed?k.Constructed:k.Primitive}return s=Ah(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 Bs(r){if(!r.byteLength){let t=new it({},lt);return t.error="Input buffer has zero length",{offset:-1,result:t}}return Es(q.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function Sh(r,t){return r?1:t}var Kt=class extends lt{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(!Qt(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(;Sh(this.isIndefiniteForm,n)>0;){let i=Es(s,o,n);if(i.offset===-1)return this.error=i.result.error,this.warnings.concat(i.result.warnings),-1;if(o=i.offset,this.blockLength+=i.result.blockLength,n-=i.result.blockLength,this.value.push(i.result),this.isIndefiniteForm&&i.result.constructor.NAME===Gr)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===Gr?this.value.pop():this.warnings.push("No EndOfContent block encoded")),o}toBER(t,e){let n=e||new jr;for(let s=0;s<this.value.length;s++)this.value[s].toBER(t,n);return e?Ot:n.final()}toJSON(){let t={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let e of this.value)t.value.push(e.toJSON());return t}};Kt.NAME="ConstructedValueBlock";var $c,ye=class extends it{constructor(t={}){super(t,Kt),this.idBlock.isConstructed=!0}fromBER(t,e,n){this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm;let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}onAsciiEncoding(){let t=[];for(let n of this.valueBlock.value)t.push(n.toString("ascii").split(`
|
|
3
3
|
`).map(s=>` ${s}`).join(`
|
|
4
4
|
`));let e=this.idBlock.tagClass===3?`[${this.idBlock.tagNumber}]`:this.constructor.NAME;return t.length?`${e} :
|
|
5
5
|
${t.join(`
|
|
6
|
-
`)}`:`${e} :`}};$c=ye;k.Constructed=$c;ye.NAME="CONSTRUCTED";var qn=class extends lt{fromBER(t,e,n){return e}toBER(t){return Tt}};qn.override="EndOfContentValueBlock";var jc,$n=class extends it{constructor(t={}){super(t,qn),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};jc=$n;k.EndOfContent=jc;$n.NAME=Gr;var Gc,Re=class extends it{constructor(t={}){super(t,lt),this.idBlock.tagClass=1,this.idBlock.tagNumber=5}fromBER(t,e,n){return this.lenBlock.length>0&&this.warnings.push("Non-zero length of value block for Null type"),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.blockLength+=n,e+n>t.byteLength?(this.error="End of input reached before message was fully decoded (inconsistent offset and length values)",-1):e+n}toBER(t,e){let n=new ArrayBuffer(2);if(!t){let s=new Uint8Array(n);s[0]=5,s[1]=0}return e&&e.write(n),n}onAsciiEncoding(){return`${this.constructor.NAME}`}};Gc=Re;k.Null=Gc;Re.NAME="NULL";var jn=class extends te(lt){get value(){for(let t of this.valueHexView)if(t>0)return!0;return!1}set value(t){this.valueHexView[0]=t?255:0}constructor({value:t,...e}={}){super(e),e.valueHex?this.valueHexView=q.BufferSourceConverter.toUint8Array(e.valueHex):this.valueHexView=new Uint8Array(1),t&&(this.value=t)}fromBER(t,e,n){let s=q.BufferSourceConverter.toUint8Array(t);return Qt(this,s,e,n)?(this.valueHexView=s.subarray(e,e+n),n>1&&this.warnings.push("Boolean value encoded in more then 1 octet"),this.isHexOnly=!0,ti.call(this),this.blockLength=n,e+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};jn.NAME="BooleanValueBlock";var Zc,Gn=class extends it{getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}constructor(t={}){super(t,jn),this.idBlock.tagClass=1,this.idBlock.tagNumber=1}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.getValue}`}};Zc=Gn;k.Boolean=Zc;Gn.NAME="BOOLEAN";var Zn=class extends te(Vt){constructor({isConstructed:t=!1,...e}={}){super(e),this.isConstructed=t}fromBER(t,e,n){let s=0;if(this.isConstructed){if(this.isHexOnly=!1,s=Vt.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let o=0;o<this.value.length;o++){let i=this.value[o].constructor.NAME;if(i===Gr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(i!==Mc)return this.error="OCTET STRING may consists of OCTET STRINGs only",-1}}else this.isHexOnly=!0,s=super.fromBER(t,e,n),this.blockLength=n;return s}toBER(t,e){return this.isConstructed?Vt.prototype.toBER.call(this,t,e):t?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};Zn.NAME="OctetStringValueBlock";var ni,Wt=class extends it{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,o;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((o=n.value)===null||o===void 0)&&o.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},Zn),this.idBlock.tagClass=1,this.idBlock.tagNumber=4}fromBER(t,e,n){if(this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,n===0)return this.idBlock.error.length===0&&(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length===0&&(this.blockLength+=this.lenBlock.blockLength),e;if(!this.valueBlock.isConstructed){let o=(t instanceof ArrayBuffer?new Uint8Array(t):t).subarray(e,e+n);try{if(o.byteLength){let i=Es(o,0,o.byteLength);i.offset!==-1&&i.offset===n&&(this.valueBlock.value=[i.result])}}catch{}}return super.fromBER(t,e,n)}onAsciiEncoding(){if(this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length)return ye.prototype.onAsciiEncoding.call(this);let t=this.constructor.NAME,e=q.Convert.ToHex(this.valueBlock.valueHexView);return`${t} : ${e}`}getValue(){if(!this.idBlock.isConstructed)return this.valueBlock.valueHexView.slice().buffer;let t=[];for(let e of this.valueBlock.value)e instanceof ni&&t.push(e.valueBlock.valueHexView);return q.BufferSourceConverter.concat(t)}};ni=Wt;k.OctetString=ni;Wt.NAME=Mc;var Yn=class extends te(Vt){constructor({unusedBits:t=0,isConstructed:e=!1,...n}={}){super(n),this.unusedBits=t,this.isConstructed=e,this.blockLength=this.valueHexView.byteLength}fromBER(t,e,n){if(!n)return e;let s=-1;if(this.isConstructed){if(s=Vt.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let c of this.value){let a=c.constructor.NAME;if(a===Gr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(a!==Pc)return this.error="BIT STRING may consists of BIT STRINGs only",-1;let l=c.valueBlock;if(this.unusedBits>0&&l.unusedBits>0)return this.error='Using of "unused bits" inside constructive BIT STRING allowed for least one only',-1;this.unusedBits=l.unusedBits}return s}let o=q.BufferSourceConverter.toUint8Array(t);if(!Qt(this,o,e,n))return-1;let i=o.subarray(e,e+n);if(this.unusedBits=i[0],this.unusedBits>7)return this.error="Unused bits for BitString must be in range 0-7",-1;if(!this.unusedBits){let c=i.subarray(1);try{if(c.byteLength){let a=Es(c,0,c.byteLength);a.offset!==-1&&a.offset===n-1&&(this.value=[a.result])}}catch{}}return this.valueHexView=i.subarray(1),this.blockLength=i.length,e+n}toBER(t,e){if(this.isConstructed)return Vt.prototype.toBER.call(this,t,e);if(t)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return Tt;let n=new Uint8Array(this.valueHexView.length+1);return n[0]=this.unusedBits,n.set(this.valueHexView,1),n.buffer}toJSON(){return{...super.toJSON(),unusedBits:this.unusedBits,isConstructed:this.isConstructed}}};Yn.NAME="BitStringValueBlock";var Yc,zn=class extends it{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,o;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((o=n.value)===null||o===void 0)&&o.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},Yn),this.idBlock.tagClass=1,this.idBlock.tagNumber=3}fromBER(t,e,n){return this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,super.fromBER(t,e,n)}onAsciiEncoding(){if(this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length)return ye.prototype.onAsciiEncoding.call(this);{let t=[],e=this.valueBlock.valueHexView;for(let i of e)t.push(i.toString(2).padStart(8,"0"));let n=t.join(""),s=this.constructor.NAME,o=n.substring(0,n.length-this.valueBlock.unusedBits);return`${s} : ${o}`}}};Yc=zn;k.BitString=Yc;zn.NAME=Pc;var zc;function kh(r,t){let e=new Uint8Array([0]),n=new Uint8Array(r),s=new Uint8Array(t),o=n.slice(0),i=o.length-1,c=s.slice(0),a=c.length-1,l=0,f=a<i?i:a,u=0;for(let d=f;d>=0;d--,u++){switch(!0){case u<c.length:l=o[i-u]+c[a-u]+e[0];break;default:l=o[i-u]+e[0]}switch(e[0]=l/10,!0){case u>=o.length:o=Kn(new Uint8Array([l%10]),o);break;default:o[i-u]=l%10}}return e[0]>0&&(o=Kn(e,o)),o}function Hc(r){if(r>=qr.length)for(let t=qr.length;t<=r;t++){let e=new Uint8Array([0]),n=qr[t-1].slice(0);for(let s=n.length-1;s>=0;s--){let o=new Uint8Array([(n[s]<<1)+e[0]]);e[0]=o[0]/10,n[s]=o[0]%10}e[0]>0&&(n=Kn(e,n)),qr.push(n)}return qr[r]}function Ih(r,t){let e=0,n=new Uint8Array(r),s=new Uint8Array(t),o=n.slice(0),i=o.length-1,c=s.slice(0),a=c.length-1,l,f=0;for(let u=a;u>=0;u--,f++)switch(l=o[i-f]-c[a-f]-e,!0){case l<0:e=1,o[i-f]=l+10;break;default:e=0,o[i-f]=l}if(e>0)for(let u=i-a+1;u>=0;u--,f++)if(l=o[i-f]-e,l<0)e=1,o[i-f]=l+10;else{e=0,o[i-f]=l;break}return o.slice()}var Zr=class extends te(lt){setValueHex(){this.valueHexView.length>=4?(this.warnings.push("Too big Integer for decoding, hex only"),this.isHexOnly=!0,this._valueDec=0):(this.isHexOnly=!1,this.valueHexView.length>0&&(this._valueDec=ti.call(this)))}constructor({value:t,...e}={}){super(e),this._valueDec=0,e.valueHex&&this.setValueHex(),t!==void 0&&(this.valueDec=t)}set valueDec(t){this._valueDec=t,this.isHexOnly=!1,this.valueHexView=new Uint8Array(Kc(t))}get valueDec(){return this._valueDec}fromDER(t,e,n,s=0){let o=this.fromBER(t,e,n);if(o===-1)return o;let i=this.valueHexView;return i[0]===0&&(i[1]&128)!==0?this.valueHexView=i.subarray(1):s!==0&&i.length<s&&(s-i.length>1&&(s=i.length+1),this.valueHexView=i.subarray(s-i.length)),o}toDER(t=!1){let e=this.valueHexView;switch(!0){case(e[0]&128)!==0:{let n=new Uint8Array(this.valueHexView.length+1);n[0]=0,n.set(e,1),this.valueHexView=n}break;case(e[0]===0&&(e[1]&128)===0):this.valueHexView=this.valueHexView.subarray(1);break}return this.toBER(t)}fromBER(t,e,n){let s=super.fromBER(t,e,n);return s===-1||this.setValueHex(),s}toBER(t){return t?new ArrayBuffer(this.valueHexView.length):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}toString(){let t=this.valueHexView.length*8-1,e=new Uint8Array(this.valueHexView.length*8/3),n=0,s,o=this.valueHexView,i="",c=!1;for(let a=o.byteLength-1;a>=0;a--){s=o[a];for(let l=0;l<8;l++){if((s&1)===1)switch(n){case t:e=Ih(Hc(n),e),i="-";break;default:e=kh(e,Hc(n))}n++,s>>=1}}for(let a=0;a<e.length;a++)e[a]&&(c=!0),c&&(i+=Oc.charAt(e[a]));return c===!1&&(i+=Oc.charAt(0)),i}};zc=Zr;Zr.NAME="IntegerValueBlock";Object.defineProperty(zc.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var $r,Jt=class extends it{constructor(t={}){super(t,Zr),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return Vn(),BigInt(this.valueBlock.toString())}static fromBigInt(t){Vn();let e=BigInt(t),n=new jr,s=e.toString(16).replace(/^-/,""),o=new Uint8Array(q.Convert.FromHex(s));if(e<0){let c=new Uint8Array(o.length+(o[0]&128?1:0));c[0]|=128;let l=BigInt(`0x${q.Convert.ToHex(c)}`)+e,f=q.BufferSourceConverter.toUint8Array(q.Convert.FromHex(l.toString(16)));f[0]|=128,n.write(f)}else o[0]&128&&n.write(new Uint8Array([0])),n.write(o);return new $r({valueHex:n.final()})}convertToDER(){let t=new $r({valueHex:this.valueBlock.valueHexView});return t.valueBlock.toDER(),t}convertFromDER(){return new $r({valueHex:this.valueBlock.valueHexView[0]===0?this.valueBlock.valueHexView.subarray(1):this.valueBlock.valueHexView})}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()}`}};$r=Jt;k.Integer=$r;Jt.NAME="INTEGER";var Wc,Wn=class extends Jt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};Wc=Wn;k.Enumerated=Wc;Wn.NAME="ENUMERATED";var Yr=class extends te(lt){constructor({valueDec:t=-1,isFirstSid:e=!1,...n}={}){super(n),this.valueDec=t,this.isFirstSid=e}fromBER(t,e,n){if(!n)return e;let s=q.BufferSourceConverter.toUint8Array(t);if(!Qt(this,s,e,n))return-1;let o=s.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let c=0;c<n&&(this.valueHexView[c]=o[c]&127,this.blockLength++,(o[c]&128)!==0);c++);let i=new Uint8Array(this.blockLength);for(let c=0;c<this.blockLength;c++)i[c]=this.valueHexView[c];return this.valueHexView=i,(o[this.blockLength-1]&128)!==0?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=Te(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}set valueBigInt(t){Vn();let e=BigInt(t).toString(2);for(;e.length%7;)e="0"+e;let n=new Uint8Array(e.length/7);for(let s=0;s<n.length;s++)n[s]=parseInt(e.slice(s*7,s*7+7),2)+(s+1<n.length?128:0);this.fromBER(n.buffer,0,n.length)}toBER(t){if(this.isHexOnly){if(t)return new ArrayBuffer(this.valueHexView.byteLength);let s=this.valueHexView,o=new Uint8Array(this.blockLength);for(let i=0;i<this.blockLength-1;i++)o[i]=s[i]|128;return o[this.blockLength-1]=s[this.blockLength-1],o.buffer}let e=ge(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Tt;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),o=e.byteLength-1;for(let i=0;i<o;i++)n[i]=s[i]|128;n[o]=s[o]}return n}toString(){let t="";if(this.isHexOnly)t=q.Convert.ToHex(this.valueHexView);else if(this.isFirstSid){let e=this.valueDec;this.valueDec<=39?t="0.":this.valueDec<=79?(t="1.",e-=40):(t="2.",e-=80),t+=e.toString()}else t=this.valueDec.toString();return t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec,isFirstSid:this.isFirstSid}}};Yr.NAME="sidBlock";var Jn=class extends lt{constructor({value:t=cr,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new Yr;if(s=o.fromBER(t,s,n),s===-1)return this.blockLength=0,this.error=o.error,s;this.value.length===0&&(o.isFirstSid=!0),this.blockLength+=o.blockLength,n-=o.blockLength,this.value.push(o)}return s}toBER(t){let e=[];for(let n=0;n<this.value.length;n++){let s=this.value[n].toBER(t);if(s.byteLength===0)return this.error=this.value[n].error,Tt;e.push(s)}return ei(e)}fromString(t){this.value=[];let e=0,n=0,s="",o=!1;do if(n=t.indexOf(".",e),n===-1?s=t.substring(e):s=t.substring(e,n),e=n+1,o){let i=this.value[0],c=0;switch(i.valueDec){case 0:break;case 1:c=40;break;case 2:c=80;break;default:this.value=[];return}let a=parseInt(s,10);if(isNaN(a))return;i.valueDec=a+c,o=!1}else{let i=new Yr;if(s>Number.MAX_SAFE_INTEGER){Vn();let c=BigInt(s);i.valueBigInt=c}else if(i.valueDec=parseInt(s,10),isNaN(i.valueDec))return;this.value.length||(i.isFirstSid=!0,o=!0),this.value.push(i)}while(n!==-1)}toString(){let t="",e=!1;for(let n=0;n<this.value.length;n++){e=this.value[n].isHexOnly;let s=this.value[n].toString();n!==0&&(t=`${t}.`),e?(s=`{${s}}`,this.value[n].isFirstSid?t=`2.{${s} - 80}`:t+=s):t+=s}return t}toJSON(){let t={...super.toJSON(),value:this.toString(),sidArray:[]};for(let e=0;e<this.value.length;e++)t.sidArray.push(this.value[e].toJSON());return t}};Jn.NAME="ObjectIdentifierValueBlock";var Jc,Ot=class extends it{getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}constructor(t={}){super(t,Jn),this.idBlock.tagClass=1,this.idBlock.tagNumber=6}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};Jc=Ot;k.ObjectIdentifier=Jc;Ot.NAME="OBJECT IDENTIFIER";var zr=class extends te(zt){constructor({valueDec:t=0,...e}={}){super(e),this.valueDec=t}fromBER(t,e,n){if(n===0)return e;let s=q.BufferSourceConverter.toUint8Array(t);if(!Qt(this,s,e,n))return-1;let o=s.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let c=0;c<n&&(this.valueHexView[c]=o[c]&127,this.blockLength++,(o[c]&128)!==0);c++);let i=new Uint8Array(this.blockLength);for(let c=0;c<this.blockLength;c++)i[c]=this.valueHexView[c];return this.valueHexView=i,(o[this.blockLength-1]&128)!==0?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=Te(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}toBER(t){if(this.isHexOnly){if(t)return new ArrayBuffer(this.valueHexView.byteLength);let s=this.valueHexView,o=new Uint8Array(this.blockLength);for(let i=0;i<this.blockLength-1;i++)o[i]=s[i]|128;return o[this.blockLength-1]=s[this.blockLength-1],o.buffer}let e=ge(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Tt;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),o=e.byteLength-1;for(let i=0;i<o;i++)n[i]=s[i]|128;n[o]=s[o]}return n.buffer}toString(){let t="";return this.isHexOnly?t=q.Convert.ToHex(this.valueHexView):t=this.valueDec.toString(),t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};zr.NAME="relativeSidBlock";var Xn=class extends lt{constructor({value:t=cr,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new zr;if(s=o.fromBER(t,s,n),s===-1)return this.blockLength=0,this.error=o.error,s;this.blockLength+=o.blockLength,n-=o.blockLength,this.value.push(o)}return s}toBER(t,e){let n=[];for(let s=0;s<this.value.length;s++){let o=this.value[s].toBER(t);if(o.byteLength===0)return this.error=this.value[s].error,Tt;n.push(o)}return ei(n)}fromString(t){this.value=[];let e=0,n=0,s="";do{n=t.indexOf(".",e),n===-1?s=t.substring(e):s=t.substring(e,n),e=n+1;let o=new zr;if(o.valueDec=parseInt(s,10),isNaN(o.valueDec))return!0;this.value.push(o)}while(n!==-1);return!0}toString(){let t="",e=!1;for(let n=0;n<this.value.length;n++){e=this.value[n].isHexOnly;let s=this.value[n].toString();n!==0&&(t=`${t}.`),e&&(s=`{${s}}`),t+=s}return t}toJSON(){let t={...super.toJSON(),value:this.toString(),sidArray:[]};for(let e=0;e<this.value.length;e++)t.sidArray.push(this.value[e].toJSON());return t}};Xn.NAME="RelativeObjectIdentifierValueBlock";var Xc,Qn=class extends it{getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}constructor(t={}){super(t,Xn),this.idBlock.tagClass=1,this.idBlock.tagNumber=13}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};Xc=Qn;k.RelativeObjectIdentifier=Xc;Qn.NAME="RelativeObjectIdentifier";var Qc,Et=class extends ye{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};Qc=Et;k.Sequence=Qc;Et.NAME="SEQUENCE";var tu,ts=class extends ye{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};tu=ts;k.Set=tu;ts.NAME="SET";var es=class extends te(lt){constructor({...t}={}){super(t),this.isHexOnly=!0,this.value=cr}toJSON(){return{...super.toJSON(),value:this.value}}};es.NAME="StringValueBlock";var rs=class extends es{};rs.NAME="SimpleStringValueBlock";var yt=class extends Mn{constructor({...t}={}){super(t,rs)}fromBuffer(t){this.valueBlock.value=String.fromCharCode.apply(null,q.BufferSourceConverter.toUint8Array(t))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e);for(let s=0;s<e;s++)n[s]=t.charCodeAt(s);this.valueBlock.value=t}};yt.NAME="SIMPLE STRING";var ns=class extends yt{fromBuffer(t){this.valueBlock.valueHexView=q.BufferSourceConverter.toUint8Array(t);try{this.valueBlock.value=q.Convert.ToUtf8String(t)}catch(e){this.warnings.push(`Error during "decodeURIComponent": ${e}, using raw string`),this.valueBlock.value=q.Convert.ToBinary(t)}}fromString(t){this.valueBlock.valueHexView=new Uint8Array(q.Convert.FromUtf8String(t)),this.valueBlock.value=t}};ns.NAME="Utf8StringValueBlock";var eu,Xt=class extends ns{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};eu=Xt;k.Utf8String=eu;Xt.NAME="UTF8String";var ss=class extends yt{fromBuffer(t){this.valueBlock.value=q.Convert.ToUtf16String(t),this.valueBlock.valueHexView=q.BufferSourceConverter.toUint8Array(t)}fromString(t){this.valueBlock.value=t,this.valueBlock.valueHexView=new Uint8Array(q.Convert.FromUtf16String(t))}};ss.NAME="BmpStringValueBlock";var ru,os=class extends ss{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};ru=os;k.BmpString=ru;os.NAME="BMPString";var is=class extends yt{fromBuffer(t){let e=ArrayBuffer.isView(t)?t.slice().buffer:t.slice(0),n=new Uint8Array(e);for(let s=0;s<n.length;s+=4)n[s]=n[s+3],n[s+1]=n[s+2],n[s+2]=0,n[s+3]=0;this.valueBlock.value=String.fromCharCode.apply(null,new Uint32Array(e))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e*4);for(let s=0;s<e;s++){let o=ge(t.charCodeAt(s),8),i=new Uint8Array(o);if(i.length>4)continue;let c=4-i.length;for(let a=i.length-1;a>=0;a--)n[s*4+a+c]=i[a]}this.valueBlock.value=t}};is.NAME="UniversalStringValueBlock";var nu,as=class extends is{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};nu=as;k.UniversalString=nu;as.NAME="UniversalString";var su,cs=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};su=cs;k.NumericString=su;cs.NAME="NumericString";var ou,us=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};ou=us;k.PrintableString=ou;us.NAME="PrintableString";var iu,ls=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};iu=ls;k.TeletexString=iu;ls.NAME="TeletexString";var au,fs=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};au=fs;k.VideotexString=au;fs.NAME="VideotexString";var cu,hs=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};cu=hs;k.IA5String=cu;hs.NAME="IA5String";var uu,ds=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};uu=ds;k.GraphicString=uu;ds.NAME="GraphicString";var lu,Wr=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};lu=Wr;k.VisibleString=lu;Wr.NAME="VisibleString";var fu,ps=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};fu=ps;k.GeneralString=fu;ps.NAME="GeneralString";var hu,gs=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};hu=gs;k.CharacterString=hu;gs.NAME="CharacterString";var du,Jr=class extends Wr{constructor({value:t,valueDate:e,...n}={}){if(super(n),this.year=0,this.month=0,this.day=0,this.hour=0,this.minute=0,this.second=0,t){this.fromString(t),this.valueBlock.valueHexView=new Uint8Array(t.length);for(let s=0;s<t.length;s++)this.valueBlock.valueHexView[s]=t.charCodeAt(s)}e&&(this.fromDate(e),this.valueBlock.valueHexView=new Uint8Array(this.toBuffer())),this.idBlock.tagClass=1,this.idBlock.tagNumber=23}fromBuffer(t){this.fromString(String.fromCharCode.apply(null,q.BufferSourceConverter.toUint8Array(t)))}toBuffer(){let t=this.toString(),e=new ArrayBuffer(t.length),n=new Uint8Array(e);for(let s=0;s<t.length;s++)n[s]=t.charCodeAt(s);return e}fromDate(t){this.year=t.getUTCFullYear(),this.month=t.getUTCMonth()+1,this.day=t.getUTCDate(),this.hour=t.getUTCHours(),this.minute=t.getUTCMinutes(),this.second=t.getUTCSeconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second))}fromString(t){let n=/(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})Z/ig.exec(t);if(n===null){this.error="Wrong input string for conversion";return}let s=parseInt(n[1],10);s>=50?this.year=1900+s:this.year=2e3+s,this.month=parseInt(n[2],10),this.day=parseInt(n[3],10),this.hour=parseInt(n[4],10),this.minute=parseInt(n[5],10),this.second=parseInt(n[6],10)}toString(t="iso"){if(t==="iso"){let e=new Array(7);return e[0]=vt(this.year<2e3?this.year-1900:this.year-2e3,2),e[1]=vt(this.month,2),e[2]=vt(this.day,2),e[3]=vt(this.hour,2),e[4]=vt(this.minute,2),e[5]=vt(this.second,2),e[6]="Z",e.join("")}return super.toString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.toDate().toISOString()}`}toJSON(){return{...super.toJSON(),year:this.year,month:this.month,day:this.day,hour:this.hour,minute:this.minute,second:this.second}}};du=Jr;k.UTCTime=du;Jr.NAME="UTCTime";var pu,ys=class extends Jr{constructor(t={}){var e;super(t),(e=this.millisecond)!==null&&e!==void 0||(this.millisecond=0),this.idBlock.tagClass=1,this.idBlock.tagNumber=24}fromDate(t){super.fromDate(t),this.millisecond=t.getUTCMilliseconds()}toDate(){let t=Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second,this.millisecond);return new Date(t)}fromString(t){let e=!1,n="",s="",o=0,i,c=0,a=0;if(t[t.length-1]==="Z")n=t.substring(0,t.length-1),e=!0;else{let u=new Number(t[t.length-1]);if(isNaN(u.valueOf()))throw new Error("Wrong input string for conversion");n=t}if(e){if(n.indexOf("+")!==-1)throw new Error("Wrong input string for conversion");if(n.indexOf("-")!==-1)throw new Error("Wrong input string for conversion")}else{let u=1,d=n.indexOf("+"),y="";if(d===-1&&(d=n.indexOf("-"),u=-1),d!==-1){if(y=n.substring(d+1),n=n.substring(0,d),y.length!==2&&y.length!==4)throw new Error("Wrong input string for conversion");let h=parseInt(y.substring(0,2),10);if(isNaN(h.valueOf()))throw new Error("Wrong input string for conversion");if(c=u*h,y.length===4){if(h=parseInt(y.substring(2,4),10),isNaN(h.valueOf()))throw new Error("Wrong input string for conversion");a=u*h}}}let l=n.indexOf(".");if(l===-1&&(l=n.indexOf(",")),l!==-1){let u=new Number(`0${n.substring(l)}`);if(isNaN(u.valueOf()))throw new Error("Wrong input string for conversion");o=u.valueOf(),s=n.substring(0,l)}else s=n;switch(!0){case s.length===8:if(i=/(\d{4})(\d{2})(\d{2})/ig,l!==-1)throw new Error("Wrong input string for conversion");break;case s.length===10:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})/ig,l!==-1){let u=60*o;this.minute=Math.floor(u),u=60*(u-this.minute),this.second=Math.floor(u),u=1e3*(u-this.second),this.millisecond=Math.floor(u)}break;case s.length===12:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})/ig,l!==-1){let u=60*o;this.second=Math.floor(u),u=1e3*(u-this.second),this.millisecond=Math.floor(u)}break;case s.length===14:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})/ig,l!==-1){let u=1e3*o;this.millisecond=Math.floor(u)}break;default:throw new Error("Wrong input string for conversion")}let f=i.exec(s);if(f===null)throw new Error("Wrong input string for conversion");for(let u=1;u<f.length;u++)switch(u){case 1:this.year=parseInt(f[u],10);break;case 2:this.month=parseInt(f[u],10);break;case 3:this.day=parseInt(f[u],10);break;case 4:this.hour=parseInt(f[u],10)+c;break;case 5:this.minute=parseInt(f[u],10)+a;break;case 6:this.second=parseInt(f[u],10);break;default:throw new Error("Wrong input string for conversion")}if(e===!1){let u=new Date(this.year,this.month,this.day,this.hour,this.minute,this.second,this.millisecond);this.year=u.getUTCFullYear(),this.month=u.getUTCMonth(),this.day=u.getUTCDay(),this.hour=u.getUTCHours(),this.minute=u.getUTCMinutes(),this.second=u.getUTCSeconds(),this.millisecond=u.getUTCMilliseconds()}}toString(t="iso"){if(t==="iso"){let e=[];return e.push(vt(this.year,4)),e.push(vt(this.month,2)),e.push(vt(this.day,2)),e.push(vt(this.hour,2)),e.push(vt(this.minute,2)),e.push(vt(this.second,2)),this.millisecond!==0&&(e.push("."),e.push(vt(this.millisecond,3))),e.push("Z"),e.join("")}return super.toString(t)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};pu=ys;k.GeneralizedTime=pu;ys.NAME="GeneralizedTime";var gu,ms=class extends Xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};gu=ms;k.DATE=gu;ms.NAME="DATE";var yu,bs=class extends Xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};yu=bs;k.TimeOfDay=yu;bs.NAME="TimeOfDay";var mu,ws=class extends Xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};mu=ws;k.DateTime=mu;ws.NAME="DateTime";var bu,xs=class extends Xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};bu=xs;k.Duration=bu;xs.NAME="Duration";var wu,vs=class extends Xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};wu=vs;k.TIME=wu;vs.NAME="TIME";async function As(r,t){let n=await ir.create().encrypt(r,t);return be.encode(n)}async function si(r,t,e){if(r.type==="RSA")return Lh(r,t,e);if(r.type==="Ed25519")return Ch(r,t,e);if(r.type==="secp256k1")return Nh(r,t,e);if(r.type==="ECDSA")return Uh(r,t,e);throw new Ve}async function Ch(r,t,e="libp2p-key"){if(e==="libp2p-key")return As(Le(r),t);throw new R(`export format '${e}' is not supported`)}async function Nh(r,t,e="libp2p-key"){if(e==="libp2p-key")return As(Le(r),t);throw new R("Export format is not supported")}async function Uh(r,t,e="libp2p-key"){if(e==="libp2p-key")return As(Le(r),t);throw new R(`export format '${e}' is not supported`)}async function Lh(r,t,e="pkcs-8"){if(e==="pkcs-8")return Th(r,t);if(e==="libp2p-key")return As(Le(r),t);throw new R("Export format is not supported")}async function Th(r,t){let e=Q.get(),s=new Et({value:[new Jt({value:0}),new Et({value:[new Ot({value:"1.2.840.113549.1.1.1"}),new Re]}),new Wt({valueHex:r.raw})]}).toBER(),o=new Uint8Array(s,0,s.byteLength),i=Ue(16),c=await Ln(ae,t,i,{c:1e4,dkLen:32}),a=Ue(16),l=await e.subtle.importKey("raw",c,"AES-CBC",!1,["encrypt"]),f=await e.subtle.encrypt({name:"AES-CBC",iv:a},l,o),u=new Et({value:[new Wt({valueHex:i}),new Jt({value:1e4}),new Jt({value:32}),new Et({value:[new Ot({value:"1.2.840.113549.2.11"}),new Re]})]}),d=new Et({value:[new Ot({value:"1.2.840.113549.1.5.13"}),new Et({value:[new Et({value:[new Ot({value:"1.2.840.113549.1.5.12"}),u]}),new Et({value:[new Ot({value:"2.16.840.1.101.3.4.1.42"}),new Wt({valueHex:a})]})]})]}),h=new Et({value:[d,new Wt({valueHex:f})]}).toBER(),B=new Uint8Array(h,0,h.byteLength);return["-----BEGIN ENCRYPTED PRIVATE KEY-----",...$(B,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
|
|
6
|
+
`)}`:`${e} :`}};$c=ye;k.Constructed=$c;ye.NAME="CONSTRUCTED";var qn=class extends lt{fromBER(t,e,n){return e}toBER(t){return Ot}};qn.override="EndOfContentValueBlock";var jc,$n=class extends it{constructor(t={}){super(t,qn),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};jc=$n;k.EndOfContent=jc;$n.NAME=Gr;var Gc,Re=class extends it{constructor(t={}){super(t,lt),this.idBlock.tagClass=1,this.idBlock.tagNumber=5}fromBER(t,e,n){return this.lenBlock.length>0&&this.warnings.push("Non-zero length of value block for Null type"),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.blockLength+=n,e+n>t.byteLength?(this.error="End of input reached before message was fully decoded (inconsistent offset and length values)",-1):e+n}toBER(t,e){let n=new ArrayBuffer(2);if(!t){let s=new Uint8Array(n);s[0]=5,s[1]=0}return e&&e.write(n),n}onAsciiEncoding(){return`${this.constructor.NAME}`}};Gc=Re;k.Null=Gc;Re.NAME="NULL";var jn=class extends te(lt){get value(){for(let t of this.valueHexView)if(t>0)return!0;return!1}set value(t){this.valueHexView[0]=t?255:0}constructor({value:t,...e}={}){super(e),e.valueHex?this.valueHexView=q.BufferSourceConverter.toUint8Array(e.valueHex):this.valueHexView=new Uint8Array(1),t&&(this.value=t)}fromBER(t,e,n){let s=q.BufferSourceConverter.toUint8Array(t);return Qt(this,s,e,n)?(this.valueHexView=s.subarray(e,e+n),n>1&&this.warnings.push("Boolean value encoded in more then 1 octet"),this.isHexOnly=!0,ti.call(this),this.blockLength=n,e+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};jn.NAME="BooleanValueBlock";var Zc,Gn=class extends it{getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}constructor(t={}){super(t,jn),this.idBlock.tagClass=1,this.idBlock.tagNumber=1}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.getValue}`}};Zc=Gn;k.Boolean=Zc;Gn.NAME="BOOLEAN";var Zn=class extends te(Kt){constructor({isConstructed:t=!1,...e}={}){super(e),this.isConstructed=t}fromBER(t,e,n){let s=0;if(this.isConstructed){if(this.isHexOnly=!1,s=Kt.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let o=0;o<this.value.length;o++){let i=this.value[o].constructor.NAME;if(i===Gr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(i!==Mc)return this.error="OCTET STRING may consists of OCTET STRINGs only",-1}}else this.isHexOnly=!0,s=super.fromBER(t,e,n),this.blockLength=n;return s}toBER(t,e){return this.isConstructed?Kt.prototype.toBER.call(this,t,e):t?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};Zn.NAME="OctetStringValueBlock";var ni,Wt=class extends it{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,o;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((o=n.value)===null||o===void 0)&&o.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},Zn),this.idBlock.tagClass=1,this.idBlock.tagNumber=4}fromBER(t,e,n){if(this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,n===0)return this.idBlock.error.length===0&&(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length===0&&(this.blockLength+=this.lenBlock.blockLength),e;if(!this.valueBlock.isConstructed){let o=(t instanceof ArrayBuffer?new Uint8Array(t):t).subarray(e,e+n);try{if(o.byteLength){let i=Es(o,0,o.byteLength);i.offset!==-1&&i.offset===n&&(this.valueBlock.value=[i.result])}}catch{}}return super.fromBER(t,e,n)}onAsciiEncoding(){if(this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length)return ye.prototype.onAsciiEncoding.call(this);let t=this.constructor.NAME,e=q.Convert.ToHex(this.valueBlock.valueHexView);return`${t} : ${e}`}getValue(){if(!this.idBlock.isConstructed)return this.valueBlock.valueHexView.slice().buffer;let t=[];for(let e of this.valueBlock.value)e instanceof ni&&t.push(e.valueBlock.valueHexView);return q.BufferSourceConverter.concat(t)}};ni=Wt;k.OctetString=ni;Wt.NAME=Mc;var Yn=class extends te(Kt){constructor({unusedBits:t=0,isConstructed:e=!1,...n}={}){super(n),this.unusedBits=t,this.isConstructed=e,this.blockLength=this.valueHexView.byteLength}fromBER(t,e,n){if(!n)return e;let s=-1;if(this.isConstructed){if(s=Kt.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let c of this.value){let a=c.constructor.NAME;if(a===Gr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(a!==Pc)return this.error="BIT STRING may consists of BIT STRINGs only",-1;let l=c.valueBlock;if(this.unusedBits>0&&l.unusedBits>0)return this.error='Using of "unused bits" inside constructive BIT STRING allowed for least one only',-1;this.unusedBits=l.unusedBits}return s}let o=q.BufferSourceConverter.toUint8Array(t);if(!Qt(this,o,e,n))return-1;let i=o.subarray(e,e+n);if(this.unusedBits=i[0],this.unusedBits>7)return this.error="Unused bits for BitString must be in range 0-7",-1;if(!this.unusedBits){let c=i.subarray(1);try{if(c.byteLength){let a=Es(c,0,c.byteLength);a.offset!==-1&&a.offset===n-1&&(this.value=[a.result])}}catch{}}return this.valueHexView=i.subarray(1),this.blockLength=i.length,e+n}toBER(t,e){if(this.isConstructed)return Kt.prototype.toBER.call(this,t,e);if(t)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength){let s=new Uint8Array(1);return s[0]=0,s.buffer}let n=new Uint8Array(this.valueHexView.length+1);return n[0]=this.unusedBits,n.set(this.valueHexView,1),n.buffer}toJSON(){return{...super.toJSON(),unusedBits:this.unusedBits,isConstructed:this.isConstructed}}};Yn.NAME="BitStringValueBlock";var Yc,zn=class extends it{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,o;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((o=n.value)===null||o===void 0)&&o.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},Yn),this.idBlock.tagClass=1,this.idBlock.tagNumber=3}fromBER(t,e,n){return this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,super.fromBER(t,e,n)}onAsciiEncoding(){if(this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length)return ye.prototype.onAsciiEncoding.call(this);{let t=[],e=this.valueBlock.valueHexView;for(let i of e)t.push(i.toString(2).padStart(8,"0"));let n=t.join(""),s=this.constructor.NAME,o=n.substring(0,n.length-this.valueBlock.unusedBits);return`${s} : ${o}`}}};Yc=zn;k.BitString=Yc;zn.NAME=Pc;var zc;function kh(r,t){let e=new Uint8Array([0]),n=new Uint8Array(r),s=new Uint8Array(t),o=n.slice(0),i=o.length-1,c=s.slice(0),a=c.length-1,l=0,f=a<i?i:a,u=0;for(let d=f;d>=0;d--,u++){switch(!0){case u<c.length:l=o[i-u]+c[a-u]+e[0];break;default:l=o[i-u]+e[0]}switch(e[0]=l/10,!0){case u>=o.length:o=Kn(new Uint8Array([l%10]),o);break;default:o[i-u]=l%10}}return e[0]>0&&(o=Kn(e,o)),o}function Hc(r){if(r>=qr.length)for(let t=qr.length;t<=r;t++){let e=new Uint8Array([0]),n=qr[t-1].slice(0);for(let s=n.length-1;s>=0;s--){let o=new Uint8Array([(n[s]<<1)+e[0]]);e[0]=o[0]/10,n[s]=o[0]%10}e[0]>0&&(n=Kn(e,n)),qr.push(n)}return qr[r]}function Ih(r,t){let e=0,n=new Uint8Array(r),s=new Uint8Array(t),o=n.slice(0),i=o.length-1,c=s.slice(0),a=c.length-1,l,f=0;for(let u=a;u>=0;u--,f++)switch(l=o[i-f]-c[a-f]-e,!0){case l<0:e=1,o[i-f]=l+10;break;default:e=0,o[i-f]=l}if(e>0)for(let u=i-a+1;u>=0;u--,f++)if(l=o[i-f]-e,l<0)e=1,o[i-f]=l+10;else{e=0,o[i-f]=l;break}return o.slice()}var Zr=class extends te(lt){setValueHex(){this.valueHexView.length>=4?(this.warnings.push("Too big Integer for decoding, hex only"),this.isHexOnly=!0,this._valueDec=0):(this.isHexOnly=!1,this.valueHexView.length>0&&(this._valueDec=ti.call(this)))}constructor({value:t,...e}={}){super(e),this._valueDec=0,e.valueHex&&this.setValueHex(),t!==void 0&&(this.valueDec=t)}set valueDec(t){this._valueDec=t,this.isHexOnly=!1,this.valueHexView=new Uint8Array(Kc(t))}get valueDec(){return this._valueDec}fromDER(t,e,n,s=0){let o=this.fromBER(t,e,n);if(o===-1)return o;let i=this.valueHexView;return i[0]===0&&(i[1]&128)!==0?this.valueHexView=i.subarray(1):s!==0&&i.length<s&&(s-i.length>1&&(s=i.length+1),this.valueHexView=i.subarray(s-i.length)),o}toDER(t=!1){let e=this.valueHexView;switch(!0){case(e[0]&128)!==0:{let n=new Uint8Array(this.valueHexView.length+1);n[0]=0,n.set(e,1),this.valueHexView=n}break;case(e[0]===0&&(e[1]&128)===0):this.valueHexView=this.valueHexView.subarray(1);break}return this.toBER(t)}fromBER(t,e,n){let s=super.fromBER(t,e,n);return s===-1||this.setValueHex(),s}toBER(t){return t?new ArrayBuffer(this.valueHexView.length):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}toString(){let t=this.valueHexView.length*8-1,e=new Uint8Array(this.valueHexView.length*8/3),n=0,s,o=this.valueHexView,i="",c=!1;for(let a=o.byteLength-1;a>=0;a--){s=o[a];for(let l=0;l<8;l++){if((s&1)===1)switch(n){case t:e=Ih(Hc(n),e),i="-";break;default:e=kh(e,Hc(n))}n++,s>>=1}}for(let a=0;a<e.length;a++)e[a]&&(c=!0),c&&(i+=Oc.charAt(e[a]));return c===!1&&(i+=Oc.charAt(0)),i}};zc=Zr;Zr.NAME="IntegerValueBlock";Object.defineProperty(zc.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var $r,Jt=class extends it{constructor(t={}){super(t,Zr),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return Vn(),BigInt(this.valueBlock.toString())}static fromBigInt(t){Vn();let e=BigInt(t),n=new jr,s=e.toString(16).replace(/^-/,""),o=new Uint8Array(q.Convert.FromHex(s));if(e<0){let c=new Uint8Array(o.length+(o[0]&128?1:0));c[0]|=128;let l=BigInt(`0x${q.Convert.ToHex(c)}`)+e,f=q.BufferSourceConverter.toUint8Array(q.Convert.FromHex(l.toString(16)));f[0]|=128,n.write(f)}else o[0]&128&&n.write(new Uint8Array([0])),n.write(o);return new $r({valueHex:n.final()})}convertToDER(){let t=new $r({valueHex:this.valueBlock.valueHexView});return t.valueBlock.toDER(),t}convertFromDER(){return new $r({valueHex:this.valueBlock.valueHexView[0]===0?this.valueBlock.valueHexView.subarray(1):this.valueBlock.valueHexView})}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()}`}};$r=Jt;k.Integer=$r;Jt.NAME="INTEGER";var Wc,Wn=class extends Jt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};Wc=Wn;k.Enumerated=Wc;Wn.NAME="ENUMERATED";var Yr=class extends te(lt){constructor({valueDec:t=-1,isFirstSid:e=!1,...n}={}){super(n),this.valueDec=t,this.isFirstSid=e}fromBER(t,e,n){if(!n)return e;let s=q.BufferSourceConverter.toUint8Array(t);if(!Qt(this,s,e,n))return-1;let o=s.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let c=0;c<n&&(this.valueHexView[c]=o[c]&127,this.blockLength++,(o[c]&128)!==0);c++);let i=new Uint8Array(this.blockLength);for(let c=0;c<this.blockLength;c++)i[c]=this.valueHexView[c];return this.valueHexView=i,(o[this.blockLength-1]&128)!==0?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=Te(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}set valueBigInt(t){Vn();let e=BigInt(t).toString(2);for(;e.length%7;)e="0"+e;let n=new Uint8Array(e.length/7);for(let s=0;s<n.length;s++)n[s]=parseInt(e.slice(s*7,s*7+7),2)+(s+1<n.length?128:0);this.fromBER(n.buffer,0,n.length)}toBER(t){if(this.isHexOnly){if(t)return new ArrayBuffer(this.valueHexView.byteLength);let s=this.valueHexView,o=new Uint8Array(this.blockLength);for(let i=0;i<this.blockLength-1;i++)o[i]=s[i]|128;return o[this.blockLength-1]=s[this.blockLength-1],o.buffer}let e=ge(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Ot;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),o=e.byteLength-1;for(let i=0;i<o;i++)n[i]=s[i]|128;n[o]=s[o]}return n}toString(){let t="";if(this.isHexOnly)t=q.Convert.ToHex(this.valueHexView);else if(this.isFirstSid){let e=this.valueDec;this.valueDec<=39?t="0.":this.valueDec<=79?(t="1.",e-=40):(t="2.",e-=80),t+=e.toString()}else t=this.valueDec.toString();return t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec,isFirstSid:this.isFirstSid}}};Yr.NAME="sidBlock";var Jn=class extends lt{constructor({value:t=cr,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new Yr;if(s=o.fromBER(t,s,n),s===-1)return this.blockLength=0,this.error=o.error,s;this.value.length===0&&(o.isFirstSid=!0),this.blockLength+=o.blockLength,n-=o.blockLength,this.value.push(o)}return s}toBER(t){let e=[];for(let n=0;n<this.value.length;n++){let s=this.value[n].toBER(t);if(s.byteLength===0)return this.error=this.value[n].error,Ot;e.push(s)}return ei(e)}fromString(t){this.value=[];let e=0,n=0,s="",o=!1;do if(n=t.indexOf(".",e),n===-1?s=t.substring(e):s=t.substring(e,n),e=n+1,o){let i=this.value[0],c=0;switch(i.valueDec){case 0:break;case 1:c=40;break;case 2:c=80;break;default:this.value=[];return}let a=parseInt(s,10);if(isNaN(a))return;i.valueDec=a+c,o=!1}else{let i=new Yr;if(s>Number.MAX_SAFE_INTEGER){Vn();let c=BigInt(s);i.valueBigInt=c}else if(i.valueDec=parseInt(s,10),isNaN(i.valueDec))return;this.value.length||(i.isFirstSid=!0,o=!0),this.value.push(i)}while(n!==-1)}toString(){let t="",e=!1;for(let n=0;n<this.value.length;n++){e=this.value[n].isHexOnly;let s=this.value[n].toString();n!==0&&(t=`${t}.`),e?(s=`{${s}}`,this.value[n].isFirstSid?t=`2.{${s} - 80}`:t+=s):t+=s}return t}toJSON(){let t={...super.toJSON(),value:this.toString(),sidArray:[]};for(let e=0;e<this.value.length;e++)t.sidArray.push(this.value[e].toJSON());return t}};Jn.NAME="ObjectIdentifierValueBlock";var Jc,Vt=class extends it{getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}constructor(t={}){super(t,Jn),this.idBlock.tagClass=1,this.idBlock.tagNumber=6}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};Jc=Vt;k.ObjectIdentifier=Jc;Vt.NAME="OBJECT IDENTIFIER";var zr=class extends te(zt){constructor({valueDec:t=0,...e}={}){super(e),this.valueDec=t}fromBER(t,e,n){if(n===0)return e;let s=q.BufferSourceConverter.toUint8Array(t);if(!Qt(this,s,e,n))return-1;let o=s.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let c=0;c<n&&(this.valueHexView[c]=o[c]&127,this.blockLength++,(o[c]&128)!==0);c++);let i=new Uint8Array(this.blockLength);for(let c=0;c<this.blockLength;c++)i[c]=this.valueHexView[c];return this.valueHexView=i,(o[this.blockLength-1]&128)!==0?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=Te(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}toBER(t){if(this.isHexOnly){if(t)return new ArrayBuffer(this.valueHexView.byteLength);let s=this.valueHexView,o=new Uint8Array(this.blockLength);for(let i=0;i<this.blockLength-1;i++)o[i]=s[i]|128;return o[this.blockLength-1]=s[this.blockLength-1],o.buffer}let e=ge(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Ot;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),o=e.byteLength-1;for(let i=0;i<o;i++)n[i]=s[i]|128;n[o]=s[o]}return n.buffer}toString(){let t="";return this.isHexOnly?t=q.Convert.ToHex(this.valueHexView):t=this.valueDec.toString(),t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};zr.NAME="relativeSidBlock";var Xn=class extends lt{constructor({value:t=cr,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new zr;if(s=o.fromBER(t,s,n),s===-1)return this.blockLength=0,this.error=o.error,s;this.blockLength+=o.blockLength,n-=o.blockLength,this.value.push(o)}return s}toBER(t,e){let n=[];for(let s=0;s<this.value.length;s++){let o=this.value[s].toBER(t);if(o.byteLength===0)return this.error=this.value[s].error,Ot;n.push(o)}return ei(n)}fromString(t){this.value=[];let e=0,n=0,s="";do{n=t.indexOf(".",e),n===-1?s=t.substring(e):s=t.substring(e,n),e=n+1;let o=new zr;if(o.valueDec=parseInt(s,10),isNaN(o.valueDec))return!0;this.value.push(o)}while(n!==-1);return!0}toString(){let t="",e=!1;for(let n=0;n<this.value.length;n++){e=this.value[n].isHexOnly;let s=this.value[n].toString();n!==0&&(t=`${t}.`),e&&(s=`{${s}}`),t+=s}return t}toJSON(){let t={...super.toJSON(),value:this.toString(),sidArray:[]};for(let e=0;e<this.value.length;e++)t.sidArray.push(this.value[e].toJSON());return t}};Xn.NAME="RelativeObjectIdentifierValueBlock";var Xc,Qn=class extends it{getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}constructor(t={}){super(t,Xn),this.idBlock.tagClass=1,this.idBlock.tagNumber=13}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};Xc=Qn;k.RelativeObjectIdentifier=Xc;Qn.NAME="RelativeObjectIdentifier";var Qc,Et=class extends ye{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};Qc=Et;k.Sequence=Qc;Et.NAME="SEQUENCE";var tu,ts=class extends ye{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};tu=ts;k.Set=tu;ts.NAME="SET";var es=class extends te(lt){constructor({...t}={}){super(t),this.isHexOnly=!0,this.value=cr}toJSON(){return{...super.toJSON(),value:this.value}}};es.NAME="StringValueBlock";var rs=class extends es{};rs.NAME="SimpleStringValueBlock";var yt=class extends Mn{constructor({...t}={}){super(t,rs)}fromBuffer(t){this.valueBlock.value=String.fromCharCode.apply(null,q.BufferSourceConverter.toUint8Array(t))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e);for(let s=0;s<e;s++)n[s]=t.charCodeAt(s);this.valueBlock.value=t}};yt.NAME="SIMPLE STRING";var ns=class extends yt{fromBuffer(t){this.valueBlock.valueHexView=q.BufferSourceConverter.toUint8Array(t);try{this.valueBlock.value=q.Convert.ToUtf8String(t)}catch(e){this.warnings.push(`Error during "decodeURIComponent": ${e}, using raw string`),this.valueBlock.value=q.Convert.ToBinary(t)}}fromString(t){this.valueBlock.valueHexView=new Uint8Array(q.Convert.FromUtf8String(t)),this.valueBlock.value=t}};ns.NAME="Utf8StringValueBlock";var eu,Xt=class extends ns{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};eu=Xt;k.Utf8String=eu;Xt.NAME="UTF8String";var ss=class extends yt{fromBuffer(t){this.valueBlock.value=q.Convert.ToUtf16String(t),this.valueBlock.valueHexView=q.BufferSourceConverter.toUint8Array(t)}fromString(t){this.valueBlock.value=t,this.valueBlock.valueHexView=new Uint8Array(q.Convert.FromUtf16String(t))}};ss.NAME="BmpStringValueBlock";var ru,os=class extends ss{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};ru=os;k.BmpString=ru;os.NAME="BMPString";var is=class extends yt{fromBuffer(t){let e=ArrayBuffer.isView(t)?t.slice().buffer:t.slice(0),n=new Uint8Array(e);for(let s=0;s<n.length;s+=4)n[s]=n[s+3],n[s+1]=n[s+2],n[s+2]=0,n[s+3]=0;this.valueBlock.value=String.fromCharCode.apply(null,new Uint32Array(e))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e*4);for(let s=0;s<e;s++){let o=ge(t.charCodeAt(s),8),i=new Uint8Array(o);if(i.length>4)continue;let c=4-i.length;for(let a=i.length-1;a>=0;a--)n[s*4+a+c]=i[a]}this.valueBlock.value=t}};is.NAME="UniversalStringValueBlock";var nu,as=class extends is{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};nu=as;k.UniversalString=nu;as.NAME="UniversalString";var su,cs=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};su=cs;k.NumericString=su;cs.NAME="NumericString";var ou,us=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};ou=us;k.PrintableString=ou;us.NAME="PrintableString";var iu,ls=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};iu=ls;k.TeletexString=iu;ls.NAME="TeletexString";var au,fs=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};au=fs;k.VideotexString=au;fs.NAME="VideotexString";var cu,hs=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};cu=hs;k.IA5String=cu;hs.NAME="IA5String";var uu,ds=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};uu=ds;k.GraphicString=uu;ds.NAME="GraphicString";var lu,Wr=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};lu=Wr;k.VisibleString=lu;Wr.NAME="VisibleString";var fu,ps=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};fu=ps;k.GeneralString=fu;ps.NAME="GeneralString";var hu,gs=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};hu=gs;k.CharacterString=hu;gs.NAME="CharacterString";var du,Jr=class extends Wr{constructor({value:t,valueDate:e,...n}={}){if(super(n),this.year=0,this.month=0,this.day=0,this.hour=0,this.minute=0,this.second=0,t){this.fromString(t),this.valueBlock.valueHexView=new Uint8Array(t.length);for(let s=0;s<t.length;s++)this.valueBlock.valueHexView[s]=t.charCodeAt(s)}e&&(this.fromDate(e),this.valueBlock.valueHexView=new Uint8Array(this.toBuffer())),this.idBlock.tagClass=1,this.idBlock.tagNumber=23}fromBuffer(t){this.fromString(String.fromCharCode.apply(null,q.BufferSourceConverter.toUint8Array(t)))}toBuffer(){let t=this.toString(),e=new ArrayBuffer(t.length),n=new Uint8Array(e);for(let s=0;s<t.length;s++)n[s]=t.charCodeAt(s);return e}fromDate(t){this.year=t.getUTCFullYear(),this.month=t.getUTCMonth()+1,this.day=t.getUTCDate(),this.hour=t.getUTCHours(),this.minute=t.getUTCMinutes(),this.second=t.getUTCSeconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second))}fromString(t){let n=/(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})Z/ig.exec(t);if(n===null){this.error="Wrong input string for conversion";return}let s=parseInt(n[1],10);s>=50?this.year=1900+s:this.year=2e3+s,this.month=parseInt(n[2],10),this.day=parseInt(n[3],10),this.hour=parseInt(n[4],10),this.minute=parseInt(n[5],10),this.second=parseInt(n[6],10)}toString(t="iso"){if(t==="iso"){let e=new Array(7);return e[0]=vt(this.year<2e3?this.year-1900:this.year-2e3,2),e[1]=vt(this.month,2),e[2]=vt(this.day,2),e[3]=vt(this.hour,2),e[4]=vt(this.minute,2),e[5]=vt(this.second,2),e[6]="Z",e.join("")}return super.toString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.toDate().toISOString()}`}toJSON(){return{...super.toJSON(),year:this.year,month:this.month,day:this.day,hour:this.hour,minute:this.minute,second:this.second}}};du=Jr;k.UTCTime=du;Jr.NAME="UTCTime";var pu,ys=class extends Jr{constructor(t={}){var e;super(t),(e=this.millisecond)!==null&&e!==void 0||(this.millisecond=0),this.idBlock.tagClass=1,this.idBlock.tagNumber=24}fromDate(t){super.fromDate(t),this.millisecond=t.getUTCMilliseconds()}toDate(){let t=Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second,this.millisecond);return new Date(t)}fromString(t){let e=!1,n="",s="",o=0,i,c=0,a=0;if(t[t.length-1]==="Z")n=t.substring(0,t.length-1),e=!0;else{let u=new Number(t[t.length-1]);if(isNaN(u.valueOf()))throw new Error("Wrong input string for conversion");n=t}if(e){if(n.indexOf("+")!==-1)throw new Error("Wrong input string for conversion");if(n.indexOf("-")!==-1)throw new Error("Wrong input string for conversion")}else{let u=1,d=n.indexOf("+"),y="";if(d===-1&&(d=n.indexOf("-"),u=-1),d!==-1){if(y=n.substring(d+1),n=n.substring(0,d),y.length!==2&&y.length!==4)throw new Error("Wrong input string for conversion");let h=parseInt(y.substring(0,2),10);if(isNaN(h.valueOf()))throw new Error("Wrong input string for conversion");if(c=u*h,y.length===4){if(h=parseInt(y.substring(2,4),10),isNaN(h.valueOf()))throw new Error("Wrong input string for conversion");a=u*h}}}let l=n.indexOf(".");if(l===-1&&(l=n.indexOf(",")),l!==-1){let u=new Number(`0${n.substring(l)}`);if(isNaN(u.valueOf()))throw new Error("Wrong input string for conversion");o=u.valueOf(),s=n.substring(0,l)}else s=n;switch(!0){case s.length===8:if(i=/(\d{4})(\d{2})(\d{2})/ig,l!==-1)throw new Error("Wrong input string for conversion");break;case s.length===10:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})/ig,l!==-1){let u=60*o;this.minute=Math.floor(u),u=60*(u-this.minute),this.second=Math.floor(u),u=1e3*(u-this.second),this.millisecond=Math.floor(u)}break;case s.length===12:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})/ig,l!==-1){let u=60*o;this.second=Math.floor(u),u=1e3*(u-this.second),this.millisecond=Math.floor(u)}break;case s.length===14:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})/ig,l!==-1){let u=1e3*o;this.millisecond=Math.floor(u)}break;default:throw new Error("Wrong input string for conversion")}let f=i.exec(s);if(f===null)throw new Error("Wrong input string for conversion");for(let u=1;u<f.length;u++)switch(u){case 1:this.year=parseInt(f[u],10);break;case 2:this.month=parseInt(f[u],10);break;case 3:this.day=parseInt(f[u],10);break;case 4:this.hour=parseInt(f[u],10)+c;break;case 5:this.minute=parseInt(f[u],10)+a;break;case 6:this.second=parseInt(f[u],10);break;default:throw new Error("Wrong input string for conversion")}if(e===!1){let u=new Date(this.year,this.month,this.day,this.hour,this.minute,this.second,this.millisecond);this.year=u.getUTCFullYear(),this.month=u.getUTCMonth(),this.day=u.getUTCDay(),this.hour=u.getUTCHours(),this.minute=u.getUTCMinutes(),this.second=u.getUTCSeconds(),this.millisecond=u.getUTCMilliseconds()}}toString(t="iso"){if(t==="iso"){let e=[];return e.push(vt(this.year,4)),e.push(vt(this.month,2)),e.push(vt(this.day,2)),e.push(vt(this.hour,2)),e.push(vt(this.minute,2)),e.push(vt(this.second,2)),this.millisecond!==0&&(e.push("."),e.push(vt(this.millisecond,3))),e.push("Z"),e.join("")}return super.toString(t)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};pu=ys;k.GeneralizedTime=pu;ys.NAME="GeneralizedTime";var gu,ms=class extends Xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};gu=ms;k.DATE=gu;ms.NAME="DATE";var yu,bs=class extends Xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};yu=bs;k.TimeOfDay=yu;bs.NAME="TimeOfDay";var mu,ws=class extends Xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};mu=ws;k.DateTime=mu;ws.NAME="DateTime";var bu,xs=class extends Xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};bu=xs;k.Duration=bu;xs.NAME="Duration";var wu,vs=class extends Xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};wu=vs;k.TIME=wu;vs.NAME="TIME";async function As(r,t){let n=await ir.create().encrypt(r,t);return be.encode(n)}async function si(r,t,e){if(r.type==="RSA")return Lh(r,t,e);if(r.type==="Ed25519")return Ch(r,t,e);if(r.type==="secp256k1")return Nh(r,t,e);if(r.type==="ECDSA")return Uh(r,t,e);throw new Ve}async function Ch(r,t,e="libp2p-key"){if(e==="libp2p-key")return As(Le(r),t);throw new R(`export format '${e}' is not supported`)}async function Nh(r,t,e="libp2p-key"){if(e==="libp2p-key")return As(Le(r),t);throw new R("Export format is not supported")}async function Uh(r,t,e="libp2p-key"){if(e==="libp2p-key")return As(Le(r),t);throw new R(`export format '${e}' is not supported`)}async function Lh(r,t,e="pkcs-8"){if(e==="pkcs-8")return Th(r,t);if(e==="libp2p-key")return As(Le(r),t);throw new R("Export format is not supported")}async function Th(r,t){let e=Q.get(),s=new Et({value:[new Jt({value:0}),new Et({value:[new Vt({value:"1.2.840.113549.1.1.1"}),new Re]}),new Wt({valueHex:r.raw})]}).toBER(),o=new Uint8Array(s,0,s.byteLength),i=Ue(16),c=await Ln(ae,t,i,{c:1e4,dkLen:32}),a=Ue(16),l=await e.subtle.importKey("raw",c,"AES-CBC",!1,["encrypt"]),f=await e.subtle.encrypt({name:"AES-CBC",iv:a},l,o),u=new Et({value:[new Wt({valueHex:i}),new Jt({value:1e4}),new Jt({value:32}),new Et({value:[new Vt({value:"1.2.840.113549.2.11"}),new Re]})]}),d=new Et({value:[new Vt({value:"1.2.840.113549.1.5.13"}),new Et({value:[new Et({value:[new Vt({value:"1.2.840.113549.1.5.12"}),u]}),new Et({value:[new Vt({value:"2.16.840.1.101.3.4.1.42"}),new Wt({valueHex:a})]})]})]}),h=new Et({value:[d,new Wt({valueHex:f})]}).toBER(),B=new Uint8Array(h,0,h.byteLength);return["-----BEGIN ENCRYPTED PRIVATE KEY-----",...$(B,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
|
|
7
7
|
`)}async function oi(r,t){try{let e=await Rh(r,t);return bc(e)}catch{}if(!r.includes("BEGIN"))throw new R("Encrypted key was not a libp2p-key or a PEM file");return _h(r,t)}async function Rh(r,t){let e=be.decode(r);return ir.create().decrypt(e,t)}async function _h(r,t){let e=Q.get(),n;if(r.includes("-----BEGIN ENCRYPTED PRIVATE KEY-----")){let o=F(r.replace("-----BEGIN ENCRYPTED PRIVATE KEY-----","").replace("-----END ENCRYPTED PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:i}=Bs(o),{iv:c,salt:a,iterations:l,keySize:f,cipherText:u}=Dh(i),d=await Ln(ae,t,a,{c:l,dkLen:f}),y=await e.subtle.importKey("raw",d,"AES-CBC",!1,["decrypt"]),h=Xr(await e.subtle.decrypt({name:"AES-CBC",iv:c},y,u)),{result:B}=Bs(h);n=Bu(B)}else if(r.includes("-----BEGIN PRIVATE KEY-----")){let o=F(r.replace("-----BEGIN PRIVATE KEY-----","").replace("-----END PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:i}=Bs(o);n=Bu(i)}else throw new R("Could not parse private key from PEM data");let s=wc(n);if(s.type!=="RSA")throw new R("Could not parse RSA private key from PEM data");return s}function Dh(r){let t=r.valueBlock.value[0];if(t.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.13")throw new R("Only pkcs5PBES2 encrypted private keys are supported");let n=t.valueBlock.value[1].valueBlock.value[0];if(n.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.12")throw new R("Only pkcs5PBKDF2 key derivation functions are supported");let o=n.valueBlock.value[1],i=Xr(o.valueBlock.value[0].getValue()),c=1e4,a=32;if(o.valueBlock.value.length===3)c=Number(o.valueBlock.value[1].toBigInt()),a=Number(o.valueBlock.value[2].toBigInt());else if(o.valueBlock.value.length===2)throw new R("Could not derive key size and iterations from PEM file - please use @libp2p/rsa to re-import your key");let l=t.valueBlock.value[1].valueBlock.value[1],f=l.valueBlock.value[0].toString();if(f!=="OBJECT IDENTIFIER : 1.2.840.113549.3.7"){if(f!=="OBJECT IDENTIFIER : 1.3.14.3.2.7"){if(f!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.2"){if(f!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.22"){if(f!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.42")throw new R("Only AES-CBC encryption schemes are supported")}}}}let u=Xr(l.valueBlock.value[1].getValue());return{cipherText:Xr(r.valueBlock.value[1].getValue()),salt:i,iterations:c,keySize:a,iv:u}}function Bu(r){return Xr(r.valueBlock.value[2].getValue())}function Xr(r){return new Uint8Array(r,0,r.byteLength)}var Kh="/pkcs8/",ii="/info/",Qr=new WeakMap,_e={minKeyLength:112/8,minSaltLength:128/8,minIterationCount:1e3};function ur(r){return r==null||typeof r!="string"?!1:r===(0,Au.default)(r.trim())&&r.length>0}async function at(){let e=Math.random()*800+200;await new Promise(n=>setTimeout(n,e))}function De(r){return new Fr(Kh+r)}function lr(r){return new Fr(ii+r)}async function Vh(r){let t=Le(r),e=await $e.digest(t);return tt.encode(e.bytes).substring(1)}var Ss=class{components;init;log;self;constructor(t,e){if(this.components=t,this.log=t.logger.forComponent("libp2p:keychain"),this.init={...e,dek:{...Xo,...e.dek}},this.self=e.selfKey??"self",this.init.pass!=null&&this.init.pass?.length<20)throw new Error("pass must be least 20 characters");if(this.init.dek?.keyLength!=null&&this.init.dek.keyLength<_e.minKeyLength)throw new Error(`dek.keyLength must be least ${_e.minKeyLength} bytes`);if(this.init.dek?.salt?.length!=null&&this.init.dek.salt.length<_e.minSaltLength)throw new Error(`dek.saltLength must be least ${_e.minSaltLength} bytes`);if(this.init.dek?.iterationCount!=null&&this.init.dek.iterationCount<_e.minIterationCount)throw new Error(`dek.iterationCount must be least ${_e.minIterationCount}`);let n=this.init.pass!=null&&this.init.dek?.salt!=null?Pr(this.init.pass,this.init.dek?.salt,this.init.dek?.iterationCount,this.init.dek?.keyLength,this.init.dek?.hash):"";Qr.set(this,{dek:n})}[Symbol.toStringTag]="@libp2p/keychain";[hi]=["@libp2p/keychain"];static generateOptions(){let t=Object.assign({},this.options),e=Math.ceil(_e.minSaltLength/3)*3;return t.dek!=null&&(t.dek.salt=$(Ue(e),"base64")),t}static get options(){return{dek:{...Xo}}}async findKeyByName(t){if(!ur(t))throw await at(),new R(`Invalid key name '${t}'`);let e=lr(t);try{let n=await this.components.datastore.get(e);return JSON.parse($(n))}catch(n){throw await at(),this.log.error("could not read key from datastore - %e",n),new nn(`Key '${t}' does not exist.`)}}async findKeyById(t){try{let e={prefix:ii};for await(let n of this.components.datastore.query(e)){let s=JSON.parse($(n.value));if(s.id===t)return s}throw new R(`Key with id '${t}' does not exist.`)}catch(e){throw await at(),e}}async importKey(t,e){if(!ur(t))throw await at(),new R(`Invalid key name '${t}'`);if(e==null)throw await at(),new R("Key is required");let n=De(t);if(await this.components.datastore.has(n))throw await at(),new R(`Key '${t}' already exists`);let o,i;try{o=await Vh(e);let l=Qr.get(this);if(l==null)throw new R("dek missing");let f=l.dek;i=await si(e,f,e.type==="RSA"?"pkcs-8":"libp2p-key")}catch(l){throw await at(),l}let c={name:t,id:o},a=this.components.datastore.batch();return a.put(n,F(i)),a.put(lr(t),F(JSON.stringify(c))),await a.commit(),c}async exportKey(t){if(!ur(t))throw await at(),new R(`Invalid key name '${t}'`);let e=De(t);try{let n=await this.components.datastore.get(e),s=$(n),o=Qr.get(this);if(o==null)throw new R("dek missing");let i=o.dek;return await oi(s,i)}catch(n){throw await at(),n}}async removeKey(t){if(!ur(t)||t===this.self)throw await at(),new R(`Invalid key name '${t}'`);let e=De(t),n=await this.findKeyByName(t),s=this.components.datastore.batch();return s.delete(e),s.delete(lr(t)),await s.commit(),n}async listKeys(){let t={prefix:ii},e=[];for await(let n of this.components.datastore.query(t))e.push(JSON.parse($(n.value)));return e}async renameKey(t,e){if(!ur(t)||t===this.self)throw await at(),new R(`Invalid old key name '${t}'`);if(!ur(e)||e===this.self)throw await at(),new R(`Invalid new key name '${e}'`);let n=De(t),s=De(e),o=lr(t),i=lr(e);if(await this.components.datastore.has(s))throw await at(),new R(`Key '${e}' already exists`);try{let a=await this.components.datastore.get(n),l=await this.components.datastore.get(o),f=JSON.parse($(l));f.name=e;let u=this.components.datastore.batch();return u.put(s,a),u.put(i,F(JSON.stringify(f))),u.delete(n),u.delete(o),await u.commit(),f}catch(a){throw await at(),a}}async rotateKeychainPass(t,e){if(typeof t!="string")throw await at(),new R(`Invalid old pass type '${typeof t}'`);if(typeof e!="string")throw await at(),new R(`Invalid new pass type '${typeof e}'`);if(e.length<20)throw await at(),new R(`Invalid pass length ${e.length}`);this.log("recreating keychain");let n=Qr.get(this);if(n==null)throw new R("dek missing");let s=n.dek;this.init.pass=e;let o=e!=null&&this.init.dek?.salt!=null?Pr(e,this.init.dek.salt,this.init.dek?.iterationCount,this.init.dek?.keyLength,this.init.dek?.hash):"";Qr.set(this,{dek:o});let i=await this.listKeys();for(let c of i){let a=await this.components.datastore.get(De(c.name)),l=$(a),f=await oi(l,s),u=o.toString(),d=await si(f,u,f.type==="RSA"?"pkcs-8":"libp2p-key"),y=this.components.datastore.batch(),h={name:c.name,id:c.id};y.put(De(c.name),F(d)),y.put(lr(c.name),F(JSON.stringify(h))),await y.commit()}this.log("keychain reconstructed")}};function Oh(r={}){return t=>new Ss(t,r)}return Uu(Hh);})();
|
|
8
8
|
/*! Bundled license information:
|
|
9
9
|
|