@libp2p/identify 1.0.12 → 1.0.13
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.min.js +3 -3
- package/package.json +18 -18
package/dist/index.min.js
CHANGED
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
(function (root, factory) {(typeof module === 'object' && module.exports) ? module.exports = factory() : root.Libp2PIdentify = factory()}(typeof self !== 'undefined' ? self : this, function () {
|
|
2
|
-
"use strict";var Libp2PIdentify=(()=>{var tu=Object.create;var cn=Object.defineProperty;var ru=Object.getOwnPropertyDescriptor;var nu=Object.getOwnPropertyNames;var su=Object.getPrototypeOf,ou=Object.prototype.hasOwnProperty;var Ui=(r,e)=>()=>(e||r((e={exports:{}}).exports,e),e.exports),he=(r,e)=>{for(var t in e)cn(r,t,{get:e[t],enumerable:!0})},Pi=(r,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of nu(e))!ou.call(r,s)&&s!==t&&cn(r,s,{get:()=>e[s],enumerable:!(n=ru(e,s))||n.enumerable});return r};var Oi=(r,e,t)=>(t=r!=null?tu(su(r)):{},Pi(e||!r||!r.__esModule?cn(t,"default",{value:r,enumerable:!0}):t,r)),iu=r=>Pi(cn({},"__esModule",{value:!0}),r);var Wa=Ui(vr=>{"use strict";var Oh="[object ArrayBuffer]",gt=class r{static isArrayBuffer(e){return Object.prototype.toString.call(e)===Oh}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}},Fo="string",Vh=/^[0-9a-f]+$/i,Dh=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,Mh=/^[a-zA-Z0-9-_]+$/,Rn=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=gt.toUint8Array(e),n="";for(let o=0;o<t.length;o++)n+=String.fromCharCode(t[o]);return decodeURIComponent(escape(n))}},Ce=class{static toString(e,t=!1){let n=gt.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}},Tn=class r{static isHex(e){return typeof e===Fo&&Vh.test(e)}static isBase64(e){return typeof e===Fo&&Dh.test(e)}static isBase64Url(e){return typeof e===Fo&&Mh.test(e)}static ToString(e,t="utf8"){let n=gt.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 Ce.toString(n,!0);case"utf16":case"utf16be":return Ce.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 Ce.fromString(e,!0);case"utf16":case"utf16be":return Ce.fromString(e);default:throw new Error(`Unknown type of encoding '${t}'`)}}static ToBase64(e){let t=gt.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 Rn.fromString(e);case"utf16":case"utf16be":return Ce.fromString(e);case"utf16le":case"usc2":return Ce.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 Rn.toString(e);case"utf16":case"utf16be":return Ce.toString(e);case"utf16le":case"usc2":return Ce.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=gt.toUint8Array(e),n="";for(let s=0;s<t.length;s++)n+=String.fromCharCode(t[s]);return n}static ToHex(e){let t=gt.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 Ce.toString(e,t)}static FromUtf16String(e,t=!1){return Ce.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,"")||""}};Tn.DEFAULT_UTF8_ENCODING="utf8";function Hh(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 Fh(...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 Kh(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}vr.BufferSourceConverter=gt;vr.Convert=Tn;vr.assign=Hh;vr.combine=Fh;vr.isEqual=Kh});var Ml=Ui((Dw,Dl)=>{function t0(){return!!(typeof window<"u"&&typeof window.process=="object"&&window.process.type==="renderer"||typeof process<"u"&&typeof process.versions=="object"&&process.versions.electron||typeof navigator=="object"&&typeof navigator.userAgent=="string"&&navigator.userAgent.indexOf("Electron")>=0)}Dl.exports=t0});var o0={};he(o0,{identify:()=>s0,multicodecs:()=>n0});var Vi="/ipfs/id/1.0.0",Di="/ipfs/id/push/1.0.0",Mi="0.1.0",Hi="id",Fi="id/push",Ki="1.0.0",qi="1.0.0";var $i=Symbol.for("@libp2p/peer-id");var C=class extends Error{code;props;constructor(e,t,n){super(e),this.code=t,this.name=n?.name??"CodeError",this.props=n??{}}};var Gi="ERR_NOT_FOUND";var ln=(r,...e)=>{try{[...e]}catch{}};var Fs={};he(Fs,{base58btc:()=>ne,base58flickr:()=>hu});var f0=new Uint8Array(0);function zi(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 it(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 ji(r){return new TextEncoder().encode(r)}function Wi(r){return new TextDecoder().decode(r)}function au(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),u=Math.log(256)/Math.log(a);function l(p){if(p instanceof Uint8Array||(ArrayBuffer.isView(p)?p=new Uint8Array(p.buffer,p.byteOffset,p.byteLength):Array.isArray(p)&&(p=Uint8Array.from(p))),!(p instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(p.length===0)return"";for(var h=0,m=0,y=0,B=p.length;y!==B&&p[y]===0;)y++,h++;for(var w=(B-y)*u+1>>>0,T=new Uint8Array(w);y!==B;){for(var x=p[y],A=0,N=w-1;(x!==0||A<m)&&N!==-1;N--,A++)x+=256*T[N]>>>0,T[N]=x%a>>>0,x=x/a>>>0;if(x!==0)throw new Error("Non-zero carry");m=A,y++}for(var R=w-m;R!==w&&T[R]===0;)R++;for(var G=c.repeat(h);R<w;++R)G+=r.charAt(T[R]);return G}function d(p){if(typeof p!="string")throw new TypeError("Expected String");if(p.length===0)return new Uint8Array;var h=0;if(p[h]!==" "){for(var m=0,y=0;p[h]===c;)m++,h++;for(var B=(p.length-h)*f+1>>>0,w=new Uint8Array(B);p[h];){var T=t[p.charCodeAt(h)];if(T===255)return;for(var x=0,A=B-1;(T!==0||x<y)&&A!==-1;A--,x++)T+=a*w[A]>>>0,w[A]=T%256>>>0,T=T/256>>>0;if(T!==0)throw new Error("Non-zero carry");y=x,h++}if(p[h]!==" "){for(var N=B-y;N!==B&&w[N]===0;)N++;for(var R=new Uint8Array(m+(B-N)),G=m;N!==B;)R[G++]=w[N++];return R}}}function b(p){var h=d(p);if(h)return h;throw new Error(`Non-${e} character`)}return{encode:l,decodeUnsafe:d,decode:b}}var cu=au,lu=cu,Zi=lu;var Vs=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 Ji(this,e)}},Ms=class{decoders;constructor(e){this.decoders=e}or(e){return Ji(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 Ji(r,e){return new Ms({...r.decoders??{[r.prefix]:r},...e.decoders??{[e.prefix]:e}})}var Hs=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 Vs(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 rr({name:r,prefix:e,encode:t,decode:n}){return new Hs(r,e,t,n)}function At({name:r,prefix:e,alphabet:t}){let{encode:n,decode:s}=Zi(t,r);return rr({prefix:e,name:r,encode:n,decode:o=>it(s(o))})}function uu(r,e,t,n){let s={};for(let u=0;u<e.length;++u)s[e[u]]=u;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 u=0;u<o;++u){let l=s[r[u]];if(l===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<t|l,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 fu(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 ee({name:r,prefix:e,bitsPerChar:t,alphabet:n}){return rr({prefix:e,name:r,encode(s){return fu(s,n,t)},decode(s){return uu(s,n,t,r)}})}var ne=At({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),hu=At({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Ks={};he(Ks,{base10:()=>du});var du=At({prefix:"9",name:"base10",alphabet:"0123456789"});var qs={};he(qs,{base16:()=>pu,base16upper:()=>gu});var pu=ee({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),gu=ee({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var $s={};he($s,{base2:()=>mu});var mu=ee({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Gs={};he(Gs,{base256emoji:()=>vu});var Xi=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}"),yu=Xi.reduce((r,e,t)=>(r[t]=e,r),[]),bu=Xi.reduce((r,e,t)=>(r[e.codePointAt(0)]=t,r),[]);function wu(r){return r.reduce((e,t)=>(e+=yu[t],e),"")}function xu(r){let e=[];for(let t of r){let n=bu[t.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${t}`);e.push(n)}return new Uint8Array(e)}var vu=rr({prefix:"\u{1F680}",name:"base256emoji",encode:wu,decode:xu});var zs={};he(zs,{base32:()=>at,base32hex:()=>Iu,base32hexpad:()=>ku,base32hexpadupper:()=>Nu,base32hexupper:()=>Su,base32pad:()=>Bu,base32padupper:()=>Au,base32upper:()=>Eu,base32z:()=>Ru});var at=ee({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),Eu=ee({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Bu=ee({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),Au=ee({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),Iu=ee({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),Su=ee({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),ku=ee({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),Nu=ee({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),Ru=ee({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var js={};he(js,{base36:()=>Tu,base36upper:()=>_u});var Tu=At({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),_u=At({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Zs={};he(Zs,{base64:()=>Ws,base64pad:()=>Cu,base64url:()=>Ys,base64urlpad:()=>Lu});var Ws=ee({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),Cu=ee({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Ys=ee({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Lu=ee({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Js={};he(Js,{base8:()=>Uu});var Uu=ee({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Xs={};he(Xs,{identity:()=>Pu});var Pu=rr({prefix:"\0",name:"identity",encode:r=>Wi(r),decode:r=>ji(r)});var k0=new TextEncoder,N0=new TextDecoder;var eo={};he(eo,{identity:()=>It});var Du=ta,Qi=128,Mu=127,Hu=~Mu,Fu=Math.pow(2,31);function ta(r,e,t){e=e||[],t=t||0;for(var n=t;r>=Fu;)e[t++]=r&255|Qi,r/=128;for(;r&Hu;)e[t++]=r&255|Qi,r>>>=7;return e[t]=r|0,ta.bytes=t-n+1,e}var Ku=Qs,qu=128,ea=127;function Qs(r,n){var t=0,n=n||0,s=0,o=n,i,a=r.length;do{if(o>=a)throw Qs.bytes=0,new RangeError("Could not decode varint");i=r[o++],t+=s<28?(i&ea)<<s:(i&ea)*Math.pow(2,s),s+=7}while(i>=qu);return Qs.bytes=o-n,t}var $u=Math.pow(2,7),Gu=Math.pow(2,14),zu=Math.pow(2,21),ju=Math.pow(2,28),Wu=Math.pow(2,35),Yu=Math.pow(2,42),Zu=Math.pow(2,49),Ju=Math.pow(2,56),Xu=Math.pow(2,63),Qu=function(r){return r<$u?1:r<Gu?2:r<zu?3:r<ju?4:r<Wu?5:r<Yu?6:r<Zu?7:r<Ju?8:r<Xu?9:10},ef={encode:Du,decode:Ku,encodingLength:Qu},tf=ef,Tr=tf;function _r(r,e=0){return[Tr.decode(r,e),Tr.decode.bytes]}function nr(r,e,t=0){return Tr.encode(r,e,t),e}function sr(r){return Tr.encodingLength(r)}function Ze(r,e){let t=e.byteLength,n=sr(r),s=n+sr(t),o=new Uint8Array(s+t);return nr(r,o,0),nr(t,o,n),o.set(e,s),new or(r,t,e,o)}function qt(r){let e=it(r),[t,n]=_r(e),[s,o]=_r(e.subarray(n)),i=e.subarray(n+o);if(i.byteLength!==s)throw new Error("Incorrect length");return new or(t,s,i,e)}function ra(r,e){if(r===e)return!0;{let t=e;return r.code===t.code&&r.size===t.size&&t.bytes instanceof Uint8Array&&zi(r.bytes,t.bytes)}}var or=class{code;size;digest;bytes;constructor(e,t,n,s){this.code=e,this.size=t,this.digest=n,this.bytes=s}};var na=0,rf="identity",sa=it;function nf(r){return Ze(na,sa(r))}var It={code:na,name:rf,encode:sa,digest:nf};var no={};he(no,{sha256:()=>ye,sha512:()=>sf});function ro({name:r,code:e,encode:t}){return new to(r,e,t)}var to=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?Ze(this.code,t):t.then(n=>Ze(this.code,n))}else throw Error("Unknown type, must be binary type")}};function ia(r){return async e=>new Uint8Array(await crypto.subtle.digest(r,e))}var ye=ro({name:"sha2-256",code:18,encode:ia("SHA-256")}),sf=ro({name:"sha2-512",code:19,encode:ia("SHA-512")});function aa(r,e){let{bytes:t,version:n}=r;switch(n){case 0:return af(t,so(r),e??ne.encoder);default:return cf(t,so(r),e??at.encoder)}}var ca=new WeakMap;function so(r){let e=ca.get(r);if(e==null){let t=new Map;return ca.set(r,t),t}return e}var De=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!==Cr)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(t.code!==lf)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=Ze(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&&ra(e.multihash,n.multihash)}toString(e){return aa(this,e)}toJSON(){return{"/":aa(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??la(n,s,o.bytes))}else if(t[uf]===!0){let{version:n,multihash:s,code:o}=t,i=qt(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!==Cr)throw new Error(`Version 0 CID must use dag-pb (code: ${Cr}) block encoding`);return new r(e,t,n,n.bytes)}case 1:{let s=la(e,t,n.bytes);return new r(e,t,n,s)}default:throw new Error("Invalid version")}}static createV0(e){return r.create(0,Cr,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=it(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 or(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[l,d]=_r(e.subarray(t));return t+=d,l},s=n(),o=Cr;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,u=f-i;return{version:s,codec:o,multihashCode:a,digestSize:c,multihashSize:u,size:f}}static parse(e,t){let[n,s]=of(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 so(o).set(n,e),o}};function of(r,e){switch(r[0]){case"Q":{let t=e??ne;return[ne.prefix,t.decode(`${ne.prefix}${r}`)]}case ne.prefix:{let t=e??ne;return[ne.prefix,t.decode(r)]}case at.prefix:{let t=e??at;return[at.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 af(r,e,t){let{prefix:n}=t;if(n!==ne.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 cf(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 Cr=112,lf=18;function la(r,e,t){let n=sr(r),s=n+sr(e),o=new Uint8Array(s+t.byteLength);return nr(r,o,0),nr(e,o,n),o.set(t,s),o}var uf=Symbol.for("@ipld/js-cid/CID");var St={...Xs,...$s,...Js,...Ks,...qs,...zs,...js,...Fs,...Zs,...Gs},Y0={...no,...eo};function de(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}var ff=Symbol.for("nodejs.util.inspect.custom"),ua=Object.values(St).map(r=>r.decoder).reduce((r,e)=>r.or(e),St.identity.decoder),fa=114,oo=36,io=37,Lr=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()})`}[$i]=!0;toString(){return this.string==null&&(this.string=ne.encode(this.multihash.bytes).slice(1)),this.string}toCID(){return De.createV1(fa,this.multihash)}toBytes(){return this.multihash.bytes}toJSON(){return this.toString()}equals(e){if(e==null)return!1;if(e instanceof Uint8Array)return de(this.multihash.bytes,e);if(typeof e=="string")return hf(e).equals(this);if(e?.multihash?.bytes!=null)return de(this.multihash.bytes,e.multihash.bytes);throw new Error("not valid Id")}[ff](){return`PeerId(${this.toString()})`}},ir=class extends Lr{type="RSA";publicKey;constructor(e){super({...e,type:"RSA"}),this.publicKey=e.publicKey}},ar=class extends Lr{type="Ed25519";publicKey;constructor(e){super({...e,type:"Ed25519"}),this.publicKey=e.multihash.digest}},cr=class extends Lr{type="secp256k1";publicKey;constructor(e){super({...e,type:"secp256k1"}),this.publicKey=e.multihash.digest}};function hf(r,e){if(e=e??ua,r.charAt(0)==="1"||r.charAt(0)==="Q"){let t=qt(ne.decode(`z${r}`));return r.startsWith("12D")?new ar({multihash:t}):r.startsWith("16U")?new cr({multihash:t}):new ir({multihash:t})}return ao(ua.decode(r))}function ao(r){try{let e=qt(r);if(e.code===It.code){if(e.digest.length===oo)return new ar({multihash:e});if(e.digest.length===io)return new cr({multihash:e})}if(e.code===ye.code)return new ir({multihash:e})}catch{return df(De.decode(r))}throw new Error("Supplied PeerID CID is invalid")}function df(r){if(r==null||r.multihash==null||r.version==null||r.version===1&&r.code!==fa)throw new Error("Supplied PeerID CID is invalid");let e=r.multihash;if(e.code===ye.code)return new ir({multihash:r.multihash});if(e.code===It.code){if(e.digest.length===oo)return new ar({multihash:r.multihash});if(e.digest.length===io)return new cr({multihash:r.multihash})}throw new Error("Supplied PeerID CID is invalid")}async function Ur(r,e){return r.length===oo?new ar({multihash:Ze(It.code,r),privateKey:e}):r.length===io?new cr({multihash:Ze(It.code,r),privateKey:e}):new ir({multihash:await ye.digest(r),publicKey:r,privateKey:e})}var Mo={};he(Mo,{Ed25519PrivateKey:()=>Zt,Ed25519PublicKey:()=>Hr,generateKeyPair:()=>Lh,generateKeyPairFromSeed:()=>ja,unmarshalEd25519PrivateKey:()=>_h,unmarshalEd25519PublicKey:()=>Ch});function kt(r){return globalThis.Buffer!=null?new Uint8Array(r.buffer,r.byteOffset,r.byteLength):r}function ct(r=0){return globalThis.Buffer?.alloc!=null?kt(globalThis.Buffer.alloc(r)):new Uint8Array(r)}function Se(r=0){return globalThis.Buffer?.allocUnsafe!=null?kt(globalThis.Buffer.allocUnsafe(r)):new Uint8Array(r)}function Be(r,e){if(globalThis.Buffer!=null)return kt(globalThis.Buffer.concat(r,e));e==null&&(e=r.reduce((s,o)=>s+o.length,0));let t=Se(e),n=0;for(let s of r)t.set(s,n),n+=s.length;return kt(t)}function da(r,e,t,n){return{name:r,prefix:e,encoder:{name:r,prefix:e,encode:t},decoder:{decode:n}}}var ha=da("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),co=da("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=Se(r.length);for(let t=0;t<r.length;t++)e[t]=r.charCodeAt(t);return e}),pf={utf8:ha,"utf-8":ha,hex:St.base16,latin1:co,ascii:co,binary:co,...St},fn=pf;function F(r,e="utf8"){let t=fn[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return(e==="utf8"||e==="utf-8")&&globalThis.Buffer!=null&&globalThis.Buffer.from!=null?kt(globalThis.Buffer.from(r,"utf-8")):t.decoder.decode(`${t.prefix}${r}`)}function _e(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function lr(r){if(!Number.isSafeInteger(r)||r<0)throw new Error(`Wrong positive integer: ${r}`)}function gf(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function lo(r,...e){if(!gf(r))throw new Error("Expected Uint8Array");if(e.length>0&&!e.includes(r.length))throw new Error(`Expected Uint8Array of length ${e}, not of length=${r.length}`)}function hn(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");lr(r.outputLen),lr(r.blockLen)}function ur(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 pa(r,e){lo(r);let t=e.outputLen;if(r.length<t)throw new Error(`digestInto() expects output buffer of length at least ${t}`)}var dn=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;function ga(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}var hr=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),Me=(r,e)=>r<<32-e|r>>>e,mf=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;if(!mf)throw new Error("Non little-endian hardware is not supported");var yf=async()=>{};async function ma(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 yf(),n+=o)}}function uo(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function Nt(r){if(typeof r=="string"&&(r=uo(r)),!ga(r))throw new Error(`expected Uint8Array, got ${typeof r}`);return r}function pn(...r){let e=0;for(let n=0;n<r.length;n++){let s=r[n];if(!ga(s))throw new Error("Uint8Array expected");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 fr=class{clone(){return this._cloneInto()}},bf={}.toString;function ya(r,e){if(e!==void 0&&bf.call(e)!=="[object Object]")throw new Error("Options should be object or undefined");return Object.assign(r,e)}function gn(r){let e=n=>r().update(Nt(n)).digest(),t=r();return e.outputLen=t.outputLen,e.blockLen=t.blockLen,e.create=()=>r(),e}function dr(r=32){if(dn&&typeof dn.getRandomValues=="function")return dn.getRandomValues(new Uint8Array(r));throw new Error("crypto.getRandomValues must be defined")}function wf(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 pr=class extends fr{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=hr(this.buffer)}update(e){ur(this);let{view:t,buffer:n,blockLen:s}=this;e=Nt(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=hr(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){ur(this),pa(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 l=i;l<s;l++)t[l]=0;wf(n,s-8,BigInt(this.length*8),o),this.process(n,0);let a=hr(e),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let f=c/4,u=this.get();if(f>u.length)throw new Error("_sha2: outputLen bigger than state");for(let l=0;l<f;l++)a.setUint32(4*l,u[l],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 mn=BigInt(4294967295),fo=BigInt(32);function ba(r,e=!1){return e?{h:Number(r&mn),l:Number(r>>fo&mn)}:{h:Number(r>>fo&mn)|0,l:Number(r&mn)|0}}function xf(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}=ba(r[s],e);[t[s],n[s]]=[o,i]}return[t,n]}var vf=(r,e)=>BigInt(r>>>0)<<fo|BigInt(e>>>0),Ef=(r,e,t)=>r>>>t,Bf=(r,e,t)=>r<<32-t|e>>>t,Af=(r,e,t)=>r>>>t|e<<32-t,If=(r,e,t)=>r<<32-t|e>>>t,Sf=(r,e,t)=>r<<64-t|e>>>t-32,kf=(r,e,t)=>r>>>t-32|e<<64-t,Nf=(r,e)=>e,Rf=(r,e)=>r,Tf=(r,e,t)=>r<<t|e>>>32-t,_f=(r,e,t)=>e<<t|r>>>32-t,Cf=(r,e,t)=>e<<t-32|r>>>64-t,Lf=(r,e,t)=>r<<t-32|e>>>64-t;function Uf(r,e,t,n){let s=(e>>>0)+(n>>>0);return{h:r+t+(s/2**32|0)|0,l:s|0}}var Pf=(r,e,t)=>(r>>>0)+(e>>>0)+(t>>>0),Of=(r,e,t,n)=>e+t+n+(r/2**32|0)|0,Vf=(r,e,t,n)=>(r>>>0)+(e>>>0)+(t>>>0)+(n>>>0),Df=(r,e,t,n,s)=>e+t+n+s+(r/2**32|0)|0,Mf=(r,e,t,n,s)=>(r>>>0)+(e>>>0)+(t>>>0)+(n>>>0)+(s>>>0),Hf=(r,e,t,n,s,o)=>e+t+n+s+o+(r/2**32|0)|0;var Ff={fromBig:ba,split:xf,toBig:vf,shrSH:Ef,shrSL:Bf,rotrSH:Af,rotrSL:If,rotrBH:Sf,rotrBL:kf,rotr32H:Nf,rotr32L:Rf,rotlSH:Tf,rotlSL:_f,rotlBH:Cf,rotlBL:Lf,add:Uf,add3L:Pf,add3H:Of,add4L:Vf,add4H:Df,add5H:Hf,add5L:Mf},U=Ff;var[Kf,qf]=U.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))),Rt=new Uint32Array(80),Tt=new Uint32Array(80),ho=class extends pr{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:u,Fh:l,Fl:d,Gh:b,Gl:p,Hh:h,Hl:m}=this;return[e,t,n,s,o,i,a,c,f,u,l,d,b,p,h,m]}set(e,t,n,s,o,i,a,c,f,u,l,d,b,p,h,m){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=u|0,this.Fh=l|0,this.Fl=d|0,this.Gh=b|0,this.Gl=p|0,this.Hh=h|0,this.Hl=m|0}process(e,t){for(let w=0;w<16;w++,t+=4)Rt[w]=e.getUint32(t),Tt[w]=e.getUint32(t+=4);for(let w=16;w<80;w++){let T=Rt[w-15]|0,x=Tt[w-15]|0,A=U.rotrSH(T,x,1)^U.rotrSH(T,x,8)^U.shrSH(T,x,7),N=U.rotrSL(T,x,1)^U.rotrSL(T,x,8)^U.shrSL(T,x,7),R=Rt[w-2]|0,G=Tt[w-2]|0,q=U.rotrSH(R,G,19)^U.rotrBH(R,G,61)^U.shrSH(R,G,6),P=U.rotrSL(R,G,19)^U.rotrBL(R,G,61)^U.shrSL(R,G,6),ie=U.add4L(N,P,Tt[w-7],Tt[w-16]),re=U.add4H(ie,A,q,Rt[w-7],Rt[w-16]);Rt[w]=re|0,Tt[w]=ie|0}let{Ah:n,Al:s,Bh:o,Bl:i,Ch:a,Cl:c,Dh:f,Dl:u,Eh:l,El:d,Fh:b,Fl:p,Gh:h,Gl:m,Hh:y,Hl:B}=this;for(let w=0;w<80;w++){let T=U.rotrSH(l,d,14)^U.rotrSH(l,d,18)^U.rotrBH(l,d,41),x=U.rotrSL(l,d,14)^U.rotrSL(l,d,18)^U.rotrBL(l,d,41),A=l&b^~l&h,N=d&p^~d&m,R=U.add5L(B,x,N,qf[w],Tt[w]),G=U.add5H(R,y,T,A,Kf[w],Rt[w]),q=R|0,P=U.rotrSH(n,s,28)^U.rotrBH(n,s,34)^U.rotrBH(n,s,39),ie=U.rotrSL(n,s,28)^U.rotrBL(n,s,34)^U.rotrBL(n,s,39),re=n&o^n&a^o&a,Te=s&i^s&c^i&c;y=h|0,B=m|0,h=b|0,m=p|0,b=l|0,p=d|0,{h:l,l:d}=U.add(f|0,u|0,G|0,q|0),f=a|0,u=c|0,a=o|0,c=i|0,o=n|0,i=s|0;let v=U.add3L(q,ie,Te);n=U.add3H(v,G,P,re),s=v|0}({h:n,l:s}=U.add(this.Ah|0,this.Al|0,n|0,s|0)),{h:o,l:i}=U.add(this.Bh|0,this.Bl|0,o|0,i|0),{h:a,l:c}=U.add(this.Ch|0,this.Cl|0,a|0,c|0),{h:f,l:u}=U.add(this.Dh|0,this.Dl|0,f|0,u|0),{h:l,l:d}=U.add(this.Eh|0,this.El|0,l|0,d|0),{h:b,l:p}=U.add(this.Fh|0,this.Fl|0,b|0,p|0),{h,l:m}=U.add(this.Gh|0,this.Gl|0,h|0,m|0),{h:y,l:B}=U.add(this.Hh|0,this.Hl|0,y|0,B|0),this.set(n,s,o,i,a,c,f,u,l,d,b,p,h,m,y,B)}roundClean(){Rt.fill(0),Tt.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 gr=gn(()=>new ho);var bn={};he(bn,{bitGet:()=>Zf,bitLen:()=>Yf,bitMask:()=>Pr,bitSet:()=>Jf,bytesToHex:()=>ut,bytesToNumberBE:()=>ft,bytesToNumberLE:()=>_t,concatBytes:()=>ht,createHmacDrbg:()=>mo,ensureBytes:()=>te,equalBytes:()=>jf,hexToBytes:()=>Gt,hexToNumber:()=>go,isBytes:()=>He,numberToBytesBE:()=>Ct,numberToBytesLE:()=>zt,numberToHexUnpadded:()=>Ea,numberToVarBytesBE:()=>zf,utf8ToBytes:()=>Wf,validateObject:()=>Je});var va=BigInt(0),yn=BigInt(1),$f=BigInt(2);function He(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}var Gf=Array.from({length:256},(r,e)=>e.toString(16).padStart(2,"0"));function ut(r){if(!He(r))throw new Error("Uint8Array expected");let e="";for(let t=0;t<r.length;t++)e+=Gf[r[t]];return e}function Ea(r){let e=r.toString(16);return e.length&1?`0${e}`:e}function go(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return BigInt(r===""?"0":`0x${r}`)}var lt={_0:48,_9:57,_A:65,_F:70,_a:97,_f:102};function wa(r){if(r>=lt._0&&r<=lt._9)return r-lt._0;if(r>=lt._A&&r<=lt._F)return r-(lt._A-10);if(r>=lt._a&&r<=lt._f)return r-(lt._a-10)}function Gt(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=wa(r.charCodeAt(o)),a=wa(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 go(ut(r))}function _t(r){if(!He(r))throw new Error("Uint8Array expected");return go(ut(Uint8Array.from(r).reverse()))}function Ct(r,e){return Gt(r.toString(16).padStart(e*2,"0"))}function zt(r,e){return Ct(r,e).reverse()}function zf(r){return Gt(Ea(r))}function te(r,e,t){let n;if(typeof e=="string")try{n=Gt(e)}catch(o){throw new Error(`${r} must be valid hex string, got "${e}". Cause: ${o}`)}else if(He(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 ht(...r){let e=0;for(let s=0;s<r.length;s++){let o=r[s];if(!He(o))throw new Error("Uint8Array expected");e+=o.length}let t=new Uint8Array(e),n=0;for(let s=0;s<r.length;s++){let o=r[s];t.set(o,n),n+=o.length}return t}function jf(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 Wf(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function Yf(r){let e;for(e=0;r>va;r>>=yn,e+=1);return e}function Zf(r,e){return r>>BigInt(e)&yn}var Jf=(r,e,t)=>r|(t?yn:va)<<BigInt(e),Pr=r=>($f<<BigInt(r-1))-yn,po=r=>new Uint8Array(r),xa=r=>Uint8Array.from(r);function mo(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=po(r),s=po(r),o=0,i=()=>{n.fill(1),s.fill(0),o=0},a=(...l)=>t(s,n,...l),c=(l=po())=>{s=a(xa([0]),l),n=a(),l.length!==0&&(s=a(xa([1]),l),n=a())},f=()=>{if(o++>=1e3)throw new Error("drbg: tried 1000 values");let l=0,d=[];for(;l<e;){n=a();let b=n.slice();d.push(b),l+=n.length}return ht(...d)};return(l,d)=>{i(),c(l);let b;for(;!(b=d(f()));)c();return i(),b}}var Xf={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"||He(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 Je(r,e,t={}){let n=(s,o,i)=>{let a=Xf[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 ue=BigInt(0),Z=BigInt(1),jt=BigInt(2),Qf=BigInt(3),yo=BigInt(4),Ba=BigInt(5),Aa=BigInt(8),eh=BigInt(9),th=BigInt(16);function Y(r,e){let t=r%e;return t>=ue?t:e+t}function rh(r,e,t){if(t<=ue||e<ue)throw new Error("Expected power/modulo > 0");if(t===Z)return ue;let n=Z;for(;e>ue;)e&Z&&(n=n*r%t),r=r*r%t,e>>=Z;return n}function J(r,e,t){let n=r;for(;e-- >ue;)n*=n,n%=t;return n}function wn(r,e){if(r===ue||e<=ue)throw new Error(`invert: expected positive integers, got n=${r} mod=${e}`);let t=Y(r,e),n=e,s=ue,o=Z,i=Z,a=ue;for(;t!==ue;){let f=n/t,u=n%t,l=s-i*f,d=o-a*f;n=t,t=u,s=i,o=a,i=l,a=d}if(n!==Z)throw new Error("invert: does not exist");return Y(s,e)}function nh(r){let e=(r-Z)/jt,t,n,s;for(t=r-Z,n=0;t%jt===ue;t/=jt,n++);for(s=jt;s<r&&rh(s,e,r)!==r-Z;s++);if(n===1){let i=(r+Z)/yo;return function(c,f){let u=c.pow(f,i);if(!c.eql(c.sqr(u),f))throw new Error("Cannot find square root");return u}}let o=(t+Z)/jt;return function(a,c){if(a.pow(c,e)===a.neg(a.ONE))throw new Error("Cannot find square root");let f=n,u=a.pow(a.mul(a.ONE,s),t),l=a.pow(c,o),d=a.pow(c,t);for(;!a.eql(d,a.ONE);){if(a.eql(d,a.ZERO))return a.ZERO;let b=1;for(let h=a.sqr(d);b<f&&!a.eql(h,a.ONE);b++)h=a.sqr(h);let p=a.pow(u,Z<<BigInt(f-b-1));u=a.sqr(p),l=a.mul(l,p),d=a.mul(d,u),f=b}return l}}function sh(r){if(r%yo===Qf){let e=(r+Z)/yo;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%Aa===Ba){let e=(r-Ba)/Aa;return function(n,s){let o=n.mul(s,jt),i=n.pow(o,e),a=n.mul(s,i),c=n.mul(n.mul(a,jt),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%th,nh(r)}var Ia=(r,e)=>(Y(r,e)&Z)===Z,oh=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function bo(r){let e={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},t=oh.reduce((n,s)=>(n[s]="function",n),e);return Je(r,t)}function ih(r,e,t){if(t<ue)throw new Error("Expected power > 0");if(t===ue)return r.ONE;if(t===Z)return e;let n=r.ONE,s=e;for(;t>ue;)t&Z&&(n=r.mul(n,s)),s=r.sqr(s),t>>=Z;return n}function ah(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 wo(r,e){let t=e!==void 0?e:r.toString(2).length,n=Math.ceil(t/8);return{nBitLength:t,nByteLength:n}}function xn(r,e,t=!1,n={}){if(r<=ue)throw new Error(`Expected Field ORDER > 0, got ${r}`);let{nBitLength:s,nByteLength:o}=wo(r,e);if(o>2048)throw new Error("Field lengths over 2048 bytes are not supported");let i=sh(r),a=Object.freeze({ORDER:r,BITS:s,BYTES:o,MASK:Pr(s),ZERO:ue,ONE:Z,create:c=>Y(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error(`Invalid field element: expected bigint, got ${typeof c}`);return ue<=c&&c<r},is0:c=>c===ue,isOdd:c=>(c&Z)===Z,neg:c=>Y(-c,r),eql:(c,f)=>c===f,sqr:c=>Y(c*c,r),add:(c,f)=>Y(c+f,r),sub:(c,f)=>Y(c-f,r),mul:(c,f)=>Y(c*f,r),pow:(c,f)=>ih(a,c,f),div:(c,f)=>Y(c*wn(f,r),r),sqrN:c=>c*c,addN:(c,f)=>c+f,subN:(c,f)=>c-f,mulN:(c,f)=>c*f,inv:c=>wn(c,r),sqrt:n.sqrt||(c=>i(a,c)),invertBatch:c=>ah(a,c),cmov:(c,f,u)=>u?f:c,toBytes:c=>t?zt(c,o):Ct(c,o),fromBytes:c=>{if(c.length!==o)throw new Error(`Fp.fromBytes: expected ${o}, got ${c.length}`);return t?_t(c):ft(c)}});return Object.freeze(a)}function Sa(r,e){if(!r.isOdd)throw new Error("Field doesn't have isOdd");let t=r.sqrt(e);return r.isOdd(t)?r.neg(t):t}function ka(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 xo(r){let e=ka(r);return e+Math.ceil(e/2)}function Na(r,e,t=!1){let n=r.length,s=ka(e),o=xo(e);if(n<16||n<o||n>1024)throw new Error(`expected ${o}-1024 bytes of input, got ${n}`);let i=t?ft(r):_t(r),a=Y(i,e-Z)+Z;return t?zt(a,s):Ct(a,s)}var lh=BigInt(0),vo=BigInt(1);function vn(r,e){let t=(s,o)=>{let i=o.negate();return s?i:o},n=s=>{let o=Math.ceil(e/s)+1,i=2**(s-1);return{windows:o,windowSize:i}};return{constTimeNegate:t,unsafeLadder(s,o){let i=r.ZERO,a=s;for(;o>lh;)o&vo&&(i=i.add(a)),a=a.double(),o>>=vo;return i},precomputeWindow(s,o){let{windows:i,windowSize:a}=n(o),c=[],f=s,u=f;for(let l=0;l<i;l++){u=f,c.push(u);for(let d=1;d<a;d++)u=u.add(f),c.push(u);f=u.double()}return c},wNAF(s,o,i){let{windows:a,windowSize:c}=n(s),f=r.ZERO,u=r.BASE,l=BigInt(2**s-1),d=2**s,b=BigInt(s);for(let p=0;p<a;p++){let h=p*c,m=Number(i&l);i>>=b,m>c&&(m-=d,i+=vo);let y=h,B=h+Math.abs(m)-1,w=p%2!==0,T=m<0;m===0?u=u.add(t(w,o[y])):f=f.add(t(T,o[B]))}return{p:f,f:u}},wNAFCached(s,o,i,a){let c=s._WINDOW_SIZE||1,f=o.get(s);return f||(f=this.precomputeWindow(s,c),c!==1&&o.set(s,a(f))),this.wNAF(c,f,i)}}}function Or(r){return bo(r.Fp),Je(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...wo(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Fe=BigInt(0),Re=BigInt(1),En=BigInt(2),uh=BigInt(8),fh={zip215:!0};function hh(r){let e=Or(r);return Je(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...e})}function Bn(r){let e=hh(r),{Fp:t,n,prehash:s,hash:o,randomBytes:i,nByteLength:a,h:c}=e,f=En<<BigInt(a*8)-Re,u=t.create,l=e.uvRatio||((E,g)=>{try{return{isValid:!0,value:t.sqrt(E*t.inv(g))}}catch{return{isValid:!1,value:Fe}}}),d=e.adjustScalarBytes||(E=>E),b=e.domain||((E,g,S)=>{if(g.length||S)throw new Error("Contexts/pre-hash are not supported");return E}),p=E=>typeof E=="bigint"&&Fe<E,h=(E,g)=>p(E)&&p(g)&&E<g,m=E=>E===Fe||h(E,f);function y(E,g){if(h(E,g))return E;throw new Error(`Expected valid scalar < ${g}, got ${typeof E} ${E}`)}function B(E){return E===Fe?E:y(E,n)}let w=new Map;function T(E){if(!(E instanceof x))throw new Error("ExtendedPoint expected")}class x{constructor(g,S,_,L){if(this.ex=g,this.ey=S,this.ez=_,this.et=L,!m(g))throw new Error("x required");if(!m(S))throw new Error("y required");if(!m(_))throw new Error("z required");if(!m(L))throw new Error("t required")}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(g){if(g instanceof x)throw new Error("extended point not allowed");let{x:S,y:_}=g||{};if(!m(S)||!m(_))throw new Error("invalid affine point");return new x(S,_,Re,u(S*_))}static normalizeZ(g){let S=t.invertBatch(g.map(_=>_.ez));return g.map((_,L)=>_.toAffine(S[L])).map(x.fromAffine)}_setWindowSize(g){this._WINDOW_SIZE=g,w.delete(this)}assertValidity(){let{a:g,d:S}=e;if(this.is0())throw new Error("bad point: ZERO");let{ex:_,ey:L,ez:V,et:D}=this,W=u(_*_),H=u(L*L),$=u(V*V),ae=u($*$),Q=u(W*g),ge=u($*u(Q+H)),me=u(ae+u(S*u(W*H)));if(ge!==me)throw new Error("bad point: equation left != right (1)");let le=u(_*L),we=u(V*D);if(le!==we)throw new Error("bad point: equation left != right (2)")}equals(g){T(g);let{ex:S,ey:_,ez:L}=this,{ex:V,ey:D,ez:W}=g,H=u(S*W),$=u(V*L),ae=u(_*W),Q=u(D*L);return H===$&&ae===Q}is0(){return this.equals(x.ZERO)}negate(){return new x(u(-this.ex),this.ey,this.ez,u(-this.et))}double(){let{a:g}=e,{ex:S,ey:_,ez:L}=this,V=u(S*S),D=u(_*_),W=u(En*u(L*L)),H=u(g*V),$=S+_,ae=u(u($*$)-V-D),Q=H+D,ge=Q-W,me=H-D,le=u(ae*ge),we=u(Q*me),ot=u(ae*me),Kt=u(ge*Q);return new x(le,we,Kt,ot)}add(g){T(g);let{a:S,d:_}=e,{ex:L,ey:V,ez:D,et:W}=this,{ex:H,ey:$,ez:ae,et:Q}=g;if(S===BigInt(-1)){let ki=u((V-L)*($+H)),Ni=u((V+L)*($-H)),Os=u(Ni-ki);if(Os===Fe)return this.double();let Ri=u(D*En*Q),Ti=u(W*En*ae),_i=Ti+Ri,Ci=Ni+ki,Li=Ti-Ri,Jl=u(_i*Os),Xl=u(Ci*Li),Ql=u(_i*Li),eu=u(Os*Ci);return new x(Jl,Xl,eu,Ql)}let ge=u(L*H),me=u(V*$),le=u(W*_*Q),we=u(D*ae),ot=u((L+V)*(H+$)-ge-me),Kt=we-le,Rr=we+le,Si=u(me-S*ge),jl=u(ot*Kt),Wl=u(Rr*Si),Yl=u(ot*Si),Zl=u(Kt*Rr);return new x(jl,Wl,Zl,Yl)}subtract(g){return this.add(g.negate())}wNAF(g){return R.wNAFCached(this,w,g,x.normalizeZ)}multiply(g){let{p:S,f:_}=this.wNAF(y(g,n));return x.normalizeZ([S,_])[0]}multiplyUnsafe(g){let S=B(g);return S===Fe?N:this.equals(N)||S===Re?this:this.equals(A)?this.wNAF(S).p:R.unsafeLadder(this,S)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return R.unsafeLadder(this,n).is0()}toAffine(g){let{ex:S,ey:_,ez:L}=this,V=this.is0();g==null&&(g=V?uh:t.inv(L));let D=u(S*g),W=u(_*g),H=u(L*g);if(V)return{x:Fe,y:Re};if(H!==Re)throw new Error("invZ was invalid");return{x:D,y:W}}clearCofactor(){let{h:g}=e;return g===Re?this:this.multiplyUnsafe(g)}static fromHex(g,S=!1){let{d:_,a:L}=e,V=t.BYTES;g=te("pointHex",g,V);let D=g.slice(),W=g[V-1];D[V-1]=W&-129;let H=_t(D);H===Fe||(S?y(H,f):y(H,t.ORDER));let $=u(H*H),ae=u($-Re),Q=u(_*$-L),{isValid:ge,value:me}=l(ae,Q);if(!ge)throw new Error("Point.fromHex: invalid y coordinate");let le=(me&Re)===Re,we=(W&128)!==0;if(!S&&me===Fe&&we)throw new Error("Point.fromHex: x=0 and x_0=1");return we!==le&&(me=u(-me)),x.fromAffine({x:me,y:H})}static fromPrivateKey(g){return P(g).point}toRawBytes(){let{x:g,y:S}=this.toAffine(),_=zt(S,t.BYTES);return _[_.length-1]|=g&Re?128:0,_}toHex(){return ut(this.toRawBytes())}}x.BASE=new x(e.Gx,e.Gy,Re,u(e.Gx*e.Gy)),x.ZERO=new x(Fe,Re,Re,Fe);let{BASE:A,ZERO:N}=x,R=vn(x,a*8);function G(E){return Y(E,n)}function q(E){return G(_t(E))}function P(E){let g=a;E=te("private key",E,g);let S=te("hashed private key",o(E),2*g),_=d(S.slice(0,g)),L=S.slice(g,2*g),V=q(_),D=A.multiply(V),W=D.toRawBytes();return{head:_,prefix:L,scalar:V,point:D,pointBytes:W}}function ie(E){return P(E).pointBytes}function re(E=new Uint8Array,...g){let S=ht(...g);return q(o(b(S,te("context",E),!!s)))}function Te(E,g,S={}){E=te("message",E),s&&(E=s(E));let{prefix:_,scalar:L,pointBytes:V}=P(g),D=re(S.context,_,E),W=A.multiply(D).toRawBytes(),H=re(S.context,W,V,E),$=G(D+H*L);B($);let ae=ht(W,zt($,t.BYTES));return te("result",ae,a*2)}let v=fh;function k(E,g,S,_=v){let{context:L,zip215:V}=_,D=t.BYTES;E=te("signature",E,2*D),g=te("message",g),s&&(g=s(g));let W=_t(E.slice(D,2*D)),H,$,ae;try{H=x.fromHex(S,V),$=x.fromHex(E.slice(0,D),V),ae=A.multiplyUnsafe(W)}catch{return!1}if(!V&&H.isSmallOrder())return!1;let Q=re(L,$.toRawBytes(),H.toRawBytes(),g);return $.add(H.multiplyUnsafe(Q)).subtract(ae).clearCofactor().equals(x.ZERO)}return A._setWindowSize(8),{CURVE:e,getPublicKey:ie,sign:Te,verify:k,ExtendedPoint:x,utils:{getExtendedPublicKey:P,randomPrivateKey:()=>i(t.BYTES),precompute(E=8,g=x.BASE){return g._setWindowSize(E),g.multiply(BigInt(3)),g}}}}var Bo=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),Ra=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),Gp=BigInt(0),dh=BigInt(1),Eo=BigInt(2),ph=BigInt(5),Ta=BigInt(10),gh=BigInt(20),mh=BigInt(40),_a=BigInt(80);function yh(r){let e=Bo,n=r*r%e*r%e,s=J(n,Eo,e)*n%e,o=J(s,dh,e)*r%e,i=J(o,ph,e)*o%e,a=J(i,Ta,e)*i%e,c=J(a,gh,e)*a%e,f=J(c,mh,e)*c%e,u=J(f,_a,e)*f%e,l=J(u,_a,e)*f%e,d=J(l,Ta,e)*i%e;return{pow_p_5_8:J(d,Eo,e)*r%e,b2:n}}function bh(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function wh(r,e){let t=Bo,n=Y(e*e*e,t),s=Y(n*n*e,t),o=yh(r*s).pow_p_5_8,i=Y(r*n*o,t),a=Y(e*i*i,t),c=i,f=Y(i*Ra,t),u=a===r,l=a===Y(-r,t),d=a===Y(-r*Ra,t);return u&&(i=c),(l||d)&&(i=f),Ia(i,t)&&(i=Y(-i,t)),{isValid:u||l,value:i}}var dt=xn(Bo,void 0,!0),Ao={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:dt,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:BigInt(8),Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:gr,randomBytes:dr,adjustScalarBytes:bh,uvRatio:wh},mr=Bn(Ao);function Ca(r,e,t){if(e.length>255)throw new Error("Context is too big");return pn(uo("SigEd25519 no Ed25519 collisions"),new Uint8Array([t?1:0,e.length]),e,r)}var zp=Bn({...Ao,domain:Ca}),jp=Bn({...Ao,domain:Ca,prehash:gr});var xh=(dt.ORDER+BigInt(3))/BigInt(8),Wp=dt.pow(Eo,xh),Yp=dt.sqrt(dt.neg(dt.ONE)),Zp=(dt.ORDER-BigInt(5))/BigInt(8),Jp=BigInt(486662);var Xp=Sa(dt,dt.neg(BigInt(486664)));var Qp=BigInt("25063068953384623474111414158702152701244531502492656460079210482610430750235"),eg=BigInt("54469307008909316920995813868745141605393597292927456921205312896311721017578"),tg=BigInt("1159843021668779879193775521855586647937357759715417654439879720876111806838"),rg=BigInt("40440834346308536858101042469323190826248399146238708352240133220865137265952");var ng=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff");var yr=32,pt=64,An=32;function La(){let r=mr.utils.randomPrivateKey(),e=mr.getPublicKey(r);return{privateKey:Va(r,e),publicKey:e}}function Ua(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=mr.getPublicKey(e);return{privateKey:Va(e,t),publicKey:t}}function Pa(r,e){let t=r.subarray(0,An);return mr.sign(e instanceof Uint8Array?e:e.subarray(),t)}function Oa(r,e,t){return mr.verify(e,t instanceof Uint8Array?t:t.subarray(),r)}function Va(r,e){let t=new Uint8Array(pt);for(let n=0;n<An;n++)t[n]=r[n],t[An+n]=e[n];return t}var Ae={get(r=globalThis){let e=r.crypto;if(e==null||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 Io={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function Da(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=Ae.get();t*=8;async function c(l,d){let b=a.getRandomValues(new Uint8Array(o)),p=a.getRandomValues(new Uint8Array(n)),h={name:e,iv:p};typeof d=="string"&&(d=F(d));let m;if(d.length===0){m=await a.subtle.importKey("jwk",Io,{name:"AES-GCM"},!0,["encrypt"]);try{let B={name:"PBKDF2",salt:b,iterations:i,hash:{name:s}},w=await a.subtle.importKey("raw",d,{name:"PBKDF2"},!1,["deriveKey"]);m=await a.subtle.deriveKey(B,w,{name:e,length:t},!0,["encrypt"])}catch{m=await a.subtle.importKey("jwk",Io,{name:"AES-GCM"},!0,["encrypt"])}}else{let B={name:"PBKDF2",salt:b,iterations:i,hash:{name:s}},w=await a.subtle.importKey("raw",d,{name:"PBKDF2"},!1,["deriveKey"]);m=await a.subtle.deriveKey(B,w,{name:e,length:t},!0,["encrypt"])}let y=await a.subtle.encrypt(h,m,l);return Be([b,h.iv,new Uint8Array(y)])}async function f(l,d){let b=l.subarray(0,o),p=l.subarray(o,o+n),h=l.subarray(o+n),m={name:e,iv:p};typeof d=="string"&&(d=F(d));let y;if(d.length===0)try{let w={name:"PBKDF2",salt:b,iterations:i,hash:{name:s}},T=await a.subtle.importKey("raw",d,{name:"PBKDF2"},!1,["deriveKey"]);y=await a.subtle.deriveKey(w,T,{name:e,length:t},!0,["decrypt"])}catch{y=await a.subtle.importKey("jwk",Io,{name:"AES-GCM"},!0,["decrypt"])}else{let w={name:"PBKDF2",salt:b,iterations:i,hash:{name:s}},T=await a.subtle.importKey("raw",d,{name:"PBKDF2"},!1,["deriveKey"]);y=await a.subtle.deriveKey(w,T,{name:e,length:t},!0,["decrypt"])}let B=await a.subtle.decrypt(m,y,h);return new Uint8Array(B)}return{encrypt:c,decrypt:f}}async function br(r,e){let n=await Da().encrypt(r,e);return Ws.encode(n)}var So=new Float32Array([-0]),Lt=new Uint8Array(So.buffer);function Ma(r,e,t){So[0]=r,e[t]=Lt[0],e[t+1]=Lt[1],e[t+2]=Lt[2],e[t+3]=Lt[3]}function Ha(r,e){return Lt[0]=r[e],Lt[1]=r[e+1],Lt[2]=r[e+2],Lt[3]=r[e+3],So[0]}var ko=new Float64Array([-0]),xe=new Uint8Array(ko.buffer);function Fa(r,e,t){ko[0]=r,e[t]=xe[0],e[t+1]=xe[1],e[t+2]=xe[2],e[t+3]=xe[3],e[t+4]=xe[4],e[t+5]=xe[5],e[t+6]=xe[6],e[t+7]=xe[7]}function Ka(r,e){return xe[0]=r[e],xe[1]=r[e+1],xe[2]=r[e+2],xe[3]=r[e+3],xe[4]=r[e+4],xe[5]=r[e+5],xe[6]=r[e+6],xe[7]=r[e+7],ko[0]}var Bh=BigInt(Number.MAX_SAFE_INTEGER),Ah=BigInt(Number.MIN_SAFE_INTEGER),ke=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 Wt;if(e<Bh&&e>Ah)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>qa&&(s=0n,++n>qa&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(e){if(e===0)return Wt;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):Wt}},Wt=new ke(0,0);Wt.toBigInt=function(){return 0n};Wt.zzEncode=Wt.zzDecode=function(){return this};Wt.length=function(){return 1};var qa=4294967296n;function $a(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 Ga(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 No(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 Ke(r,e){return RangeError(`index out of range: ${r.pos} + ${e??1} > ${r.len}`)}function In(r,e){return(r[e-4]|r[e-3]<<8|r[e-2]<<16|r[e-1]<<24)>>>0}var Ro=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,Ke(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 Ke(this,4);return In(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Ke(this,4);return In(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Ke(this,4);let e=Ha(this.buf,this.pos);return this.pos+=4,e}double(){if(this.pos+8>this.len)throw Ke(this,4);let e=Ka(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 Ke(this,e);return this.pos+=e,t===n?new Uint8Array(0):this.buf.subarray(t,n)}string(){let e=this.bytes();return Ga(e,0,e.length)}skip(e){if(typeof e=="number"){if(this.pos+e>this.len)throw Ke(this,e);this.pos+=e}else do if(this.pos>=this.len)throw Ke(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 ke(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 Ke(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 Ke(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 Ke(this,8);let e=In(this.buf,this.pos+=4),t=In(this.buf,this.pos+=4);return new ke(e,t)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){return this.readLongVarint().toNumber(!0)}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 To(r){return new Ro(r instanceof Uint8Array?r:r.subarray())}function qe(r,e){let t=To(r);return e.decode(t)}function _o(r){let e=r??8192,t=e>>>1,n,s=e;return function(i){if(i<1||i>t)return Se(i);s+i>e&&(n=Se(e),s=0);let a=n.subarray(s,s+=i);return s&7&&(s=(s|7)+1),a}}var Yt=class{fn;len;next;val;constructor(e,t,n){this.fn=e,this.len=t,this.next=void 0,this.val=n}};function Co(){}var Uo=class{head;tail;len;next;constructor(e){this.head=e.head,this.tail=e.tail,this.len=e.len,this.next=e.states}},Ih=_o();function Sh(r){return globalThis.Buffer!=null?Se(r):Ih(r)}var Mr=class{len;head;tail;states;constructor(){this.len=0,this.head=new Yt(Co,0,0),this.tail=this.head,this.states=null}_push(e,t,n){return this.tail=this.tail.next=new Yt(e,t,n),this.len+=t,this}uint32(e){return this.len+=(this.tail=this.tail.next=new Po((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(Vr,10,ke.fromNumber(e)):this.uint32(e)}sint32(e){return this.uint32((e<<1^e>>31)>>>0)}uint64(e){let t=ke.fromBigInt(e);return this._push(Vr,t.length(),t)}uint64Number(e){let t=ke.fromNumber(e);return this._push(Vr,t.length(),t)}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=ke.fromBigInt(e).zzEncode();return this._push(Vr,t.length(),t)}sint64Number(e){let t=ke.fromNumber(e).zzEncode();return this._push(Vr,t.length(),t)}sint64String(e){return this.sint64(BigInt(e))}bool(e){return this._push(Lo,1,e?1:0)}fixed32(e){return this._push(Dr,4,e>>>0)}sfixed32(e){return this.fixed32(e)}fixed64(e){let t=ke.fromBigInt(e);return this._push(Dr,4,t.lo)._push(Dr,4,t.hi)}fixed64Number(e){let t=ke.fromNumber(e);return this._push(Dr,4,t.lo)._push(Dr,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(Ma,4,e)}double(e){return this._push(Fa,8,e)}bytes(e){let t=e.length>>>0;return t===0?this._push(Lo,1,0):this.uint32(t)._push(Nh,t,e)}string(e){let t=$a(e);return t!==0?this.uint32(t)._push(No,t,e):this._push(Lo,1,0)}fork(){return this.states=new Uo(this),this.head=this.tail=new Yt(Co,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 Yt(Co,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=Sh(this.len),n=0;for(;e!=null;)e.fn(e.val,t,n),n+=e.len,e=e.next;return t}};function Lo(r,e,t){e[t]=r&255}function kh(r,e,t){for(;r>127;)e[t++]=r&127|128,r>>>=7;e[t]=r}var Po=class extends Yt{next;constructor(e,t){super(kh,e,t),this.next=void 0}};function Vr(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 Dr(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 Nh(r,e,t){e.set(r,t)}globalThis.Buffer!=null&&(Mr.prototype.bytes=function(r){let e=r.length>>>0;return this.uint32(e),e>0&&this._push(Rh,e,r),this},Mr.prototype.string=function(r){let e=globalThis.Buffer.byteLength(r);return this.uint32(e),e>0&&this._push(Th,e,r),this});function Rh(r,e,t){e.set(r,t)}function Th(r,e,t){r.length<40?No(r,e,t):e.utf8Write!=null?e.utf8Write(r,t):e.set(F(r),t)}function Oo(){return new Mr}function $e(r,e){let t=Oo();return e.encode(r,t,{lengthDelimited:!1}),t.finish()}var wr;(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"})(wr||(wr={}));function Sn(r,e,t,n){return{name:r,type:e,encode:t,decode:n}}function Vo(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 Sn("enum",wr.VARINT,t,n)}function Ge(r,e){return Sn("message",wr.LENGTH_DELIMITED,r,e)}var X;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.Secp256k1="Secp256k1"})(X||(X={}));var Do;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.Secp256k1=2]="Secp256k1"})(Do||(Do={}));(function(r){r.codec=()=>Vo(Do)})(X||(X={}));var Xe;(function(r){let e;r.codec=()=>(e==null&&(e=Ge((t,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),t.Type!=null&&(n.uint32(8),X.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=X.codec().decode(t);break;case 2:s.Data=t.bytes();break;default:t.skipType(i&7);break}}return s})),e),r.encode=t=>$e(t,r.codec()),r.decode=t=>qe(t,r.codec())})(Xe||(Xe={}));var Qe;(function(r){let e;r.codec=()=>(e==null&&(e=Ge((t,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),t.Type!=null&&(n.uint32(8),X.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=X.codec().decode(t);break;case 2:s.Data=t.bytes();break;default:t.skipType(i&7);break}}return s})),e),r.encode=t=>$e(t,r.codec()),r.decode=t=>qe(t,r.codec())})(Qe||(Qe={}));var Hr=class{_key;constructor(e){this._key=xr(e,yr)}verify(e,t){return Oa(this._key,t,e)}marshal(){return this._key}get bytes(){return Xe.encode({Type:X.Ed25519,Data:this.marshal()}).subarray()}equals(e){return de(this.bytes,e.bytes)}hash(){let e=ye.digest(this.bytes);return _e(e)?e.then(({bytes:t})=>t):e.bytes}},Zt=class{_key;_publicKey;constructor(e,t){this._key=xr(e,pt),this._publicKey=xr(t,yr)}sign(e){return Pa(this._key,e)}get public(){return new Hr(this._publicKey)}marshal(){return this._key}get bytes(){return Qe.encode({Type:X.Ed25519,Data:this.marshal()}).subarray()}equals(e){return de(this.bytes,e.bytes)}async hash(){let e=ye.digest(this.bytes),t;return _e(e)?{bytes:t}=await e:t=e.bytes,t}async id(){let e=It.digest(this.public.bytes);return ne.encode(e.bytes).substring(1)}async export(e,t="libp2p-key"){if(t==="libp2p-key")return br(this.bytes,e);throw new C(`export format '${t}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function _h(r){if(r.length>pt){r=xr(r,pt+yr);let n=r.subarray(0,pt),s=r.subarray(pt,r.length);return new Zt(n,s)}r=xr(r,pt);let e=r.subarray(0,pt),t=r.subarray(yr);return new Zt(e,t)}function Ch(r){return r=xr(r,yr),new Hr(r)}async function Lh(){let{privateKey:r,publicKey:e}=La();return new Zt(r,e)}async function ja(r){let{privateKey:e,publicKey:t}=Ua(r);return new Zt(e,t)}function xr(r,e){if(r=Uint8Array.from(r??[]),r.length!==e)throw new C(`Key must be a Uint8Array of length ${e}, got ${r.length}`,"ERR_INVALID_KEY_TYPE");return r}function K(r,e="utf8"){let t=fn[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return(e==="utf8"||e==="utf-8")&&globalThis.Buffer!=null&&globalThis.Buffer.from!=null?globalThis.Buffer.from(r.buffer,r.byteOffset,r.byteLength).toString("utf8"):t.encoder.encode(r).substring(1)}var Yo={};he(Yo,{MAX_RSA_KEY_SIZE:()=>Xr,RsaPrivateKey:()=>Ir,RsaPublicKey:()=>Jr,fromJwk:()=>id,generateKeyPair:()=>ad,unmarshalRsaPrivateKey:()=>jo,unmarshalRsaPublicKey:()=>od});function Jt(r){if(isNaN(r)||r<=0)throw new C("random bytes length must be a Number bigger than 0","ERR_INVALID_LENGTH");return dr(r)}var Vt={};he(Vt,{exportToPem:()=>ed,importFromPem:()=>td,jwkToPkcs1:()=>Zh,jwkToPkix:()=>Xh,pkcs1ToJwk:()=>Yh,pkixToJwk:()=>Jh});var Nn=class extends fr{constructor(e,t){super(),this.finished=!1,this.destroyed=!1,hn(e);let n=Nt(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 ur(this),this.iHash.update(e),this}digestInto(e){ur(this),lo(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()}},Fr=(r,e,t)=>new Nn(r,e).update(t).digest();Fr.create=(r,e)=>new Nn(r,e);function Uh(r,e,t,n){hn(r);let s=ya({dkLen:32,asyncTick:10},n),{c:o,dkLen:i,asyncTick:a}=s;if(lr(o),lr(i),lr(a),o<1)throw new Error("PBKDF2: iterations (c) should be >= 1");let c=Nt(e),f=Nt(t),u=new Uint8Array(i),l=Fr.create(r,c),d=l._cloneInto().update(f);return{c:o,dkLen:i,asyncTick:a,DK:u,PRF:l,PRFSalt:d}}function Ph(r,e,t,n,s){return r.destroy(),e.destroy(),n&&n.destroy(),s.fill(0),t}async function Ho(r,e,t,n){let{c:s,dkLen:o,asyncTick:i,DK:a,PRF:c,PRFSalt:f}=Uh(r,e,t,n),u,l=new Uint8Array(4),d=hr(l),b=new Uint8Array(c.outputLen);for(let p=1,h=0;h<o;p++,h+=c.outputLen){let m=a.subarray(h,h+c.outputLen);d.setInt32(0,p,!1),(u=f._cloneInto(u)).update(l).digestInto(b),m.set(b.subarray(0,m.length)),await ma(s-1,i,()=>{c._cloneInto(u).update(b).digestInto(b);for(let y=0;y<m.length;y++)m[y]^=b[y]})}return Ph(c,f,a,u,b)}var M=Oi(Wa());function Xt(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 Ut(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 u=a-1;u>=0;u--){let l=Math.pow(2,u*e);f[o-u-1]=Math.floor(s/l),s-=f[o-u-1]*l}return c}i*=Math.pow(2,e)}return new ArrayBuffer(0)}function _n(...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 Ko(){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=Xt(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,Xt(o,8)-n}function Ya(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=Ut(i,8,n),c=new Uint8Array(a);return c[0]|=128,a}let s=Ut(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 Za(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 Ne(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 cm=Math.log(2);function Cn(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function qo(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 wt(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 qr=class{constructor(){this.items=[]}write(e){this.items.push(e)}final(){return qo(this.items)}},Kr=[new Uint8Array([1])],Ja="0123456789";var Br="",je=new ArrayBuffer(0),$o=new Uint8Array(0),$r="EndOfContent",Qa="OCTET STRING",ec="BIT STRING";function xt(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):$o}get valueHex(){return this.valueHexView.slice().buffer}set valueHex(n){this.valueHexView=new Uint8Array(n)}fromBER(n,s,o){let i=n instanceof ArrayBuffer?new Uint8Array(n):n;if(!wt(this,i,s,o))return-1;let a=s+o;return this.valueHexView=i.subarray(s,a),this.valueHexView.length?(this.blockLength=o,a):(this.warnings.push("Zero buffer length"),s)}toBER(n=!1){return this.isHexOnly?n?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.byteLength===this.valueHexView.buffer.byteLength?this.valueHexView.buffer:this.valueHexView.slice().buffer:(this.error="Flag 'isHexOnly' is not set, abort",je)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:M.Convert.ToHex(this.valueHexView)}}},e.NAME="hexBlock",e}var mt=class{constructor({blockLength:e=0,error:t=Br,warnings:n=[],valueBeforeDecode:s=$o}={}){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)}}};mt.NAME="baseBlock";var ve=class extends mt{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'")}};ve.NAME="valueBlock";var Ln=class extends xt(mt){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):$o,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",je}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=Ut(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(!wt(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),u=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===u){u+=255;let d=new Uint8Array(u);for(let b=0;b<f.length;b++)d[b]=f[b];f=this.valueHexView=new Uint8Array(u)}}this.blockLength=c+1,f[c-1]=o[c]&127;let l=new Uint8Array(c);for(let d=0;d<c;d++)l[d]=f[d];f=this.valueHexView=new Uint8Array(c),f.set(l),this.blockLength<=9?this.tagNumber=Xt(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}}};Ln.NAME="identificationBlock";var Un=class extends mt{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(!wt(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=Xt(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=Ut(this.length,8);if(s.byteLength>127)return this.error="Too big length",je;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}}};Un.NAME="lengthBlock";var I={},be=class extends mt{constructor({name:e=Br,optional:t=!1,primitiveSchema:n,...s}={},o){super(s),this.name=e,this.optional=t,n&&(this.primitiveSchema=n),this.idBlock=new Ln(s),this.lenBlock=new Un(s),this.valueBlock=o?new o(s):new ve(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 qr;t||tc(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?je: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 Za(t,n)}};be.NAME="BaseBlock";function tc(r){if(r instanceof I.Constructed)for(let e of r.valueBlock.value)tc(e)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var Pn=class extends be{constructor({value:e=Br,...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}'`}};Pn.NAME="BaseStringBlock";var On=class extends xt(ve){constructor({isHexOnly:e=!0,...t}={}){super(t),this.isHexOnly=e}};On.NAME="PrimitiveValueBlock";var rc,Vn=class extends be{constructor(e={}){super(e,On),this.idBlock.isConstructed=!1}};rc=Vn;I.Primitive=rc;Vn.NAME="PRIMITIVE";function $h(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 ms(r,e=0,t=r.length){let n=e,s=new be({},ve),o=new mt;if(!wt(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=be;switch(s.idBlock.tagClass){case 1:if(s.idBlock.tagNumber>=37&&s.idBlock.isHexOnly===!1)return s.error="UNIVERSAL 37 and upper tags are reserved by ASN.1 standard",{offset:-1,result:s};switch(s.idBlock.tagNumber){case 0:if(s.idBlock.isConstructed&&s.lenBlock.length>0)return s.error="Type [UNIVERSAL 0] is reserved",{offset:-1,result:s};c=I.EndOfContent;break;case 1:c=I.Boolean;break;case 2:c=I.Integer;break;case 3:c=I.BitString;break;case 4:c=I.OctetString;break;case 5:c=I.Null;break;case 6:c=I.ObjectIdentifier;break;case 10:c=I.Enumerated;break;case 12:c=I.Utf8String;break;case 13:c=I.RelativeObjectIdentifier;break;case 14:c=I.TIME;break;case 15:return s.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:s};case 16:c=I.Sequence;break;case 17:c=I.Set;break;case 18:c=I.NumericString;break;case 19:c=I.PrintableString;break;case 20:c=I.TeletexString;break;case 21:c=I.VideotexString;break;case 22:c=I.IA5String;break;case 23:c=I.UTCTime;break;case 24:c=I.GeneralizedTime;break;case 25:c=I.GraphicString;break;case 26:c=I.VisibleString;break;case 27:c=I.GeneralString;break;case 28:c=I.UniversalString;break;case 29:c=I.CharacterString;break;case 30:c=I.BmpString;break;case 31:c=I.DATE;break;case 32:c=I.TimeOfDay;break;case 33:c=I.DateTime;break;case 34:c=I.Duration;break;default:{let f=s.idBlock.isConstructed?new I.Constructed:new I.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?I.Constructed:I.Primitive}return s=$h(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 Ar(r){if(!r.byteLength){let e=new be({},ve);return e.error="Input buffer has zero length",{offset:-1,result:e}}return ms(M.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function Gh(r,e){return r?1:e}var et=class extends ve{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(!wt(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(;Gh(this.isIndefiniteForm,n)>0;){let i=ms(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===$r)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===$r?this.value.pop():this.warnings.push("No EndOfContent block encoded")),o}toBER(e,t){let n=t||new qr;for(let s=0;s<this.value.length;s++)this.value[s].toBER(e,n);return t?je:n.final()}toJSON(){let e={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let t of this.value)e.value.push(t.toJSON());return e}};et.NAME="ConstructedValueBlock";var nc,Pt=class extends be{constructor(e={}){super(e,et),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 Libp2PIdentify=(()=>{var nu=Object.create;var an=Object.defineProperty;var su=Object.getOwnPropertyDescriptor;var ou=Object.getOwnPropertyNames;var iu=Object.getPrototypeOf,au=Object.prototype.hasOwnProperty;var Oi=(r,e)=>()=>(e||r((e={exports:{}}).exports,e),e.exports),he=(r,e)=>{for(var t in e)an(r,t,{get:e[t],enumerable:!0})},Vi=(r,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of ou(e))!au.call(r,s)&&s!==t&&an(r,s,{get:()=>e[s],enumerable:!(n=su(e,s))||n.enumerable});return r};var Di=(r,e,t)=>(t=r!=null?nu(iu(r)):{},Vi(e||!r||!r.__esModule?an(t,"default",{value:r,enumerable:!0}):t,r)),cu=r=>Vi(an({},"__esModule",{value:!0}),r);var Za=Oi(vr=>{"use strict";var qh="[object ArrayBuffer]",mt=class r{static isArrayBuffer(e){return Object.prototype.toString.call(e)===qh}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}},jo="string",$h=/^[0-9a-f]+$/i,Gh=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,zh=/^[a-zA-Z0-9-_]+$/,Tn=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=mt.toUint8Array(e),n="";for(let o=0;o<t.length;o++)n+=String.fromCharCode(t[o]);return decodeURIComponent(escape(n))}},Ue=class{static toString(e,t=!1){let n=mt.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}},_n=class r{static isHex(e){return typeof e===jo&&$h.test(e)}static isBase64(e){return typeof e===jo&&Gh.test(e)}static isBase64Url(e){return typeof e===jo&&zh.test(e)}static ToString(e,t="utf8"){let n=mt.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 Ue.toString(n,!0);case"utf16":case"utf16be":return Ue.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 Ue.fromString(e,!0);case"utf16":case"utf16be":return Ue.fromString(e);default:throw new Error(`Unknown type of encoding '${t}'`)}}static ToBase64(e){let t=mt.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 Tn.fromString(e);case"utf16":case"utf16be":return Ue.fromString(e);case"utf16le":case"usc2":return Ue.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 Tn.toString(e);case"utf16":case"utf16be":return Ue.toString(e);case"utf16le":case"usc2":return Ue.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=mt.toUint8Array(e),n="";for(let s=0;s<t.length;s++)n+=String.fromCharCode(t[s]);return n}static ToHex(e){let t=mt.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 Ue.toString(e,t)}static FromUtf16String(e,t=!1){return Ue.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,"")||""}};_n.DEFAULT_UTF8_ENCODING="utf8";function jh(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 Wh(...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 Yh(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}vr.BufferSourceConverter=mt;vr.Convert=_n;vr.assign=jh;vr.combine=Wh;vr.isEqual=Yh});var Fl=Oi((Hw,Hl)=>{function t0(){return!!(typeof window<"u"&&typeof window.process=="object"&&window.process.type==="renderer"||typeof process<"u"&&typeof process.versions=="object"&&process.versions.electron||typeof navigator=="object"&&typeof navigator.userAgent=="string"&&navigator.userAgent.indexOf("Electron")>=0)}Hl.exports=t0});var o0={};he(o0,{identify:()=>s0,multicodecs:()=>n0});var Mi="/ipfs/id/1.0.0",Hi="/ipfs/id/push/1.0.0",Fi="0.1.0",Ki="id",qi="id/push",$i="1.0.0",Gi="1.0.0";var zi=Symbol.for("@libp2p/peer-id");var C=class extends Error{code;props;constructor(e,t,n){super(e),this.code=t,this.name=n?.name??"CodeError",this.props=n??{}}};var ji="ERR_NOT_FOUND";var cn=(r,...e)=>{try{[...e]}catch{}};var Fs={};he(Fs,{base58btc:()=>ne,base58flickr:()=>pu});var f0=new Uint8Array(0);function Wi(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 it(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 Yi(r){return new TextEncoder().encode(r)}function Zi(r){return new TextDecoder().decode(r)}function lu(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),u=Math.log(256)/Math.log(a);function l(p){if(p instanceof Uint8Array||(ArrayBuffer.isView(p)?p=new Uint8Array(p.buffer,p.byteOffset,p.byteLength):Array.isArray(p)&&(p=Uint8Array.from(p))),!(p instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(p.length===0)return"";for(var h=0,m=0,y=0,B=p.length;y!==B&&p[y]===0;)y++,h++;for(var w=(B-y)*u+1>>>0,T=new Uint8Array(w);y!==B;){for(var x=p[y],A=0,N=w-1;(x!==0||A<m)&&N!==-1;N--,A++)x+=256*T[N]>>>0,T[N]=x%a>>>0,x=x/a>>>0;if(x!==0)throw new Error("Non-zero carry");m=A,y++}for(var R=w-m;R!==w&&T[R]===0;)R++;for(var G=c.repeat(h);R<w;++R)G+=r.charAt(T[R]);return G}function d(p){if(typeof p!="string")throw new TypeError("Expected String");if(p.length===0)return new Uint8Array;var h=0;if(p[h]!==" "){for(var m=0,y=0;p[h]===c;)m++,h++;for(var B=(p.length-h)*f+1>>>0,w=new Uint8Array(B);p[h];){var T=t[p.charCodeAt(h)];if(T===255)return;for(var x=0,A=B-1;(T!==0||x<y)&&A!==-1;A--,x++)T+=a*w[A]>>>0,w[A]=T%256>>>0,T=T/256>>>0;if(T!==0)throw new Error("Non-zero carry");y=x,h++}if(p[h]!==" "){for(var N=B-y;N!==B&&w[N]===0;)N++;for(var R=new Uint8Array(m+(B-N)),G=m;N!==B;)R[G++]=w[N++];return R}}}function b(p){var h=d(p);if(h)return h;throw new Error(`Non-${e} character`)}return{encode:l,decodeUnsafe:d,decode:b}}var uu=lu,fu=uu,Xi=fu;var Vs=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 Qi(this,e)}},Ms=class{decoders;constructor(e){this.decoders=e}or(e){return Qi(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 Qi(r,e){return new Ms({...r.decoders??{[r.prefix]:r},...e.decoders??{[e.prefix]:e}})}var Hs=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 Vs(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 rr({name:r,prefix:e,encode:t,decode:n}){return new Hs(r,e,t,n)}function At({name:r,prefix:e,alphabet:t}){let{encode:n,decode:s}=Xi(t,r);return rr({prefix:e,name:r,encode:n,decode:o=>it(s(o))})}function hu(r,e,t,n){let s={};for(let u=0;u<e.length;++u)s[e[u]]=u;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 u=0;u<o;++u){let l=s[r[u]];if(l===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<t|l,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 du(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 ee({name:r,prefix:e,bitsPerChar:t,alphabet:n}){return rr({prefix:e,name:r,encode(s){return du(s,n,t)},decode(s){return hu(s,n,t,r)}})}var ne=At({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),pu=At({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Ks={};he(Ks,{base10:()=>gu});var gu=At({prefix:"9",name:"base10",alphabet:"0123456789"});var qs={};he(qs,{base16:()=>mu,base16upper:()=>yu});var mu=ee({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),yu=ee({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var $s={};he($s,{base2:()=>bu});var bu=ee({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Gs={};he(Gs,{base256emoji:()=>Bu});var ea=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}"),wu=ea.reduce((r,e,t)=>(r[t]=e,r),[]),xu=ea.reduce((r,e,t)=>(r[e.codePointAt(0)]=t,r),[]);function vu(r){return r.reduce((e,t)=>(e+=wu[t],e),"")}function Eu(r){let e=[];for(let t of r){let n=xu[t.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${t}`);e.push(n)}return new Uint8Array(e)}var Bu=rr({prefix:"\u{1F680}",name:"base256emoji",encode:vu,decode:Eu});var zs={};he(zs,{base32:()=>at,base32hex:()=>ku,base32hexpad:()=>Ru,base32hexpadupper:()=>Tu,base32hexupper:()=>Nu,base32pad:()=>Iu,base32padupper:()=>Su,base32upper:()=>Au,base32z:()=>_u});var at=ee({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),Au=ee({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Iu=ee({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),Su=ee({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),ku=ee({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),Nu=ee({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),Ru=ee({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),Tu=ee({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),_u=ee({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var js={};he(js,{base36:()=>Cu,base36upper:()=>Lu});var Cu=At({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),Lu=At({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Zs={};he(Zs,{base64:()=>Ws,base64pad:()=>Uu,base64url:()=>Ys,base64urlpad:()=>Pu});var Ws=ee({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),Uu=ee({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Ys=ee({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Pu=ee({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Js={};he(Js,{base8:()=>Ou});var Ou=ee({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Xs={};he(Xs,{identity:()=>Vu});var Vu=rr({prefix:"\0",name:"identity",encode:r=>Zi(r),decode:r=>Yi(r)});var k0=new TextEncoder,N0=new TextDecoder;var eo={};he(eo,{identity:()=>It});var Hu=na,ta=128,Fu=127,Ku=~Fu,qu=Math.pow(2,31);function na(r,e,t){e=e||[],t=t||0;for(var n=t;r>=qu;)e[t++]=r&255|ta,r/=128;for(;r&Ku;)e[t++]=r&255|ta,r>>>=7;return e[t]=r|0,na.bytes=t-n+1,e}var $u=Qs,Gu=128,ra=127;function Qs(r,n){var t=0,n=n||0,s=0,o=n,i,a=r.length;do{if(o>=a)throw Qs.bytes=0,new RangeError("Could not decode varint");i=r[o++],t+=s<28?(i&ra)<<s:(i&ra)*Math.pow(2,s),s+=7}while(i>=Gu);return Qs.bytes=o-n,t}var zu=Math.pow(2,7),ju=Math.pow(2,14),Wu=Math.pow(2,21),Yu=Math.pow(2,28),Zu=Math.pow(2,35),Ju=Math.pow(2,42),Xu=Math.pow(2,49),Qu=Math.pow(2,56),ef=Math.pow(2,63),tf=function(r){return r<zu?1:r<ju?2:r<Wu?3:r<Yu?4:r<Zu?5:r<Ju?6:r<Xu?7:r<Qu?8:r<ef?9:10},rf={encode:Hu,decode:$u,encodingLength:tf},nf=rf,Tr=nf;function _r(r,e=0){return[Tr.decode(r,e),Tr.decode.bytes]}function nr(r,e,t=0){return Tr.encode(r,e,t),e}function sr(r){return Tr.encodingLength(r)}function Ze(r,e){let t=e.byteLength,n=sr(r),s=n+sr(t),o=new Uint8Array(s+t);return nr(r,o,0),nr(t,o,n),o.set(e,s),new or(r,t,e,o)}function qt(r){let e=it(r),[t,n]=_r(e),[s,o]=_r(e.subarray(n)),i=e.subarray(n+o);if(i.byteLength!==s)throw new Error("Incorrect length");return new or(t,s,i,e)}function sa(r,e){if(r===e)return!0;{let t=e;return r.code===t.code&&r.size===t.size&&t.bytes instanceof Uint8Array&&Wi(r.bytes,t.bytes)}}var or=class{code;size;digest;bytes;constructor(e,t,n,s){this.code=e,this.size=t,this.digest=n,this.bytes=s}};var oa=0,sf="identity",ia=it;function of(r){return Ze(oa,ia(r))}var It={code:oa,name:sf,encode:ia,digest:of};var no={};he(no,{sha256:()=>ye,sha512:()=>af});function ro({name:r,code:e,encode:t}){return new to(r,e,t)}var to=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?Ze(this.code,t):t.then(n=>Ze(this.code,n))}else throw Error("Unknown type, must be binary type")}};function ca(r){return async e=>new Uint8Array(await crypto.subtle.digest(r,e))}var ye=ro({name:"sha2-256",code:18,encode:ca("SHA-256")}),af=ro({name:"sha2-512",code:19,encode:ca("SHA-512")});function la(r,e){let{bytes:t,version:n}=r;switch(n){case 0:return lf(t,so(r),e??ne.encoder);default:return uf(t,so(r),e??at.encoder)}}var ua=new WeakMap;function so(r){let e=ua.get(r);if(e==null){let t=new Map;return ua.set(r,t),t}return e}var De=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!==Cr)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(t.code!==ff)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=Ze(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&&sa(e.multihash,n.multihash)}toString(e){return la(this,e)}toJSON(){return{"/":la(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??fa(n,s,o.bytes))}else if(t[hf]===!0){let{version:n,multihash:s,code:o}=t,i=qt(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!==Cr)throw new Error(`Version 0 CID must use dag-pb (code: ${Cr}) block encoding`);return new r(e,t,n,n.bytes)}case 1:{let s=fa(e,t,n.bytes);return new r(e,t,n,s)}default:throw new Error("Invalid version")}}static createV0(e){return r.create(0,Cr,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=it(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 or(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[l,d]=_r(e.subarray(t));return t+=d,l},s=n(),o=Cr;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,u=f-i;return{version:s,codec:o,multihashCode:a,digestSize:c,multihashSize:u,size:f}}static parse(e,t){let[n,s]=cf(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 so(o).set(n,e),o}};function cf(r,e){switch(r[0]){case"Q":{let t=e??ne;return[ne.prefix,t.decode(`${ne.prefix}${r}`)]}case ne.prefix:{let t=e??ne;return[ne.prefix,t.decode(r)]}case at.prefix:{let t=e??at;return[at.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 lf(r,e,t){let{prefix:n}=t;if(n!==ne.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 uf(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 Cr=112,ff=18;function fa(r,e,t){let n=sr(r),s=n+sr(e),o=new Uint8Array(s+t.byteLength);return nr(r,o,0),nr(e,o,n),o.set(t,s),o}var hf=Symbol.for("@ipld/js-cid/CID");var St={...Xs,...$s,...Js,...Ks,...qs,...zs,...js,...Fs,...Zs,...Gs},Y0={...no,...eo};function de(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}var df=Symbol.for("nodejs.util.inspect.custom"),ha=Object.values(St).map(r=>r.decoder).reduce((r,e)=>r.or(e),St.identity.decoder),da=114,oo=36,io=37,Lr=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()})`}[zi]=!0;toString(){return this.string==null&&(this.string=ne.encode(this.multihash.bytes).slice(1)),this.string}toCID(){return De.createV1(da,this.multihash)}toBytes(){return this.multihash.bytes}toJSON(){return this.toString()}equals(e){if(e==null)return!1;if(e instanceof Uint8Array)return de(this.multihash.bytes,e);if(typeof e=="string")return pf(e).equals(this);if(e?.multihash?.bytes!=null)return de(this.multihash.bytes,e.multihash.bytes);throw new Error("not valid Id")}[df](){return`PeerId(${this.toString()})`}},ir=class extends Lr{type="RSA";publicKey;constructor(e){super({...e,type:"RSA"}),this.publicKey=e.publicKey}},ar=class extends Lr{type="Ed25519";publicKey;constructor(e){super({...e,type:"Ed25519"}),this.publicKey=e.multihash.digest}},cr=class extends Lr{type="secp256k1";publicKey;constructor(e){super({...e,type:"secp256k1"}),this.publicKey=e.multihash.digest}};function pf(r,e){if(e=e??ha,r.charAt(0)==="1"||r.charAt(0)==="Q"){let t=qt(ne.decode(`z${r}`));return r.startsWith("12D")?new ar({multihash:t}):r.startsWith("16U")?new cr({multihash:t}):new ir({multihash:t})}return ao(ha.decode(r))}function ao(r){try{let e=qt(r);if(e.code===It.code){if(e.digest.length===oo)return new ar({multihash:e});if(e.digest.length===io)return new cr({multihash:e})}if(e.code===ye.code)return new ir({multihash:e})}catch{return gf(De.decode(r))}throw new Error("Supplied PeerID CID is invalid")}function gf(r){if(r==null||r.multihash==null||r.version==null||r.version===1&&r.code!==da)throw new Error("Supplied PeerID CID is invalid");let e=r.multihash;if(e.code===ye.code)return new ir({multihash:r.multihash});if(e.code===It.code){if(e.digest.length===oo)return new ar({multihash:r.multihash});if(e.digest.length===io)return new cr({multihash:r.multihash})}throw new Error("Supplied PeerID CID is invalid")}async function Ur(r,e){return r.length===oo?new ar({multihash:Ze(It.code,r),privateKey:e}):r.length===io?new cr({multihash:Ze(It.code,r),privateKey:e}):new ir({multihash:await ye.digest(r),publicKey:r,privateKey:e})}var Go={};he(Go,{Ed25519PrivateKey:()=>Zt,Ed25519PublicKey:()=>Mr,generateKeyPair:()=>Hh,generateKeyPairFromSeed:()=>Ya,unmarshalEd25519PrivateKey:()=>Dh,unmarshalEd25519PublicKey:()=>Mh});function kt(r){return globalThis.Buffer!=null?new Uint8Array(r.buffer,r.byteOffset,r.byteLength):r}function ct(r=0){return globalThis.Buffer?.alloc!=null?kt(globalThis.Buffer.alloc(r)):new Uint8Array(r)}function ke(r=0){return globalThis.Buffer?.allocUnsafe!=null?kt(globalThis.Buffer.allocUnsafe(r)):new Uint8Array(r)}function Ae(r,e){if(globalThis.Buffer!=null)return kt(globalThis.Buffer.concat(r,e));e==null&&(e=r.reduce((s,o)=>s+o.length,0));let t=ke(e),n=0;for(let s of r)t.set(s,n),n+=s.length;return kt(t)}function ga(r,e,t,n){return{name:r,prefix:e,encoder:{name:r,prefix:e,encode:t},decoder:{decode:n}}}var pa=ga("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),co=ga("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=ke(r.length);for(let t=0;t<r.length;t++)e[t]=r.charCodeAt(t);return e}),mf={utf8:pa,"utf-8":pa,hex:St.base16,latin1:co,ascii:co,binary:co,...St},un=mf;function F(r,e="utf8"){let t=un[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return(e==="utf8"||e==="utf-8")&&globalThis.Buffer!=null&&globalThis.Buffer.from!=null?kt(globalThis.Buffer.from(r,"utf-8")):t.decoder.decode(`${t.prefix}${r}`)}function Ce(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function lr(r){if(!Number.isSafeInteger(r)||r<0)throw new Error(`Wrong positive integer: ${r}`)}function yf(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function lo(r,...e){if(!yf(r))throw new Error("Expected Uint8Array");if(e.length>0&&!e.includes(r.length))throw new Error(`Expected Uint8Array of length ${e}, not of length=${r.length}`)}function fn(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");lr(r.outputLen),lr(r.blockLen)}function ur(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 ma(r,e){lo(r);let t=e.outputLen;if(r.length<t)throw new Error(`digestInto() expects output buffer of length at least ${t}`)}var hn=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;function ya(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}var hr=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),Me=(r,e)=>r<<32-e|r>>>e,bf=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;if(!bf)throw new Error("Non little-endian hardware is not supported");var wf=async()=>{};async function ba(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 wf(),n+=o)}}function uo(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function Nt(r){if(typeof r=="string"&&(r=uo(r)),!ya(r))throw new Error(`expected Uint8Array, got ${typeof r}`);return r}function dn(...r){let e=0;for(let n=0;n<r.length;n++){let s=r[n];if(!ya(s))throw new Error("Uint8Array expected");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 fr=class{clone(){return this._cloneInto()}},xf={}.toString;function wa(r,e){if(e!==void 0&&xf.call(e)!=="[object Object]")throw new Error("Options should be object or undefined");return Object.assign(r,e)}function pn(r){let e=n=>r().update(Nt(n)).digest(),t=r();return e.outputLen=t.outputLen,e.blockLen=t.blockLen,e.create=()=>r(),e}function dr(r=32){if(hn&&typeof hn.getRandomValues=="function")return hn.getRandomValues(new Uint8Array(r));throw new Error("crypto.getRandomValues must be defined")}function vf(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 pr=class extends fr{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=hr(this.buffer)}update(e){ur(this);let{view:t,buffer:n,blockLen:s}=this;e=Nt(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=hr(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){ur(this),ma(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 l=i;l<s;l++)t[l]=0;vf(n,s-8,BigInt(this.length*8),o),this.process(n,0);let a=hr(e),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let f=c/4,u=this.get();if(f>u.length)throw new Error("_sha2: outputLen bigger than state");for(let l=0;l<f;l++)a.setUint32(4*l,u[l],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 gn=BigInt(4294967295),fo=BigInt(32);function xa(r,e=!1){return e?{h:Number(r&gn),l:Number(r>>fo&gn)}:{h:Number(r>>fo&gn)|0,l:Number(r&gn)|0}}function Ef(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}=xa(r[s],e);[t[s],n[s]]=[o,i]}return[t,n]}var Bf=(r,e)=>BigInt(r>>>0)<<fo|BigInt(e>>>0),Af=(r,e,t)=>r>>>t,If=(r,e,t)=>r<<32-t|e>>>t,Sf=(r,e,t)=>r>>>t|e<<32-t,kf=(r,e,t)=>r<<32-t|e>>>t,Nf=(r,e,t)=>r<<64-t|e>>>t-32,Rf=(r,e,t)=>r>>>t-32|e<<64-t,Tf=(r,e)=>e,_f=(r,e)=>r,Cf=(r,e,t)=>r<<t|e>>>32-t,Lf=(r,e,t)=>e<<t|r>>>32-t,Uf=(r,e,t)=>e<<t-32|r>>>64-t,Pf=(r,e,t)=>r<<t-32|e>>>64-t;function Of(r,e,t,n){let s=(e>>>0)+(n>>>0);return{h:r+t+(s/2**32|0)|0,l:s|0}}var Vf=(r,e,t)=>(r>>>0)+(e>>>0)+(t>>>0),Df=(r,e,t,n)=>e+t+n+(r/2**32|0)|0,Mf=(r,e,t,n)=>(r>>>0)+(e>>>0)+(t>>>0)+(n>>>0),Hf=(r,e,t,n,s)=>e+t+n+s+(r/2**32|0)|0,Ff=(r,e,t,n,s)=>(r>>>0)+(e>>>0)+(t>>>0)+(n>>>0)+(s>>>0),Kf=(r,e,t,n,s,o)=>e+t+n+s+o+(r/2**32|0)|0;var qf={fromBig:xa,split:Ef,toBig:Bf,shrSH:Af,shrSL:If,rotrSH:Sf,rotrSL:kf,rotrBH:Nf,rotrBL:Rf,rotr32H:Tf,rotr32L:_f,rotlSH:Cf,rotlSL:Lf,rotlBH:Uf,rotlBL:Pf,add:Of,add3L:Vf,add3H:Df,add4L:Mf,add4H:Hf,add5H:Kf,add5L:Ff},U=qf;var[$f,Gf]=U.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))),Rt=new Uint32Array(80),Tt=new Uint32Array(80),ho=class extends pr{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:u,Fh:l,Fl:d,Gh:b,Gl:p,Hh:h,Hl:m}=this;return[e,t,n,s,o,i,a,c,f,u,l,d,b,p,h,m]}set(e,t,n,s,o,i,a,c,f,u,l,d,b,p,h,m){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=u|0,this.Fh=l|0,this.Fl=d|0,this.Gh=b|0,this.Gl=p|0,this.Hh=h|0,this.Hl=m|0}process(e,t){for(let w=0;w<16;w++,t+=4)Rt[w]=e.getUint32(t),Tt[w]=e.getUint32(t+=4);for(let w=16;w<80;w++){let T=Rt[w-15]|0,x=Tt[w-15]|0,A=U.rotrSH(T,x,1)^U.rotrSH(T,x,8)^U.shrSH(T,x,7),N=U.rotrSL(T,x,1)^U.rotrSL(T,x,8)^U.shrSL(T,x,7),R=Rt[w-2]|0,G=Tt[w-2]|0,q=U.rotrSH(R,G,19)^U.rotrBH(R,G,61)^U.shrSH(R,G,6),P=U.rotrSL(R,G,19)^U.rotrBL(R,G,61)^U.shrSL(R,G,6),ie=U.add4L(N,P,Tt[w-7],Tt[w-16]),re=U.add4H(ie,A,q,Rt[w-7],Rt[w-16]);Rt[w]=re|0,Tt[w]=ie|0}let{Ah:n,Al:s,Bh:o,Bl:i,Ch:a,Cl:c,Dh:f,Dl:u,Eh:l,El:d,Fh:b,Fl:p,Gh:h,Gl:m,Hh:y,Hl:B}=this;for(let w=0;w<80;w++){let T=U.rotrSH(l,d,14)^U.rotrSH(l,d,18)^U.rotrBH(l,d,41),x=U.rotrSL(l,d,14)^U.rotrSL(l,d,18)^U.rotrBL(l,d,41),A=l&b^~l&h,N=d&p^~d&m,R=U.add5L(B,x,N,Gf[w],Tt[w]),G=U.add5H(R,y,T,A,$f[w],Rt[w]),q=R|0,P=U.rotrSH(n,s,28)^U.rotrBH(n,s,34)^U.rotrBH(n,s,39),ie=U.rotrSL(n,s,28)^U.rotrBL(n,s,34)^U.rotrBL(n,s,39),re=n&o^n&a^o&a,_e=s&i^s&c^i&c;y=h|0,B=m|0,h=b|0,m=p|0,b=l|0,p=d|0,{h:l,l:d}=U.add(f|0,u|0,G|0,q|0),f=a|0,u=c|0,a=o|0,c=i|0,o=n|0,i=s|0;let v=U.add3L(q,ie,_e);n=U.add3H(v,G,P,re),s=v|0}({h:n,l:s}=U.add(this.Ah|0,this.Al|0,n|0,s|0)),{h:o,l:i}=U.add(this.Bh|0,this.Bl|0,o|0,i|0),{h:a,l:c}=U.add(this.Ch|0,this.Cl|0,a|0,c|0),{h:f,l:u}=U.add(this.Dh|0,this.Dl|0,f|0,u|0),{h:l,l:d}=U.add(this.Eh|0,this.El|0,l|0,d|0),{h:b,l:p}=U.add(this.Fh|0,this.Fl|0,b|0,p|0),{h,l:m}=U.add(this.Gh|0,this.Gl|0,h|0,m|0),{h:y,l:B}=U.add(this.Hh|0,this.Hl|0,y|0,B|0),this.set(n,s,o,i,a,c,f,u,l,d,b,p,h,m,y,B)}roundClean(){Rt.fill(0),Tt.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 gr=pn(()=>new ho);var yn={};he(yn,{bitGet:()=>Xf,bitLen:()=>Jf,bitMask:()=>Pr,bitSet:()=>Qf,bytesToHex:()=>ut,bytesToNumberBE:()=>ft,bytesToNumberLE:()=>_t,concatBytes:()=>ht,createHmacDrbg:()=>mo,ensureBytes:()=>te,equalBytes:()=>Yf,hexToBytes:()=>Gt,hexToNumber:()=>go,isBytes:()=>He,numberToBytesBE:()=>Ct,numberToBytesLE:()=>zt,numberToHexUnpadded:()=>Aa,numberToVarBytesBE:()=>Wf,utf8ToBytes:()=>Zf,validateObject:()=>Je});var Ba=BigInt(0),mn=BigInt(1),zf=BigInt(2);function He(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}var jf=Array.from({length:256},(r,e)=>e.toString(16).padStart(2,"0"));function ut(r){if(!He(r))throw new Error("Uint8Array expected");let e="";for(let t=0;t<r.length;t++)e+=jf[r[t]];return e}function Aa(r){let e=r.toString(16);return e.length&1?`0${e}`:e}function go(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return BigInt(r===""?"0":`0x${r}`)}var lt={_0:48,_9:57,_A:65,_F:70,_a:97,_f:102};function va(r){if(r>=lt._0&&r<=lt._9)return r-lt._0;if(r>=lt._A&&r<=lt._F)return r-(lt._A-10);if(r>=lt._a&&r<=lt._f)return r-(lt._a-10)}function Gt(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=va(r.charCodeAt(o)),a=va(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 go(ut(r))}function _t(r){if(!He(r))throw new Error("Uint8Array expected");return go(ut(Uint8Array.from(r).reverse()))}function Ct(r,e){return Gt(r.toString(16).padStart(e*2,"0"))}function zt(r,e){return Ct(r,e).reverse()}function Wf(r){return Gt(Aa(r))}function te(r,e,t){let n;if(typeof e=="string")try{n=Gt(e)}catch(o){throw new Error(`${r} must be valid hex string, got "${e}". Cause: ${o}`)}else if(He(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 ht(...r){let e=0;for(let s=0;s<r.length;s++){let o=r[s];if(!He(o))throw new Error("Uint8Array expected");e+=o.length}let t=new Uint8Array(e),n=0;for(let s=0;s<r.length;s++){let o=r[s];t.set(o,n),n+=o.length}return t}function Yf(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 Zf(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function Jf(r){let e;for(e=0;r>Ba;r>>=mn,e+=1);return e}function Xf(r,e){return r>>BigInt(e)&mn}var Qf=(r,e,t)=>r|(t?mn:Ba)<<BigInt(e),Pr=r=>(zf<<BigInt(r-1))-mn,po=r=>new Uint8Array(r),Ea=r=>Uint8Array.from(r);function mo(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=po(r),s=po(r),o=0,i=()=>{n.fill(1),s.fill(0),o=0},a=(...l)=>t(s,n,...l),c=(l=po())=>{s=a(Ea([0]),l),n=a(),l.length!==0&&(s=a(Ea([1]),l),n=a())},f=()=>{if(o++>=1e3)throw new Error("drbg: tried 1000 values");let l=0,d=[];for(;l<e;){n=a();let b=n.slice();d.push(b),l+=n.length}return ht(...d)};return(l,d)=>{i(),c(l);let b;for(;!(b=d(f()));)c();return i(),b}}var eh={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"||He(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 Je(r,e,t={}){let n=(s,o,i)=>{let a=eh[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 ue=BigInt(0),Z=BigInt(1),jt=BigInt(2),th=BigInt(3),yo=BigInt(4),Ia=BigInt(5),Sa=BigInt(8),rh=BigInt(9),nh=BigInt(16);function Y(r,e){let t=r%e;return t>=ue?t:e+t}function sh(r,e,t){if(t<=ue||e<ue)throw new Error("Expected power/modulo > 0");if(t===Z)return ue;let n=Z;for(;e>ue;)e&Z&&(n=n*r%t),r=r*r%t,e>>=Z;return n}function J(r,e,t){let n=r;for(;e-- >ue;)n*=n,n%=t;return n}function bn(r,e){if(r===ue||e<=ue)throw new Error(`invert: expected positive integers, got n=${r} mod=${e}`);let t=Y(r,e),n=e,s=ue,o=Z,i=Z,a=ue;for(;t!==ue;){let f=n/t,u=n%t,l=s-i*f,d=o-a*f;n=t,t=u,s=i,o=a,i=l,a=d}if(n!==Z)throw new Error("invert: does not exist");return Y(s,e)}function oh(r){let e=(r-Z)/jt,t,n,s;for(t=r-Z,n=0;t%jt===ue;t/=jt,n++);for(s=jt;s<r&&sh(s,e,r)!==r-Z;s++);if(n===1){let i=(r+Z)/yo;return function(c,f){let u=c.pow(f,i);if(!c.eql(c.sqr(u),f))throw new Error("Cannot find square root");return u}}let o=(t+Z)/jt;return function(a,c){if(a.pow(c,e)===a.neg(a.ONE))throw new Error("Cannot find square root");let f=n,u=a.pow(a.mul(a.ONE,s),t),l=a.pow(c,o),d=a.pow(c,t);for(;!a.eql(d,a.ONE);){if(a.eql(d,a.ZERO))return a.ZERO;let b=1;for(let h=a.sqr(d);b<f&&!a.eql(h,a.ONE);b++)h=a.sqr(h);let p=a.pow(u,Z<<BigInt(f-b-1));u=a.sqr(p),l=a.mul(l,p),d=a.mul(d,u),f=b}return l}}function ih(r){if(r%yo===th){let e=(r+Z)/yo;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%Sa===Ia){let e=(r-Ia)/Sa;return function(n,s){let o=n.mul(s,jt),i=n.pow(o,e),a=n.mul(s,i),c=n.mul(n.mul(a,jt),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%nh,oh(r)}var ka=(r,e)=>(Y(r,e)&Z)===Z,ah=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function bo(r){let e={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},t=ah.reduce((n,s)=>(n[s]="function",n),e);return Je(r,t)}function ch(r,e,t){if(t<ue)throw new Error("Expected power > 0");if(t===ue)return r.ONE;if(t===Z)return e;let n=r.ONE,s=e;for(;t>ue;)t&Z&&(n=r.mul(n,s)),s=r.sqr(s),t>>=Z;return n}function lh(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 wo(r,e){let t=e!==void 0?e:r.toString(2).length,n=Math.ceil(t/8);return{nBitLength:t,nByteLength:n}}function wn(r,e,t=!1,n={}){if(r<=ue)throw new Error(`Expected Field ORDER > 0, got ${r}`);let{nBitLength:s,nByteLength:o}=wo(r,e);if(o>2048)throw new Error("Field lengths over 2048 bytes are not supported");let i=ih(r),a=Object.freeze({ORDER:r,BITS:s,BYTES:o,MASK:Pr(s),ZERO:ue,ONE:Z,create:c=>Y(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error(`Invalid field element: expected bigint, got ${typeof c}`);return ue<=c&&c<r},is0:c=>c===ue,isOdd:c=>(c&Z)===Z,neg:c=>Y(-c,r),eql:(c,f)=>c===f,sqr:c=>Y(c*c,r),add:(c,f)=>Y(c+f,r),sub:(c,f)=>Y(c-f,r),mul:(c,f)=>Y(c*f,r),pow:(c,f)=>ch(a,c,f),div:(c,f)=>Y(c*bn(f,r),r),sqrN:c=>c*c,addN:(c,f)=>c+f,subN:(c,f)=>c-f,mulN:(c,f)=>c*f,inv:c=>bn(c,r),sqrt:n.sqrt||(c=>i(a,c)),invertBatch:c=>lh(a,c),cmov:(c,f,u)=>u?f:c,toBytes:c=>t?zt(c,o):Ct(c,o),fromBytes:c=>{if(c.length!==o)throw new Error(`Fp.fromBytes: expected ${o}, got ${c.length}`);return t?_t(c):ft(c)}});return Object.freeze(a)}function Na(r,e){if(!r.isOdd)throw new Error("Field doesn't have isOdd");let t=r.sqrt(e);return r.isOdd(t)?r.neg(t):t}function Ra(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 xo(r){let e=Ra(r);return e+Math.ceil(e/2)}function Ta(r,e,t=!1){let n=r.length,s=Ra(e),o=xo(e);if(n<16||n<o||n>1024)throw new Error(`expected ${o}-1024 bytes of input, got ${n}`);let i=t?ft(r):_t(r),a=Y(i,e-Z)+Z;return t?zt(a,s):Ct(a,s)}var fh=BigInt(0),vo=BigInt(1);function xn(r,e){let t=(s,o)=>{let i=o.negate();return s?i:o},n=s=>{let o=Math.ceil(e/s)+1,i=2**(s-1);return{windows:o,windowSize:i}};return{constTimeNegate:t,unsafeLadder(s,o){let i=r.ZERO,a=s;for(;o>fh;)o&vo&&(i=i.add(a)),a=a.double(),o>>=vo;return i},precomputeWindow(s,o){let{windows:i,windowSize:a}=n(o),c=[],f=s,u=f;for(let l=0;l<i;l++){u=f,c.push(u);for(let d=1;d<a;d++)u=u.add(f),c.push(u);f=u.double()}return c},wNAF(s,o,i){let{windows:a,windowSize:c}=n(s),f=r.ZERO,u=r.BASE,l=BigInt(2**s-1),d=2**s,b=BigInt(s);for(let p=0;p<a;p++){let h=p*c,m=Number(i&l);i>>=b,m>c&&(m-=d,i+=vo);let y=h,B=h+Math.abs(m)-1,w=p%2!==0,T=m<0;m===0?u=u.add(t(w,o[y])):f=f.add(t(T,o[B]))}return{p:f,f:u}},wNAFCached(s,o,i,a){let c=s._WINDOW_SIZE||1,f=o.get(s);return f||(f=this.precomputeWindow(s,c),c!==1&&o.set(s,a(f))),this.wNAF(c,f,i)}}}function Or(r){return bo(r.Fp),Je(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...wo(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Fe=BigInt(0),Re=BigInt(1),vn=BigInt(2),hh=BigInt(8),dh={zip215:!0};function ph(r){let e=Or(r);return Je(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...e})}function En(r){let e=ph(r),{Fp:t,n,prehash:s,hash:o,randomBytes:i,nByteLength:a,h:c}=e,f=vn<<BigInt(a*8)-Re,u=t.create,l=e.uvRatio||((E,g)=>{try{return{isValid:!0,value:t.sqrt(E*t.inv(g))}}catch{return{isValid:!1,value:Fe}}}),d=e.adjustScalarBytes||(E=>E),b=e.domain||((E,g,S)=>{if(g.length||S)throw new Error("Contexts/pre-hash are not supported");return E}),p=E=>typeof E=="bigint"&&Fe<E,h=(E,g)=>p(E)&&p(g)&&E<g,m=E=>E===Fe||h(E,f);function y(E,g){if(h(E,g))return E;throw new Error(`Expected valid scalar < ${g}, got ${typeof E} ${E}`)}function B(E){return E===Fe?E:y(E,n)}let w=new Map;function T(E){if(!(E instanceof x))throw new Error("ExtendedPoint expected")}class x{constructor(g,S,_,L){if(this.ex=g,this.ey=S,this.ez=_,this.et=L,!m(g))throw new Error("x required");if(!m(S))throw new Error("y required");if(!m(_))throw new Error("z required");if(!m(L))throw new Error("t required")}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(g){if(g instanceof x)throw new Error("extended point not allowed");let{x:S,y:_}=g||{};if(!m(S)||!m(_))throw new Error("invalid affine point");return new x(S,_,Re,u(S*_))}static normalizeZ(g){let S=t.invertBatch(g.map(_=>_.ez));return g.map((_,L)=>_.toAffine(S[L])).map(x.fromAffine)}_setWindowSize(g){this._WINDOW_SIZE=g,w.delete(this)}assertValidity(){let{a:g,d:S}=e;if(this.is0())throw new Error("bad point: ZERO");let{ex:_,ey:L,ez:V,et:D}=this,W=u(_*_),H=u(L*L),$=u(V*V),ae=u($*$),Q=u(W*g),ge=u($*u(Q+H)),me=u(ae+u(S*u(W*H)));if(ge!==me)throw new Error("bad point: equation left != right (1)");let le=u(_*L),we=u(V*D);if(le!==we)throw new Error("bad point: equation left != right (2)")}equals(g){T(g);let{ex:S,ey:_,ez:L}=this,{ex:V,ey:D,ez:W}=g,H=u(S*W),$=u(V*L),ae=u(_*W),Q=u(D*L);return H===$&&ae===Q}is0(){return this.equals(x.ZERO)}negate(){return new x(u(-this.ex),this.ey,this.ez,u(-this.et))}double(){let{a:g}=e,{ex:S,ey:_,ez:L}=this,V=u(S*S),D=u(_*_),W=u(vn*u(L*L)),H=u(g*V),$=S+_,ae=u(u($*$)-V-D),Q=H+D,ge=Q-W,me=H-D,le=u(ae*ge),we=u(Q*me),ot=u(ae*me),Kt=u(ge*Q);return new x(le,we,Kt,ot)}add(g){T(g);let{a:S,d:_}=e,{ex:L,ey:V,ez:D,et:W}=this,{ex:H,ey:$,ez:ae,et:Q}=g;if(S===BigInt(-1)){let Ri=u((V-L)*($+H)),Ti=u((V+L)*($-H)),Os=u(Ti-Ri);if(Os===Fe)return this.double();let _i=u(D*vn*Q),Ci=u(W*vn*ae),Li=Ci+_i,Ui=Ti+Ri,Pi=Ci-_i,Ql=u(Li*Os),eu=u(Ui*Pi),tu=u(Li*Pi),ru=u(Os*Ui);return new x(Ql,eu,ru,tu)}let ge=u(L*H),me=u(V*$),le=u(W*_*Q),we=u(D*ae),ot=u((L+V)*(H+$)-ge-me),Kt=we-le,Rr=we+le,Ni=u(me-S*ge),Yl=u(ot*Kt),Zl=u(Rr*Ni),Jl=u(ot*Ni),Xl=u(Kt*Rr);return new x(Yl,Zl,Xl,Jl)}subtract(g){return this.add(g.negate())}wNAF(g){return R.wNAFCached(this,w,g,x.normalizeZ)}multiply(g){let{p:S,f:_}=this.wNAF(y(g,n));return x.normalizeZ([S,_])[0]}multiplyUnsafe(g){let S=B(g);return S===Fe?N:this.equals(N)||S===Re?this:this.equals(A)?this.wNAF(S).p:R.unsafeLadder(this,S)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return R.unsafeLadder(this,n).is0()}toAffine(g){let{ex:S,ey:_,ez:L}=this,V=this.is0();g==null&&(g=V?hh:t.inv(L));let D=u(S*g),W=u(_*g),H=u(L*g);if(V)return{x:Fe,y:Re};if(H!==Re)throw new Error("invZ was invalid");return{x:D,y:W}}clearCofactor(){let{h:g}=e;return g===Re?this:this.multiplyUnsafe(g)}static fromHex(g,S=!1){let{d:_,a:L}=e,V=t.BYTES;g=te("pointHex",g,V);let D=g.slice(),W=g[V-1];D[V-1]=W&-129;let H=_t(D);H===Fe||(S?y(H,f):y(H,t.ORDER));let $=u(H*H),ae=u($-Re),Q=u(_*$-L),{isValid:ge,value:me}=l(ae,Q);if(!ge)throw new Error("Point.fromHex: invalid y coordinate");let le=(me&Re)===Re,we=(W&128)!==0;if(!S&&me===Fe&&we)throw new Error("Point.fromHex: x=0 and x_0=1");return we!==le&&(me=u(-me)),x.fromAffine({x:me,y:H})}static fromPrivateKey(g){return P(g).point}toRawBytes(){let{x:g,y:S}=this.toAffine(),_=zt(S,t.BYTES);return _[_.length-1]|=g&Re?128:0,_}toHex(){return ut(this.toRawBytes())}}x.BASE=new x(e.Gx,e.Gy,Re,u(e.Gx*e.Gy)),x.ZERO=new x(Fe,Re,Re,Fe);let{BASE:A,ZERO:N}=x,R=xn(x,a*8);function G(E){return Y(E,n)}function q(E){return G(_t(E))}function P(E){let g=a;E=te("private key",E,g);let S=te("hashed private key",o(E),2*g),_=d(S.slice(0,g)),L=S.slice(g,2*g),V=q(_),D=A.multiply(V),W=D.toRawBytes();return{head:_,prefix:L,scalar:V,point:D,pointBytes:W}}function ie(E){return P(E).pointBytes}function re(E=new Uint8Array,...g){let S=ht(...g);return q(o(b(S,te("context",E),!!s)))}function _e(E,g,S={}){E=te("message",E),s&&(E=s(E));let{prefix:_,scalar:L,pointBytes:V}=P(g),D=re(S.context,_,E),W=A.multiply(D).toRawBytes(),H=re(S.context,W,V,E),$=G(D+H*L);B($);let ae=ht(W,zt($,t.BYTES));return te("result",ae,a*2)}let v=dh;function k(E,g,S,_=v){let{context:L,zip215:V}=_,D=t.BYTES;E=te("signature",E,2*D),g=te("message",g),s&&(g=s(g));let W=_t(E.slice(D,2*D)),H,$,ae;try{H=x.fromHex(S,V),$=x.fromHex(E.slice(0,D),V),ae=A.multiplyUnsafe(W)}catch{return!1}if(!V&&H.isSmallOrder())return!1;let Q=re(L,$.toRawBytes(),H.toRawBytes(),g);return $.add(H.multiplyUnsafe(Q)).subtract(ae).clearCofactor().equals(x.ZERO)}return A._setWindowSize(8),{CURVE:e,getPublicKey:ie,sign:_e,verify:k,ExtendedPoint:x,utils:{getExtendedPublicKey:P,randomPrivateKey:()=>i(t.BYTES),precompute(E=8,g=x.BASE){return g._setWindowSize(E),g.multiply(BigInt(3)),g}}}}var Bo=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),_a=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),Gp=BigInt(0),gh=BigInt(1),Eo=BigInt(2),mh=BigInt(5),Ca=BigInt(10),yh=BigInt(20),bh=BigInt(40),La=BigInt(80);function wh(r){let e=Bo,n=r*r%e*r%e,s=J(n,Eo,e)*n%e,o=J(s,gh,e)*r%e,i=J(o,mh,e)*o%e,a=J(i,Ca,e)*i%e,c=J(a,yh,e)*a%e,f=J(c,bh,e)*c%e,u=J(f,La,e)*f%e,l=J(u,La,e)*f%e,d=J(l,Ca,e)*i%e;return{pow_p_5_8:J(d,Eo,e)*r%e,b2:n}}function xh(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function vh(r,e){let t=Bo,n=Y(e*e*e,t),s=Y(n*n*e,t),o=wh(r*s).pow_p_5_8,i=Y(r*n*o,t),a=Y(e*i*i,t),c=i,f=Y(i*_a,t),u=a===r,l=a===Y(-r,t),d=a===Y(-r*_a,t);return u&&(i=c),(l||d)&&(i=f),ka(i,t)&&(i=Y(-i,t)),{isValid:u||l,value:i}}var dt=wn(Bo,void 0,!0),Ao={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:dt,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:BigInt(8),Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:gr,randomBytes:dr,adjustScalarBytes:xh,uvRatio:vh},mr=En(Ao);function Ua(r,e,t){if(e.length>255)throw new Error("Context is too big");return dn(uo("SigEd25519 no Ed25519 collisions"),new Uint8Array([t?1:0,e.length]),e,r)}var zp=En({...Ao,domain:Ua}),jp=En({...Ao,domain:Ua,prehash:gr});var Eh=(dt.ORDER+BigInt(3))/BigInt(8),Wp=dt.pow(Eo,Eh),Yp=dt.sqrt(dt.neg(dt.ONE)),Zp=(dt.ORDER-BigInt(5))/BigInt(8),Jp=BigInt(486662);var Xp=Na(dt,dt.neg(BigInt(486664)));var Qp=BigInt("25063068953384623474111414158702152701244531502492656460079210482610430750235"),eg=BigInt("54469307008909316920995813868745141605393597292927456921205312896311721017578"),tg=BigInt("1159843021668779879193775521855586647937357759715417654439879720876111806838"),rg=BigInt("40440834346308536858101042469323190826248399146238708352240133220865137265952");var ng=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff");var yr=32,pt=64,Bn=32;function Pa(){let r=mr.utils.randomPrivateKey(),e=mr.getPublicKey(r);return{privateKey:Ma(r,e),publicKey:e}}function Oa(r){if(r.length!==Bn)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=mr.getPublicKey(e);return{privateKey:Ma(e,t),publicKey:t}}function Va(r,e){let t=r.subarray(0,Bn);return mr.sign(e instanceof Uint8Array?e:e.subarray(),t)}function Da(r,e,t){return mr.verify(e,t instanceof Uint8Array?t:t.subarray(),r)}function Ma(r,e){let t=new Uint8Array(pt);for(let n=0;n<Bn;n++)t[n]=r[n],t[Bn+n]=e[n];return t}var Ie={get(r=globalThis){let e=r.crypto;if(e==null||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 Io={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function Ha(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=Ie.get();t*=8;async function c(l,d){let b=a.getRandomValues(new Uint8Array(o)),p=a.getRandomValues(new Uint8Array(n)),h={name:e,iv:p};typeof d=="string"&&(d=F(d));let m;if(d.length===0){m=await a.subtle.importKey("jwk",Io,{name:"AES-GCM"},!0,["encrypt"]);try{let B={name:"PBKDF2",salt:b,iterations:i,hash:{name:s}},w=await a.subtle.importKey("raw",d,{name:"PBKDF2"},!1,["deriveKey"]);m=await a.subtle.deriveKey(B,w,{name:e,length:t},!0,["encrypt"])}catch{m=await a.subtle.importKey("jwk",Io,{name:"AES-GCM"},!0,["encrypt"])}}else{let B={name:"PBKDF2",salt:b,iterations:i,hash:{name:s}},w=await a.subtle.importKey("raw",d,{name:"PBKDF2"},!1,["deriveKey"]);m=await a.subtle.deriveKey(B,w,{name:e,length:t},!0,["encrypt"])}let y=await a.subtle.encrypt(h,m,l);return Ae([b,h.iv,new Uint8Array(y)])}async function f(l,d){let b=l.subarray(0,o),p=l.subarray(o,o+n),h=l.subarray(o+n),m={name:e,iv:p};typeof d=="string"&&(d=F(d));let y;if(d.length===0)try{let w={name:"PBKDF2",salt:b,iterations:i,hash:{name:s}},T=await a.subtle.importKey("raw",d,{name:"PBKDF2"},!1,["deriveKey"]);y=await a.subtle.deriveKey(w,T,{name:e,length:t},!0,["decrypt"])}catch{y=await a.subtle.importKey("jwk",Io,{name:"AES-GCM"},!0,["decrypt"])}else{let w={name:"PBKDF2",salt:b,iterations:i,hash:{name:s}},T=await a.subtle.importKey("raw",d,{name:"PBKDF2"},!1,["deriveKey"]);y=await a.subtle.deriveKey(w,T,{name:e,length:t},!0,["decrypt"])}let B=await a.subtle.decrypt(m,y,h);return new Uint8Array(B)}return{encrypt:c,decrypt:f}}async function br(r,e){let n=await Ha().encrypt(r,e);return Ws.encode(n)}var Ih=Math.pow(2,7),Sh=Math.pow(2,14),kh=Math.pow(2,21),So=Math.pow(2,28),ko=Math.pow(2,35),No=Math.pow(2,42),Ro=Math.pow(2,49),z=128,xe=127;function ve(r){if(r<Ih)return 1;if(r<Sh)return 2;if(r<kh)return 3;if(r<So)return 4;if(r<ko)return 5;if(r<No)return 6;if(r<Ro)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(ve(r)){case 8:e[t++]=r&255|z,r/=128;case 7:e[t++]=r&255|z,r/=128;case 6:e[t++]=r&255|z,r/=128;case 5:e[t++]=r&255|z,r/=128;case 4:e[t++]=r&255|z,r>>>=7;case 3:e[t++]=r&255|z,r>>>=7;case 2:e[t++]=r&255|z,r>>>=7;case 1:{e[t++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return e}function Nh(r,e,t=0){switch(ve(r)){case 8:e.set(t++,r&255|z),r/=128;case 7:e.set(t++,r&255|z),r/=128;case 6:e.set(t++,r&255|z),r/=128;case 5:e.set(t++,r&255|z),r/=128;case 4:e.set(t++,r&255|z),r>>>=7;case 3:e.set(t++,r&255|z),r>>>=7;case 2:e.set(t++,r&255|z),r>>>=7;case 1:{e.set(t++,r&255),r>>>=7;break}default:throw new Error("unreachable")}return e}function _o(r,e){let t=r[e],n=0;if(n+=t&xe,t<z||(t=r[e+1],n+=(t&xe)<<7,t<z)||(t=r[e+2],n+=(t&xe)<<14,t<z)||(t=r[e+3],n+=(t&xe)<<21,t<z)||(t=r[e+4],n+=(t&xe)*So,t<z)||(t=r[e+5],n+=(t&xe)*ko,t<z)||(t=r[e+6],n+=(t&xe)*No,t<z)||(t=r[e+7],n+=(t&xe)*Ro,t<z))return n;throw new RangeError("Could not decode varint")}function Rh(r,e){let t=r.get(e),n=0;if(n+=t&xe,t<z||(t=r.get(e+1),n+=(t&xe)<<7,t<z)||(t=r.get(e+2),n+=(t&xe)<<14,t<z)||(t=r.get(e+3),n+=(t&xe)<<21,t<z)||(t=r.get(e+4),n+=(t&xe)*So,t<z)||(t=r.get(e+5),n+=(t&xe)*ko,t<z)||(t=r.get(e+6),n+=(t&xe)*No,t<z)||(t=r.get(e+7),n+=(t&xe)*Ro,t<z))return n;throw new RangeError("Could not decode varint")}function Le(r,e,t=0){return e==null&&(e=ke(ve(r))),e instanceof Uint8Array?To(r,e,t):Nh(r,e,t)}function gt(r,e=0){return r instanceof Uint8Array?_o(r,e):Rh(r,e)}var Co=new Float32Array([-0]),Lt=new Uint8Array(Co.buffer);function Fa(r,e,t){Co[0]=r,e[t]=Lt[0],e[t+1]=Lt[1],e[t+2]=Lt[2],e[t+3]=Lt[3]}function Ka(r,e){return Lt[0]=r[e],Lt[1]=r[e+1],Lt[2]=r[e+2],Lt[3]=r[e+3],Co[0]}var Lo=new Float64Array([-0]),Ee=new Uint8Array(Lo.buffer);function qa(r,e,t){Lo[0]=r,e[t]=Ee[0],e[t+1]=Ee[1],e[t+2]=Ee[2],e[t+3]=Ee[3],e[t+4]=Ee[4],e[t+5]=Ee[5],e[t+6]=Ee[6],e[t+7]=Ee[7]}function $a(r,e){return Ee[0]=r[e],Ee[1]=r[e+1],Ee[2]=r[e+2],Ee[3]=r[e+3],Ee[4]=r[e+4],Ee[5]=r[e+5],Ee[6]=r[e+6],Ee[7]=r[e+7],Lo[0]}var Th=BigInt(Number.MAX_SAFE_INTEGER),_h=BigInt(Number.MIN_SAFE_INTEGER),Te=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 Wt;if(e<Th&&e>_h)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>Ga&&(s=0n,++n>Ga&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(e){if(e===0)return Wt;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):Wt}},Wt=new Te(0,0);Wt.toBigInt=function(){return 0n};Wt.zzEncode=Wt.zzDecode=function(){return this};Wt.length=function(){return 1};var Ga=4294967296n;function za(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 ja(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 Uo(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 Ke(r,e){return RangeError(`index out of range: ${r.pos} + ${e??1} > ${r.len}`)}function In(r,e){return(r[e-4]|r[e-3]<<8|r[e-2]<<16|r[e-1]<<24)>>>0}var Po=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,Ke(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 Ke(this,4);return In(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Ke(this,4);return In(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Ke(this,4);let e=Ka(this.buf,this.pos);return this.pos+=4,e}double(){if(this.pos+8>this.len)throw Ke(this,4);let e=$a(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 Ke(this,e);return this.pos+=e,t===n?new Uint8Array(0):this.buf.subarray(t,n)}string(){let e=this.bytes();return ja(e,0,e.length)}skip(e){if(typeof e=="number"){if(this.pos+e>this.len)throw Ke(this,e);this.pos+=e}else do if(this.pos>=this.len)throw Ke(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 Te(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 Ke(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 Ke(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 Ke(this,8);let e=In(this.buf,this.pos+=4),t=In(this.buf,this.pos+=4);return new Te(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=_o(this.buf,this.pos);return this.pos+=ve(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 Oo(r){return new Po(r instanceof Uint8Array?r:r.subarray())}function qe(r,e,t){let n=Oo(r);return e.decode(n,void 0,t)}function Vo(r){let e=r??8192,t=e>>>1,n,s=e;return function(i){if(i<1||i>t)return ke(i);s+i>e&&(n=ke(e),s=0);let a=n.subarray(s,s+=i);return s&7&&(s=(s|7)+1),a}}var Yt=class{fn;len;next;val;constructor(e,t,n){this.fn=e,this.len=t,this.next=void 0,this.val=n}};function Do(){}var Ho=class{head;tail;len;next;constructor(e){this.head=e.head,this.tail=e.tail,this.len=e.len,this.next=e.states}},Ch=Vo();function Lh(r){return globalThis.Buffer!=null?ke(r):Ch(r)}var Dr=class{len;head;tail;states;constructor(){this.len=0,this.head=new Yt(Do,0,0),this.tail=this.head,this.states=null}_push(e,t,n){return this.tail=this.tail.next=new Yt(e,t,n),this.len+=t,this}uint32(e){return this.len+=(this.tail=this.tail.next=new Fo((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(Sn,10,Te.fromNumber(e)):this.uint32(e)}sint32(e){return this.uint32((e<<1^e>>31)>>>0)}uint64(e){let t=Te.fromBigInt(e);return this._push(Sn,t.length(),t)}uint64Number(e){return this._push(To,ve(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=Te.fromBigInt(e).zzEncode();return this._push(Sn,t.length(),t)}sint64Number(e){let t=Te.fromNumber(e).zzEncode();return this._push(Sn,t.length(),t)}sint64String(e){return this.sint64(BigInt(e))}bool(e){return this._push(Mo,1,e?1:0)}fixed32(e){return this._push(Vr,4,e>>>0)}sfixed32(e){return this.fixed32(e)}fixed64(e){let t=Te.fromBigInt(e);return this._push(Vr,4,t.lo)._push(Vr,4,t.hi)}fixed64Number(e){let t=Te.fromNumber(e);return this._push(Vr,4,t.lo)._push(Vr,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(Fa,4,e)}double(e){return this._push(qa,8,e)}bytes(e){let t=e.length>>>0;return t===0?this._push(Mo,1,0):this.uint32(t)._push(Ph,t,e)}string(e){let t=za(e);return t!==0?this.uint32(t)._push(Uo,t,e):this._push(Mo,1,0)}fork(){return this.states=new Ho(this),this.head=this.tail=new Yt(Do,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 Yt(Do,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=Lh(this.len),n=0;for(;e!=null;)e.fn(e.val,t,n),n+=e.len,e=e.next;return t}};function Mo(r,e,t){e[t]=r&255}function Uh(r,e,t){for(;r>127;)e[t++]=r&127|128,r>>>=7;e[t]=r}var Fo=class extends Yt{next;constructor(e,t){super(Uh,e,t),this.next=void 0}};function Sn(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 Vr(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 Ph(r,e,t){e.set(r,t)}globalThis.Buffer!=null&&(Dr.prototype.bytes=function(r){let e=r.length>>>0;return this.uint32(e),e>0&&this._push(Oh,e,r),this},Dr.prototype.string=function(r){let e=globalThis.Buffer.byteLength(r);return this.uint32(e),e>0&&this._push(Vh,e,r),this});function Oh(r,e,t){e.set(r,t)}function Vh(r,e,t){r.length<40?Uo(r,e,t):e.utf8Write!=null?e.utf8Write(r,t):e.set(F(r),t)}function Ko(){return new Dr}function $e(r,e){let t=Ko();return e.encode(r,t,{lengthDelimited:!1}),t.finish()}var wr;(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"})(wr||(wr={}));function kn(r,e,t,n){return{name:r,type:e,encode:t,decode:n}}function qo(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 kn("enum",wr.VARINT,t,n)}function Ge(r,e){return kn("message",wr.LENGTH_DELIMITED,r,e)}var X;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.Secp256k1="Secp256k1"})(X||(X={}));var $o;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.Secp256k1=2]="Secp256k1"})($o||($o={}));(function(r){r.codec=()=>qo($o)})(X||(X={}));var Xe;(function(r){let e;r.codec=()=>(e==null&&(e=Ge((t,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),t.Type!=null&&(n.uint32(8),X.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=X.codec().decode(t);break;case 2:s.Data=t.bytes();break;default:t.skipType(i&7);break}}return s})),e),r.encode=t=>$e(t,r.codec()),r.decode=t=>qe(t,r.codec())})(Xe||(Xe={}));var Qe;(function(r){let e;r.codec=()=>(e==null&&(e=Ge((t,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),t.Type!=null&&(n.uint32(8),X.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=X.codec().decode(t);break;case 2:s.Data=t.bytes();break;default:t.skipType(i&7);break}}return s})),e),r.encode=t=>$e(t,r.codec()),r.decode=t=>qe(t,r.codec())})(Qe||(Qe={}));var Mr=class{_key;constructor(e){this._key=xr(e,yr)}verify(e,t){return Da(this._key,t,e)}marshal(){return this._key}get bytes(){return Xe.encode({Type:X.Ed25519,Data:this.marshal()}).subarray()}equals(e){return de(this.bytes,e.bytes)}hash(){let e=ye.digest(this.bytes);return Ce(e)?e.then(({bytes:t})=>t):e.bytes}},Zt=class{_key;_publicKey;constructor(e,t){this._key=xr(e,pt),this._publicKey=xr(t,yr)}sign(e){return Va(this._key,e)}get public(){return new Mr(this._publicKey)}marshal(){return this._key}get bytes(){return Qe.encode({Type:X.Ed25519,Data:this.marshal()}).subarray()}equals(e){return de(this.bytes,e.bytes)}async hash(){let e=ye.digest(this.bytes),t;return Ce(e)?{bytes:t}=await e:t=e.bytes,t}async id(){let e=It.digest(this.public.bytes);return ne.encode(e.bytes).substring(1)}async export(e,t="libp2p-key"){if(t==="libp2p-key")return br(this.bytes,e);throw new C(`export format '${t}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function Dh(r){if(r.length>pt){r=xr(r,pt+yr);let n=r.subarray(0,pt),s=r.subarray(pt,r.length);return new Zt(n,s)}r=xr(r,pt);let e=r.subarray(0,pt),t=r.subarray(yr);return new Zt(e,t)}function Mh(r){return r=xr(r,yr),new Mr(r)}async function Hh(){let{privateKey:r,publicKey:e}=Pa();return new Zt(r,e)}async function Ya(r){let{privateKey:e,publicKey:t}=Oa(r);return new Zt(e,t)}function xr(r,e){if(r=Uint8Array.from(r??[]),r.length!==e)throw new C(`Key must be a Uint8Array of length ${e}, got ${r.length}`,"ERR_INVALID_KEY_TYPE");return r}function K(r,e="utf8"){let t=un[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return(e==="utf8"||e==="utf-8")&&globalThis.Buffer!=null&&globalThis.Buffer.from!=null?globalThis.Buffer.from(r.buffer,r.byteOffset,r.byteLength).toString("utf8"):t.encoder.encode(r).substring(1)}var ti={};he(ti,{MAX_RSA_KEY_SIZE:()=>Jr,RsaPrivateKey:()=>Ir,RsaPublicKey:()=>Zr,fromJwk:()=>dd,generateKeyPair:()=>pd,unmarshalRsaPrivateKey:()=>Qo,unmarshalRsaPublicKey:()=>hd});function Jt(r){if(isNaN(r)||r<=0)throw new C("random bytes length must be a Number bigger than 0","ERR_INVALID_LENGTH");return dr(r)}var Vt={};he(Vt,{exportToPem:()=>ad,importFromPem:()=>cd,jwkToPkcs1:()=>nd,jwkToPkix:()=>od,pkcs1ToJwk:()=>rd,pkixToJwk:()=>sd});var Rn=class extends fr{constructor(e,t){super(),this.finished=!1,this.destroyed=!1,fn(e);let n=Nt(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 ur(this),this.iHash.update(e),this}digestInto(e){ur(this),lo(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()}},Hr=(r,e,t)=>new Rn(r,e).update(t).digest();Hr.create=(r,e)=>new Rn(r,e);function Fh(r,e,t,n){fn(r);let s=wa({dkLen:32,asyncTick:10},n),{c:o,dkLen:i,asyncTick:a}=s;if(lr(o),lr(i),lr(a),o<1)throw new Error("PBKDF2: iterations (c) should be >= 1");let c=Nt(e),f=Nt(t),u=new Uint8Array(i),l=Hr.create(r,c),d=l._cloneInto().update(f);return{c:o,dkLen:i,asyncTick:a,DK:u,PRF:l,PRFSalt:d}}function Kh(r,e,t,n,s){return r.destroy(),e.destroy(),n&&n.destroy(),s.fill(0),t}async function zo(r,e,t,n){let{c:s,dkLen:o,asyncTick:i,DK:a,PRF:c,PRFSalt:f}=Fh(r,e,t,n),u,l=new Uint8Array(4),d=hr(l),b=new Uint8Array(c.outputLen);for(let p=1,h=0;h<o;p++,h+=c.outputLen){let m=a.subarray(h,h+c.outputLen);d.setInt32(0,p,!1),(u=f._cloneInto(u)).update(l).digestInto(b),m.set(b.subarray(0,m.length)),await ba(s-1,i,()=>{c._cloneInto(u).update(b).digestInto(b);for(let y=0;y<m.length;y++)m[y]^=b[y]})}return Kh(c,f,a,u,b)}var M=Di(Za());function Xt(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 Ut(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 u=a-1;u>=0;u--){let l=Math.pow(2,u*e);f[o-u-1]=Math.floor(s/l),s-=f[o-u-1]*l}return c}i*=Math.pow(2,e)}return new ArrayBuffer(0)}function Cn(...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 Wo(){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=Xt(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,Xt(o,8)-n}function Ja(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=Ut(i,8,n),c=new Uint8Array(a);return c[0]|=128,a}let s=Ut(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 Xa(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 Ne(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 fm=Math.log(2);function Ln(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function Yo(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 xt(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 Kr=class{constructor(){this.items=[]}write(e){this.items.push(e)}final(){return Yo(this.items)}},Fr=[new Uint8Array([1])],Qa="0123456789";var Br="",je=new ArrayBuffer(0),Zo=new Uint8Array(0),qr="EndOfContent",tc="OCTET STRING",rc="BIT STRING";function vt(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):Zo}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(!xt(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",je)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:M.Convert.ToHex(this.valueHexView)}}},e.NAME="hexBlock",e}var yt=class{constructor({blockLength:e=0,error:t=Br,warnings:n=[],valueBeforeDecode:s=Zo}={}){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)}}};yt.NAME="baseBlock";var Be=class extends yt{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'")}};Be.NAME="valueBlock";var Un=class extends vt(yt){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):Zo,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",je}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=Ut(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(!xt(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),u=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===u){u+=255;let d=new Uint8Array(u);for(let b=0;b<f.length;b++)d[b]=f[b];f=this.valueHexView=new Uint8Array(u)}}this.blockLength=c+1,f[c-1]=o[c]&127;let l=new Uint8Array(c);for(let d=0;d<c;d++)l[d]=f[d];f=this.valueHexView=new Uint8Array(c),f.set(l),this.blockLength<=9?this.tagNumber=Xt(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}}};Un.NAME="identificationBlock";var Pn=class extends yt{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(!xt(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=Xt(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=Ut(this.length,8);if(s.byteLength>127)return this.error="Too big length",je;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}}};Pn.NAME="lengthBlock";var I={},be=class extends yt{constructor({name:e=Br,optional:t=!1,primitiveSchema:n,...s}={},o){super(s),this.name=e,this.optional=t,n&&(this.primitiveSchema=n),this.idBlock=new Un(s),this.lenBlock=new Pn(s),this.valueBlock=o?new o(s):new Be(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 Kr;t||nc(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?je: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 Xa(t,n)}};be.NAME="BaseBlock";function nc(r){if(r instanceof I.Constructed)for(let e of r.valueBlock.value)nc(e)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var On=class extends be{constructor({value:e=Br,...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}'`}};On.NAME="BaseStringBlock";var Vn=class extends vt(Be){constructor({isHexOnly:e=!0,...t}={}){super(t),this.isHexOnly=e}};Vn.NAME="PrimitiveValueBlock";var sc,Dn=class extends be{constructor(e={}){super(e,Vn),this.idBlock.isConstructed=!1}};sc=Dn;I.Primitive=sc;Dn.NAME="PRIMITIVE";function Jh(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 ys(r,e=0,t=r.length){let n=e,s=new be({},Be),o=new yt;if(!xt(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=be;switch(s.idBlock.tagClass){case 1:if(s.idBlock.tagNumber>=37&&s.idBlock.isHexOnly===!1)return s.error="UNIVERSAL 37 and upper tags are reserved by ASN.1 standard",{offset:-1,result:s};switch(s.idBlock.tagNumber){case 0:if(s.idBlock.isConstructed&&s.lenBlock.length>0)return s.error="Type [UNIVERSAL 0] is reserved",{offset:-1,result:s};c=I.EndOfContent;break;case 1:c=I.Boolean;break;case 2:c=I.Integer;break;case 3:c=I.BitString;break;case 4:c=I.OctetString;break;case 5:c=I.Null;break;case 6:c=I.ObjectIdentifier;break;case 10:c=I.Enumerated;break;case 12:c=I.Utf8String;break;case 13:c=I.RelativeObjectIdentifier;break;case 14:c=I.TIME;break;case 15:return s.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:s};case 16:c=I.Sequence;break;case 17:c=I.Set;break;case 18:c=I.NumericString;break;case 19:c=I.PrintableString;break;case 20:c=I.TeletexString;break;case 21:c=I.VideotexString;break;case 22:c=I.IA5String;break;case 23:c=I.UTCTime;break;case 24:c=I.GeneralizedTime;break;case 25:c=I.GraphicString;break;case 26:c=I.VisibleString;break;case 27:c=I.GeneralString;break;case 28:c=I.UniversalString;break;case 29:c=I.CharacterString;break;case 30:c=I.BmpString;break;case 31:c=I.DATE;break;case 32:c=I.TimeOfDay;break;case 33:c=I.DateTime;break;case 34:c=I.Duration;break;default:{let f=s.idBlock.isConstructed?new I.Constructed:new I.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?I.Constructed:I.Primitive}return s=Jh(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 Ar(r){if(!r.byteLength){let e=new be({},Be);return e.error="Input buffer has zero length",{offset:-1,result:e}}return ys(M.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function Xh(r,e){return r?1:e}var et=class extends Be{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(!xt(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(;Xh(this.isIndefiniteForm,n)>0;){let i=ys(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===qr)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===qr?this.value.pop():this.warnings.push("No EndOfContent block encoded")),o}toBER(e,t){let n=t||new Kr;for(let s=0;s<this.value.length;s++)this.value[s].toBER(e,n);return t?je:n.final()}toJSON(){let e={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let t of this.value)e.value.push(t.toJSON());return e}};et.NAME="ConstructedValueBlock";var oc,Pt=class extends be{constructor(e={}){super(e,et),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(`
|
|
3
3
|
`).map(s=>` ${s}`).join(`
|
|
4
4
|
`));let t=this.idBlock.tagClass===3?`[${this.idBlock.tagNumber}]`:this.constructor.NAME;return e.length?`${t} :
|
|
5
5
|
${e.join(`
|
|
6
|
-
`)}`:`${t} :`}};nc=Pt;I.Constructed=nc;Pt.NAME="CONSTRUCTED";var Dn=class extends ve{fromBER(e,t,n){return t}toBER(e){return je}};Dn.override="EndOfContentValueBlock";var sc,Mn=class extends be{constructor(e={}){super(e,Dn),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};sc=Mn;I.EndOfContent=sc;Mn.NAME=$r;var oc,Ot=class extends be{constructor(e={}){super(e,ve),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}`}};oc=Ot;I.Null=oc;Ot.NAME="NULL";var Hn=class extends xt(ve){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 wt(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,Ko.call(this),this.blockLength=n,t+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};Hn.NAME="BooleanValueBlock";var ic,Fn=class extends be{constructor(e={}){super(e,Hn),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}`}};ic=Fn;I.Boolean=ic;Fn.NAME="BOOLEAN";var Kn=class extends xt(et){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=et.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===$r){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(i!==Qa)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?et.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 ac,yt=class r extends be{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=ms(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?Pt.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)}};ac=yt;I.OctetString=ac;yt.NAME=Qa;var qn=class extends xt(et){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=et.prototype.fromBER.call(this,e,t,n),s===-1)return s;for(let a of this.value){let c=a.constructor.NAME;if(c===$r){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==ec)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(!wt(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=ms(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 et.prototype.toBER.call(this,e,t);if(e)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return je;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}}};qn.NAME="BitStringValueBlock";var cc,Er=class extends be{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},qn),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 Pt.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)}`}}};cc=Er;I.BitString=cc;Er.NAME=ec;var lc;function zh(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,u=c<i?i:c,l=0;for(let d=u;d>=0;d--,l++){switch(!0){case l<a.length:f=o[i-l]+a[c-l]+t[0];break;default:f=o[i-l]+t[0]}switch(t[0]=f/10,!0){case l>=o.length:o=_n(new Uint8Array([f%10]),o);break;default:o[i-l]=f%10}}return t[0]>0&&(o=_n(t,o)),o}function Xa(r){if(r>=Kr.length)for(let e=Kr.length;e<=r;e++){let t=new Uint8Array([0]),n=Kr[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=_n(t,n)),Kr.push(n)}return Kr[r]}function jh(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,u=0;for(let l=c;l>=0;l--,u++)switch(f=o[i-u]-a[c-u]-t,!0){case f<0:t=1,o[i-u]=f+10;break;default:t=0,o[i-u]=f}if(t>0)for(let l=i-c+1;l>=0;l--,u++)if(f=o[i-u]-t,f<0)t=1,o[i-u]=f+10;else{t=0,o[i-u]=f;break}return o.slice()}var Gr=class extends xt(ve){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=Ko.call(this)))}set valueDec(e){this._valueDec=e,this.isHexOnly=!1,this.valueHexView=new Uint8Array(Ya(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=jh(Xa(n),t),i="-";break;default:t=zh(t,Xa(n))}n++,s>>=1}}for(let c=0;c<t.length;c++)t[c]&&(a=!0),a&&(i+=Ja.charAt(t[c]));return a===!1&&(i+=Ja.charAt(0)),i}};lc=Gr;Gr.NAME="IntegerValueBlock";Object.defineProperty(lc.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var uc,ce=class r extends be{constructor(e={}){super(e,Gr),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return Cn(),BigInt(this.valueBlock.toString())}static fromBigInt(e){Cn();let t=BigInt(e),n=new qr,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,u=M.BufferSourceConverter.toUint8Array(M.Convert.FromHex(f.toString(16)));u[0]|=128,n.write(u)}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()}`}};uc=ce;I.Integer=uc;ce.NAME="INTEGER";var fc,$n=class extends ce{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};fc=$n;I.Enumerated=fc;$n.NAME="ENUMERATED";var zr=class extends xt(ve){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(!wt(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=Xt(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),t+this.blockLength)}set valueBigInt(e){Cn();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=Ut(this.valueDec,7);if(t.byteLength===0)return this.error="Error during encoding SID value",je;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}}};zr.NAME="sidBlock";var Gn=class extends ve{constructor({value:e=Br,...t}={}){super(t),this.value=[],e&&this.fromString(e)}fromBER(e,t,n){let s=t;for(;n>0;){let o=new zr;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,je;t.push(s)}return qo(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 zr;if(s>Number.MAX_SAFE_INTEGER){Cn();let a=BigInt(s);i.valueBigInt=a}else if(i.valueDec=parseInt(s,10),isNaN(i.valueDec))return;this.value.length||(i.isFirstSid=!0,o=!0),this.value.push(i)}while(n!==-1)}toString(){let 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}};Gn.NAME="ObjectIdentifierValueBlock";var hc,ze=class extends be{constructor(e={}){super(e,Gn),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()}}};hc=ze;I.ObjectIdentifier=hc;ze.NAME="OBJECT IDENTIFIER";var jr=class extends xt(mt){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(!wt(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=Xt(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=Ut(this.valueDec,7);if(t.byteLength===0)return this.error="Error during encoding SID value",je;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}}};jr.NAME="relativeSidBlock";var zn=class extends ve{constructor({value:e=Br,...t}={}){super(t),this.value=[],e&&this.fromString(e)}fromBER(e,t,n){let s=t;for(;n>0;){let o=new jr;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,je;n.push(o)}return qo(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 jr;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}};zn.NAME="RelativeObjectIdentifierValueBlock";var dc,jn=class extends be{constructor(e={}){super(e,zn),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()}}};dc=jn;I.RelativeObjectIdentifier=dc;jn.NAME="RelativeObjectIdentifier";var pc,pe=class extends Pt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};pc=pe;I.Sequence=pc;pe.NAME="SEQUENCE";var gc,Wn=class extends Pt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};gc=Wn;I.Set=gc;Wn.NAME="SET";var Yn=class extends xt(ve){constructor({...e}={}){super(e),this.isHexOnly=!0,this.value=Br}toJSON(){return{...super.toJSON(),value:this.value}}};Yn.NAME="StringValueBlock";var Zn=class extends Yn{};Zn.NAME="SimpleStringValueBlock";var Ie=class extends Pn{constructor({...e}={}){super(e,Zn)}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}};Ie.NAME="SIMPLE STRING";var Jn=class extends Ie{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}};Jn.NAME="Utf8StringValueBlock";var mc,bt=class extends Jn{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};mc=bt;I.Utf8String=mc;bt.NAME="UTF8String";var Xn=class extends Ie{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))}};Xn.NAME="BmpStringValueBlock";var yc,Qn=class extends Xn{constructor({...e}={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};yc=Qn;I.BmpString=yc;Qn.NAME="BMPString";var es=class extends Ie{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=Ut(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}};es.NAME="UniversalStringValueBlock";var bc,ts=class extends es{constructor({...e}={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};bc=ts;I.UniversalString=bc;ts.NAME="UniversalString";var wc,rs=class extends Ie{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};wc=rs;I.NumericString=wc;rs.NAME="NumericString";var xc,ns=class extends Ie{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};xc=ns;I.PrintableString=xc;ns.NAME="PrintableString";var vc,ss=class extends Ie{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};vc=ss;I.TeletexString=vc;ss.NAME="TeletexString";var Ec,os=class extends Ie{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};Ec=os;I.VideotexString=Ec;os.NAME="VideotexString";var Bc,is=class extends Ie{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};Bc=is;I.IA5String=Bc;is.NAME="IA5String";var Ac,as=class extends Ie{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};Ac=as;I.GraphicString=Ac;as.NAME="GraphicString";var Ic,Wr=class extends Ie{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};Ic=Wr;I.VisibleString=Ic;Wr.NAME="VisibleString";var Sc,cs=class extends Ie{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};Sc=cs;I.GeneralString=Sc;cs.NAME="GeneralString";var kc,ls=class extends Ie{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};kc=ls;I.CharacterString=kc;ls.NAME="CharacterString";var Nc,Yr=class extends Wr{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]=Ne(this.year<2e3?this.year-1900:this.year-2e3,2),t[1]=Ne(this.month,2),t[2]=Ne(this.day,2),t[3]=Ne(this.hour,2),t[4]=Ne(this.minute,2),t[5]=Ne(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}}};Nc=Yr;I.UTCTime=Nc;Yr.NAME="UTCTime";var Rc,us=class extends Yr{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 l=new Number(e[e.length-1]);if(isNaN(l.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 l=1,d=n.indexOf("+"),b="";if(d===-1&&(d=n.indexOf("-"),l=-1),d!==-1){if(b=n.substring(d+1),n=n.substring(0,d),b.length!==2&&b.length!==4)throw new Error("Wrong input string for conversion");let p=parseInt(b.substring(0,2),10);if(isNaN(p.valueOf()))throw new Error("Wrong input string for conversion");if(a=l*p,b.length===4){if(p=parseInt(b.substring(2,4),10),isNaN(p.valueOf()))throw new Error("Wrong input string for conversion");c=l*p}}}let f=n.indexOf(".");if(f===-1&&(f=n.indexOf(",")),f!==-1){let l=new Number(`0${n.substring(f)}`);if(isNaN(l.valueOf()))throw new Error("Wrong input string for conversion");o=l.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 l=60*o;this.minute=Math.floor(l),l=60*(l-this.minute),this.second=Math.floor(l),l=1e3*(l-this.second),this.millisecond=Math.floor(l)}break;case s.length===12:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let l=60*o;this.second=Math.floor(l),l=1e3*(l-this.second),this.millisecond=Math.floor(l)}break;case s.length===14:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let l=1e3*o;this.millisecond=Math.floor(l)}break;default:throw new Error("Wrong input string for conversion")}let u=i.exec(s);if(u===null)throw new Error("Wrong input string for conversion");for(let l=1;l<u.length;l++)switch(l){case 1:this.year=parseInt(u[l],10);break;case 2:this.month=parseInt(u[l],10);break;case 3:this.day=parseInt(u[l],10);break;case 4:this.hour=parseInt(u[l],10)+a;break;case 5:this.minute=parseInt(u[l],10)+c;break;case 6:this.second=parseInt(u[l],10);break;default:throw new Error("Wrong input string for conversion")}if(t===!1){let l=new Date(this.year,this.month,this.day,this.hour,this.minute,this.second,this.millisecond);this.year=l.getUTCFullYear(),this.month=l.getUTCMonth(),this.day=l.getUTCDay(),this.hour=l.getUTCHours(),this.minute=l.getUTCMinutes(),this.second=l.getUTCSeconds(),this.millisecond=l.getUTCMilliseconds()}}toString(e="iso"){if(e==="iso"){let t=[];return t.push(Ne(this.year,4)),t.push(Ne(this.month,2)),t.push(Ne(this.day,2)),t.push(Ne(this.hour,2)),t.push(Ne(this.minute,2)),t.push(Ne(this.second,2)),this.millisecond!==0&&(t.push("."),t.push(Ne(this.millisecond,3))),t.push("Z"),t.join("")}return super.toString(e)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};Rc=us;I.GeneralizedTime=Rc;us.NAME="GeneralizedTime";var Tc,fs=class extends bt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};Tc=fs;I.DATE=Tc;fs.NAME="DATE";var _c,hs=class extends bt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};_c=hs;I.TimeOfDay=_c;hs.NAME="TimeOfDay";var Cc,ds=class extends bt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};Cc=ds;I.DateTime=Cc;ds.NAME="DateTime";var Lc,ps=class extends bt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};Lc=ps;I.Duration=Lc;ps.NAME="Duration";var Uc,gs=class extends bt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};Uc=gs;I.TIME=Uc;gs.NAME="TIME";function Yh(r){let{result:e}=Ar(r),t=e.valueBlock.value;return{n:K(tt(t[1].toBigInt()),"base64url"),e:K(tt(t[2].toBigInt()),"base64url"),d:K(tt(t[3].toBigInt()),"base64url"),p:K(tt(t[4].toBigInt()),"base64url"),q:K(tt(t[5].toBigInt()),"base64url"),dp:K(tt(t[6].toBigInt()),"base64url"),dq:K(tt(t[7].toBigInt()),"base64url"),qi:K(tt(t[8].toBigInt()),"base64url"),kty:"RSA",alg:"RS256"}}function Zh(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 C("JWK was missing components","ERR_INVALID_PARAMETERS");let t=new pe({value:[new ce({value:0}),ce.fromBigInt(rt(F(r.n,"base64url"))),ce.fromBigInt(rt(F(r.e,"base64url"))),ce.fromBigInt(rt(F(r.d,"base64url"))),ce.fromBigInt(rt(F(r.p,"base64url"))),ce.fromBigInt(rt(F(r.q,"base64url"))),ce.fromBigInt(rt(F(r.dp,"base64url"))),ce.fromBigInt(rt(F(r.dq,"base64url"))),ce.fromBigInt(rt(F(r.qi,"base64url")))]}).toBER();return new Uint8Array(t,0,t.byteLength)}function Jh(r){let{result:e}=Ar(r),t=e.valueBlock.value[1].valueBlock.value[0].valueBlock.value;return{kty:"RSA",n:K(tt(t[0].toBigInt()),"base64url"),e:K(tt(t[1].toBigInt()),"base64url")}}function Xh(r){if(r.n==null||r.e==null)throw new C("JWK was missing components","ERR_INVALID_PARAMETERS");let t=new pe({value:[new pe({value:[new ze({value:"1.2.840.113549.1.1.1"}),new Ot]}),new Er({valueHex:new pe({value:[ce.fromBigInt(rt(F(r.n,"base64url"))),ce.fromBigInt(rt(F(r.e,"base64url")))]}).toBER()})]}).toBER();return new Uint8Array(t,0,t.byteLength)}function tt(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 rt(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 Qh=16,Go=32,zo=1e4;async function ed(r,e){let t=Ae.get(),s=new pe({value:[new ce({value:0}),new pe({value:[new ze({value:"1.2.840.113549.1.1.1"}),new Ot]}),new yt({valueHex:r.marshal()})]}).toBER(),o=new Uint8Array(s,0,s.byteLength),i=Jt(Qh),a=await Ho(gr,e,i,{c:zo,dkLen:Go}),c=Jt(16),f=await t.subtle.importKey("raw",a,"AES-CBC",!1,["encrypt"]),u=await t.subtle.encrypt({name:"AES-CBC",iv:c},f,o),l=new pe({value:[new yt({valueHex:i}),new ce({value:zo}),new ce({value:Go}),new pe({value:[new ze({value:"1.2.840.113549.2.11"}),new Ot]})]}),d=new pe({value:[new ze({value:"1.2.840.113549.1.5.13"}),new pe({value:[new pe({value:[new ze({value:"1.2.840.113549.1.5.12"}),l]}),new pe({value:[new ze({value:"2.16.840.1.101.3.4.1.42"}),new yt({valueHex:c})]})]})]}),p=new pe({value:[d,new yt({valueHex:u})]}).toBER(),h=new Uint8Array(p,0,p.byteLength);return["-----BEGIN ENCRYPTED PRIVATE KEY-----",...K(h,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
|
|
7
|
-
`)}async function td(r,e){let t=Ae.get(),n;if(r.includes("-----BEGIN ENCRYPTED PRIVATE KEY-----")){let s=F(r.replace("-----BEGIN ENCRYPTED PRIVATE KEY-----","").replace("-----END ENCRYPTED PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:o}=Ar(s),{iv:i,salt:a,iterations:c,keySize:f,cipherText:u}=rd(o),l=await Ho(gr,e,a,{c,dkLen:f}),d=await t.subtle.importKey("raw",l,"AES-CBC",!1,["decrypt"]),b=Zr(await t.subtle.decrypt({name:"AES-CBC",iv:i},d,u)),{result:p}=Ar(b);n=Pc(p)}else if(r.includes("-----BEGIN PRIVATE KEY-----")){let s=F(r.replace("-----BEGIN PRIVATE KEY-----","").replace("-----END PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:o}=Ar(s);n=Pc(o)}else throw new C("Could not parse private key from PEM data","ERR_INVALID_PARAMETERS");return jo(n)}function rd(r){let e=r.valueBlock.value[0];if(e.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.13")throw new C("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 C("Only pkcs5PBKDF2 key derivation functions are supported","ERR_INVALID_PARAMS");let o=n.valueBlock.value[1],i=Zr(o.valueBlock.value[0].getValue()),a=zo,c=Go;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 C("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],u=f.valueBlock.value[0].toString();if(u!=="OBJECT IDENTIFIER : 1.2.840.113549.3.7"){if(u!=="OBJECT IDENTIFIER : 1.3.14.3.2.7"){if(u!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.2"){if(u!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.22"){if(u!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.42")throw new C("Only AES-CBC encryption schemes are supported","ERR_INVALID_PARAMS")}}}}let l=Zr(f.valueBlock.value[1].getValue());return{cipherText:Zr(r.valueBlock.value[1].getValue()),salt:i,iterations:a,keySize:c,iv:l}}function Pc(r){return Zr(r.valueBlock.value[2].getValue())}function Zr(r){return new Uint8Array(r,0,r.byteLength)}async function Oc(r){let e=await Ae.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 Mc(e);return{privateKey:t[0],publicKey:t[1]}}async function Wo(r){let t=[await Ae.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["sign"]),await nd(r)],n=await Mc({privateKey:t[0],publicKey:t[1]});return{privateKey:n[0],publicKey:n[1]}}async function Vc(r,e){let t=await Ae.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await Ae.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},t,e instanceof Uint8Array?e:e.subarray());return new Uint8Array(n,0,n.byteLength)}async function Dc(r,e,t){let n=await Ae.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return Ae.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,e,t instanceof Uint8Array?t:t.subarray())}async function Mc(r){if(r.privateKey==null||r.publicKey==null)throw new C("Private and public key are required","ERR_INVALID_PARAMETERS");return Promise.all([Ae.get().subtle.exportKey("jwk",r.privateKey),Ae.get().subtle.exportKey("jwk",r.publicKey)])}async function nd(r){return Ae.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 ys(r){if(r.kty!=="RSA")throw new C("invalid key type","ERR_INVALID_KEY_TYPE");if(r.n==null)throw new C("invalid key modulus","ERR_INVALID_KEY_MODULUS");return F(r.n,"base64url").length*8}var Xr=8192,Jr=class{_key;constructor(e){this._key=e}verify(e,t){return Dc(this._key,t,e)}marshal(){return Vt.jwkToPkix(this._key)}get bytes(){return Xe.encode({Type:X.RSA,Data:this.marshal()}).subarray()}equals(e){return de(this.bytes,e.bytes)}hash(){let e=ye.digest(this.bytes);return _e(e)?e.then(({bytes:t})=>t):e.bytes}},Ir=class{_key;_publicKey;constructor(e,t){this._key=e,this._publicKey=t}genSecret(){return Jt(16)}sign(e){return Vc(this._key,e)}get public(){if(this._publicKey==null)throw new C("public key not provided","ERR_PUBKEY_NOT_PROVIDED");return new Jr(this._publicKey)}marshal(){return Vt.jwkToPkcs1(this._key)}get bytes(){return Qe.encode({Type:X.RSA,Data:this.marshal()}).subarray()}equals(e){return de(this.bytes,e.bytes)}hash(){let e=ye.digest(this.bytes);return _e(e)?e.then(({bytes:t})=>t):e.bytes}async id(){let e=await this.public.hash();return K(e,"base58btc")}async export(e,t="pkcs-8"){if(t==="pkcs-8")return Vt.exportToPem(this,e);if(t==="libp2p-key")return br(this.bytes,e);throw new C(`export format '${t}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};async function jo(r){let e=Vt.pkcs1ToJwk(r);if(ys(e)>Xr)throw new C("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await Wo(e);return new Ir(t.privateKey,t.publicKey)}function od(r){let e=Vt.pkixToJwk(r);if(ys(e)>Xr)throw new C("key size is too large","ERR_KEY_SIZE_TOO_LARGE");return new Jr(e)}async function id(r){if(ys(r)>Xr)throw new C("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await Wo(r);return new Ir(e.privateKey,e.publicKey)}async function ad(r){if(r>Xr)throw new C("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await Oc(r);return new Ir(e.privateKey,e.publicKey)}var ei={};he(ei,{Secp256k1PrivateKey:()=>en,Secp256k1PublicKey:()=>Qr,generateKeyPair:()=>Ed,unmarshalSecp256k1PrivateKey:()=>xd,unmarshalSecp256k1PublicKey:()=>vd});var cd=(r,e,t)=>r&e^~r&t,ld=(r,e,t)=>r&e^r&t^e&t,ud=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]),Dt=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),Mt=new Uint32Array(64),Zo=class extends pr{constructor(){super(64,32,8,!1),this.A=Dt[0]|0,this.B=Dt[1]|0,this.C=Dt[2]|0,this.D=Dt[3]|0,this.E=Dt[4]|0,this.F=Dt[5]|0,this.G=Dt[6]|0,this.H=Dt[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 l=0;l<16;l++,t+=4)Mt[l]=e.getUint32(t,!1);for(let l=16;l<64;l++){let d=Mt[l-15],b=Mt[l-2],p=Me(d,7)^Me(d,18)^d>>>3,h=Me(b,17)^Me(b,19)^b>>>10;Mt[l]=h+Mt[l-7]+p+Mt[l-16]|0}let{A:n,B:s,C:o,D:i,E:a,F:c,G:f,H:u}=this;for(let l=0;l<64;l++){let d=Me(a,6)^Me(a,11)^Me(a,25),b=u+d+cd(a,c,f)+ud[l]+Mt[l]|0,h=(Me(n,2)^Me(n,13)^Me(n,22))+ld(n,s,o)|0;u=f,f=c,c=a,a=i+b|0,i=o,o=s,s=n,n=b+h|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,u=u+this.H|0,this.set(n,s,o,i,a,c,f,u)}roundClean(){Mt.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var Hc=gn(()=>new Zo);function fd(r){let e=Or(r);Je(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:hd,hexToBytes:dd}=bn,Qt={Err:class extends Error{constructor(e=""){super(e)}},_parseInt(r){let{Err:e}=Qt;if(r.length<2||r[0]!==2)throw new e("Invalid signature integer tag");let t=r[1],n=r.subarray(2,t+2);if(!t||n.length!==t)throw new e("Invalid signature integer: wrong length");if(n[0]&128)throw new e("Invalid signature integer: negative");if(n[0]===0&&!(n[1]&128))throw new e("Invalid signature integer: unnecessary leading zero");return{d:hd(n),l:r.subarray(t+2)}},toSig(r){let{Err:e}=Qt,t=typeof r=="string"?dd(r):r;if(!He(t))throw new Error("ui8a expected");let n=t.length;if(n<2||t[0]!=48)throw new e("Invalid signature tag");if(t[1]!==n-2)throw new e("Invalid signature: incorrect length");let{d:s,l:o}=Qt._parseInt(t.subarray(2)),{d:i,l:a}=Qt._parseInt(o);if(a.length)throw new e("Invalid signature: left bytes after parsing");return{r:s,s:i}},hexFromSig(r){let e=f=>Number.parseInt(f[0],16)&8?"00"+f:f,t=f=>{let u=f.toString(16);return u.length&1?`0${u}`:u},n=e(t(r.s)),s=e(t(r.r)),o=n.length/2,i=s.length/2,a=t(o),c=t(i);return`30${t(i+o+4)}02${c}${s}02${a}${n}`}},vt=BigInt(0),Le=BigInt(1),Um=BigInt(2),Fc=BigInt(3),Pm=BigInt(4);function pd(r){let e=fd(r),{Fp:t}=e,n=e.toBytes||((p,h,m)=>{let y=h.toAffine();return ht(Uint8Array.from([4]),t.toBytes(y.x),t.toBytes(y.y))}),s=e.fromBytes||(p=>{let h=p.subarray(1),m=t.fromBytes(h.subarray(0,t.BYTES)),y=t.fromBytes(h.subarray(t.BYTES,2*t.BYTES));return{x:m,y}});function o(p){let{a:h,b:m}=e,y=t.sqr(p),B=t.mul(y,p);return t.add(t.add(B,t.mul(p,h)),m)}if(!t.eql(t.sqr(e.Gy),o(e.Gx)))throw new Error("bad generator point: equation left != right");function i(p){return typeof p=="bigint"&&vt<p&&p<e.n}function a(p){if(!i(p))throw new Error("Expected valid bigint: 0 < bigint < curve.n")}function c(p){let{allowedPrivateKeyLengths:h,nByteLength:m,wrapPrivateKey:y,n:B}=e;if(h&&typeof p!="bigint"){if(He(p)&&(p=ut(p)),typeof p!="string"||!h.includes(p.length))throw new Error("Invalid key");p=p.padStart(m*2,"0")}let w;try{w=typeof p=="bigint"?p:ft(te("private key",p,m))}catch{throw new Error(`private key must be ${m} bytes, hex or bigint, not ${typeof p}`)}return y&&(w=Y(w,B)),a(w),w}let f=new Map;function u(p){if(!(p instanceof l))throw new Error("ProjectivePoint expected")}class l{constructor(h,m,y){if(this.px=h,this.py=m,this.pz=y,h==null||!t.isValid(h))throw new Error("x required");if(m==null||!t.isValid(m))throw new Error("y required");if(y==null||!t.isValid(y))throw new Error("z required")}static fromAffine(h){let{x:m,y}=h||{};if(!h||!t.isValid(m)||!t.isValid(y))throw new Error("invalid affine point");if(h instanceof l)throw new Error("projective point not allowed");let B=w=>t.eql(w,t.ZERO);return B(m)&&B(y)?l.ZERO:new l(m,y,t.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(h){let m=t.invertBatch(h.map(y=>y.pz));return h.map((y,B)=>y.toAffine(m[B])).map(l.fromAffine)}static fromHex(h){let m=l.fromAffine(s(te("pointHex",h)));return m.assertValidity(),m}static fromPrivateKey(h){return l.BASE.multiply(c(h))}_setWindowSize(h){this._WINDOW_SIZE=h,f.delete(this)}assertValidity(){if(this.is0()){if(e.allowInfinityPoint&&!t.is0(this.py))return;throw new Error("bad point: ZERO")}let{x:h,y:m}=this.toAffine();if(!t.isValid(h)||!t.isValid(m))throw new Error("bad point: x or y not FE");let y=t.sqr(m),B=o(h);if(!t.eql(y,B))throw new Error("bad point: equation left != right");if(!this.isTorsionFree())throw new Error("bad point: not in prime-order subgroup")}hasEvenY(){let{y:h}=this.toAffine();if(t.isOdd)return!t.isOdd(h);throw new Error("Field doesn't support isOdd")}equals(h){u(h);let{px:m,py:y,pz:B}=this,{px:w,py:T,pz:x}=h,A=t.eql(t.mul(m,x),t.mul(w,B)),N=t.eql(t.mul(y,x),t.mul(T,B));return A&&N}negate(){return new l(this.px,t.neg(this.py),this.pz)}double(){let{a:h,b:m}=e,y=t.mul(m,Fc),{px:B,py:w,pz:T}=this,x=t.ZERO,A=t.ZERO,N=t.ZERO,R=t.mul(B,B),G=t.mul(w,w),q=t.mul(T,T),P=t.mul(B,w);return P=t.add(P,P),N=t.mul(B,T),N=t.add(N,N),x=t.mul(h,N),A=t.mul(y,q),A=t.add(x,A),x=t.sub(G,A),A=t.add(G,A),A=t.mul(x,A),x=t.mul(P,x),N=t.mul(y,N),q=t.mul(h,q),P=t.sub(R,q),P=t.mul(h,P),P=t.add(P,N),N=t.add(R,R),R=t.add(N,R),R=t.add(R,q),R=t.mul(R,P),A=t.add(A,R),q=t.mul(w,T),q=t.add(q,q),R=t.mul(q,P),x=t.sub(x,R),N=t.mul(q,G),N=t.add(N,N),N=t.add(N,N),new l(x,A,N)}add(h){u(h);let{px:m,py:y,pz:B}=this,{px:w,py:T,pz:x}=h,A=t.ZERO,N=t.ZERO,R=t.ZERO,G=e.a,q=t.mul(e.b,Fc),P=t.mul(m,w),ie=t.mul(y,T),re=t.mul(B,x),Te=t.add(m,y),v=t.add(w,T);Te=t.mul(Te,v),v=t.add(P,ie),Te=t.sub(Te,v),v=t.add(m,B);let k=t.add(w,x);return v=t.mul(v,k),k=t.add(P,re),v=t.sub(v,k),k=t.add(y,B),A=t.add(T,x),k=t.mul(k,A),A=t.add(ie,re),k=t.sub(k,A),R=t.mul(G,v),A=t.mul(q,re),R=t.add(A,R),A=t.sub(ie,R),R=t.add(ie,R),N=t.mul(A,R),ie=t.add(P,P),ie=t.add(ie,P),re=t.mul(G,re),v=t.mul(q,v),ie=t.add(ie,re),re=t.sub(P,re),re=t.mul(G,re),v=t.add(v,re),P=t.mul(ie,v),N=t.add(N,P),P=t.mul(k,v),A=t.mul(Te,A),A=t.sub(A,P),P=t.mul(Te,ie),R=t.mul(k,R),R=t.add(R,P),new l(A,N,R)}subtract(h){return this.add(h.negate())}is0(){return this.equals(l.ZERO)}wNAF(h){return b.wNAFCached(this,f,h,m=>{let y=t.invertBatch(m.map(B=>B.pz));return m.map((B,w)=>B.toAffine(y[w])).map(l.fromAffine)})}multiplyUnsafe(h){let m=l.ZERO;if(h===vt)return m;if(a(h),h===Le)return this;let{endo:y}=e;if(!y)return b.unsafeLadder(this,h);let{k1neg:B,k1:w,k2neg:T,k2:x}=y.splitScalar(h),A=m,N=m,R=this;for(;w>vt||x>vt;)w&Le&&(A=A.add(R)),x&Le&&(N=N.add(R)),R=R.double(),w>>=Le,x>>=Le;return B&&(A=A.negate()),T&&(N=N.negate()),N=new l(t.mul(N.px,y.beta),N.py,N.pz),A.add(N)}multiply(h){a(h);let m=h,y,B,{endo:w}=e;if(w){let{k1neg:T,k1:x,k2neg:A,k2:N}=w.splitScalar(m),{p:R,f:G}=this.wNAF(x),{p:q,f:P}=this.wNAF(N);R=b.constTimeNegate(T,R),q=b.constTimeNegate(A,q),q=new l(t.mul(q.px,w.beta),q.py,q.pz),y=R.add(q),B=G.add(P)}else{let{p:T,f:x}=this.wNAF(m);y=T,B=x}return l.normalizeZ([y,B])[0]}multiplyAndAddUnsafe(h,m,y){let B=l.BASE,w=(x,A)=>A===vt||A===Le||!x.equals(B)?x.multiplyUnsafe(A):x.multiply(A),T=w(this,m).add(w(h,y));return T.is0()?void 0:T}toAffine(h){let{px:m,py:y,pz:B}=this,w=this.is0();h==null&&(h=w?t.ONE:t.inv(B));let T=t.mul(m,h),x=t.mul(y,h),A=t.mul(B,h);if(w)return{x:t.ZERO,y:t.ZERO};if(!t.eql(A,t.ONE))throw new Error("invZ was invalid");return{x:T,y:x}}isTorsionFree(){let{h,isTorsionFree:m}=e;if(h===Le)return!0;if(m)return m(l,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h,clearCofactor:m}=e;return h===Le?this:m?m(l,this):this.multiplyUnsafe(e.h)}toRawBytes(h=!0){return this.assertValidity(),n(l,this,h)}toHex(h=!0){return ut(this.toRawBytes(h))}}l.BASE=new l(e.Gx,e.Gy,t.ONE),l.ZERO=new l(t.ZERO,t.ONE,t.ZERO);let d=e.nBitLength,b=vn(l,e.endo?Math.ceil(d/2):d);return{CURVE:e,ProjectivePoint:l,normPrivateKeyToScalar:c,weierstrassEquation:o,isWithinCurveOrder:i}}function gd(r){let e=Or(r);return Je(e,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...e})}function Kc(r){let e=gd(r),{Fp:t,n}=e,s=t.BYTES+1,o=2*t.BYTES+1;function i(v){return vt<v&&v<t.ORDER}function a(v){return Y(v,n)}function c(v){return wn(v,n)}let{ProjectivePoint:f,normPrivateKeyToScalar:u,weierstrassEquation:l,isWithinCurveOrder:d}=pd({...e,toBytes(v,k,O){let E=k.toAffine(),g=t.toBytes(E.x),S=ht;return O?S(Uint8Array.from([k.hasEvenY()?2:3]),g):S(Uint8Array.from([4]),g,t.toBytes(E.y))},fromBytes(v){let k=v.length,O=v[0],E=v.subarray(1);if(k===s&&(O===2||O===3)){let g=ft(E);if(!i(g))throw new Error("Point is not on curve");let S=l(g),_=t.sqrt(S),L=(_&Le)===Le;return(O&1)===1!==L&&(_=t.neg(_)),{x:g,y:_}}else if(k===o&&O===4){let g=t.fromBytes(E.subarray(0,t.BYTES)),S=t.fromBytes(E.subarray(t.BYTES,2*t.BYTES));return{x:g,y:S}}else throw new Error(`Point of length ${k} was invalid. Expected ${s} compressed bytes or ${o} uncompressed bytes`)}}),b=v=>ut(Ct(v,e.nByteLength));function p(v){let k=n>>Le;return v>k}function h(v){return p(v)?a(-v):v}let m=(v,k,O)=>ft(v.slice(k,O));class y{constructor(k,O,E){this.r=k,this.s=O,this.recovery=E,this.assertValidity()}static fromCompact(k){let O=e.nByteLength;return k=te("compactSignature",k,O*2),new y(m(k,0,O),m(k,O,2*O))}static fromDER(k){let{r:O,s:E}=Qt.toSig(te("DER",k));return new y(O,E)}assertValidity(){if(!d(this.r))throw new Error("r must be 0 < r < CURVE.n");if(!d(this.s))throw new Error("s must be 0 < s < CURVE.n")}addRecoveryBit(k){return new y(this.r,this.s,k)}recoverPublicKey(k){let{r:O,s:E,recovery:g}=this,S=N(te("msgHash",k));if(g==null||![0,1,2,3].includes(g))throw new Error("recovery id invalid");let _=g===2||g===3?O+e.n:O;if(_>=t.ORDER)throw new Error("recovery id 2 or 3 invalid");let L=g&1?"03":"02",V=f.fromHex(L+b(_)),D=c(_),W=a(-S*D),H=a(E*D),$=f.BASE.multiplyAndAddUnsafe(V,W,H);if(!$)throw new Error("point at infinify");return $.assertValidity(),$}hasHighS(){return p(this.s)}normalizeS(){return this.hasHighS()?new y(this.r,a(-this.s),this.recovery):this}toDERRawBytes(){return Gt(this.toDERHex())}toDERHex(){return Qt.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return Gt(this.toCompactHex())}toCompactHex(){return b(this.r)+b(this.s)}}let B={isValidPrivateKey(v){try{return u(v),!0}catch{return!1}},normPrivateKeyToScalar:u,randomPrivateKey:()=>{let v=xo(e.n);return Na(e.randomBytes(v),e.n)},precompute(v=8,k=f.BASE){return k._setWindowSize(v),k.multiply(BigInt(3)),k}};function w(v,k=!0){return f.fromPrivateKey(v).toRawBytes(k)}function T(v){let k=He(v),O=typeof v=="string",E=(k||O)&&v.length;return k?E===s||E===o:O?E===2*s||E===2*o:v instanceof f}function x(v,k,O=!0){if(T(v))throw new Error("first arg must be private key");if(!T(k))throw new Error("second arg must be public key");return f.fromHex(k).multiply(u(v)).toRawBytes(O)}let A=e.bits2int||function(v){let k=ft(v),O=v.length*8-e.nBitLength;return O>0?k>>BigInt(O):k},N=e.bits2int_modN||function(v){return a(A(v))},R=Pr(e.nBitLength);function G(v){if(typeof v!="bigint")throw new Error("bigint expected");if(!(vt<=v&&v<R))throw new Error(`bigint expected < 2^${e.nBitLength}`);return Ct(v,e.nByteLength)}function q(v,k,O=P){if(["recovered","canonical"].some(Q=>Q in O))throw new Error("sign() legacy options not supported");let{hash:E,randomBytes:g}=e,{lowS:S,prehash:_,extraEntropy:L}=O;S==null&&(S=!0),v=te("msgHash",v),_&&(v=te("prehashed msgHash",E(v)));let V=N(v),D=u(k),W=[G(D),G(V)];if(L!=null){let Q=L===!0?g(t.BYTES):L;W.push(te("extraEntropy",Q))}let H=ht(...W),$=V;function ae(Q){let ge=A(Q);if(!d(ge))return;let me=c(ge),le=f.BASE.multiply(ge).toAffine(),we=a(le.x);if(we===vt)return;let ot=a(me*a($+we*D));if(ot===vt)return;let Kt=(le.x===we?0:2)|Number(le.y&Le),Rr=ot;return S&&p(ot)&&(Rr=h(ot),Kt^=1),new y(we,Rr,Kt)}return{seed:H,k2sig:ae}}let P={lowS:e.lowS,prehash:!1},ie={lowS:e.lowS,prehash:!1};function re(v,k,O=P){let{seed:E,k2sig:g}=q(v,k,O),S=e;return mo(S.hash.outputLen,S.nByteLength,S.hmac)(E,g)}f.BASE._setWindowSize(8);function Te(v,k,O,E=ie){let g=v;if(k=te("msgHash",k),O=te("publicKey",O),"strict"in E)throw new Error("options.strict was renamed to lowS");let{lowS:S,prehash:_}=E,L,V;try{if(typeof g=="string"||He(g))try{L=y.fromDER(g)}catch(le){if(!(le instanceof Qt.Err))throw le;L=y.fromCompact(g)}else if(typeof g=="object"&&typeof g.r=="bigint"&&typeof g.s=="bigint"){let{r:le,s:we}=g;L=new y(le,we)}else throw new Error("PARSE");V=f.fromHex(O)}catch(le){if(le.message==="PARSE")throw new Error("signature must be Signature instance, Uint8Array or hex string");return!1}if(S&&L.hasHighS())return!1;_&&(k=e.hash(k));let{r:D,s:W}=L,H=N(k),$=c(W),ae=a(H*$),Q=a(D*$),ge=f.BASE.multiplyAndAddUnsafe(V,ae,Q)?.toAffine();return ge?a(ge.x)===D:!1}return{CURVE:e,getPublicKey:w,getSharedSecret:x,sign:re,verify:Te,ProjectivePoint:f,Signature:y,utils:B}}function md(r){return{hash:r,hmac:(e,...t)=>Fr(r,e,pn(...t)),randomBytes:dr}}function qc(r,e){let t=n=>Kc({...r,...md(n)});return Object.freeze({...t(e),create:t})}var zc=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),$c=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),yd=BigInt(1),Jo=BigInt(2),Gc=(r,e)=>(r+e/Jo)/e;function bd(r){let e=zc,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,u=f*f*r%e,l=J(u,t,e)*u%e,d=J(l,t,e)*u%e,b=J(d,Jo,e)*f%e,p=J(b,s,e)*b%e,h=J(p,o,e)*p%e,m=J(h,a,e)*h%e,y=J(m,c,e)*m%e,B=J(y,a,e)*h%e,w=J(B,t,e)*u%e,T=J(w,i,e)*p%e,x=J(T,n,e)*f%e,A=J(x,Jo,e);if(!Xo.eql(Xo.sqr(A),r))throw new Error("Cannot find square root");return A}var Xo=xn(zc,void 0,void 0,{sqrt:bd}),We=qc({a:BigInt(0),b:BigInt(7),Fp:Xo,n:$c,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let e=$c,t=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-yd*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),s=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),o=t,i=BigInt("0x100000000000000000000000000000000"),a=Gc(o*r,e),c=Gc(-n*r,e),f=Y(r-a*t-c*s,e),u=Y(-a*n-c*o,e),l=f>i,d=u>i;if(l&&(f=e-f),d&&(u=e-u),f>i||u>i)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:l,k1:f,k2neg:d,k2:u}}}},Hc),$m=BigInt(0);var Gm=We.ProjectivePoint;function jc(){return We.utils.randomPrivateKey()}function Wc(r,e){let t=ye.digest(e instanceof Uint8Array?e:e.subarray());if(_e(t))return t.then(({digest:n})=>We.sign(n,r).toDERRawBytes()).catch(n=>{throw new C(String(n),"ERR_INVALID_INPUT")});try{return We.sign(t.digest,r).toDERRawBytes()}catch(n){throw new C(String(n),"ERR_INVALID_INPUT")}}function Yc(r,e,t){let n=ye.digest(t instanceof Uint8Array?t:t.subarray());if(_e(n))return n.then(({digest:s})=>We.verify(e,s,r)).catch(s=>{throw new C(String(s),"ERR_INVALID_INPUT")});try{return We.verify(e,n.digest,r)}catch(s){throw new C(String(s),"ERR_INVALID_INPUT")}}function Zc(r){return We.ProjectivePoint.fromHex(r).toRawBytes(!0)}function Jc(r){try{We.getPublicKey(r,!0)}catch(e){throw new C(String(e),"ERR_INVALID_PRIVATE_KEY")}}function Qo(r){try{We.ProjectivePoint.fromHex(r)}catch(e){throw new C(String(e),"ERR_INVALID_PUBLIC_KEY")}}function Xc(r){try{return We.getPublicKey(r,!0)}catch(e){throw new C(String(e),"ERR_INVALID_PRIVATE_KEY")}}var Qr=class{_key;constructor(e){Qo(e),this._key=e}verify(e,t){return Yc(this._key,t,e)}marshal(){return Zc(this._key)}get bytes(){return Xe.encode({Type:X.Secp256k1,Data:this.marshal()}).subarray()}equals(e){return de(this.bytes,e.bytes)}async hash(){let e=ye.digest(this.bytes),t;return _e(e)?{bytes:t}=await e:t=e.bytes,t}},en=class{_key;_publicKey;constructor(e,t){this._key=e,this._publicKey=t??Xc(e),Jc(this._key),Qo(this._publicKey)}sign(e){return Wc(this._key,e)}get public(){return new Qr(this._publicKey)}marshal(){return this._key}get bytes(){return Qe.encode({Type:X.Secp256k1,Data:this.marshal()}).subarray()}equals(e){return de(this.bytes,e.bytes)}hash(){let e=ye.digest(this.bytes);return _e(e)?e.then(({bytes:t})=>t):e.bytes}async id(){let e=await this.public.hash();return K(e,"base58btc")}async export(e,t="libp2p-key"){if(t==="libp2p-key")return br(this.bytes,e);throw new C(`export format '${t}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function xd(r){return new en(r)}function vd(r){return new Qr(r)}async function Ed(){let r=jc();return new en(r)}var er={rsa:Yo,ed25519:Mo,secp256k1:ei};function Qc(r){let e=Object.keys(er).join(" / ");return new C(`invalid or unsupported key type ${r}. Must be ${e}`,"ERR_UNSUPPORTED_KEY_TYPE")}function el(r){let e=Xe.decode(r),t=e.Data??new Uint8Array;switch(e.Type){case X.RSA:return er.rsa.unmarshalRsaPublicKey(t);case X.Ed25519:return er.ed25519.unmarshalEd25519PublicKey(t);case X.Secp256k1:return er.secp256k1.unmarshalSecp256k1PublicKey(t);default:throw Qc(e.Type??"unknown")}}async function tl(r){let e=Qe.decode(r),t=e.Data??new Uint8Array;switch(e.Type){case X.RSA:return er.rsa.unmarshalRsaPrivateKey(t);case X.Ed25519:return er.ed25519.unmarshalEd25519PrivateKey(t);case X.Secp256k1:return er.secp256k1.unmarshalSecp256k1PrivateKey(t);default:throw Qc(e.Type??"RSA")}}var Bd=Math.pow(2,7),Ad=Math.pow(2,14),Id=Math.pow(2,21),ti=Math.pow(2,28),ri=Math.pow(2,35),ni=Math.pow(2,42),si=Math.pow(2,49),z=128,Ee=127;function Ue(r){if(r<Bd)return 1;if(r<Ad)return 2;if(r<Id)return 3;if(r<ti)return 4;if(r<ri)return 5;if(r<ni)return 6;if(r<si)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function Sd(r,e,t=0){switch(Ue(r)){case 8:e[t++]=r&255|z,r/=128;case 7:e[t++]=r&255|z,r/=128;case 6:e[t++]=r&255|z,r/=128;case 5:e[t++]=r&255|z,r/=128;case 4:e[t++]=r&255|z,r>>>=7;case 3:e[t++]=r&255|z,r>>>=7;case 2:e[t++]=r&255|z,r>>>=7;case 1:{e[t++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return e}function kd(r,e,t=0){switch(Ue(r)){case 8:e.set(t++,r&255|z),r/=128;case 7:e.set(t++,r&255|z),r/=128;case 6:e.set(t++,r&255|z),r/=128;case 5:e.set(t++,r&255|z),r/=128;case 4:e.set(t++,r&255|z),r>>>=7;case 3:e.set(t++,r&255|z),r>>>=7;case 2:e.set(t++,r&255|z),r>>>=7;case 1:{e.set(t++,r&255),r>>>=7;break}default:throw new Error("unreachable")}return e}function Nd(r,e){let t=r[e],n=0;if(n+=t&Ee,t<z||(t=r[e+1],n+=(t&Ee)<<7,t<z)||(t=r[e+2],n+=(t&Ee)<<14,t<z)||(t=r[e+3],n+=(t&Ee)<<21,t<z)||(t=r[e+4],n+=(t&Ee)*ti,t<z)||(t=r[e+5],n+=(t&Ee)*ri,t<z)||(t=r[e+6],n+=(t&Ee)*ni,t<z)||(t=r[e+7],n+=(t&Ee)*si,t<z))return n;throw new RangeError("Could not decode varint")}function Rd(r,e){let t=r.get(e),n=0;if(n+=t&Ee,t<z||(t=r.get(e+1),n+=(t&Ee)<<7,t<z)||(t=r.get(e+2),n+=(t&Ee)<<14,t<z)||(t=r.get(e+3),n+=(t&Ee)<<21,t<z)||(t=r.get(e+4),n+=(t&Ee)*ti,t<z)||(t=r.get(e+5),n+=(t&Ee)*ri,t<z)||(t=r.get(e+6),n+=(t&Ee)*ni,t<z)||(t=r.get(e+7),n+=(t&Ee)*si,t<z))return n;throw new RangeError("Could not decode varint")}function Pe(r,e,t=0){return e==null&&(e=Se(Ue(r))),e instanceof Uint8Array?Sd(r,e,t):kd(r,e,t)}function Et(r,e=0){return r instanceof Uint8Array?Nd(r,e):Rd(r,e)}var nl=Symbol.for("@achingbrain/uint8arraylist");function rl(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 ws(r){return!!r?.[nl]}var Ye=class r{bufs;length;[nl]=!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(ws(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(ws(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=rl(this.bufs,e);return t.buf[t.index]}set(e,t){let n=rl(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(ws(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 Be(n,s)}subarray(e,t){let{bufs:n,length:s}=this._subList(e,t);return n.length===1?n[0]:Be(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,u=t>a&&t<=c;if(f&&u){if(e===a&&t===c){n.push(i);break}let l=e-a;n.push(i.subarray(l,l+(t-e)));break}if(f){if(e===0){n.push(i);continue}n.push(i.subarray(e-a));continue}if(u){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(!ws(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 l=0;l<o;l++)i[l]=-1;for(let l=0;l<s;l++)i[n[l]]=l;let a=i,c=this.byteLength-n.byteLength,f=n.byteLength-1,u;for(let l=t;l<=c;l+=u){u=0;for(let d=f;d>=0;d--){let b=this.get(l+d);if(n[d]!==b){u=Math.max(1,d-a[b]);break}}if(u===0)return l}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=Se(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=ct(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=ct(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=ct(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=Se(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=ct(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=ct(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=ct(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=ct(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=ct(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(!de(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 sl={ERR_SIGNATURE_NOT_VALID:"ERR_SIGNATURE_NOT_VALID"};var tn;(function(r){let e;r.codec=()=>(e==null&&(e=Ge((t,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),t.publicKey!=null&&t.publicKey.byteLength>0&&(n.uint32(10),n.bytes(t.publicKey)),t.payloadType!=null&&t.payloadType.byteLength>0&&(n.uint32(18),n.bytes(t.payloadType)),t.payload!=null&&t.payload.byteLength>0&&(n.uint32(26),n.bytes(t.payload)),t.signature!=null&&t.signature.byteLength>0&&(n.uint32(42),n.bytes(t.signature)),s.lengthDelimited!==!1&&n.ldelim()},(t,n)=>{let s={publicKey:new Uint8Array(0),payloadType:new Uint8Array(0),payload:new Uint8Array(0),signature: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.publicKey=t.bytes();break;case 2:s.payloadType=t.bytes();break;case 3:s.payload=t.bytes();break;case 5:s.signature=t.bytes();break;default:t.skipType(i&7);break}}return s})),e),r.encode=t=>$e(t,r.codec()),r.decode=t=>qe(t,r.codec())})(tn||(tn={}));var Ht=class r{static createFromProtobuf=async e=>{let t=tn.decode(e),n=await Ur(t.publicKey);return new r({peerId:n,payloadType:t.payloadType,payload:t.payload,signature:t.signature})};static seal=async(e,t)=>{if(t.privateKey==null)throw new Error("Missing private key");let n=e.domain,s=e.codec,o=e.marshal(),i=ol(n,s,o),c=await(await tl(t.privateKey)).sign(i.subarray());return new r({peerId:t,payloadType:s,payload:o,signature:c})};static openAndCertify=async(e,t)=>{let n=await r.createFromProtobuf(e);if(!await n.validate(t))throw new C("envelope signature is not valid for the given domain",sl.ERR_SIGNATURE_NOT_VALID);return n};peerId;payloadType;payload;signature;marshaled;constructor(e){let{peerId:t,payloadType:n,payload:s,signature:o}=e;this.peerId=t,this.payloadType=n,this.payload=s,this.signature=o}marshal(){if(this.peerId.publicKey==null)throw new Error("Missing public key");return this.marshaled==null&&(this.marshaled=tn.encode({publicKey:this.peerId.publicKey,payloadType:this.payloadType,payload:this.payload.subarray(),signature:this.signature})),this.marshaled}equals(e){return de(this.marshal(),e.marshal())}async validate(e){let t=ol(e,this.payloadType,this.payload);if(this.peerId.publicKey==null)throw new Error("Missing public key");return el(this.peerId.publicKey).verify(t.subarray(),this.signature)}},ol=(r,e,t)=>{let n=F(r),s=Pe(n.byteLength),o=Pe(e.length),i=Pe(t.length);return new Ye(s,n,o,e,i,t)};function il(r,e){let t=(n,s)=>n.toString().localeCompare(s.toString());return r.length!==e.length?!1:(e.sort(t),r.sort(t).every((n,s)=>e[s].equals(n)))}var xs=class{index=0;input="";new(e){return this.index=0,this.input=e,this}readAtomically(e){let t=this.index,n=e();return n===void 0&&(this.index=t),n}parseWith(e){let t=e();if(this.index===this.input.length)return t}peekChar(){if(!(this.index>=this.input.length))return this.input[this.index]}readChar(){if(!(this.index>=this.input.length))return this.input[this.index++]}readGivenChar(e){return this.readAtomically(()=>{let t=this.readChar();if(t===e)return t})}readSeparator(e,t,n){return this.readAtomically(()=>{if(!(t>0&&this.readGivenChar(e)===void 0))return n()})}readNumber(e,t,n,s){return this.readAtomically(()=>{let o=0,i=0,a=this.peekChar();if(a===void 0)return;let c=a==="0",f=2**(8*s)-1;for(;;){let u=this.readAtomically(()=>{let l=this.readChar();if(l===void 0)return;let d=Number.parseInt(l,e);if(!Number.isNaN(d))return d});if(u===void 0)break;if(o*=e,o+=u,o>f||(i+=1,t!==void 0&&i>t))return}if(i!==0)return!n&&c&&i>1?void 0:o})}readIPv4Addr(){return this.readAtomically(()=>{let e=new Uint8Array(4);for(let t=0;t<e.length;t++){let n=this.readSeparator(".",t,()=>this.readNumber(10,3,!1,1));if(n===void 0)return;e[t]=n}return e})}readIPv6Addr(){let e=t=>{for(let n=0;n<t.length/2;n++){let s=n*2;if(n<t.length-3){let i=this.readSeparator(":",n,()=>this.readIPv4Addr());if(i!==void 0)return t[s]=i[0],t[s+1]=i[1],t[s+2]=i[2],t[s+3]=i[3],[s+4,!0]}let o=this.readSeparator(":",n,()=>this.readNumber(16,4,!0,2));if(o===void 0)return[s,!1];t[s]=o>>8,t[s+1]=o&255}return[t.length,!1]};return this.readAtomically(()=>{let t=new Uint8Array(16),[n,s]=e(t);if(n===16)return t;if(s||this.readGivenChar(":")===void 0||this.readGivenChar(":")===void 0)return;let o=new Uint8Array(14),i=16-(n+2),[a]=e(o.subarray(0,i));return t.set(o.subarray(0,a),16-a),t})}readIPAddr(){return this.readIPv4Addr()??this.readIPv6Addr()}};var al=45,Td=15,Sr=new xs;function oi(r){if(!(r.length>Td))return Sr.new(r).parseWith(()=>Sr.readIPv4Addr())}function ii(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>al))return Sr.new(r).parseWith(()=>Sr.readIPv6Addr())}function vs(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>al))return Sr.new(r).parseWith(()=>Sr.readIPAddr())}var Cy=parseInt("0xFFFF",16),Ly=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);function Es(r){return!!oi(r)}function Bs(r){return!!ii(r)}function As(r){return!!vs(r)}var ul=Es,Pd=Bs,ai=function(r){let e=0;if(r=r.toString().trim(),ul(r)){let t=new Uint8Array(e+4);return r.split(/\./g).forEach(n=>{t[e++]=parseInt(n,10)&255}),t}if(Pd(r)){let t=r.split(":",8),n;for(n=0;n<t.length;n++){let o=ul(t[n]),i;o&&(i=ai(t[n]),t[n]=K(i.slice(0,2),"base16")),i!=null&&++n<8&&t.splice(n,0,K(i.slice(2,4),"base16"))}if(t[0]==="")for(;t.length<8;)t.unshift("0");else if(t[t.length-1]==="")for(;t.length<8;)t.push("0");else if(t.length<8){for(n=0;n<t.length&&t[n]!=="";n++);let o=[n,1];for(n=9-t.length;n>0;n--)o.push("0");t.splice.apply(t,o)}let s=new Uint8Array(e+16);for(n=0;n<t.length;n++){let o=parseInt(t[n],16);s[e++]=o>>8&255,s[e++]=o&255}return s}throw new Error("invalid ip address")},fl=function(r,e=0,t){e=~~e,t=t??r.length-e;let n=new DataView(r.buffer);if(t===4){let s=[];for(let o=0;o<t;o++)s.push(r[e+o]);return s.join(".")}if(t===16){let s=[];for(let o=0;o<t;o+=2)s.push(n.getUint16(e+o).toString(16));return s.join(":").replace(/(^|:)0(:0)*:0(:|$)/,"$1::$3").replace(/:{3,4}/,"::")}return""};var kr={},ci={},Vd=[[4,32,"ip4"],[6,16,"tcp"],[33,16,"dccp"],[41,128,"ip6"],[42,-1,"ip6zone"],[43,8,"ipcidr"],[53,-1,"dns",!0],[54,-1,"dns4",!0],[55,-1,"dns6",!0],[56,-1,"dnsaddr",!0],[132,16,"sctp"],[273,16,"udp"],[275,0,"p2p-webrtc-star"],[276,0,"p2p-webrtc-direct"],[277,0,"p2p-stardust"],[280,0,"webrtc-direct"],[281,0,"webrtc"],[290,0,"p2p-circuit"],[301,0,"udt"],[302,0,"utp"],[400,-1,"unix",!1,!0],[421,-1,"ipfs"],[421,-1,"p2p"],[443,0,"https"],[444,96,"onion"],[445,296,"onion3"],[446,-1,"garlic64"],[448,0,"tls"],[449,-1,"sni"],[460,0,"quic"],[461,0,"quic-v1"],[465,0,"webtransport"],[466,-1,"certhash"],[477,0,"ws"],[478,0,"wss"],[479,0,"p2p-websocket-star"],[480,0,"http"],[777,-1,"memory"]];Vd.forEach(r=>{let e=Dd(...r);ci[e.code]=e,kr[e.name]=e});function Dd(r,e,t,n,s){return{code:r,size:e,name:t,resolvable:!!n,path:!!s}}function j(r){if(typeof r=="number"){if(ci[r]!=null)return ci[r];throw new Error(`no protocol with code: ${r}`)}else if(typeof r=="string"){if(kr[r]!=null)return kr[r];throw new Error(`no protocol with name: ${r}`)}throw new Error(`invalid protocol id type: ${typeof r}`)}var mb=j("ip4"),yb=j("ip6"),bb=j("ipcidr");function ui(r,e){switch(j(r).code){case 4:case 41:return Hd(e);case 42:return pl(e);case 6:case 273:case 33:case 132:return ml(e).toString();case 53:case 54:case 55:case 56:case 400:case 449:case 777:return pl(e);case 421:return $d(e);case 444:return gl(e);case 445:return gl(e);case 466:return qd(e);default:return K(e,"base16")}}function fi(r,e){switch(j(r).code){case 4:return hl(e);case 41:return hl(e);case 42:return dl(e);case 6:case 273:case 33:case 132:return hi(parseInt(e,10));case 53:case 54:case 55:case 56:case 400:case 449:case 777:return dl(e);case 421:return Fd(e);case 444:return Gd(e);case 445:return zd(e);case 466:return Kd(e);default:return F(e,"base16")}}var li=Object.values(St).map(r=>r.decoder),Md=function(){let r=li[0].or(li[1]);return li.slice(2).forEach(e=>r=r.or(e)),r}();function hl(r){if(!As(r))throw new Error("invalid ip address");return ai(r)}function Hd(r){let e=fl(r,0,r.length);if(e==null)throw new Error("ipBuff is required");if(!As(e))throw new Error("invalid ip address");return e}function hi(r){let e=new ArrayBuffer(2);return new DataView(e).setUint16(0,r),new Uint8Array(e)}function ml(r){return new DataView(r.buffer).getUint16(r.byteOffset)}function dl(r){let e=F(r),t=Uint8Array.from(Pe(e.length));return Be([t,e],t.length+e.length)}function pl(r){let e=Et(r);if(r=r.slice(Ue(e)),r.length!==e)throw new Error("inconsistent lengths");return K(r)}function Fd(r){let e;r[0]==="Q"||r[0]==="1"?e=qt(ne.decode(`z${r}`)).bytes:e=De.parse(r).multihash.bytes;let t=Uint8Array.from(Pe(e.length));return Be([t,e],t.length+e.length)}function Kd(r){let e=Md.decode(r),t=Uint8Array.from(Pe(e.length));return Be([t,e],t.length+e.length)}function qd(r){let e=Et(r),t=r.slice(Ue(e));if(t.length!==e)throw new Error("inconsistent lengths");return"u"+K(t,"base64url")}function $d(r){let e=Et(r),t=r.slice(Ue(e));if(t.length!==e)throw new Error("inconsistent lengths");return K(t,"base58btc")}function Gd(r){let e=r.split(":");if(e.length!==2)throw new Error(`failed to parse onion addr: ["'${e.join('", "')}'"]' does not contain a port number`);if(e[0].length!==16)throw new Error(`failed to parse onion addr: ${e[0]} not a Tor onion address.`);let t=at.decode("b"+e[0]),n=parseInt(e[1],10);if(n<1||n>65536)throw new Error("Port number is not in range(1, 65536)");let s=hi(n);return Be([t,s],t.length+s.length)}function zd(r){let e=r.split(":");if(e.length!==2)throw new Error(`failed to parse onion addr: ["'${e.join('", "')}'"]' does not contain a port number`);if(e[0].length!==56)throw new Error(`failed to parse onion addr: ${e[0]} not a Tor onion3 address.`);let t=at.decode(`b${e[0]}`),n=parseInt(e[1],10);if(n<1||n>65536)throw new Error("Port number is not in range(1, 65536)");let s=hi(n);return Be([t,s],t.length+s.length)}function gl(r){let e=r.slice(0,r.length-2),t=r.slice(r.length-2),n=K(e,"base32"),s=ml(t);return`${n}:${s}`}function yl(r){r=di(r);let e=[],t=[],n=null,s=r.split("/").slice(1);if(s.length===1&&s[0]==="")return{bytes:new Uint8Array,string:"/",tuples:[],stringTuples:[],path:null};for(let o=0;o<s.length;o++){let i=s[o],a=j(i);if(a.size===0){e.push([a.code]),t.push([a.code]);continue}if(o++,o>=s.length)throw wl("invalid address: "+r);if(a.path===!0){n=di(s.slice(o).join("/")),e.push([a.code,fi(a.code,n)]),t.push([a.code,n]);break}let c=fi(a.code,s[o]);e.push([a.code,c]),t.push([a.code,ui(a.code,c)])}return{string:bl(t),bytes:gi(e),tuples:e,stringTuples:t,path:n}}function pi(r){let e=[],t=[],n=null,s=0;for(;s<r.length;){let o=Et(r,s),i=Ue(o),a=j(o),c=jd(a,r.slice(s+i));if(c===0){e.push([o]),t.push([o]),s+=i;continue}let f=r.slice(s+i,s+i+c);if(s+=c+i,s>r.length)throw wl("Invalid address Uint8Array: "+K(r,"base16"));e.push([o,f]);let u=ui(o,f);if(t.push([o,u]),a.path===!0){n=u;break}}return{bytes:Uint8Array.from(r),string:bl(t),tuples:e,stringTuples:t,path:n}}function bl(r){let e=[];return r.map(t=>{let n=j(t[0]);return e.push(n.name),t.length>1&&t[1]!=null&&e.push(t[1]),null}),di(e.join("/"))}function gi(r){return Be(r.map(e=>{let t=j(e[0]),n=Uint8Array.from(Pe(t.code));return e.length>1&&e[1]!=null&&(n=Be([n,e[1]])),n}))}function jd(r,e){if(r.size>0)return r.size/8;if(r.size===0)return 0;{let t=Et(e instanceof Uint8Array?e:Uint8Array.from(e));return t+Ue(t)}}function di(r){return"/"+r.trim().split("/").filter(e=>e).join("/")}function wl(r){return new Error("Error parsing address: "+r)}var Wd=Symbol.for("nodejs.util.inspect.custom"),mi=Symbol.for("@multiformats/js-multiaddr/multiaddr"),Yd=[j("dns").code,j("dns4").code,j("dns6").code,j("dnsaddr").code],Is=class r{bytes;#e;#t;#r;#n;[mi]=!0;constructor(e){e==null&&(e="");let t;if(e instanceof Uint8Array)t=pi(e);else if(typeof e=="string"){if(e.length>0&&e.charAt(0)!=="/")throw new Error(`multiaddr "${e}" must start with a "/"`);t=yl(e)}else if(vl(e))t=pi(e.bytes);else throw new Error("addr must be a string, Buffer, or another Multiaddr");this.bytes=t.bytes,this.#e=t.string,this.#t=t.tuples,this.#r=t.stringTuples,this.#n=t.path}toString(){return this.#e}toJSON(){return this.toString()}toOptions(){let e,t,n,s,o="",i=j("tcp"),a=j("udp"),c=j("ip4"),f=j("ip6"),u=j("dns6"),l=j("ip6zone");for(let[b,p]of this.stringTuples())b===l.code&&(o=`%${p??""}`),Yd.includes(b)&&(t=i.name,s=443,n=`${p??""}${o}`,e=b===u.code?6:4),(b===i.code||b===a.code)&&(t=j(b).name,s=parseInt(p??"")),(b===c.code||b===f.code)&&(t=j(b).name,n=`${p??""}${o}`,e=b===f.code?6:4);if(e==null||t==null||n==null||s==null)throw new Error('multiaddr must have a valid format: "/{ip4, ip6, dns4, dns6, dnsaddr}/{address}/{tcp, udp}/{port}".');return{family:e,host:n,transport:t,port:s}}protos(){return this.#t.map(([e])=>Object.assign({},j(e)))}protoCodes(){return this.#t.map(([e])=>e)}protoNames(){return this.#t.map(([e])=>j(e).name)}tuples(){return this.#t}stringTuples(){return this.#r}encapsulate(e){return e=new r(e),new r(this.toString()+e.toString())}decapsulate(e){let t=e.toString(),n=this.toString(),s=n.lastIndexOf(t);if(s<0)throw new Error(`Address ${this.toString()} does not contain subaddress: ${e.toString()}`);return new r(n.slice(0,s))}decapsulateCode(e){let t=this.tuples();for(let n=t.length-1;n>=0;n--)if(t[n][0]===e)return new r(gi(t.slice(0,n)));return this}getPeerId(){try{let e=[];this.stringTuples().forEach(([n,s])=>{n===kr.p2p.code&&e.push([n,s]),n===kr["p2p-circuit"].code&&(e=[])});let t=e.pop();if(t?.[1]!=null){let n=t[1];return n[0]==="Q"||n[0]==="1"?K(ne.decode(`z${n}`),"base58btc"):K(De.parse(n).multihash.bytes,"base58btc")}return null}catch{return null}}getPath(){return this.#n}equals(e){return de(this.bytes,e.bytes)}async resolve(e){let t=this.protos().find(o=>o.resolvable);if(t==null)return[this];let n=xl.get(t.name);if(n==null)throw new C(`no available resolver for ${t.name}`,"ERR_NO_AVAILABLE_RESOLVER");return(await n(this,e)).map(o=>new r(o))}nodeAddress(){let e=this.toOptions();if(e.transport!=="tcp"&&e.transport!=="udp")throw new Error(`multiaddr must have a valid format - no protocol with name: "${e.transport}". Must have a valid transport protocol: "{tcp, udp}"`);return{family:e.family,address:e.host,port:e.port}}isThinWaistAddress(e){let t=(e??this).protos();return!(t.length!==2||t[0].code!==4&&t[0].code!==41||t[1].code!==6&&t[1].code!==273)}[Wd](){return`Multiaddr(${this.#e})`}};var xl=new Map;function vl(r){return!!r?.[mi]}function Ft(r){return new Is(r)}var El="libp2p-peer-record",Bl=Uint8Array.from([3,1]);var rn;(function(r){let e;(function(n){let s;n.codec=()=>(s==null&&(s=Ge((o,i,a={})=>{a.lengthDelimited!==!1&&i.fork(),o.multiaddr!=null&&o.multiaddr.byteLength>0&&(i.uint32(10),i.bytes(o.multiaddr)),a.lengthDelimited!==!1&&i.ldelim()},(o,i)=>{let a={multiaddr:new Uint8Array(0)},c=i==null?o.len:o.pos+i;for(;o.pos<c;){let f=o.uint32();switch(f>>>3){case 1:a.multiaddr=o.bytes();break;default:o.skipType(f&7);break}}return a})),s),n.encode=o=>$e(o,n.codec()),n.decode=o=>qe(o,n.codec())})(e=r.AddressInfo||(r.AddressInfo={}));let t;r.codec=()=>(t==null&&(t=Ge((n,s,o={})=>{if(o.lengthDelimited!==!1&&s.fork(),n.peerId!=null&&n.peerId.byteLength>0&&(s.uint32(10),s.bytes(n.peerId)),n.seq!=null&&n.seq!==0n&&(s.uint32(16),s.uint64(n.seq)),n.addresses!=null)for(let i of n.addresses)s.uint32(26),r.AddressInfo.codec().encode(i,s);o.lengthDelimited!==!1&&s.ldelim()},(n,s)=>{let o={peerId:new Uint8Array(0),seq:0n,addresses:[]},i=s==null?n.len:n.pos+s;for(;n.pos<i;){let a=n.uint32();switch(a>>>3){case 1:o.peerId=n.bytes();break;case 2:o.seq=n.uint64();break;case 3:o.addresses.push(r.AddressInfo.codec().decode(n,n.uint32()));break;default:n.skipType(a&7);break}}return o})),t),r.encode=n=>$e(n,r.codec()),r.decode=n=>qe(n,r.codec())})(rn||(rn={}));var Bt=class r{static createFromProtobuf=e=>{let t=rn.decode(e),n=ao(t.peerId),s=(t.addresses??[]).map(i=>Ft(i.multiaddr)),o=t.seq;return new r({peerId:n,multiaddrs:s,seqNumber:o})};static DOMAIN=El;static CODEC=Bl;peerId;multiaddrs;seqNumber;domain=r.DOMAIN;codec=r.CODEC;marshaled;constructor(e){let{peerId:t,multiaddrs:n,seqNumber:s}=e;this.peerId=t,this.multiaddrs=n??[],this.seqNumber=s??BigInt(Date.now())}marshal(){return this.marshaled==null&&(this.marshaled=rn.encode({peerId:this.peerId.toBytes(),seq:BigInt(this.seqNumber),addresses:this.multiaddrs.map(e=>({multiaddr:e.bytes}))})),this.marshaled}equals(e){return!(!(e instanceof r)||!this.peerId.equals(e.peerId)||this.seqNumber!==e.seqNumber||!il(this.multiaddrs,e.multiaddrs))}};var Zd=r=>r.toString().split("/").slice(1),nn=r=>({match:e=>e.length<1?!1:r(e[0])?e.slice(1):!1,pattern:"fn"}),se=r=>({match:e=>nn(t=>t===r).match(e),pattern:r}),Ns=()=>({match:r=>nn(e=>typeof e=="string").match(r),pattern:"{string}"}),Al=()=>({match:r=>nn(e=>!isNaN(parseInt(e))).match(r),pattern:"{number}"}),Oe=()=>({match:r=>{if(r.length<2||r[0]!=="p2p"&&r[0]!=="ipfs")return!1;if(r[1].startsWith("Q")||r[1].startsWith("1"))try{ne.decode(`z${r[1]}`)}catch{return!1}else return!1;return r.slice(2)},pattern:"/p2p/{peerid}"}),Ss=()=>({match:r=>{if(r.length<2||r[0]!=="certhash")return!1;try{Ys.decode(r[1])}catch{return!1}return r.slice(2)},pattern:"/certhash/{certhash}"}),nt=r=>({match:e=>{let t=r.match(e);return t===!1?e:t},pattern:`optional(${r.pattern})`}),st=(...r)=>({match:e=>{let t;for(let n of r){let s=n.match(e);s!==!1&&(t==null||s.length<t.length)&&(t=s)}return t??!1},pattern:`or(${r.map(e=>e.pattern).join(", ")})`}),oe=(...r)=>({match:e=>{for(let t of r){let n=t.match(e);if(n===!1)return!1;e=n}return e},pattern:`and(${r.map(e=>e.pattern).join(", ")})`});function fe(...r){function e(s){let o=Zd(s);for(let i of r){let a=i.match(o);if(a===!1)return!1;o=a}return o}function t(s){return e(s)!==!1}function n(s){let o=e(s);return o===!1?!1:o.length===0}return{matches:t,exactMatch:n}}var bi=oe(se("dns4"),Ns()),wi=oe(se("dns6"),Ns()),xi=oe(se("dnsaddr"),Ns()),Il=oe(se("dns"),Ns()),ow=fe(bi),iw=fe(wi),aw=fe(xi),cw=fe(st(Il,xi,bi,wi)),Sl=oe(se("ip4"),nn(Es)),kl=oe(se("ip6"),nn(Bs)),Nl=st(Sl,kl),sn=st(Nl,Il,bi,wi,xi),Rl=fe(sn),lw=fe(Sl),uw=fe(kl),fw=fe(Nl),Rs=oe(sn,se("tcp"),Al()),on=oe(sn,se("udp"),Al()),Jd=st(Rs,on),hw=fe(Rs),dw=fe(on),vi=oe(on,se("quic")),Ts=oe(on,se("quic-v1")),Xd=st(vi,Ts),pw=fe(vi),gw=fe(Ts),yi=st(sn,Rs,on,vi,Ts),Tl=st(oe(yi,se("ws"),nt(Oe()))),mw=fe(Tl),_l=st(oe(yi,se("wss"),nt(Oe())),oe(yi,se("tls"),se("ws"),nt(Oe()))),yw=fe(_l),Cl=oe(Jd,se("webrtc-direct"),Ss(),nt(Ss()),nt(Oe())),bw=fe(Cl),Ll=oe(Ts,se("webtransport"),Ss(),Ss(),nt(Oe())),ww=fe(Ll),ks=st(Tl,_l,oe(Rs,nt(Oe())),oe(Xd,nt(Oe())),oe(sn,nt(Oe())),Cl,Ll,Oe()),xw=fe(ks),Qd=oe(ks,se("p2p-circuit"),Oe()),vw=fe(Qd),e0=st(oe(ks,se("p2p-circuit"),se("webrtc"),Oe()),oe(ks,se("webrtc"),nt(Oe())),se("webrtc")),Ew=fe(e0);function Nr(){let r={};return r.promise=new Promise((e,t)=>{r.resolve=e,r.reject=t}),r}var _s=class extends Error{type;code;constructor(e,t){super(e??"The operation was aborted"),this.type="aborted",this.name="AbortError",this.code=t??"ABORT_ERR"}};async function Ul(r,e,t){if(e==null)return r;if(e.aborted)return Promise.reject(new _s(t?.errorMessage,t?.errorCode));let n,s=new _s(t?.errorMessage,t?.errorCode);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 Ei=class{needNext;haveNext;ended;nextResult;constructor(){this.ended=!1,this.needNext=Nr(),this.haveNext=Nr()}[Symbol.asyncIterator](){return this}async next(){if(this.nextResult==null&&await this.haveNext.promise,this.nextResult==null)throw new Error("Have next but next was undefined");let e=this.nextResult;return this.nextResult=void 0,this.needNext.resolve(),this.needNext=Nr(),e}async throw(e){return this.ended=!0,e!=null&&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");this.nextResult!=null&&await this.needNext.promise,e!=null?this.nextResult={done:!1,value:e}:(this.ended=!0,this.nextResult={done:!0,value:void 0}),this.haveNext.resolve(),this.haveNext=Nr(),await Ul(this.needNext.promise,t?.signal,t)}};function Pl(){return new Ei}var Cs=class extends Error{code;constructor(e,t){super(e),this.code=t}},Bi=class extends Cs{type;constructor(e){super(e,"ABORT_ERR"),this.type="aborted"}};function Ol(r,e){let t=Pl();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 Ye;return{read:async(i,a)=>{a?.signal?.throwIfAborted();let c,f=new Promise((u,l)=>{c=()=>{l(new Bi("Read aborted"))},a?.signal?.addEventListener("abort",c)});try{if(i==null){let{done:l,value:d}=await Promise.race([n.next(),f]);return l===!0?new Ye:d}for(;s.byteLength<i;){let{value:l,done:d}=await Promise.race([n.next(),f]);if(d===!0)throw new Cs("unexpected end of input","ERR_UNEXPECTED_EOF");s.append(l)}let u=s.sublist(0,i);return s.consume(i),u}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 Ls=class extends Error{code;constructor(e,t){super(e),this.code=t}};function Vl(r,e={}){let t=Ol(r,e);e.maxDataLength!=null&&e.maxLengthLength==null&&(e.maxLengthLength=Ue(e.maxDataLength));let n=e?.lengthDecoder??Et,s=e?.lengthEncoder??Pe;return{read:async i=>{let a=-1,c=new Ye;for(;;){c.append(await t.read(1,i));try{a=n(c)}catch(f){if(f instanceof RangeError)continue;throw f}if(e?.maxLengthLength!=null&&c.byteLength>e.maxLengthLength)throw new Ls("message length length too long","ERR_MSG_LENGTH_TOO_LONG");if(a>-1)break}if(e?.maxDataLength!=null&&a>e.maxDataLength)throw new Ls("message length too long","ERR_MSG_DATA_TOO_LONG");return t.read(a,i)},write:async(i,a)=>{await t.write(new Ye(s(i.byteLength),i),a)},writeV:async(i,a)=>{let c=new Ye(...i.flatMap(f=>[s(f.byteLength),f]));await t.write(c,a)},unwrap:()=>t.unwrap()}}function an(r,e){let t=Vl(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 Hl=Oi(Ml(),1),Ai=typeof window=="object"&&typeof document=="object"&&document.nodeType===9,Us=(0,Hl.default)(),Fl=Ai&&!Us,Kl=Us&&!Ai,ql=Us&&Ai,$l=typeof globalThis.process<"u"&&typeof globalThis.process.release<"u"&&globalThis.process.release.name==="node"&&!Us,Gl=typeof importScripts=="function"&&typeof self<"u"&&typeof WorkerGlobalScope<"u"&&self instanceof WorkerGlobalScope,Mw=typeof globalThis.process<"u"&&typeof globalThis.process.env<"u"&&globalThis.process.env["NODE"+"_"+"ENV"]==="test",zl=typeof navigator<"u"&&navigator.product==="ReactNative";var tr;(function(r){let e;r.codec=()=>(e==null&&(e=Ge((t,n,s={})=>{if(s.lengthDelimited!==!1&&n.fork(),t.protocolVersion!=null&&(n.uint32(42),n.string(t.protocolVersion)),t.agentVersion!=null&&(n.uint32(50),n.string(t.agentVersion)),t.publicKey!=null&&(n.uint32(10),n.bytes(t.publicKey)),t.listenAddrs!=null)for(let o of t.listenAddrs)n.uint32(18),n.bytes(o);if(t.observedAddr!=null&&(n.uint32(34),n.bytes(t.observedAddr)),t.protocols!=null)for(let o of t.protocols)n.uint32(26),n.string(o);t.signedPeerRecord!=null&&(n.uint32(66),n.bytes(t.signedPeerRecord)),s.lengthDelimited!==!1&&n.ldelim()},(t,n)=>{let s={listenAddrs:[],protocols:[]},o=n==null?t.len:t.pos+n;for(;t.pos<o;){let i=t.uint32();switch(i>>>3){case 5:s.protocolVersion=t.string();break;case 6:s.agentVersion=t.string();break;case 1:s.publicKey=t.bytes();break;case 2:s.listenAddrs.push(t.bytes());break;case 4:s.observedAddr=t.bytes();break;case 3:s.protocols.push(t.string());break;case 8:s.signedPeerRecord=t.bytes();break;default:t.skipType(i&7);break}}return s})),e),r.encode=t=>$e(t,r.codec()),r.decode=t=>qe(t,r.codec())})(tr||(tr={}));var Ii=1024*8,Ve={protocolPrefix:"ipfs",timeout:6e4,maxInboundStreams:1,maxOutboundStreams:1,maxPushIncomingStreams:1,maxPushOutgoingStreams:1,maxObservedAddresses:10,maxIdentifyMessageSize:8192,runOnConnectionOpen:!0,runOnTransientConnection:!0},Ps=class{identifyProtocolStr;identifyPushProtocolStr;host;started;timeout;peerId;peerStore;registrar;connectionManager;addressManager;maxInboundStreams;maxOutboundStreams;maxPushIncomingStreams;maxPushOutgoingStreams;maxIdentifyMessageSize;maxObservedAddresses;events;runOnTransientConnection;log;constructor(e,t={}){this.started=!1,this.peerId=e.peerId,this.peerStore=e.peerStore,this.registrar=e.registrar,this.addressManager=e.addressManager,this.connectionManager=e.connectionManager,this.events=e.events,this.log=e.logger.forComponent("libp2p:identify"),this.identifyProtocolStr=`/${t.protocolPrefix??Ve.protocolPrefix}/${Hi}/${Ki}`,this.identifyPushProtocolStr=`/${t.protocolPrefix??Ve.protocolPrefix}/${Fi}/${qi}`,this.timeout=t.timeout??Ve.timeout,this.maxInboundStreams=t.maxInboundStreams??Ve.maxInboundStreams,this.maxOutboundStreams=t.maxOutboundStreams??Ve.maxOutboundStreams,this.maxPushIncomingStreams=t.maxPushIncomingStreams??Ve.maxPushIncomingStreams,this.maxPushOutgoingStreams=t.maxPushOutgoingStreams??Ve.maxPushOutgoingStreams,this.maxIdentifyMessageSize=t.maxIdentifyMessageSize??Ve.maxIdentifyMessageSize,this.maxObservedAddresses=t.maxObservedAddresses??Ve.maxObservedAddresses,this.runOnTransientConnection=t.runOnTransientConnection??Ve.runOnTransientConnection,this.host={protocolVersion:`${t.protocolPrefix??Ve.protocolPrefix}/${Mi}`,agentVersion:t.agentVersion??`${e.nodeInfo.name}/${e.nodeInfo.version}`},(t.runOnConnectionOpen??Ve.runOnConnectionOpen)&&e.events.addEventListener("connection:open",n=>{let s=n.detail;this.identify(s).catch(o=>{this.log.error("error during identify trigged by connection:open",o)})}),e.events.addEventListener("self:peer:update",n=>{this.push().catch(s=>{this.log.error(s)})}),this.host.agentVersion===`${e.nodeInfo.name}/${e.nodeInfo.version}`&&($l||Kl?this.host.agentVersion+=` UserAgent=${globalThis.process.version}`:(Fl||Gl||ql||zl)&&(this.host.agentVersion+=` UserAgent=${globalThis.navigator.userAgent}`))}isStarted(){return this.started}async start(){this.started||(await this.peerStore.merge(this.peerId,{metadata:{AgentVersion:F(this.host.agentVersion),ProtocolVersion:F(this.host.protocolVersion)}}),await this.registrar.handle(this.identifyProtocolStr,e=>{this._handleIdentify(e).catch(t=>{this.log.error(t)})},{maxInboundStreams:this.maxInboundStreams,maxOutboundStreams:this.maxOutboundStreams,runOnTransientConnection:this.runOnTransientConnection}),await this.registrar.handle(this.identifyPushProtocolStr,e=>{this._handlePush(e).catch(t=>{this.log.error(t)})},{maxInboundStreams:this.maxPushIncomingStreams,maxOutboundStreams:this.maxPushOutgoingStreams,runOnTransientConnection:this.runOnTransientConnection}),this.started=!0)}async stop(){await this.registrar.unhandle(this.identifyProtocolStr),await this.registrar.unhandle(this.identifyPushProtocolStr),this.started=!1}async pushToConnections(e){let t=this.addressManager.getAddresses().map(u=>u.decapsulateCode(j("p2p").code)),n=new Bt({peerId:this.peerId,multiaddrs:t}),s=await Ht.seal(n,this.peerId),o=this.registrar.getProtocols(),i=await this.peerStore.get(this.peerId),a=K(i.metadata.get("AgentVersion")??F(this.host.agentVersion)),c=K(i.metadata.get("ProtocolVersion")??F(this.host.protocolVersion)),f=e.map(async u=>{let l,d=AbortSignal.timeout(this.timeout);ln(1/0,d);try{l=await u.newStream(this.identifyPushProtocolStr,{signal:d,runOnTransientConnection:this.runOnTransientConnection}),await an(l,{maxDataLength:this.maxIdentifyMessageSize??Ii}).pb(tr).write({listenAddrs:t.map(p=>p.bytes),signedPeerRecord:s.marshal(),protocols:o,agentVersion:a,protocolVersion:c},{signal:d}),await l.close({signal:d})}catch(b){this.log.error("could not push identify update to peer",b),l?.abort(b)}});await Promise.all(f)}async push(){if(!this.isStarted())return;let e=[];await Promise.all(this.connectionManager.getConnections().map(async t=>{try{if(!(await this.peerStore.get(t.remotePeer)).protocols.includes(this.identifyPushProtocolStr))return;e.push(t)}catch(n){if(n.code!==Gi)throw n}})),await this.pushToConnections(e)}async _identify(e,t={}){let n;if(t.signal==null){let s=AbortSignal.timeout(this.timeout);ln(1/0,s),t={...t,signal:s}}try{n=await e.newStream(this.identifyProtocolStr,{...t,runOnTransientConnection:this.runOnTransientConnection});let o=await an(n,{maxDataLength:this.maxIdentifyMessageSize??Ii}).pb(tr).read(t);return await n.close(t),o}catch(s){throw this.log.error("error while reading identify message",s),n?.abort(s),s}}async identify(e,t={}){let n=await this._identify(e,t),{publicKey:s,protocols:o,observedAddr:i}=n;if(s==null)throw new C("public key was missing from identify message","ERR_MISSING_PUBLIC_KEY");let a=await Ur(s);if(!e.remotePeer.equals(a))throw new C("identified peer does not match the expected peer","ERR_INVALID_PEER");if(this.peerId.equals(a))throw new C("identified peer is our own peer id?","ERR_INVALID_PEER");let c=r0(i);return this.log("identify completed for peer %p and protocols %o",a,o),this.log("our observed address is %a",c),c!=null&&this.addressManager.getObservedAddrs().length<(this.maxObservedAddresses??1/0)&&(this.log("storing our observed address %a",c),this.addressManager.addObservedAddr(c)),this.#e(e,n)}async _handleIdentify(e){let{connection:t,stream:n}=e,s=AbortSignal.timeout(this.timeout);ln(1/0,s);try{let o=this.peerId.publicKey??new Uint8Array(0),i=await this.peerStore.get(this.peerId),a=this.addressManager.getAddresses().map(l=>l.decapsulateCode(j("p2p").code)),c=i.peerRecordEnvelope;if(a.length>0&&c==null){let l=new Bt({peerId:this.peerId,multiaddrs:a});c=(await Ht.seal(l,this.peerId)).marshal().subarray()}let f=t.remoteAddr.bytes;Rl.matches(t.remoteAddr)||(f=void 0),await an(n).pb(tr).write({protocolVersion:this.host.protocolVersion,agentVersion:this.host.agentVersion,publicKey:o,listenAddrs:a.map(l=>l.bytes),signedPeerRecord:c,observedAddr:f,protocols:i.protocols},{signal:s}),await n.close({signal:s})}catch(o){this.log.error("could not respond to identify request",o),n.abort(o)}}async _handlePush(e){let{connection:t,stream:n}=e;try{if(this.peerId.equals(t.remotePeer))throw new Error("received push from ourselves?");let s={signal:AbortSignal.timeout(this.timeout)},i=await an(n,{maxDataLength:this.maxIdentifyMessageSize??Ii}).pb(tr).read(s);await n.close(s),await this.#e(t,i)}catch(s){this.log.error("received invalid message",s),n.abort(s);return}this.log("handled push from %p",t.remotePeer)}async#e(e,t){if(this.log("received identify from %p",e.remotePeer),t==null)throw new C("message was null or undefined","ERR_INVALID_MESSAGE");let n={};if(t.listenAddrs.length>0&&(n.addresses=t.listenAddrs.map(i=>({isCertified:!1,multiaddr:Ft(i)}))),t.protocols.length>0&&(n.protocols=t.protocols),t.publicKey!=null&&(n.publicKey=t.publicKey,!(await Ur(t.publicKey)).equals(e.remotePeer)))throw new C("public key did not match remote PeerId","ERR_INVALID_PUBLIC_KEY");let s;if(t.signedPeerRecord!=null){this.log("received signedPeerRecord from %p",e.remotePeer);let i=t.signedPeerRecord,a=await Ht.openAndCertify(i,Bt.DOMAIN),c=Bt.createFromProtobuf(a.payload);if(!c.peerId.equals(a.peerId))throw new C("signing key does not match PeerId in the PeerRecord","ERR_INVALID_SIGNING_KEY");if(!e.remotePeer.equals(c.peerId))throw new C("signing key does not match remote PeerId","ERR_INVALID_PEER_RECORD_KEY");let f;try{f=await this.peerStore.get(c.peerId)}catch(u){if(u.code!=="ERR_NOT_FOUND")throw u}if(f!=null&&(n.metadata=f.metadata,f.peerRecordEnvelope!=null)){let u=await Ht.createFromProtobuf(f.peerRecordEnvelope),l=Bt.createFromProtobuf(u.payload);l.seqNumber>=c.seqNumber&&(this.log("sequence number was lower or equal to existing sequence number - stored: %d received: %d",l.seqNumber,c.seqNumber),c=l,i=f.peerRecordEnvelope)}n.peerRecordEnvelope=i,n.addresses=c.multiaddrs.map(u=>({isCertified:!0,multiaddr:u})),s={seq:c.seqNumber,addresses:c.multiaddrs}}else this.log("%p did not send a signed peer record",e.remotePeer);if(this.log("patching %p with",e.remotePeer,n),await this.peerStore.patch(e.remotePeer,n),t.agentVersion!=null||t.protocolVersion!=null){let i={};t.agentVersion!=null&&(i.AgentVersion=F(t.agentVersion)),t.protocolVersion!=null&&(i.ProtocolVersion=F(t.protocolVersion)),this.log("merging %p metadata",e.remotePeer,i),await this.peerStore.merge(e.remotePeer,{metadata:i})}let o={peerId:e.remotePeer,protocolVersion:t.protocolVersion,agentVersion:t.agentVersion,publicKey:t.publicKey,listenAddrs:t.listenAddrs.map(i=>Ft(i)),observedAddr:t.observedAddr==null?void 0:Ft(t.observedAddr),protocols:t.protocols,signedPeerRecord:s,connection:e};return this.events.safeDispatchEvent("peer:identify",{detail:o}),o}};function r0(r){if(r!=null&&r.length>0)try{return Ft(r)}catch{}}var n0={IDENTIFY:Vi,IDENTIFY_PUSH:Di};function s0(r={}){return e=>new Ps(e,r)}return iu(o0);})();
|
|
6
|
+
`)}`:`${t} :`}};oc=Pt;I.Constructed=oc;Pt.NAME="CONSTRUCTED";var Mn=class extends Be{fromBER(e,t,n){return t}toBER(e){return je}};Mn.override="EndOfContentValueBlock";var ic,Hn=class extends be{constructor(e={}){super(e,Mn),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};ic=Hn;I.EndOfContent=ic;Hn.NAME=qr;var ac,Ot=class extends be{constructor(e={}){super(e,Be),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}`}};ac=Ot;I.Null=ac;Ot.NAME="NULL";var Fn=class extends vt(Be){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 xt(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,Wo.call(this),this.blockLength=n,t+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};Fn.NAME="BooleanValueBlock";var cc,Kn=class extends be{constructor(e={}){super(e,Fn),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}`}};cc=Kn;I.Boolean=cc;Kn.NAME="BOOLEAN";var qn=class extends vt(et){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=et.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===qr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(i!==tc)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?et.prototype.toBER.call(this,e,t):e?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};qn.NAME="OctetStringValueBlock";var lc,bt=class r extends be{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},qn),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=ys(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?Pt.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)}};lc=bt;I.OctetString=lc;bt.NAME=tc;var $n=class extends vt(et){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=et.prototype.fromBER.call(this,e,t,n),s===-1)return s;for(let a of this.value){let c=a.constructor.NAME;if(c===qr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==rc)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(!xt(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=ys(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 et.prototype.toBER.call(this,e,t);if(e)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return je;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}}};$n.NAME="BitStringValueBlock";var uc,Er=class extends be{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},$n),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 Pt.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)}`}}};uc=Er;I.BitString=uc;Er.NAME=rc;var fc;function Qh(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,u=c<i?i:c,l=0;for(let d=u;d>=0;d--,l++){switch(!0){case l<a.length:f=o[i-l]+a[c-l]+t[0];break;default:f=o[i-l]+t[0]}switch(t[0]=f/10,!0){case l>=o.length:o=Cn(new Uint8Array([f%10]),o);break;default:o[i-l]=f%10}}return t[0]>0&&(o=Cn(t,o)),o}function ec(r){if(r>=Fr.length)for(let e=Fr.length;e<=r;e++){let t=new Uint8Array([0]),n=Fr[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=Cn(t,n)),Fr.push(n)}return Fr[r]}function ed(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,u=0;for(let l=c;l>=0;l--,u++)switch(f=o[i-u]-a[c-u]-t,!0){case f<0:t=1,o[i-u]=f+10;break;default:t=0,o[i-u]=f}if(t>0)for(let l=i-c+1;l>=0;l--,u++)if(f=o[i-u]-t,f<0)t=1,o[i-u]=f+10;else{t=0,o[i-u]=f;break}return o.slice()}var $r=class extends vt(Be){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=Wo.call(this)))}set valueDec(e){this._valueDec=e,this.isHexOnly=!1,this.valueHexView=new Uint8Array(Ja(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=ed(ec(n),t),i="-";break;default:t=Qh(t,ec(n))}n++,s>>=1}}for(let c=0;c<t.length;c++)t[c]&&(a=!0),a&&(i+=Qa.charAt(t[c]));return a===!1&&(i+=Qa.charAt(0)),i}};fc=$r;$r.NAME="IntegerValueBlock";Object.defineProperty(fc.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var hc,ce=class r extends be{constructor(e={}){super(e,$r),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return Ln(),BigInt(this.valueBlock.toString())}static fromBigInt(e){Ln();let t=BigInt(e),n=new Kr,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,u=M.BufferSourceConverter.toUint8Array(M.Convert.FromHex(f.toString(16)));u[0]|=128,n.write(u)}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()}`}};hc=ce;I.Integer=hc;ce.NAME="INTEGER";var dc,Gn=class extends ce{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};dc=Gn;I.Enumerated=dc;Gn.NAME="ENUMERATED";var Gr=class extends vt(Be){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(!xt(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=Xt(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),t+this.blockLength)}set valueBigInt(e){Ln();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=Ut(this.valueDec,7);if(t.byteLength===0)return this.error="Error during encoding SID value",je;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}}};Gr.NAME="sidBlock";var zn=class extends Be{constructor({value:e=Br,...t}={}){super(t),this.value=[],e&&this.fromString(e)}fromBER(e,t,n){let s=t;for(;n>0;){let o=new Gr;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,je;t.push(s)}return Yo(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 Gr;if(s>Number.MAX_SAFE_INTEGER){Ln();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}};zn.NAME="ObjectIdentifierValueBlock";var pc,ze=class extends be{constructor(e={}){super(e,zn),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()}}};pc=ze;I.ObjectIdentifier=pc;ze.NAME="OBJECT IDENTIFIER";var zr=class extends vt(yt){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(!xt(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=Xt(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=Ut(this.valueDec,7);if(t.byteLength===0)return this.error="Error during encoding SID value",je;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}}};zr.NAME="relativeSidBlock";var jn=class extends Be{constructor({value:e=Br,...t}={}){super(t),this.value=[],e&&this.fromString(e)}fromBER(e,t,n){let s=t;for(;n>0;){let o=new zr;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,je;n.push(o)}return Yo(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 zr;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}};jn.NAME="RelativeObjectIdentifierValueBlock";var gc,Wn=class extends be{constructor(e={}){super(e,jn),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()}}};gc=Wn;I.RelativeObjectIdentifier=gc;Wn.NAME="RelativeObjectIdentifier";var mc,pe=class extends Pt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};mc=pe;I.Sequence=mc;pe.NAME="SEQUENCE";var yc,Yn=class extends Pt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};yc=Yn;I.Set=yc;Yn.NAME="SET";var Zn=class extends vt(Be){constructor({...e}={}){super(e),this.isHexOnly=!0,this.value=Br}toJSON(){return{...super.toJSON(),value:this.value}}};Zn.NAME="StringValueBlock";var Jn=class extends Zn{};Jn.NAME="SimpleStringValueBlock";var Se=class extends On{constructor({...e}={}){super(e,Jn)}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}};Se.NAME="SIMPLE STRING";var Xn=class extends Se{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}};Xn.NAME="Utf8StringValueBlock";var bc,wt=class extends Xn{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};bc=wt;I.Utf8String=bc;wt.NAME="UTF8String";var Qn=class extends Se{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))}};Qn.NAME="BmpStringValueBlock";var wc,es=class extends Qn{constructor({...e}={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};wc=es;I.BmpString=wc;es.NAME="BMPString";var ts=class extends Se{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=Ut(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}};ts.NAME="UniversalStringValueBlock";var xc,rs=class extends ts{constructor({...e}={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};xc=rs;I.UniversalString=xc;rs.NAME="UniversalString";var vc,ns=class extends Se{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};vc=ns;I.NumericString=vc;ns.NAME="NumericString";var Ec,ss=class extends Se{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};Ec=ss;I.PrintableString=Ec;ss.NAME="PrintableString";var Bc,os=class extends Se{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};Bc=os;I.TeletexString=Bc;os.NAME="TeletexString";var Ac,is=class extends Se{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};Ac=is;I.VideotexString=Ac;is.NAME="VideotexString";var Ic,as=class extends Se{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};Ic=as;I.IA5String=Ic;as.NAME="IA5String";var Sc,cs=class extends Se{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};Sc=cs;I.GraphicString=Sc;cs.NAME="GraphicString";var kc,jr=class extends Se{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};kc=jr;I.VisibleString=kc;jr.NAME="VisibleString";var Nc,ls=class extends Se{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};Nc=ls;I.GeneralString=Nc;ls.NAME="GeneralString";var Rc,us=class extends Se{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};Rc=us;I.CharacterString=Rc;us.NAME="CharacterString";var Tc,Wr=class extends jr{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]=Ne(this.year<2e3?this.year-1900:this.year-2e3,2),t[1]=Ne(this.month,2),t[2]=Ne(this.day,2),t[3]=Ne(this.hour,2),t[4]=Ne(this.minute,2),t[5]=Ne(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}}};Tc=Wr;I.UTCTime=Tc;Wr.NAME="UTCTime";var _c,fs=class extends Wr{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 l=new Number(e[e.length-1]);if(isNaN(l.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 l=1,d=n.indexOf("+"),b="";if(d===-1&&(d=n.indexOf("-"),l=-1),d!==-1){if(b=n.substring(d+1),n=n.substring(0,d),b.length!==2&&b.length!==4)throw new Error("Wrong input string for conversion");let p=parseInt(b.substring(0,2),10);if(isNaN(p.valueOf()))throw new Error("Wrong input string for conversion");if(a=l*p,b.length===4){if(p=parseInt(b.substring(2,4),10),isNaN(p.valueOf()))throw new Error("Wrong input string for conversion");c=l*p}}}let f=n.indexOf(".");if(f===-1&&(f=n.indexOf(",")),f!==-1){let l=new Number(`0${n.substring(f)}`);if(isNaN(l.valueOf()))throw new Error("Wrong input string for conversion");o=l.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 l=60*o;this.minute=Math.floor(l),l=60*(l-this.minute),this.second=Math.floor(l),l=1e3*(l-this.second),this.millisecond=Math.floor(l)}break;case s.length===12:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let l=60*o;this.second=Math.floor(l),l=1e3*(l-this.second),this.millisecond=Math.floor(l)}break;case s.length===14:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let l=1e3*o;this.millisecond=Math.floor(l)}break;default:throw new Error("Wrong input string for conversion")}let u=i.exec(s);if(u===null)throw new Error("Wrong input string for conversion");for(let l=1;l<u.length;l++)switch(l){case 1:this.year=parseInt(u[l],10);break;case 2:this.month=parseInt(u[l],10);break;case 3:this.day=parseInt(u[l],10);break;case 4:this.hour=parseInt(u[l],10)+a;break;case 5:this.minute=parseInt(u[l],10)+c;break;case 6:this.second=parseInt(u[l],10);break;default:throw new Error("Wrong input string for conversion")}if(t===!1){let l=new Date(this.year,this.month,this.day,this.hour,this.minute,this.second,this.millisecond);this.year=l.getUTCFullYear(),this.month=l.getUTCMonth(),this.day=l.getUTCDay(),this.hour=l.getUTCHours(),this.minute=l.getUTCMinutes(),this.second=l.getUTCSeconds(),this.millisecond=l.getUTCMilliseconds()}}toString(e="iso"){if(e==="iso"){let t=[];return t.push(Ne(this.year,4)),t.push(Ne(this.month,2)),t.push(Ne(this.day,2)),t.push(Ne(this.hour,2)),t.push(Ne(this.minute,2)),t.push(Ne(this.second,2)),this.millisecond!==0&&(t.push("."),t.push(Ne(this.millisecond,3))),t.push("Z"),t.join("")}return super.toString(e)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};_c=fs;I.GeneralizedTime=_c;fs.NAME="GeneralizedTime";var Cc,hs=class extends wt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};Cc=hs;I.DATE=Cc;hs.NAME="DATE";var Lc,ds=class extends wt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};Lc=ds;I.TimeOfDay=Lc;ds.NAME="TimeOfDay";var Uc,ps=class extends wt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};Uc=ps;I.DateTime=Uc;ps.NAME="DateTime";var Pc,gs=class extends wt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};Pc=gs;I.Duration=Pc;gs.NAME="Duration";var Oc,ms=class extends wt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};Oc=ms;I.TIME=Oc;ms.NAME="TIME";function rd(r){let{result:e}=Ar(r),t=e.valueBlock.value;return{n:K(tt(t[1].toBigInt()),"base64url"),e:K(tt(t[2].toBigInt()),"base64url"),d:K(tt(t[3].toBigInt()),"base64url"),p:K(tt(t[4].toBigInt()),"base64url"),q:K(tt(t[5].toBigInt()),"base64url"),dp:K(tt(t[6].toBigInt()),"base64url"),dq:K(tt(t[7].toBigInt()),"base64url"),qi:K(tt(t[8].toBigInt()),"base64url"),kty:"RSA",alg:"RS256"}}function nd(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 C("JWK was missing components","ERR_INVALID_PARAMETERS");let t=new pe({value:[new ce({value:0}),ce.fromBigInt(rt(F(r.n,"base64url"))),ce.fromBigInt(rt(F(r.e,"base64url"))),ce.fromBigInt(rt(F(r.d,"base64url"))),ce.fromBigInt(rt(F(r.p,"base64url"))),ce.fromBigInt(rt(F(r.q,"base64url"))),ce.fromBigInt(rt(F(r.dp,"base64url"))),ce.fromBigInt(rt(F(r.dq,"base64url"))),ce.fromBigInt(rt(F(r.qi,"base64url")))]}).toBER();return new Uint8Array(t,0,t.byteLength)}function sd(r){let{result:e}=Ar(r),t=e.valueBlock.value[1].valueBlock.value[0].valueBlock.value;return{kty:"RSA",n:K(tt(t[0].toBigInt()),"base64url"),e:K(tt(t[1].toBigInt()),"base64url")}}function od(r){if(r.n==null||r.e==null)throw new C("JWK was missing components","ERR_INVALID_PARAMETERS");let t=new pe({value:[new pe({value:[new ze({value:"1.2.840.113549.1.1.1"}),new Ot]}),new Er({valueHex:new pe({value:[ce.fromBigInt(rt(F(r.n,"base64url"))),ce.fromBigInt(rt(F(r.e,"base64url")))]}).toBER()})]}).toBER();return new Uint8Array(t,0,t.byteLength)}function tt(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 rt(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 id=16,Jo=32,Xo=1e4;async function ad(r,e){let t=Ie.get(),s=new pe({value:[new ce({value:0}),new pe({value:[new ze({value:"1.2.840.113549.1.1.1"}),new Ot]}),new bt({valueHex:r.marshal()})]}).toBER(),o=new Uint8Array(s,0,s.byteLength),i=Jt(id),a=await zo(gr,e,i,{c:Xo,dkLen:Jo}),c=Jt(16),f=await t.subtle.importKey("raw",a,"AES-CBC",!1,["encrypt"]),u=await t.subtle.encrypt({name:"AES-CBC",iv:c},f,o),l=new pe({value:[new bt({valueHex:i}),new ce({value:Xo}),new ce({value:Jo}),new pe({value:[new ze({value:"1.2.840.113549.2.11"}),new Ot]})]}),d=new pe({value:[new ze({value:"1.2.840.113549.1.5.13"}),new pe({value:[new pe({value:[new ze({value:"1.2.840.113549.1.5.12"}),l]}),new pe({value:[new ze({value:"2.16.840.1.101.3.4.1.42"}),new bt({valueHex:c})]})]})]}),p=new pe({value:[d,new bt({valueHex:u})]}).toBER(),h=new Uint8Array(p,0,p.byteLength);return["-----BEGIN ENCRYPTED PRIVATE KEY-----",...K(h,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
|
|
7
|
+
`)}async function cd(r,e){let t=Ie.get(),n;if(r.includes("-----BEGIN ENCRYPTED PRIVATE KEY-----")){let s=F(r.replace("-----BEGIN ENCRYPTED PRIVATE KEY-----","").replace("-----END ENCRYPTED PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:o}=Ar(s),{iv:i,salt:a,iterations:c,keySize:f,cipherText:u}=ld(o),l=await zo(gr,e,a,{c,dkLen:f}),d=await t.subtle.importKey("raw",l,"AES-CBC",!1,["decrypt"]),b=Yr(await t.subtle.decrypt({name:"AES-CBC",iv:i},d,u)),{result:p}=Ar(b);n=Vc(p)}else if(r.includes("-----BEGIN PRIVATE KEY-----")){let s=F(r.replace("-----BEGIN PRIVATE KEY-----","").replace("-----END PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:o}=Ar(s);n=Vc(o)}else throw new C("Could not parse private key from PEM data","ERR_INVALID_PARAMETERS");return Qo(n)}function ld(r){let e=r.valueBlock.value[0];if(e.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.13")throw new C("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 C("Only pkcs5PBKDF2 key derivation functions are supported","ERR_INVALID_PARAMS");let o=n.valueBlock.value[1],i=Yr(o.valueBlock.value[0].getValue()),a=Xo,c=Jo;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 C("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],u=f.valueBlock.value[0].toString();if(u!=="OBJECT IDENTIFIER : 1.2.840.113549.3.7"){if(u!=="OBJECT IDENTIFIER : 1.3.14.3.2.7"){if(u!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.2"){if(u!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.22"){if(u!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.42")throw new C("Only AES-CBC encryption schemes are supported","ERR_INVALID_PARAMS")}}}}let l=Yr(f.valueBlock.value[1].getValue());return{cipherText:Yr(r.valueBlock.value[1].getValue()),salt:i,iterations:a,keySize:c,iv:l}}function Vc(r){return Yr(r.valueBlock.value[2].getValue())}function Yr(r){return new Uint8Array(r,0,r.byteLength)}async function Dc(r){let e=await Ie.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 Fc(e);return{privateKey:t[0],publicKey:t[1]}}async function ei(r){let t=[await Ie.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["sign"]),await ud(r)],n=await Fc({privateKey:t[0],publicKey:t[1]});return{privateKey:n[0],publicKey:n[1]}}async function Mc(r,e){let t=await Ie.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await Ie.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},t,e instanceof Uint8Array?e:e.subarray());return new Uint8Array(n,0,n.byteLength)}async function Hc(r,e,t){let n=await Ie.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return Ie.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,e,t instanceof Uint8Array?t:t.subarray())}async function Fc(r){if(r.privateKey==null||r.publicKey==null)throw new C("Private and public key are required","ERR_INVALID_PARAMETERS");return Promise.all([Ie.get().subtle.exportKey("jwk",r.privateKey),Ie.get().subtle.exportKey("jwk",r.publicKey)])}async function ud(r){return Ie.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 bs(r){if(r.kty!=="RSA")throw new C("invalid key type","ERR_INVALID_KEY_TYPE");if(r.n==null)throw new C("invalid key modulus","ERR_INVALID_KEY_MODULUS");return F(r.n,"base64url").length*8}var Jr=8192,Zr=class{_key;constructor(e){this._key=e}verify(e,t){return Hc(this._key,t,e)}marshal(){return Vt.jwkToPkix(this._key)}get bytes(){return Xe.encode({Type:X.RSA,Data:this.marshal()}).subarray()}equals(e){return de(this.bytes,e.bytes)}hash(){let e=ye.digest(this.bytes);return Ce(e)?e.then(({bytes:t})=>t):e.bytes}},Ir=class{_key;_publicKey;constructor(e,t){this._key=e,this._publicKey=t}genSecret(){return Jt(16)}sign(e){return Mc(this._key,e)}get public(){if(this._publicKey==null)throw new C("public key not provided","ERR_PUBKEY_NOT_PROVIDED");return new Zr(this._publicKey)}marshal(){return Vt.jwkToPkcs1(this._key)}get bytes(){return Qe.encode({Type:X.RSA,Data:this.marshal()}).subarray()}equals(e){return de(this.bytes,e.bytes)}hash(){let e=ye.digest(this.bytes);return Ce(e)?e.then(({bytes:t})=>t):e.bytes}async id(){let e=await this.public.hash();return K(e,"base58btc")}async export(e,t="pkcs-8"){if(t==="pkcs-8")return Vt.exportToPem(this,e);if(t==="libp2p-key")return br(this.bytes,e);throw new C(`export format '${t}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};async function Qo(r){let e=Vt.pkcs1ToJwk(r);if(bs(e)>Jr)throw new C("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await ei(e);return new Ir(t.privateKey,t.publicKey)}function hd(r){let e=Vt.pkixToJwk(r);if(bs(e)>Jr)throw new C("key size is too large","ERR_KEY_SIZE_TOO_LARGE");return new Zr(e)}async function dd(r){if(bs(r)>Jr)throw new C("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await ei(r);return new Ir(e.privateKey,e.publicKey)}async function pd(r){if(r>Jr)throw new C("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await Dc(r);return new Ir(e.privateKey,e.publicKey)}var ii={};he(ii,{Secp256k1PrivateKey:()=>Qr,Secp256k1PublicKey:()=>Xr,generateKeyPair:()=>Rd,unmarshalSecp256k1PrivateKey:()=>kd,unmarshalSecp256k1PublicKey:()=>Nd});var gd=(r,e,t)=>r&e^~r&t,md=(r,e,t)=>r&e^r&t^e&t,yd=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]),Dt=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),Mt=new Uint32Array(64),ri=class extends pr{constructor(){super(64,32,8,!1),this.A=Dt[0]|0,this.B=Dt[1]|0,this.C=Dt[2]|0,this.D=Dt[3]|0,this.E=Dt[4]|0,this.F=Dt[5]|0,this.G=Dt[6]|0,this.H=Dt[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 l=0;l<16;l++,t+=4)Mt[l]=e.getUint32(t,!1);for(let l=16;l<64;l++){let d=Mt[l-15],b=Mt[l-2],p=Me(d,7)^Me(d,18)^d>>>3,h=Me(b,17)^Me(b,19)^b>>>10;Mt[l]=h+Mt[l-7]+p+Mt[l-16]|0}let{A:n,B:s,C:o,D:i,E:a,F:c,G:f,H:u}=this;for(let l=0;l<64;l++){let d=Me(a,6)^Me(a,11)^Me(a,25),b=u+d+gd(a,c,f)+yd[l]+Mt[l]|0,h=(Me(n,2)^Me(n,13)^Me(n,22))+md(n,s,o)|0;u=f,f=c,c=a,a=i+b|0,i=o,o=s,s=n,n=b+h|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,u=u+this.H|0,this.set(n,s,o,i,a,c,f,u)}roundClean(){Mt.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var Kc=pn(()=>new ri);function bd(r){let e=Or(r);Je(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:wd,hexToBytes:xd}=yn,Qt={Err:class extends Error{constructor(e=""){super(e)}},_parseInt(r){let{Err:e}=Qt;if(r.length<2||r[0]!==2)throw new e("Invalid signature integer tag");let t=r[1],n=r.subarray(2,t+2);if(!t||n.length!==t)throw new e("Invalid signature integer: wrong length");if(n[0]&128)throw new e("Invalid signature integer: negative");if(n[0]===0&&!(n[1]&128))throw new e("Invalid signature integer: unnecessary leading zero");return{d:wd(n),l:r.subarray(t+2)}},toSig(r){let{Err:e}=Qt,t=typeof r=="string"?xd(r):r;if(!He(t))throw new Error("ui8a expected");let n=t.length;if(n<2||t[0]!=48)throw new e("Invalid signature tag");if(t[1]!==n-2)throw new e("Invalid signature: incorrect length");let{d:s,l:o}=Qt._parseInt(t.subarray(2)),{d:i,l:a}=Qt._parseInt(o);if(a.length)throw new e("Invalid signature: left bytes after parsing");return{r:s,s:i}},hexFromSig(r){let e=f=>Number.parseInt(f[0],16)&8?"00"+f:f,t=f=>{let u=f.toString(16);return u.length&1?`0${u}`:u},n=e(t(r.s)),s=e(t(r.r)),o=n.length/2,i=s.length/2,a=t(o),c=t(i);return`30${t(i+o+4)}02${c}${s}02${a}${n}`}},Et=BigInt(0),Pe=BigInt(1),Vm=BigInt(2),qc=BigInt(3),Dm=BigInt(4);function vd(r){let e=bd(r),{Fp:t}=e,n=e.toBytes||((p,h,m)=>{let y=h.toAffine();return ht(Uint8Array.from([4]),t.toBytes(y.x),t.toBytes(y.y))}),s=e.fromBytes||(p=>{let h=p.subarray(1),m=t.fromBytes(h.subarray(0,t.BYTES)),y=t.fromBytes(h.subarray(t.BYTES,2*t.BYTES));return{x:m,y}});function o(p){let{a:h,b:m}=e,y=t.sqr(p),B=t.mul(y,p);return t.add(t.add(B,t.mul(p,h)),m)}if(!t.eql(t.sqr(e.Gy),o(e.Gx)))throw new Error("bad generator point: equation left != right");function i(p){return typeof p=="bigint"&&Et<p&&p<e.n}function a(p){if(!i(p))throw new Error("Expected valid bigint: 0 < bigint < curve.n")}function c(p){let{allowedPrivateKeyLengths:h,nByteLength:m,wrapPrivateKey:y,n:B}=e;if(h&&typeof p!="bigint"){if(He(p)&&(p=ut(p)),typeof p!="string"||!h.includes(p.length))throw new Error("Invalid key");p=p.padStart(m*2,"0")}let w;try{w=typeof p=="bigint"?p:ft(te("private key",p,m))}catch{throw new Error(`private key must be ${m} bytes, hex or bigint, not ${typeof p}`)}return y&&(w=Y(w,B)),a(w),w}let f=new Map;function u(p){if(!(p instanceof l))throw new Error("ProjectivePoint expected")}class l{constructor(h,m,y){if(this.px=h,this.py=m,this.pz=y,h==null||!t.isValid(h))throw new Error("x required");if(m==null||!t.isValid(m))throw new Error("y required");if(y==null||!t.isValid(y))throw new Error("z required")}static fromAffine(h){let{x:m,y}=h||{};if(!h||!t.isValid(m)||!t.isValid(y))throw new Error("invalid affine point");if(h instanceof l)throw new Error("projective point not allowed");let B=w=>t.eql(w,t.ZERO);return B(m)&&B(y)?l.ZERO:new l(m,y,t.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(h){let m=t.invertBatch(h.map(y=>y.pz));return h.map((y,B)=>y.toAffine(m[B])).map(l.fromAffine)}static fromHex(h){let m=l.fromAffine(s(te("pointHex",h)));return m.assertValidity(),m}static fromPrivateKey(h){return l.BASE.multiply(c(h))}_setWindowSize(h){this._WINDOW_SIZE=h,f.delete(this)}assertValidity(){if(this.is0()){if(e.allowInfinityPoint&&!t.is0(this.py))return;throw new Error("bad point: ZERO")}let{x:h,y:m}=this.toAffine();if(!t.isValid(h)||!t.isValid(m))throw new Error("bad point: x or y not FE");let y=t.sqr(m),B=o(h);if(!t.eql(y,B))throw new Error("bad point: equation left != right");if(!this.isTorsionFree())throw new Error("bad point: not in prime-order subgroup")}hasEvenY(){let{y:h}=this.toAffine();if(t.isOdd)return!t.isOdd(h);throw new Error("Field doesn't support isOdd")}equals(h){u(h);let{px:m,py:y,pz:B}=this,{px:w,py:T,pz:x}=h,A=t.eql(t.mul(m,x),t.mul(w,B)),N=t.eql(t.mul(y,x),t.mul(T,B));return A&&N}negate(){return new l(this.px,t.neg(this.py),this.pz)}double(){let{a:h,b:m}=e,y=t.mul(m,qc),{px:B,py:w,pz:T}=this,x=t.ZERO,A=t.ZERO,N=t.ZERO,R=t.mul(B,B),G=t.mul(w,w),q=t.mul(T,T),P=t.mul(B,w);return P=t.add(P,P),N=t.mul(B,T),N=t.add(N,N),x=t.mul(h,N),A=t.mul(y,q),A=t.add(x,A),x=t.sub(G,A),A=t.add(G,A),A=t.mul(x,A),x=t.mul(P,x),N=t.mul(y,N),q=t.mul(h,q),P=t.sub(R,q),P=t.mul(h,P),P=t.add(P,N),N=t.add(R,R),R=t.add(N,R),R=t.add(R,q),R=t.mul(R,P),A=t.add(A,R),q=t.mul(w,T),q=t.add(q,q),R=t.mul(q,P),x=t.sub(x,R),N=t.mul(q,G),N=t.add(N,N),N=t.add(N,N),new l(x,A,N)}add(h){u(h);let{px:m,py:y,pz:B}=this,{px:w,py:T,pz:x}=h,A=t.ZERO,N=t.ZERO,R=t.ZERO,G=e.a,q=t.mul(e.b,qc),P=t.mul(m,w),ie=t.mul(y,T),re=t.mul(B,x),_e=t.add(m,y),v=t.add(w,T);_e=t.mul(_e,v),v=t.add(P,ie),_e=t.sub(_e,v),v=t.add(m,B);let k=t.add(w,x);return v=t.mul(v,k),k=t.add(P,re),v=t.sub(v,k),k=t.add(y,B),A=t.add(T,x),k=t.mul(k,A),A=t.add(ie,re),k=t.sub(k,A),R=t.mul(G,v),A=t.mul(q,re),R=t.add(A,R),A=t.sub(ie,R),R=t.add(ie,R),N=t.mul(A,R),ie=t.add(P,P),ie=t.add(ie,P),re=t.mul(G,re),v=t.mul(q,v),ie=t.add(ie,re),re=t.sub(P,re),re=t.mul(G,re),v=t.add(v,re),P=t.mul(ie,v),N=t.add(N,P),P=t.mul(k,v),A=t.mul(_e,A),A=t.sub(A,P),P=t.mul(_e,ie),R=t.mul(k,R),R=t.add(R,P),new l(A,N,R)}subtract(h){return this.add(h.negate())}is0(){return this.equals(l.ZERO)}wNAF(h){return b.wNAFCached(this,f,h,m=>{let y=t.invertBatch(m.map(B=>B.pz));return m.map((B,w)=>B.toAffine(y[w])).map(l.fromAffine)})}multiplyUnsafe(h){let m=l.ZERO;if(h===Et)return m;if(a(h),h===Pe)return this;let{endo:y}=e;if(!y)return b.unsafeLadder(this,h);let{k1neg:B,k1:w,k2neg:T,k2:x}=y.splitScalar(h),A=m,N=m,R=this;for(;w>Et||x>Et;)w&Pe&&(A=A.add(R)),x&Pe&&(N=N.add(R)),R=R.double(),w>>=Pe,x>>=Pe;return B&&(A=A.negate()),T&&(N=N.negate()),N=new l(t.mul(N.px,y.beta),N.py,N.pz),A.add(N)}multiply(h){a(h);let m=h,y,B,{endo:w}=e;if(w){let{k1neg:T,k1:x,k2neg:A,k2:N}=w.splitScalar(m),{p:R,f:G}=this.wNAF(x),{p:q,f:P}=this.wNAF(N);R=b.constTimeNegate(T,R),q=b.constTimeNegate(A,q),q=new l(t.mul(q.px,w.beta),q.py,q.pz),y=R.add(q),B=G.add(P)}else{let{p:T,f:x}=this.wNAF(m);y=T,B=x}return l.normalizeZ([y,B])[0]}multiplyAndAddUnsafe(h,m,y){let B=l.BASE,w=(x,A)=>A===Et||A===Pe||!x.equals(B)?x.multiplyUnsafe(A):x.multiply(A),T=w(this,m).add(w(h,y));return T.is0()?void 0:T}toAffine(h){let{px:m,py:y,pz:B}=this,w=this.is0();h==null&&(h=w?t.ONE:t.inv(B));let T=t.mul(m,h),x=t.mul(y,h),A=t.mul(B,h);if(w)return{x:t.ZERO,y:t.ZERO};if(!t.eql(A,t.ONE))throw new Error("invZ was invalid");return{x:T,y:x}}isTorsionFree(){let{h,isTorsionFree:m}=e;if(h===Pe)return!0;if(m)return m(l,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h,clearCofactor:m}=e;return h===Pe?this:m?m(l,this):this.multiplyUnsafe(e.h)}toRawBytes(h=!0){return this.assertValidity(),n(l,this,h)}toHex(h=!0){return ut(this.toRawBytes(h))}}l.BASE=new l(e.Gx,e.Gy,t.ONE),l.ZERO=new l(t.ZERO,t.ONE,t.ZERO);let d=e.nBitLength,b=xn(l,e.endo?Math.ceil(d/2):d);return{CURVE:e,ProjectivePoint:l,normPrivateKeyToScalar:c,weierstrassEquation:o,isWithinCurveOrder:i}}function Ed(r){let e=Or(r);return Je(e,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...e})}function $c(r){let e=Ed(r),{Fp:t,n}=e,s=t.BYTES+1,o=2*t.BYTES+1;function i(v){return Et<v&&v<t.ORDER}function a(v){return Y(v,n)}function c(v){return bn(v,n)}let{ProjectivePoint:f,normPrivateKeyToScalar:u,weierstrassEquation:l,isWithinCurveOrder:d}=vd({...e,toBytes(v,k,O){let E=k.toAffine(),g=t.toBytes(E.x),S=ht;return O?S(Uint8Array.from([k.hasEvenY()?2:3]),g):S(Uint8Array.from([4]),g,t.toBytes(E.y))},fromBytes(v){let k=v.length,O=v[0],E=v.subarray(1);if(k===s&&(O===2||O===3)){let g=ft(E);if(!i(g))throw new Error("Point is not on curve");let S=l(g),_=t.sqrt(S),L=(_&Pe)===Pe;return(O&1)===1!==L&&(_=t.neg(_)),{x:g,y:_}}else if(k===o&&O===4){let g=t.fromBytes(E.subarray(0,t.BYTES)),S=t.fromBytes(E.subarray(t.BYTES,2*t.BYTES));return{x:g,y:S}}else throw new Error(`Point of length ${k} was invalid. Expected ${s} compressed bytes or ${o} uncompressed bytes`)}}),b=v=>ut(Ct(v,e.nByteLength));function p(v){let k=n>>Pe;return v>k}function h(v){return p(v)?a(-v):v}let m=(v,k,O)=>ft(v.slice(k,O));class y{constructor(k,O,E){this.r=k,this.s=O,this.recovery=E,this.assertValidity()}static fromCompact(k){let O=e.nByteLength;return k=te("compactSignature",k,O*2),new y(m(k,0,O),m(k,O,2*O))}static fromDER(k){let{r:O,s:E}=Qt.toSig(te("DER",k));return new y(O,E)}assertValidity(){if(!d(this.r))throw new Error("r must be 0 < r < CURVE.n");if(!d(this.s))throw new Error("s must be 0 < s < CURVE.n")}addRecoveryBit(k){return new y(this.r,this.s,k)}recoverPublicKey(k){let{r:O,s:E,recovery:g}=this,S=N(te("msgHash",k));if(g==null||![0,1,2,3].includes(g))throw new Error("recovery id invalid");let _=g===2||g===3?O+e.n:O;if(_>=t.ORDER)throw new Error("recovery id 2 or 3 invalid");let L=g&1?"03":"02",V=f.fromHex(L+b(_)),D=c(_),W=a(-S*D),H=a(E*D),$=f.BASE.multiplyAndAddUnsafe(V,W,H);if(!$)throw new Error("point at infinify");return $.assertValidity(),$}hasHighS(){return p(this.s)}normalizeS(){return this.hasHighS()?new y(this.r,a(-this.s),this.recovery):this}toDERRawBytes(){return Gt(this.toDERHex())}toDERHex(){return Qt.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return Gt(this.toCompactHex())}toCompactHex(){return b(this.r)+b(this.s)}}let B={isValidPrivateKey(v){try{return u(v),!0}catch{return!1}},normPrivateKeyToScalar:u,randomPrivateKey:()=>{let v=xo(e.n);return Ta(e.randomBytes(v),e.n)},precompute(v=8,k=f.BASE){return k._setWindowSize(v),k.multiply(BigInt(3)),k}};function w(v,k=!0){return f.fromPrivateKey(v).toRawBytes(k)}function T(v){let k=He(v),O=typeof v=="string",E=(k||O)&&v.length;return k?E===s||E===o:O?E===2*s||E===2*o:v instanceof f}function x(v,k,O=!0){if(T(v))throw new Error("first arg must be private key");if(!T(k))throw new Error("second arg must be public key");return f.fromHex(k).multiply(u(v)).toRawBytes(O)}let A=e.bits2int||function(v){let k=ft(v),O=v.length*8-e.nBitLength;return O>0?k>>BigInt(O):k},N=e.bits2int_modN||function(v){return a(A(v))},R=Pr(e.nBitLength);function G(v){if(typeof v!="bigint")throw new Error("bigint expected");if(!(Et<=v&&v<R))throw new Error(`bigint expected < 2^${e.nBitLength}`);return Ct(v,e.nByteLength)}function q(v,k,O=P){if(["recovered","canonical"].some(Q=>Q in O))throw new Error("sign() legacy options not supported");let{hash:E,randomBytes:g}=e,{lowS:S,prehash:_,extraEntropy:L}=O;S==null&&(S=!0),v=te("msgHash",v),_&&(v=te("prehashed msgHash",E(v)));let V=N(v),D=u(k),W=[G(D),G(V)];if(L!=null){let Q=L===!0?g(t.BYTES):L;W.push(te("extraEntropy",Q))}let H=ht(...W),$=V;function ae(Q){let ge=A(Q);if(!d(ge))return;let me=c(ge),le=f.BASE.multiply(ge).toAffine(),we=a(le.x);if(we===Et)return;let ot=a(me*a($+we*D));if(ot===Et)return;let Kt=(le.x===we?0:2)|Number(le.y&Pe),Rr=ot;return S&&p(ot)&&(Rr=h(ot),Kt^=1),new y(we,Rr,Kt)}return{seed:H,k2sig:ae}}let P={lowS:e.lowS,prehash:!1},ie={lowS:e.lowS,prehash:!1};function re(v,k,O=P){let{seed:E,k2sig:g}=q(v,k,O),S=e;return mo(S.hash.outputLen,S.nByteLength,S.hmac)(E,g)}f.BASE._setWindowSize(8);function _e(v,k,O,E=ie){let g=v;if(k=te("msgHash",k),O=te("publicKey",O),"strict"in E)throw new Error("options.strict was renamed to lowS");let{lowS:S,prehash:_}=E,L,V;try{if(typeof g=="string"||He(g))try{L=y.fromDER(g)}catch(le){if(!(le instanceof Qt.Err))throw le;L=y.fromCompact(g)}else if(typeof g=="object"&&typeof g.r=="bigint"&&typeof g.s=="bigint"){let{r:le,s:we}=g;L=new y(le,we)}else throw new Error("PARSE");V=f.fromHex(O)}catch(le){if(le.message==="PARSE")throw new Error("signature must be Signature instance, Uint8Array or hex string");return!1}if(S&&L.hasHighS())return!1;_&&(k=e.hash(k));let{r:D,s:W}=L,H=N(k),$=c(W),ae=a(H*$),Q=a(D*$),ge=f.BASE.multiplyAndAddUnsafe(V,ae,Q)?.toAffine();return ge?a(ge.x)===D:!1}return{CURVE:e,getPublicKey:w,getSharedSecret:x,sign:re,verify:_e,ProjectivePoint:f,Signature:y,utils:B}}function Bd(r){return{hash:r,hmac:(e,...t)=>Hr(r,e,dn(...t)),randomBytes:dr}}function Gc(r,e){let t=n=>$c({...r,...Bd(n)});return Object.freeze({...t(e),create:t})}var Wc=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),zc=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),Ad=BigInt(1),ni=BigInt(2),jc=(r,e)=>(r+e/ni)/e;function Id(r){let e=Wc,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,u=f*f*r%e,l=J(u,t,e)*u%e,d=J(l,t,e)*u%e,b=J(d,ni,e)*f%e,p=J(b,s,e)*b%e,h=J(p,o,e)*p%e,m=J(h,a,e)*h%e,y=J(m,c,e)*m%e,B=J(y,a,e)*h%e,w=J(B,t,e)*u%e,T=J(w,i,e)*p%e,x=J(T,n,e)*f%e,A=J(x,ni,e);if(!si.eql(si.sqr(A),r))throw new Error("Cannot find square root");return A}var si=wn(Wc,void 0,void 0,{sqrt:Id}),We=Gc({a:BigInt(0),b:BigInt(7),Fp:si,n:zc,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let e=zc,t=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-Ad*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),s=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),o=t,i=BigInt("0x100000000000000000000000000000000"),a=jc(o*r,e),c=jc(-n*r,e),f=Y(r-a*t-c*s,e),u=Y(-a*n-c*o,e),l=f>i,d=u>i;if(l&&(f=e-f),d&&(u=e-u),f>i||u>i)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:l,k1:f,k2neg:d,k2:u}}}},Kc),jm=BigInt(0);var Wm=We.ProjectivePoint;function Yc(){return We.utils.randomPrivateKey()}function Zc(r,e){let t=ye.digest(e instanceof Uint8Array?e:e.subarray());if(Ce(t))return t.then(({digest:n})=>We.sign(n,r).toDERRawBytes()).catch(n=>{throw new C(String(n),"ERR_INVALID_INPUT")});try{return We.sign(t.digest,r).toDERRawBytes()}catch(n){throw new C(String(n),"ERR_INVALID_INPUT")}}function Jc(r,e,t){let n=ye.digest(t instanceof Uint8Array?t:t.subarray());if(Ce(n))return n.then(({digest:s})=>We.verify(e,s,r)).catch(s=>{throw new C(String(s),"ERR_INVALID_INPUT")});try{return We.verify(e,n.digest,r)}catch(s){throw new C(String(s),"ERR_INVALID_INPUT")}}function Xc(r){return We.ProjectivePoint.fromHex(r).toRawBytes(!0)}function Qc(r){try{We.getPublicKey(r,!0)}catch(e){throw new C(String(e),"ERR_INVALID_PRIVATE_KEY")}}function oi(r){try{We.ProjectivePoint.fromHex(r)}catch(e){throw new C(String(e),"ERR_INVALID_PUBLIC_KEY")}}function el(r){try{return We.getPublicKey(r,!0)}catch(e){throw new C(String(e),"ERR_INVALID_PRIVATE_KEY")}}var Xr=class{_key;constructor(e){oi(e),this._key=e}verify(e,t){return Jc(this._key,t,e)}marshal(){return Xc(this._key)}get bytes(){return Xe.encode({Type:X.Secp256k1,Data:this.marshal()}).subarray()}equals(e){return de(this.bytes,e.bytes)}async hash(){let e=ye.digest(this.bytes),t;return Ce(e)?{bytes:t}=await e:t=e.bytes,t}},Qr=class{_key;_publicKey;constructor(e,t){this._key=e,this._publicKey=t??el(e),Qc(this._key),oi(this._publicKey)}sign(e){return Zc(this._key,e)}get public(){return new Xr(this._publicKey)}marshal(){return this._key}get bytes(){return Qe.encode({Type:X.Secp256k1,Data:this.marshal()}).subarray()}equals(e){return de(this.bytes,e.bytes)}hash(){let e=ye.digest(this.bytes);return Ce(e)?e.then(({bytes:t})=>t):e.bytes}async id(){let e=await this.public.hash();return K(e,"base58btc")}async export(e,t="libp2p-key"){if(t==="libp2p-key")return br(this.bytes,e);throw new C(`export format '${t}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function kd(r){return new Qr(r)}function Nd(r){return new Xr(r)}async function Rd(){let r=Yc();return new Qr(r)}var er={rsa:ti,ed25519:Go,secp256k1:ii};function tl(r){let e=Object.keys(er).join(" / ");return new C(`invalid or unsupported key type ${r}. Must be ${e}`,"ERR_UNSUPPORTED_KEY_TYPE")}function rl(r){let e=Xe.decode(r),t=e.Data??new Uint8Array;switch(e.Type){case X.RSA:return er.rsa.unmarshalRsaPublicKey(t);case X.Ed25519:return er.ed25519.unmarshalEd25519PublicKey(t);case X.Secp256k1:return er.secp256k1.unmarshalSecp256k1PublicKey(t);default:throw tl(e.Type??"unknown")}}async function nl(r){let e=Qe.decode(r),t=e.Data??new Uint8Array;switch(e.Type){case X.RSA:return er.rsa.unmarshalRsaPrivateKey(t);case X.Ed25519:return er.ed25519.unmarshalEd25519PrivateKey(t);case X.Secp256k1:return er.secp256k1.unmarshalSecp256k1PrivateKey(t);default:throw tl(e.Type??"RSA")}}var ol=Symbol.for("@achingbrain/uint8arraylist");function sl(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 ws(r){return!!r?.[ol]}var Ye=class r{bufs;length;[ol]=!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(ws(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(ws(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=sl(this.bufs,e);return t.buf[t.index]}set(e,t){let n=sl(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(ws(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 Ae(n,s)}subarray(e,t){let{bufs:n,length:s}=this._subList(e,t);return n.length===1?n[0]:Ae(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,u=t>a&&t<=c;if(f&&u){if(e===a&&t===c){n.push(i);break}let l=e-a;n.push(i.subarray(l,l+(t-e)));break}if(f){if(e===0){n.push(i);continue}n.push(i.subarray(e-a));continue}if(u){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(!ws(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 l=0;l<o;l++)i[l]=-1;for(let l=0;l<s;l++)i[n[l]]=l;let a=i,c=this.byteLength-n.byteLength,f=n.byteLength-1,u;for(let l=t;l<=c;l+=u){u=0;for(let d=f;d>=0;d--){let b=this.get(l+d);if(n[d]!==b){u=Math.max(1,d-a[b]);break}}if(u===0)return l}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=ke(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=ct(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=ct(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=ct(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=ke(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=ct(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=ct(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=ct(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=ct(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=ct(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(!de(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 il={ERR_SIGNATURE_NOT_VALID:"ERR_SIGNATURE_NOT_VALID"};var en;(function(r){let e;r.codec=()=>(e==null&&(e=Ge((t,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),t.publicKey!=null&&t.publicKey.byteLength>0&&(n.uint32(10),n.bytes(t.publicKey)),t.payloadType!=null&&t.payloadType.byteLength>0&&(n.uint32(18),n.bytes(t.payloadType)),t.payload!=null&&t.payload.byteLength>0&&(n.uint32(26),n.bytes(t.payload)),t.signature!=null&&t.signature.byteLength>0&&(n.uint32(42),n.bytes(t.signature)),s.lengthDelimited!==!1&&n.ldelim()},(t,n)=>{let s={publicKey:new Uint8Array(0),payloadType:new Uint8Array(0),payload:new Uint8Array(0),signature: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.publicKey=t.bytes();break;case 2:s.payloadType=t.bytes();break;case 3:s.payload=t.bytes();break;case 5:s.signature=t.bytes();break;default:t.skipType(i&7);break}}return s})),e),r.encode=t=>$e(t,r.codec()),r.decode=t=>qe(t,r.codec())})(en||(en={}));var Ht=class r{static createFromProtobuf=async e=>{let t=en.decode(e),n=await Ur(t.publicKey);return new r({peerId:n,payloadType:t.payloadType,payload:t.payload,signature:t.signature})};static seal=async(e,t)=>{if(t.privateKey==null)throw new Error("Missing private key");let n=e.domain,s=e.codec,o=e.marshal(),i=al(n,s,o),c=await(await nl(t.privateKey)).sign(i.subarray());return new r({peerId:t,payloadType:s,payload:o,signature:c})};static openAndCertify=async(e,t)=>{let n=await r.createFromProtobuf(e);if(!await n.validate(t))throw new C("envelope signature is not valid for the given domain",il.ERR_SIGNATURE_NOT_VALID);return n};peerId;payloadType;payload;signature;marshaled;constructor(e){let{peerId:t,payloadType:n,payload:s,signature:o}=e;this.peerId=t,this.payloadType=n,this.payload=s,this.signature=o}marshal(){if(this.peerId.publicKey==null)throw new Error("Missing public key");return this.marshaled==null&&(this.marshaled=en.encode({publicKey:this.peerId.publicKey,payloadType:this.payloadType,payload:this.payload.subarray(),signature:this.signature})),this.marshaled}equals(e){return de(this.marshal(),e.marshal())}async validate(e){let t=al(e,this.payloadType,this.payload);if(this.peerId.publicKey==null)throw new Error("Missing public key");return rl(this.peerId.publicKey).verify(t.subarray(),this.signature)}},al=(r,e,t)=>{let n=F(r),s=Le(n.byteLength),o=Le(e.length),i=Le(t.length);return new Ye(s,n,o,e,i,t)};function cl(r,e){let t=(n,s)=>n.toString().localeCompare(s.toString());return r.length!==e.length?!1:(e.sort(t),r.sort(t).every((n,s)=>e[s].equals(n)))}var xs=class{index=0;input="";new(e){return this.index=0,this.input=e,this}readAtomically(e){let t=this.index,n=e();return n===void 0&&(this.index=t),n}parseWith(e){let t=e();if(this.index===this.input.length)return t}peekChar(){if(!(this.index>=this.input.length))return this.input[this.index]}readChar(){if(!(this.index>=this.input.length))return this.input[this.index++]}readGivenChar(e){return this.readAtomically(()=>{let t=this.readChar();if(t===e)return t})}readSeparator(e,t,n){return this.readAtomically(()=>{if(!(t>0&&this.readGivenChar(e)===void 0))return n()})}readNumber(e,t,n,s){return this.readAtomically(()=>{let o=0,i=0,a=this.peekChar();if(a===void 0)return;let c=a==="0",f=2**(8*s)-1;for(;;){let u=this.readAtomically(()=>{let l=this.readChar();if(l===void 0)return;let d=Number.parseInt(l,e);if(!Number.isNaN(d))return d});if(u===void 0)break;if(o*=e,o+=u,o>f||(i+=1,t!==void 0&&i>t))return}if(i!==0)return!n&&c&&i>1?void 0:o})}readIPv4Addr(){return this.readAtomically(()=>{let e=new Uint8Array(4);for(let t=0;t<e.length;t++){let n=this.readSeparator(".",t,()=>this.readNumber(10,3,!1,1));if(n===void 0)return;e[t]=n}return e})}readIPv6Addr(){let e=t=>{for(let n=0;n<t.length/2;n++){let s=n*2;if(n<t.length-3){let i=this.readSeparator(":",n,()=>this.readIPv4Addr());if(i!==void 0)return t[s]=i[0],t[s+1]=i[1],t[s+2]=i[2],t[s+3]=i[3],[s+4,!0]}let o=this.readSeparator(":",n,()=>this.readNumber(16,4,!0,2));if(o===void 0)return[s,!1];t[s]=o>>8,t[s+1]=o&255}return[t.length,!1]};return this.readAtomically(()=>{let t=new Uint8Array(16),[n,s]=e(t);if(n===16)return t;if(s||this.readGivenChar(":")===void 0||this.readGivenChar(":")===void 0)return;let o=new Uint8Array(14),i=16-(n+2),[a]=e(o.subarray(0,i));return t.set(o.subarray(0,a),16-a),t})}readIPAddr(){return this.readIPv4Addr()??this.readIPv6Addr()}};var ll=45,Td=15,Sr=new xs;function ai(r){if(!(r.length>Td))return Sr.new(r).parseWith(()=>Sr.readIPv4Addr())}function ci(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>ll))return Sr.new(r).parseWith(()=>Sr.readIPv6Addr())}function vs(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>ll))return Sr.new(r).parseWith(()=>Sr.readIPAddr())}var Uy=parseInt("0xFFFF",16),Py=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);function Es(r){return!!ai(r)}function Bs(r){return!!ci(r)}function As(r){return!!vs(r)}var hl=Es,Pd=Bs,li=function(r){let e=0;if(r=r.toString().trim(),hl(r)){let t=new Uint8Array(e+4);return r.split(/\./g).forEach(n=>{t[e++]=parseInt(n,10)&255}),t}if(Pd(r)){let t=r.split(":",8),n;for(n=0;n<t.length;n++){let o=hl(t[n]),i;o&&(i=li(t[n]),t[n]=K(i.slice(0,2),"base16")),i!=null&&++n<8&&t.splice(n,0,K(i.slice(2,4),"base16"))}if(t[0]==="")for(;t.length<8;)t.unshift("0");else if(t[t.length-1]==="")for(;t.length<8;)t.push("0");else if(t.length<8){for(n=0;n<t.length&&t[n]!=="";n++);let o=[n,1];for(n=9-t.length;n>0;n--)o.push("0");t.splice.apply(t,o)}let s=new Uint8Array(e+16);for(n=0;n<t.length;n++){let o=parseInt(t[n],16);s[e++]=o>>8&255,s[e++]=o&255}return s}throw new Error("invalid ip address")},dl=function(r,e=0,t){e=~~e,t=t??r.length-e;let n=new DataView(r.buffer);if(t===4){let s=[];for(let o=0;o<t;o++)s.push(r[e+o]);return s.join(".")}if(t===16){let s=[];for(let o=0;o<t;o+=2)s.push(n.getUint16(e+o).toString(16));return s.join(":").replace(/(^|:)0(:0)*:0(:|$)/,"$1::$3").replace(/:{3,4}/,"::")}return""};var kr={},ui={},Vd=[[4,32,"ip4"],[6,16,"tcp"],[33,16,"dccp"],[41,128,"ip6"],[42,-1,"ip6zone"],[43,8,"ipcidr"],[53,-1,"dns",!0],[54,-1,"dns4",!0],[55,-1,"dns6",!0],[56,-1,"dnsaddr",!0],[132,16,"sctp"],[273,16,"udp"],[275,0,"p2p-webrtc-star"],[276,0,"p2p-webrtc-direct"],[277,0,"p2p-stardust"],[280,0,"webrtc-direct"],[281,0,"webrtc"],[290,0,"p2p-circuit"],[301,0,"udt"],[302,0,"utp"],[400,-1,"unix",!1,!0],[421,-1,"ipfs"],[421,-1,"p2p"],[443,0,"https"],[444,96,"onion"],[445,296,"onion3"],[446,-1,"garlic64"],[448,0,"tls"],[449,-1,"sni"],[460,0,"quic"],[461,0,"quic-v1"],[465,0,"webtransport"],[466,-1,"certhash"],[477,0,"ws"],[478,0,"wss"],[479,0,"p2p-websocket-star"],[480,0,"http"],[777,-1,"memory"]];Vd.forEach(r=>{let e=Dd(...r);ui[e.code]=e,kr[e.name]=e});function Dd(r,e,t,n,s){return{code:r,size:e,name:t,resolvable:!!n,path:!!s}}function j(r){if(typeof r=="number"){if(ui[r]!=null)return ui[r];throw new Error(`no protocol with code: ${r}`)}else if(typeof r=="string"){if(kr[r]!=null)return kr[r];throw new Error(`no protocol with name: ${r}`)}throw new Error(`invalid protocol id type: ${typeof r}`)}var bb=j("ip4"),wb=j("ip6"),xb=j("ipcidr");function hi(r,e){switch(j(r).code){case 4:case 41:return Hd(e);case 42:return ml(e);case 6:case 273:case 33:case 132:return bl(e).toString();case 53:case 54:case 55:case 56:case 400:case 449:case 777:return ml(e);case 421:return $d(e);case 444:return yl(e);case 445:return yl(e);case 466:return qd(e);default:return K(e,"base16")}}function di(r,e){switch(j(r).code){case 4:return pl(e);case 41:return pl(e);case 42:return gl(e);case 6:case 273:case 33:case 132:return pi(parseInt(e,10));case 53:case 54:case 55:case 56:case 400:case 449:case 777:return gl(e);case 421:return Fd(e);case 444:return Gd(e);case 445:return zd(e);case 466:return Kd(e);default:return F(e,"base16")}}var fi=Object.values(St).map(r=>r.decoder),Md=function(){let r=fi[0].or(fi[1]);return fi.slice(2).forEach(e=>r=r.or(e)),r}();function pl(r){if(!As(r))throw new Error("invalid ip address");return li(r)}function Hd(r){let e=dl(r,0,r.length);if(e==null)throw new Error("ipBuff is required");if(!As(e))throw new Error("invalid ip address");return e}function pi(r){let e=new ArrayBuffer(2);return new DataView(e).setUint16(0,r),new Uint8Array(e)}function bl(r){return new DataView(r.buffer).getUint16(r.byteOffset)}function gl(r){let e=F(r),t=Uint8Array.from(Le(e.length));return Ae([t,e],t.length+e.length)}function ml(r){let e=gt(r);if(r=r.slice(ve(e)),r.length!==e)throw new Error("inconsistent lengths");return K(r)}function Fd(r){let e;r[0]==="Q"||r[0]==="1"?e=qt(ne.decode(`z${r}`)).bytes:e=De.parse(r).multihash.bytes;let t=Uint8Array.from(Le(e.length));return Ae([t,e],t.length+e.length)}function Kd(r){let e=Md.decode(r),t=Uint8Array.from(Le(e.length));return Ae([t,e],t.length+e.length)}function qd(r){let e=gt(r),t=r.slice(ve(e));if(t.length!==e)throw new Error("inconsistent lengths");return"u"+K(t,"base64url")}function $d(r){let e=gt(r),t=r.slice(ve(e));if(t.length!==e)throw new Error("inconsistent lengths");return K(t,"base58btc")}function Gd(r){let e=r.split(":");if(e.length!==2)throw new Error(`failed to parse onion addr: ["'${e.join('", "')}'"]' does not contain a port number`);if(e[0].length!==16)throw new Error(`failed to parse onion addr: ${e[0]} not a Tor onion address.`);let t=at.decode("b"+e[0]),n=parseInt(e[1],10);if(n<1||n>65536)throw new Error("Port number is not in range(1, 65536)");let s=pi(n);return Ae([t,s],t.length+s.length)}function zd(r){let e=r.split(":");if(e.length!==2)throw new Error(`failed to parse onion addr: ["'${e.join('", "')}'"]' does not contain a port number`);if(e[0].length!==56)throw new Error(`failed to parse onion addr: ${e[0]} not a Tor onion3 address.`);let t=at.decode(`b${e[0]}`),n=parseInt(e[1],10);if(n<1||n>65536)throw new Error("Port number is not in range(1, 65536)");let s=pi(n);return Ae([t,s],t.length+s.length)}function yl(r){let e=r.slice(0,r.length-2),t=r.slice(r.length-2),n=K(e,"base32"),s=bl(t);return`${n}:${s}`}function wl(r){r=gi(r);let e=[],t=[],n=null,s=r.split("/").slice(1);if(s.length===1&&s[0]==="")return{bytes:new Uint8Array,string:"/",tuples:[],stringTuples:[],path:null};for(let o=0;o<s.length;o++){let i=s[o],a=j(i);if(a.size===0){e.push([a.code]),t.push([a.code]);continue}if(o++,o>=s.length)throw vl("invalid address: "+r);if(a.path===!0){n=gi(s.slice(o).join("/")),e.push([a.code,di(a.code,n)]),t.push([a.code,n]);break}let c=di(a.code,s[o]);e.push([a.code,c]),t.push([a.code,hi(a.code,c)])}return{string:xl(t),bytes:yi(e),tuples:e,stringTuples:t,path:n}}function mi(r){let e=[],t=[],n=null,s=0;for(;s<r.length;){let o=gt(r,s),i=ve(o),a=j(o),c=jd(a,r.slice(s+i));if(c===0){e.push([o]),t.push([o]),s+=i;continue}let f=r.slice(s+i,s+i+c);if(s+=c+i,s>r.length)throw vl("Invalid address Uint8Array: "+K(r,"base16"));e.push([o,f]);let u=hi(o,f);if(t.push([o,u]),a.path===!0){n=u;break}}return{bytes:Uint8Array.from(r),string:xl(t),tuples:e,stringTuples:t,path:n}}function xl(r){let e=[];return r.map(t=>{let n=j(t[0]);return e.push(n.name),t.length>1&&t[1]!=null&&e.push(t[1]),null}),gi(e.join("/"))}function yi(r){return Ae(r.map(e=>{let t=j(e[0]),n=Uint8Array.from(Le(t.code));return e.length>1&&e[1]!=null&&(n=Ae([n,e[1]])),n}))}function jd(r,e){if(r.size>0)return r.size/8;if(r.size===0)return 0;{let t=gt(e instanceof Uint8Array?e:Uint8Array.from(e));return t+ve(t)}}function gi(r){return"/"+r.trim().split("/").filter(e=>e).join("/")}function vl(r){return new Error("Error parsing address: "+r)}var Wd=Symbol.for("nodejs.util.inspect.custom"),bi=Symbol.for("@multiformats/js-multiaddr/multiaddr"),Yd=[j("dns").code,j("dns4").code,j("dns6").code,j("dnsaddr").code],Is=class r{bytes;#e;#t;#r;#n;[bi]=!0;constructor(e){e==null&&(e="");let t;if(e instanceof Uint8Array)t=mi(e);else if(typeof e=="string"){if(e.length>0&&e.charAt(0)!=="/")throw new Error(`multiaddr "${e}" must start with a "/"`);t=wl(e)}else if(Bl(e))t=mi(e.bytes);else throw new Error("addr must be a string, Buffer, or another Multiaddr");this.bytes=t.bytes,this.#e=t.string,this.#t=t.tuples,this.#r=t.stringTuples,this.#n=t.path}toString(){return this.#e}toJSON(){return this.toString()}toOptions(){let e,t,n,s,o="",i=j("tcp"),a=j("udp"),c=j("ip4"),f=j("ip6"),u=j("dns6"),l=j("ip6zone");for(let[b,p]of this.stringTuples())b===l.code&&(o=`%${p??""}`),Yd.includes(b)&&(t=i.name,s=443,n=`${p??""}${o}`,e=b===u.code?6:4),(b===i.code||b===a.code)&&(t=j(b).name,s=parseInt(p??"")),(b===c.code||b===f.code)&&(t=j(b).name,n=`${p??""}${o}`,e=b===f.code?6:4);if(e==null||t==null||n==null||s==null)throw new Error('multiaddr must have a valid format: "/{ip4, ip6, dns4, dns6, dnsaddr}/{address}/{tcp, udp}/{port}".');return{family:e,host:n,transport:t,port:s}}protos(){return this.#t.map(([e])=>Object.assign({},j(e)))}protoCodes(){return this.#t.map(([e])=>e)}protoNames(){return this.#t.map(([e])=>j(e).name)}tuples(){return this.#t}stringTuples(){return this.#r}encapsulate(e){return e=new r(e),new r(this.toString()+e.toString())}decapsulate(e){let t=e.toString(),n=this.toString(),s=n.lastIndexOf(t);if(s<0)throw new Error(`Address ${this.toString()} does not contain subaddress: ${e.toString()}`);return new r(n.slice(0,s))}decapsulateCode(e){let t=this.tuples();for(let n=t.length-1;n>=0;n--)if(t[n][0]===e)return new r(yi(t.slice(0,n)));return this}getPeerId(){try{let e=[];this.stringTuples().forEach(([n,s])=>{n===kr.p2p.code&&e.push([n,s]),n===kr["p2p-circuit"].code&&(e=[])});let t=e.pop();if(t?.[1]!=null){let n=t[1];return n[0]==="Q"||n[0]==="1"?K(ne.decode(`z${n}`),"base58btc"):K(De.parse(n).multihash.bytes,"base58btc")}return null}catch{return null}}getPath(){return this.#n}equals(e){return de(this.bytes,e.bytes)}async resolve(e){let t=this.protos().find(o=>o.resolvable);if(t==null)return[this];let n=El.get(t.name);if(n==null)throw new C(`no available resolver for ${t.name}`,"ERR_NO_AVAILABLE_RESOLVER");return(await n(this,e)).map(o=>new r(o))}nodeAddress(){let e=this.toOptions();if(e.transport!=="tcp"&&e.transport!=="udp")throw new Error(`multiaddr must have a valid format - no protocol with name: "${e.transport}". Must have a valid transport protocol: "{tcp, udp}"`);return{family:e.family,address:e.host,port:e.port}}isThinWaistAddress(e){let t=(e??this).protos();return!(t.length!==2||t[0].code!==4&&t[0].code!==41||t[1].code!==6&&t[1].code!==273)}[Wd](){return`Multiaddr(${this.#e})`}};var El=new Map;function Bl(r){return!!r?.[bi]}function Ft(r){return new Is(r)}var Al="libp2p-peer-record",Il=Uint8Array.from([3,1]);var tn;(function(r){let e;(function(n){let s;n.codec=()=>(s==null&&(s=Ge((o,i,a={})=>{a.lengthDelimited!==!1&&i.fork(),o.multiaddr!=null&&o.multiaddr.byteLength>0&&(i.uint32(10),i.bytes(o.multiaddr)),a.lengthDelimited!==!1&&i.ldelim()},(o,i)=>{let a={multiaddr:new Uint8Array(0)},c=i==null?o.len:o.pos+i;for(;o.pos<c;){let f=o.uint32();switch(f>>>3){case 1:a.multiaddr=o.bytes();break;default:o.skipType(f&7);break}}return a})),s),n.encode=o=>$e(o,n.codec()),n.decode=o=>qe(o,n.codec())})(e=r.AddressInfo||(r.AddressInfo={}));let t;r.codec=()=>(t==null&&(t=Ge((n,s,o={})=>{if(o.lengthDelimited!==!1&&s.fork(),n.peerId!=null&&n.peerId.byteLength>0&&(s.uint32(10),s.bytes(n.peerId)),n.seq!=null&&n.seq!==0n&&(s.uint32(16),s.uint64(n.seq)),n.addresses!=null)for(let i of n.addresses)s.uint32(26),r.AddressInfo.codec().encode(i,s);o.lengthDelimited!==!1&&s.ldelim()},(n,s)=>{let o={peerId:new Uint8Array(0),seq:0n,addresses:[]},i=s==null?n.len:n.pos+s;for(;n.pos<i;){let a=n.uint32();switch(a>>>3){case 1:o.peerId=n.bytes();break;case 2:o.seq=n.uint64();break;case 3:o.addresses.push(r.AddressInfo.codec().decode(n,n.uint32()));break;default:n.skipType(a&7);break}}return o})),t),r.encode=n=>$e(n,r.codec()),r.decode=n=>qe(n,r.codec())})(tn||(tn={}));var Bt=class r{static createFromProtobuf=e=>{let t=tn.decode(e),n=ao(t.peerId),s=(t.addresses??[]).map(i=>Ft(i.multiaddr)),o=t.seq;return new r({peerId:n,multiaddrs:s,seqNumber:o})};static DOMAIN=Al;static CODEC=Il;peerId;multiaddrs;seqNumber;domain=r.DOMAIN;codec=r.CODEC;marshaled;constructor(e){let{peerId:t,multiaddrs:n,seqNumber:s}=e;this.peerId=t,this.multiaddrs=n??[],this.seqNumber=s??BigInt(Date.now())}marshal(){return this.marshaled==null&&(this.marshaled=tn.encode({peerId:this.peerId.toBytes(),seq:BigInt(this.seqNumber),addresses:this.multiaddrs.map(e=>({multiaddr:e.bytes}))})),this.marshaled}equals(e){return!(!(e instanceof r)||!this.peerId.equals(e.peerId)||this.seqNumber!==e.seqNumber||!cl(this.multiaddrs,e.multiaddrs))}};var Zd=r=>r.toString().split("/").slice(1),rn=r=>({match:e=>e.length<1?!1:r(e[0])?e.slice(1):!1,pattern:"fn"}),se=r=>({match:e=>rn(t=>t===r).match(e),pattern:r}),Ns=()=>({match:r=>rn(e=>typeof e=="string").match(r),pattern:"{string}"}),Sl=()=>({match:r=>rn(e=>!isNaN(parseInt(e))).match(r),pattern:"{number}"}),Oe=()=>({match:r=>{if(r.length<2||r[0]!=="p2p"&&r[0]!=="ipfs")return!1;if(r[1].startsWith("Q")||r[1].startsWith("1"))try{ne.decode(`z${r[1]}`)}catch{return!1}else return!1;return r.slice(2)},pattern:"/p2p/{peerid}"}),Ss=()=>({match:r=>{if(r.length<2||r[0]!=="certhash")return!1;try{Ys.decode(r[1])}catch{return!1}return r.slice(2)},pattern:"/certhash/{certhash}"}),nt=r=>({match:e=>{let t=r.match(e);return t===!1?e:t},pattern:`optional(${r.pattern})`}),st=(...r)=>({match:e=>{let t;for(let n of r){let s=n.match(e);s!==!1&&(t==null||s.length<t.length)&&(t=s)}return t??!1},pattern:`or(${r.map(e=>e.pattern).join(", ")})`}),oe=(...r)=>({match:e=>{for(let t of r){let n=t.match(e);if(n===!1)return!1;e=n}return e},pattern:`and(${r.map(e=>e.pattern).join(", ")})`});function fe(...r){function e(s){let o=Zd(s);for(let i of r){let a=i.match(o);if(a===!1)return!1;o=a}return o}function t(s){return e(s)!==!1}function n(s){let o=e(s);return o===!1?!1:o.length===0}return{matches:t,exactMatch:n}}var xi=oe(se("dns4"),Ns()),vi=oe(se("dns6"),Ns()),Ei=oe(se("dnsaddr"),Ns()),kl=oe(se("dns"),Ns()),aw=fe(xi),cw=fe(vi),lw=fe(Ei),uw=fe(st(kl,Ei,xi,vi)),Nl=oe(se("ip4"),rn(Es)),Rl=oe(se("ip6"),rn(Bs)),Tl=st(Nl,Rl),nn=st(Tl,kl,xi,vi,Ei),_l=fe(nn),fw=fe(Nl),hw=fe(Rl),dw=fe(Tl),Rs=oe(nn,se("tcp"),Sl()),sn=oe(nn,se("udp"),Sl()),Jd=st(Rs,sn),pw=fe(Rs),gw=fe(sn),Bi=oe(sn,se("quic")),Ts=oe(sn,se("quic-v1")),Xd=st(Bi,Ts),mw=fe(Bi),yw=fe(Ts),wi=st(nn,Rs,sn,Bi,Ts),Cl=st(oe(wi,se("ws"),nt(Oe()))),bw=fe(Cl),Ll=st(oe(wi,se("wss"),nt(Oe())),oe(wi,se("tls"),se("ws"),nt(Oe()))),ww=fe(Ll),Ul=oe(Jd,se("webrtc-direct"),Ss(),nt(Ss()),nt(Oe())),xw=fe(Ul),Pl=oe(Ts,se("webtransport"),Ss(),Ss(),nt(Oe())),vw=fe(Pl),ks=st(Cl,Ll,oe(Rs,nt(Oe())),oe(Xd,nt(Oe())),oe(nn,nt(Oe())),Ul,Pl,Oe()),Ew=fe(ks),Qd=oe(ks,se("p2p-circuit"),Oe()),Bw=fe(Qd),e0=st(oe(ks,se("p2p-circuit"),se("webrtc"),Oe()),oe(ks,se("webrtc"),nt(Oe())),se("webrtc")),Aw=fe(e0);function Nr(){let r={};return r.promise=new Promise((e,t)=>{r.resolve=e,r.reject=t}),r}var _s=class extends Error{type;code;constructor(e,t){super(e??"The operation was aborted"),this.type="aborted",this.name="AbortError",this.code=t??"ABORT_ERR"}};async function Ol(r,e,t){if(e==null)return r;if(e.aborted)return Promise.reject(new _s(t?.errorMessage,t?.errorCode));let n,s=new _s(t?.errorMessage,t?.errorCode);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 Ai=class{readNext;haveNext;ended;nextResult;constructor(){this.ended=!1,this.readNext=Nr(),this.haveNext=Nr()}[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=Nr(),e}async throw(e){return this.ended=!0,e!=null&&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");if(this.nextResult!=null&&(await this.readNext.promise,this.nextResult!=null))throw new Error("NeedNext promise resolved but nextResult was not consumed");e!=null?this.nextResult={done:!1,value:e}:(this.ended=!0,this.nextResult={done:!0,value:void 0}),this.haveNext.resolve(),this.haveNext=Nr(),await Ol(this.readNext.promise,t?.signal,t)}};function Vl(){return new Ai}var Cs=class extends Error{code;constructor(e,t){super(e),this.code=t}},Ii=class extends Cs{type;constructor(e){super(e,"ABORT_ERR"),this.type="aborted"}};function Dl(r,e){let t=Vl();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 Ye;return{read:async(i,a)=>{a?.signal?.throwIfAborted();let c,f=new Promise((u,l)=>{c=()=>{l(new Ii("Read aborted"))},a?.signal?.addEventListener("abort",c)});try{if(i==null){let{done:l,value:d}=await Promise.race([n.next(),f]);return l===!0?new Ye:d}for(;s.byteLength<i;){let{value:l,done:d}=await Promise.race([n.next(),f]);if(d===!0)throw new Cs("unexpected end of input","ERR_UNEXPECTED_EOF");s.append(l)}let u=s.sublist(0,i);return s.consume(i),u}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 Ls=class extends Error{code;constructor(e,t){super(e),this.code=t}};function Ml(r,e={}){let t=Dl(r,e);e.maxDataLength!=null&&e.maxLengthLength==null&&(e.maxLengthLength=ve(e.maxDataLength));let n=e?.lengthDecoder??gt,s=e?.lengthEncoder??Le;return{read:async i=>{let a=-1,c=new Ye;for(;;){c.append(await t.read(1,i));try{a=n(c)}catch(f){if(f instanceof RangeError)continue;throw f}if(e?.maxLengthLength!=null&&c.byteLength>e.maxLengthLength)throw new Ls("message length length too long","ERR_MSG_LENGTH_TOO_LONG");if(a>-1)break}if(e?.maxDataLength!=null&&a>e.maxDataLength)throw new Ls("message length too long","ERR_MSG_DATA_TOO_LONG");return t.read(a,i)},write:async(i,a)=>{await t.write(new Ye(s(i.byteLength),i),a)},writeV:async(i,a)=>{let c=new Ye(...i.flatMap(f=>[s(f.byteLength),f]));await t.write(c,a)},unwrap:()=>t.unwrap()}}function on(r,e){let t=Ml(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 Kl=Di(Fl(),1),Si=typeof window=="object"&&typeof document=="object"&&document.nodeType===9,Us=(0,Kl.default)(),ql=Si&&!Us,$l=Us&&!Si,Gl=Us&&Si,zl=typeof globalThis.process<"u"&&typeof globalThis.process.release<"u"&&globalThis.process.release.name==="node"&&!Us,jl=typeof importScripts=="function"&&typeof self<"u"&&typeof WorkerGlobalScope<"u"&&self instanceof WorkerGlobalScope,Fw=typeof globalThis.process<"u"&&typeof globalThis.process.env<"u"&&globalThis.process.env["NODE"+"_"+"ENV"]==="test",Wl=typeof navigator<"u"&&navigator.product==="ReactNative";var tr;(function(r){let e;r.codec=()=>(e==null&&(e=Ge((t,n,s={})=>{if(s.lengthDelimited!==!1&&n.fork(),t.protocolVersion!=null&&(n.uint32(42),n.string(t.protocolVersion)),t.agentVersion!=null&&(n.uint32(50),n.string(t.agentVersion)),t.publicKey!=null&&(n.uint32(10),n.bytes(t.publicKey)),t.listenAddrs!=null)for(let o of t.listenAddrs)n.uint32(18),n.bytes(o);if(t.observedAddr!=null&&(n.uint32(34),n.bytes(t.observedAddr)),t.protocols!=null)for(let o of t.protocols)n.uint32(26),n.string(o);t.signedPeerRecord!=null&&(n.uint32(66),n.bytes(t.signedPeerRecord)),s.lengthDelimited!==!1&&n.ldelim()},(t,n)=>{let s={listenAddrs:[],protocols:[]},o=n==null?t.len:t.pos+n;for(;t.pos<o;){let i=t.uint32();switch(i>>>3){case 5:s.protocolVersion=t.string();break;case 6:s.agentVersion=t.string();break;case 1:s.publicKey=t.bytes();break;case 2:s.listenAddrs.push(t.bytes());break;case 4:s.observedAddr=t.bytes();break;case 3:s.protocols.push(t.string());break;case 8:s.signedPeerRecord=t.bytes();break;default:t.skipType(i&7);break}}return s})),e),r.encode=t=>$e(t,r.codec()),r.decode=t=>qe(t,r.codec())})(tr||(tr={}));var ki=1024*8,Ve={protocolPrefix:"ipfs",timeout:6e4,maxInboundStreams:1,maxOutboundStreams:1,maxPushIncomingStreams:1,maxPushOutgoingStreams:1,maxObservedAddresses:10,maxIdentifyMessageSize:8192,runOnConnectionOpen:!0,runOnTransientConnection:!0},Ps=class{identifyProtocolStr;identifyPushProtocolStr;host;started;timeout;peerId;peerStore;registrar;connectionManager;addressManager;maxInboundStreams;maxOutboundStreams;maxPushIncomingStreams;maxPushOutgoingStreams;maxIdentifyMessageSize;maxObservedAddresses;events;runOnTransientConnection;log;constructor(e,t={}){this.started=!1,this.peerId=e.peerId,this.peerStore=e.peerStore,this.registrar=e.registrar,this.addressManager=e.addressManager,this.connectionManager=e.connectionManager,this.events=e.events,this.log=e.logger.forComponent("libp2p:identify"),this.identifyProtocolStr=`/${t.protocolPrefix??Ve.protocolPrefix}/${Ki}/${$i}`,this.identifyPushProtocolStr=`/${t.protocolPrefix??Ve.protocolPrefix}/${qi}/${Gi}`,this.timeout=t.timeout??Ve.timeout,this.maxInboundStreams=t.maxInboundStreams??Ve.maxInboundStreams,this.maxOutboundStreams=t.maxOutboundStreams??Ve.maxOutboundStreams,this.maxPushIncomingStreams=t.maxPushIncomingStreams??Ve.maxPushIncomingStreams,this.maxPushOutgoingStreams=t.maxPushOutgoingStreams??Ve.maxPushOutgoingStreams,this.maxIdentifyMessageSize=t.maxIdentifyMessageSize??Ve.maxIdentifyMessageSize,this.maxObservedAddresses=t.maxObservedAddresses??Ve.maxObservedAddresses,this.runOnTransientConnection=t.runOnTransientConnection??Ve.runOnTransientConnection,this.host={protocolVersion:`${t.protocolPrefix??Ve.protocolPrefix}/${Fi}`,agentVersion:t.agentVersion??`${e.nodeInfo.name}/${e.nodeInfo.version}`},(t.runOnConnectionOpen??Ve.runOnConnectionOpen)&&e.events.addEventListener("connection:open",n=>{let s=n.detail;this.identify(s).catch(o=>{this.log.error("error during identify trigged by connection:open",o)})}),e.events.addEventListener("self:peer:update",n=>{this.push().catch(s=>{this.log.error(s)})}),this.host.agentVersion===`${e.nodeInfo.name}/${e.nodeInfo.version}`&&(zl||$l?this.host.agentVersion+=` UserAgent=${globalThis.process.version}`:(ql||jl||Gl||Wl)&&(this.host.agentVersion+=` UserAgent=${globalThis.navigator.userAgent}`))}isStarted(){return this.started}async start(){this.started||(await this.peerStore.merge(this.peerId,{metadata:{AgentVersion:F(this.host.agentVersion),ProtocolVersion:F(this.host.protocolVersion)}}),await this.registrar.handle(this.identifyProtocolStr,e=>{this._handleIdentify(e).catch(t=>{this.log.error(t)})},{maxInboundStreams:this.maxInboundStreams,maxOutboundStreams:this.maxOutboundStreams,runOnTransientConnection:this.runOnTransientConnection}),await this.registrar.handle(this.identifyPushProtocolStr,e=>{this._handlePush(e).catch(t=>{this.log.error(t)})},{maxInboundStreams:this.maxPushIncomingStreams,maxOutboundStreams:this.maxPushOutgoingStreams,runOnTransientConnection:this.runOnTransientConnection}),this.started=!0)}async stop(){await this.registrar.unhandle(this.identifyProtocolStr),await this.registrar.unhandle(this.identifyPushProtocolStr),this.started=!1}async pushToConnections(e){let t=this.addressManager.getAddresses().map(u=>u.decapsulateCode(j("p2p").code)),n=new Bt({peerId:this.peerId,multiaddrs:t}),s=await Ht.seal(n,this.peerId),o=this.registrar.getProtocols(),i=await this.peerStore.get(this.peerId),a=K(i.metadata.get("AgentVersion")??F(this.host.agentVersion)),c=K(i.metadata.get("ProtocolVersion")??F(this.host.protocolVersion)),f=e.map(async u=>{let l,d=AbortSignal.timeout(this.timeout);cn(1/0,d);try{l=await u.newStream(this.identifyPushProtocolStr,{signal:d,runOnTransientConnection:this.runOnTransientConnection}),await on(l,{maxDataLength:this.maxIdentifyMessageSize??ki}).pb(tr).write({listenAddrs:t.map(p=>p.bytes),signedPeerRecord:s.marshal(),protocols:o,agentVersion:a,protocolVersion:c},{signal:d}),await l.close({signal:d})}catch(b){this.log.error("could not push identify update to peer",b),l?.abort(b)}});await Promise.all(f)}async push(){if(!this.isStarted())return;let e=[];await Promise.all(this.connectionManager.getConnections().map(async t=>{try{if(!(await this.peerStore.get(t.remotePeer)).protocols.includes(this.identifyPushProtocolStr))return;e.push(t)}catch(n){if(n.code!==ji)throw n}})),await this.pushToConnections(e)}async _identify(e,t={}){let n;if(t.signal==null){let s=AbortSignal.timeout(this.timeout);cn(1/0,s),t={...t,signal:s}}try{n=await e.newStream(this.identifyProtocolStr,{...t,runOnTransientConnection:this.runOnTransientConnection});let o=await on(n,{maxDataLength:this.maxIdentifyMessageSize??ki}).pb(tr).read(t);return await n.close(t),o}catch(s){throw this.log.error("error while reading identify message",s),n?.abort(s),s}}async identify(e,t={}){let n=await this._identify(e,t),{publicKey:s,protocols:o,observedAddr:i}=n;if(s==null)throw new C("public key was missing from identify message","ERR_MISSING_PUBLIC_KEY");let a=await Ur(s);if(!e.remotePeer.equals(a))throw new C("identified peer does not match the expected peer","ERR_INVALID_PEER");if(this.peerId.equals(a))throw new C("identified peer is our own peer id?","ERR_INVALID_PEER");let c=r0(i);return this.log("identify completed for peer %p and protocols %o",a,o),this.log("our observed address is %a",c),c!=null&&this.addressManager.getObservedAddrs().length<(this.maxObservedAddresses??1/0)&&(this.log("storing our observed address %a",c),this.addressManager.addObservedAddr(c)),this.#e(e,n)}async _handleIdentify(e){let{connection:t,stream:n}=e,s=AbortSignal.timeout(this.timeout);cn(1/0,s);try{let o=this.peerId.publicKey??new Uint8Array(0),i=await this.peerStore.get(this.peerId),a=this.addressManager.getAddresses().map(l=>l.decapsulateCode(j("p2p").code)),c=i.peerRecordEnvelope;if(a.length>0&&c==null){let l=new Bt({peerId:this.peerId,multiaddrs:a});c=(await Ht.seal(l,this.peerId)).marshal().subarray()}let f=t.remoteAddr.bytes;_l.matches(t.remoteAddr)||(f=void 0),await on(n).pb(tr).write({protocolVersion:this.host.protocolVersion,agentVersion:this.host.agentVersion,publicKey:o,listenAddrs:a.map(l=>l.bytes),signedPeerRecord:c,observedAddr:f,protocols:i.protocols},{signal:s}),await n.close({signal:s})}catch(o){this.log.error("could not respond to identify request",o),n.abort(o)}}async _handlePush(e){let{connection:t,stream:n}=e;try{if(this.peerId.equals(t.remotePeer))throw new Error("received push from ourselves?");let s={signal:AbortSignal.timeout(this.timeout)},i=await on(n,{maxDataLength:this.maxIdentifyMessageSize??ki}).pb(tr).read(s);await n.close(s),await this.#e(t,i)}catch(s){this.log.error("received invalid message",s),n.abort(s);return}this.log("handled push from %p",t.remotePeer)}async#e(e,t){if(this.log("received identify from %p",e.remotePeer),t==null)throw new C("message was null or undefined","ERR_INVALID_MESSAGE");let n={};if(t.listenAddrs.length>0&&(n.addresses=t.listenAddrs.map(i=>({isCertified:!1,multiaddr:Ft(i)}))),t.protocols.length>0&&(n.protocols=t.protocols),t.publicKey!=null&&(n.publicKey=t.publicKey,!(await Ur(t.publicKey)).equals(e.remotePeer)))throw new C("public key did not match remote PeerId","ERR_INVALID_PUBLIC_KEY");let s;if(t.signedPeerRecord!=null){this.log("received signedPeerRecord from %p",e.remotePeer);let i=t.signedPeerRecord,a=await Ht.openAndCertify(i,Bt.DOMAIN),c=Bt.createFromProtobuf(a.payload);if(!c.peerId.equals(a.peerId))throw new C("signing key does not match PeerId in the PeerRecord","ERR_INVALID_SIGNING_KEY");if(!e.remotePeer.equals(c.peerId))throw new C("signing key does not match remote PeerId","ERR_INVALID_PEER_RECORD_KEY");let f;try{f=await this.peerStore.get(c.peerId)}catch(u){if(u.code!=="ERR_NOT_FOUND")throw u}if(f!=null&&(n.metadata=f.metadata,f.peerRecordEnvelope!=null)){let u=await Ht.createFromProtobuf(f.peerRecordEnvelope),l=Bt.createFromProtobuf(u.payload);l.seqNumber>=c.seqNumber&&(this.log("sequence number was lower or equal to existing sequence number - stored: %d received: %d",l.seqNumber,c.seqNumber),c=l,i=f.peerRecordEnvelope)}n.peerRecordEnvelope=i,n.addresses=c.multiaddrs.map(u=>({isCertified:!0,multiaddr:u})),s={seq:c.seqNumber,addresses:c.multiaddrs}}else this.log("%p did not send a signed peer record",e.remotePeer);if(this.log("patching %p with",e.remotePeer,n),await this.peerStore.patch(e.remotePeer,n),t.agentVersion!=null||t.protocolVersion!=null){let i={};t.agentVersion!=null&&(i.AgentVersion=F(t.agentVersion)),t.protocolVersion!=null&&(i.ProtocolVersion=F(t.protocolVersion)),this.log("merging %p metadata",e.remotePeer,i),await this.peerStore.merge(e.remotePeer,{metadata:i})}let o={peerId:e.remotePeer,protocolVersion:t.protocolVersion,agentVersion:t.agentVersion,publicKey:t.publicKey,listenAddrs:t.listenAddrs.map(i=>Ft(i)),observedAddr:t.observedAddr==null?void 0:Ft(t.observedAddr),protocols:t.protocols,signedPeerRecord:s,connection:e};return this.events.safeDispatchEvent("peer:identify",{detail:o}),o}};function r0(r){if(r!=null&&r.length>0)try{return Ft(r)}catch{}}var n0={IDENTIFY:Mi,IDENTIFY_PUSH:Hi};function s0(r={}){return e=>new Ps(e,r)}return cu(o0);})();
|
|
8
8
|
/*! Bundled license information:
|
|
9
9
|
|
|
10
10
|
pvtsutils/build/index.js:
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@libp2p/identify",
|
|
3
|
-
"version": "1.0.
|
|
3
|
+
"version": "1.0.13",
|
|
4
4
|
"description": "Implementation of the Identify Protocol",
|
|
5
5
|
"license": "Apache-2.0 OR MIT",
|
|
6
6
|
"homepage": "https://github.com/libp2p/js-libp2p/tree/main/packages/protocol-identify#readme",
|
|
@@ -51,29 +51,29 @@
|
|
|
51
51
|
"dep-check": "aegir dep-check"
|
|
52
52
|
},
|
|
53
53
|
"dependencies": {
|
|
54
|
-
"@libp2p/interface": "^1.1.
|
|
55
|
-
"@libp2p/interface-internal": "^1.0.
|
|
56
|
-
"@libp2p/peer-id": "^4.0.
|
|
57
|
-
"@libp2p/peer-record": "^7.0.
|
|
58
|
-
"@multiformats/multiaddr": "^12.1.
|
|
59
|
-
"@multiformats/multiaddr-matcher": "^1.1.
|
|
60
|
-
"it-protobuf-stream": "^1.1.
|
|
61
|
-
"protons-runtime": "^5.
|
|
62
|
-
"uint8arraylist": "^2.4.
|
|
63
|
-
"uint8arrays": "^5.0.
|
|
54
|
+
"@libp2p/interface": "^1.1.3",
|
|
55
|
+
"@libp2p/interface-internal": "^1.0.8",
|
|
56
|
+
"@libp2p/peer-id": "^4.0.6",
|
|
57
|
+
"@libp2p/peer-record": "^7.0.8",
|
|
58
|
+
"@multiformats/multiaddr": "^12.1.14",
|
|
59
|
+
"@multiformats/multiaddr-matcher": "^1.1.2",
|
|
60
|
+
"it-protobuf-stream": "^1.1.2",
|
|
61
|
+
"protons-runtime": "^5.4.0",
|
|
62
|
+
"uint8arraylist": "^2.4.8",
|
|
63
|
+
"uint8arrays": "^5.0.1",
|
|
64
64
|
"wherearewe": "^2.0.1"
|
|
65
65
|
},
|
|
66
66
|
"devDependencies": {
|
|
67
|
-
"@libp2p/interface-compliance-tests": "^5.
|
|
68
|
-
"@libp2p/logger": "^4.0.
|
|
69
|
-
"@libp2p/peer-id-factory": "^4.0.
|
|
70
|
-
"aegir": "^42.
|
|
67
|
+
"@libp2p/interface-compliance-tests": "^5.3.0",
|
|
68
|
+
"@libp2p/logger": "^4.0.6",
|
|
69
|
+
"@libp2p/peer-id-factory": "^4.0.6",
|
|
70
|
+
"aegir": "^42.2.3",
|
|
71
71
|
"delay": "^6.0.0",
|
|
72
72
|
"it-drain": "^3.0.5",
|
|
73
|
-
"it-length-prefixed": "^9.0.
|
|
73
|
+
"it-length-prefixed": "^9.0.4",
|
|
74
74
|
"it-pair": "^2.0.6",
|
|
75
|
-
"it-pushable": "^3.2.
|
|
76
|
-
"protons": "^7.
|
|
75
|
+
"it-pushable": "^3.2.3",
|
|
76
|
+
"protons": "^7.5.0",
|
|
77
77
|
"sinon-ts": "^2.0.0"
|
|
78
78
|
},
|
|
79
79
|
"sideEffects": false
|