@libp2p/plaintext 1.1.6-737b3ea5b → 1.1.6-81ebe4e47
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 +4 -5
- package/dist/src/index.d.ts +3 -9
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/index.js +32 -55
- package/dist/src/index.js.map +1 -1
- package/dist/src/pb/proto.d.ts +4 -4
- package/dist/src/pb/proto.d.ts.map +1 -1
- package/dist/src/pb/proto.js +26 -17
- package/dist/src/pb/proto.js.map +1 -1
- package/package.json +10 -9
- package/src/index.ts +34 -63
- package/src/pb/proto.proto +1 -1
- package/src/pb/proto.ts +26 -18
package/dist/index.min.js
CHANGED
|
@@ -1,10 +1,9 @@
|
|
|
1
1
|
(function (root, factory) {(typeof module === 'object' && module.exports) ? module.exports = factory() : root.Libp2PPlaintext = factory()}(typeof self !== 'undefined' ? self : this, function () {
|
|
2
|
-
"use strict";var Libp2PPlaintext=(()=>{var Ac=Object.create;var jr=Object.defineProperty;var kc=Object.getOwnPropertyDescriptor;var Sc=Object.getOwnPropertyNames;var Ic=Object.getPrototypeOf,Rc=Object.prototype.hasOwnProperty;var Nc=(r,e)=>()=>(e||r((e={exports:{}}).exports,e),e.exports),ie=(r,e)=>{for(var t in e)jr(r,t,{get:e[t],enumerable:!0})},Zo=(r,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of Sc(e))!Rc.call(r,s)&&s!==t&&jr(r,s,{get:()=>e[s],enumerable:!(n=kc(e,s))||n.enumerable});return r};var Tc=(r,e,t)=>(t=r!=null?Ac(Ic(r)):{},Zo(e||!r||!r.__esModule?jr(t,"default",{value:r,enumerable:!0}):t,r)),Lc=r=>Zo(jr({},"__esModule",{value:!0}),r);var Ji=Nc(ir=>{"use strict";var uf="[object ArrayBuffer]",Xe=class r{static isArrayBuffer(e){return Object.prototype.toString.call(e)===uf}static toArrayBuffer(e){return this.isArrayBuffer(e)?e:e.byteLength===e.buffer.byteLength||e.byteOffset===0&&e.byteLength===e.buffer.byteLength?e.buffer:this.toUint8Array(e.buffer).slice(e.byteOffset,e.byteOffset+e.byteLength).buffer}static toUint8Array(e){return this.toView(e,Uint8Array)}static toView(e,t){if(e.constructor===t)return e;if(this.isArrayBuffer(e))return new t(e);if(this.isArrayBufferView(e))return new t(e.buffer,e.byteOffset,e.byteLength);throw new TypeError("The provided value is not of type '(ArrayBuffer or ArrayBufferView)'")}static isBufferSource(e){return this.isArrayBufferView(e)||this.isArrayBuffer(e)}static isArrayBufferView(e){return ArrayBuffer.isView(e)||e&&this.isArrayBuffer(e.buffer)}static isEqual(e,t){let n=r.toUint8Array(e),s=r.toUint8Array(t);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(...e){let t;Array.isArray(e[0])&&!(e[1]instanceof Function)||Array.isArray(e[0])&&e[1]instanceof Function?t=e[0]:e[e.length-1]instanceof Function?t=e.slice(0,e.length-1):t=e;let n=0;for(let i of t)n+=i.byteLength;let s=new Uint8Array(n),o=0;for(let i of t){let a=this.toUint8Array(i);s.set(a,o),o+=a.length}return e[e.length-1]instanceof Function?this.toView(s,e[e.length-1]):s.buffer}},wo="string",ff=/^[0-9a-f]+$/i,hf=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,df=/^[a-zA-Z0-9-_]+$/,hn=class{static fromString(e){let t=unescape(encodeURIComponent(e)),n=new Uint8Array(t.length);for(let s=0;s<t.length;s++)n[s]=t.charCodeAt(s);return n.buffer}static toString(e){let t=Xe.toUint8Array(e),n="";for(let o=0;o<t.length;o++)n+=String.fromCharCode(t[o]);return decodeURIComponent(escape(n))}},Ne=class{static toString(e,t=!1){let n=Xe.toArrayBuffer(e),s=new DataView(n),o="";for(let i=0;i<n.byteLength;i+=2){let a=s.getUint16(i,t);o+=String.fromCharCode(a)}return o}static fromString(e,t=!1){let n=new ArrayBuffer(e.length*2),s=new DataView(n);for(let o=0;o<e.length;o++)s.setUint16(o*2,e.charCodeAt(o),t);return n}},dn=class r{static isHex(e){return typeof e===wo&&ff.test(e)}static isBase64(e){return typeof e===wo&&hf.test(e)}static isBase64Url(e){return typeof e===wo&&df.test(e)}static ToString(e,t="utf8"){let n=Xe.toUint8Array(e);switch(t.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 Ne.toString(n,!0);case"utf16":case"utf16be":return Ne.toString(n);default:throw new Error(`Unknown type of encoding '${t}'`)}}static FromString(e,t="utf8"){if(!e)return new ArrayBuffer(0);switch(t.toLowerCase()){case"utf8":return this.FromUtf8String(e);case"binary":return this.FromBinary(e);case"hex":return this.FromHex(e);case"base64":return this.FromBase64(e);case"base64url":return this.FromBase64Url(e);case"utf16le":return Ne.fromString(e,!0);case"utf16":case"utf16be":return Ne.fromString(e);default:throw new Error(`Unknown type of encoding '${t}'`)}}static ToBase64(e){let t=Xe.toUint8Array(e);if(typeof btoa<"u"){let n=this.ToString(t,"binary");return btoa(n)}else return Buffer.from(t).toString("base64")}static FromBase64(e){let t=this.formatString(e);if(!t)return new ArrayBuffer(0);if(!r.isBase64(t))throw new TypeError("Argument 'base64Text' is not Base64 encoded");return typeof atob<"u"?this.FromBinary(atob(t)):new Uint8Array(Buffer.from(t,"base64")).buffer}static FromBase64Url(e){let t=this.formatString(e);if(!t)return new ArrayBuffer(0);if(!r.isBase64Url(t))throw new TypeError("Argument 'base64url' is not Base64Url encoded");return this.FromBase64(this.Base64Padding(t.replace(/\-/g,"+").replace(/\_/g,"/")))}static ToBase64Url(e){return this.ToBase64(e).replace(/\+/g,"-").replace(/\//g,"_").replace(/\=/g,"")}static FromUtf8String(e,t=r.DEFAULT_UTF8_ENCODING){switch(t){case"ascii":return this.FromBinary(e);case"utf8":return hn.fromString(e);case"utf16":case"utf16be":return Ne.fromString(e);case"utf16le":case"usc2":return Ne.fromString(e,!0);default:throw new Error(`Unknown type of encoding '${t}'`)}}static ToUtf8String(e,t=r.DEFAULT_UTF8_ENCODING){switch(t){case"ascii":return this.ToBinary(e);case"utf8":return hn.toString(e);case"utf16":case"utf16be":return Ne.toString(e);case"utf16le":case"usc2":return Ne.toString(e,!0);default:throw new Error(`Unknown type of encoding '${t}'`)}}static FromBinary(e){let t=e.length,n=new Uint8Array(t);for(let s=0;s<t;s++)n[s]=e.charCodeAt(s);return n.buffer}static ToBinary(e){let t=Xe.toUint8Array(e),n="";for(let s=0;s<t.length;s++)n+=String.fromCharCode(t[s]);return n}static ToHex(e){let t=Xe.toUint8Array(e),n="",s=t.length;for(let o=0;o<s;o++){let i=t[o];i<16&&(n+="0"),n+=i.toString(16)}return n}static FromHex(e){let t=this.formatString(e);if(!t)return new ArrayBuffer(0);if(!r.isHex(t))throw new TypeError("Argument 'hexString' is not HEX encoded");t.length%2&&(t=`0${t}`);let n=new Uint8Array(t.length/2);for(let s=0;s<t.length;s=s+2){let o=t.slice(s,s+2);n[s/2]=parseInt(o,16)}return n.buffer}static ToUtf16String(e,t=!1){return Ne.toString(e,t)}static FromUtf16String(e,t=!1){return Ne.fromString(e,t)}static Base64Padding(e){let t=4-e.length%4;if(t<4)for(let n=0;n<t;n++)e+="=";return e}static formatString(e){return e?.replace(/[\n\r\t ]/g,"")||""}};dn.DEFAULT_UTF8_ENCODING="utf8";function pf(r,...e){let t=arguments[0];for(let n=1;n<arguments.length;n++){let s=arguments[n];for(let o in s)t[o]=s[o]}return t}function gf(...r){let e=r.map(s=>s.byteLength).reduce((s,o)=>s+o),t=new Uint8Array(e),n=0;return r.map(s=>new Uint8Array(s)).forEach(s=>{for(let o of s)t[n++]=o}),t.buffer}function yf(r,e){if(!(r&&e)||r.byteLength!==e.byteLength)return!1;let t=new Uint8Array(r),n=new Uint8Array(e);for(let s=0;s<r.byteLength;s++)if(t[s]!==n[s])return!1;return!0}ir.BufferSourceConverter=Xe;ir.Convert=dn;ir.assign=pf;ir.combine=gf;ir.isEqual=yf});var th={};ie(th,{plaintext:()=>eh});var fs=Symbol.for("@libp2p/peer-id");var D=class extends Error{code;props;constructor(e,t,n){super(e),this.code=t,this.name=n?.name??"CodeError",this.props=n??{}}};var zr=class r extends Error{code;constructor(e="Unexpected Peer"){super(e),this.name="UnexpectedPeerError",this.code=r.code}static code="ERR_UNEXPECTED_PEER"},Zr=class r extends Error{code;constructor(e="Invalid crypto exchange"){super(e),this.name="InvalidCryptoExchangeError",this.code=r.code}static code="ERR_INVALID_CRYPTO_EXCHANGE"};var Wo=Symbol.for("@libp2p/service-capabilities"),oh=Symbol.for("@libp2p/service-dependencies");var mo={};ie(mo,{Ed25519PrivateKey:()=>Dt,Ed25519PublicKey:()=>Tr,generateKeyPair:()=>af,generateKeyPairFromSeed:()=>Yi,unmarshalEd25519PrivateKey:()=>sf,unmarshalEd25519PublicKey:()=>of});var ys={};ie(ys,{base58btc:()=>me,base58flickr:()=>Oc});var Nh=new Uint8Array(0);function Yo(r,e){if(r===e)return!0;if(r.byteLength!==e.byteLength)return!1;for(let t=0;t<r.byteLength;t++)if(r[t]!==e[t])return!1;return!0}function qe(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 Jo(r){return new TextEncoder().encode(r)}function Xo(r){return new TextDecoder().decode(r)}function Cc(r,e){if(r.length>=255)throw new TypeError("Alphabet too long");for(var t=new Uint8Array(256),n=0;n<t.length;n++)t[n]=255;for(var s=0;s<r.length;s++){var o=r.charAt(s),i=o.charCodeAt(0);if(t[i]!==255)throw new TypeError(o+" is ambiguous");t[i]=s}var a=r.length,c=r.charAt(0),f=Math.log(a)/Math.log(256),l=Math.log(256)/Math.log(a);function u(x){if(x instanceof Uint8Array||(ArrayBuffer.isView(x)?x=new Uint8Array(x.buffer,x.byteOffset,x.byteLength):Array.isArray(x)&&(x=Uint8Array.from(x))),!(x instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(x.length===0)return"";for(var y=0,d=0,b=0,B=x.length;b!==B&&x[b]===0;)b++,y++;for(var g=(B-b)*l+1>>>0,E=new Uint8Array(g);b!==B;){for(var C=x[b],L=0,S=g-1;(C!==0||L<d)&&S!==-1;S--,L++)C+=256*E[S]>>>0,E[S]=C%a>>>0,C=C/a>>>0;if(C!==0)throw new Error("Non-zero carry");d=L,b++}for(var I=g-d;I!==g&&E[I]===0;)I++;for(var T=c.repeat(y);I<g;++I)T+=r.charAt(E[I]);return T}function h(x){if(typeof x!="string")throw new TypeError("Expected String");if(x.length===0)return new Uint8Array;var y=0;if(x[y]!==" "){for(var d=0,b=0;x[y]===c;)d++,y++;for(var B=(x.length-y)*f+1>>>0,g=new Uint8Array(B);x[y];){var E=t[x.charCodeAt(y)];if(E===255)return;for(var C=0,L=B-1;(E!==0||C<b)&&L!==-1;L--,C++)E+=a*g[L]>>>0,g[L]=E%256>>>0,E=E/256>>>0;if(E!==0)throw new Error("Non-zero carry");b=C,y++}if(x[y]!==" "){for(var S=B-b;S!==B&&g[S]===0;)S++;for(var I=new Uint8Array(d+(B-S)),T=d;S!==B;)I[T++]=g[S++];return I}}}function w(x){var y=h(x);if(y)return y;throw new Error(`Non-${e} character`)}return{encode:u,decodeUnsafe:h,decode:w}}var _c=Cc,Uc=_c,ei=Uc;var hs=class{name;prefix;baseEncode;constructor(e,t,n){this.name=e,this.prefix=t,this.baseEncode=n}encode(e){if(e instanceof Uint8Array)return`${this.prefix}${this.baseEncode(e)}`;throw Error("Unknown type, must be binary type")}},ds=class{name;prefix;baseDecode;prefixCodePoint;constructor(e,t,n){if(this.name=e,this.prefix=t,t.codePointAt(0)===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=t.codePointAt(0),this.baseDecode=n}decode(e){if(typeof e=="string"){if(e.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(e)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(e.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(e){return ti(this,e)}},ps=class{decoders;constructor(e){this.decoders=e}or(e){return ti(this,e)}decode(e){let t=e[0],n=this.decoders[t];if(n!=null)return n.decode(e);throw RangeError(`Unable to decode multibase string ${JSON.stringify(e)}, only inputs prefixed with ${Object.keys(this.decoders)} are supported`)}};function ti(r,e){return new ps({...r.decoders??{[r.prefix]:r},...e.decoders??{[e.prefix]:e}})}var gs=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(e,t,n,s){this.name=e,this.prefix=t,this.baseEncode=n,this.baseDecode=s,this.encoder=new hs(e,t,n),this.decoder=new ds(e,t,s)}encode(e){return this.encoder.encode(e)}decode(e){return this.decoder.decode(e)}};function Pt({name:r,prefix:e,encode:t,decode:n}){return new gs(r,e,t,n)}function at({name:r,prefix:e,alphabet:t}){let{encode:n,decode:s}=ei(t,r);return Pt({prefix:e,name:r,encode:n,decode:o=>qe(s(o))})}function Vc(r,e,t,n){let s={};for(let l=0;l<e.length;++l)s[e[l]]=l;let o=r.length;for(;r[o-1]==="=";)--o;let i=new Uint8Array(o*t/8|0),a=0,c=0,f=0;for(let l=0;l<o;++l){let u=s[r[l]];if(u===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<t|u,a+=t,a>=8&&(a-=8,i[f++]=255&c>>a)}if(a>=t||255&c<<8-a)throw new SyntaxError("Unexpected end of data");return i}function Dc(r,e,t){let n=e[e.length-1]==="=",s=(1<<t)-1,o="",i=0,a=0;for(let c=0;c<r.length;++c)for(a=a<<8|r[c],i+=8;i>t;)i-=t,o+=e[s&a>>i];if(i!==0&&(o+=e[s&a<<t-i]),n)for(;o.length*t&7;)o+="=";return o}function Y({name:r,prefix:e,bitsPerChar:t,alphabet:n}){return Pt({prefix:e,name:r,encode(s){return Dc(s,n,t)},decode(s){return Vc(s,n,t,r)}})}var me=at({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),Oc=at({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var bs={};ie(bs,{identity:()=>$e});var Hc=si,ri=128,Pc=127,Mc=~Pc,Kc=Math.pow(2,31);function si(r,e,t){e=e||[],t=t||0;for(var n=t;r>=Kc;)e[t++]=r&255|ri,r/=128;for(;r&Mc;)e[t++]=r&255|ri,r>>>=7;return e[t]=r|0,si.bytes=t-n+1,e}var Fc=ms,qc=128,ni=127;function ms(r,n){var t=0,n=n||0,s=0,o=n,i,a=r.length;do{if(o>=a)throw ms.bytes=0,new RangeError("Could not decode varint");i=r[o++],t+=s<28?(i&ni)<<s:(i&ni)*Math.pow(2,s),s+=7}while(i>=qc);return ms.bytes=o-n,t}var $c=Math.pow(2,7),Gc=Math.pow(2,14),jc=Math.pow(2,21),zc=Math.pow(2,28),Zc=Math.pow(2,35),Wc=Math.pow(2,42),Yc=Math.pow(2,49),Jc=Math.pow(2,56),Xc=Math.pow(2,63),Qc=function(r){return r<$c?1:r<Gc?2:r<jc?3:r<zc?4:r<Zc?5:r<Wc?6:r<Yc?7:r<Jc?8:r<Xc?9:10},el={encode:Hc,decode:Fc,encodingLength:Qc},tl=el,wr=tl;function xr(r,e=0){return[wr.decode(r,e),wr.decode.bytes]}function Mt(r,e,t=0){return wr.encode(r,e,t),e}function Kt(r){return wr.encodingLength(r)}function Oe(r,e){let t=e.byteLength,n=Kt(r),s=n+Kt(t),o=new Uint8Array(s+t);return Mt(r,o,0),Mt(t,o,n),o.set(e,s),new Ft(r,t,e,o)}function vr(r){let e=qe(r),[t,n]=xr(e),[s,o]=xr(e.subarray(n)),i=e.subarray(n+o);if(i.byteLength!==s)throw new Error("Incorrect length");return new Ft(t,s,i,e)}function oi(r,e){if(r===e)return!0;{let t=e;return r.code===t.code&&r.size===t.size&&t.bytes instanceof Uint8Array&&Yo(r.bytes,t.bytes)}}var Ft=class{code;size;digest;bytes;constructor(e,t,n,s){this.code=e,this.size=t,this.digest=n,this.bytes=s}};var ii=0,rl="identity",ai=qe;function nl(r){return Oe(ii,ai(r))}var $e={code:ii,name:rl,encode:ai,digest:nl};var vs={};ie(vs,{sha256:()=>ue,sha512:()=>sl});function xs({name:r,code:e,encode:t}){return new ws(r,e,t)}var ws=class{name;code;encode;constructor(e,t,n){this.name=e,this.code=t,this.encode=n}digest(e){if(e instanceof Uint8Array){let t=this.encode(e);return t instanceof Uint8Array?Oe(this.code,t):t.then(n=>Oe(this.code,n))}else throw Error("Unknown type, must be binary type")}};function li(r){return async e=>new Uint8Array(await crypto.subtle.digest(r,e))}var ue=xs({name:"sha2-256",code:18,encode:li("SHA-256")}),sl=xs({name:"sha2-512",code:19,encode:li("SHA-512")});function ve(r,e){if(r===e)return!0;if(r.byteLength!==e.byteLength)return!1;for(let t=0;t<r.byteLength;t++)if(r[t]!==e[t])return!1;return!0}function Ge(r=0){return new Uint8Array(r)}function Be(r=0){return new Uint8Array(r)}function $t(r,e){e==null&&(e=r.reduce((s,o)=>s+o.length,0));let t=Be(e),n=0;for(let s of r)t.set(s,n),n+=s.length;return t}var Bs={};ie(Bs,{base10:()=>ol});var ol=at({prefix:"9",name:"base10",alphabet:"0123456789"});var Es={};ie(Es,{base16:()=>il,base16upper:()=>al});var il=Y({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),al=Y({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var As={};ie(As,{base2:()=>cl});var cl=Y({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var ks={};ie(ks,{base256emoji:()=>dl});var ui=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}"),ll=ui.reduce((r,e,t)=>(r[t]=e,r),[]),ul=ui.reduce((r,e,t)=>(r[e.codePointAt(0)]=t,r),[]);function fl(r){return r.reduce((e,t)=>(e+=ll[t],e),"")}function hl(r){let e=[];for(let t of r){let n=ul[t.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${t}`);e.push(n)}return new Uint8Array(e)}var dl=Pt({prefix:"\u{1F680}",name:"base256emoji",encode:fl,decode:hl});var Ss={};ie(Ss,{base32:()=>Gt,base32hex:()=>ml,base32hexpad:()=>wl,base32hexpadupper:()=>xl,base32hexupper:()=>bl,base32pad:()=>gl,base32padupper:()=>yl,base32upper:()=>pl,base32z:()=>vl});var Gt=Y({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),pl=Y({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),gl=Y({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),yl=Y({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),ml=Y({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),bl=Y({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),wl=Y({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),xl=Y({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),vl=Y({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Is={};ie(Is,{base36:()=>Bl,base36upper:()=>El});var Bl=at({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),El=at({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Ns={};ie(Ns,{base64:()=>Rs,base64pad:()=>Al,base64url:()=>kl,base64urlpad:()=>Sl});var Rs=Y({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),Al=Y({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),kl=Y({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Sl=Y({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Ts={};ie(Ts,{base8:()=>Il});var Il=Y({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Ls={};ie(Ls,{identity:()=>Rl});var Rl=Pt({prefix:"\0",name:"identity",encode:r=>Xo(r),decode:r=>Jo(r)});var nd=new TextEncoder,sd=new TextDecoder;function fi(r,e){let{bytes:t,version:n}=r;switch(n){case 0:return Cl(t,Cs(r),e??me.encoder);default:return _l(t,Cs(r),e??Gt.encoder)}}var hi=new WeakMap;function Cs(r){let e=hi.get(r);if(e==null){let t=new Map;return hi.set(r,t),t}return e}var ct=class r{code;version;multihash;bytes;"/";constructor(e,t,n,s){this.code=t,this.version=e,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:e,multihash:t}=this;if(e!==Br)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(t.code!==Ul)throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");return r.createV0(t)}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:e,digest:t}=this.multihash,n=Oe(e,t);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(e){return r.equals(this,e)}static equals(e,t){let n=t;return n!=null&&e.code===n.code&&e.version===n.version&&oi(e.multihash,n.multihash)}toString(e){return fi(this,e)}toJSON(){return{"/":fi(this)}}link(){return this}[Symbol.toStringTag]="CID";[Symbol.for("nodejs.util.inspect.custom")](){return`CID(${this.toString()})`}static asCID(e){if(e==null)return null;let t=e;if(t instanceof r)return t;if(t["/"]!=null&&t["/"]===t.bytes||t.asCID===t){let{version:n,code:s,multihash:o,bytes:i}=t;return new r(n,s,o,i??di(n,s,o.bytes))}else if(t[Vl]===!0){let{version:n,multihash:s,code:o}=t,i=vr(s);return r.create(n,o,i)}else return null}static create(e,t,n){if(typeof t!="number")throw new Error("String codecs are no longer supported");if(!(n.bytes instanceof Uint8Array))throw new Error("Invalid digest");switch(e){case 0:{if(t!==Br)throw new Error(`Version 0 CID must use dag-pb (code: ${Br}) block encoding`);return new r(e,t,n,n.bytes)}case 1:{let s=di(e,t,n.bytes);return new r(e,t,n,s)}default:throw new Error("Invalid version")}}static createV0(e){return r.create(0,Br,e)}static createV1(e,t){return r.create(1,e,t)}static decode(e){let[t,n]=r.decodeFirst(e);if(n.length!==0)throw new Error("Incorrect length");return t}static decodeFirst(e){let t=r.inspectBytes(e),n=t.size-t.multihashSize,s=qe(e.subarray(n,n+t.multihashSize));if(s.byteLength!==t.multihashSize)throw new Error("Incorrect length");let o=s.subarray(t.multihashSize-t.digestSize),i=new Ft(t.multihashCode,t.digestSize,o,s);return[t.version===0?r.createV0(i):r.createV1(t.codec,i),e.subarray(t.size)]}static inspectBytes(e){let t=0,n=()=>{let[u,h]=xr(e.subarray(t));return t+=h,u},s=n(),o=Br;if(s===18?(s=0,t=0):o=n(),s!==0&&s!==1)throw new RangeError(`Invalid CID version ${s}`);let i=t,a=n(),c=n(),f=t+c,l=f-i;return{version:s,codec:o,multihashCode:a,digestSize:c,multihashSize:l,size:f}}static parse(e,t){let[n,s]=Ll(e,t),o=r.decode(s);if(o.version===0&&e[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return Cs(o).set(n,e),o}};function Ll(r,e){switch(r[0]){case"Q":{let t=e??me;return[me.prefix,t.decode(`${me.prefix}${r}`)]}case me.prefix:{let t=e??me;return[me.prefix,t.decode(r)]}case Gt.prefix:{let t=e??Gt;return[Gt.prefix,t.decode(r)]}default:{if(e==null)throw Error("To parse non base32 or base58btc encoded CID multibase decoder must be provided");return[r[0],e.decode(r)]}}}function Cl(r,e,t){let{prefix:n}=t;if(n!==me.prefix)throw Error(`Cannot string encode V0 in ${t.name} encoding`);let s=e.get(n);if(s==null){let o=t.encode(r).slice(1);return e.set(n,o),o}else return s}function _l(r,e,t){let{prefix:n}=t,s=e.get(n);if(s==null){let o=t.encode(r);return e.set(n,o),o}else return s}var Br=112,Ul=18;function di(r,e,t){let n=Kt(r),s=n+Kt(e),o=new Uint8Array(s+t.byteLength);return Mt(r,o,0),Mt(e,o,n),o.set(t,s),o}var Vl=Symbol.for("@ipld/js-cid/CID");var jt={...Ls,...As,...Ts,...Bs,...Es,...Ss,...Is,...ys,...Ns,...ks},xd={...vs,...bs};function gi(r,e,t,n){return{name:r,prefix:e,encoder:{name:r,prefix:e,encode:t},decoder:{decode:n}}}var pi=gi("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),_s=gi("ascii","a",r=>{let e="a";for(let t=0;t<r.length;t++)e+=String.fromCharCode(r[t]);return e},r=>{r=r.substring(1);let e=Be(r.length);for(let t=0;t<r.length;t++)e[t]=r.charCodeAt(t);return e}),Dl={utf8:pi,"utf-8":pi,hex:jt.base16,latin1:_s,ascii:_s,binary:_s,...jt},Yr=Dl;function z(r,e="utf8"){let t=Yr[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return t.decoder.decode(`${t.prefix}${r}`)}function Re(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function zt(r){if(!Number.isSafeInteger(r)||r<0)throw new Error(`positive integer expected, not ${r}`)}function Ol(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function Zt(r,...e){if(!Ol(r))throw new Error("Uint8Array expected");if(e.length>0&&!e.includes(r.length))throw new Error(`Uint8Array expected of length ${e}, not of length=${r.length}`)}function Jr(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");zt(r.outputLen),zt(r.blockLen)}function Wt(r,e=!0){if(r.destroyed)throw new Error("Hash instance has been destroyed");if(e&&r.finished)throw new Error("Hash#digest() has already been called")}function yi(r,e){Zt(r);let t=e.outputLen;if(r.length<t)throw new Error(`digestInto() expects output buffer of length at least ${t}`)}var kt=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;var Jt=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),Te=(r,e)=>r<<32-e|r>>>e;var Ud=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;var Hl=async()=>{};async function mi(r,e,t){let n=Date.now();for(let s=0;s<r;s++){t(s);let o=Date.now()-n;o>=0&&o<e||(await Hl(),n+=o)}}function bi(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function lt(r){return typeof r=="string"&&(r=bi(r)),Zt(r),r}function Us(...r){let e=0;for(let n=0;n<r.length;n++){let s=r[n];Zt(s),e+=s.length}let t=new Uint8Array(e);for(let n=0,s=0;n<r.length;n++){let o=r[n];t.set(o,s),s+=o.length}return t}var Yt=class{clone(){return this._cloneInto()}},Pl={}.toString;function wi(r,e){if(e!==void 0&&Pl.call(e)!=="[object Object]")throw new Error("Options should be object or undefined");return Object.assign(r,e)}function Xr(r){let e=n=>r().update(lt(n)).digest(),t=r();return e.outputLen=t.outputLen,e.blockLen=t.blockLen,e.create=()=>r(),e}function Xt(r=32){if(kt&&typeof kt.getRandomValues=="function")return kt.getRandomValues(new Uint8Array(r));if(kt&&typeof kt.randomBytes=="function")return kt.randomBytes(r);throw new Error("crypto.getRandomValues must be defined")}function Ml(r,e,t,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(e,t,n);let s=BigInt(32),o=BigInt(4294967295),i=Number(t>>s&o),a=Number(t&o),c=n?4:0,f=n?0:4;r.setUint32(e+c,i,n),r.setUint32(e+f,a,n)}var xi=(r,e,t)=>r&e^~r&t,vi=(r,e,t)=>r&e^r&t^e&t,Qt=class extends Yt{constructor(e,t,n,s){super(),this.blockLen=e,this.outputLen=t,this.padOffset=n,this.isLE=s,this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.buffer=new Uint8Array(e),this.view=Jt(this.buffer)}update(e){Wt(this);let{view:t,buffer:n,blockLen:s}=this;e=lt(e);let o=e.length;for(let i=0;i<o;){let a=Math.min(s-this.pos,o-i);if(a===s){let c=Jt(e);for(;s<=o-i;i+=s)this.process(c,i);continue}n.set(e.subarray(i,i+a),this.pos),this.pos+=a,i+=a,this.pos===s&&(this.process(t,0),this.pos=0)}return this.length+=e.length,this.roundClean(),this}digestInto(e){Wt(this),yi(e,this),this.finished=!0;let{buffer:t,view:n,blockLen:s,isLE:o}=this,{pos:i}=this;t[i++]=128,this.buffer.subarray(i).fill(0),this.padOffset>s-i&&(this.process(n,0),i=0);for(let u=i;u<s;u++)t[u]=0;Ml(n,s-8,BigInt(this.length*8),o),this.process(n,0);let a=Jt(e),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let f=c/4,l=this.get();if(f>l.length)throw new Error("_sha2: outputLen bigger than state");for(let u=0;u<f;u++)a.setUint32(4*u,l[u],o)}digest(){let{buffer:e,outputLen:t}=this;this.digestInto(e);let n=e.slice(0,t);return this.destroy(),n}_cloneInto(e){e||(e=new this.constructor),e.set(...this.get());let{blockLen:t,buffer:n,length:s,finished:o,destroyed:i,pos:a}=this;return e.length=s,e.pos=a,e.finished=o,e.destroyed=i,s%t&&e.buffer.set(n),e}};var Qr=BigInt(4294967295),Vs=BigInt(32);function Bi(r,e=!1){return e?{h:Number(r&Qr),l:Number(r>>Vs&Qr)}:{h:Number(r>>Vs&Qr)|0,l:Number(r&Qr)|0}}function Kl(r,e=!1){let t=new Uint32Array(r.length),n=new Uint32Array(r.length);for(let s=0;s<r.length;s++){let{h:o,l:i}=Bi(r[s],e);[t[s],n[s]]=[o,i]}return[t,n]}var Fl=(r,e)=>BigInt(r>>>0)<<Vs|BigInt(e>>>0),ql=(r,e,t)=>r>>>t,$l=(r,e,t)=>r<<32-t|e>>>t,Gl=(r,e,t)=>r>>>t|e<<32-t,jl=(r,e,t)=>r<<32-t|e>>>t,zl=(r,e,t)=>r<<64-t|e>>>t-32,Zl=(r,e,t)=>r>>>t-32|e<<64-t,Wl=(r,e)=>e,Yl=(r,e)=>r,Jl=(r,e,t)=>r<<t|e>>>32-t,Xl=(r,e,t)=>e<<t|r>>>32-t,Ql=(r,e,t)=>e<<t-32|r>>>64-t,eu=(r,e,t)=>r<<t-32|e>>>64-t;function tu(r,e,t,n){let s=(e>>>0)+(n>>>0);return{h:r+t+(s/2**32|0)|0,l:s|0}}var ru=(r,e,t)=>(r>>>0)+(e>>>0)+(t>>>0),nu=(r,e,t,n)=>e+t+n+(r/2**32|0)|0,su=(r,e,t,n)=>(r>>>0)+(e>>>0)+(t>>>0)+(n>>>0),ou=(r,e,t,n,s)=>e+t+n+s+(r/2**32|0)|0,iu=(r,e,t,n,s)=>(r>>>0)+(e>>>0)+(t>>>0)+(n>>>0)+(s>>>0),au=(r,e,t,n,s,o)=>e+t+n+s+o+(r/2**32|0)|0;var cu={fromBig:Bi,split:Kl,toBig:Fl,shrSH:ql,shrSL:$l,rotrSH:Gl,rotrSL:jl,rotrBH:zl,rotrBL:Zl,rotr32H:Wl,rotr32L:Yl,rotlSH:Jl,rotlSL:Xl,rotlBH:Ql,rotlBL:eu,add:tu,add3L:ru,add3H:nu,add4L:su,add4H:ou,add5H:au,add5L:iu},V=cu;var[lu,uu]=V.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))),ut=new Uint32Array(80),ft=new Uint32Array(80),Ds=class extends Qt{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:e,Al:t,Bh:n,Bl:s,Ch:o,Cl:i,Dh:a,Dl:c,Eh:f,El:l,Fh:u,Fl:h,Gh:w,Gl:x,Hh:y,Hl:d}=this;return[e,t,n,s,o,i,a,c,f,l,u,h,w,x,y,d]}set(e,t,n,s,o,i,a,c,f,l,u,h,w,x,y,d){this.Ah=e|0,this.Al=t|0,this.Bh=n|0,this.Bl=s|0,this.Ch=o|0,this.Cl=i|0,this.Dh=a|0,this.Dl=c|0,this.Eh=f|0,this.El=l|0,this.Fh=u|0,this.Fl=h|0,this.Gh=w|0,this.Gl=x|0,this.Hh=y|0,this.Hl=d|0}process(e,t){for(let g=0;g<16;g++,t+=4)ut[g]=e.getUint32(t),ft[g]=e.getUint32(t+=4);for(let g=16;g<80;g++){let E=ut[g-15]|0,C=ft[g-15]|0,L=V.rotrSH(E,C,1)^V.rotrSH(E,C,8)^V.shrSH(E,C,7),S=V.rotrSL(E,C,1)^V.rotrSL(E,C,8)^V.shrSL(E,C,7),I=ut[g-2]|0,T=ft[g-2]|0,Q=V.rotrSH(I,T,19)^V.rotrBH(I,T,61)^V.shrSH(I,T,6),F=V.rotrSL(I,T,19)^V.rotrBL(I,T,61)^V.shrSL(I,T,6),O=V.add4L(S,F,ft[g-7],ft[g-16]),ee=V.add4H(O,L,Q,ut[g-7],ut[g-16]);ut[g]=ee|0,ft[g]=O|0}let{Ah:n,Al:s,Bh:o,Bl:i,Ch:a,Cl:c,Dh:f,Dl:l,Eh:u,El:h,Fh:w,Fl:x,Gh:y,Gl:d,Hh:b,Hl:B}=this;for(let g=0;g<80;g++){let E=V.rotrSH(u,h,14)^V.rotrSH(u,h,18)^V.rotrBH(u,h,41),C=V.rotrSL(u,h,14)^V.rotrSL(u,h,18)^V.rotrBL(u,h,41),L=u&w^~u&y,S=h&x^~h&d,I=V.add5L(B,C,S,uu[g],ft[g]),T=V.add5H(I,b,E,L,lu[g],ut[g]),Q=I|0,F=V.rotrSH(n,s,28)^V.rotrBH(n,s,34)^V.rotrBH(n,s,39),O=V.rotrSL(n,s,28)^V.rotrBL(n,s,34)^V.rotrBL(n,s,39),ee=n&o^n&a^o&a,A=s&i^s&c^i&c;b=y|0,B=d|0,y=w|0,d=x|0,w=u|0,x=h|0,{h:u,l:h}=V.add(f|0,l|0,T|0,Q|0),f=a|0,l=c|0,a=o|0,c=i|0,o=n|0,i=s|0;let R=V.add3L(Q,O,A);n=V.add3H(R,T,F,ee),s=R|0}({h:n,l:s}=V.add(this.Ah|0,this.Al|0,n|0,s|0)),{h:o,l:i}=V.add(this.Bh|0,this.Bl|0,o|0,i|0),{h:a,l:c}=V.add(this.Ch|0,this.Cl|0,a|0,c|0),{h:f,l}=V.add(this.Dh|0,this.Dl|0,f|0,l|0),{h:u,l:h}=V.add(this.Eh|0,this.El|0,u|0,h|0),{h:w,l:x}=V.add(this.Fh|0,this.Fl|0,w|0,x|0),{h:y,l:d}=V.add(this.Gh|0,this.Gl|0,y|0,d|0),{h:b,l:B}=V.add(this.Hh|0,this.Hl|0,b|0,B|0),this.set(n,s,o,i,a,c,f,l,u,h,w,x,y,d,b,B)}roundClean(){ut.fill(0),ft.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 Er=Xr(()=>new Ds);var tn={};ie(tn,{aInRange:()=>Ee,abool:()=>Le,abytes:()=>er,bitGet:()=>yu,bitLen:()=>Ks,bitMask:()=>kr,bitSet:()=>mu,bytesToHex:()=>ze,bytesToNumberBE:()=>Ze,bytesToNumberLE:()=>dt,concatBytes:()=>We,createHmacDrbg:()=>Fs,ensureBytes:()=>J,equalBytes:()=>pu,hexToBytes:()=>It,hexToNumber:()=>Ms,inRange:()=>Ar,isBytes:()=>ht,memoized:()=>Nt,notImplemented:()=>wu,numberToBytesBE:()=>pt,numberToBytesLE:()=>Rt,numberToHexUnpadded:()=>St,numberToVarBytesBE:()=>du,utf8ToBytes:()=>gu,validateObject:()=>He});var Ps=BigInt(0),en=BigInt(1),fu=BigInt(2);function ht(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function er(r){if(!ht(r))throw new Error("Uint8Array expected")}function Le(r,e){if(typeof e!="boolean")throw new Error(`${r} must be valid boolean, got "${e}".`)}var hu=Array.from({length:256},(r,e)=>e.toString(16).padStart(2,"0"));function ze(r){er(r);let e="";for(let t=0;t<r.length;t++)e+=hu[r[t]];return e}function St(r){let e=r.toString(16);return e.length&1?`0${e}`:e}function Ms(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return BigInt(r===""?"0":`0x${r}`)}var je={_0:48,_9:57,_A:65,_F:70,_a:97,_f:102};function Ei(r){if(r>=je._0&&r<=je._9)return r-je._0;if(r>=je._A&&r<=je._F)return r-(je._A-10);if(r>=je._a&&r<=je._f)return r-(je._a-10)}function It(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);let e=r.length,t=e/2;if(e%2)throw new Error("padded hex string expected, got unpadded hex of length "+e);let n=new Uint8Array(t);for(let s=0,o=0;s<t;s++,o+=2){let i=Ei(r.charCodeAt(o)),a=Ei(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 Ze(r){return Ms(ze(r))}function dt(r){return er(r),Ms(ze(Uint8Array.from(r).reverse()))}function pt(r,e){return It(r.toString(16).padStart(e*2,"0"))}function Rt(r,e){return pt(r,e).reverse()}function du(r){return It(St(r))}function J(r,e,t){let n;if(typeof e=="string")try{n=It(e)}catch(o){throw new Error(`${r} must be valid hex string, got "${e}". Cause: ${o}`)}else if(ht(e))n=Uint8Array.from(e);else throw new Error(`${r} must be hex string or Uint8Array`);let s=n.length;if(typeof t=="number"&&s!==t)throw new Error(`${r} expected ${t} bytes, got ${s}`);return n}function We(...r){let e=0;for(let n=0;n<r.length;n++){let s=r[n];er(s),e+=s.length}let t=new Uint8Array(e);for(let n=0,s=0;n<r.length;n++){let o=r[n];t.set(o,s),s+=o.length}return t}function pu(r,e){if(r.length!==e.length)return!1;let t=0;for(let n=0;n<r.length;n++)t|=r[n]^e[n];return t===0}function gu(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}var Os=r=>typeof r=="bigint"&&Ps<=r;function Ar(r,e,t){return Os(r)&&Os(e)&&Os(t)&&e<=r&&r<t}function Ee(r,e,t,n){if(!Ar(e,t,n))throw new Error(`expected valid ${r}: ${t} <= n < ${n}, got ${typeof e} ${e}`)}function Ks(r){let e;for(e=0;r>Ps;r>>=en,e+=1);return e}function yu(r,e){return r>>BigInt(e)&en}function mu(r,e,t){return r|(t?en:Ps)<<BigInt(e)}var kr=r=>(fu<<BigInt(r-1))-en,Hs=r=>new Uint8Array(r),Ai=r=>Uint8Array.from(r);function Fs(r,e,t){if(typeof r!="number"||r<2)throw new Error("hashLen must be a number");if(typeof e!="number"||e<2)throw new Error("qByteLen must be a number");if(typeof t!="function")throw new Error("hmacFn must be a function");let n=Hs(r),s=Hs(r),o=0,i=()=>{n.fill(1),s.fill(0),o=0},a=(...u)=>t(s,n,...u),c=(u=Hs())=>{s=a(Ai([0]),u),n=a(),u.length!==0&&(s=a(Ai([1]),u),n=a())},f=()=>{if(o++>=1e3)throw new Error("drbg: tried 1000 values");let u=0,h=[];for(;u<e;){n=a();let w=n.slice();h.push(w),u+=n.length}return We(...h)};return(u,h)=>{i(),c(u);let w;for(;!(w=h(f()));)c();return i(),w}}var bu={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"||ht(r),isSafeInteger:r=>Number.isSafeInteger(r),array:r=>Array.isArray(r),field:(r,e)=>e.Fp.isValid(r),hash:r=>typeof r=="function"&&Number.isSafeInteger(r.outputLen)};function He(r,e,t={}){let n=(s,o,i)=>{let a=bu[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(e))n(s,o,!1);for(let[s,o]of Object.entries(t))n(s,o,!0);return r}var wu=()=>{throw new Error("not implemented")};function Nt(r){let e=new WeakMap;return(t,...n)=>{let s=e.get(t);if(s!==void 0)return s;let o=r(t,...n);return e.set(t,o),o}}var re=BigInt(0),Z=BigInt(1),Tt=BigInt(2),xu=BigInt(3),qs=BigInt(4),ki=BigInt(5),Si=BigInt(8),vu=BigInt(9),Bu=BigInt(16);function G(r,e){let t=r%e;return t>=re?t:e+t}function Eu(r,e,t){if(t<=re||e<re)throw new Error("Expected power/modulo > 0");if(t===Z)return re;let n=Z;for(;e>re;)e&Z&&(n=n*r%t),r=r*r%t,e>>=Z;return n}function W(r,e,t){let n=r;for(;e-- >re;)n*=n,n%=t;return n}function rn(r,e){if(r===re||e<=re)throw new Error(`invert: expected positive integers, got n=${r} mod=${e}`);let t=G(r,e),n=e,s=re,o=Z,i=Z,a=re;for(;t!==re;){let f=n/t,l=n%t,u=s-i*f,h=o-a*f;n=t,t=l,s=i,o=a,i=u,a=h}if(n!==Z)throw new Error("invert: does not exist");return G(s,e)}function Au(r){let e=(r-Z)/Tt,t,n,s;for(t=r-Z,n=0;t%Tt===re;t/=Tt,n++);for(s=Tt;s<r&&Eu(s,e,r)!==r-Z;s++);if(n===1){let i=(r+Z)/qs;return function(c,f){let l=c.pow(f,i);if(!c.eql(c.sqr(l),f))throw new Error("Cannot find square root");return l}}let o=(t+Z)/Tt;return function(a,c){if(a.pow(c,e)===a.neg(a.ONE))throw new Error("Cannot find square root");let f=n,l=a.pow(a.mul(a.ONE,s),t),u=a.pow(c,o),h=a.pow(c,t);for(;!a.eql(h,a.ONE);){if(a.eql(h,a.ZERO))return a.ZERO;let w=1;for(let y=a.sqr(h);w<f&&!a.eql(y,a.ONE);w++)y=a.sqr(y);let x=a.pow(l,Z<<BigInt(f-w-1));l=a.sqr(x),u=a.mul(u,x),h=a.mul(h,l),f=w}return u}}function ku(r){if(r%qs===xu){let e=(r+Z)/qs;return function(n,s){let o=n.pow(s,e);if(!n.eql(n.sqr(o),s))throw new Error("Cannot find square root");return o}}if(r%Si===ki){let e=(r-ki)/Si;return function(n,s){let o=n.mul(s,Tt),i=n.pow(o,e),a=n.mul(s,i),c=n.mul(n.mul(a,Tt),i),f=n.mul(a,n.sub(c,n.ONE));if(!n.eql(n.sqr(f),s))throw new Error("Cannot find square root");return f}}return r%Bu,Au(r)}var Ii=(r,e)=>(G(r,e)&Z)===Z,Su=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function $s(r){let e={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},t=Su.reduce((n,s)=>(n[s]="function",n),e);return He(r,t)}function Iu(r,e,t){if(t<re)throw new Error("Expected power > 0");if(t===re)return r.ONE;if(t===Z)return e;let n=r.ONE,s=e;for(;t>re;)t&Z&&(n=r.mul(n,s)),s=r.sqr(s),t>>=Z;return n}function Ru(r,e){let t=new Array(e.length),n=e.reduce((o,i,a)=>r.is0(i)?o:(t[a]=o,r.mul(o,i)),r.ONE),s=r.inv(n);return e.reduceRight((o,i,a)=>r.is0(i)?o:(t[a]=r.mul(o,t[a]),r.mul(o,i)),s),t}function Gs(r,e){let t=e!==void 0?e:r.toString(2).length,n=Math.ceil(t/8);return{nBitLength:t,nByteLength:n}}function gt(r,e,t=!1,n={}){if(r<=re)throw new Error(`Expected Field ORDER > 0, got ${r}`);let{nBitLength:s,nByteLength:o}=Gs(r,e);if(o>2048)throw new Error("Field lengths over 2048 bytes are not supported");let i=ku(r),a=Object.freeze({ORDER:r,BITS:s,BYTES:o,MASK:kr(s),ZERO:re,ONE:Z,create:c=>G(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error(`Invalid field element: expected bigint, got ${typeof c}`);return re<=c&&c<r},is0:c=>c===re,isOdd:c=>(c&Z)===Z,neg:c=>G(-c,r),eql:(c,f)=>c===f,sqr:c=>G(c*c,r),add:(c,f)=>G(c+f,r),sub:(c,f)=>G(c-f,r),mul:(c,f)=>G(c*f,r),pow:(c,f)=>Iu(a,c,f),div:(c,f)=>G(c*rn(f,r),r),sqrN:c=>c*c,addN:(c,f)=>c+f,subN:(c,f)=>c-f,mulN:(c,f)=>c*f,inv:c=>rn(c,r),sqrt:n.sqrt||(c=>i(a,c)),invertBatch:c=>Ru(a,c),cmov:(c,f,l)=>l?f:c,toBytes:c=>t?Rt(c,o):pt(c,o),fromBytes:c=>{if(c.length!==o)throw new Error(`Fp.fromBytes: expected ${o}, got ${c.length}`);return t?dt(c):Ze(c)}});return Object.freeze(a)}function Ri(r){if(typeof r!="bigint")throw new Error("field order must be bigint");let e=r.toString(2).length;return Math.ceil(e/8)}function js(r){let e=Ri(r);return e+Math.ceil(e/2)}function Ni(r,e,t=!1){let n=r.length,s=Ri(e),o=js(e);if(n<16||n<o||n>1024)throw new Error(`expected ${o}-1024 bytes of input, got ${n}`);let i=t?Ze(r):dt(r),a=G(i,e-Z)+Z;return t?Rt(a,s):pt(a,s)}var Tu=BigInt(0),zs=BigInt(1),Zs=new WeakMap,Ti=new WeakMap;function nn(r,e){let t=(o,i)=>{let a=i.negate();return o?a:i},n=o=>{if(!Number.isSafeInteger(o)||o<=0||o>e)throw new Error(`Wrong window size=${o}, should be [1..${e}]`)},s=o=>{n(o);let i=Math.ceil(e/o)+1,a=2**(o-1);return{windows:i,windowSize:a}};return{constTimeNegate:t,unsafeLadder(o,i){let a=r.ZERO,c=o;for(;i>Tu;)i&zs&&(a=a.add(c)),c=c.double(),i>>=zs;return a},precomputeWindow(o,i){let{windows:a,windowSize:c}=s(i),f=[],l=o,u=l;for(let h=0;h<a;h++){u=l,f.push(u);for(let w=1;w<c;w++)u=u.add(l),f.push(u);l=u.double()}return f},wNAF(o,i,a){let{windows:c,windowSize:f}=s(o),l=r.ZERO,u=r.BASE,h=BigInt(2**o-1),w=2**o,x=BigInt(o);for(let y=0;y<c;y++){let d=y*f,b=Number(a&h);a>>=x,b>f&&(b-=w,a+=zs);let B=d,g=d+Math.abs(b)-1,E=y%2!==0,C=b<0;b===0?u=u.add(t(E,i[B])):l=l.add(t(C,i[g]))}return{p:l,f:u}},wNAFCached(o,i,a){let c=Ti.get(o)||1,f=Zs.get(o);return f||(f=this.precomputeWindow(o,c),c!==1&&Zs.set(o,a(f))),this.wNAF(c,f,i)},setWindowSize(o,i){n(i),Ti.set(o,i),Zs.delete(o)}}}function sn(r,e,t,n){if(!Array.isArray(t)||!Array.isArray(n)||n.length!==t.length)throw new Error("arrays of points and scalars must have equal length");n.forEach((l,u)=>{if(!e.isValid(l))throw new Error(`wrong scalar at index ${u}`)}),t.forEach((l,u)=>{if(!(l instanceof r))throw new Error(`wrong point at index ${u}`)});let s=Ks(BigInt(t.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((e.BITS-1)/o)*o,f=r.ZERO;for(let l=c;l>=0;l-=o){a.fill(r.ZERO);for(let h=0;h<n.length;h++){let w=n[h],x=Number(w>>BigInt(l)&BigInt(i));a[x]=a[x].add(t[h])}let u=r.ZERO;for(let h=a.length-1,w=r.ZERO;h>0;h--)w=w.add(a[h]),u=u.add(w);if(f=f.add(u),l!==0)for(let h=0;h<o;h++)f=f.double()}return f}function Sr(r){return $s(r.Fp),He(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...Gs(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Ce=BigInt(0),Ae=BigInt(1),on=BigInt(2),Lu=BigInt(8),Cu={zip215:!0};function _u(r){let e=Sr(r);return He(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...e})}function Li(r){let e=_u(r),{Fp:t,n,prehash:s,hash:o,randomBytes:i,nByteLength:a,h:c}=e,f=on<<BigInt(a*8)-Ae,l=t.create,u=gt(e.n,e.nBitLength),h=e.uvRatio||((m,p)=>{try{return{isValid:!0,value:t.sqrt(m*t.inv(p))}}catch{return{isValid:!1,value:Ce}}}),w=e.adjustScalarBytes||(m=>m),x=e.domain||((m,p,v)=>{if(Le("phflag",v),p.length||v)throw new Error("Contexts/pre-hash are not supported");return m});function y(m,p){Ee("coordinate "+m,p,Ce,f)}function d(m){if(!(m instanceof g))throw new Error("ExtendedPoint expected")}let b=Nt((m,p)=>{let{ex:v,ey:N,ez:_}=m,U=m.is0();p==null&&(p=U?Lu:t.inv(_));let H=l(v*p),K=l(N*p),P=l(_*p);if(U)return{x:Ce,y:Ae};if(P!==Ae)throw new Error("invZ was invalid");return{x:H,y:K}}),B=Nt(m=>{let{a:p,d:v}=e;if(m.is0())throw new Error("bad point: ZERO");let{ex:N,ey:_,ez:U,et:H}=m,K=l(N*N),P=l(_*_),$=l(U*U),j=l($*$),se=l(K*p),oe=l($*l(se+P)),le=l(j+l(v*l(K*P)));if(oe!==le)throw new Error("bad point: equation left != right (1)");let ye=l(N*_),te=l(U*H);if(ye!==te)throw new Error("bad point: equation left != right (2)");return!0});class g{constructor(p,v,N,_){this.ex=p,this.ey=v,this.ez=N,this.et=_,y("x",p),y("y",v),y("z",N),y("t",_),Object.freeze(this)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(p){if(p instanceof g)throw new Error("extended point not allowed");let{x:v,y:N}=p||{};return y("x",v),y("y",N),new g(v,N,Ae,l(v*N))}static normalizeZ(p){let v=t.invertBatch(p.map(N=>N.ez));return p.map((N,_)=>N.toAffine(v[_])).map(g.fromAffine)}static msm(p,v){return sn(g,u,p,v)}_setWindowSize(p){L.setWindowSize(this,p)}assertValidity(){B(this)}equals(p){d(p);let{ex:v,ey:N,ez:_}=this,{ex:U,ey:H,ez:K}=p,P=l(v*K),$=l(U*_),j=l(N*K),se=l(H*_);return P===$&&j===se}is0(){return this.equals(g.ZERO)}negate(){return new g(l(-this.ex),this.ey,this.ez,l(-this.et))}double(){let{a:p}=e,{ex:v,ey:N,ez:_}=this,U=l(v*v),H=l(N*N),K=l(on*l(_*_)),P=l(p*U),$=v+N,j=l(l($*$)-U-H),se=P+H,oe=se-K,le=P-H,ye=l(j*oe),te=l(se*le),xe=l(j*le),Fe=l(oe*se);return new g(ye,te,Fe,xe)}add(p){d(p);let{a:v,d:N}=e,{ex:_,ey:U,ez:H,et:K}=this,{ex:P,ey:$,ez:j,et:se}=p;if(v===BigInt(-1)){let Ko=l((U-_)*($+P)),Fo=l((U+_)*($-P)),us=l(Fo-Ko);if(us===Ce)return this.double();let qo=l(H*on*se),$o=l(K*on*j),Go=$o+qo,jo=Fo+Ko,zo=$o-qo,xc=l(Go*us),vc=l(jo*zo),Bc=l(Go*zo),Ec=l(us*jo);return new g(xc,vc,Ec,Bc)}let oe=l(_*P),le=l(U*$),ye=l(K*N*se),te=l(H*j),xe=l((_+U)*(P+$)-oe-le),Fe=te-ye,mr=te+ye,br=l(le-v*oe),yc=l(xe*Fe),mc=l(mr*br),bc=l(xe*br),wc=l(Fe*mr);return new g(yc,mc,wc,bc)}subtract(p){return this.add(p.negate())}wNAF(p){return L.wNAFCached(this,p,g.normalizeZ)}multiply(p){let v=p;Ee("scalar",v,Ae,n);let{p:N,f:_}=this.wNAF(v);return g.normalizeZ([N,_])[0]}multiplyUnsafe(p){let v=p;return Ee("scalar",v,Ce,n),v===Ce?C:this.equals(C)||v===Ae?this:this.equals(E)?this.wNAF(v).p:L.unsafeLadder(this,v)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return L.unsafeLadder(this,n).is0()}toAffine(p){return b(this,p)}clearCofactor(){let{h:p}=e;return p===Ae?this:this.multiplyUnsafe(p)}static fromHex(p,v=!1){let{d:N,a:_}=e,U=t.BYTES;p=J("pointHex",p,U),Le("zip215",v);let H=p.slice(),K=p[U-1];H[U-1]=K&-129;let P=dt(H),$=v?f:t.ORDER;Ee("pointHex.y",P,Ce,$);let j=l(P*P),se=l(j-Ae),oe=l(N*j-_),{isValid:le,value:ye}=h(se,oe);if(!le)throw new Error("Point.fromHex: invalid y coordinate");let te=(ye&Ae)===Ae,xe=(K&128)!==0;if(!v&&ye===Ce&&xe)throw new Error("Point.fromHex: x=0 and x_0=1");return xe!==te&&(ye=l(-ye)),g.fromAffine({x:ye,y:P})}static fromPrivateKey(p){return T(p).point}toRawBytes(){let{x:p,y:v}=this.toAffine(),N=Rt(v,t.BYTES);return N[N.length-1]|=p&Ae?128:0,N}toHex(){return ze(this.toRawBytes())}}g.BASE=new g(e.Gx,e.Gy,Ae,l(e.Gx*e.Gy)),g.ZERO=new g(Ce,Ae,Ae,Ce);let{BASE:E,ZERO:C}=g,L=nn(g,a*8);function S(m){return G(m,n)}function I(m){return S(dt(m))}function T(m){let p=a;m=J("private key",m,p);let v=J("hashed private key",o(m),2*p),N=w(v.slice(0,p)),_=v.slice(p,2*p),U=I(N),H=E.multiply(U),K=H.toRawBytes();return{head:N,prefix:_,scalar:U,point:H,pointBytes:K}}function Q(m){return T(m).pointBytes}function F(m=new Uint8Array,...p){let v=We(...p);return I(o(x(v,J("context",m),!!s)))}function O(m,p,v={}){m=J("message",m),s&&(m=s(m));let{prefix:N,scalar:_,pointBytes:U}=T(p),H=F(v.context,N,m),K=E.multiply(H).toRawBytes(),P=F(v.context,K,U,m),$=S(H+P*_);Ee("signature.s",$,Ce,n);let j=We(K,Rt($,t.BYTES));return J("result",j,a*2)}let ee=Cu;function A(m,p,v,N=ee){let{context:_,zip215:U}=N,H=t.BYTES;m=J("signature",m,2*H),p=J("message",p),U!==void 0&&Le("zip215",U),s&&(p=s(p));let K=dt(m.slice(H,2*H)),P,$,j;try{P=g.fromHex(v,U),$=g.fromHex(m.slice(0,H),U),j=E.multiplyUnsafe(K)}catch{return!1}if(!U&&P.isSmallOrder())return!1;let se=F(_,$.toRawBytes(),P.toRawBytes(),p);return $.add(P.multiplyUnsafe(se)).subtract(j).clearCofactor().equals(g.ZERO)}return E._setWindowSize(8),{CURVE:e,getPublicKey:Q,sign:O,verify:A,ExtendedPoint:g,utils:{getExtendedPublicKey:T,randomPrivateKey:()=>i(t.BYTES),precompute(m=8,p=g.BASE){return p._setWindowSize(m),p.multiply(BigInt(3)),p}}}}var Ws=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),Ci=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),n0=BigInt(0),Uu=BigInt(1),_i=BigInt(2),s0=BigInt(3),Vu=BigInt(5),Du=BigInt(8);function Ou(r){let e=BigInt(10),t=BigInt(20),n=BigInt(40),s=BigInt(80),o=Ws,a=r*r%o*r%o,c=W(a,_i,o)*a%o,f=W(c,Uu,o)*r%o,l=W(f,Vu,o)*f%o,u=W(l,e,o)*l%o,h=W(u,t,o)*u%o,w=W(h,n,o)*h%o,x=W(w,s,o)*w%o,y=W(x,s,o)*w%o,d=W(y,e,o)*l%o;return{pow_p_5_8:W(d,_i,o)*r%o,b2:a}}function Hu(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function Pu(r,e){let t=Ws,n=G(e*e*e,t),s=G(n*n*e,t),o=Ou(r*s).pow_p_5_8,i=G(r*n*o,t),a=G(e*i*i,t),c=i,f=G(i*Ci,t),l=a===r,u=a===G(-r,t),h=a===G(-r*Ci,t);return l&&(i=c),(u||h)&&(i=f),Ii(i,t)&&(i=G(-i,t)),{isValid:l||u,value:i}}var Mu=gt(Ws,void 0,!0),Ku={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:Mu,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:Du,Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:Er,randomBytes:Xt,adjustScalarBytes:Hu,uvRatio:Pu},tr=Li(Ku);var rr=32,Ye=64,an=32;function Ui(){let r=tr.utils.randomPrivateKey(),e=tr.getPublicKey(r);return{privateKey:Hi(r,e),publicKey:e}}function Vi(r){if(r.length!==an)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 e=r,t=tr.getPublicKey(e);return{privateKey:Hi(e,t),publicKey:t}}function Di(r,e){let t=r.subarray(0,an);return tr.sign(e instanceof Uint8Array?e:e.subarray(),t)}function Oi(r,e,t){return tr.verify(e,t instanceof Uint8Array?t:t.subarray(),r)}function Hi(r,e){let t=new Uint8Array(Ye);for(let n=0;n<an;n++)t[n]=r[n],t[an+n]=e[n];return t}var be={get(r=globalThis){let e=r.crypto;if(e?.subtle==null)throw Object.assign(new Error("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"),{code:"ERR_MISSING_WEB_CRYPTO"});return e}};var Ys={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function Pi(r){let e=r?.algorithm??"AES-GCM",t=r?.keyLength??16,n=r?.nonceLength??12,s=r?.digest??"SHA-256",o=r?.saltLength??16,i=r?.iterations??32767,a=be.get();t*=8;async function c(u,h){let w=a.getRandomValues(new Uint8Array(o)),x=a.getRandomValues(new Uint8Array(n)),y={name:e,iv:x};typeof h=="string"&&(h=z(h));let d;if(h.length===0){d=await a.subtle.importKey("jwk",Ys,{name:"AES-GCM"},!0,["encrypt"]);try{let B={name:"PBKDF2",salt:w,iterations:i,hash:{name:s}},g=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);d=await a.subtle.deriveKey(B,g,{name:e,length:t},!0,["encrypt"])}catch{d=await a.subtle.importKey("jwk",Ys,{name:"AES-GCM"},!0,["encrypt"])}}else{let B={name:"PBKDF2",salt:w,iterations:i,hash:{name:s}},g=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);d=await a.subtle.deriveKey(B,g,{name:e,length:t},!0,["encrypt"])}let b=await a.subtle.encrypt(y,d,u);return $t([w,y.iv,new Uint8Array(b)])}async function f(u,h){let w=u.subarray(0,o),x=u.subarray(o,o+n),y=u.subarray(o+n),d={name:e,iv:x};typeof h=="string"&&(h=z(h));let b;if(h.length===0)try{let g={name:"PBKDF2",salt:w,iterations:i,hash:{name:s}},E=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);b=await a.subtle.deriveKey(g,E,{name:e,length:t},!0,["decrypt"])}catch{b=await a.subtle.importKey("jwk",Ys,{name:"AES-GCM"},!0,["decrypt"])}else{let g={name:"PBKDF2",salt:w,iterations:i,hash:{name:s}},E=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);b=await a.subtle.deriveKey(g,E,{name:e,length:t},!0,["decrypt"])}let B=await a.subtle.decrypt(d,b,y);return new Uint8Array(B)}return{encrypt:c,decrypt:f}}async function nr(r,e){let n=await Pi().encrypt(r,e);return Rs.encode(n)}var $u=Math.pow(2,7),Gu=Math.pow(2,14),ju=Math.pow(2,21),Js=Math.pow(2,28),Xs=Math.pow(2,35),Qs=Math.pow(2,42),eo=Math.pow(2,49),q=128,de=127;function Je(r){if(r<$u)return 1;if(r<Gu)return 2;if(r<ju)return 3;if(r<Js)return 4;if(r<Xs)return 5;if(r<Qs)return 6;if(r<eo)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function to(r,e,t=0){switch(Je(r)){case 8:e[t++]=r&255|q,r/=128;case 7:e[t++]=r&255|q,r/=128;case 6:e[t++]=r&255|q,r/=128;case 5:e[t++]=r&255|q,r/=128;case 4:e[t++]=r&255|q,r>>>=7;case 3:e[t++]=r&255|q,r>>>=7;case 2:e[t++]=r&255|q,r>>>=7;case 1:{e[t++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return e}function zu(r,e,t=0){switch(Je(r)){case 8:e.set(t++,r&255|q),r/=128;case 7:e.set(t++,r&255|q),r/=128;case 6:e.set(t++,r&255|q),r/=128;case 5:e.set(t++,r&255|q),r/=128;case 4:e.set(t++,r&255|q),r>>>=7;case 3:e.set(t++,r&255|q),r>>>=7;case 2:e.set(t++,r&255|q),r>>>=7;case 1:{e.set(t++,r&255),r>>>=7;break}default:throw new Error("unreachable")}return e}function ro(r,e){let t=r[e],n=0;if(n+=t&de,t<q||(t=r[e+1],n+=(t&de)<<7,t<q)||(t=r[e+2],n+=(t&de)<<14,t<q)||(t=r[e+3],n+=(t&de)<<21,t<q)||(t=r[e+4],n+=(t&de)*Js,t<q)||(t=r[e+5],n+=(t&de)*Xs,t<q)||(t=r[e+6],n+=(t&de)*Qs,t<q)||(t=r[e+7],n+=(t&de)*eo,t<q))return n;throw new RangeError("Could not decode varint")}function Zu(r,e){let t=r.get(e),n=0;if(n+=t&de,t<q||(t=r.get(e+1),n+=(t&de)<<7,t<q)||(t=r.get(e+2),n+=(t&de)<<14,t<q)||(t=r.get(e+3),n+=(t&de)<<21,t<q)||(t=r.get(e+4),n+=(t&de)*Js,t<q)||(t=r.get(e+5),n+=(t&de)*Xs,t<q)||(t=r.get(e+6),n+=(t&de)*Qs,t<q)||(t=r.get(e+7),n+=(t&de)*eo,t<q))return n;throw new RangeError("Could not decode varint")}function Mi(r,e,t=0){return e==null&&(e=Be(Je(r))),e instanceof Uint8Array?to(r,e,t):zu(r,e,t)}function Ki(r,e=0){return r instanceof Uint8Array?ro(r,e):Zu(r,e)}var no=new Float32Array([-0]),yt=new Uint8Array(no.buffer);function Fi(r,e,t){no[0]=r,e[t]=yt[0],e[t+1]=yt[1],e[t+2]=yt[2],e[t+3]=yt[3]}function qi(r,e){return yt[0]=r[e],yt[1]=r[e+1],yt[2]=r[e+2],yt[3]=r[e+3],no[0]}var so=new Float64Array([-0]),pe=new Uint8Array(so.buffer);function $i(r,e,t){so[0]=r,e[t]=pe[0],e[t+1]=pe[1],e[t+2]=pe[2],e[t+3]=pe[3],e[t+4]=pe[4],e[t+5]=pe[5],e[t+6]=pe[6],e[t+7]=pe[7]}function Gi(r,e){return pe[0]=r[e],pe[1]=r[e+1],pe[2]=r[e+2],pe[3]=r[e+3],pe[4]=r[e+4],pe[5]=r[e+5],pe[6]=r[e+6],pe[7]=r[e+7],so[0]}var Yu=BigInt(Number.MAX_SAFE_INTEGER),Ju=BigInt(Number.MIN_SAFE_INTEGER),Ie=class r{lo;hi;constructor(e,t){this.lo=e|0,this.hi=t|0}toNumber(e=!1){if(!e&&this.hi>>>31>0){let t=~this.lo+1>>>0,n=~this.hi>>>0;return t===0&&(n=n+1>>>0),-(t+n*4294967296)}return this.lo+this.hi*4294967296}toBigInt(e=!1){if(e)return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n);if(this.hi>>>31){let t=~this.lo+1>>>0,n=~this.hi>>>0;return t===0&&(n=n+1>>>0),-(BigInt(t)+(BigInt(n)<<32n))}return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n)}toString(e=!1){return this.toBigInt(e).toString()}zzEncode(){let e=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^e)>>>0,this.lo=(this.lo<<1^e)>>>0,this}zzDecode(){let e=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^e)>>>0,this.hi=(this.hi>>>1^e)>>>0,this}length(){let e=this.lo,t=(this.lo>>>28|this.hi<<4)>>>0,n=this.hi>>>24;return n===0?t===0?e<16384?e<128?1:2:e<2097152?3:4:t<16384?t<128?5:6:t<2097152?7:8:n<128?9:10}static fromBigInt(e){if(e===0n)return Lt;if(e<Yu&&e>Ju)return this.fromNumber(Number(e));let t=e<0n;t&&(e=-e);let n=e>>32n,s=e-(n<<32n);return t&&(n=~n|0n,s=~s|0n,++s>ji&&(s=0n,++n>ji&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(e){if(e===0)return Lt;let t=e<0;t&&(e=-e);let n=e>>>0,s=(e-n)/4294967296>>>0;return t&&(s=~s>>>0,n=~n>>>0,++n>4294967295&&(n=0,++s>4294967295&&(s=0))),new r(n,s)}static from(e){return typeof e=="number"?r.fromNumber(e):typeof e=="bigint"?r.fromBigInt(e):typeof e=="string"?r.fromBigInt(BigInt(e)):e.low!=null||e.high!=null?new r(e.low>>>0,e.high>>>0):Lt}},Lt=new Ie(0,0);Lt.toBigInt=function(){return 0n};Lt.zzEncode=Lt.zzDecode=function(){return this};Lt.length=function(){return 1};var ji=4294967296n;function zi(r){let e=0,t=0;for(let n=0;n<r.length;++n)t=r.charCodeAt(n),t<128?e+=1:t<2048?e+=2:(t&64512)===55296&&(r.charCodeAt(n+1)&64512)===56320?(++n,e+=4):e+=3;return e}function Zi(r,e,t){if(t-e<1)return"";let s,o=[],i=0,a;for(;e<t;)a=r[e++],a<128?o[i++]=a:a>191&&a<224?o[i++]=(a&31)<<6|r[e++]&63:a>239&&a<365?(a=((a&7)<<18|(r[e++]&63)<<12|(r[e++]&63)<<6|r[e++]&63)-65536,o[i++]=55296+(a>>10),o[i++]=56320+(a&1023)):o[i++]=(a&15)<<12|(r[e++]&63)<<6|r[e++]&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 oo(r,e,t){let n=t,s,o;for(let i=0;i<r.length;++i)s=r.charCodeAt(i),s<128?e[t++]=s:s<2048?(e[t++]=s>>6|192,e[t++]=s&63|128):(s&64512)===55296&&((o=r.charCodeAt(i+1))&64512)===56320?(s=65536+((s&1023)<<10)+(o&1023),++i,e[t++]=s>>18|240,e[t++]=s>>12&63|128,e[t++]=s>>6&63|128,e[t++]=s&63|128):(e[t++]=s>>12|224,e[t++]=s>>6&63|128,e[t++]=s&63|128);return t-n}function _e(r,e){return RangeError(`index out of range: ${r.pos} + ${e??1} > ${r.len}`)}function cn(r,e){return(r[e-4]|r[e-3]<<8|r[e-2]<<16|r[e-1]<<24)>>>0}var io=class{buf;pos;len;_slice=Uint8Array.prototype.subarray;constructor(e){this.buf=e,this.pos=0,this.len=e.length}uint32(){let e=4294967295;if(e=(this.buf[this.pos]&127)>>>0,this.buf[this.pos++]<128||(e=(e|(this.buf[this.pos]&127)<<7)>>>0,this.buf[this.pos++]<128)||(e=(e|(this.buf[this.pos]&127)<<14)>>>0,this.buf[this.pos++]<128)||(e=(e|(this.buf[this.pos]&127)<<21)>>>0,this.buf[this.pos++]<128)||(e=(e|(this.buf[this.pos]&15)<<28)>>>0,this.buf[this.pos++]<128))return e;if((this.pos+=5)>this.len)throw this.pos=this.len,_e(this,10);return e}int32(){return this.uint32()|0}sint32(){let e=this.uint32();return e>>>1^-(e&1)|0}bool(){return this.uint32()!==0}fixed32(){if(this.pos+4>this.len)throw _e(this,4);return cn(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw _e(this,4);return cn(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw _e(this,4);let e=qi(this.buf,this.pos);return this.pos+=4,e}double(){if(this.pos+8>this.len)throw _e(this,4);let e=Gi(this.buf,this.pos);return this.pos+=8,e}bytes(){let e=this.uint32(),t=this.pos,n=this.pos+e;if(n>this.len)throw _e(this,e);return this.pos+=e,t===n?new Uint8Array(0):this.buf.subarray(t,n)}string(){let e=this.bytes();return Zi(e,0,e.length)}skip(e){if(typeof e=="number"){if(this.pos+e>this.len)throw _e(this,e);this.pos+=e}else do if(this.pos>=this.len)throw _e(this);while(this.buf[this.pos++]&128);return this}skipType(e){switch(e){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;(e=this.uint32()&7)!==4;)this.skipType(e);break;case 5:this.skip(4);break;default:throw Error(`invalid wire type ${e} at offset ${this.pos}`)}return this}readLongVarint(){let e=new Ie(0,0),t=0;if(this.len-this.pos>4){for(;t<4;++t)if(e.lo=(e.lo|(this.buf[this.pos]&127)<<t*7)>>>0,this.buf[this.pos++]<128)return e;if(e.lo=(e.lo|(this.buf[this.pos]&127)<<28)>>>0,e.hi=(e.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return e;t=0}else{for(;t<3;++t){if(this.pos>=this.len)throw _e(this);if(e.lo=(e.lo|(this.buf[this.pos]&127)<<t*7)>>>0,this.buf[this.pos++]<128)return e}return e.lo=(e.lo|(this.buf[this.pos++]&127)<<t*7)>>>0,e}if(this.len-this.pos>4){for(;t<5;++t)if(e.hi=(e.hi|(this.buf[this.pos]&127)<<t*7+3)>>>0,this.buf[this.pos++]<128)return e}else for(;t<5;++t){if(this.pos>=this.len)throw _e(this);if(e.hi=(e.hi|(this.buf[this.pos]&127)<<t*7+3)>>>0,this.buf[this.pos++]<128)return e}throw Error("invalid varint encoding")}readFixed64(){if(this.pos+8>this.len)throw _e(this,8);let e=cn(this.buf,this.pos+=4),t=cn(this.buf,this.pos+=4);return new Ie(e,t)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){let e=ro(this.buf,this.pos);return this.pos+=Je(e),e}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 ao(r){return new io(r instanceof Uint8Array?r:r.subarray())}function Ct(r,e,t){let n=ao(r);return e.decode(n,void 0,t)}function co(r){let e=r??8192,t=e>>>1,n,s=e;return function(i){if(i<1||i>t)return Be(i);s+i>e&&(n=Be(e),s=0);let a=n.subarray(s,s+=i);return s&7&&(s=(s|7)+1),a}}var _t=class{fn;len;next;val;constructor(e,t,n){this.fn=e,this.len=t,this.next=void 0,this.val=n}};function lo(){}var fo=class{head;tail;len;next;constructor(e){this.head=e.head,this.tail=e.tail,this.len=e.len,this.next=e.states}},Xu=co();function Qu(r){return globalThis.Buffer!=null?Be(r):Xu(r)}var Rr=class{len;head;tail;states;constructor(){this.len=0,this.head=new _t(lo,0,0),this.tail=this.head,this.states=null}_push(e,t,n){return this.tail=this.tail.next=new _t(e,t,n),this.len+=t,this}uint32(e){return this.len+=(this.tail=this.tail.next=new ho((e=e>>>0)<128?1:e<16384?2:e<2097152?3:e<268435456?4:5,e)).len,this}int32(e){return e<0?this._push(ln,10,Ie.fromNumber(e)):this.uint32(e)}sint32(e){return this.uint32((e<<1^e>>31)>>>0)}uint64(e){let t=Ie.fromBigInt(e);return this._push(ln,t.length(),t)}uint64Number(e){return this._push(to,Je(e),e)}uint64String(e){return this.uint64(BigInt(e))}int64(e){return this.uint64(e)}int64Number(e){return this.uint64Number(e)}int64String(e){return this.uint64String(e)}sint64(e){let t=Ie.fromBigInt(e).zzEncode();return this._push(ln,t.length(),t)}sint64Number(e){let t=Ie.fromNumber(e).zzEncode();return this._push(ln,t.length(),t)}sint64String(e){return this.sint64(BigInt(e))}bool(e){return this._push(uo,1,e?1:0)}fixed32(e){return this._push(Ir,4,e>>>0)}sfixed32(e){return this.fixed32(e)}fixed64(e){let t=Ie.fromBigInt(e);return this._push(Ir,4,t.lo)._push(Ir,4,t.hi)}fixed64Number(e){let t=Ie.fromNumber(e);return this._push(Ir,4,t.lo)._push(Ir,4,t.hi)}fixed64String(e){return this.fixed64(BigInt(e))}sfixed64(e){return this.fixed64(e)}sfixed64Number(e){return this.fixed64Number(e)}sfixed64String(e){return this.fixed64String(e)}float(e){return this._push(Fi,4,e)}double(e){return this._push($i,8,e)}bytes(e){let t=e.length>>>0;return t===0?this._push(uo,1,0):this.uint32(t)._push(tf,t,e)}string(e){let t=zi(e);return t!==0?this.uint32(t)._push(oo,t,e):this._push(uo,1,0)}fork(){return this.states=new fo(this),this.head=this.tail=new _t(lo,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 _t(lo,0,0),this.len=0),this}ldelim(){let e=this.head,t=this.tail,n=this.len;return this.reset().uint32(n),n!==0&&(this.tail.next=e.next,this.tail=t,this.len+=n),this}finish(){let e=this.head.next,t=Qu(this.len),n=0;for(;e!=null;)e.fn(e.val,t,n),n+=e.len,e=e.next;return t}};function uo(r,e,t){e[t]=r&255}function ef(r,e,t){for(;r>127;)e[t++]=r&127|128,r>>>=7;e[t]=r}var ho=class extends _t{next;constructor(e,t){super(ef,e,t),this.next=void 0}};function ln(r,e,t){for(;r.hi!==0;)e[t++]=r.lo&127|128,r.lo=(r.lo>>>7|r.hi<<25)>>>0,r.hi>>>=7;for(;r.lo>127;)e[t++]=r.lo&127|128,r.lo=r.lo>>>7;e[t++]=r.lo}function Ir(r,e,t){e[t]=r&255,e[t+1]=r>>>8&255,e[t+2]=r>>>16&255,e[t+3]=r>>>24}function tf(r,e,t){e.set(r,t)}globalThis.Buffer!=null&&(Rr.prototype.bytes=function(r){let e=r.length>>>0;return this.uint32(e),e>0&&this._push(rf,e,r),this},Rr.prototype.string=function(r){let e=globalThis.Buffer.byteLength(r);return this.uint32(e),e>0&&this._push(nf,e,r),this});function rf(r,e,t){e.set(r,t)}function nf(r,e,t){r.length<40?oo(r,e,t):e.utf8Write!=null?e.utf8Write(r,t):e.set(z(r),t)}function po(){return new Rr}function Ut(r,e){let t=po();return e.encode(r,t,{lengthDelimited:!1}),t.finish()}var sr;(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"})(sr||(sr={}));function un(r,e,t,n){return{name:r,type:e,encode:t,decode:n}}function Nr(r){function e(s){if(r[s.toString()]==null)throw new Error("Invalid enum value");return r[s]}let t=function(o,i){let a=e(o);i.int32(a)},n=function(o){let i=o.int32();return e(i)};return un("enum",sr.VARINT,t,n)}function Vt(r,e){return un("message",sr.LENGTH_DELIMITED,r,e)}var fe;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.Secp256k1="Secp256k1"})(fe||(fe={}));var go;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.Secp256k1=2]="Secp256k1"})(go||(go={}));(function(r){r.codec=()=>Nr(go)})(fe||(fe={}));var mt;(function(r){let e;r.codec=()=>(e==null&&(e=Vt((t,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),t.Type!=null&&(n.uint32(8),fe.codec().encode(t.Type,n)),t.Data!=null&&(n.uint32(18),n.bytes(t.Data)),s.lengthDelimited!==!1&&n.ldelim()},(t,n)=>{let s={},o=n==null?t.len:t.pos+n;for(;t.pos<o;){let i=t.uint32();switch(i>>>3){case 1:s.Type=fe.codec().decode(t);break;case 2:s.Data=t.bytes();break;default:t.skipType(i&7);break}}return s})),e),r.encode=t=>Ut(t,r.codec()),r.decode=t=>Ct(t,r.codec())})(mt||(mt={}));var bt;(function(r){let e;r.codec=()=>(e==null&&(e=Vt((t,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),t.Type!=null&&(n.uint32(8),fe.codec().encode(t.Type,n)),t.Data!=null&&(n.uint32(18),n.bytes(t.Data)),s.lengthDelimited!==!1&&n.ldelim()},(t,n)=>{let s={},o=n==null?t.len:t.pos+n;for(;t.pos<o;){let i=t.uint32();switch(i>>>3){case 1:s.Type=fe.codec().decode(t);break;case 2:s.Data=t.bytes();break;default:t.skipType(i&7);break}}return s})),e),r.encode=t=>Ut(t,r.codec()),r.decode=t=>Ct(t,r.codec())})(bt||(bt={}));var Tr=class{_key;constructor(e){this._key=or(e,rr)}verify(e,t){return Oi(this._key,t,e)}marshal(){return this._key}get bytes(){return mt.encode({Type:fe.Ed25519,Data:this.marshal()}).subarray()}equals(e){return ve(this.bytes,e.bytes)}hash(){let e=ue.digest(this.bytes);return Re(e)?e.then(({bytes:t})=>t):e.bytes}},Dt=class{_key;_publicKey;constructor(e,t){this._key=or(e,Ye),this._publicKey=or(t,rr)}sign(e){return Di(this._key,e)}get public(){return new Tr(this._publicKey)}marshal(){return this._key}get bytes(){return bt.encode({Type:fe.Ed25519,Data:this.marshal()}).subarray()}equals(e){return ve(this.bytes,e.bytes)}async hash(){let e=ue.digest(this.bytes),t;return Re(e)?{bytes:t}=await e:t=e.bytes,t}async id(){let e=$e.digest(this.public.bytes);return me.encode(e.bytes).substring(1)}async export(e,t="libp2p-key"){if(t==="libp2p-key")return nr(this.bytes,e);throw new D(`export format '${t}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function sf(r){if(r.length>Ye){r=or(r,Ye+rr);let n=r.subarray(0,Ye),s=r.subarray(Ye,r.length);return new Dt(n,s)}r=or(r,Ye);let e=r.subarray(0,Ye),t=r.subarray(rr);return new Dt(e,t)}function of(r){return r=or(r,rr),new Tr(r)}async function af(){let{privateKey:r,publicKey:e}=Ui();return new Dt(r,e)}async function Yi(r){let{privateKey:e,publicKey:t}=Vi(r);return new Dt(e,t)}function or(r,e){if(r=Uint8Array.from(r??[]),r.length!==e)throw new D(`Key must be a Uint8Array of length ${e}, got ${r.length}`,"ERR_INVALID_KEY_TYPE");return r}function ne(r,e="utf8"){let t=Yr[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return t.encoder.encode(r).substring(1)}var Io={};ie(Io,{MAX_RSA_KEY_SIZE:()=>Fr,RsaPrivateKey:()=>ur,RsaPublicKey:()=>Kr,fromJwk:()=>Uf,generateKeyPair:()=>Vf,unmarshalRsaPrivateKey:()=>ko,unmarshalRsaPublicKey:()=>_f});function Ot(r){if(isNaN(r)||r<=0)throw new D("random bytes length must be a Number bigger than 0","ERR_INVALID_LENGTH");return Xt(r)}var Bt={};ie(Bt,{exportToPem:()=>Rf,importFromPem:()=>Nf,jwkToPkcs1:()=>Af,jwkToPkix:()=>Sf,pkcs1ToJwk:()=>Ef,pkixToJwk:()=>kf});var fn=class extends Yt{constructor(e,t){super(),this.finished=!1,this.destroyed=!1,Jr(e);let n=lt(t);if(this.iHash=e.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?e.create().update(n).digest():n);for(let i=0;i<o.length;i++)o[i]^=54;this.iHash.update(o),this.oHash=e.create();for(let i=0;i<o.length;i++)o[i]^=106;this.oHash.update(o),o.fill(0)}update(e){return Wt(this),this.iHash.update(e),this}digestInto(e){Wt(this),Zt(e,this.outputLen),this.finished=!0,this.iHash.digestInto(e),this.oHash.update(e),this.oHash.digestInto(e),this.destroy()}digest(){let e=new Uint8Array(this.oHash.outputLen);return this.digestInto(e),e}_cloneInto(e){e||(e=Object.create(Object.getPrototypeOf(this),{}));let{oHash:t,iHash:n,finished:s,destroyed:o,blockLen:i,outputLen:a}=this;return e=e,e.finished=s,e.destroyed=o,e.blockLen=i,e.outputLen=a,e.oHash=t._cloneInto(e.oHash),e.iHash=n._cloneInto(e.iHash),e}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},Lr=(r,e,t)=>new fn(r,e).update(t).digest();Lr.create=(r,e)=>new fn(r,e);function cf(r,e,t,n){Jr(r);let s=wi({dkLen:32,asyncTick:10},n),{c:o,dkLen:i,asyncTick:a}=s;if(zt(o),zt(i),zt(a),o<1)throw new Error("PBKDF2: iterations (c) should be >= 1");let c=lt(e),f=lt(t),l=new Uint8Array(i),u=Lr.create(r,c),h=u._cloneInto().update(f);return{c:o,dkLen:i,asyncTick:a,DK:l,PRF:u,PRFSalt:h}}function lf(r,e,t,n,s){return r.destroy(),e.destroy(),n&&n.destroy(),s.fill(0),t}async function bo(r,e,t,n){let{c:s,dkLen:o,asyncTick:i,DK:a,PRF:c,PRFSalt:f}=cf(r,e,t,n),l,u=new Uint8Array(4),h=Jt(u),w=new Uint8Array(c.outputLen);for(let x=1,y=0;y<o;x++,y+=c.outputLen){let d=a.subarray(y,y+c.outputLen);h.setInt32(0,x,!1),(l=f._cloneInto(l)).update(u).digestInto(w),d.set(w.subarray(0,d.length)),await mi(s-1,i,()=>{c._cloneInto(l).update(w).digestInto(w);for(let b=0;b<d.length;b++)d[b]^=w[b]})}return lf(c,f,a,l,w)}var M=Tc(Ji());function Ht(r,e){let t=0;if(r.length===1)return r[0];for(let n=r.length-1;n>=0;n--)t+=r[r.length-1-n]*Math.pow(2,e*n);return t}function wt(r,e,t=-1){let n=t,s=r,o=0,i=Math.pow(2,e);for(let a=1;a<8;a++){if(r<i){let c;if(n<0)c=new ArrayBuffer(a),o=a;else{if(n<a)return new ArrayBuffer(0);c=new ArrayBuffer(n),o=n}let f=new Uint8Array(c);for(let l=a-1;l>=0;l--){let u=Math.pow(2,l*e);f[o-l-1]=Math.floor(s/u),s-=f[o-l-1]*u}return c}i*=Math.pow(2,e)}return new ArrayBuffer(0)}function pn(...r){let e=0,t=0;for(let o of r)e+=o.length;let n=new ArrayBuffer(e),s=new Uint8Array(n);for(let o of r)s.set(o,t),t+=o.length;return s}function xo(){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 e=new ArrayBuffer(this.valueHex.byteLength),t=new Uint8Array(e);for(let a=0;a<this.valueHex.byteLength;a++)t[a]=0;t[0]=r[0]&128;let n=Ht(t,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,Ht(o,8)-n}function Xi(r){let e=r<0?r*-1:r,t=128;for(let n=1;n<8;n++){if(e<=t){if(r<0){let i=t-e,a=wt(i,8,n),c=new Uint8Array(a);return c[0]|=128,a}let s=wt(e,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}t*=Math.pow(2,8)}return new ArrayBuffer(0)}function Qi(r,e){if(r.byteLength!==e.byteLength)return!1;let t=new Uint8Array(r),n=new Uint8Array(e);for(let s=0;s<t.length;s++)if(t[s]!==n[s])return!1;return!0}function ke(r,e){let t=r.toString(10);if(e<t.length)return"";let n=e-t.length,s=new Array(n);for(let i=0;i<n;i++)s[i]="0";return s.join("").concat(t)}var hp=Math.log(2);function gn(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function vo(r){let e=0,t=0;for(let s=0;s<r.length;s++){let o=r[s];e+=o.byteLength}let n=new Uint8Array(e);for(let s=0;s<r.length;s++){let o=r[s];n.set(new Uint8Array(o),t),t+=o.byteLength}return n.buffer}function rt(r,e,t,n){return e instanceof Uint8Array?e.byteLength?t<0?(r.error="Wrong parameter: inputOffset less than zero",!1):n<0?(r.error="Wrong parameter: inputLength less than zero",!1):e.byteLength-t-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 _r=class{constructor(){this.items=[]}write(e){this.items.push(e)}final(){return vo(this.items)}},Cr=[new Uint8Array([1])],ea="0123456789";var cr="",Ve=new ArrayBuffer(0),Bo=new Uint8Array(0),Ur="EndOfContent",ra="OCTET STRING",na="BIT STRING";function nt(r){var e;return e=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):Bo}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(!rt(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",Ve)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:M.Convert.ToHex(this.valueHexView)}}},e.NAME="hexBlock",e}var Qe=class{constructor({blockLength:e=0,error:t=cr,warnings:n=[],valueBeforeDecode:s=Bo}={}){this.blockLength=e,this.error=t,this.warnings=n,this.valueBeforeDecodeView=M.BufferSourceConverter.toUint8Array(s)}static blockName(){return this.NAME}get valueBeforeDecode(){return this.valueBeforeDecodeView.slice().buffer}set valueBeforeDecode(e){this.valueBeforeDecodeView=new Uint8Array(e)}toJSON(){return{blockName:this.constructor.NAME,blockLength:this.blockLength,error:this.error,warnings:this.warnings,valueBeforeDecode:M.Convert.ToHex(this.valueBeforeDecodeView)}}};Qe.NAME="baseBlock";var ge=class extends Qe{fromBER(e,t,n){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}toBER(e,t){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}};ge.NAME="valueBlock";var yn=class extends nt(Qe){constructor({idBlock:e={}}={}){var t,n,s,o;super(),e?(this.isHexOnly=(t=e.isHexOnly)!==null&&t!==void 0?t:!1,this.valueHexView=e.valueHex?M.BufferSourceConverter.toUint8Array(e.valueHex):Bo,this.tagClass=(n=e.tagClass)!==null&&n!==void 0?n:-1,this.tagNumber=(s=e.tagNumber)!==null&&s!==void 0?s:-1,this.isConstructed=(o=e.isConstructed)!==null&&o!==void 0?o:!1):(this.tagClass=-1,this.tagNumber=-1,this.isConstructed=!1)}toBER(e=!1){let t=0;switch(this.tagClass){case 1:t|=0;break;case 2:t|=64;break;case 3:t|=128;break;case 4:t|=192;break;default:return this.error="Unknown tag class",Ve}if(this.isConstructed&&(t|=32),this.tagNumber<31&&!this.isHexOnly){let s=new Uint8Array(1);if(!e){let o=this.tagNumber;o&=31,t|=o,s[0]=t}return s.buffer}if(!this.isHexOnly){let s=wt(this.tagNumber,7),o=new Uint8Array(s),i=s.byteLength,a=new Uint8Array(i+1);if(a[0]=t|31,!e){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]=t|31,!e){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(e,t,n){let s=M.BufferSourceConverter.toUint8Array(e);if(!rt(this,s,t,n))return-1;let o=s.subarray(t,t+n);if(o.length===0)return this.error="Zero buffer length",-1;switch(o[0]&192){case 0:this.tagClass=1;break;case 64:this.tagClass=2;break;case 128:this.tagClass=3;break;case 192:this.tagClass=4;break;default:return this.error="Unknown tag class",-1}this.isConstructed=(o[0]&32)===32,this.isHexOnly=!1;let a=o[0]&31;if(a!==31)this.tagNumber=a,this.blockLength=1;else{let c=1,f=this.valueHexView=new Uint8Array(255),l=255;for(;o[c]&128;){if(f[c-1]=o[c]&127,c++,c>=o.length)return this.error="End of input reached before message was fully decoded",-1;if(c===l){l+=255;let h=new Uint8Array(l);for(let w=0;w<f.length;w++)h[w]=f[w];f=this.valueHexView=new Uint8Array(l)}}this.blockLength=c+1,f[c-1]=o[c]&127;let u=new Uint8Array(c);for(let h=0;h<c;h++)u[h]=f[h];f=this.valueHexView=new Uint8Array(c),f.set(u),this.blockLength<=9?this.tagNumber=Ht(f,7):(this.isHexOnly=!0,this.warnings.push("Tag too long, represented as hex-coded"))}if(this.tagClass===1&&this.isConstructed)switch(this.tagNumber){case 1:case 2:case 5:case 6:case 9:case 13:case 14:case 23:case 24:case 31:case 32:case 33:case 34:return this.error="Constructed encoding used for primitive type",-1}return t+this.blockLength}toJSON(){return{...super.toJSON(),tagClass:this.tagClass,tagNumber:this.tagNumber,isConstructed:this.isConstructed}}};yn.NAME="identificationBlock";var mn=class extends Qe{constructor({lenBlock:e={}}={}){var t,n,s;super(),this.isIndefiniteForm=(t=e.isIndefiniteForm)!==null&&t!==void 0?t:!1,this.longFormUsed=(n=e.longFormUsed)!==null&&n!==void 0?n:!1,this.length=(s=e.length)!==null&&s!==void 0?s:0}fromBER(e,t,n){let s=M.BufferSourceConverter.toUint8Array(e);if(!rt(this,s,t,n))return-1;let o=s.subarray(t,t+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,t+this.blockLength;if(this.longFormUsed=!!(o[0]&128),this.longFormUsed===!1)return this.length=o[0],this.blockLength=1,t+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=t+1,c=s.subarray(a,a+i);return c[i-1]===0&&this.warnings.push("Needlessly long encoded length"),this.length=Ht(c,8),this.longFormUsed&&this.length<=127&&this.warnings.push("Unnecessary usage of long length form"),this.blockLength=i+1,t+this.blockLength}toBER(e=!1){let t,n;if(this.length>127&&(this.longFormUsed=!0),this.isIndefiniteForm)return t=new ArrayBuffer(1),e===!1&&(n=new Uint8Array(t),n[0]=128),t;if(this.longFormUsed){let s=wt(this.length,8);if(s.byteLength>127)return this.error="Too big length",Ve;if(t=new ArrayBuffer(s.byteLength+1),e)return t;let o=new Uint8Array(s);n=new Uint8Array(t),n[0]=s.byteLength|128;for(let i=0;i<s.byteLength;i++)n[i+1]=o[i];return t}return t=new ArrayBuffer(1),e===!1&&(n=new Uint8Array(t),n[0]=this.length),t}toJSON(){return{...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,longFormUsed:this.longFormUsed,length:this.length}}};mn.NAME="lengthBlock";var k={},he=class extends Qe{constructor({name:e=cr,optional:t=!1,primitiveSchema:n,...s}={},o){super(s),this.name=e,this.optional=t,n&&(this.primitiveSchema=n),this.idBlock=new yn(s),this.lenBlock=new mn(s),this.valueBlock=o?new o(s):new ge(s)}fromBER(e,t,n){let s=this.valueBlock.fromBER(e,t,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(e,t){let n=t||new _r;t||sa(this);let s=this.idBlock.toBER(e);if(n.write(s),this.lenBlock.isIndefiniteForm)n.write(new Uint8Array([128]).buffer),this.valueBlock.toBER(e,n),n.write(new ArrayBuffer(2));else{let o=this.valueBlock.toBER(e);this.lenBlock.length=o.byteLength;let i=this.lenBlock.toBER(e);n.write(i),n.write(o)}return t?Ve:n.final()}toJSON(){let e={...super.toJSON(),idBlock:this.idBlock.toJSON(),lenBlock:this.lenBlock.toJSON(),valueBlock:this.valueBlock.toJSON(),name:this.name,optional:this.optional};return this.primitiveSchema&&(e.primitiveSchema=this.primitiveSchema.toJSON()),e}toString(e="ascii"){return e==="ascii"?this.onAsciiEncoding():M.Convert.ToHex(this.toBER())}onAsciiEncoding(){return`${this.constructor.NAME} : ${M.Convert.ToHex(this.valueBlock.valueBeforeDecodeView)}`}isEqual(e){if(this===e)return!0;if(!(e instanceof this.constructor))return!1;let t=this.toBER(),n=e.toBER();return Qi(t,n)}};he.NAME="BaseBlock";function sa(r){if(r instanceof k.Constructed)for(let e of r.valueBlock.value)sa(e)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var bn=class extends he{constructor({value:e=cr,...t}={},n){super(t,n),e&&this.fromString(e)}getValue(){return this.valueBlock.value}setValue(e){this.valueBlock.value=e}fromBER(e,t,n){let s=this.valueBlock.fromBER(e,t,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}'`}};bn.NAME="BaseStringBlock";var wn=class extends nt(ge){constructor({isHexOnly:e=!0,...t}={}){super(t),this.isHexOnly=e}};wn.NAME="PrimitiveValueBlock";var oa,xn=class extends he{constructor(e={}){super(e,wn),this.idBlock.isConstructed=!1}};oa=xn;k.Primitive=oa;xn.NAME="PRIMITIVE";function bf(r,e){if(r instanceof e)return r;let t=new e;return t.idBlock=r.idBlock,t.lenBlock=r.lenBlock,t.warnings=r.warnings,t.valueBeforeDecodeView=r.valueBeforeDecodeView,t}function Qn(r,e=0,t=r.length){let n=e,s=new he({},ge),o=new Qe;if(!rt(o,r,e,t))return s.error=o.error,{offset:-1,result:s};if(!r.subarray(e,e+t).length)return s.error="Zero buffer length",{offset:-1,result:s};let a=s.idBlock.fromBER(r,e,t);if(s.idBlock.warnings.length&&s.warnings.concat(s.idBlock.warnings),a===-1)return s.error=s.idBlock.error,{offset:-1,result:s};if(e=a,t-=s.idBlock.blockLength,a=s.lenBlock.fromBER(r,e,t),s.lenBlock.warnings.length&&s.warnings.concat(s.lenBlock.warnings),a===-1)return s.error=s.lenBlock.error,{offset:-1,result:s};if(e=a,t-=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=he;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=k.EndOfContent;break;case 1:c=k.Boolean;break;case 2:c=k.Integer;break;case 3:c=k.BitString;break;case 4:c=k.OctetString;break;case 5:c=k.Null;break;case 6:c=k.ObjectIdentifier;break;case 10:c=k.Enumerated;break;case 12:c=k.Utf8String;break;case 13:c=k.RelativeObjectIdentifier;break;case 14:c=k.TIME;break;case 15:return s.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:s};case 16:c=k.Sequence;break;case 17:c=k.Set;break;case 18:c=k.NumericString;break;case 19:c=k.PrintableString;break;case 20:c=k.TeletexString;break;case 21:c=k.VideotexString;break;case 22:c=k.IA5String;break;case 23:c=k.UTCTime;break;case 24:c=k.GeneralizedTime;break;case 25:c=k.GraphicString;break;case 26:c=k.VisibleString;break;case 27:c=k.GeneralString;break;case 28:c=k.UniversalString;break;case 29:c=k.CharacterString;break;case 30:c=k.BmpString;break;case 31:c=k.DATE;break;case 32:c=k.TimeOfDay;break;case 33:c=k.DateTime;break;case 34:c=k.Duration;break;default:{let f=s.idBlock.isConstructed?new k.Constructed:new k.Primitive;f.idBlock=s.idBlock,f.lenBlock=s.lenBlock,f.warnings=s.warnings,s=f}}break;case 2:case 3:case 4:default:c=s.idBlock.isConstructed?k.Constructed:k.Primitive}return s=bf(s,c),a=s.fromBER(r,e,s.lenBlock.isIndefiniteForm?t:s.lenBlock.length),s.valueBeforeDecodeView=r.subarray(n,n+s.blockLength),{offset:a,result:s}}function lr(r){if(!r.byteLength){let e=new he({},ge);return e.error="Input buffer has zero length",{offset:-1,result:e}}return Qn(M.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function wf(r,e){return r?1:e}var Pe=class extends ge{constructor({value:e=[],isIndefiniteForm:t=!1,...n}={}){super(n),this.value=e,this.isIndefiniteForm=t}fromBER(e,t,n){let s=M.BufferSourceConverter.toUint8Array(e);if(!rt(this,s,t,n))return-1;if(this.valueBeforeDecodeView=s.subarray(t,t+n),this.valueBeforeDecodeView.length===0)return this.warnings.push("Zero buffer length"),t;let o=t;for(;wf(this.isIndefiniteForm,n)>0;){let i=Qn(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===Ur)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===Ur?this.value.pop():this.warnings.push("No EndOfContent block encoded")),o}toBER(e,t){let n=t||new _r;for(let s=0;s<this.value.length;s++)this.value[s].toBER(e,n);return t?Ve:n.final()}toJSON(){let e={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let t of this.value)e.value.push(t.toJSON());return e}};Pe.NAME="ConstructedValueBlock";var ia,xt=class extends he{constructor(e={}){super(e,Pe),this.idBlock.isConstructed=!0}fromBER(e,t,n){this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm;let s=this.valueBlock.fromBER(e,t,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 e=[];for(let n of this.valueBlock.value)e.push(n.toString("ascii").split(`
|
|
2
|
+
"use strict";var Libp2PPlaintext=(()=>{var sc=Object.create;var vr=Object.defineProperty;var oc=Object.getOwnPropertyDescriptor;var ic=Object.getOwnPropertyNames;var ac=Object.getPrototypeOf,cc=Object.prototype.hasOwnProperty;var lc=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),ht=(r,t)=>{for(var e in t)vr(r,e,{get:t[e],enumerable:!0})},Co=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of ic(t))!cc.call(r,s)&&s!==e&&vr(r,s,{get:()=>t[s],enumerable:!(n=oc(t,s))||n.enumerable});return r};var uc=(r,t,e)=>(e=r!=null?sc(ac(r)):{},Co(t||!r||!r.__esModule?vr(e,"default",{value:r,enumerable:!0}):e,r)),fc=r=>Co(vr({},"__esModule",{value:!0}),r);var Ti=lc($e=>{"use strict";var Du="[object ArrayBuffer]",qt=class r{static isArrayBuffer(t){return Object.prototype.toString.call(t)===Du}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}},so="string",Ou=/^[0-9a-f]+$/i,Mu=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,Pu=/^[a-zA-Z0-9-_]+$/,$r=class{static fromString(t){let e=unescape(encodeURIComponent(t)),n=new Uint8Array(e.length);for(let s=0;s<e.length;s++)n[s]=e.charCodeAt(s);return n.buffer}static toString(t){let e=qt.toUint8Array(t),n="";for(let o=0;o<e.length;o++)n+=String.fromCharCode(e[o]);return decodeURIComponent(escape(n))}},St=class{static toString(t,e=!1){let n=qt.toArrayBuffer(t),s=new DataView(n),o="";for(let i=0;i<n.byteLength;i+=2){let a=s.getUint16(i,e);o+=String.fromCharCode(a)}return o}static fromString(t,e=!1){let n=new ArrayBuffer(t.length*2),s=new DataView(n);for(let o=0;o<t.length;o++)s.setUint16(o*2,t.charCodeAt(o),e);return n}},qr=class r{static isHex(t){return typeof t===so&&Ou.test(t)}static isBase64(t){return typeof t===so&&Mu.test(t)}static isBase64Url(t){return typeof t===so&&Pu.test(t)}static ToString(t,e="utf8"){let n=qt.toUint8Array(t);switch(e.toLowerCase()){case"utf8":return this.ToUtf8String(n);case"binary":return this.ToBinary(n);case"hex":return this.ToHex(n);case"base64":return this.ToBase64(n);case"base64url":return this.ToBase64Url(n);case"utf16le":return St.toString(n,!0);case"utf16":case"utf16be":return St.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 St.fromString(t,!0);case"utf16":case"utf16be":return St.fromString(t);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToBase64(t){let e=qt.toUint8Array(t);if(typeof btoa<"u"){let n=this.ToString(e,"binary");return btoa(n)}else return Buffer.from(e).toString("base64")}static FromBase64(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isBase64(e))throw new TypeError("Argument 'base64Text' is not Base64 encoded");return typeof atob<"u"?this.FromBinary(atob(e)):new Uint8Array(Buffer.from(e,"base64")).buffer}static FromBase64Url(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isBase64Url(e))throw new TypeError("Argument 'base64url' is not Base64Url encoded");return this.FromBase64(this.Base64Padding(e.replace(/\-/g,"+").replace(/\_/g,"/")))}static ToBase64Url(t){return this.ToBase64(t).replace(/\+/g,"-").replace(/\//g,"_").replace(/\=/g,"")}static FromUtf8String(t,e=r.DEFAULT_UTF8_ENCODING){switch(e){case"ascii":return this.FromBinary(t);case"utf8":return $r.fromString(t);case"utf16":case"utf16be":return St.fromString(t);case"utf16le":case"usc2":return St.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 $r.toString(t);case"utf16":case"utf16be":return St.toString(t);case"utf16le":case"usc2":return St.toString(t,!0);default:throw new Error(`Unknown type of encoding '${e}'`)}}static FromBinary(t){let e=t.length,n=new Uint8Array(e);for(let s=0;s<e;s++)n[s]=t.charCodeAt(s);return n.buffer}static ToBinary(t){let e=qt.toUint8Array(t),n="";for(let s=0;s<e.length;s++)n+=String.fromCharCode(e[s]);return n}static ToHex(t){let e=qt.toUint8Array(t),n="",s=e.length;for(let o=0;o<s;o++){let i=e[o];i<16&&(n+="0"),n+=i.toString(16)}return n}static FromHex(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isHex(e))throw new TypeError("Argument 'hexString' is not HEX encoded");e.length%2&&(e=`0${e}`);let n=new Uint8Array(e.length/2);for(let s=0;s<e.length;s=s+2){let o=e.slice(s,s+2);n[s/2]=parseInt(o,16)}return n.buffer}static ToUtf16String(t,e=!1){return St.toString(t,e)}static FromUtf16String(t,e=!1){return St.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,"")||""}};qr.DEFAULT_UTF8_ENCODING="utf8";function Fu(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 $u(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}$e.BufferSourceConverter=qt;$e.Convert=qr;$e.assign=Fu;$e.combine=Ku;$e.isEqual=$u});var ff={};ht(ff,{plaintext:()=>uf});var Yn=Symbol.for("@libp2p/peer-id");var Br=class extends Error{static name="UnexpectedPeerError";constructor(t="Unexpected Peer"){super(t),this.name="UnexpectedPeerError"}},Xe=class extends Error{static name="InvalidCryptoExchangeError";constructor(t="Invalid crypto exchange"){super(t),this.name="InvalidCryptoExchangeError"}},dt=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"}};var Ce=class extends Error{static name="ProtocolError";constructor(t="Protocol error"){super(t),this.name="ProtocolError"}};var Er=class extends Error{static name="UnsupportedKeyTypeError";constructor(t="Unsupported key type"){super(t),this.name="UnsupportedKeyTypeError"}};var Uo=Symbol.for("@libp2p/service-capabilities"),pf=Symbol.for("@libp2p/service-dependencies");var rs={};ht(rs,{base58btc:()=>Q,base58flickr:()=>bc});var Mf=new Uint8Array(0);function To(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 Ot(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 Ro(r){return new TextDecoder().decode(r)}function hc(r,t){if(r.length>=255)throw new TypeError("Alphabet too long");for(var e=new Uint8Array(256),n=0;n<e.length;n++)e[n]=255;for(var s=0;s<r.length;s++){var o=r.charAt(s),i=o.charCodeAt(0);if(e[i]!==255)throw new TypeError(o+" is ambiguous");e[i]=s}var a=r.length,c=r.charAt(0),f=Math.log(a)/Math.log(256),l=Math.log(256)/Math.log(a);function u(v){if(v instanceof Uint8Array||(ArrayBuffer.isView(v)?v=new Uint8Array(v.buffer,v.byteOffset,v.byteLength):Array.isArray(v)&&(v=Uint8Array.from(v))),!(v instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(v.length===0)return"";for(var b=0,d=0,y=0,E=v.length;y!==E&&v[y]===0;)y++,b++;for(var p=(E-y)*l+1>>>0,S=new Uint8Array(p);y!==E;){for(var L=v[y],T=0,k=p-1;(L!==0||T<d)&&k!==-1;k--,T++)L+=256*S[k]>>>0,S[k]=L%a>>>0,L=L/a>>>0;if(L!==0)throw new Error("Non-zero carry");d=T,y++}for(var I=p-d;I!==p&&S[I]===0;)I++;for(var U=c.repeat(b);I<p;++I)U+=r.charAt(S[I]);return U}function h(v){if(typeof v!="string")throw new TypeError("Expected String");if(v.length===0)return new Uint8Array;var b=0;if(v[b]!==" "){for(var d=0,y=0;v[b]===c;)d++,b++;for(var E=(v.length-b)*f+1>>>0,p=new Uint8Array(E);v[b];){var S=e[v.charCodeAt(b)];if(S===255)return;for(var L=0,T=E-1;(S!==0||L<y)&&T!==-1;T--,L++)S+=a*p[T]>>>0,p[T]=S%256>>>0,S=S/256>>>0;if(S!==0)throw new Error("Non-zero carry");y=L,b++}if(v[b]!==" "){for(var k=E-y;k!==E&&p[k]===0;)k++;for(var I=new Uint8Array(d+(E-k)),U=d;k!==E;)I[U++]=p[k++];return I}}}function x(v){var b=h(v);if(b)return b;throw new Error(`Non-${t} character`)}return{encode:u,decodeUnsafe:h,decode:x}}var dc=hc,gc=dc,Vo=gc;var Xn=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")}},Qn=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 Ho(this,t)}},ts=class{decoders;constructor(t){this.decoders=t}or(t){return Ho(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 Ho(r,t){return new ts({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var es=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 Xn(t,e,n),this.decoder=new Qn(t,e,s)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function Ue({name:r,prefix:t,encode:e,decode:n}){return new es(r,t,e,n)}function te({name:r,prefix:t,alphabet:e}){let{encode:n,decode:s}=Vo(e,r);return Ue({prefix:t,name:r,encode:n,decode:o=>Ot(s(o))})}function pc(r,t,e,n){let s={};for(let l=0;l<t.length;++l)s[t[l]]=l;let o=r.length;for(;r[o-1]==="=";)--o;let i=new Uint8Array(o*e/8|0),a=0,c=0,f=0;for(let l=0;l<o;++l){let u=s[r[l]];if(u===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<e|u,a+=e,a>=8&&(a-=8,i[f++]=255&c>>a)}if(a>=e||255&c<<8-a)throw new SyntaxError("Unexpected end of data");return i}function mc(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 Z({name:r,prefix:t,bitsPerChar:e,alphabet:n}){return Ue({prefix:t,name:r,encode(s){return mc(s,n,e)},decode(s){return pc(s,n,e,r)}})}var Q=te({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),bc=te({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var ns={};ht(ns,{base32:()=>Te,base32hex:()=>vc,base32hexpad:()=>Ec,base32hexpadupper:()=>Ac,base32hexupper:()=>Bc,base32pad:()=>wc,base32padupper:()=>xc,base32upper:()=>yc,base32z:()=>Sc});var Te=Z({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),yc=Z({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),wc=Z({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),xc=Z({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),vc=Z({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),Bc=Z({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),Ec=Z({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),Ac=Z({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),Sc=Z({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var kc=Mo,Do=128,Ic=127,Nc=~Ic,Cc=Math.pow(2,31);function Mo(r,t,e){t=t||[],e=e||0;for(var n=e;r>=Cc;)t[e++]=r&255|Do,r/=128;for(;r&Nc;)t[e++]=r&255|Do,r>>>=7;return t[e]=r|0,Mo.bytes=e-n+1,t}var Uc=ss,Tc=128,Oo=127;function ss(r,n){var e=0,n=n||0,s=0,o=n,i,a=r.length;do{if(o>=a)throw ss.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>=Tc);return ss.bytes=o-n,e}var Lc=Math.pow(2,7),Rc=Math.pow(2,14),_c=Math.pow(2,21),Vc=Math.pow(2,28),Hc=Math.pow(2,35),Dc=Math.pow(2,42),Oc=Math.pow(2,49),Mc=Math.pow(2,56),Pc=Math.pow(2,63),Fc=function(r){return r<Lc?1:r<Rc?2:r<_c?3:r<Vc?4:r<Hc?5:r<Dc?6:r<Oc?7:r<Mc?8:r<Pc?9:10},Kc={encode:kc,decode:Uc,encodingLength:Fc},$c=Kc,Qe=$c;function tr(r,t=0){return[Qe.decode(r,t),Qe.decode.bytes]}function Le(r,t,e=0){return Qe.encode(r,t,e),t}function Re(r){return Qe.encodingLength(r)}function kt(r,t){let e=t.byteLength,n=Re(r),s=n+Re(e),o=new Uint8Array(s+e);return Le(r,o,0),Le(e,o,n),o.set(t,s),new _e(r,e,t,o)}function os(r){let t=Ot(r),[e,n]=tr(t),[s,o]=tr(t.subarray(n)),i=t.subarray(n+o);if(i.byteLength!==s)throw new Error("Incorrect length");return new _e(e,s,i,t)}function Po(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&To(r.bytes,e.bytes)}}var _e=class{code;size;digest;bytes;constructor(t,e,n,s){this.code=t,this.size=e,this.digest=n,this.bytes=s}};function Fo(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return zc(e,is(r),t??Q.encoder);default:return Gc(e,is(r),t??Te.encoder)}}var Ko=new WeakMap;function is(r){let t=Ko.get(r);if(t==null){let e=new Map;return Ko.set(r,e),e}return t}var Et=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!==er)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=kt(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&&Po(t.multihash,n.multihash)}toString(t){return Fo(this,t)}toJSON(){return{"/":Fo(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[Zc]===!0){let{version:n,multihash:s,code:o}=e,i=os(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!==er)throw new Error(`Version 0 CID must use dag-pb (code: ${er}) 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,er,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=Ot(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 _e(e.multihashCode,e.digestSize,o,s);return[e.version===0?r.createV0(i):r.createV1(e.codec,i),t.subarray(e.size)]}static inspectBytes(t){let e=0,n=()=>{let[u,h]=tr(t.subarray(e));return e+=h,u},s=n(),o=er;if(s===18?(s=0,e=0):o=n(),s!==0&&s!==1)throw new RangeError(`Invalid CID version ${s}`);let i=e,a=n(),c=n(),f=e+c,l=f-i;return{version:s,codec:o,multihashCode:a,digestSize:c,multihashSize:l,size:f}}static parse(t,e){let[n,s]=qc(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 is(o).set(n,t),o}};function qc(r,t){switch(r[0]){case"Q":{let e=t??Q;return[Q.prefix,e.decode(`${Q.prefix}${r}`)]}case Q.prefix:{let e=t??Q;return[Q.prefix,e.decode(r)]}case Te.prefix:{let e=t??Te;return[Te.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!==Q.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 Gc(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 er=112,jc=18;function $o(r,t,e){let n=Re(r),s=n+Re(t),o=new Uint8Array(s+e.byteLength);return Le(r,o,0),Le(t,o,n),o.set(e,s),o}var Zc=Symbol.for("@ipld/js-cid/CID");var as={};ht(as,{identity:()=>ee});var qo=0,Wc="identity",zo=Ot;function Jc(r){return kt(qo,zo(r))}var ee={code:qo,name:Wc,encode:zo,digest:Jc};function mt(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function Go(r){if(!Number.isSafeInteger(r)||r<0)throw new Error(`positive integer expected, not ${r}`)}function Yc(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function He(r,...t){if(!Yc(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 jo(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");Go(r.outputLen),Go(r.blockLen)}function De(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){He(r);let e=t.outputLen;if(r.length<e)throw new Error(`digestInto() expects output buffer of length at least ${e}`)}var pe=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;var Sr=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),It=(r,t)=>r<<32-t|r>>>t;var ih=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 rr(r){return typeof r=="string"&&(r=Wo(r)),He(r),r}function cs(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];He(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()}},ah={}.toString;function kr(r){let t=n=>r().update(rr(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function Ir(r=32){if(pe&&typeof pe.getRandomValues=="function")return pe.getRandomValues(new Uint8Array(r));if(pe&&typeof pe.randomBytes=="function")return pe.randomBytes(r);throw new Error("crypto.getRandomValues must be defined")}function Xc(r,t,e,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(t,e,n);let s=BigInt(32),o=BigInt(4294967295),i=Number(e>>s&o),a=Number(e&o),c=n?4:0,f=n?0:4;r.setUint32(t+c,i,n),r.setUint32(t+f,a,n)}var Jo=(r,t,e)=>r&t^~r&e,Yo=(r,t,e)=>r&t^r&e^t&e,Me=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=Sr(this.buffer)}update(t){De(this);let{view:e,buffer:n,blockLen:s}=this;t=rr(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=Sr(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){De(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 u=i;u<s;u++)e[u]=0;Xc(n,s-8,BigInt(this.length*8),o),this.process(n,0);let a=Sr(t),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let f=c/4,l=this.get();if(f>l.length)throw new Error("_sha2: outputLen bigger than state");for(let u=0;u<f;u++)a.setUint32(4*u,l[u],o)}digest(){let{buffer:t,outputLen:e}=this;this.digestInto(t);let n=t.slice(0,e);return this.destroy(),n}_cloneInto(t){t||(t=new this.constructor),t.set(...this.get());let{blockLen:e,buffer:n,length:s,finished:o,destroyed:i,pos:a}=this;return t.length=s,t.pos=a,t.finished=o,t.destroyed=i,s%e&&t.buffer.set(n),t}};var Nr=BigInt(4294967295),ls=BigInt(32);function Xo(r,t=!1){return t?{h:Number(r&Nr),l:Number(r>>ls&Nr)}:{h:Number(r>>ls&Nr)|0,l:Number(r&Nr)|0}}function Qc(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}=Xo(r[s],t);[e[s],n[s]]=[o,i]}return[e,n]}var tl=(r,t)=>BigInt(r>>>0)<<ls|BigInt(t>>>0),el=(r,t,e)=>r>>>e,rl=(r,t,e)=>r<<32-e|t>>>e,nl=(r,t,e)=>r>>>e|t<<32-e,sl=(r,t,e)=>r<<32-e|t>>>e,ol=(r,t,e)=>r<<64-e|t>>>e-32,il=(r,t,e)=>r>>>e-32|t<<64-e,al=(r,t)=>t,cl=(r,t)=>r,ll=(r,t,e)=>r<<e|t>>>32-e,ul=(r,t,e)=>t<<e|r>>>32-e,fl=(r,t,e)=>t<<e-32|r>>>64-e,hl=(r,t,e)=>r<<e-32|t>>>64-e;function dl(r,t,e,n){let s=(t>>>0)+(n>>>0);return{h:r+e+(s/2**32|0)|0,l:s|0}}var gl=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),pl=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,ml=(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,yl=(r,t,e,n,s)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(s>>>0),wl=(r,t,e,n,s,o)=>t+e+n+s+o+(r/2**32|0)|0;var xl={fromBig:Xo,split:Qc,toBig:tl,shrSH:el,shrSL:rl,rotrSH:nl,rotrSL:sl,rotrBH:ol,rotrBL:il,rotr32H:al,rotr32L:cl,rotlSH:ll,rotlSL:ul,rotlBH:fl,rotlBL:hl,add:dl,add3L:gl,add3H:pl,add4L:ml,add4H:bl,add5H:wl,add5L:yl},V=xl;var[vl,Bl]=V.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))),re=new Uint32Array(80),ne=new Uint32Array(80),us=class extends Me{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:f,El:l,Fh:u,Fl:h,Gh:x,Gl:v,Hh:b,Hl:d}=this;return[t,e,n,s,o,i,a,c,f,l,u,h,x,v,b,d]}set(t,e,n,s,o,i,a,c,f,l,u,h,x,v,b,d){this.Ah=t|0,this.Al=e|0,this.Bh=n|0,this.Bl=s|0,this.Ch=o|0,this.Cl=i|0,this.Dh=a|0,this.Dl=c|0,this.Eh=f|0,this.El=l|0,this.Fh=u|0,this.Fl=h|0,this.Gh=x|0,this.Gl=v|0,this.Hh=b|0,this.Hl=d|0}process(t,e){for(let p=0;p<16;p++,e+=4)re[p]=t.getUint32(e),ne[p]=t.getUint32(e+=4);for(let p=16;p<80;p++){let S=re[p-15]|0,L=ne[p-15]|0,T=V.rotrSH(S,L,1)^V.rotrSH(S,L,8)^V.shrSH(S,L,7),k=V.rotrSL(S,L,1)^V.rotrSL(S,L,8)^V.shrSL(S,L,7),I=re[p-2]|0,U=ne[p-2]|0,J=V.rotrSH(I,U,19)^V.rotrBH(I,U,61)^V.shrSH(I,U,6),F=V.rotrSL(I,U,19)^V.rotrBL(I,U,61)^V.shrSL(I,U,6),H=V.add4L(k,F,ne[p-7],ne[p-16]),Y=V.add4H(H,T,J,re[p-7],re[p-16]);re[p]=Y|0,ne[p]=H|0}let{Ah:n,Al:s,Bh:o,Bl:i,Ch:a,Cl:c,Dh:f,Dl:l,Eh:u,El:h,Fh:x,Fl:v,Gh:b,Gl:d,Hh:y,Hl:E}=this;for(let p=0;p<80;p++){let S=V.rotrSH(u,h,14)^V.rotrSH(u,h,18)^V.rotrBH(u,h,41),L=V.rotrSL(u,h,14)^V.rotrSL(u,h,18)^V.rotrBL(u,h,41),T=u&x^~u&b,k=h&v^~h&d,I=V.add5L(E,L,k,Bl[p],ne[p]),U=V.add5H(I,y,S,T,vl[p],re[p]),J=I|0,F=V.rotrSH(n,s,28)^V.rotrBH(n,s,34)^V.rotrBH(n,s,39),H=V.rotrSL(n,s,28)^V.rotrBL(n,s,34)^V.rotrBL(n,s,39),Y=n&o^n&a^o&a,B=s&i^s&c^i&c;y=b|0,E=d|0,b=x|0,d=v|0,x=u|0,v=h|0,{h:u,l:h}=V.add(f|0,l|0,U|0,J|0),f=a|0,l=c|0,a=o|0,c=i|0,o=n|0,i=s|0;let N=V.add3L(J,H,B);n=V.add3H(N,U,F,Y),s=N|0}({h:n,l:s}=V.add(this.Ah|0,this.Al|0,n|0,s|0)),{h:o,l:i}=V.add(this.Bh|0,this.Bl|0,o|0,i|0),{h:a,l:c}=V.add(this.Ch|0,this.Cl|0,a|0,c|0),{h:f,l}=V.add(this.Dh|0,this.Dl|0,f|0,l|0),{h:u,l:h}=V.add(this.Eh|0,this.El|0,u|0,h|0),{h:x,l:v}=V.add(this.Fh|0,this.Fl|0,x|0,v|0),{h:b,l:d}=V.add(this.Gh|0,this.Gl|0,b|0,d|0),{h:y,l:E}=V.add(this.Hh|0,this.Hl|0,y|0,E|0),this.set(n,s,o,i,a,c,f,l,u,h,x,v,b,d,y,E)}roundClean(){re.fill(0),ne.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 Qo=kr(()=>new us);var Ur={};ht(Ur,{aInRange:()=>bt,abool:()=>Nt,abytes:()=>Pe,bitGet:()=>Nl,bitLen:()=>ps,bitMask:()=>sr,bitSet:()=>Cl,bytesToHex:()=>Pt,bytesToNumberBE:()=>Ft,bytesToNumberLE:()=>oe,concatBytes:()=>Kt,createHmacDrbg:()=>ms,ensureBytes:()=>W,equalBytes:()=>kl,hexToBytes:()=>be,hexToNumber:()=>gs,inRange:()=>nr,isBytes:()=>se,memoized:()=>we,notImplemented:()=>Tl,numberToBytesBE:()=>ie,numberToBytesLE:()=>ye,numberToHexUnpadded:()=>me,numberToVarBytesBE:()=>Sl,utf8ToBytes:()=>Il,validateObject:()=>Rt});var ds=BigInt(0),Cr=BigInt(1),El=BigInt(2);function se(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function Pe(r){if(!se(r))throw new Error("Uint8Array expected")}function Nt(r,t){if(typeof t!="boolean")throw new Error(`${r} must be valid boolean, got "${t}".`)}var Al=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function Pt(r){Pe(r);let t="";for(let e=0;e<r.length;e++)t+=Al[r[e]];return t}function me(r){let t=r.toString(16);return t.length&1?`0${t}`:t}function gs(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return BigInt(r===""?"0":`0x${r}`)}var Mt={_0:48,_9:57,_A:65,_F:70,_a:97,_f:102};function ti(r){if(r>=Mt._0&&r<=Mt._9)return r-Mt._0;if(r>=Mt._A&&r<=Mt._F)return r-(Mt._A-10);if(r>=Mt._a&&r<=Mt._f)return r-(Mt._a-10)}function be(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=ti(r.charCodeAt(o)),a=ti(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 Ft(r){return gs(Pt(r))}function oe(r){return Pe(r),gs(Pt(Uint8Array.from(r).reverse()))}function ie(r,t){return be(r.toString(16).padStart(t*2,"0"))}function ye(r,t){return ie(r,t).reverse()}function Sl(r){return be(me(r))}function W(r,t,e){let n;if(typeof t=="string")try{n=be(t)}catch(o){throw new Error(`${r} must be valid hex string, got "${t}". Cause: ${o}`)}else if(se(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 Kt(...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 kl(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 Il(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}var fs=r=>typeof r=="bigint"&&ds<=r;function nr(r,t,e){return fs(r)&&fs(t)&&fs(e)&&t<=r&&r<e}function bt(r,t,e,n){if(!nr(t,e,n))throw new Error(`expected valid ${r}: ${e} <= n < ${n}, got ${typeof t} ${t}`)}function ps(r){let t;for(t=0;r>ds;r>>=Cr,t+=1);return t}function Nl(r,t){return r>>BigInt(t)&Cr}function Cl(r,t,e){return r|(e?Cr:ds)<<BigInt(t)}var sr=r=>(El<<BigInt(r-1))-Cr,hs=r=>new Uint8Array(r),ei=r=>Uint8Array.from(r);function ms(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=hs(r),s=hs(r),o=0,i=()=>{n.fill(1),s.fill(0),o=0},a=(...u)=>e(s,n,...u),c=(u=hs())=>{s=a(ei([0]),u),n=a(),u.length!==0&&(s=a(ei([1]),u),n=a())},f=()=>{if(o++>=1e3)throw new Error("drbg: tried 1000 values");let u=0,h=[];for(;u<t;){n=a();let x=n.slice();h.push(x),u+=n.length}return Kt(...h)};return(u,h)=>{i(),c(u);let x;for(;!(x=h(f()));)c();return i(),x}}var Ul={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"||se(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=Ul[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 Tl=()=>{throw new Error("not implemented")};function we(r){let t=new WeakMap;return(e,...n)=>{let s=t.get(e);if(s!==void 0)return s;let o=r(e,...n);return t.set(e,o),o}}var tt=BigInt(0),G=BigInt(1),xe=BigInt(2),Ll=BigInt(3),bs=BigInt(4),ri=BigInt(5),ni=BigInt(8),Rl=BigInt(9),_l=BigInt(16);function q(r,t){let e=r%t;return e>=tt?e:t+e}function Vl(r,t,e){if(e<=tt||t<tt)throw new Error("Expected power/modulo > 0");if(e===G)return tt;let n=G;for(;t>tt;)t&G&&(n=n*r%e),r=r*r%e,t>>=G;return n}function j(r,t,e){let n=r;for(;t-- >tt;)n*=n,n%=e;return n}function Tr(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=G,i=G,a=tt;for(;e!==tt;){let f=n/e,l=n%e,u=s-i*f,h=o-a*f;n=e,e=l,s=i,o=a,i=u,a=h}if(n!==G)throw new Error("invert: does not exist");return q(s,t)}function Hl(r){let t=(r-G)/xe,e,n,s;for(e=r-G,n=0;e%xe===tt;e/=xe,n++);for(s=xe;s<r&&Vl(s,t,r)!==r-G;s++);if(n===1){let i=(r+G)/bs;return function(c,f){let l=c.pow(f,i);if(!c.eql(c.sqr(l),f))throw new Error("Cannot find square root");return l}}let o=(e+G)/xe;return function(a,c){if(a.pow(c,t)===a.neg(a.ONE))throw new Error("Cannot find square root");let f=n,l=a.pow(a.mul(a.ONE,s),e),u=a.pow(c,o),h=a.pow(c,e);for(;!a.eql(h,a.ONE);){if(a.eql(h,a.ZERO))return a.ZERO;let x=1;for(let b=a.sqr(h);x<f&&!a.eql(b,a.ONE);x++)b=a.sqr(b);let v=a.pow(l,G<<BigInt(f-x-1));l=a.sqr(v),u=a.mul(u,v),h=a.mul(h,l),f=x}return u}}function Dl(r){if(r%bs===Ll){let t=(r+G)/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%ni===ri){let t=(r-ri)/ni;return function(n,s){let o=n.mul(s,xe),i=n.pow(o,t),a=n.mul(s,i),c=n.mul(n.mul(a,xe),i),f=n.mul(a,n.sub(c,n.ONE));if(!n.eql(n.sqr(f),s))throw new Error("Cannot find square root");return f}}return r%_l,Hl(r)}var si=(r,t)=>(q(r,t)&G)===G,Ol=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function ys(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=Ol.reduce((n,s)=>(n[s]="function",n),t);return Rt(r,e)}function Ml(r,t,e){if(e<tt)throw new Error("Expected power > 0");if(e===tt)return r.ONE;if(e===G)return t;let n=r.ONE,s=t;for(;e>tt;)e&G&&(n=r.mul(n,s)),s=r.sqr(s),e>>=G;return n}function Pl(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 ae(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=Dl(r),a=Object.freeze({ORDER:r,BITS:s,BYTES:o,MASK:sr(s),ZERO:tt,ONE:G,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&G)===G,neg:c=>q(-c,r),eql:(c,f)=>c===f,sqr:c=>q(c*c,r),add:(c,f)=>q(c+f,r),sub:(c,f)=>q(c-f,r),mul:(c,f)=>q(c*f,r),pow:(c,f)=>Ml(a,c,f),div:(c,f)=>q(c*Tr(f,r),r),sqrN:c=>c*c,addN:(c,f)=>c+f,subN:(c,f)=>c-f,mulN:(c,f)=>c*f,inv:c=>Tr(c,r),sqrt:n.sqrt||(c=>i(a,c)),invertBatch:c=>Pl(a,c),cmov:(c,f,l)=>l?f:c,toBytes:c=>e?ye(c,o):ie(c,o),fromBytes:c=>{if(c.length!==o)throw new Error(`Fp.fromBytes: expected ${o}, got ${c.length}`);return e?oe(c):Ft(c)}});return Object.freeze(a)}function oi(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 xs(r){let t=oi(r);return t+Math.ceil(t/2)}function ii(r,t,e=!1){let n=r.length,s=oi(t),o=xs(t);if(n<16||n<o||n>1024)throw new Error(`expected ${o}-1024 bytes of input, got ${n}`);let i=e?Ft(r):oe(r),a=q(i,t-G)+G;return e?ye(a,s):ie(a,s)}var Kl=BigInt(0),vs=BigInt(1),Bs=new WeakMap,ai=new WeakMap;function Lr(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>Kl;)i&vs&&(a=a.add(c)),c=c.double(),i>>=vs;return a},precomputeWindow(o,i){let{windows:a,windowSize:c}=s(i),f=[],l=o,u=l;for(let h=0;h<a;h++){u=l,f.push(u);for(let x=1;x<c;x++)u=u.add(l),f.push(u);l=u.double()}return f},wNAF(o,i,a){let{windows:c,windowSize:f}=s(o),l=r.ZERO,u=r.BASE,h=BigInt(2**o-1),x=2**o,v=BigInt(o);for(let b=0;b<c;b++){let d=b*f,y=Number(a&h);a>>=v,y>f&&(y-=x,a+=vs);let E=d,p=d+Math.abs(y)-1,S=b%2!==0,L=y<0;y===0?u=u.add(e(S,i[E])):l=l.add(e(L,i[p]))}return{p:l,f:u}},wNAFCached(o,i,a){let c=ai.get(o)||1,f=Bs.get(o);return f||(f=this.precomputeWindow(o,c),c!==1&&Bs.set(o,a(f))),this.wNAF(c,f,i)},setWindowSize(o,i){n(i),ai.set(o,i),Bs.delete(o)}}}function Rr(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,u)=>{if(!t.isValid(l))throw new Error(`wrong scalar at index ${u}`)}),e.forEach((l,u)=>{if(!(l instanceof r))throw new Error(`wrong point at index ${u}`)});let s=ps(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,f=r.ZERO;for(let l=c;l>=0;l-=o){a.fill(r.ZERO);for(let h=0;h<n.length;h++){let x=n[h],v=Number(x>>BigInt(l)&BigInt(i));a[v]=a[v].add(e[h])}let u=r.ZERO;for(let h=a.length-1,x=r.ZERO;h>0;h--)x=x.add(a[h]),u=u.add(x);if(f=f.add(u),l!==0)for(let h=0;h<o;h++)f=f.double()}return f}function or(r){return ys(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 Ct=BigInt(0),yt=BigInt(1),_r=BigInt(2),$l=BigInt(8),ql={zip215:!0};function zl(r){let t=or(r);return Rt(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function ci(r){let t=zl(r),{Fp:e,n,prehash:s,hash:o,randomBytes:i,nByteLength:a,h:c}=t,f=_r<<BigInt(a*8)-yt,l=e.create,u=ae(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:Ct}}}),x=t.adjustScalarBytes||(m=>m),v=t.domain||((m,g,w)=>{if(Nt("phflag",w),g.length||w)throw new Error("Contexts/pre-hash are not supported");return m});function b(m,g){bt("coordinate "+m,g,Ct,f)}function d(m){if(!(m instanceof p))throw new Error("ExtendedPoint expected")}let y=we((m,g)=>{let{ex:w,ey:C,ez:R}=m,_=m.is0();g==null&&(g=_?$l:e.inv(R));let D=l(w*g),P=l(C*g),O=l(R*g);if(_)return{x:Ct,y:yt};if(O!==yt)throw new Error("invZ was invalid");return{x:D,y:P}}),E=we(m=>{let{a:g,d:w}=t;if(m.is0())throw new Error("bad point: ZERO");let{ex:C,ey:R,ez:_,et:D}=m,P=l(C*C),O=l(R*R),$=l(_*_),z=l($*$),et=l(P*g),rt=l($*l(et+O)),ot=l(z+l(w*l(P*O)));if(rt!==ot)throw new Error("bad point: equation left != right (1)");let ft=l(C*R),X=l(_*D);if(ft!==X)throw new Error("bad point: equation left != right (2)");return!0});class p{constructor(g,w,C,R){this.ex=g,this.ey=w,this.ez=C,this.et=R,b("x",g),b("y",w),b("z",C),b("t",R),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:w,y:C}=g||{};return b("x",w),b("y",C),new p(w,C,yt,l(w*C))}static normalizeZ(g){let w=e.invertBatch(g.map(C=>C.ez));return g.map((C,R)=>C.toAffine(w[R])).map(p.fromAffine)}static msm(g,w){return Rr(p,u,g,w)}_setWindowSize(g){T.setWindowSize(this,g)}assertValidity(){E(this)}equals(g){d(g);let{ex:w,ey:C,ez:R}=this,{ex:_,ey:D,ez:P}=g,O=l(w*P),$=l(_*R),z=l(C*P),et=l(D*R);return O===$&&z===et}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:w,ey:C,ez:R}=this,_=l(w*w),D=l(C*C),P=l(_r*l(R*R)),O=l(g*_),$=w+C,z=l(l($*$)-_-D),et=O+D,rt=et-P,ot=O-D,ft=l(z*rt),X=l(et*ot),pt=l(z*ot),Dt=l(rt*et);return new p(ft,X,Dt,pt)}add(g){d(g);let{a:w,d:C}=t,{ex:R,ey:_,ez:D,et:P}=this,{ex:O,ey:$,ez:z,et}=g;if(w===BigInt(-1)){let Bo=l((_-R)*($+O)),Eo=l((_+R)*($-O)),Jn=l(Eo-Bo);if(Jn===Ct)return this.double();let Ao=l(D*_r*et),So=l(P*_r*z),ko=So+Ao,Io=Eo+Bo,No=So-Ao,tc=l(ko*Jn),ec=l(Io*No),rc=l(ko*No),nc=l(Jn*Io);return new p(tc,ec,nc,rc)}let rt=l(R*O),ot=l(_*$),ft=l(P*C*et),X=l(D*z),pt=l((R+_)*(O+$)-rt-ot),Dt=X-ft,Je=X+ft,Ye=l(ot-w*rt),Ja=l(pt*Dt),Ya=l(Je*Ye),Xa=l(pt*Ye),Qa=l(Dt*Je);return new p(Ja,Ya,Qa,Xa)}subtract(g){return this.add(g.negate())}wNAF(g){return T.wNAFCached(this,g,p.normalizeZ)}multiply(g){let w=g;bt("scalar",w,yt,n);let{p:C,f:R}=this.wNAF(w);return p.normalizeZ([C,R])[0]}multiplyUnsafe(g){let w=g;return bt("scalar",w,Ct,n),w===Ct?L:this.equals(L)||w===yt?this:this.equals(S)?this.wNAF(w).p:T.unsafeLadder(this,w)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return T.unsafeLadder(this,n).is0()}toAffine(g){return y(this,g)}clearCofactor(){let{h:g}=t;return g===yt?this:this.multiplyUnsafe(g)}static fromHex(g,w=!1){let{d:C,a:R}=t,_=e.BYTES;g=W("pointHex",g,_),Nt("zip215",w);let D=g.slice(),P=g[_-1];D[_-1]=P&-129;let O=oe(D),$=w?f:e.ORDER;bt("pointHex.y",O,Ct,$);let z=l(O*O),et=l(z-yt),rt=l(C*z-R),{isValid:ot,value:ft}=h(et,rt);if(!ot)throw new Error("Point.fromHex: invalid y coordinate");let X=(ft&yt)===yt,pt=(P&128)!==0;if(!w&&ft===Ct&&pt)throw new Error("Point.fromHex: x=0 and x_0=1");return pt!==X&&(ft=l(-ft)),p.fromAffine({x:ft,y:O})}static fromPrivateKey(g){return U(g).point}toRawBytes(){let{x:g,y:w}=this.toAffine(),C=ye(w,e.BYTES);return C[C.length-1]|=g&yt?128:0,C}toHex(){return Pt(this.toRawBytes())}}p.BASE=new p(t.Gx,t.Gy,yt,l(t.Gx*t.Gy)),p.ZERO=new p(Ct,yt,yt,Ct);let{BASE:S,ZERO:L}=p,T=Lr(p,a*8);function k(m){return q(m,n)}function I(m){return k(oe(m))}function U(m){let g=a;m=W("private key",m,g);let w=W("hashed private key",o(m),2*g),C=x(w.slice(0,g)),R=w.slice(g,2*g),_=I(C),D=S.multiply(_),P=D.toRawBytes();return{head:C,prefix:R,scalar:_,point:D,pointBytes:P}}function J(m){return U(m).pointBytes}function F(m=new Uint8Array,...g){let w=Kt(...g);return I(o(v(w,W("context",m),!!s)))}function H(m,g,w={}){m=W("message",m),s&&(m=s(m));let{prefix:C,scalar:R,pointBytes:_}=U(g),D=F(w.context,C,m),P=S.multiply(D).toRawBytes(),O=F(w.context,P,_,m),$=k(D+O*R);bt("signature.s",$,Ct,n);let z=Kt(P,ye($,e.BYTES));return W("result",z,a*2)}let Y=ql;function B(m,g,w,C=Y){let{context:R,zip215:_}=C,D=e.BYTES;m=W("signature",m,2*D),g=W("message",g),_!==void 0&&Nt("zip215",_),s&&(g=s(g));let P=oe(m.slice(D,2*D)),O,$,z;try{O=p.fromHex(w,_),$=p.fromHex(m.slice(0,D),_),z=S.multiplyUnsafe(P)}catch{return!1}if(!_&&O.isSmallOrder())return!1;let et=F(R,$.toRawBytes(),O.toRawBytes(),g);return $.add(O.multiplyUnsafe(et)).subtract(z).clearCofactor().equals(p.ZERO)}return S._setWindowSize(8),{CURVE:t,getPublicKey:J,sign:H,verify:B,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 Es=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),li=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),Uh=BigInt(0),Gl=BigInt(1),ui=BigInt(2),Th=BigInt(3),jl=BigInt(5),Zl=BigInt(8);function Wl(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),s=BigInt(80),o=Es,a=r*r%o*r%o,c=j(a,ui,o)*a%o,f=j(c,Gl,o)*r%o,l=j(f,jl,o)*f%o,u=j(l,t,o)*l%o,h=j(u,e,o)*u%o,x=j(h,n,o)*h%o,v=j(x,s,o)*x%o,b=j(v,s,o)*x%o,d=j(b,t,o)*l%o;return{pow_p_5_8:j(d,ui,o)*r%o,b2:a}}function Jl(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function Yl(r,t){let e=Es,n=q(t*t*t,e),s=q(n*n*t,e),o=Wl(r*s).pow_p_5_8,i=q(r*n*o,e),a=q(t*i*i,e),c=i,f=q(i*li,e),l=a===r,u=a===q(-r,e),h=a===q(-r*li,e);return l&&(i=c),(u||h)&&(i=f),si(i,e)&&(i=q(-i,e)),{isValid:l||u,value:i}}var Xl=ae(Es,void 0,!0),Ql={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:Xl,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:Zl,Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:Qo,randomBytes:Ir,adjustScalarBytes:Jl,uvRatio:Yl},fi=ci(Ql);var Vr=32;function hi(r,t,e){return fi.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}var Hr=class{type="Ed25519";raw;constructor(t){this.raw=As(t,Vr)}toMultihash(){return ee.digest(Dr(this))}toCID(){return Et.createV1(114,this.toMultihash())}toString(){return Q.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:mt(this.raw,t.raw)}verify(t,e){return hi(this.raw,e,t)}};function gi(r){return r=As(r,Vr),new Hr(r)}function As(r,t){if(r=Uint8Array.from(r??[]),r.length!==t)throw new dt(`Key must be a Uint8Array of length ${t}, got ${r.length}`);return r}function Ut(r=0){return new Uint8Array(r)}function wt(r=0){return new Uint8Array(r)}var eu=Math.pow(2,7),ru=Math.pow(2,14),nu=Math.pow(2,21),Ss=Math.pow(2,28),ks=Math.pow(2,35),Is=Math.pow(2,42),Ns=Math.pow(2,49),K=128,ct=127;function $t(r){if(r<eu)return 1;if(r<ru)return 2;if(r<nu)return 3;if(r<Ss)return 4;if(r<ks)return 5;if(r<Is)return 6;if(r<Ns)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function Cs(r,t,e=0){switch($t(r)){case 8:t[e++]=r&255|K,r/=128;case 7:t[e++]=r&255|K,r/=128;case 6:t[e++]=r&255|K,r/=128;case 5:t[e++]=r&255|K,r/=128;case 4:t[e++]=r&255|K,r>>>=7;case 3:t[e++]=r&255|K,r>>>=7;case 2:t[e++]=r&255|K,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function su(r,t,e=0){switch($t(r)){case 8:t.set(e++,r&255|K),r/=128;case 7:t.set(e++,r&255|K),r/=128;case 6:t.set(e++,r&255|K),r/=128;case 5:t.set(e++,r&255|K),r/=128;case 4:t.set(e++,r&255|K),r>>>=7;case 3:t.set(e++,r&255|K),r>>>=7;case 2:t.set(e++,r&255|K),r>>>=7;case 1:{t.set(e++,r&255),r>>>=7;break}default:throw new Error("unreachable")}return t}function Us(r,t){let e=r[t],n=0;if(n+=e&ct,e<K||(e=r[t+1],n+=(e&ct)<<7,e<K)||(e=r[t+2],n+=(e&ct)<<14,e<K)||(e=r[t+3],n+=(e&ct)<<21,e<K)||(e=r[t+4],n+=(e&ct)*Ss,e<K)||(e=r[t+5],n+=(e&ct)*ks,e<K)||(e=r[t+6],n+=(e&ct)*Is,e<K)||(e=r[t+7],n+=(e&ct)*Ns,e<K))return n;throw new RangeError("Could not decode varint")}function ou(r,t){let e=r.get(t),n=0;if(n+=e&ct,e<K||(e=r.get(t+1),n+=(e&ct)<<7,e<K)||(e=r.get(t+2),n+=(e&ct)<<14,e<K)||(e=r.get(t+3),n+=(e&ct)<<21,e<K)||(e=r.get(t+4),n+=(e&ct)*Ss,e<K)||(e=r.get(t+5),n+=(e&ct)*ks,e<K)||(e=r.get(t+6),n+=(e&ct)*Is,e<K)||(e=r.get(t+7),n+=(e&ct)*Ns,e<K))return n;throw new RangeError("Could not decode varint")}function pi(r,t,e=0){return t==null&&(t=wt($t(r))),t instanceof Uint8Array?Cs(r,t,e):su(r,t,e)}function mi(r,t=0){return r instanceof Uint8Array?Us(r,t):ou(r,t)}var Ts=new Float32Array([-0]),ce=new Uint8Array(Ts.buffer);function bi(r,t,e){Ts[0]=r,t[e]=ce[0],t[e+1]=ce[1],t[e+2]=ce[2],t[e+3]=ce[3]}function yi(r,t){return ce[0]=r[t],ce[1]=r[t+1],ce[2]=r[t+2],ce[3]=r[t+3],Ts[0]}var Ls=new Float64Array([-0]),lt=new Uint8Array(Ls.buffer);function wi(r,t,e){Ls[0]=r,t[e]=lt[0],t[e+1]=lt[1],t[e+2]=lt[2],t[e+3]=lt[3],t[e+4]=lt[4],t[e+5]=lt[5],t[e+6]=lt[6],t[e+7]=lt[7]}function xi(r,t){return lt[0]=r[t],lt[1]=r[t+1],lt[2]=r[t+2],lt[3]=r[t+3],lt[4]=r[t+4],lt[5]=r[t+5],lt[6]=r[t+6],lt[7]=r[t+7],Ls[0]}var au=BigInt(Number.MAX_SAFE_INTEGER),cu=BigInt(Number.MIN_SAFE_INTEGER),At=class r{lo;hi;constructor(t,e){this.lo=t|0,this.hi=e|0}toNumber(t=!1){if(!t&&this.hi>>>31>0){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(e+n*4294967296)}return this.lo+this.hi*4294967296}toBigInt(t=!1){if(t)return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n);if(this.hi>>>31){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(BigInt(e)+(BigInt(n)<<32n))}return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n)}toString(t=!1){return this.toBigInt(t).toString()}zzEncode(){let t=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^t)>>>0,this.lo=(this.lo<<1^t)>>>0,this}zzDecode(){let t=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^t)>>>0,this.hi=(this.hi>>>1^t)>>>0,this}length(){let t=this.lo,e=(this.lo>>>28|this.hi<<4)>>>0,n=this.hi>>>24;return n===0?e===0?t<16384?t<128?1:2:t<2097152?3:4:e<16384?e<128?5:6:e<2097152?7:8:n<128?9:10}static fromBigInt(t){if(t===0n)return ve;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>vi&&(s=0n,++n>vi&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(t){if(t===0)return ve;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):ve}},ve=new At(0,0);ve.toBigInt=function(){return 0n};ve.zzEncode=ve.zzDecode=function(){return this};ve.length=function(){return 1};var vi=4294967296n;function Bi(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 Ei(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 Rs(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 Tt(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function Or(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var _s=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,Tt(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 Tt(this,4);return Or(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Tt(this,4);return Or(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Tt(this,4);let t=yi(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Tt(this,4);let t=xi(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 Tt(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return Ei(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw Tt(this,t);this.pos+=t}else do if(this.pos>=this.len)throw Tt(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 At(0,0),e=0;if(this.len-this.pos>4){for(;e<4;++e)if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t;if(t.lo=(t.lo|(this.buf[this.pos]&127)<<28)>>>0,t.hi=(t.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return t;e=0}else{for(;e<3;++e){if(this.pos>=this.len)throw Tt(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 Tt(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 Tt(this,8);let t=Or(this.buf,this.pos+=4),e=Or(this.buf,this.pos+=4);return new At(t,e)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){let t=Us(this.buf,this.pos);return this.pos+=$t(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 Vs(r){return new _s(r instanceof Uint8Array?r:r.subarray())}function Be(r,t,e){let n=Vs(r);return t.decode(n,void 0,e)}var Hs={};ht(Hs,{base10:()=>lu});var lu=te({prefix:"9",name:"base10",alphabet:"0123456789"});var Ds={};ht(Ds,{base16:()=>uu,base16upper:()=>fu});var uu=Z({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),fu=Z({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Os={};ht(Os,{base2:()=>hu});var hu=Z({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Ms={};ht(Ms,{base256emoji:()=>bu});var Si=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=Si.reduce((r,t,e)=>(r[e]=t,r),[]),gu=Si.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 bu=Ue({prefix:"\u{1F680}",name:"base256emoji",encode:pu,decode:mu});var Ps={};ht(Ps,{base36:()=>yu,base36upper:()=>wu});var yu=te({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),wu=te({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Fs={};ht(Fs,{base64:()=>xu,base64pad:()=>vu,base64url:()=>Bu,base64urlpad:()=>Eu});var xu=Z({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),vu=Z({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Bu=Z({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Eu=Z({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Ks={};ht(Ks,{base8:()=>Au});var Au=Z({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var $s={};ht($s,{identity:()=>Su});var Su=Ue({prefix:"\0",name:"identity",encode:r=>Ro(r),decode:r=>Lo(r)});var gd=new TextEncoder,pd=new TextDecoder;var Gs={};ht(Gs,{sha256:()=>Mr,sha512:()=>Nu});function zs({name:r,code:t,encode:e}){return new qs(r,t,e)}var qs=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?kt(this.code,e):e.then(n=>kt(this.code,n))}else throw Error("Unknown type, must be binary type")}};function Ii(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var Mr=zs({name:"sha2-256",code:18,encode:Ii("SHA-256")}),Nu=zs({name:"sha2-512",code:19,encode:Ii("SHA-512")});var js={...$s,...Os,...Ks,...Hs,...Ds,...ns,...Ps,...rs,...Fs,...Ms},Id={...Gs,...as};function Ci(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var Ni=Ci("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),Zs=Ci("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=wt(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),Cu={utf8:Ni,"utf-8":Ni,hex:js.base16,latin1:Zs,ascii:Zs,binary:Zs,...js},Pr=Cu;function nt(r,t="utf8"){let e=Pr[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function Ws(r){let t=r??8192,e=t>>>1,n,s=t;return function(i){if(i<1||i>e)return wt(i);s+i>t&&(n=wt(t),s=0);let a=n.subarray(s,s+=i);return s&7&&(s=(s|7)+1),a}}var Ee=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 Xs=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},Uu=Ws();function Tu(r){return globalThis.Buffer!=null?wt(r):Uu(r)}var ar=class{len;head;tail;states;constructor(){this.len=0,this.head=new Ee(Js,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new Ee(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new Qs((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(Fr,10,At.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=At.fromBigInt(t);return this._push(Fr,e.length(),e)}uint64Number(t){return this._push(Cs,$t(t),t)}uint64String(t){return this.uint64(BigInt(t))}int64(t){return this.uint64(t)}int64Number(t){return this.uint64Number(t)}int64String(t){return this.uint64String(t)}sint64(t){let e=At.fromBigInt(t).zzEncode();return this._push(Fr,e.length(),e)}sint64Number(t){let e=At.fromNumber(t).zzEncode();return this._push(Fr,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(Ys,1,t?1:0)}fixed32(t){return this._push(ir,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=At.fromBigInt(t);return this._push(ir,4,e.lo)._push(ir,4,e.hi)}fixed64Number(t){let e=At.fromNumber(t);return this._push(ir,4,e.lo)._push(ir,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(bi,4,t)}double(t){return this._push(wi,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(Ys,1,0):this.uint32(e)._push(Ru,e,t)}string(t){let e=Bi(t);return e!==0?this.uint32(e)._push(Rs,e,t):this._push(Ys,1,0)}fork(){return this.states=new Xs(this),this.head=this.tail=new Ee(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 Ee(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=Tu(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function Ys(r,t,e){t[e]=r&255}function Lu(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var Qs=class extends Ee{next;constructor(t,e){super(Lu,t,e),this.next=void 0}};function Fr(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 ir(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&&(ar.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(_u,t,r),this},ar.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(Vu,t,r),this});function _u(r,t,e){t.set(r,e)}function Vu(r,t,e){r.length<40?Rs(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(nt(r),e)}function to(){return new ar}function Ae(r,t){let e=to();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var Fe;(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"})(Fe||(Fe={}));function Kr(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function cr(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 Kr("enum",Fe.VARINT,e,n)}function Se(r,t){return Kr("message",Fe.LENGTH_DELIMITED,r,t)}var xt;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.secp256k1="secp256k1"})(xt||(xt={}));var eo;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1"})(eo||(eo={}));(function(r){r.codec=()=>cr(eo)})(xt||(xt={}));var le;(function(r){let t;r.codec=()=>(t==null&&(t=Se((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),xt.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=xt.codec().decode(e);break}case 2:{o.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return o})),t),r.encode=e=>Ae(e,r.codec()),r.decode=(e,n)=>Be(e,r.codec(),n)})(le||(le={}));var ro;(function(r){let t;r.codec=()=>(t==null&&(t=Se((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),xt.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=xt.codec().decode(e);break}case 2:{o.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return o})),t),r.encode=e=>Ae(e,r.codec()),r.decode=(e,n)=>Be(e,r.codec(),n)})(ro||(ro={}));var yr={};ht(yr,{MAX_RSA_KEY_SIZE:()=>_n,generateRSAKeyPair:()=>ka,jwkToJWKKeyPair:()=>Ia,jwkToPkcs1:()=>Yu,jwkToPkix:()=>fo,jwkToRSAPrivateKey:()=>Sa,pkcs1ToJwk:()=>Ba,pkcs1ToRSAPrivateKey:()=>Aa,pkixToJwk:()=>Ea,pkixToRSAPublicKey:()=>ho});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]),ue=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),fe=new Uint32Array(64),no=class extends Me{constructor(){super(64,32,8,!1),this.A=ue[0]|0,this.B=ue[1]|0,this.C=ue[2]|0,this.D=ue[3]|0,this.E=ue[4]|0,this.F=ue[5]|0,this.G=ue[6]|0,this.H=ue[7]|0}get(){let{A:t,B:e,C:n,D:s,E:o,F:i,G:a,H:c}=this;return[t,e,n,s,o,i,a,c]}set(t,e,n,s,o,i,a,c){this.A=t|0,this.B=e|0,this.C=n|0,this.D=s|0,this.E=o|0,this.F=i|0,this.G=a|0,this.H=c|0}process(t,e){for(let u=0;u<16;u++,e+=4)fe[u]=t.getUint32(e,!1);for(let u=16;u<64;u++){let h=fe[u-15],x=fe[u-2],v=It(h,7)^It(h,18)^h>>>3,b=It(x,17)^It(x,19)^x>>>10;fe[u]=b+fe[u-7]+v+fe[u-16]|0}let{A:n,B:s,C:o,D:i,E:a,F:c,G:f,H:l}=this;for(let u=0;u<64;u++){let h=It(a,6)^It(a,11)^It(a,25),x=l+h+Jo(a,c,f)+Hu[u]+fe[u]|0,b=(It(n,2)^It(n,13)^It(n,22))+Yo(n,s,o)|0;l=f,f=c,c=a,a=i+x|0,i=o,o=s,s=n,n=x+b|0}n=n+this.A|0,s=s+this.B|0,o=o+this.C|0,i=i+this.D|0,a=a+this.E|0,c=c+this.F|0,f=f+this.G|0,l=l+this.H|0,this.set(n,s,o,i,a,c,f,l)}roundClean(){fe.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var Ke=kr(()=>new no);var M=uc(Ti());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 he(r,t,e=-1){let n=e,s=r,o=0,i=Math.pow(2,t);for(let a=1;a<8;a++){if(r<i){let c;if(n<0)c=new ArrayBuffer(a),o=a;else{if(n<a)return new ArrayBuffer(0);c=new ArrayBuffer(n),o=n}let f=new Uint8Array(c);for(let l=a-1;l>=0;l--){let u=Math.pow(2,l*t);f[o-l-1]=Math.floor(s/u),s-=f[o-l-1]*u}return c}i*=Math.pow(2,t)}return new ArrayBuffer(0)}function zr(...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 oo(){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 Li(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=he(i,8,n),c=new Uint8Array(a);return c[0]|=128,a}let s=he(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 Ri(r,t){if(r.byteLength!==t.byteLength)return!1;let e=new Uint8Array(r),n=new Uint8Array(t);for(let s=0;s<e.length;s++)if(e[s]!==n[s])return!1;return!0}function vt(r,t){let e=r.toString(10);if(t<e.length)return"";let n=t-e.length,s=new Array(n);for(let i=0;i<n;i++)s[i]="0";return s.join("").concat(e)}var c0=Math.log(2);function Gr(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function io(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 Zt(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 ur=class{constructor(){this.items=[]}write(t){this.items.push(t)}final(){return io(this.items)}},lr=[new Uint8Array([1])],_i="0123456789";var je="",Lt=new ArrayBuffer(0),ao=new Uint8Array(0),fr="EndOfContent",Hi="OCTET STRING",Di="BIT STRING";function Wt(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):ao}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(!Zt(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",Lt)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:M.Convert.ToHex(this.valueHexView)}}},t.NAME="hexBlock",t}var zt=class{constructor({blockLength:t=0,error:e=je,warnings:n=[],valueBeforeDecode:s=ao}={}){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)}}};zt.NAME="baseBlock";var ut=class extends zt{fromBER(t,e,n){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}toBER(t,e){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}};ut.NAME="valueBlock";var jr=class extends Wt(zt){constructor({idBlock:t={}}={}){var e,n,s,o;super(),t?(this.isHexOnly=(e=t.isHexOnly)!==null&&e!==void 0?e:!1,this.valueHexView=t.valueHex?M.BufferSourceConverter.toUint8Array(t.valueHex):ao,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",Lt}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=he(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(!Zt(this,s,e,n))return-1;let o=s.subarray(e,e+n);if(o.length===0)return this.error="Zero buffer length",-1;switch(o[0]&192){case 0:this.tagClass=1;break;case 64:this.tagClass=2;break;case 128:this.tagClass=3;break;case 192:this.tagClass=4;break;default:return this.error="Unknown tag class",-1}this.isConstructed=(o[0]&32)===32,this.isHexOnly=!1;let a=o[0]&31;if(a!==31)this.tagNumber=a,this.blockLength=1;else{let c=1,f=this.valueHexView=new Uint8Array(255),l=255;for(;o[c]&128;){if(f[c-1]=o[c]&127,c++,c>=o.length)return this.error="End of input reached before message was fully decoded",-1;if(c===l){l+=255;let h=new Uint8Array(l);for(let x=0;x<f.length;x++)h[x]=f[x];f=this.valueHexView=new Uint8Array(l)}}this.blockLength=c+1,f[c-1]=o[c]&127;let u=new Uint8Array(c);for(let h=0;h<c;h++)u[h]=f[h];f=this.valueHexView=new Uint8Array(c),f.set(u),this.blockLength<=9?this.tagNumber=ke(f,7):(this.isHexOnly=!0,this.warnings.push("Tag too long, represented as hex-coded"))}if(this.tagClass===1&&this.isConstructed)switch(this.tagNumber){case 1:case 2:case 5:case 6:case 9:case 13:case 14:case 23:case 24:case 31:case 32:case 33:case 34:return this.error="Constructed encoding used for primitive type",-1}return e+this.blockLength}toJSON(){return{...super.toJSON(),tagClass:this.tagClass,tagNumber:this.tagNumber,isConstructed:this.isConstructed}}};jr.NAME="identificationBlock";var Zr=class extends zt{constructor({lenBlock:t={}}={}){var e,n,s;super(),this.isIndefiniteForm=(e=t.isIndefiniteForm)!==null&&e!==void 0?e:!1,this.longFormUsed=(n=t.longFormUsed)!==null&&n!==void 0?n:!1,this.length=(s=t.length)!==null&&s!==void 0?s:0}fromBER(t,e,n){let s=M.BufferSourceConverter.toUint8Array(t);if(!Zt(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=he(this.length,8);if(s.byteLength>127)return this.error="Too big length",Lt;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}}};Zr.NAME="lengthBlock";var A={},it=class extends zt{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 jr(s),this.lenBlock=new Zr(s),this.valueBlock=o?new o(s):new ut(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 ur;e||Oi(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?Lt: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 Ri(e,n)}};it.NAME="BaseBlock";function Oi(r){if(r instanceof A.Constructed)for(let t of r.valueBlock.value)Oi(t)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var Wr=class extends it{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}'`}};Wr.NAME="BaseStringBlock";var Jr=class extends Wt(ut){constructor({isHexOnly:t=!0,...e}={}){super(e),this.isHexOnly=t}};Jr.NAME="PrimitiveValueBlock";var Mi,Yr=class extends it{constructor(t={}){super(t,Jr),this.idBlock.isConstructed=!1}};Mi=Yr;A.Primitive=Mi;Yr.NAME="PRIMITIVE";function zu(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 Ln(r,t=0,e=r.length){let n=t,s=new it({},ut),o=new zt;if(!Zt(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=it;switch(s.idBlock.tagClass){case 1:if(s.idBlock.tagNumber>=37&&s.idBlock.isHexOnly===!1)return s.error="UNIVERSAL 37 and upper tags are reserved by ASN.1 standard",{offset:-1,result:s};switch(s.idBlock.tagNumber){case 0:if(s.idBlock.isConstructed&&s.lenBlock.length>0)return s.error="Type [UNIVERSAL 0] is reserved",{offset:-1,result:s};c=A.EndOfContent;break;case 1:c=A.Boolean;break;case 2:c=A.Integer;break;case 3:c=A.BitString;break;case 4:c=A.OctetString;break;case 5:c=A.Null;break;case 6:c=A.ObjectIdentifier;break;case 10:c=A.Enumerated;break;case 12:c=A.Utf8String;break;case 13:c=A.RelativeObjectIdentifier;break;case 14:c=A.TIME;break;case 15:return s.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:s};case 16:c=A.Sequence;break;case 17:c=A.Set;break;case 18:c=A.NumericString;break;case 19:c=A.PrintableString;break;case 20:c=A.TeletexString;break;case 21:c=A.VideotexString;break;case 22:c=A.IA5String;break;case 23:c=A.UTCTime;break;case 24:c=A.GeneralizedTime;break;case 25:c=A.GraphicString;break;case 26:c=A.VisibleString;break;case 27:c=A.GeneralString;break;case 28:c=A.UniversalString;break;case 29:c=A.CharacterString;break;case 30:c=A.BmpString;break;case 31:c=A.DATE;break;case 32:c=A.TimeOfDay;break;case 33:c=A.DateTime;break;case 34:c=A.Duration;break;default:{let f=s.idBlock.isConstructed?new A.Constructed:new A.Primitive;f.idBlock=s.idBlock,f.lenBlock=s.lenBlock,f.warnings=s.warnings,s=f}}break;case 2:case 3:case 4:default:c=s.idBlock.isConstructed?A.Constructed:A.Primitive}return s=zu(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 co(r){if(!r.byteLength){let t=new it({},ut);return t.error="Input buffer has zero length",{offset:-1,result:t}}return Ln(M.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function Gu(r,t){return r?1:t}var _t=class extends ut{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(!Zt(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(;Gu(this.isIndefiniteForm,n)>0;){let i=Ln(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===fr)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===fr?this.value.pop():this.warnings.push("No EndOfContent block encoded")),o}toBER(t,e){let n=e||new ur;for(let s=0;s<this.value.length;s++)this.value[s].toBER(t,n);return e?Lt:n.final()}toJSON(){let t={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let e of this.value)t.value.push(e.toJSON());return t}};_t.NAME="ConstructedValueBlock";var Pi,de=class extends it{constructor(t={}){super(t,_t),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
|
-
`));let
|
|
5
|
-
${
|
|
6
|
-
`)}`:`${t} :`}};ia=xt;k.Constructed=ia;xt.NAME="CONSTRUCTED";var vn=class extends ge{fromBER(e,t,n){return t}toBER(e){return Ve}};vn.override="EndOfContentValueBlock";var aa,Bn=class extends he{constructor(e={}){super(e,vn),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};aa=Bn;k.EndOfContent=aa;Bn.NAME=Ur;var ca,vt=class extends he{constructor(e={}){super(e,ge),this.idBlock.tagClass=1,this.idBlock.tagNumber=5}fromBER(e,t,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,t+n>e.byteLength?(this.error="End of input reached before message was fully decoded (inconsistent offset and length values)",-1):t+n}toBER(e,t){let n=new ArrayBuffer(2);if(!e){let s=new Uint8Array(n);s[0]=5,s[1]=0}return t&&t.write(n),n}onAsciiEncoding(){return`${this.constructor.NAME}`}};ca=vt;k.Null=ca;vt.NAME="NULL";var En=class extends nt(ge){constructor({value:e,...t}={}){super(t),t.valueHex?this.valueHexView=M.BufferSourceConverter.toUint8Array(t.valueHex):this.valueHexView=new Uint8Array(1),e&&(this.value=e)}get value(){for(let e of this.valueHexView)if(e>0)return!0;return!1}set value(e){this.valueHexView[0]=e?255:0}fromBER(e,t,n){let s=M.BufferSourceConverter.toUint8Array(e);return rt(this,s,t,n)?(this.valueHexView=s.subarray(t,t+n),n>1&&this.warnings.push("Boolean value encoded in more then 1 octet"),this.isHexOnly=!0,xo.call(this),this.blockLength=n,t+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};En.NAME="BooleanValueBlock";var la,An=class extends he{constructor(e={}){super(e,En),this.idBlock.tagClass=1,this.idBlock.tagNumber=1}getValue(){return this.valueBlock.value}setValue(e){this.valueBlock.value=e}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.getValue}`}};la=An;k.Boolean=la;An.NAME="BOOLEAN";var kn=class extends nt(Pe){constructor({isConstructed:e=!1,...t}={}){super(t),this.isConstructed=e}fromBER(e,t,n){let s=0;if(this.isConstructed){if(this.isHexOnly=!1,s=Pe.prototype.fromBER.call(this,e,t,n),s===-1)return s;for(let o=0;o<this.value.length;o++){let i=this.value[o].constructor.NAME;if(i===Ur){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(i!==ra)return this.error="OCTET STRING may consists of OCTET STRINGs only",-1}}else this.isHexOnly=!0,s=super.fromBER(e,t,n),this.blockLength=n;return s}toBER(e,t){return this.isConstructed?Pe.prototype.toBER.call(this,e,t):e?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};kn.NAME="OctetStringValueBlock";var ua,et=class r extends he{constructor({idBlock:e={},lenBlock:t={},...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,...e},lenBlock:{...t,isIndefiniteForm:!!n.isIndefiniteForm},...n},kn),this.idBlock.tagClass=1,this.idBlock.tagNumber=4}fromBER(e,t,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),t;if(!this.valueBlock.isConstructed){let o=(e instanceof ArrayBuffer?new Uint8Array(e):e).subarray(t,t+n);try{if(o.byteLength){let i=Qn(o,0,o.byteLength);i.offset!==-1&&i.offset===n&&(this.valueBlock.value=[i.result])}}catch{}}return super.fromBER(e,t,n)}onAsciiEncoding(){return this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length?xt.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 e=[];for(let t of this.valueBlock.value)t instanceof r&&e.push(t.valueBlock.valueHexView);return M.BufferSourceConverter.concat(e)}};ua=et;k.OctetString=ua;et.NAME=ra;var Sn=class extends nt(Pe){constructor({unusedBits:e=0,isConstructed:t=!1,...n}={}){super(n),this.unusedBits=e,this.isConstructed=t,this.blockLength=this.valueHexView.byteLength}fromBER(e,t,n){if(!n)return t;let s=-1;if(this.isConstructed){if(s=Pe.prototype.fromBER.call(this,e,t,n),s===-1)return s;for(let a of this.value){let c=a.constructor.NAME;if(c===Ur){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==na)return this.error="BIT STRING may consists of BIT STRINGs only",-1;let f=a.valueBlock;if(this.unusedBits>0&&f.unusedBits>0)return this.error='Using of "unused bits" inside constructive BIT STRING allowed for least one only',-1;this.unusedBits=f.unusedBits}return s}let o=M.BufferSourceConverter.toUint8Array(e);if(!rt(this,o,t,n))return-1;let i=o.subarray(t,t+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=Qn(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,t+n}toBER(e,t){if(this.isConstructed)return Pe.prototype.toBER.call(this,e,t);if(e)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return Ve;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}}};Sn.NAME="BitStringValueBlock";var fa,ar=class extends he{constructor({idBlock:e={},lenBlock:t={},...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,...e},lenBlock:{...t,isIndefiniteForm:!!n.isIndefiniteForm},...n},Sn),this.idBlock.tagClass=1,this.idBlock.tagNumber=3}fromBER(e,t,n){return this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,super.fromBER(e,t,n)}onAsciiEncoding(){if(this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length)return xt.prototype.onAsciiEncoding.call(this);{let e=[],t=this.valueBlock.valueHexView;for(let s of t)e.push(s.toString(2).padStart(8,"0"));let n=e.join("");return`${this.constructor.NAME} : ${n.substring(0,n.length-this.valueBlock.unusedBits)}`}}};fa=ar;k.BitString=fa;ar.NAME=na;var ha;function xf(r,e){let t=new Uint8Array([0]),n=new Uint8Array(r),s=new Uint8Array(e),o=n.slice(0),i=o.length-1,a=s.slice(0),c=a.length-1,f=0,l=c<i?i:c,u=0;for(let h=l;h>=0;h--,u++){switch(!0){case u<a.length:f=o[i-u]+a[c-u]+t[0];break;default:f=o[i-u]+t[0]}switch(t[0]=f/10,!0){case u>=o.length:o=pn(new Uint8Array([f%10]),o);break;default:o[i-u]=f%10}}return t[0]>0&&(o=pn(t,o)),o}function ta(r){if(r>=Cr.length)for(let e=Cr.length;e<=r;e++){let t=new Uint8Array([0]),n=Cr[e-1].slice(0);for(let s=n.length-1;s>=0;s--){let o=new Uint8Array([(n[s]<<1)+t[0]]);t[0]=o[0]/10,n[s]=o[0]%10}t[0]>0&&(n=pn(t,n)),Cr.push(n)}return Cr[r]}function vf(r,e){let t=0,n=new Uint8Array(r),s=new Uint8Array(e),o=n.slice(0),i=o.length-1,a=s.slice(0),c=a.length-1,f,l=0;for(let u=c;u>=0;u--,l++)switch(f=o[i-l]-a[c-l]-t,!0){case f<0:t=1,o[i-l]=f+10;break;default:t=0,o[i-l]=f}if(t>0)for(let u=i-c+1;u>=0;u--,l++)if(f=o[i-l]-t,f<0)t=1,o[i-l]=f+10;else{t=0,o[i-l]=f;break}return o.slice()}var Vr=class extends nt(ge){constructor({value:e,...t}={}){super(t),this._valueDec=0,t.valueHex&&this.setValueHex(),e!==void 0&&(this.valueDec=e)}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=xo.call(this)))}set valueDec(e){this._valueDec=e,this.isHexOnly=!1,this.valueHexView=new Uint8Array(Xi(e))}get valueDec(){return this._valueDec}fromDER(e,t,n,s=0){let o=this.fromBER(e,t,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(e=!1){let t=this.valueHexView;switch(!0){case(t[0]&128)!==0:{let n=new Uint8Array(this.valueHexView.length+1);n[0]=0,n.set(t,1),this.valueHexView=n}break;case(t[0]===0&&(t[1]&128)===0):this.valueHexView=this.valueHexView.subarray(1);break}return this.toBER(e)}fromBER(e,t,n){let s=super.fromBER(e,t,n);return s===-1||this.setValueHex(),s}toBER(e){return e?new ArrayBuffer(this.valueHexView.length):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}toString(){let e=this.valueHexView.length*8-1,t=new Uint8Array(this.valueHexView.length*8/3),n=0,s,o=this.valueHexView,i="",a=!1;for(let c=o.byteLength-1;c>=0;c--){s=o[c];for(let f=0;f<8;f++){if((s&1)===1)switch(n){case e:t=vf(ta(n),t),i="-";break;default:t=xf(t,ta(n))}n++,s>>=1}}for(let c=0;c<t.length;c++)t[c]&&(a=!0),a&&(i+=ea.charAt(t[c]));return a===!1&&(i+=ea.charAt(0)),i}};ha=Vr;Vr.NAME="IntegerValueBlock";Object.defineProperty(ha.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var da,X=class r extends he{constructor(e={}){super(e,Vr),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return gn(),BigInt(this.valueBlock.toString())}static fromBigInt(e){gn();let t=BigInt(e),n=new _r,s=t.toString(16).replace(/^-/,""),o=new Uint8Array(M.Convert.FromHex(s));if(t<0){let a=new Uint8Array(o.length+(o[0]&128?1:0));a[0]|=128;let f=BigInt(`0x${M.Convert.ToHex(a)}`)+t,l=M.BufferSourceConverter.toUint8Array(M.Convert.FromHex(f.toString(16)));l[0]|=128,n.write(l)}else o[0]&128&&n.write(new Uint8Array([0])),n.write(o);return new r({valueHex:n.final()})}convertToDER(){let e=new r({valueHex:this.valueBlock.valueHexView});return e.valueBlock.toDER(),e}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()}`}};da=X;k.Integer=da;X.NAME="INTEGER";var pa,In=class extends X{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};pa=In;k.Enumerated=pa;In.NAME="ENUMERATED";var Dr=class extends nt(ge){constructor({valueDec:e=-1,isFirstSid:t=!1,...n}={}){super(n),this.valueDec=e,this.isFirstSid=t}fromBER(e,t,n){if(!n)return t;let s=M.BufferSourceConverter.toUint8Array(e);if(!rt(this,s,t,n))return-1;let o=s.subarray(t,t+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=Ht(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),t+this.blockLength)}set valueBigInt(e){gn();let t=BigInt(e).toString(2);for(;t.length%7;)t="0"+t;let n=new Uint8Array(t.length/7);for(let s=0;s<n.length;s++)n[s]=parseInt(t.slice(s*7,s*7+7),2)+(s+1<n.length?128:0);this.fromBER(n.buffer,0,n.length)}toBER(e){if(this.isHexOnly){if(e)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 t=wt(this.valueDec,7);if(t.byteLength===0)return this.error="Error during encoding SID value",Ve;let n=new Uint8Array(t.byteLength);if(!e){let s=new Uint8Array(t),o=t.byteLength-1;for(let i=0;i<o;i++)n[i]=s[i]|128;n[o]=s[o]}return n}toString(){let e="";if(this.isHexOnly)e=M.Convert.ToHex(this.valueHexView);else if(this.isFirstSid){let t=this.valueDec;this.valueDec<=39?e="0.":this.valueDec<=79?(e="1.",t-=40):(e="2.",t-=80),e+=t.toString()}else e=this.valueDec.toString();return e}toJSON(){return{...super.toJSON(),valueDec:this.valueDec,isFirstSid:this.isFirstSid}}};Dr.NAME="sidBlock";var Rn=class extends ge{constructor({value:e=cr,...t}={}){super(t),this.value=[],e&&this.fromString(e)}fromBER(e,t,n){let s=t;for(;n>0;){let o=new Dr;if(s=o.fromBER(e,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(e){let t=[];for(let n=0;n<this.value.length;n++){let s=this.value[n].toBER(e);if(s.byteLength===0)return this.error=this.value[n].error,Ve;t.push(s)}return vo(t)}fromString(e){this.value=[];let t=0,n=0,s="",o=!1;do if(n=e.indexOf(".",t),n===-1?s=e.substring(t):s=e.substring(t,n),t=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 Dr;if(s>Number.MAX_SAFE_INTEGER){gn();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 e="",t=!1;for(let n=0;n<this.value.length;n++){t=this.value[n].isHexOnly;let s=this.value[n].toString();n!==0&&(e=`${e}.`),t?(s=`{${s}}`,this.value[n].isFirstSid?e=`2.{${s} - 80}`:e+=s):e+=s}return e}toJSON(){let e={...super.toJSON(),value:this.toString(),sidArray:[]};for(let t=0;t<this.value.length;t++)e.sidArray.push(this.value[t].toJSON());return e}};Rn.NAME="ObjectIdentifierValueBlock";var ga,Ue=class extends he{constructor(e={}){super(e,Rn),this.idBlock.tagClass=1,this.idBlock.tagNumber=6}getValue(){return this.valueBlock.toString()}setValue(e){this.valueBlock.fromString(e)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};ga=Ue;k.ObjectIdentifier=ga;Ue.NAME="OBJECT IDENTIFIER";var Or=class extends nt(Qe){constructor({valueDec:e=0,...t}={}){super(t),this.valueDec=e}fromBER(e,t,n){if(n===0)return t;let s=M.BufferSourceConverter.toUint8Array(e);if(!rt(this,s,t,n))return-1;let o=s.subarray(t,t+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=Ht(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),t+this.blockLength)}toBER(e){if(this.isHexOnly){if(e)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 t=wt(this.valueDec,7);if(t.byteLength===0)return this.error="Error during encoding SID value",Ve;let n=new Uint8Array(t.byteLength);if(!e){let s=new Uint8Array(t),o=t.byteLength-1;for(let i=0;i<o;i++)n[i]=s[i]|128;n[o]=s[o]}return n.buffer}toString(){let e="";return this.isHexOnly?e=M.Convert.ToHex(this.valueHexView):e=this.valueDec.toString(),e}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};Or.NAME="relativeSidBlock";var Nn=class extends ge{constructor({value:e=cr,...t}={}){super(t),this.value=[],e&&this.fromString(e)}fromBER(e,t,n){let s=t;for(;n>0;){let o=new Or;if(s=o.fromBER(e,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(e,t){let n=[];for(let s=0;s<this.value.length;s++){let o=this.value[s].toBER(e);if(o.byteLength===0)return this.error=this.value[s].error,Ve;n.push(o)}return vo(n)}fromString(e){this.value=[];let t=0,n=0,s="";do{n=e.indexOf(".",t),n===-1?s=e.substring(t):s=e.substring(t,n),t=n+1;let o=new Or;if(o.valueDec=parseInt(s,10),isNaN(o.valueDec))return!0;this.value.push(o)}while(n!==-1);return!0}toString(){let e="",t=!1;for(let n=0;n<this.value.length;n++){t=this.value[n].isHexOnly;let s=this.value[n].toString();n!==0&&(e=`${e}.`),t&&(s=`{${s}}`),e+=s}return e}toJSON(){let e={...super.toJSON(),value:this.toString(),sidArray:[]};for(let t=0;t<this.value.length;t++)e.sidArray.push(this.value[t].toJSON());return e}};Nn.NAME="RelativeObjectIdentifierValueBlock";var ya,Tn=class extends he{constructor(e={}){super(e,Nn),this.idBlock.tagClass=1,this.idBlock.tagNumber=13}getValue(){return this.valueBlock.toString()}setValue(e){this.valueBlock.fromString(e)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};ya=Tn;k.RelativeObjectIdentifier=ya;Tn.NAME="RelativeObjectIdentifier";var ma,ae=class extends xt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};ma=ae;k.Sequence=ma;ae.NAME="SEQUENCE";var ba,Ln=class extends xt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};ba=Ln;k.Set=ba;Ln.NAME="SET";var Cn=class extends nt(ge){constructor({...e}={}){super(e),this.isHexOnly=!0,this.value=cr}toJSON(){return{...super.toJSON(),value:this.value}}};Cn.NAME="StringValueBlock";var _n=class extends Cn{};_n.NAME="SimpleStringValueBlock";var we=class extends bn{constructor({...e}={}){super(e,_n)}fromBuffer(e){this.valueBlock.value=String.fromCharCode.apply(null,M.BufferSourceConverter.toUint8Array(e))}fromString(e){let t=e.length,n=this.valueBlock.valueHexView=new Uint8Array(t);for(let s=0;s<t;s++)n[s]=e.charCodeAt(s);this.valueBlock.value=e}};we.NAME="SIMPLE STRING";var Un=class extends we{fromBuffer(e){this.valueBlock.valueHexView=M.BufferSourceConverter.toUint8Array(e);try{this.valueBlock.value=M.Convert.ToUtf8String(e)}catch(t){this.warnings.push(`Error during "decodeURIComponent": ${t}, using raw string`),this.valueBlock.value=M.Convert.ToBinary(e)}}fromString(e){this.valueBlock.valueHexView=new Uint8Array(M.Convert.FromUtf8String(e)),this.valueBlock.value=e}};Un.NAME="Utf8StringValueBlock";var wa,tt=class extends Un{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};wa=tt;k.Utf8String=wa;tt.NAME="UTF8String";var Vn=class extends we{fromBuffer(e){this.valueBlock.value=M.Convert.ToUtf16String(e),this.valueBlock.valueHexView=M.BufferSourceConverter.toUint8Array(e)}fromString(e){this.valueBlock.value=e,this.valueBlock.valueHexView=new Uint8Array(M.Convert.FromUtf16String(e))}};Vn.NAME="BmpStringValueBlock";var xa,Dn=class extends Vn{constructor({...e}={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};xa=Dn;k.BmpString=xa;Dn.NAME="BMPString";var On=class extends we{fromBuffer(e){let t=ArrayBuffer.isView(e)?e.slice().buffer:e.slice(0),n=new Uint8Array(t);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(t))}fromString(e){let t=e.length,n=this.valueBlock.valueHexView=new Uint8Array(t*4);for(let s=0;s<t;s++){let o=wt(e.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=e}};On.NAME="UniversalStringValueBlock";var va,Hn=class extends On{constructor({...e}={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};va=Hn;k.UniversalString=va;Hn.NAME="UniversalString";var Ba,Pn=class extends we{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};Ba=Pn;k.NumericString=Ba;Pn.NAME="NumericString";var Ea,Mn=class extends we{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};Ea=Mn;k.PrintableString=Ea;Mn.NAME="PrintableString";var Aa,Kn=class extends we{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};Aa=Kn;k.TeletexString=Aa;Kn.NAME="TeletexString";var ka,Fn=class extends we{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};ka=Fn;k.VideotexString=ka;Fn.NAME="VideotexString";var Sa,qn=class extends we{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};Sa=qn;k.IA5String=Sa;qn.NAME="IA5String";var Ia,$n=class extends we{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};Ia=$n;k.GraphicString=Ia;$n.NAME="GraphicString";var Ra,Hr=class extends we{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};Ra=Hr;k.VisibleString=Ra;Hr.NAME="VisibleString";var Na,Gn=class extends we{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};Na=Gn;k.GeneralString=Na;Gn.NAME="GeneralString";var Ta,jn=class extends we{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};Ta=jn;k.CharacterString=Ta;jn.NAME="CharacterString";var La,Pr=class extends Hr{constructor({value:e,valueDate:t,...n}={}){if(super(n),this.year=0,this.month=0,this.day=0,this.hour=0,this.minute=0,this.second=0,e){this.fromString(e),this.valueBlock.valueHexView=new Uint8Array(e.length);for(let s=0;s<e.length;s++)this.valueBlock.valueHexView[s]=e.charCodeAt(s)}t&&(this.fromDate(t),this.valueBlock.valueHexView=new Uint8Array(this.toBuffer())),this.idBlock.tagClass=1,this.idBlock.tagNumber=23}fromBuffer(e){this.fromString(String.fromCharCode.apply(null,M.BufferSourceConverter.toUint8Array(e)))}toBuffer(){let e=this.toString(),t=new ArrayBuffer(e.length),n=new Uint8Array(t);for(let s=0;s<e.length;s++)n[s]=e.charCodeAt(s);return t}fromDate(e){this.year=e.getUTCFullYear(),this.month=e.getUTCMonth()+1,this.day=e.getUTCDate(),this.hour=e.getUTCHours(),this.minute=e.getUTCMinutes(),this.second=e.getUTCSeconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second))}fromString(e){let n=/(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})Z/ig.exec(e);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(e="iso"){if(e==="iso"){let t=new Array(7);return t[0]=ke(this.year<2e3?this.year-1900:this.year-2e3,2),t[1]=ke(this.month,2),t[2]=ke(this.day,2),t[3]=ke(this.hour,2),t[4]=ke(this.minute,2),t[5]=ke(this.second,2),t[6]="Z",t.join("")}return super.toString(e)}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}}};La=Pr;k.UTCTime=La;Pr.NAME="UTCTime";var Ca,zn=class extends Pr{constructor(e={}){var t;super(e),(t=this.millisecond)!==null&&t!==void 0||(this.millisecond=0),this.idBlock.tagClass=1,this.idBlock.tagNumber=24}fromDate(e){super.fromDate(e),this.millisecond=e.getUTCMilliseconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second,this.millisecond))}fromString(e){let t=!1,n="",s="",o=0,i,a=0,c=0;if(e[e.length-1]==="Z")n=e.substring(0,e.length-1),t=!0;else{let u=new Number(e[e.length-1]);if(isNaN(u.valueOf()))throw new Error("Wrong input string for conversion");n=e}if(t){if(n.indexOf("+")!==-1)throw new Error("Wrong input string for conversion");if(n.indexOf("-")!==-1)throw new Error("Wrong input string for conversion")}else{let u=1,h=n.indexOf("+"),w="";if(h===-1&&(h=n.indexOf("-"),u=-1),h!==-1){if(w=n.substring(h+1),n=n.substring(0,h),w.length!==2&&w.length!==4)throw new Error("Wrong input string for conversion");let x=parseInt(w.substring(0,2),10);if(isNaN(x.valueOf()))throw new Error("Wrong input string for conversion");if(a=u*x,w.length===4){if(x=parseInt(w.substring(2,4),10),isNaN(x.valueOf()))throw new Error("Wrong input string for conversion");c=u*x}}}let f=n.indexOf(".");if(f===-1&&(f=n.indexOf(",")),f!==-1){let u=new Number(`0${n.substring(f)}`);if(isNaN(u.valueOf()))throw new Error("Wrong input string for conversion");o=u.valueOf(),s=n.substring(0,f)}else s=n;switch(!0){case s.length===8:if(i=/(\d{4})(\d{2})(\d{2})/ig,f!==-1)throw new Error("Wrong input string for conversion");break;case s.length===10:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let u=60*o;this.minute=Math.floor(u),u=60*(u-this.minute),this.second=Math.floor(u),u=1e3*(u-this.second),this.millisecond=Math.floor(u)}break;case s.length===12:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let u=60*o;this.second=Math.floor(u),u=1e3*(u-this.second),this.millisecond=Math.floor(u)}break;case s.length===14:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let u=1e3*o;this.millisecond=Math.floor(u)}break;default:throw new Error("Wrong input string for conversion")}let l=i.exec(s);if(l===null)throw new Error("Wrong input string for conversion");for(let u=1;u<l.length;u++)switch(u){case 1:this.year=parseInt(l[u],10);break;case 2:this.month=parseInt(l[u],10);break;case 3:this.day=parseInt(l[u],10);break;case 4:this.hour=parseInt(l[u],10)+a;break;case 5:this.minute=parseInt(l[u],10)+c;break;case 6:this.second=parseInt(l[u],10);break;default:throw new Error("Wrong input string for conversion")}if(t===!1){let u=new Date(this.year,this.month,this.day,this.hour,this.minute,this.second,this.millisecond);this.year=u.getUTCFullYear(),this.month=u.getUTCMonth(),this.day=u.getUTCDay(),this.hour=u.getUTCHours(),this.minute=u.getUTCMinutes(),this.second=u.getUTCSeconds(),this.millisecond=u.getUTCMilliseconds()}}toString(e="iso"){if(e==="iso"){let t=[];return t.push(ke(this.year,4)),t.push(ke(this.month,2)),t.push(ke(this.day,2)),t.push(ke(this.hour,2)),t.push(ke(this.minute,2)),t.push(ke(this.second,2)),this.millisecond!==0&&(t.push("."),t.push(ke(this.millisecond,3))),t.push("Z"),t.join("")}return super.toString(e)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};Ca=zn;k.GeneralizedTime=Ca;zn.NAME="GeneralizedTime";var _a,Zn=class extends tt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};_a=Zn;k.DATE=_a;Zn.NAME="DATE";var Ua,Wn=class extends tt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};Ua=Wn;k.TimeOfDay=Ua;Wn.NAME="TimeOfDay";var Va,Yn=class extends tt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};Va=Yn;k.DateTime=Va;Yn.NAME="DateTime";var Da,Jn=class extends tt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};Da=Jn;k.Duration=Da;Jn.NAME="Duration";var Oa,Xn=class extends tt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};Oa=Xn;k.TIME=Oa;Xn.NAME="TIME";function Ef(r){let{result:e}=lr(r),t=e.valueBlock.value;return{n:ne(Me(t[1].toBigInt()),"base64url"),e:ne(Me(t[2].toBigInt()),"base64url"),d:ne(Me(t[3].toBigInt()),"base64url"),p:ne(Me(t[4].toBigInt()),"base64url"),q:ne(Me(t[5].toBigInt()),"base64url"),dp:ne(Me(t[6].toBigInt()),"base64url"),dq:ne(Me(t[7].toBigInt()),"base64url"),qi:ne(Me(t[8].toBigInt()),"base64url"),kty:"RSA",alg:"RS256"}}function Af(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 D("JWK was missing components","ERR_INVALID_PARAMETERS");let t=new ae({value:[new X({value:0}),X.fromBigInt(Ke(z(r.n,"base64url"))),X.fromBigInt(Ke(z(r.e,"base64url"))),X.fromBigInt(Ke(z(r.d,"base64url"))),X.fromBigInt(Ke(z(r.p,"base64url"))),X.fromBigInt(Ke(z(r.q,"base64url"))),X.fromBigInt(Ke(z(r.dp,"base64url"))),X.fromBigInt(Ke(z(r.dq,"base64url"))),X.fromBigInt(Ke(z(r.qi,"base64url")))]}).toBER();return new Uint8Array(t,0,t.byteLength)}function kf(r){let{result:e}=lr(r),t=e.valueBlock.value[1].valueBlock.value[0].valueBlock.value;return{kty:"RSA",n:ne(Me(t[0].toBigInt()),"base64url"),e:ne(Me(t[1].toBigInt()),"base64url")}}function Sf(r){if(r.n==null||r.e==null)throw new D("JWK was missing components","ERR_INVALID_PARAMETERS");let t=new ae({value:[new ae({value:[new Ue({value:"1.2.840.113549.1.1.1"}),new vt]}),new ar({valueHex:new ae({value:[X.fromBigInt(Ke(z(r.n,"base64url"))),X.fromBigInt(Ke(z(r.e,"base64url")))]}).toBER()})]}).toBER();return new Uint8Array(t,0,t.byteLength)}function Me(r){let e=r.toString(16);e.length%2>0&&(e=`0${e}`);let t=e.length/2,n=new Uint8Array(t),s=0,o=0;for(;s<t;)n[s]=parseInt(e.slice(o,o+2),16),s+=1,o+=2;return n}function Ke(r){let e=[];return r.forEach(function(t){let n=t.toString(16);n.length%2>0&&(n=`0${n}`),e.push(n)}),BigInt("0x"+e.join(""))}var If=16,Eo=32,Ao=1e4;async function Rf(r,e){let t=be.get(),s=new ae({value:[new X({value:0}),new ae({value:[new Ue({value:"1.2.840.113549.1.1.1"}),new vt]}),new et({valueHex:r.marshal()})]}).toBER(),o=new Uint8Array(s,0,s.byteLength),i=Ot(If),a=await bo(Er,e,i,{c:Ao,dkLen:Eo}),c=Ot(16),f=await t.subtle.importKey("raw",a,"AES-CBC",!1,["encrypt"]),l=await t.subtle.encrypt({name:"AES-CBC",iv:c},f,o),u=new ae({value:[new et({valueHex:i}),new X({value:Ao}),new X({value:Eo}),new ae({value:[new Ue({value:"1.2.840.113549.2.11"}),new vt]})]}),h=new ae({value:[new Ue({value:"1.2.840.113549.1.5.13"}),new ae({value:[new ae({value:[new Ue({value:"1.2.840.113549.1.5.12"}),u]}),new ae({value:[new Ue({value:"2.16.840.1.101.3.4.1.42"}),new et({valueHex:c})]})]})]}),x=new ae({value:[h,new et({valueHex:l})]}).toBER(),y=new Uint8Array(x,0,x.byteLength);return["-----BEGIN ENCRYPTED PRIVATE KEY-----",...ne(y,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
|
|
7
|
-
`)}async function Nf(r,e){let t=be.get(),n;if(r.includes("-----BEGIN ENCRYPTED PRIVATE KEY-----")){let s=z(r.replace("-----BEGIN ENCRYPTED PRIVATE KEY-----","").replace("-----END ENCRYPTED PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:o}=lr(s),{iv:i,salt:a,iterations:c,keySize:f,cipherText:l}=Tf(o),u=await bo(Er,e,a,{c,dkLen:f}),h=await t.subtle.importKey("raw",u,"AES-CBC",!1,["decrypt"]),w=Mr(await t.subtle.decrypt({name:"AES-CBC",iv:i},h,l)),{result:x}=lr(w);n=Ha(x)}else if(r.includes("-----BEGIN PRIVATE KEY-----")){let s=z(r.replace("-----BEGIN PRIVATE KEY-----","").replace("-----END PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:o}=lr(s);n=Ha(o)}else throw new D("Could not parse private key from PEM data","ERR_INVALID_PARAMETERS");return ko(n)}function Tf(r){let e=r.valueBlock.value[0];if(e.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.13")throw new D("Only pkcs5PBES2 encrypted private keys are supported","ERR_INVALID_PARAMS");let n=e.valueBlock.value[1].valueBlock.value[0];if(n.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.12")throw new D("Only pkcs5PBKDF2 key derivation functions are supported","ERR_INVALID_PARAMS");let o=n.valueBlock.value[1],i=Mr(o.valueBlock.value[0].getValue()),a=Ao,c=Eo;if(o.valueBlock.value.length===3)a=Number(o.valueBlock.value[1].toBigInt()),c=Number(o.valueBlock.value[2].toBigInt());else if(o.valueBlock.value.length===2)throw new D("Could not derive key size and iterations from PEM file - please use @libp2p/rsa to re-import your key","ERR_INVALID_PARAMS");let f=e.valueBlock.value[1].valueBlock.value[1],l=f.valueBlock.value[0].toString();if(l!=="OBJECT IDENTIFIER : 1.2.840.113549.3.7"){if(l!=="OBJECT IDENTIFIER : 1.3.14.3.2.7"){if(l!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.2"){if(l!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.22"){if(l!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.42")throw new D("Only AES-CBC encryption schemes are supported","ERR_INVALID_PARAMS")}}}}let u=Mr(f.valueBlock.value[1].getValue());return{cipherText:Mr(r.valueBlock.value[1].getValue()),salt:i,iterations:a,keySize:c,iv:u}}function Ha(r){return Mr(r.valueBlock.value[2].getValue())}function Mr(r){return new Uint8Array(r,0,r.byteLength)}async function Pa(r){let e=await be.get().subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:r,publicExponent:new Uint8Array([1,0,1]),hash:{name:"SHA-256"}},!0,["sign","verify"]),t=await Fa(e);return{privateKey:t[0],publicKey:t[1]}}async function So(r){let t=[await be.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["sign"]),await Lf(r)],n=await Fa({privateKey:t[0],publicKey:t[1]});return{privateKey:n[0],publicKey:n[1]}}async function Ma(r,e){let t=await be.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await be.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},t,e instanceof Uint8Array?e:e.subarray());return new Uint8Array(n,0,n.byteLength)}async function Ka(r,e,t){let n=await be.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return be.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,e,t instanceof Uint8Array?t:t.subarray())}async function Fa(r){if(r.privateKey==null||r.publicKey==null)throw new D("Private and public key are required","ERR_INVALID_PARAMETERS");return Promise.all([be.get().subtle.exportKey("jwk",r.privateKey),be.get().subtle.exportKey("jwk",r.publicKey)])}async function Lf(r){return be.get().subtle.importKey("jwk",{kty:r.kty,n:r.n,e:r.e},{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["verify"])}function es(r){if(r.kty!=="RSA")throw new D("invalid key type","ERR_INVALID_KEY_TYPE");if(r.n==null)throw new D("invalid key modulus","ERR_INVALID_KEY_MODULUS");return z(r.n,"base64url").length*8}var Fr=8192,Kr=class{_key;constructor(e){this._key=e}verify(e,t){return Ka(this._key,t,e)}marshal(){return Bt.jwkToPkix(this._key)}get bytes(){return mt.encode({Type:fe.RSA,Data:this.marshal()}).subarray()}equals(e){return ve(this.bytes,e.bytes)}hash(){let e=ue.digest(this.bytes);return Re(e)?e.then(({bytes:t})=>t):e.bytes}},ur=class{_key;_publicKey;constructor(e,t){this._key=e,this._publicKey=t}genSecret(){return Ot(16)}sign(e){return Ma(this._key,e)}get public(){if(this._publicKey==null)throw new D("public key not provided","ERR_PUBKEY_NOT_PROVIDED");return new Kr(this._publicKey)}marshal(){return Bt.jwkToPkcs1(this._key)}get bytes(){return bt.encode({Type:fe.RSA,Data:this.marshal()}).subarray()}equals(e){return ve(this.bytes,e.bytes)}hash(){let e=ue.digest(this.bytes);return Re(e)?e.then(({bytes:t})=>t):e.bytes}async id(){let e=await this.public.hash();return ne(e,"base58btc")}async export(e,t="pkcs-8"){if(t==="pkcs-8")return Bt.exportToPem(this,e);if(t==="libp2p-key")return nr(this.bytes,e);throw new D(`export format '${t}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};async function ko(r){let e=Bt.pkcs1ToJwk(r);if(es(e)>Fr)throw new D("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await So(e);return new ur(t.privateKey,t.publicKey)}function _f(r){let e=Bt.pkixToJwk(r);if(es(e)>Fr)throw new D("key size is too large","ERR_KEY_SIZE_TOO_LARGE");return new Kr(e)}async function Uf(r){if(es(r)>Fr)throw new D("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await So(r);return new ur(e.privateKey,e.publicKey)}async function Vf(r){if(r>Fr)throw new D("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await Pa(r);return new ur(e.privateKey,e.publicKey)}var Co={};ie(Co,{Secp256k1PrivateKey:()=>$r,Secp256k1PublicKey:()=>qr,generateKeyPair:()=>Zf,unmarshalSecp256k1PrivateKey:()=>jf,unmarshalSecp256k1PublicKey:()=>zf});var Df=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]),Et=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),At=new Uint32Array(64),Ro=class extends Qt{constructor(){super(64,32,8,!1),this.A=Et[0]|0,this.B=Et[1]|0,this.C=Et[2]|0,this.D=Et[3]|0,this.E=Et[4]|0,this.F=Et[5]|0,this.G=Et[6]|0,this.H=Et[7]|0}get(){let{A:e,B:t,C:n,D:s,E:o,F:i,G:a,H:c}=this;return[e,t,n,s,o,i,a,c]}set(e,t,n,s,o,i,a,c){this.A=e|0,this.B=t|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(e,t){for(let u=0;u<16;u++,t+=4)At[u]=e.getUint32(t,!1);for(let u=16;u<64;u++){let h=At[u-15],w=At[u-2],x=Te(h,7)^Te(h,18)^h>>>3,y=Te(w,17)^Te(w,19)^w>>>10;At[u]=y+At[u-7]+x+At[u-16]|0}let{A:n,B:s,C:o,D:i,E:a,F:c,G:f,H:l}=this;for(let u=0;u<64;u++){let h=Te(a,6)^Te(a,11)^Te(a,25),w=l+h+xi(a,c,f)+Df[u]+At[u]|0,y=(Te(n,2)^Te(n,13)^Te(n,22))+vi(n,s,o)|0;l=f,f=c,c=a,a=i+w|0,i=o,o=s,s=n,n=w+y|0}n=n+this.A|0,s=s+this.B|0,o=o+this.C|0,i=i+this.D|0,a=a+this.E|0,c=c+this.F|0,f=f+this.G|0,l=l+this.H|0,this.set(n,s,o,i,a,c,f,l)}roundClean(){At.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var qa=Xr(()=>new Ro);function $a(r){r.lowS!==void 0&&Le("lowS",r.lowS),r.prehash!==void 0&&Le("prehash",r.prehash)}function Of(r){let e=Sr(r);He(e,{a:"field",b:"field"},{allowedPrivateKeyLengths:"array",wrapPrivateKey:"boolean",isTorsionFree:"function",clearCofactor:"function",allowInfinityPoint:"boolean",fromBytes:"function",toBytes:"function"});let{endo:t,Fp:n,a:s}=e;if(t){if(!n.eql(s,n.ZERO))throw new Error("Endomorphism can only be defined for Koblitz curves that have a=0");if(typeof t!="object"||typeof t.beta!="bigint"||typeof t.splitScalar!="function")throw new Error("Expected endomorphism with beta: bigint and splitScalar: function")}return Object.freeze({...e})}var{bytesToNumberBE:Hf,hexToBytes:Pf}=tn,st={Err:class extends Error{constructor(e=""){super(e)}},_tlv:{encode:(r,e)=>{let{Err:t}=st;if(r<0||r>256)throw new t("tlv.encode: wrong tag");if(e.length&1)throw new t("tlv.encode: unpadded data");let n=e.length/2,s=St(n);if(s.length/2&128)throw new t("tlv.encode: long form length too big");let o=n>127?St(s.length/2|128):"";return`${St(r)}${o}${s}${e}`},decode(r,e){let{Err:t}=st,n=0;if(r<0||r>256)throw new t("tlv.encode: wrong tag");if(e.length<2||e[n++]!==r)throw new t("tlv.decode: wrong tlv");let s=e[n++],o=!!(s&128),i=0;if(!o)i=s;else{let c=s&127;if(!c)throw new t("tlv.decode(long): indefinite length not supported");if(c>4)throw new t("tlv.decode(long): byte length is too big");let f=e.subarray(n,n+c);if(f.length!==c)throw new t("tlv.decode: length bytes not complete");if(f[0]===0)throw new t("tlv.decode(long): zero leftmost byte");for(let l of f)i=i<<8|l;if(n+=c,i<128)throw new t("tlv.decode(long): not minimal encoding")}let a=e.subarray(n,n+i);if(a.length!==i)throw new t("tlv.decode: wrong value length");return{v:a,l:e.subarray(n+i)}}},_int:{encode(r){let{Err:e}=st;if(r<ot)throw new e("integer: negative integers are not allowed");let t=St(r);if(Number.parseInt(t[0],16)&8&&(t="00"+t),t.length&1)throw new e("unexpected assertion");return t},decode(r){let{Err:e}=st;if(r[0]&128)throw new e("Invalid signature integer: negative");if(r[0]===0&&!(r[1]&128))throw new e("Invalid signature integer: unnecessary leading zero");return Hf(r)}},toSig(r){let{Err:e,_int:t,_tlv:n}=st,s=typeof r=="string"?Pf(r):r;er(s);let{v:o,l:i}=n.decode(48,s);if(i.length)throw new e("Invalid signature: left bytes after parsing");let{v:a,l:c}=n.decode(2,o),{v:f,l}=n.decode(2,c);if(l.length)throw new e("Invalid signature: left bytes after parsing");return{r:t.decode(a),s:t.decode(f)}},hexFromSig(r){let{_tlv:e,_int:t}=st,n=`${e.encode(2,t.encode(r.r))}${e.encode(2,t.encode(r.s))}`;return e.encode(48,n)}},ot=BigInt(0),ce=BigInt(1),Hp=BigInt(2),Ga=BigInt(3),Pp=BigInt(4);function Mf(r){let e=Of(r),{Fp:t}=e,n=gt(e.n,e.nBitLength),s=e.toBytes||((y,d,b)=>{let B=d.toAffine();return We(Uint8Array.from([4]),t.toBytes(B.x),t.toBytes(B.y))}),o=e.fromBytes||(y=>{let d=y.subarray(1),b=t.fromBytes(d.subarray(0,t.BYTES)),B=t.fromBytes(d.subarray(t.BYTES,2*t.BYTES));return{x:b,y:B}});function i(y){let{a:d,b}=e,B=t.sqr(y),g=t.mul(B,y);return t.add(t.add(g,t.mul(y,d)),b)}if(!t.eql(t.sqr(e.Gy),i(e.Gx)))throw new Error("bad generator point: equation left != right");function a(y){return Ar(y,ce,e.n)}function c(y){let{allowedPrivateKeyLengths:d,nByteLength:b,wrapPrivateKey:B,n:g}=e;if(d&&typeof y!="bigint"){if(ht(y)&&(y=ze(y)),typeof y!="string"||!d.includes(y.length))throw new Error("Invalid key");y=y.padStart(b*2,"0")}let E;try{E=typeof y=="bigint"?y:Ze(J("private key",y,b))}catch{throw new Error(`private key must be ${b} bytes, hex or bigint, not ${typeof y}`)}return B&&(E=G(E,g)),Ee("private key",E,ce,g),E}function f(y){if(!(y instanceof h))throw new Error("ProjectivePoint expected")}let l=Nt((y,d)=>{let{px:b,py:B,pz:g}=y;if(t.eql(g,t.ONE))return{x:b,y:B};let E=y.is0();d==null&&(d=E?t.ONE:t.inv(g));let C=t.mul(b,d),L=t.mul(B,d),S=t.mul(g,d);if(E)return{x:t.ZERO,y:t.ZERO};if(!t.eql(S,t.ONE))throw new Error("invZ was invalid");return{x:C,y:L}}),u=Nt(y=>{if(y.is0()){if(e.allowInfinityPoint&&!t.is0(y.py))return;throw new Error("bad point: ZERO")}let{x:d,y:b}=y.toAffine();if(!t.isValid(d)||!t.isValid(b))throw new Error("bad point: x or y not FE");let B=t.sqr(b),g=i(d);if(!t.eql(B,g))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||!t.isValid(d))throw new Error("x required");if(b==null||!t.isValid(b))throw new Error("y required");if(B==null||!t.isValid(B))throw new Error("z required");Object.freeze(this)}static fromAffine(d){let{x:b,y:B}=d||{};if(!d||!t.isValid(b)||!t.isValid(B))throw new Error("invalid affine point");if(d instanceof h)throw new Error("projective point not allowed");let g=E=>t.eql(E,t.ZERO);return g(b)&&g(B)?h.ZERO:new h(b,B,t.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(d){let b=t.invertBatch(d.map(B=>B.pz));return d.map((B,g)=>B.toAffine(b[g])).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 sn(h,n,d,b)}_setWindowSize(d){x.setWindowSize(this,d)}assertValidity(){u(this)}hasEvenY(){let{y:d}=this.toAffine();if(t.isOdd)return!t.isOdd(d);throw new Error("Field doesn't support isOdd")}equals(d){f(d);let{px:b,py:B,pz:g}=this,{px:E,py:C,pz:L}=d,S=t.eql(t.mul(b,L),t.mul(E,g)),I=t.eql(t.mul(B,L),t.mul(C,g));return S&&I}negate(){return new h(this.px,t.neg(this.py),this.pz)}double(){let{a:d,b}=e,B=t.mul(b,Ga),{px:g,py:E,pz:C}=this,L=t.ZERO,S=t.ZERO,I=t.ZERO,T=t.mul(g,g),Q=t.mul(E,E),F=t.mul(C,C),O=t.mul(g,E);return O=t.add(O,O),I=t.mul(g,C),I=t.add(I,I),L=t.mul(d,I),S=t.mul(B,F),S=t.add(L,S),L=t.sub(Q,S),S=t.add(Q,S),S=t.mul(L,S),L=t.mul(O,L),I=t.mul(B,I),F=t.mul(d,F),O=t.sub(T,F),O=t.mul(d,O),O=t.add(O,I),I=t.add(T,T),T=t.add(I,T),T=t.add(T,F),T=t.mul(T,O),S=t.add(S,T),F=t.mul(E,C),F=t.add(F,F),T=t.mul(F,O),L=t.sub(L,T),I=t.mul(F,Q),I=t.add(I,I),I=t.add(I,I),new h(L,S,I)}add(d){f(d);let{px:b,py:B,pz:g}=this,{px:E,py:C,pz:L}=d,S=t.ZERO,I=t.ZERO,T=t.ZERO,Q=e.a,F=t.mul(e.b,Ga),O=t.mul(b,E),ee=t.mul(B,C),A=t.mul(g,L),R=t.add(b,B),m=t.add(E,C);R=t.mul(R,m),m=t.add(O,ee),R=t.sub(R,m),m=t.add(b,g);let p=t.add(E,L);return m=t.mul(m,p),p=t.add(O,A),m=t.sub(m,p),p=t.add(B,g),S=t.add(C,L),p=t.mul(p,S),S=t.add(ee,A),p=t.sub(p,S),T=t.mul(Q,m),S=t.mul(F,A),T=t.add(S,T),S=t.sub(ee,T),T=t.add(ee,T),I=t.mul(S,T),ee=t.add(O,O),ee=t.add(ee,O),A=t.mul(Q,A),m=t.mul(F,m),ee=t.add(ee,A),A=t.sub(O,A),A=t.mul(Q,A),m=t.add(m,A),O=t.mul(ee,m),I=t.add(I,O),O=t.mul(p,m),S=t.mul(R,S),S=t.sub(S,O),O=t.mul(R,ee),T=t.mul(p,T),T=t.add(T,O),new h(S,I,T)}subtract(d){return this.add(d.negate())}is0(){return this.equals(h.ZERO)}wNAF(d){return x.wNAFCached(this,d,h.normalizeZ)}multiplyUnsafe(d){Ee("scalar",d,ot,e.n);let b=h.ZERO;if(d===ot)return b;if(d===ce)return this;let{endo:B}=e;if(!B)return x.unsafeLadder(this,d);let{k1neg:g,k1:E,k2neg:C,k2:L}=B.splitScalar(d),S=b,I=b,T=this;for(;E>ot||L>ot;)E&ce&&(S=S.add(T)),L&ce&&(I=I.add(T)),T=T.double(),E>>=ce,L>>=ce;return g&&(S=S.negate()),C&&(I=I.negate()),I=new h(t.mul(I.px,B.beta),I.py,I.pz),S.add(I)}multiply(d){let{endo:b,n:B}=e;Ee("scalar",d,ce,B);let g,E;if(b){let{k1neg:C,k1:L,k2neg:S,k2:I}=b.splitScalar(d),{p:T,f:Q}=this.wNAF(L),{p:F,f:O}=this.wNAF(I);T=x.constTimeNegate(C,T),F=x.constTimeNegate(S,F),F=new h(t.mul(F.px,b.beta),F.py,F.pz),g=T.add(F),E=Q.add(O)}else{let{p:C,f:L}=this.wNAF(d);g=C,E=L}return h.normalizeZ([g,E])[0]}multiplyAndAddUnsafe(d,b,B){let g=h.BASE,E=(L,S)=>S===ot||S===ce||!L.equals(g)?L.multiplyUnsafe(S):L.multiply(S),C=E(this,b).add(E(d,B));return C.is0()?void 0:C}toAffine(d){return l(this,d)}isTorsionFree(){let{h:d,isTorsionFree:b}=e;if(d===ce)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}=e;return d===ce?this:b?b(h,this):this.multiplyUnsafe(e.h)}toRawBytes(d=!0){return Le("isCompressed",d),this.assertValidity(),s(h,this,d)}toHex(d=!0){return Le("isCompressed",d),ze(this.toRawBytes(d))}}h.BASE=new h(e.Gx,e.Gy,t.ONE),h.ZERO=new h(t.ZERO,t.ONE,t.ZERO);let w=e.nBitLength,x=nn(h,e.endo?Math.ceil(w/2):w);return{CURVE:e,ProjectivePoint:h,normPrivateKeyToScalar:c,weierstrassEquation:i,isWithinCurveOrder:a}}function Kf(r){let e=Sr(r);return He(e,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...e})}function ja(r){let e=Kf(r),{Fp:t,n}=e,s=t.BYTES+1,o=2*t.BYTES+1;function i(A){return G(A,n)}function a(A){return rn(A,n)}let{ProjectivePoint:c,normPrivateKeyToScalar:f,weierstrassEquation:l,isWithinCurveOrder:u}=Mf({...e,toBytes(A,R,m){let p=R.toAffine(),v=t.toBytes(p.x),N=We;return Le("isCompressed",m),m?N(Uint8Array.from([R.hasEvenY()?2:3]),v):N(Uint8Array.from([4]),v,t.toBytes(p.y))},fromBytes(A){let R=A.length,m=A[0],p=A.subarray(1);if(R===s&&(m===2||m===3)){let v=Ze(p);if(!Ar(v,ce,t.ORDER))throw new Error("Point is not on curve");let N=l(v),_;try{_=t.sqrt(N)}catch(K){let P=K instanceof Error?": "+K.message:"";throw new Error("Point is not on curve"+P)}let U=(_&ce)===ce;return(m&1)===1!==U&&(_=t.neg(_)),{x:v,y:_}}else if(R===o&&m===4){let v=t.fromBytes(p.subarray(0,t.BYTES)),N=t.fromBytes(p.subarray(t.BYTES,2*t.BYTES));return{x:v,y:N}}else throw new Error(`Point of length ${R} was invalid. Expected ${s} compressed bytes or ${o} uncompressed bytes`)}}),h=A=>ze(pt(A,e.nByteLength));function w(A){let R=n>>ce;return A>R}function x(A){return w(A)?i(-A):A}let y=(A,R,m)=>Ze(A.slice(R,m));class d{constructor(R,m,p){this.r=R,this.s=m,this.recovery=p,this.assertValidity()}static fromCompact(R){let m=e.nByteLength;return R=J("compactSignature",R,m*2),new d(y(R,0,m),y(R,m,2*m))}static fromDER(R){let{r:m,s:p}=st.toSig(J("DER",R));return new d(m,p)}assertValidity(){Ee("r",this.r,ce,n),Ee("s",this.s,ce,n)}addRecoveryBit(R){return new d(this.r,this.s,R)}recoverPublicKey(R){let{r:m,s:p,recovery:v}=this,N=L(J("msgHash",R));if(v==null||![0,1,2,3].includes(v))throw new Error("recovery id invalid");let _=v===2||v===3?m+e.n:m;if(_>=t.ORDER)throw new Error("recovery id 2 or 3 invalid");let U=v&1?"03":"02",H=c.fromHex(U+h(_)),K=a(_),P=i(-N*K),$=i(p*K),j=c.BASE.multiplyAndAddUnsafe(H,P,$);if(!j)throw new Error("point at infinify");return j.assertValidity(),j}hasHighS(){return w(this.s)}normalizeS(){return this.hasHighS()?new d(this.r,i(-this.s),this.recovery):this}toDERRawBytes(){return It(this.toDERHex())}toDERHex(){return st.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return It(this.toCompactHex())}toCompactHex(){return h(this.r)+h(this.s)}}let b={isValidPrivateKey(A){try{return f(A),!0}catch{return!1}},normPrivateKeyToScalar:f,randomPrivateKey:()=>{let A=js(e.n);return Ni(e.randomBytes(A),e.n)},precompute(A=8,R=c.BASE){return R._setWindowSize(A),R.multiply(BigInt(3)),R}};function B(A,R=!0){return c.fromPrivateKey(A).toRawBytes(R)}function g(A){let R=ht(A),m=typeof A=="string",p=(R||m)&&A.length;return R?p===s||p===o:m?p===2*s||p===2*o:A instanceof c}function E(A,R,m=!0){if(g(A))throw new Error("first arg must be private key");if(!g(R))throw new Error("second arg must be public key");return c.fromHex(R).multiply(f(A)).toRawBytes(m)}let C=e.bits2int||function(A){let R=Ze(A),m=A.length*8-e.nBitLength;return m>0?R>>BigInt(m):R},L=e.bits2int_modN||function(A){return i(C(A))},S=kr(e.nBitLength);function I(A){return Ee(`num < 2^${e.nBitLength}`,A,ot,S),pt(A,e.nByteLength)}function T(A,R,m=Q){if(["recovered","canonical"].some(oe=>oe in m))throw new Error("sign() legacy options not supported");let{hash:p,randomBytes:v}=e,{lowS:N,prehash:_,extraEntropy:U}=m;N==null&&(N=!0),A=J("msgHash",A),$a(m),_&&(A=J("prehashed msgHash",p(A)));let H=L(A),K=f(R),P=[I(K),I(H)];if(U!=null&&U!==!1){let oe=U===!0?v(t.BYTES):U;P.push(J("extraEntropy",oe))}let $=We(...P),j=H;function se(oe){let le=C(oe);if(!u(le))return;let ye=a(le),te=c.BASE.multiply(le).toAffine(),xe=i(te.x);if(xe===ot)return;let Fe=i(ye*i(j+xe*K));if(Fe===ot)return;let mr=(te.x===xe?0:2)|Number(te.y&ce),br=Fe;return N&&w(Fe)&&(br=x(Fe),mr^=1),new d(xe,br,mr)}return{seed:$,k2sig:se}}let Q={lowS:e.lowS,prehash:!1},F={lowS:e.lowS,prehash:!1};function O(A,R,m=Q){let{seed:p,k2sig:v}=T(A,R,m),N=e;return Fs(N.hash.outputLen,N.nByteLength,N.hmac)(p,v)}c.BASE._setWindowSize(8);function ee(A,R,m,p=F){let v=A;if(R=J("msgHash",R),m=J("publicKey",m),"strict"in p)throw new Error("options.strict was renamed to lowS");$a(p);let{lowS:N,prehash:_}=p,U,H;try{if(typeof v=="string"||ht(v))try{U=d.fromDER(v)}catch(te){if(!(te instanceof st.Err))throw te;U=d.fromCompact(v)}else if(typeof v=="object"&&typeof v.r=="bigint"&&typeof v.s=="bigint"){let{r:te,s:xe}=v;U=new d(te,xe)}else throw new Error("PARSE");H=c.fromHex(m)}catch(te){if(te.message==="PARSE")throw new Error("signature must be Signature instance, Uint8Array or hex string");return!1}if(N&&U.hasHighS())return!1;_&&(R=e.hash(R));let{r:K,s:P}=U,$=L(R),j=a(P),se=i($*j),oe=i(K*j),le=c.BASE.multiplyAndAddUnsafe(H,se,oe)?.toAffine();return le?i(le.x)===K:!1}return{CURVE:e,getPublicKey:B,getSharedSecret:E,sign:O,verify:ee,ProjectivePoint:c,Signature:d,utils:b}}function Ff(r){return{hash:r,hmac:(e,...t)=>Lr(r,e,Us(...t)),randomBytes:Xt}}function za(r,e){let t=n=>ja({...r,...Ff(n)});return Object.freeze({...t(e),create:t})}var Ya=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),Za=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),qf=BigInt(1),No=BigInt(2),Wa=(r,e)=>(r+e/No)/e;function $f(r){let e=Ya,t=BigInt(3),n=BigInt(6),s=BigInt(11),o=BigInt(22),i=BigInt(23),a=BigInt(44),c=BigInt(88),f=r*r*r%e,l=f*f*r%e,u=W(l,t,e)*l%e,h=W(u,t,e)*l%e,w=W(h,No,e)*f%e,x=W(w,s,e)*w%e,y=W(x,o,e)*x%e,d=W(y,a,e)*y%e,b=W(d,c,e)*d%e,B=W(b,a,e)*y%e,g=W(B,t,e)*l%e,E=W(g,i,e)*x%e,C=W(E,n,e)*f%e,L=W(C,No,e);if(!To.eql(To.sqr(L),r))throw new Error("Cannot find square root");return L}var To=gt(Ya,void 0,void 0,{sqrt:$f}),De=za({a:BigInt(0),b:BigInt(7),Fp:To,n:Za,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let e=Za,t=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-qf*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),s=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),o=t,i=BigInt("0x100000000000000000000000000000000"),a=Wa(o*r,e),c=Wa(-n*r,e),f=G(r-a*t-c*s,e),l=G(-a*n-c*o,e),u=f>i,h=l>i;if(u&&(f=e-f),h&&(l=e-l),f>i||l>i)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:u,k1:f,k2neg:h,k2:l}}}},qa),Zp=BigInt(0);var Wp=De.ProjectivePoint;function Ja(){return De.utils.randomPrivateKey()}function Xa(r,e){let t=ue.digest(e instanceof Uint8Array?e:e.subarray());if(Re(t))return t.then(({digest:n})=>De.sign(n,r).toDERRawBytes()).catch(n=>{throw new D(String(n),"ERR_INVALID_INPUT")});try{return De.sign(t.digest,r).toDERRawBytes()}catch(n){throw new D(String(n),"ERR_INVALID_INPUT")}}function Qa(r,e,t){let n=ue.digest(t instanceof Uint8Array?t:t.subarray());if(Re(n))return n.then(({digest:s})=>De.verify(e,s,r)).catch(s=>{throw new D(String(s),"ERR_INVALID_INPUT")});try{return De.verify(e,n.digest,r)}catch(s){throw new D(String(s),"ERR_INVALID_INPUT")}}function ec(r){return De.ProjectivePoint.fromHex(r).toRawBytes(!0)}function tc(r){try{De.getPublicKey(r,!0)}catch(e){throw new D(String(e),"ERR_INVALID_PRIVATE_KEY")}}function Lo(r){try{De.ProjectivePoint.fromHex(r)}catch(e){throw new D(String(e),"ERR_INVALID_PUBLIC_KEY")}}function rc(r){try{return De.getPublicKey(r,!0)}catch(e){throw new D(String(e),"ERR_INVALID_PRIVATE_KEY")}}var qr=class{_key;constructor(e){Lo(e),this._key=e}verify(e,t){return Qa(this._key,t,e)}marshal(){return ec(this._key)}get bytes(){return mt.encode({Type:fe.Secp256k1,Data:this.marshal()}).subarray()}equals(e){return ve(this.bytes,e.bytes)}async hash(){let e=ue.digest(this.bytes),t;return Re(e)?{bytes:t}=await e:t=e.bytes,t}},$r=class{_key;_publicKey;constructor(e,t){this._key=e,this._publicKey=t??rc(e),tc(this._key),Lo(this._publicKey)}sign(e){return Xa(this._key,e)}get public(){return new qr(this._publicKey)}marshal(){return this._key}get bytes(){return bt.encode({Type:fe.Secp256k1,Data:this.marshal()}).subarray()}equals(e){return ve(this.bytes,e.bytes)}hash(){let e=ue.digest(this.bytes);return Re(e)?e.then(({bytes:t})=>t):e.bytes}async id(){let e=await this.public.hash();return ne(e,"base58btc")}async export(e,t="libp2p-key"){if(t==="libp2p-key")return nr(this.bytes,e);throw new D(`export format '${t}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function jf(r){return new $r(r)}function zf(r){return new qr(r)}async function Zf(){let r=Ja();return new $r(r)}var fr={rsa:Io,ed25519:mo,secp256k1:Co};function Wf(r){let e=Object.keys(fr).join(" / ");return new D(`invalid or unsupported key type ${r}. Must be ${e}`,"ERR_UNSUPPORTED_KEY_TYPE")}function Yf(r){if(r=r.toLowerCase(),r==="rsa"||r==="ed25519"||r==="secp256k1")return fr[r];throw Wf(r)}function nc(r,e){return e=(e??"rsa").toLowerCase(),Yf(e),r.bytes}var oc=Symbol.for("nodejs.util.inspect.custom"),sc=Object.values(jt).map(r=>r.decoder).reduce((r,e)=>r.or(e),jt.identity.decoder),ic=114,Vo=36,Do=37,Gr=class{type;multihash;privateKey;publicKey;string;constructor(e){this.type=e.type,this.multihash=e.multihash,this.privateKey=e.privateKey,Object.defineProperty(this,"string",{enumerable:!1,writable:!0})}get[Symbol.toStringTag](){return`PeerId(${this.toString()})`}[fs]=!0;toString(){return this.string==null&&(this.string=me.encode(this.multihash.bytes).slice(1)),this.string}toCID(){return ct.createV1(ic,this.multihash)}toBytes(){return this.multihash.bytes}toJSON(){return this.toString()}equals(e){if(e==null)return!1;if(e instanceof Uint8Array)return ve(this.multihash.bytes,e);if(typeof e=="string")return Jf(e).equals(this);if(e?.multihash?.bytes!=null)return ve(this.multihash.bytes,e.multihash.bytes);throw new Error("not valid Id")}[oc](){return`PeerId(${this.toString()})`}},hr=class extends Gr{type="RSA";publicKey;constructor(e){super({...e,type:"RSA"}),this.publicKey=e.publicKey}},dr=class extends Gr{type="Ed25519";publicKey;constructor(e){super({...e,type:"Ed25519"}),this.publicKey=e.multihash.digest}},pr=class extends Gr{type="secp256k1";publicKey;constructor(e){super({...e,type:"secp256k1"}),this.publicKey=e.multihash.digest}},_o=2336,Uo=class{type="url";multihash;privateKey;publicKey;url;constructor(e){this.url=e.toString(),this.multihash=$e.digest(z(this.url))}[oc](){return`PeerId(${this.url})`}[fs]=!0;toString(){return this.toCID().toString()}toCID(){return ct.createV1(_o,this.multihash)}toBytes(){return this.toCID().bytes}equals(e){return e==null?!1:(e instanceof Uint8Array&&(e=ne(e)),e.toString()===this.toString())}};function Jf(r,e){if(e=e??sc,r.charAt(0)==="1"||r.charAt(0)==="Q"){let t=vr(me.decode(`z${r}`));return r.startsWith("12D")?new dr({multihash:t}):r.startsWith("16U")?new pr({multihash:t}):new hr({multihash:t})}return ts(sc.decode(r))}function ts(r){try{let e=vr(r);if(e.code===$e.code){if(e.digest.length===Vo)return new dr({multihash:e});if(e.digest.length===Do)return new pr({multihash:e})}if(e.code===ue.code)return new hr({multihash:e})}catch{return Xf(ct.decode(r))}throw new Error("Supplied PeerID CID is invalid")}function Xf(r){if(r?.multihash==null||r.version==null||r.version===1&&r.code!==ic&&r.code!==_o)throw new Error("Supplied PeerID CID is invalid");if(r.code===_o){let t=ne(r.multihash.digest);return new Uo(new URL(t))}let e=r.multihash;if(e.code===ue.code)return new hr({multihash:r.multihash});if(e.code===$e.code){if(e.digest.length===Vo)return new dr({multihash:r.multihash});if(e.digest.length===Do)return new pr({multihash:r.multihash})}throw new Error("Supplied PeerID CID is invalid")}async function ac(r,e){return r.length===Vo?new dr({multihash:Oe($e.code,r),privateKey:e}):r.length===Do?new pr({multihash:Oe($e.code,r),privateKey:e}):new hr({multihash:await ue.digest(r),publicKey:r,privateKey:e})}async function cc(r){return ac(nc(r))}function gr(){let r={};return r.promise=new Promise((e,t)=>{r.resolve=e,r.reject=t}),r}var rs=class extends Error{type;code;constructor(e,t,n){super(e??"The operation was aborted"),this.type="aborted",this.name=n??"AbortError",this.code=t??"ABORT_ERR"}};async function lc(r,e,t){if(e==null)return r;if(e.aborted)return Promise.reject(new rs(t?.errorMessage,t?.errorCode,t?.errorName));let n,s=new rs(t?.errorMessage,t?.errorCode,t?.errorName);try{return await Promise.race([r,new Promise((o,i)=>{n=()=>{i(s)},e.addEventListener("abort",n)})])}finally{n!=null&&e.removeEventListener("abort",n)}}var Oo=class{readNext;haveNext;ended;nextResult;constructor(){this.ended=!1,this.readNext=gr(),this.haveNext=gr()}[Symbol.asyncIterator](){return this}async next(){if(this.nextResult==null&&await this.haveNext.promise,this.nextResult==null)throw new Error("HaveNext promise resolved but nextResult was undefined");let e=this.nextResult;return this.nextResult=void 0,this.readNext.resolve(),this.readNext=gr(),e}async throw(e){return this.ended=!0,e!=null&&(this.haveNext.promise.catch(()=>{}),this.haveNext.reject(e)),{done:!0,value:void 0}}async return(){let e={done:!0,value:void 0};return await this._push(void 0),e}async push(e,t){await this._push(e,t)}async end(e,t){e!=null?await this.throw(e):await this._push(void 0,t)}async _push(e,t){if(e!=null&&this.ended)throw new Error("Cannot push value onto an ended pushable");for(;this.nextResult!=null;)await this.readNext.promise;e!=null?this.nextResult={done:!1,value:e}:(this.ended=!0,this.nextResult={done:!0,value:void 0}),this.haveNext.resolve(),this.haveNext=gr(),await lc(this.readNext.promise,t?.signal,t)}};function uc(){return new Oo}var hc=Symbol.for("@achingbrain/uint8arraylist");function fc(r,e){if(e==null||e<0)throw new RangeError("index is out of bounds");let t=0;for(let n of r){let s=t+n.byteLength;if(e<s)return{buf:n,index:e-t};t=s}throw new RangeError("index is out of bounds")}function ns(r){return!!r?.[hc]}var it=class r{bufs;length;[hc]=!0;constructor(...e){this.bufs=[],this.length=0,e.length>0&&this.appendAll(e)}*[Symbol.iterator](){yield*this.bufs}get byteLength(){return this.length}append(...e){this.appendAll(e)}appendAll(e){let t=0;for(let n of e)if(n instanceof Uint8Array)t+=n.byteLength,this.bufs.push(n);else if(ns(n))t+=n.byteLength,this.bufs.push(...n.bufs);else throw new Error("Could not append value, must be an Uint8Array or a Uint8ArrayList");this.length+=t}prepend(...e){this.prependAll(e)}prependAll(e){let t=0;for(let n of e.reverse())if(n instanceof Uint8Array)t+=n.byteLength,this.bufs.unshift(n);else if(ns(n))t+=n.byteLength,this.bufs.unshift(...n.bufs);else throw new Error("Could not prepend value, must be an Uint8Array or a Uint8ArrayList");this.length+=t}get(e){let t=fc(this.bufs,e);return t.buf[t.index]}set(e,t){let n=fc(this.bufs,e);n.buf[n.index]=t}write(e,t=0){if(e instanceof Uint8Array)for(let n=0;n<e.length;n++)this.set(t+n,e[n]);else if(ns(e))for(let n=0;n<e.length;n++)this.set(t+n,e.get(n));else throw new Error("Could not write value, must be an Uint8Array or a Uint8ArrayList")}consume(e){if(e=Math.trunc(e),!(Number.isNaN(e)||e<=0)){if(e===this.byteLength){this.bufs=[],this.length=0;return}for(;this.bufs.length>0;)if(e>=this.bufs[0].byteLength)e-=this.bufs[0].byteLength,this.length-=this.bufs[0].byteLength,this.bufs.shift();else{this.bufs[0]=this.bufs[0].subarray(e),this.length-=e;break}}}slice(e,t){let{bufs:n,length:s}=this._subList(e,t);return $t(n,s)}subarray(e,t){let{bufs:n,length:s}=this._subList(e,t);return n.length===1?n[0]:$t(n,s)}sublist(e,t){let{bufs:n,length:s}=this._subList(e,t),o=new r;return o.length=s,o.bufs=[...n],o}_subList(e,t){if(e=e??0,t=t??this.length,e<0&&(e=this.length+e),t<0&&(t=this.length+t),e<0||t>this.length)throw new RangeError("index is out of bounds");if(e===t)return{bufs:[],length:0};if(e===0&&t===this.length)return{bufs:this.bufs,length:this.length};let n=[],s=0;for(let o=0;o<this.bufs.length;o++){let i=this.bufs[o],a=s,c=a+i.byteLength;if(s=c,e>=c)continue;let f=e>=a&&e<c,l=t>a&&t<=c;if(f&&l){if(e===a&&t===c){n.push(i);break}let u=e-a;n.push(i.subarray(u,u+(t-e)));break}if(f){if(e===0){n.push(i);continue}n.push(i.subarray(e-a));continue}if(l){if(t===c){n.push(i);break}n.push(i.subarray(0,t-a));break}n.push(i)}return{bufs:n,length:t-e}}indexOf(e,t=0){if(!ns(e)&&!(e instanceof Uint8Array))throw new TypeError('The "value" argument must be a Uint8ArrayList or Uint8Array');let n=e instanceof Uint8Array?e:e.subarray();if(t=Number(t??0),isNaN(t)&&(t=0),t<0&&(t=this.length+t),t<0&&(t=0),e.length===0)return t>this.length?this.length:t;let s=n.byteLength;if(s===0)throw new TypeError("search must be at least 1 byte long");let o=256,i=new Int32Array(o);for(let u=0;u<o;u++)i[u]=-1;for(let u=0;u<s;u++)i[n[u]]=u;let a=i,c=this.byteLength-n.byteLength,f=n.byteLength-1,l;for(let u=t;u<=c;u+=l){l=0;for(let h=f;h>=0;h--){let w=this.get(u+h);if(n[h]!==w){l=Math.max(1,h-a[w]);break}}if(l===0)return u}return-1}getInt8(e){let t=this.subarray(e,e+1);return new DataView(t.buffer,t.byteOffset,t.byteLength).getInt8(0)}setInt8(e,t){let n=Be(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setInt8(0,t),this.write(n,e)}getInt16(e,t){let n=this.subarray(e,e+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt16(0,t)}setInt16(e,t,n){let s=Ge(2);new DataView(s.buffer,s.byteOffset,s.byteLength).setInt16(0,t,n),this.write(s,e)}getInt32(e,t){let n=this.subarray(e,e+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt32(0,t)}setInt32(e,t,n){let s=Ge(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setInt32(0,t,n),this.write(s,e)}getBigInt64(e,t){let n=this.subarray(e,e+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigInt64(0,t)}setBigInt64(e,t,n){let s=Ge(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigInt64(0,t,n),this.write(s,e)}getUint8(e){let t=this.subarray(e,e+1);return new DataView(t.buffer,t.byteOffset,t.byteLength).getUint8(0)}setUint8(e,t){let n=Be(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setUint8(0,t),this.write(n,e)}getUint16(e,t){let n=this.subarray(e,e+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint16(0,t)}setUint16(e,t,n){let s=Ge(2);new DataView(s.buffer,s.byteOffset,s.byteLength).setUint16(0,t,n),this.write(s,e)}getUint32(e,t){let n=this.subarray(e,e+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint32(0,t)}setUint32(e,t,n){let s=Ge(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setUint32(0,t,n),this.write(s,e)}getBigUint64(e,t){let n=this.subarray(e,e+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigUint64(0,t)}setBigUint64(e,t,n){let s=Ge(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigUint64(0,t,n),this.write(s,e)}getFloat32(e,t){let n=this.subarray(e,e+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat32(0,t)}setFloat32(e,t,n){let s=Ge(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setFloat32(0,t,n),this.write(s,e)}getFloat64(e,t){let n=this.subarray(e,e+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat64(0,t)}setFloat64(e,t,n){let s=Ge(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setFloat64(0,t,n),this.write(s,e)}equals(e){if(e==null||!(e instanceof r)||e.bufs.length!==this.bufs.length)return!1;for(let t=0;t<this.bufs.length;t++)if(!ve(this.bufs[t],e.bufs[t]))return!1;return!0}static fromUint8Arrays(e,t){let n=new r;return n.bufs=e,t==null&&(t=e.reduce((s,o)=>s+o.byteLength,0)),n.length=t,n}};var ss=class extends Error{name="UnexpectedEOFError";code="ERR_UNEXPECTED_EOF"};var Ho=class extends Error{code;constructor(e,t){super(e),this.code=t}},Po=class extends Ho{type;constructor(e){super(e,"ABORT_ERR"),this.type="aborted",this.name="AbortError"}};function dc(r,e){let t=uc();r.sink(t).catch(async i=>{await t.end(i)}),r.sink=async i=>{for await(let a of i)await t.push(a);await t.end()};let n=r.source;r.source[Symbol.iterator]!=null?n=r.source[Symbol.iterator]():r.source[Symbol.asyncIterator]!=null&&(n=r.source[Symbol.asyncIterator]());let s=new it;return{read:async(i,a)=>{a?.signal?.throwIfAborted();let c,f=new Promise((l,u)=>{c=()=>{u(new Po("Read aborted"))},a?.signal?.addEventListener("abort",c)});try{if(i==null){let{done:u,value:h}=await Promise.race([n.next(),f]);return u===!0?new it:h}for(;s.byteLength<i;){let{value:u,done:h}=await Promise.race([n.next(),f]);if(h===!0)throw new ss("unexpected end of input");s.append(u)}let l=s.sublist(0,i);return s.consume(i),l}finally{c!=null&&a?.signal?.removeEventListener("abort",c)}},write:async(i,a)=>{a?.signal?.throwIfAborted(),i instanceof Uint8Array?await t.push(i,a):await t.push(i.subarray(),a)},unwrap:()=>{if(s.byteLength>0){let i=r.source;r.source=async function*(){e?.yieldBytes===!1?yield s:yield*s,yield*i}()}return r}}}var os=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},is=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},as=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"};function pc(r,e={}){let t=dc(r,e);e.maxDataLength!=null&&e.maxLengthLength==null&&(e.maxLengthLength=Je(e.maxDataLength));let n=e?.lengthDecoder??Ki,s=e?.lengthEncoder??Mi;return{read:async i=>{let a=-1,c=new it;for(;;){c.append(await t.read(1,i));try{a=n(c)}catch(f){if(f instanceof RangeError)continue;throw f}if(a<0)throw new os("Invalid message length");if(e?.maxLengthLength!=null&&c.byteLength>e.maxLengthLength)throw new as("message length length too long");if(a>-1)break}if(e?.maxDataLength!=null&&a>e.maxDataLength)throw new is("message length too long");return t.read(a,i)},write:async(i,a)=>{await t.write(new it(s(i.byteLength),i),a)},writeV:async(i,a)=>{let c=new it(...i.flatMap(f=>[s(f.byteLength),f]));await t.write(c,a)},unwrap:()=>t.unwrap()}}function gc(r,e){let t=pc(r,e),n={read:async(s,o)=>{let i=await t.read(o);return s.decode(i)},write:async(s,o,i)=>{await t.write(o.encode(s),i)},writeV:async(s,o,i)=>{await t.writeV(s.map(a=>o.encode(a)),i)},pb:s=>({read:async o=>n.read(s,o),write:async(o,i)=>n.write(o,s,i),writeV:async(o,i)=>n.writeV(o,s,i),unwrap:()=>n}),unwrap:()=>t.unwrap()};return n}var cs;(function(r){let e;r.codec=()=>(e==null&&(e=Vt((t,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),t.id!=null&&(n.uint32(10),n.bytes(t.id)),t.pubkey!=null&&(n.uint32(18),yr.codec().encode(t.pubkey,n)),s.lengthDelimited!==!1&&n.ldelim()},(t,n)=>{let s={},o=n==null?t.len:t.pos+n;for(;t.pos<o;){let i=t.uint32();switch(i>>>3){case 1:s.id=t.bytes();break;case 2:s.pubkey=yr.codec().decode(t,t.uint32());break;default:t.skipType(i&7);break}}return s})),e),r.encode=t=>Ut(t,r.codec()),r.decode=t=>Ct(t,r.codec())})(cs||(cs={}));var Se;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.Secp256k1="Secp256k1",r.ECDSA="ECDSA"})(Se||(Se={}));var ls;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.Secp256k1=2]="Secp256k1",r[r.ECDSA=3]="ECDSA"})(ls||(ls={}));(function(r){r.codec=()=>Nr(ls)})(Se||(Se={}));var yr;(function(r){let e;r.codec=()=>(e==null&&(e=Vt((t,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),t.Type!=null&&ls[t.Type]!==0&&(n.uint32(8),Se.codec().encode(t.Type,n)),t.Data!=null&&t.Data.byteLength>0&&(n.uint32(18),n.bytes(t.Data)),s.lengthDelimited!==!1&&n.ldelim()},(t,n)=>{let s={Type:Se.RSA,Data:new Uint8Array(0)},o=n==null?t.len:t.pos+n;for(;t.pos<o;){let i=t.uint32();switch(i>>>3){case 1:s.Type=Se.codec().decode(t);break;case 2:s.Data=t.bytes();break;default:t.skipType(i&7);break}}return s})),e),r.encode=t=>Ut(t,r.codec()),r.decode=t=>Ct(t,r.codec())})(yr||(yr={}));var Qf="/plaintext/2.0.0",Mo=class{protocol=Qf;log;timeout;constructor(e,t={}){this.log=e.logger.forComponent("libp2p:plaintext"),this.timeout=t.timeout??1e3}[Symbol.toStringTag]="@libp2p/plaintext";[Wo]=["@libp2p/connection-encryption"];async secureInbound(e,t,n){return this._encrypt(e,t,n)}async secureOutbound(e,t,n){return this._encrypt(e,t,n)}async _encrypt(e,t,n){let s=AbortSignal.timeout(this.timeout),o=gc(t).pb(cs),i=Se.RSA;e.type==="Ed25519"?i=Se.Ed25519:e.type==="secp256k1"&&(i=Se.Secp256k1),this.log("write pubkey exchange to peer %p",n);let[,a]=await Promise.all([o.write({id:e.toBytes(),pubkey:{Type:i,Data:e.publicKey==null?new Uint8Array(0):yr.decode(e.publicKey).Data??new Uint8Array(0)}},{signal:s}),o.read({signal:s})]),c;try{if(a.pubkey==null)throw new Error("Public key missing");if(a.pubkey.Data.length===0)throw new Error("Public key data too short");if(a.id==null)throw new Error("Remote id missing");let f;if(a.pubkey.Type===Se.RSA)f=fr.rsa.unmarshalRsaPublicKey(a.pubkey.Data);else if(a.pubkey.Type===Se.Ed25519)f=fr.ed25519.unmarshalEd25519PublicKey(a.pubkey.Data);else if(a.pubkey.Type===Se.Secp256k1)f=fr.secp256k1.unmarshalSecp256k1PublicKey(a.pubkey.Data);else throw new Error("Unknown public key type");if(c=await cc(f),!c.equals(ts(a.id)))throw new Error("Public key did not match id")}catch(f){throw this.log.error(f),new Zr("Remote did not provide its public key")}if(n!=null&&!c.equals(n))throw new zr;return this.log("plaintext key exchange completed successfully with peer %p",c),{conn:o.unwrap().unwrap(),remotePeer:c}}};function eh(r){return e=>new Mo(e,r)}return Lc(th);})();
|
|
4
|
+
`));let e=this.idBlock.tagClass===3?`[${this.idBlock.tagNumber}]`:this.constructor.NAME;return t.length?`${e} :
|
|
5
|
+
${t.join(`
|
|
6
|
+
`)}`:`${e} :`}};Pi=de;A.Constructed=Pi;de.NAME="CONSTRUCTED";var Xr=class extends ut{fromBER(t,e,n){return e}toBER(t){return Lt}};Xr.override="EndOfContentValueBlock";var Fi,Qr=class extends it{constructor(t={}){super(t,Xr),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};Fi=Qr;A.EndOfContent=Fi;Qr.NAME=fr;var Ki,qe=class extends it{constructor(t={}){super(t,ut),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}`}};Ki=qe;A.Null=Ki;qe.NAME="NULL";var tn=class extends Wt(ut){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 Zt(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,oo.call(this),this.blockLength=n,e+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};tn.NAME="BooleanValueBlock";var $i,en=class extends it{constructor(t={}){super(t,tn),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}`}};$i=en;A.Boolean=$i;en.NAME="BOOLEAN";var rn=class extends Wt(_t){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=_t.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===fr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(i!==Hi)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?_t.prototype.toBER.call(this,t,e):t?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};rn.NAME="OctetStringValueBlock";var qi,nn=class r extends it{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,o;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((o=n.value)===null||o===void 0)&&o.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},rn),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=Ln(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?de.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)}};qi=nn;A.OctetString=qi;nn.NAME=Hi;var sn=class extends Wt(_t){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=_t.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let a of this.value){let c=a.constructor.NAME;if(c===fr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==Di)return this.error="BIT STRING may consists of BIT STRINGs only",-1;let f=a.valueBlock;if(this.unusedBits>0&&f.unusedBits>0)return this.error='Using of "unused bits" inside constructive BIT STRING allowed for least one only',-1;this.unusedBits=f.unusedBits}return s}let o=M.BufferSourceConverter.toUint8Array(t);if(!Zt(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=Ln(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 _t.prototype.toBER.call(this,t,e);if(t)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return Lt;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}}};sn.NAME="BitStringValueBlock";var zi,ze=class extends it{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,o;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((o=n.value)===null||o===void 0)&&o.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},sn),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 de.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)}`}}};zi=ze;A.BitString=zi;ze.NAME=Di;var Gi;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,f=0,l=c<i?i:c,u=0;for(let h=l;h>=0;h--,u++){switch(!0){case u<a.length:f=o[i-u]+a[c-u]+e[0];break;default:f=o[i-u]+e[0]}switch(e[0]=f/10,!0){case u>=o.length:o=zr(new Uint8Array([f%10]),o);break;default:o[i-u]=f%10}}return e[0]>0&&(o=zr(e,o)),o}function Vi(r){if(r>=lr.length)for(let t=lr.length;t<=r;t++){let e=new Uint8Array([0]),n=lr[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=zr(e,n)),lr.push(n)}return lr[r]}function Zu(r,t){let e=0,n=new Uint8Array(r),s=new Uint8Array(t),o=n.slice(0),i=o.length-1,a=s.slice(0),c=a.length-1,f,l=0;for(let u=c;u>=0;u--,l++)switch(f=o[i-l]-a[c-l]-e,!0){case f<0:e=1,o[i-l]=f+10;break;default:e=0,o[i-l]=f}if(e>0)for(let u=i-c+1;u>=0;u--,l++)if(f=o[i-l]-e,f<0)e=1,o[i-l]=f+10;else{e=0,o[i-l]=f;break}return o.slice()}var hr=class extends Wt(ut){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=oo.call(this)))}set valueDec(t){this._valueDec=t,this.isHexOnly=!1,this.valueHexView=new Uint8Array(Li(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 f=0;f<8;f++){if((s&1)===1)switch(n){case t:e=Zu(Vi(n),e),i="-";break;default:e=ju(e,Vi(n))}n++,s>>=1}}for(let c=0;c<e.length;c++)e[c]&&(a=!0),a&&(i+=_i.charAt(e[c]));return a===!1&&(i+=_i.charAt(0)),i}};Gi=hr;hr.NAME="IntegerValueBlock";Object.defineProperty(Gi.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var ji,at=class r extends it{constructor(t={}){super(t,hr),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return Gr(),BigInt(this.valueBlock.toString())}static fromBigInt(t){Gr();let e=BigInt(t),n=new ur,s=e.toString(16).replace(/^-/,""),o=new Uint8Array(M.Convert.FromHex(s));if(e<0){let a=new Uint8Array(o.length+(o[0]&128?1:0));a[0]|=128;let f=BigInt(`0x${M.Convert.ToHex(a)}`)+e,l=M.BufferSourceConverter.toUint8Array(M.Convert.FromHex(f.toString(16)));l[0]|=128,n.write(l)}else o[0]&128&&n.write(new Uint8Array([0])),n.write(o);return new 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()}`}};ji=at;A.Integer=ji;at.NAME="INTEGER";var Zi,on=class extends at{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};Zi=on;A.Enumerated=Zi;on.NAME="ENUMERATED";var dr=class extends Wt(ut){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(!Zt(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){Gr();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=he(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Lt;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}}};dr.NAME="sidBlock";var an=class extends ut{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 dr;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,Lt;e.push(s)}return io(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 dr;if(s>Number.MAX_SAFE_INTEGER){Gr();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}};an.NAME="ObjectIdentifierValueBlock";var Wi,Ge=class extends it{constructor(t={}){super(t,an),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()}}};Wi=Ge;A.ObjectIdentifier=Wi;Ge.NAME="OBJECT IDENTIFIER";var gr=class extends Wt(zt){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(!Zt(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=he(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Lt;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}}};gr.NAME="relativeSidBlock";var cn=class extends ut{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 gr;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,Lt;n.push(o)}return io(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 gr;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}};cn.NAME="RelativeObjectIdentifierValueBlock";var Ji,ln=class extends it{constructor(t={}){super(t,cn),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()}}};Ji=ln;A.RelativeObjectIdentifier=Ji;ln.NAME="RelativeObjectIdentifier";var Yi,Gt=class extends de{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};Yi=Gt;A.Sequence=Yi;Gt.NAME="SEQUENCE";var Xi,un=class extends de{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};Xi=un;A.Set=Xi;un.NAME="SET";var fn=class extends Wt(ut){constructor({...t}={}){super(t),this.isHexOnly=!0,this.value=je}toJSON(){return{...super.toJSON(),value:this.value}}};fn.NAME="StringValueBlock";var hn=class extends fn{};hn.NAME="SimpleStringValueBlock";var gt=class extends Wr{constructor({...t}={}){super(t,hn)}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}};gt.NAME="SIMPLE STRING";var dn=class extends gt{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}};dn.NAME="Utf8StringValueBlock";var Qi,jt=class extends dn{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};Qi=jt;A.Utf8String=Qi;jt.NAME="UTF8String";var gn=class extends gt{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))}};gn.NAME="BmpStringValueBlock";var ta,pn=class extends gn{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};ta=pn;A.BmpString=ta;pn.NAME="BMPString";var mn=class extends gt{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=he(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}};mn.NAME="UniversalStringValueBlock";var ea,bn=class extends mn{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};ea=bn;A.UniversalString=ea;bn.NAME="UniversalString";var ra,yn=class extends gt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};ra=yn;A.NumericString=ra;yn.NAME="NumericString";var na,wn=class extends gt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};na=wn;A.PrintableString=na;wn.NAME="PrintableString";var sa,xn=class extends gt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};sa=xn;A.TeletexString=sa;xn.NAME="TeletexString";var oa,vn=class extends gt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};oa=vn;A.VideotexString=oa;vn.NAME="VideotexString";var ia,Bn=class extends gt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};ia=Bn;A.IA5String=ia;Bn.NAME="IA5String";var aa,En=class extends gt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};aa=En;A.GraphicString=aa;En.NAME="GraphicString";var ca,pr=class extends gt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};ca=pr;A.VisibleString=ca;pr.NAME="VisibleString";var la,An=class extends gt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};la=An;A.GeneralString=la;An.NAME="GeneralString";var ua,Sn=class extends gt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};ua=Sn;A.CharacterString=ua;Sn.NAME="CharacterString";var fa,mr=class extends pr{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]=vt(this.year<2e3?this.year-1900:this.year-2e3,2),e[1]=vt(this.month,2),e[2]=vt(this.day,2),e[3]=vt(this.hour,2),e[4]=vt(this.minute,2),e[5]=vt(this.second,2),e[6]="Z",e.join("")}return super.toString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.toDate().toISOString()}`}toJSON(){return{...super.toJSON(),year:this.year,month:this.month,day:this.day,hour:this.hour,minute:this.minute,second:this.second}}};fa=mr;A.UTCTime=fa;mr.NAME="UTCTime";var ha,kn=class extends mr{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 u=new Number(t[t.length-1]);if(isNaN(u.valueOf()))throw new Error("Wrong input string for conversion");n=t}if(e){if(n.indexOf("+")!==-1)throw new Error("Wrong input string for conversion");if(n.indexOf("-")!==-1)throw new Error("Wrong input string for conversion")}else{let u=1,h=n.indexOf("+"),x="";if(h===-1&&(h=n.indexOf("-"),u=-1),h!==-1){if(x=n.substring(h+1),n=n.substring(0,h),x.length!==2&&x.length!==4)throw new Error("Wrong input string for conversion");let v=parseInt(x.substring(0,2),10);if(isNaN(v.valueOf()))throw new Error("Wrong input string for conversion");if(a=u*v,x.length===4){if(v=parseInt(x.substring(2,4),10),isNaN(v.valueOf()))throw new Error("Wrong input string for conversion");c=u*v}}}let f=n.indexOf(".");if(f===-1&&(f=n.indexOf(",")),f!==-1){let u=new Number(`0${n.substring(f)}`);if(isNaN(u.valueOf()))throw new Error("Wrong input string for conversion");o=u.valueOf(),s=n.substring(0,f)}else s=n;switch(!0){case s.length===8:if(i=/(\d{4})(\d{2})(\d{2})/ig,f!==-1)throw new Error("Wrong input string for conversion");break;case s.length===10:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let u=60*o;this.minute=Math.floor(u),u=60*(u-this.minute),this.second=Math.floor(u),u=1e3*(u-this.second),this.millisecond=Math.floor(u)}break;case s.length===12:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let u=60*o;this.second=Math.floor(u),u=1e3*(u-this.second),this.millisecond=Math.floor(u)}break;case s.length===14:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let u=1e3*o;this.millisecond=Math.floor(u)}break;default:throw new Error("Wrong input string for conversion")}let l=i.exec(s);if(l===null)throw new Error("Wrong input string for conversion");for(let u=1;u<l.length;u++)switch(u){case 1:this.year=parseInt(l[u],10);break;case 2:this.month=parseInt(l[u],10);break;case 3:this.day=parseInt(l[u],10);break;case 4:this.hour=parseInt(l[u],10)+a;break;case 5:this.minute=parseInt(l[u],10)+c;break;case 6:this.second=parseInt(l[u],10);break;default:throw new Error("Wrong input string for conversion")}if(e===!1){let u=new Date(this.year,this.month,this.day,this.hour,this.minute,this.second,this.millisecond);this.year=u.getUTCFullYear(),this.month=u.getUTCMonth(),this.day=u.getUTCDay(),this.hour=u.getUTCHours(),this.minute=u.getUTCMinutes(),this.second=u.getUTCSeconds(),this.millisecond=u.getUTCMilliseconds()}}toString(t="iso"){if(t==="iso"){let e=[];return e.push(vt(this.year,4)),e.push(vt(this.month,2)),e.push(vt(this.day,2)),e.push(vt(this.hour,2)),e.push(vt(this.minute,2)),e.push(vt(this.second,2)),this.millisecond!==0&&(e.push("."),e.push(vt(this.millisecond,3))),e.push("Z"),e.join("")}return super.toString(t)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};ha=kn;A.GeneralizedTime=ha;kn.NAME="GeneralizedTime";var da,In=class extends jt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};da=In;A.DATE=da;In.NAME="DATE";var ga,Nn=class extends jt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};ga=Nn;A.TimeOfDay=ga;Nn.NAME="TimeOfDay";var pa,Cn=class extends jt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};pa=Cn;A.DateTime=pa;Cn.NAME="DateTime";var ma,Un=class extends jt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};ma=Un;A.Duration=ma;Un.NAME="Duration";var ba,Tn=class extends jt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};ba=Tn;A.TIME=ba;Tn.NAME="TIME";function Bt(r,t="utf8"){let e=Pr[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}var br=class extends Error{constructor(t="An error occurred while verifying a message"){super(t),this.name="VerificationError"}},Rn=class extends Error{constructor(t="Missing Web Crypto API"){super(t),this.name="WebCryptoMissingError"}};var ya={get(r=globalThis){let t=r.crypto;if(t?.subtle==null)throw new Rn("Missing Web Crypto API. The most likely cause of this error is that this page is being accessed from an insecure context (i.e. not HTTPS). For more information and possible resolutions see https://github.com/libp2p/js-libp2p/blob/main/packages/crypto/README.md#web-crypto-api");return t}};var ge=ya;async function wa(r){let t=await ge.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 Ju(t);return{privateKey:e[0],publicKey:e[1]}}async function xa(r,t){let e=await ge.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await ge.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},e,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(n,0,n.byteLength)}async function va(r,t,e){let n=await ge.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return ge.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,t,e instanceof Uint8Array?e:e.subarray())}async function Ju(r){if(r.privateKey==null||r.publicKey==null)throw new dt("Private and public key are required");return Promise.all([ge.get().subtle.exportKey("jwk",r.privateKey),ge.get().subtle.exportKey("jwk",r.publicKey)])}function lo(r){if(r.kty!=="RSA")throw new dt("invalid key type");if(r.n==null)throw new dt("invalid key modulus");return nt(r.n,"base64url").length*8}var Ze=class{type="RSA";_key;_raw;_multihash;constructor(t,e){this._key=t,this._multihash=e}get raw(){return this._raw==null&&(this._raw=yr.jwkToPkix(this._key)),this._raw}toMultihash(){return this._multihash}toCID(){return Et.createV1(114,this._multihash)}toString(){return Q.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:mt(this.raw,t.raw)}verify(t,e){return va(this._key,e,t)}},wr=class{type="RSA";_key;_raw;publicKey;constructor(t,e){this._key=t,this.publicKey=e}get raw(){return this._raw==null&&(this._raw=yr.jwkToPkcs1(this._key)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:mt(this.raw,t.raw)}sign(t){return xa(this._key,t)}};var _n=8192,uo=18;function Ba(r){let{result:t}=co(r),e=t.valueBlock.value;return{n:Bt(Vt(e[1].toBigInt()),"base64url"),e:Bt(Vt(e[2].toBigInt()),"base64url"),d:Bt(Vt(e[3].toBigInt()),"base64url"),p:Bt(Vt(e[4].toBigInt()),"base64url"),q:Bt(Vt(e[5].toBigInt()),"base64url"),dp:Bt(Vt(e[6].toBigInt()),"base64url"),dq:Bt(Vt(e[7].toBigInt()),"base64url"),qi:Bt(Vt(e[8].toBigInt()),"base64url"),kty:"RSA",alg:"RS256"}}function Yu(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 dt("JWK was missing components");let e=new Gt({value:[new at({value:0}),at.fromBigInt(Ht(nt(r.n,"base64url"))),at.fromBigInt(Ht(nt(r.e,"base64url"))),at.fromBigInt(Ht(nt(r.d,"base64url"))),at.fromBigInt(Ht(nt(r.p,"base64url"))),at.fromBigInt(Ht(nt(r.q,"base64url"))),at.fromBigInt(Ht(nt(r.dp,"base64url"))),at.fromBigInt(Ht(nt(r.dq,"base64url"))),at.fromBigInt(Ht(nt(r.qi,"base64url")))]}).toBER();return new Uint8Array(e,0,e.byteLength)}function Ea(r){let{result:t}=co(r),e=t.valueBlock.value[1].valueBlock.value[0].valueBlock.value;return{kty:"RSA",n:Bt(Vt(e[0].toBigInt()),"base64url"),e:Bt(Vt(e[1].toBigInt()),"base64url")}}function fo(r){if(r.n==null||r.e==null)throw new dt("JWK was missing components");let e=new Gt({value:[new Gt({value:[new Ge({value:"1.2.840.113549.1.1.1"}),new qe]}),new ze({valueHex:new Gt({value:[at.fromBigInt(Ht(nt(r.n,"base64url"))),at.fromBigInt(Ht(nt(r.e,"base64url")))]}).toBER()})]}).toBER();return new Uint8Array(e,0,e.byteLength)}function Vt(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 Ht(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 Aa(r){let t=Ba(r);return Sa(t)}function ho(r){let t=Ea(r);if(lo(t)>_n)throw new Ne("Key size is too large");let e=Ke(le.encode({Type:xt.RSA,Data:r})),n=kt(uo,e);return new Ze(t,n)}function Sa(r){if(lo(r)>_n)throw new dt("Key size is too large");let t=Ia(r),e=Ke(le.encode({Type:xt.RSA,Data:fo(t.publicKey)})),n=kt(uo,e);return new wr(t.privateKey,new Ze(t.publicKey,n))}async function ka(r){if(r>_n)throw new dt("Key size is too large");let t=await wa(r),e=Ke(le.encode({Type:xt.RSA,Data:fo(t.publicKey)})),n=kt(uo,e);return new wr(t.privateKey,new Ze(t.publicKey,n))}function Ia(r){if(r==null)throw new dt("Missing key parameter");return{privateKey:r,publicKey:{kty:r.kty,n:r.n,e:r.e}}}var Vn=class extends Oe{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,jo(t);let n=rr(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 De(this),this.iHash.update(t),this}digestInto(t){De(this),He(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()}},go=(r,t,e)=>new Vn(r,t).update(e).digest();go.create=(r,t)=>new Vn(r,t);function Na(r){r.lowS!==void 0&&Nt("lowS",r.lowS),r.prehash!==void 0&&Nt("prehash",r.prehash)}function Xu(r){let t=or(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:Qu,hexToBytes:tf}=Ur,Jt={Err:class extends Error{constructor(t=""){super(t)}},_tlv:{encode:(r,t)=>{let{Err:e}=Jt;if(r<0||r>256)throw new e("tlv.encode: wrong tag");if(t.length&1)throw new e("tlv.encode: unpadded data");let n=t.length/2,s=me(n);if(s.length/2&128)throw new e("tlv.encode: long form length too big");let o=n>127?me(s.length/2|128):"";return`${me(r)}${o}${s}${t}`},decode(r,t){let{Err:e}=Jt,n=0;if(r<0||r>256)throw new e("tlv.encode: wrong tag");if(t.length<2||t[n++]!==r)throw new e("tlv.decode: wrong tlv");let s=t[n++],o=!!(s&128),i=0;if(!o)i=s;else{let c=s&127;if(!c)throw new e("tlv.decode(long): indefinite length not supported");if(c>4)throw new e("tlv.decode(long): byte length is too big");let f=t.subarray(n,n+c);if(f.length!==c)throw new e("tlv.decode: length bytes not complete");if(f[0]===0)throw new e("tlv.decode(long): zero leftmost byte");for(let l of f)i=i<<8|l;if(n+=c,i<128)throw new e("tlv.decode(long): not minimal encoding")}let a=t.subarray(n,n+i);if(a.length!==i)throw new e("tlv.decode: wrong value length");return{v:a,l:t.subarray(n+i)}}},_int:{encode(r){let{Err:t}=Jt;if(r<Yt)throw new t("integer: negative integers are not allowed");let e=me(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}=Jt;if(r[0]&128)throw new t("Invalid signature integer: negative");if(r[0]===0&&!(r[1]&128))throw new t("Invalid signature integer: unnecessary leading zero");return Qu(r)}},toSig(r){let{Err:t,_int:e,_tlv:n}=Jt,s=typeof r=="string"?tf(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:f,l}=n.decode(2,c);if(l.length)throw new t("Invalid signature: left bytes after parsing");return{r:e.decode(a),s:e.decode(f)}},hexFromSig(r){let{_tlv:t,_int:e}=Jt,n=`${t.encode(2,e.encode(r.r))}${t.encode(2,e.encode(r.s))}`;return t.encode(48,n)}},Yt=BigInt(0),st=BigInt(1),P0=BigInt(2),Ca=BigInt(3),F0=BigInt(4);function ef(r){let t=Xu(r),{Fp:e}=t,n=ae(t.n,t.nBitLength),s=t.toBytes||((b,d,y)=>{let E=d.toAffine();return Kt(Uint8Array.from([4]),e.toBytes(E.x),e.toBytes(E.y))}),o=t.fromBytes||(b=>{let d=b.subarray(1),y=e.fromBytes(d.subarray(0,e.BYTES)),E=e.fromBytes(d.subarray(e.BYTES,2*e.BYTES));return{x:y,y:E}});function i(b){let{a:d,b:y}=t,E=e.sqr(b),p=e.mul(E,b);return e.add(e.add(p,e.mul(b,d)),y)}if(!e.eql(e.sqr(t.Gy),i(t.Gx)))throw new Error("bad generator point: equation left != right");function a(b){return nr(b,st,t.n)}function c(b){let{allowedPrivateKeyLengths:d,nByteLength:y,wrapPrivateKey:E,n:p}=t;if(d&&typeof b!="bigint"){if(se(b)&&(b=Pt(b)),typeof b!="string"||!d.includes(b.length))throw new Error("Invalid key");b=b.padStart(y*2,"0")}let S;try{S=typeof b=="bigint"?b:Ft(W("private key",b,y))}catch{throw new Error(`private key must be ${y} bytes, hex or bigint, not ${typeof b}`)}return E&&(S=q(S,p)),bt("private key",S,st,p),S}function f(b){if(!(b instanceof h))throw new Error("ProjectivePoint expected")}let l=we((b,d)=>{let{px:y,py:E,pz:p}=b;if(e.eql(p,e.ONE))return{x:y,y:E};let S=b.is0();d==null&&(d=S?e.ONE:e.inv(p));let L=e.mul(y,d),T=e.mul(E,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:L,y:T}}),u=we(b=>{if(b.is0()){if(t.allowInfinityPoint&&!e.is0(b.py))return;throw new Error("bad point: ZERO")}let{x:d,y}=b.toAffine();if(!e.isValid(d)||!e.isValid(y))throw new Error("bad point: x or y not FE");let E=e.sqr(y),p=i(d);if(!e.eql(E,p))throw new Error("bad point: equation left != right");if(!b.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});class h{constructor(d,y,E){if(this.px=d,this.py=y,this.pz=E,d==null||!e.isValid(d))throw new Error("x required");if(y==null||!e.isValid(y))throw new Error("y required");if(E==null||!e.isValid(E))throw new Error("z required");Object.freeze(this)}static fromAffine(d){let{x:y,y:E}=d||{};if(!d||!e.isValid(y)||!e.isValid(E))throw new Error("invalid affine point");if(d instanceof h)throw new Error("projective point not allowed");let p=S=>e.eql(S,e.ZERO);return p(y)&&p(E)?h.ZERO:new h(y,E,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(d){let y=e.invertBatch(d.map(E=>E.pz));return d.map((E,p)=>E.toAffine(y[p])).map(h.fromAffine)}static fromHex(d){let y=h.fromAffine(o(W("pointHex",d)));return y.assertValidity(),y}static fromPrivateKey(d){return h.BASE.multiply(c(d))}static msm(d,y){return Rr(h,n,d,y)}_setWindowSize(d){v.setWindowSize(this,d)}assertValidity(){u(this)}hasEvenY(){let{y:d}=this.toAffine();if(e.isOdd)return!e.isOdd(d);throw new Error("Field doesn't support isOdd")}equals(d){f(d);let{px:y,py:E,pz:p}=this,{px:S,py:L,pz:T}=d,k=e.eql(e.mul(y,T),e.mul(S,p)),I=e.eql(e.mul(E,T),e.mul(L,p));return k&&I}negate(){return new h(this.px,e.neg(this.py),this.pz)}double(){let{a:d,b:y}=t,E=e.mul(y,Ca),{px:p,py:S,pz:L}=this,T=e.ZERO,k=e.ZERO,I=e.ZERO,U=e.mul(p,p),J=e.mul(S,S),F=e.mul(L,L),H=e.mul(p,S);return H=e.add(H,H),I=e.mul(p,L),I=e.add(I,I),T=e.mul(d,I),k=e.mul(E,F),k=e.add(T,k),T=e.sub(J,k),k=e.add(J,k),k=e.mul(T,k),T=e.mul(H,T),I=e.mul(E,I),F=e.mul(d,F),H=e.sub(U,F),H=e.mul(d,H),H=e.add(H,I),I=e.add(U,U),U=e.add(I,U),U=e.add(U,F),U=e.mul(U,H),k=e.add(k,U),F=e.mul(S,L),F=e.add(F,F),U=e.mul(F,H),T=e.sub(T,U),I=e.mul(F,J),I=e.add(I,I),I=e.add(I,I),new h(T,k,I)}add(d){f(d);let{px:y,py:E,pz:p}=this,{px:S,py:L,pz:T}=d,k=e.ZERO,I=e.ZERO,U=e.ZERO,J=t.a,F=e.mul(t.b,Ca),H=e.mul(y,S),Y=e.mul(E,L),B=e.mul(p,T),N=e.add(y,E),m=e.add(S,L);N=e.mul(N,m),m=e.add(H,Y),N=e.sub(N,m),m=e.add(y,p);let g=e.add(S,T);return m=e.mul(m,g),g=e.add(H,B),m=e.sub(m,g),g=e.add(E,p),k=e.add(L,T),g=e.mul(g,k),k=e.add(Y,B),g=e.sub(g,k),U=e.mul(J,m),k=e.mul(F,B),U=e.add(k,U),k=e.sub(Y,U),U=e.add(Y,U),I=e.mul(k,U),Y=e.add(H,H),Y=e.add(Y,H),B=e.mul(J,B),m=e.mul(F,m),Y=e.add(Y,B),B=e.sub(H,B),B=e.mul(J,B),m=e.add(m,B),H=e.mul(Y,m),I=e.add(I,H),H=e.mul(g,m),k=e.mul(N,k),k=e.sub(k,H),H=e.mul(N,Y),U=e.mul(g,U),U=e.add(U,H),new h(k,I,U)}subtract(d){return this.add(d.negate())}is0(){return this.equals(h.ZERO)}wNAF(d){return v.wNAFCached(this,d,h.normalizeZ)}multiplyUnsafe(d){bt("scalar",d,Yt,t.n);let y=h.ZERO;if(d===Yt)return y;if(d===st)return this;let{endo:E}=t;if(!E)return v.unsafeLadder(this,d);let{k1neg:p,k1:S,k2neg:L,k2:T}=E.splitScalar(d),k=y,I=y,U=this;for(;S>Yt||T>Yt;)S&st&&(k=k.add(U)),T&st&&(I=I.add(U)),U=U.double(),S>>=st,T>>=st;return p&&(k=k.negate()),L&&(I=I.negate()),I=new h(e.mul(I.px,E.beta),I.py,I.pz),k.add(I)}multiply(d){let{endo:y,n:E}=t;bt("scalar",d,st,E);let p,S;if(y){let{k1neg:L,k1:T,k2neg:k,k2:I}=y.splitScalar(d),{p:U,f:J}=this.wNAF(T),{p:F,f:H}=this.wNAF(I);U=v.constTimeNegate(L,U),F=v.constTimeNegate(k,F),F=new h(e.mul(F.px,y.beta),F.py,F.pz),p=U.add(F),S=J.add(H)}else{let{p:L,f:T}=this.wNAF(d);p=L,S=T}return h.normalizeZ([p,S])[0]}multiplyAndAddUnsafe(d,y,E){let p=h.BASE,S=(T,k)=>k===Yt||k===st||!T.equals(p)?T.multiplyUnsafe(k):T.multiply(k),L=S(this,y).add(S(d,E));return L.is0()?void 0:L}toAffine(d){return l(this,d)}isTorsionFree(){let{h:d,isTorsionFree:y}=t;if(d===st)return!0;if(y)return y(h,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h:d,clearCofactor:y}=t;return d===st?this:y?y(h,this):this.multiplyUnsafe(t.h)}toRawBytes(d=!0){return Nt("isCompressed",d),this.assertValidity(),s(h,this,d)}toHex(d=!0){return Nt("isCompressed",d),Pt(this.toRawBytes(d))}}h.BASE=new h(t.Gx,t.Gy,e.ONE),h.ZERO=new h(e.ZERO,e.ONE,e.ZERO);let x=t.nBitLength,v=Lr(h,t.endo?Math.ceil(x/2):x);return{CURVE:t,ProjectivePoint:h,normPrivateKeyToScalar:c,weierstrassEquation:i,isWithinCurveOrder:a}}function rf(r){let t=or(r);return Rt(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function Ua(r){let t=rf(r),{Fp:e,n}=t,s=e.BYTES+1,o=2*e.BYTES+1;function i(B){return q(B,n)}function a(B){return Tr(B,n)}let{ProjectivePoint:c,normPrivateKeyToScalar:f,weierstrassEquation:l,isWithinCurveOrder:u}=ef({...t,toBytes(B,N,m){let g=N.toAffine(),w=e.toBytes(g.x),C=Kt;return Nt("isCompressed",m),m?C(Uint8Array.from([N.hasEvenY()?2:3]),w):C(Uint8Array.from([4]),w,e.toBytes(g.y))},fromBytes(B){let N=B.length,m=B[0],g=B.subarray(1);if(N===s&&(m===2||m===3)){let w=Ft(g);if(!nr(w,st,e.ORDER))throw new Error("Point is not on curve");let C=l(w),R;try{R=e.sqrt(C)}catch(P){let O=P instanceof Error?": "+P.message:"";throw new Error("Point is not on curve"+O)}let _=(R&st)===st;return(m&1)===1!==_&&(R=e.neg(R)),{x:w,y:R}}else if(N===o&&m===4){let w=e.fromBytes(g.subarray(0,e.BYTES)),C=e.fromBytes(g.subarray(e.BYTES,2*e.BYTES));return{x:w,y:C}}else throw new Error(`Point of length ${N} was invalid. Expected ${s} compressed bytes or ${o} uncompressed bytes`)}}),h=B=>Pt(ie(B,t.nByteLength));function x(B){let N=n>>st;return B>N}function v(B){return x(B)?i(-B):B}let b=(B,N,m)=>Ft(B.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=W("compactSignature",N,m*2),new d(b(N,0,m),b(N,m,2*m))}static fromDER(N){let{r:m,s:g}=Jt.toSig(W("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:w}=this,C=T(W("msgHash",N));if(w==null||![0,1,2,3].includes(w))throw new Error("recovery id invalid");let R=w===2||w===3?m+t.n:m;if(R>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let _=w&1?"03":"02",D=c.fromHex(_+h(R)),P=a(R),O=i(-C*P),$=i(g*P),z=c.BASE.multiplyAndAddUnsafe(D,O,$);if(!z)throw new Error("point at infinify");return z.assertValidity(),z}hasHighS(){return x(this.s)}normalizeS(){return this.hasHighS()?new d(this.r,i(-this.s),this.recovery):this}toDERRawBytes(){return be(this.toDERHex())}toDERHex(){return Jt.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return be(this.toCompactHex())}toCompactHex(){return h(this.r)+h(this.s)}}let y={isValidPrivateKey(B){try{return f(B),!0}catch{return!1}},normPrivateKeyToScalar:f,randomPrivateKey:()=>{let B=xs(t.n);return ii(t.randomBytes(B),t.n)},precompute(B=8,N=c.BASE){return N._setWindowSize(B),N.multiply(BigInt(3)),N}};function E(B,N=!0){return c.fromPrivateKey(B).toRawBytes(N)}function p(B){let N=se(B),m=typeof B=="string",g=(N||m)&&B.length;return N?g===s||g===o:m?g===2*s||g===2*o:B instanceof c}function S(B,N,m=!0){if(p(B))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(f(B)).toRawBytes(m)}let L=t.bits2int||function(B){let N=Ft(B),m=B.length*8-t.nBitLength;return m>0?N>>BigInt(m):N},T=t.bits2int_modN||function(B){return i(L(B))},k=sr(t.nBitLength);function I(B){return bt(`num < 2^${t.nBitLength}`,B,Yt,k),ie(B,t.nByteLength)}function U(B,N,m=J){if(["recovered","canonical"].some(rt=>rt in m))throw new Error("sign() legacy options not supported");let{hash:g,randomBytes:w}=t,{lowS:C,prehash:R,extraEntropy:_}=m;C==null&&(C=!0),B=W("msgHash",B),Na(m),R&&(B=W("prehashed msgHash",g(B)));let D=T(B),P=f(N),O=[I(P),I(D)];if(_!=null&&_!==!1){let rt=_===!0?w(e.BYTES):_;O.push(W("extraEntropy",rt))}let $=Kt(...O),z=D;function et(rt){let ot=L(rt);if(!u(ot))return;let ft=a(ot),X=c.BASE.multiply(ot).toAffine(),pt=i(X.x);if(pt===Yt)return;let Dt=i(ft*i(z+pt*P));if(Dt===Yt)return;let Je=(X.x===pt?0:2)|Number(X.y&st),Ye=Dt;return C&&x(Dt)&&(Ye=v(Dt),Je^=1),new d(pt,Ye,Je)}return{seed:$,k2sig:et}}let J={lowS:t.lowS,prehash:!1},F={lowS:t.lowS,prehash:!1};function H(B,N,m=J){let{seed:g,k2sig:w}=U(B,N,m),C=t;return ms(C.hash.outputLen,C.nByteLength,C.hmac)(g,w)}c.BASE._setWindowSize(8);function Y(B,N,m,g=F){let w=B;if(N=W("msgHash",N),m=W("publicKey",m),"strict"in g)throw new Error("options.strict was renamed to lowS");Na(g);let{lowS:C,prehash:R}=g,_,D;try{if(typeof w=="string"||se(w))try{_=d.fromDER(w)}catch(X){if(!(X instanceof Jt.Err))throw X;_=d.fromCompact(w)}else if(typeof w=="object"&&typeof w.r=="bigint"&&typeof w.s=="bigint"){let{r:X,s:pt}=w;_=new d(X,pt)}else throw new Error("PARSE");D=c.fromHex(m)}catch(X){if(X.message==="PARSE")throw new Error("signature must be Signature instance, Uint8Array or hex string");return!1}if(C&&_.hasHighS())return!1;R&&(N=t.hash(N));let{r:P,s:O}=_,$=T(N),z=a(O),et=i($*z),rt=i(P*z),ot=c.BASE.multiplyAndAddUnsafe(D,et,rt)?.toAffine();return ot?i(ot.x)===P:!1}return{CURVE:t,getPublicKey:E,getSharedSecret:S,sign:H,verify:Y,ProjectivePoint:c,Signature:d,utils:y}}function nf(r){return{hash:r,hmac:(t,...e)=>go(r,t,cs(...e)),randomBytes:Ir}}function Ta(r,t){let e=n=>Ua({...r,...nf(n)});return Object.freeze({...e(t),create:e})}var _a=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),La=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),sf=BigInt(1),po=BigInt(2),Ra=(r,t)=>(r+t/po)/t;function of(r){let t=_a,e=BigInt(3),n=BigInt(6),s=BigInt(11),o=BigInt(22),i=BigInt(23),a=BigInt(44),c=BigInt(88),f=r*r*r%t,l=f*f*r%t,u=j(l,e,t)*l%t,h=j(u,e,t)*l%t,x=j(h,po,t)*f%t,v=j(x,s,t)*x%t,b=j(v,o,t)*v%t,d=j(b,a,t)*b%t,y=j(d,c,t)*d%t,E=j(y,a,t)*b%t,p=j(E,e,t)*l%t,S=j(p,i,t)*v%t,L=j(S,n,t)*f%t,T=j(L,po,t);if(!mo.eql(mo.sqr(T),r))throw new Error("Cannot find square root");return T}var mo=ae(_a,void 0,void 0,{sqrt:of}),Ie=Ta({a:BigInt(0),b:BigInt(7),Fp:mo,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=-sf*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),s=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),o=e,i=BigInt("0x100000000000000000000000000000000"),a=Ra(o*r,t),c=Ra(-n*r,t),f=q(r-a*e-c*s,t),l=q(-a*n-c*o,t),u=f>i,h=l>i;if(u&&(f=t-f),h&&(l=t-l),f>i||l>i)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:u,k1:f,k2neg:h,k2:l}}}},Ke),J0=BigInt(0);var Y0=Ie.ProjectivePoint;function Hn(r,t){t==null&&(t=r.reduce((s,o)=>s+o.length,0));let e=wt(t),n=0;for(let s of r)e.set(s,n),n+=s.length;return e}function Va(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function Ha(r,t,e){let n=Mr.digest(e instanceof Uint8Array?e:e.subarray());if(Va(n))return n.then(({digest:s})=>Ie.verify(t,s,r)).catch(s=>{throw new br(String(s))});try{return Ie.verify(t,n.digest,r)}catch(s){throw new br(String(s))}}var Dn=class{type="secp256k1";raw;_key;constructor(t){this._key=Oa(t),this.raw=Da(this._key)}toMultihash(){return ee.digest(Dr(this))}toCID(){return Et.createV1(114,this.toMultihash())}toString(){return Q.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:mt(this.raw,t.raw)}verify(t,e){return Ha(this._key,e,t)}};function Ma(r){return new Dn(r)}function Da(r){return Ie.ProjectivePoint.fromHex(r).toRawBytes(!0)}function Oa(r){try{return Ie.ProjectivePoint.fromHex(r),r}catch(t){throw new Ne(String(t))}}function Pa(r){return r.byteLength===32?gi(r):r.byteLength===34?Ma(r):ho(r)}function Dr(r){return le.encode({Type:xt[r.type],Data:r.raw})}var Fa=Symbol.for("nodejs.util.inspect.custom"),af=114,xr=class{type;multihash;publicKey;string;constructor(t){this.type=t.type,this.multihash=t.multihash,Object.defineProperty(this,"string",{enumerable:!1,writable:!0})}get[Symbol.toStringTag](){return`PeerId(${this.toString()})`}[Yn]=!0;toString(){return this.string==null&&(this.string=Q.encode(this.multihash.bytes).slice(1)),this.string}toMultihash(){return this.multihash}toCID(){return Et.createV1(af,this.multihash)}toJSON(){return this.toString()}equals(t){if(t==null)return!1;if(t instanceof Uint8Array)return mt(this.multihash.bytes,t);if(typeof t=="string")return this.toString()===t;if(t?.toMultihash()?.bytes!=null)return mt(this.multihash.bytes,t.toMultihash().bytes);throw new Error("not valid Id")}[Fa](){return`PeerId(${this.toString()})`}},On=class extends xr{type="RSA";publicKey;constructor(t){super({...t,type:"RSA"}),this.publicKey=t.publicKey}},Mn=class extends xr{type="Ed25519";publicKey;constructor(t){super({...t,type:"Ed25519"}),this.publicKey=t.publicKey}},Pn=class extends xr{type="secp256k1";publicKey;constructor(t){super({...t,type:"secp256k1"}),this.publicKey=t.publicKey}},cf=2336,bo=class{type="url";multihash;publicKey;url;constructor(t){this.url=t.toString(),this.multihash=ee.digest(nt(this.url))}[Fa](){return`PeerId(${this.url})`}[Yn]=!0;toString(){return this.toCID().toString()}toMultihash(){return this.multihash}toCID(){return Et.createV1(cf,this.toMultihash())}toJSON(){return this.toString()}equals(t){return t==null?!1:(t instanceof Uint8Array&&(t=Bt(t)),t.toString()===this.toString())}};function Ka(r){if(r.type==="Ed25519")return new Mn({multihash:r.toCID().multihash,publicKey:r});if(r.type==="secp256k1")return new Pn({multihash:r.toCID().multihash,publicKey:r});if(r.type==="RSA")return new On({multihash:r.toCID().multihash,publicKey:r});throw new Er}function We(){let r={};return r.promise=new Promise((t,e)=>{r.resolve=t,r.reject=e}),r}var Fn=class extends Error{type;code;constructor(t,e,n){super(t??"The operation was aborted"),this.type="aborted",this.name=n??"AbortError",this.code=e??"ABORT_ERR"}};async function $a(r,t,e){if(t==null)return r;if(t.aborted)return Promise.reject(new Fn(e?.errorMessage,e?.errorCode,e?.errorName));let n,s=new Fn(e?.errorMessage,e?.errorCode,e?.errorName);try{return await Promise.race([r,new Promise((o,i)=>{n=()=>{i(s)},t.addEventListener("abort",n)})])}finally{n!=null&&t.removeEventListener("abort",n)}}var yo=class{readNext;haveNext;ended;nextResult;constructor(){this.ended=!1,this.readNext=We(),this.haveNext=We()}[Symbol.asyncIterator](){return this}async next(){if(this.nextResult==null&&await this.haveNext.promise,this.nextResult==null)throw new Error("HaveNext promise resolved but nextResult was undefined");let t=this.nextResult;return this.nextResult=void 0,this.readNext.resolve(),this.readNext=We(),t}async throw(t){return this.ended=!0,t!=null&&(this.haveNext.promise.catch(()=>{}),this.haveNext.reject(t)),{done:!0,value:void 0}}async return(){let t={done:!0,value:void 0};return await this._push(void 0),t}async push(t,e){await this._push(t,e)}async end(t,e){t!=null?await this.throw(t):await this._push(void 0,e)}async _push(t,e){if(t!=null&&this.ended)throw new Error("Cannot push value onto an ended pushable");for(;this.nextResult!=null;)await this.readNext.promise;t!=null?this.nextResult={done:!1,value:t}:(this.ended=!0,this.nextResult={done:!0,value:void 0}),this.haveNext.resolve(),this.haveNext=We(),await $a(this.readNext.promise,e?.signal,e)}};function qa(){return new yo}var Ga=Symbol.for("@achingbrain/uint8arraylist");function za(r,t){if(t==null||t<0)throw new RangeError("index is out of bounds");let e=0;for(let n of r){let s=e+n.byteLength;if(t<s)return{buf:n,index:t-e};e=s}throw new RangeError("index is out of bounds")}function Kn(r){return!!r?.[Ga]}var Xt=class r{bufs;length;[Ga]=!0;constructor(...t){this.bufs=[],this.length=0,t.length>0&&this.appendAll(t)}*[Symbol.iterator](){yield*this.bufs}get byteLength(){return this.length}append(...t){this.appendAll(t)}appendAll(t){let e=0;for(let n of t)if(n instanceof Uint8Array)e+=n.byteLength,this.bufs.push(n);else if(Kn(n))e+=n.byteLength,this.bufs.push(...n.bufs);else throw new Error("Could not append value, must be an Uint8Array or a Uint8ArrayList");this.length+=e}prepend(...t){this.prependAll(t)}prependAll(t){let e=0;for(let n of t.reverse())if(n instanceof Uint8Array)e+=n.byteLength,this.bufs.unshift(n);else if(Kn(n))e+=n.byteLength,this.bufs.unshift(...n.bufs);else throw new Error("Could not prepend value, must be an Uint8Array or a Uint8ArrayList");this.length+=e}get(t){let e=za(this.bufs,t);return e.buf[e.index]}set(t,e){let n=za(this.bufs,t);n.buf[n.index]=e}write(t,e=0){if(t instanceof Uint8Array)for(let n=0;n<t.length;n++)this.set(e+n,t[n]);else if(Kn(t))for(let n=0;n<t.length;n++)this.set(e+n,t.get(n));else throw new Error("Could not write value, must be an Uint8Array or a Uint8ArrayList")}consume(t){if(t=Math.trunc(t),!(Number.isNaN(t)||t<=0)){if(t===this.byteLength){this.bufs=[],this.length=0;return}for(;this.bufs.length>0;)if(t>=this.bufs[0].byteLength)t-=this.bufs[0].byteLength,this.length-=this.bufs[0].byteLength,this.bufs.shift();else{this.bufs[0]=this.bufs[0].subarray(t),this.length-=t;break}}}slice(t,e){let{bufs:n,length:s}=this._subList(t,e);return Hn(n,s)}subarray(t,e){let{bufs:n,length:s}=this._subList(t,e);return n.length===1?n[0]:Hn(n,s)}sublist(t,e){let{bufs:n,length:s}=this._subList(t,e),o=new r;return o.length=s,o.bufs=[...n],o}_subList(t,e){if(t=t??0,e=e??this.length,t<0&&(t=this.length+t),e<0&&(e=this.length+e),t<0||e>this.length)throw new RangeError("index is out of bounds");if(t===e)return{bufs:[],length:0};if(t===0&&e===this.length)return{bufs:this.bufs,length:this.length};let n=[],s=0;for(let o=0;o<this.bufs.length;o++){let i=this.bufs[o],a=s,c=a+i.byteLength;if(s=c,t>=c)continue;let f=t>=a&&t<c,l=e>a&&e<=c;if(f&&l){if(t===a&&e===c){n.push(i);break}let u=t-a;n.push(i.subarray(u,u+(e-t)));break}if(f){if(t===0){n.push(i);continue}n.push(i.subarray(t-a));continue}if(l){if(e===c){n.push(i);break}n.push(i.subarray(0,e-a));break}n.push(i)}return{bufs:n,length:e-t}}indexOf(t,e=0){if(!Kn(t)&&!(t instanceof Uint8Array))throw new TypeError('The "value" argument must be a Uint8ArrayList or Uint8Array');let n=t instanceof Uint8Array?t:t.subarray();if(e=Number(e??0),isNaN(e)&&(e=0),e<0&&(e=this.length+e),e<0&&(e=0),t.length===0)return e>this.length?this.length:e;let s=n.byteLength;if(s===0)throw new TypeError("search must be at least 1 byte long");let o=256,i=new Int32Array(o);for(let u=0;u<o;u++)i[u]=-1;for(let u=0;u<s;u++)i[n[u]]=u;let a=i,c=this.byteLength-n.byteLength,f=n.byteLength-1,l;for(let u=e;u<=c;u+=l){l=0;for(let h=f;h>=0;h--){let x=this.get(u+h);if(n[h]!==x){l=Math.max(1,h-a[x]);break}}if(l===0)return u}return-1}getInt8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getInt8(0)}setInt8(t,e){let n=wt(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setInt8(0,e),this.write(n,t)}getInt16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt16(0,e)}setInt16(t,e,n){let s=Ut(2);new DataView(s.buffer,s.byteOffset,s.byteLength).setInt16(0,e,n),this.write(s,t)}getInt32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt32(0,e)}setInt32(t,e,n){let s=Ut(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setInt32(0,e,n),this.write(s,t)}getBigInt64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigInt64(0,e)}setBigInt64(t,e,n){let s=Ut(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigInt64(0,e,n),this.write(s,t)}getUint8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getUint8(0)}setUint8(t,e){let n=wt(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setUint8(0,e),this.write(n,t)}getUint16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint16(0,e)}setUint16(t,e,n){let s=Ut(2);new DataView(s.buffer,s.byteOffset,s.byteLength).setUint16(0,e,n),this.write(s,t)}getUint32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint32(0,e)}setUint32(t,e,n){let s=Ut(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setUint32(0,e,n),this.write(s,t)}getBigUint64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigUint64(0,e)}setBigUint64(t,e,n){let s=Ut(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigUint64(0,e,n),this.write(s,t)}getFloat32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat32(0,e)}setFloat32(t,e,n){let s=Ut(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setFloat32(0,e,n),this.write(s,t)}getFloat64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat64(0,e)}setFloat64(t,e,n){let s=Ut(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setFloat64(0,e,n),this.write(s,t)}equals(t){if(t==null||!(t instanceof r)||t.bufs.length!==this.bufs.length)return!1;for(let e=0;e<this.bufs.length;e++)if(!mt(this.bufs[e],t.bufs[e]))return!1;return!0}static fromUint8Arrays(t,e){let n=new r;return n.bufs=t,e==null&&(e=t.reduce((s,o)=>s+o.byteLength,0)),n.length=e,n}};var $n=class extends Error{name="UnexpectedEOFError";code="ERR_UNEXPECTED_EOF"};var wo=class extends Error{code;constructor(t,e){super(t),this.code=e}},xo=class extends wo{type;constructor(t){super(t,"ABORT_ERR"),this.type="aborted",this.name="AbortError"}};function ja(r,t){let e=qa();r.sink(e).catch(async i=>{await e.end(i)}),r.sink=async i=>{for await(let a of i)await e.push(a);await e.end()};let n=r.source;r.source[Symbol.iterator]!=null?n=r.source[Symbol.iterator]():r.source[Symbol.asyncIterator]!=null&&(n=r.source[Symbol.asyncIterator]());let s=new Xt;return{read:async(i,a)=>{a?.signal?.throwIfAborted();let c,f=new Promise((l,u)=>{c=()=>{u(new xo("Read aborted"))},a?.signal?.addEventListener("abort",c)});try{if(i==null){let{done:u,value:h}=await Promise.race([n.next(),f]);return u===!0?new Xt:h}for(;s.byteLength<i;){let{value:u,done:h}=await Promise.race([n.next(),f]);if(h===!0)throw new $n("unexpected end of input");s.append(u)}let l=s.sublist(0,i);return s.consume(i),l}finally{c!=null&&a?.signal?.removeEventListener("abort",c)}},write:async(i,a)=>{a?.signal?.throwIfAborted(),i instanceof Uint8Array?await e.push(i,a):await e.push(i.subarray(),a)},unwrap:()=>{if(s.byteLength>0){let i=r.source;r.source=async function*(){t?.yieldBytes===!1?yield s:yield*s,yield*i}()}return r}}}var qn=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},zn=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},Gn=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"};function Za(r,t={}){let e=ja(r,t);t.maxDataLength!=null&&t.maxLengthLength==null&&(t.maxLengthLength=$t(t.maxDataLength));let n=t?.lengthDecoder??mi,s=t?.lengthEncoder??pi;return{read:async i=>{let a=-1,c=new Xt;for(;;){c.append(await e.read(1,i));try{a=n(c)}catch(f){if(f instanceof RangeError)continue;throw f}if(a<0)throw new qn("Invalid message length");if(t?.maxLengthLength!=null&&c.byteLength>t.maxLengthLength)throw new Gn("message length length too long");if(a>-1)break}if(t?.maxDataLength!=null&&a>t.maxDataLength)throw new zn("message length too long");return e.read(a,i)},write:async(i,a)=>{await e.write(new Xt(s(i.byteLength),i),a)},writeV:async(i,a)=>{let c=new Xt(...i.flatMap(f=>[s(f.byteLength),f]));await e.write(c,a)},unwrap:()=>e.unwrap()}}function Wa(r,t){let e=Za(r,t),n={read:async(s,o)=>{let i=await e.read(o);return s.decode(i)},write:async(s,o,i)=>{await e.write(o.encode(s),i)},writeV:async(s,o,i)=>{await e.writeV(s.map(a=>o.encode(a)),i)},pb:s=>({read:async o=>n.read(s,o),write:async(o,i)=>n.write(o,s,i),writeV:async(o,i)=>n.writeV(o,s,i),unwrap:()=>n}),unwrap:()=>e.unwrap()};return n}var jn;(function(r){let t;r.codec=()=>(t==null&&(t=Se((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.id!=null&&(n.uint32(10),n.bytes(e.id)),e.pubkey!=null&&(n.uint32(18),Wn.codec().encode(e.pubkey,n)),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.id=e.bytes();break}case 2:{o.pubkey=Wn.codec().decode(e,e.uint32(),{limits:s.limits?.pubkey});break}default:{e.skipType(a&7);break}}}return o})),t),r.encode=e=>Ae(e,r.codec()),r.decode=(e,n)=>Be(e,r.codec(),n)})(jn||(jn={}));var Qt;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.secp256k1="secp256k1",r.ECDSA="ECDSA"})(Qt||(Qt={}));var Zn;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1",r[r.ECDSA=3]="ECDSA"})(Zn||(Zn={}));(function(r){r.codec=()=>cr(Zn)})(Qt||(Qt={}));var Wn;(function(r){let t;r.codec=()=>(t==null&&(t=Se((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&Zn[e.Type]!==0&&(n.uint32(8),Qt.codec().encode(e.Type,n)),e.Data!=null&&e.Data.byteLength>0&&(n.uint32(18),n.bytes(e.Data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let o={Type:Qt.RSA,Data:Ut(0)},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let a=e.uint32();switch(a>>>3){case 1:{o.Type=Qt.codec().decode(e);break}case 2:{o.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return o})),t),r.encode=e=>Ae(e,r.codec()),r.decode=(e,n)=>Be(e,r.codec(),n)})(Wn||(Wn={}));var lf="/plaintext/2.0.0",vo=class{protocol=lf;privateKey;log;constructor(t){this.privateKey=t.privateKey,this.log=t.logger.forComponent("libp2p:plaintext")}[Symbol.toStringTag]="@libp2p/plaintext";[Uo]=["@libp2p/connection-encryption"];async secureInbound(t,e){return this._encrypt(t,e)}async secureOutbound(t,e){return this._encrypt(t,e)}async _encrypt(t,e){let n=Wa(t).pb(jn);this.log("write pubkey exchange to peer %p",e?.remotePeer);let s=this.privateKey.publicKey,[,o]=await Promise.all([n.write({id:s.toMultihash().bytes,pubkey:{Type:Qt[s.type],Data:s.raw}},e),n.read(e)]),i;try{if(o.pubkey==null)throw new Ce("Public key missing");if(o.pubkey.Data.byteLength===0)throw new Ce("Public key data too short");if(o.id==null)throw new Ce("Remote id missing");let a=Pa(o.pubkey.Data);if(i=Ka(a),!mt(i.toMultihash().bytes,o.id))throw new Xe("Public key did not match id")}catch(a){throw this.log.error(a),new Xe("Invalid public key - "+a.message)}if(e?.remotePeer!=null&&!i.equals(e?.remotePeer))throw new Br;return this.log("plaintext key exchange completed successfully with peer %p",i),{conn:n.unwrap().unwrap(),remotePeer:i}}};function uf(){return r=>new vo(r)}return fc(ff);})();
|
|
8
7
|
/*! Bundled license information:
|
|
9
8
|
|
|
10
9
|
pvtsutils/build/index.js:
|