@libp2p/crypto 5.0.1 → 5.0.2-7f7ec82ae

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.min.js CHANGED
@@ -1,9 +1,9 @@
1
1
  (function (root, factory) {(typeof module === 'object' && module.exports) ? module.exports = factory() : root.Libp2PCrypto = factory()}(typeof self !== 'undefined' ? self : this, function () {
2
- "use strict";var Libp2PCrypto=(()=>{var oc=Object.create;var Tr=Object.defineProperty;var ic=Object.getOwnPropertyDescriptor;var ac=Object.getOwnPropertyNames;var cc=Object.getPrototypeOf,lc=Object.prototype.hasOwnProperty;var uc=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),it=(r,t)=>{for(var e in t)Tr(r,e,{get:t[e],enumerable:!0})},Io=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of ac(t))!lc.call(r,s)&&s!==e&&Tr(r,s,{get:()=>t[s],enumerable:!(n=ic(t,s))||n.enumerable});return r};var fc=(r,t,e)=>(e=r!=null?oc(cc(r)):{},Io(t||!r||!r.__esModule?Tr(e,"default",{value:r,enumerable:!0}):e,r)),hc=r=>Io(Tr({},"__esModule",{value:!0}),r);var _i=uc(je=>{"use strict";var Vu="[object ArrayBuffer]",zt=class r{static isArrayBuffer(t){return Object.prototype.toString.call(t)===Vu}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}},to="string",Ou=/^[0-9a-f]+$/i,Du=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,Mu=/^[a-zA-Z0-9-_]+$/,nn=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=zt.toUint8Array(t),n="";for(let o=0;o<e.length;o++)n+=String.fromCharCode(e[o]);return decodeURIComponent(escape(n))}},Bt=class{static toString(t,e=!1){let n=zt.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}},sn=class r{static isHex(t){return typeof t===to&&Ou.test(t)}static isBase64(t){return typeof t===to&&Du.test(t)}static isBase64Url(t){return typeof t===to&&Mu.test(t)}static ToString(t,e="utf8"){let n=zt.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 Bt.toString(n,!0);case"utf16":case"utf16be":return Bt.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 Bt.fromString(t,!0);case"utf16":case"utf16be":return Bt.fromString(t);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToBase64(t){let e=zt.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 nn.fromString(t);case"utf16":case"utf16be":return Bt.fromString(t);case"utf16le":case"usc2":return Bt.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 nn.toString(t);case"utf16":case"utf16be":return Bt.toString(t);case"utf16le":case"usc2":return Bt.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=zt.toUint8Array(t),n="";for(let s=0;s<e.length;s++)n+=String.fromCharCode(e[s]);return n}static ToHex(t){let e=zt.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 Bt.toString(t,e)}static FromUtf16String(t,e=!1){return Bt.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,"")||""}};sn.DEFAULT_UTF8_ENCODING="utf8";function Ku(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 Pu(...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 Fu(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}je.BufferSourceConverter=zt;je.Convert=sn;je.assign=Ku;je.combine=Pu;je.isEqual=Fu});var vf={};it(vf,{hmac:()=>Lr,keys:()=>yo,pbkdf2:()=>xo,randomBytes:()=>oo});var Lr={};it(Lr,{create:()=>Qn});var tr=class extends Error{constructor(t="An error occurred while signing a message"){super(t),this.name="SigningError"}},er=class extends Error{constructor(t="An error occurred while verifying a message"){super(t),this.name="VerificationError"}},Rr=class extends Error{constructor(t="Missing Web Crypto API"){super(t),this.name="WebCryptoMissingError"}};var No={get(r=globalThis){let t=r.crypto;if(t?.subtle==null)throw new Rr("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 at=No;var Co={SHA1:20,SHA256:32,SHA512:64};var dc={SHA1:"SHA-1",SHA256:"SHA-256",SHA512:"SHA-512"},gc=async(r,t)=>{let e=await at.get().subtle.sign({name:"HMAC"},r,t);return new Uint8Array(e,0,e.byteLength)};async function Qn(r,t){let e=dc[r],n=await at.get().subtle.importKey("raw",t,{name:"HMAC",hash:{name:e}},!1,["sign"]);return{async digest(s){return gc(n,s)},length:Co[r]}}var yo={};it(yo,{generateEphemeralKeyPair:()=>qa,generateKeyPair:()=>ff,generateKeyPairFromSeed:()=>hf,keyStretcher:()=>Ga,privateKeyFromProtobuf:()=>mf,privateKeyFromRaw:()=>yf,privateKeyToProtobuf:()=>bf,publicKeyFromMultihash:()=>pf,publicKeyFromProtobuf:()=>df,publicKeyFromRaw:()=>gf,publicKeyToProtobuf:()=>hr});var $=class extends Error{static name="InvalidParametersError";constructor(t="Invalid parameters"){super(t),this.name="InvalidParametersError"}},Ne=class extends Error{static name="InvalidPublicKeyError";constructor(t="Invalid public key"){super(t),this.name="InvalidPublicKeyError"}},rr=class extends Error{static name="InvalidPrivateKeyError";constructor(t="Invalid private key"){super(t),this.name="InvalidPrivateKeyError"}};var Qt=class extends Error{static name="UnsupportedKeyTypeError";constructor(t="Unsupported key type"){super(t),this.name="UnsupportedKeyTypeError"}};var ss={};it(ss,{base58btc:()=>ut,base58flickr:()=>wc});var Rf=new Uint8Array(0);function Uo(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 Kt(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 To(r){return new TextEncoder().encode(r)}function Ro(r){return new TextDecoder().decode(r)}function pc(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(w){if(w instanceof Uint8Array||(ArrayBuffer.isView(w)?w=new Uint8Array(w.buffer,w.byteOffset,w.byteLength):Array.isArray(w)&&(w=Uint8Array.from(w))),!(w instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(w.length===0)return"";for(var y=0,d=0,b=0,B=w.length;b!==B&&w[b]===0;)b++,y++;for(var p=(B-b)*l+1>>>0,S=new Uint8Array(p);b!==B;){for(var R=w[b],T=0,k=p-1;(R!==0||T<d)&&k!==-1;k--,T++)R+=256*S[k]>>>0,S[k]=R%a>>>0,R=R/a>>>0;if(R!==0)throw new Error("Non-zero carry");d=T,b++}for(var I=p-d;I!==p&&S[I]===0;)I++;for(var U=c.repeat(y);I<p;++I)U+=r.charAt(S[I]);return U}function h(w){if(typeof w!="string")throw new TypeError("Expected String");if(w.length===0)return new Uint8Array;var y=0;if(w[y]!==" "){for(var d=0,b=0;w[y]===c;)d++,y++;for(var B=(w.length-y)*u+1>>>0,p=new Uint8Array(B);w[y];){var S=e[w.charCodeAt(y)];if(S===255)return;for(var R=0,T=B-1;(S!==0||R<b)&&T!==-1;T--,R++)S+=a*p[T]>>>0,p[T]=S%256>>>0,S=S/256>>>0;if(S!==0)throw new Error("Non-zero carry");b=R,y++}if(w[y]!==" "){for(var k=B-b;k!==B&&p[k]===0;)k++;for(var I=new Uint8Array(d+(B-k)),U=d;k!==B;)I[U++]=p[k++];return I}}}function v(w){var y=h(w);if(y)return y;throw new Error(`Non-${t} character`)}return{encode:f,decodeUnsafe:h,decode:v}}var mc=pc,yc=mc,Ho=yc;var ts=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")}},es=class{name;prefix;baseDecode;prefixCodePoint;constructor(t,e,n){if(this.name=t,this.prefix=e,e.codePointAt(0)===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=e.codePointAt(0),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 _o(this,t)}},rs=class{decoders;constructor(t){this.decoders=t}or(t){return _o(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 _o(r,t){return new rs({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var ns=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(t,e,n,s){this.name=t,this.prefix=e,this.baseEncode=n,this.baseDecode=s,this.encoder=new ts(t,e,n),this.decoder=new es(t,e,s)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function Ce({name:r,prefix:t,encode:e,decode:n}){return new ns(r,t,e,n)}function te({name:r,prefix:t,alphabet:e}){let{encode:n,decode:s}=Ho(e,r);return Ce({prefix:t,name:r,encode:n,decode:o=>Kt(s(o))})}function bc(r,t,e,n){let s={};for(let l=0;l<t.length;++l)s[t[l]]=l;let o=r.length;for(;r[o-1]==="=";)--o;let i=new Uint8Array(o*e/8|0),a=0,c=0,u=0;for(let l=0;l<o;++l){let f=s[r[l]];if(f===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<e|f,a+=e,a>=8&&(a-=8,i[u++]=255&c>>a)}if(a>=e||255&c<<8-a)throw new SyntaxError("Unexpected end of data");return i}function xc(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;)o+="=";return o}function W({name:r,prefix:t,bitsPerChar:e,alphabet:n}){return Ce({prefix:t,name:r,encode(s){return xc(s,n,e)},decode(s){return bc(s,n,e,r)}})}var ut=te({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),wc=te({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var os={};it(os,{base32:()=>Ue,base32hex:()=>Ac,base32hexpad:()=>kc,base32hexpadupper:()=>Ic,base32hexupper:()=>Sc,base32pad:()=>Bc,base32padupper:()=>Ec,base32upper:()=>vc,base32z:()=>Nc});var Ue=W({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),vc=W({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Bc=W({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),Ec=W({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),Ac=W({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),Sc=W({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),kc=W({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),Ic=W({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),Nc=W({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Cc=Do,Vo=128,Uc=127,Tc=~Uc,Rc=Math.pow(2,31);function Do(r,t,e){t=t||[],e=e||0;for(var n=e;r>=Rc;)t[e++]=r&255|Vo,r/=128;for(;r&Tc;)t[e++]=r&255|Vo,r>>>=7;return t[e]=r|0,Do.bytes=e-n+1,t}var Lc=is,Hc=128,Oo=127;function is(r,n){var e=0,n=n||0,s=0,o=n,i,a=r.length;do{if(o>=a)throw is.bytes=0,new RangeError("Could not decode varint");i=r[o++],e+=s<28?(i&Oo)<<s:(i&Oo)*Math.pow(2,s),s+=7}while(i>=Hc);return is.bytes=o-n,e}var _c=Math.pow(2,7),Vc=Math.pow(2,14),Oc=Math.pow(2,21),Dc=Math.pow(2,28),Mc=Math.pow(2,35),Kc=Math.pow(2,42),Pc=Math.pow(2,49),Fc=Math.pow(2,56),$c=Math.pow(2,63),qc=function(r){return r<_c?1:r<Vc?2:r<Oc?3:r<Dc?4:r<Mc?5:r<Kc?6:r<Pc?7:r<Fc?8:r<$c?9:10},zc={encode:Cc,decode:Lc,encodingLength:qc},jc=zc,nr=jc;function sr(r,t=0){return[nr.decode(r,t),nr.decode.bytes]}function Te(r,t,e=0){return nr.encode(r,t,e),t}function Re(r){return nr.encodingLength(r)}function At(r,t){let e=t.byteLength,n=Re(r),s=n+Re(e),o=new Uint8Array(s+e);return Te(r,o,0),Te(e,o,n),o.set(t,s),new Le(r,e,t,o)}function Mo(r){let t=Kt(r),[e,n]=sr(t),[s,o]=sr(t.subarray(n)),i=t.subarray(n+o);if(i.byteLength!==s)throw new Error("Incorrect length");return new Le(e,s,i,t)}function Ko(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&Uo(r.bytes,e.bytes)}}var Le=class{code;size;digest;bytes;constructor(t,e,n,s){this.code=t,this.size=e,this.digest=n,this.bytes=s}};function Po(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return Zc(e,as(r),t??ut.encoder);default:return Wc(e,as(r),t??Ue.encoder)}}var Fo=new WeakMap;function as(r){let t=Fo.get(r);if(t==null){let e=new Map;return Fo.set(r,e),e}return t}var Tt=class r{code;version;multihash;bytes;"/";constructor(t,e,n,s){this.code=e,this.version=t,this.multihash=n,this.bytes=s,this["/"]=s}get asCID(){return this}get byteOffset(){return this.bytes.byteOffset}get byteLength(){return this.bytes.byteLength}toV0(){switch(this.version){case 0:return this;case 1:{let{code:t,multihash:e}=this;if(t!==ir)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==Jc)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=At(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&&Ko(t.multihash,n.multihash)}toString(t){return Po(this,t)}toJSON(){return{"/":Po(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??$o(n,s,o.bytes))}else if(e[Yc]===!0){let{version:n,multihash:s,code:o}=e,i=Mo(s);return r.create(n,o,i)}else return null}static create(t,e,n){if(typeof e!="number")throw new Error("String codecs are no longer supported");if(!(n.bytes instanceof Uint8Array))throw new Error("Invalid digest");switch(t){case 0:{if(e!==ir)throw new Error(`Version 0 CID must use dag-pb (code: ${ir}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let s=$o(t,e,n.bytes);return new r(t,e,n,s)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,ir,t)}static createV1(t,e){return r.create(1,t,e)}static decode(t){let[e,n]=r.decodeFirst(t);if(n.length!==0)throw new Error("Incorrect length");return e}static decodeFirst(t){let e=r.inspectBytes(t),n=e.size-e.multihashSize,s=Kt(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 Le(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]=sr(t.subarray(e));return e+=h,f},s=n(),o=ir;if(s===18?(s=0,e=0):o=n(),s!==0&&s!==1)throw new RangeError(`Invalid CID version ${s}`);let i=e,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]=Gc(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 as(o).set(n,t),o}};function Gc(r,t){switch(r[0]){case"Q":{let e=t??ut;return[ut.prefix,e.decode(`${ut.prefix}${r}`)]}case ut.prefix:{let e=t??ut;return[ut.prefix,e.decode(r)]}case Ue.prefix:{let e=t??Ue;return[Ue.prefix,e.decode(r)]}default:{if(t==null)throw Error("To parse non base32 or base58btc encoded CID multibase decoder must be provided");return[r[0],t.decode(r)]}}}function Zc(r,t,e){let{prefix:n}=e;if(n!==ut.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 Wc(r,t,e){let{prefix:n}=e,s=t.get(n);if(s==null){let o=e.encode(r);return t.set(n,o),o}else return s}var ir=112,Jc=18;function $o(r,t,e){let n=Re(r),s=n+Re(t),o=new Uint8Array(s+e.byteLength);return Te(r,o,0),Te(t,o,n),o.set(e,s),o}var Yc=Symbol.for("@ipld/js-cid/CID");var cs={};it(cs,{identity:()=>ar});var qo=0,Xc="identity",zo=Kt;function Qc(r){return At(qo,zo(r))}var ar={code:qo,name:Xc,encode:zo,digest:Qc};function St(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 He(r){if(!Number.isSafeInteger(r)||r<0)throw new Error(`positive integer expected, not ${r}`)}function tl(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function _e(r,...t){if(!tl(r))throw new Error("Uint8Array expected");if(t.length>0&&!t.includes(r.length))throw new Error(`Uint8Array expected of length ${t}, not of length=${r.length}`)}function _r(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");He(r.outputLen),He(r.blockLen)}function Ve(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 jo(r,t){_e(r);let e=t.outputLen;if(r.length<e)throw new Error(`digestInto() expects output buffer of length at least ${e}`)}var ye=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;var De=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),kt=(r,t)=>r<<32-t|r>>>t,Vr=(r,t)=>r<<t|r>>>32-t>>>0,Qf=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;function Go(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function ee(r){return typeof r=="string"&&(r=Go(r)),_e(r),r}function ls(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];_e(s),t+=s.length}let e=new Uint8Array(t);for(let n=0,s=0;n<r.length;n++){let o=r[n];e.set(o,s),s+=o.length}return e}var Oe=class{clone(){return this._cloneInto()}},el={}.toString;function Zo(r,t){if(t!==void 0&&el.call(t)!=="[object Object]")throw new Error("Options should be object or undefined");return Object.assign(r,t)}function Me(r){let t=n=>r().update(ee(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function Ke(r=32){if(ye&&typeof ye.getRandomValues=="function")return ye.getRandomValues(new Uint8Array(r));if(ye&&typeof ye.randomBytes=="function")return ye.randomBytes(r);throw new Error("crypto.getRandomValues must be defined")}function rl(r,t,e,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(t,e,n);let s=BigInt(32),o=BigInt(4294967295),i=Number(e>>s&o),a=Number(e&o),c=n?4:0,u=n?0:4;r.setUint32(t+c,i,n),r.setUint32(t+u,a,n)}var Or=(r,t,e)=>r&t^~r&e,Dr=(r,t,e)=>r&t^r&e^t&e,re=class extends Oe{constructor(t,e,n,s){super(),this.blockLen=t,this.outputLen=e,this.padOffset=n,this.isLE=s,this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.buffer=new Uint8Array(t),this.view=De(this.buffer)}update(t){Ve(this);let{view:e,buffer:n,blockLen:s}=this;t=ee(t);let o=t.length;for(let i=0;i<o;){let a=Math.min(s-this.pos,o-i);if(a===s){let c=De(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){Ve(this),jo(t,this),this.finished=!0;let{buffer:e,view:n,blockLen:s,isLE:o}=this,{pos:i}=this;e[i++]=128,this.buffer.subarray(i).fill(0),this.padOffset>s-i&&(this.process(n,0),i=0);for(let f=i;f<s;f++)e[f]=0;rl(n,s-8,BigInt(this.length*8),o),this.process(n,0);let a=De(t),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should 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||(t=new this.constructor),t.set(...this.get());let{blockLen:e,buffer:n,length:s,finished:o,destroyed:i,pos:a}=this;return t.length=s,t.pos=a,t.finished=o,t.destroyed=i,s%e&&t.buffer.set(n),t}};var Mr=BigInt(4294967295),us=BigInt(32);function Wo(r,t=!1){return t?{h:Number(r&Mr),l:Number(r>>us&Mr)}:{h:Number(r>>us&Mr)|0,l:Number(r&Mr)|0}}function nl(r,t=!1){let e=new Uint32Array(r.length),n=new Uint32Array(r.length);for(let s=0;s<r.length;s++){let{h:o,l:i}=Wo(r[s],t);[e[s],n[s]]=[o,i]}return[e,n]}var sl=(r,t)=>BigInt(r>>>0)<<us|BigInt(t>>>0),ol=(r,t,e)=>r>>>e,il=(r,t,e)=>r<<32-e|t>>>e,al=(r,t,e)=>r>>>e|t<<32-e,cl=(r,t,e)=>r<<32-e|t>>>e,ll=(r,t,e)=>r<<64-e|t>>>e-32,ul=(r,t,e)=>r>>>e-32|t<<64-e,fl=(r,t)=>t,hl=(r,t)=>r,dl=(r,t,e)=>r<<e|t>>>32-e,gl=(r,t,e)=>t<<e|r>>>32-e,pl=(r,t,e)=>t<<e-32|r>>>64-e,ml=(r,t,e)=>r<<e-32|t>>>64-e;function yl(r,t,e,n){let s=(t>>>0)+(n>>>0);return{h:r+e+(s/2**32|0)|0,l:s|0}}var bl=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),xl=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,wl=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),vl=(r,t,e,n,s)=>t+e+n+s+(r/2**32|0)|0,Bl=(r,t,e,n,s)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(s>>>0),El=(r,t,e,n,s,o)=>t+e+n+s+o+(r/2**32|0)|0;var Al={fromBig:Wo,split:nl,toBig:sl,shrSH:ol,shrSL:il,rotrSH:al,rotrSL:cl,rotrBH:ll,rotrBL:ul,rotr32H:fl,rotr32L:hl,rotlSH:dl,rotlSL:gl,rotlBH:pl,rotlBL:ml,add:yl,add3L:bl,add3H:xl,add4L:wl,add4H:vl,add5H:El,add5L:Bl},_=Al;var[Sl,kl]=_.split(["0x428a2f98d728ae22","0x7137449123ef65cd","0xb5c0fbcfec4d3b2f","0xe9b5dba58189dbbc","0x3956c25bf348b538","0x59f111f1b605d019","0x923f82a4af194f9b","0xab1c5ed5da6d8118","0xd807aa98a3030242","0x12835b0145706fbe","0x243185be4ee4b28c","0x550c7dc3d5ffb4e2","0x72be5d74f27b896f","0x80deb1fe3b1696b1","0x9bdc06a725c71235","0xc19bf174cf692694","0xe49b69c19ef14ad2","0xefbe4786384f25e3","0x0fc19dc68b8cd5b5","0x240ca1cc77ac9c65","0x2de92c6f592b0275","0x4a7484aa6ea6e483","0x5cb0a9dcbd41fbd4","0x76f988da831153b5","0x983e5152ee66dfab","0xa831c66d2db43210","0xb00327c898fb213f","0xbf597fc7beef0ee4","0xc6e00bf33da88fc2","0xd5a79147930aa725","0x06ca6351e003826f","0x142929670a0e6e70","0x27b70a8546d22ffc","0x2e1b21385c26c926","0x4d2c6dfc5ac42aed","0x53380d139d95b3df","0x650a73548baf63de","0x766a0abb3c77b2a8","0x81c2c92e47edaee6","0x92722c851482353b","0xa2bfe8a14cf10364","0xa81a664bbc423001","0xc24b8b70d0f89791","0xc76c51a30654be30","0xd192e819d6ef5218","0xd69906245565a910","0xf40e35855771202a","0x106aa07032bbd1b8","0x19a4c116b8d2d0c8","0x1e376c085141ab53","0x2748774cdf8eeb99","0x34b0bcb5e19b48a8","0x391c0cb3c5c95a63","0x4ed8aa4ae3418acb","0x5b9cca4f7763e373","0x682e6ff3d6b2b8a3","0x748f82ee5defb2fc","0x78a5636f43172f60","0x84c87814a1f0ab72","0x8cc702081a6439ec","0x90befffa23631e28","0xa4506cebde82bde9","0xbef9a3f7b2c67915","0xc67178f2e372532b","0xca273eceea26619c","0xd186b8c721c0c207","0xeada7dd6cde0eb1e","0xf57d4f7fee6ed178","0x06f067aa72176fba","0x0a637dc5a2c898a6","0x113f9804bef90dae","0x1b710b35131c471b","0x28db77f523047d84","0x32caab7b40c72493","0x3c9ebe0a15c9bebc","0x431d67c49c100d4c","0x4cc5d4becb3e42b6","0x597f299cfc657e2a","0x5fcb6fab3ad6faec","0x6c44198c4a475817"].map(r=>BigInt(r))),ne=new Uint32Array(80),se=new Uint32Array(80),fs=class extends re{constructor(){super(128,64,16,!1),this.Ah=1779033703,this.Al=-205731576,this.Bh=-1150833019,this.Bl=-2067093701,this.Ch=1013904242,this.Cl=-23791573,this.Dh=-1521486534,this.Dl=1595750129,this.Eh=1359893119,this.El=-1377402159,this.Fh=-1694144372,this.Fl=725511199,this.Gh=528734635,this.Gl=-79577749,this.Hh=1541459225,this.Hl=327033209}get(){let{Ah:t,Al:e,Bh:n,Bl:s,Ch:o,Cl:i,Dh:a,Dl:c,Eh:u,El:l,Fh:f,Fl:h,Gh:v,Gl:w,Hh:y,Hl:d}=this;return[t,e,n,s,o,i,a,c,u,l,f,h,v,w,y,d]}set(t,e,n,s,o,i,a,c,u,l,f,h,v,w,y,d){this.Ah=t|0,this.Al=e|0,this.Bh=n|0,this.Bl=s|0,this.Ch=o|0,this.Cl=i|0,this.Dh=a|0,this.Dl=c|0,this.Eh=u|0,this.El=l|0,this.Fh=f|0,this.Fl=h|0,this.Gh=v|0,this.Gl=w|0,this.Hh=y|0,this.Hl=d|0}process(t,e){for(let p=0;p<16;p++,e+=4)ne[p]=t.getUint32(e),se[p]=t.getUint32(e+=4);for(let p=16;p<80;p++){let S=ne[p-15]|0,R=se[p-15]|0,T=_.rotrSH(S,R,1)^_.rotrSH(S,R,8)^_.shrSH(S,R,7),k=_.rotrSL(S,R,1)^_.rotrSL(S,R,8)^_.shrSL(S,R,7),I=ne[p-2]|0,U=se[p-2]|0,Y=_.rotrSH(I,U,19)^_.rotrBH(I,U,61)^_.shrSH(I,U,6),P=_.rotrSL(I,U,19)^_.rotrBL(I,U,61)^_.shrSL(I,U,6),V=_.add4L(k,P,se[p-7],se[p-16]),X=_.add4H(V,T,Y,ne[p-7],ne[p-16]);ne[p]=X|0,se[p]=V|0}let{Ah:n,Al:s,Bh:o,Bl:i,Ch:a,Cl:c,Dh:u,Dl:l,Eh:f,El:h,Fh:v,Fl:w,Gh:y,Gl:d,Hh:b,Hl:B}=this;for(let p=0;p<80;p++){let S=_.rotrSH(f,h,14)^_.rotrSH(f,h,18)^_.rotrBH(f,h,41),R=_.rotrSL(f,h,14)^_.rotrSL(f,h,18)^_.rotrBL(f,h,41),T=f&v^~f&y,k=h&w^~h&d,I=_.add5L(B,R,k,kl[p],se[p]),U=_.add5H(I,b,S,T,Sl[p],ne[p]),Y=I|0,P=_.rotrSH(n,s,28)^_.rotrBH(n,s,34)^_.rotrBH(n,s,39),V=_.rotrSL(n,s,28)^_.rotrBL(n,s,34)^_.rotrBL(n,s,39),X=n&o^n&a^o&a,E=s&i^s&c^i&c;b=y|0,B=d|0,y=v|0,d=w|0,v=f|0,w=h|0,{h:f,l:h}=_.add(u|0,l|0,U|0,Y|0),u=a|0,l=c|0,a=o|0,c=i|0,o=n|0,i=s|0;let N=_.add3L(Y,V,E);n=_.add3H(N,U,P,X),s=N|0}({h:n,l:s}=_.add(this.Ah|0,this.Al|0,n|0,s|0)),{h:o,l:i}=_.add(this.Bh|0,this.Bl|0,o|0,i|0),{h:a,l:c}=_.add(this.Ch|0,this.Cl|0,a|0,c|0),{h:u,l}=_.add(this.Dh|0,this.Dl|0,u|0,l|0),{h:f,l:h}=_.add(this.Eh|0,this.El|0,f|0,h|0),{h:v,l:w}=_.add(this.Fh|0,this.Fl|0,v|0,w|0),{h:y,l:d}=_.add(this.Gh|0,this.Gl|0,y|0,d|0),{h:b,l:B}=_.add(this.Hh|0,this.Hl|0,b|0,B|0),this.set(n,s,o,i,a,c,u,l,f,h,v,w,y,d,b,B)}roundClean(){ne.fill(0),se.fill(0)}destroy(){this.buffer.fill(0),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}};var Kr=Me(()=>new fs);var Fr={};it(Fr,{aInRange:()=>bt,abool:()=>It,abytes:()=>Pe,bitGet:()=>Rl,bitLen:()=>ms,bitMask:()=>lr,bitSet:()=>Ll,bytesToHex:()=>Ft,bytesToNumberBE:()=>$t,bytesToNumberLE:()=>ie,concatBytes:()=>qt,createHmacDrbg:()=>ys,ensureBytes:()=>J,equalBytes:()=>Ul,hexToBytes:()=>xe,hexToNumber:()=>ps,inRange:()=>cr,isBytes:()=>oe,memoized:()=>ve,notImplemented:()=>_l,numberToBytesBE:()=>ae,numberToBytesLE:()=>we,numberToHexUnpadded:()=>be,numberToVarBytesBE:()=>Cl,utf8ToBytes:()=>Tl,validateObject:()=>Rt});var gs=BigInt(0),Pr=BigInt(1),Il=BigInt(2);function oe(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function Pe(r){if(!oe(r))throw new Error("Uint8Array expected")}function It(r,t){if(typeof t!="boolean")throw new Error(`${r} must be valid boolean, got "${t}".`)}var Nl=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function Ft(r){Pe(r);let t="";for(let e=0;e<r.length;e++)t+=Nl[r[e]];return t}function be(r){let t=r.toString(16);return t.length&1?`0${t}`:t}function ps(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return BigInt(r===""?"0":`0x${r}`)}var Pt={_0:48,_9:57,_A:65,_F:70,_a:97,_f:102};function Jo(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 xe(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);let t=r.length,e=t/2;if(t%2)throw new Error("padded 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=Jo(r.charCodeAt(o)),a=Jo(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 $t(r){return ps(Ft(r))}function ie(r){return Pe(r),ps(Ft(Uint8Array.from(r).reverse()))}function ae(r,t){return xe(r.toString(16).padStart(t*2,"0"))}function we(r,t){return ae(r,t).reverse()}function Cl(r){return xe(be(r))}function J(r,t,e){let n;if(typeof t=="string")try{n=xe(t)}catch(o){throw new Error(`${r} must be valid hex string, got "${t}". Cause: ${o}`)}else if(oe(t))n=Uint8Array.from(t);else throw new Error(`${r} must be hex string or Uint8Array`);let s=n.length;if(typeof e=="number"&&s!==e)throw new Error(`${r} expected ${e} bytes, got ${s}`);return n}function qt(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];Pe(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 Ul(r,t){if(r.length!==t.length)return!1;let e=0;for(let n=0;n<r.length;n++)e|=r[n]^t[n];return e===0}function Tl(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}var hs=r=>typeof r=="bigint"&&gs<=r;function cr(r,t,e){return hs(r)&&hs(t)&&hs(e)&&t<=r&&r<e}function bt(r,t,e,n){if(!cr(t,e,n))throw new Error(`expected valid ${r}: ${e} <= n < ${n}, got ${typeof t} ${t}`)}function ms(r){let t;for(t=0;r>gs;r>>=Pr,t+=1);return t}function Rl(r,t){return r>>BigInt(t)&Pr}function Ll(r,t,e){return r|(e?Pr:gs)<<BigInt(t)}var lr=r=>(Il<<BigInt(r-1))-Pr,ds=r=>new Uint8Array(r),Yo=r=>Uint8Array.from(r);function ys(r,t,e){if(typeof r!="number"||r<2)throw new Error("hashLen must be a number");if(typeof t!="number"||t<2)throw new Error("qByteLen must be a number");if(typeof e!="function")throw new Error("hmacFn must be a function");let n=ds(r),s=ds(r),o=0,i=()=>{n.fill(1),s.fill(0),o=0},a=(...f)=>e(s,n,...f),c=(f=ds())=>{s=a(Yo([0]),f),n=a(),f.length!==0&&(s=a(Yo([1]),f),n=a())},u=()=>{if(o++>=1e3)throw new Error("drbg: tried 1000 values");let f=0,h=[];for(;f<t;){n=a();let v=n.slice();h.push(v),f+=n.length}return qt(...h)};return(f,h)=>{i(),c(f);let v;for(;!(v=h(u()));)c();return i(),v}}var Hl={bigint:r=>typeof r=="bigint",function:r=>typeof r=="function",boolean:r=>typeof r=="boolean",string:r=>typeof r=="string",stringOrUint8Array:r=>typeof r=="string"||oe(r),isSafeInteger:r=>Number.isSafeInteger(r),array:r=>Array.isArray(r),field:(r,t)=>t.Fp.isValid(r),hash:r=>typeof r=="function"&&Number.isSafeInteger(r.outputLen)};function Rt(r,t,e={}){let n=(s,o,i)=>{let a=Hl[o];if(typeof a!="function")throw new Error(`Invalid validator "${o}", expected function`);let c=r[s];if(!(i&&c===void 0)&&!a(c,r))throw new Error(`Invalid param ${String(s)}=${c} (${typeof c}), expected ${o}`)};for(let[s,o]of Object.entries(t))n(s,o,!1);for(let[s,o]of Object.entries(e))n(s,o,!0);return r}var _l=()=>{throw new Error("not implemented")};function ve(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 tt=BigInt(0),j=BigInt(1),Be=BigInt(2),Vl=BigInt(3),bs=BigInt(4),Xo=BigInt(5),Qo=BigInt(8),Ol=BigInt(9),Dl=BigInt(16);function q(r,t){let e=r%t;return e>=tt?e:t+e}function Ml(r,t,e){if(e<=tt||t<tt)throw new Error("Expected power/modulo > 0");if(e===j)return tt;let n=j;for(;t>tt;)t&j&&(n=n*r%e),r=r*r%e,t>>=j;return n}function G(r,t,e){let n=r;for(;t-- >tt;)n*=n,n%=e;return n}function $r(r,t){if(r===tt||t<=tt)throw new Error(`invert: expected positive integers, got n=${r} mod=${t}`);let e=q(r,t),n=t,s=tt,o=j,i=j,a=tt;for(;e!==tt;){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!==j)throw new Error("invert: does not exist");return q(s,t)}function Kl(r){let t=(r-j)/Be,e,n,s;for(e=r-j,n=0;e%Be===tt;e/=Be,n++);for(s=Be;s<r&&Ml(s,t,r)!==r-j;s++);if(n===1){let i=(r+j)/bs;return function(c,u){let l=c.pow(u,i);if(!c.eql(c.sqr(l),u))throw new Error("Cannot find square root");return l}}let o=(e+j)/Be;return function(a,c){if(a.pow(c,t)===a.neg(a.ONE))throw new Error("Cannot find square root");let u=n,l=a.pow(a.mul(a.ONE,s),e),f=a.pow(c,o),h=a.pow(c,e);for(;!a.eql(h,a.ONE);){if(a.eql(h,a.ZERO))return a.ZERO;let v=1;for(let y=a.sqr(h);v<u&&!a.eql(y,a.ONE);v++)y=a.sqr(y);let w=a.pow(l,j<<BigInt(u-v-1));l=a.sqr(w),f=a.mul(f,w),h=a.mul(h,l),u=v}return f}}function Pl(r){if(r%bs===Vl){let t=(r+j)/bs;return function(n,s){let o=n.pow(s,t);if(!n.eql(n.sqr(o),s))throw new Error("Cannot find square root");return o}}if(r%Qo===Xo){let t=(r-Xo)/Qo;return function(n,s){let o=n.mul(s,Be),i=n.pow(o,t),a=n.mul(s,i),c=n.mul(n.mul(a,Be),i),u=n.mul(a,n.sub(c,n.ONE));if(!n.eql(n.sqr(u),s))throw new Error("Cannot find square root");return u}}return r%Dl,Kl(r)}var ti=(r,t)=>(q(r,t)&j)===j,Fl=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function xs(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=Fl.reduce((n,s)=>(n[s]="function",n),t);return Rt(r,e)}function $l(r,t,e){if(e<tt)throw new Error("Expected power > 0");if(e===tt)return r.ONE;if(e===j)return t;let n=r.ONE,s=t;for(;e>tt;)e&j&&(n=r.mul(n,s)),s=r.sqr(s),e>>=j;return n}function ql(r,t){let e=new Array(t.length),n=t.reduce((o,i,a)=>r.is0(i)?o:(e[a]=o,r.mul(o,i)),r.ONE),s=r.inv(n);return t.reduceRight((o,i,a)=>r.is0(i)?o:(e[a]=r.mul(o,e[a]),r.mul(o,i)),s),e}function ws(r,t){let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function ce(r,t,e=!1,n={}){if(r<=tt)throw new Error(`Expected Field ORDER > 0, got ${r}`);let{nBitLength:s,nByteLength:o}=ws(r,t);if(o>2048)throw new Error("Field lengths over 2048 bytes are not supported");let i=Pl(r),a=Object.freeze({ORDER:r,BITS:s,BYTES:o,MASK:lr(s),ZERO:tt,ONE:j,create:c=>q(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error(`Invalid field element: expected bigint, got ${typeof c}`);return tt<=c&&c<r},is0:c=>c===tt,isOdd:c=>(c&j)===j,neg:c=>q(-c,r),eql:(c,u)=>c===u,sqr:c=>q(c*c,r),add:(c,u)=>q(c+u,r),sub:(c,u)=>q(c-u,r),mul:(c,u)=>q(c*u,r),pow:(c,u)=>$l(a,c,u),div:(c,u)=>q(c*$r(u,r),r),sqrN:c=>c*c,addN:(c,u)=>c+u,subN:(c,u)=>c-u,mulN:(c,u)=>c*u,inv:c=>$r(c,r),sqrt:n.sqrt||(c=>i(a,c)),invertBatch:c=>ql(a,c),cmov:(c,u,l)=>l?u:c,toBytes:c=>e?we(c,o):ae(c,o),fromBytes:c=>{if(c.length!==o)throw new Error(`Fp.fromBytes: expected ${o}, got ${c.length}`);return e?ie(c):$t(c)}});return Object.freeze(a)}function ei(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 vs(r){let t=ei(r);return t+Math.ceil(t/2)}function ri(r,t,e=!1){let n=r.length,s=ei(t),o=vs(t);if(n<16||n<o||n>1024)throw new Error(`expected ${o}-1024 bytes of input, got ${n}`);let i=e?$t(r):ie(r),a=q(i,t-j)+j;return e?we(a,s):ae(a,s)}var jl=BigInt(0),Bs=BigInt(1),Es=new WeakMap,ni=new WeakMap;function qr(r,t){let e=(o,i)=>{let a=i.negate();return o?a:i},n=o=>{if(!Number.isSafeInteger(o)||o<=0||o>t)throw new Error(`Wrong window size=${o}, should be [1..${t}]`)},s=o=>{n(o);let i=Math.ceil(t/o)+1,a=2**(o-1);return{windows:i,windowSize:a}};return{constTimeNegate:e,unsafeLadder(o,i){let a=r.ZERO,c=o;for(;i>jl;)i&Bs&&(a=a.add(c)),c=c.double(),i>>=Bs;return a},precomputeWindow(o,i){let{windows:a,windowSize:c}=s(i),u=[],l=o,f=l;for(let h=0;h<a;h++){f=l,u.push(f);for(let v=1;v<c;v++)f=f.add(l),u.push(f);l=f.double()}return u},wNAF(o,i,a){let{windows:c,windowSize:u}=s(o),l=r.ZERO,f=r.BASE,h=BigInt(2**o-1),v=2**o,w=BigInt(o);for(let y=0;y<c;y++){let d=y*u,b=Number(a&h);a>>=w,b>u&&(b-=v,a+=Bs);let B=d,p=d+Math.abs(b)-1,S=y%2!==0,R=b<0;b===0?f=f.add(e(S,i[B])):l=l.add(e(R,i[p]))}return{p:l,f}},wNAFCached(o,i,a){let c=ni.get(o)||1,u=Es.get(o);return u||(u=this.precomputeWindow(o,c),c!==1&&Es.set(o,a(u))),this.wNAF(c,u,i)},setWindowSize(o,i){n(i),ni.set(o,i),Es.delete(o)}}}function zr(r,t,e,n){if(!Array.isArray(e)||!Array.isArray(n)||n.length!==e.length)throw new Error("arrays of points and scalars must have equal length");n.forEach((l,f)=>{if(!t.isValid(l))throw new Error(`wrong scalar at index ${f}`)}),e.forEach((l,f)=>{if(!(l instanceof r))throw new Error(`wrong point at index ${f}`)});let s=ms(BigInt(e.length)),o=s>12?s-3:s>4?s-2:s?2:1,i=(1<<o)-1,a=new Array(i+1).fill(r.ZERO),c=Math.floor((t.BITS-1)/o)*o,u=r.ZERO;for(let l=c;l>=0;l-=o){a.fill(r.ZERO);for(let h=0;h<n.length;h++){let v=n[h],w=Number(v>>BigInt(l)&BigInt(i));a[w]=a[w].add(e[h])}let f=r.ZERO;for(let h=a.length-1,v=r.ZERO;h>0;h--)v=v.add(a[h]),f=f.add(v);if(u=u.add(f),l!==0)for(let h=0;h<o;h++)u=u.double()}return u}function ur(r){return xs(r.Fp),Rt(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...ws(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Nt=BigInt(0),xt=BigInt(1),jr=BigInt(2),Gl=BigInt(8),Zl={zip215:!0};function Wl(r){let t=ur(r);return Rt(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function si(r){let t=Wl(r),{Fp:e,n,prehash:s,hash:o,randomBytes:i,nByteLength:a,h:c}=t,u=jr<<BigInt(a*8)-xt,l=e.create,f=ce(t.n,t.nBitLength),h=t.uvRatio||((m,g)=>{try{return{isValid:!0,value:e.sqrt(m*e.inv(g))}}catch{return{isValid:!1,value:Nt}}}),v=t.adjustScalarBytes||(m=>m),w=t.domain||((m,g,x)=>{if(It("phflag",x),g.length||x)throw new Error("Contexts/pre-hash are not supported");return m});function y(m,g){bt("coordinate "+m,g,Nt,u)}function d(m){if(!(m instanceof p))throw new Error("ExtendedPoint expected")}let b=ve((m,g)=>{let{ex:x,ey:C,ez:L}=m,H=m.is0();g==null&&(g=H?Gl:e.inv(L));let O=l(x*g),K=l(C*g),D=l(L*g);if(H)return{x:Nt,y:xt};if(D!==xt)throw new Error("invZ was invalid");return{x:O,y:K}}),B=ve(m=>{let{a:g,d:x}=t;if(m.is0())throw new Error("bad point: ZERO");let{ex:C,ey:L,ez:H,et:O}=m,K=l(C*C),D=l(L*L),F=l(H*H),z=l(F*F),rt=l(K*g),nt=l(F*l(rt+D)),ot=l(z+l(x*l(K*D)));if(nt!==ot)throw new Error("bad point: equation left != right (1)");let dt=l(C*L),Q=l(H*O);if(dt!==Q)throw new Error("bad point: equation left != right (2)");return!0});class p{constructor(g,x,C,L){this.ex=g,this.ey=x,this.ez=C,this.et=L,y("x",g),y("y",x),y("z",C),y("t",L),Object.freeze(this)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(g){if(g instanceof p)throw new Error("extended point not allowed");let{x,y:C}=g||{};return y("x",x),y("y",C),new p(x,C,xt,l(x*C))}static normalizeZ(g){let x=e.invertBatch(g.map(C=>C.ez));return g.map((C,L)=>C.toAffine(x[L])).map(p.fromAffine)}static msm(g,x){return zr(p,f,g,x)}_setWindowSize(g){T.setWindowSize(this,g)}assertValidity(){B(this)}equals(g){d(g);let{ex:x,ey:C,ez:L}=this,{ex:H,ey:O,ez:K}=g,D=l(x*K),F=l(H*L),z=l(C*K),rt=l(O*L);return D===F&&z===rt}is0(){return this.equals(p.ZERO)}negate(){return new p(l(-this.ex),this.ey,this.ez,l(-this.et))}double(){let{a:g}=t,{ex:x,ey:C,ez:L}=this,H=l(x*x),O=l(C*C),K=l(jr*l(L*L)),D=l(g*H),F=x+C,z=l(l(F*F)-H-O),rt=D+O,nt=rt-K,ot=D-O,dt=l(z*nt),Q=l(rt*ot),yt=l(z*ot),Mt=l(nt*rt);return new p(dt,Q,Mt,yt)}add(g){d(g);let{a:x,d:C}=t,{ex:L,ey:H,ez:O,et:K}=this,{ex:D,ey:F,ez:z,et:rt}=g;if(x===BigInt(-1)){let wo=l((H-L)*(F+D)),vo=l((H+L)*(F-D)),Xn=l(vo-wo);if(Xn===Nt)return this.double();let Bo=l(O*jr*rt),Eo=l(K*jr*z),Ao=Eo+Bo,So=vo+wo,ko=Eo-Bo,ec=l(Ao*Xn),rc=l(So*ko),nc=l(Ao*ko),sc=l(Xn*So);return new p(ec,rc,sc,nc)}let nt=l(L*D),ot=l(H*F),dt=l(K*C*rt),Q=l(O*z),yt=l((L+H)*(D+F)-nt-ot),Mt=Q-dt,Xe=Q+dt,Qe=l(ot-x*nt),Ya=l(yt*Mt),Xa=l(Xe*Qe),Qa=l(yt*Qe),tc=l(Mt*Xe);return new p(Ya,Xa,tc,Qa)}subtract(g){return this.add(g.negate())}wNAF(g){return T.wNAFCached(this,g,p.normalizeZ)}multiply(g){let x=g;bt("scalar",x,xt,n);let{p:C,f:L}=this.wNAF(x);return p.normalizeZ([C,L])[0]}multiplyUnsafe(g){let x=g;return bt("scalar",x,Nt,n),x===Nt?R:this.equals(R)||x===xt?this:this.equals(S)?this.wNAF(x).p:T.unsafeLadder(this,x)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return T.unsafeLadder(this,n).is0()}toAffine(g){return b(this,g)}clearCofactor(){let{h:g}=t;return g===xt?this:this.multiplyUnsafe(g)}static fromHex(g,x=!1){let{d:C,a:L}=t,H=e.BYTES;g=J("pointHex",g,H),It("zip215",x);let O=g.slice(),K=g[H-1];O[H-1]=K&-129;let D=ie(O),F=x?u:e.ORDER;bt("pointHex.y",D,Nt,F);let z=l(D*D),rt=l(z-xt),nt=l(C*z-L),{isValid:ot,value:dt}=h(rt,nt);if(!ot)throw new Error("Point.fromHex: invalid y coordinate");let Q=(dt&xt)===xt,yt=(K&128)!==0;if(!x&&dt===Nt&&yt)throw new Error("Point.fromHex: x=0 and x_0=1");return yt!==Q&&(dt=l(-dt)),p.fromAffine({x:dt,y:D})}static fromPrivateKey(g){return U(g).point}toRawBytes(){let{x:g,y:x}=this.toAffine(),C=we(x,e.BYTES);return C[C.length-1]|=g&xt?128:0,C}toHex(){return Ft(this.toRawBytes())}}p.BASE=new p(t.Gx,t.Gy,xt,l(t.Gx*t.Gy)),p.ZERO=new p(Nt,xt,xt,Nt);let{BASE:S,ZERO:R}=p,T=qr(p,a*8);function k(m){return q(m,n)}function I(m){return k(ie(m))}function U(m){let g=a;m=J("private key",m,g);let x=J("hashed private key",o(m),2*g),C=v(x.slice(0,g)),L=x.slice(g,2*g),H=I(C),O=S.multiply(H),K=O.toRawBytes();return{head:C,prefix:L,scalar:H,point:O,pointBytes:K}}function Y(m){return U(m).pointBytes}function P(m=new Uint8Array,...g){let x=qt(...g);return I(o(w(x,J("context",m),!!s)))}function V(m,g,x={}){m=J("message",m),s&&(m=s(m));let{prefix:C,scalar:L,pointBytes:H}=U(g),O=P(x.context,C,m),K=S.multiply(O).toRawBytes(),D=P(x.context,K,H,m),F=k(O+D*L);bt("signature.s",F,Nt,n);let z=qt(K,we(F,e.BYTES));return J("result",z,a*2)}let X=Zl;function E(m,g,x,C=X){let{context:L,zip215:H}=C,O=e.BYTES;m=J("signature",m,2*O),g=J("message",g),H!==void 0&&It("zip215",H),s&&(g=s(g));let K=ie(m.slice(O,2*O)),D,F,z;try{D=p.fromHex(x,H),F=p.fromHex(m.slice(0,O),H),z=S.multiplyUnsafe(K)}catch{return!1}if(!H&&D.isSmallOrder())return!1;let rt=P(L,F.toRawBytes(),D.toRawBytes(),g);return F.add(D.multiplyUnsafe(rt)).subtract(z).clearCofactor().equals(p.ZERO)}return S._setWindowSize(8),{CURVE:t,getPublicKey:Y,sign:V,verify:E,ExtendedPoint:p,utils:{getExtendedPublicKey:U,randomPrivateKey:()=>i(e.BYTES),precompute(m=8,g=p.BASE){return g._setWindowSize(m),g.multiply(BigInt(3)),g}}}}var As=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),oi=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),Bh=BigInt(0),Jl=BigInt(1),ii=BigInt(2),Eh=BigInt(3),Yl=BigInt(5),Xl=BigInt(8);function Ql(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),s=BigInt(80),o=As,a=r*r%o*r%o,c=G(a,ii,o)*a%o,u=G(c,Jl,o)*r%o,l=G(u,Yl,o)*u%o,f=G(l,t,o)*l%o,h=G(f,e,o)*f%o,v=G(h,n,o)*h%o,w=G(v,s,o)*v%o,y=G(w,s,o)*v%o,d=G(y,t,o)*l%o;return{pow_p_5_8:G(d,ii,o)*r%o,b2:a}}function tu(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function eu(r,t){let e=As,n=q(t*t*t,e),s=q(n*n*t,e),o=Ql(r*s).pow_p_5_8,i=q(r*n*o,e),a=q(t*i*i,e),c=i,u=q(i*oi,e),l=a===r,f=a===q(-r,e),h=a===q(-r*oi,e);return l&&(i=c),(f||h)&&(i=u),ti(i,e)&&(i=q(-i,e)),{isValid:l||f,value:i}}var ru=ce(As,void 0,!0),nu={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:ru,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:Xl,Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:Kr,randomBytes:Ke,adjustScalarBytes:tu,uvRatio:eu},Fe=si(nu);var $e=32,Lt=64,Gr=32;function ai(){let r=Fe.utils.randomPrivateKey(),t=Fe.getPublicKey(r);return{privateKey:fi(r,t),publicKey:t}}function ci(r){if(r.length!==Gr)throw new TypeError('"seed" must be 32 bytes in length.');if(!(r instanceof Uint8Array))throw new TypeError('"seed" must be a node.js Buffer, or Uint8Array.');let t=r,e=Fe.getPublicKey(t);return{privateKey:fi(t,e),publicKey:e}}function li(r,t){let e=r.subarray(0,Gr);return Fe.sign(t instanceof Uint8Array?t:t.subarray(),e)}function ui(r,t,e){return Fe.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}function fi(r,t){let e=new Uint8Array(Lt);for(let n=0;n<Gr;n++)e[n]=r[n],e[Gr+n]=t[n];return e}var fr=class{type="Ed25519";raw;constructor(t){this.raw=qe(t,$e)}toMultihash(){return ar.digest(hr(this))}toCID(){return Tt.createV1(114,this.toMultihash())}toString(){return ut.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:St(this.raw,t.raw)}verify(t,e){return ui(this.raw,e,t)}},Ee=class{type="Ed25519";raw;publicKey;constructor(t,e){this.raw=qe(t,Lt),this.publicKey=new fr(e)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:St(this.raw,t.raw)}sign(t){return li(this.raw,t)}};function Ss(r){if(r.length>Lt){r=qe(r,Lt+$e);let n=r.subarray(0,Lt),s=r.subarray(Lt,r.length);return new Ee(n,s)}r=qe(r,Lt);let t=r.subarray(0,Lt),e=r.subarray($e);return new Ee(t,e)}function Zr(r){return r=qe(r,$e),new fr(r)}async function di(){let{privateKey:r,publicKey:t}=ai();return new Ee(r,t)}async function gi(r){let{privateKey:t,publicKey:e}=ci(r);return new Ee(t,e)}function qe(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}function Ht(r=0){return new Uint8Array(r)}var su=Math.pow(2,7),ou=Math.pow(2,14),iu=Math.pow(2,21),pi=Math.pow(2,28),mi=Math.pow(2,35),yi=Math.pow(2,42),bi=Math.pow(2,49),gt=128,le=127;function dr(r){if(r<su)return 1;if(r<ou)return 2;if(r<iu)return 3;if(r<pi)return 4;if(r<mi)return 5;if(r<yi)return 6;if(r<bi)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function xi(r,t,e=0){switch(dr(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 wi(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)*pi,e<gt)||(e=r[t+5],n+=(e&le)*mi,e<gt)||(e=r[t+6],n+=(e&le)*yi,e<gt)||(e=r[t+7],n+=(e&le)*bi,e<gt))return n;throw new RangeError("Could not decode varint")}var ks=new Float32Array([-0]),ue=new Uint8Array(ks.buffer);function vi(r,t,e){ks[0]=r,t[e]=ue[0],t[e+1]=ue[1],t[e+2]=ue[2],t[e+3]=ue[3]}function Bi(r,t){return ue[0]=r[t],ue[1]=r[t+1],ue[2]=r[t+2],ue[3]=r[t+3],ks[0]}var Is=new Float64Array([-0]),ft=new Uint8Array(Is.buffer);function Ei(r,t,e){Is[0]=r,t[e]=ft[0],t[e+1]=ft[1],t[e+2]=ft[2],t[e+3]=ft[3],t[e+4]=ft[4],t[e+5]=ft[5],t[e+6]=ft[6],t[e+7]=ft[7]}function Ai(r,t){return ft[0]=r[t],ft[1]=r[t+1],ft[2]=r[t+2],ft[3]=r[t+3],ft[4]=r[t+4],ft[5]=r[t+5],ft[6]=r[t+6],ft[7]=r[t+7],Is[0]}var au=BigInt(Number.MAX_SAFE_INTEGER),cu=BigInt(Number.MIN_SAFE_INTEGER),vt=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 Ae;if(t<au&&t>cu)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>Si&&(s=0n,++n>Si&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(t){if(t===0)return Ae;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):Ae}},Ae=new vt(0,0);Ae.toBigInt=function(){return 0n};Ae.zzEncode=Ae.zzDecode=function(){return this};Ae.length=function(){return 1};var Si=4294967296n;function ki(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 Ii(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 Ns(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 Ct(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function Wr(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var Cs=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,Ct(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 Ct(this,4);return Wr(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Ct(this,4);return Wr(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Ct(this,4);let t=Bi(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Ct(this,4);let t=Ai(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 Ct(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return Ii(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw Ct(this,t);this.pos+=t}else do if(this.pos>=this.len)throw Ct(this);while(this.buf[this.pos++]&128);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 vt(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 Ct(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 Ct(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 Ct(this,8);let t=Wr(this.buf,this.pos+=4),e=Wr(this.buf,this.pos+=4);return new vt(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=wi(this.buf,this.pos);return this.pos+=dr(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 Us(r){return new Cs(r instanceof Uint8Array?r:r.subarray())}function Jr(r,t,e){let n=Us(r);return t.decode(n,void 0,e)}var Ts={};it(Ts,{base10:()=>lu});var lu=te({prefix:"9",name:"base10",alphabet:"0123456789"});var Rs={};it(Rs,{base16:()=>uu,base16upper:()=>fu});var uu=W({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),fu=W({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Ls={};it(Ls,{base2:()=>hu});var hu=W({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Hs={};it(Hs,{base256emoji:()=>yu});var Ci=Array.from("\u{1F680}\u{1FA90}\u2604\u{1F6F0}\u{1F30C}\u{1F311}\u{1F312}\u{1F313}\u{1F314}\u{1F315}\u{1F316}\u{1F317}\u{1F318}\u{1F30D}\u{1F30F}\u{1F30E}\u{1F409}\u2600\u{1F4BB}\u{1F5A5}\u{1F4BE}\u{1F4BF}\u{1F602}\u2764\u{1F60D}\u{1F923}\u{1F60A}\u{1F64F}\u{1F495}\u{1F62D}\u{1F618}\u{1F44D}\u{1F605}\u{1F44F}\u{1F601}\u{1F525}\u{1F970}\u{1F494}\u{1F496}\u{1F499}\u{1F622}\u{1F914}\u{1F606}\u{1F644}\u{1F4AA}\u{1F609}\u263A\u{1F44C}\u{1F917}\u{1F49C}\u{1F614}\u{1F60E}\u{1F607}\u{1F339}\u{1F926}\u{1F389}\u{1F49E}\u270C\u2728\u{1F937}\u{1F631}\u{1F60C}\u{1F338}\u{1F64C}\u{1F60B}\u{1F497}\u{1F49A}\u{1F60F}\u{1F49B}\u{1F642}\u{1F493}\u{1F929}\u{1F604}\u{1F600}\u{1F5A4}\u{1F603}\u{1F4AF}\u{1F648}\u{1F447}\u{1F3B6}\u{1F612}\u{1F92D}\u2763\u{1F61C}\u{1F48B}\u{1F440}\u{1F62A}\u{1F611}\u{1F4A5}\u{1F64B}\u{1F61E}\u{1F629}\u{1F621}\u{1F92A}\u{1F44A}\u{1F973}\u{1F625}\u{1F924}\u{1F449}\u{1F483}\u{1F633}\u270B\u{1F61A}\u{1F61D}\u{1F634}\u{1F31F}\u{1F62C}\u{1F643}\u{1F340}\u{1F337}\u{1F63B}\u{1F613}\u2B50\u2705\u{1F97A}\u{1F308}\u{1F608}\u{1F918}\u{1F4A6}\u2714\u{1F623}\u{1F3C3}\u{1F490}\u2639\u{1F38A}\u{1F498}\u{1F620}\u261D\u{1F615}\u{1F33A}\u{1F382}\u{1F33B}\u{1F610}\u{1F595}\u{1F49D}\u{1F64A}\u{1F639}\u{1F5E3}\u{1F4AB}\u{1F480}\u{1F451}\u{1F3B5}\u{1F91E}\u{1F61B}\u{1F534}\u{1F624}\u{1F33C}\u{1F62B}\u26BD\u{1F919}\u2615\u{1F3C6}\u{1F92B}\u{1F448}\u{1F62E}\u{1F646}\u{1F37B}\u{1F343}\u{1F436}\u{1F481}\u{1F632}\u{1F33F}\u{1F9E1}\u{1F381}\u26A1\u{1F31E}\u{1F388}\u274C\u270A\u{1F44B}\u{1F630}\u{1F928}\u{1F636}\u{1F91D}\u{1F6B6}\u{1F4B0}\u{1F353}\u{1F4A2}\u{1F91F}\u{1F641}\u{1F6A8}\u{1F4A8}\u{1F92C}\u2708\u{1F380}\u{1F37A}\u{1F913}\u{1F619}\u{1F49F}\u{1F331}\u{1F616}\u{1F476}\u{1F974}\u25B6\u27A1\u2753\u{1F48E}\u{1F4B8}\u2B07\u{1F628}\u{1F31A}\u{1F98B}\u{1F637}\u{1F57A}\u26A0\u{1F645}\u{1F61F}\u{1F635}\u{1F44E}\u{1F932}\u{1F920}\u{1F927}\u{1F4CC}\u{1F535}\u{1F485}\u{1F9D0}\u{1F43E}\u{1F352}\u{1F617}\u{1F911}\u{1F30A}\u{1F92F}\u{1F437}\u260E\u{1F4A7}\u{1F62F}\u{1F486}\u{1F446}\u{1F3A4}\u{1F647}\u{1F351}\u2744\u{1F334}\u{1F4A3}\u{1F438}\u{1F48C}\u{1F4CD}\u{1F940}\u{1F922}\u{1F445}\u{1F4A1}\u{1F4A9}\u{1F450}\u{1F4F8}\u{1F47B}\u{1F910}\u{1F92E}\u{1F3BC}\u{1F975}\u{1F6A9}\u{1F34E}\u{1F34A}\u{1F47C}\u{1F48D}\u{1F4E3}\u{1F942}"),du=Ci.reduce((r,t,e)=>(r[e]=t,r),[]),gu=Ci.reduce((r,t,e)=>(r[t.codePointAt(0)]=e,r),[]);function pu(r){return r.reduce((t,e)=>(t+=du[e],t),"")}function mu(r){let t=[];for(let e of r){let n=gu[e.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${e}`);t.push(n)}return new Uint8Array(t)}var yu=Ce({prefix:"\u{1F680}",name:"base256emoji",encode:pu,decode:mu});var _s={};it(_s,{base36:()=>bu,base36upper:()=>xu});var bu=te({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),xu=te({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Os={};it(Os,{base64:()=>Vs,base64pad:()=>wu,base64url:()=>vu,base64urlpad:()=>Bu});var Vs=W({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),wu=W({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),vu=W({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Bu=W({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Ds={};it(Ds,{base8:()=>Eu});var Eu=W({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Ms={};it(Ms,{identity:()=>Au});var Au=Ce({prefix:"\0",name:"identity",encode:r=>Ro(r),decode:r=>To(r)});var nd=new TextEncoder,sd=new TextDecoder;var Fs={};it(Fs,{sha256:()=>Yr,sha512:()=>Iu});function Ps({name:r,code:t,encode:e}){return new Ks(r,t,e)}var Ks=class{name;code;encode;constructor(t,e,n){this.name=t,this.code=e,this.encode=n}digest(t){if(t instanceof Uint8Array){let e=this.encode(t);return e instanceof Uint8Array?At(this.code,e):e.then(n=>At(this.code,n))}else throw Error("Unknown type, must be binary type")}};function Ti(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var Yr=Ps({name:"sha2-256",code:18,encode:Ti("SHA-256")}),Iu=Ps({name:"sha2-512",code:19,encode:Ti("SHA-512")});var $s={...Ms,...Ls,...Ds,...Ts,...Rs,...os,..._s,...ss,...Os,...Hs},md={...Fs,...cs};function Li(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var Ri=Li("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),qs=Li("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=Ht(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),Nu={utf8:Ri,"utf-8":Ri,hex:$s.base16,latin1:qs,ascii:qs,binary:qs,...$s},Xr=Nu;function et(r,t="utf8"){let e=Xr[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function zs(r){let t=r??8192,e=t>>>1,n,s=t;return function(i){if(i<1||i>e)return Ht(i);s+i>t&&(n=Ht(t),s=0);let a=n.subarray(s,s+=i);return s&7&&(s=(s|7)+1),a}}var Se=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function js(){}var Zs=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},Cu=zs();function Uu(r){return globalThis.Buffer!=null?Ht(r):Cu(r)}var pr=class{len;head;tail;states;constructor(){this.len=0,this.head=new Se(js,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new Se(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new Ws((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(Qr,10,vt.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=vt.fromBigInt(t);return this._push(Qr,e.length(),e)}uint64Number(t){return this._push(xi,dr(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=vt.fromBigInt(t).zzEncode();return this._push(Qr,e.length(),e)}sint64Number(t){let e=vt.fromNumber(t).zzEncode();return this._push(Qr,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(Gs,1,t?1:0)}fixed32(t){return this._push(gr,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=vt.fromBigInt(t);return this._push(gr,4,e.lo)._push(gr,4,e.hi)}fixed64Number(t){let e=vt.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(vi,4,t)}double(t){return this._push(Ei,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(Gs,1,0):this.uint32(e)._push(Ru,e,t)}string(t){let e=ki(t);return e!==0?this.uint32(e)._push(Ns,e,t):this._push(Gs,1,0)}fork(){return this.states=new Zs(this),this.head=this.tail=new Se(js,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 Se(js,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=Uu(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function Gs(r,t,e){t[e]=r&255}function Tu(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var Ws=class extends Se{next;constructor(t,e){super(Tu,t,e),this.next=void 0}};function Qr(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 Ru(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(pr.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(Lu,t,r),this},pr.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(Hu,t,r),this});function Lu(r,t,e){t.set(r,e)}function Hu(r,t,e){r.length<40?Ns(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(et(r),e)}function Js(){return new pr}function tn(r,t){let e=Js();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var ze;(function(r){r[r.VARINT=0]="VARINT",r[r.BIT64=1]="BIT64",r[r.LENGTH_DELIMITED=2]="LENGTH_DELIMITED",r[r.START_GROUP=3]="START_GROUP",r[r.END_GROUP=4]="END_GROUP",r[r.BIT32=5]="BIT32"})(ze||(ze={}));function en(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function Ys(r){function t(s){if(r[s.toString()]==null)throw new Error("Invalid enum value");return r[s]}let e=function(o,i){let a=t(o);i.int32(a)},n=function(o){let i=o.int32();return t(i)};return en("enum",ze.VARINT,e,n)}function rn(r,t){return en("message",ze.LENGTH_DELIMITED,r,t)}var Z;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.secp256k1="secp256k1"})(Z||(Z={}));var Xs;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1"})(Xs||(Xs={}));(function(r){r.codec=()=>Ys(Xs)})(Z||(Z={}));var _t;(function(r){let t;r.codec=()=>(t==null&&(t=rn((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),Z.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let o={},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let a=e.uint32();switch(a>>>3){case 1:{o.Type=Z.codec().decode(e);break}case 2:{o.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return o})),t),r.encode=e=>tn(e,r.codec()),r.decode=(e,n)=>Jr(e,r.codec(),n)})(_t||(_t={}));var mr;(function(r){let t;r.codec=()=>(t==null&&(t=rn((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),Z.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let o={},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let a=e.uint32();switch(a>>>3){case 1:{o.Type=Z.codec().decode(e);break}case 2:{o.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return o})),t),r.encode=e=>tn(e,r.codec()),r.decode=(e,n)=>Jr(e,r.codec(),n)})(mr||(mr={}));var Sr={};it(Sr,{MAX_RSA_KEY_SIZE:()=>Gn,generateRSAKeyPair:()=>lo,jwkToJWKKeyPair:()=>Na,jwkToPkcs1:()=>Ju,jwkToPkix:()=>co,jwkToRSAPrivateKey:()=>Ia,pkcs1ToJwk:()=>Sa,pkcs1ToRSAPrivateKey:()=>Zn,pkixToJwk:()=>ka,pkixToRSAPublicKey:()=>Wn});var _u=new Uint32Array([1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298]),fe=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),he=new Uint32Array(64),Qs=class extends re{constructor(){super(64,32,8,!1),this.A=fe[0]|0,this.B=fe[1]|0,this.C=fe[2]|0,this.D=fe[3]|0,this.E=fe[4]|0,this.F=fe[5]|0,this.G=fe[6]|0,this.H=fe[7]|0}get(){let{A:t,B:e,C:n,D:s,E:o,F:i,G:a,H:c}=this;return[t,e,n,s,o,i,a,c]}set(t,e,n,s,o,i,a,c){this.A=t|0,this.B=e|0,this.C=n|0,this.D=s|0,this.E=o|0,this.F=i|0,this.G=a|0,this.H=c|0}process(t,e){for(let f=0;f<16;f++,e+=4)he[f]=t.getUint32(e,!1);for(let f=16;f<64;f++){let h=he[f-15],v=he[f-2],w=kt(h,7)^kt(h,18)^h>>>3,y=kt(v,17)^kt(v,19)^v>>>10;he[f]=y+he[f-7]+w+he[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=kt(a,6)^kt(a,11)^kt(a,25),v=l+h+Or(a,c,u)+_u[f]+he[f]|0,y=(kt(n,2)^kt(n,13)^kt(n,22))+Dr(n,s,o)|0;l=u,u=c,c=a,a=i+v|0,i=o,o=s,s=n,n=v+y|0}n=n+this.A|0,s=s+this.B|0,o=o+this.C|0,i=i+this.D|0,a=a+this.E|0,c=c+this.F|0,u=u+this.G|0,l=l+this.H|0,this.set(n,s,o,i,a,c,u,l)}roundClean(){he.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var de=Me(()=>new Qs);var M=fc(_i());function ke(r,t){let e=0;if(r.length===1)return r[0];for(let n=r.length-1;n>=0;n--)e+=r[r.length-1-n]*Math.pow(2,t*n);return e}function ge(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 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 eo(){let r=new Uint8Array(this.valueHex);if(this.valueHex.byteLength>=2){let a=r[0]===255&&r[1]&128,c=r[0]===0&&(r[1]&128)===0;(a||c)&&this.warnings.push("Needlessly long format")}let t=new ArrayBuffer(this.valueHex.byteLength),e=new Uint8Array(t);for(let a=0;a<this.valueHex.byteLength;a++)e[a]=0;e[0]=r[0]&128;let n=ke(e,8),s=new ArrayBuffer(this.valueHex.byteLength),o=new Uint8Array(s);for(let a=0;a<this.valueHex.byteLength;a++)o[a]=r[a];return o[0]&=127,ke(o,8)-n}function Vi(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=ge(i,8,n),c=new Uint8Array(a);return c[0]|=128,a}let s=ge(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 Oi(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 wt(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 Yd=Math.log(2);function an(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function ro(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 Wt(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 br=class{constructor(){this.items=[]}write(t){this.items.push(t)}final(){return ro(this.items)}},yr=[new Uint8Array([1])],Di="0123456789";var Je="",Ut=new ArrayBuffer(0),no=new Uint8Array(0),xr="EndOfContent",Ki="OCTET STRING",Pi="BIT STRING";function Jt(r){var t;return t=class extends r{constructor(...n){var s;super(...n);let o=n[0]||{};this.isHexOnly=(s=o.isHexOnly)!==null&&s!==void 0?s:!1,this.valueHexView=o.valueHex?M.BufferSourceConverter.toUint8Array(o.valueHex):no}get valueHex(){return this.valueHexView.slice().buffer}set valueHex(n){this.valueHexView=new Uint8Array(n)}fromBER(n,s,o){let i=n instanceof ArrayBuffer?new Uint8Array(n):n;if(!Wt(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",Ut)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:M.Convert.ToHex(this.valueHexView)}}},t.NAME="hexBlock",t}var jt=class{constructor({blockLength:t=0,error:e=Je,warnings:n=[],valueBeforeDecode:s=no}={}){this.blockLength=t,this.error=e,this.warnings=n,this.valueBeforeDecodeView=M.BufferSourceConverter.toUint8Array(s)}static blockName(){return this.NAME}get valueBeforeDecode(){return this.valueBeforeDecodeView.slice().buffer}set valueBeforeDecode(t){this.valueBeforeDecodeView=new Uint8Array(t)}toJSON(){return{blockName:this.constructor.NAME,blockLength:this.blockLength,error:this.error,warnings:this.warnings,valueBeforeDecode:M.Convert.ToHex(this.valueBeforeDecodeView)}}};jt.NAME="baseBlock";var ht=class extends jt{fromBER(t,e,n){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}toBER(t,e){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}};ht.NAME="valueBlock";var cn=class extends Jt(jt){constructor({idBlock:t={}}={}){var e,n,s,o;super(),t?(this.isHexOnly=(e=t.isHexOnly)!==null&&e!==void 0?e:!1,this.valueHexView=t.valueHex?M.BufferSourceConverter.toUint8Array(t.valueHex):no,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",Ut}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,a=new Uint8Array(i+1);if(a[0]=e|31,!t){for(let c=0;c<i-1;c++)a[c+1]=o[c]|128;a[i]=o[i-1]}return a.buffer}let n=new Uint8Array(this.valueHexView.byteLength+1);if(n[0]=e|31,!t){let s=this.valueHexView;for(let o=0;o<s.length-1;o++)n[o+1]=s[o]|128;n[this.valueHexView.byteLength]=s[s.length-1]}return n.buffer}fromBER(t,e,n){let s=M.BufferSourceConverter.toUint8Array(t);if(!Wt(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 v=0;v<u.length;v++)h[v]=u[v];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=ke(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}}};cn.NAME="identificationBlock";var ln=class extends jt{constructor({lenBlock:t={}}={}){var e,n,s;super(),this.isIndefiniteForm=(e=t.isIndefiniteForm)!==null&&e!==void 0?e:!1,this.longFormUsed=(n=t.longFormUsed)!==null&&n!==void 0?n:!1,this.length=(s=t.length)!==null&&s!==void 0?s:0}fromBER(t,e,n){let s=M.BufferSourceConverter.toUint8Array(t);if(!Wt(this,s,e,n))return-1;let o=s.subarray(e,e+n);if(o.length===0)return this.error="Zero buffer length",-1;if(o[0]===255)return this.error="Length block 0xFF is reserved by standard",-1;if(this.isIndefiniteForm=o[0]===128,this.isIndefiniteForm)return this.blockLength=1,e+this.blockLength;if(this.longFormUsed=!!(o[0]&128),this.longFormUsed===!1)return this.length=o[0],this.blockLength=1,e+this.blockLength;let i=o[0]&127;if(i>8)return this.error="Too big integer",-1;if(i+1>o.length)return this.error="End of input reached before message was fully decoded",-1;let a=e+1,c=s.subarray(a,a+i);return c[i-1]===0&&this.warnings.push("Needlessly long encoded length"),this.length=ke(c,8),this.longFormUsed&&this.length<=127&&this.warnings.push("Unnecessary usage of long length form"),this.blockLength=i+1,e+this.blockLength}toBER(t=!1){let e,n;if(this.length>127&&(this.longFormUsed=!0),this.isIndefiniteForm)return e=new ArrayBuffer(1),t===!1&&(n=new Uint8Array(e),n[0]=128),e;if(this.longFormUsed){let s=ge(this.length,8);if(s.byteLength>127)return this.error="Too big length",Ut;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}}};ln.NAME="lengthBlock";var A={},ct=class extends jt{constructor({name:t=Je,optional:e=!1,primitiveSchema:n,...s}={},o){super(s),this.name=t,this.optional=e,n&&(this.primitiveSchema=n),this.idBlock=new cn(s),this.lenBlock=new ln(s),this.valueBlock=o?new o(s):new ht(s)}fromBER(t,e,n){let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}toBER(t,e){let n=e||new br;e||Fi(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?Ut:n.final()}toJSON(){let t={...super.toJSON(),idBlock:this.idBlock.toJSON(),lenBlock:this.lenBlock.toJSON(),valueBlock:this.valueBlock.toJSON(),name:this.name,optional:this.optional};return this.primitiveSchema&&(t.primitiveSchema=this.primitiveSchema.toJSON()),t}toString(t="ascii"){return t==="ascii"?this.onAsciiEncoding():M.Convert.ToHex(this.toBER())}onAsciiEncoding(){return`${this.constructor.NAME} : ${M.Convert.ToHex(this.valueBlock.valueBeforeDecodeView)}`}isEqual(t){if(this===t)return!0;if(!(t instanceof this.constructor))return!1;let e=this.toBER(),n=t.toBER();return Oi(e,n)}};ct.NAME="BaseBlock";function Fi(r){if(r instanceof A.Constructed)for(let t of r.valueBlock.value)Fi(t)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var un=class extends ct{constructor({value:t=Je,...e}={},n){super(e,n),t&&this.fromString(t)}getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}fromBER(t,e,n){let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.fromBuffer(this.valueBlock.valueHexView),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}onAsciiEncoding(){return`${this.constructor.NAME} : '${this.valueBlock.value}'`}};un.NAME="BaseStringBlock";var fn=class extends Jt(ht){constructor({isHexOnly:t=!0,...e}={}){super(e),this.isHexOnly=t}};fn.NAME="PrimitiveValueBlock";var $i,hn=class extends ct{constructor(t={}){super(t,fn),this.idBlock.isConstructed=!1}};$i=hn;A.Primitive=$i;hn.NAME="PRIMITIVE";function qu(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 jn(r,t=0,e=r.length){let n=t,s=new ct({},ht),o=new jt;if(!Wt(o,r,t,e))return s.error=o.error,{offset:-1,result:s};if(!r.subarray(t,t+e).length)return s.error="Zero buffer length",{offset:-1,result:s};let a=s.idBlock.fromBER(r,t,e);if(s.idBlock.warnings.length&&s.warnings.concat(s.idBlock.warnings),a===-1)return s.error=s.idBlock.error,{offset:-1,result:s};if(t=a,e-=s.idBlock.blockLength,a=s.lenBlock.fromBER(r,t,e),s.lenBlock.warnings.length&&s.warnings.concat(s.lenBlock.warnings),a===-1)return s.error=s.lenBlock.error,{offset:-1,result:s};if(t=a,e-=s.lenBlock.blockLength,!s.idBlock.isConstructed&&s.lenBlock.isIndefiniteForm)return s.error="Indefinite length form used for primitive encoding form",{offset:-1,result:s};let c=ct;switch(s.idBlock.tagClass){case 1:if(s.idBlock.tagNumber>=37&&s.idBlock.isHexOnly===!1)return s.error="UNIVERSAL 37 and upper tags are reserved by ASN.1 standard",{offset:-1,result:s};switch(s.idBlock.tagNumber){case 0:if(s.idBlock.isConstructed&&s.lenBlock.length>0)return s.error="Type [UNIVERSAL 0] is reserved",{offset:-1,result:s};c=A.EndOfContent;break;case 1:c=A.Boolean;break;case 2:c=A.Integer;break;case 3:c=A.BitString;break;case 4:c=A.OctetString;break;case 5:c=A.Null;break;case 6:c=A.ObjectIdentifier;break;case 10:c=A.Enumerated;break;case 12:c=A.Utf8String;break;case 13:c=A.RelativeObjectIdentifier;break;case 14:c=A.TIME;break;case 15:return s.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:s};case 16:c=A.Sequence;break;case 17:c=A.Set;break;case 18:c=A.NumericString;break;case 19:c=A.PrintableString;break;case 20:c=A.TeletexString;break;case 21:c=A.VideotexString;break;case 22:c=A.IA5String;break;case 23:c=A.UTCTime;break;case 24:c=A.GeneralizedTime;break;case 25:c=A.GraphicString;break;case 26:c=A.VisibleString;break;case 27:c=A.GeneralString;break;case 28:c=A.UniversalString;break;case 29:c=A.CharacterString;break;case 30:c=A.BmpString;break;case 31:c=A.DATE;break;case 32:c=A.TimeOfDay;break;case 33:c=A.DateTime;break;case 34:c=A.Duration;break;default:{let u=s.idBlock.isConstructed?new A.Constructed:new A.Primitive;u.idBlock=s.idBlock,u.lenBlock=s.lenBlock,u.warnings=s.warnings,s=u}}break;case 2:case 3:case 4:default:c=s.idBlock.isConstructed?A.Constructed:A.Primitive}return s=qu(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 so(r){if(!r.byteLength){let t=new ct({},ht);return t.error="Input buffer has zero length",{offset:-1,result:t}}return jn(M.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function zu(r,t){return r?1:t}var Vt=class extends ht{constructor({value:t=[],isIndefiniteForm:e=!1,...n}={}){super(n),this.value=t,this.isIndefiniteForm=e}fromBER(t,e,n){let s=M.BufferSourceConverter.toUint8Array(t);if(!Wt(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(;zu(this.isIndefiniteForm,n)>0;){let i=jn(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===xr)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===xr?this.value.pop():this.warnings.push("No EndOfContent block encoded")),o}toBER(t,e){let n=e||new br;for(let s=0;s<this.value.length;s++)this.value[s].toBER(t,n);return e?Ut:n.final()}toJSON(){let t={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let e of this.value)t.value.push(e.toJSON());return t}};Vt.NAME="ConstructedValueBlock";var qi,pe=class extends ct{constructor(t={}){super(t,Vt),this.idBlock.isConstructed=!0}fromBER(t,e,n){this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm;let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}onAsciiEncoding(){let t=[];for(let n of this.valueBlock.value)t.push(n.toString("ascii").split(`
2
+ "use strict";var Libp2PCrypto=(()=>{var oc=Object.create;var Rr=Object.defineProperty;var ic=Object.getOwnPropertyDescriptor;var ac=Object.getOwnPropertyNames;var cc=Object.getPrototypeOf,lc=Object.prototype.hasOwnProperty;var uc=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),it=(r,t)=>{for(var e in t)Rr(r,e,{get:t[e],enumerable:!0})},Co=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of ac(t))!lc.call(r,s)&&s!==e&&Rr(r,s,{get:()=>t[s],enumerable:!(n=ic(t,s))||n.enumerable});return r};var fc=(r,t,e)=>(e=r!=null?oc(cc(r)):{},Co(t||!r||!r.__esModule?Rr(e,"default",{value:r,enumerable:!0}):e,r)),hc=r=>Co(Rr({},"__esModule",{value:!0}),r);var Oi=uc(je=>{"use strict";var _u="[object ArrayBuffer]",zt=class r{static isArrayBuffer(t){return Object.prototype.toString.call(t)===_u}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}},ro="string",Vu=/^[0-9a-f]+$/i,Ou=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,Du=/^[a-zA-Z0-9-_]+$/,sn=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=zt.toUint8Array(t),n="";for(let o=0;o<e.length;o++)n+=String.fromCharCode(e[o]);return decodeURIComponent(escape(n))}},Bt=class{static toString(t,e=!1){let n=zt.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}},on=class r{static isHex(t){return typeof t===ro&&Vu.test(t)}static isBase64(t){return typeof t===ro&&Ou.test(t)}static isBase64Url(t){return typeof t===ro&&Du.test(t)}static ToString(t,e="utf8"){let n=zt.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 Bt.toString(n,!0);case"utf16":case"utf16be":return Bt.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 Bt.fromString(t,!0);case"utf16":case"utf16be":return Bt.fromString(t);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToBase64(t){let e=zt.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 sn.fromString(t);case"utf16":case"utf16be":return Bt.fromString(t);case"utf16le":case"usc2":return Bt.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 sn.toString(t);case"utf16":case"utf16be":return Bt.toString(t);case"utf16le":case"usc2":return Bt.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=zt.toUint8Array(t),n="";for(let s=0;s<e.length;s++)n+=String.fromCharCode(e[s]);return n}static ToHex(t){let e=zt.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 Bt.toString(t,e)}static FromUtf16String(t,e=!1){return Bt.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,"")||""}};on.DEFAULT_UTF8_ENCODING="utf8";function Mu(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 Ku(...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 Pu(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}je.BufferSourceConverter=zt;je.Convert=on;je.assign=Mu;je.combine=Ku;je.isEqual=Pu});var wf={};it(wf,{hmac:()=>Hr,keys:()=>xo,pbkdf2:()=>vo,randomBytes:()=>ao});var Hr={};it(Hr,{create:()=>es});var tr=class extends Error{constructor(t="An error occurred while signing a message"){super(t),this.name="SigningError"}},er=class extends Error{constructor(t="An error occurred while verifying a message"){super(t),this.name="VerificationError"}},Lr=class extends Error{constructor(t="Missing Web Crypto API"){super(t),this.name="WebCryptoMissingError"}};var Uo={get(r=globalThis){let t=r.crypto;if(t?.subtle==null)throw new Lr("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 at=Uo;var To={SHA1:20,SHA256:32,SHA512:64};var dc={SHA1:"SHA-1",SHA256:"SHA-256",SHA512:"SHA-512"},gc=async(r,t)=>{let e=await at.get().subtle.sign({name:"HMAC"},r,t);return new Uint8Array(e,0,e.byteLength)};async function es(r,t){let e=dc[r],n=await at.get().subtle.importKey("raw",t,{name:"HMAC",hash:{name:e}},!1,["sign"]);return{async digest(s){return gc(n,s)},length:To[r]}}var xo={};it(xo,{generateEphemeralKeyPair:()=>za,generateKeyPair:()=>uf,generateKeyPairFromSeed:()=>ff,keyStretcher:()=>Ga,privateKeyFromProtobuf:()=>pf,privateKeyFromRaw:()=>mf,privateKeyToProtobuf:()=>yf,publicKeyFromMultihash:()=>gf,publicKeyFromProtobuf:()=>hf,publicKeyFromRaw:()=>df,publicKeyToProtobuf:()=>dr});var $=class extends Error{static name="InvalidParametersError";constructor(t="Invalid parameters"){super(t),this.name="InvalidParametersError"}},Ne=class extends Error{static name="InvalidPublicKeyError";constructor(t="Invalid public key"){super(t),this.name="InvalidPublicKeyError"}},rr=class extends Error{static name="InvalidPrivateKeyError";constructor(t="Invalid private key"){super(t),this.name="InvalidPrivateKeyError"}};var Qt=class extends Error{static name="UnsupportedKeyTypeError";constructor(t="Unsupported key type"){super(t),this.name="UnsupportedKeyTypeError"}};var is={};it(is,{base58btc:()=>ut,base58flickr:()=>wc});var Tf=new Uint8Array(0);function Ro(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 Kt(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 Lo(r){return new TextEncoder().encode(r)}function Ho(r){return new TextDecoder().decode(r)}function pc(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(w){if(w instanceof Uint8Array||(ArrayBuffer.isView(w)?w=new Uint8Array(w.buffer,w.byteOffset,w.byteLength):Array.isArray(w)&&(w=Uint8Array.from(w))),!(w instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(w.length===0)return"";for(var y=0,d=0,b=0,B=w.length;b!==B&&w[b]===0;)b++,y++;for(var p=(B-b)*l+1>>>0,S=new Uint8Array(p);b!==B;){for(var R=w[b],T=0,k=p-1;(R!==0||T<d)&&k!==-1;k--,T++)R+=256*S[k]>>>0,S[k]=R%a>>>0,R=R/a>>>0;if(R!==0)throw new Error("Non-zero carry");d=T,b++}for(var I=p-d;I!==p&&S[I]===0;)I++;for(var U=c.repeat(y);I<p;++I)U+=r.charAt(S[I]);return U}function h(w){if(typeof w!="string")throw new TypeError("Expected String");if(w.length===0)return new Uint8Array;var y=0;if(w[y]!==" "){for(var d=0,b=0;w[y]===c;)d++,y++;for(var B=(w.length-y)*u+1>>>0,p=new Uint8Array(B);w[y];){var S=e[w.charCodeAt(y)];if(S===255)return;for(var R=0,T=B-1;(S!==0||R<b)&&T!==-1;T--,R++)S+=a*p[T]>>>0,p[T]=S%256>>>0,S=S/256>>>0;if(S!==0)throw new Error("Non-zero carry");b=R,y++}if(w[y]!==" "){for(var k=B-b;k!==B&&p[k]===0;)k++;for(var I=new Uint8Array(d+(B-k)),U=d;k!==B;)I[U++]=p[k++];return I}}}function v(w){var y=h(w);if(y)return y;throw new Error(`Non-${t} character`)}return{encode:f,decodeUnsafe:h,decode:v}}var mc=pc,yc=mc,Vo=yc;var rs=class{name;prefix;baseEncode;constructor(t,e,n){this.name=t,this.prefix=e,this.baseEncode=n}encode(t){if(t instanceof Uint8Array)return`${this.prefix}${this.baseEncode(t)}`;throw Error("Unknown type, must be binary type")}},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 Oo(this,t)}},ss=class{decoders;constructor(t){this.decoders=t}or(t){return Oo(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 Oo(r,t){return new ss({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var os=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(t,e,n,s){this.name=t,this.prefix=e,this.baseEncode=n,this.baseDecode=s,this.encoder=new rs(t,e,n),this.decoder=new ns(t,e,s)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function Ce({name:r,prefix:t,encode:e,decode:n}){return new os(r,t,e,n)}function te({name:r,prefix:t,alphabet:e}){let{encode:n,decode:s}=Vo(e,r);return Ce({prefix:t,name:r,encode:n,decode:o=>Kt(s(o))})}function bc(r,t,e,n){let s={};for(let l=0;l<t.length;++l)s[t[l]]=l;let o=r.length;for(;r[o-1]==="=";)--o;let i=new Uint8Array(o*e/8|0),a=0,c=0,u=0;for(let l=0;l<o;++l){let f=s[r[l]];if(f===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<e|f,a+=e,a>=8&&(a-=8,i[u++]=255&c>>a)}if(a>=e||255&c<<8-a)throw new SyntaxError("Unexpected end of data");return i}function xc(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;)o+="=";return o}function W({name:r,prefix:t,bitsPerChar:e,alphabet:n}){return Ce({prefix:t,name:r,encode(s){return xc(s,n,e)},decode(s){return bc(s,n,e,r)}})}var ut=te({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),wc=te({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var as={};it(as,{base32:()=>Ue,base32hex:()=>Ac,base32hexpad:()=>kc,base32hexpadupper:()=>Ic,base32hexupper:()=>Sc,base32pad:()=>Bc,base32padupper:()=>Ec,base32upper:()=>vc,base32z:()=>Nc});var Ue=W({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),vc=W({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Bc=W({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),Ec=W({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),Ac=W({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),Sc=W({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),kc=W({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),Ic=W({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),Nc=W({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var cs={};it(cs,{base36:()=>nr,base36upper:()=>Cc});var nr=te({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),Cc=te({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Uc=Ko,Do=128,Tc=127,Rc=~Tc,Lc=Math.pow(2,31);function Ko(r,t,e){t=t||[],e=e||0;for(var n=e;r>=Lc;)t[e++]=r&255|Do,r/=128;for(;r&Rc;)t[e++]=r&255|Do,r>>>=7;return t[e]=r|0,Ko.bytes=e-n+1,t}var Hc=ls,_c=128,Mo=127;function ls(r,n){var e=0,n=n||0,s=0,o=n,i,a=r.length;do{if(o>=a)throw ls.bytes=0,new RangeError("Could not decode varint");i=r[o++],e+=s<28?(i&Mo)<<s:(i&Mo)*Math.pow(2,s),s+=7}while(i>=_c);return ls.bytes=o-n,e}var Vc=Math.pow(2,7),Oc=Math.pow(2,14),Dc=Math.pow(2,21),Mc=Math.pow(2,28),Kc=Math.pow(2,35),Pc=Math.pow(2,42),Fc=Math.pow(2,49),$c=Math.pow(2,56),qc=Math.pow(2,63),zc=function(r){return r<Vc?1:r<Oc?2:r<Dc?3:r<Mc?4:r<Kc?5:r<Pc?6:r<Fc?7:r<$c?8:r<qc?9:10},jc={encode:Uc,decode:Hc,encodingLength:zc},Gc=jc,sr=Gc;function or(r,t=0){return[sr.decode(r,t),sr.decode.bytes]}function Te(r,t,e=0){return sr.encode(r,t,e),t}function Re(r){return sr.encodingLength(r)}function At(r,t){let e=t.byteLength,n=Re(r),s=n+Re(e),o=new Uint8Array(s+e);return Te(r,o,0),Te(e,o,n),o.set(t,s),new Le(r,e,t,o)}function Po(r){let t=Kt(r),[e,n]=or(t),[s,o]=or(t.subarray(n)),i=t.subarray(n+o);if(i.byteLength!==s)throw new Error("Incorrect length");return new Le(e,s,i,t)}function Fo(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&Ro(r.bytes,e.bytes)}}var Le=class{code;size;digest;bytes;constructor(t,e,n,s){this.code=t,this.size=e,this.digest=n,this.bytes=s}};function $o(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return Wc(e,us(r),t??ut.encoder);default:return Jc(e,us(r),t??Ue.encoder)}}var qo=new WeakMap;function us(r){let t=qo.get(r);if(t==null){let e=new Map;return qo.set(r,e),e}return t}var Tt=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!==ar)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==Yc)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=At(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&&Fo(t.multihash,n.multihash)}toString(t){return $o(this,t)}toJSON(){return{"/":$o(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??zo(n,s,o.bytes))}else if(e[Xc]===!0){let{version:n,multihash:s,code:o}=e,i=Po(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!==ar)throw new Error(`Version 0 CID must use dag-pb (code: ${ar}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let s=zo(t,e,n.bytes);return new r(t,e,n,s)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,ar,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=Kt(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 Le(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]=or(t.subarray(e));return e+=h,f},s=n(),o=ar;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]=Zc(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 us(o).set(n,t),o}};function Zc(r,t){switch(r[0]){case"Q":{let e=t??ut;return[ut.prefix,e.decode(`${ut.prefix}${r}`)]}case ut.prefix:{let e=t??ut;return[ut.prefix,e.decode(r)]}case Ue.prefix:{let e=t??Ue;return[Ue.prefix,e.decode(r)]}case nr.prefix:{let e=t??nr;return[nr.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 Wc(r,t,e){let{prefix:n}=e;if(n!==ut.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 Jc(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 ar=112,Yc=18;function zo(r,t,e){let n=Re(r),s=n+Re(t),o=new Uint8Array(s+e.byteLength);return Te(r,o,0),Te(t,o,n),o.set(e,s),o}var Xc=Symbol.for("@ipld/js-cid/CID");var fs={};it(fs,{identity:()=>cr});var jo=0,Qc="identity",Go=Kt;function tl(r){return At(jo,Go(r))}var cr={code:jo,name:Qc,encode:Go,digest:tl};function St(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 He(r){if(!Number.isSafeInteger(r)||r<0)throw new Error(`positive integer expected, not ${r}`)}function el(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function _e(r,...t){if(!el(r))throw new Error("Uint8Array expected");if(t.length>0&&!t.includes(r.length))throw new Error(`Uint8Array expected of length ${t}, not of length=${r.length}`)}function Vr(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");He(r.outputLen),He(r.blockLen)}function Ve(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 Zo(r,t){_e(r);let e=t.outputLen;if(r.length<e)throw new Error(`digestInto() expects output buffer of length at least ${e}`)}var ye=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;var De=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),kt=(r,t)=>r<<32-t|r>>>t,Or=(r,t)=>r<<t|r>>>32-t>>>0,th=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;function Wo(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function ee(r){return typeof r=="string"&&(r=Wo(r)),_e(r),r}function hs(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];_e(s),t+=s.length}let e=new Uint8Array(t);for(let n=0,s=0;n<r.length;n++){let o=r[n];e.set(o,s),s+=o.length}return e}var Oe=class{clone(){return this._cloneInto()}},rl={}.toString;function Jo(r,t){if(t!==void 0&&rl.call(t)!=="[object Object]")throw new Error("Options should be object or undefined");return Object.assign(r,t)}function Me(r){let t=n=>r().update(ee(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function Ke(r=32){if(ye&&typeof ye.getRandomValues=="function")return ye.getRandomValues(new Uint8Array(r));if(ye&&typeof ye.randomBytes=="function")return ye.randomBytes(r);throw new Error("crypto.getRandomValues must be defined")}function nl(r,t,e,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(t,e,n);let s=BigInt(32),o=BigInt(4294967295),i=Number(e>>s&o),a=Number(e&o),c=n?4:0,u=n?0:4;r.setUint32(t+c,i,n),r.setUint32(t+u,a,n)}var Dr=(r,t,e)=>r&t^~r&e,Mr=(r,t,e)=>r&t^r&e^t&e,re=class extends Oe{constructor(t,e,n,s){super(),this.blockLen=t,this.outputLen=e,this.padOffset=n,this.isLE=s,this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.buffer=new Uint8Array(t),this.view=De(this.buffer)}update(t){Ve(this);let{view:e,buffer:n,blockLen:s}=this;t=ee(t);let o=t.length;for(let i=0;i<o;){let a=Math.min(s-this.pos,o-i);if(a===s){let c=De(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){Ve(this),Zo(t,this),this.finished=!0;let{buffer:e,view:n,blockLen:s,isLE:o}=this,{pos:i}=this;e[i++]=128,this.buffer.subarray(i).fill(0),this.padOffset>s-i&&(this.process(n,0),i=0);for(let f=i;f<s;f++)e[f]=0;nl(n,s-8,BigInt(this.length*8),o),this.process(n,0);let a=De(t),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should 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||(t=new this.constructor),t.set(...this.get());let{blockLen:e,buffer:n,length:s,finished:o,destroyed:i,pos:a}=this;return t.length=s,t.pos=a,t.finished=o,t.destroyed=i,s%e&&t.buffer.set(n),t}};var Kr=BigInt(4294967295),ds=BigInt(32);function Yo(r,t=!1){return t?{h:Number(r&Kr),l:Number(r>>ds&Kr)}:{h:Number(r>>ds&Kr)|0,l:Number(r&Kr)|0}}function sl(r,t=!1){let e=new Uint32Array(r.length),n=new Uint32Array(r.length);for(let s=0;s<r.length;s++){let{h:o,l:i}=Yo(r[s],t);[e[s],n[s]]=[o,i]}return[e,n]}var ol=(r,t)=>BigInt(r>>>0)<<ds|BigInt(t>>>0),il=(r,t,e)=>r>>>e,al=(r,t,e)=>r<<32-e|t>>>e,cl=(r,t,e)=>r>>>e|t<<32-e,ll=(r,t,e)=>r<<32-e|t>>>e,ul=(r,t,e)=>r<<64-e|t>>>e-32,fl=(r,t,e)=>r>>>e-32|t<<64-e,hl=(r,t)=>t,dl=(r,t)=>r,gl=(r,t,e)=>r<<e|t>>>32-e,pl=(r,t,e)=>t<<e|r>>>32-e,ml=(r,t,e)=>t<<e-32|r>>>64-e,yl=(r,t,e)=>r<<e-32|t>>>64-e;function bl(r,t,e,n){let s=(t>>>0)+(n>>>0);return{h:r+e+(s/2**32|0)|0,l:s|0}}var xl=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),wl=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,vl=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),Bl=(r,t,e,n,s)=>t+e+n+s+(r/2**32|0)|0,El=(r,t,e,n,s)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(s>>>0),Al=(r,t,e,n,s,o)=>t+e+n+s+o+(r/2**32|0)|0;var Sl={fromBig:Yo,split:sl,toBig:ol,shrSH:il,shrSL:al,rotrSH:cl,rotrSL:ll,rotrBH:ul,rotrBL:fl,rotr32H:hl,rotr32L:dl,rotlSH:gl,rotlSL:pl,rotlBH:ml,rotlBL:yl,add:bl,add3L:xl,add3H:wl,add4L:vl,add4H:Bl,add5H:Al,add5L:El},_=Sl;var[kl,Il]=_.split(["0x428a2f98d728ae22","0x7137449123ef65cd","0xb5c0fbcfec4d3b2f","0xe9b5dba58189dbbc","0x3956c25bf348b538","0x59f111f1b605d019","0x923f82a4af194f9b","0xab1c5ed5da6d8118","0xd807aa98a3030242","0x12835b0145706fbe","0x243185be4ee4b28c","0x550c7dc3d5ffb4e2","0x72be5d74f27b896f","0x80deb1fe3b1696b1","0x9bdc06a725c71235","0xc19bf174cf692694","0xe49b69c19ef14ad2","0xefbe4786384f25e3","0x0fc19dc68b8cd5b5","0x240ca1cc77ac9c65","0x2de92c6f592b0275","0x4a7484aa6ea6e483","0x5cb0a9dcbd41fbd4","0x76f988da831153b5","0x983e5152ee66dfab","0xa831c66d2db43210","0xb00327c898fb213f","0xbf597fc7beef0ee4","0xc6e00bf33da88fc2","0xd5a79147930aa725","0x06ca6351e003826f","0x142929670a0e6e70","0x27b70a8546d22ffc","0x2e1b21385c26c926","0x4d2c6dfc5ac42aed","0x53380d139d95b3df","0x650a73548baf63de","0x766a0abb3c77b2a8","0x81c2c92e47edaee6","0x92722c851482353b","0xa2bfe8a14cf10364","0xa81a664bbc423001","0xc24b8b70d0f89791","0xc76c51a30654be30","0xd192e819d6ef5218","0xd69906245565a910","0xf40e35855771202a","0x106aa07032bbd1b8","0x19a4c116b8d2d0c8","0x1e376c085141ab53","0x2748774cdf8eeb99","0x34b0bcb5e19b48a8","0x391c0cb3c5c95a63","0x4ed8aa4ae3418acb","0x5b9cca4f7763e373","0x682e6ff3d6b2b8a3","0x748f82ee5defb2fc","0x78a5636f43172f60","0x84c87814a1f0ab72","0x8cc702081a6439ec","0x90befffa23631e28","0xa4506cebde82bde9","0xbef9a3f7b2c67915","0xc67178f2e372532b","0xca273eceea26619c","0xd186b8c721c0c207","0xeada7dd6cde0eb1e","0xf57d4f7fee6ed178","0x06f067aa72176fba","0x0a637dc5a2c898a6","0x113f9804bef90dae","0x1b710b35131c471b","0x28db77f523047d84","0x32caab7b40c72493","0x3c9ebe0a15c9bebc","0x431d67c49c100d4c","0x4cc5d4becb3e42b6","0x597f299cfc657e2a","0x5fcb6fab3ad6faec","0x6c44198c4a475817"].map(r=>BigInt(r))),ne=new Uint32Array(80),se=new Uint32Array(80),gs=class extends re{constructor(){super(128,64,16,!1),this.Ah=1779033703,this.Al=-205731576,this.Bh=-1150833019,this.Bl=-2067093701,this.Ch=1013904242,this.Cl=-23791573,this.Dh=-1521486534,this.Dl=1595750129,this.Eh=1359893119,this.El=-1377402159,this.Fh=-1694144372,this.Fl=725511199,this.Gh=528734635,this.Gl=-79577749,this.Hh=1541459225,this.Hl=327033209}get(){let{Ah:t,Al:e,Bh:n,Bl:s,Ch:o,Cl:i,Dh:a,Dl:c,Eh:u,El:l,Fh:f,Fl:h,Gh:v,Gl:w,Hh:y,Hl:d}=this;return[t,e,n,s,o,i,a,c,u,l,f,h,v,w,y,d]}set(t,e,n,s,o,i,a,c,u,l,f,h,v,w,y,d){this.Ah=t|0,this.Al=e|0,this.Bh=n|0,this.Bl=s|0,this.Ch=o|0,this.Cl=i|0,this.Dh=a|0,this.Dl=c|0,this.Eh=u|0,this.El=l|0,this.Fh=f|0,this.Fl=h|0,this.Gh=v|0,this.Gl=w|0,this.Hh=y|0,this.Hl=d|0}process(t,e){for(let p=0;p<16;p++,e+=4)ne[p]=t.getUint32(e),se[p]=t.getUint32(e+=4);for(let p=16;p<80;p++){let S=ne[p-15]|0,R=se[p-15]|0,T=_.rotrSH(S,R,1)^_.rotrSH(S,R,8)^_.shrSH(S,R,7),k=_.rotrSL(S,R,1)^_.rotrSL(S,R,8)^_.shrSL(S,R,7),I=ne[p-2]|0,U=se[p-2]|0,Y=_.rotrSH(I,U,19)^_.rotrBH(I,U,61)^_.shrSH(I,U,6),P=_.rotrSL(I,U,19)^_.rotrBL(I,U,61)^_.shrSL(I,U,6),V=_.add4L(k,P,se[p-7],se[p-16]),X=_.add4H(V,T,Y,ne[p-7],ne[p-16]);ne[p]=X|0,se[p]=V|0}let{Ah:n,Al:s,Bh:o,Bl:i,Ch:a,Cl:c,Dh:u,Dl:l,Eh:f,El:h,Fh:v,Fl:w,Gh:y,Gl:d,Hh:b,Hl:B}=this;for(let p=0;p<80;p++){let S=_.rotrSH(f,h,14)^_.rotrSH(f,h,18)^_.rotrBH(f,h,41),R=_.rotrSL(f,h,14)^_.rotrSL(f,h,18)^_.rotrBL(f,h,41),T=f&v^~f&y,k=h&w^~h&d,I=_.add5L(B,R,k,Il[p],se[p]),U=_.add5H(I,b,S,T,kl[p],ne[p]),Y=I|0,P=_.rotrSH(n,s,28)^_.rotrBH(n,s,34)^_.rotrBH(n,s,39),V=_.rotrSL(n,s,28)^_.rotrBL(n,s,34)^_.rotrBL(n,s,39),X=n&o^n&a^o&a,E=s&i^s&c^i&c;b=y|0,B=d|0,y=v|0,d=w|0,v=f|0,w=h|0,{h:f,l:h}=_.add(u|0,l|0,U|0,Y|0),u=a|0,l=c|0,a=o|0,c=i|0,o=n|0,i=s|0;let N=_.add3L(Y,V,E);n=_.add3H(N,U,P,X),s=N|0}({h:n,l:s}=_.add(this.Ah|0,this.Al|0,n|0,s|0)),{h:o,l:i}=_.add(this.Bh|0,this.Bl|0,o|0,i|0),{h:a,l:c}=_.add(this.Ch|0,this.Cl|0,a|0,c|0),{h:u,l}=_.add(this.Dh|0,this.Dl|0,u|0,l|0),{h:f,l:h}=_.add(this.Eh|0,this.El|0,f|0,h|0),{h:v,l:w}=_.add(this.Fh|0,this.Fl|0,v|0,w|0),{h:y,l:d}=_.add(this.Gh|0,this.Gl|0,y|0,d|0),{h:b,l:B}=_.add(this.Hh|0,this.Hl|0,b|0,B|0),this.set(n,s,o,i,a,c,u,l,f,h,v,w,y,d,b,B)}roundClean(){ne.fill(0),se.fill(0)}destroy(){this.buffer.fill(0),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}};var Pr=Me(()=>new gs);var $r={};it($r,{aInRange:()=>bt,abool:()=>It,abytes:()=>Pe,bitGet:()=>Ll,bitLen:()=>xs,bitMask:()=>ur,bitSet:()=>Hl,bytesToHex:()=>Ft,bytesToNumberBE:()=>$t,bytesToNumberLE:()=>ie,concatBytes:()=>qt,createHmacDrbg:()=>ws,ensureBytes:()=>J,equalBytes:()=>Tl,hexToBytes:()=>xe,hexToNumber:()=>bs,inRange:()=>lr,isBytes:()=>oe,memoized:()=>ve,notImplemented:()=>Vl,numberToBytesBE:()=>ae,numberToBytesLE:()=>we,numberToHexUnpadded:()=>be,numberToVarBytesBE:()=>Ul,utf8ToBytes:()=>Rl,validateObject:()=>Rt});var ys=BigInt(0),Fr=BigInt(1),Nl=BigInt(2);function oe(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function Pe(r){if(!oe(r))throw new Error("Uint8Array expected")}function It(r,t){if(typeof t!="boolean")throw new Error(`${r} must be valid boolean, got "${t}".`)}var Cl=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function Ft(r){Pe(r);let t="";for(let e=0;e<r.length;e++)t+=Cl[r[e]];return t}function be(r){let t=r.toString(16);return t.length&1?`0${t}`:t}function bs(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return BigInt(r===""?"0":`0x${r}`)}var Pt={_0:48,_9:57,_A:65,_F:70,_a:97,_f:102};function Xo(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 xe(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);let t=r.length,e=t/2;if(t%2)throw new Error("padded 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=Xo(r.charCodeAt(o)),a=Xo(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 $t(r){return bs(Ft(r))}function ie(r){return Pe(r),bs(Ft(Uint8Array.from(r).reverse()))}function ae(r,t){return xe(r.toString(16).padStart(t*2,"0"))}function we(r,t){return ae(r,t).reverse()}function Ul(r){return xe(be(r))}function J(r,t,e){let n;if(typeof t=="string")try{n=xe(t)}catch(o){throw new Error(`${r} must be valid hex string, got "${t}". Cause: ${o}`)}else if(oe(t))n=Uint8Array.from(t);else throw new Error(`${r} must be hex string or Uint8Array`);let s=n.length;if(typeof e=="number"&&s!==e)throw new Error(`${r} expected ${e} bytes, got ${s}`);return n}function qt(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];Pe(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 Tl(r,t){if(r.length!==t.length)return!1;let e=0;for(let n=0;n<r.length;n++)e|=r[n]^t[n];return e===0}function Rl(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}var ps=r=>typeof r=="bigint"&&ys<=r;function lr(r,t,e){return ps(r)&&ps(t)&&ps(e)&&t<=r&&r<e}function bt(r,t,e,n){if(!lr(t,e,n))throw new Error(`expected valid ${r}: ${e} <= n < ${n}, got ${typeof t} ${t}`)}function xs(r){let t;for(t=0;r>ys;r>>=Fr,t+=1);return t}function Ll(r,t){return r>>BigInt(t)&Fr}function Hl(r,t,e){return r|(e?Fr:ys)<<BigInt(t)}var ur=r=>(Nl<<BigInt(r-1))-Fr,ms=r=>new Uint8Array(r),Qo=r=>Uint8Array.from(r);function ws(r,t,e){if(typeof r!="number"||r<2)throw new Error("hashLen must be a number");if(typeof t!="number"||t<2)throw new Error("qByteLen must be a number");if(typeof e!="function")throw new Error("hmacFn must be a function");let n=ms(r),s=ms(r),o=0,i=()=>{n.fill(1),s.fill(0),o=0},a=(...f)=>e(s,n,...f),c=(f=ms())=>{s=a(Qo([0]),f),n=a(),f.length!==0&&(s=a(Qo([1]),f),n=a())},u=()=>{if(o++>=1e3)throw new Error("drbg: tried 1000 values");let f=0,h=[];for(;f<t;){n=a();let v=n.slice();h.push(v),f+=n.length}return qt(...h)};return(f,h)=>{i(),c(f);let v;for(;!(v=h(u()));)c();return i(),v}}var _l={bigint:r=>typeof r=="bigint",function:r=>typeof r=="function",boolean:r=>typeof r=="boolean",string:r=>typeof r=="string",stringOrUint8Array:r=>typeof r=="string"||oe(r),isSafeInteger:r=>Number.isSafeInteger(r),array:r=>Array.isArray(r),field:(r,t)=>t.Fp.isValid(r),hash:r=>typeof r=="function"&&Number.isSafeInteger(r.outputLen)};function Rt(r,t,e={}){let n=(s,o,i)=>{let a=_l[o];if(typeof a!="function")throw new Error(`Invalid validator "${o}", expected function`);let c=r[s];if(!(i&&c===void 0)&&!a(c,r))throw new Error(`Invalid param ${String(s)}=${c} (${typeof c}), expected ${o}`)};for(let[s,o]of Object.entries(t))n(s,o,!1);for(let[s,o]of Object.entries(e))n(s,o,!0);return r}var Vl=()=>{throw new Error("not implemented")};function ve(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 tt=BigInt(0),j=BigInt(1),Be=BigInt(2),Ol=BigInt(3),vs=BigInt(4),ti=BigInt(5),ei=BigInt(8),Dl=BigInt(9),Ml=BigInt(16);function q(r,t){let e=r%t;return e>=tt?e:t+e}function Kl(r,t,e){if(e<=tt||t<tt)throw new Error("Expected power/modulo > 0");if(e===j)return tt;let n=j;for(;t>tt;)t&j&&(n=n*r%e),r=r*r%e,t>>=j;return n}function G(r,t,e){let n=r;for(;t-- >tt;)n*=n,n%=e;return n}function qr(r,t){if(r===tt||t<=tt)throw new Error(`invert: expected positive integers, got n=${r} mod=${t}`);let e=q(r,t),n=t,s=tt,o=j,i=j,a=tt;for(;e!==tt;){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!==j)throw new Error("invert: does not exist");return q(s,t)}function Pl(r){let t=(r-j)/Be,e,n,s;for(e=r-j,n=0;e%Be===tt;e/=Be,n++);for(s=Be;s<r&&Kl(s,t,r)!==r-j;s++);if(n===1){let i=(r+j)/vs;return function(c,u){let l=c.pow(u,i);if(!c.eql(c.sqr(l),u))throw new Error("Cannot find square root");return l}}let o=(e+j)/Be;return function(a,c){if(a.pow(c,t)===a.neg(a.ONE))throw new Error("Cannot find square root");let u=n,l=a.pow(a.mul(a.ONE,s),e),f=a.pow(c,o),h=a.pow(c,e);for(;!a.eql(h,a.ONE);){if(a.eql(h,a.ZERO))return a.ZERO;let v=1;for(let y=a.sqr(h);v<u&&!a.eql(y,a.ONE);v++)y=a.sqr(y);let w=a.pow(l,j<<BigInt(u-v-1));l=a.sqr(w),f=a.mul(f,w),h=a.mul(h,l),u=v}return f}}function Fl(r){if(r%vs===Ol){let t=(r+j)/vs;return function(n,s){let o=n.pow(s,t);if(!n.eql(n.sqr(o),s))throw new Error("Cannot find square root");return o}}if(r%ei===ti){let t=(r-ti)/ei;return function(n,s){let o=n.mul(s,Be),i=n.pow(o,t),a=n.mul(s,i),c=n.mul(n.mul(a,Be),i),u=n.mul(a,n.sub(c,n.ONE));if(!n.eql(n.sqr(u),s))throw new Error("Cannot find square root");return u}}return r%Ml,Pl(r)}var ri=(r,t)=>(q(r,t)&j)===j,$l=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function Bs(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=$l.reduce((n,s)=>(n[s]="function",n),t);return Rt(r,e)}function ql(r,t,e){if(e<tt)throw new Error("Expected power > 0");if(e===tt)return r.ONE;if(e===j)return t;let n=r.ONE,s=t;for(;e>tt;)e&j&&(n=r.mul(n,s)),s=r.sqr(s),e>>=j;return n}function zl(r,t){let e=new Array(t.length),n=t.reduce((o,i,a)=>r.is0(i)?o:(e[a]=o,r.mul(o,i)),r.ONE),s=r.inv(n);return t.reduceRight((o,i,a)=>r.is0(i)?o:(e[a]=r.mul(o,e[a]),r.mul(o,i)),s),e}function Es(r,t){let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function ce(r,t,e=!1,n={}){if(r<=tt)throw new Error(`Expected Field ORDER > 0, got ${r}`);let{nBitLength:s,nByteLength:o}=Es(r,t);if(o>2048)throw new Error("Field lengths over 2048 bytes are not supported");let i=Fl(r),a=Object.freeze({ORDER:r,BITS:s,BYTES:o,MASK:ur(s),ZERO:tt,ONE:j,create:c=>q(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error(`Invalid field element: expected bigint, got ${typeof c}`);return tt<=c&&c<r},is0:c=>c===tt,isOdd:c=>(c&j)===j,neg:c=>q(-c,r),eql:(c,u)=>c===u,sqr:c=>q(c*c,r),add:(c,u)=>q(c+u,r),sub:(c,u)=>q(c-u,r),mul:(c,u)=>q(c*u,r),pow:(c,u)=>ql(a,c,u),div:(c,u)=>q(c*qr(u,r),r),sqrN:c=>c*c,addN:(c,u)=>c+u,subN:(c,u)=>c-u,mulN:(c,u)=>c*u,inv:c=>qr(c,r),sqrt:n.sqrt||(c=>i(a,c)),invertBatch:c=>zl(a,c),cmov:(c,u,l)=>l?u:c,toBytes:c=>e?we(c,o):ae(c,o),fromBytes:c=>{if(c.length!==o)throw new Error(`Fp.fromBytes: expected ${o}, got ${c.length}`);return e?ie(c):$t(c)}});return Object.freeze(a)}function ni(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 As(r){let t=ni(r);return t+Math.ceil(t/2)}function si(r,t,e=!1){let n=r.length,s=ni(t),o=As(t);if(n<16||n<o||n>1024)throw new Error(`expected ${o}-1024 bytes of input, got ${n}`);let i=e?$t(r):ie(r),a=q(i,t-j)+j;return e?we(a,s):ae(a,s)}var Gl=BigInt(0),Ss=BigInt(1),ks=new WeakMap,oi=new WeakMap;function zr(r,t){let e=(o,i)=>{let a=i.negate();return o?a:i},n=o=>{if(!Number.isSafeInteger(o)||o<=0||o>t)throw new Error(`Wrong window size=${o}, should be [1..${t}]`)},s=o=>{n(o);let i=Math.ceil(t/o)+1,a=2**(o-1);return{windows:i,windowSize:a}};return{constTimeNegate:e,unsafeLadder(o,i){let a=r.ZERO,c=o;for(;i>Gl;)i&Ss&&(a=a.add(c)),c=c.double(),i>>=Ss;return a},precomputeWindow(o,i){let{windows:a,windowSize:c}=s(i),u=[],l=o,f=l;for(let h=0;h<a;h++){f=l,u.push(f);for(let v=1;v<c;v++)f=f.add(l),u.push(f);l=f.double()}return u},wNAF(o,i,a){let{windows:c,windowSize:u}=s(o),l=r.ZERO,f=r.BASE,h=BigInt(2**o-1),v=2**o,w=BigInt(o);for(let y=0;y<c;y++){let d=y*u,b=Number(a&h);a>>=w,b>u&&(b-=v,a+=Ss);let B=d,p=d+Math.abs(b)-1,S=y%2!==0,R=b<0;b===0?f=f.add(e(S,i[B])):l=l.add(e(R,i[p]))}return{p:l,f}},wNAFCached(o,i,a){let c=oi.get(o)||1,u=ks.get(o);return u||(u=this.precomputeWindow(o,c),c!==1&&ks.set(o,a(u))),this.wNAF(c,u,i)},setWindowSize(o,i){n(i),oi.set(o,i),ks.delete(o)}}}function jr(r,t,e,n){if(!Array.isArray(e)||!Array.isArray(n)||n.length!==e.length)throw new Error("arrays of points and scalars must have equal length");n.forEach((l,f)=>{if(!t.isValid(l))throw new Error(`wrong scalar at index ${f}`)}),e.forEach((l,f)=>{if(!(l instanceof r))throw new Error(`wrong point at index ${f}`)});let s=xs(BigInt(e.length)),o=s>12?s-3:s>4?s-2:s?2:1,i=(1<<o)-1,a=new Array(i+1).fill(r.ZERO),c=Math.floor((t.BITS-1)/o)*o,u=r.ZERO;for(let l=c;l>=0;l-=o){a.fill(r.ZERO);for(let h=0;h<n.length;h++){let v=n[h],w=Number(v>>BigInt(l)&BigInt(i));a[w]=a[w].add(e[h])}let f=r.ZERO;for(let h=a.length-1,v=r.ZERO;h>0;h--)v=v.add(a[h]),f=f.add(v);if(u=u.add(f),l!==0)for(let h=0;h<o;h++)u=u.double()}return u}function fr(r){return Bs(r.Fp),Rt(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...Es(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Nt=BigInt(0),xt=BigInt(1),Gr=BigInt(2),Zl=BigInt(8),Wl={zip215:!0};function Jl(r){let t=fr(r);return Rt(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function ii(r){let t=Jl(r),{Fp:e,n,prehash:s,hash:o,randomBytes:i,nByteLength:a,h:c}=t,u=Gr<<BigInt(a*8)-xt,l=e.create,f=ce(t.n,t.nBitLength),h=t.uvRatio||((m,g)=>{try{return{isValid:!0,value:e.sqrt(m*e.inv(g))}}catch{return{isValid:!1,value:Nt}}}),v=t.adjustScalarBytes||(m=>m),w=t.domain||((m,g,x)=>{if(It("phflag",x),g.length||x)throw new Error("Contexts/pre-hash are not supported");return m});function y(m,g){bt("coordinate "+m,g,Nt,u)}function d(m){if(!(m instanceof p))throw new Error("ExtendedPoint expected")}let b=ve((m,g)=>{let{ex:x,ey:C,ez:L}=m,H=m.is0();g==null&&(g=H?Zl:e.inv(L));let O=l(x*g),K=l(C*g),D=l(L*g);if(H)return{x:Nt,y:xt};if(D!==xt)throw new Error("invZ was invalid");return{x:O,y:K}}),B=ve(m=>{let{a:g,d:x}=t;if(m.is0())throw new Error("bad point: ZERO");let{ex:C,ey:L,ez:H,et:O}=m,K=l(C*C),D=l(L*L),F=l(H*H),z=l(F*F),rt=l(K*g),nt=l(F*l(rt+D)),ot=l(z+l(x*l(K*D)));if(nt!==ot)throw new Error("bad point: equation left != right (1)");let dt=l(C*L),Q=l(H*O);if(dt!==Q)throw new Error("bad point: equation left != right (2)");return!0});class p{constructor(g,x,C,L){this.ex=g,this.ey=x,this.ez=C,this.et=L,y("x",g),y("y",x),y("z",C),y("t",L),Object.freeze(this)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(g){if(g instanceof p)throw new Error("extended point not allowed");let{x,y:C}=g||{};return y("x",x),y("y",C),new p(x,C,xt,l(x*C))}static normalizeZ(g){let x=e.invertBatch(g.map(C=>C.ez));return g.map((C,L)=>C.toAffine(x[L])).map(p.fromAffine)}static msm(g,x){return jr(p,f,g,x)}_setWindowSize(g){T.setWindowSize(this,g)}assertValidity(){B(this)}equals(g){d(g);let{ex:x,ey:C,ez:L}=this,{ex:H,ey:O,ez:K}=g,D=l(x*K),F=l(H*L),z=l(C*K),rt=l(O*L);return D===F&&z===rt}is0(){return this.equals(p.ZERO)}negate(){return new p(l(-this.ex),this.ey,this.ez,l(-this.et))}double(){let{a:g}=t,{ex:x,ey:C,ez:L}=this,H=l(x*x),O=l(C*C),K=l(Gr*l(L*L)),D=l(g*H),F=x+C,z=l(l(F*F)-H-O),rt=D+O,nt=rt-K,ot=D-O,dt=l(z*nt),Q=l(rt*ot),yt=l(z*ot),Mt=l(nt*rt);return new p(dt,Q,Mt,yt)}add(g){d(g);let{a:x,d:C}=t,{ex:L,ey:H,ez:O,et:K}=this,{ex:D,ey:F,ez:z,et:rt}=g;if(x===BigInt(-1)){let Bo=l((H-L)*(F+D)),Eo=l((H+L)*(F-D)),ts=l(Eo-Bo);if(ts===Nt)return this.double();let Ao=l(O*Gr*rt),So=l(K*Gr*z),ko=So+Ao,Io=Eo+Bo,No=So-Ao,ec=l(ko*ts),rc=l(Io*No),nc=l(ko*No),sc=l(ts*Io);return new p(ec,rc,sc,nc)}let nt=l(L*D),ot=l(H*F),dt=l(K*C*rt),Q=l(O*z),yt=l((L+H)*(D+F)-nt-ot),Mt=Q-dt,Xe=Q+dt,Qe=l(ot-x*nt),Ya=l(yt*Mt),Xa=l(Xe*Qe),Qa=l(yt*Qe),tc=l(Mt*Xe);return new p(Ya,Xa,tc,Qa)}subtract(g){return this.add(g.negate())}wNAF(g){return T.wNAFCached(this,g,p.normalizeZ)}multiply(g){let x=g;bt("scalar",x,xt,n);let{p:C,f:L}=this.wNAF(x);return p.normalizeZ([C,L])[0]}multiplyUnsafe(g){let x=g;return bt("scalar",x,Nt,n),x===Nt?R:this.equals(R)||x===xt?this:this.equals(S)?this.wNAF(x).p:T.unsafeLadder(this,x)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return T.unsafeLadder(this,n).is0()}toAffine(g){return b(this,g)}clearCofactor(){let{h:g}=t;return g===xt?this:this.multiplyUnsafe(g)}static fromHex(g,x=!1){let{d:C,a:L}=t,H=e.BYTES;g=J("pointHex",g,H),It("zip215",x);let O=g.slice(),K=g[H-1];O[H-1]=K&-129;let D=ie(O),F=x?u:e.ORDER;bt("pointHex.y",D,Nt,F);let z=l(D*D),rt=l(z-xt),nt=l(C*z-L),{isValid:ot,value:dt}=h(rt,nt);if(!ot)throw new Error("Point.fromHex: invalid y coordinate");let Q=(dt&xt)===xt,yt=(K&128)!==0;if(!x&&dt===Nt&&yt)throw new Error("Point.fromHex: x=0 and x_0=1");return yt!==Q&&(dt=l(-dt)),p.fromAffine({x:dt,y:D})}static fromPrivateKey(g){return U(g).point}toRawBytes(){let{x:g,y:x}=this.toAffine(),C=we(x,e.BYTES);return C[C.length-1]|=g&xt?128:0,C}toHex(){return Ft(this.toRawBytes())}}p.BASE=new p(t.Gx,t.Gy,xt,l(t.Gx*t.Gy)),p.ZERO=new p(Nt,xt,xt,Nt);let{BASE:S,ZERO:R}=p,T=zr(p,a*8);function k(m){return q(m,n)}function I(m){return k(ie(m))}function U(m){let g=a;m=J("private key",m,g);let x=J("hashed private key",o(m),2*g),C=v(x.slice(0,g)),L=x.slice(g,2*g),H=I(C),O=S.multiply(H),K=O.toRawBytes();return{head:C,prefix:L,scalar:H,point:O,pointBytes:K}}function Y(m){return U(m).pointBytes}function P(m=new Uint8Array,...g){let x=qt(...g);return I(o(w(x,J("context",m),!!s)))}function V(m,g,x={}){m=J("message",m),s&&(m=s(m));let{prefix:C,scalar:L,pointBytes:H}=U(g),O=P(x.context,C,m),K=S.multiply(O).toRawBytes(),D=P(x.context,K,H,m),F=k(O+D*L);bt("signature.s",F,Nt,n);let z=qt(K,we(F,e.BYTES));return J("result",z,a*2)}let X=Wl;function E(m,g,x,C=X){let{context:L,zip215:H}=C,O=e.BYTES;m=J("signature",m,2*O),g=J("message",g),H!==void 0&&It("zip215",H),s&&(g=s(g));let K=ie(m.slice(O,2*O)),D,F,z;try{D=p.fromHex(x,H),F=p.fromHex(m.slice(0,O),H),z=S.multiplyUnsafe(K)}catch{return!1}if(!H&&D.isSmallOrder())return!1;let rt=P(L,F.toRawBytes(),D.toRawBytes(),g);return F.add(D.multiplyUnsafe(rt)).subtract(z).clearCofactor().equals(p.ZERO)}return S._setWindowSize(8),{CURVE:t,getPublicKey:Y,sign:V,verify:E,ExtendedPoint:p,utils:{getExtendedPublicKey:U,randomPrivateKey:()=>i(e.BYTES),precompute(m=8,g=p.BASE){return g._setWindowSize(m),g.multiply(BigInt(3)),g}}}}var Is=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),ai=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),Eh=BigInt(0),Yl=BigInt(1),ci=BigInt(2),Ah=BigInt(3),Xl=BigInt(5),Ql=BigInt(8);function tu(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),s=BigInt(80),o=Is,a=r*r%o*r%o,c=G(a,ci,o)*a%o,u=G(c,Yl,o)*r%o,l=G(u,Xl,o)*u%o,f=G(l,t,o)*l%o,h=G(f,e,o)*f%o,v=G(h,n,o)*h%o,w=G(v,s,o)*v%o,y=G(w,s,o)*v%o,d=G(y,t,o)*l%o;return{pow_p_5_8:G(d,ci,o)*r%o,b2:a}}function eu(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function ru(r,t){let e=Is,n=q(t*t*t,e),s=q(n*n*t,e),o=tu(r*s).pow_p_5_8,i=q(r*n*o,e),a=q(t*i*i,e),c=i,u=q(i*ai,e),l=a===r,f=a===q(-r,e),h=a===q(-r*ai,e);return l&&(i=c),(f||h)&&(i=u),ri(i,e)&&(i=q(-i,e)),{isValid:l||f,value:i}}var nu=ce(Is,void 0,!0),su={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:nu,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:Ql,Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:Pr,randomBytes:Ke,adjustScalarBytes:eu,uvRatio:ru},Fe=ii(su);var $e=32,Lt=64,Zr=32;function li(){let r=Fe.utils.randomPrivateKey(),t=Fe.getPublicKey(r);return{privateKey:di(r,t),publicKey:t}}function ui(r){if(r.length!==Zr)throw new TypeError('"seed" must be 32 bytes in length.');if(!(r instanceof Uint8Array))throw new TypeError('"seed" must be a node.js Buffer, or Uint8Array.');let t=r,e=Fe.getPublicKey(t);return{privateKey:di(t,e),publicKey:e}}function fi(r,t){let e=r.subarray(0,Zr);return Fe.sign(t instanceof Uint8Array?t:t.subarray(),e)}function hi(r,t,e){return Fe.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}function di(r,t){let e=new Uint8Array(Lt);for(let n=0;n<Zr;n++)e[n]=r[n],e[Zr+n]=t[n];return e}var hr=class{type="Ed25519";raw;constructor(t){this.raw=qe(t,$e)}toMultihash(){return cr.digest(dr(this))}toCID(){return Tt.createV1(114,this.toMultihash())}toString(){return ut.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:St(this.raw,t.raw)}verify(t,e){return hi(this.raw,e,t)}},Ee=class{type="Ed25519";raw;publicKey;constructor(t,e){this.raw=qe(t,Lt),this.publicKey=new hr(e)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:St(this.raw,t.raw)}sign(t){return fi(this.raw,t)}};function Ns(r){if(r.length>Lt){r=qe(r,Lt+$e);let n=r.subarray(0,Lt),s=r.subarray(Lt,r.length);return new Ee(n,s)}r=qe(r,Lt);let t=r.subarray(0,Lt),e=r.subarray($e);return new Ee(t,e)}function Wr(r){return r=qe(r,$e),new hr(r)}async function pi(){let{privateKey:r,publicKey:t}=li();return new Ee(r,t)}async function mi(r){let{privateKey:t,publicKey:e}=ui(r);return new Ee(t,e)}function qe(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}function Ht(r=0){return new Uint8Array(r)}var ou=Math.pow(2,7),iu=Math.pow(2,14),au=Math.pow(2,21),yi=Math.pow(2,28),bi=Math.pow(2,35),xi=Math.pow(2,42),wi=Math.pow(2,49),gt=128,le=127;function gr(r){if(r<ou)return 1;if(r<iu)return 2;if(r<au)return 3;if(r<yi)return 4;if(r<bi)return 5;if(r<xi)return 6;if(r<wi)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function vi(r,t,e=0){switch(gr(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 Bi(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)*yi,e<gt)||(e=r[t+5],n+=(e&le)*bi,e<gt)||(e=r[t+6],n+=(e&le)*xi,e<gt)||(e=r[t+7],n+=(e&le)*wi,e<gt))return n;throw new RangeError("Could not decode varint")}var Cs=new Float32Array([-0]),ue=new Uint8Array(Cs.buffer);function Ei(r,t,e){Cs[0]=r,t[e]=ue[0],t[e+1]=ue[1],t[e+2]=ue[2],t[e+3]=ue[3]}function Ai(r,t){return ue[0]=r[t],ue[1]=r[t+1],ue[2]=r[t+2],ue[3]=r[t+3],Cs[0]}var Us=new Float64Array([-0]),ft=new Uint8Array(Us.buffer);function Si(r,t,e){Us[0]=r,t[e]=ft[0],t[e+1]=ft[1],t[e+2]=ft[2],t[e+3]=ft[3],t[e+4]=ft[4],t[e+5]=ft[5],t[e+6]=ft[6],t[e+7]=ft[7]}function ki(r,t){return ft[0]=r[t],ft[1]=r[t+1],ft[2]=r[t+2],ft[3]=r[t+3],ft[4]=r[t+4],ft[5]=r[t+5],ft[6]=r[t+6],ft[7]=r[t+7],Us[0]}var cu=BigInt(Number.MAX_SAFE_INTEGER),lu=BigInt(Number.MIN_SAFE_INTEGER),vt=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 Ae;if(t<cu&&t>lu)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>Ii&&(s=0n,++n>Ii&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(t){if(t===0)return Ae;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):Ae}},Ae=new vt(0,0);Ae.toBigInt=function(){return 0n};Ae.zzEncode=Ae.zzDecode=function(){return this};Ae.length=function(){return 1};var Ii=4294967296n;function Ni(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 Ci(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 Ts(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 Ct(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function Jr(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var Rs=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,Ct(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 Ct(this,4);return Jr(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Ct(this,4);return Jr(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Ct(this,4);let t=Ai(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Ct(this,4);let t=ki(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 Ct(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return Ci(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw Ct(this,t);this.pos+=t}else do if(this.pos>=this.len)throw Ct(this);while(this.buf[this.pos++]&128);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 vt(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 Ct(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 Ct(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 Ct(this,8);let t=Jr(this.buf,this.pos+=4),e=Jr(this.buf,this.pos+=4);return new vt(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=Bi(this.buf,this.pos);return this.pos+=gr(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 Ls(r){return new Rs(r instanceof Uint8Array?r:r.subarray())}function Yr(r,t,e){let n=Ls(r);return t.decode(n,void 0,e)}var Hs={};it(Hs,{base10:()=>uu});var uu=te({prefix:"9",name:"base10",alphabet:"0123456789"});var _s={};it(_s,{base16:()=>fu,base16upper:()=>hu});var fu=W({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),hu=W({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Vs={};it(Vs,{base2:()=>du});var du=W({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Os={};it(Os,{base256emoji:()=>bu});var Ti=Array.from("\u{1F680}\u{1FA90}\u2604\u{1F6F0}\u{1F30C}\u{1F311}\u{1F312}\u{1F313}\u{1F314}\u{1F315}\u{1F316}\u{1F317}\u{1F318}\u{1F30D}\u{1F30F}\u{1F30E}\u{1F409}\u2600\u{1F4BB}\u{1F5A5}\u{1F4BE}\u{1F4BF}\u{1F602}\u2764\u{1F60D}\u{1F923}\u{1F60A}\u{1F64F}\u{1F495}\u{1F62D}\u{1F618}\u{1F44D}\u{1F605}\u{1F44F}\u{1F601}\u{1F525}\u{1F970}\u{1F494}\u{1F496}\u{1F499}\u{1F622}\u{1F914}\u{1F606}\u{1F644}\u{1F4AA}\u{1F609}\u263A\u{1F44C}\u{1F917}\u{1F49C}\u{1F614}\u{1F60E}\u{1F607}\u{1F339}\u{1F926}\u{1F389}\u{1F49E}\u270C\u2728\u{1F937}\u{1F631}\u{1F60C}\u{1F338}\u{1F64C}\u{1F60B}\u{1F497}\u{1F49A}\u{1F60F}\u{1F49B}\u{1F642}\u{1F493}\u{1F929}\u{1F604}\u{1F600}\u{1F5A4}\u{1F603}\u{1F4AF}\u{1F648}\u{1F447}\u{1F3B6}\u{1F612}\u{1F92D}\u2763\u{1F61C}\u{1F48B}\u{1F440}\u{1F62A}\u{1F611}\u{1F4A5}\u{1F64B}\u{1F61E}\u{1F629}\u{1F621}\u{1F92A}\u{1F44A}\u{1F973}\u{1F625}\u{1F924}\u{1F449}\u{1F483}\u{1F633}\u270B\u{1F61A}\u{1F61D}\u{1F634}\u{1F31F}\u{1F62C}\u{1F643}\u{1F340}\u{1F337}\u{1F63B}\u{1F613}\u2B50\u2705\u{1F97A}\u{1F308}\u{1F608}\u{1F918}\u{1F4A6}\u2714\u{1F623}\u{1F3C3}\u{1F490}\u2639\u{1F38A}\u{1F498}\u{1F620}\u261D\u{1F615}\u{1F33A}\u{1F382}\u{1F33B}\u{1F610}\u{1F595}\u{1F49D}\u{1F64A}\u{1F639}\u{1F5E3}\u{1F4AB}\u{1F480}\u{1F451}\u{1F3B5}\u{1F91E}\u{1F61B}\u{1F534}\u{1F624}\u{1F33C}\u{1F62B}\u26BD\u{1F919}\u2615\u{1F3C6}\u{1F92B}\u{1F448}\u{1F62E}\u{1F646}\u{1F37B}\u{1F343}\u{1F436}\u{1F481}\u{1F632}\u{1F33F}\u{1F9E1}\u{1F381}\u26A1\u{1F31E}\u{1F388}\u274C\u270A\u{1F44B}\u{1F630}\u{1F928}\u{1F636}\u{1F91D}\u{1F6B6}\u{1F4B0}\u{1F353}\u{1F4A2}\u{1F91F}\u{1F641}\u{1F6A8}\u{1F4A8}\u{1F92C}\u2708\u{1F380}\u{1F37A}\u{1F913}\u{1F619}\u{1F49F}\u{1F331}\u{1F616}\u{1F476}\u{1F974}\u25B6\u27A1\u2753\u{1F48E}\u{1F4B8}\u2B07\u{1F628}\u{1F31A}\u{1F98B}\u{1F637}\u{1F57A}\u26A0\u{1F645}\u{1F61F}\u{1F635}\u{1F44E}\u{1F932}\u{1F920}\u{1F927}\u{1F4CC}\u{1F535}\u{1F485}\u{1F9D0}\u{1F43E}\u{1F352}\u{1F617}\u{1F911}\u{1F30A}\u{1F92F}\u{1F437}\u260E\u{1F4A7}\u{1F62F}\u{1F486}\u{1F446}\u{1F3A4}\u{1F647}\u{1F351}\u2744\u{1F334}\u{1F4A3}\u{1F438}\u{1F48C}\u{1F4CD}\u{1F940}\u{1F922}\u{1F445}\u{1F4A1}\u{1F4A9}\u{1F450}\u{1F4F8}\u{1F47B}\u{1F910}\u{1F92E}\u{1F3BC}\u{1F975}\u{1F6A9}\u{1F34E}\u{1F34A}\u{1F47C}\u{1F48D}\u{1F4E3}\u{1F942}"),gu=Ti.reduce((r,t,e)=>(r[e]=t,r),[]),pu=Ti.reduce((r,t,e)=>{let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);return r[n]=e,r},[]);function mu(r){return r.reduce((t,e)=>(t+=gu[e],t),"")}function yu(r){let t=[];for(let e of r){let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);let s=pu[n];if(s==null)throw new Error(`Non-base256emoji character: ${e}`);t.push(s)}return new Uint8Array(t)}var bu=Ce({prefix:"\u{1F680}",name:"base256emoji",encode:mu,decode:yu});var Ms={};it(Ms,{base64:()=>Ds,base64pad:()=>xu,base64url:()=>wu,base64urlpad:()=>vu});var Ds=W({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),xu=W({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),wu=W({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),vu=W({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Ks={};it(Ks,{base8:()=>Bu});var Bu=W({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Ps={};it(Ps,{identity:()=>Eu});var Eu=Ce({prefix:"\0",name:"identity",encode:r=>Ho(r),decode:r=>Lo(r)});var nd=new TextEncoder,sd=new TextDecoder;var qs={};it(qs,{sha256:()=>Xr,sha512:()=>ku});function $s({name:r,code:t,encode:e}){return new Fs(r,t,e)}var Fs=class{name;code;encode;constructor(t,e,n){this.name=t,this.code=e,this.encode=n}digest(t){if(t instanceof Uint8Array){let e=this.encode(t);return e instanceof Uint8Array?At(this.code,e):e.then(n=>At(this.code,n))}else throw Error("Unknown type, must be binary type")}};function Li(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var Xr=$s({name:"sha2-256",code:18,encode:Li("SHA-256")}),ku=$s({name:"sha2-512",code:19,encode:Li("SHA-512")});var zs={...Ps,...Vs,...Ks,...Hs,..._s,...as,...cs,...is,...Ms,...Os},md={...qs,...fs};function _i(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var Hi=_i("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),js=_i("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=Ht(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),Iu={utf8:Hi,"utf-8":Hi,hex:zs.base16,latin1:js,ascii:js,binary:js,...zs},Qr=Iu;function et(r,t="utf8"){let e=Qr[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function Gs(r){let t=r??8192,e=t>>>1,n,s=t;return function(i){if(i<1||i>e)return Ht(i);s+i>t&&(n=Ht(t),s=0);let a=n.subarray(s,s+=i);return s&7&&(s=(s|7)+1),a}}var Se=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function Zs(){}var Js=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},Nu=Gs();function Cu(r){return globalThis.Buffer!=null?Ht(r):Nu(r)}var mr=class{len;head;tail;states;constructor(){this.len=0,this.head=new Se(Zs,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new Se(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new Ys((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(tn,10,vt.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=vt.fromBigInt(t);return this._push(tn,e.length(),e)}uint64Number(t){return this._push(vi,gr(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=vt.fromBigInt(t).zzEncode();return this._push(tn,e.length(),e)}sint64Number(t){let e=vt.fromNumber(t).zzEncode();return this._push(tn,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(Ws,1,t?1:0)}fixed32(t){return this._push(pr,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=vt.fromBigInt(t);return this._push(pr,4,e.lo)._push(pr,4,e.hi)}fixed64Number(t){let e=vt.fromNumber(t);return this._push(pr,4,e.lo)._push(pr,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(Ei,4,t)}double(t){return this._push(Si,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(Ws,1,0):this.uint32(e)._push(Tu,e,t)}string(t){let e=Ni(t);return e!==0?this.uint32(e)._push(Ts,e,t):this._push(Ws,1,0)}fork(){return this.states=new Js(this),this.head=this.tail=new Se(Zs,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 Se(Zs,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=Cu(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function Ws(r,t,e){t[e]=r&255}function Uu(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var Ys=class extends Se{next;constructor(t,e){super(Uu,t,e),this.next=void 0}};function tn(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 pr(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 Tu(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(mr.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(Ru,t,r),this},mr.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(Lu,t,r),this});function Ru(r,t,e){t.set(r,e)}function Lu(r,t,e){r.length<40?Ts(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(et(r),e)}function Xs(){return new mr}function en(r,t){let e=Xs();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var ze;(function(r){r[r.VARINT=0]="VARINT",r[r.BIT64=1]="BIT64",r[r.LENGTH_DELIMITED=2]="LENGTH_DELIMITED",r[r.START_GROUP=3]="START_GROUP",r[r.END_GROUP=4]="END_GROUP",r[r.BIT32=5]="BIT32"})(ze||(ze={}));function rn(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function Qs(r){function t(s){if(r[s.toString()]==null)throw new Error("Invalid enum value");return r[s]}let e=function(o,i){let a=t(o);i.int32(a)},n=function(o){let i=o.int32();return t(i)};return rn("enum",ze.VARINT,e,n)}function nn(r,t){return rn("message",ze.LENGTH_DELIMITED,r,t)}var Z;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.secp256k1="secp256k1"})(Z||(Z={}));var to;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1"})(to||(to={}));(function(r){r.codec=()=>Qs(to)})(Z||(Z={}));var _t;(function(r){let t;r.codec=()=>(t==null&&(t=nn((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),Z.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let o={},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let a=e.uint32();switch(a>>>3){case 1:{o.Type=Z.codec().decode(e);break}case 2:{o.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return o})),t),r.encode=e=>en(e,r.codec()),r.decode=(e,n)=>Yr(e,r.codec(),n)})(_t||(_t={}));var yr;(function(r){let t;r.codec=()=>(t==null&&(t=nn((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),Z.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let o={},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let a=e.uint32();switch(a>>>3){case 1:{o.Type=Z.codec().decode(e);break}case 2:{o.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return o})),t),r.encode=e=>en(e,r.codec()),r.decode=(e,n)=>Yr(e,r.codec(),n)})(yr||(yr={}));var kr={};it(kr,{MAX_RSA_KEY_SIZE:()=>Zn,generateRSAKeyPair:()=>fo,jwkToJWKKeyPair:()=>Ua,jwkToPkcs1:()=>Wu,jwkToPkix:()=>uo,jwkToRSAPrivateKey:()=>Ca,pkcs1ToJwk:()=>Ia,pkcs1ToRSAPrivateKey:()=>Wn,pkixToJwk:()=>Na,pkixToRSAPublicKey:()=>Jn});var Hu=new Uint32Array([1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298]),fe=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),he=new Uint32Array(64),eo=class extends re{constructor(){super(64,32,8,!1),this.A=fe[0]|0,this.B=fe[1]|0,this.C=fe[2]|0,this.D=fe[3]|0,this.E=fe[4]|0,this.F=fe[5]|0,this.G=fe[6]|0,this.H=fe[7]|0}get(){let{A:t,B:e,C:n,D:s,E:o,F:i,G:a,H:c}=this;return[t,e,n,s,o,i,a,c]}set(t,e,n,s,o,i,a,c){this.A=t|0,this.B=e|0,this.C=n|0,this.D=s|0,this.E=o|0,this.F=i|0,this.G=a|0,this.H=c|0}process(t,e){for(let f=0;f<16;f++,e+=4)he[f]=t.getUint32(e,!1);for(let f=16;f<64;f++){let h=he[f-15],v=he[f-2],w=kt(h,7)^kt(h,18)^h>>>3,y=kt(v,17)^kt(v,19)^v>>>10;he[f]=y+he[f-7]+w+he[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=kt(a,6)^kt(a,11)^kt(a,25),v=l+h+Dr(a,c,u)+Hu[f]+he[f]|0,y=(kt(n,2)^kt(n,13)^kt(n,22))+Mr(n,s,o)|0;l=u,u=c,c=a,a=i+v|0,i=o,o=s,s=n,n=v+y|0}n=n+this.A|0,s=s+this.B|0,o=o+this.C|0,i=i+this.D|0,a=a+this.E|0,c=c+this.F|0,u=u+this.G|0,l=l+this.H|0,this.set(n,s,o,i,a,c,u,l)}roundClean(){he.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var de=Me(()=>new eo);var M=fc(Oi());function ke(r,t){let e=0;if(r.length===1)return r[0];for(let n=r.length-1;n>=0;n--)e+=r[r.length-1-n]*Math.pow(2,t*n);return e}function ge(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 an(...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 no(){let r=new Uint8Array(this.valueHex);if(this.valueHex.byteLength>=2){let a=r[0]===255&&r[1]&128,c=r[0]===0&&(r[1]&128)===0;(a||c)&&this.warnings.push("Needlessly long format")}let t=new ArrayBuffer(this.valueHex.byteLength),e=new Uint8Array(t);for(let a=0;a<this.valueHex.byteLength;a++)e[a]=0;e[0]=r[0]&128;let n=ke(e,8),s=new ArrayBuffer(this.valueHex.byteLength),o=new Uint8Array(s);for(let a=0;a<this.valueHex.byteLength;a++)o[a]=r[a];return o[0]&=127,ke(o,8)-n}function Di(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=ge(i,8,n),c=new Uint8Array(a);return c[0]|=128,a}let s=ge(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 Mi(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 wt(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 Yd=Math.log(2);function cn(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function so(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 Wt(r,t,e,n){return t instanceof Uint8Array?t.byteLength?e<0?(r.error="Wrong parameter: inputOffset less than zero",!1):n<0?(r.error="Wrong parameter: inputLength less than zero",!1):t.byteLength-e-n<0?(r.error="End of input reached before message was fully decoded (inconsistent offset and length values)",!1):!0:(r.error="Wrong parameter: inputBuffer has zero length",!1):(r.error="Wrong parameter: inputBuffer must be 'Uint8Array'",!1)}var xr=class{constructor(){this.items=[]}write(t){this.items.push(t)}final(){return so(this.items)}},br=[new Uint8Array([1])],Ki="0123456789";var Je="",Ut=new ArrayBuffer(0),oo=new Uint8Array(0),wr="EndOfContent",Fi="OCTET STRING",$i="BIT STRING";function Jt(r){var t;return t=class extends r{constructor(...n){var s;super(...n);let o=n[0]||{};this.isHexOnly=(s=o.isHexOnly)!==null&&s!==void 0?s:!1,this.valueHexView=o.valueHex?M.BufferSourceConverter.toUint8Array(o.valueHex):oo}get valueHex(){return this.valueHexView.slice().buffer}set valueHex(n){this.valueHexView=new Uint8Array(n)}fromBER(n,s,o){let i=n instanceof ArrayBuffer?new Uint8Array(n):n;if(!Wt(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",Ut)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:M.Convert.ToHex(this.valueHexView)}}},t.NAME="hexBlock",t}var jt=class{constructor({blockLength:t=0,error:e=Je,warnings:n=[],valueBeforeDecode:s=oo}={}){this.blockLength=t,this.error=e,this.warnings=n,this.valueBeforeDecodeView=M.BufferSourceConverter.toUint8Array(s)}static blockName(){return this.NAME}get valueBeforeDecode(){return this.valueBeforeDecodeView.slice().buffer}set valueBeforeDecode(t){this.valueBeforeDecodeView=new Uint8Array(t)}toJSON(){return{blockName:this.constructor.NAME,blockLength:this.blockLength,error:this.error,warnings:this.warnings,valueBeforeDecode:M.Convert.ToHex(this.valueBeforeDecodeView)}}};jt.NAME="baseBlock";var ht=class extends jt{fromBER(t,e,n){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}toBER(t,e){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}};ht.NAME="valueBlock";var ln=class extends Jt(jt){constructor({idBlock:t={}}={}){var e,n,s,o;super(),t?(this.isHexOnly=(e=t.isHexOnly)!==null&&e!==void 0?e:!1,this.valueHexView=t.valueHex?M.BufferSourceConverter.toUint8Array(t.valueHex):oo,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",Ut}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,a=new Uint8Array(i+1);if(a[0]=e|31,!t){for(let c=0;c<i-1;c++)a[c+1]=o[c]|128;a[i]=o[i-1]}return a.buffer}let n=new Uint8Array(this.valueHexView.byteLength+1);if(n[0]=e|31,!t){let s=this.valueHexView;for(let o=0;o<s.length-1;o++)n[o+1]=s[o]|128;n[this.valueHexView.byteLength]=s[s.length-1]}return n.buffer}fromBER(t,e,n){let s=M.BufferSourceConverter.toUint8Array(t);if(!Wt(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 v=0;v<u.length;v++)h[v]=u[v];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=ke(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}}};ln.NAME="identificationBlock";var un=class extends jt{constructor({lenBlock:t={}}={}){var e,n,s;super(),this.isIndefiniteForm=(e=t.isIndefiniteForm)!==null&&e!==void 0?e:!1,this.longFormUsed=(n=t.longFormUsed)!==null&&n!==void 0?n:!1,this.length=(s=t.length)!==null&&s!==void 0?s:0}fromBER(t,e,n){let s=M.BufferSourceConverter.toUint8Array(t);if(!Wt(this,s,e,n))return-1;let o=s.subarray(e,e+n);if(o.length===0)return this.error="Zero buffer length",-1;if(o[0]===255)return this.error="Length block 0xFF is reserved by standard",-1;if(this.isIndefiniteForm=o[0]===128,this.isIndefiniteForm)return this.blockLength=1,e+this.blockLength;if(this.longFormUsed=!!(o[0]&128),this.longFormUsed===!1)return this.length=o[0],this.blockLength=1,e+this.blockLength;let i=o[0]&127;if(i>8)return this.error="Too big integer",-1;if(i+1>o.length)return this.error="End of input reached before message was fully decoded",-1;let a=e+1,c=s.subarray(a,a+i);return c[i-1]===0&&this.warnings.push("Needlessly long encoded length"),this.length=ke(c,8),this.longFormUsed&&this.length<=127&&this.warnings.push("Unnecessary usage of long length form"),this.blockLength=i+1,e+this.blockLength}toBER(t=!1){let e,n;if(this.length>127&&(this.longFormUsed=!0),this.isIndefiniteForm)return e=new ArrayBuffer(1),t===!1&&(n=new Uint8Array(e),n[0]=128),e;if(this.longFormUsed){let s=ge(this.length,8);if(s.byteLength>127)return this.error="Too big length",Ut;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}}};un.NAME="lengthBlock";var A={},ct=class extends jt{constructor({name:t=Je,optional:e=!1,primitiveSchema:n,...s}={},o){super(s),this.name=t,this.optional=e,n&&(this.primitiveSchema=n),this.idBlock=new ln(s),this.lenBlock=new un(s),this.valueBlock=o?new o(s):new ht(s)}fromBER(t,e,n){let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}toBER(t,e){let n=e||new xr;e||qi(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?Ut:n.final()}toJSON(){let t={...super.toJSON(),idBlock:this.idBlock.toJSON(),lenBlock:this.lenBlock.toJSON(),valueBlock:this.valueBlock.toJSON(),name:this.name,optional:this.optional};return this.primitiveSchema&&(t.primitiveSchema=this.primitiveSchema.toJSON()),t}toString(t="ascii"){return t==="ascii"?this.onAsciiEncoding():M.Convert.ToHex(this.toBER())}onAsciiEncoding(){return`${this.constructor.NAME} : ${M.Convert.ToHex(this.valueBlock.valueBeforeDecodeView)}`}isEqual(t){if(this===t)return!0;if(!(t instanceof this.constructor))return!1;let e=this.toBER(),n=t.toBER();return Mi(e,n)}};ct.NAME="BaseBlock";function qi(r){if(r instanceof A.Constructed)for(let t of r.valueBlock.value)qi(t)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var fn=class extends ct{constructor({value:t=Je,...e}={},n){super(e,n),t&&this.fromString(t)}getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}fromBER(t,e,n){let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.fromBuffer(this.valueBlock.valueHexView),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}onAsciiEncoding(){return`${this.constructor.NAME} : '${this.valueBlock.value}'`}};fn.NAME="BaseStringBlock";var hn=class extends Jt(ht){constructor({isHexOnly:t=!0,...e}={}){super(e),this.isHexOnly=t}};hn.NAME="PrimitiveValueBlock";var zi,dn=class extends ct{constructor(t={}){super(t,hn),this.idBlock.isConstructed=!1}};zi=dn;A.Primitive=zi;dn.NAME="PRIMITIVE";function $u(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 Gn(r,t=0,e=r.length){let n=t,s=new ct({},ht),o=new jt;if(!Wt(o,r,t,e))return s.error=o.error,{offset:-1,result:s};if(!r.subarray(t,t+e).length)return s.error="Zero buffer length",{offset:-1,result:s};let a=s.idBlock.fromBER(r,t,e);if(s.idBlock.warnings.length&&s.warnings.concat(s.idBlock.warnings),a===-1)return s.error=s.idBlock.error,{offset:-1,result:s};if(t=a,e-=s.idBlock.blockLength,a=s.lenBlock.fromBER(r,t,e),s.lenBlock.warnings.length&&s.warnings.concat(s.lenBlock.warnings),a===-1)return s.error=s.lenBlock.error,{offset:-1,result:s};if(t=a,e-=s.lenBlock.blockLength,!s.idBlock.isConstructed&&s.lenBlock.isIndefiniteForm)return s.error="Indefinite length form used for primitive encoding form",{offset:-1,result:s};let c=ct;switch(s.idBlock.tagClass){case 1:if(s.idBlock.tagNumber>=37&&s.idBlock.isHexOnly===!1)return s.error="UNIVERSAL 37 and upper tags are reserved by ASN.1 standard",{offset:-1,result:s};switch(s.idBlock.tagNumber){case 0:if(s.idBlock.isConstructed&&s.lenBlock.length>0)return s.error="Type [UNIVERSAL 0] is reserved",{offset:-1,result:s};c=A.EndOfContent;break;case 1:c=A.Boolean;break;case 2:c=A.Integer;break;case 3:c=A.BitString;break;case 4:c=A.OctetString;break;case 5:c=A.Null;break;case 6:c=A.ObjectIdentifier;break;case 10:c=A.Enumerated;break;case 12:c=A.Utf8String;break;case 13:c=A.RelativeObjectIdentifier;break;case 14:c=A.TIME;break;case 15:return s.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:s};case 16:c=A.Sequence;break;case 17:c=A.Set;break;case 18:c=A.NumericString;break;case 19:c=A.PrintableString;break;case 20:c=A.TeletexString;break;case 21:c=A.VideotexString;break;case 22:c=A.IA5String;break;case 23:c=A.UTCTime;break;case 24:c=A.GeneralizedTime;break;case 25:c=A.GraphicString;break;case 26:c=A.VisibleString;break;case 27:c=A.GeneralString;break;case 28:c=A.UniversalString;break;case 29:c=A.CharacterString;break;case 30:c=A.BmpString;break;case 31:c=A.DATE;break;case 32:c=A.TimeOfDay;break;case 33:c=A.DateTime;break;case 34:c=A.Duration;break;default:{let u=s.idBlock.isConstructed?new A.Constructed:new A.Primitive;u.idBlock=s.idBlock,u.lenBlock=s.lenBlock,u.warnings=s.warnings,s=u}}break;case 2:case 3:case 4:default:c=s.idBlock.isConstructed?A.Constructed:A.Primitive}return s=$u(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 io(r){if(!r.byteLength){let t=new ct({},ht);return t.error="Input buffer has zero length",{offset:-1,result:t}}return Gn(M.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function qu(r,t){return r?1:t}var Vt=class extends ht{constructor({value:t=[],isIndefiniteForm:e=!1,...n}={}){super(n),this.value=t,this.isIndefiniteForm=e}fromBER(t,e,n){let s=M.BufferSourceConverter.toUint8Array(t);if(!Wt(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(;qu(this.isIndefiniteForm,n)>0;){let i=Gn(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===wr)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===wr?this.value.pop():this.warnings.push("No EndOfContent block encoded")),o}toBER(t,e){let n=e||new xr;for(let s=0;s<this.value.length;s++)this.value[s].toBER(t,n);return e?Ut:n.final()}toJSON(){let t={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let e of this.value)t.value.push(e.toJSON());return t}};Vt.NAME="ConstructedValueBlock";var ji,pe=class extends ct{constructor(t={}){super(t,Vt),this.idBlock.isConstructed=!0}fromBER(t,e,n){this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm;let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}onAsciiEncoding(){let t=[];for(let n of this.valueBlock.value)t.push(n.toString("ascii").split(`
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} :`}};qi=pe;A.Constructed=qi;pe.NAME="CONSTRUCTED";var dn=class extends ht{fromBER(t,e,n){return e}toBER(t){return Ut}};dn.override="EndOfContentValueBlock";var zi,gn=class extends ct{constructor(t={}){super(t,dn),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};zi=gn;A.EndOfContent=zi;gn.NAME=xr;var ji,Ge=class extends ct{constructor(t={}){super(t,ht),this.idBlock.tagClass=1,this.idBlock.tagNumber=5}fromBER(t,e,n){return this.lenBlock.length>0&&this.warnings.push("Non-zero length of value block for Null type"),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.blockLength+=n,e+n>t.byteLength?(this.error="End of input reached before message was fully decoded (inconsistent offset and length values)",-1):e+n}toBER(t,e){let n=new ArrayBuffer(2);if(!t){let s=new Uint8Array(n);s[0]=5,s[1]=0}return e&&e.write(n),n}onAsciiEncoding(){return`${this.constructor.NAME}`}};ji=Ge;A.Null=ji;Ge.NAME="NULL";var pn=class extends Jt(ht){constructor({value:t,...e}={}){super(e),e.valueHex?this.valueHexView=M.BufferSourceConverter.toUint8Array(e.valueHex):this.valueHexView=new Uint8Array(1),t&&(this.value=t)}get value(){for(let t of this.valueHexView)if(t>0)return!0;return!1}set value(t){this.valueHexView[0]=t?255:0}fromBER(t,e,n){let s=M.BufferSourceConverter.toUint8Array(t);return Wt(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,eo.call(this),this.blockLength=n,e+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};pn.NAME="BooleanValueBlock";var Gi,mn=class extends ct{constructor(t={}){super(t,pn),this.idBlock.tagClass=1,this.idBlock.tagNumber=1}getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.getValue}`}};Gi=mn;A.Boolean=Gi;mn.NAME="BOOLEAN";var yn=class extends Jt(Vt){constructor({isConstructed:t=!1,...e}={}){super(e),this.isConstructed=t}fromBER(t,e,n){let s=0;if(this.isConstructed){if(this.isHexOnly=!1,s=Vt.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let o=0;o<this.value.length;o++){let i=this.value[o].constructor.NAME;if(i===xr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(i!==Ki)return this.error="OCTET STRING may consists of OCTET STRINGs only",-1}}else this.isHexOnly=!0,s=super.fromBER(t,e,n),this.blockLength=n;return s}toBER(t,e){return this.isConstructed?Vt.prototype.toBER.call(this,t,e):t?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};yn.NAME="OctetStringValueBlock";var Zi,bn=class r extends ct{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,o;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((o=n.value)===null||o===void 0)&&o.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},yn),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=jn(o,0,o.byteLength);i.offset!==-1&&i.offset===n&&(this.valueBlock.value=[i.result])}}catch{}}return super.fromBER(t,e,n)}onAsciiEncoding(){return this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length?pe.prototype.onAsciiEncoding.call(this):`${this.constructor.NAME} : ${M.Convert.ToHex(this.valueBlock.valueHexView)}`}getValue(){if(!this.idBlock.isConstructed)return this.valueBlock.valueHexView.slice().buffer;let t=[];for(let e of this.valueBlock.value)e instanceof r&&t.push(e.valueBlock.valueHexView);return M.BufferSourceConverter.concat(t)}};Zi=bn;A.OctetString=Zi;bn.NAME=Ki;var xn=class extends Jt(Vt){constructor({unusedBits:t=0,isConstructed:e=!1,...n}={}){super(n),this.unusedBits=t,this.isConstructed=e,this.blockLength=this.valueHexView.byteLength}fromBER(t,e,n){if(!n)return e;let s=-1;if(this.isConstructed){if(s=Vt.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let a of this.value){let c=a.constructor.NAME;if(c===xr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==Pi)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=M.BufferSourceConverter.toUint8Array(t);if(!Wt(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=jn(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 Vt.prototype.toBER.call(this,t,e);if(t)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return Ut;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}}};xn.NAME="BitStringValueBlock";var Wi,Ze=class extends ct{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,o;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((o=n.value)===null||o===void 0)&&o.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},xn),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 pe.prototype.onAsciiEncoding.call(this);{let t=[],e=this.valueBlock.valueHexView;for(let s of e)t.push(s.toString(2).padStart(8,"0"));let n=t.join("");return`${this.constructor.NAME} : ${n.substring(0,n.length-this.valueBlock.unusedBits)}`}}};Wi=Ze;A.BitString=Wi;Ze.NAME=Pi;var Ji;function ju(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++){switch(!0){case f<a.length:u=o[i-f]+a[c-f]+e[0];break;default:u=o[i-f]+e[0]}switch(e[0]=u/10,!0){case f>=o.length:o=on(new Uint8Array([u%10]),o);break;default:o[i-f]=u%10}}return e[0]>0&&(o=on(e,o)),o}function Mi(r){if(r>=yr.length)for(let t=yr.length;t<=r;t++){let e=new Uint8Array([0]),n=yr[t-1].slice(0);for(let s=n.length-1;s>=0;s--){let o=new Uint8Array([(n[s]<<1)+e[0]]);e[0]=o[0]/10,n[s]=o[0]%10}e[0]>0&&(n=on(e,n)),yr.push(n)}return yr[r]}function Gu(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++)switch(u=o[i-l]-a[c-l]-e,!0){case u<0:e=1,o[i-l]=u+10;break;default: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 wr=class extends Jt(ht){constructor({value:t,...e}={}){super(e),this._valueDec=0,e.valueHex&&this.setValueHex(),t!==void 0&&(this.valueDec=t)}setValueHex(){this.valueHexView.length>=4?(this.warnings.push("Too big Integer for decoding, hex only"),this.isHexOnly=!0,this._valueDec=0):(this.isHexOnly=!1,this.valueHexView.length>0&&(this._valueDec=eo.call(this)))}set valueDec(t){this._valueDec=t,this.isHexOnly=!1,this.valueHexView=new Uint8Array(Vi(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?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++){if((s&1)===1)switch(n){case t:e=Gu(Mi(n),e),i="-";break;default:e=ju(e,Mi(n))}n++,s>>=1}}for(let c=0;c<e.length;c++)e[c]&&(a=!0),a&&(i+=Di.charAt(e[c]));return a===!1&&(i+=Di.charAt(0)),i}};Ji=wr;wr.NAME="IntegerValueBlock";Object.defineProperty(Ji.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var Yi,lt=class r extends ct{constructor(t={}){super(t,wr),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return an(),BigInt(this.valueBlock.toString())}static fromBigInt(t){an();let e=BigInt(t),n=new br,s=e.toString(16).replace(/^-/,""),o=new Uint8Array(M.Convert.FromHex(s));if(e<0){let a=new Uint8Array(o.length+(o[0]&128?1:0));a[0]|=128;let u=BigInt(`0x${M.Convert.ToHex(a)}`)+e,l=M.BufferSourceConverter.toUint8Array(M.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 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()}`}};Yi=lt;A.Integer=Yi;lt.NAME="INTEGER";var Xi,wn=class extends lt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};Xi=wn;A.Enumerated=Xi;wn.NAME="ENUMERATED";var vr=class extends Jt(ht){constructor({valueDec:t=-1,isFirstSid:e=!1,...n}={}){super(n),this.valueDec=t,this.isFirstSid=e}fromBER(t,e,n){if(!n)return e;let s=M.BufferSourceConverter.toUint8Array(t);if(!Wt(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));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?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=ke(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}set valueBigInt(t){an();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",Ut;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),o=e.byteLength-1;for(let i=0;i<o;i++)n[i]=s[i]|128;n[o]=s[o]}return n}toString(){let t="";if(this.isHexOnly)t=M.Convert.ToHex(this.valueHexView);else if(this.isFirstSid){let e=this.valueDec;this.valueDec<=39?t="0.":this.valueDec<=79?(t="1.",e-=40):(t="2.",e-=80),t+=e.toString()}else t=this.valueDec.toString();return t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec,isFirstSid:this.isFirstSid}}};vr.NAME="sidBlock";var vn=class extends ht{constructor({value:t=Je,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new vr;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,Ut;e.push(s)}return ro(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 vr;if(s>Number.MAX_SAFE_INTEGER){an();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}};vn.NAME="ObjectIdentifierValueBlock";var Qi,We=class extends ct{constructor(t={}){super(t,vn),this.idBlock.tagClass=1,this.idBlock.tagNumber=6}getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};Qi=We;A.ObjectIdentifier=Qi;We.NAME="OBJECT IDENTIFIER";var Br=class extends Jt(jt){constructor({valueDec:t=0,...e}={}){super(e),this.valueDec=t}fromBER(t,e,n){if(n===0)return e;let s=M.BufferSourceConverter.toUint8Array(t);if(!Wt(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));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?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=ke(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}toBER(t){if(this.isHexOnly){if(t)return new ArrayBuffer(this.valueHexView.byteLength);let s=this.valueHexView,o=new Uint8Array(this.blockLength);for(let i=0;i<this.blockLength-1;i++)o[i]=s[i]|128;return o[this.blockLength-1]=s[this.blockLength-1],o.buffer}let e=ge(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Ut;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),o=e.byteLength-1;for(let i=0;i<o;i++)n[i]=s[i]|128;n[o]=s[o]}return n.buffer}toString(){let t="";return this.isHexOnly?t=M.Convert.ToHex(this.valueHexView):t=this.valueDec.toString(),t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};Br.NAME="relativeSidBlock";var Bn=class extends ht{constructor({value:t=Je,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new Br;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,Ut;n.push(o)}return ro(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 Br;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}};Bn.NAME="RelativeObjectIdentifierValueBlock";var ta,En=class extends ct{constructor(t={}){super(t,Bn),this.idBlock.tagClass=1,this.idBlock.tagNumber=13}getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};ta=En;A.RelativeObjectIdentifier=ta;En.NAME="RelativeObjectIdentifier";var ea,Gt=class extends pe{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};ea=Gt;A.Sequence=ea;Gt.NAME="SEQUENCE";var ra,An=class extends pe{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};ra=An;A.Set=ra;An.NAME="SET";var Sn=class extends Jt(ht){constructor({...t}={}){super(t),this.isHexOnly=!0,this.value=Je}toJSON(){return{...super.toJSON(),value:this.value}}};Sn.NAME="StringValueBlock";var kn=class extends Sn{};kn.NAME="SimpleStringValueBlock";var pt=class extends un{constructor({...t}={}){super(t,kn)}fromBuffer(t){this.valueBlock.value=String.fromCharCode.apply(null,M.BufferSourceConverter.toUint8Array(t))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e);for(let s=0;s<e;s++)n[s]=t.charCodeAt(s);this.valueBlock.value=t}};pt.NAME="SIMPLE STRING";var In=class extends pt{fromBuffer(t){this.valueBlock.valueHexView=M.BufferSourceConverter.toUint8Array(t);try{this.valueBlock.value=M.Convert.ToUtf8String(t)}catch(e){this.warnings.push(`Error during "decodeURIComponent": ${e}, using raw string`),this.valueBlock.value=M.Convert.ToBinary(t)}}fromString(t){this.valueBlock.valueHexView=new Uint8Array(M.Convert.FromUtf8String(t)),this.valueBlock.value=t}};In.NAME="Utf8StringValueBlock";var na,Zt=class extends In{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};na=Zt;A.Utf8String=na;Zt.NAME="UTF8String";var Nn=class extends pt{fromBuffer(t){this.valueBlock.value=M.Convert.ToUtf16String(t),this.valueBlock.valueHexView=M.BufferSourceConverter.toUint8Array(t)}fromString(t){this.valueBlock.value=t,this.valueBlock.valueHexView=new Uint8Array(M.Convert.FromUtf16String(t))}};Nn.NAME="BmpStringValueBlock";var sa,Cn=class extends Nn{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};sa=Cn;A.BmpString=sa;Cn.NAME="BMPString";var Un=class extends pt{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 a=4-i.length;for(let c=i.length-1;c>=0;c--)n[s*4+c+a]=i[c]}this.valueBlock.value=t}};Un.NAME="UniversalStringValueBlock";var oa,Tn=class extends Un{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};oa=Tn;A.UniversalString=oa;Tn.NAME="UniversalString";var ia,Rn=class extends pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};ia=Rn;A.NumericString=ia;Rn.NAME="NumericString";var aa,Ln=class extends pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};aa=Ln;A.PrintableString=aa;Ln.NAME="PrintableString";var ca,Hn=class extends pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};ca=Hn;A.TeletexString=ca;Hn.NAME="TeletexString";var la,_n=class extends pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};la=_n;A.VideotexString=la;_n.NAME="VideotexString";var ua,Vn=class extends pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};ua=Vn;A.IA5String=ua;Vn.NAME="IA5String";var fa,On=class extends pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};fa=On;A.GraphicString=fa;On.NAME="GraphicString";var ha,Er=class extends pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};ha=Er;A.VisibleString=ha;Er.NAME="VisibleString";var da,Dn=class extends pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};da=Dn;A.GeneralString=da;Dn.NAME="GeneralString";var ga,Mn=class extends pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};ga=Mn;A.CharacterString=ga;Mn.NAME="CharacterString";var pa,Ar=class extends Er{constructor({value:t,valueDate:e,...n}={}){if(super(n),this.year=0,this.month=0,this.day=0,this.hour=0,this.minute=0,this.second=0,t){this.fromString(t),this.valueBlock.valueHexView=new Uint8Array(t.length);for(let s=0;s<t.length;s++)this.valueBlock.valueHexView[s]=t.charCodeAt(s)}e&&(this.fromDate(e),this.valueBlock.valueHexView=new Uint8Array(this.toBuffer())),this.idBlock.tagClass=1,this.idBlock.tagNumber=23}fromBuffer(t){this.fromString(String.fromCharCode.apply(null,M.BufferSourceConverter.toUint8Array(t)))}toBuffer(){let t=this.toString(),e=new ArrayBuffer(t.length),n=new Uint8Array(e);for(let s=0;s<t.length;s++)n[s]=t.charCodeAt(s);return e}fromDate(t){this.year=t.getUTCFullYear(),this.month=t.getUTCMonth()+1,this.day=t.getUTCDate(),this.hour=t.getUTCHours(),this.minute=t.getUTCMinutes(),this.second=t.getUTCSeconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second))}fromString(t){let n=/(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})Z/ig.exec(t);if(n===null){this.error="Wrong input string for conversion";return}let s=parseInt(n[1],10);s>=50?this.year=1900+s:this.year=2e3+s,this.month=parseInt(n[2],10),this.day=parseInt(n[3],10),this.hour=parseInt(n[4],10),this.minute=parseInt(n[5],10),this.second=parseInt(n[6],10)}toString(t="iso"){if(t==="iso"){let e=new Array(7);return e[0]=wt(this.year<2e3?this.year-1900:this.year-2e3,2),e[1]=wt(this.month,2),e[2]=wt(this.day,2),e[3]=wt(this.hour,2),e[4]=wt(this.minute,2),e[5]=wt(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}}};pa=Ar;A.UTCTime=pa;Ar.NAME="UTCTime";var ma,Kn=class extends Ar{constructor(t={}){var e;super(t),(e=this.millisecond)!==null&&e!==void 0||(this.millisecond=0),this.idBlock.tagClass=1,this.idBlock.tagNumber=24}fromDate(t){super.fromDate(t),this.millisecond=t.getUTCMilliseconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second,this.millisecond))}fromString(t){let e=!1,n="",s="",o=0,i,a=0,c=0;if(t[t.length-1]==="Z")n=t.substring(0,t.length-1),e=!0;else{let 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("+"),v="";if(h===-1&&(h=n.indexOf("-"),f=-1),h!==-1){if(v=n.substring(h+1),n=n.substring(0,h),v.length!==2&&v.length!==4)throw new Error("Wrong input string for conversion");let w=parseInt(v.substring(0,2),10);if(isNaN(w.valueOf()))throw new Error("Wrong input string for conversion");if(a=f*w,v.length===4){if(w=parseInt(v.substring(2,4),10),isNaN(w.valueOf()))throw new Error("Wrong input string for conversion");c=f*w}}}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(wt(this.year,4)),e.push(wt(this.month,2)),e.push(wt(this.day,2)),e.push(wt(this.hour,2)),e.push(wt(this.minute,2)),e.push(wt(this.second,2)),this.millisecond!==0&&(e.push("."),e.push(wt(this.millisecond,3))),e.push("Z"),e.join("")}return super.toString(t)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};ma=Kn;A.GeneralizedTime=ma;Kn.NAME="GeneralizedTime";var ya,Pn=class extends Zt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};ya=Pn;A.DATE=ya;Pn.NAME="DATE";var ba,Fn=class extends Zt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};ba=Fn;A.TimeOfDay=ba;Fn.NAME="TimeOfDay";var xa,$n=class extends Zt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};xa=$n;A.DateTime=xa;$n.NAME="DateTime";var wa,qn=class extends Zt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};wa=qn;A.Duration=wa;qn.NAME="Duration";var va,zn=class extends Zt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};va=zn;A.TIME=va;zn.NAME="TIME";function mt(r,t="utf8"){let e=Xr[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}function oo(r){if(isNaN(r)||r<=0)throw new $("random bytes length must be a Number bigger than 0");return Ke(r)}async function Ba(r){let t=await at.get().subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:r,publicExponent:new Uint8Array([1,0,1]),hash:{name:"SHA-256"}},!0,["sign","verify"]),e=await Wu(t);return{privateKey:e[0],publicKey:e[1]}}async function Ea(r,t){let e=await at.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await at.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},e,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(n,0,n.byteLength)}async function Aa(r,t,e){let n=await at.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return at.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,t,e instanceof Uint8Array?e:e.subarray())}async function Wu(r){if(r.privateKey==null||r.publicKey==null)throw new $("Private and public key are required");return Promise.all([at.get().subtle.exportKey("jwk",r.privateKey),at.get().subtle.exportKey("jwk",r.publicKey)])}function io(r){if(r.kty!=="RSA")throw new $("invalid key type");if(r.n==null)throw new $("invalid key modulus");return et(r.n,"base64url").length*8}var Ye=class{type="RSA";_key;_raw;_multihash;constructor(t,e){this._key=t,this._multihash=e}get raw(){return this._raw==null&&(this._raw=Sr.jwkToPkix(this._key)),this._raw}toMultihash(){return this._multihash}toCID(){return Tt.createV1(114,this._multihash)}toString(){return ut.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:St(this.raw,t.raw)}verify(t,e){return Aa(this._key,e,t)}},kr=class{type="RSA";_key;_raw;publicKey;constructor(t,e){this._key=t,this.publicKey=e}get raw(){return this._raw==null&&(this._raw=Sr.jwkToPkcs1(this._key)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:St(this.raw,t.raw)}sign(t){return Ea(this._key,t)}};var Gn=8192,ao=18;function Sa(r){let{result:t}=so(r),e=t.valueBlock.value;return{n:mt(Ot(e[1].toBigInt()),"base64url"),e:mt(Ot(e[2].toBigInt()),"base64url"),d:mt(Ot(e[3].toBigInt()),"base64url"),p:mt(Ot(e[4].toBigInt()),"base64url"),q:mt(Ot(e[5].toBigInt()),"base64url"),dp:mt(Ot(e[6].toBigInt()),"base64url"),dq:mt(Ot(e[7].toBigInt()),"base64url"),qi:mt(Ot(e[8].toBigInt()),"base64url"),kty:"RSA",alg:"RS256"}}function Ju(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");let e=new Gt({value:[new lt({value:0}),lt.fromBigInt(Dt(et(r.n,"base64url"))),lt.fromBigInt(Dt(et(r.e,"base64url"))),lt.fromBigInt(Dt(et(r.d,"base64url"))),lt.fromBigInt(Dt(et(r.p,"base64url"))),lt.fromBigInt(Dt(et(r.q,"base64url"))),lt.fromBigInt(Dt(et(r.dp,"base64url"))),lt.fromBigInt(Dt(et(r.dq,"base64url"))),lt.fromBigInt(Dt(et(r.qi,"base64url")))]}).toBER();return new Uint8Array(e,0,e.byteLength)}function ka(r){let{result:t}=so(r),e=t.valueBlock.value[1].valueBlock.value[0].valueBlock.value;return{kty:"RSA",n:mt(Ot(e[0].toBigInt()),"base64url"),e:mt(Ot(e[1].toBigInt()),"base64url")}}function co(r){if(r.n==null||r.e==null)throw new $("JWK was missing components");let e=new Gt({value:[new Gt({value:[new We({value:"1.2.840.113549.1.1.1"}),new Ge]}),new Ze({valueHex:new Gt({value:[lt.fromBigInt(Dt(et(r.n,"base64url"))),lt.fromBigInt(Dt(et(r.e,"base64url")))]}).toBER()})]}).toBER();return new Uint8Array(e,0,e.byteLength)}function Ot(r){let t=r.toString(16);t.length%2>0&&(t=`0${t}`);let e=t.length/2,n=new Uint8Array(e),s=0,o=0;for(;s<e;)n[s]=parseInt(t.slice(o,o+2),16),s+=1,o+=2;return n}function Dt(r){let t=[];return r.forEach(function(e){let n=e.toString(16);n.length%2>0&&(n=`0${n}`),t.push(n)}),BigInt("0x"+t.join(""))}function Zn(r){let t=Sa(r);return Ia(t)}function Wn(r){let t=ka(r);if(io(t)>Gn)throw new Ne("Key size is too large");let e=de(_t.encode({Type:Z.RSA,Data:r})),n=At(ao,e);return new Ye(t,n)}function Ia(r){if(io(r)>Gn)throw new $("Key size is too large");let t=Na(r),e=de(_t.encode({Type:Z.RSA,Data:co(t.publicKey)})),n=At(ao,e);return new kr(t.privateKey,new Ye(t.publicKey,n))}async function lo(r){if(r>Gn)throw new $("Key size is too large");let t=await Ba(r),e=de(_t.encode({Type:Z.RSA,Data:co(t.publicKey)})),n=At(ao,e);return new kr(t.privateKey,new Ye(t.publicKey,n))}function Na(r){if(r==null)throw new $("Missing key parameter");return{privateKey:r,publicKey:{kty:r.kty,n:r.n,e:r.e}}}var Jn=class extends Oe{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,_r(t);let n=ee(e);if(this.iHash=t.create(),typeof this.iHash.update!="function")throw new Error("Expected instance of class which extends utils.Hash");this.blockLen=this.iHash.blockLen,this.outputLen=this.iHash.outputLen;let s=this.blockLen,o=new Uint8Array(s);o.set(n.length>s?t.create().update(n).digest():n);for(let i=0;i<o.length;i++)o[i]^=54;this.iHash.update(o),this.oHash=t.create();for(let i=0;i<o.length;i++)o[i]^=106;this.oHash.update(o),o.fill(0)}update(t){return Ve(this),this.iHash.update(t),this}digestInto(t){Ve(this),_e(t,this.outputLen),this.finished=!0,this.iHash.digestInto(t),this.oHash.update(t),this.oHash.digestInto(t),this.destroy()}digest(){let t=new Uint8Array(this.oHash.outputLen);return this.digestInto(t),t}_cloneInto(t){t||(t=Object.create(Object.getPrototypeOf(this),{}));let{oHash:e,iHash:n,finished:s,destroyed:o,blockLen:i,outputLen:a}=this;return t=t,t.finished=s,t.destroyed=o,t.blockLen=i,t.outputLen=a,t.oHash=e._cloneInto(t.oHash),t.iHash=n._cloneInto(t.iHash),t}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},Ir=(r,t,e)=>new Jn(r,t).update(e).digest();Ir.create=(r,t)=>new Jn(r,t);function Ca(r){r.lowS!==void 0&&It("lowS",r.lowS),r.prehash!==void 0&&It("prehash",r.prehash)}function Yu(r){let t=ur(r);Rt(t,{a:"field",b:"field"},{allowedPrivateKeyLengths:"array",wrapPrivateKey:"boolean",isTorsionFree:"function",clearCofactor:"function",allowInfinityPoint:"boolean",fromBytes:"function",toBytes:"function"});let{endo:e,Fp:n,a:s}=t;if(e){if(!n.eql(s,n.ZERO))throw new Error("Endomorphism can only be defined for Koblitz curves that have a=0");if(typeof e!="object"||typeof e.beta!="bigint"||typeof e.splitScalar!="function")throw new Error("Expected endomorphism with beta: bigint and splitScalar: function")}return Object.freeze({...t})}var{bytesToNumberBE:Xu,hexToBytes:Qu}=Fr,Yt={Err:class extends Error{constructor(t=""){super(t)}},_tlv:{encode:(r,t)=>{let{Err:e}=Yt;if(r<0||r>256)throw new e("tlv.encode: wrong tag");if(t.length&1)throw new e("tlv.encode: unpadded data");let n=t.length/2,s=be(n);if(s.length/2&128)throw new e("tlv.encode: long form length too big");let o=n>127?be(s.length/2|128):"";return`${be(r)}${o}${s}${t}`},decode(r,t){let{Err:e}=Yt,n=0;if(r<0||r>256)throw new e("tlv.encode: wrong tag");if(t.length<2||t[n++]!==r)throw new e("tlv.decode: wrong tlv");let s=t[n++],o=!!(s&128),i=0;if(!o)i=s;else{let c=s&127;if(!c)throw new e("tlv.decode(long): indefinite length not supported");if(c>4)throw new e("tlv.decode(long): byte length is too big");let 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}=Yt;if(r<Xt)throw new t("integer: negative integers are not allowed");let e=be(r);if(Number.parseInt(e[0],16)&8&&(e="00"+e),e.length&1)throw new t("unexpected assertion");return e},decode(r){let{Err:t}=Yt;if(r[0]&128)throw new t("Invalid signature integer: negative");if(r[0]===0&&!(r[1]&128))throw new t("Invalid signature integer: unnecessary leading zero");return Xu(r)}},toSig(r){let{Err:t,_int:e,_tlv:n}=Yt,s=typeof r=="string"?Qu(r):r;Pe(s);let{v:o,l:i}=n.decode(48,s);if(i.length)throw new t("Invalid signature: left bytes after parsing");let{v:a,l:c}=n.decode(2,o),{v: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}=Yt,n=`${t.encode(2,e.encode(r.r))}${t.encode(2,e.encode(r.s))}`;return t.encode(48,n)}},Xt=BigInt(0),st=BigInt(1),I0=BigInt(2),Ua=BigInt(3),N0=BigInt(4);function tf(r){let t=Yu(r),{Fp:e}=t,n=ce(t.n,t.nBitLength),s=t.toBytes||((y,d,b)=>{let B=d.toAffine();return qt(Uint8Array.from([4]),e.toBytes(B.x),e.toBytes(B.y))}),o=t.fromBytes||(y=>{let d=y.subarray(1),b=e.fromBytes(d.subarray(0,e.BYTES)),B=e.fromBytes(d.subarray(e.BYTES,2*e.BYTES));return{x:b,y:B}});function i(y){let{a:d,b}=t,B=e.sqr(y),p=e.mul(B,y);return e.add(e.add(p,e.mul(y,d)),b)}if(!e.eql(e.sqr(t.Gy),i(t.Gx)))throw new Error("bad generator point: equation left != right");function a(y){return cr(y,st,t.n)}function c(y){let{allowedPrivateKeyLengths:d,nByteLength:b,wrapPrivateKey:B,n:p}=t;if(d&&typeof y!="bigint"){if(oe(y)&&(y=Ft(y)),typeof y!="string"||!d.includes(y.length))throw new Error("Invalid key");y=y.padStart(b*2,"0")}let S;try{S=typeof y=="bigint"?y:$t(J("private key",y,b))}catch{throw new Error(`private key must be ${b} bytes, hex or bigint, not ${typeof y}`)}return B&&(S=q(S,p)),bt("private key",S,st,p),S}function u(y){if(!(y instanceof h))throw new Error("ProjectivePoint expected")}let l=ve((y,d)=>{let{px:b,py:B,pz:p}=y;if(e.eql(p,e.ONE))return{x:b,y:B};let S=y.is0();d==null&&(d=S?e.ONE:e.inv(p));let R=e.mul(b,d),T=e.mul(B,d),k=e.mul(p,d);if(S)return{x:e.ZERO,y:e.ZERO};if(!e.eql(k,e.ONE))throw new Error("invZ was invalid");return{x:R,y:T}}),f=ve(y=>{if(y.is0()){if(t.allowInfinityPoint&&!e.is0(y.py))return;throw new Error("bad point: ZERO")}let{x:d,y:b}=y.toAffine();if(!e.isValid(d)||!e.isValid(b))throw new Error("bad point: x or y not FE");let B=e.sqr(b),p=i(d);if(!e.eql(B,p))throw new Error("bad point: equation left != right");if(!y.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});class h{constructor(d,b,B){if(this.px=d,this.py=b,this.pz=B,d==null||!e.isValid(d))throw new Error("x required");if(b==null||!e.isValid(b))throw new Error("y required");if(B==null||!e.isValid(B))throw new Error("z required");Object.freeze(this)}static fromAffine(d){let{x:b,y:B}=d||{};if(!d||!e.isValid(b)||!e.isValid(B))throw new Error("invalid affine point");if(d instanceof h)throw new Error("projective point not allowed");let p=S=>e.eql(S,e.ZERO);return p(b)&&p(B)?h.ZERO:new h(b,B,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(d){let b=e.invertBatch(d.map(B=>B.pz));return d.map((B,p)=>B.toAffine(b[p])).map(h.fromAffine)}static fromHex(d){let b=h.fromAffine(o(J("pointHex",d)));return b.assertValidity(),b}static fromPrivateKey(d){return h.BASE.multiply(c(d))}static msm(d,b){return zr(h,n,d,b)}_setWindowSize(d){w.setWindowSize(this,d)}assertValidity(){f(this)}hasEvenY(){let{y:d}=this.toAffine();if(e.isOdd)return!e.isOdd(d);throw new Error("Field doesn't support isOdd")}equals(d){u(d);let{px:b,py:B,pz:p}=this,{px:S,py:R,pz:T}=d,k=e.eql(e.mul(b,T),e.mul(S,p)),I=e.eql(e.mul(B,T),e.mul(R,p));return k&&I}negate(){return new h(this.px,e.neg(this.py),this.pz)}double(){let{a:d,b}=t,B=e.mul(b,Ua),{px:p,py:S,pz:R}=this,T=e.ZERO,k=e.ZERO,I=e.ZERO,U=e.mul(p,p),Y=e.mul(S,S),P=e.mul(R,R),V=e.mul(p,S);return V=e.add(V,V),I=e.mul(p,R),I=e.add(I,I),T=e.mul(d,I),k=e.mul(B,P),k=e.add(T,k),T=e.sub(Y,k),k=e.add(Y,k),k=e.mul(T,k),T=e.mul(V,T),I=e.mul(B,I),P=e.mul(d,P),V=e.sub(U,P),V=e.mul(d,V),V=e.add(V,I),I=e.add(U,U),U=e.add(I,U),U=e.add(U,P),U=e.mul(U,V),k=e.add(k,U),P=e.mul(S,R),P=e.add(P,P),U=e.mul(P,V),T=e.sub(T,U),I=e.mul(P,Y),I=e.add(I,I),I=e.add(I,I),new h(T,k,I)}add(d){u(d);let{px:b,py:B,pz:p}=this,{px:S,py:R,pz:T}=d,k=e.ZERO,I=e.ZERO,U=e.ZERO,Y=t.a,P=e.mul(t.b,Ua),V=e.mul(b,S),X=e.mul(B,R),E=e.mul(p,T),N=e.add(b,B),m=e.add(S,R);N=e.mul(N,m),m=e.add(V,X),N=e.sub(N,m),m=e.add(b,p);let g=e.add(S,T);return m=e.mul(m,g),g=e.add(V,E),m=e.sub(m,g),g=e.add(B,p),k=e.add(R,T),g=e.mul(g,k),k=e.add(X,E),g=e.sub(g,k),U=e.mul(Y,m),k=e.mul(P,E),U=e.add(k,U),k=e.sub(X,U),U=e.add(X,U),I=e.mul(k,U),X=e.add(V,V),X=e.add(X,V),E=e.mul(Y,E),m=e.mul(P,m),X=e.add(X,E),E=e.sub(V,E),E=e.mul(Y,E),m=e.add(m,E),V=e.mul(X,m),I=e.add(I,V),V=e.mul(g,m),k=e.mul(N,k),k=e.sub(k,V),V=e.mul(N,X),U=e.mul(g,U),U=e.add(U,V),new h(k,I,U)}subtract(d){return this.add(d.negate())}is0(){return this.equals(h.ZERO)}wNAF(d){return w.wNAFCached(this,d,h.normalizeZ)}multiplyUnsafe(d){bt("scalar",d,Xt,t.n);let b=h.ZERO;if(d===Xt)return b;if(d===st)return this;let{endo:B}=t;if(!B)return w.unsafeLadder(this,d);let{k1neg:p,k1:S,k2neg:R,k2:T}=B.splitScalar(d),k=b,I=b,U=this;for(;S>Xt||T>Xt;)S&st&&(k=k.add(U)),T&st&&(I=I.add(U)),U=U.double(),S>>=st,T>>=st;return p&&(k=k.negate()),R&&(I=I.negate()),I=new h(e.mul(I.px,B.beta),I.py,I.pz),k.add(I)}multiply(d){let{endo:b,n:B}=t;bt("scalar",d,st,B);let p,S;if(b){let{k1neg:R,k1:T,k2neg:k,k2:I}=b.splitScalar(d),{p:U,f:Y}=this.wNAF(T),{p:P,f:V}=this.wNAF(I);U=w.constTimeNegate(R,U),P=w.constTimeNegate(k,P),P=new h(e.mul(P.px,b.beta),P.py,P.pz),p=U.add(P),S=Y.add(V)}else{let{p:R,f:T}=this.wNAF(d);p=R,S=T}return h.normalizeZ([p,S])[0]}multiplyAndAddUnsafe(d,b,B){let p=h.BASE,S=(T,k)=>k===Xt||k===st||!T.equals(p)?T.multiplyUnsafe(k):T.multiply(k),R=S(this,b).add(S(d,B));return R.is0()?void 0:R}toAffine(d){return l(this,d)}isTorsionFree(){let{h:d,isTorsionFree:b}=t;if(d===st)return!0;if(b)return b(h,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h:d,clearCofactor:b}=t;return d===st?this:b?b(h,this):this.multiplyUnsafe(t.h)}toRawBytes(d=!0){return It("isCompressed",d),this.assertValidity(),s(h,this,d)}toHex(d=!0){return It("isCompressed",d),Ft(this.toRawBytes(d))}}h.BASE=new h(t.Gx,t.Gy,e.ONE),h.ZERO=new h(e.ZERO,e.ONE,e.ZERO);let v=t.nBitLength,w=qr(h,t.endo?Math.ceil(v/2):v);return{CURVE:t,ProjectivePoint:h,normPrivateKeyToScalar:c,weierstrassEquation:i,isWithinCurveOrder:a}}function ef(r){let t=ur(r);return Rt(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function Ta(r){let t=ef(r),{Fp:e,n}=t,s=e.BYTES+1,o=2*e.BYTES+1;function i(E){return q(E,n)}function a(E){return $r(E,n)}let{ProjectivePoint:c,normPrivateKeyToScalar:u,weierstrassEquation:l,isWithinCurveOrder:f}=tf({...t,toBytes(E,N,m){let g=N.toAffine(),x=e.toBytes(g.x),C=qt;return It("isCompressed",m),m?C(Uint8Array.from([N.hasEvenY()?2:3]),x):C(Uint8Array.from([4]),x,e.toBytes(g.y))},fromBytes(E){let N=E.length,m=E[0],g=E.subarray(1);if(N===s&&(m===2||m===3)){let x=$t(g);if(!cr(x,st,e.ORDER))throw new Error("Point is not on curve");let C=l(x),L;try{L=e.sqrt(C)}catch(K){let D=K instanceof Error?": "+K.message:"";throw new Error("Point is not on curve"+D)}let H=(L&st)===st;return(m&1)===1!==H&&(L=e.neg(L)),{x,y:L}}else if(N===o&&m===4){let x=e.fromBytes(g.subarray(0,e.BYTES)),C=e.fromBytes(g.subarray(e.BYTES,2*e.BYTES));return{x,y:C}}else throw new Error(`Point of length ${N} was invalid. Expected ${s} compressed bytes or ${o} uncompressed bytes`)}}),h=E=>Ft(ae(E,t.nByteLength));function v(E){let N=n>>st;return E>N}function w(E){return v(E)?i(-E):E}let y=(E,N,m)=>$t(E.slice(N,m));class d{constructor(N,m,g){this.r=N,this.s=m,this.recovery=g,this.assertValidity()}static fromCompact(N){let m=t.nByteLength;return N=J("compactSignature",N,m*2),new d(y(N,0,m),y(N,m,2*m))}static fromDER(N){let{r:m,s:g}=Yt.toSig(J("DER",N));return new d(m,g)}assertValidity(){bt("r",this.r,st,n),bt("s",this.s,st,n)}addRecoveryBit(N){return new d(this.r,this.s,N)}recoverPublicKey(N){let{r:m,s:g,recovery:x}=this,C=T(J("msgHash",N));if(x==null||![0,1,2,3].includes(x))throw new Error("recovery id invalid");let L=x===2||x===3?m+t.n:m;if(L>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let H=x&1?"03":"02",O=c.fromHex(H+h(L)),K=a(L),D=i(-C*K),F=i(g*K),z=c.BASE.multiplyAndAddUnsafe(O,D,F);if(!z)throw new Error("point at infinify");return z.assertValidity(),z}hasHighS(){return v(this.s)}normalizeS(){return this.hasHighS()?new d(this.r,i(-this.s),this.recovery):this}toDERRawBytes(){return xe(this.toDERHex())}toDERHex(){return Yt.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return xe(this.toCompactHex())}toCompactHex(){return h(this.r)+h(this.s)}}let b={isValidPrivateKey(E){try{return u(E),!0}catch{return!1}},normPrivateKeyToScalar:u,randomPrivateKey:()=>{let E=vs(t.n);return ri(t.randomBytes(E),t.n)},precompute(E=8,N=c.BASE){return N._setWindowSize(E),N.multiply(BigInt(3)),N}};function B(E,N=!0){return c.fromPrivateKey(E).toRawBytes(N)}function p(E){let N=oe(E),m=typeof E=="string",g=(N||m)&&E.length;return N?g===s||g===o:m?g===2*s||g===2*o:E instanceof c}function S(E,N,m=!0){if(p(E))throw new Error("first arg must be private key");if(!p(N))throw new Error("second arg must be public key");return c.fromHex(N).multiply(u(E)).toRawBytes(m)}let R=t.bits2int||function(E){let N=$t(E),m=E.length*8-t.nBitLength;return m>0?N>>BigInt(m):N},T=t.bits2int_modN||function(E){return i(R(E))},k=lr(t.nBitLength);function I(E){return bt(`num < 2^${t.nBitLength}`,E,Xt,k),ae(E,t.nByteLength)}function U(E,N,m=Y){if(["recovered","canonical"].some(nt=>nt in m))throw new Error("sign() legacy options not supported");let{hash:g,randomBytes:x}=t,{lowS:C,prehash:L,extraEntropy:H}=m;C==null&&(C=!0),E=J("msgHash",E),Ca(m),L&&(E=J("prehashed msgHash",g(E)));let O=T(E),K=u(N),D=[I(K),I(O)];if(H!=null&&H!==!1){let nt=H===!0?x(e.BYTES):H;D.push(J("extraEntropy",nt))}let F=qt(...D),z=O;function rt(nt){let ot=R(nt);if(!f(ot))return;let dt=a(ot),Q=c.BASE.multiply(ot).toAffine(),yt=i(Q.x);if(yt===Xt)return;let Mt=i(dt*i(z+yt*K));if(Mt===Xt)return;let Xe=(Q.x===yt?0:2)|Number(Q.y&st),Qe=Mt;return C&&v(Mt)&&(Qe=w(Mt),Xe^=1),new d(yt,Qe,Xe)}return{seed:F,k2sig:rt}}let Y={lowS:t.lowS,prehash:!1},P={lowS:t.lowS,prehash:!1};function V(E,N,m=Y){let{seed:g,k2sig:x}=U(E,N,m),C=t;return ys(C.hash.outputLen,C.nByteLength,C.hmac)(g,x)}c.BASE._setWindowSize(8);function X(E,N,m,g=P){let x=E;if(N=J("msgHash",N),m=J("publicKey",m),"strict"in g)throw new Error("options.strict was renamed to lowS");Ca(g);let{lowS:C,prehash:L}=g,H,O;try{if(typeof x=="string"||oe(x))try{H=d.fromDER(x)}catch(Q){if(!(Q instanceof Yt.Err))throw Q;H=d.fromCompact(x)}else if(typeof x=="object"&&typeof x.r=="bigint"&&typeof x.s=="bigint"){let{r:Q,s:yt}=x;H=new d(Q,yt)}else throw new Error("PARSE");O=c.fromHex(m)}catch(Q){if(Q.message==="PARSE")throw new Error("signature must be Signature instance, Uint8Array or hex string");return!1}if(C&&H.hasHighS())return!1;L&&(N=t.hash(N));let{r:K,s:D}=H,F=T(N),z=a(D),rt=i(F*z),nt=i(K*z),ot=c.BASE.multiplyAndAddUnsafe(O,rt,nt)?.toAffine();return ot?i(ot.x)===K:!1}return{CURVE:t,getPublicKey:B,getSharedSecret:S,sign:V,verify:X,ProjectivePoint:c,Signature:d,utils:b}}function rf(r){return{hash:r,hmac:(t,...e)=>Ir(r,t,ls(...e)),randomBytes:Ke}}function Ra(r,t){let e=n=>Ta({...r,...rf(n)});return Object.freeze({...e(t),create:e})}var _a=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),La=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),nf=BigInt(1),uo=BigInt(2),Ha=(r,t)=>(r+t/uo)/t;function sf(r){let t=_a,e=BigInt(3),n=BigInt(6),s=BigInt(11),o=BigInt(22),i=BigInt(23),a=BigInt(44),c=BigInt(88),u=r*r*r%t,l=u*u*r%t,f=G(l,e,t)*l%t,h=G(f,e,t)*l%t,v=G(h,uo,t)*u%t,w=G(v,s,t)*v%t,y=G(w,o,t)*w%t,d=G(y,a,t)*y%t,b=G(d,c,t)*d%t,B=G(b,a,t)*y%t,p=G(B,e,t)*l%t,S=G(p,i,t)*w%t,R=G(S,n,t)*u%t,T=G(R,uo,t);if(!fo.eql(fo.sqr(T),r))throw new Error("Cannot find square root");return T}var fo=ce(_a,void 0,void 0,{sqrt:sf}),Et=Ra({a:BigInt(0),b:BigInt(7),Fp:fo,n:La,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=La,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-nf*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),s=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),o=e,i=BigInt("0x100000000000000000000000000000000"),a=Ha(o*r,t),c=Ha(-n*r,t),u=q(r-a*e-c*s,t),l=q(-a*n-c*o,t),f=u>i,h=l>i;if(f&&(u=t-u),h&&(l=t-l),u>i||l>i)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:f,k1:u,k2neg:h,k2:l}}}},de),O0=BigInt(0);var D0=Et.ProjectivePoint;function Ie(r,t){t==null&&(t=r.reduce((s,o)=>s+o.length,0));let e=Ht(t),n=0;for(let s of r)e.set(s,n),n+=s.length;return e}function ho(r,t){let e=et(r,"base64urlpad");if(t!=null){if(e.length>t)throw new Error("byte array longer than desired length");e=Ie([new Uint8Array(t-e.length),e])}return e}function go(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function Va(r,t){let e=Yr.digest(t instanceof Uint8Array?t:t.subarray());if(go(e))return e.then(({digest:n})=>Et.sign(n,r).toDERRawBytes()).catch(n=>{throw new tr(String(n))});try{return Et.sign(e.digest,r).toDERRawBytes()}catch(n){throw new tr(String(n))}}function Oa(r,t,e){let n=Yr.digest(e instanceof Uint8Array?e:e.subarray());if(go(n))return n.then(({digest:s})=>Et.verify(t,s,r)).catch(s=>{throw new er(String(s))});try{return Et.verify(t,n.digest,r)}catch(s){throw new er(String(s))}}var Nr=class{type="secp256k1";raw;_key;constructor(t){this._key=Ka(t),this.raw=Da(this._key)}toMultihash(){return ar.digest(hr(this))}toCID(){return Tt.createV1(114,this.toMultihash())}toString(){return ut.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:St(this.raw,t.raw)}verify(t,e){return Oa(this._key,e,t)}},Cr=class{type="secp256k1";raw;publicKey;constructor(t,e){this.raw=Ma(t),this.publicKey=new Nr(e??Pa(t))}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:St(this.raw,t.raw)}sign(t){return Va(this.raw,t)}};function po(r){return new Cr(r)}function Yn(r){return new Nr(r)}async function Fa(){let r=of();return new Cr(r)}function Da(r){return Et.ProjectivePoint.fromHex(r).toRawBytes(!0)}function Ma(r){try{return Et.getPublicKey(r,!0),r}catch(t){throw new rr(String(t))}}function Ka(r){try{return Et.ProjectivePoint.fromHex(r),r}catch(t){throw new Ne(String(t))}}function Pa(r){try{return Et.getPublicKey(r,!0)}catch(t){throw new rr(String(t))}}function of(){return Et.utils.randomPrivateKey()}var $a={"P-256":256,"P-384":384,"P-521":521},af=Object.keys($a),mo=af.join(" / ");async function qa(r){if(r!=="P-256"&&r!=="P-384"&&r!=="P-521")throw new $(`Unknown curve: ${r}. Must be ${mo}`);let t=await at.get().subtle.generateKey({name:"ECDH",namedCurve:r},!0,["deriveBits"]),e=async(o,i)=>{let a;i!=null?a=await at.get().subtle.importKey("jwk",lf(r,i),{name:"ECDH",namedCurve:r},!1,["deriveBits"]):a=t.privateKey;let c=await at.get().subtle.importKey("jwk",ja(r,o),{name:"ECDH",namedCurve:r},!1,[]),u=await at.get().subtle.deriveBits({name:"ECDH",namedCurve:r,public:c},a,$a[r]);return new Uint8Array(u,0,u.byteLength)},n=await at.get().subtle.exportKey("jwk",t.publicKey);return{key:cf(n),genSharedKey:e}}var za={"P-256":32,"P-384":48,"P-521":66};function cf(r){if(r.crv==null||r.x==null||r.y==null)throw new $("JWK was missing components");if(r.crv!=="P-256"&&r.crv!=="P-384"&&r.crv!=="P-521")throw new $(`Unknown curve: ${r.crv}. Must be ${mo}`);let t=za[r.crv];return Ie([Uint8Array.from([4]),ho(r.x,t),ho(r.y,t)],1+t*2)}function ja(r,t){if(r!=="P-256"&&r!=="P-384"&&r!=="P-521")throw new $(`Unknown curve: ${r}. Must be ${mo}`);let e=za[r];if(!St(t.subarray(0,1),Uint8Array.from([4])))throw new $("Cannot unmarshal public key - invalid key format");return{kty:"EC",crv:r,x:mt(t.subarray(1,e+1),"base64url"),y:mt(t.subarray(1+e),"base64url"),ext:!0}}var lf=(r,t)=>({...ja(r,t.public),d:mt(t.private,"base64url")});var uf={"AES-128":{ivSize:16,keySize:16},"AES-256":{ivSize:16,keySize:32},Blowfish:{ivSize:8,keySize:32}};async function Ga(r,t,e){if(r!=="AES-128"&&r!=="AES-256"&&r!=="Blowfish")throw new $("Cipher type was missing or unsupported");if(t!=="SHA1"&&t!=="SHA256"&&t!=="SHA512")throw new $("Hash type was missing or unsupported");if(e==null||!(e instanceof Uint8Array))throw new $("Secret was missing or an incorrect type");let n=uf[r],s=n.keySize,o=n.ivSize,i=20,a=et("key expansion"),c=2*(o+s+i),u=await Qn(t,e),l=await u.digest(a),f=[],h=0;for(;h<c;){let B=await u.digest(Ie([l,a])),p=B.length;h+p>c&&(p=c-h),f.push(B),h+=p,l=await u.digest(l)}let v=c/2,w=Ie(f),y=w.subarray(0,v),d=w.subarray(v,c),b=B=>({iv:B.subarray(0,o),cipherKey:B.subarray(o,o+s),macKey:B.subarray(o+s)});return{k1:b(y),k2:b(d)}}async function ff(r,t){if(r==="Ed25519")return di();if(r==="secp256k1")return Fa();if(r==="RSA")return lo(t??2048);throw new Qt}async function hf(r,t){if(r!=="Ed25519")throw new Qt("Seed key derivation only supported for Ed25519 keys");return gi(t)}function df(r){let{Type:t,Data:e}=_t.decode(r),n=e??new Uint8Array;switch(t){case Z.RSA:return Wn(n);case Z.Ed25519:return Zr(n);case Z.secp256k1:return Yn(n);default:throw new Qt}}function gf(r){return r.byteLength===32?Zr(r):r.byteLength===33?Yn(r):Wn(r)}function pf(r){let{Type:t,Data:e}=_t.decode(r.digest),n=e??new Uint8Array;switch(t){case Z.Ed25519:return Zr(n);case Z.secp256k1:return Yn(n);default:throw new Qt}}function hr(r){return _t.encode({Type:Z[r.type],Data:r.raw})}function mf(r){let t=mr.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case Z.RSA:return Zn(e);case Z.Ed25519:return Ss(e);case Z.secp256k1:return po(e);default:throw new Qt}}function yf(r){return r.byteLength===64?Ss(r):r.byteLength===32?po(r):Zn(r)}function bf(r){return mr.encode({Type:Z[r.type],Data:r.raw})}function xf(r,t,e,n){_r(r);let s=Zo({dkLen:32,asyncTick:10},n),{c:o,dkLen:i,asyncTick:a}=s;if(He(o),He(i),He(a),o<1)throw new Error("PBKDF2: iterations (c) should be >= 1");let c=ee(t),u=ee(e),l=new Uint8Array(i),f=Ir.create(r,c),h=f._cloneInto().update(u);return{c:o,dkLen:i,asyncTick:a,DK:l,PRF:f,PRFSalt:h}}function wf(r,t,e,n,s){return r.destroy(),t.destroy(),n&&n.destroy(),s.fill(0),e}function Za(r,t,e,n){let{c:s,dkLen:o,DK:i,PRF:a,PRFSalt:c}=xf(r,t,e,n),u,l=new Uint8Array(4),f=De(l),h=new Uint8Array(a.outputLen);for(let v=1,w=0;w<o;v++,w+=a.outputLen){let y=i.subarray(w,w+a.outputLen);f.setInt32(0,v,!1),(u=c._cloneInto(u)).update(l).digestInto(h),y.set(h.subarray(0,y.length));for(let d=1;d<s;d++){a._cloneInto(u).update(h).digestInto(h);for(let b=0;b<y.length;b++)y[b]^=h[b]}}return wf(a,c,i,u,h)}var Ur=new Uint32Array([1732584193,4023233417,2562383102,271733878,3285377520]),me=new Uint32Array(80),bo=class extends re{constructor(){super(64,20,8,!1),this.A=Ur[0]|0,this.B=Ur[1]|0,this.C=Ur[2]|0,this.D=Ur[3]|0,this.E=Ur[4]|0}get(){let{A:t,B:e,C:n,D:s,E:o}=this;return[t,e,n,s,o]}set(t,e,n,s,o){this.A=t|0,this.B=e|0,this.C=n|0,this.D=s|0,this.E=o|0}process(t,e){for(let c=0;c<16;c++,e+=4)me[c]=t.getUint32(e,!1);for(let c=16;c<80;c++)me[c]=Vr(me[c-3]^me[c-8]^me[c-14]^me[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=Or(s,o,i),l=1518500249):c<40?(u=s^o^i,l=1859775393):c<60?(u=Dr(s,o,i),l=2400959708):(u=s^o^i,l=3395469782);let f=Vr(n,5)+u+a+l+me[c]|0;a=i,i=o,o=Vr(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(){me.fill(0)}destroy(){this.set(0,0,0,0,0),this.buffer.fill(0)}},Wa=Me(()=>new bo);var Ja={sha1:Wa,"sha2-256":de,"sha2-512":Kr};function xo(r,t,e,n,s){if(s!=="sha1"&&s!=="sha2-256"&&s!=="sha2-512"){let a=Object.keys(Ja).join(" / ");throw new $(`Hash '${s}' is unknown or not supported. Must be ${a}`)}let o=Ja[s],i=Za(o,r,t,{c:e,dkLen:n});return Vs.encode(i).substring(1)}return hc(vf);})();
6
+ `)}`:`${e} :`}};ji=pe;A.Constructed=ji;pe.NAME="CONSTRUCTED";var gn=class extends ht{fromBER(t,e,n){return e}toBER(t){return Ut}};gn.override="EndOfContentValueBlock";var Gi,pn=class extends ct{constructor(t={}){super(t,gn),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};Gi=pn;A.EndOfContent=Gi;pn.NAME=wr;var Zi,Ge=class extends ct{constructor(t={}){super(t,ht),this.idBlock.tagClass=1,this.idBlock.tagNumber=5}fromBER(t,e,n){return this.lenBlock.length>0&&this.warnings.push("Non-zero length of value block for Null type"),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.blockLength+=n,e+n>t.byteLength?(this.error="End of input reached before message was fully decoded (inconsistent offset and length values)",-1):e+n}toBER(t,e){let n=new ArrayBuffer(2);if(!t){let s=new Uint8Array(n);s[0]=5,s[1]=0}return e&&e.write(n),n}onAsciiEncoding(){return`${this.constructor.NAME}`}};Zi=Ge;A.Null=Zi;Ge.NAME="NULL";var mn=class extends Jt(ht){constructor({value:t,...e}={}){super(e),e.valueHex?this.valueHexView=M.BufferSourceConverter.toUint8Array(e.valueHex):this.valueHexView=new Uint8Array(1),t&&(this.value=t)}get value(){for(let t of this.valueHexView)if(t>0)return!0;return!1}set value(t){this.valueHexView[0]=t?255:0}fromBER(t,e,n){let s=M.BufferSourceConverter.toUint8Array(t);return Wt(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,no.call(this),this.blockLength=n,e+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};mn.NAME="BooleanValueBlock";var Wi,yn=class extends ct{constructor(t={}){super(t,mn),this.idBlock.tagClass=1,this.idBlock.tagNumber=1}getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.getValue}`}};Wi=yn;A.Boolean=Wi;yn.NAME="BOOLEAN";var bn=class extends Jt(Vt){constructor({isConstructed:t=!1,...e}={}){super(e),this.isConstructed=t}fromBER(t,e,n){let s=0;if(this.isConstructed){if(this.isHexOnly=!1,s=Vt.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let o=0;o<this.value.length;o++){let i=this.value[o].constructor.NAME;if(i===wr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(i!==Fi)return this.error="OCTET STRING may consists of OCTET STRINGs only",-1}}else this.isHexOnly=!0,s=super.fromBER(t,e,n),this.blockLength=n;return s}toBER(t,e){return this.isConstructed?Vt.prototype.toBER.call(this,t,e):t?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};bn.NAME="OctetStringValueBlock";var Ji,xn=class r extends ct{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,o;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((o=n.value)===null||o===void 0)&&o.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},bn),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=Gn(o,0,o.byteLength);i.offset!==-1&&i.offset===n&&(this.valueBlock.value=[i.result])}}catch{}}return super.fromBER(t,e,n)}onAsciiEncoding(){return this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length?pe.prototype.onAsciiEncoding.call(this):`${this.constructor.NAME} : ${M.Convert.ToHex(this.valueBlock.valueHexView)}`}getValue(){if(!this.idBlock.isConstructed)return this.valueBlock.valueHexView.slice().buffer;let t=[];for(let e of this.valueBlock.value)e instanceof r&&t.push(e.valueBlock.valueHexView);return M.BufferSourceConverter.concat(t)}};Ji=xn;A.OctetString=Ji;xn.NAME=Fi;var wn=class extends Jt(Vt){constructor({unusedBits:t=0,isConstructed:e=!1,...n}={}){super(n),this.unusedBits=t,this.isConstructed=e,this.blockLength=this.valueHexView.byteLength}fromBER(t,e,n){if(!n)return e;let s=-1;if(this.isConstructed){if(s=Vt.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let a of this.value){let c=a.constructor.NAME;if(c===wr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==$i)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=M.BufferSourceConverter.toUint8Array(t);if(!Wt(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=Gn(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 Vt.prototype.toBER.call(this,t,e);if(t)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return Ut;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 Yi,Ze=class extends ct{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,o;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((o=n.value)===null||o===void 0)&&o.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},wn),this.idBlock.tagClass=1,this.idBlock.tagNumber=3}fromBER(t,e,n){return this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,super.fromBER(t,e,n)}onAsciiEncoding(){if(this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length)return pe.prototype.onAsciiEncoding.call(this);{let t=[],e=this.valueBlock.valueHexView;for(let s of e)t.push(s.toString(2).padStart(8,"0"));let n=t.join("");return`${this.constructor.NAME} : ${n.substring(0,n.length-this.valueBlock.unusedBits)}`}}};Yi=Ze;A.BitString=Yi;Ze.NAME=$i;var Xi;function zu(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++){switch(!0){case f<a.length:u=o[i-f]+a[c-f]+e[0];break;default:u=o[i-f]+e[0]}switch(e[0]=u/10,!0){case f>=o.length:o=an(new Uint8Array([u%10]),o);break;default:o[i-f]=u%10}}return e[0]>0&&(o=an(e,o)),o}function Pi(r){if(r>=br.length)for(let t=br.length;t<=r;t++){let e=new Uint8Array([0]),n=br[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=an(e,n)),br.push(n)}return br[r]}function ju(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++)switch(u=o[i-l]-a[c-l]-e,!0){case u<0:e=1,o[i-l]=u+10;break;default: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 vr=class extends Jt(ht){constructor({value:t,...e}={}){super(e),this._valueDec=0,e.valueHex&&this.setValueHex(),t!==void 0&&(this.valueDec=t)}setValueHex(){this.valueHexView.length>=4?(this.warnings.push("Too big Integer for decoding, hex only"),this.isHexOnly=!0,this._valueDec=0):(this.isHexOnly=!1,this.valueHexView.length>0&&(this._valueDec=no.call(this)))}set valueDec(t){this._valueDec=t,this.isHexOnly=!1,this.valueHexView=new Uint8Array(Di(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?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++){if((s&1)===1)switch(n){case t:e=ju(Pi(n),e),i="-";break;default:e=zu(e,Pi(n))}n++,s>>=1}}for(let c=0;c<e.length;c++)e[c]&&(a=!0),a&&(i+=Ki.charAt(e[c]));return a===!1&&(i+=Ki.charAt(0)),i}};Xi=vr;vr.NAME="IntegerValueBlock";Object.defineProperty(Xi.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var Qi,lt=class r extends ct{constructor(t={}){super(t,vr),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return cn(),BigInt(this.valueBlock.toString())}static fromBigInt(t){cn();let e=BigInt(t),n=new xr,s=e.toString(16).replace(/^-/,""),o=new Uint8Array(M.Convert.FromHex(s));if(e<0){let a=new Uint8Array(o.length+(o[0]&128?1:0));a[0]|=128;let u=BigInt(`0x${M.Convert.ToHex(a)}`)+e,l=M.BufferSourceConverter.toUint8Array(M.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 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()}`}};Qi=lt;A.Integer=Qi;lt.NAME="INTEGER";var ta,vn=class extends lt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};ta=vn;A.Enumerated=ta;vn.NAME="ENUMERATED";var Br=class extends Jt(ht){constructor({valueDec:t=-1,isFirstSid:e=!1,...n}={}){super(n),this.valueDec=t,this.isFirstSid=e}fromBER(t,e,n){if(!n)return e;let s=M.BufferSourceConverter.toUint8Array(t);if(!Wt(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));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?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=ke(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}set valueBigInt(t){cn();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",Ut;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),o=e.byteLength-1;for(let i=0;i<o;i++)n[i]=s[i]|128;n[o]=s[o]}return n}toString(){let t="";if(this.isHexOnly)t=M.Convert.ToHex(this.valueHexView);else if(this.isFirstSid){let e=this.valueDec;this.valueDec<=39?t="0.":this.valueDec<=79?(t="1.",e-=40):(t="2.",e-=80),t+=e.toString()}else t=this.valueDec.toString();return t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec,isFirstSid:this.isFirstSid}}};Br.NAME="sidBlock";var Bn=class extends ht{constructor({value:t=Je,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new Br;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,Ut;e.push(s)}return so(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 Br;if(s>Number.MAX_SAFE_INTEGER){cn();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}};Bn.NAME="ObjectIdentifierValueBlock";var ea,We=class extends ct{constructor(t={}){super(t,Bn),this.idBlock.tagClass=1,this.idBlock.tagNumber=6}getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};ea=We;A.ObjectIdentifier=ea;We.NAME="OBJECT IDENTIFIER";var Er=class extends Jt(jt){constructor({valueDec:t=0,...e}={}){super(e),this.valueDec=t}fromBER(t,e,n){if(n===0)return e;let s=M.BufferSourceConverter.toUint8Array(t);if(!Wt(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));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?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=ke(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}toBER(t){if(this.isHexOnly){if(t)return new ArrayBuffer(this.valueHexView.byteLength);let s=this.valueHexView,o=new Uint8Array(this.blockLength);for(let i=0;i<this.blockLength-1;i++)o[i]=s[i]|128;return o[this.blockLength-1]=s[this.blockLength-1],o.buffer}let e=ge(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Ut;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),o=e.byteLength-1;for(let i=0;i<o;i++)n[i]=s[i]|128;n[o]=s[o]}return n.buffer}toString(){let t="";return this.isHexOnly?t=M.Convert.ToHex(this.valueHexView):t=this.valueDec.toString(),t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};Er.NAME="relativeSidBlock";var En=class extends ht{constructor({value:t=Je,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new Er;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,Ut;n.push(o)}return so(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 Er;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}};En.NAME="RelativeObjectIdentifierValueBlock";var ra,An=class extends ct{constructor(t={}){super(t,En),this.idBlock.tagClass=1,this.idBlock.tagNumber=13}getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};ra=An;A.RelativeObjectIdentifier=ra;An.NAME="RelativeObjectIdentifier";var na,Gt=class extends pe{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};na=Gt;A.Sequence=na;Gt.NAME="SEQUENCE";var sa,Sn=class extends pe{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};sa=Sn;A.Set=sa;Sn.NAME="SET";var kn=class extends Jt(ht){constructor({...t}={}){super(t),this.isHexOnly=!0,this.value=Je}toJSON(){return{...super.toJSON(),value:this.value}}};kn.NAME="StringValueBlock";var In=class extends kn{};In.NAME="SimpleStringValueBlock";var pt=class extends fn{constructor({...t}={}){super(t,In)}fromBuffer(t){this.valueBlock.value=String.fromCharCode.apply(null,M.BufferSourceConverter.toUint8Array(t))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e);for(let s=0;s<e;s++)n[s]=t.charCodeAt(s);this.valueBlock.value=t}};pt.NAME="SIMPLE STRING";var Nn=class extends pt{fromBuffer(t){this.valueBlock.valueHexView=M.BufferSourceConverter.toUint8Array(t);try{this.valueBlock.value=M.Convert.ToUtf8String(t)}catch(e){this.warnings.push(`Error during "decodeURIComponent": ${e}, using raw string`),this.valueBlock.value=M.Convert.ToBinary(t)}}fromString(t){this.valueBlock.valueHexView=new Uint8Array(M.Convert.FromUtf8String(t)),this.valueBlock.value=t}};Nn.NAME="Utf8StringValueBlock";var oa,Zt=class extends Nn{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};oa=Zt;A.Utf8String=oa;Zt.NAME="UTF8String";var Cn=class extends pt{fromBuffer(t){this.valueBlock.value=M.Convert.ToUtf16String(t),this.valueBlock.valueHexView=M.BufferSourceConverter.toUint8Array(t)}fromString(t){this.valueBlock.value=t,this.valueBlock.valueHexView=new Uint8Array(M.Convert.FromUtf16String(t))}};Cn.NAME="BmpStringValueBlock";var ia,Un=class extends Cn{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};ia=Un;A.BmpString=ia;Un.NAME="BMPString";var Tn=class extends pt{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 a=4-i.length;for(let c=i.length-1;c>=0;c--)n[s*4+c+a]=i[c]}this.valueBlock.value=t}};Tn.NAME="UniversalStringValueBlock";var aa,Rn=class extends Tn{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};aa=Rn;A.UniversalString=aa;Rn.NAME="UniversalString";var ca,Ln=class extends pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};ca=Ln;A.NumericString=ca;Ln.NAME="NumericString";var la,Hn=class extends pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};la=Hn;A.PrintableString=la;Hn.NAME="PrintableString";var ua,_n=class extends pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};ua=_n;A.TeletexString=ua;_n.NAME="TeletexString";var fa,Vn=class extends pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};fa=Vn;A.VideotexString=fa;Vn.NAME="VideotexString";var ha,On=class extends pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};ha=On;A.IA5String=ha;On.NAME="IA5String";var da,Dn=class extends pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};da=Dn;A.GraphicString=da;Dn.NAME="GraphicString";var ga,Ar=class extends pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};ga=Ar;A.VisibleString=ga;Ar.NAME="VisibleString";var pa,Mn=class extends pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};pa=Mn;A.GeneralString=pa;Mn.NAME="GeneralString";var ma,Kn=class extends pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};ma=Kn;A.CharacterString=ma;Kn.NAME="CharacterString";var ya,Sr=class extends Ar{constructor({value:t,valueDate:e,...n}={}){if(super(n),this.year=0,this.month=0,this.day=0,this.hour=0,this.minute=0,this.second=0,t){this.fromString(t),this.valueBlock.valueHexView=new Uint8Array(t.length);for(let s=0;s<t.length;s++)this.valueBlock.valueHexView[s]=t.charCodeAt(s)}e&&(this.fromDate(e),this.valueBlock.valueHexView=new Uint8Array(this.toBuffer())),this.idBlock.tagClass=1,this.idBlock.tagNumber=23}fromBuffer(t){this.fromString(String.fromCharCode.apply(null,M.BufferSourceConverter.toUint8Array(t)))}toBuffer(){let t=this.toString(),e=new ArrayBuffer(t.length),n=new Uint8Array(e);for(let s=0;s<t.length;s++)n[s]=t.charCodeAt(s);return e}fromDate(t){this.year=t.getUTCFullYear(),this.month=t.getUTCMonth()+1,this.day=t.getUTCDate(),this.hour=t.getUTCHours(),this.minute=t.getUTCMinutes(),this.second=t.getUTCSeconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second))}fromString(t){let n=/(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})Z/ig.exec(t);if(n===null){this.error="Wrong input string for conversion";return}let s=parseInt(n[1],10);s>=50?this.year=1900+s:this.year=2e3+s,this.month=parseInt(n[2],10),this.day=parseInt(n[3],10),this.hour=parseInt(n[4],10),this.minute=parseInt(n[5],10),this.second=parseInt(n[6],10)}toString(t="iso"){if(t==="iso"){let e=new Array(7);return e[0]=wt(this.year<2e3?this.year-1900:this.year-2e3,2),e[1]=wt(this.month,2),e[2]=wt(this.day,2),e[3]=wt(this.hour,2),e[4]=wt(this.minute,2),e[5]=wt(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}}};ya=Sr;A.UTCTime=ya;Sr.NAME="UTCTime";var ba,Pn=class extends Sr{constructor(t={}){var e;super(t),(e=this.millisecond)!==null&&e!==void 0||(this.millisecond=0),this.idBlock.tagClass=1,this.idBlock.tagNumber=24}fromDate(t){super.fromDate(t),this.millisecond=t.getUTCMilliseconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second,this.millisecond))}fromString(t){let e=!1,n="",s="",o=0,i,a=0,c=0;if(t[t.length-1]==="Z")n=t.substring(0,t.length-1),e=!0;else{let 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("+"),v="";if(h===-1&&(h=n.indexOf("-"),f=-1),h!==-1){if(v=n.substring(h+1),n=n.substring(0,h),v.length!==2&&v.length!==4)throw new Error("Wrong input string for conversion");let w=parseInt(v.substring(0,2),10);if(isNaN(w.valueOf()))throw new Error("Wrong input string for conversion");if(a=f*w,v.length===4){if(w=parseInt(v.substring(2,4),10),isNaN(w.valueOf()))throw new Error("Wrong input string for conversion");c=f*w}}}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(wt(this.year,4)),e.push(wt(this.month,2)),e.push(wt(this.day,2)),e.push(wt(this.hour,2)),e.push(wt(this.minute,2)),e.push(wt(this.second,2)),this.millisecond!==0&&(e.push("."),e.push(wt(this.millisecond,3))),e.push("Z"),e.join("")}return super.toString(t)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};ba=Pn;A.GeneralizedTime=ba;Pn.NAME="GeneralizedTime";var xa,Fn=class extends Zt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};xa=Fn;A.DATE=xa;Fn.NAME="DATE";var wa,$n=class extends Zt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};wa=$n;A.TimeOfDay=wa;$n.NAME="TimeOfDay";var va,qn=class extends Zt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};va=qn;A.DateTime=va;qn.NAME="DateTime";var Ba,zn=class extends Zt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};Ba=zn;A.Duration=Ba;zn.NAME="Duration";var Ea,jn=class extends Zt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};Ea=jn;A.TIME=Ea;jn.NAME="TIME";function mt(r,t="utf8"){let e=Qr[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}function ao(r){if(isNaN(r)||r<=0)throw new $("random bytes length must be a Number bigger than 0");return Ke(r)}async function Aa(r){let t=await at.get().subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:r,publicExponent:new Uint8Array([1,0,1]),hash:{name:"SHA-256"}},!0,["sign","verify"]),e=await Zu(t);return{privateKey:e[0],publicKey:e[1]}}async function Sa(r,t){let e=await at.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await at.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},e,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(n,0,n.byteLength)}async function ka(r,t,e){let n=await at.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return at.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,t,e instanceof Uint8Array?e:e.subarray())}async function Zu(r){if(r.privateKey==null||r.publicKey==null)throw new $("Private and public key are required");return Promise.all([at.get().subtle.exportKey("jwk",r.privateKey),at.get().subtle.exportKey("jwk",r.publicKey)])}function co(r){if(r.kty!=="RSA")throw new $("invalid key type");if(r.n==null)throw new $("invalid key modulus");return et(r.n,"base64url").length*8}var Ye=class{type="RSA";_key;_raw;_multihash;constructor(t,e){this._key=t,this._multihash=e}get raw(){return this._raw==null&&(this._raw=kr.jwkToPkix(this._key)),this._raw}toMultihash(){return this._multihash}toCID(){return Tt.createV1(114,this._multihash)}toString(){return ut.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:St(this.raw,t.raw)}verify(t,e){return ka(this._key,e,t)}},Ir=class{type="RSA";_key;_raw;publicKey;constructor(t,e){this._key=t,this.publicKey=e}get raw(){return this._raw==null&&(this._raw=kr.jwkToPkcs1(this._key)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:St(this.raw,t.raw)}sign(t){return Sa(this._key,t)}};var Zn=8192,lo=18;function Ia(r){let{result:t}=io(r),e=t.valueBlock.value;return{n:mt(Ot(e[1].toBigInt()),"base64url"),e:mt(Ot(e[2].toBigInt()),"base64url"),d:mt(Ot(e[3].toBigInt()),"base64url"),p:mt(Ot(e[4].toBigInt()),"base64url"),q:mt(Ot(e[5].toBigInt()),"base64url"),dp:mt(Ot(e[6].toBigInt()),"base64url"),dq:mt(Ot(e[7].toBigInt()),"base64url"),qi:mt(Ot(e[8].toBigInt()),"base64url"),kty:"RSA",alg:"RS256"}}function Wu(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");let e=new Gt({value:[new lt({value:0}),lt.fromBigInt(Dt(et(r.n,"base64url"))),lt.fromBigInt(Dt(et(r.e,"base64url"))),lt.fromBigInt(Dt(et(r.d,"base64url"))),lt.fromBigInt(Dt(et(r.p,"base64url"))),lt.fromBigInt(Dt(et(r.q,"base64url"))),lt.fromBigInt(Dt(et(r.dp,"base64url"))),lt.fromBigInt(Dt(et(r.dq,"base64url"))),lt.fromBigInt(Dt(et(r.qi,"base64url")))]}).toBER();return new Uint8Array(e,0,e.byteLength)}function Na(r){let{result:t}=io(r),e=t.valueBlock.value[1].valueBlock.value[0].valueBlock.value;return{kty:"RSA",n:mt(Ot(e[0].toBigInt()),"base64url"),e:mt(Ot(e[1].toBigInt()),"base64url")}}function uo(r){if(r.n==null||r.e==null)throw new $("JWK was missing components");let e=new Gt({value:[new Gt({value:[new We({value:"1.2.840.113549.1.1.1"}),new Ge]}),new Ze({valueHex:new Gt({value:[lt.fromBigInt(Dt(et(r.n,"base64url"))),lt.fromBigInt(Dt(et(r.e,"base64url")))]}).toBER()})]}).toBER();return new Uint8Array(e,0,e.byteLength)}function Ot(r){let t=r.toString(16);t.length%2>0&&(t=`0${t}`);let e=t.length/2,n=new Uint8Array(e),s=0,o=0;for(;s<e;)n[s]=parseInt(t.slice(o,o+2),16),s+=1,o+=2;return n}function Dt(r){let t=[];return r.forEach(function(e){let n=e.toString(16);n.length%2>0&&(n=`0${n}`),t.push(n)}),BigInt("0x"+t.join(""))}function Wn(r){let t=Ia(r);return Ca(t)}function Jn(r){let t=Na(r);if(co(t)>Zn)throw new Ne("Key size is too large");let e=de(_t.encode({Type:Z.RSA,Data:r})),n=At(lo,e);return new Ye(t,n)}function Ca(r){if(co(r)>Zn)throw new $("Key size is too large");let t=Ua(r),e=de(_t.encode({Type:Z.RSA,Data:uo(t.publicKey)})),n=At(lo,e);return new Ir(t.privateKey,new Ye(t.publicKey,n))}async function fo(r){if(r>Zn)throw new $("Key size is too large");let t=await Aa(r),e=de(_t.encode({Type:Z.RSA,Data:uo(t.publicKey)})),n=At(lo,e);return new Ir(t.privateKey,new Ye(t.publicKey,n))}function Ua(r){if(r==null)throw new $("Missing key parameter");return{privateKey:r,publicKey:{kty:r.kty,n:r.n,e:r.e}}}var Yn=class extends Oe{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,Vr(t);let n=ee(e);if(this.iHash=t.create(),typeof this.iHash.update!="function")throw new Error("Expected instance of class which extends utils.Hash");this.blockLen=this.iHash.blockLen,this.outputLen=this.iHash.outputLen;let s=this.blockLen,o=new Uint8Array(s);o.set(n.length>s?t.create().update(n).digest():n);for(let i=0;i<o.length;i++)o[i]^=54;this.iHash.update(o),this.oHash=t.create();for(let i=0;i<o.length;i++)o[i]^=106;this.oHash.update(o),o.fill(0)}update(t){return Ve(this),this.iHash.update(t),this}digestInto(t){Ve(this),_e(t,this.outputLen),this.finished=!0,this.iHash.digestInto(t),this.oHash.update(t),this.oHash.digestInto(t),this.destroy()}digest(){let t=new Uint8Array(this.oHash.outputLen);return this.digestInto(t),t}_cloneInto(t){t||(t=Object.create(Object.getPrototypeOf(this),{}));let{oHash:e,iHash:n,finished:s,destroyed:o,blockLen:i,outputLen:a}=this;return t=t,t.finished=s,t.destroyed=o,t.blockLen=i,t.outputLen=a,t.oHash=e._cloneInto(t.oHash),t.iHash=n._cloneInto(t.iHash),t}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},Nr=(r,t,e)=>new Yn(r,t).update(e).digest();Nr.create=(r,t)=>new Yn(r,t);function Ta(r){r.lowS!==void 0&&It("lowS",r.lowS),r.prehash!==void 0&&It("prehash",r.prehash)}function Ju(r){let t=fr(r);Rt(t,{a:"field",b:"field"},{allowedPrivateKeyLengths:"array",wrapPrivateKey:"boolean",isTorsionFree:"function",clearCofactor:"function",allowInfinityPoint:"boolean",fromBytes:"function",toBytes:"function"});let{endo:e,Fp:n,a:s}=t;if(e){if(!n.eql(s,n.ZERO))throw new Error("Endomorphism can only be defined for Koblitz curves that have a=0");if(typeof e!="object"||typeof e.beta!="bigint"||typeof e.splitScalar!="function")throw new Error("Expected endomorphism with beta: bigint and splitScalar: function")}return Object.freeze({...t})}var{bytesToNumberBE:Yu,hexToBytes:Xu}=$r,Yt={Err:class extends Error{constructor(t=""){super(t)}},_tlv:{encode:(r,t)=>{let{Err:e}=Yt;if(r<0||r>256)throw new e("tlv.encode: wrong tag");if(t.length&1)throw new e("tlv.encode: unpadded data");let n=t.length/2,s=be(n);if(s.length/2&128)throw new e("tlv.encode: long form length too big");let o=n>127?be(s.length/2|128):"";return`${be(r)}${o}${s}${t}`},decode(r,t){let{Err:e}=Yt,n=0;if(r<0||r>256)throw new e("tlv.encode: wrong tag");if(t.length<2||t[n++]!==r)throw new e("tlv.decode: wrong tlv");let s=t[n++],o=!!(s&128),i=0;if(!o)i=s;else{let c=s&127;if(!c)throw new e("tlv.decode(long): indefinite length not supported");if(c>4)throw new e("tlv.decode(long): byte length is too big");let 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}=Yt;if(r<Xt)throw new t("integer: negative integers are not allowed");let e=be(r);if(Number.parseInt(e[0],16)&8&&(e="00"+e),e.length&1)throw new t("unexpected assertion");return e},decode(r){let{Err:t}=Yt;if(r[0]&128)throw new t("Invalid signature integer: negative");if(r[0]===0&&!(r[1]&128))throw new t("Invalid signature integer: unnecessary leading zero");return Yu(r)}},toSig(r){let{Err:t,_int:e,_tlv:n}=Yt,s=typeof r=="string"?Xu(r):r;Pe(s);let{v:o,l:i}=n.decode(48,s);if(i.length)throw new t("Invalid signature: left bytes after parsing");let{v:a,l:c}=n.decode(2,o),{v: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}=Yt,n=`${t.encode(2,e.encode(r.r))}${t.encode(2,e.encode(r.s))}`;return t.encode(48,n)}},Xt=BigInt(0),st=BigInt(1),I0=BigInt(2),Ra=BigInt(3),N0=BigInt(4);function Qu(r){let t=Ju(r),{Fp:e}=t,n=ce(t.n,t.nBitLength),s=t.toBytes||((y,d,b)=>{let B=d.toAffine();return qt(Uint8Array.from([4]),e.toBytes(B.x),e.toBytes(B.y))}),o=t.fromBytes||(y=>{let d=y.subarray(1),b=e.fromBytes(d.subarray(0,e.BYTES)),B=e.fromBytes(d.subarray(e.BYTES,2*e.BYTES));return{x:b,y:B}});function i(y){let{a:d,b}=t,B=e.sqr(y),p=e.mul(B,y);return e.add(e.add(p,e.mul(y,d)),b)}if(!e.eql(e.sqr(t.Gy),i(t.Gx)))throw new Error("bad generator point: equation left != right");function a(y){return lr(y,st,t.n)}function c(y){let{allowedPrivateKeyLengths:d,nByteLength:b,wrapPrivateKey:B,n:p}=t;if(d&&typeof y!="bigint"){if(oe(y)&&(y=Ft(y)),typeof y!="string"||!d.includes(y.length))throw new Error("Invalid key");y=y.padStart(b*2,"0")}let S;try{S=typeof y=="bigint"?y:$t(J("private key",y,b))}catch{throw new Error(`private key must be ${b} bytes, hex or bigint, not ${typeof y}`)}return B&&(S=q(S,p)),bt("private key",S,st,p),S}function u(y){if(!(y instanceof h))throw new Error("ProjectivePoint expected")}let l=ve((y,d)=>{let{px:b,py:B,pz:p}=y;if(e.eql(p,e.ONE))return{x:b,y:B};let S=y.is0();d==null&&(d=S?e.ONE:e.inv(p));let R=e.mul(b,d),T=e.mul(B,d),k=e.mul(p,d);if(S)return{x:e.ZERO,y:e.ZERO};if(!e.eql(k,e.ONE))throw new Error("invZ was invalid");return{x:R,y:T}}),f=ve(y=>{if(y.is0()){if(t.allowInfinityPoint&&!e.is0(y.py))return;throw new Error("bad point: ZERO")}let{x:d,y:b}=y.toAffine();if(!e.isValid(d)||!e.isValid(b))throw new Error("bad point: x or y not FE");let B=e.sqr(b),p=i(d);if(!e.eql(B,p))throw new Error("bad point: equation left != right");if(!y.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});class h{constructor(d,b,B){if(this.px=d,this.py=b,this.pz=B,d==null||!e.isValid(d))throw new Error("x required");if(b==null||!e.isValid(b))throw new Error("y required");if(B==null||!e.isValid(B))throw new Error("z required");Object.freeze(this)}static fromAffine(d){let{x:b,y:B}=d||{};if(!d||!e.isValid(b)||!e.isValid(B))throw new Error("invalid affine point");if(d instanceof h)throw new Error("projective point not allowed");let p=S=>e.eql(S,e.ZERO);return p(b)&&p(B)?h.ZERO:new h(b,B,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(d){let b=e.invertBatch(d.map(B=>B.pz));return d.map((B,p)=>B.toAffine(b[p])).map(h.fromAffine)}static fromHex(d){let b=h.fromAffine(o(J("pointHex",d)));return b.assertValidity(),b}static fromPrivateKey(d){return h.BASE.multiply(c(d))}static msm(d,b){return jr(h,n,d,b)}_setWindowSize(d){w.setWindowSize(this,d)}assertValidity(){f(this)}hasEvenY(){let{y:d}=this.toAffine();if(e.isOdd)return!e.isOdd(d);throw new Error("Field doesn't support isOdd")}equals(d){u(d);let{px:b,py:B,pz:p}=this,{px:S,py:R,pz:T}=d,k=e.eql(e.mul(b,T),e.mul(S,p)),I=e.eql(e.mul(B,T),e.mul(R,p));return k&&I}negate(){return new h(this.px,e.neg(this.py),this.pz)}double(){let{a:d,b}=t,B=e.mul(b,Ra),{px:p,py:S,pz:R}=this,T=e.ZERO,k=e.ZERO,I=e.ZERO,U=e.mul(p,p),Y=e.mul(S,S),P=e.mul(R,R),V=e.mul(p,S);return V=e.add(V,V),I=e.mul(p,R),I=e.add(I,I),T=e.mul(d,I),k=e.mul(B,P),k=e.add(T,k),T=e.sub(Y,k),k=e.add(Y,k),k=e.mul(T,k),T=e.mul(V,T),I=e.mul(B,I),P=e.mul(d,P),V=e.sub(U,P),V=e.mul(d,V),V=e.add(V,I),I=e.add(U,U),U=e.add(I,U),U=e.add(U,P),U=e.mul(U,V),k=e.add(k,U),P=e.mul(S,R),P=e.add(P,P),U=e.mul(P,V),T=e.sub(T,U),I=e.mul(P,Y),I=e.add(I,I),I=e.add(I,I),new h(T,k,I)}add(d){u(d);let{px:b,py:B,pz:p}=this,{px:S,py:R,pz:T}=d,k=e.ZERO,I=e.ZERO,U=e.ZERO,Y=t.a,P=e.mul(t.b,Ra),V=e.mul(b,S),X=e.mul(B,R),E=e.mul(p,T),N=e.add(b,B),m=e.add(S,R);N=e.mul(N,m),m=e.add(V,X),N=e.sub(N,m),m=e.add(b,p);let g=e.add(S,T);return m=e.mul(m,g),g=e.add(V,E),m=e.sub(m,g),g=e.add(B,p),k=e.add(R,T),g=e.mul(g,k),k=e.add(X,E),g=e.sub(g,k),U=e.mul(Y,m),k=e.mul(P,E),U=e.add(k,U),k=e.sub(X,U),U=e.add(X,U),I=e.mul(k,U),X=e.add(V,V),X=e.add(X,V),E=e.mul(Y,E),m=e.mul(P,m),X=e.add(X,E),E=e.sub(V,E),E=e.mul(Y,E),m=e.add(m,E),V=e.mul(X,m),I=e.add(I,V),V=e.mul(g,m),k=e.mul(N,k),k=e.sub(k,V),V=e.mul(N,X),U=e.mul(g,U),U=e.add(U,V),new h(k,I,U)}subtract(d){return this.add(d.negate())}is0(){return this.equals(h.ZERO)}wNAF(d){return w.wNAFCached(this,d,h.normalizeZ)}multiplyUnsafe(d){bt("scalar",d,Xt,t.n);let b=h.ZERO;if(d===Xt)return b;if(d===st)return this;let{endo:B}=t;if(!B)return w.unsafeLadder(this,d);let{k1neg:p,k1:S,k2neg:R,k2:T}=B.splitScalar(d),k=b,I=b,U=this;for(;S>Xt||T>Xt;)S&st&&(k=k.add(U)),T&st&&(I=I.add(U)),U=U.double(),S>>=st,T>>=st;return p&&(k=k.negate()),R&&(I=I.negate()),I=new h(e.mul(I.px,B.beta),I.py,I.pz),k.add(I)}multiply(d){let{endo:b,n:B}=t;bt("scalar",d,st,B);let p,S;if(b){let{k1neg:R,k1:T,k2neg:k,k2:I}=b.splitScalar(d),{p:U,f:Y}=this.wNAF(T),{p:P,f:V}=this.wNAF(I);U=w.constTimeNegate(R,U),P=w.constTimeNegate(k,P),P=new h(e.mul(P.px,b.beta),P.py,P.pz),p=U.add(P),S=Y.add(V)}else{let{p:R,f:T}=this.wNAF(d);p=R,S=T}return h.normalizeZ([p,S])[0]}multiplyAndAddUnsafe(d,b,B){let p=h.BASE,S=(T,k)=>k===Xt||k===st||!T.equals(p)?T.multiplyUnsafe(k):T.multiply(k),R=S(this,b).add(S(d,B));return R.is0()?void 0:R}toAffine(d){return l(this,d)}isTorsionFree(){let{h:d,isTorsionFree:b}=t;if(d===st)return!0;if(b)return b(h,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h:d,clearCofactor:b}=t;return d===st?this:b?b(h,this):this.multiplyUnsafe(t.h)}toRawBytes(d=!0){return It("isCompressed",d),this.assertValidity(),s(h,this,d)}toHex(d=!0){return It("isCompressed",d),Ft(this.toRawBytes(d))}}h.BASE=new h(t.Gx,t.Gy,e.ONE),h.ZERO=new h(e.ZERO,e.ONE,e.ZERO);let v=t.nBitLength,w=zr(h,t.endo?Math.ceil(v/2):v);return{CURVE:t,ProjectivePoint:h,normPrivateKeyToScalar:c,weierstrassEquation:i,isWithinCurveOrder:a}}function tf(r){let t=fr(r);return Rt(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function La(r){let t=tf(r),{Fp:e,n}=t,s=e.BYTES+1,o=2*e.BYTES+1;function i(E){return q(E,n)}function a(E){return qr(E,n)}let{ProjectivePoint:c,normPrivateKeyToScalar:u,weierstrassEquation:l,isWithinCurveOrder:f}=Qu({...t,toBytes(E,N,m){let g=N.toAffine(),x=e.toBytes(g.x),C=qt;return It("isCompressed",m),m?C(Uint8Array.from([N.hasEvenY()?2:3]),x):C(Uint8Array.from([4]),x,e.toBytes(g.y))},fromBytes(E){let N=E.length,m=E[0],g=E.subarray(1);if(N===s&&(m===2||m===3)){let x=$t(g);if(!lr(x,st,e.ORDER))throw new Error("Point is not on curve");let C=l(x),L;try{L=e.sqrt(C)}catch(K){let D=K instanceof Error?": "+K.message:"";throw new Error("Point is not on curve"+D)}let H=(L&st)===st;return(m&1)===1!==H&&(L=e.neg(L)),{x,y:L}}else if(N===o&&m===4){let x=e.fromBytes(g.subarray(0,e.BYTES)),C=e.fromBytes(g.subarray(e.BYTES,2*e.BYTES));return{x,y:C}}else throw new Error(`Point of length ${N} was invalid. Expected ${s} compressed bytes or ${o} uncompressed bytes`)}}),h=E=>Ft(ae(E,t.nByteLength));function v(E){let N=n>>st;return E>N}function w(E){return v(E)?i(-E):E}let y=(E,N,m)=>$t(E.slice(N,m));class d{constructor(N,m,g){this.r=N,this.s=m,this.recovery=g,this.assertValidity()}static fromCompact(N){let m=t.nByteLength;return N=J("compactSignature",N,m*2),new d(y(N,0,m),y(N,m,2*m))}static fromDER(N){let{r:m,s:g}=Yt.toSig(J("DER",N));return new d(m,g)}assertValidity(){bt("r",this.r,st,n),bt("s",this.s,st,n)}addRecoveryBit(N){return new d(this.r,this.s,N)}recoverPublicKey(N){let{r:m,s:g,recovery:x}=this,C=T(J("msgHash",N));if(x==null||![0,1,2,3].includes(x))throw new Error("recovery id invalid");let L=x===2||x===3?m+t.n:m;if(L>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let H=x&1?"03":"02",O=c.fromHex(H+h(L)),K=a(L),D=i(-C*K),F=i(g*K),z=c.BASE.multiplyAndAddUnsafe(O,D,F);if(!z)throw new Error("point at infinify");return z.assertValidity(),z}hasHighS(){return v(this.s)}normalizeS(){return this.hasHighS()?new d(this.r,i(-this.s),this.recovery):this}toDERRawBytes(){return xe(this.toDERHex())}toDERHex(){return Yt.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return xe(this.toCompactHex())}toCompactHex(){return h(this.r)+h(this.s)}}let b={isValidPrivateKey(E){try{return u(E),!0}catch{return!1}},normPrivateKeyToScalar:u,randomPrivateKey:()=>{let E=As(t.n);return si(t.randomBytes(E),t.n)},precompute(E=8,N=c.BASE){return N._setWindowSize(E),N.multiply(BigInt(3)),N}};function B(E,N=!0){return c.fromPrivateKey(E).toRawBytes(N)}function p(E){let N=oe(E),m=typeof E=="string",g=(N||m)&&E.length;return N?g===s||g===o:m?g===2*s||g===2*o:E instanceof c}function S(E,N,m=!0){if(p(E))throw new Error("first arg must be private key");if(!p(N))throw new Error("second arg must be public key");return c.fromHex(N).multiply(u(E)).toRawBytes(m)}let R=t.bits2int||function(E){let N=$t(E),m=E.length*8-t.nBitLength;return m>0?N>>BigInt(m):N},T=t.bits2int_modN||function(E){return i(R(E))},k=ur(t.nBitLength);function I(E){return bt(`num < 2^${t.nBitLength}`,E,Xt,k),ae(E,t.nByteLength)}function U(E,N,m=Y){if(["recovered","canonical"].some(nt=>nt in m))throw new Error("sign() legacy options not supported");let{hash:g,randomBytes:x}=t,{lowS:C,prehash:L,extraEntropy:H}=m;C==null&&(C=!0),E=J("msgHash",E),Ta(m),L&&(E=J("prehashed msgHash",g(E)));let O=T(E),K=u(N),D=[I(K),I(O)];if(H!=null&&H!==!1){let nt=H===!0?x(e.BYTES):H;D.push(J("extraEntropy",nt))}let F=qt(...D),z=O;function rt(nt){let ot=R(nt);if(!f(ot))return;let dt=a(ot),Q=c.BASE.multiply(ot).toAffine(),yt=i(Q.x);if(yt===Xt)return;let Mt=i(dt*i(z+yt*K));if(Mt===Xt)return;let Xe=(Q.x===yt?0:2)|Number(Q.y&st),Qe=Mt;return C&&v(Mt)&&(Qe=w(Mt),Xe^=1),new d(yt,Qe,Xe)}return{seed:F,k2sig:rt}}let Y={lowS:t.lowS,prehash:!1},P={lowS:t.lowS,prehash:!1};function V(E,N,m=Y){let{seed:g,k2sig:x}=U(E,N,m),C=t;return ws(C.hash.outputLen,C.nByteLength,C.hmac)(g,x)}c.BASE._setWindowSize(8);function X(E,N,m,g=P){let x=E;if(N=J("msgHash",N),m=J("publicKey",m),"strict"in g)throw new Error("options.strict was renamed to lowS");Ta(g);let{lowS:C,prehash:L}=g,H,O;try{if(typeof x=="string"||oe(x))try{H=d.fromDER(x)}catch(Q){if(!(Q instanceof Yt.Err))throw Q;H=d.fromCompact(x)}else if(typeof x=="object"&&typeof x.r=="bigint"&&typeof x.s=="bigint"){let{r:Q,s:yt}=x;H=new d(Q,yt)}else throw new Error("PARSE");O=c.fromHex(m)}catch(Q){if(Q.message==="PARSE")throw new Error("signature must be Signature instance, Uint8Array or hex string");return!1}if(C&&H.hasHighS())return!1;L&&(N=t.hash(N));let{r:K,s:D}=H,F=T(N),z=a(D),rt=i(F*z),nt=i(K*z),ot=c.BASE.multiplyAndAddUnsafe(O,rt,nt)?.toAffine();return ot?i(ot.x)===K:!1}return{CURVE:t,getPublicKey:B,getSharedSecret:S,sign:V,verify:X,ProjectivePoint:c,Signature:d,utils:b}}function ef(r){return{hash:r,hmac:(t,...e)=>Nr(r,t,hs(...e)),randomBytes:Ke}}function Ha(r,t){let e=n=>La({...r,...ef(n)});return Object.freeze({...e(t),create:e})}var Oa=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),_a=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),rf=BigInt(1),ho=BigInt(2),Va=(r,t)=>(r+t/ho)/t;function nf(r){let t=Oa,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=G(l,e,t)*l%t,h=G(f,e,t)*l%t,v=G(h,ho,t)*u%t,w=G(v,s,t)*v%t,y=G(w,o,t)*w%t,d=G(y,a,t)*y%t,b=G(d,c,t)*d%t,B=G(b,a,t)*y%t,p=G(B,e,t)*l%t,S=G(p,i,t)*w%t,R=G(S,n,t)*u%t,T=G(R,ho,t);if(!go.eql(go.sqr(T),r))throw new Error("Cannot find square root");return T}var go=ce(Oa,void 0,void 0,{sqrt:nf}),Et=Ha({a:BigInt(0),b:BigInt(7),Fp:go,n:_a,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=_a,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-rf*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),s=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),o=e,i=BigInt("0x100000000000000000000000000000000"),a=Va(o*r,t),c=Va(-n*r,t),u=q(r-a*e-c*s,t),l=q(-a*n-c*o,t),f=u>i,h=l>i;if(f&&(u=t-u),h&&(l=t-l),u>i||l>i)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:f,k1:u,k2neg:h,k2:l}}}},de),O0=BigInt(0);var D0=Et.ProjectivePoint;function Ie(r,t){t==null&&(t=r.reduce((s,o)=>s+o.length,0));let e=Ht(t),n=0;for(let s of r)e.set(s,n),n+=s.length;return e}function po(r,t){let e=et(r,"base64urlpad");if(t!=null){if(e.length>t)throw new Error("byte array longer than desired length");e=Ie([new Uint8Array(t-e.length),e])}return e}function mo(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function Da(r,t){let e=Xr.digest(t instanceof Uint8Array?t:t.subarray());if(mo(e))return e.then(({digest:n})=>Et.sign(n,r).toDERRawBytes()).catch(n=>{throw new tr(String(n))});try{return Et.sign(e.digest,r).toDERRawBytes()}catch(n){throw new tr(String(n))}}function Ma(r,t,e){let n=Xr.digest(e instanceof Uint8Array?e:e.subarray());if(mo(n))return n.then(({digest:s})=>Et.verify(t,s,r)).catch(s=>{throw new er(String(s))});try{return Et.verify(t,n.digest,r)}catch(s){throw new er(String(s))}}var Cr=class{type="secp256k1";raw;_key;constructor(t){this._key=Fa(t),this.raw=Ka(this._key)}toMultihash(){return cr.digest(dr(this))}toCID(){return Tt.createV1(114,this.toMultihash())}toString(){return ut.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:St(this.raw,t.raw)}verify(t,e){return Ma(this._key,e,t)}},Ur=class{type="secp256k1";raw;publicKey;constructor(t,e){this.raw=Pa(t),this.publicKey=new Cr(e??$a(t))}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:St(this.raw,t.raw)}sign(t){return Da(this.raw,t)}};function yo(r){return new Ur(r)}function Xn(r){return new Cr(r)}async function qa(){let r=sf();return new Ur(r)}function Ka(r){return Et.ProjectivePoint.fromHex(r).toRawBytes(!0)}function Pa(r){try{return Et.getPublicKey(r,!0),r}catch(t){throw new rr(String(t))}}function Fa(r){try{return Et.ProjectivePoint.fromHex(r),r}catch(t){throw new Ne(String(t))}}function $a(r){try{return Et.getPublicKey(r,!0)}catch(t){throw new rr(String(t))}}function sf(){return Et.utils.randomPrivateKey()}var Qn={"P-256":32,"P-384":48,"P-521":66},of=Object.keys(Qn),bo=of.join(" / ");async function za(r){if(r!=="P-256"&&r!=="P-384"&&r!=="P-521")throw new $(`Unknown curve: ${r}. Must be ${bo}`);let t=await at.get().subtle.generateKey({name:"ECDH",namedCurve:r},!0,["deriveBits"]),e=async(o,i)=>{let a;i!=null?a=await at.get().subtle.importKey("jwk",cf(r,i),{name:"ECDH",namedCurve:r},!1,["deriveBits"]):a=t.privateKey;let c=await at.get().subtle.importKey("jwk",ja(r,o),{name:"ECDH",namedCurve:r},!1,[]),u=await at.get().subtle.deriveBits({name:"ECDH",public:c},a,Qn[r]*8);return new Uint8Array(u,0,u.byteLength)},n=await at.get().subtle.exportKey("jwk",t.publicKey);return{key:af(n),genSharedKey:e}}function af(r){if(r.crv==null||r.x==null||r.y==null)throw new $("JWK was missing components");if(r.crv!=="P-256"&&r.crv!=="P-384"&&r.crv!=="P-521")throw new $(`Unknown curve: ${r.crv}. Must be ${bo}`);let t=Qn[r.crv];return Ie([Uint8Array.from([4]),po(r.x,t),po(r.y,t)],1+t*2)}function ja(r,t){if(r!=="P-256"&&r!=="P-384"&&r!=="P-521")throw new $(`Unknown curve: ${r}. Must be ${bo}`);let e=Qn[r];if(!St(t.subarray(0,1),Uint8Array.from([4])))throw new $("Cannot unmarshal public key - invalid key format");return{kty:"EC",crv:r,x:mt(t.subarray(1,e+1),"base64url"),y:mt(t.subarray(1+e),"base64url"),ext:!0}}var cf=(r,t)=>({...ja(r,t.public),d:mt(t.private,"base64url")});var lf={"AES-128":{ivSize:16,keySize:16},"AES-256":{ivSize:16,keySize:32},Blowfish:{ivSize:8,keySize:32}};async function Ga(r,t,e){if(r!=="AES-128"&&r!=="AES-256"&&r!=="Blowfish")throw new $("Cipher type was missing or unsupported");if(t!=="SHA1"&&t!=="SHA256"&&t!=="SHA512")throw new $("Hash type was missing or unsupported");if(e==null||!(e instanceof Uint8Array))throw new $("Secret was missing or an incorrect type");let n=lf[r],s=n.keySize,o=n.ivSize,i=20,a=et("key expansion"),c=2*(o+s+i),u=await es(t,e),l=await u.digest(a),f=[],h=0;for(;h<c;){let B=await u.digest(Ie([l,a])),p=B.length;h+p>c&&(p=c-h),f.push(B),h+=p,l=await u.digest(l)}let v=c/2,w=Ie(f),y=w.subarray(0,v),d=w.subarray(v,c),b=B=>({iv:B.subarray(0,o),cipherKey:B.subarray(o,o+s),macKey:B.subarray(o+s)});return{k1:b(y),k2:b(d)}}async function uf(r,t){if(r==="Ed25519")return pi();if(r==="secp256k1")return qa();if(r==="RSA")return fo(t??2048);throw new Qt}async function ff(r,t){if(r!=="Ed25519")throw new Qt("Seed key derivation only supported for Ed25519 keys");return mi(t)}function hf(r){let{Type:t,Data:e}=_t.decode(r),n=e??new Uint8Array;switch(t){case Z.RSA:return Jn(n);case Z.Ed25519:return Wr(n);case Z.secp256k1:return Xn(n);default:throw new Qt}}function df(r){return r.byteLength===32?Wr(r):r.byteLength===33?Xn(r):Jn(r)}function gf(r){let{Type:t,Data:e}=_t.decode(r.digest),n=e??new Uint8Array;switch(t){case Z.Ed25519:return Wr(n);case Z.secp256k1:return Xn(n);default:throw new Qt}}function dr(r){return _t.encode({Type:Z[r.type],Data:r.raw})}function pf(r){let t=yr.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case Z.RSA:return Wn(e);case Z.Ed25519:return Ns(e);case Z.secp256k1:return yo(e);default:throw new Qt}}function mf(r){return r.byteLength===64?Ns(r):r.byteLength===32?yo(r):Wn(r)}function yf(r){return yr.encode({Type:Z[r.type],Data:r.raw})}function bf(r,t,e,n){Vr(r);let s=Jo({dkLen:32,asyncTick:10},n),{c:o,dkLen:i,asyncTick:a}=s;if(He(o),He(i),He(a),o<1)throw new Error("PBKDF2: iterations (c) should be >= 1");let c=ee(t),u=ee(e),l=new Uint8Array(i),f=Nr.create(r,c),h=f._cloneInto().update(u);return{c:o,dkLen:i,asyncTick:a,DK:l,PRF:f,PRFSalt:h}}function xf(r,t,e,n,s){return r.destroy(),t.destroy(),n&&n.destroy(),s.fill(0),e}function Za(r,t,e,n){let{c:s,dkLen:o,DK:i,PRF:a,PRFSalt:c}=bf(r,t,e,n),u,l=new Uint8Array(4),f=De(l),h=new Uint8Array(a.outputLen);for(let v=1,w=0;w<o;v++,w+=a.outputLen){let y=i.subarray(w,w+a.outputLen);f.setInt32(0,v,!1),(u=c._cloneInto(u)).update(l).digestInto(h),y.set(h.subarray(0,y.length));for(let d=1;d<s;d++){a._cloneInto(u).update(h).digestInto(h);for(let b=0;b<y.length;b++)y[b]^=h[b]}}return xf(a,c,i,u,h)}var Tr=new Uint32Array([1732584193,4023233417,2562383102,271733878,3285377520]),me=new Uint32Array(80),wo=class extends re{constructor(){super(64,20,8,!1),this.A=Tr[0]|0,this.B=Tr[1]|0,this.C=Tr[2]|0,this.D=Tr[3]|0,this.E=Tr[4]|0}get(){let{A:t,B:e,C:n,D:s,E:o}=this;return[t,e,n,s,o]}set(t,e,n,s,o){this.A=t|0,this.B=e|0,this.C=n|0,this.D=s|0,this.E=o|0}process(t,e){for(let c=0;c<16;c++,e+=4)me[c]=t.getUint32(e,!1);for(let c=16;c<80;c++)me[c]=Or(me[c-3]^me[c-8]^me[c-14]^me[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=Dr(s,o,i),l=1518500249):c<40?(u=s^o^i,l=1859775393):c<60?(u=Mr(s,o,i),l=2400959708):(u=s^o^i,l=3395469782);let f=Or(n,5)+u+a+l+me[c]|0;a=i,i=o,o=Or(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(){me.fill(0)}destroy(){this.set(0,0,0,0,0),this.buffer.fill(0)}},Wa=Me(()=>new wo);var Ja={sha1:Wa,"sha2-256":de,"sha2-512":Pr};function vo(r,t,e,n,s){if(s!=="sha1"&&s!=="sha2-256"&&s!=="sha2-512"){let a=Object.keys(Ja).join(" / ");throw new $(`Hash '${s}' is unknown or not supported. Must be ${a}`)}let o=Ja[s],i=Za(o,r,t,{c:e,dkLen:n});return Ds.encode(i).substring(1)}return hc(wf);})();
7
7
  /*! Bundled license information:
8
8
 
9
9
  pvtsutils/build/index.js:
@@ -1 +1 @@
1
- {"version":3,"file":"index.browser.d.ts","sourceRoot":"","sources":["../../../../src/keys/ecdh/index.browser.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,YAAY,CAAA;AACvC,OAAO,KAAK,EAAE,OAAO,EAA0D,MAAM,iBAAiB,CAAA;AAWtG,wBAAsB,wBAAwB,CAAE,KAAK,EAAE,KAAK,GAAG,OAAO,CAAC,OAAO,CAAC,CAkE9E"}
1
+ {"version":3,"file":"index.browser.d.ts","sourceRoot":"","sources":["../../../../src/keys/ecdh/index.browser.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,YAAY,CAAA;AACvC,OAAO,KAAK,EAAE,OAAO,EAA0D,MAAM,iBAAiB,CAAA;AAWtG,wBAAsB,wBAAwB,CAAE,KAAK,EAAE,KAAK,GAAG,OAAO,CAAC,OAAO,CAAC,CAgE9E"}
@@ -4,12 +4,12 @@ import { equals as uint8ArrayEquals } from 'uint8arrays/equals';
4
4
  import { toString as uint8ArrayToString } from 'uint8arrays/to-string';
5
5
  import { base64urlToBuffer } from '../../util.js';
6
6
  import webcrypto from '../../webcrypto/index.js';
7
- const bits = {
8
- 'P-256': 256,
9
- 'P-384': 384,
10
- 'P-521': 521
7
+ const curveLengths = {
8
+ 'P-256': 32,
9
+ 'P-384': 48,
10
+ 'P-521': 66
11
11
  };
12
- const curveTypes = Object.keys(bits);
12
+ const curveTypes = Object.keys(curveLengths);
13
13
  const names = curveTypes.join(' / ');
14
14
  export async function generateEphemeralKeyPair(curve) {
15
15
  if (curve !== 'P-256' && curve !== 'P-384' && curve !== 'P-521') {
@@ -37,10 +37,8 @@ export async function generateEphemeralKeyPair(curve) {
37
37
  }, false, []);
38
38
  const buffer = await webcrypto.get().subtle.deriveBits({
39
39
  name: 'ECDH',
40
- // @ts-expect-error namedCurve is missing from the types
41
- namedCurve: curve,
42
40
  public: key
43
- }, privateKey, bits[curve]);
41
+ }, privateKey, curveLengths[curve] * 8);
44
42
  return new Uint8Array(buffer, 0, buffer.byteLength);
45
43
  };
46
44
  const publicKey = await webcrypto.get().subtle.exportKey('jwk', pair.publicKey);
@@ -50,11 +48,6 @@ export async function generateEphemeralKeyPair(curve) {
50
48
  };
51
49
  return ecdhKey;
52
50
  }
53
- const curveLengths = {
54
- 'P-256': 32,
55
- 'P-384': 48,
56
- 'P-521': 66
57
- };
58
51
  // Marshal converts a jwk encoded ECDH public key into the
59
52
  // form specified in section 4.3.6 of ANSI X9.62. (This is the format
60
53
  // go-ipfs uses)
@@ -1 +1 @@
1
- {"version":3,"file":"index.browser.js","sourceRoot":"","sources":["../../../../src/keys/ecdh/index.browser.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"index.browser.js","sourceRoot":"","sources":["../../../../src/keys/ecdh/index.browser.ts"],"names":[],"mappings":"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"}
@@ -1,9 +1,7 @@
1
1
  /**
2
2
  * @packageDocumentation
3
3
  *
4
- * **Supported Key Types**
5
- *
6
- * The {@link generateKeyPair}, {@link marshalPublicKey}, and {@link marshalPrivateKey} functions accept a string `type` argument.
4
+ * ## Supported Key Types
7
5
  *
8
6
  * Currently the `'RSA'`, `'ed25519'`, and `secp256k1` types are supported, although ed25519 and secp256k1 keys support only signing and verification of messages.
9
7
  *
@@ -12,6 +10,8 @@
12
10
  import type { PrivateKey, PublicKey, KeyType, RSAPrivateKey, Secp256k1PrivateKey, Ed25519PrivateKey, Secp256k1PublicKey, Ed25519PublicKey } from '@libp2p/interface';
13
11
  import type { MultihashDigest } from 'multiformats';
14
12
  export { generateEphemeralKeyPair } from './ecdh/index.js';
13
+ export type { Curve } from './ecdh/index.js';
14
+ export type { ECDHKey, EnhancedKey, EnhancedKeyPair, ECDHKeyPair } from './interface.js';
15
15
  export { keyStretcher } from './key-stretcher.js';
16
16
  /**
17
17
  * Generates a keypair of the given type and bitsize
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/keys/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;GAUG;AAOH,OAAO,KAAK,EAAE,UAAU,EAAE,SAAS,EAAE,OAAO,EAAE,aAAa,EAAE,mBAAmB,EAAE,iBAAiB,EAAE,kBAAkB,EAAE,gBAAgB,EAAE,MAAM,mBAAmB,CAAA;AACpK,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,cAAc,CAAA;AAEnD,OAAO,EAAE,wBAAwB,EAAE,MAAM,iBAAiB,CAAA;AAC1D,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAA;AAEjD;;GAEG;AACH,wBAAsB,eAAe,CAAE,IAAI,EAAE,SAAS,GAAG,OAAO,CAAC,iBAAiB,CAAC,CAAA;AACnF,wBAAsB,eAAe,CAAE,IAAI,EAAE,WAAW,GAAG,OAAO,CAAC,mBAAmB,CAAC,CAAA;AACvF,wBAAsB,eAAe,CAAE,IAAI,EAAE,KAAK,EAAE,IAAI,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,aAAa,CAAC,CAAA;AAC1F,wBAAsB,eAAe,CAAE,IAAI,EAAE,OAAO,EAAE,IAAI,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,UAAU,CAAC,CAAA;AAiBzF;;;;;GAKG;AACH,wBAAsB,uBAAuB,CAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,UAAU,GAAG,OAAO,CAAC,iBAAiB,CAAC,CAAA;AAC7G,wBAAsB,uBAAuB,CAAE,CAAC,SAAS,OAAO,EAAG,IAAI,EAAE,CAAC,EAAE,IAAI,EAAE,UAAU,EAAE,IAAI,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,KAAK,CAAC,CAAA;AAS5H;;GAEG;AACH,wBAAgB,qBAAqB,CAAE,GAAG,EAAE,UAAU,GAAG,SAAS,CAcjE;AAED;;GAEG;AACH,wBAAgB,gBAAgB,CAAE,GAAG,EAAE,UAAU,GAAG,SAAS,CAQ5D;AAED;;;;;;GAMG;AACH,wBAAgB,sBAAsB,CAAE,MAAM,EAAE,eAAe,CAAC,GAAG,CAAC,GAAG,gBAAgB,GAAG,kBAAkB,CAY3G;AAED;;GAEG;AACH,wBAAgB,mBAAmB,CAAE,GAAG,EAAE,SAAS,GAAG,UAAU,CAK/D;AAED;;GAEG;AACH,wBAAgB,sBAAsB,CAAE,GAAG,EAAE,UAAU,GAAG,iBAAiB,GAAG,mBAAmB,GAAG,aAAa,CAchH;AAED;;;;GAIG;AACH,wBAAgB,iBAAiB,CAAE,GAAG,EAAE,UAAU,GAAG,UAAU,CAQ9D;AAED;;GAEG;AACH,wBAAgB,oBAAoB,CAAE,GAAG,EAAE,UAAU,GAAG,UAAU,CAKjE"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/keys/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAOH,OAAO,KAAK,EAAE,UAAU,EAAE,SAAS,EAAE,OAAO,EAAE,aAAa,EAAE,mBAAmB,EAAE,iBAAiB,EAAE,kBAAkB,EAAE,gBAAgB,EAAE,MAAM,mBAAmB,CAAA;AACpK,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,cAAc,CAAA;AAEnD,OAAO,EAAE,wBAAwB,EAAE,MAAM,iBAAiB,CAAA;AAC1D,YAAY,EAAE,KAAK,EAAE,MAAM,iBAAiB,CAAA;AAC5C,YAAY,EAAE,OAAO,EAAE,WAAW,EAAE,eAAe,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAA;AACxF,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAA;AAEjD;;GAEG;AACH,wBAAsB,eAAe,CAAE,IAAI,EAAE,SAAS,GAAG,OAAO,CAAC,iBAAiB,CAAC,CAAA;AACnF,wBAAsB,eAAe,CAAE,IAAI,EAAE,WAAW,GAAG,OAAO,CAAC,mBAAmB,CAAC,CAAA;AACvF,wBAAsB,eAAe,CAAE,IAAI,EAAE,KAAK,EAAE,IAAI,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,aAAa,CAAC,CAAA;AAC1F,wBAAsB,eAAe,CAAE,IAAI,EAAE,OAAO,EAAE,IAAI,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,UAAU,CAAC,CAAA;AAiBzF;;;;;GAKG;AACH,wBAAsB,uBAAuB,CAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,UAAU,GAAG,OAAO,CAAC,iBAAiB,CAAC,CAAA;AAC7G,wBAAsB,uBAAuB,CAAE,CAAC,SAAS,OAAO,EAAG,IAAI,EAAE,CAAC,EAAE,IAAI,EAAE,UAAU,EAAE,IAAI,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,KAAK,CAAC,CAAA;AAS5H;;GAEG;AACH,wBAAgB,qBAAqB,CAAE,GAAG,EAAE,UAAU,GAAG,SAAS,CAcjE;AAED;;GAEG;AACH,wBAAgB,gBAAgB,CAAE,GAAG,EAAE,UAAU,GAAG,SAAS,CAQ5D;AAED;;;;;;GAMG;AACH,wBAAgB,sBAAsB,CAAE,MAAM,EAAE,eAAe,CAAC,GAAG,CAAC,GAAG,gBAAgB,GAAG,kBAAkB,CAY3G;AAED;;GAEG;AACH,wBAAgB,mBAAmB,CAAE,GAAG,EAAE,SAAS,GAAG,UAAU,CAK/D;AAED;;GAEG;AACH,wBAAgB,sBAAsB,CAAE,GAAG,EAAE,UAAU,GAAG,iBAAiB,GAAG,mBAAmB,GAAG,aAAa,CAchH;AAED;;;;GAIG;AACH,wBAAgB,iBAAiB,CAAE,GAAG,EAAE,UAAU,GAAG,UAAU,CAQ9D;AAED;;GAEG;AACH,wBAAgB,oBAAoB,CAAE,GAAG,EAAE,UAAU,GAAG,UAAU,CAKjE"}
@@ -1,9 +1,7 @@
1
1
  /**
2
2
  * @packageDocumentation
3
3
  *
4
- * **Supported Key Types**
5
- *
6
- * The {@link generateKeyPair}, {@link marshalPublicKey}, and {@link marshalPrivateKey} functions accept a string `type` argument.
4
+ * ## Supported Key Types
7
5
  *
8
6
  * Currently the `'RSA'`, `'ed25519'`, and `secp256k1` types are supported, although ed25519 and secp256k1 keys support only signing and verification of messages.
9
7
  *
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/keys/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;GAUG;AAEH,OAAO,EAAE,uBAAuB,EAAE,MAAM,mBAAmB,CAAA;AAC3D,OAAO,EAAE,sBAAsB,EAAE,8BAA8B,EAAE,0BAA0B,EAAE,yBAAyB,EAAE,MAAM,oBAAoB,CAAA;AAClJ,OAAO,KAAK,EAAE,MAAM,WAAW,CAAA;AAC/B,OAAO,EAAE,oBAAoB,EAAE,kBAAkB,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAA;AAC7F,OAAO,EAAE,wBAAwB,EAAE,4BAA4B,EAAE,2BAA2B,EAAE,MAAM,sBAAsB,CAAA;AAI1H,OAAO,EAAE,wBAAwB,EAAE,MAAM,iBAAiB,CAAA;AAC1D,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAA;AASjD,MAAM,CAAC,KAAK,UAAU,eAAe,CAAE,IAAa,EAAE,IAAa;IACjE,IAAI,IAAI,KAAK,SAAS,EAAE,CAAC;QACvB,OAAO,sBAAsB,EAAE,CAAA;IACjC,CAAC;IAED,IAAI,IAAI,KAAK,WAAW,EAAE,CAAC;QACzB,OAAO,wBAAwB,EAAE,CAAA;IACnC,CAAC;IAED,IAAI,IAAI,KAAK,KAAK,EAAE,CAAC;QACnB,OAAO,kBAAkB,CAAC,IAAI,IAAI,IAAI,CAAC,CAAA;IACzC,CAAC;IAED,MAAM,IAAI,uBAAuB,EAAE,CAAA;AACrC,CAAC;AAUD,MAAM,CAAC,KAAK,UAAU,uBAAuB,CAAE,IAAY,EAAE,IAAgB;IAC3E,IAAI,IAAI,KAAK,SAAS,EAAE,CAAC;QACvB,MAAM,IAAI,uBAAuB,CAAC,qDAAqD,CAAC,CAAA;IAC1F,CAAC;IAED,OAAO,8BAA8B,CAAC,IAAI,CAAC,CAAA;AAC7C,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,qBAAqB,CAAE,GAAe;IACpD,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,EAAE,CAAC,SAAS,CAAC,MAAM,CAAC,GAAG,CAAC,CAAA;IAC/C,MAAM,IAAI,GAAG,IAAI,IAAI,IAAI,UAAU,EAAE,CAAA;IAErC,QAAQ,IAAI,EAAE,CAAC;QACb,KAAK,EAAE,CAAC,OAAO,CAAC,GAAG;YACjB,OAAO,kBAAkB,CAAC,IAAI,CAAC,CAAA;QACjC,KAAK,EAAE,CAAC,OAAO,CAAC,OAAO;YACrB,OAAO,yBAAyB,CAAC,IAAI,CAAC,CAAA;QACxC,KAAK,EAAE,CAAC,OAAO,CAAC,SAAS;YACvB,OAAO,2BAA2B,CAAC,IAAI,CAAC,CAAA;QAC1C;YACE,MAAM,IAAI,uBAAuB,EAAE,CAAA;IACvC,CAAC;AACH,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,gBAAgB,CAAE,GAAe;IAC/C,IAAI,GAAG,CAAC,UAAU,KAAK,EAAE,EAAE,CAAC;QAC1B,OAAO,yBAAyB,CAAC,GAAG,CAAC,CAAA;IACvC,CAAC;SAAM,IAAI,GAAG,CAAC,UAAU,KAAK,EAAE,EAAE,CAAC;QACjC,OAAO,2BAA2B,CAAC,GAAG,CAAC,CAAA;IACzC,CAAC;SAAM,CAAC;QACN,OAAO,kBAAkB,CAAC,GAAG,CAAC,CAAA;IAChC,CAAC;AACH,CAAC;AAED;;;;;;GAMG;AACH,MAAM,UAAU,sBAAsB,CAAE,MAA4B;IAClE,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,EAAE,CAAC,SAAS,CAAC,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAA;IACzD,MAAM,IAAI,GAAG,IAAI,IAAI,IAAI,UAAU,EAAE,CAAA;IAErC,QAAQ,IAAI,EAAE,CAAC;QACb,KAAK,EAAE,CAAC,OAAO,CAAC,OAAO;YACrB,OAAO,yBAAyB,CAAC,IAAI,CAAC,CAAA;QACxC,KAAK,EAAE,CAAC,OAAO,CAAC,SAAS;YACvB,OAAO,2BAA2B,CAAC,IAAI,CAAC,CAAA;QAC1C;YACE,MAAM,IAAI,uBAAuB,EAAE,CAAA;IACvC,CAAC;AACH,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,mBAAmB,CAAE,GAAc;IACjD,OAAO,EAAE,CAAC,SAAS,CAAC,MAAM,CAAC;QACzB,IAAI,EAAE,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC;QAC1B,IAAI,EAAE,GAAG,CAAC,GAAG;KACd,CAAC,CAAA;AACJ,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,sBAAsB,CAAE,GAAe;IACrD,MAAM,OAAO,GAAG,EAAE,CAAC,UAAU,CAAC,MAAM,CAAC,GAAG,CAAC,CAAA;IACzC,MAAM,IAAI,GAAG,OAAO,CAAC,IAAI,IAAI,IAAI,UAAU,EAAE,CAAA;IAE7C,QAAQ,OAAO,CAAC,IAAI,EAAE,CAAC;QACrB,KAAK,EAAE,CAAC,OAAO,CAAC,GAAG;YACjB,OAAO,oBAAoB,CAAC,IAAI,CAAC,CAAA;QACnC,KAAK,EAAE,CAAC,OAAO,CAAC,OAAO;YACrB,OAAO,0BAA0B,CAAC,IAAI,CAAC,CAAA;QACzC,KAAK,EAAE,CAAC,OAAO,CAAC,SAAS;YACvB,OAAO,4BAA4B,CAAC,IAAI,CAAC,CAAA;QAC3C;YACE,MAAM,IAAI,uBAAuB,EAAE,CAAA;IACvC,CAAC;AACH,CAAC;AAED;;;;GAIG;AACH,MAAM,UAAU,iBAAiB,CAAE,GAAe;IAChD,IAAI,GAAG,CAAC,UAAU,KAAK,EAAE,EAAE,CAAC;QAC1B,OAAO,0BAA0B,CAAC,GAAG,CAAC,CAAA;IACxC,CAAC;SAAM,IAAI,GAAG,CAAC,UAAU,KAAK,EAAE,EAAE,CAAC;QACjC,OAAO,4BAA4B,CAAC,GAAG,CAAC,CAAA;IAC1C,CAAC;SAAM,CAAC;QACN,OAAO,oBAAoB,CAAC,GAAG,CAAC,CAAA;IAClC,CAAC;AACH,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,oBAAoB,CAAE,GAAe;IACnD,OAAO,EAAE,CAAC,UAAU,CAAC,MAAM,CAAC;QAC1B,IAAI,EAAE,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC;QAC1B,IAAI,EAAE,GAAG,CAAC,GAAG;KACd,CAAC,CAAA;AACJ,CAAC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/keys/index.ts"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@libp2p/crypto",
3
- "version": "5.0.1",
3
+ "version": "5.0.2-7f7ec82ae",
4
4
  "description": "Crypto primitives for libp2p",
5
5
  "license": "Apache-2.0 OR MIT",
6
6
  "homepage": "https://github.com/libp2p/js-libp2p/tree/main/packages/crypto#readme",
@@ -92,7 +92,7 @@
92
92
  "generate": "protons ./src/keys/keys.proto"
93
93
  },
94
94
  "dependencies": {
95
- "@libp2p/interface": "^2.0.1",
95
+ "@libp2p/interface": "2.1.0-7f7ec82ae",
96
96
  "@noble/curves": "^1.4.0",
97
97
  "@noble/hashes": "^1.4.0",
98
98
  "asn1js": "^3.0.5",
@@ -7,13 +7,13 @@ import webcrypto from '../../webcrypto/index.js'
7
7
  import type { Curve } from './index.js'
8
8
  import type { ECDHKey, ECDHKeyPair, JWKEncodedPrivateKey, JWKEncodedPublicKey } from '../interface.js'
9
9
 
10
- const bits = {
11
- 'P-256': 256,
12
- 'P-384': 384,
13
- 'P-521': 521
10
+ const curveLengths = {
11
+ 'P-256': 32,
12
+ 'P-384': 48,
13
+ 'P-521': 66
14
14
  }
15
15
 
16
- const curveTypes = Object.keys(bits)
16
+ const curveTypes = Object.keys(curveLengths)
17
17
  const names = curveTypes.join(' / ')
18
18
 
19
19
  export async function generateEphemeralKeyPair (curve: Curve): Promise<ECDHKey> {
@@ -63,12 +63,10 @@ export async function generateEphemeralKeyPair (curve: Curve): Promise<ECDHKey>
63
63
  const buffer = await webcrypto.get().subtle.deriveBits(
64
64
  {
65
65
  name: 'ECDH',
66
- // @ts-expect-error namedCurve is missing from the types
67
- namedCurve: curve,
68
66
  public: key
69
67
  },
70
68
  privateKey,
71
- bits[curve]
69
+ curveLengths[curve] * 8
72
70
  )
73
71
 
74
72
  return new Uint8Array(buffer, 0, buffer.byteLength)
@@ -84,12 +82,6 @@ export async function generateEphemeralKeyPair (curve: Curve): Promise<ECDHKey>
84
82
  return ecdhKey
85
83
  }
86
84
 
87
- const curveLengths = {
88
- 'P-256': 32,
89
- 'P-384': 48,
90
- 'P-521': 66
91
- }
92
-
93
85
  // Marshal converts a jwk encoded ECDH public key into the
94
86
  // form specified in section 4.3.6 of ANSI X9.62. (This is the format
95
87
  // go-ipfs uses)
package/src/keys/index.ts CHANGED
@@ -1,9 +1,7 @@
1
1
  /**
2
2
  * @packageDocumentation
3
3
  *
4
- * **Supported Key Types**
5
- *
6
- * The {@link generateKeyPair}, {@link marshalPublicKey}, and {@link marshalPrivateKey} functions accept a string `type` argument.
4
+ * ## Supported Key Types
7
5
  *
8
6
  * Currently the `'RSA'`, `'ed25519'`, and `secp256k1` types are supported, although ed25519 and secp256k1 keys support only signing and verification of messages.
9
7
  *
@@ -19,6 +17,8 @@ import type { PrivateKey, PublicKey, KeyType, RSAPrivateKey, Secp256k1PrivateKey
19
17
  import type { MultihashDigest } from 'multiformats'
20
18
 
21
19
  export { generateEphemeralKeyPair } from './ecdh/index.js'
20
+ export type { Curve } from './ecdh/index.js'
21
+ export type { ECDHKey, EnhancedKey, EnhancedKeyPair, ECDHKeyPair } from './interface.js'
22
22
  export { keyStretcher } from './key-stretcher.js'
23
23
 
24
24
  /**
@@ -1,28 +0,0 @@
1
- {
2
- "HMAC": "https://libp2p.github.io/js-libp2p/interfaces/_libp2p_crypto.hmac.HMAC.html",
3
- "./hmac:HMAC": "https://libp2p.github.io/js-libp2p/interfaces/_libp2p_crypto.hmac.HMAC.html",
4
- "create": "https://libp2p.github.io/js-libp2p/functions/_libp2p_crypto.hmac.create.html",
5
- "./hmac:create": "https://libp2p.github.io/js-libp2p/functions/_libp2p_crypto.hmac.create.html",
6
- "pbkdf2": "https://libp2p.github.io/js-libp2p/functions/_libp2p_crypto.index.pbkdf2.html",
7
- "randomBytes": "https://libp2p.github.io/js-libp2p/functions/_libp2p_crypto.index.randomBytes.html",
8
- "generateEphemeralKeyPair": "https://libp2p.github.io/js-libp2p/functions/_libp2p_crypto.keys.generateEphemeralKeyPair.html",
9
- "generateKeyPair": "https://libp2p.github.io/js-libp2p/functions/_libp2p_crypto.keys.generateKeyPair.html",
10
- "./keys:generateKeyPair": "https://libp2p.github.io/js-libp2p/functions/_libp2p_crypto.keys.generateKeyPair.html",
11
- "generateKeyPairFromSeed": "https://libp2p.github.io/js-libp2p/functions/_libp2p_crypto.keys.generateKeyPairFromSeed.html",
12
- "./keys:generateKeyPairFromSeed": "https://libp2p.github.io/js-libp2p/functions/_libp2p_crypto.keys.generateKeyPairFromSeed.html",
13
- "keyStretcher": "https://libp2p.github.io/js-libp2p/functions/_libp2p_crypto.keys.keyStretcher.html",
14
- "privateKeyFromProtobuf": "https://libp2p.github.io/js-libp2p/functions/_libp2p_crypto.keys.privateKeyFromProtobuf.html",
15
- "./keys:privateKeyFromProtobuf": "https://libp2p.github.io/js-libp2p/functions/_libp2p_crypto.keys.privateKeyFromProtobuf.html",
16
- "privateKeyFromRaw": "https://libp2p.github.io/js-libp2p/functions/_libp2p_crypto.keys.privateKeyFromRaw.html",
17
- "./keys:privateKeyFromRaw": "https://libp2p.github.io/js-libp2p/functions/_libp2p_crypto.keys.privateKeyFromRaw.html",
18
- "privateKeyToProtobuf": "https://libp2p.github.io/js-libp2p/functions/_libp2p_crypto.keys.privateKeyToProtobuf.html",
19
- "./keys:privateKeyToProtobuf": "https://libp2p.github.io/js-libp2p/functions/_libp2p_crypto.keys.privateKeyToProtobuf.html",
20
- "publicKeyFromMultihash": "https://libp2p.github.io/js-libp2p/functions/_libp2p_crypto.keys.publicKeyFromMultihash.html",
21
- "./keys:publicKeyFromMultihash": "https://libp2p.github.io/js-libp2p/functions/_libp2p_crypto.keys.publicKeyFromMultihash.html",
22
- "publicKeyFromProtobuf": "https://libp2p.github.io/js-libp2p/functions/_libp2p_crypto.keys.publicKeyFromProtobuf.html",
23
- "./keys:publicKeyFromProtobuf": "https://libp2p.github.io/js-libp2p/functions/_libp2p_crypto.keys.publicKeyFromProtobuf.html",
24
- "publicKeyFromRaw": "https://libp2p.github.io/js-libp2p/functions/_libp2p_crypto.keys.publicKeyFromRaw.html",
25
- "./keys:publicKeyFromRaw": "https://libp2p.github.io/js-libp2p/functions/_libp2p_crypto.keys.publicKeyFromRaw.html",
26
- "publicKeyToProtobuf": "https://libp2p.github.io/js-libp2p/functions/_libp2p_crypto.keys.publicKeyToProtobuf.html",
27
- "./keys:publicKeyToProtobuf": "https://libp2p.github.io/js-libp2p/functions/_libp2p_crypto.keys.publicKeyToProtobuf.html"
28
- }