@libp2p/keychain 6.0.11 → 6.0.12-2151144c3
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 +3 -3
- package/dist/index.min.js.map +4 -4
- package/package.json +6 -5
- package/dist/typedoc-urls.json +0 -14
package/dist/index.min.js
CHANGED
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
(function (root, factory) {(typeof module === 'object' && module.exports) ? module.exports = factory() : root.Libp2PKeychain = factory()}(typeof self !== 'undefined' ? self : this, function () {
|
|
2
|
-
"use strict";var Libp2PKeychain=(()=>{var ku=Object.create;var en=Object.defineProperty;var Iu=Object.getOwnPropertyDescriptor;var Cu=Object.getOwnPropertyNames;var Nu=Object.getPrototypeOf,Tu=Object.prototype.hasOwnProperty;var lr=(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})},li=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of Cu(t))!Tu.call(r,s)&&s!==e&&en(r,s,{get:()=>t[s],enumerable:!(n=Iu(t,s))||n.enumerable});return r};var fi=(r,t,e)=>(e=r!=null?ku(Nu(r)):{},li(t||!r||!r.__esModule?en(e,"default",{value:r,enumerable:!0}):e,r)),Uu=r=>li(en({},"__esModule",{value:!0}),r);var Cc=lr((Wy,Ic)=>{"use strict";function sh(r){return r>=55296&&r<=56319}function oh(r){return r>=56320&&r<=57343}Ic.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],sh(i)&&oh(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 Tc=lr((Jy,Nc)=>{"use strict";function ih(r){return r>=55296&&r<=56319}function ah(r){return r>=56320&&r<=57343}Nc.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),ah(s)?o!=null&&ih(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=lr((Xy,Uc)=>{"use strict";var ch=Cc(),uh=Tc();Uc.exports=ch.bind(null,uh)});var Dc=lr((Qy,Rc)=>{"use strict";var lh=Lc(),fh=/[\/\?<>\\:\*\|"]/g,hh=/[\x00-\x1f\x80-\x9f]/g,dh=/^\.+$/,ph=/^(con|prn|aux|nul|com[0-9]|lpt[0-9])(\..*)?$/i;function gh(r,t){for(var e=r.length;e>0&&(r[e-1]==="."||r[e-1]===" ");)e--;return e<r.length?r.slice(0,e)+t:r}function _c(r,t){if(typeof r!="string")throw new Error("Input must be string");var e=r.replace(fh,t).replace(hh,t).replace(dh,t).replace(ph,t);return e=gh(e,t),lh(e,255)}Rc.exports=function(r,t){var e=t&&t.replacement||"",n=_c(r,e);return e===""?n:_c(n,"")}});var Kc=lr(ir=>{"use strict";var mh="[object ArrayBuffer]",Yt=class r{static isArrayBuffer(t){return Object.prototype.toString.call(t)===mh}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}},ti="string",bh=/^[0-9a-f\s]+$/i,wh=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,xh=/^[a-zA-Z0-9-_]+$/,Kn=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}},Vn=class r{static isHex(t){return typeof t===ti&&bh.test(t)}static isBase64(t){return typeof t===ti&&wh.test(t)}static isBase64Url(t){return typeof t===ti&&xh.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 Kn.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 Kn.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,"")||""}};Vn.DEFAULT_UTF8_ENCODING="utf8";function vh(r,...t){let e=arguments[0];for(let n=1;n<arguments.length;n++){let s=arguments[n];for(let o in s)e[o]=s[o]}return e}function Eh(...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 Bh(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}ir.BufferSourceConverter=Yt;ir.Convert=Vn;ir.assign=vh;ir.combine=Eh;ir.isEqual=Bh});var Mh={};ft(Mh,{keychain:()=>Hh});var fr=class extends Error{constructor(t="An error occurred while signing a message"){super(t),this.name="SigningError"}},hr=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 hi={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 tt=hi;var _=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"}},dr=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 di=Symbol.for("@libp2p/service-capabilities"),Yh=Symbol.for("@libp2p/service-dependencies");var Ls={};ft(Ls,{base58btc:()=>et,base58flickr:()=>Ou});var xd=new Uint8Array(0);function pi(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function 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 gi(r){return new TextEncoder().encode(r)}function yi(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),u=Math.log(c)/Math.log(256),f=Math.log(256)/Math.log(c);function l(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)*u+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:l,decodeUnsafe:d,decode:y}}var _u=Lu,Ru=_u,bi=Ru;var Cs=class{name;prefix;baseEncode;constructor(t,e,n){this.name=t,this.prefix=e,this.baseEncode=n}encode(t){if(t instanceof Uint8Array)return`${this.prefix}${this.baseEncode(t)}`;throw Error("Unknown type, must be binary type")}},Ns=class{name;prefix;baseDecode;prefixCodePoint;constructor(t,e,n){this.name=t,this.prefix=e;let s=e.codePointAt(0);if(s===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=s,this.baseDecode=n}decode(t){if(typeof t=="string"){if(t.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(t)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(t.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(t){return wi(this,t)}},Ts=class{decoders;constructor(t){this.decoders=t}or(t){return wi(this,t)}decode(t){let e=t[0],n=this.decoders[e];if(n!=null)return n.decode(t);throw RangeError(`Unable to decode multibase string ${JSON.stringify(t)}, only inputs prefixed with ${Object.keys(this.decoders)} are supported`)}};function wi(r,t){return new Ts({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var Us=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(t,e,n,s){this.name=t,this.prefix=e,this.baseEncode=n,this.baseDecode=s,this.encoder=new Cs(t,e,n),this.decoder=new Ns(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 Us(r,t,e,n)}function ee({name:r,prefix:t,alphabet:e}){let{encode:n,decode:s}=bi(e,r);return Oe({prefix:t,name:r,encode:n,decode:o=>Ht(s(o))})}function Du(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 u=0;u<s;++u){let f=t[r[u]];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 Ku(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 Vu(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=Vu(n);return Oe({prefix:t,name:r,encode(o){return Ku(o,n,e)},decode(o){return Du(o,s,e,r)}})}var et=ee({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),Ou=ee({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var _s={};ft(_s,{base32:()=>He,base32hex:()=>Fu,base32hexpad:()=>$u,base32hexpadupper:()=>ju,base32hexupper:()=>qu,base32pad:()=>Mu,base32padupper:()=>Pu,base32upper:()=>Hu,base32z:()=>Gu});var He=J({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),Hu=J({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Mu=J({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),Pu=J({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),Fu=J({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),qu=J({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),$u=J({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),ju=J({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),Gu=J({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Rs={};ft(Rs,{base36:()=>pr,base36upper:()=>Zu});var pr=ee({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),Zu=ee({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Yu=Ei,xi=128,zu=127,Wu=~zu,Ju=Math.pow(2,31);function Ei(r,t,e){t=t||[],e=e||0;for(var n=e;r>=Ju;)t[e++]=r&255|xi,r/=128;for(;r&Wu;)t[e++]=r&255|xi,r>>>=7;return t[e]=r|0,Ei.bytes=e-n+1,t}var Xu=Ds,Qu=128,vi=127;function Ds(r,n){var e=0,n=n||0,s=0,o=n,i,c=r.length;do{if(o>=c)throw Ds.bytes=0,new RangeError("Could not decode varint");i=r[o++],e+=s<28?(i&vi)<<s:(i&vi)*Math.pow(2,s),s+=7}while(i>=Qu);return Ds.bytes=o-n,e}var tl=Math.pow(2,7),el=Math.pow(2,14),rl=Math.pow(2,21),nl=Math.pow(2,28),sl=Math.pow(2,35),ol=Math.pow(2,42),il=Math.pow(2,49),al=Math.pow(2,56),cl=Math.pow(2,63),ul=function(r){return r<tl?1:r<el?2:r<rl?3:r<nl?4:r<sl?5:r<ol?6:r<il?7:r<al?8:r<cl?9:10},ll={encode:Yu,decode:Xu,encodingLength:ul},fl=ll,gr=fl;function yr(r,t=0){return[gr.decode(r,t),gr.decode.bytes]}function Me(r,t,e=0){return gr.encode(r,t,e),t}function Pe(r){return gr.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 Bi(r){let t=Ht(r),[e,n]=yr(t),[s,o]=yr(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 Ai(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&pi(r.bytes,e.bytes)}}var Fe=class{code;size;digest;bytes;constructor(t,e,n,s){this.code=t,this.size=e,this.digest=n,this.bytes=s}};function Si(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return dl(e,Ks(r),t??et.encoder);default:return pl(e,Ks(r),t??He.encoder)}}var ki=new WeakMap;function Ks(r){let t=ki.get(r);if(t==null){let e=new Map;return ki.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!==br)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==gl)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&&Ai(t.multihash,n.multihash)}toString(t){return Si(this,t)}toJSON(){return{"/":Si(this)}}link(){return this}[Symbol.toStringTag]="CID";[Symbol.for("nodejs.util.inspect.custom")](){return`CID(${this.toString()})`}static asCID(t){if(t==null)return null;let e=t;if(e instanceof r)return e;if(e["/"]!=null&&e["/"]===e.bytes||e.asCID===e){let{version:n,code:s,multihash:o,bytes:i}=e;return new r(n,s,o,i??Ii(n,s,o.bytes))}else if(e[yl]===!0){let{version:n,multihash:s,code:o}=e,i=Bi(s);return r.create(n,o,i)}else return null}static create(t,e,n){if(typeof e!="number")throw new Error("String codecs are no longer supported");if(!(n.bytes instanceof Uint8Array))throw new Error("Invalid digest");switch(t){case 0:{if(e!==br)throw new Error(`Version 0 CID must use dag-pb (code: ${br}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let s=Ii(t,e,n.bytes);return new r(t,e,n,s)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,br,t)}static createV1(t,e){return r.create(1,t,e)}static decode(t){let[e,n]=r.decodeFirst(t);if(n.length!==0)throw new Error("Incorrect length");return e}static decodeFirst(t){let e=r.inspectBytes(t),n=e.size-e.multihashSize,s=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[l,d]=yr(t.subarray(e));return e+=d,l},s=n(),o=br;if(s===18?(s=0,e=0):o=n(),s!==0&&s!==1)throw new RangeError(`Invalid CID version ${s}`);let i=e,c=n(),a=n(),u=e+a,f=u-i;return{version:s,codec:o,multihashCode:c,digestSize:a,multihashSize:f,size:u}}static parse(t,e){let[n,s]=hl(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 Ks(o).set(n,t),o}};function hl(r,t){switch(r[0]){case"Q":{let e=t??et;return[et.prefix,e.decode(`${et.prefix}${r}`)]}case et.prefix:{let e=t??et;return[et.prefix,e.decode(r)]}case He.prefix:{let e=t??He;return[He.prefix,e.decode(r)]}case pr.prefix:{let e=t??pr;return[pr.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 dl(r,t,e){let{prefix:n}=e;if(n!==et.prefix)throw Error(`Cannot string encode V0 in ${e.name} encoding`);let s=t.get(n);if(s==null){let o=e.encode(r).slice(1);return t.set(n,o),o}else return s}function pl(r,t,e){let{prefix:n}=e,s=t.get(n);if(s==null){let o=e.encode(r);return t.set(n,o),o}else return s}var br=112,gl=18;function Ii(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 yl=Symbol.for("@ipld/js-cid/CID");var Vs={};ft(Vs,{identity:()=>me});var Ci=0,ml="identity",Ni=Ht;function bl(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(Ci,Ni(r))}var me={code:Ci,name:ml,encode:Ni,digest:bl};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 Ti(r,t){if(t==null||t<0)throw new RangeError("index is out of bounds");let e=0;for(let n of r){let s=e+n.byteLength;if(t<s)return{buf:n,index:t-e};e=s}throw new RangeError("index is out of bounds")}function 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=Ti(this.bufs,t);return e.buf[e.index]}set(t,e){let n=Ti(this.bufs,t);n.buf[n.index]=e}write(t,e=0){if(t instanceof Uint8Array)for(let n=0;n<t.length;n++)this.set(e+n,t[n]);else if(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 u=t>=c&&t<a,f=e>c&&e<=a;if(u&&f){if(t===c&&e===a){n.push(i);break}let l=t-c;n.push(i.subarray(l,l+(e-t)));break}if(u){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 l=0;l<o;l++)i[l]=-1;for(let l=0;l<s;l++)i[n[l]]=l;let c=i,a=this.byteLength-n.byteLength,u=n.byteLength-1,f;for(let l=e;l<=a;l+=f){f=0;for(let d=u;d>=0;d--){let y=this.get(l+d);if(n[d]!==y){f=Math.max(1,d-c[y]);break}}if(f===0)return l}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 Os={};ft(Os,{base10:()=>wl});var wl=ee({prefix:"9",name:"base10",alphabet:"0123456789"});var Hs={};ft(Hs,{base16:()=>xl,base16upper:()=>vl});var xl=J({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),vl=J({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Ms={};ft(Ms,{base2:()=>El});var El=J({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Ps={};ft(Ps,{base256emoji:()=>Il});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}"),Bl=Li.reduce((r,t,e)=>(r[e]=t,r),[]),Al=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 Sl(r){return r.reduce((t,e)=>(t+=Bl[e],t),"")}function kl(r){let t=[];for(let e of r){let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);let s=Al[n];if(s==null)throw new Error(`Non-base256emoji character: ${e}`);t.push(s)}return new Uint8Array(t)}var Il=Oe({prefix:"\u{1F680}",name:"base256emoji",encode:Sl,decode:kl});var Fs={};ft(Fs,{base64:()=>be,base64pad:()=>Cl,base64url:()=>Nl,base64urlpad:()=>Tl});var be=J({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),Cl=J({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Nl=J({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Tl=J({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var qs={};ft(qs,{base8:()=>Ul});var Ul=J({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var $s={};ft($s,{identity:()=>Ll});var Ll=Oe({prefix:"\0",name:"identity",encode:r=>yi(r),decode:r=>gi(r)});var n0=new TextEncoder,s0=new TextDecoder;var Zs={};ft(Zs,{sha256:()=>$e,sha512:()=>Kl});var Dl=20;function Gs({name:r,code:t,encode:e,minDigestLength:n,maxDigestLength:s}){return new js(r,t,e,n,s)}var js=class{name;code;encode;minDigestLength;maxDigestLength;constructor(t,e,n,s,o){this.name=t,this.code=e,this.encode=n,this.minDigestLength=s??Dl,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?_i(n,this.code,e?.truncate):n.then(s=>_i(s,this.code,e?.truncate))}else throw Error("Unknown type, must be binary type")}};function _i(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 Di(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var $e=Gs({name:"sha2-256",code:18,encode:Di("SHA-256")}),Kl=Gs({name:"sha2-512",code:19,encode:Di("SHA-512")});var Ys={...$s,...Ms,...qs,...Os,...Hs,..._s,...Rs,...Ls,...Fs,...Ps},y0={...Zs,...Vs};function Vi(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var Ki=Vi("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),zs=Vi("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}),Vl={utf8:Ki,"utf-8":Ki,hex:Ys.base16,latin1:zs,ascii:zs,binary:zs,...Ys},an=Vl;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 Ol=parseInt("11111",2),Ws=parseInt("10000000",2),Hl=parseInt("01111111",2),Oi={0:wr,1:wr,2:Ml,3:ql,4:$l,5:Fl,6:Pl,16:wr,22:wr,48:wr};function Ct(r,t={offset:0}){let e=r[t.offset]&Ol;if(t.offset++,Oi[e]!=null)return Oi[e](r,t);throw new Error("No decoder for tag "+e)}function xr(r,t){let e=0;if((r[t.offset]&Ws)===Ws){let n=r[t.offset]&Hl,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 wr(r,t){xr(r,t);let e=[];for(;!(t.offset>=r.byteLength);){let n=Ct(r,t);if(n===null)break;e.push(n)}return e}function Ml(r,t){let e=xr(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 Pl(r,t){let e=xr(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 u=r[t.offset];if(t.offset++,a.push(u&127),u<128){a.reverse();let f=0;for(let l=0;l<a.length;l++)f+=a[l]<<l*7;c+=`.${f}`,a=[]}}return c}function Fl(r,t){return t.offset++,null}function ql(r,t){let e=xr(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 $l(r,t){let e=xr(r,t),n=r.subarray(t.offset,t.offset+e);return t.offset+=e,n}function jl(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=jl(r.byteLength);return new ht(Uint8Array.from([t.byteLength|Ws]),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 vr(r){let t=Uint8Array.from([0]),e=new ht(t,r);return new ht(Uint8Array.from([3]),cn(e),e)}function Hi(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 Mi="1.2.840.10045.3.1.7",Pi="1.3.132.0.34",Fi="1.3.132.0.35";async function qi(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 $i(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 Gl=Uint8Array.from([6,8,42,134,72,206,61,3,1,7]),Zl=Uint8Array.from([6,5,43,129,4,0,34]),Yl=Uint8Array.from([6,5,43,129,4,0,35]),zl={ext:!0,kty:"EC",crv:"P-256"},Wl={ext:!0,kty:"EC",crv:"P-384"},Jl={ext:!0,kty:"EC",crv:"P-521"},Js=32,Xs=48,Qs=66;function ji(r){let t=Ct(r);return to(t)}function to(r){let t=r[1],e=$(t,"base64url"),n=r[2][1][0],s=1,o,i;if(t.byteLength===Js)return o=$(n.subarray(s,s+Js),"base64url"),i=$(n.subarray(s+Js),"base64url"),new je({...zl,key_ops:["sign"],d:e,x:o,y:i});if(t.byteLength===Xs)return o=$(n.subarray(s,s+Xs),"base64url"),i=$(n.subarray(s+Xs),"base64url"),new je({...Wl,key_ops:["sign"],d:e,x:o,y:i});if(t.byteLength===Qs)return o=$(n.subarray(s,s+Qs),"base64url"),i=$(n.subarray(s+Qs),"base64url"),new je({...Jl,key_ops:["sign"],d:e,x:o,y:i});throw new _(`Private key length was wrong length, got ${t.byteLength}, expected 32, 48 or 66`)}function Gi(r){return Nt([dt(Uint8Array.from([1])),Hi(F(r.d??"","base64url")),Nt([Yi(r.crv)],160),Nt([vr(new ht(Uint8Array.from([4]),F(r.x??"","base64url"),F(r.y??"","base64url")))],161)]).subarray()}function Zi(r){return Nt([dt(Uint8Array.from([1])),Nt([Yi(r.crv)],160),Nt([vr(new ht(Uint8Array.from([4]),F(r.x??"","base64url"),F(r.y??"","base64url")))],161)]).subarray()}function Yi(r){if(r==="P-256")return Gl;if(r==="P-384")return Zl;if(r==="P-521")return Yl;throw new _(`Invalid curve ${r}`)}var un=class{type="ECDSA";jwk;_raw;constructor(t){this.jwk=t}get raw(){return this._raw==null&&(this._raw=Zi(this.jwk)),this._raw}toMultihash(){return me.digest(Ge(this))}toCID(){return St.createV1(114,this.toMultihash())}toString(){return et.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 $i(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=Gi(this.jwk)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:mt(this.raw,t.raw)}async sign(t,e){return qi(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 Wi(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 Tt(r,t){return r<<32-t|r>>>t}function ln(r,t){return r<<t|r>>>32-t>>>0}var Ji=typeof Uint8Array.from([]).toHex=="function"&&typeof Uint8Array.fromHex=="function",Xl=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function Ft(r){if(O(r),Ji)return r.toHex();let t="";for(let e=0;e<r.length;e++)t+=Xl[r[e]];return t}var Pt={_0:48,_9:57,A:65,F:70,a:97,f:102};function zi(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(Ji)return Uint8Array.fromHex(r);let t=r.length,e=t/2;if(t%2)throw new Error("hex string expected, got unpadded hex of length "+t);let n=new Uint8Array(e);for(let s=0,o=0;s<e;s++,o+=2){let i=zi(r.charCodeAt(o)),c=zi(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 Ql=async()=>{};async function Xi(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 Ql(),n+=o)}}function tf(r){if(typeof r!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(r))}function eo(r,t=""){return typeof r=="string"?tf(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 Qi(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 Er(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 ro=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),Wi(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 l=i;l<s;l++)e[l]=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 u=a/4,f=this.get();if(u>f.length)throw new Error("_sha2: outputLen bigger than state");for(let l=0;l<u;l++)c.setUint32(4*l,f[l],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),ta=BigInt(32);function ef(r,t=!1){return t?{h:Number(r&dn),l:Number(r>>ta&dn)}:{h:Number(r>>ta&dn)|0,l:Number(r&dn)|0}}function ea(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}=ef(r[o],t);[n[o],s[o]]=[i,c]}return[n,s]}var no=(r,t,e)=>r>>>e,so=(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,Br=(r,t,e)=>r<<64-e|t>>>e-32,Ar=(r,t,e)=>r>>>e-32|t<<64-e;function Rt(r,t,e,n){let s=(t>>>0)+(n>>>0);return{h:r+e+(s/2**32|0)|0,l:s|0}}var ra=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),na=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,sa=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),oa=(r,t,e,n,s)=>t+e+n+s+(r/2**32|0)|0,ia=(r,t,e,n,s)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(s>>>0),aa=(r,t,e,n,s,o)=>t+e+n+s+o+(r/2**32|0)|0;var nf=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),oo=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 l=0;l<16;l++,e+=4)ne[l]=t.getUint32(e,!1);for(let l=16;l<64;l++){let d=ne[l-15],y=ne[l-2],h=Tt(d,7)^Tt(d,18)^d>>>3,B=Tt(y,17)^Tt(y,19)^y>>>10;ne[l]=B+ne[l-7]+h+ne[l-16]|0}let{A:n,B:s,C:o,D:i,E:c,F:a,G:u,H:f}=this;for(let l=0;l<64;l++){let d=Tt(c,6)^Tt(c,11)^Tt(c,25),y=f+d+fn(c,a,u)+nf[l]+ne[l]|0,B=(Tt(n,2)^Tt(n,13)^Tt(n,22))+hn(n,s,o)|0;f=u,u=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,u=u+this.G|0,f=f+this.H|0,this.set(n,s,o,i,c,a,u,f)}roundClean(){wt(ne)}destroy(){this.set(0,0,0,0,0,0,0,0),wt(this.buffer)}},io=class extends oo{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 ca=ea(["0x428a2f98d728ae22","0x7137449123ef65cd","0xb5c0fbcfec4d3b2f","0xe9b5dba58189dbbc","0x3956c25bf348b538","0x59f111f1b605d019","0x923f82a4af194f9b","0xab1c5ed5da6d8118","0xd807aa98a3030242","0x12835b0145706fbe","0x243185be4ee4b28c","0x550c7dc3d5ffb4e2","0x72be5d74f27b896f","0x80deb1fe3b1696b1","0x9bdc06a725c71235","0xc19bf174cf692694","0xe49b69c19ef14ad2","0xefbe4786384f25e3","0x0fc19dc68b8cd5b5","0x240ca1cc77ac9c65","0x2de92c6f592b0275","0x4a7484aa6ea6e483","0x5cb0a9dcbd41fbd4","0x76f988da831153b5","0x983e5152ee66dfab","0xa831c66d2db43210","0xb00327c898fb213f","0xbf597fc7beef0ee4","0xc6e00bf33da88fc2","0xd5a79147930aa725","0x06ca6351e003826f","0x142929670a0e6e70","0x27b70a8546d22ffc","0x2e1b21385c26c926","0x4d2c6dfc5ac42aed","0x53380d139d95b3df","0x650a73548baf63de","0x766a0abb3c77b2a8","0x81c2c92e47edaee6","0x92722c851482353b","0xa2bfe8a14cf10364","0xa81a664bbc423001","0xc24b8b70d0f89791","0xc76c51a30654be30","0xd192e819d6ef5218","0xd69906245565a910","0xf40e35855771202a","0x106aa07032bbd1b8","0x19a4c116b8d2d0c8","0x1e376c085141ab53","0x2748774cdf8eeb99","0x34b0bcb5e19b48a8","0x391c0cb3c5c95a63","0x4ed8aa4ae3418acb","0x5b9cca4f7763e373","0x682e6ff3d6b2b8a3","0x748f82ee5defb2fc","0x78a5636f43172f60","0x84c87814a1f0ab72","0x8cc702081a6439ec","0x90befffa23631e28","0xa4506cebde82bde9","0xbef9a3f7b2c67915","0xc67178f2e372532b","0xca273eceea26619c","0xd186b8c721c0c207","0xeada7dd6cde0eb1e","0xf57d4f7fee6ed178","0x06f067aa72176fba","0x0a637dc5a2c898a6","0x113f9804bef90dae","0x1b710b35131c471b","0x28db77f523047d84","0x32caab7b40c72493","0x3c9ebe0a15c9bebc","0x431d67c49c100d4c","0x4cc5d4becb3e42b6","0x597f299cfc657e2a","0x5fcb6fab3ad6faec","0x6c44198c4a475817"].map(r=>BigInt(r))),sf=ca[0],of=ca[1],se=new Uint32Array(80),oe=new Uint32Array(80),ao=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:u,El:f,Fh:l,Fl:d,Gh:y,Gl:h,Hh:B,Hl:v}=this;return[t,e,n,s,o,i,c,a,u,f,l,d,y,h,B,v]}set(t,e,n,s,o,i,c,a,u,f,l,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=u|0,this.El=f|0,this.Fh=l|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)^no(I,D,7),M=Be(I,D,1)^Be(I,D,8)^so(I,D,7),E=se[w-2]|0,x=oe[w-2]|0,K=Ee(E,x,19)^Br(E,x,61)^no(E,x,6),P=Be(E,x,19)^Ar(E,x,61)^so(E,x,6),U=sa(M,P,oe[w-7],oe[w-16]),m=oa(U,H,K,se[w-7],se[w-16]);se[w]=m|0,oe[w]=U|0}let{Ah:n,Al:s,Bh:o,Bl:i,Ch:c,Cl:a,Dh:u,Dl:f,Eh:l,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(l,d,14)^Ee(l,d,18)^Br(l,d,41),D=Be(l,d,14)^Be(l,d,18)^Ar(l,d,41),H=l&y^~l&B,M=d&h^~d&v,E=ia(A,D,M,of[w],oe[w]),x=aa(E,g,I,H,sf[w],se[w]),K=E|0,P=Ee(n,s,28)^Br(n,s,34)^Br(n,s,39),U=Be(n,s,28)^Ar(n,s,34)^Ar(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=l|0,h=d|0,{h:l,l:d}=Rt(u|0,f|0,x|0,K|0),u=c|0,f=a|0,c=o|0,a=i|0,o=n|0,i=s|0;let p=ra(K,U,b);n=na(p,x,P,m),s=p|0}({h:n,l:s}=Rt(this.Ah|0,this.Al|0,n|0,s|0)),{h:o,l:i}=Rt(this.Bh|0,this.Bl|0,o|0,i|0),{h:c,l:a}=Rt(this.Ch|0,this.Cl|0,c|0,a|0),{h:u,l:f}=Rt(this.Dh|0,this.Dl|0,u|0,f|0),{h:l,l:d}=Rt(this.Eh|0,this.El|0,l|0,d|0),{h:y,l:h}=Rt(this.Fh|0,this.Fl|0,y|0,h|0),{h:B,l:v}=Rt(this.Gh|0,this.Gl|0,B|0,v|0),{h:g,l:A}=Rt(this.Hh|0,this.Hl|0,g|0,A|0),this.set(n,s,o,i,c,a,u,f,l,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)}},co=class extends ao{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=Er(()=>new io,ro(1));var ae=Er(()=>new co,ro(3));var lo=BigInt(0),uo=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 ua(r){if(typeof r=="bigint"){if(!pn(r))throw new Error("positive bigint expected, got "+r)}else bt(r);return r}function Sr(r){let t=ua(r).toString(16);return t.length&1?"0"+t:t}function la(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return r===""?lo:BigInt("0x"+r)}function ze(r){return la(Ft(r))}function Ae(r){return la(Ft(yn(O(r)).reverse()))}function gn(r,t){bt(t),r=ua(r);let e=qt(r.toString(16).padStart(t*2,"0"));if(e.length!==t)throw new Error("number too large");return e}function fo(r,t){return gn(r,t).reverse()}function yn(r){return Uint8Array.from(r)}var pn=r=>typeof r=="bigint"&&lo<=r;function af(r,t,e){return pn(r)&&pn(t)&&pn(e)&&t<=r&&r<e}function kr(r,t,e,n){if(!af(t,e,n))throw new Error("expected valid "+r+": "+e+" <= n < "+n+", got "+t)}function ho(r){let t;for(t=0;r>lo;r>>=uo,t+=1);return t}var Ir=r=>(uo<<BigInt(r))-uo;function fa(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),u=n(r),f=0,l=()=>{a.fill(1),u.fill(0),f=0},d=(...v)=>e(u,xt(a,...v)),y=(v=s)=>{u=d(o,v),a=d(),v.length!==0&&(u=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)=>{l(),y(v);let A;for(;!(A=g(h()));)y();return l(),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 u=typeof a;if(u!==i||a===null)throw new Error(`param "${o}" is invalid: expected ${i}, got ${u}`)}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),pa=BigInt(3),ga=BigInt(4),ya=BigInt(5),cf=BigInt(7),ma=BigInt(8),uf=BigInt(9),ba=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 ha(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 u=n/e,f=n%e,l=s-i*u,d=o-c*u;n=e,e=f,s=i,o=c,i=l,c=d}if(n!==rt)throw new Error("invert: does not exist");return X(s,t)}function go(r,t,e){if(!r.eql(r.sqr(t),e))throw new Error("Cannot find square root")}function wa(r,t){let e=(r.ORDER+rt)/ga,n=r.pow(t,e);return go(r,n,t),n}function lf(r,t){let e=(r.ORDER-ya)/ma,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 go(r,c,t),c}function ff(r){let t=Je(r),e=xa(r),n=e(t,t.neg(t.ONE)),s=e(t,n),o=e(t,t.neg(n)),i=(r+cf)/ba;return(c,a)=>{let u=c.pow(a,i),f=c.mul(u,n),l=c.mul(u,s),d=c.mul(u,o),y=c.eql(c.sqr(f),a),h=c.eql(c.sqr(l),a);u=c.cmov(u,f,y),f=c.cmov(d,l,h);let B=c.eql(c.sqr(f),a),v=c.cmov(u,f,B);return go(c,v,a),v}}function xa(r){if(r<pa)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(;da(s,n)===1;)if(n++>1e3)throw new Error("Cannot find square root: probably non-prime P");if(e===1)return wa;let o=s.pow(n,t),i=(t+rt)/Se;return function(a,u){if(a.is0(u))return u;if(da(a,u)!==1)throw new Error("Cannot find square root");let f=e,l=a.mul(a.ONE,o),d=a.pow(u,t),y=a.pow(u,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(l,v);f=h,l=a.sqr(g),d=a.mul(d,l),y=a.mul(y,g)}return y}}function hf(r){return r%ga===pa?wa:r%ma===ya?lf:r%ba===uf?ff(r):xa(r)}var va=(r,t)=>(X(r,t)&rt)===rt,df=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function yo(r){let t={ORDER:"bigint",BYTES:"number",BITS:"number"},e=df.reduce((n,s)=>(n[s]="function",n),t);return ce(r,e),r}function pf(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 Cr(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 da(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 gf(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 po=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}=gf(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 pf(this,t,e)}div(t,e){return X(t*ha(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 ha(t,this.ORDER)}sqrt(t){return this._sqrt||(this._sqrt=hf(this.ORDER)),this._sqrt(this,t)}toBytes(t){return this.isLE?fo(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 u=new Uint8Array(s);u.set(t,o?0:u.length-t.length),t=u}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 Cr(this,t)}cmov(t,e,n){return n?e:t}};function Je(r,t={}){return new po(r,t)}function Ea(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 mo(r){let t=Ea(r);return t+Math.ceil(t/2)}function bo(r,t,e=!1){O(r);let n=r.length,s=Ea(t),o=mo(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?fo(c,s):gn(c,s)}var Xe=BigInt(0),ke=BigInt(1);function Nr(r,t){let e=t.negate();return r?e:t}function Ie(r,t){let e=Cr(r.Fp,t.map(n=>n.Z));return t.map((n,s)=>r.fromAffine(n.toAffine(e[s])))}function ka(r,t){if(!Number.isSafeInteger(r)||r<=0||r>t)throw new Error("invalid window size, expected [1.."+t+"], got W="+r)}function wo(r,t){ka(r,t);let e=Math.ceil(t/r)+1,n=2**(r-1),s=2**r,o=Ir(r),i=BigInt(r);return{windows:e,windowSize:n,mask:o,maxNumber:s,shiftBy:i}}function Ba(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 u=t*n,f=u+Math.abs(c)-1,l=c===0,d=c<0,y=t%2!==0;return{nextN:a,offset:f,isZero:l,isNeg:d,isNegF:y,offsetF:u}}var xo=new WeakMap,Ia=new WeakMap;function vo(r){return Ia.get(r)||1}function Aa(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}=wo(e,this.bits),o=[],i=t,c=i;for(let a=0;a<n;a++){c=i,o.push(c);for(let u=1;u<s;u++)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=wo(t,this.bits);for(let c=0;c<i.windows;c++){let{nextN:a,offset:u,isZero:f,isNeg:l,isNegF:d,offsetF:y}=Ba(n,c,i);n=a,f?o=o.add(Nr(d,e[y])):s=s.add(Nr(l,e[u]))}return Aa(n),{p:s,f:o}}wNAFUnsafe(t,e,n,s=this.ZERO){let o=wo(t,this.bits);for(let i=0;i<o.windows&&n!==Xe;i++){let{nextN:c,offset:a,isZero:u,isNeg:f}=Ba(n,i,o);if(n=c,!u){let l=e[a];s=s.add(f?l.negate():l)}}return Aa(n),s}getPrecomputes(t,e,n){let s=xo.get(e);return s||(s=this.precomputeWindow(e,t),t!==1&&(typeof n=="function"&&(s=n(s)),xo.set(e,s))),s}cached(t,e,n){let s=vo(t);return this.wNAF(s,this.getPrecomputes(s,t,n),e)}unsafe(t,e,n,s){let o=vo(t);return o===1?this._unsafeLadder(t,e,s):this.wNAFUnsafe(o,this.getPrecomputes(o,t,n),e,s)}createCache(t,e){ka(e,this.bits),Ia.set(t,e),xo.delete(t)}hasCache(t){return vo(t)!==1}};function Ca(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 Sa(r,t,e){if(t){if(t.ORDER!==r)throw new Error("Field.ORDER must match order: Fp == p, Fn == n");return yo(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 u=t[a];if(!(typeof u=="bigint"&&u>Xe))throw new Error(`CURVE.${a} must be positive bigint`)}let s=Sa(t.p,e.Fp,n),o=Sa(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),Eo=BigInt(2),yf=BigInt(8);function mf(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 Na(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=Eo<<BigInt(s.BYTES*8)-nt,a=v=>n.create(v),u=t.uvRatio||((v,g)=>{try{return{isValid:!0,value:n.sqrt(n.div(v,g))}}catch{return{isValid:!1,value:ue}}});if(!mf(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 kr("coordinate "+v,g,w,c),g}function l(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?yf: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),U=a(x*a(P+E)),m=a(K+a(A*a(M*E)));if(U!==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;kr("point.y",E,ue,x);let K=a(E*E),P=a(K-nt),U=a(D*K-I),{isValid:m,value:b}=u(P,U);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(Eo),this}assertValidity(){y(this)}equals(g){l(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(Eo*a(I*I)),E=a(g*D),x=A+w,K=a(a(x*x)-D-H),P=E+H,U=P-M,m=E-H,b=a(K*U),p=a(P*m),S=a(K*m),C=a(U*P);return new h(b,p,C,S)}add(g){l(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,U=a(I*E),m=a(D*x),b=a(M*w*P),p=a(H*K),S=a((I+D)*(E+x)-U-m),C=p-b,T=p+b,L=a(m-A*U),N=a(S*C),R=a(T*L),V=a(S*L),Y=a(C*T);return new h(N,R,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 Ta(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),u=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 l(E){let x=w.secretKey;O(E,w.secretKey,"secretKey");let K=O(t(E),2*x,"hashedSecretKey"),P=a(K.slice(0,x)),U=K.slice(x,2*x),m=f(P);return{head:P,prefix:U,scalar:m}}function d(E){let{head:x,prefix:K,scalar:P}=l(E),U=s.multiply(P),m=U.toBytes();return{head:x,prefix:K,scalar:P,point:U,pointBytes:m}}function y(E){return d(E).pointBytes}function h(E=Uint8Array.of(),...x){let K=xt(...x);return f(t(u(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:U,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*U);if(!i.isValid(C))throw new Error("sign failed: invalid s");let T=xt(p,i.toBytes(C));return O(T,w.signature,"result")}let v={zip215:!0};function g(E,x,K,P=v){let{context:U,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)),T,L,N;try{T=r.fromBytes(K,m),L=r.fromBytes(S,m),N=s.multiplyUnsafe(C)}catch{return!1}if(!m&&T.isSmallOrder())return!1;let R=h(U,L.toBytes(),T.toBytes(),x);return L.add(T.multiplyUnsafe(R)).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 U=P?o.div(nt+x,nt-x):o.div(x-nt,x+nt);return o.toBytes(U)},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 bf=BigInt(1),Ua=BigInt(2);var wf=BigInt(5),xf=BigInt(8),Bo=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffed"),vf={p:Bo,n:BigInt("0x1000000000000000000000000000000014def9dea2f79cd65812631a5cf5d3ed"),h:xf,a:BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffec"),d:BigInt("0x52036cee2b6ffe738cc740797779e89800700a4d4141d8ab75eb4dca135978a3"),Gx:BigInt("0x216936d3cd6e53fec0a4e231fdd6dc5c692cc7609525a7b2c9562d608f25d51a"),Gy:BigInt("0x6666666666666666666666666666666666666666666666666666666666666658")};function Ef(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),s=BigInt(80),o=Bo,c=r*r%o*r%o,a=Z(c,Ua,o)*c%o,u=Z(a,bf,o)*r%o,f=Z(u,wf,o)*u%o,l=Z(f,t,o)*f%o,d=Z(l,e,o)*l%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 Bf(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}var La=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752");function Af(r,t){let e=Bo,n=X(t*t*t,e),s=X(n*n*t,e),o=Ef(r*s).pow_p_5_8,i=X(r*n*o,e),c=X(t*i*i,e),a=i,u=X(i*La,e),f=c===r,l=c===X(-r,e),d=c===X(-r*La,e);return f&&(i=a),(l||d)&&(i=u),va(i,e)&&(i=X(-i,e)),{isValid:f||l,value:i}}var Sf=Na(vf,{uvRatio:Af});function kf(r){return Ta(Sf,ae,Object.assign({adjustScalarBytes:Bf},r))}var Ao=kf({});var er=32,kt=64,If=32;var tr,_a=(async()=>{try{return await tt.get().subtle.generateKey({name:"Ed25519"},!0,["sign","verify"]),!0}catch{return!1}})();async function Cf(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 tt.get().subtle.importKey("jwk",n,{name:"Ed25519"},!0,["sign"]),o=await tt.get().subtle.sign({name:"Ed25519"},s,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(o,0,o.byteLength)}function Nf(r,t){let e=r.subarray(0,If);return Ao.sign(t instanceof Uint8Array?t:t.subarray(),e)}async function Ra(r,t){return tr==null&&(tr=await _a),tr?Cf(r,t):Nf(r,t)}async function Tf(r,t,e){if(r.buffer instanceof ArrayBuffer){let n=await tt.get().subtle.importKey("raw",r.buffer,{name:"Ed25519"},!1,["verify"]);return await tt.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 Ao.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}async function Da(r,t,e){return tr==null&&(tr=await _a),tr?Tf(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=Ur(t,er)}toMultihash(){return me.digest(Ge(this))}toCID(){return St.createV1(114,this.toMultihash())}toString(){return et.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=Da(this.raw,e,t);return rr(s)?s.then(o=>(n?.signal?.throwIfAborted(),o)):s}},Tr=class{type="Ed25519";raw;publicKey;constructor(t,e){this.raw=Ur(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 So(r){if(r.length>kt){r=Ur(r,kt+er);let n=r.subarray(0,kt),s=r.subarray(kt,r.length);return new Tr(n,s)}r=Ur(r,kt);let t=r.subarray(0,kt),e=r.subarray(er);return new Tr(t,e)}function Ur(r,t){if(r=Uint8Array.from(r??[]),r.length!==t)throw new _(`Key must be a Uint8Array of length ${t}, got ${r.length}`);return r}var Lf=Math.pow(2,7),_f=Math.pow(2,14),Rf=Math.pow(2,21),Va=Math.pow(2,28),Oa=Math.pow(2,35),Ha=Math.pow(2,42),Ma=Math.pow(2,49),gt=128,le=127;function Lr(r){if(r<Lf)return 1;if(r<_f)return 2;if(r<Rf)return 3;if(r<Va)return 4;if(r<Oa)return 5;if(r<Ha)return 6;if(r<Ma)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function Pa(r,t,e=0){switch(Lr(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 Fa(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)*Va,e<gt)||(e=r[t+5],n+=(e&le)*Oa,e<gt)||(e=r[t+6],n+=(e&le)*Ha,e<gt)||(e=r[t+7],n+=(e&le)*Ma,e<gt))return n;throw new RangeError("Could not decode varint")}var ko=new Float32Array([-0]),fe=new Uint8Array(ko.buffer);function qa(r,t,e){ko[0]=r,t[e]=fe[0],t[e+1]=fe[1],t[e+2]=fe[2],t[e+3]=fe[3]}function $a(r,t){return fe[0]=r[t],fe[1]=r[t+1],fe[2]=r[t+2],fe[3]=r[t+3],ko[0]}var Io=new Float64Array([-0]),ut=new Uint8Array(Io.buffer);function ja(r,t,e){Io[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 Ga(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],Io[0]}var Df=BigInt(Number.MAX_SAFE_INTEGER),Kf=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<Df&&t>Kf)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>Za&&(s=0n,++n>Za&&(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 Za=4294967296n;function Ya(r){let t=0,e=0;for(let n=0;n<r.length;++n)e=r.charCodeAt(n),e<128?t+=1:e<2048?t+=2:(e&64512)===55296&&(r.charCodeAt(n+1)&64512)===56320?(++n,t+=4):t+=3;return t}function za(r,t,e){if(e-t<1)return"";let s,o=[],i=0,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 Co(r,t,e){let n=e,s,o;for(let i=0;i<r.length;++i)s=r.charCodeAt(i),s<128?t[e++]=s:s<2048?(t[e++]=s>>6|192,t[e++]=s&63|128):(s&64512)===55296&&((o=r.charCodeAt(i+1))&64512)===56320?(s=65536+((s&1023)<<10)+(o&1023),++i,t[e++]=s>>18|240,t[e++]=s>>12&63|128,t[e++]=s>>6&63|128,t[e++]=s&63|128):(t[e++]=s>>12|224,t[e++]=s>>6&63|128,t[e++]=s&63|128);return e-n}function Ut(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 No=class{buf;pos;len;_slice=Uint8Array.prototype.subarray;constructor(t){this.buf=t,this.pos=0,this.len=t.length}uint32(){let t=4294967295;if(t=(this.buf[this.pos]&127)>>>0,this.buf[this.pos++]<128||(t=(t|(this.buf[this.pos]&127)<<7)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<14)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<21)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&15)<<28)>>>0,this.buf[this.pos++]<128))return t;if((this.pos+=5)>this.len)throw this.pos=this.len,Ut(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 Ut(this,4);return xn(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Ut(this,4);return xn(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Ut(this,4);let t=$a(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Ut(this,4);let t=Ga(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 Ut(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return za(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw Ut(this,t);this.pos+=t}else do if(this.pos>=this.len)throw Ut(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 Ut(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 Ut(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 Ut(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=Fa(this.buf,this.pos);return this.pos+=Lr(t),t}uint64String(){return this.readLongVarint().toString(!0)}sint64(){return this.readLongVarint().zzDecode().toBigInt()}sint64Number(){return this.readLongVarint().zzDecode().toNumber()}sint64String(){return this.readLongVarint().zzDecode().toString()}fixed64(){return this.readFixed64().toBigInt()}fixed64Number(){return this.readFixed64().toNumber()}fixed64String(){return this.readFixed64().toString()}sfixed64(){return this.readFixed64().toBigInt()}sfixed64Number(){return this.readFixed64().toNumber()}sfixed64String(){return this.readFixed64().toString()}};function _r(r){return new No(r instanceof Uint8Array?r:r.subarray())}function vn(r,t,e){let n=_r(r);return t.decode(n,void 0,e)}function To(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 _o=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},Vf=To();function Of(r){return globalThis.Buffer!=null?Bt(r):Vf(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(Pa,Lr(t),t)}uint64String(t){return this.uint64(BigInt(t))}int64(t){return this.uint64(t)}int64Number(t){return this.uint64Number(t)}int64String(t){return this.uint64String(t)}sint64(t){let e=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(Rr,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=At.fromBigInt(t);return this._push(Rr,4,e.lo)._push(Rr,4,e.hi)}fixed64Number(t){let e=At.fromNumber(t);return this._push(Rr,4,e.lo)._push(Rr,4,e.hi)}fixed64String(t){return this.fixed64(BigInt(t))}sfixed64(t){return this.fixed64(t)}sfixed64Number(t){return this.fixed64Number(t)}sfixed64String(t){return this.fixed64String(t)}float(t){return this._push(qa,4,t)}double(t){return this._push(ja,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(Lo,1,0):this.uint32(e)._push(Mf,e,t)}string(t){let e=Ya(t);return e!==0?this.uint32(e)._push(Co,e,t):this._push(Lo,1,0)}fork(){return this.states=new _o(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=Of(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 Hf(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(Hf,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 Rr(r,t,e){t[e]=r&255,t[e+1]=r>>>8&255,t[e+2]=r>>>16&255,t[e+3]=r>>>24}function Mf(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(Pf,t,r),this},Dr.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(Ff,t,r),this});function Pf(r,t,e){t.set(r,e)}function Ff(r,t,e){r.length<40?Co(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(F(r),e)}function Do(){return new Dr}function Bn(r,t){let e=Do();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}function*An(r,t,e){let n=_r(r);yield*t.stream(n,void 0,"$",e)}var Sn={VARINT:0,BIT64:1,LENGTH_DELIMITED:2,START_GROUP:3,END_GROUP:4,BIT32:5};function kn(r,t,e,n,s){return{name:r,type:t,encode:e,decode:n,stream:s}}function Ko(r){function t(o){if(r[o.toString()]==null)throw new Error("Invalid enum value");return r[o]}let e=function(i,c){let a=t(i);c.int32(a)},n=function(i){let c=i.int32();return t(c)},s=function*(i){let c=i.int32();yield t(c)};return kn("enum",Sn.VARINT,e,n,s)}function In(r,t,e){return kn("message",Sn.LENGTH_DELIMITED,r,t,e)}var Q;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.secp256k1="secp256k1",r.ECDSA="ECDSA"})(Q||(Q={}));var Vo;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1",r[r.ECDSA=3]="ECDSA"})(Vo||(Vo={}));(function(r){r.codec=()=>Ko(Vo)})(Q||(Q={}));var he;(function(r){let t;r.codec=()=>(t==null&&(t=In((o,i,c={})=>{c.lengthDelimited!==!1&&i.fork(),o.Type!=null&&(i.uint32(8),Q.codec().encode(o.Type,i)),o.Data!=null&&(i.uint32(18),i.bytes(o.Data)),c.lengthDelimited!==!1&&i.ldelim()},(o,i,c={})=>{let a={},u=i==null?o.len:o.pos+i;for(;o.pos<u;){let f=o.uint32();switch(f>>>3){case 1:{a.Type=Q.codec().decode(o);break}case 2:{a.Data=o.bytes();break}default:{o.skipType(f&7);break}}}return a},function*(o,i,c,a={}){let u=i==null?o.len:o.pos+i;for(;o.pos<u;){let f=o.uint32();switch(f>>>3){case 1:{yield{field:`${c}.Type`,value:Q.codec().decode(o)};break}case 2:{yield{field:`${c}.Data`,value:o.bytes()};break}default:{o.skipType(f&7);break}}}})),t);function e(o){return Bn(o,r.codec())}r.encode=e;function n(o,i){return vn(o,r.codec(),i)}r.decode=n;function s(o,i){return An(o,r.codec(),i)}r.stream=s})(he||(he={}));var Kr;(function(r){let t;r.codec=()=>(t==null&&(t=In((o,i,c={})=>{c.lengthDelimited!==!1&&i.fork(),o.Type!=null&&(i.uint32(8),Q.codec().encode(o.Type,i)),o.Data!=null&&(i.uint32(18),i.bytes(o.Data)),c.lengthDelimited!==!1&&i.ldelim()},(o,i,c={})=>{let a={},u=i==null?o.len:o.pos+i;for(;o.pos<u;){let f=o.uint32();switch(f>>>3){case 1:{a.Type=Q.codec().decode(o);break}case 2:{a.Data=o.bytes();break}default:{o.skipType(f&7);break}}}return a},function*(o,i,c,a={}){let u=i==null?o.len:o.pos+i;for(;o.pos<u;){let f=o.uint32();switch(f>>>3){case 1:{yield{field:`${c}.Type`,value:Q.codec().decode(o)};break}case 2:{yield{field:`${c}.Data`,value:o.bytes()};break}default:{o.skipType(f&7);break}}}})),t);function e(o){return Bn(o,r.codec())}r.encode=e;function n(o,i){return vn(o,r.codec(),i)}r.decode=n;function s(o,i){return An(o,r.codec(),i)}r.stream=s})(Kr||(Kr={}));function Te(r){if(isNaN(r)||r<=0)throw new _("random bytes length must be a Number bigger than 0");return re(r)}var Or={};ft(Or,{MAX_RSA_KEY_SIZE:()=>Oo,generateRSAKeyPair:()=>ec,jwkToJWKKeyPair:()=>rc,jwkToPkcs1:()=>Gf,jwkToPkix:()=>Fo,jwkToRSAPrivateKey:()=>jo,pkcs1MessageToJwk:()=>Mo,pkcs1MessageToRSAPrivateKey:()=>Cn,pkcs1ToJwk:()=>jf,pkcs1ToRSAPrivateKey:()=>qo,pkixMessageToJwk:()=>Po,pkixMessageToRSAPublicKey:()=>$o,pkixToJwk:()=>Zf,pkixToRSAPublicKey:()=>tc});var nr=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 et.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 Qa(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 Xa(this.jwk,t,e)}};var Oo=8192,Ho=18,qf=1062,$f=Uint8Array.from([48,13,6,9,42,134,72,134,247,13,1,1,1,5,0]);function jf(r){let t=Ct(r);return Mo(t)}function Mo(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 Gf(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 _("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 Zf(r){let t=Ct(r,{offset:0});return Po(t)}function Po(r){let t=Ct(r[1],{offset:0});return{kty:"RSA",n:$(t[0],"base64url"),e:$(t[1],"base64url")}}function Fo(r){if(r.n==null||r.e==null)throw new _("JWK was missing components");return Nt([$f,vr(Nt([dt(F(r.n,"base64url")),dt(F(r.e,"base64url"))]))]).subarray()}function qo(r){let t=Ct(r);return Cn(t)}function Cn(r){let t=Mo(r);return jo(t)}function tc(r,t){if(r.byteLength>=qf)throw new Ke("Key size is too large");let e=Ct(r,{offset:0});return $o(e,r,t)}function $o(r,t,e){let n=Po(r);if(e==null){let s=ie(he.encode({Type:Q.RSA,Data:t}));e=_t(Ho,s)}return new nr(n,e)}function jo(r){if(sc(r)>Oo)throw new _("Key size is too large");let t=rc(r),e=ie(he.encode({Type:Q.RSA,Data:Fo(t.publicKey)})),n=_t(Ho,e);return new Vr(t.privateKey,new nr(t.publicKey,n))}async function ec(r){if(r>Oo)throw new _("Key size is too large");let t=await nc(r),e=ie(he.encode({Type:Q.RSA,Data:Fo(t.publicKey)})),n=_t(Ho,e);return new Vr(t.privateKey,new nr(t.publicKey,n))}function rc(r){if(r==null)throw new _("Missing key parameter");return{privateKey:r,publicKey:{kty:r.kty,n:r.n,e:r.e}}}async function nc(r,t){let e=await tt.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 Yf(e,t);return{privateKey:n[0],publicKey:n[1]}}async function Xa(r,t,e){let n=await tt.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]);e?.signal?.throwIfAborted();let s=await tt.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 Qa(r,t,e,n){let s=await tt.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);n?.signal?.throwIfAborted();let o=await tt.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},s,t,e instanceof Uint8Array?e:e.subarray());return n?.signal?.throwIfAborted(),o}async function Yf(r,t){if(r.privateKey==null||r.publicKey==null)throw new _("Private and public key are required");let e=await Promise.all([tt.get().subtle.exportKey("jwk",r.privateKey),tt.get().subtle.exportKey("jwk",r.publicKey)]);return t?.signal?.throwIfAborted(),e}function sc(r){if(r.kty!=="RSA")throw new _("invalid key type");if(r.n==null)throw new _("invalid key modulus");return F(r.n,"base64url").length*8}var Nn=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 Nn(r,t).update(e).digest();Hr.create=(r,t)=>new Nn(r,t);var oc=(r,t)=>(r+(r>=0?t:-t)/ic)/t;function zf(r,t,e){let[[n,s],[o,i]]=t,c=oc(i*r,e),a=oc(-s*r,e),u=r-c*n-a*o,f=-c*s-a*i,l=u<Gt,d=f<Gt;l&&(u=-u),d&&(f=-f);let y=Ir(Math.ceil(ho(e)/2))+sr;if(u<Gt||u>=y||f<Gt||f>=y)throw new Error("splitScalar (endomorphism): failed, k="+r);return{k1neg:l,k1:u,k2neg:d,k2:f}}function Zo(r){if(!["compact","recovered","der"].includes(r))throw new Error('Signature format must be "compact", "recovered", or "der"');return r}function Go(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&&Zo(e.format),e}var Yo=class extends Error{constructor(t=""){super(t)}},de={Err:Yo,_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=Sr(n);if(s.length/2&128)throw new e("tlv.encode: long form length too big");let o=n>127?Sr(s.length/2|128):"";return Sr(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 u=t.subarray(n,n+a);if(u.length!==a)throw new e("tlv.decode: length bytes not complete");if(u[0]===0)throw new e("tlv.decode(long): zero leftmost byte");for(let f of u)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=Sr(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:u,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(u)}},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),sr=BigInt(1),ic=BigInt(2),Tn=BigInt(3),Wf=BigInt(4);function ac(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 u=uc(n,s);function f(){if(!n.isOdd)throw new Error("compression is not supported: Field does not have .isOdd()")}function l(U,m,b){let{x:p,y:S}=m.toAffine(),C=n.toBytes(p);if(jt(b,"isCompressed"),b){f();let T=!n.isOdd(S);return xt(cc(T),C)}else return xt(Uint8Array.of(4),C,n.toBytes(S))}function d(U){O(U,void 0,"Point");let{publicKey:m,publicKeyUncompressed:b}=u,p=U.length,S=U[0],C=U.subarray(1);if(p===m&&(S===2||S===3)){let T=n.fromBytes(C);if(!n.isValid(T))throw new Error("bad point: is not on curve, wrong x");let L=B(T),N;try{N=n.sqrt(L)}catch(Y){let G=Y instanceof Error?": "+Y.message:"";throw new Error("bad point: is not on curve, sqrt error"+G)}f();let R=n.isOdd(N);return(S&1)===1!==R&&(N=n.neg(N)),{x:T,y:N}}else if(p===b&&S===4){let T=n.BYTES,L=n.fromBytes(C.subarray(0,T)),N=n.fromBytes(C.subarray(T,T*2));if(!v(L,N))throw new Error("bad point: is not on curve");return{x:L,y:N}}else throw new Error(`bad point: got length ${p}, expected compressed=${m} or uncompressed=${b}`)}let y=t.toBytes||l,h=t.fromBytes||d;function B(U){let m=n.sqr(U),b=n.mul(m,U);return n.add(n.add(b,n.mul(U,o.a)),o.b)}function v(U,m){let b=n.sqr(m),p=B(U);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,Tn),Wf),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(U,m,b=!1){if(!n.isValid(m)||b&&n.is0(m))throw new Error(`bad point coordinate ${U}`);return m}function I(U){if(!(U instanceof x))throw new Error("Weierstrass Point expected")}function D(U){if(!a||!a.basises)throw new Error("no endo");return zf(U,a.basises,s.ORDER)}let H=We((U,m)=>{let{X:b,Y:p,Z:S}=U;if(n.eql(S,n.ONE))return{x:b,y:p};let C=U.is0();m==null&&(m=C?n.ONE:n.inv(S));let T=n.mul(b,m),L=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:T,y:L}}),M=We(U=>{if(U.is0()){if(t.allowInfinityPoint&&!n.is0(U.Y))return;throw new Error("bad point: ZERO")}let{x:m,y:b}=U.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(!U.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});function E(U,m,b,p,S){return b=new x(n.mul(b.X,U),b.Y,b.Z),m=Nr(p,m),b=Nr(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(Tn),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:T,Z:L}=m,N=n.eql(n.mul(b,L),n.mul(C,S)),R=n.eql(n.mul(p,L),n.mul(T,S));return N&&R}negate(){return new x(this.X,n.neg(this.Y),this.Z)}double(){let{a:m,b}=o,p=n.mul(b,Tn),{X:S,Y:C,Z:T}=this,L=n.ZERO,N=n.ZERO,R=n.ZERO,V=n.mul(S,S),Y=n.mul(C,C),G=n.mul(T,T),j=n.mul(S,C);return j=n.add(j,j),R=n.mul(S,T),R=n.add(R,R),L=n.mul(m,R),N=n.mul(p,G),N=n.add(L,N),L=n.sub(Y,N),N=n.add(Y,N),N=n.mul(L,N),L=n.mul(j,L),R=n.mul(p,R),G=n.mul(m,G),j=n.sub(V,G),j=n.mul(m,j),j=n.add(j,R),R=n.add(V,V),V=n.add(R,V),V=n.add(V,G),V=n.mul(V,j),N=n.add(N,V),G=n.mul(C,T),G=n.add(G,G),V=n.mul(G,j),L=n.sub(L,V),R=n.mul(G,Y),R=n.add(R,R),R=n.add(R,R),new x(L,N,R)}add(m){I(m);let{X:b,Y:p,Z:S}=this,{X:C,Y:T,Z:L}=m,N=n.ZERO,R=n.ZERO,V=n.ZERO,Y=o.a,G=n.mul(o.b,Tn),j=n.mul(b,C),z=n.mul(p,T),st=n.mul(S,L),Lt=n.add(b,p),W=n.add(C,T);Lt=n.mul(Lt,W),W=n.add(j,z),Lt=n.sub(Lt,W),W=n.add(b,S);let ct=n.add(C,L);return W=n.mul(W,ct),ct=n.add(j,st),W=n.sub(W,ct),ct=n.add(p,S),N=n.add(T,L),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),R=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),R=n.add(R,j),j=n.mul(ct,W),N=n.mul(Lt,N),N=n.sub(N,j),j=n.mul(Lt,z),V=n.mul(ct,V),V=n.add(V,j),new x(N,R,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=T=>P.cached(this,T,L=>Ie(x,L));if(b){let{k1neg:T,k1:L,k2neg:N,k2:R}=D(m),{p:V,f:Y}=C(L),{p:G,f:j}=C(R);S=Y.add(j),p=E(b.beta,V,G,T,N)}else{let{p:T,f:L}=C(m);p=T,S=L}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===sr)return p;if(P.hasCache(this))return this.multiply(m);if(b){let{k1neg:S,k1:C,k2neg:T,k2:L}=D(m),{p1:N,p2:R}=Ca(x,p,C,L);return E(b.beta,N,R,S,T)}else return P.unsafe(p,m)}toAffine(m){return H(this,m)}isTorsionFree(){let{isTorsionFree:m}=t;return i===sr?!0:m?m(x,this):P.unsafe(this,c).is0()}clearCofactor(){let{clearCofactor:m}=t;return i===sr?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 cc(r){return Uint8Array.of(r?2:3)}function uc(r,t){return{secretKey:t.BYTES,publicKey:1+r.BYTES,publicKeyUncompressed:1+2*r.BYTES,publicKeyHasPrefix:!0,signature:2*t.BYTES}}function Jf(r,t={}){let{Fn:e}=r,n=t.randomBytes||re,s=Object.assign(uc(r.Fp,e),{seed:mo(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 bo(O(y,s.seed,"seed"),e.ORDER)}function a(y,h=!0){return r.BASE.multiply(e.fromBytes(y)).toBytes(h)}function u(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(u(y)===!0)throw new Error("first arg must be private key");if(u(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 l={isValidSecretKey:o,isValidPublicKey:i,randomSecretKey:c},d=bn(c,a);return Object.freeze({getPublicKey:a,getSharedSecret:f,keygen:d,Point:r,utils:l,lengths:s})}function lc(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:u,getPublicKey:f,getSharedSecret:l,utils:d,lengths:y}=Jf(r,e),h={prehash:!0,lowS:typeof e.lowS=="boolean"?e.lowS:!0,format:"compact",extraEntropy:!1},B=c*ic<o.ORDER;function v(b){let p=c>>sr;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){Zo(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:R,s:V}=de.toSig(O(p));return new I(R,V)}S==="recovered"&&(C=p[0],S="compact",p=p.subarray(1));let T=y.signature/2,L=p.subarray(0,T),N=p.subarray(T,T*2);return new I(i.fromBytes(L),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,T=this.assertRecovery(),L=T===2||T===3?S+c:S;if(!o.isValid(L))throw new Error("invalid recovery id: sig.r+curve.n != R.x");let N=o.toBytes(L),R=r.fromBytes(xt(cc((T&1)===0),N)),V=i.inv(L),Y=H(O(p,void 0,"msgHash")),G=i.create(-Y*V),j=i.create(C*V),z=r.BASE.multiplyUnsafe(G).add(R.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(Zo(p),p==="der")return qt(de.hexFromSig(this));let{r:S,s:C}=this,T=i.toBytes(S),L=i.toBytes(C);return p==="recovered"?(A(),xt(Uint8Array.of(this.assertRecovery()),T,L)):xt(T,L)}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=Ir(a);function E(b){return kr("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:T,extraEntropy:L}=Go(S,h);b=x(b,T);let N=H(b),R=i.fromBytes(p);if(!i.isValidNot0(R))throw new Error("invalid private key");let V=[E(R),E(N)];if(L!=null&&L!==!1){let z=L===!0?n(y.secretKey):L;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 Lt=i.inv(st),W=r.BASE.multiply(st).toAffine(),ct=i.create(W.x);if(ct===Gt)return;let tn=i.create(Lt*i.create(G+ct*R));if(tn===Gt)return;let ci=(W.x===ct?0:2)|Number(W.y&sr),ui=tn;return C&&v(tn)&&(ui=i.neg(tn),ci^=1),new I(ct,ui,B?void 0:ci)}return{seed:Y,k2sig:j}}function P(b,p,S={}){let{seed:C,k2sig:T}=K(b,p,S);return fa(t.outputLen,i.BYTES,s)(C,T).toBytes(S.format)}function U(b,p,S,C={}){let{lowS:T,prehash:L,format:N}=Go(C,h);if(S=O(S,void 0,"publicKey"),p=x(p,L),!we(b)){let R=b instanceof I?", use sig.toBytes()":"";throw new Error("verify expects Uint8Array signature"+R)}w(b,N);try{let R=I.fromBytes(b,N),V=r.fromBytes(S);if(T&&R.hasHighS())return!1;let{r:Y,s:G}=R,j=H(p),z=i.inv(G),st=i.create(j*z),Lt=i.create(Y*z),W=r.BASE.multiplyUnsafe(st).add(V.multiplyUnsafe(Lt));return W.is0()?!1:i.create(W.x)===Y}catch{return!1}}function m(b,p,S={}){let{prehash:C}=Go(S,h);return p=x(p,C),I.fromBytes(b,"recovered").recoverPublicKey(p).toBytes()}return Object.freeze({keygen:u,getPublicKey:f,getSharedSecret:l,utils:d,lengths:y,Point:r,sign:P,verify:U,recoverPublicKey:m,Signature:I,hash:t})}var Wo={p:BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),n:BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),h:BigInt(1),a:BigInt(0),b:BigInt(7),Gx:BigInt("0x79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798"),Gy:BigInt("0x483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8")},Xf={beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),basises:[[BigInt("0x3086d221a7d46bcde86c90e49284eb15"),-BigInt("0xe4437ed6010e88286f547fa90abfe4c3")],[BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),BigInt("0x3086d221a7d46bcde86c90e49284eb15")]]};var fc=BigInt(2);function Qf(r){let t=Wo.p,e=BigInt(3),n=BigInt(6),s=BigInt(11),o=BigInt(22),i=BigInt(23),c=BigInt(44),a=BigInt(88),u=r*r*r%t,f=u*u*r%t,l=Z(f,e,t)*f%t,d=Z(l,e,t)*f%t,y=Z(d,fc,t)*u%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)*u%t,H=Z(D,fc,t);if(!zo.eql(zo.sqr(H),r))throw new Error("Cannot find square root");return H}var zo=Je(Wo.p,{sqrt:Qf}),th=ac(Wo,{Fp:zo,endo:Xf}),Dt=lc(th,ie);var hc=32;function dc(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 fr(String(s))});try{return Dt.sign(n.digest,r,{prehash:!1,format:"der"})}catch(s){throw new fr(String(s))}}function pc(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 hr(String(o))});try{return n?.signal?.throwIfAborted(),Dt.verify(t,s.digest,r,{prehash:!1,format:"der"})}catch(o){throw new hr(String(o))}}var Un=class{type="secp256k1";raw;_key;constructor(t){this._key=mc(t),this.raw=gc(this._key)}toMultihash(){return me.digest(Ge(this))}toCID(){return St.createV1(114,this.toMultihash())}toString(){return et.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 pc(this._key,e,t,n)}},Ln=class{type="secp256k1";raw;publicKey;constructor(t,e){this.raw=yc(t),this.publicKey=new Un(e??bc(t))}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:mt(this.raw,t.raw)}sign(t,e){return dc(this.raw,t,e)}};function Jo(r){return new Ln(r)}function gc(r){return Dt.Point.fromBytes(r).toBytes()}function yc(r){try{return Dt.getPublicKey(r,!0),r}catch(t){throw new dr(String(t))}}function mc(r){try{return Dt.Point.fromBytes(r),r}catch(t){throw new Ke(String(t))}}function bc(r){try{return Dt.getPublicKey(r,!0)}catch(t){throw new dr(String(t))}}function Ge(r){return he.encode({Type:Q[r.type],Data:r.raw})}function wc(r){let t=Kr.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case Q.RSA:return qo(e);case Q.Ed25519:return So(e);case Q.secp256k1:return Jo(e);case Q.ECDSA:return ji(e);default:throw new Ve}}function xc(r){if(r.byteLength===kt)return So(r);if(r.byteLength===hc)return Jo(r);let t=Ct(r),e=t[2]?.[0];if(e===Mi||e===Pi||e===Fi)return to(t);if(t.length>8)return Cn(t);throw new _("Could not extract private key from raw bytes")}function Ue(r){return Kr.encode({Type:Q[r.type],Data:r.raw})}var Mr=Uint32Array.from([1732584193,4023233417,2562383102,271733878,3285377520]),pe=new Uint32Array(80),Xo=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 u,f;a<20?(u=fn(s,o,i),f=1518500249):a<40?(u=s^o^i,f=1859775393):a<60?(u=hn(s,o,i),f=2400959708):(u=s^o^i,f=3395469782);let l=ln(n,5)+u+c+f+pe[a]|0;c=i,i=o,o=ln(s,30),s=n,n=l}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)}},vc=Er(()=>new Xo);function Ec(r,t,e,n){Ze(r);let s=Qi({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=eo(t,"password"),u=eo(e,"salt"),f=new Uint8Array(i),l=Hr.create(r,a),d=l._cloneInto().update(u);return{c:o,dkLen:i,asyncTick:c,DK:f,PRF:l,PRFSalt:d}}function Bc(r,t,e,n,s){return r.destroy(),t.destroy(),n&&n.destroy(),wt(s),e}function Ac(r,t,e,n){let{c:s,dkLen:o,DK:i,PRF:c,PRFSalt:a}=Ec(r,t,e,n),u,f=new Uint8Array(4),l=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);l.setInt32(0,y,!1),(u=a._cloneInto(u)).update(f).digestInto(d),B.set(d.subarray(0,B.length));for(let v=1;v<s;v++){c._cloneInto(u).update(d).digestInto(d);for(let g=0;g<B.length;g++)B[g]^=d[g]}}return Bc(c,a,i,u,d)}async function _n(r,t,e,n){let{c:s,dkLen:o,asyncTick:i,DK:c,PRF:a,PRFSalt:u}=Ec(r,t,e,n),f,l=new Uint8Array(4),d=xe(l),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=u._cloneInto(f)).update(l).digestInto(y),v.set(y.subarray(0,v.length)),await Xi(s-1,i,()=>{a._cloneInto(f).update(y).digestInto(y);for(let g=0;g<v.length;g++)v[g]^=y[g]})}return Bc(a,u,c,f,y)}var Sc={sha1:vc,"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(Sc).join(" / ");throw new _(`Hash '${s}' is unknown or not supported. Must be ${c}`)}let o=Sc[s],i=Ac(o,r,t,{c:e,dkLen:n});return be.encode(i).substring(1)}var Zt="/",kc=new TextEncoder().encode(Zt),Rn=kc[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]!==Rn)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=kc),this._buf[0]!==Rn){let t=new Uint8Array(this._buf.byteLength+1);t.fill(Rn,0,1),t.set(this._buf,1),this._buf=t}for(;this._buf.byteLength>1&&this._buf[this._buf.byteLength-1]===Rn;)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 eh(this.baseNamespace())}name(){return rh(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(),...nh(t.map(e=>e.namespaces()))])}};function eh(r){let t=r.split(":");return t.length<2?"":t.slice(0,-1).join(":")}function rh(r){let t=r.split(":");return t[t.length-1]}function nh(r){return[].concat(...r)}var Su=fi(Dc(),1);var Qo={keyLength:64,iterationCount:1e4,salt:"you should override this value with a crypto secure random number",hash:"sha2-512"};var or={};ft(or,{create:()=>yh,derivedEmptyPasswordKey:()=>Dn});var Dn={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function yh(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=tt.get();e*=8;async function a(l,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",Dn,{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",Dn,{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,l);return qe([y,B.iv,new Uint8Array(g)])}async function u(l,d){let y=l.subarray(0,o),h=l.subarray(o,o+n),B=l.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",Dn,{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:u}}var q=fi(Kc());function Le(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 u=new Uint8Array(a);for(let f=c-1;f>=0;f--){let l=Math.pow(2,f*t);u[o-f-1]=Math.floor(s/l),s-=u[o-f-1]*l}return a}i*=Math.pow(2,t)}return new ArrayBuffer(0)}function On(...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 ei(){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=Le(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,Le(o,8)-n}function Vc(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 Oc(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 im=Math.log(2);function Hn(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function ri(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 ri(this.items)}},qr=[new Uint8Array([1])],Hc="0123456789";var ar="",Ot=new ArrayBuffer(0),ni=new Uint8Array(0),Gr="EndOfContent",Pc="OCTET STRING",Fc="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):ni}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=ar,warnings:n=[],valueBeforeDecode:s=ni}={}){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 Mn=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):ni,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,u=this.valueHexView=new Uint8Array(255),f=255;for(;o[a]&128;){if(u[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<u.length;y++)d[y]=u[y];u=this.valueHexView=new Uint8Array(f)}}this.blockLength=a+1,u[a-1]=o[a]&127;let l=new Uint8Array(a);for(let d=0;d<a;d++)l[d]=u[d];u=this.valueHexView=new Uint8Array(a),u.set(l),this.blockLength<=9?this.tagNumber=Le(u,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}}};Mn.NAME="identificationBlock";var Pn=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=Le(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}}};Pn.NAME="lengthBlock";var k={},it=class extends zt{constructor({name:t=ar,optional:e=!1,primitiveSchema:n,...s}={},o){super(s),this.name=t,this.optional=e,n&&(this.primitiveSchema=n),this.idBlock=new Mn(s),this.lenBlock=new Pn(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||qc(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 Oc(e,n)}};it.NAME="BaseBlock";function qc(r){var t;if(r instanceof k.Constructed)for(let e of r.valueBlock.value)qc(e)&&(r.lenBlock.isIndefiniteForm=!0);return!!(!((t=r.lenBlock)===null||t===void 0)&&t.isIndefiniteForm)}var Fn=class extends it{getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}constructor({value:t=ar,...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}'`}};Fn.NAME="BaseStringBlock";var qn=class extends te(lt){constructor({isHexOnly:t=!0,...e}={}){super(e),this.isHexOnly=t}};qn.NAME="PrimitiveValueBlock";var $c,$n=class extends it{constructor(t={}){super(t,qn),this.idBlock.isConstructed=!1}};$c=$n;k.Primitive=$c;$n.NAME="PRIMITIVE";function Sh(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 As(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 u=s.idBlock.isConstructed?new k.Constructed:new k.Primitive;u.idBlock=s.idBlock,u.lenBlock=s.lenBlock,u.warnings=s.warnings,s=u}}break;case 2:case 3:case 4:default:a=s.idBlock.isConstructed?k.Constructed:k.Primitive}return s=Sh(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 Ss(r){if(!r.byteLength){let t=new it({},lt);return t.error="Input buffer has zero length",{offset:-1,result:t}}return As(q.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function kh(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(;kh(this.isIndefiniteForm,n)>0;){let i=As(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 jc,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(`
|
|
2
|
+
"use strict";var Libp2PKeychain=(()=>{var yu=Object.create;var bn=Object.defineProperty;var mu=Object.getOwnPropertyDescriptor;var xu=Object.getOwnPropertyNames;var wu=Object.getPrototypeOf,vu=Object.prototype.hasOwnProperty;var Er=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),ht=(r,t)=>{for(var e in t)bn(r,e,{get:t[e],enumerable:!0})},Oi=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of xu(t))!vu.call(r,s)&&s!==e&&bn(r,s,{get:()=>t[s],enumerable:!(n=mu(t,s))||n.enumerable});return r};var Mi=(r,t,e)=>(e=r!=null?yu(wu(r)):{},Oi(t||!r||!r.__esModule?bn(e,"default",{value:r,enumerable:!0}):e,r)),Eu=r=>Oi(bn({},"__esModule",{value:!0}),r);var xf=Er((em,mf)=>{"use strict";function t0(r){return r>=55296&&r<=56319}function e0(r){return r>=56320&&r<=57343}mf.exports=function(t,e,n){if(typeof e!="string")throw new Error("Input must be string");for(var s=e.length,o=0,i,a,c=0;c<s;c+=1){if(i=e.charCodeAt(c),a=e[c],t0(i)&&e0(e.charCodeAt(c+1))&&(c+=1,a+=e[c]),o+=t(a),o===n)return e.slice(0,c+1);if(o>n)return e.slice(0,c-a.length+1)}return e}});var vf=Er((rm,wf)=>{"use strict";function r0(r){return r>=55296&&r<=56319}function n0(r){return r>=56320&&r<=57343}wf.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),n0(s)?o!=null&&r0(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 Bf=Er((nm,Ef)=>{"use strict";var s0=xf(),o0=vf();Ef.exports=s0.bind(null,o0)});var kf=Er((sm,Sf)=>{"use strict";var i0=Bf(),a0=/[\/\?<>\\:\*\|"]/g,c0=/[\x00-\x1f\x80-\x9f]/g,f0=/^\.+$/,u0=/^(con|prn|aux|nul|com[0-9]|lpt[0-9])(\..*)?$/i;function l0(r,t){for(var e=r.length;e>0&&(r[e-1]==="."||r[e-1]===" ");)e--;return e<r.length?r.slice(0,e)+t:r}function Af(r,t){if(typeof r!="string")throw new Error("Input must be string");var e=r.replace(a0,t).replace(c0,t).replace(f0,t).replace(u0,t);return e=l0(e,t),i0(e,255)}Sf.exports=function(r,t){var e=t&&t.replacement||"",n=Af(r,e);return e===""?n:Af(n,"")}});var If=Er(mr=>{"use strict";var d0="[object ArrayBuffer]",Qt=class r{static isArrayBuffer(t){return Object.prototype.toString.call(t)===d0}static toArrayBuffer(t){return this.isArrayBuffer(t)?t:t.byteLength===t.buffer.byteLength||t.byteOffset===0&&t.byteLength===t.buffer.byteLength?t.buffer:this.toUint8Array(t.buffer).slice(t.byteOffset,t.byteOffset+t.byteLength).buffer}static toUint8Array(t){return this.toView(t,Uint8Array)}static toView(t,e){if(t.constructor===e)return t;if(this.isArrayBuffer(t))return new e(t);if(this.isArrayBufferView(t))return new e(t.buffer,t.byteOffset,t.byteLength);throw new TypeError("The provided value is not of type '(ArrayBuffer or ArrayBufferView)'")}static isBufferSource(t){return this.isArrayBufferView(t)||this.isArrayBuffer(t)}static isArrayBufferView(t){return ArrayBuffer.isView(t)||t&&this.isArrayBuffer(t.buffer)}static isEqual(t,e){let n=r.toUint8Array(t),s=r.toUint8Array(e);if(n.length!==s.byteLength)return!1;for(let o=0;o<n.length;o++)if(n[o]!==s[o])return!1;return!0}static concat(...t){let e;Array.isArray(t[0])&&!(t[1]instanceof Function)||Array.isArray(t[0])&&t[1]instanceof Function?e=t[0]:t[t.length-1]instanceof Function?e=t.slice(0,t.length-1):e=t;let n=0;for(let i of e)n+=i.byteLength;let s=new Uint8Array(n),o=0;for(let i of e){let a=this.toUint8Array(i);s.set(a,o),o+=a.length}return t[t.length-1]instanceof Function?this.toView(s,t[t.length-1]):s.buffer}},Li="string",p0=/^[0-9a-f\s]+$/i,g0=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,b0=/^[a-zA-Z0-9-_]+$/,rs=class{static fromString(t){let e=unescape(encodeURIComponent(t)),n=new Uint8Array(e.length);for(let s=0;s<e.length;s++)n[s]=e.charCodeAt(s);return n.buffer}static toString(t){let e=Qt.toUint8Array(t),n="";for(let o=0;o<e.length;o++)n+=String.fromCharCode(e[o]);return decodeURIComponent(escape(n))}},It=class{static toString(t,e=!1){let n=Qt.toArrayBuffer(t),s=new DataView(n),o="";for(let i=0;i<n.byteLength;i+=2){let a=s.getUint16(i,e);o+=String.fromCharCode(a)}return o}static fromString(t,e=!1){let n=new ArrayBuffer(t.length*2),s=new DataView(n);for(let o=0;o<t.length;o++)s.setUint16(o*2,t.charCodeAt(o),e);return n}},ns=class r{static isHex(t){return typeof t===Li&&p0.test(t)}static isBase64(t){return typeof t===Li&&g0.test(t)}static isBase64Url(t){return typeof t===Li&&b0.test(t)}static ToString(t,e="utf8"){let n=Qt.toUint8Array(t);switch(e.toLowerCase()){case"utf8":return this.ToUtf8String(n);case"binary":return this.ToBinary(n);case"hex":return this.ToHex(n);case"base64":return this.ToBase64(n);case"base64url":return this.ToBase64Url(n);case"utf16le":return 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=Qt.toUint8Array(t);if(typeof btoa<"u"){let n=this.ToString(e,"binary");return btoa(n)}else return Buffer.from(e).toString("base64")}static FromBase64(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isBase64(e))throw new TypeError("Argument 'base64Text' is not Base64 encoded");return typeof atob<"u"?this.FromBinary(atob(e)):new Uint8Array(Buffer.from(e,"base64")).buffer}static FromBase64Url(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isBase64Url(e))throw new TypeError("Argument 'base64url' is not Base64Url encoded");return this.FromBase64(this.Base64Padding(e.replace(/\-/g,"+").replace(/\_/g,"/")))}static ToBase64Url(t){return this.ToBase64(t).replace(/\+/g,"-").replace(/\//g,"_").replace(/\=/g,"")}static FromUtf8String(t,e=r.DEFAULT_UTF8_ENCODING){switch(e){case"ascii":return this.FromBinary(t);case"utf8":return rs.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 rs.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=Qt.toUint8Array(t),n="";for(let s=0;s<e.length;s++)n+=String.fromCharCode(e[s]);return n}static ToHex(t){let e=Qt.toUint8Array(t),n="",s=e.length;for(let o=0;o<s;o++){let i=e[o];i<16&&(n+="0"),n+=i.toString(16)}return n}static FromHex(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isHex(e))throw new TypeError("Argument 'hexString' is not HEX encoded");e.length%2&&(e=`0${e}`);let n=new Uint8Array(e.length/2);for(let s=0;s<e.length;s=s+2){let o=e.slice(s,s+2);n[s/2]=parseInt(o,16)}return n.buffer}static ToUtf16String(t,e=!1){return 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,"")||""}};ns.DEFAULT_UTF8_ENCODING="utf8";function y0(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 m0(...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 x0(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}mr.BufferSourceConverter=Qt;mr.Convert=ns;mr.assign=y0;mr.combine=m0;mr.isEqual=x0});var H0={};ht(H0,{keychain:()=>D0});var Br=class extends Error{constructor(t="An error occurred while signing a message"){super(t),this.name="SigningError"}},Ar=class extends Error{constructor(t="An error occurred while verifying a message"){super(t),this.name="VerificationError"}},yn=class extends Error{constructor(t="Missing Web Crypto API"){super(t),this.name="WebCryptoMissingError"}};var Pi={get(r=globalThis){let t=r.crypto;if(t?.subtle==null)throw new yn("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 tt=Pi;var R=class extends Error{static name="InvalidParametersError";constructor(t="Invalid parameters"){super(t),this.name="InvalidParametersError"}},$e=class extends Error{static name="InvalidPublicKeyError";constructor(t="Invalid public key"){super(t),this.name="InvalidPublicKeyError"}},Sr=class extends Error{static name="InvalidPrivateKeyError";constructor(t="Invalid private key"){super(t),this.name="InvalidPrivateKeyError"}};var mn=class extends Error{static name="NotFoundError";constructor(t="Not found"){super(t),this.name="NotFoundError"}};var je=class extends Error{static name="UnsupportedKeyTypeError";constructor(t="Unsupported key type"){super(t),this.name="UnsupportedKeyTypeError"}};var Fi=Symbol.for("@libp2p/service-capabilities");var Xs={};ht(Xs,{base58btc:()=>et,base58flickr:()=>Lu});var gd=new Uint8Array(0);function qi(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function Ft(r){if(r instanceof Uint8Array&&r.constructor.name==="Uint8Array")return r;if(r instanceof ArrayBuffer)return new Uint8Array(r);if(ArrayBuffer.isView(r))return new Uint8Array(r.buffer,r.byteOffset,r.byteLength);throw new Error("Unknown type, must be binary type")}function $i(r){return new TextEncoder().encode(r)}function ji(r){return new TextDecoder().decode(r)}function Bu(r,t){if(r.length>=255)throw new TypeError("Alphabet too long");for(var e=new Uint8Array(256),n=0;n<e.length;n++)e[n]=255;for(var s=0;s<r.length;s++){var o=r.charAt(s),i=o.charCodeAt(0);if(e[i]!==255)throw new TypeError(o+" is ambiguous");e[i]=s}var a=r.length,c=r.charAt(0),u=Math.log(a)/Math.log(256),l=Math.log(256)/Math.log(a);function f(d){if(d instanceof Uint8Array||(ArrayBuffer.isView(d)?d=new Uint8Array(d.buffer,d.byteOffset,d.byteLength):Array.isArray(d)&&(d=Uint8Array.from(d))),!(d instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(d.length===0)return"";for(var E=0,w=0,b=0,A=d.length;b!==A&&d[b]===0;)b++,E++;for(var g=(A-b)*l+1>>>0,S=new Uint8Array(g);b!==A;){for(var T=d[b],V=0,O=g-1;(T!==0||V<w)&&O!==-1;O--,V++)T+=256*S[O]>>>0,S[O]=T%a>>>0,T=T/a>>>0;if(T!==0)throw new Error("Non-zero carry");w=V,b++}for(var B=g-w;B!==g&&S[B]===0;)B++;for(var v=c.repeat(E);B<g;++B)v+=r.charAt(S[B]);return v}function h(d){if(typeof d!="string")throw new TypeError("Expected String");if(d.length===0)return new Uint8Array;var E=0;if(d[E]!==" "){for(var w=0,b=0;d[E]===c;)w++,E++;for(var A=(d.length-E)*u+1>>>0,g=new Uint8Array(A);d[E];){var S=e[d.charCodeAt(E)];if(S===255)return;for(var T=0,V=A-1;(S!==0||T<b)&&V!==-1;V--,T++)S+=a*g[V]>>>0,g[V]=S%256>>>0,S=S/256>>>0;if(S!==0)throw new Error("Non-zero carry");b=T,E++}if(d[E]!==" "){for(var O=A-b;O!==A&&g[O]===0;)O++;for(var B=new Uint8Array(w+(A-O)),v=w;O!==A;)B[v++]=g[O++];return B}}}function p(d){var E=h(d);if(E)return E;throw new Error(`Non-${t} character`)}return{encode:f,decodeUnsafe:h,decode:p}}var Au=Bu,Su=Au,Zi=Su;var Ys=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")}},Ws=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 Yi(this,t)}},zs=class{decoders;constructor(t){this.decoders=t}or(t){return Yi(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 Yi(r,t){return new zs({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var Js=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(t,e,n,s){this.name=t,this.prefix=e,this.baseEncode=n,this.baseDecode=s,this.encoder=new Ys(t,e,n),this.decoder=new Ws(t,e,s)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function Ge({name:r,prefix:t,encode:e,decode:n}){return new Js(r,t,e,n)}function ie({name:r,prefix:t,alphabet:e}){let{encode:n,decode:s}=Zi(e,r);return Ge({prefix:t,name:r,encode:n,decode:o=>Ft(s(o))})}function ku(r,t,e,n){let s=r.length;for(;r[s-1]==="=";)--s;let o=new Uint8Array(s*e/8|0),i=0,a=0,c=0;for(let u=0;u<s;++u){let l=t[r[u]];if(l===void 0)throw new SyntaxError(`Non-${n} character`);a=a<<e|l,i+=e,i>=8&&(i-=8,o[c++]=255&a>>i)}if(i>=e||(255&a<<8-i)!==0)throw new SyntaxError("Unexpected end of data");return o}function Iu(r,t,e){let n=t[t.length-1]==="=",s=(1<<e)-1,o="",i=0,a=0;for(let c=0;c<r.length;++c)for(a=a<<8|r[c],i+=8;i>e;)i-=e,o+=t[s&a>>i];if(i!==0&&(o+=t[s&a<<e-i]),n)for(;(o.length*e&7)!==0;)o+="=";return o}function Cu(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=Cu(n);return Ge({prefix:t,name:r,encode(o){return Iu(o,n,e)},decode(o){return ku(o,s,e,r)}})}var et=ie({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),Lu=ie({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Qs={};ht(Qs,{base32:()=>Ze,base32hex:()=>_u,base32hexpad:()=>Du,base32hexpadupper:()=>Hu,base32hexupper:()=>Ru,base32pad:()=>Uu,base32padupper:()=>Tu,base32upper:()=>Nu,base32z:()=>Vu});var Ze=J({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),Nu=J({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Uu=J({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),Tu=J({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),_u=J({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),Ru=J({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),Du=J({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),Hu=J({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),Vu=J({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var to={};ht(to,{base36:()=>kr,base36upper:()=>Ku});var kr=ie({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),Ku=ie({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Ou=Ji,Wi=128,Mu=127,Pu=~Mu,Fu=Math.pow(2,31);function Ji(r,t,e){t=t||[],e=e||0;for(var n=e;r>=Fu;)t[e++]=r&255|Wi,r/=128;for(;r&Pu;)t[e++]=r&255|Wi,r>>>=7;return t[e]=r|0,Ji.bytes=e-n+1,t}var qu=eo,$u=128,zi=127;function eo(r,n){var e=0,n=n||0,s=0,o=n,i,a=r.length;do{if(o>=a)throw eo.bytes=0,new RangeError("Could not decode varint");i=r[o++],e+=s<28?(i&zi)<<s:(i&zi)*Math.pow(2,s),s+=7}while(i>=$u);return eo.bytes=o-n,e}var ju=Math.pow(2,7),Gu=Math.pow(2,14),Zu=Math.pow(2,21),Yu=Math.pow(2,28),Wu=Math.pow(2,35),zu=Math.pow(2,42),Ju=Math.pow(2,49),Xu=Math.pow(2,56),Qu=Math.pow(2,63),tl=function(r){return r<ju?1:r<Gu?2:r<Zu?3:r<Yu?4:r<Wu?5:r<zu?6:r<Ju?7:r<Xu?8:r<Qu?9:10},el={encode:Ou,decode:qu,encodingLength:tl},rl=el,Ir=rl;function Cr(r,t=0){return[Ir.decode(r,t),Ir.decode.bytes]}function Ye(r,t,e=0){return Ir.encode(r,t,e),t}function We(r){return Ir.encodingLength(r)}function Rt(r,t){let e=t.byteLength,n=We(r),s=n+We(e),o=new Uint8Array(s+e);return Ye(r,o,0),Ye(e,o,n),o.set(t,s),new ze(r,e,t,o)}function Xi(r){let t=Ft(r),[e,n]=Cr(t),[s,o]=Cr(t.subarray(n)),i=t.subarray(n+o);if(i.byteLength!==s)throw new Error("Incorrect length");return new ze(e,s,i,t)}function Qi(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&qi(r.bytes,e.bytes)}}var ze=class{code;size;digest;bytes;constructor(t,e,n,s){this.code=t,this.size=e,this.digest=n,this.bytes=s}};function ta(r,t){let{bytes:e,version:n}=r;return n===0?sl(e,ro(r),t??et.encoder):ol(e,ro(r),t??Ze.encoder)}var ea=new WeakMap;function ro(r){let t=ea.get(r);if(t==null){let e=new Map;return ea.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!==Nr)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==il)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&&Qi(t.multihash,n.multihash)}toString(t){return ta(this,t)}toJSON(){return{"/":ta(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??ra(n,s,o.bytes))}else if(e[al]===!0){let{version:n,multihash:s,code:o}=e,i=Xi(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!==Nr)throw new Error(`Version 0 CID must use dag-pb (code: ${Nr}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let s=ra(t,e,n.bytes);return new r(t,e,n,s)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,Nr,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=Ft(t.subarray(n,n+e.multihashSize));if(s.byteLength!==e.multihashSize)throw new Error("Incorrect length");let o=s.subarray(e.multihashSize-e.digestSize),i=new ze(e.multihashCode,e.digestSize,o,s);return[e.version===0?r.createV0(i):r.createV1(e.codec,i),t.subarray(e.size)]}static inspectBytes(t){let e=0,n=()=>{let[f,h]=Cr(t.subarray(e));return e+=h,f},s=n(),o=Nr;if(s===18?(s=0,e=0):o=n(),s!==0&&s!==1)throw new RangeError(`Invalid CID version ${s}`);let i=e,a=n(),c=n(),u=e+c,l=u-i;return{version:s,codec:o,multihashCode:a,digestSize:c,multihashSize:l,size:u}}static parse(t,e){let[n,s]=nl(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 ro(o).set(n,t),o}};function nl(r,t){switch(r[0]){case"Q":{let e=t??et;return[et.prefix,e.decode(`${et.prefix}${r}`)]}case et.prefix:{let e=t??et;return[et.prefix,e.decode(r)]}case Ze.prefix:{let e=t??Ze;return[Ze.prefix,e.decode(r)]}case kr.prefix:{let e=t??kr;return[kr.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 sl(r,t,e){let{prefix:n}=e;if(n!==et.prefix)throw Error(`Cannot string encode V0 in ${e.name} encoding`);let s=t.get(n);if(s==null){let o=e.encode(r).slice(1);return t.set(n,o),o}else return s}function ol(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 Nr=112,il=18;function ra(r,t,e){let n=We(r),s=n+We(t),o=new Uint8Array(s+e.byteLength);return Ye(r,o,0),Ye(t,o,n),o.set(e,s),o}var al=Symbol.for("@ipld/js-cid/CID");var no={};ht(no,{identity:()=>Ee});var na=0,cl="identity",sa=Ft;function fl(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(na,sa(r))}var Ee={code:na,name:cl,encode:sa,digest:fl};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 qt(r=0){return new Uint8Array(r)}function Bt(r=0){return new Uint8Array(r)}function Je(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 ia=Symbol.for("@achingbrain/uint8arraylist");function oa(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 wn(r){return!!r?.[ia]}var dt=class r{bufs;length;[ia]=!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(wn(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(wn(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=oa(this.bufs,t);return e.buf[e.index]}set(t,e){let n=oa(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(wn(t))for(let n=0;n<t.length;n++)this.set(e+n,t.get(n));else throw new Error("Could not write value, must be an Uint8Array or a Uint8ArrayList")}consume(t){if(t=Math.trunc(t),!(Number.isNaN(t)||t<=0)){if(t===this.byteLength){this.bufs=[],this.length=0;return}for(;this.bufs.length>0;)if(t>=this.bufs[0].byteLength)t-=this.bufs[0].byteLength,this.length-=this.bufs[0].byteLength,this.bufs.shift();else{this.bufs[0]=this.bufs[0].subarray(t),this.length-=t;break}}}slice(t,e){let{bufs:n,length:s}=this._subList(t,e);return Je(n,s)}subarray(t,e){let{bufs:n,length:s}=this._subList(t,e);return n.length===1?n[0]:Je(n,s)}sublist(t,e){let{bufs:n,length:s}=this._subList(t,e),o=new r;return o.length=s,o.bufs=[...n],o}_subList(t,e){if(t=t??0,e=e??this.length,t<0&&(t=this.length+t),e<0&&(e=this.length+e),t<0||e>this.length)throw new RangeError("index is out of bounds");if(t===e)return{bufs:[],length:0};if(t===0&&e===this.length)return{bufs:this.bufs,length:this.length};let n=[],s=0;for(let o=0;o<this.bufs.length;o++){let i=this.bufs[o],a=s,c=a+i.byteLength;if(s=c,t>=c)continue;let u=t>=a&&t<c,l=e>a&&e<=c;if(u&&l){if(t===a&&e===c){n.push(i);break}let f=t-a;n.push(i.subarray(f,f+(e-t)));break}if(u){if(t===0){n.push(i);continue}n.push(i.subarray(t-a));continue}if(l){if(e===c){n.push(i);break}n.push(i.subarray(0,e-a));break}n.push(i)}return{bufs:n,length:e-t}}indexOf(t,e=0){if(!wn(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 f=0;f<o;f++)i[f]=-1;for(let f=0;f<s;f++)i[n[f]]=f;let a=i,c=this.byteLength-n.byteLength,u=n.byteLength-1,l;for(let f=e;f<=c;f+=l){l=0;for(let h=u;h>=0;h--){let p=this.get(f+h);if(n[h]!==p){l=Math.max(1,h-a[p]);break}}if(l===0)return f}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=qt(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=qt(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=qt(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=qt(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=qt(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=qt(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=qt(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=qt(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 so={};ht(so,{base10:()=>ul});var ul=ie({prefix:"9",name:"base10",alphabet:"0123456789"});var oo={};ht(oo,{base16:()=>ll,base16upper:()=>hl});var ll=J({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),hl=J({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var io={};ht(io,{base2:()=>dl});var dl=J({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var ao={};ht(ao,{base256emoji:()=>ml});var aa=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}"),pl=aa.reduce((r,t,e)=>(r[e]=t,r),[]),gl=aa.reduce((r,t,e)=>{let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);return r[n]=e,r},[]);function bl(r){return r.reduce((t,e)=>(t+=pl[e],t),"")}function yl(r){let t=[];for(let e of r){let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);let s=gl[n];if(s==null)throw new Error(`Non-base256emoji character: ${e}`);t.push(s)}return new Uint8Array(t)}var ml=Ge({prefix:"\u{1F680}",name:"base256emoji",encode:bl,decode:yl});var co={};ht(co,{base64:()=>Be,base64pad:()=>xl,base64url:()=>wl,base64urlpad:()=>vl});var Be=J({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),xl=J({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),wl=J({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),vl=J({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var fo={};ht(fo,{base8:()=>El});var El=J({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var uo={};ht(uo,{identity:()=>Bl});var Bl=Ge({prefix:"\0",name:"identity",encode:r=>ji(r),decode:r=>$i(r)});var Xd=new TextEncoder,Qd=new TextDecoder;var po={};ht(po,{sha256:()=>Xe,sha512:()=>Il});var kl=20;function ho({name:r,code:t,encode:e,minDigestLength:n,maxDigestLength:s}){return new lo(r,t,e,n,s)}var lo=class{name;code;encode;minDigestLength;maxDigestLength;constructor(t,e,n,s,o){this.name=t,this.code=e,this.encode=n,this.minDigestLength=s??kl,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?ca(n,this.code,e?.truncate):n.then(s=>ca(s,this.code,e?.truncate))}else throw Error("Unknown type, must be binary type")}};function ca(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 ua(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var Xe=ho({name:"sha2-256",code:18,encode:ua("SHA-256")}),Il=ho({name:"sha2-512",code:19,encode:ua("SHA-512")});var go={...uo,...io,...fo,...so,...oo,...Qs,...to,...Xs,...co,...ao},lp={...po,...no};function ha(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var la=ha("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),bo=ha("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}),Cl={utf8:la,"utf-8":la,hex:go.base16,latin1:bo,ascii:bo,binary:bo,...go},vn=Cl;function F(r,t="utf8"){let e=vn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function $(r,t="utf8"){let e=vn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}var Ll=parseInt("11111",2),yo=parseInt("10000000",2),Nl=parseInt("01111111",2),da={0:Ur,1:Ur,2:Ul,3:Rl,4:Dl,5:_l,6:Tl,16:Ur,22:Ur,48:Ur};function Ct(r,t={offset:0}){let e=r[t.offset]⋘if(t.offset++,da[e]!=null)return da[e](r,t);throw new Error("No decoder for tag "+e)}function Tr(r,t){let e=0;if((r[t.offset]&yo)===yo){let n=r[t.offset]&Nl,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 Ur(r,t){Tr(r,t);let e=[];for(;!(t.offset>=r.byteLength);){let n=Ct(r,t);if(n===null)break;e.push(n)}return e}function Ul(r,t){let e=Tr(r,t),n=t.offset,s=t.offset+e,o=[];for(let i=n;i<s;i++)i===n&&r[i]===0||o.push(r[i]);return t.offset+=e,Uint8Array.from(o)}function Tl(r,t){let e=Tr(r,t),n=t.offset+e,s=r[t.offset];t.offset++;let o=0,i=0;s<40?(o=0,i=s):s<80?(o=1,i=s-40):(o=2,i=s-80);let a=`${o}.${i}`,c=[];for(;t.offset<n;){let u=r[t.offset];if(t.offset++,c.push(u&127),u<128){c.reverse();let l=0;for(let f=0;f<c.length;f++)l+=c[f]<<f*7;a+=`.${l}`,c=[]}}return a}function _l(r,t){return t.offset++,null}function Rl(r,t){let e=Tr(r,t),n=r[t.offset];t.offset++;let s=r.subarray(t.offset,t.offset+e-1);if(t.offset+=e,n!==0)throw new Error("Unused bits in bit string is unimplemented");return s}function Dl(r,t){let e=Tr(r,t),n=r.subarray(t.offset,t.offset+e);return t.offset+=e,n}function Hl(r){let t=r.toString(16);t.length%2===1&&(t="0"+t);let e=new dt;for(let n=0;n<t.length;n+=2)e.append(Uint8Array.from([parseInt(`${t[n]}${t[n+1]}`,16)]));return e}function En(r){if(r.byteLength<128)return Uint8Array.from([r.byteLength]);let t=Hl(r.byteLength);return new dt(Uint8Array.from([t.byteLength|yo]),t)}function pt(r){let t=new dt,e=128;return(r.subarray()[0]&e)===e&&t.append(Uint8Array.from([0])),t.append(r),new dt(Uint8Array.from([2]),En(t),t)}function _r(r){let t=Uint8Array.from([0]),e=new dt(t,r);return new dt(Uint8Array.from([3]),En(e),e)}function pa(r){return new dt(Uint8Array.from([4]),En(r),r)}function Lt(r,t=48){let e=new dt;for(let n of r)e.append(n);return new dt(Uint8Array.from([t]),En(e),e)}var ga="1.2.840.10045.3.1.7",ba="1.3.132.0.34",ya="1.3.132.0.35";async function ma(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 xa(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 Vl=Uint8Array.from([6,8,42,134,72,206,61,3,1,7]),Kl=Uint8Array.from([6,5,43,129,4,0,34]),Ol=Uint8Array.from([6,5,43,129,4,0,35]),Ml={ext:!0,kty:"EC",crv:"P-256"},Pl={ext:!0,kty:"EC",crv:"P-384"},Fl={ext:!0,kty:"EC",crv:"P-521"},mo=32,xo=48,wo=66;function wa(r){let t=Ct(r);return vo(t)}function vo(r){let t=r[1],e=$(t,"base64url"),n=r[2][1][0],s=1,o,i;if(t.byteLength===mo)return o=$(n.subarray(s,s+mo),"base64url"),i=$(n.subarray(s+mo),"base64url"),new Qe({...Ml,key_ops:["sign"],d:e,x:o,y:i});if(t.byteLength===xo)return o=$(n.subarray(s,s+xo),"base64url"),i=$(n.subarray(s+xo),"base64url"),new Qe({...Pl,key_ops:["sign"],d:e,x:o,y:i});if(t.byteLength===wo)return o=$(n.subarray(s,s+wo),"base64url"),i=$(n.subarray(s+wo),"base64url"),new Qe({...Fl,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 va(r){return Lt([pt(Uint8Array.from([1])),pa(F(r.d??"","base64url")),Lt([Ba(r.crv)],160),Lt([_r(new dt(Uint8Array.from([4]),F(r.x??"","base64url"),F(r.y??"","base64url")))],161)]).subarray()}function Ea(r){return Lt([pt(Uint8Array.from([1])),Lt([Ba(r.crv)],160),Lt([_r(new dt(Uint8Array.from([4]),F(r.x??"","base64url"),F(r.y??"","base64url")))],161)]).subarray()}function Ba(r){if(r==="P-256")return Vl;if(r==="P-384")return Kl;if(r==="P-521")return Ol;throw new R(`Invalid curve ${r}`)}var Bn=class{type="ECDSA";jwk;_raw;constructor(t){this.jwk=t}get raw(){return this._raw==null&&(this._raw=Ea(this.jwk)),this._raw}toMultihash(){return Ee.digest(tr(this))}toCID(){return St.createV1(114,this.toMultihash())}toString(){return et.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 xa(this.jwk,e,t,n)}},Qe=class{type="ECDSA";jwk;publicKey;_raw;constructor(t){this.jwk=t,this.publicKey=new Bn({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=va(this.jwk)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:mt(this.raw,t.raw)}async sign(t,e){return ma(this.jwk,t,e)}};function Ae(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function Dt(r,t=""){if(!Number.isSafeInteger(r)||r<0){let e=t&&`"${t}" `;throw new Error(`${e}expected integer >= 0, got ${r}`)}}function P(r,t,e=""){let n=Ae(r),s=r?.length,o=t!==void 0;if(!n||o&&s!==t){let i=e&&`"${e}" `,a=o?` of length ${t}`:"",c=n?`length=${s}`:`type=${typeof r}`;throw new Error(i+"expected Uint8Array"+a+", got "+c)}return r}function An(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash must wrapped by utils.createHasher");Dt(r.outputLen),Dt(r.blockLen)}function er(r,t=!0){if(r.destroyed)throw new Error("Hash instance has been destroyed");if(t&&r.finished)throw new Error("Hash#digest() has already been called")}function Sa(r,t){P(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 jt(...r){for(let t=0;t<r.length;t++)r[t].fill(0)}function Sn(r){return new DataView(r.buffer,r.byteOffset,r.byteLength)}function Nt(r,t){return r<<32-t|r>>>t}var ka=typeof Uint8Array.from([]).toHex=="function"&&typeof Uint8Array.fromHex=="function",ql=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function Gt(r){if(P(r),ka)return r.toHex();let t="";for(let e=0;e<r.length;e++)t+=ql[r[e]];return t}var $t={_0:48,_9:57,A:65,F:70,a:97,f:102};function Aa(r){if(r>=$t._0&&r<=$t._9)return r-$t._0;if(r>=$t.A&&r<=$t.F)return r-($t.A-10);if(r>=$t.a&&r<=$t.f)return r-($t.a-10)}function Zt(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);if(ka)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=Aa(r.charCodeAt(o)),a=Aa(r.charCodeAt(o+1));if(i===void 0||a===void 0){let c=r[o]+r[o+1];throw new Error('hex string expected, got non-hex character "'+c+'" at index '+o)}n[s]=i*16+a}return n}function xt(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];P(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 Eo(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 rr(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 Bo=r=>({oid:Uint8Array.from([6,9,96,134,72,1,101,3,4,2,r])});function Ia(r,t,e){return r&t^~r&e}function Ca(r,t,e){return r&t^r&e^t&e}var Rr=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=Sn(this.buffer)}update(t){er(this),P(t);let{view:e,buffer:n,blockLen:s}=this,o=t.length;for(let i=0;i<o;){let a=Math.min(s-this.pos,o-i);if(a===s){let c=Sn(t);for(;s<=o-i;i+=s)this.process(c,i);continue}n.set(t.subarray(i,i+a),this.pos),this.pos+=a,i+=a,this.pos===s&&(this.process(e,0),this.pos=0)}return this.length+=t.length,this.roundClean(),this}digestInto(t){er(this),Sa(t,this),this.finished=!0;let{buffer:e,view:n,blockLen:s,isLE:o}=this,{pos:i}=this;e[i++]=128,jt(this.buffer.subarray(i)),this.padOffset>s-i&&(this.process(n,0),i=0);for(let f=i;f<s;f++)e[f]=0;n.setBigUint64(s-8,BigInt(this.length*8),o),this.process(n,0);let a=Sn(t),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen must be aligned to 32bit");let u=c/4,l=this.get();if(u>l.length)throw new Error("_sha2: outputLen bigger than state");for(let f=0;f<u;f++)a.setUint32(4*f,l[f],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:a}=this;return t.destroyed=i,t.finished=o,t.length=s,t.pos=a,s%e&&t.buffer.set(n),t}clone(){return this._cloneInto()}},Yt=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 kn=BigInt(4294967295),La=BigInt(32);function $l(r,t=!1){return t?{h:Number(r&kn),l:Number(r>>La&kn)}:{h:Number(r>>La&kn)|0,l:Number(r&kn)|0}}function Na(r,t=!1){let e=r.length,n=new Uint32Array(e),s=new Uint32Array(e);for(let o=0;o<e;o++){let{h:i,l:a}=$l(r[o],t);[n[o],s[o]]=[i,a]}return[n,s]}var Ao=(r,t,e)=>r>>>e,So=(r,t,e)=>r<<32-e|t>>>e,Se=(r,t,e)=>r>>>e|t<<32-e,ke=(r,t,e)=>r<<32-e|t>>>e,Dr=(r,t,e)=>r<<64-e|t>>>e-32,Hr=(r,t,e)=>r>>>e-32|t<<64-e;function Ht(r,t,e,n){let s=(t>>>0)+(n>>>0);return{h:r+e+(s/2**32|0)|0,l:s|0}}var Ua=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),Ta=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,_a=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),Ra=(r,t,e,n,s)=>t+e+n+s+(r/2**32|0)|0,Da=(r,t,e,n,s)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(s>>>0),Ha=(r,t,e,n,s,o)=>t+e+n+s+o+(r/2**32|0)|0;var Gl=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]),ae=new Uint32Array(64),ko=class extends Rr{constructor(t){super(64,t,8,!1)}get(){let{A:t,B:e,C:n,D:s,E:o,F:i,G:a,H:c}=this;return[t,e,n,s,o,i,a,c]}set(t,e,n,s,o,i,a,c){this.A=t|0,this.B=e|0,this.C=n|0,this.D=s|0,this.E=o|0,this.F=i|0,this.G=a|0,this.H=c|0}process(t,e){for(let f=0;f<16;f++,e+=4)ae[f]=t.getUint32(e,!1);for(let f=16;f<64;f++){let h=ae[f-15],p=ae[f-2],d=Nt(h,7)^Nt(h,18)^h>>>3,E=Nt(p,17)^Nt(p,19)^p>>>10;ae[f]=E+ae[f-7]+d+ae[f-16]|0}let{A:n,B:s,C:o,D:i,E:a,F:c,G:u,H:l}=this;for(let f=0;f<64;f++){let h=Nt(a,6)^Nt(a,11)^Nt(a,25),p=l+h+Ia(a,c,u)+Gl[f]+ae[f]|0,E=(Nt(n,2)^Nt(n,13)^Nt(n,22))+Ca(n,s,o)|0;l=u,u=c,c=a,a=i+p|0,i=o,o=s,s=n,n=p+E|0}n=n+this.A|0,s=s+this.B|0,o=o+this.C|0,i=i+this.D|0,a=a+this.E|0,c=c+this.F|0,u=u+this.G|0,l=l+this.H|0,this.set(n,s,o,i,a,c,u,l)}roundClean(){jt(ae)}destroy(){this.set(0,0,0,0,0,0,0,0),jt(this.buffer)}},Io=class extends ko{A=Yt[0]|0;B=Yt[1]|0;C=Yt[2]|0;D=Yt[3]|0;E=Yt[4]|0;F=Yt[5]|0;G=Yt[6]|0;H=Yt[7]|0;constructor(){super(32)}};var Va=Na(["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))),Zl=Va[0],Yl=Va[1],ce=new Uint32Array(80),fe=new Uint32Array(80),Co=class extends Rr{constructor(t){super(128,t,16,!1)}get(){let{Ah:t,Al:e,Bh:n,Bl:s,Ch:o,Cl:i,Dh:a,Dl:c,Eh:u,El:l,Fh:f,Fl:h,Gh:p,Gl:d,Hh:E,Hl:w}=this;return[t,e,n,s,o,i,a,c,u,l,f,h,p,d,E,w]}set(t,e,n,s,o,i,a,c,u,l,f,h,p,d,E,w){this.Ah=t|0,this.Al=e|0,this.Bh=n|0,this.Bl=s|0,this.Ch=o|0,this.Cl=i|0,this.Dh=a|0,this.Dl=c|0,this.Eh=u|0,this.El=l|0,this.Fh=f|0,this.Fl=h|0,this.Gh=p|0,this.Gl=d|0,this.Hh=E|0,this.Hl=w|0}process(t,e){for(let g=0;g<16;g++,e+=4)ce[g]=t.getUint32(e),fe[g]=t.getUint32(e+=4);for(let g=16;g<80;g++){let S=ce[g-15]|0,T=fe[g-15]|0,V=Se(S,T,1)^Se(S,T,8)^Ao(S,T,7),O=ke(S,T,1)^ke(S,T,8)^So(S,T,7),B=ce[g-2]|0,v=fe[g-2]|0,D=Se(B,v,19)^Dr(B,v,61)^Ao(B,v,6),M=ke(B,v,19)^Hr(B,v,61)^So(B,v,6),C=_a(O,M,fe[g-7],fe[g-16]),m=Ra(C,V,D,ce[g-7],ce[g-16]);ce[g]=m|0,fe[g]=C|0}let{Ah:n,Al:s,Bh:o,Bl:i,Ch:a,Cl:c,Dh:u,Dl:l,Eh:f,El:h,Fh:p,Fl:d,Gh:E,Gl:w,Hh:b,Hl:A}=this;for(let g=0;g<80;g++){let S=Se(f,h,14)^Se(f,h,18)^Dr(f,h,41),T=ke(f,h,14)^ke(f,h,18)^Hr(f,h,41),V=f&p^~f&E,O=h&d^~h&w,B=Da(A,T,O,Yl[g],fe[g]),v=Ha(B,b,S,V,Zl[g],ce[g]),D=B|0,M=Se(n,s,28)^Dr(n,s,34)^Dr(n,s,39),C=ke(n,s,28)^Hr(n,s,34)^Hr(n,s,39),m=n&o^n&a^o&a,x=s&i^s&c^i&c;b=E|0,A=w|0,E=p|0,w=d|0,p=f|0,d=h|0,{h:f,l:h}=Ht(u|0,l|0,v|0,D|0),u=a|0,l=c|0,a=o|0,c=i|0,o=n|0,i=s|0;let y=Ua(D,C,x);n=Ta(y,v,M,m),s=y|0}({h:n,l:s}=Ht(this.Ah|0,this.Al|0,n|0,s|0)),{h:o,l:i}=Ht(this.Bh|0,this.Bl|0,o|0,i|0),{h:a,l:c}=Ht(this.Ch|0,this.Cl|0,a|0,c|0),{h:u,l}=Ht(this.Dh|0,this.Dl|0,u|0,l|0),{h:f,l:h}=Ht(this.Eh|0,this.El|0,f|0,h|0),{h:p,l:d}=Ht(this.Fh|0,this.Fl|0,p|0,d|0),{h:E,l:w}=Ht(this.Gh|0,this.Gl|0,E|0,w|0),{h:b,l:A}=Ht(this.Hh|0,this.Hl|0,b|0,A|0),this.set(n,s,o,i,a,c,u,l,f,h,p,d,E,w,b,A)}roundClean(){jt(ce,fe)}destroy(){jt(this.buffer),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}},Lo=class extends Co{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 Ka=Eo(()=>new Io,Bo(1));var Oa=Eo(()=>new Lo,Bo(3));var Uo=BigInt(0),No=BigInt(1);function Wt(r,t=""){if(typeof r!="boolean"){let e=t&&`"${t}" `;throw new Error(e+"expected boolean, got type="+typeof r)}return r}function Ma(r){if(typeof r=="bigint"){if(!In(r))throw new Error("positive bigint expected, got "+r)}else Dt(r);return r}function Vr(r){let t=Ma(r).toString(16);return t.length&1?"0"+t:t}function Pa(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return r===""?Uo:BigInt("0x"+r)}function nr(r){return Pa(Gt(r))}function Ie(r){return Pa(Gt(Ln(P(r)).reverse()))}function Cn(r,t){Dt(t),r=Ma(r);let e=Zt(r.toString(16).padStart(t*2,"0"));if(e.length!==t)throw new Error("number too large");return e}function To(r,t){return Cn(r,t).reverse()}function Ln(r){return Uint8Array.from(r)}var In=r=>typeof r=="bigint"&&Uo<=r;function Wl(r,t,e){return In(r)&&In(t)&&In(e)&&t<=r&&r<e}function Kr(r,t,e,n){if(!Wl(t,e,n))throw new Error("expected valid "+r+": "+e+" <= n < "+n+", got "+t)}function _o(r){let t;for(t=0;r>Uo;r>>=No,t+=1);return t}var Or=r=>(No<<BigInt(r))-No;function Fa(r,t,e){if(Dt(r,"hashLen"),Dt(t,"qByteLen"),typeof e!="function")throw new Error("hmacFn must be a function");let n=w=>new Uint8Array(w),s=Uint8Array.of(),o=Uint8Array.of(0),i=Uint8Array.of(1),a=1e3,c=n(r),u=n(r),l=0,f=()=>{c.fill(1),u.fill(0),l=0},h=(...w)=>e(u,xt(c,...w)),p=(w=s)=>{u=h(o,w),c=h(),w.length!==0&&(u=h(i,w),c=h())},d=()=>{if(l++>=a)throw new Error("drbg: tried max amount of iterations");let w=0,b=[];for(;w<t;){c=h();let A=c.slice();b.push(A),w+=c.length}return xt(...b)};return(w,b)=>{f(),p(w);let A;for(;!(A=b(d()));)p();return f(),A}}function ue(r,t={},e={}){if(!r||typeof r!="object")throw new Error("expected valid options object");function n(o,i,a){let c=r[o];if(a&&c===void 0)return;let u=typeof c;if(u!==i||c===null)throw new Error(`param "${o}" is invalid: expected ${i}, got ${u}`)}let s=(o,i)=>Object.entries(o).forEach(([a,c])=>n(a,c,i));s(t,!1),s(e,!0)}function sr(r){let t=new WeakMap;return(e,...n)=>{let s=t.get(e);if(s!==void 0)return s;let o=r(e,...n);return t.set(e,o),o}}var gt=BigInt(0),rt=BigInt(1),Ce=BigInt(2),ja=BigInt(3),Ga=BigInt(4),Za=BigInt(5),zl=BigInt(7),Ya=BigInt(8),Jl=BigInt(9),Wa=BigInt(16);function X(r,t){let e=r%t;return e>=gt?e:t+e}function Z(r,t,e){let n=r;for(;t-- >gt;)n*=n,n%=e;return n}function qa(r,t){if(r===gt)throw new Error("invert: expected non-zero number");if(t<=gt)throw new Error("invert: expected positive modulus, got "+t);let e=X(r,t),n=t,s=gt,o=rt,i=rt,a=gt;for(;e!==gt;){let u=n/e,l=n%e,f=s-i*u,h=o-a*u;n=e,e=l,s=i,o=a,i=f,a=h}if(n!==rt)throw new Error("invert: does not exist");return X(s,t)}function Do(r,t,e){if(!r.eql(r.sqr(t),e))throw new Error("Cannot find square root")}function za(r,t){let e=(r.ORDER+rt)/Ga,n=r.pow(t,e);return Do(r,n,t),n}function Xl(r,t){let e=(r.ORDER-Za)/Ya,n=r.mul(t,Ce),s=r.pow(n,e),o=r.mul(t,s),i=r.mul(r.mul(o,Ce),s),a=r.mul(o,r.sub(i,r.ONE));return Do(r,a,t),a}function Ql(r){let t=or(r),e=Ja(r),n=e(t,t.neg(t.ONE)),s=e(t,n),o=e(t,t.neg(n)),i=(r+zl)/Wa;return(a,c)=>{let u=a.pow(c,i),l=a.mul(u,n),f=a.mul(u,s),h=a.mul(u,o),p=a.eql(a.sqr(l),c),d=a.eql(a.sqr(f),c);u=a.cmov(u,l,p),l=a.cmov(h,f,d);let E=a.eql(a.sqr(l),c),w=a.cmov(u,l,E);return Do(a,w,c),w}}function Ja(r){if(r<ja)throw new Error("sqrt is not defined for small field");let t=r-rt,e=0;for(;t%Ce===gt;)t/=Ce,e++;let n=Ce,s=or(r);for(;$a(s,n)===1;)if(n++>1e3)throw new Error("Cannot find square root: probably non-prime P");if(e===1)return za;let o=s.pow(n,t),i=(t+rt)/Ce;return function(c,u){if(c.is0(u))return u;if($a(c,u)!==1)throw new Error("Cannot find square root");let l=e,f=c.mul(c.ONE,o),h=c.pow(u,t),p=c.pow(u,i);for(;!c.eql(h,c.ONE);){if(c.is0(h))return c.ZERO;let d=1,E=c.sqr(h);for(;!c.eql(E,c.ONE);)if(d++,E=c.sqr(E),d===l)throw new Error("Cannot find square root");let w=rt<<BigInt(l-d-1),b=c.pow(f,w);l=d,f=c.sqr(b),h=c.mul(h,f),p=c.mul(p,b)}return p}}function th(r){return r%Ga===ja?za:r%Ya===Za?Xl:r%Wa===Jl?Ql(r):Ja(r)}var Xa=(r,t)=>(X(r,t)&rt)===rt,eh=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function Ho(r){let t={ORDER:"bigint",BYTES:"number",BITS:"number"},e=eh.reduce((n,s)=>(n[s]="function",n),t);return ue(r,e),r}function rh(r,t,e){if(e<gt)throw new Error("invalid exponent, negatives unsupported");if(e===gt)return r.ONE;if(e===rt)return t;let n=r.ONE,s=t;for(;e>gt;)e&rt&&(n=r.mul(n,s)),s=r.sqr(s),e>>=rt;return n}function Mr(r,t,e=!1){let n=new Array(t.length).fill(e?r.ZERO:void 0),s=t.reduce((i,a,c)=>r.is0(a)?i:(n[c]=i,r.mul(i,a)),r.ONE),o=r.inv(s);return t.reduceRight((i,a,c)=>r.is0(a)?i:(n[c]=r.mul(i,n[c]),r.mul(i,a)),o),n}function $a(r,t){let e=(r.ORDER-rt)/Ce,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 nh(r,t){t!==void 0&&Dt(t);let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}var Ro=class{ORDER;BITS;BYTES;isLE;ZERO=gt;ONE=rt;_lengths;_sqrt;_mod;constructor(t,e={}){if(t<=gt)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}=nh(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 gt<=t&&t<this.ORDER}is0(t){return t===gt}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 rh(this,t,e)}div(t,e){return X(t*qa(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 qa(t,this.ORDER)}sqrt(t){return this._sqrt||(this._sqrt=th(this.ORDER)),this._sqrt(this,t)}toBytes(t){return this.isLE?To(t,this.BYTES):Cn(t,this.BYTES)}fromBytes(t,e=!1){P(t);let{_lengths:n,BYTES:s,isLE:o,ORDER:i,_mod:a}=this;if(n){if(!n.includes(t.length)||t.length>s)throw new Error("Field.fromBytes: expected "+n+" bytes, got "+t.length);let u=new Uint8Array(s);u.set(t,o?0:u.length-t.length),t=u}if(t.length!==s)throw new Error("Field.fromBytes: expected "+s+" bytes, got "+t.length);let c=o?Ie(t):nr(t);if(a&&(c=X(c,i)),!e&&!this.isValid(c))throw new Error("invalid field element: outside of range 0..ORDER");return c}invertBatch(t){return Mr(this,t)}cmov(t,e,n){return n?e:t}};function or(r,t={}){return new Ro(r,t)}function Qa(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 Vo(r){let t=Qa(r);return t+Math.ceil(t/2)}function Ko(r,t,e=!1){P(r);let n=r.length,s=Qa(t),o=Vo(t);if(n<16||n<o||n>1024)throw new Error("expected "+o+"-1024 bytes of input, got "+n);let i=e?Ie(r):nr(r),a=X(i,t-rt)+rt;return e?To(a,s):Cn(a,s)}var ir=BigInt(0),Le=BigInt(1);function Pr(r,t){let e=t.negate();return r?e:t}function Ne(r,t){let e=Mr(r.Fp,t.map(n=>n.Z));return t.map((n,s)=>r.fromAffine(n.toAffine(e[s])))}function nc(r,t){if(!Number.isSafeInteger(r)||r<=0||r>t)throw new Error("invalid window size, expected [1.."+t+"], got W="+r)}function Oo(r,t){nc(r,t);let e=Math.ceil(t/r)+1,n=2**(r-1),s=2**r,o=Or(r),i=BigInt(r);return{windows:e,windowSize:n,mask:o,maxNumber:s,shiftBy:i}}function tc(r,t,e){let{windowSize:n,mask:s,maxNumber:o,shiftBy:i}=e,a=Number(r&s),c=r>>i;a>n&&(a-=o,c+=Le);let u=t*n,l=u+Math.abs(a)-1,f=a===0,h=a<0,p=t%2!==0;return{nextN:c,offset:l,isZero:f,isNeg:h,isNegF:p,offsetF:u}}var Mo=new WeakMap,sc=new WeakMap;function Po(r){return sc.get(r)||1}function ec(r){if(r!==ir)throw new Error("invalid wNAF")}var ar=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>ir;)e&Le&&(n=n.add(s)),s=s.double(),e>>=Le;return n}precomputeWindow(t,e){let{windows:n,windowSize:s}=Oo(e,this.bits),o=[],i=t,a=i;for(let c=0;c<n;c++){a=i,o.push(a);for(let u=1;u<s;u++)a=a.add(i),o.push(a);i=a.double()}return o}wNAF(t,e,n){if(!this.Fn.isValid(n))throw new Error("invalid scalar");let s=this.ZERO,o=this.BASE,i=Oo(t,this.bits);for(let a=0;a<i.windows;a++){let{nextN:c,offset:u,isZero:l,isNeg:f,isNegF:h,offsetF:p}=tc(n,a,i);n=c,l?o=o.add(Pr(h,e[p])):s=s.add(Pr(f,e[u]))}return ec(n),{p:s,f:o}}wNAFUnsafe(t,e,n,s=this.ZERO){let o=Oo(t,this.bits);for(let i=0;i<o.windows&&n!==ir;i++){let{nextN:a,offset:c,isZero:u,isNeg:l}=tc(n,i,o);if(n=a,!u){let f=e[c];s=s.add(l?f.negate():f)}}return ec(n),s}getPrecomputes(t,e,n){let s=Mo.get(e);return s||(s=this.precomputeWindow(e,t),t!==1&&(typeof n=="function"&&(s=n(s)),Mo.set(e,s))),s}cached(t,e,n){let s=Po(t);return this.wNAF(s,this.getPrecomputes(s,t,n),e)}unsafe(t,e,n,s){let o=Po(t);return o===1?this._unsafeLadder(t,e,s):this.wNAFUnsafe(o,this.getPrecomputes(o,t,n),e,s)}createCache(t,e){nc(e,this.bits),sc.set(t,e),Mo.delete(t)}hasCache(t){return Po(t)!==1}};function oc(r,t,e,n){let s=t,o=r.ZERO,i=r.ZERO;for(;e>ir||n>ir;)e&Le&&(o=o.add(s)),n&Le&&(i=i.add(s)),s=s.double(),e>>=Le,n>>=Le;return{p1:o,p2:i}}function rc(r,t,e){if(t){if(t.ORDER!==r)throw new Error("Field.ORDER must match order: Fp == p, Fn == n");return Ho(t),t}else return or(r,{isLE:e})}function Nn(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 c of["p","n","h"]){let u=t[c];if(!(typeof u=="bigint"&&u>ir))throw new Error(`CURVE.${c} must be positive bigint`)}let s=rc(t.p,e.Fp,n),o=rc(t.n,e.Fn,n),a=["Gx","Gy","a",r==="weierstrass"?"b":"d"];for(let c of a)if(!s.isValid(t[c]))throw new Error(`CURVE.${c} must be valid field element of CURVE.Fp`);return t=Object.freeze(Object.assign({},t)),{CURVE:t,Fp:s,Fn:o}}function Un(r,t){return function(n){let s=r(n);return{secretKey:s,publicKey:t(s)}}}var le=BigInt(0),nt=BigInt(1),Fo=BigInt(2),sh=BigInt(8);function oh(r,t,e,n){let s=r.sqr(e),o=r.sqr(n),i=r.add(r.mul(t.a,s),o),a=r.add(r.ONE,r.mul(t.d,r.mul(s,o)));return r.eql(i,a)}function ic(r,t={}){let e=Nn("edwards",r,t,t.FpFnLE),{Fp:n,Fn:s}=e,o=e.CURVE,{h:i}=o;ue(t,{},{uvRatio:"function"});let a=Fo<<BigInt(s.BYTES*8)-nt,c=w=>n.create(w),u=t.uvRatio||((w,b)=>{try{return{isValid:!0,value:n.sqrt(n.div(w,b))}}catch{return{isValid:!1,value:le}}});if(!oh(n,o,o.Gx,o.Gy))throw new Error("bad curve params: generator point");function l(w,b,A=!1){let g=A?nt:le;return Kr("coordinate "+w,b,g,a),b}function f(w){if(!(w instanceof d))throw new Error("EdwardsPoint expected")}let h=sr((w,b)=>{let{X:A,Y:g,Z:S}=w,T=w.is0();b==null&&(b=T?sh:n.inv(S));let V=c(A*b),O=c(g*b),B=n.mul(S,b);if(T)return{x:le,y:nt};if(B!==nt)throw new Error("invZ was invalid");return{x:V,y:O}}),p=sr(w=>{let{a:b,d:A}=o;if(w.is0())throw new Error("bad point: ZERO");let{X:g,Y:S,Z:T,T:V}=w,O=c(g*g),B=c(S*S),v=c(T*T),D=c(v*v),M=c(O*b),C=c(v*c(M+B)),m=c(D+c(A*c(O*B)));if(C!==m)throw new Error("bad point: equation left != right (1)");let x=c(g*S),y=c(T*V);if(x!==y)throw new Error("bad point: equation left != right (2)");return!0});class d{static BASE=new d(o.Gx,o.Gy,nt,c(o.Gx*o.Gy));static ZERO=new d(le,nt,nt,le);static Fp=n;static Fn=s;X;Y;Z;T;constructor(b,A,g,S){this.X=l("x",b),this.Y=l("y",A),this.Z=l("z",g,!0),this.T=l("t",S),Object.freeze(this)}static CURVE(){return o}static fromAffine(b){if(b instanceof d)throw new Error("extended point not allowed");let{x:A,y:g}=b||{};return l("x",A),l("y",g),new d(A,g,nt,c(A*g))}static fromBytes(b,A=!1){let g=n.BYTES,{a:S,d:T}=o;b=Ln(P(b,g,"point")),Wt(A,"zip215");let V=Ln(b),O=b[g-1];V[g-1]=O&-129;let B=Ie(V),v=A?a:n.ORDER;Kr("point.y",B,le,v);let D=c(B*B),M=c(D-nt),C=c(T*D-S),{isValid:m,value:x}=u(M,C);if(!m)throw new Error("bad point: invalid y coordinate");let y=(x&nt)===nt,k=(O&128)!==0;if(!A&&x===le&&k)throw new Error("bad point: x=0 and x_0=1");return k!==y&&(x=c(-x)),d.fromAffine({x,y:B})}static fromHex(b,A=!1){return d.fromBytes(Zt(b),A)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}precompute(b=8,A=!0){return E.createCache(this,b),A||this.multiply(Fo),this}assertValidity(){p(this)}equals(b){f(b);let{X:A,Y:g,Z:S}=this,{X:T,Y:V,Z:O}=b,B=c(A*O),v=c(T*S),D=c(g*O),M=c(V*S);return B===v&&D===M}is0(){return this.equals(d.ZERO)}negate(){return new d(c(-this.X),this.Y,this.Z,c(-this.T))}double(){let{a:b}=o,{X:A,Y:g,Z:S}=this,T=c(A*A),V=c(g*g),O=c(Fo*c(S*S)),B=c(b*T),v=A+g,D=c(c(v*v)-T-V),M=B+V,C=M-O,m=B-V,x=c(D*C),y=c(M*m),k=c(D*m),L=c(C*M);return new d(x,y,L,k)}add(b){f(b);let{a:A,d:g}=o,{X:S,Y:T,Z:V,T:O}=this,{X:B,Y:v,Z:D,T:M}=b,C=c(S*B),m=c(T*v),x=c(O*g*M),y=c(V*D),k=c((S+T)*(B+v)-C-m),L=y-x,U=y+x,_=c(m-A*C),N=c(k*L),H=c(U*_),K=c(k*_),Y=c(L*U);return new d(N,H,Y,K)}subtract(b){return this.add(b.negate())}multiply(b){if(!s.isValidNot0(b))throw new Error("invalid scalar: expected 1 <= sc < curve.n");let{p:A,f:g}=E.cached(this,b,S=>Ne(d,S));return Ne(d,[A,g])[0]}multiplyUnsafe(b,A=d.ZERO){if(!s.isValid(b))throw new Error("invalid scalar: expected 0 <= sc < curve.n");return b===le?d.ZERO:this.is0()||b===nt?this:E.unsafe(this,b,g=>Ne(d,g),A)}isSmallOrder(){return this.multiplyUnsafe(i).is0()}isTorsionFree(){return E.unsafe(this,o.n).is0()}toAffine(b){return h(this,b)}clearCofactor(){return i===nt?this:this.multiplyUnsafe(i)}toBytes(){let{x:b,y:A}=this.toAffine(),g=n.toBytes(A);return g[g.length-1]|=b&nt?128:0,g}toHex(){return Gt(this.toBytes())}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}}let E=new ar(d,s.BITS);return d.BASE.precompute(8),d}function ac(r,t,e={}){if(typeof t!="function")throw new Error('"hash" function param is required');ue(e,{},{adjustScalarBytes:"function",randomBytes:"function",domain:"function",prehash:"function",mapToCurve:"function"});let{prehash:n}=e,{BASE:s,Fp:o,Fn:i}=r,a=e.randomBytes||rr,c=e.adjustScalarBytes||(B=>B),u=e.domain||((B,v,D)=>{if(Wt(D,"phflag"),v.length||D)throw new Error("Contexts/pre-hash are not supported");return B});function l(B){return i.create(Ie(B))}function f(B){let v=g.secretKey;P(B,g.secretKey,"secretKey");let D=P(t(B),2*v,"hashedSecretKey"),M=c(D.slice(0,v)),C=D.slice(v,2*v),m=l(M);return{head:M,prefix:C,scalar:m}}function h(B){let{head:v,prefix:D,scalar:M}=f(B),C=s.multiply(M),m=C.toBytes();return{head:v,prefix:D,scalar:M,point:C,pointBytes:m}}function p(B){return h(B).pointBytes}function d(B=Uint8Array.of(),...v){let D=xt(...v);return l(t(u(D,P(B,void 0,"context"),!!n)))}function E(B,v,D={}){B=P(B,void 0,"message"),n&&(B=n(B));let{prefix:M,scalar:C,pointBytes:m}=h(v),x=d(D.context,M,B),y=s.multiply(x).toBytes(),k=d(D.context,y,m,B),L=i.create(x+k*C);if(!i.isValid(L))throw new Error("sign failed: invalid s");let U=xt(y,i.toBytes(L));return P(U,g.signature,"result")}let w={zip215:!0};function b(B,v,D,M=w){let{context:C,zip215:m}=M,x=g.signature;B=P(B,x,"signature"),v=P(v,void 0,"message"),D=P(D,g.publicKey,"publicKey"),m!==void 0&&Wt(m,"zip215"),n&&(v=n(v));let y=x/2,k=B.subarray(0,y),L=Ie(B.subarray(y,x)),U,_,N;try{U=r.fromBytes(D,m),_=r.fromBytes(k,m),N=s.multiplyUnsafe(L)}catch{return!1}if(!m&&U.isSmallOrder())return!1;let H=d(C,_.toBytes(),U.toBytes(),v);return _.add(U.multiplyUnsafe(H)).subtract(N).clearCofactor().is0()}let A=o.BYTES,g={secretKey:A,publicKey:A,signature:2*A,seed:A};function S(B=a(g.seed)){return P(B,g.seed,"seed")}function T(B){return Ae(B)&&B.length===i.BYTES}function V(B,v){try{return!!r.fromBytes(B,v)}catch{return!1}}let O={getExtendedPublicKey:h,randomSecretKey:S,isValidSecretKey:T,isValidPublicKey:V,toMontgomery(B){let{y:v}=r.fromBytes(B),D=g.publicKey,M=D===32;if(!M&&D!==57)throw new Error("only defined for 25519 and 448");let C=M?o.div(nt+v,nt-v):o.div(v-nt,v+nt);return o.toBytes(C)},toMontgomerySecret(B){let v=g.secretKey;P(B,v);let D=t(B.subarray(0,v));return c(D).subarray(0,v)}};return Object.freeze({keygen:Un(S,p),getPublicKey:p,sign:E,verify:b,utils:O,Point:r,lengths:g})}var ih=BigInt(1),cc=BigInt(2);var ah=BigInt(5),ch=BigInt(8),qo=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffed"),fh={p:qo,n:BigInt("0x1000000000000000000000000000000014def9dea2f79cd65812631a5cf5d3ed"),h:ch,a:BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffec"),d:BigInt("0x52036cee2b6ffe738cc740797779e89800700a4d4141d8ab75eb4dca135978a3"),Gx:BigInt("0x216936d3cd6e53fec0a4e231fdd6dc5c692cc7609525a7b2c9562d608f25d51a"),Gy:BigInt("0x6666666666666666666666666666666666666666666666666666666666666658")};function uh(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),s=BigInt(80),o=qo,a=r*r%o*r%o,c=Z(a,cc,o)*a%o,u=Z(c,ih,o)*r%o,l=Z(u,ah,o)*u%o,f=Z(l,t,o)*l%o,h=Z(f,e,o)*f%o,p=Z(h,n,o)*h%o,d=Z(p,s,o)*p%o,E=Z(d,s,o)*p%o,w=Z(E,t,o)*l%o;return{pow_p_5_8:Z(w,cc,o)*r%o,b2:a}}function lh(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}var fc=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752");function hh(r,t){let e=qo,n=X(t*t*t,e),s=X(n*n*t,e),o=uh(r*s).pow_p_5_8,i=X(r*n*o,e),a=X(t*i*i,e),c=i,u=X(i*fc,e),l=a===r,f=a===X(-r,e),h=a===X(-r*fc,e);return l&&(i=c),(f||h)&&(i=u),Xa(i,e)&&(i=X(-i,e)),{isValid:l||f,value:i}}var dh=ic(fh,{uvRatio:hh});function ph(r){return ac(dh,Oa,Object.assign({adjustScalarBytes:lh},r))}var $o=ph({});var fr=32,kt=64,gh=32;var cr,uc=(async()=>{try{return await tt.get().subtle.generateKey({name:"Ed25519"},!0,["sign","verify"]),!0}catch{return!1}})();async function bh(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 tt.get().subtle.importKey("jwk",n,{name:"Ed25519"},!0,["sign"]),o=await tt.get().subtle.sign({name:"Ed25519"},s,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(o,0,o.byteLength)}function yh(r,t){let e=r.subarray(0,gh);return $o.sign(t instanceof Uint8Array?t:t.subarray(),e)}async function lc(r,t){return cr==null&&(cr=await uc),cr?bh(r,t):yh(r,t)}async function mh(r,t,e){if(r.buffer instanceof ArrayBuffer){let n=await tt.get().subtle.importKey("raw",r.buffer,{name:"Ed25519"},!1,["verify"]);return await tt.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 xh(r,t,e){return $o.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}async function hc(r,t,e){return cr==null&&(cr=await uc),cr?mh(r,t,e):xh(r,t,e)}function ur(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}var Tn=class{type="Ed25519";raw;constructor(t){this.raw=qr(t,fr)}toMultihash(){return Ee.digest(tr(this))}toCID(){return St.createV1(114,this.toMultihash())}toString(){return et.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=hc(this.raw,e,t);return ur(s)?s.then(o=>(n?.signal?.throwIfAborted(),o)):s}},Fr=class{type="Ed25519";raw;publicKey;constructor(t,e){this.raw=qr(t,kt),this.publicKey=new Tn(e)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:mt(this.raw,t.raw)}sign(t,e){e?.signal?.throwIfAborted();let n=lc(this.raw,t);return ur(n)?n.then(s=>(e?.signal?.throwIfAborted(),s)):(e?.signal?.throwIfAborted(),n)}};function jo(r){if(r.length>kt){r=qr(r,kt+fr);let n=r.subarray(0,kt),s=r.subarray(kt,r.length);return new Fr(n,s)}r=qr(r,kt);let t=r.subarray(0,kt),e=r.subarray(fr);return new Fr(t,e)}function qr(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 wh=Math.pow(2,7),vh=Math.pow(2,14),Eh=Math.pow(2,21),pc=Math.pow(2,28),gc=Math.pow(2,35),bc=Math.pow(2,42),yc=Math.pow(2,49),bt=128,he=127;function $r(r){if(r<wh)return 1;if(r<vh)return 2;if(r<Eh)return 3;if(r<pc)return 4;if(r<gc)return 5;if(r<bc)return 6;if(r<yc)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function mc(r,t,e=0){switch($r(r)){case 8:t[e++]=r&255|bt,r/=128;case 7:t[e++]=r&255|bt,r/=128;case 6:t[e++]=r&255|bt,r/=128;case 5:t[e++]=r&255|bt,r/=128;case 4:t[e++]=r&255|bt,r>>>=7;case 3:t[e++]=r&255|bt,r>>>=7;case 2:t[e++]=r&255|bt,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function xc(r,t){let e=r[t],n=0;if(n+=e&he,e<bt||(e=r[t+1],n+=(e&he)<<7,e<bt)||(e=r[t+2],n+=(e&he)<<14,e<bt)||(e=r[t+3],n+=(e&he)<<21,e<bt)||(e=r[t+4],n+=(e&he)*pc,e<bt)||(e=r[t+5],n+=(e&he)*gc,e<bt)||(e=r[t+6],n+=(e&he)*bc,e<bt)||(e=r[t+7],n+=(e&he)*yc,e<bt))return n;throw new RangeError("Could not decode varint")}var Go=new Float32Array([-0]),de=new Uint8Array(Go.buffer);function wc(r,t,e){Go[0]=r,t[e]=de[0],t[e+1]=de[1],t[e+2]=de[2],t[e+3]=de[3]}function vc(r,t){return de[0]=r[t],de[1]=r[t+1],de[2]=r[t+2],de[3]=r[t+3],Go[0]}var Zo=new Float64Array([-0]),ut=new Uint8Array(Zo.buffer);function Ec(r,t,e){Zo[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 Bc(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],Zo[0]}var Bh=BigInt(Number.MAX_SAFE_INTEGER),Ah=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 Ue;if(t<Bh&&t>Ah)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>Ac&&(s=0n,++n>Ac&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(t){if(t===0)return Ue;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):Ue}},Ue=new At(0,0);Ue.toBigInt=function(){return 0n};Ue.zzEncode=Ue.zzDecode=function(){return this};Ue.length=function(){return 1};var Ac=4294967296n;function Sc(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 kc(r,t,e){if(e-t<1)return"";let s,o=[],i=0,a;for(;t<e;)a=r[t++],a<128?o[i++]=a:a>191&&a<224?o[i++]=(a&31)<<6|r[t++]&63:a>239&&a<365?(a=((a&7)<<18|(r[t++]&63)<<12|(r[t++]&63)<<6|r[t++]&63)-65536,o[i++]=55296+(a>>10),o[i++]=56320+(a&1023)):o[i++]=(a&15)<<12|(r[t++]&63)<<6|r[t++]&63,i>8191&&((s??(s=[])).push(String.fromCharCode.apply(String,o)),i=0);return s!=null?(i>0&&s.push(String.fromCharCode.apply(String,o.slice(0,i))),s.join("")):String.fromCharCode.apply(String,o.slice(0,i))}function Yo(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 Ut(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function _n(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var Wo=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,Ut(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 Ut(this,4);return _n(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Ut(this,4);return _n(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Ut(this,4);let t=vc(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Ut(this,4);let t=Bc(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 Ut(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return kc(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw Ut(this,t);this.pos+=t}else do if(this.pos>=this.len)throw Ut(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 Ut(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 Ut(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 Ut(this,8);let t=_n(this.buf,this.pos+=4),e=_n(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=xc(this.buf,this.pos);return this.pos+=$r(t),t}uint64String(){return this.readLongVarint().toString(!0)}sint64(){return this.readLongVarint().zzDecode().toBigInt()}sint64Number(){return this.readLongVarint().zzDecode().toNumber()}sint64String(){return this.readLongVarint().zzDecode().toString()}fixed64(){return this.readFixed64().toBigInt()}fixed64Number(){return this.readFixed64().toNumber()}fixed64String(){return this.readFixed64().toString()}sfixed64(){return this.readFixed64().toBigInt()}sfixed64Number(){return this.readFixed64().toNumber()}sfixed64String(){return this.readFixed64().toString()}};function jr(r){return new Wo(r instanceof Uint8Array?r:r.subarray())}function Rn(r,t,e){let n=jr(r);return t.decode(n,void 0,e)}function zo(r){let t=r??8192,e=t>>>1,n,s=t;return function(i){if(i<1||i>e)return Bt(i);s+i>t&&(n=Bt(t),s=0);let a=n.subarray(s,s+=i);return(s&7)!==0&&(s=(s|7)+1),a}}var Te=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function Jo(){}var Qo=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},Sh=zo();function kh(r){return globalThis.Buffer!=null?Bt(r):Sh(r)}var Zr=class{len;head;tail;states;constructor(){this.len=0,this.head=new Te(Jo,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new Te(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new ti((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(Dn,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(Dn,e.length(),e)}uint64Number(t){return this._push(mc,$r(t),t)}uint64String(t){return this.uint64(BigInt(t))}int64(t){return this.uint64(t)}int64Number(t){return this.uint64Number(t)}int64String(t){return this.uint64String(t)}sint64(t){let e=At.fromBigInt(t).zzEncode();return this._push(Dn,e.length(),e)}sint64Number(t){let e=At.fromNumber(t).zzEncode();return this._push(Dn,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(Xo,1,t?1:0)}fixed32(t){return this._push(Gr,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=At.fromBigInt(t);return this._push(Gr,4,e.lo)._push(Gr,4,e.hi)}fixed64Number(t){let e=At.fromNumber(t);return this._push(Gr,4,e.lo)._push(Gr,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(wc,4,t)}double(t){return this._push(Ec,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(Xo,1,0):this.uint32(e)._push(Ch,e,t)}string(t){let e=Sc(t);return e!==0?this.uint32(e)._push(Yo,e,t):this._push(Xo,1,0)}fork(){return this.states=new Qo(this),this.head=this.tail=new Te(Jo,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 Te(Jo,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=kh(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function Xo(r,t,e){t[e]=r&255}function Ih(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var ti=class extends Te{next;constructor(t,e){super(Ih,t,e),this.next=void 0}};function Dn(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 Gr(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 Ch(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(Zr.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(Lh,t,r),this},Zr.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(Nh,t,r),this});function Lh(r,t,e){t.set(r,e)}function Nh(r,t,e){r.length<40?Yo(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(F(r),e)}function ei(){return new Zr}function Hn(r,t){let e=ei();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}function*Vn(r,t,e){let n=jr(r);yield*t.stream(n,void 0,"$",e)}var Kn={VARINT:0,BIT64:1,LENGTH_DELIMITED:2,START_GROUP:3,END_GROUP:4,BIT32:5};function On(r,t,e,n,s){return{name:r,type:t,encode:e,decode:n,stream:s}}function ri(r){function t(o){if(r[o.toString()]==null)throw new Error("Invalid enum value");return r[o]}let e=function(i,a){let c=t(i);a.int32(c)},n=function(i){let a=i.int32();return t(a)},s=function*(i){let a=i.int32();yield t(a)};return On("enum",Kn.VARINT,e,n,s)}function Mn(r,t,e){return On("message",Kn.LENGTH_DELIMITED,r,t,e)}var Q;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.secp256k1="secp256k1",r.ECDSA="ECDSA"})(Q||(Q={}));var ni;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1",r[r.ECDSA=3]="ECDSA"})(ni||(ni={}));(function(r){r.codec=()=>ri(ni)})(Q||(Q={}));var pe;(function(r){let t;r.codec=()=>(t==null&&(t=Mn((o,i,a={})=>{a.lengthDelimited!==!1&&i.fork(),o.Type!=null&&(i.uint32(8),Q.codec().encode(o.Type,i)),o.Data!=null&&(i.uint32(18),i.bytes(o.Data)),a.lengthDelimited!==!1&&i.ldelim()},(o,i,a={})=>{let c={},u=i==null?o.len:o.pos+i;for(;o.pos<u;){let l=o.uint32();switch(l>>>3){case 1:{c.Type=Q.codec().decode(o);break}case 2:{c.Data=o.bytes();break}default:{o.skipType(l&7);break}}}return c},function*(o,i,a,c={}){let u=i==null?o.len:o.pos+i;for(;o.pos<u;){let l=o.uint32();switch(l>>>3){case 1:{yield{field:`${a}.Type`,value:Q.codec().decode(o)};break}case 2:{yield{field:`${a}.Data`,value:o.bytes()};break}default:{o.skipType(l&7);break}}}})),t);function e(o){return Hn(o,r.codec())}r.encode=e;function n(o,i){return Rn(o,r.codec(),i)}r.decode=n;function s(o,i){return Vn(o,r.codec(),i)}r.stream=s})(pe||(pe={}));var Yr;(function(r){let t;r.codec=()=>(t==null&&(t=Mn((o,i,a={})=>{a.lengthDelimited!==!1&&i.fork(),o.Type!=null&&(i.uint32(8),Q.codec().encode(o.Type,i)),o.Data!=null&&(i.uint32(18),i.bytes(o.Data)),a.lengthDelimited!==!1&&i.ldelim()},(o,i,a={})=>{let c={},u=i==null?o.len:o.pos+i;for(;o.pos<u;){let l=o.uint32();switch(l>>>3){case 1:{c.Type=Q.codec().decode(o);break}case 2:{c.Data=o.bytes();break}default:{o.skipType(l&7);break}}}return c},function*(o,i,a,c={}){let u=i==null?o.len:o.pos+i;for(;o.pos<u;){let l=o.uint32();switch(l>>>3){case 1:{yield{field:`${a}.Type`,value:Q.codec().decode(o)};break}case 2:{yield{field:`${a}.Data`,value:o.bytes()};break}default:{o.skipType(l&7);break}}}})),t);function e(o){return Hn(o,r.codec())}r.encode=e;function n(o,i){return Rn(o,r.codec(),i)}r.decode=n;function s(o,i){return Vn(o,r.codec(),i)}r.stream=s})(Yr||(Yr={}));function Uh(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"&&"BYTES_PER_ELEMENT"in r&&r.BYTES_PER_ELEMENT===1}function _e(r,t=""){if(typeof r!="number"){let e=t&&`"${t}" `;throw new TypeError(`${e}expected number, got ${typeof r}`)}if(!Number.isSafeInteger(r)||r<0){let e=t&&`"${t}" `;throw new RangeError(`${e}expected integer >= 0, got ${r}`)}}function lr(r,t,e=""){let n=Uh(r),s=r?.length,o=t!==void 0;if(!n||o&&s!==t){let i=e&&`"${e}" `,a=o?` of length ${t}`:"",c=n?`length=${s}`:`type=${typeof r}`,u=i+"expected Uint8Array"+a+", got "+c;throw n?new RangeError(u):new TypeError(u)}return r}function Pn(r){if(typeof r!="function"||typeof r.create!="function")throw new TypeError("Hash must wrapped by utils.createHasher");if(_e(r.outputLen),_e(r.blockLen),r.outputLen<1)throw new Error('"outputLen" must be >= 1');if(r.blockLen<1)throw new Error('"blockLen" must be >= 1')}function hr(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 Fn(r,t){lr(r,void 0,"digestInto() output");let e=t.outputLen;if(r.length<e)throw new RangeError('"digestInto() output" expected to be of length >='+e)}function wt(...r){for(let t=0;t<r.length;t++)r[t].fill(0)}function Re(r){return new DataView(r.buffer,r.byteOffset,r.byteLength)}function Tt(r,t){return r<<32-t|r>>>t}function qn(r,t){return r<<t|r>>>32-t>>>0}var Th=async()=>{};async function Lc(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 Th(),n+=o)}}function _h(r){if(typeof r!="string")throw new TypeError("string expected");return new Uint8Array(new TextEncoder().encode(r))}function si(r,t=""){return typeof r=="string"?_h(r):lr(r,void 0,t)}function Nc(r,t){if(t!==void 0&&{}.toString.call(t)!=="[object Object]")throw new TypeError("options must be object or undefined");return Object.assign(r,t)}function Wr(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.canXOF=n.canXOF,e.create=s=>r(s),Object.assign(e,t),Object.freeze(e)}function Uc(r=32){_e(r,"bytesLength");let t=typeof globalThis=="object"?globalThis.crypto:null;if(typeof t?.getRandomValues!="function")throw new Error("crypto.getRandomValues must be defined");if(r>65536)throw new RangeError(`"bytesLength" expected <= 65536, got ${r}`);return t.getRandomValues(new Uint8Array(r))}var oi=r=>({oid:Uint8Array.from([6,9,96,134,72,1,101,3,4,2,r])});function De(r){if(isNaN(r)||r<=0)throw new R("random bytes length must be a Number bigger than 0");return Uc(r)}var Qr={};ht(Qr,{MAX_RSA_KEY_SIZE:()=>hi,generateRSAKeyPair:()=>$c,jwkToJWKKeyPair:()=>jc,jwkToPkcs1:()=>Fh,jwkToPkix:()=>bi,jwkToRSAPrivateKey:()=>xi,pkcs1MessageToJwk:()=>pi,pkcs1MessageToRSAPrivateKey:()=>Zn,pkcs1ToJwk:()=>Ph,pkcs1ToRSAPrivateKey:()=>yi,pkixMessageToJwk:()=>gi,pkixMessageToRSAPublicKey:()=>mi,pkixToJwk:()=>qh,pkixToRSAPublicKey:()=>qc});function $n(r,t,e){return r&t^~r&e}function jn(r,t,e){return r&t^r&e^t&e}var He=class{blockLen;outputLen;canXOF=!1;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=Re(this.buffer)}update(t){hr(this),lr(t);let{view:e,buffer:n,blockLen:s}=this,o=t.length;for(let i=0;i<o;){let a=Math.min(s-this.pos,o-i);if(a===s){let c=Re(t);for(;s<=o-i;i+=s)this.process(c,i);continue}n.set(t.subarray(i,i+a),this.pos),this.pos+=a,i+=a,this.pos===s&&(this.process(e,0),this.pos=0)}return this.length+=t.length,this.roundClean(),this}digestInto(t){hr(this),Fn(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 f=i;f<s;f++)e[f]=0;n.setBigUint64(s-8,BigInt(this.length*8),o),this.process(n,0);let a=Re(t),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen must be aligned to 32bit");let u=c/4,l=this.get();if(u>l.length)throw new Error("_sha2: outputLen bigger than state");for(let f=0;f<u;f++)a.setUint32(4*f,l[f],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:a}=this;return t.destroyed=i,t.finished=o,t.length=s,t.pos=a,s%e&&t.buffer.set(n),t}clone(){return this._cloneInto()}},zt=Uint32Array.from([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]);var it=Uint32Array.from([1779033703,4089235720,3144134277,2227873595,1013904242,4271175723,2773480762,1595750129,1359893119,2917565137,2600822924,725511199,528734635,4215389547,1541459225,327033209]);var Gn=BigInt(4294967295),Tc=BigInt(32);function Rh(r,t=!1){return t?{h:Number(r&Gn),l:Number(r>>Tc&Gn)}:{h:Number(r>>Tc&Gn)|0,l:Number(r&Gn)|0}}function _c(r,t=!1){let e=r.length,n=new Uint32Array(e),s=new Uint32Array(e);for(let o=0;o<e;o++){let{h:i,l:a}=Rh(r[o],t);[n[o],s[o]]=[i,a]}return[n,s]}var ii=(r,t,e)=>r>>>e,ai=(r,t,e)=>r<<32-e|t>>>e,Ve=(r,t,e)=>r>>>e|t<<32-e,Ke=(r,t,e)=>r<<32-e|t>>>e,zr=(r,t,e)=>r<<64-e|t>>>e-32,Jr=(r,t,e)=>r>>>e-32|t<<64-e;function Vt(r,t,e,n){let s=(t>>>0)+(n>>>0);return{h:r+e+(s/2**32|0)|0,l:s|0}}var Rc=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),Dc=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,Hc=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),Vc=(r,t,e,n,s)=>t+e+n+s+(r/2**32|0)|0,Kc=(r,t,e,n,s)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(s>>>0),Oc=(r,t,e,n,s,o)=>t+e+n+s+o+(r/2**32|0)|0;var Hh=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]),ge=new Uint32Array(64),ci=class extends He{constructor(t){super(64,t,8,!1)}get(){let{A:t,B:e,C:n,D:s,E:o,F:i,G:a,H:c}=this;return[t,e,n,s,o,i,a,c]}set(t,e,n,s,o,i,a,c){this.A=t|0,this.B=e|0,this.C=n|0,this.D=s|0,this.E=o|0,this.F=i|0,this.G=a|0,this.H=c|0}process(t,e){for(let f=0;f<16;f++,e+=4)ge[f]=t.getUint32(e,!1);for(let f=16;f<64;f++){let h=ge[f-15],p=ge[f-2],d=Tt(h,7)^Tt(h,18)^h>>>3,E=Tt(p,17)^Tt(p,19)^p>>>10;ge[f]=E+ge[f-7]+d+ge[f-16]|0}let{A:n,B:s,C:o,D:i,E:a,F:c,G:u,H:l}=this;for(let f=0;f<64;f++){let h=Tt(a,6)^Tt(a,11)^Tt(a,25),p=l+h+$n(a,c,u)+Hh[f]+ge[f]|0,E=(Tt(n,2)^Tt(n,13)^Tt(n,22))+jn(n,s,o)|0;l=u,u=c,c=a,a=i+p|0,i=o,o=s,s=n,n=p+E|0}n=n+this.A|0,s=s+this.B|0,o=o+this.C|0,i=i+this.D|0,a=a+this.E|0,c=c+this.F|0,u=u+this.G|0,l=l+this.H|0,this.set(n,s,o,i,a,c,u,l)}roundClean(){wt(ge)}destroy(){this.destroyed=!0,this.set(0,0,0,0,0,0,0,0),wt(this.buffer)}},fi=class extends ci{A=zt[0]|0;B=zt[1]|0;C=zt[2]|0;D=zt[3]|0;E=zt[4]|0;F=zt[5]|0;G=zt[6]|0;H=zt[7]|0;constructor(){super(32)}};var Mc=_c(["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))),Vh=Mc[0],Kh=Mc[1],be=new Uint32Array(80),ye=new Uint32Array(80),ui=class extends He{constructor(t){super(128,t,16,!1)}get(){let{Ah:t,Al:e,Bh:n,Bl:s,Ch:o,Cl:i,Dh:a,Dl:c,Eh:u,El:l,Fh:f,Fl:h,Gh:p,Gl:d,Hh:E,Hl:w}=this;return[t,e,n,s,o,i,a,c,u,l,f,h,p,d,E,w]}set(t,e,n,s,o,i,a,c,u,l,f,h,p,d,E,w){this.Ah=t|0,this.Al=e|0,this.Bh=n|0,this.Bl=s|0,this.Ch=o|0,this.Cl=i|0,this.Dh=a|0,this.Dl=c|0,this.Eh=u|0,this.El=l|0,this.Fh=f|0,this.Fl=h|0,this.Gh=p|0,this.Gl=d|0,this.Hh=E|0,this.Hl=w|0}process(t,e){for(let g=0;g<16;g++,e+=4)be[g]=t.getUint32(e),ye[g]=t.getUint32(e+=4);for(let g=16;g<80;g++){let S=be[g-15]|0,T=ye[g-15]|0,V=Ve(S,T,1)^Ve(S,T,8)^ii(S,T,7),O=Ke(S,T,1)^Ke(S,T,8)^ai(S,T,7),B=be[g-2]|0,v=ye[g-2]|0,D=Ve(B,v,19)^zr(B,v,61)^ii(B,v,6),M=Ke(B,v,19)^Jr(B,v,61)^ai(B,v,6),C=Hc(O,M,ye[g-7],ye[g-16]),m=Vc(C,V,D,be[g-7],be[g-16]);be[g]=m|0,ye[g]=C|0}let{Ah:n,Al:s,Bh:o,Bl:i,Ch:a,Cl:c,Dh:u,Dl:l,Eh:f,El:h,Fh:p,Fl:d,Gh:E,Gl:w,Hh:b,Hl:A}=this;for(let g=0;g<80;g++){let S=Ve(f,h,14)^Ve(f,h,18)^zr(f,h,41),T=Ke(f,h,14)^Ke(f,h,18)^Jr(f,h,41),V=f&p^~f&E,O=h&d^~h&w,B=Kc(A,T,O,Kh[g],ye[g]),v=Oc(B,b,S,V,Vh[g],be[g]),D=B|0,M=Ve(n,s,28)^zr(n,s,34)^zr(n,s,39),C=Ke(n,s,28)^Jr(n,s,34)^Jr(n,s,39),m=n&o^n&a^o&a,x=s&i^s&c^i&c;b=E|0,A=w|0,E=p|0,w=d|0,p=f|0,d=h|0,{h:f,l:h}=Vt(u|0,l|0,v|0,D|0),u=a|0,l=c|0,a=o|0,c=i|0,o=n|0,i=s|0;let y=Rc(D,C,x);n=Dc(y,v,M,m),s=y|0}({h:n,l:s}=Vt(this.Ah|0,this.Al|0,n|0,s|0)),{h:o,l:i}=Vt(this.Bh|0,this.Bl|0,o|0,i|0),{h:a,l:c}=Vt(this.Ch|0,this.Cl|0,a|0,c|0),{h:u,l}=Vt(this.Dh|0,this.Dl|0,u|0,l|0),{h:f,l:h}=Vt(this.Eh|0,this.El|0,f|0,h|0),{h:p,l:d}=Vt(this.Fh|0,this.Fl|0,p|0,d|0),{h:E,l:w}=Vt(this.Gh|0,this.Gl|0,E|0,w|0),{h:b,l:A}=Vt(this.Hh|0,this.Hl|0,b|0,A|0),this.set(n,s,o,i,a,c,u,l,f,h,p,d,E,w,b,A)}roundClean(){wt(be,ye)}destroy(){this.destroyed=!0,wt(this.buffer),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}},li=class extends ui{Ah=it[0]|0;Al=it[1]|0;Bh=it[2]|0;Bl=it[3]|0;Ch=it[4]|0;Cl=it[5]|0;Dh=it[6]|0;Dl=it[7]|0;Eh=it[8]|0;El=it[9]|0;Fh=it[10]|0;Fl=it[11]|0;Gh=it[12]|0;Gl=it[13]|0;Hh=it[14]|0;Hl=it[15]|0;constructor(){super(64)}};var dr=Wr(()=>new fi,oi(1));var pr=Wr(()=>new li,oi(3));var gr=class{type="RSA";jwk;_raw;_multihash;constructor(t,e){this.jwk=t,this._multihash=e}get raw(){return this._raw==null&&(this._raw=Qr.jwkToPkix(this.jwk)),this._raw}toMultihash(){return this._multihash}toCID(){return St.createV1(114,this._multihash)}toString(){return et.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 Fc(this.jwk,e,t,n)}},Xr=class{type="RSA";jwk;_raw;publicKey;constructor(t,e){this.jwk=t,this.publicKey=e}get raw(){return this._raw==null&&(this._raw=Qr.jwkToPkcs1(this.jwk)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:mt(this.raw,t.raw)}sign(t,e){return Pc(this.jwk,t,e)}};var hi=8192,di=18,Oh=1062,Mh=Uint8Array.from([48,13,6,9,42,134,72,134,247,13,1,1,1,5,0]);function Ph(r){let t=Ct(r);return pi(t)}function pi(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 Fh(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 Lt([pt(Uint8Array.from([0])),pt(F(r.n,"base64url")),pt(F(r.e,"base64url")),pt(F(r.d,"base64url")),pt(F(r.p,"base64url")),pt(F(r.q,"base64url")),pt(F(r.dp,"base64url")),pt(F(r.dq,"base64url")),pt(F(r.qi,"base64url"))]).subarray()}function qh(r){let t=Ct(r,{offset:0});return gi(t)}function gi(r){let t=Ct(r[1],{offset:0});return{kty:"RSA",n:$(t[0],"base64url"),e:$(t[1],"base64url")}}function bi(r){if(r.n==null||r.e==null)throw new R("JWK was missing components");return Lt([Mh,_r(Lt([pt(F(r.n,"base64url")),pt(F(r.e,"base64url"))]))]).subarray()}function yi(r){let t=Ct(r);return Zn(t)}function Zn(r){let t=pi(r);return xi(t)}function qc(r,t){if(r.byteLength>=Oh)throw new $e("Key size is too large");let e=Ct(r,{offset:0});return mi(e,r,t)}function mi(r,t,e){let n=gi(r);if(e==null){let s=dr(pe.encode({Type:Q.RSA,Data:t}));e=Rt(di,s)}return new gr(n,e)}function xi(r){if(Zc(r)>hi)throw new R("Key size is too large");let t=jc(r),e=dr(pe.encode({Type:Q.RSA,Data:bi(t.publicKey)})),n=Rt(di,e);return new Xr(t.privateKey,new gr(t.publicKey,n))}async function $c(r){if(r>hi)throw new R("Key size is too large");let t=await Gc(r),e=dr(pe.encode({Type:Q.RSA,Data:bi(t.publicKey)})),n=Rt(di,e);return new Xr(t.privateKey,new gr(t.publicKey,n))}function jc(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 Gc(r,t){let e=await tt.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 $h(e,t);return{privateKey:n[0],publicKey:n[1]}}async function Pc(r,t,e){let n=await tt.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]);e?.signal?.throwIfAborted();let s=await tt.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 Fc(r,t,e,n){let s=await tt.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);n?.signal?.throwIfAborted();let o=await tt.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},s,t,e instanceof Uint8Array?e:e.subarray());return n?.signal?.throwIfAborted(),o}async function $h(r,t){if(r.privateKey==null||r.publicKey==null)throw new R("Private and public key are required");let e=await Promise.all([tt.get().subtle.exportKey("jwk",r.privateKey),tt.get().subtle.exportKey("jwk",r.publicKey)]);return t?.signal?.throwIfAborted(),e}function Zc(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 Yn=class{oHash;iHash;blockLen;outputLen;finished=!1;destroyed=!1;constructor(t,e){if(An(t),P(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),jt(s)}update(t){return er(this),this.iHash.update(t),this}digestInto(t){er(this),P(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:a}=this;return t=t,t.finished=s,t.destroyed=o,t.blockLen=i,t.outputLen=a,t.oHash=e._cloneInto(t.oHash),t.iHash=n._cloneInto(t.iHash),t}clone(){return this._cloneInto()}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},wi=(r,t,e)=>new Yn(r,t).update(e).digest();wi.create=(r,t)=>new Yn(r,t);var Yc=(r,t)=>(r+(r>=0?t:-t)/Wc)/t;function jh(r,t,e){let[[n,s],[o,i]]=t,a=Yc(i*r,e),c=Yc(-s*r,e),u=r-a*n-c*o,l=-a*s-c*i,f=u<Jt,h=l<Jt;f&&(u=-u),h&&(l=-l);let p=Or(Math.ceil(_o(e)/2))+br;if(u<Jt||u>=p||l<Jt||l>=p)throw new Error("splitScalar (endomorphism): failed, k="+r);return{k1neg:f,k1:u,k2neg:h,k2:l}}function Ei(r){if(!["compact","recovered","der"].includes(r))throw new Error('Signature format must be "compact", "recovered", or "der"');return r}function vi(r,t){let e={};for(let n of Object.keys(t))e[n]=r[n]===void 0?t[n]:r[n];return Wt(e.lowS,"lowS"),Wt(e.prehash,"prehash"),e.format!==void 0&&Ei(e.format),e}var Bi=class extends Error{constructor(t=""){super(t)}},me={Err:Bi,_tlv:{encode:(r,t)=>{let{Err:e}=me;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=Vr(n);if(s.length/2&128)throw new e("tlv.encode: long form length too big");let o=n>127?Vr(s.length/2|128):"";return Vr(r)+o+s+t},decode(r,t){let{Err:e}=me,n=0;if(r<0||r>256)throw new e("tlv.encode: wrong tag");if(t.length<2||t[n++]!==r)throw new e("tlv.decode: wrong tlv");let s=t[n++],o=!!(s&128),i=0;if(!o)i=s;else{let c=s&127;if(!c)throw new e("tlv.decode(long): indefinite length not supported");if(c>4)throw new e("tlv.decode(long): byte length is too big");let u=t.subarray(n,n+c);if(u.length!==c)throw new e("tlv.decode: length bytes not complete");if(u[0]===0)throw new e("tlv.decode(long): zero leftmost byte");for(let l of u)i=i<<8|l;if(n+=c,i<128)throw new e("tlv.decode(long): not minimal encoding")}let a=t.subarray(n,n+i);if(a.length!==i)throw new e("tlv.decode: wrong value length");return{v:a,l:t.subarray(n+i)}}},_int:{encode(r){let{Err:t}=me;if(r<Jt)throw new t("integer: negative integers are not allowed");let e=Vr(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}=me;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 nr(r)}},toSig(r){let{Err:t,_int:e,_tlv:n}=me,s=P(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:a,l:c}=n.decode(2,o),{v:u,l}=n.decode(2,c);if(l.length)throw new t("invalid signature: left bytes after parsing");return{r:e.decode(a),s:e.decode(u)}},hexFromSig(r){let{_tlv:t,_int:e}=me,n=t.encode(2,e.encode(r.r)),s=t.encode(2,e.encode(r.s)),o=n+s;return t.encode(48,o)}},Jt=BigInt(0),br=BigInt(1),Wc=BigInt(2),Wn=BigInt(3),Gh=BigInt(4);function zc(r,t={}){let e=Nn("weierstrass",r,t),{Fp:n,Fn:s}=e,o=e.CURVE,{h:i,n:a}=o;ue(t,{},{allowInfinityPoint:"boolean",clearCofactor:"function",isTorsionFree:"function",fromBytes:"function",toBytes:"function",endo:"object"});let{endo:c}=t;if(c&&(!n.is0(o.a)||typeof c.beta!="bigint"||!Array.isArray(c.basises)))throw new Error('invalid endo: expected "beta": bigint and "basises": array');let u=Xc(n,s);function l(){if(!n.isOdd)throw new Error("compression is not supported: Field does not have .isOdd()")}function f(C,m,x){let{x:y,y:k}=m.toAffine(),L=n.toBytes(y);if(Wt(x,"isCompressed"),x){l();let U=!n.isOdd(k);return xt(Jc(U),L)}else return xt(Uint8Array.of(4),L,n.toBytes(k))}function h(C){P(C,void 0,"Point");let{publicKey:m,publicKeyUncompressed:x}=u,y=C.length,k=C[0],L=C.subarray(1);if(y===m&&(k===2||k===3)){let U=n.fromBytes(L);if(!n.isValid(U))throw new Error("bad point: is not on curve, wrong x");let _=E(U),N;try{N=n.sqrt(_)}catch(Y){let G=Y instanceof Error?": "+Y.message:"";throw new Error("bad point: is not on curve, sqrt error"+G)}l();let H=n.isOdd(N);return(k&1)===1!==H&&(N=n.neg(N)),{x:U,y:N}}else if(y===x&&k===4){let U=n.BYTES,_=n.fromBytes(L.subarray(0,U)),N=n.fromBytes(L.subarray(U,U*2));if(!w(_,N))throw new Error("bad point: is not on curve");return{x:_,y:N}}else throw new Error(`bad point: got length ${y}, expected compressed=${m} or uncompressed=${x}`)}let p=t.toBytes||f,d=t.fromBytes||h;function E(C){let m=n.sqr(C),x=n.mul(m,C);return n.add(n.add(x,n.mul(C,o.a)),o.b)}function w(C,m){let x=n.sqr(m),y=E(C);return n.eql(x,y)}if(!w(o.Gx,o.Gy))throw new Error("bad curve params: generator point");let b=n.mul(n.pow(o.a,Wn),Gh),A=n.mul(n.sqr(o.b),BigInt(27));if(n.is0(n.add(b,A)))throw new Error("bad curve params: a or b");function g(C,m,x=!1){if(!n.isValid(m)||x&&n.is0(m))throw new Error(`bad point coordinate ${C}`);return m}function S(C){if(!(C instanceof v))throw new Error("Weierstrass Point expected")}function T(C){if(!c||!c.basises)throw new Error("no endo");return jh(C,c.basises,s.ORDER)}let V=sr((C,m)=>{let{X:x,Y:y,Z:k}=C;if(n.eql(k,n.ONE))return{x,y};let L=C.is0();m==null&&(m=L?n.ONE:n.inv(k));let U=n.mul(x,m),_=n.mul(y,m),N=n.mul(k,m);if(L)return{x:n.ZERO,y:n.ZERO};if(!n.eql(N,n.ONE))throw new Error("invZ was invalid");return{x:U,y:_}}),O=sr(C=>{if(C.is0()){if(t.allowInfinityPoint&&!n.is0(C.Y))return;throw new Error("bad point: ZERO")}let{x:m,y:x}=C.toAffine();if(!n.isValid(m)||!n.isValid(x))throw new Error("bad point: x or y not field elements");if(!w(m,x))throw new Error("bad point: equation left != right");if(!C.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});function B(C,m,x,y,k){return x=new v(n.mul(x.X,C),x.Y,x.Z),m=Pr(y,m),x=Pr(k,x),m.add(x)}class v{static BASE=new v(o.Gx,o.Gy,n.ONE);static ZERO=new v(n.ZERO,n.ONE,n.ZERO);static Fp=n;static Fn=s;X;Y;Z;constructor(m,x,y){this.X=g("x",m),this.Y=g("y",x,!0),this.Z=g("z",y),Object.freeze(this)}static CURVE(){return o}static fromAffine(m){let{x,y}=m||{};if(!m||!n.isValid(x)||!n.isValid(y))throw new Error("invalid affine point");if(m instanceof v)throw new Error("projective point not allowed");return n.is0(x)&&n.is0(y)?v.ZERO:new v(x,y,n.ONE)}static fromBytes(m){let x=v.fromAffine(d(P(m,void 0,"point")));return x.assertValidity(),x}static fromHex(m){return v.fromBytes(Zt(m))}get x(){return this.toAffine().x}get y(){return this.toAffine().y}precompute(m=8,x=!0){return M.createCache(this,m),x||this.multiply(Wn),this}assertValidity(){O(this)}hasEvenY(){let{y:m}=this.toAffine();if(!n.isOdd)throw new Error("Field doesn't support isOdd");return!n.isOdd(m)}equals(m){S(m);let{X:x,Y:y,Z:k}=this,{X:L,Y:U,Z:_}=m,N=n.eql(n.mul(x,_),n.mul(L,k)),H=n.eql(n.mul(y,_),n.mul(U,k));return N&&H}negate(){return new v(this.X,n.neg(this.Y),this.Z)}double(){let{a:m,b:x}=o,y=n.mul(x,Wn),{X:k,Y:L,Z:U}=this,_=n.ZERO,N=n.ZERO,H=n.ZERO,K=n.mul(k,k),Y=n.mul(L,L),G=n.mul(U,U),j=n.mul(k,L);return j=n.add(j,j),H=n.mul(k,U),H=n.add(H,H),_=n.mul(m,H),N=n.mul(y,G),N=n.add(_,N),_=n.sub(Y,N),N=n.add(Y,N),N=n.mul(_,N),_=n.mul(j,_),H=n.mul(y,H),G=n.mul(m,G),j=n.sub(K,G),j=n.mul(m,j),j=n.add(j,H),H=n.add(K,K),K=n.add(H,K),K=n.add(K,G),K=n.mul(K,j),N=n.add(N,K),G=n.mul(L,U),G=n.add(G,G),K=n.mul(G,j),_=n.sub(_,K),H=n.mul(G,Y),H=n.add(H,H),H=n.add(H,H),new v(_,N,H)}add(m){S(m);let{X:x,Y:y,Z:k}=this,{X:L,Y:U,Z:_}=m,N=n.ZERO,H=n.ZERO,K=n.ZERO,Y=o.a,G=n.mul(o.b,Wn),j=n.mul(x,L),W=n.mul(y,U),st=n.mul(k,_),_t=n.add(x,y),z=n.add(L,U);_t=n.mul(_t,z),z=n.add(j,W),_t=n.sub(_t,z),z=n.add(x,k);let ft=n.add(L,_);return z=n.mul(z,ft),ft=n.add(j,st),z=n.sub(z,ft),ft=n.add(y,k),N=n.add(U,_),ft=n.mul(ft,N),N=n.add(W,st),ft=n.sub(ft,N),K=n.mul(Y,z),N=n.mul(G,st),K=n.add(N,K),N=n.sub(W,K),K=n.add(W,K),H=n.mul(N,K),W=n.add(j,j),W=n.add(W,j),st=n.mul(Y,st),z=n.mul(G,z),W=n.add(W,st),st=n.sub(j,st),st=n.mul(Y,st),z=n.add(z,st),j=n.mul(W,z),H=n.add(H,j),j=n.mul(ft,z),N=n.mul(_t,N),N=n.sub(N,j),j=n.mul(_t,W),K=n.mul(ft,K),K=n.add(K,j),new v(N,H,K)}subtract(m){return this.add(m.negate())}is0(){return this.equals(v.ZERO)}multiply(m){let{endo:x}=t;if(!s.isValidNot0(m))throw new Error("invalid scalar: out of range");let y,k,L=U=>M.cached(this,U,_=>Ne(v,_));if(x){let{k1neg:U,k1:_,k2neg:N,k2:H}=T(m),{p:K,f:Y}=L(_),{p:G,f:j}=L(H);k=Y.add(j),y=B(x.beta,K,G,U,N)}else{let{p:U,f:_}=L(m);y=U,k=_}return Ne(v,[y,k])[0]}multiplyUnsafe(m){let{endo:x}=t,y=this;if(!s.isValid(m))throw new Error("invalid scalar: out of range");if(m===Jt||y.is0())return v.ZERO;if(m===br)return y;if(M.hasCache(this))return this.multiply(m);if(x){let{k1neg:k,k1:L,k2neg:U,k2:_}=T(m),{p1:N,p2:H}=oc(v,y,L,_);return B(x.beta,N,H,k,U)}else return M.unsafe(y,m)}toAffine(m){return V(this,m)}isTorsionFree(){let{isTorsionFree:m}=t;return i===br?!0:m?m(v,this):M.unsafe(this,a).is0()}clearCofactor(){let{clearCofactor:m}=t;return i===br?this:m?m(v,this):this.multiplyUnsafe(i)}isSmallOrder(){return this.multiplyUnsafe(i).is0()}toBytes(m=!0){return Wt(m,"isCompressed"),this.assertValidity(),p(v,this,m)}toHex(m=!0){return Gt(this.toBytes(m))}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}}let D=s.BITS,M=new ar(v,t.endo?Math.ceil(D/2):D);return v.BASE.precompute(8),v}function Jc(r){return Uint8Array.of(r?2:3)}function Xc(r,t){return{secretKey:t.BYTES,publicKey:1+r.BYTES,publicKeyUncompressed:1+2*r.BYTES,publicKeyHasPrefix:!0,signature:2*t.BYTES}}function Zh(r,t={}){let{Fn:e}=r,n=t.randomBytes||rr,s=Object.assign(Xc(r.Fp,e),{seed:Vo(e.ORDER)});function o(p){try{let d=e.fromBytes(p);return e.isValidNot0(d)}catch{return!1}}function i(p,d){let{publicKey:E,publicKeyUncompressed:w}=s;try{let b=p.length;return d===!0&&b!==E||d===!1&&b!==w?!1:!!r.fromBytes(p)}catch{return!1}}function a(p=n(s.seed)){return Ko(P(p,s.seed,"seed"),e.ORDER)}function c(p,d=!0){return r.BASE.multiply(e.fromBytes(p)).toBytes(d)}function u(p){let{secretKey:d,publicKey:E,publicKeyUncompressed:w}=s;if(!Ae(p)||"_lengths"in e&&e._lengths||d===E)return;let b=P(p,void 0,"key").length;return b===E||b===w}function l(p,d,E=!0){if(u(p)===!0)throw new Error("first arg must be private key");if(u(d)===!1)throw new Error("second arg must be public key");let w=e.fromBytes(p);return r.fromBytes(d).multiply(w).toBytes(E)}let f={isValidSecretKey:o,isValidPublicKey:i,randomSecretKey:a},h=Un(a,c);return Object.freeze({getPublicKey:c,getSharedSecret:l,keygen:h,Point:r,utils:f,lengths:s})}function Qc(r,t,e={}){An(t),ue(e,{},{hmac:"function",lowS:"boolean",randomBytes:"function",bits2int:"function",bits2int_modN:"function"}),e=Object.assign({},e);let n=e.randomBytes||rr,s=e.hmac||((x,y)=>wi(t,x,y)),{Fp:o,Fn:i}=r,{ORDER:a,BITS:c}=i,{keygen:u,getPublicKey:l,getSharedSecret:f,utils:h,lengths:p}=Zh(r,e),d={prehash:!0,lowS:typeof e.lowS=="boolean"?e.lowS:!0,format:"compact",extraEntropy:!1},E=a*Wc<o.ORDER;function w(x){let y=a>>br;return x>y}function b(x,y){if(!i.isValidNot0(y))throw new Error(`invalid signature ${x}: out of range 1..Point.Fn.ORDER`);return y}function A(){if(E)throw new Error('"recovered" sig type is not supported for cofactor >2 curves')}function g(x,y){Ei(y);let k=p.signature,L=y==="compact"?k:y==="recovered"?k+1:void 0;return P(x,L)}class S{r;s;recovery;constructor(y,k,L){if(this.r=b("r",y),this.s=b("s",k),L!=null){if(A(),![0,1,2,3].includes(L))throw new Error("invalid recovery id");this.recovery=L}Object.freeze(this)}static fromBytes(y,k=d.format){g(y,k);let L;if(k==="der"){let{r:H,s:K}=me.toSig(P(y));return new S(H,K)}k==="recovered"&&(L=y[0],k="compact",y=y.subarray(1));let U=p.signature/2,_=y.subarray(0,U),N=y.subarray(U,U*2);return new S(i.fromBytes(_),i.fromBytes(N),L)}static fromHex(y,k){return this.fromBytes(Zt(y),k)}assertRecovery(){let{recovery:y}=this;if(y==null)throw new Error("invalid recovery id: must be present");return y}addRecoveryBit(y){return new S(this.r,this.s,y)}recoverPublicKey(y){let{r:k,s:L}=this,U=this.assertRecovery(),_=U===2||U===3?k+a:k;if(!o.isValid(_))throw new Error("invalid recovery id: sig.r+curve.n != R.x");let N=o.toBytes(_),H=r.fromBytes(xt(Jc((U&1)===0),N)),K=i.inv(_),Y=V(P(y,void 0,"msgHash")),G=i.create(-Y*K),j=i.create(L*K),W=r.BASE.multiplyUnsafe(G).add(H.multiplyUnsafe(j));if(W.is0())throw new Error("invalid recovery: point at infinify");return W.assertValidity(),W}hasHighS(){return w(this.s)}toBytes(y=d.format){if(Ei(y),y==="der")return Zt(me.hexFromSig(this));let{r:k,s:L}=this,U=i.toBytes(k),_=i.toBytes(L);return y==="recovered"?(A(),xt(Uint8Array.of(this.assertRecovery()),U,_)):xt(U,_)}toHex(y){return Gt(this.toBytes(y))}}let T=e.bits2int||function(y){if(y.length>8192)throw new Error("input is too large");let k=nr(y),L=y.length*8-c;return L>0?k>>BigInt(L):k},V=e.bits2int_modN||function(y){return i.create(T(y))},O=Or(c);function B(x){return Kr("num < 2^"+c,x,Jt,O),i.toBytes(x)}function v(x,y){return P(x,void 0,"message"),y?P(t(x),void 0,"prehashed message"):x}function D(x,y,k){let{lowS:L,prehash:U,extraEntropy:_}=vi(k,d);x=v(x,U);let N=V(x),H=i.fromBytes(y);if(!i.isValidNot0(H))throw new Error("invalid private key");let K=[B(H),B(N)];if(_!=null&&_!==!1){let W=_===!0?n(p.secretKey):_;K.push(P(W,void 0,"extraEntropy"))}let Y=xt(...K),G=N;function j(W){let st=T(W);if(!i.isValidNot0(st))return;let _t=i.inv(st),z=r.BASE.multiply(st).toAffine(),ft=i.create(z.x);if(ft===Jt)return;let gn=i.create(_t*i.create(G+ft*H));if(gn===Jt)return;let Vi=(z.x===ft?0:2)|Number(z.y&br),Ki=gn;return L&&w(gn)&&(Ki=i.neg(gn),Vi^=1),new S(ft,Ki,E?void 0:Vi)}return{seed:Y,k2sig:j}}function M(x,y,k={}){let{seed:L,k2sig:U}=D(x,y,k);return Fa(t.outputLen,i.BYTES,s)(L,U).toBytes(k.format)}function C(x,y,k,L={}){let{lowS:U,prehash:_,format:N}=vi(L,d);if(k=P(k,void 0,"publicKey"),y=v(y,_),!Ae(x)){let H=x instanceof S?", use sig.toBytes()":"";throw new Error("verify expects Uint8Array signature"+H)}g(x,N);try{let H=S.fromBytes(x,N),K=r.fromBytes(k);if(U&&H.hasHighS())return!1;let{r:Y,s:G}=H,j=V(y),W=i.inv(G),st=i.create(j*W),_t=i.create(Y*W),z=r.BASE.multiplyUnsafe(st).add(K.multiplyUnsafe(_t));return z.is0()?!1:i.create(z.x)===Y}catch{return!1}}function m(x,y,k={}){let{prehash:L}=vi(k,d);return y=v(y,L),S.fromBytes(x,"recovered").recoverPublicKey(y).toBytes()}return Object.freeze({keygen:u,getPublicKey:l,getSharedSecret:f,utils:h,lengths:p,Point:r,sign:M,verify:C,recoverPublicKey:m,Signature:S,hash:t})}var Si={p:BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),n:BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),h:BigInt(1),a:BigInt(0),b:BigInt(7),Gx:BigInt("0x79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798"),Gy:BigInt("0x483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8")},Yh={beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),basises:[[BigInt("0x3086d221a7d46bcde86c90e49284eb15"),-BigInt("0xe4437ed6010e88286f547fa90abfe4c3")],[BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),BigInt("0x3086d221a7d46bcde86c90e49284eb15")]]};var tf=BigInt(2);function Wh(r){let t=Si.p,e=BigInt(3),n=BigInt(6),s=BigInt(11),o=BigInt(22),i=BigInt(23),a=BigInt(44),c=BigInt(88),u=r*r*r%t,l=u*u*r%t,f=Z(l,e,t)*l%t,h=Z(f,e,t)*l%t,p=Z(h,tf,t)*u%t,d=Z(p,s,t)*p%t,E=Z(d,o,t)*d%t,w=Z(E,a,t)*E%t,b=Z(w,c,t)*w%t,A=Z(b,a,t)*E%t,g=Z(A,e,t)*l%t,S=Z(g,i,t)*d%t,T=Z(S,n,t)*u%t,V=Z(T,tf,t);if(!Ai.eql(Ai.sqr(V),r))throw new Error("Cannot find square root");return V}var Ai=or(Si.p,{sqrt:Wh}),zh=zc(Si,{Fp:Ai,endo:Yh}),Kt=Qc(zh,Ka);var ef=32;function rf(r,t,e){let n=Xe.digest(t instanceof Uint8Array?t:t.subarray());if(ur(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 Br(String(s))});try{return Kt.sign(n.digest,r,{prehash:!1,format:"der"})}catch(s){throw new Br(String(s))}}function nf(r,t,e,n){let s=Xe.digest(e instanceof Uint8Array?e:e.subarray());if(ur(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 Ar(String(o))});try{return n?.signal?.throwIfAborted(),Kt.verify(t,s.digest,r,{prehash:!1,format:"der"})}catch(o){throw new Ar(String(o))}}var zn=class{type="secp256k1";raw;_key;constructor(t){this._key=af(t),this.raw=sf(this._key)}toMultihash(){return Ee.digest(tr(this))}toCID(){return St.createV1(114,this.toMultihash())}toString(){return et.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 nf(this._key,e,t,n)}},Jn=class{type="secp256k1";raw;publicKey;constructor(t,e){this.raw=of(t),this.publicKey=new zn(e??cf(t))}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:mt(this.raw,t.raw)}sign(t,e){return rf(this.raw,t,e)}};function ki(r){return new Jn(r)}function sf(r){return Kt.Point.fromBytes(r).toBytes()}function of(r){try{return Kt.getPublicKey(r,!0),r}catch(t){throw new Sr(String(t))}}function af(r){try{return Kt.Point.fromBytes(r),r}catch(t){throw new $e(String(t))}}function cf(r){try{return Kt.getPublicKey(r,!0)}catch(t){throw new Sr(String(t))}}function tr(r){return pe.encode({Type:Q[r.type],Data:r.raw})}function ff(r){let t=Yr.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case Q.RSA:return yi(e);case Q.Ed25519:return jo(e);case Q.secp256k1:return ki(e);case Q.ECDSA:return wa(e);default:throw new je}}function uf(r){if(r.byteLength===kt)return jo(r);if(r.byteLength===ef)return ki(r);let t=Ct(r),e=t[2]?.[0];if(e===ga||e===ba||e===ya)return vo(t);if(t.length>8)return Zn(t);throw new R("Could not extract private key from raw bytes")}function Oe(r){return Yr.encode({Type:Q[r.type],Data:r.raw})}var tn=Uint32Array.from([1732584193,4023233417,2562383102,271733878,3285377520]),xe=new Uint32Array(80),Ii=class extends He{A=tn[0]|0;B=tn[1]|0;C=tn[2]|0;D=tn[3]|0;E=tn[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 c=0;c<16;c++,e+=4)xe[c]=t.getUint32(e,!1);for(let c=16;c<80;c++)xe[c]=qn(xe[c-3]^xe[c-8]^xe[c-14]^xe[c-16],1);let{A:n,B:s,C:o,D:i,E:a}=this;for(let c=0;c<80;c++){let u,l;c<20?(u=$n(s,o,i),l=1518500249):c<40?(u=s^o^i,l=1859775393):c<60?(u=jn(s,o,i),l=2400959708):(u=s^o^i,l=3395469782);let f=qn(n,5)+u+a+l+xe[c]|0;a=i,i=o,o=qn(s,30),s=n,n=f}n=n+this.A|0,s=s+this.B|0,o=o+this.C|0,i=i+this.D|0,a=a+this.E|0,this.set(n,s,o,i,a)}roundClean(){wt(xe)}destroy(){this.destroyed=!0,this.set(0,0,0,0,0),wt(this.buffer)}},lf=Wr(()=>new Ii);var Xn=class{oHash;iHash;blockLen;outputLen;canXOF=!1;finished=!1;destroyed=!1;constructor(t,e){if(Pn(t),lr(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 hr(this),this.iHash.update(t),this}digestInto(t){hr(this),Fn(t,this),this.finished=!0;let e=t.subarray(0,this.outputLen);this.iHash.digestInto(e),this.oHash.update(e),this.oHash.digestInto(e),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:a}=this;return t=t,t.finished=s,t.destroyed=o,t.blockLen=i,t.outputLen=a,t.oHash=e._cloneInto(t.oHash),t.iHash=n._cloneInto(t.iHash),t}clone(){return this._cloneInto()}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},hf=(()=>{let r=((t,e,n)=>new Xn(t,e).update(n).digest());return r.create=(t,e)=>new Xn(t,e),r})();function df(r,t,e,n){Pn(r);let s=Nc({dkLen:32,asyncTick:10},n),{c:o,dkLen:i,asyncTick:a}=s;if(_e(o,"c"),_e(i,"dkLen"),_e(a,"asyncTick"),o<1)throw new Error("iterations (c) must be >= 1");if(i<1)throw new Error('"dkLen" must be >= 1');if(i>(2**32-1)*r.outputLen)throw new Error("derived key too long");let c=si(t,"password"),u=si(e,"salt"),l=new Uint8Array(i),f=hf.create(r,c),h=f._cloneInto().update(u);return{c:o,dkLen:i,asyncTick:a,DK:l,PRF:f,PRFSalt:h}}function pf(r,t,e,n,s){return r.destroy(),t.destroy(),n&&n.destroy(),wt(s),e}function gf(r,t,e,n){let{c:s,dkLen:o,DK:i,PRF:a,PRFSalt:c}=df(r,t,e,n),u,l=new Uint8Array(4),f=Re(l),h=new Uint8Array(a.outputLen);for(let p=1,d=0;d<o;p++,d+=a.outputLen){let E=i.subarray(d,d+a.outputLen);f.setInt32(0,p,!1),(u=c._cloneInto(u)).update(l).digestInto(h),E.set(h.subarray(0,E.length));for(let w=1;w<s;w++){a._cloneInto(u).update(h).digestInto(h);for(let b=0;b<E.length;b++)E[b]^=h[b]}}return pf(a,c,i,u,h)}async function Qn(r,t,e,n){let{c:s,dkLen:o,asyncTick:i,DK:a,PRF:c,PRFSalt:u}=df(r,t,e,n),l,f=new Uint8Array(4),h=Re(f),p=new Uint8Array(c.outputLen);for(let d=1,E=0;E<o;d++,E+=c.outputLen){let w=a.subarray(E,E+c.outputLen);h.setInt32(0,d,!1),(l=u._cloneInto(l)).update(f).digestInto(p),w.set(p.subarray(0,w.length)),await Lc(s-1,i,()=>{c._cloneInto(l).update(p).digestInto(p);for(let b=0;b<w.length;b++)w[b]^=p[b]})}return pf(c,u,a,l,p)}var bf={sha1:lf,"sha2-256":dr,"sha2-512":pr};function en(r,t,e,n,s){if(s!=="sha1"&&s!=="sha2-256"&&s!=="sha2-512"){let a=Object.keys(bf).join(" / ");throw new R(`Hash '${s}' is unknown or not supported. Must be ${a}`)}let o=bf[s],i=gf(o,r,t,{c:e,dkLen:n});return Be.encode(i).substring(1)}var Xt="/",yf=new TextEncoder().encode(Xt),ts=yf[0],rn=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]!==ts)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(Xt))}static random(){return new r(Math.random().toString().substring(2))}static asKey(t){return t instanceof Uint8Array||typeof t=="string"?new r(t):typeof t.uint8Array=="function"?new r(t.uint8Array()):null}clean(){if((this._buf==null||this._buf.byteLength===0)&&(this._buf=yf),this._buf[0]!==ts){let t=new Uint8Array(this._buf.byteLength+1);t.fill(ts,0,1),t.set(this._buf,1),this._buf=t}for(;this._buf.byteLength>1&&this._buf[this._buf.byteLength-1]===ts;)this._buf=this._buf.subarray(0,-1)}less(t){let e=this.list(),n=t.list();for(let s=0;s<e.length;s++){if(n.length<s+1)return!1;let o=e[s],i=n[s];if(o<i)return!0;if(o>i)return!1}return e.length<n.length}reverse(){return r.withNamespaces(this.list().slice().reverse())}namespaces(){return this.list()}baseNamespace(){let t=this.namespaces();return t[t.length-1]}list(){return this.toString().split(Xt).slice(1)}type(){return Jh(this.baseNamespace())}name(){return Xh(this.baseNamespace())}instance(t){return new r(this.toString()+":"+t)}path(){let t=this.parent().toString();return t.endsWith(Xt)||(t+=Xt),t+=this.type(),new r(t)}parent(){let t=this.list();return t.length===1?new r(Xt):new r(t.slice(0,-1).join(Xt))}child(t){return this.toString()===Xt?t:t.toString()===Xt?this:new r(this.toString()+t.toString(),!1)}isAncestorOf(t){return t.toString()===this.toString()?!1:t.toString().startsWith(this.toString())}isDecendantOf(t){return t.toString()===this.toString()?!1:this.toString().startsWith(t.toString())}isTopLevel(){return this.list().length===1}concat(...t){return r.withNamespaces([...this.namespaces(),...Qh(t.map(e=>e.namespaces()))])}};function Jh(r){let t=r.split(":");return t.length<2?"":t.slice(0,-1).join(":")}function Xh(r){let t=r.split(":");return t[t.length-1]}function Qh(r){return[].concat(...r)}var bu=Mi(kf(),1);var Ci={keyLength:64,iterationCount:1e4,salt:"you should override this value with a crypto secure random number",hash:"sha2-512"};var yr={};ht(yr,{create:()=>h0,derivedEmptyPasswordKey:()=>es});var es={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function h0(r){let t=r?.algorithm??"AES-GCM",e=r?.keyLength??16,n=r?.nonceLength??12,s=r?.digest??"SHA-256",o=r?.saltLength??16,i=r?.iterations??32767,a=tt.get();e*=8;async function c(f,h){let p=a.getRandomValues(new Uint8Array(o)),d=a.getRandomValues(new Uint8Array(n)),E={name:t,iv:d};typeof h=="string"&&(h=F(h));let w;if(h.length===0){w=await a.subtle.importKey("jwk",es,{name:"AES-GCM"},!0,["encrypt"]);try{let A={name:"PBKDF2",salt:p,iterations:i,hash:{name:s}},g=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);w=await a.subtle.deriveKey(A,g,{name:t,length:e},!0,["encrypt"])}catch{w=await a.subtle.importKey("jwk",es,{name:"AES-GCM"},!0,["encrypt"])}}else{let A={name:"PBKDF2",salt:p,iterations:i,hash:{name:s}},g=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);w=await a.subtle.deriveKey(A,g,{name:t,length:e},!0,["encrypt"])}let b=await a.subtle.encrypt(E,w,f);return Je([p,E.iv,new Uint8Array(b)])}async function u(f,h){let p=f.subarray(0,o),d=f.subarray(o,o+n),E=f.subarray(o+n),w={name:t,iv:d};typeof h=="string"&&(h=F(h));let b;if(h.length===0)try{let g={name:"PBKDF2",salt:p,iterations:i,hash:{name:s}},S=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);b=await a.subtle.deriveKey(g,S,{name:t,length:e},!0,["decrypt"])}catch{b=await a.subtle.importKey("jwk",es,{name:"AES-GCM"},!0,["decrypt"])}else{let g={name:"PBKDF2",salt:p,iterations:i,hash:{name:s}},S=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);b=await a.subtle.deriveKey(g,S,{name:t,length:e},!0,["decrypt"])}let A=await a.subtle.decrypt(w,b,E);return new Uint8Array(A)}return{encrypt:c,decrypt:u}}var q=Mi(If());function Me(r,t){let e=0;if(r.length===1)return r[0];for(let n=r.length-1;n>=0;n--)e+=r[r.length-1-n]*Math.pow(2,t*n);return e}function we(r,t,e=-1){let n=e,s=r,o=0,i=Math.pow(2,t);for(let a=1;a<8;a++){if(r<i){let c;if(n<0)c=new ArrayBuffer(a),o=a;else{if(n<a)return new ArrayBuffer(0);c=new ArrayBuffer(n),o=n}let u=new Uint8Array(c);for(let l=a-1;l>=0;l--){let f=Math.pow(2,l*t);u[o-l-1]=Math.floor(s/f),s-=u[o-l-1]*f}return c}i*=Math.pow(2,t)}return new ArrayBuffer(0)}function ss(...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 Ni(){let r=new Uint8Array(this.valueHex);if(this.valueHex.byteLength>=2){let a=r[0]===255&&r[1]&128,c=r[0]===0&&(r[1]&128)===0;(a||c)&&this.warnings.push("Needlessly long format")}let t=new ArrayBuffer(this.valueHex.byteLength),e=new Uint8Array(t);for(let a=0;a<this.valueHex.byteLength;a++)e[a]=0;e[0]=r[0]&128;let n=Me(e,8),s=new ArrayBuffer(this.valueHex.byteLength),o=new Uint8Array(s);for(let a=0;a<this.valueHex.byteLength;a++)o[a]=r[a];return o[0]&=127,Me(o,8)-n}function Cf(r){let t=r<0?r*-1:r,e=128;for(let n=1;n<8;n++){if(t<=e){if(r<0){let i=e-t,a=we(i,8,n),c=new Uint8Array(a);return c[0]|=128,a}let s=we(t,8,n),o=new Uint8Array(s);if(o[0]&128){let i=s.slice(0),a=new Uint8Array(i);s=new ArrayBuffer(s.byteLength+1),o=new Uint8Array(s);for(let c=0;c<i.byteLength;c++)o[c+1]=a[c];o[0]=0}return s}e*=Math.pow(2,8)}return new ArrayBuffer(0)}function Lf(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 lm=Math.log(2);function os(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function Ui(r){let t=0,e=0;for(let s=0;s<r.length;s++){let o=r[s];t+=o.byteLength}let n=new Uint8Array(t);for(let s=0;s<r.length;s++){let o=r[s];n.set(new Uint8Array(o),e),e+=o.byteLength}return n.buffer}function se(r,t,e,n){return t instanceof Uint8Array?t.byteLength?e<0?(r.error="Wrong parameter: inputOffset less than zero",!1):n<0?(r.error="Wrong parameter: inputLength less than zero",!1):t.byteLength-e-n<0?(r.error="End of input reached before message was fully decoded (inconsistent offset and length values)",!1):!0:(r.error="Wrong parameter: inputBuffer has zero length",!1):(r.error="Wrong parameter: inputBuffer must be 'Uint8Array'",!1)}var on=class{constructor(){this.items=[]}write(t){this.items.push(t)}final(){return Ui(this.items)}},nn=[new Uint8Array([1])],Nf="0123456789";var xr="",Pt=new ArrayBuffer(0),Ti=new Uint8Array(0),an="EndOfContent",Tf="OCTET STRING",_f="BIT STRING";function oe(r){var t;return t=class extends r{get valueHex(){return this.valueHexView.slice().buffer}set valueHex(n){this.valueHexView=new Uint8Array(n)}constructor(...n){var s;super(...n);let o=n[0]||{};this.isHexOnly=(s=o.isHexOnly)!==null&&s!==void 0?s:!1,this.valueHexView=o.valueHex?q.BufferSourceConverter.toUint8Array(o.valueHex):Ti}fromBER(n,s,o){let i=n instanceof ArrayBuffer?new Uint8Array(n):n;if(!se(this,i,s,o))return-1;let a=s+o;return this.valueHexView=i.subarray(s,a),this.valueHexView.length?(this.blockLength=o,a):(this.warnings.push("Zero buffer length"),s)}toBER(n=!1){return this.isHexOnly?n?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.byteLength===this.valueHexView.buffer.byteLength?this.valueHexView.buffer:this.valueHexView.slice().buffer:(this.error="Flag 'isHexOnly' is not set, abort",Pt)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:q.Convert.ToHex(this.valueHexView)}}},t.NAME="hexBlock",t}var te=class{static blockName(){return this.NAME}get valueBeforeDecode(){return this.valueBeforeDecodeView.slice().buffer}set valueBeforeDecode(t){this.valueBeforeDecodeView=new Uint8Array(t)}constructor({blockLength:t=0,error:e=xr,warnings:n=[],valueBeforeDecode:s=Ti}={}){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)}}};te.NAME="baseBlock";var lt=class extends te{fromBER(t,e,n){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}toBER(t,e){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}};lt.NAME="valueBlock";var is=class extends oe(te){constructor({idBlock:t={}}={}){var e,n,s,o;super(),t?(this.isHexOnly=(e=t.isHexOnly)!==null&&e!==void 0?e:!1,this.valueHexView=t.valueHex?q.BufferSourceConverter.toUint8Array(t.valueHex):Ti,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",Pt}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=we(this.tagNumber,7),o=new Uint8Array(s),i=s.byteLength,a=new Uint8Array(i+1);if(a[0]=e|31,!t){for(let c=0;c<i-1;c++)a[c+1]=o[c]|128;a[i]=o[i-1]}return a.buffer}let n=new Uint8Array(this.valueHexView.byteLength+1);if(n[0]=e|31,!t){let s=this.valueHexView;for(let o=0;o<s.length-1;o++)n[o+1]=s[o]|128;n[this.valueHexView.byteLength]=s[s.length-1]}return n.buffer}fromBER(t,e,n){let s=q.BufferSourceConverter.toUint8Array(t);if(!se(this,s,e,n))return-1;let o=s.subarray(e,e+n);if(o.length===0)return this.error="Zero buffer length",-1;switch(o[0]&192){case 0:this.tagClass=1;break;case 64:this.tagClass=2;break;case 128:this.tagClass=3;break;case 192:this.tagClass=4;break;default:return this.error="Unknown tag class",-1}this.isConstructed=(o[0]&32)===32,this.isHexOnly=!1;let a=o[0]&31;if(a!==31)this.tagNumber=a,this.blockLength=1;else{let c=1,u=this.valueHexView=new Uint8Array(255),l=255;for(;o[c]&128;){if(u[c-1]=o[c]&127,c++,c>=o.length)return this.error="End of input reached before message was fully decoded",-1;if(c===l){l+=255;let h=new Uint8Array(l);for(let p=0;p<u.length;p++)h[p]=u[p];u=this.valueHexView=new Uint8Array(l)}}this.blockLength=c+1,u[c-1]=o[c]&127;let f=new Uint8Array(c);for(let h=0;h<c;h++)f[h]=u[h];u=this.valueHexView=new Uint8Array(c),u.set(f),this.blockLength<=9?this.tagNumber=Me(u,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}}};is.NAME="identificationBlock";var as=class extends te{constructor({lenBlock:t={}}={}){var e,n,s;super(),this.isIndefiniteForm=(e=t.isIndefiniteForm)!==null&&e!==void 0?e:!1,this.longFormUsed=(n=t.longFormUsed)!==null&&n!==void 0?n:!1,this.length=(s=t.length)!==null&&s!==void 0?s:0}fromBER(t,e,n){let s=q.BufferSourceConverter.toUint8Array(t);if(!se(this,s,e,n))return-1;let o=s.subarray(e,e+n);if(o.length===0)return this.error="Zero buffer length",-1;if(o[0]===255)return this.error="Length block 0xFF is reserved by standard",-1;if(this.isIndefiniteForm=o[0]===128,this.isIndefiniteForm)return this.blockLength=1,e+this.blockLength;if(this.longFormUsed=!!(o[0]&128),this.longFormUsed===!1)return this.length=o[0],this.blockLength=1,e+this.blockLength;let i=o[0]&127;if(i>8)return this.error="Too big integer",-1;if(i+1>o.length)return this.error="End of input reached before message was fully decoded",-1;let a=e+1,c=s.subarray(a,a+i);return c[i-1]===0&&this.warnings.push("Needlessly long encoded length"),this.length=Me(c,8),this.longFormUsed&&this.length<=127&&this.warnings.push("Unnecessary usage of long length form"),this.blockLength=i+1,e+this.blockLength}toBER(t=!1){let e,n;if(this.length>127&&(this.longFormUsed=!0),this.isIndefiniteForm)return e=new ArrayBuffer(1),t===!1&&(n=new Uint8Array(e),n[0]=128),e;if(this.longFormUsed){let s=we(this.length,8);if(s.byteLength>127)return this.error="Too big length",Pt;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}}};as.NAME="lengthBlock";var I={},at=class extends te{constructor({name:t=xr,optional:e=!1,primitiveSchema:n,...s}={},o){super(s),this.name=t,this.optional=e,n&&(this.primitiveSchema=n),this.idBlock=new is(s),this.lenBlock=new as(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 on;e||Rf(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?Pt: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 Lf(e,n)}};at.NAME="BaseBlock";function Rf(r){var t;if(r instanceof I.Constructed)for(let e of r.valueBlock.value)Rf(e)&&(r.lenBlock.isIndefiniteForm=!0);return!!(!((t=r.lenBlock)===null||t===void 0)&&t.isIndefiniteForm)}var cs=class extends at{getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}constructor({value:t=xr,...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}'`}};cs.NAME="BaseStringBlock";var fs=class extends oe(lt){constructor({isHexOnly:t=!0,...e}={}){super(e),this.isHexOnly=t}};fs.NAME="PrimitiveValueBlock";var Df,us=class extends at{constructor(t={}){super(t,fs),this.idBlock.isConstructed=!1}};Df=us;I.Primitive=Df;us.NAME="PRIMITIVE";function v0(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 $s(r,t=0,e=r.length){let n=t,s=new at({},lt),o=new te;if(!se(o,r,t,e))return s.error=o.error,{offset:-1,result:s};if(!r.subarray(t,t+e).length)return s.error="Zero buffer length",{offset:-1,result:s};let a=s.idBlock.fromBER(r,t,e);if(s.idBlock.warnings.length&&s.warnings.concat(s.idBlock.warnings),a===-1)return s.error=s.idBlock.error,{offset:-1,result:s};if(t=a,e-=s.idBlock.blockLength,a=s.lenBlock.fromBER(r,t,e),s.lenBlock.warnings.length&&s.warnings.concat(s.lenBlock.warnings),a===-1)return s.error=s.lenBlock.error,{offset:-1,result:s};if(t=a,e-=s.lenBlock.blockLength,!s.idBlock.isConstructed&&s.lenBlock.isIndefiniteForm)return s.error="Indefinite length form used for primitive encoding form",{offset:-1,result:s};let c=at;switch(s.idBlock.tagClass){case 1:if(s.idBlock.tagNumber>=37&&s.idBlock.isHexOnly===!1)return s.error="UNIVERSAL 37 and upper tags are reserved by ASN.1 standard",{offset:-1,result:s};switch(s.idBlock.tagNumber){case 0:if(s.idBlock.isConstructed&&s.lenBlock.length>0)return s.error="Type [UNIVERSAL 0] is reserved",{offset:-1,result:s};c=I.EndOfContent;break;case 1:c=I.Boolean;break;case 2:c=I.Integer;break;case 3:c=I.BitString;break;case 4:c=I.OctetString;break;case 5:c=I.Null;break;case 6:c=I.ObjectIdentifier;break;case 10:c=I.Enumerated;break;case 12:c=I.Utf8String;break;case 13:c=I.RelativeObjectIdentifier;break;case 14:c=I.TIME;break;case 15:return s.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:s};case 16:c=I.Sequence;break;case 17:c=I.Set;break;case 18:c=I.NumericString;break;case 19:c=I.PrintableString;break;case 20:c=I.TeletexString;break;case 21:c=I.VideotexString;break;case 22:c=I.IA5String;break;case 23:c=I.UTCTime;break;case 24:c=I.GeneralizedTime;break;case 25:c=I.GraphicString;break;case 26:c=I.VisibleString;break;case 27:c=I.GeneralString;break;case 28:c=I.UniversalString;break;case 29:c=I.CharacterString;break;case 30:c=I.BmpString;break;case 31:c=I.DATE;break;case 32:c=I.TimeOfDay;break;case 33:c=I.DateTime;break;case 34:c=I.Duration;break;default:{let u=s.idBlock.isConstructed?new I.Constructed:new I.Primitive;u.idBlock=s.idBlock,u.lenBlock=s.lenBlock,u.warnings=s.warnings,s=u}}break;default:c=s.idBlock.isConstructed?I.Constructed:I.Primitive}return s=v0(s,c),a=s.fromBER(r,t,s.lenBlock.isIndefiniteForm?e:s.lenBlock.length),s.valueBeforeDecodeView=r.subarray(n,n+s.blockLength),{offset:a,result:s}}function js(r){if(!r.byteLength){let t=new at({},lt);return t.error="Input buffer has zero length",{offset:-1,result:t}}return $s(q.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function E0(r,t){return r?1:t}var Ot=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(!se(this,s,e,n))return-1;if(this.valueBeforeDecodeView=s.subarray(e,e+n),this.valueBeforeDecodeView.length===0)return this.warnings.push("Zero buffer length"),e;let o=e;for(;E0(this.isIndefiniteForm,n)>0;){let i=$s(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===an)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===an?this.value.pop():this.warnings.push("No EndOfContent block encoded")),o}toBER(t,e){let n=e||new on;for(let s=0;s<this.value.length;s++)this.value[s].toBER(t,n);return e?Pt:n.final()}toJSON(){let t={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let e of this.value)t.value.push(e.toJSON());return t}};Ot.NAME="ConstructedValueBlock";var Hf,ve=class extends at{constructor(t={}){super(t,Ot),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} :`}};jc=ye;k.Constructed=jc;ye.NAME="CONSTRUCTED";var jn=class extends lt{fromBER(t,e,n){return e}toBER(t){return Ot}};jn.override="EndOfContentValueBlock";var Gc,Gn=class extends it{constructor(t={}){super(t,jn),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};Gc=Gn;k.EndOfContent=Gc;Gn.NAME=Gr;var Zc,_e=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}`}};Zc=_e;k.Null=Zc;_e.NAME="NULL";var Zn=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,ei.call(this),this.blockLength=n,e+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};Zn.NAME="BooleanValueBlock";var Yc,Yn=class extends it{getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}constructor(t={}){super(t,Zn),this.idBlock.tagClass=1,this.idBlock.tagNumber=1}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.getValue}`}};Yc=Yn;k.Boolean=Yc;Yn.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!==Pc)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 si,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=As(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 si&&t.push(e.valueBlock.valueHexView);return q.BufferSourceConverter.concat(t)}};si=Wt;k.OctetString=si;Wt.NAME=Pc;var Wn=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!==Fc)return this.error="BIT STRING may consists of BIT STRINGs only",-1;let u=c.valueBlock;if(this.unusedBits>0&&u.unusedBits>0)return this.error='Using of "unused bits" inside constructive BIT STRING allowed for least one only',-1;this.unusedBits=u.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=As(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}}};Wn.NAME="BitStringValueBlock";var zc,Jn=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},Wn),this.idBlock.tagClass=1,this.idBlock.tagNumber=3}fromBER(t,e,n){return this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,super.fromBER(t,e,n)}onAsciiEncoding(){if(this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length)return 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}`}}};zc=Jn;k.BitString=zc;Jn.NAME=Fc;var Wc;function Ih(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,u=0,f=a<i?i:a,l=0;for(let d=f;d>=0;d--,l++){switch(!0){case l<c.length:u=o[i-l]+c[a-l]+e[0];break;default:u=o[i-l]+e[0]}switch(e[0]=u/10,!0){case l>=o.length:o=On(new Uint8Array([u%10]),o);break;default:o[i-l]=u%10}}return e[0]>0&&(o=On(e,o)),o}function Mc(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=On(e,n)),qr.push(n)}return qr[r]}function Ch(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,u,f=0;for(let l=a;l>=0;l--,f++)switch(u=o[i-f]-c[a-f]-e,!0){case u<0:e=1,o[i-f]=u+10;break;default:e=0,o[i-f]=u}if(e>0)for(let l=i-a+1;l>=0;l--,f++)if(u=o[i-f]-e,u<0)e=1,o[i-f]=u+10;else{e=0,o[i-f]=u;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=ei.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(Vc(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 u=0;u<8;u++){if((s&1)===1)switch(n){case t:e=Ch(Mc(n),e),i="-";break;default:e=Ih(e,Mc(n))}n++,s>>=1}}for(let a=0;a<e.length;a++)e[a]&&(c=!0),c&&(i+=Hc.charAt(e[a]));return c===!1&&(i+=Hc.charAt(0)),i}};Wc=Zr;Zr.NAME="IntegerValueBlock";Object.defineProperty(Wc.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 Hn(),BigInt(this.valueBlock.toString())}static fromBigInt(t){Hn();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 u=BigInt(`0x${q.Convert.ToHex(c)}`)+e,f=q.BufferSourceConverter.toUint8Array(q.Convert.FromHex(u.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 Jc,Xn=class extends Jt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};Jc=Xn;k.Enumerated=Jc;Xn.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=Le(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}set valueBigInt(t){Hn();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 Qn=class extends lt{constructor({value:t=ar,...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 ri(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){Hn();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}};Qn.NAME="ObjectIdentifierValueBlock";var Xc,Vt=class extends it{getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}constructor(t={}){super(t,Qn),this.idBlock.tagClass=1,this.idBlock.tagNumber=6}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};Xc=Vt;k.ObjectIdentifier=Xc;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=Le(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 ts=class extends lt{constructor({value:t=ar,...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 ri(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}};ts.NAME="RelativeObjectIdentifierValueBlock";var Qc,es=class extends it{getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}constructor(t={}){super(t,ts),this.idBlock.tagClass=1,this.idBlock.tagNumber=13}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};Qc=es;k.RelativeObjectIdentifier=Qc;es.NAME="RelativeObjectIdentifier";var tu,Et=class extends ye{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};tu=Et;k.Sequence=tu;Et.NAME="SEQUENCE";var eu,rs=class extends ye{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};eu=rs;k.Set=eu;rs.NAME="SET";var ns=class extends te(lt){constructor({...t}={}){super(t),this.isHexOnly=!0,this.value=ar}toJSON(){return{...super.toJSON(),value:this.value}}};ns.NAME="StringValueBlock";var ss=class extends ns{};ss.NAME="SimpleStringValueBlock";var yt=class extends Fn{constructor({...t}={}){super(t,ss)}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 os=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}};os.NAME="Utf8StringValueBlock";var ru,Xt=class extends os{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};ru=Xt;k.Utf8String=ru;Xt.NAME="UTF8String";var is=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))}};is.NAME="BmpStringValueBlock";var nu,as=class extends is{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};nu=as;k.BmpString=nu;as.NAME="BMPString";var cs=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}};cs.NAME="UniversalStringValueBlock";var su,us=class extends cs{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};su=us;k.UniversalString=su;us.NAME="UniversalString";var ou,ls=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};ou=ls;k.NumericString=ou;ls.NAME="NumericString";var iu,fs=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};iu=fs;k.PrintableString=iu;fs.NAME="PrintableString";var au,hs=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};au=hs;k.TeletexString=au;hs.NAME="TeletexString";var cu,ds=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};cu=ds;k.VideotexString=cu;ds.NAME="VideotexString";var uu,ps=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};uu=ps;k.IA5String=uu;ps.NAME="IA5String";var lu,gs=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};lu=gs;k.GraphicString=lu;gs.NAME="GraphicString";var fu,Wr=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};fu=Wr;k.VisibleString=fu;Wr.NAME="VisibleString";var hu,ys=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};hu=ys;k.GeneralString=hu;ys.NAME="GeneralString";var du,ms=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};du=ms;k.CharacterString=du;ms.NAME="CharacterString";var pu,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}}};pu=Jr;k.UTCTime=pu;Jr.NAME="UTCTime";var gu,bs=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 l=new Number(t[t.length-1]);if(isNaN(l.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 l=1,d=n.indexOf("+"),y="";if(d===-1&&(d=n.indexOf("-"),l=-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=l*h,y.length===4){if(h=parseInt(y.substring(2,4),10),isNaN(h.valueOf()))throw new Error("Wrong input string for conversion");a=l*h}}}let u=n.indexOf(".");if(u===-1&&(u=n.indexOf(",")),u!==-1){let l=new Number(`0${n.substring(u)}`);if(isNaN(l.valueOf()))throw new Error("Wrong input string for conversion");o=l.valueOf(),s=n.substring(0,u)}else s=n;switch(!0){case s.length===8:if(i=/(\d{4})(\d{2})(\d{2})/ig,u!==-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,u!==-1){let l=60*o;this.minute=Math.floor(l),l=60*(l-this.minute),this.second=Math.floor(l),l=1e3*(l-this.second),this.millisecond=Math.floor(l)}break;case s.length===12:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})/ig,u!==-1){let l=60*o;this.second=Math.floor(l),l=1e3*(l-this.second),this.millisecond=Math.floor(l)}break;case s.length===14:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})/ig,u!==-1){let l=1e3*o;this.millisecond=Math.floor(l)}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 l=1;l<f.length;l++)switch(l){case 1:this.year=parseInt(f[l],10);break;case 2:this.month=parseInt(f[l],10);break;case 3:this.day=parseInt(f[l],10);break;case 4:this.hour=parseInt(f[l],10)+c;break;case 5:this.minute=parseInt(f[l],10)+a;break;case 6:this.second=parseInt(f[l],10);break;default:throw new Error("Wrong input string for conversion")}if(e===!1){let l=new Date(this.year,this.month,this.day,this.hour,this.minute,this.second,this.millisecond);this.year=l.getUTCFullYear(),this.month=l.getUTCMonth(),this.day=l.getUTCDay(),this.hour=l.getUTCHours(),this.minute=l.getUTCMinutes(),this.second=l.getUTCSeconds(),this.millisecond=l.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}}};gu=bs;k.GeneralizedTime=gu;bs.NAME="GeneralizedTime";var yu,ws=class extends Xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};yu=ws;k.DATE=yu;ws.NAME="DATE";var mu,xs=class extends Xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};mu=xs;k.TimeOfDay=mu;xs.NAME="TimeOfDay";var bu,vs=class extends Xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};bu=vs;k.DateTime=bu;vs.NAME="DateTime";var wu,Es=class extends Xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};wu=Es;k.Duration=wu;Es.NAME="Duration";var xu,Bs=class extends Xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};xu=Bs;k.TIME=xu;Bs.NAME="TIME";async function ks(r,t){let n=await or.create().encrypt(r,t);return be.encode(n)}async function oi(r,t,e){if(r.type==="RSA")return Lh(r,t,e);if(r.type==="Ed25519")return Nh(r,t,e);if(r.type==="secp256k1")return Th(r,t,e);if(r.type==="ECDSA")return Uh(r,t,e);throw new Ve}async function Nh(r,t,e="libp2p-key"){if(e==="libp2p-key")return ks(Ue(r),t);throw new _(`export format '${e}' is not supported`)}async function Th(r,t,e="libp2p-key"){if(e==="libp2p-key")return ks(Ue(r),t);throw new _("Export format is not supported")}async function Uh(r,t,e="libp2p-key"){if(e==="libp2p-key")return ks(Ue(r),t);throw new _(`export format '${e}' is not supported`)}async function Lh(r,t,e="pkcs-8"){if(e==="pkcs-8")return _h(r,t);if(e==="libp2p-key")return ks(Ue(r),t);throw new _("Export format is not supported")}async function _h(r,t){let e=tt.get(),s=new Et({value:[new Jt({value:0}),new Et({value:[new Vt({value:"1.2.840.113549.1.1.1"}),new _e]}),new Wt({valueHex:r.raw})]}).toBER(),o=new Uint8Array(s,0,s.byteLength),i=Te(16),c=await _n(ae,t,i,{c:1e4,dkLen:32}),a=Te(16),u=await e.subtle.importKey("raw",c,"AES-CBC",!1,["encrypt"]),f=await e.subtle.encrypt({name:"AES-CBC",iv:a},u,o),l=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 _e]})]}),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"}),l]}),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
|
-
`)}async function
|
|
6
|
+
`)}`:`${e} :`}};Hf=ve;I.Constructed=Hf;ve.NAME="CONSTRUCTED";var ls=class extends lt{fromBER(t,e,n){return e}toBER(t){return Pt}};ls.override="EndOfContentValueBlock";var Vf,hs=class extends at{constructor(t={}){super(t,ls),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};Vf=hs;I.EndOfContent=Vf;hs.NAME=an;var Kf,Pe=class extends at{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}`}};Kf=Pe;I.Null=Kf;Pe.NAME="NULL";var ds=class extends oe(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 se(this,s,e,n)?(this.valueHexView=s.subarray(e,e+n),n>1&&this.warnings.push("Boolean value encoded in more then 1 octet"),this.isHexOnly=!0,Ni.call(this),this.blockLength=n,e+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};ds.NAME="BooleanValueBlock";var Of,ps=class extends at{getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}constructor(t={}){super(t,ds),this.idBlock.tagClass=1,this.idBlock.tagNumber=1}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.getValue}`}};Of=ps;I.Boolean=Of;ps.NAME="BOOLEAN";var gs=class extends oe(Ot){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=Ot.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===an){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(i!==Tf)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?Ot.prototype.toBER.call(this,t,e):t?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};gs.NAME="OctetStringValueBlock";var _i,ee=class extends at{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,o;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((o=n.value)===null||o===void 0)&&o.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},gs),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=$s(o,0,o.byteLength);i.offset!==-1&&i.offset===n&&(this.valueBlock.value=[i.result])}}catch{}}return super.fromBER(t,e,n)}onAsciiEncoding(){if(this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length)return ve.prototype.onAsciiEncoding.call(this);let t=this.constructor.NAME,e=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 _i&&t.push(e.valueBlock.valueHexView);return q.BufferSourceConverter.concat(t)}};_i=ee;I.OctetString=_i;ee.NAME=Tf;var bs=class extends oe(Ot){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=Ot.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let a of this.value){let c=a.constructor.NAME;if(c===an){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==_f)return this.error="BIT STRING may consists of BIT STRINGs only",-1;let u=a.valueBlock;if(this.unusedBits>0&&u.unusedBits>0)return this.error='Using of "unused bits" inside constructive BIT STRING allowed for least one only',-1;this.unusedBits=u.unusedBits}return s}let o=q.BufferSourceConverter.toUint8Array(t);if(!se(this,o,e,n))return-1;let i=o.subarray(e,e+n);if(this.unusedBits=i[0],this.unusedBits>7)return this.error="Unused bits for BitString must be in range 0-7",-1;if(!this.unusedBits){let a=i.subarray(1);try{if(a.byteLength){let c=$s(a,0,a.byteLength);c.offset!==-1&&c.offset===n-1&&(this.value=[c.result])}}catch{}}return this.valueHexView=i.subarray(1),this.blockLength=i.length,e+n}toBER(t,e){if(this.isConstructed)return Ot.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}}};bs.NAME="BitStringValueBlock";var Mf,ys=class extends at{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,o;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((o=n.value)===null||o===void 0)&&o.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},bs),this.idBlock.tagClass=1,this.idBlock.tagNumber=3}fromBER(t,e,n){return this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,super.fromBER(t,e,n)}onAsciiEncoding(){if(this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length)return ve.prototype.onAsciiEncoding.call(this);{let t=[],e=this.valueBlock.valueHexView;for(let i of e)t.push(i.toString(2).padStart(8,"0"));let n=t.join(""),s=this.constructor.NAME,o=n.substring(0,n.length-this.valueBlock.unusedBits);return`${s} : ${o}`}}};Mf=ys;I.BitString=Mf;ys.NAME=_f;var Pf;function B0(r,t){let e=new Uint8Array([0]),n=new Uint8Array(r),s=new Uint8Array(t),o=n.slice(0),i=o.length-1,a=s.slice(0),c=a.length-1,u=0,l=c<i?i:c,f=0;for(let h=l;h>=0;h--,f++)!0===f<a.length?u=o[i-f]+a[c-f]+e[0]:u=o[i-f]+e[0],e[0]=u/10,!0===f>=o.length?o=ss(new Uint8Array([u%10]),o):o[i-f]=u%10;return e[0]>0&&(o=ss(e,o)),o}function Uf(r){if(r>=nn.length)for(let t=nn.length;t<=r;t++){let e=new Uint8Array([0]),n=nn[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=ss(e,n)),nn.push(n)}return nn[r]}function A0(r,t){let e=0,n=new Uint8Array(r),s=new Uint8Array(t),o=n.slice(0),i=o.length-1,a=s.slice(0),c=a.length-1,u,l=0;for(let f=c;f>=0;f--,l++)u=o[i-l]-a[c-l]-e,!0===u<0?(e=1,o[i-l]=u+10):(e=0,o[i-l]=u);if(e>0)for(let f=i-c+1;f>=0;f--,l++)if(u=o[i-l]-e,u<0)e=1,o[i-l]=u+10;else{e=0,o[i-l]=u;break}return o.slice()}var cn=class extends oe(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=Ni.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(Cf(t))}get valueDec(){return this._valueDec}fromDER(t,e,n,s=0){let o=this.fromBER(t,e,n);if(o===-1)return o;let i=this.valueHexView;return i[0]===0&&(i[1]&128)!==0?this.valueHexView=i.subarray(1):s!==0&&i.length<s&&(s-i.length>1&&(s=i.length+1),this.valueHexView=i.subarray(s-i.length)),o}toDER(t=!1){let e=this.valueHexView;switch(!0){case(e[0]&128)!==0:{let n=new Uint8Array(this.valueHexView.length+1);n[0]=0,n.set(e,1),this.valueHexView=n}break;case(e[0]===0&&(e[1]&128)===0):this.valueHexView=this.valueHexView.subarray(1);break}return this.toBER(t)}fromBER(t,e,n){let s=super.fromBER(t,e,n);return s===-1||this.setValueHex(),s}toBER(t){return t?new ArrayBuffer(this.valueHexView.length):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}toString(){let t=this.valueHexView.length*8-1,e=new Uint8Array(this.valueHexView.length*8/3),n=0,s,o=this.valueHexView,i="",a=!1;for(let c=o.byteLength-1;c>=0;c--){s=o[c];for(let u=0;u<8;u++)(s&1)===1&&(n===t?(e=A0(Uf(n),e),i="-"):e=B0(e,Uf(n))),n++,s>>=1}for(let c=0;c<e.length;c++)e[c]&&(a=!0),a&&(i+=Nf.charAt(e[c]));return a===!1&&(i+=Nf.charAt(0)),i}};Pf=cn;cn.NAME="IntegerValueBlock";Object.defineProperty(Pf.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var sn,re=class extends at{constructor(t={}){super(t,cn),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return os(),BigInt(this.valueBlock.toString())}static fromBigInt(t){os();let e=BigInt(t),n=new on,s=e.toString(16).replace(/^-/,""),o=new Uint8Array(q.Convert.FromHex(s));if(e<0){let a=new Uint8Array(o.length+(o[0]&128?1:0));a[0]|=128;let u=BigInt(`0x${q.Convert.ToHex(a)}`)+e,l=q.BufferSourceConverter.toUint8Array(q.Convert.FromHex(u.toString(16)));l[0]|=128,n.write(l)}else o[0]&128&&n.write(new Uint8Array([0])),n.write(o);return new sn({valueHex:n.final()})}convertToDER(){let t=new sn({valueHex:this.valueBlock.valueHexView});return t.valueBlock.toDER(),t}convertFromDER(){return new sn({valueHex:this.valueBlock.valueHexView[0]===0?this.valueBlock.valueHexView.subarray(1):this.valueBlock.valueHexView})}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()}`}};sn=re;I.Integer=sn;re.NAME="INTEGER";var Ff,ms=class extends re{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};Ff=ms;I.Enumerated=Ff;ms.NAME="ENUMERATED";var fn=class extends oe(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(!se(this,s,e,n))return-1;let o=s.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=o[a]&127,this.blockLength++,(o[a]&128)!==0);a++);let i=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)i[a]=this.valueHexView[a];return this.valueHexView=i,(o[this.blockLength-1]&128)!==0?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=Me(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}set valueBigInt(t){os();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=we(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Pt;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}}};fn.NAME="sidBlock";var xs=class extends lt{constructor({value:t=xr,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new fn;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,Pt;e.push(s)}return Ui(e)}fromString(t){this.value=[];let e=0,n=0,s="",o=!1;do if(n=t.indexOf(".",e),n===-1?s=t.substring(e):s=t.substring(e,n),e=n+1,o){let i=this.value[0],a=0;switch(i.valueDec){case 0:break;case 1:a=40;break;case 2:a=80;break;default:this.value=[];return}let c=parseInt(s,10);if(isNaN(c))return;i.valueDec=c+a,o=!1}else{let i=new fn;if(s>Number.MAX_SAFE_INTEGER){os();let a=BigInt(s);i.valueBigInt=a}else if(i.valueDec=parseInt(s,10),isNaN(i.valueDec))return;this.value.length||(i.isFirstSid=!0,o=!0),this.value.push(i)}while(n!==-1)}toString(){let t="",e=!1;for(let n=0;n<this.value.length;n++){e=this.value[n].isHexOnly;let s=this.value[n].toString();n!==0&&(t=`${t}.`),e?(s=`{${s}}`,this.value[n].isFirstSid?t=`2.{${s} - 80}`:t+=s):t+=s}return t}toJSON(){let t={...super.toJSON(),value:this.toString(),sidArray:[]};for(let e=0;e<this.value.length;e++)t.sidArray.push(this.value[e].toJSON());return t}};xs.NAME="ObjectIdentifierValueBlock";var qf,Mt=class extends at{getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}constructor(t={}){super(t,xs),this.idBlock.tagClass=1,this.idBlock.tagNumber=6}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};qf=Mt;I.ObjectIdentifier=qf;Mt.NAME="OBJECT IDENTIFIER";var un=class extends oe(te){constructor({valueDec:t=0,...e}={}){super(e),this.valueDec=t}fromBER(t,e,n){if(n===0)return e;let s=q.BufferSourceConverter.toUint8Array(t);if(!se(this,s,e,n))return-1;let o=s.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=o[a]&127,this.blockLength++,(o[a]&128)!==0);a++);let i=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)i[a]=this.valueHexView[a];return this.valueHexView=i,(o[this.blockLength-1]&128)!==0?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=Me(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}toBER(t){if(this.isHexOnly){if(t)return new ArrayBuffer(this.valueHexView.byteLength);let s=this.valueHexView,o=new Uint8Array(this.blockLength);for(let i=0;i<this.blockLength-1;i++)o[i]=s[i]|128;return o[this.blockLength-1]=s[this.blockLength-1],o.buffer}let e=we(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Pt;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}}};un.NAME="relativeSidBlock";var ws=class extends lt{constructor({value:t=xr,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new un;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,Pt;n.push(o)}return Ui(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 un;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}};ws.NAME="RelativeObjectIdentifierValueBlock";var $f,vs=class extends at{getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}constructor(t={}){super(t,ws),this.idBlock.tagClass=1,this.idBlock.tagNumber=13}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};$f=vs;I.RelativeObjectIdentifier=$f;vs.NAME="RelativeObjectIdentifier";var jf,Et=class extends ve{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};jf=Et;I.Sequence=jf;Et.NAME="SEQUENCE";var Gf,Es=class extends ve{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};Gf=Es;I.Set=Gf;Es.NAME="SET";var Bs=class extends oe(lt){constructor({...t}={}){super(t),this.isHexOnly=!0,this.value=xr}toJSON(){return{...super.toJSON(),value:this.value}}};Bs.NAME="StringValueBlock";var As=class extends Bs{};As.NAME="SimpleStringValueBlock";var yt=class extends cs{constructor({...t}={}){super(t,As)}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 Ss=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}};Ss.NAME="Utf8StringValueBlock";var Zf,ne=class extends Ss{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};Zf=ne;I.Utf8String=Zf;ne.NAME="UTF8String";var ks=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))}};ks.NAME="BmpStringValueBlock";var Yf,Is=class extends ks{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};Yf=Is;I.BmpString=Yf;Is.NAME="BMPString";var Cs=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=we(t.charCodeAt(s),8),i=new Uint8Array(o);if(i.length>4)continue;let a=4-i.length;for(let c=i.length-1;c>=0;c--)n[s*4+c+a]=i[c]}this.valueBlock.value=t}};Cs.NAME="UniversalStringValueBlock";var Wf,Ls=class extends Cs{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};Wf=Ls;I.UniversalString=Wf;Ls.NAME="UniversalString";var zf,Ns=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};zf=Ns;I.NumericString=zf;Ns.NAME="NumericString";var Jf,Us=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};Jf=Us;I.PrintableString=Jf;Us.NAME="PrintableString";var Xf,Ts=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};Xf=Ts;I.TeletexString=Xf;Ts.NAME="TeletexString";var Qf,_s=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};Qf=_s;I.VideotexString=Qf;_s.NAME="VideotexString";var tu,Rs=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};tu=Rs;I.IA5String=tu;Rs.NAME="IA5String";var eu,Ds=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};eu=Ds;I.GraphicString=eu;Ds.NAME="GraphicString";var ru,ln=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};ru=ln;I.VisibleString=ru;ln.NAME="VisibleString";var nu,Hs=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};nu=Hs;I.GeneralString=nu;Hs.NAME="GeneralString";var su,Vs=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};su=Vs;I.CharacterString=su;Vs.NAME="CharacterString";var ou,hn=class extends ln{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}}};ou=hn;I.UTCTime=ou;hn.NAME="UTCTime";var iu,Ks=class extends hn{constructor(t={}){var e;super(t),(e=this.millisecond)!==null&&e!==void 0||(this.millisecond=0),this.idBlock.tagClass=1,this.idBlock.tagNumber=24}fromDate(t){super.fromDate(t),this.millisecond=t.getUTCMilliseconds()}toDate(){let t=Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second,this.millisecond);return new Date(t)}fromString(t){let e=!1,n="",s="",o=0,i,a=0,c=0;if(t[t.length-1]==="Z")n=t.substring(0,t.length-1),e=!0;else{let f=new Number(t[t.length-1]);if(isNaN(f.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 f=1,h=n.indexOf("+"),p="";if(h===-1&&(h=n.indexOf("-"),f=-1),h!==-1){if(p=n.substring(h+1),n=n.substring(0,h),p.length!==2&&p.length!==4)throw new Error("Wrong input string for conversion");let d=parseInt(p.substring(0,2),10);if(isNaN(d.valueOf()))throw new Error("Wrong input string for conversion");if(a=f*d,p.length===4){if(d=parseInt(p.substring(2,4),10),isNaN(d.valueOf()))throw new Error("Wrong input string for conversion");c=f*d}}}let u=n.indexOf(".");if(u===-1&&(u=n.indexOf(",")),u!==-1){let f=new Number(`0${n.substring(u)}`);if(isNaN(f.valueOf()))throw new Error("Wrong input string for conversion");o=f.valueOf(),s=n.substring(0,u)}else s=n;switch(!0){case s.length===8:if(i=/(\d{4})(\d{2})(\d{2})/ig,u!==-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,u!==-1){let f=60*o;this.minute=Math.floor(f),f=60*(f-this.minute),this.second=Math.floor(f),f=1e3*(f-this.second),this.millisecond=Math.floor(f)}break;case s.length===12:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})/ig,u!==-1){let f=60*o;this.second=Math.floor(f),f=1e3*(f-this.second),this.millisecond=Math.floor(f)}break;case s.length===14:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})/ig,u!==-1){let f=1e3*o;this.millisecond=Math.floor(f)}break;default:throw new Error("Wrong input string for conversion")}let l=i.exec(s);if(l===null)throw new Error("Wrong input string for conversion");for(let f=1;f<l.length;f++)switch(f){case 1:this.year=parseInt(l[f],10);break;case 2:this.month=parseInt(l[f],10);break;case 3:this.day=parseInt(l[f],10);break;case 4:this.hour=parseInt(l[f],10)+a;break;case 5:this.minute=parseInt(l[f],10)+c;break;case 6:this.second=parseInt(l[f],10);break;default:throw new Error("Wrong input string for conversion")}if(e===!1){let f=new Date(this.year,this.month,this.day,this.hour,this.minute,this.second,this.millisecond);this.year=f.getUTCFullYear(),this.month=f.getUTCMonth(),this.day=f.getUTCDay(),this.hour=f.getUTCHours(),this.minute=f.getUTCMinutes(),this.second=f.getUTCSeconds(),this.millisecond=f.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}}};iu=Ks;I.GeneralizedTime=iu;Ks.NAME="GeneralizedTime";var au,Os=class extends ne{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};au=Os;I.DATE=au;Os.NAME="DATE";var cu,Ms=class extends ne{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};cu=Ms;I.TimeOfDay=cu;Ms.NAME="TimeOfDay";var fu,Ps=class extends ne{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};fu=Ps;I.DateTime=fu;Ps.NAME="DateTime";var uu,Fs=class extends ne{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};uu=Fs;I.Duration=uu;Fs.NAME="Duration";var lu,qs=class extends ne{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};lu=qs;I.TIME=lu;qs.NAME="TIME";async function Gs(r,t){let n=await yr.create().encrypt(r,t);return Be.encode(n)}async function Ri(r,t,e){if(r.type==="RSA")return C0(r,t,e);if(r.type==="Ed25519")return S0(r,t,e);if(r.type==="secp256k1")return k0(r,t,e);if(r.type==="ECDSA")return I0(r,t,e);throw new je}async function S0(r,t,e="libp2p-key"){if(e==="libp2p-key")return Gs(Oe(r),t);throw new R(`export format '${e}' is not supported`)}async function k0(r,t,e="libp2p-key"){if(e==="libp2p-key")return Gs(Oe(r),t);throw new R("Export format is not supported")}async function I0(r,t,e="libp2p-key"){if(e==="libp2p-key")return Gs(Oe(r),t);throw new R(`export format '${e}' is not supported`)}async function C0(r,t,e="pkcs-8"){if(e==="pkcs-8")return L0(r,t);if(e==="libp2p-key")return Gs(Oe(r),t);throw new R("Export format is not supported")}async function L0(r,t){let e=tt.get(),s=new Et({value:[new re({value:0}),new Et({value:[new Mt({value:"1.2.840.113549.1.1.1"}),new Pe]}),new ee({valueHex:r.raw})]}).toBER(),o=new Uint8Array(s,0,s.byteLength),i=De(16),a=await Qn(pr,t,i,{c:1e4,dkLen:32}),c=De(16),u=await e.subtle.importKey("raw",a,"AES-CBC",!1,["encrypt"]),l=await e.subtle.encrypt({name:"AES-CBC",iv:c},u,o),f=new Et({value:[new ee({valueHex:i}),new re({value:1e4}),new re({value:32}),new Et({value:[new Mt({value:"1.2.840.113549.2.11"}),new Pe]})]}),h=new Et({value:[new Mt({value:"1.2.840.113549.1.5.13"}),new Et({value:[new Et({value:[new Mt({value:"1.2.840.113549.1.5.12"}),f]}),new Et({value:[new Mt({value:"2.16.840.1.101.3.4.1.42"}),new ee({valueHex:c})]})]})]}),d=new Et({value:[h,new ee({valueHex:l})]}).toBER(),E=new Uint8Array(d,0,d.byteLength);return["-----BEGIN ENCRYPTED PRIVATE KEY-----",...$(E,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
|
|
7
|
+
`)}async function Di(r,t){try{let e=await N0(r,t);return ff(e)}catch{}if(!r.includes("BEGIN"))throw new R("Encrypted key was not a libp2p-key or a PEM file");return U0(r,t)}async function N0(r,t){let e=Be.decode(r);return yr.create().decrypt(e,t)}async function U0(r,t){let e=tt.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}=js(o),{iv:a,salt:c,iterations:u,keySize:l,cipherText:f}=T0(i),h=await Qn(pr,t,c,{c:u,dkLen:l}),p=await e.subtle.importKey("raw",h,"AES-CBC",!1,["decrypt"]),d=dn(await e.subtle.decrypt({name:"AES-CBC",iv:a},p,f)),{result:E}=js(d);n=gu(E)}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}=js(o);n=gu(i)}else throw new R("Could not parse private key from PEM data");let s=uf(n);if(s.type!=="RSA")throw new R("Could not parse RSA private key from PEM data");return s}function T0(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=dn(o.valueBlock.value[0].getValue()),a=1e4,c=32;if(o.valueBlock.value.length===3)a=Number(o.valueBlock.value[1].toBigInt()),c=Number(o.valueBlock.value[2].toBigInt());else if(o.valueBlock.value.length===2)throw new R("Could not derive key size and iterations from PEM file - please use @libp2p/rsa to re-import your key");let u=t.valueBlock.value[1].valueBlock.value[1],l=u.valueBlock.value[0].toString();if(l!=="OBJECT IDENTIFIER : 1.2.840.113549.3.7"){if(l!=="OBJECT IDENTIFIER : 1.3.14.3.2.7"){if(l!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.2"){if(l!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.22"){if(l!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.42")throw new R("Only AES-CBC encryption schemes are supported")}}}}let f=dn(u.valueBlock.value[1].getValue());return{cipherText:dn(r.valueBlock.value[1].getValue()),salt:i,iterations:a,keySize:c,iv:f}}function gu(r){return dn(r.valueBlock.value[2].getValue())}function dn(r){return new Uint8Array(r,0,r.byteLength)}var _0="/pkcs8/",Hi="/info/",pn=new WeakMap,Fe={minKeyLength:112/8,minSaltLength:128/8,minIterationCount:1e3};function wr(r){return r==null||typeof r!="string"?!1:r===(0,bu.default)(r.trim())&&r.length>0}async function ct(){let e=Math.random()*800+200;await new Promise(n=>setTimeout(n,e))}function qe(r){return new rn(_0+r)}function vr(r){return new rn(Hi+r)}async function R0(r){let t=Oe(r),e=await Xe.digest(t);return et.encode(e.bytes).substring(1)}var Zs=class{components;init;log;self;constructor(t,e){if(this.components=t,this.log=t.logger.forComponent("libp2p:keychain"),this.init={...e,dek:{...Ci,...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<Fe.minKeyLength)throw new Error(`dek.keyLength must be least ${Fe.minKeyLength} bytes`);if(this.init.dek?.salt?.length!=null&&this.init.dek.salt.length<Fe.minSaltLength)throw new Error(`dek.saltLength must be least ${Fe.minSaltLength} bytes`);if(this.init.dek?.iterationCount!=null&&this.init.dek.iterationCount<Fe.minIterationCount)throw new Error(`dek.iterationCount must be least ${Fe.minIterationCount}`);let n=this.init.pass!=null&&this.init.dek?.salt!=null?en(this.init.pass,this.init.dek?.salt,this.init.dek?.iterationCount,this.init.dek?.keyLength,this.init.dek?.hash):"";pn.set(this,{dek:n})}[Symbol.toStringTag]="@libp2p/keychain";[Fi]=["@libp2p/keychain"];static generateOptions(){let t=Object.assign({},this.options),e=Math.ceil(Fe.minSaltLength/3)*3;return t.dek!=null&&(t.dek.salt=$(De(e),"base64")),t}static get options(){return{dek:{...Ci}}}async findKeyByName(t){if(!wr(t))throw await ct(),new R(`Invalid key name '${t}'`);let e=vr(t);try{let n=await this.components.datastore.get(e);return JSON.parse($(n))}catch(n){throw await ct(),this.log.error("could not read key from datastore - %e",n),new mn(`Key '${t}' does not exist.`)}}async findKeyById(t){try{let e={prefix:Hi};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 ct(),e}}async importKey(t,e){if(!wr(t))throw await ct(),new R(`Invalid key name '${t}'`);if(e==null)throw await ct(),new R("Key is required");let n=qe(t);if(await this.components.datastore.has(n))throw await ct(),new R(`Key '${t}' already exists`);let o,i;try{o=await R0(e);let u=pn.get(this);if(u==null)throw new R("dek missing");let l=u.dek;i=await Ri(e,l,e.type==="RSA"?"pkcs-8":"libp2p-key")}catch(u){throw await ct(),u}let a={name:t,id:o},c=this.components.datastore.batch();return c.put(n,F(i)),c.put(vr(t),F(JSON.stringify(a))),await c.commit(),a}async exportKey(t){if(!wr(t))throw await ct(),new R(`Invalid key name '${t}'`);let e=qe(t);try{let n=await this.components.datastore.get(e),s=$(n),o=pn.get(this);if(o==null)throw new R("dek missing");let i=o.dek;return await Di(s,i)}catch(n){throw await ct(),n}}async removeKey(t){if(!wr(t)||t===this.self)throw await ct(),new R(`Invalid key name '${t}'`);let e=qe(t),n=await this.findKeyByName(t),s=this.components.datastore.batch();return s.delete(e),s.delete(vr(t)),await s.commit(),n}async listKeys(){let t={prefix:Hi},e=[];for await(let n of this.components.datastore.query(t))e.push(JSON.parse($(n.value)));return e}async renameKey(t,e){if(!wr(t)||t===this.self)throw await ct(),new R(`Invalid old key name '${t}'`);if(!wr(e)||e===this.self)throw await ct(),new R(`Invalid new key name '${e}'`);let n=qe(t),s=qe(e),o=vr(t),i=vr(e);if(await this.components.datastore.has(s))throw await ct(),new R(`Key '${e}' already exists`);try{let c=await this.components.datastore.get(n),u=await this.components.datastore.get(o),l=JSON.parse($(u));l.name=e;let f=this.components.datastore.batch();return f.put(s,c),f.put(i,F(JSON.stringify(l))),f.delete(n),f.delete(o),await f.commit(),l}catch(c){throw await ct(),c}}async rotateKeychainPass(t,e){if(typeof t!="string")throw await ct(),new R(`Invalid old pass type '${typeof t}'`);if(typeof e!="string")throw await ct(),new R(`Invalid new pass type '${typeof e}'`);if(e.length<20)throw await ct(),new R(`Invalid pass length ${e.length}`);this.log("recreating keychain");let n=pn.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?en(e,this.init.dek.salt,this.init.dek?.iterationCount,this.init.dek?.keyLength,this.init.dek?.hash):"";pn.set(this,{dek:o});let i=await this.listKeys();for(let a of i){let c=await this.components.datastore.get(qe(a.name)),u=$(c),l=await Di(u,s),f=o.toString(),h=await Ri(l,f,l.type==="RSA"?"pkcs-8":"libp2p-key"),p=this.components.datastore.batch(),d={name:a.name,id:a.id};p.put(qe(a.name),F(h)),p.put(vr(a.name),F(JSON.stringify(d))),await p.commit()}this.log("keychain reconstructed")}};function D0(r={}){return t=>new Zs(t,r)}return Eu(H0);})();
|
|
8
8
|
/*! Bundled license information:
|
|
9
9
|
|
|
10
10
|
pvtsutils/build/index.js:
|