@libp2p/floodsub 9.1.0 → 9.1.1
Sign up to get free protection for your applications and to get access to all the features.
- package/dist/index.min.js +3 -3
- package/package.json +7 -7
package/dist/index.min.js
CHANGED
@@ -1,10 +1,10 @@
|
|
1
1
|
(function (root, factory) {(typeof module === 'object' && module.exports) ? module.exports = factory() : root.Libp2PFloodsub = factory()}(typeof self !== 'undefined' ? self : this, function () {
|
2
|
-
"use strict";var Libp2PFloodsub=(()=>{var Lu=Object.create;var ln=Object.defineProperty;var Uu=Object.getOwnPropertyDescriptor;var Du=Object.getOwnPropertyNames;var Pu=Object.getPrototypeOf,Vu=Object.prototype.hasOwnProperty;var Ms=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),it=(r,t)=>{for(var e in t)ln(r,e,{get:t[e],enumerable:!0})},To=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of Du(t))!Vu.call(r,s)&&s!==e&&ln(r,s,{get:()=>t[s],enumerable:!(n=Uu(t,s))||n.enumerable});return r};var Hs=(r,t,e)=>(e=r!=null?Lu(Pu(r)):{},To(t||!r||!r.__esModule?ln(e,"default",{value:r,enumerable:!0}):e,r)),Ou=r=>To(ln({},"__esModule",{value:!0}),r);var Wa=Ms(Br=>{"use strict";var Bh="[object ArrayBuffer]",ue=class r{static isArrayBuffer(t){return Object.prototype.toString.call(t)===Bh}static toArrayBuffer(t){return this.isArrayBuffer(t)?t:t.byteLength===t.buffer.byteLength||t.byteOffset===0&&t.byteLength===t.buffer.byteLength?t.buffer:this.toUint8Array(t.buffer).slice(t.byteOffset,t.byteOffset+t.byteLength).buffer}static toUint8Array(t){return this.toView(t,Uint8Array)}static toView(t,e){if(t.constructor===e)return t;if(this.isArrayBuffer(t))return new e(t);if(this.isArrayBufferView(t))return new e(t.buffer,t.byteOffset,t.byteLength);throw new TypeError("The provided value is not of type '(ArrayBuffer or ArrayBufferView)'")}static isBufferSource(t){return this.isArrayBufferView(t)||this.isArrayBuffer(t)}static isArrayBufferView(t){return ArrayBuffer.isView(t)||t&&this.isArrayBuffer(t.buffer)}static isEqual(t,e){let n=r.toUint8Array(t),s=r.toUint8Array(e);if(n.length!==s.byteLength)return!1;for(let i=0;i<n.length;i++)if(n[i]!==s[i])return!1;return!0}static concat(...t){let e;Array.isArray(t[0])&&!(t[1]instanceof Function)||Array.isArray(t[0])&&t[1]instanceof Function?e=t[0]:t[t.length-1]instanceof Function?e=t.slice(0,t.length-1):e=t;let n=0;for(let o of e)n+=o.byteLength;let s=new Uint8Array(n),i=0;for(let o of e){let a=this.toUint8Array(o);s.set(a,i),i+=a.length}return t[t.length-1]instanceof Function?this.toView(s,t[t.length-1]):s.buffer}},Wi="string",Ah=/^[0-9a-f]+$/i,Sh=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,kh=/^[a-zA-Z0-9-_]+$/,Cn=class{static fromString(t){let e=unescape(encodeURIComponent(t)),n=new Uint8Array(e.length);for(let s=0;s<e.length;s++)n[s]=e.charCodeAt(s);return n.buffer}static toString(t){let e=ue.toUint8Array(t),n="";for(let i=0;i<e.length;i++)n+=String.fromCharCode(e[i]);return decodeURIComponent(escape(n))}},Ut=class{static toString(t,e=!1){let n=ue.toArrayBuffer(t),s=new DataView(n),i="";for(let o=0;o<n.byteLength;o+=2){let a=s.getUint16(o,e);i+=String.fromCharCode(a)}return i}static fromString(t,e=!1){let n=new ArrayBuffer(t.length*2),s=new DataView(n);for(let i=0;i<t.length;i++)s.setUint16(i*2,t.charCodeAt(i),e);return n}},Ln=class r{static isHex(t){return typeof t===Wi&&Ah.test(t)}static isBase64(t){return typeof t===Wi&&Sh.test(t)}static isBase64Url(t){return typeof t===Wi&&kh.test(t)}static ToString(t,e="utf8"){let n=ue.toUint8Array(t);switch(e.toLowerCase()){case"utf8":return this.ToUtf8String(n);case"binary":return this.ToBinary(n);case"hex":return this.ToHex(n);case"base64":return this.ToBase64(n);case"base64url":return this.ToBase64Url(n);case"utf16le":return Ut.toString(n,!0);case"utf16":case"utf16be":return Ut.toString(n);default:throw new Error(`Unknown type of encoding '${e}'`)}}static FromString(t,e="utf8"){if(!t)return new ArrayBuffer(0);switch(e.toLowerCase()){case"utf8":return this.FromUtf8String(t);case"binary":return this.FromBinary(t);case"hex":return this.FromHex(t);case"base64":return this.FromBase64(t);case"base64url":return this.FromBase64Url(t);case"utf16le":return Ut.fromString(t,!0);case"utf16":case"utf16be":return Ut.fromString(t);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToBase64(t){let e=ue.toUint8Array(t);if(typeof btoa<"u"){let n=this.ToString(e,"binary");return btoa(n)}else return Buffer.from(e).toString("base64")}static FromBase64(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isBase64(e))throw new TypeError("Argument 'base64Text' is not Base64 encoded");return typeof atob<"u"?this.FromBinary(atob(e)):new Uint8Array(Buffer.from(e,"base64")).buffer}static FromBase64Url(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isBase64Url(e))throw new TypeError("Argument 'base64url' is not Base64Url encoded");return this.FromBase64(this.Base64Padding(e.replace(/\-/g,"+").replace(/\_/g,"/")))}static ToBase64Url(t){return this.ToBase64(t).replace(/\+/g,"-").replace(/\//g,"_").replace(/\=/g,"")}static FromUtf8String(t,e=r.DEFAULT_UTF8_ENCODING){switch(e){case"ascii":return this.FromBinary(t);case"utf8":return Cn.fromString(t);case"utf16":case"utf16be":return Ut.fromString(t);case"utf16le":case"usc2":return Ut.fromString(t,!0);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToUtf8String(t,e=r.DEFAULT_UTF8_ENCODING){switch(e){case"ascii":return this.ToBinary(t);case"utf8":return Cn.toString(t);case"utf16":case"utf16be":return Ut.toString(t);case"utf16le":case"usc2":return Ut.toString(t,!0);default:throw new Error(`Unknown type of encoding '${e}'`)}}static FromBinary(t){let e=t.length,n=new Uint8Array(e);for(let s=0;s<e;s++)n[s]=t.charCodeAt(s);return n.buffer}static ToBinary(t){let e=ue.toUint8Array(t),n="";for(let s=0;s<e.length;s++)n+=String.fromCharCode(e[s]);return n}static ToHex(t){let e=ue.toUint8Array(t),n="",s=e.length;for(let i=0;i<s;i++){let o=e[i];o<16&&(n+="0"),n+=o.toString(16)}return n}static FromHex(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isHex(e))throw new TypeError("Argument 'hexString' is not HEX encoded");e.length%2&&(e=`0${e}`);let n=new Uint8Array(e.length/2);for(let s=0;s<e.length;s=s+2){let i=e.slice(s,s+2);n[s/2]=parseInt(i,16)}return n.buffer}static ToUtf16String(t,e=!1){return Ut.toString(t,e)}static FromUtf16String(t,e=!1){return Ut.fromString(t,e)}static Base64Padding(t){let e=4-t.length%4;if(e<4)for(let n=0;n<e;n++)t+="=";return t}static formatString(t){return t?.replace(/[\n\r\t ]/g,"")||""}};Ln.DEFAULT_UTF8_ENCODING="utf8";function Ih(r,...t){let e=arguments[0];for(let n=1;n<arguments.length;n++){let s=arguments[n];for(let i in s)e[i]=s[i]}return e}function Nh(...r){let t=r.map(s=>s.byteLength).reduce((s,i)=>s+i),e=new Uint8Array(t),n=0;return r.map(s=>new Uint8Array(s)).forEach(s=>{for(let i of s)e[n++]=i}),e.buffer}function Rh(r,t){if(!(r&&t)||r.byteLength!==t.byteLength)return!1;let e=new Uint8Array(r),n=new Uint8Array(t);for(let s=0;s<r.byteLength;s++)if(e[s]!==n[s])return!1;return!0}Br.BufferSourceConverter=ue;Br.Convert=Ln;Br.assign=Ih;Br.combine=Nh;Br.isEqual=Rh});var cu=Ms((nb,mo)=>{"use strict";var bd=Object.prototype.hasOwnProperty,St="~";function nn(){}Object.create&&(nn.prototype=Object.create(null),new nn().__proto__||(St=!1));function wd(r,t,e){this.fn=r,this.context=t,this.once=e||!1}function au(r,t,e,n,s){if(typeof e!="function")throw new TypeError("The listener must be a function");var i=new wd(e,n||r,s),o=St?St+t:t;return r._events[o]?r._events[o].fn?r._events[o]=[r._events[o],i]:r._events[o].push(i):(r._events[o]=i,r._eventsCount++),r}function As(r,t){--r._eventsCount===0?r._events=new nn:delete r._events[t]}function Et(){this._events=new nn,this._eventsCount=0}Et.prototype.eventNames=function(){var t=[],e,n;if(this._eventsCount===0)return t;for(n in e=this._events)bd.call(e,n)&&t.push(St?n.slice(1):n);return Object.getOwnPropertySymbols?t.concat(Object.getOwnPropertySymbols(e)):t};Et.prototype.listeners=function(t){var e=St?St+t:t,n=this._events[e];if(!n)return[];if(n.fn)return[n.fn];for(var s=0,i=n.length,o=new Array(i);s<i;s++)o[s]=n[s].fn;return o};Et.prototype.listenerCount=function(t){var e=St?St+t:t,n=this._events[e];return n?n.fn?1:n.length:0};Et.prototype.emit=function(t,e,n,s,i,o){var a=St?St+t:t;if(!this._events[a])return!1;var c=this._events[a],l=arguments.length,f,u;if(c.fn){switch(c.once&&this.removeListener(t,c.fn,void 0,!0),l){case 1:return c.fn.call(c.context),!0;case 2:return c.fn.call(c.context,e),!0;case 3:return c.fn.call(c.context,e,n),!0;case 4:return c.fn.call(c.context,e,n,s),!0;case 5:return c.fn.call(c.context,e,n,s,i),!0;case 6:return c.fn.call(c.context,e,n,s,i,o),!0}for(u=1,f=new Array(l-1);u<l;u++)f[u-1]=arguments[u];c.fn.apply(c.context,f)}else{var p=c.length,w;for(u=0;u<p;u++)switch(c[u].once&&this.removeListener(t,c[u].fn,void 0,!0),l){case 1:c[u].fn.call(c[u].context);break;case 2:c[u].fn.call(c[u].context,e);break;case 3:c[u].fn.call(c[u].context,e,n);break;case 4:c[u].fn.call(c[u].context,e,n,s);break;default:if(!f)for(w=1,f=new Array(l-1);w<l;w++)f[w-1]=arguments[w];c[u].fn.apply(c[u].context,f)}}return!0};Et.prototype.on=function(t,e,n){return au(this,t,e,n,!1)};Et.prototype.once=function(t,e,n){return au(this,t,e,n,!0)};Et.prototype.removeListener=function(t,e,n,s){var i=St?St+t:t;if(!this._events[i])return this;if(!e)return As(this,i),this;var o=this._events[i];if(o.fn)o.fn===e&&(!s||o.once)&&(!n||o.context===n)&&As(this,i);else{for(var a=0,c=[],l=o.length;a<l;a++)(o[a].fn!==e||s&&!o[a].once||n&&o[a].context!==n)&&c.push(o[a]);c.length?this._events[i]=c.length===1?c[0]:c:As(this,i)}return this};Et.prototype.removeAllListeners=function(t){var e;return t?(e=St?St+t:t,this._events[e]&&As(this,e)):(this._events=new nn,this._eventsCount=0),this};Et.prototype.off=Et.prototype.removeListener;Et.prototype.addListener=Et.prototype.on;Et.prefixed=St;Et.EventEmitter=Et;typeof mo<"u"&&(mo.exports=Et)});var mu=Ms((Ab,gu)=>{"use strict";function pu(r,t){for(let e in t)Object.defineProperty(r,e,{value:t[e],enumerable:!0,configurable:!0});return r}function xd(r,t,e){if(!r||typeof r=="string")throw new TypeError("Please pass an Error to err-code");e||(e={}),typeof t=="object"&&(e=t,t=""),t&&(e.code=t);try{return pu(r,e)}catch{e.message=r.message,e.stack=r.stack;let s=function(){};return s.prototype=Object.create(Object.getPrototypeOf(r)),pu(new s,e)}}gu.exports=xd});var Rd={};it(Rd,{FloodSub:()=>Vs,floodsub:()=>Nd,multicodec:()=>vo});var Co=Symbol.for("@libp2p/peer-id");var Tr;(function(r){r.Accept="accept",r.Ignore="ignore",r.Reject="reject"})(Tr||(Tr={}));var A=class extends Error{code;props;constructor(t,e,n){super(t),this.code=e,this.name=n?.name??"CodeError",this.props=n??{}}};var Lo=(r,...t)=>{try{[...t]}catch{}};var We=class extends EventTarget{#t=new Map;constructor(){super(),Lo(1/0,this)}listenerCount(t){let e=this.#t.get(t);return e==null?0:e.length}addEventListener(t,e,n){super.addEventListener(t,e,n);let s=this.#t.get(t);s==null&&(s=[],this.#t.set(t,s)),s.push({callback:e,once:(n!==!0&&n!==!1&&n?.once)??!1})}removeEventListener(t,e,n){super.removeEventListener(t.toString(),e??null,n);let s=this.#t.get(t);s!=null&&(s=s.filter(({callback:i})=>i!==e),this.#t.set(t,s))}dispatchEvent(t){let e=super.dispatchEvent(t),n=this.#t.get(t.type);return n==null||(n=n.filter(({once:s})=>!s),this.#t.set(t.type,n)),e}safeDispatchEvent(t,e={}){return this.dispatchEvent(new Gt(t,e))}},Ks=class extends Event{detail;constructor(t,e){super(t,e),this.detail=e?.detail}},Gt=globalThis.CustomEvent??Ks;var Vd=Symbol.for("@libp2p/service-capabilities"),Uo=Symbol.for("@libp2p/service-dependencies");var zs={};it(zs,{base58btc:()=>vt,base58flickr:()=>$u});var a0=new Uint8Array(0);function Do(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function Qt(r){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 Po(r){return new TextEncoder().encode(r)}function Vo(r){return new TextDecoder().decode(r)}function Mu(r,t){if(r.length>=255)throw new TypeError("Alphabet too long");for(var e=new Uint8Array(256),n=0;n<e.length;n++)e[n]=255;for(var s=0;s<r.length;s++){var i=r.charAt(s),o=i.charCodeAt(0);if(e[o]!==255)throw new TypeError(i+" is ambiguous");e[o]=s}var a=r.length,c=r.charAt(0),l=Math.log(a)/Math.log(256),f=Math.log(256)/Math.log(a);function u(g){if(g instanceof Uint8Array||(ArrayBuffer.isView(g)?g=new Uint8Array(g.buffer,g.byteOffset,g.byteLength):Array.isArray(g)&&(g=Uint8Array.from(g))),!(g instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(g.length===0)return"";for(var h=0,d=0,m=0,x=g.length;m!==x&&g[m]===0;)m++,h++;for(var b=(x-m)*f+1>>>0,T=new Uint8Array(b);m!==x;){for(var E=g[m],S=0,R=b-1;(E!==0||S<d)&&R!==-1;R--,S++)E+=256*T[R]>>>0,T[R]=E%a>>>0,E=E/a>>>0;if(E!==0)throw new Error("Non-zero carry");d=S,m++}for(var _=b-d;_!==b&&T[_]===0;)_++;for(var $=c.repeat(h);_<b;++_)$+=r.charAt(T[_]);return $}function p(g){if(typeof g!="string")throw new TypeError("Expected String");if(g.length===0)return new Uint8Array;var h=0;if(g[h]!==" "){for(var d=0,m=0;g[h]===c;)d++,h++;for(var x=(g.length-h)*l+1>>>0,b=new Uint8Array(x);g[h];){var T=e[g.charCodeAt(h)];if(T===255)return;for(var E=0,S=x-1;(T!==0||E<m)&&S!==-1;S--,E++)T+=a*b[S]>>>0,b[S]=T%256>>>0,T=T/256>>>0;if(T!==0)throw new Error("Non-zero carry");m=E,h++}if(g[h]!==" "){for(var R=x-m;R!==x&&b[R]===0;)R++;for(var _=new Uint8Array(d+(x-R)),$=d;R!==x;)_[$++]=b[R++];return _}}}function w(g){var h=p(g);if(h)return h;throw new Error(`Non-${t} character`)}return{encode:u,decodeUnsafe:p,decode:w}}var Hu=Mu,Ku=Hu,Mo=Ku;var Fs=class{name;prefix;baseEncode;constructor(t,e,n){this.name=t,this.prefix=e,this.baseEncode=n}encode(t){if(t instanceof Uint8Array)return`${this.prefix}${this.baseEncode(t)}`;throw Error("Unknown type, must be binary type")}},qs=class{name;prefix;baseDecode;prefixCodePoint;constructor(t,e,n){if(this.name=t,this.prefix=e,e.codePointAt(0)===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=e.codePointAt(0),this.baseDecode=n}decode(t){if(typeof t=="string"){if(t.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(t)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(t.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(t){return Ho(this,t)}},$s=class{decoders;constructor(t){this.decoders=t}or(t){return Ho(this,t)}decode(t){let e=t[0],n=this.decoders[e];if(n!=null)return n.decode(t);throw RangeError(`Unable to decode multibase string ${JSON.stringify(t)}, only inputs prefixed with ${Object.keys(this.decoders)} are supported`)}};function Ho(r,t){return new $s({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var Gs=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(t,e,n,s){this.name=t,this.prefix=e,this.baseEncode=n,this.baseDecode=s,this.encoder=new Fs(t,e,n),this.decoder=new qs(t,e,s)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function Je({name:r,prefix:t,encode:e,decode:n}){return new Gs(r,t,e,n)}function ye({name:r,prefix:t,alphabet:e}){let{encode:n,decode:s}=Mo(e,r);return Je({prefix:t,name:r,encode:n,decode:i=>Qt(s(i))})}function Fu(r,t,e,n){let s={};for(let f=0;f<t.length;++f)s[t[f]]=f;let i=r.length;for(;r[i-1]==="=";)--i;let o=new Uint8Array(i*e/8|0),a=0,c=0,l=0;for(let f=0;f<i;++f){let u=s[r[f]];if(u===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<e|u,a+=e,a>=8&&(a-=8,o[l++]=255&c>>a)}if(a>=e||255&c<<8-a)throw new SyntaxError("Unexpected end of data");return o}function qu(r,t,e){let n=t[t.length-1]==="=",s=(1<<e)-1,i="",o=0,a=0;for(let c=0;c<r.length;++c)for(a=a<<8|r[c],o+=8;o>e;)o-=e,i+=t[s&a>>o];if(o!==0&&(i+=t[s&a<<e-o]),n)for(;i.length*e&7;)i+="=";return i}function tt({name:r,prefix:t,bitsPerChar:e,alphabet:n}){return Je({prefix:t,name:r,encode(s){return qu(s,n,e)},decode(s){return Fu(s,n,e,r)}})}var vt=ye({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),$u=ye({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Ys={};it(Ys,{base10:()=>Gu});var Gu=ye({prefix:"9",name:"base10",alphabet:"0123456789"});var js={};it(js,{base16:()=>zu,base16upper:()=>Yu});var zu=tt({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Yu=tt({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Zs={};it(Zs,{base2:()=>ju});var ju=tt({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Ws={};it(Ws,{base256emoji:()=>Qu});var Ko=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}"),Zu=Ko.reduce((r,t,e)=>(r[e]=t,r),[]),Wu=Ko.reduce((r,t,e)=>(r[t.codePointAt(0)]=e,r),[]);function Ju(r){return r.reduce((t,e)=>(t+=Zu[e],t),"")}function Xu(r){let t=[];for(let e of r){let n=Wu[e.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${e}`);t.push(n)}return new Uint8Array(t)}var Qu=Je({prefix:"\u{1F680}",name:"base256emoji",encode:Ju,decode:Xu});var Js={};it(Js,{base32:()=>Xe,base32hex:()=>nl,base32hexpad:()=>il,base32hexpadupper:()=>ol,base32hexupper:()=>sl,base32pad:()=>el,base32padupper:()=>rl,base32upper:()=>tl,base32z:()=>al});var Xe=tt({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),tl=tt({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),el=tt({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),rl=tt({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),nl=tt({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),sl=tt({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),il=tt({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),ol=tt({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),al=tt({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Xs={};it(Xs,{base36:()=>cl,base36upper:()=>ul});var cl=ye({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),ul=ye({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Qs={};it(Qs,{base64:()=>Cr,base64pad:()=>ll,base64url:()=>fl,base64urlpad:()=>hl});var Cr=tt({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),ll=tt({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),fl=tt({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),hl=tt({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var ti={};it(ti,{base8:()=>dl});var dl=tt({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var ei={};it(ei,{identity:()=>pl});var pl=Je({prefix:"\0",name:"identity",encode:r=>Vo(r),decode:r=>Po(r)});var B0=new TextEncoder,A0=new TextDecoder;var ni={};it(ni,{identity:()=>be});var yl=$o,Fo=128,bl=127,wl=~bl,xl=Math.pow(2,31);function $o(r,t,e){t=t||[],e=e||0;for(var n=e;r>=xl;)t[e++]=r&255|Fo,r/=128;for(;r&wl;)t[e++]=r&255|Fo,r>>>=7;return t[e]=r|0,$o.bytes=e-n+1,t}var El=ri,vl=128,qo=127;function ri(r,n){var e=0,n=n||0,s=0,i=n,o,a=r.length;do{if(i>=a)throw ri.bytes=0,new RangeError("Could not decode varint");o=r[i++],e+=s<28?(o&qo)<<s:(o&qo)*Math.pow(2,s),s+=7}while(o>=vl);return ri.bytes=i-n,e}var Bl=Math.pow(2,7),Al=Math.pow(2,14),Sl=Math.pow(2,21),kl=Math.pow(2,28),Il=Math.pow(2,35),Nl=Math.pow(2,42),Rl=Math.pow(2,49),_l=Math.pow(2,56),Tl=Math.pow(2,63),Cl=function(r){return r<Bl?1:r<Al?2:r<Sl?3:r<kl?4:r<Il?5:r<Nl?6:r<Rl?7:r<_l?8:r<Tl?9:10},Ll={encode:yl,decode:El,encodingLength:Cl},Ul=Ll,Lr=Ul;function Ur(r,t=0){return[Lr.decode(r,t),Lr.decode.bytes]}function Qe(r,t,e=0){return Lr.encode(r,t,e),t}function tr(r){return Lr.encodingLength(r)}function zt(r,t){let e=t.byteLength,n=tr(r),s=n+tr(e),i=new Uint8Array(s+e);return Qe(r,i,0),Qe(e,i,n),i.set(t,s),new er(r,e,t,i)}function Dr(r){let t=Qt(r),[e,n]=Ur(t),[s,i]=Ur(t.subarray(n)),o=t.subarray(n+i);if(o.byteLength!==s)throw new Error("Incorrect length");return new er(e,s,o,t)}function Go(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&Do(r.bytes,e.bytes)}}var er=class{code;size;digest;bytes;constructor(t,e,n,s){this.code=t,this.size=e,this.digest=n,this.bytes=s}};var zo=0,Dl="identity",Yo=Qt;function Pl(r){return zt(zo,Yo(r))}var be={code:zo,name:Dl,encode:Yo,digest:Pl};var oi={};it(oi,{sha256:()=>ct,sha512:()=>Vl});function ii({name:r,code:t,encode:e}){return new si(r,t,e)}var si=class{name;code;encode;constructor(t,e,n){this.name=t,this.code=e,this.encode=n}digest(t){if(t instanceof Uint8Array){let e=this.encode(t);return e instanceof Uint8Array?zt(this.code,e):e.then(n=>zt(this.code,n))}else throw Error("Unknown type, must be binary type")}};function Zo(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var ct=ii({name:"sha2-256",code:18,encode:Zo("SHA-256")}),Vl=ii({name:"sha2-512",code:19,encode:Zo("SHA-512")});function Wo(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return Ml(e,ai(r),t??vt.encoder);default:return Hl(e,ai(r),t??Xe.encoder)}}var Jo=new WeakMap;function ai(r){let t=Jo.get(r);if(t==null){let e=new Map;return Jo.set(r,e),e}return t}var De=class r{code;version;multihash;bytes;"/";constructor(t,e,n,s){this.code=e,this.version=t,this.multihash=n,this.bytes=s,this["/"]=s}get asCID(){return this}get byteOffset(){return this.bytes.byteOffset}get byteLength(){return this.bytes.byteLength}toV0(){switch(this.version){case 0:return this;case 1:{let{code:t,multihash:e}=this;if(t!==Pr)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==Kl)throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");return r.createV0(e)}default:throw Error(`Can not convert CID version ${this.version} to version 0. This is a bug please report`)}}toV1(){switch(this.version){case 0:{let{code:t,digest:e}=this.multihash,n=zt(t,e);return r.createV1(this.code,n)}case 1:return this;default:throw Error(`Can not convert CID version ${this.version} to version 1. This is a bug please report`)}}equals(t){return r.equals(this,t)}static equals(t,e){let n=e;return n!=null&&t.code===n.code&&t.version===n.version&&Go(t.multihash,n.multihash)}toString(t){return Wo(this,t)}toJSON(){return{"/":Wo(this)}}link(){return this}[Symbol.toStringTag]="CID";[Symbol.for("nodejs.util.inspect.custom")](){return`CID(${this.toString()})`}static asCID(t){if(t==null)return null;let e=t;if(e instanceof r)return e;if(e["/"]!=null&&e["/"]===e.bytes||e.asCID===e){let{version:n,code:s,multihash:i,bytes:o}=e;return new r(n,s,i,o??Xo(n,s,i.bytes))}else if(e[Fl]===!0){let{version:n,multihash:s,code:i}=e,o=Dr(s);return r.create(n,i,o)}else return null}static create(t,e,n){if(typeof e!="number")throw new Error("String codecs are no longer supported");if(!(n.bytes instanceof Uint8Array))throw new Error("Invalid digest");switch(t){case 0:{if(e!==Pr)throw new Error(`Version 0 CID must use dag-pb (code: ${Pr}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let s=Xo(t,e,n.bytes);return new r(t,e,n,s)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,Pr,t)}static createV1(t,e){return r.create(1,t,e)}static decode(t){let[e,n]=r.decodeFirst(t);if(n.length!==0)throw new Error("Incorrect length");return e}static decodeFirst(t){let e=r.inspectBytes(t),n=e.size-e.multihashSize,s=Qt(t.subarray(n,n+e.multihashSize));if(s.byteLength!==e.multihashSize)throw new Error("Incorrect length");let i=s.subarray(e.multihashSize-e.digestSize),o=new er(e.multihashCode,e.digestSize,i,s);return[e.version===0?r.createV0(o):r.createV1(e.codec,o),t.subarray(e.size)]}static inspectBytes(t){let e=0,n=()=>{let[u,p]=Ur(t.subarray(e));return e+=p,u},s=n(),i=Pr;if(s===18?(s=0,e=0):i=n(),s!==0&&s!==1)throw new RangeError(`Invalid CID version ${s}`);let o=e,a=n(),c=n(),l=e+c,f=l-o;return{version:s,codec:i,multihashCode:a,digestSize:c,multihashSize:f,size:l}}static parse(t,e){let[n,s]=Ol(t,e),i=r.decode(s);if(i.version===0&&t[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return ai(i).set(n,t),i}};function Ol(r,t){switch(r[0]){case"Q":{let e=t??vt;return[vt.prefix,e.decode(`${vt.prefix}${r}`)]}case vt.prefix:{let e=t??vt;return[vt.prefix,e.decode(r)]}case Xe.prefix:{let e=t??Xe;return[Xe.prefix,e.decode(r)]}default:{if(t==null)throw Error("To parse non base32 or base58btc encoded CID multibase decoder must be provided");return[r[0],t.decode(r)]}}}function Ml(r,t,e){let{prefix:n}=e;if(n!==vt.prefix)throw Error(`Cannot string encode V0 in ${e.name} encoding`);let s=t.get(n);if(s==null){let i=e.encode(r).slice(1);return t.set(n,i),i}else return s}function Hl(r,t,e){let{prefix:n}=e,s=t.get(n);if(s==null){let i=e.encode(r);return t.set(n,i),i}else return s}var Pr=112,Kl=18;function Xo(r,t,e){let n=tr(r),s=n+tr(t),i=new Uint8Array(s+e.byteLength);return Qe(r,i,0),Qe(t,i,n),i.set(e,s),i}var Fl=Symbol.for("@ipld/js-cid/CID");var nr={...ei,...Zs,...ti,...Ys,...js,...Js,...Xs,...zs,...Qs,...Ws},G0={...oi,...ni};function mt(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}var ql=Symbol.for("nodejs.util.inspect.custom"),Qo=Object.values(nr).map(r=>r.decoder).reduce((r,t)=>r.or(t),nr.identity.decoder),ta=114,ci=36,ui=37,Vr=class{type;multihash;privateKey;publicKey;string;constructor(t){this.type=t.type,this.multihash=t.multihash,this.privateKey=t.privateKey,Object.defineProperty(this,"string",{enumerable:!1,writable:!0})}get[Symbol.toStringTag](){return`PeerId(${this.toString()})`}[Co]=!0;toString(){return this.string==null&&(this.string=vt.encode(this.multihash.bytes).slice(1)),this.string}toCID(){return De.createV1(ta,this.multihash)}toBytes(){return this.multihash.bytes}toJSON(){return this.toString()}equals(t){if(t==null)return!1;if(t instanceof Uint8Array)return mt(this.multihash.bytes,t);if(typeof t=="string")return te(t).equals(this);if(t?.multihash?.bytes!=null)return mt(this.multihash.bytes,t.multihash.bytes);throw new Error("not valid Id")}[ql](){return`PeerId(${this.toString()})`}},sr=class extends Vr{type="RSA";publicKey;constructor(t){super({...t,type:"RSA"}),this.publicKey=t.publicKey}},ir=class extends Vr{type="Ed25519";publicKey;constructor(t){super({...t,type:"Ed25519"}),this.publicKey=t.multihash.digest}},or=class extends Vr{type="secp256k1";publicKey;constructor(t){super({...t,type:"secp256k1"}),this.publicKey=t.multihash.digest}};function te(r,t){if(t=t??Qo,r.charAt(0)==="1"||r.charAt(0)==="Q"){let e=Dr(vt.decode(`z${r}`));return r.startsWith("12D")?new ir({multihash:e}):r.startsWith("16U")?new or({multihash:e}):new sr({multihash:e})}return Or(Qo.decode(r))}function Or(r){try{let t=Dr(r);if(t.code===be.code){if(t.digest.length===ci)return new ir({multihash:t});if(t.digest.length===ui)return new or({multihash:t})}if(t.code===ct.code)return new sr({multihash:t})}catch{return $l(De.decode(r))}throw new Error("Supplied PeerID CID is invalid")}function $l(r){if(r==null||r.multihash==null||r.version==null||r.version===1&&r.code!==ta)throw new Error("Supplied PeerID CID is invalid");let t=r.multihash;if(t.code===ct.code)return new sr({multihash:r.multihash});if(t.code===be.code){if(t.digest.length===ci)return new ir({multihash:r.multihash});if(t.digest.length===ui)return new or({multihash:r.multihash})}throw new Error("Supplied PeerID CID is invalid")}async function hn(r,t){return r.length===ci?new ir({multihash:zt(be.code,r),privateKey:t}):r.length===ui?new or({multihash:zt(be.code,r),privateKey:t}):new sr({multihash:await ct.digest(r),publicKey:r,privateKey:t})}function ar(r,t){let e={[Symbol.iterator]:()=>e,next:()=>{let n=r.next(),s=n.value;return n.done===!0||s==null?{done:!0,value:void 0}:{done:!1,value:t(s)}}};return e}var Mr=class{map;constructor(t){if(this.map=new Map,t!=null)for(let[e,n]of t.entries())this.map.set(e.toString(),n)}[Symbol.iterator](){return this.entries()}clear(){this.map.clear()}delete(t){return this.map.delete(t.toString())}entries(){return ar(this.map.entries(),t=>[te(t[0]),t[1]])}forEach(t){this.map.forEach((e,n)=>{t(e,te(n),this)})}get(t){return this.map.get(t.toString())}has(t){return this.map.has(t.toString())}set(t,e){this.map.set(t.toString(),e)}keys(){return ar(this.map.keys(),t=>te(t))}values(){return this.map.values()}get size(){return this.map.size}};var Hr=class r{set;constructor(t){if(this.set=new Set,t!=null)for(let e of t)this.set.add(e.toString())}get size(){return this.set.size}[Symbol.iterator](){return this.values()}add(t){this.set.add(t.toString())}clear(){this.set.clear()}delete(t){this.set.delete(t.toString())}entries(){return ar(this.set.entries(),t=>{let e=te(t[0]);return[e,e]})}forEach(t){this.set.forEach(e=>{let n=te(e);t(n,n,this)})}has(t){return this.set.has(t.toString())}values(){return ar(this.set.values(),t=>te(t))}intersection(t){let e=new r;for(let n of t)this.has(n)&&e.add(n);return e}difference(t){let e=new r;for(let n of this)t.has(n)||e.add(n);return e}union(t){let e=new r;for(let n of t)e.add(n);for(let n of this)e.add(n);return e}};var W={get(r=globalThis){let t=r.crypto;if(t==null||t.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 t}};var ea={SHA1:20,SHA256:32,SHA512:64};var Gl={SHA1:"SHA-1",SHA256:"SHA-256",SHA512:"SHA-512"},zl=async(r,t)=>{let e=await W.get().subtle.sign({name:"HMAC"},r,t);return new Uint8Array(e,0,e.byteLength)};async function ra(r,t){let e=Gl[r],n=await W.get().subtle.importKey("raw",t,{name:"HMAC",hash:{name:e}},!1,["sign"]);return{async digest(s){return zl(n,s)},length:ea[r]}}var en={};it(en,{Ed25519PrivateKey:()=>ce,Ed25519PublicKey:()=>Ke,MAX_RSA_KEY_SIZE:()=>$e,RsaPrivateKey:()=>_e,RsaPublicKey:()=>qe,Secp256k1PrivateKey:()=>Ye,Secp256k1PublicKey:()=>ze,generateEphemeralKeyPair:()=>za,generateKeyPair:()=>ad,generateKeyPairFromSeed:()=>cd,importKey:()=>hd,keyStretcher:()=>Za,keysPBM:()=>Er,marshalPrivateKey:()=>fd,marshalPublicKey:()=>ld,supportedKeys:()=>me,unmarshalPrivateKey:()=>eu,unmarshalPublicKey:()=>ud});var Yi={};it(Yi,{Ed25519PrivateKey:()=>ce,Ed25519PublicKey:()=>Ke,generateKeyPair:()=>yh,generateKeyPairFromSeed:()=>zi,unmarshalEd25519PrivateKey:()=>gh,unmarshalEd25519PublicKey:()=>mh});function ee(r=0){return new Uint8Array(r)}function yt(r=0){return new Uint8Array(r)}function Bt(r,t){t==null&&(t=r.reduce((s,i)=>s+i.length,0));let e=yt(t),n=0;for(let s of r)e.set(s,n),n+=s.length;return e}function sa(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var na=sa("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),li=sa("ascii","a",r=>{let t="a";for(let e=0;e<r.length;e++)t+=String.fromCharCode(r[e]);return t},r=>{r=r.substring(1);let t=yt(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),jl={utf8:na,"utf-8":na,hex:nr.base16,latin1:li,ascii:li,binary:li,...nr},dn=jl;function z(r,t="utf8"){let e=dn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function fi(r,t){let e=z(r,"base64urlpad");if(t!=null){if(e.length>t)throw new Error("byte array longer than desired length");e=Bt([new Uint8Array(t-e.length),e])}return e}function Lt(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function cr(r){if(!Number.isSafeInteger(r)||r<0)throw new Error(`positive integer expected, not ${r}`)}function Zl(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function ur(r,...t){if(!Zl(r))throw new Error("Uint8Array expected");if(t.length>0&&!t.includes(r.length))throw new Error(`Uint8Array expected of length ${t}, not of length=${r.length}`)}function pn(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");cr(r.outputLen),cr(r.blockLen)}function lr(r,t=!0){if(r.destroyed)throw new Error("Hash instance has been destroyed");if(t&&r.finished)throw new Error("Hash#digest() has already been called")}function ia(r,t){ur(r);let e=t.outputLen;if(r.length<e)throw new Error(`digestInto() expects output buffer of length at least ${e}`)}var gn=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;var hr=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),Pt=(r,t)=>r<<32-t|r>>>t;var Tp=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;var Wl=async()=>{};async function oa(r,t,e){let n=Date.now();for(let s=0;s<r;s++){e(s);let i=Date.now()-n;i>=0&&i<t||(await Wl(),n+=i)}}function hi(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function we(r){return typeof r=="string"&&(r=hi(r)),ur(r),r}function mn(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];ur(s),t+=s.length}let e=new Uint8Array(t);for(let n=0,s=0;n<r.length;n++){let i=r[n];e.set(i,s),s+=i.length}return e}var fr=class{clone(){return this._cloneInto()}},Jl={}.toString;function aa(r,t){if(t!==void 0&&Jl.call(t)!=="[object Object]")throw new Error("Options should be object or undefined");return Object.assign(r,t)}function yn(r){let t=n=>r().update(we(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function dr(r=32){if(gn&&typeof gn.getRandomValues=="function")return gn.getRandomValues(new Uint8Array(r));throw new Error("crypto.getRandomValues must be defined")}function Xl(r,t,e,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(t,e,n);let s=BigInt(32),i=BigInt(4294967295),o=Number(e>>s&i),a=Number(e&i),c=n?4:0,l=n?0:4;r.setUint32(t+c,o,n),r.setUint32(t+l,a,n)}var ca=(r,t,e)=>r&t^~r&e,ua=(r,t,e)=>r&t^r&e^t&e,pr=class extends fr{constructor(t,e,n,s){super(),this.blockLen=t,this.outputLen=e,this.padOffset=n,this.isLE=s,this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.buffer=new Uint8Array(t),this.view=hr(this.buffer)}update(t){lr(this);let{view:e,buffer:n,blockLen:s}=this;t=we(t);let i=t.length;for(let o=0;o<i;){let a=Math.min(s-this.pos,i-o);if(a===s){let c=hr(t);for(;s<=i-o;o+=s)this.process(c,o);continue}n.set(t.subarray(o,o+a),this.pos),this.pos+=a,o+=a,this.pos===s&&(this.process(e,0),this.pos=0)}return this.length+=t.length,this.roundClean(),this}digestInto(t){lr(this),ia(t,this),this.finished=!0;let{buffer:e,view:n,blockLen:s,isLE:i}=this,{pos:o}=this;e[o++]=128,this.buffer.subarray(o).fill(0),this.padOffset>s-o&&(this.process(n,0),o=0);for(let u=o;u<s;u++)e[u]=0;Xl(n,s-8,BigInt(this.length*8),i),this.process(n,0);let a=hr(t),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let l=c/4,f=this.get();if(l>f.length)throw new Error("_sha2: outputLen bigger than state");for(let u=0;u<l;u++)a.setUint32(4*u,f[u],i)}digest(){let{buffer:t,outputLen:e}=this;this.digestInto(t);let n=t.slice(0,e);return this.destroy(),n}_cloneInto(t){t||(t=new this.constructor),t.set(...this.get());let{blockLen:e,buffer:n,length:s,finished:i,destroyed:o,pos:a}=this;return t.length=s,t.pos=a,t.finished=i,t.destroyed=o,s%e&&t.buffer.set(n),t}};var bn=BigInt(4294967295),di=BigInt(32);function la(r,t=!1){return t?{h:Number(r&bn),l:Number(r>>di&bn)}:{h:Number(r>>di&bn)|0,l:Number(r&bn)|0}}function Ql(r,t=!1){let e=new Uint32Array(r.length),n=new Uint32Array(r.length);for(let s=0;s<r.length;s++){let{h:i,l:o}=la(r[s],t);[e[s],n[s]]=[i,o]}return[e,n]}var tf=(r,t)=>BigInt(r>>>0)<<di|BigInt(t>>>0),ef=(r,t,e)=>r>>>e,rf=(r,t,e)=>r<<32-e|t>>>e,nf=(r,t,e)=>r>>>e|t<<32-e,sf=(r,t,e)=>r<<32-e|t>>>e,of=(r,t,e)=>r<<64-e|t>>>e-32,af=(r,t,e)=>r>>>e-32|t<<64-e,cf=(r,t)=>t,uf=(r,t)=>r,lf=(r,t,e)=>r<<e|t>>>32-e,ff=(r,t,e)=>t<<e|r>>>32-e,hf=(r,t,e)=>t<<e-32|r>>>64-e,df=(r,t,e)=>r<<e-32|t>>>64-e;function pf(r,t,e,n){let s=(t>>>0)+(n>>>0);return{h:r+e+(s/2**32|0)|0,l:s|0}}var gf=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),mf=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,yf=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),bf=(r,t,e,n,s)=>t+e+n+s+(r/2**32|0)|0,wf=(r,t,e,n,s)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(s>>>0),xf=(r,t,e,n,s,i)=>t+e+n+s+i+(r/2**32|0)|0;var Ef={fromBig:la,split:Ql,toBig:tf,shrSH:ef,shrSL:rf,rotrSH:nf,rotrSL:sf,rotrBH:of,rotrBL:af,rotr32H:cf,rotr32L:uf,rotlSH:lf,rotlSL:ff,rotlBH:hf,rotlBL:df,add:pf,add3L:gf,add3H:mf,add4L:yf,add4H:bf,add5H:xf,add5L:wf},U=Ef;var[vf,Bf]=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))),xe=new Uint32Array(80),Ee=new Uint32Array(80),pi=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:t,Al:e,Bh:n,Bl:s,Ch:i,Cl:o,Dh:a,Dl:c,Eh:l,El:f,Fh:u,Fl:p,Gh:w,Gl:g,Hh:h,Hl:d}=this;return[t,e,n,s,i,o,a,c,l,f,u,p,w,g,h,d]}set(t,e,n,s,i,o,a,c,l,f,u,p,w,g,h,d){this.Ah=t|0,this.Al=e|0,this.Bh=n|0,this.Bl=s|0,this.Ch=i|0,this.Cl=o|0,this.Dh=a|0,this.Dl=c|0,this.Eh=l|0,this.El=f|0,this.Fh=u|0,this.Fl=p|0,this.Gh=w|0,this.Gl=g|0,this.Hh=h|0,this.Hl=d|0}process(t,e){for(let b=0;b<16;b++,e+=4)xe[b]=t.getUint32(e),Ee[b]=t.getUint32(e+=4);for(let b=16;b<80;b++){let T=xe[b-15]|0,E=Ee[b-15]|0,S=U.rotrSH(T,E,1)^U.rotrSH(T,E,8)^U.shrSH(T,E,7),R=U.rotrSL(T,E,1)^U.rotrSL(T,E,8)^U.shrSL(T,E,7),_=xe[b-2]|0,$=Ee[b-2]|0,K=U.rotrSH(_,$,19)^U.rotrBH(_,$,61)^U.shrSH(_,$,6),D=U.rotrSL(_,$,19)^U.rotrBL(_,$,61)^U.shrSL(_,$,6),nt=U.add4L(R,D,Ee[b-7],Ee[b-16]),rt=U.add4H(nt,S,K,xe[b-7],xe[b-16]);xe[b]=rt|0,Ee[b]=nt|0}let{Ah:n,Al:s,Bh:i,Bl:o,Ch:a,Cl:c,Dh:l,Dl:f,Eh:u,El:p,Fh:w,Fl:g,Gh:h,Gl:d,Hh:m,Hl:x}=this;for(let b=0;b<80;b++){let T=U.rotrSH(u,p,14)^U.rotrSH(u,p,18)^U.rotrBH(u,p,41),E=U.rotrSL(u,p,14)^U.rotrSL(u,p,18)^U.rotrBL(u,p,41),S=u&w^~u&h,R=p&g^~p&d,_=U.add5L(x,E,R,Bf[b],Ee[b]),$=U.add5H(_,m,T,S,vf[b],xe[b]),K=_|0,D=U.rotrSH(n,s,28)^U.rotrBH(n,s,34)^U.rotrBH(n,s,39),nt=U.rotrSL(n,s,28)^U.rotrBL(n,s,34)^U.rotrBL(n,s,39),rt=n&i^n&a^i&a,Ct=s&o^s&c^o&c;m=h|0,x=d|0,h=w|0,d=g|0,w=u|0,g=p|0,{h:u,l:p}=U.add(l|0,f|0,$|0,K|0),l=a|0,f=c|0,a=i|0,c=o|0,i=n|0,o=s|0;let v=U.add3L(K,nt,Ct);n=U.add3H(v,$,D,rt),s=v|0}({h:n,l:s}=U.add(this.Ah|0,this.Al|0,n|0,s|0)),{h:i,l:o}=U.add(this.Bh|0,this.Bl|0,i|0,o|0),{h:a,l:c}=U.add(this.Ch|0,this.Cl|0,a|0,c|0),{h:l,l:f}=U.add(this.Dh|0,this.Dl|0,l|0,f|0),{h:u,l:p}=U.add(this.Eh|0,this.El|0,u|0,p|0),{h:w,l:g}=U.add(this.Fh|0,this.Fl|0,w|0,g|0),{h,l:d}=U.add(this.Gh|0,this.Gl|0,h|0,d|0),{h:m,l:x}=U.add(this.Hh|0,this.Hl|0,m|0,x|0),this.set(n,s,i,o,a,c,l,f,u,p,w,g,h,d,m,x)}roundClean(){xe.fill(0),Ee.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=yn(()=>new pi);var xn={};it(xn,{abytes:()=>mr,bitGet:()=>_f,bitLen:()=>Rf,bitMask:()=>Kr,bitSet:()=>Tf,bytesToHex:()=>ne,bytesToNumberBE:()=>se,bytesToNumberLE:()=>Be,concatBytes:()=>ie,createHmacDrbg:()=>yi,ensureBytes:()=>et,equalBytes:()=>If,hexToBytes:()=>Pe,hexToNumber:()=>mi,isBytes:()=>ve,numberToBytesBE:()=>Ae,numberToBytesLE:()=>Ve,numberToHexUnpadded:()=>pa,numberToVarBytesBE:()=>kf,utf8ToBytes:()=>Nf,validateObject:()=>Yt});var da=BigInt(0),wn=BigInt(1),Af=BigInt(2);function ve(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function mr(r){if(!ve(r))throw new Error("Uint8Array expected")}var Sf=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function ne(r){mr(r);let t="";for(let e=0;e<r.length;e++)t+=Sf[r[e]];return t}function pa(r){let t=r.toString(16);return t.length&1?`0${t}`:t}function mi(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return BigInt(r===""?"0":`0x${r}`)}var re={_0:48,_9:57,_A:65,_F:70,_a:97,_f:102};function fa(r){if(r>=re._0&&r<=re._9)return r-re._0;if(r>=re._A&&r<=re._F)return r-(re._A-10);if(r>=re._a&&r<=re._f)return r-(re._a-10)}function Pe(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);let t=r.length,e=t/2;if(t%2)throw new Error("padded hex string expected, got unpadded hex of length "+t);let n=new Uint8Array(e);for(let s=0,i=0;s<e;s++,i+=2){let o=fa(r.charCodeAt(i)),a=fa(r.charCodeAt(i+1));if(o===void 0||a===void 0){let c=r[i]+r[i+1];throw new Error('hex string expected, got non-hex character "'+c+'" at index '+i)}n[s]=o*16+a}return n}function se(r){return mi(ne(r))}function Be(r){return mr(r),mi(ne(Uint8Array.from(r).reverse()))}function Ae(r,t){return Pe(r.toString(16).padStart(t*2,"0"))}function Ve(r,t){return Ae(r,t).reverse()}function kf(r){return Pe(pa(r))}function et(r,t,e){let n;if(typeof t=="string")try{n=Pe(t)}catch(i){throw new Error(`${r} must be valid hex string, got "${t}". Cause: ${i}`)}else if(ve(t))n=Uint8Array.from(t);else throw new Error(`${r} must be hex string or Uint8Array`);let s=n.length;if(typeof e=="number"&&s!==e)throw new Error(`${r} expected ${e} bytes, got ${s}`);return n}function ie(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];mr(s),t+=s.length}let e=new Uint8Array(t);for(let n=0,s=0;n<r.length;n++){let i=r[n];e.set(i,s),s+=i.length}return e}function If(r,t){if(r.length!==t.length)return!1;let e=0;for(let n=0;n<r.length;n++)e|=r[n]^t[n];return e===0}function Nf(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function Rf(r){let t;for(t=0;r>da;r>>=wn,t+=1);return t}function _f(r,t){return r>>BigInt(t)&wn}function Tf(r,t,e){return r|(e?wn:da)<<BigInt(t)}var Kr=r=>(Af<<BigInt(r-1))-wn,gi=r=>new Uint8Array(r),ha=r=>Uint8Array.from(r);function yi(r,t,e){if(typeof r!="number"||r<2)throw new Error("hashLen must be a number");if(typeof t!="number"||t<2)throw new Error("qByteLen must be a number");if(typeof e!="function")throw new Error("hmacFn must be a function");let n=gi(r),s=gi(r),i=0,o=()=>{n.fill(1),s.fill(0),i=0},a=(...u)=>e(s,n,...u),c=(u=gi())=>{s=a(ha([0]),u),n=a(),u.length!==0&&(s=a(ha([1]),u),n=a())},l=()=>{if(i++>=1e3)throw new Error("drbg: tried 1000 values");let u=0,p=[];for(;u<t;){n=a();let w=n.slice();p.push(w),u+=n.length}return ie(...p)};return(u,p)=>{o(),c(u);let w;for(;!(w=p(l()));)c();return o(),w}}var Cf={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"||ve(r),isSafeInteger:r=>Number.isSafeInteger(r),array:r=>Array.isArray(r),field:(r,t)=>t.Fp.isValid(r),hash:r=>typeof r=="function"&&Number.isSafeInteger(r.outputLen)};function Yt(r,t,e={}){let n=(s,i,o)=>{let a=Cf[i];if(typeof a!="function")throw new Error(`Invalid validator "${i}", expected function`);let c=r[s];if(!(o&&c===void 0)&&!a(c,r))throw new Error(`Invalid param ${String(s)}=${c} (${typeof c}), expected ${i}`)};for(let[s,i]of Object.entries(t))n(s,i,!1);for(let[s,i]of Object.entries(e))n(s,i,!0);return r}var ut=BigInt(0),J=BigInt(1),Oe=BigInt(2),Lf=BigInt(3),bi=BigInt(4),ga=BigInt(5),ma=BigInt(8),Uf=BigInt(9),Df=BigInt(16);function Y(r,t){let e=r%t;return e>=ut?e:t+e}function Pf(r,t,e){if(e<=ut||t<ut)throw new Error("Expected power/modulo > 0");if(e===J)return ut;let n=J;for(;t>ut;)t&J&&(n=n*r%e),r=r*r%e,t>>=J;return n}function X(r,t,e){let n=r;for(;t-- >ut;)n*=n,n%=e;return n}function En(r,t){if(r===ut||t<=ut)throw new Error(`invert: expected positive integers, got n=${r} mod=${t}`);let e=Y(r,t),n=t,s=ut,i=J,o=J,a=ut;for(;e!==ut;){let l=n/e,f=n%e,u=s-o*l,p=i-a*l;n=e,e=f,s=o,i=a,o=u,a=p}if(n!==J)throw new Error("invert: does not exist");return Y(s,t)}function Vf(r){let t=(r-J)/Oe,e,n,s;for(e=r-J,n=0;e%Oe===ut;e/=Oe,n++);for(s=Oe;s<r&&Pf(s,t,r)!==r-J;s++);if(n===1){let o=(r+J)/bi;return function(c,l){let f=c.pow(l,o);if(!c.eql(c.sqr(f),l))throw new Error("Cannot find square root");return f}}let i=(e+J)/Oe;return function(a,c){if(a.pow(c,t)===a.neg(a.ONE))throw new Error("Cannot find square root");let l=n,f=a.pow(a.mul(a.ONE,s),e),u=a.pow(c,i),p=a.pow(c,e);for(;!a.eql(p,a.ONE);){if(a.eql(p,a.ZERO))return a.ZERO;let w=1;for(let h=a.sqr(p);w<l&&!a.eql(h,a.ONE);w++)h=a.sqr(h);let g=a.pow(f,J<<BigInt(l-w-1));f=a.sqr(g),u=a.mul(u,g),p=a.mul(p,f),l=w}return u}}function Of(r){if(r%bi===Lf){let t=(r+J)/bi;return function(n,s){let i=n.pow(s,t);if(!n.eql(n.sqr(i),s))throw new Error("Cannot find square root");return i}}if(r%ma===ga){let t=(r-ga)/ma;return function(n,s){let i=n.mul(s,Oe),o=n.pow(i,t),a=n.mul(s,o),c=n.mul(n.mul(a,Oe),o),l=n.mul(a,n.sub(c,n.ONE));if(!n.eql(n.sqr(l),s))throw new Error("Cannot find square root");return l}}return r%Df,Vf(r)}var ya=(r,t)=>(Y(r,t)&J)===J,Mf=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function wi(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=Mf.reduce((n,s)=>(n[s]="function",n),t);return Yt(r,e)}function Hf(r,t,e){if(e<ut)throw new Error("Expected power > 0");if(e===ut)return r.ONE;if(e===J)return t;let n=r.ONE,s=t;for(;e>ut;)e&J&&(n=r.mul(n,s)),s=r.sqr(s),e>>=J;return n}function Kf(r,t){let e=new Array(t.length),n=t.reduce((i,o,a)=>r.is0(o)?i:(e[a]=i,r.mul(i,o)),r.ONE),s=r.inv(n);return t.reduceRight((i,o,a)=>r.is0(o)?i:(e[a]=r.mul(i,e[a]),r.mul(i,o)),s),e}function xi(r,t){let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function vn(r,t,e=!1,n={}){if(r<=ut)throw new Error(`Expected Field ORDER > 0, got ${r}`);let{nBitLength:s,nByteLength:i}=xi(r,t);if(i>2048)throw new Error("Field lengths over 2048 bytes are not supported");let o=Of(r),a=Object.freeze({ORDER:r,BITS:s,BYTES:i,MASK:Kr(s),ZERO:ut,ONE:J,create:c=>Y(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error(`Invalid field element: expected bigint, got ${typeof c}`);return ut<=c&&c<r},is0:c=>c===ut,isOdd:c=>(c&J)===J,neg:c=>Y(-c,r),eql:(c,l)=>c===l,sqr:c=>Y(c*c,r),add:(c,l)=>Y(c+l,r),sub:(c,l)=>Y(c-l,r),mul:(c,l)=>Y(c*l,r),pow:(c,l)=>Hf(a,c,l),div:(c,l)=>Y(c*En(l,r),r),sqrN:c=>c*c,addN:(c,l)=>c+l,subN:(c,l)=>c-l,mulN:(c,l)=>c*l,inv:c=>En(c,r),sqrt:n.sqrt||(c=>o(a,c)),invertBatch:c=>Kf(a,c),cmov:(c,l,f)=>f?l:c,toBytes:c=>e?Ve(c,i):Ae(c,i),fromBytes:c=>{if(c.length!==i)throw new Error(`Fp.fromBytes: expected ${i}, got ${c.length}`);return e?Be(c):se(c)}});return Object.freeze(a)}function ba(r,t){if(!r.isOdd)throw new Error("Field doesn't have isOdd");let e=r.sqrt(t);return r.isOdd(e)?r.neg(e):e}function wa(r){if(typeof r!="bigint")throw new Error("field order must be bigint");let t=r.toString(2).length;return Math.ceil(t/8)}function Ei(r){let t=wa(r);return t+Math.ceil(t/2)}function xa(r,t,e=!1){let n=r.length,s=wa(t),i=Ei(t);if(n<16||n<i||n>1024)throw new Error(`expected ${i}-1024 bytes of input, got ${n}`);let o=e?se(r):Be(r),a=Y(o,t-J)+J;return e?Ve(a,s):Ae(a,s)}var qf=BigInt(0),vi=BigInt(1);function Bn(r,t){let e=(s,i)=>{let o=i.negate();return s?o:i},n=s=>{let i=Math.ceil(t/s)+1,o=2**(s-1);return{windows:i,windowSize:o}};return{constTimeNegate:e,unsafeLadder(s,i){let o=r.ZERO,a=s;for(;i>qf;)i&vi&&(o=o.add(a)),a=a.double(),i>>=vi;return o},precomputeWindow(s,i){let{windows:o,windowSize:a}=n(i),c=[],l=s,f=l;for(let u=0;u<o;u++){f=l,c.push(f);for(let p=1;p<a;p++)f=f.add(l),c.push(f);l=f.double()}return c},wNAF(s,i,o){let{windows:a,windowSize:c}=n(s),l=r.ZERO,f=r.BASE,u=BigInt(2**s-1),p=2**s,w=BigInt(s);for(let g=0;g<a;g++){let h=g*c,d=Number(o&u);o>>=w,d>c&&(d-=p,o+=vi);let m=h,x=h+Math.abs(d)-1,b=g%2!==0,T=d<0;d===0?f=f.add(e(b,i[m])):l=l.add(e(T,i[x]))}return{p:l,f}},wNAFCached(s,i,o,a){let c=s._WINDOW_SIZE||1,l=i.get(s);return l||(l=this.precomputeWindow(s,c),c!==1&&i.set(s,a(l))),this.wNAF(c,l,o)}}}function Fr(r){return wi(r.Fp),Yt(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...xi(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Vt=BigInt(0),_t=BigInt(1),An=BigInt(2),$f=BigInt(8),Gf={zip215:!0};function zf(r){let t=Fr(r);return Yt(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function Sn(r){let t=zf(r),{Fp:e,n,prehash:s,hash:i,randomBytes:o,nByteLength:a,h:c}=t,l=An<<BigInt(a*8)-_t,f=e.create,u=t.uvRatio||((B,y)=>{try{return{isValid:!0,value:e.sqrt(B*e.inv(y))}}catch{return{isValid:!1,value:Vt}}}),p=t.adjustScalarBytes||(B=>B),w=t.domain||((B,y,I)=>{if(y.length||I)throw new Error("Contexts/pre-hash are not supported");return B}),g=B=>typeof B=="bigint"&&Vt<B,h=(B,y)=>g(B)&&g(y)&&B<y,d=B=>B===Vt||h(B,l);function m(B,y){if(h(B,y))return B;throw new Error(`Expected valid scalar < ${y}, got ${typeof B} ${B}`)}function x(B){return B===Vt?B:m(B,n)}let b=new Map;function T(B){if(!(B instanceof E))throw new Error("ExtendedPoint expected")}class E{constructor(y,I,C,L){if(this.ex=y,this.ey=I,this.ez=C,this.et=L,!d(y))throw new Error("x required");if(!d(I))throw new Error("y required");if(!d(C))throw new Error("z required");if(!d(L))throw new Error("t required")}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(y){if(y instanceof E)throw new Error("extended point not allowed");let{x:I,y:C}=y||{};if(!d(I)||!d(C))throw new Error("invalid affine point");return new E(I,C,_t,f(I*C))}static normalizeZ(y){let I=e.invertBatch(y.map(C=>C.ez));return y.map((C,L)=>C.toAffine(I[L])).map(E.fromAffine)}_setWindowSize(y){this._WINDOW_SIZE=y,b.delete(this)}assertValidity(){let{a:y,d:I}=t;if(this.is0())throw new Error("bad point: ZERO");let{ex:C,ey:L,ez:V,et:O}=this,q=f(C*C),H=f(L*L),F=f(V*V),st=f(F*F),Q=f(q*y),ht=f(F*f(Q+H)),dt=f(st+f(I*f(q*H)));if(ht!==dt)throw new Error("bad point: equation left != right (1)");let at=f(C*L),gt=f(V*O);if(at!==gt)throw new Error("bad point: equation left != right (2)")}equals(y){T(y);let{ex:I,ey:C,ez:L}=this,{ex:V,ey:O,ez:q}=y,H=f(I*q),F=f(V*L),st=f(C*q),Q=f(O*L);return H===F&&st===Q}is0(){return this.equals(E.ZERO)}negate(){return new E(f(-this.ex),this.ey,this.ez,f(-this.et))}double(){let{a:y}=t,{ex:I,ey:C,ez:L}=this,V=f(I*I),O=f(C*C),q=f(An*f(L*L)),H=f(y*V),F=I+C,st=f(f(F*F)-V-O),Q=H+O,ht=Q-q,dt=H-O,at=f(st*ht),gt=f(Q*dt),Xt=f(st*dt),Ue=f(ht*Q);return new E(at,gt,Ue,Xt)}add(y){T(y);let{a:I,d:C}=t,{ex:L,ey:V,ez:O,et:q}=this,{ex:H,ey:F,ez:st,et:Q}=y;if(I===BigInt(-1)){let Ao=f((V-L)*(F+H)),So=f((V+L)*(F-H)),Os=f(So-Ao);if(Os===Vt)return this.double();let ko=f(O*An*Q),Io=f(q*An*st),No=Io+ko,Ro=So+Ao,_o=Io-ko,Ru=f(No*Os),_u=f(Ro*_o),Tu=f(No*_o),Cu=f(Os*Ro);return new E(Ru,_u,Cu,Tu)}let ht=f(L*H),dt=f(V*F),at=f(q*C*Q),gt=f(O*st),Xt=f((L+V)*(H+F)-ht-dt),Ue=gt-at,_r=gt+at,Bo=f(dt-I*ht),Su=f(Xt*Ue),ku=f(_r*Bo),Iu=f(Xt*Bo),Nu=f(Ue*_r);return new E(Su,ku,Nu,Iu)}subtract(y){return this.add(y.negate())}wNAF(y){return _.wNAFCached(this,b,y,E.normalizeZ)}multiply(y){let{p:I,f:C}=this.wNAF(m(y,n));return E.normalizeZ([I,C])[0]}multiplyUnsafe(y){let I=x(y);return I===Vt?R:this.equals(R)||I===_t?this:this.equals(S)?this.wNAF(I).p:_.unsafeLadder(this,I)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return _.unsafeLadder(this,n).is0()}toAffine(y){let{ex:I,ey:C,ez:L}=this,V=this.is0();y==null&&(y=V?$f:e.inv(L));let O=f(I*y),q=f(C*y),H=f(L*y);if(V)return{x:Vt,y:_t};if(H!==_t)throw new Error("invZ was invalid");return{x:O,y:q}}clearCofactor(){let{h:y}=t;return y===_t?this:this.multiplyUnsafe(y)}static fromHex(y,I=!1){let{d:C,a:L}=t,V=e.BYTES;y=et("pointHex",y,V);let O=y.slice(),q=y[V-1];O[V-1]=q&-129;let H=Be(O);H===Vt||(I?m(H,l):m(H,e.ORDER));let F=f(H*H),st=f(F-_t),Q=f(C*F-L),{isValid:ht,value:dt}=u(st,Q);if(!ht)throw new Error("Point.fromHex: invalid y coordinate");let at=(dt&_t)===_t,gt=(q&128)!==0;if(!I&&dt===Vt&>)throw new Error("Point.fromHex: x=0 and x_0=1");return gt!==at&&(dt=f(-dt)),E.fromAffine({x:dt,y:H})}static fromPrivateKey(y){return D(y).point}toRawBytes(){let{x:y,y:I}=this.toAffine(),C=Ve(I,e.BYTES);return C[C.length-1]|=y&_t?128:0,C}toHex(){return ne(this.toRawBytes())}}E.BASE=new E(t.Gx,t.Gy,_t,f(t.Gx*t.Gy)),E.ZERO=new E(Vt,_t,_t,Vt);let{BASE:S,ZERO:R}=E,_=Bn(E,a*8);function $(B){return Y(B,n)}function K(B){return $(Be(B))}function D(B){let y=a;B=et("private key",B,y);let I=et("hashed private key",i(B),2*y),C=p(I.slice(0,y)),L=I.slice(y,2*y),V=K(C),O=S.multiply(V),q=O.toRawBytes();return{head:C,prefix:L,scalar:V,point:O,pointBytes:q}}function nt(B){return D(B).pointBytes}function rt(B=new Uint8Array,...y){let I=ie(...y);return K(i(w(I,et("context",B),!!s)))}function Ct(B,y,I={}){B=et("message",B),s&&(B=s(B));let{prefix:C,scalar:L,pointBytes:V}=D(y),O=rt(I.context,C,B),q=S.multiply(O).toRawBytes(),H=rt(I.context,q,V,B),F=$(O+H*L);x(F);let st=ie(q,Ve(F,e.BYTES));return et("result",st,a*2)}let v=Gf;function N(B,y,I,C=v){let{context:L,zip215:V}=C,O=e.BYTES;B=et("signature",B,2*O),y=et("message",y),s&&(y=s(y));let q=Be(B.slice(O,2*O)),H,F,st;try{H=E.fromHex(I,V),F=E.fromHex(B.slice(0,O),V),st=S.multiplyUnsafe(q)}catch{return!1}if(!V&&H.isSmallOrder())return!1;let Q=rt(L,F.toRawBytes(),H.toRawBytes(),y);return F.add(H.multiplyUnsafe(Q)).subtract(st).clearCofactor().equals(E.ZERO)}return S._setWindowSize(8),{CURVE:t,getPublicKey:nt,sign:Ct,verify:N,ExtendedPoint:E,utils:{getExtendedPublicKey:D,randomPrivateKey:()=>o(e.BYTES),precompute(B=8,y=E.BASE){return y._setWindowSize(B),y.multiply(BigInt(3)),y}}}}var Ai=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),Ea=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),Qp=BigInt(0),Yf=BigInt(1),Bi=BigInt(2),jf=BigInt(5),va=BigInt(10),Zf=BigInt(20),Wf=BigInt(40),Ba=BigInt(80);function Jf(r){let t=Ai,n=r*r%t*r%t,s=X(n,Bi,t)*n%t,i=X(s,Yf,t)*r%t,o=X(i,jf,t)*i%t,a=X(o,va,t)*o%t,c=X(a,Zf,t)*a%t,l=X(c,Wf,t)*c%t,f=X(l,Ba,t)*l%t,u=X(f,Ba,t)*l%t,p=X(u,va,t)*o%t;return{pow_p_5_8:X(p,Bi,t)*r%t,b2:n}}function Xf(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function Qf(r,t){let e=Ai,n=Y(t*t*t,e),s=Y(n*n*t,e),i=Jf(r*s).pow_p_5_8,o=Y(r*n*i,e),a=Y(t*o*o,e),c=o,l=Y(o*Ea,e),f=a===r,u=a===Y(-r,e),p=a===Y(-r*Ea,e);return f&&(o=c),(u||p)&&(o=l),ya(o,e)&&(o=Y(-o,e)),{isValid:f||u,value:o}}var oe=vn(Ai,void 0,!0),Si={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:oe,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:BigInt(8),Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:gr,randomBytes:dr,adjustScalarBytes:Xf,uvRatio:Qf},yr=Sn(Si);function Aa(r,t,e){if(t.length>255)throw new Error("Context is too big");return mn(hi("SigEd25519 no Ed25519 collisions"),new Uint8Array([e?1:0,t.length]),t,r)}var tg=Sn({...Si,domain:Aa}),eg=Sn({...Si,domain:Aa,prehash:gr});var th=(oe.ORDER+BigInt(3))/BigInt(8),rg=oe.pow(Bi,th),ng=oe.sqrt(oe.neg(oe.ONE)),sg=(oe.ORDER-BigInt(5))/BigInt(8),ig=BigInt(486662);var og=ba(oe,oe.neg(BigInt(486664)));var ag=BigInt("25063068953384623474111414158702152701244531502492656460079210482610430750235"),cg=BigInt("54469307008909316920995813868745141605393597292927456921205312896311721017578"),ug=BigInt("1159843021668779879193775521855586647937357759715417654439879720876111806838"),lg=BigInt("40440834346308536858101042469323190826248399146238708352240133220865137265952");var fg=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff");var br=32,ae=64,kn=32;function Sa(){let r=yr.utils.randomPrivateKey(),t=yr.getPublicKey(r);return{privateKey:Ra(r,t),publicKey:t}}function ka(r){if(r.length!==kn)throw new TypeError('"seed" must be 32 bytes in length.');if(!(r instanceof Uint8Array))throw new TypeError('"seed" must be a node.js Buffer, or Uint8Array.');let t=r,e=yr.getPublicKey(t);return{privateKey:Ra(t,e),publicKey:e}}function Ia(r,t){let e=r.subarray(0,kn);return yr.sign(t instanceof Uint8Array?t:t.subarray(),e)}function Na(r,t,e){return yr.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}function Ra(r,t){let e=new Uint8Array(ae);for(let n=0;n<kn;n++)e[n]=r[n],e[kn+n]=t[n];return e}var ki={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function In(r){let t=r?.algorithm??"AES-GCM",e=r?.keyLength??16,n=r?.nonceLength??12,s=r?.digest??"SHA-256",i=r?.saltLength??16,o=r?.iterations??32767,a=W.get();e*=8;async function c(u,p){let w=a.getRandomValues(new Uint8Array(i)),g=a.getRandomValues(new Uint8Array(n)),h={name:t,iv:g};typeof p=="string"&&(p=z(p));let d;if(p.length===0){d=await a.subtle.importKey("jwk",ki,{name:"AES-GCM"},!0,["encrypt"]);try{let x={name:"PBKDF2",salt:w,iterations:o,hash:{name:s}},b=await a.subtle.importKey("raw",p,{name:"PBKDF2"},!1,["deriveKey"]);d=await a.subtle.deriveKey(x,b,{name:t,length:e},!0,["encrypt"])}catch{d=await a.subtle.importKey("jwk",ki,{name:"AES-GCM"},!0,["encrypt"])}}else{let x={name:"PBKDF2",salt:w,iterations:o,hash:{name:s}},b=await a.subtle.importKey("raw",p,{name:"PBKDF2"},!1,["deriveKey"]);d=await a.subtle.deriveKey(x,b,{name:t,length:e},!0,["encrypt"])}let m=await a.subtle.encrypt(h,d,u);return Bt([w,h.iv,new Uint8Array(m)])}async function l(u,p){let w=u.subarray(0,i),g=u.subarray(i,i+n),h=u.subarray(i+n),d={name:t,iv:g};typeof p=="string"&&(p=z(p));let m;if(p.length===0)try{let b={name:"PBKDF2",salt:w,iterations:o,hash:{name:s}},T=await a.subtle.importKey("raw",p,{name:"PBKDF2"},!1,["deriveKey"]);m=await a.subtle.deriveKey(b,T,{name:t,length:e},!0,["decrypt"])}catch{m=await a.subtle.importKey("jwk",ki,{name:"AES-GCM"},!0,["decrypt"])}else{let b={name:"PBKDF2",salt:w,iterations:o,hash:{name:s}},T=await a.subtle.importKey("raw",p,{name:"PBKDF2"},!1,["deriveKey"]);m=await a.subtle.deriveKey(b,T,{name:t,length:e},!0,["decrypt"])}let x=await a.subtle.decrypt(d,m,h);return new Uint8Array(x)}return{encrypt:c,decrypt:l}}async function wr(r,t){let n=await In().encrypt(r,t);return Cr.encode(n)}var Er={};it(Er,{KeyType:()=>j,PrivateKey:()=>Kt,PublicKey:()=>Ht});var rh=Math.pow(2,7),nh=Math.pow(2,14),sh=Math.pow(2,21),Ii=Math.pow(2,28),Ni=Math.pow(2,35),Ri=Math.pow(2,42),_i=Math.pow(2,49),G=128,bt=127;function Ot(r){if(r<rh)return 1;if(r<nh)return 2;if(r<sh)return 3;if(r<Ii)return 4;if(r<Ni)return 5;if(r<Ri)return 6;if(r<_i)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function Ti(r,t,e=0){switch(Ot(r)){case 8:t[e++]=r&255|G,r/=128;case 7:t[e++]=r&255|G,r/=128;case 6:t[e++]=r&255|G,r/=128;case 5:t[e++]=r&255|G,r/=128;case 4:t[e++]=r&255|G,r>>>=7;case 3:t[e++]=r&255|G,r>>>=7;case 2:t[e++]=r&255|G,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function ih(r,t,e=0){switch(Ot(r)){case 8:t.set(e++,r&255|G),r/=128;case 7:t.set(e++,r&255|G),r/=128;case 6:t.set(e++,r&255|G),r/=128;case 5:t.set(e++,r&255|G),r/=128;case 4:t.set(e++,r&255|G),r>>>=7;case 3:t.set(e++,r&255|G),r>>>=7;case 2:t.set(e++,r&255|G),r>>>=7;case 1:{t.set(e++,r&255),r>>>=7;break}default:throw new Error("unreachable")}return t}function Ci(r,t){let e=r[t],n=0;if(n+=e&bt,e<G||(e=r[t+1],n+=(e&bt)<<7,e<G)||(e=r[t+2],n+=(e&bt)<<14,e<G)||(e=r[t+3],n+=(e&bt)<<21,e<G)||(e=r[t+4],n+=(e&bt)*Ii,e<G)||(e=r[t+5],n+=(e&bt)*Ni,e<G)||(e=r[t+6],n+=(e&bt)*Ri,e<G)||(e=r[t+7],n+=(e&bt)*_i,e<G))return n;throw new RangeError("Could not decode varint")}function oh(r,t){let e=r.get(t),n=0;if(n+=e&bt,e<G||(e=r.get(t+1),n+=(e&bt)<<7,e<G)||(e=r.get(t+2),n+=(e&bt)<<14,e<G)||(e=r.get(t+3),n+=(e&bt)<<21,e<G)||(e=r.get(t+4),n+=(e&bt)*Ii,e<G)||(e=r.get(t+5),n+=(e&bt)*Ni,e<G)||(e=r.get(t+6),n+=(e&bt)*Ri,e<G)||(e=r.get(t+7),n+=(e&bt)*_i,e<G))return n;throw new RangeError("Could not decode varint")}function Ta(r,t,e=0){return t==null&&(t=yt(Ot(r))),t instanceof Uint8Array?Ti(r,t,e):ih(r,t,e)}function Ca(r,t=0){return r instanceof Uint8Array?Ci(r,t):oh(r,t)}var Li=new Float32Array([-0]),Se=new Uint8Array(Li.buffer);function Ua(r,t,e){Li[0]=r,t[e]=Se[0],t[e+1]=Se[1],t[e+2]=Se[2],t[e+3]=Se[3]}function Da(r,t){return Se[0]=r[t],Se[1]=r[t+1],Se[2]=r[t+2],Se[3]=r[t+3],Li[0]}var Ui=new Float64Array([-0]),wt=new Uint8Array(Ui.buffer);function Pa(r,t,e){Ui[0]=r,t[e]=wt[0],t[e+1]=wt[1],t[e+2]=wt[2],t[e+3]=wt[3],t[e+4]=wt[4],t[e+5]=wt[5],t[e+6]=wt[6],t[e+7]=wt[7]}function Va(r,t){return wt[0]=r[t],wt[1]=r[t+1],wt[2]=r[t+2],wt[3]=r[t+3],wt[4]=r[t+4],wt[5]=r[t+5],wt[6]=r[t+6],wt[7]=r[t+7],Ui[0]}var ah=BigInt(Number.MAX_SAFE_INTEGER),ch=BigInt(Number.MIN_SAFE_INTEGER),Tt=class r{lo;hi;constructor(t,e){this.lo=t|0,this.hi=e|0}toNumber(t=!1){if(!t&&this.hi>>>31>0){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(e+n*4294967296)}return this.lo+this.hi*4294967296}toBigInt(t=!1){if(t)return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n);if(this.hi>>>31){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(BigInt(e)+(BigInt(n)<<32n))}return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n)}toString(t=!1){return this.toBigInt(t).toString()}zzEncode(){let t=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^t)>>>0,this.lo=(this.lo<<1^t)>>>0,this}zzDecode(){let t=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^t)>>>0,this.hi=(this.hi>>>1^t)>>>0,this}length(){let t=this.lo,e=(this.lo>>>28|this.hi<<4)>>>0,n=this.hi>>>24;return n===0?e===0?t<16384?t<128?1:2:t<2097152?3:4:e<16384?e<128?5:6:e<2097152?7:8:n<128?9:10}static fromBigInt(t){if(t===0n)return Me;if(t<ah&&t>ch)return this.fromNumber(Number(t));let e=t<0n;e&&(t=-t);let n=t>>32n,s=t-(n<<32n);return e&&(n=~n|0n,s=~s|0n,++s>Oa&&(s=0n,++n>Oa&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(t){if(t===0)return Me;let e=t<0;e&&(t=-t);let n=t>>>0,s=(t-n)/4294967296>>>0;return e&&(s=~s>>>0,n=~n>>>0,++n>4294967295&&(n=0,++s>4294967295&&(s=0))),new r(n,s)}static from(t){return typeof t=="number"?r.fromNumber(t):typeof t=="bigint"?r.fromBigInt(t):typeof t=="string"?r.fromBigInt(BigInt(t)):t.low!=null||t.high!=null?new r(t.low>>>0,t.high>>>0):Me}},Me=new Tt(0,0);Me.toBigInt=function(){return 0n};Me.zzEncode=Me.zzDecode=function(){return this};Me.length=function(){return 1};var Oa=4294967296n;function Ma(r){let t=0,e=0;for(let n=0;n<r.length;++n)e=r.charCodeAt(n),e<128?t+=1:e<2048?t+=2:(e&64512)===55296&&(r.charCodeAt(n+1)&64512)===56320?(++n,t+=4):t+=3;return t}function Ha(r,t,e){if(e-t<1)return"";let s,i=[],o=0,a;for(;t<e;)a=r[t++],a<128?i[o++]=a:a>191&&a<224?i[o++]=(a&31)<<6|r[t++]&63:a>239&&a<365?(a=((a&7)<<18|(r[t++]&63)<<12|(r[t++]&63)<<6|r[t++]&63)-65536,i[o++]=55296+(a>>10),i[o++]=56320+(a&1023)):i[o++]=(a&15)<<12|(r[t++]&63)<<6|r[t++]&63,o>8191&&((s??(s=[])).push(String.fromCharCode.apply(String,i)),o=0);return s!=null?(o>0&&s.push(String.fromCharCode.apply(String,i.slice(0,o))),s.join("")):String.fromCharCode.apply(String,i.slice(0,o))}function Di(r,t,e){let n=e,s,i;for(let o=0;o<r.length;++o)s=r.charCodeAt(o),s<128?t[e++]=s:s<2048?(t[e++]=s>>6|192,t[e++]=s&63|128):(s&64512)===55296&&((i=r.charCodeAt(o+1))&64512)===56320?(s=65536+((s&1023)<<10)+(i&1023),++o,t[e++]=s>>18|240,t[e++]=s>>12&63|128,t[e++]=s>>6&63|128,t[e++]=s&63|128):(t[e++]=s>>12|224,t[e++]=s>>6&63|128,t[e++]=s&63|128);return e-n}function Mt(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function Nn(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var Pi=class{buf;pos;len;_slice=Uint8Array.prototype.subarray;constructor(t){this.buf=t,this.pos=0,this.len=t.length}uint32(){let t=4294967295;if(t=(this.buf[this.pos]&127)>>>0,this.buf[this.pos++]<128||(t=(t|(this.buf[this.pos]&127)<<7)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<14)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<21)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&15)<<28)>>>0,this.buf[this.pos++]<128))return t;if((this.pos+=5)>this.len)throw this.pos=this.len,Mt(this,10);return t}int32(){return this.uint32()|0}sint32(){let t=this.uint32();return t>>>1^-(t&1)|0}bool(){return this.uint32()!==0}fixed32(){if(this.pos+4>this.len)throw Mt(this,4);return Nn(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Mt(this,4);return Nn(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Mt(this,4);let t=Da(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Mt(this,4);let t=Va(this.buf,this.pos);return this.pos+=8,t}bytes(){let t=this.uint32(),e=this.pos,n=this.pos+t;if(n>this.len)throw Mt(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return Ha(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw Mt(this,t);this.pos+=t}else do if(this.pos>=this.len)throw Mt(this);while(this.buf[this.pos++]&128);return this}skipType(t){switch(t){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;(t=this.uint32()&7)!==4;)this.skipType(t);break;case 5:this.skip(4);break;default:throw Error(`invalid wire type ${t} at offset ${this.pos}`)}return this}readLongVarint(){let t=new Tt(0,0),e=0;if(this.len-this.pos>4){for(;e<4;++e)if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t;if(t.lo=(t.lo|(this.buf[this.pos]&127)<<28)>>>0,t.hi=(t.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return t;e=0}else{for(;e<3;++e){if(this.pos>=this.len)throw Mt(this);if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t}return t.lo=(t.lo|(this.buf[this.pos++]&127)<<e*7)>>>0,t}if(this.len-this.pos>4){for(;e<5;++e)if(t.hi=(t.hi|(this.buf[this.pos]&127)<<e*7+3)>>>0,this.buf[this.pos++]<128)return t}else for(;e<5;++e){if(this.pos>=this.len)throw Mt(this);if(t.hi=(t.hi|(this.buf[this.pos]&127)<<e*7+3)>>>0,this.buf[this.pos++]<128)return t}throw Error("invalid varint encoding")}readFixed64(){if(this.pos+8>this.len)throw Mt(this,8);let t=Nn(this.buf,this.pos+=4),e=Nn(this.buf,this.pos+=4);return new Tt(t,e)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){let t=Ci(this.buf,this.pos);return this.pos+=Ot(t),t}uint64String(){return this.readLongVarint().toString(!0)}sint64(){return this.readLongVarint().zzDecode().toBigInt()}sint64Number(){return this.readLongVarint().zzDecode().toNumber()}sint64String(){return this.readLongVarint().zzDecode().toString()}fixed64(){return this.readFixed64().toBigInt()}fixed64Number(){return this.readFixed64().toNumber()}fixed64String(){return this.readFixed64().toString()}sfixed64(){return this.readFixed64().toBigInt()}sfixed64Number(){return this.readFixed64().toNumber()}sfixed64String(){return this.readFixed64().toString()}};function Vi(r){return new Pi(r instanceof Uint8Array?r:r.subarray())}function kt(r,t,e){let n=Vi(r);return t.decode(n,void 0,e)}function Oi(r){let t=r??8192,e=t>>>1,n,s=t;return function(o){if(o<1||o>e)return yt(o);s+o>t&&(n=yt(t),s=0);let a=n.subarray(s,s+=o);return s&7&&(s=(s|7)+1),a}}var He=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function Mi(){}var Ki=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},uh=Oi();function lh(r){return globalThis.Buffer!=null?yt(r):uh(r)}var $r=class{len;head;tail;states;constructor(){this.len=0,this.head=new He(Mi,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new He(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new Fi((t=t>>>0)<128?1:t<16384?2:t<2097152?3:t<268435456?4:5,t)).len,this}int32(t){return t<0?this._push(Rn,10,Tt.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=Tt.fromBigInt(t);return this._push(Rn,e.length(),e)}uint64Number(t){return this._push(Ti,Ot(t),t)}uint64String(t){return this.uint64(BigInt(t))}int64(t){return this.uint64(t)}int64Number(t){return this.uint64Number(t)}int64String(t){return this.uint64String(t)}sint64(t){let e=Tt.fromBigInt(t).zzEncode();return this._push(Rn,e.length(),e)}sint64Number(t){let e=Tt.fromNumber(t).zzEncode();return this._push(Rn,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(Hi,1,t?1:0)}fixed32(t){return this._push(qr,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=Tt.fromBigInt(t);return this._push(qr,4,e.lo)._push(qr,4,e.hi)}fixed64Number(t){let e=Tt.fromNumber(t);return this._push(qr,4,e.lo)._push(qr,4,e.hi)}fixed64String(t){return this.fixed64(BigInt(t))}sfixed64(t){return this.fixed64(t)}sfixed64Number(t){return this.fixed64Number(t)}sfixed64String(t){return this.fixed64String(t)}float(t){return this._push(Ua,4,t)}double(t){return this._push(Pa,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(Hi,1,0):this.uint32(e)._push(hh,e,t)}string(t){let e=Ma(t);return e!==0?this.uint32(e)._push(Di,e,t):this._push(Hi,1,0)}fork(){return this.states=new Ki(this),this.head=this.tail=new He(Mi,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 He(Mi,0,0),this.len=0),this}ldelim(){let t=this.head,e=this.tail,n=this.len;return this.reset().uint32(n),n!==0&&(this.tail.next=t.next,this.tail=e,this.len+=n),this}finish(){let t=this.head.next,e=lh(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function Hi(r,t,e){t[e]=r&255}function fh(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var Fi=class extends He{next;constructor(t,e){super(fh,t,e),this.next=void 0}};function Rn(r,t,e){for(;r.hi!==0;)t[e++]=r.lo&127|128,r.lo=(r.lo>>>7|r.hi<<25)>>>0,r.hi>>>=7;for(;r.lo>127;)t[e++]=r.lo&127|128,r.lo=r.lo>>>7;t[e++]=r.lo}function qr(r,t,e){t[e]=r&255,t[e+1]=r>>>8&255,t[e+2]=r>>>16&255,t[e+3]=r>>>24}function hh(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&($r.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(dh,t,r),this},$r.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(ph,t,r),this});function dh(r,t,e){t.set(r,e)}function ph(r,t,e){r.length<40?Di(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(z(r),e)}function qi(){return new $r}function It(r,t){let e=qi();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var xr;(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"})(xr||(xr={}));function _n(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function $i(r){function t(s){if(r[s.toString()]==null)throw new Error("Invalid enum value");return r[s]}let e=function(i,o){let a=t(i);o.int32(a)},n=function(i){let o=i.int32();return t(o)};return _n("enum",xr.VARINT,e,n)}function Nt(r,t){return _n("message",xr.LENGTH_DELIMITED,r,t)}var j;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.Secp256k1="Secp256k1"})(j||(j={}));var Gi;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.Secp256k1=2]="Secp256k1"})(Gi||(Gi={}));(function(r){r.codec=()=>$i(Gi)})(j||(j={}));var Ht;(function(r){let t;r.codec=()=>(t==null&&(t=Nt((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),j.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let s={},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let o=e.uint32();switch(o>>>3){case 1:s.Type=j.codec().decode(e);break;case 2:s.Data=e.bytes();break;default:e.skipType(o&7);break}}return s})),t),r.encode=e=>It(e,r.codec()),r.decode=e=>kt(e,r.codec())})(Ht||(Ht={}));var Kt;(function(r){let t;r.codec=()=>(t==null&&(t=Nt((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),j.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let s={},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let o=e.uint32();switch(o>>>3){case 1:s.Type=j.codec().decode(e);break;case 2:s.Data=e.bytes();break;default:e.skipType(o&7);break}}return s})),t),r.encode=e=>It(e,r.codec()),r.decode=e=>kt(e,r.codec())})(Kt||(Kt={}));var Ke=class{_key;constructor(t){this._key=vr(t,br)}verify(t,e){return Na(this._key,e,t)}marshal(){return this._key}get bytes(){return Ht.encode({Type:j.Ed25519,Data:this.marshal()}).subarray()}equals(t){return mt(this.bytes,t.bytes)}hash(){let t=ct.digest(this.bytes);return Lt(t)?t.then(({bytes:e})=>e):t.bytes}},ce=class{_key;_publicKey;constructor(t,e){this._key=vr(t,ae),this._publicKey=vr(e,br)}sign(t){return Ia(this._key,t)}get public(){return new Ke(this._publicKey)}marshal(){return this._key}get bytes(){return Kt.encode({Type:j.Ed25519,Data:this.marshal()}).subarray()}equals(t){return mt(this.bytes,t.bytes)}async hash(){let t=ct.digest(this.bytes),e;return Lt(t)?{bytes:e}=await t:e=t.bytes,e}async id(){let t=be.digest(this.public.bytes);return vt.encode(t.bytes).substring(1)}async export(t,e="libp2p-key"){if(e==="libp2p-key")return wr(this.bytes,t);throw new A(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function gh(r){if(r.length>ae){r=vr(r,ae+br);let n=r.subarray(0,ae),s=r.subarray(ae,r.length);return new ce(n,s)}r=vr(r,ae);let t=r.subarray(0,ae),e=r.subarray(br);return new ce(t,e)}function mh(r){return r=vr(r,br),new Ke(r)}async function yh(){let{privateKey:r,publicKey:t}=Sa();return new ce(r,t)}async function zi(r){let{privateKey:t,publicKey:e}=ka(r);return new ce(t,e)}function vr(r,t){if(r=Uint8Array.from(r??[]),r.length!==t)throw new A(`Key must be a Uint8Array of length ${t}, got ${r.length}`,"ERR_INVALID_KEY_TYPE");return r}function Z(r,t="utf8"){let e=dn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}var Fa={"P-256":256,"P-384":384,"P-521":521},bh=Object.keys(Fa),ji=bh.join(" / ");async function qa(r){if(r!=="P-256"&&r!=="P-384"&&r!=="P-521")throw new A(`Unknown curve: ${r}. Must be ${ji}`,"ERR_INVALID_CURVE");let t=await W.get().subtle.generateKey({name:"ECDH",namedCurve:r},!0,["deriveBits"]),e=async(i,o)=>{let a;o!=null?a=await W.get().subtle.importKey("jwk",xh(r,o),{name:"ECDH",namedCurve:r},!1,["deriveBits"]):a=t.privateKey;let c=await W.get().subtle.importKey("jwk",Ga(r,i),{name:"ECDH",namedCurve:r},!1,[]),l=await W.get().subtle.deriveBits({name:"ECDH",namedCurve:r,public:c},a,Fa[r]);return new Uint8Array(l,0,l.byteLength)},n=await W.get().subtle.exportKey("jwk",t.publicKey);return{key:wh(n),genSharedKey:e}}var $a={"P-256":32,"P-384":48,"P-521":66};function wh(r){if(r.crv==null||r.x==null||r.y==null)throw new A("JWK was missing components","ERR_INVALID_PARAMETERS");if(r.crv!=="P-256"&&r.crv!=="P-384"&&r.crv!=="P-521")throw new A(`Unknown curve: ${r.crv}. Must be ${ji}`,"ERR_INVALID_CURVE");let t=$a[r.crv];return Bt([Uint8Array.from([4]),fi(r.x,t),fi(r.y,t)],1+t*2)}function Ga(r,t){if(r!=="P-256"&&r!=="P-384"&&r!=="P-521")throw new A(`Unknown curve: ${r}. Must be ${ji}`,"ERR_INVALID_CURVE");let e=$a[r];if(!mt(t.subarray(0,1),Uint8Array.from([4])))throw new A("Cannot unmarshal public key - invalid key format","ERR_INVALID_KEY_FORMAT");return{kty:"EC",crv:r,x:Z(t.subarray(1,e+1),"base64url"),y:Z(t.subarray(1+e),"base64url"),ext:!0}}var xh=(r,t)=>({...Ga(r,t.public),d:Z(t.private,"base64url")});var za=qa;async function Ya(r,t){let e=Cr.decode(r);return In().decrypt(e,t)}var ja={"AES-128":{ivSize:16,keySize:16},"AES-256":{ivSize:16,keySize:32},Blowfish:{ivSize:8,keySize:32}};async function Za(r,t,e){let n=ja[r];if(n==null){let x=Object.keys(ja).join(" / ");throw new A(`unknown cipher type '${r}'. Must be ${x}`,"ERR_INVALID_CIPHER_TYPE")}if(t==null)throw new A("missing hash type","ERR_MISSING_HASH_TYPE");let s=n.keySize,i=n.ivSize,o=20,a=z("key expansion"),c=2*(i+s+o),l=await ra(t,e),f=await l.digest(a),u=[],p=0;for(;p<c;){let x=await l.digest(Bt([f,a])),b=x.length;p+b>c&&(b=c-p),u.push(x),p+=b,f=await l.digest(f)}let w=c/2,g=Bt(u),h=g.subarray(0,w),d=g.subarray(w,c),m=x=>({iv:x.subarray(0,i),cipherKey:x.subarray(i,i+s),macKey:x.subarray(i+s)});return{k1:m(h),k2:m(d)}}var io={};it(io,{MAX_RSA_KEY_SIZE:()=>$e,RsaPrivateKey:()=>_e,RsaPublicKey:()=>qe,fromJwk:()=>zh,generateKeyPair:()=>Yh,unmarshalRsaPrivateKey:()=>no,unmarshalRsaPublicKey:()=>Gh});function jt(r){if(isNaN(r)||r<=0)throw new A("random bytes length must be a Number bigger than 0","ERR_INVALID_LENGTH");return dr(r)}var Re={};it(Re,{exportToPem:()=>Kh,importFromPem:()=>ro,jwkToPkcs1:()=>Vh,jwkToPkix:()=>Mh,pkcs1ToJwk:()=>Ph,pkixToJwk:()=>Oh});var Tn=class extends fr{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,pn(t);let n=we(e);if(this.iHash=t.create(),typeof this.iHash.update!="function")throw new Error("Expected instance of class which extends utils.Hash");this.blockLen=this.iHash.blockLen,this.outputLen=this.iHash.outputLen;let s=this.blockLen,i=new Uint8Array(s);i.set(n.length>s?t.create().update(n).digest():n);for(let o=0;o<i.length;o++)i[o]^=54;this.iHash.update(i),this.oHash=t.create();for(let o=0;o<i.length;o++)i[o]^=106;this.oHash.update(i),i.fill(0)}update(t){return lr(this),this.iHash.update(t),this}digestInto(t){lr(this),ur(t,this.outputLen),this.finished=!0,this.iHash.digestInto(t),this.oHash.update(t),this.oHash.digestInto(t),this.destroy()}digest(){let t=new Uint8Array(this.oHash.outputLen);return this.digestInto(t),t}_cloneInto(t){t||(t=Object.create(Object.getPrototypeOf(this),{}));let{oHash:e,iHash:n,finished:s,destroyed:i,blockLen:o,outputLen:a}=this;return t=t,t.finished=s,t.destroyed=i,t.blockLen=o,t.outputLen=a,t.oHash=e._cloneInto(t.oHash),t.iHash=n._cloneInto(t.iHash),t}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},Gr=(r,t,e)=>new Tn(r,t).update(e).digest();Gr.create=(r,t)=>new Tn(r,t);function Eh(r,t,e,n){pn(r);let s=aa({dkLen:32,asyncTick:10},n),{c:i,dkLen:o,asyncTick:a}=s;if(cr(i),cr(o),cr(a),i<1)throw new Error("PBKDF2: iterations (c) should be >= 1");let c=we(t),l=we(e),f=new Uint8Array(o),u=Gr.create(r,c),p=u._cloneInto().update(l);return{c:i,dkLen:o,asyncTick:a,DK:f,PRF:u,PRFSalt:p}}function vh(r,t,e,n,s){return r.destroy(),t.destroy(),n&&n.destroy(),s.fill(0),e}async function Zi(r,t,e,n){let{c:s,dkLen:i,asyncTick:o,DK:a,PRF:c,PRFSalt:l}=Eh(r,t,e,n),f,u=new Uint8Array(4),p=hr(u),w=new Uint8Array(c.outputLen);for(let g=1,h=0;h<i;g++,h+=c.outputLen){let d=a.subarray(h,h+c.outputLen);p.setInt32(0,g,!1),(f=l._cloneInto(f)).update(u).digestInto(w),d.set(w.subarray(0,d.length)),await oa(s-1,o,()=>{c._cloneInto(f).update(w).digestInto(w);for(let m=0;m<d.length;m++)d[m]^=w[m]})}return vh(c,l,a,f,w)}var M=Hs(Wa());function Fe(r,t){let e=0;if(r.length===1)return r[0];for(let n=r.length-1;n>=0;n--)e+=r[r.length-1-n]*Math.pow(2,t*n);return e}function ke(r,t,e=-1){let n=e,s=r,i=0,o=Math.pow(2,t);for(let a=1;a<8;a++){if(r<o){let c;if(n<0)c=new ArrayBuffer(a),i=a;else{if(n<a)return new ArrayBuffer(0);c=new ArrayBuffer(n),i=n}let l=new Uint8Array(c);for(let f=a-1;f>=0;f--){let u=Math.pow(2,f*t);l[i-f-1]=Math.floor(s/u),s-=l[i-f-1]*u}return c}o*=Math.pow(2,t)}return new ArrayBuffer(0)}function Un(...r){let t=0,e=0;for(let i of r)t+=i.length;let n=new ArrayBuffer(t),s=new Uint8Array(n);for(let i of r)s.set(i,e),e+=i.length;return s}function Ji(){let r=new Uint8Array(this.valueHex);if(this.valueHex.byteLength>=2){let a=r[0]===255&&r[1]&128,c=r[0]===0&&(r[1]&128)===0;(a||c)&&this.warnings.push("Needlessly long format")}let t=new ArrayBuffer(this.valueHex.byteLength),e=new Uint8Array(t);for(let a=0;a<this.valueHex.byteLength;a++)e[a]=0;e[0]=r[0]&128;let n=Fe(e,8),s=new ArrayBuffer(this.valueHex.byteLength),i=new Uint8Array(s);for(let a=0;a<this.valueHex.byteLength;a++)i[a]=r[a];return i[0]&=127,Fe(i,8)-n}function Ja(r){let t=r<0?r*-1:r,e=128;for(let n=1;n<8;n++){if(t<=e){if(r<0){let o=e-t,a=ke(o,8,n),c=new Uint8Array(a);return c[0]|=128,a}let s=ke(t,8,n),i=new Uint8Array(s);if(i[0]&128){let o=s.slice(0),a=new Uint8Array(o);s=new ArrayBuffer(s.byteLength+1),i=new Uint8Array(s);for(let c=0;c<o.byteLength;c++)i[c+1]=a[c];i[0]=0}return s}e*=Math.pow(2,8)}return new ArrayBuffer(0)}function Xa(r,t){if(r.byteLength!==t.byteLength)return!1;let e=new Uint8Array(r),n=new Uint8Array(t);for(let s=0;s<e.length;s++)if(e[s]!==n[s])return!1;return!0}function Rt(r,t){let e=r.toString(10);if(t<e.length)return"";let n=t-e.length,s=new Array(n);for(let o=0;o<n;o++)s[o]="0";return s.join("").concat(e)}var Lm=Math.log(2);function Dn(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function Xi(r){let t=0,e=0;for(let s=0;s<r.length;s++){let i=r[s];t+=i.byteLength}let n=new Uint8Array(t);for(let s=0;s<r.length;s++){let i=r[s];n.set(new Uint8Array(i),e),e+=i.byteLength}return n.buffer}function de(r,t,e,n){return t instanceof Uint8Array?t.byteLength?e<0?(r.error="Wrong parameter: inputOffset less than zero",!1):n<0?(r.error="Wrong parameter: inputLength less than zero",!1):t.byteLength-e-n<0?(r.error="End of input reached before message was fully decoded (inconsistent offset and length values)",!1):!0:(r.error="Wrong parameter: inputBuffer has zero length",!1):(r.error="Wrong parameter: inputBuffer must be 'Uint8Array'",!1)}var Yr=class{constructor(){this.items=[]}write(t){this.items.push(t)}final(){return Xi(this.items)}},zr=[new Uint8Array([1])],Qa="0123456789";var Sr="",qt=new ArrayBuffer(0),Qi=new Uint8Array(0),jr="EndOfContent",ec="OCTET STRING",rc="BIT STRING";function pe(r){var t;return t=class extends r{constructor(...n){var s;super(...n);let i=n[0]||{};this.isHexOnly=(s=i.isHexOnly)!==null&&s!==void 0?s:!1,this.valueHexView=i.valueHex?M.BufferSourceConverter.toUint8Array(i.valueHex):Qi}get valueHex(){return this.valueHexView.slice().buffer}set valueHex(n){this.valueHexView=new Uint8Array(n)}fromBER(n,s,i){let o=n instanceof ArrayBuffer?new Uint8Array(n):n;if(!de(this,o,s,i))return-1;let a=s+i;return this.valueHexView=o.subarray(s,a),this.valueHexView.length?(this.blockLength=i,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",qt)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:M.Convert.ToHex(this.valueHexView)}}},t.NAME="hexBlock",t}var le=class{constructor({blockLength:t=0,error:e=Sr,warnings:n=[],valueBeforeDecode:s=Qi}={}){this.blockLength=t,this.error=e,this.warnings=n,this.valueBeforeDecodeView=M.BufferSourceConverter.toUint8Array(s)}static blockName(){return this.NAME}get valueBeforeDecode(){return this.valueBeforeDecodeView.slice().buffer}set valueBeforeDecode(t){this.valueBeforeDecodeView=new Uint8Array(t)}toJSON(){return{blockName:this.constructor.NAME,blockLength:this.blockLength,error:this.error,warnings:this.warnings,valueBeforeDecode:M.Convert.ToHex(this.valueBeforeDecodeView)}}};le.NAME="baseBlock";var xt=class extends le{fromBER(t,e,n){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}toBER(t,e){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}};xt.NAME="valueBlock";var Pn=class extends pe(le){constructor({idBlock:t={}}={}){var e,n,s,i;super(),t?(this.isHexOnly=(e=t.isHexOnly)!==null&&e!==void 0?e:!1,this.valueHexView=t.valueHex?M.BufferSourceConverter.toUint8Array(t.valueHex):Qi,this.tagClass=(n=t.tagClass)!==null&&n!==void 0?n:-1,this.tagNumber=(s=t.tagNumber)!==null&&s!==void 0?s:-1,this.isConstructed=(i=t.isConstructed)!==null&&i!==void 0?i:!1):(this.tagClass=-1,this.tagNumber=-1,this.isConstructed=!1)}toBER(t=!1){let e=0;switch(this.tagClass){case 1:e|=0;break;case 2:e|=64;break;case 3:e|=128;break;case 4:e|=192;break;default:return this.error="Unknown tag class",qt}if(this.isConstructed&&(e|=32),this.tagNumber<31&&!this.isHexOnly){let s=new Uint8Array(1);if(!t){let i=this.tagNumber;i&=31,e|=i,s[0]=e}return s.buffer}if(!this.isHexOnly){let s=ke(this.tagNumber,7),i=new Uint8Array(s),o=s.byteLength,a=new Uint8Array(o+1);if(a[0]=e|31,!t){for(let c=0;c<o-1;c++)a[c+1]=i[c]|128;a[o]=i[o-1]}return a.buffer}let n=new Uint8Array(this.valueHexView.byteLength+1);if(n[0]=e|31,!t){let s=this.valueHexView;for(let i=0;i<s.length-1;i++)n[i+1]=s[i]|128;n[this.valueHexView.byteLength]=s[s.length-1]}return n.buffer}fromBER(t,e,n){let s=M.BufferSourceConverter.toUint8Array(t);if(!de(this,s,e,n))return-1;let i=s.subarray(e,e+n);if(i.length===0)return this.error="Zero buffer length",-1;switch(i[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=(i[0]&32)===32,this.isHexOnly=!1;let a=i[0]&31;if(a!==31)this.tagNumber=a,this.blockLength=1;else{let c=1,l=this.valueHexView=new Uint8Array(255),f=255;for(;i[c]&128;){if(l[c-1]=i[c]&127,c++,c>=i.length)return this.error="End of input reached before message was fully decoded",-1;if(c===f){f+=255;let p=new Uint8Array(f);for(let w=0;w<l.length;w++)p[w]=l[w];l=this.valueHexView=new Uint8Array(f)}}this.blockLength=c+1,l[c-1]=i[c]&127;let u=new Uint8Array(c);for(let p=0;p<c;p++)u[p]=l[p];l=this.valueHexView=new Uint8Array(c),l.set(u),this.blockLength<=9?this.tagNumber=Fe(l,7):(this.isHexOnly=!0,this.warnings.push("Tag too long, represented as hex-coded"))}if(this.tagClass===1&&this.isConstructed)switch(this.tagNumber){case 1:case 2:case 5:case 6:case 9:case 13:case 14:case 23:case 24:case 31:case 32:case 33:case 34:return this.error="Constructed encoding used for primitive type",-1}return e+this.blockLength}toJSON(){return{...super.toJSON(),tagClass:this.tagClass,tagNumber:this.tagNumber,isConstructed:this.isConstructed}}};Pn.NAME="identificationBlock";var Vn=class extends le{constructor({lenBlock:t={}}={}){var e,n,s;super(),this.isIndefiniteForm=(e=t.isIndefiniteForm)!==null&&e!==void 0?e:!1,this.longFormUsed=(n=t.longFormUsed)!==null&&n!==void 0?n:!1,this.length=(s=t.length)!==null&&s!==void 0?s:0}fromBER(t,e,n){let s=M.BufferSourceConverter.toUint8Array(t);if(!de(this,s,e,n))return-1;let i=s.subarray(e,e+n);if(i.length===0)return this.error="Zero buffer length",-1;if(i[0]===255)return this.error="Length block 0xFF is reserved by standard",-1;if(this.isIndefiniteForm=i[0]===128,this.isIndefiniteForm)return this.blockLength=1,e+this.blockLength;if(this.longFormUsed=!!(i[0]&128),this.longFormUsed===!1)return this.length=i[0],this.blockLength=1,e+this.blockLength;let o=i[0]&127;if(o>8)return this.error="Too big integer",-1;if(o+1>i.length)return this.error="End of input reached before message was fully decoded",-1;let a=e+1,c=s.subarray(a,a+o);return c[o-1]===0&&this.warnings.push("Needlessly long encoded length"),this.length=Fe(c,8),this.longFormUsed&&this.length<=127&&this.warnings.push("Unnecessary usage of long length form"),this.blockLength=o+1,e+this.blockLength}toBER(t=!1){let e,n;if(this.length>127&&(this.longFormUsed=!0),this.isIndefiniteForm)return e=new ArrayBuffer(1),t===!1&&(n=new Uint8Array(e),n[0]=128),e;if(this.longFormUsed){let s=ke(this.length,8);if(s.byteLength>127)return this.error="Too big length",qt;if(e=new ArrayBuffer(s.byteLength+1),t)return e;let i=new Uint8Array(s);n=new Uint8Array(e),n[0]=s.byteLength|128;for(let o=0;o<s.byteLength;o++)n[o+1]=i[o];return e}return e=new ArrayBuffer(1),t===!1&&(n=new Uint8Array(e),n[0]=this.length),e}toJSON(){return{...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,longFormUsed:this.longFormUsed,length:this.length}}};Vn.NAME="lengthBlock";var k={},pt=class extends le{constructor({name:t=Sr,optional:e=!1,primitiveSchema:n,...s}={},i){super(s),this.name=t,this.optional=e,n&&(this.primitiveSchema=n),this.idBlock=new Pn(s),this.lenBlock=new Vn(s),this.valueBlock=i?new i(s):new xt(s)}fromBER(t,e,n){let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}toBER(t,e){let n=e||new Yr;e||nc(this);let s=this.idBlock.toBER(t);if(n.write(s),this.lenBlock.isIndefiniteForm)n.write(new Uint8Array([128]).buffer),this.valueBlock.toBER(t,n),n.write(new ArrayBuffer(2));else{let i=this.valueBlock.toBER(t);this.lenBlock.length=i.byteLength;let o=this.lenBlock.toBER(t);n.write(o),n.write(i)}return e?qt:n.final()}toJSON(){let t={...super.toJSON(),idBlock:this.idBlock.toJSON(),lenBlock:this.lenBlock.toJSON(),valueBlock:this.valueBlock.toJSON(),name:this.name,optional:this.optional};return this.primitiveSchema&&(t.primitiveSchema=this.primitiveSchema.toJSON()),t}toString(t="ascii"){return t==="ascii"?this.onAsciiEncoding():M.Convert.ToHex(this.toBER())}onAsciiEncoding(){return`${this.constructor.NAME} : ${M.Convert.ToHex(this.valueBlock.valueBeforeDecodeView)}`}isEqual(t){if(this===t)return!0;if(!(t instanceof this.constructor))return!1;let e=this.toBER(),n=t.toBER();return Xa(e,n)}};pt.NAME="BaseBlock";function nc(r){if(r instanceof k.Constructed)for(let t of r.valueBlock.value)nc(t)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var On=class extends pt{constructor({value:t=Sr,...e}={},n){super(e,n),t&&this.fromString(t)}getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}fromBER(t,e,n){let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.fromBuffer(this.valueBlock.valueHexView),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}onAsciiEncoding(){return`${this.constructor.NAME} : '${this.valueBlock.value}'`}};On.NAME="BaseStringBlock";var Mn=class extends pe(xt){constructor({isHexOnly:t=!0,...e}={}){super(e),this.isHexOnly=t}};Mn.NAME="PrimitiveValueBlock";var sc,Hn=class extends pt{constructor(t={}){super(t,Mn),this.idBlock.isConstructed=!1}};sc=Hn;k.Primitive=sc;Hn.NAME="PRIMITIVE";function Th(r,t){if(r instanceof t)return r;let e=new t;return e.idBlock=r.idBlock,e.lenBlock=r.lenBlock,e.warnings=r.warnings,e.valueBeforeDecodeView=r.valueBeforeDecodeView,e}function ws(r,t=0,e=r.length){let n=t,s=new pt({},xt),i=new le;if(!de(i,r,t,e))return s.error=i.error,{offset:-1,result:s};if(!r.subarray(t,t+e).length)return s.error="Zero buffer length",{offset:-1,result:s};let a=s.idBlock.fromBER(r,t,e);if(s.idBlock.warnings.length&&s.warnings.concat(s.idBlock.warnings),a===-1)return s.error=s.idBlock.error,{offset:-1,result:s};if(t=a,e-=s.idBlock.blockLength,a=s.lenBlock.fromBER(r,t,e),s.lenBlock.warnings.length&&s.warnings.concat(s.lenBlock.warnings),a===-1)return s.error=s.lenBlock.error,{offset:-1,result:s};if(t=a,e-=s.lenBlock.blockLength,!s.idBlock.isConstructed&&s.lenBlock.isIndefiniteForm)return s.error="Indefinite length form used for primitive encoding form",{offset:-1,result:s};let c=pt;switch(s.idBlock.tagClass){case 1:if(s.idBlock.tagNumber>=37&&s.idBlock.isHexOnly===!1)return s.error="UNIVERSAL 37 and upper tags are reserved by ASN.1 standard",{offset:-1,result:s};switch(s.idBlock.tagNumber){case 0:if(s.idBlock.isConstructed&&s.lenBlock.length>0)return s.error="Type [UNIVERSAL 0] is reserved",{offset:-1,result:s};c=k.EndOfContent;break;case 1:c=k.Boolean;break;case 2:c=k.Integer;break;case 3:c=k.BitString;break;case 4:c=k.OctetString;break;case 5:c=k.Null;break;case 6:c=k.ObjectIdentifier;break;case 10:c=k.Enumerated;break;case 12:c=k.Utf8String;break;case 13:c=k.RelativeObjectIdentifier;break;case 14:c=k.TIME;break;case 15:return s.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:s};case 16:c=k.Sequence;break;case 17:c=k.Set;break;case 18:c=k.NumericString;break;case 19:c=k.PrintableString;break;case 20:c=k.TeletexString;break;case 21:c=k.VideotexString;break;case 22:c=k.IA5String;break;case 23:c=k.UTCTime;break;case 24:c=k.GeneralizedTime;break;case 25:c=k.GraphicString;break;case 26:c=k.VisibleString;break;case 27:c=k.GeneralString;break;case 28:c=k.UniversalString;break;case 29:c=k.CharacterString;break;case 30:c=k.BmpString;break;case 31:c=k.DATE;break;case 32:c=k.TimeOfDay;break;case 33:c=k.DateTime;break;case 34:c=k.Duration;break;default:{let l=s.idBlock.isConstructed?new k.Constructed:new k.Primitive;l.idBlock=s.idBlock,l.lenBlock=s.lenBlock,l.warnings=s.warnings,s=l}}break;case 2:case 3:case 4:default:c=s.idBlock.isConstructed?k.Constructed:k.Primitive}return s=Th(s,c),a=s.fromBER(r,t,s.lenBlock.isIndefiniteForm?e:s.lenBlock.length),s.valueBeforeDecodeView=r.subarray(n,n+s.blockLength),{offset:a,result:s}}function kr(r){if(!r.byteLength){let t=new pt({},xt);return t.error="Input buffer has zero length",{offset:-1,result:t}}return ws(M.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function Ch(r,t){return r?1:t}var Zt=class extends xt{constructor({value:t=[],isIndefiniteForm:e=!1,...n}={}){super(n),this.value=t,this.isIndefiniteForm=e}fromBER(t,e,n){let s=M.BufferSourceConverter.toUint8Array(t);if(!de(this,s,e,n))return-1;if(this.valueBeforeDecodeView=s.subarray(e,e+n),this.valueBeforeDecodeView.length===0)return this.warnings.push("Zero buffer length"),e;let i=e;for(;Ch(this.isIndefiniteForm,n)>0;){let o=ws(s,i,n);if(o.offset===-1)return this.error=o.result.error,this.warnings.concat(o.result.warnings),-1;if(i=o.offset,this.blockLength+=o.result.blockLength,n-=o.result.blockLength,this.value.push(o.result),this.isIndefiniteForm&&o.result.constructor.NAME===jr)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===jr?this.value.pop():this.warnings.push("No EndOfContent block encoded")),i}toBER(t,e){let n=e||new Yr;for(let s=0;s<this.value.length;s++)this.value[s].toBER(t,n);return e?qt:n.final()}toJSON(){let t={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let e of this.value)t.value.push(e.toJSON());return t}};Zt.NAME="ConstructedValueBlock";var ic,Ie=class extends pt{constructor(t={}){super(t,Zt),this.idBlock.isConstructed=!0}fromBER(t,e,n){this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm;let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}onAsciiEncoding(){let t=[];for(let n of this.valueBlock.value)t.push(n.toString("ascii").split(`
|
2
|
+
"use strict";var Libp2PFloodsub=(()=>{var _u=Object.create;var un=Object.defineProperty;var Tu=Object.getOwnPropertyDescriptor;var Cu=Object.getOwnPropertyNames;var Lu=Object.getPrototypeOf,Uu=Object.prototype.hasOwnProperty;var Ps=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),it=(r,t)=>{for(var e in t)un(r,e,{get:t[e],enumerable:!0})},Ro=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of Cu(t))!Uu.call(r,s)&&s!==e&&un(r,s,{get:()=>t[s],enumerable:!(n=Tu(t,s))||n.enumerable});return r};var Os=(r,t,e)=>(e=r!=null?_u(Lu(r)):{},Ro(t||!r||!r.__esModule?un(e,"default",{value:r,enumerable:!0}):e,r)),Du=r=>Ro(un({},"__esModule",{value:!0}),r);var Ya=Ps(Er=>{"use strict";var wh="[object ArrayBuffer]",ue=class r{static isArrayBuffer(t){return Object.prototype.toString.call(t)===wh}static toArrayBuffer(t){return this.isArrayBuffer(t)?t:t.byteLength===t.buffer.byteLength||t.byteOffset===0&&t.byteLength===t.buffer.byteLength?t.buffer:this.toUint8Array(t.buffer).slice(t.byteOffset,t.byteOffset+t.byteLength).buffer}static toUint8Array(t){return this.toView(t,Uint8Array)}static toView(t,e){if(t.constructor===e)return t;if(this.isArrayBuffer(t))return new e(t);if(this.isArrayBufferView(t))return new e(t.buffer,t.byteOffset,t.byteLength);throw new TypeError("The provided value is not of type '(ArrayBuffer or ArrayBufferView)'")}static isBufferSource(t){return this.isArrayBufferView(t)||this.isArrayBuffer(t)}static isArrayBufferView(t){return ArrayBuffer.isView(t)||t&&this.isArrayBuffer(t.buffer)}static isEqual(t,e){let n=r.toUint8Array(t),s=r.toUint8Array(e);if(n.length!==s.byteLength)return!1;for(let i=0;i<n.length;i++)if(n[i]!==s[i])return!1;return!0}static concat(...t){let e;Array.isArray(t[0])&&!(t[1]instanceof Function)||Array.isArray(t[0])&&t[1]instanceof Function?e=t[0]:t[t.length-1]instanceof Function?e=t.slice(0,t.length-1):e=t;let n=0;for(let o of e)n+=o.byteLength;let s=new Uint8Array(n),i=0;for(let o of e){let a=this.toUint8Array(o);s.set(a,i),i+=a.length}return t[t.length-1]instanceof Function?this.toView(s,t[t.length-1]):s.buffer}},ji="string",xh=/^[0-9a-f]+$/i,Eh=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,vh=/^[a-zA-Z0-9-_]+$/,Rn=class{static fromString(t){let e=unescape(encodeURIComponent(t)),n=new Uint8Array(e.length);for(let s=0;s<e.length;s++)n[s]=e.charCodeAt(s);return n.buffer}static toString(t){let e=ue.toUint8Array(t),n="";for(let i=0;i<e.length;i++)n+=String.fromCharCode(e[i]);return decodeURIComponent(escape(n))}},Ut=class{static toString(t,e=!1){let n=ue.toArrayBuffer(t),s=new DataView(n),i="";for(let o=0;o<n.byteLength;o+=2){let a=s.getUint16(o,e);i+=String.fromCharCode(a)}return i}static fromString(t,e=!1){let n=new ArrayBuffer(t.length*2),s=new DataView(n);for(let i=0;i<t.length;i++)s.setUint16(i*2,t.charCodeAt(i),e);return n}},_n=class r{static isHex(t){return typeof t===ji&&xh.test(t)}static isBase64(t){return typeof t===ji&&Eh.test(t)}static isBase64Url(t){return typeof t===ji&&vh.test(t)}static ToString(t,e="utf8"){let n=ue.toUint8Array(t);switch(e.toLowerCase()){case"utf8":return this.ToUtf8String(n);case"binary":return this.ToBinary(n);case"hex":return this.ToHex(n);case"base64":return this.ToBase64(n);case"base64url":return this.ToBase64Url(n);case"utf16le":return Ut.toString(n,!0);case"utf16":case"utf16be":return Ut.toString(n);default:throw new Error(`Unknown type of encoding '${e}'`)}}static FromString(t,e="utf8"){if(!t)return new ArrayBuffer(0);switch(e.toLowerCase()){case"utf8":return this.FromUtf8String(t);case"binary":return this.FromBinary(t);case"hex":return this.FromHex(t);case"base64":return this.FromBase64(t);case"base64url":return this.FromBase64Url(t);case"utf16le":return Ut.fromString(t,!0);case"utf16":case"utf16be":return Ut.fromString(t);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToBase64(t){let e=ue.toUint8Array(t);if(typeof btoa<"u"){let n=this.ToString(e,"binary");return btoa(n)}else return Buffer.from(e).toString("base64")}static FromBase64(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isBase64(e))throw new TypeError("Argument 'base64Text' is not Base64 encoded");return typeof atob<"u"?this.FromBinary(atob(e)):new Uint8Array(Buffer.from(e,"base64")).buffer}static FromBase64Url(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isBase64Url(e))throw new TypeError("Argument 'base64url' is not Base64Url encoded");return this.FromBase64(this.Base64Padding(e.replace(/\-/g,"+").replace(/\_/g,"/")))}static ToBase64Url(t){return this.ToBase64(t).replace(/\+/g,"-").replace(/\//g,"_").replace(/\=/g,"")}static FromUtf8String(t,e=r.DEFAULT_UTF8_ENCODING){switch(e){case"ascii":return this.FromBinary(t);case"utf8":return Rn.fromString(t);case"utf16":case"utf16be":return Ut.fromString(t);case"utf16le":case"usc2":return Ut.fromString(t,!0);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToUtf8String(t,e=r.DEFAULT_UTF8_ENCODING){switch(e){case"ascii":return this.ToBinary(t);case"utf8":return Rn.toString(t);case"utf16":case"utf16be":return Ut.toString(t);case"utf16le":case"usc2":return Ut.toString(t,!0);default:throw new Error(`Unknown type of encoding '${e}'`)}}static FromBinary(t){let e=t.length,n=new Uint8Array(e);for(let s=0;s<e;s++)n[s]=t.charCodeAt(s);return n.buffer}static ToBinary(t){let e=ue.toUint8Array(t),n="";for(let s=0;s<e.length;s++)n+=String.fromCharCode(e[s]);return n}static ToHex(t){let e=ue.toUint8Array(t),n="",s=e.length;for(let i=0;i<s;i++){let o=e[i];o<16&&(n+="0"),n+=o.toString(16)}return n}static FromHex(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isHex(e))throw new TypeError("Argument 'hexString' is not HEX encoded");e.length%2&&(e=`0${e}`);let n=new Uint8Array(e.length/2);for(let s=0;s<e.length;s=s+2){let i=e.slice(s,s+2);n[s/2]=parseInt(i,16)}return n.buffer}static ToUtf16String(t,e=!1){return Ut.toString(t,e)}static FromUtf16String(t,e=!1){return Ut.fromString(t,e)}static Base64Padding(t){let e=4-t.length%4;if(e<4)for(let n=0;n<e;n++)t+="=";return t}static formatString(t){return t?.replace(/[\n\r\t ]/g,"")||""}};_n.DEFAULT_UTF8_ENCODING="utf8";function Bh(r,...t){let e=arguments[0];for(let n=1;n<arguments.length;n++){let s=arguments[n];for(let i in s)e[i]=s[i]}return e}function Ah(...r){let t=r.map(s=>s.byteLength).reduce((s,i)=>s+i),e=new Uint8Array(t),n=0;return r.map(s=>new Uint8Array(s)).forEach(s=>{for(let i of s)e[n++]=i}),e.buffer}function Sh(r,t){if(!(r&&t)||r.byteLength!==t.byteLength)return!1;let e=new Uint8Array(r),n=new Uint8Array(t);for(let s=0;s<r.byteLength;s++)if(e[s]!==n[s])return!1;return!0}Er.BufferSourceConverter=ue;Er.Convert=_n;Er.assign=Bh;Er.combine=Ah;Er.isEqual=Sh});var iu=Ps((Gy,po)=>{"use strict";var pd=Object.prototype.hasOwnProperty,St="~";function rn(){}Object.create&&(rn.prototype=Object.create(null),new rn().__proto__||(St=!1));function gd(r,t,e){this.fn=r,this.context=t,this.once=e||!1}function su(r,t,e,n,s){if(typeof e!="function")throw new TypeError("The listener must be a function");var i=new gd(e,n||r,s),o=St?St+t:t;return r._events[o]?r._events[o].fn?r._events[o]=[r._events[o],i]:r._events[o].push(i):(r._events[o]=i,r._eventsCount++),r}function Es(r,t){--r._eventsCount===0?r._events=new rn:delete r._events[t]}function Et(){this._events=new rn,this._eventsCount=0}Et.prototype.eventNames=function(){var t=[],e,n;if(this._eventsCount===0)return t;for(n in e=this._events)pd.call(e,n)&&t.push(St?n.slice(1):n);return Object.getOwnPropertySymbols?t.concat(Object.getOwnPropertySymbols(e)):t};Et.prototype.listeners=function(t){var e=St?St+t:t,n=this._events[e];if(!n)return[];if(n.fn)return[n.fn];for(var s=0,i=n.length,o=new Array(i);s<i;s++)o[s]=n[s].fn;return o};Et.prototype.listenerCount=function(t){var e=St?St+t:t,n=this._events[e];return n?n.fn?1:n.length:0};Et.prototype.emit=function(t,e,n,s,i,o){var a=St?St+t:t;if(!this._events[a])return!1;var c=this._events[a],f=arguments.length,l,u;if(c.fn){switch(c.once&&this.removeListener(t,c.fn,void 0,!0),f){case 1:return c.fn.call(c.context),!0;case 2:return c.fn.call(c.context,e),!0;case 3:return c.fn.call(c.context,e,n),!0;case 4:return c.fn.call(c.context,e,n,s),!0;case 5:return c.fn.call(c.context,e,n,s,i),!0;case 6:return c.fn.call(c.context,e,n,s,i,o),!0}for(u=1,l=new Array(f-1);u<f;u++)l[u-1]=arguments[u];c.fn.apply(c.context,l)}else{var p=c.length,w;for(u=0;u<p;u++)switch(c[u].once&&this.removeListener(t,c[u].fn,void 0,!0),f){case 1:c[u].fn.call(c[u].context);break;case 2:c[u].fn.call(c[u].context,e);break;case 3:c[u].fn.call(c[u].context,e,n);break;case 4:c[u].fn.call(c[u].context,e,n,s);break;default:if(!l)for(w=1,l=new Array(f-1);w<f;w++)l[w-1]=arguments[w];c[u].fn.apply(c[u].context,l)}}return!0};Et.prototype.on=function(t,e,n){return su(this,t,e,n,!1)};Et.prototype.once=function(t,e,n){return su(this,t,e,n,!0)};Et.prototype.removeListener=function(t,e,n,s){var i=St?St+t:t;if(!this._events[i])return this;if(!e)return Es(this,i),this;var o=this._events[i];if(o.fn)o.fn===e&&(!s||o.once)&&(!n||o.context===n)&&Es(this,i);else{for(var a=0,c=[],f=o.length;a<f;a++)(o[a].fn!==e||s&&!o[a].once||n&&o[a].context!==n)&&c.push(o[a]);c.length?this._events[i]=c.length===1?c[0]:c:Es(this,i)}return this};Et.prototype.removeAllListeners=function(t){var e;return t?(e=St?St+t:t,this._events[e]&&Es(this,e)):(this._events=new rn,this._eventsCount=0),this};Et.prototype.off=Et.prototype.removeListener;Et.prototype.addListener=Et.prototype.on;Et.prefixed=St;Et.EventEmitter=Et;typeof po<"u"&&(po.exports=Et)});var du=Ps((hb,hu)=>{"use strict";function fu(r,t){for(let e in t)Object.defineProperty(r,e,{value:t[e],enumerable:!0,configurable:!0});return r}function md(r,t,e){if(!r||typeof r=="string")throw new TypeError("Please pass an Error to err-code");e||(e={}),typeof t=="object"&&(e=t,t=""),t&&(e.code=t);try{return fu(r,e)}catch{e.message=r.message,e.stack=r.stack;let s=function(){};return s.prototype=Object.create(Object.getPrototypeOf(r)),fu(new s,e)}}hu.exports=md});var Sd={};it(Sd,{FloodSub:()=>Us,floodsub:()=>Ad,multicodec:()=>xo});var Vs=Symbol.for("@libp2p/peer-id");var Rr;(function(r){r.Accept="accept",r.Ignore="ignore",r.Reject="reject"})(Rr||(Rr={}));var A=class extends Error{code;props;constructor(t,e,n){super(t),this.code=e,this.name=n?.name??"CodeError",this.props=n??{}}};var _o=(r,...t)=>{try{[...t]}catch{}};var Ze=class extends EventTarget{#t=new Map;constructor(){super(),_o(1/0,this)}listenerCount(t){let e=this.#t.get(t);return e==null?0:e.length}addEventListener(t,e,n){super.addEventListener(t,e,n);let s=this.#t.get(t);s==null&&(s=[],this.#t.set(t,s)),s.push({callback:e,once:(n!==!0&&n!==!1&&n?.once)??!1})}removeEventListener(t,e,n){super.removeEventListener(t.toString(),e??null,n);let s=this.#t.get(t);s!=null&&(s=s.filter(({callback:i})=>i!==e),this.#t.set(t,s))}dispatchEvent(t){let e=super.dispatchEvent(t),n=this.#t.get(t.type);return n==null||(n=n.filter(({once:s})=>!s),this.#t.set(t.type,n)),e}safeDispatchEvent(t,e={}){return this.dispatchEvent(new Gt(t,e))}},Ms=class extends Event{detail;constructor(t,e){super(t,e),this.detail=e?.detail}},Gt=globalThis.CustomEvent??Ms;var Ld=Symbol.for("@libp2p/service-capabilities"),To=Symbol.for("@libp2p/service-dependencies");var $s={};it($s,{base58btc:()=>vt,base58flickr:()=>Ku});var n0=new Uint8Array(0);function Co(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function Qt(r){if(r instanceof Uint8Array&&r.constructor.name==="Uint8Array")return r;if(r instanceof ArrayBuffer)return new Uint8Array(r);if(ArrayBuffer.isView(r))return new Uint8Array(r.buffer,r.byteOffset,r.byteLength);throw new Error("Unknown type, must be binary type")}function Lo(r){return new TextEncoder().encode(r)}function Uo(r){return new TextDecoder().decode(r)}function Pu(r,t){if(r.length>=255)throw new TypeError("Alphabet too long");for(var e=new Uint8Array(256),n=0;n<e.length;n++)e[n]=255;for(var s=0;s<r.length;s++){var i=r.charAt(s),o=i.charCodeAt(0);if(e[o]!==255)throw new TypeError(i+" is ambiguous");e[o]=s}var a=r.length,c=r.charAt(0),f=Math.log(a)/Math.log(256),l=Math.log(256)/Math.log(a);function u(g){if(g instanceof Uint8Array||(ArrayBuffer.isView(g)?g=new Uint8Array(g.buffer,g.byteOffset,g.byteLength):Array.isArray(g)&&(g=Uint8Array.from(g))),!(g instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(g.length===0)return"";for(var h=0,d=0,m=0,x=g.length;m!==x&&g[m]===0;)m++,h++;for(var b=(x-m)*l+1>>>0,T=new Uint8Array(b);m!==x;){for(var E=g[m],S=0,R=b-1;(E!==0||S<d)&&R!==-1;R--,S++)E+=256*T[R]>>>0,T[R]=E%a>>>0,E=E/a>>>0;if(E!==0)throw new Error("Non-zero carry");d=S,m++}for(var _=b-d;_!==b&&T[_]===0;)_++;for(var G=c.repeat(h);_<b;++_)G+=r.charAt(T[_]);return G}function p(g){if(typeof g!="string")throw new TypeError("Expected String");if(g.length===0)return new Uint8Array;var h=0;if(g[h]!==" "){for(var d=0,m=0;g[h]===c;)d++,h++;for(var x=(g.length-h)*f+1>>>0,b=new Uint8Array(x);g[h];){var T=e[g.charCodeAt(h)];if(T===255)return;for(var E=0,S=x-1;(T!==0||E<m)&&S!==-1;S--,E++)T+=a*b[S]>>>0,b[S]=T%256>>>0,T=T/256>>>0;if(T!==0)throw new Error("Non-zero carry");m=E,h++}if(g[h]!==" "){for(var R=x-m;R!==x&&b[R]===0;)R++;for(var _=new Uint8Array(d+(x-R)),G=d;R!==x;)_[G++]=b[R++];return _}}}function w(g){var h=p(g);if(h)return h;throw new Error(`Non-${t} character`)}return{encode:u,decodeUnsafe:p,decode:w}}var Ou=Pu,Vu=Ou,Po=Vu;var Hs=class{name;prefix;baseEncode;constructor(t,e,n){this.name=t,this.prefix=e,this.baseEncode=n}encode(t){if(t instanceof Uint8Array)return`${this.prefix}${this.baseEncode(t)}`;throw Error("Unknown type, must be binary type")}},Ks=class{name;prefix;baseDecode;prefixCodePoint;constructor(t,e,n){if(this.name=t,this.prefix=e,e.codePointAt(0)===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=e.codePointAt(0),this.baseDecode=n}decode(t){if(typeof t=="string"){if(t.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(t)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(t.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(t){return Oo(this,t)}},Fs=class{decoders;constructor(t){this.decoders=t}or(t){return Oo(this,t)}decode(t){let e=t[0],n=this.decoders[e];if(n!=null)return n.decode(t);throw RangeError(`Unable to decode multibase string ${JSON.stringify(t)}, only inputs prefixed with ${Object.keys(this.decoders)} are supported`)}};function Oo(r,t){return new Fs({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var qs=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(t,e,n,s){this.name=t,this.prefix=e,this.baseEncode=n,this.baseDecode=s,this.encoder=new Hs(t,e,n),this.decoder=new Ks(t,e,s)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function We({name:r,prefix:t,encode:e,decode:n}){return new qs(r,t,e,n)}function ye({name:r,prefix:t,alphabet:e}){let{encode:n,decode:s}=Po(e,r);return We({prefix:t,name:r,encode:n,decode:i=>Qt(s(i))})}function Mu(r,t,e,n){let s={};for(let l=0;l<t.length;++l)s[t[l]]=l;let i=r.length;for(;r[i-1]==="=";)--i;let o=new Uint8Array(i*e/8|0),a=0,c=0,f=0;for(let l=0;l<i;++l){let u=s[r[l]];if(u===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<e|u,a+=e,a>=8&&(a-=8,o[f++]=255&c>>a)}if(a>=e||255&c<<8-a)throw new SyntaxError("Unexpected end of data");return o}function Hu(r,t,e){let n=t[t.length-1]==="=",s=(1<<e)-1,i="",o=0,a=0;for(let c=0;c<r.length;++c)for(a=a<<8|r[c],o+=8;o>e;)o-=e,i+=t[s&a>>o];if(o!==0&&(i+=t[s&a<<e-o]),n)for(;i.length*e&7;)i+="=";return i}function tt({name:r,prefix:t,bitsPerChar:e,alphabet:n}){return We({prefix:t,name:r,encode(s){return Hu(s,n,e)},decode(s){return Mu(s,n,e,r)}})}var vt=ye({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),Ku=ye({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Gs={};it(Gs,{base10:()=>Fu});var Fu=ye({prefix:"9",name:"base10",alphabet:"0123456789"});var zs={};it(zs,{base16:()=>qu,base16upper:()=>$u});var qu=tt({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),$u=tt({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Ys={};it(Ys,{base2:()=>Gu});var Gu=tt({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var js={};it(js,{base256emoji:()=>Wu});var Vo=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}"),zu=Vo.reduce((r,t,e)=>(r[e]=t,r),[]),Yu=Vo.reduce((r,t,e)=>(r[t.codePointAt(0)]=e,r),[]);function ju(r){return r.reduce((t,e)=>(t+=zu[e],t),"")}function Zu(r){let t=[];for(let e of r){let n=Yu[e.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${e}`);t.push(n)}return new Uint8Array(t)}var Wu=We({prefix:"\u{1F680}",name:"base256emoji",encode:ju,decode:Zu});var Zs={};it(Zs,{base32:()=>Je,base32hex:()=>tl,base32hexpad:()=>rl,base32hexpadupper:()=>nl,base32hexupper:()=>el,base32pad:()=>Xu,base32padupper:()=>Qu,base32upper:()=>Ju,base32z:()=>sl});var Je=tt({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),Ju=tt({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Xu=tt({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),Qu=tt({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),tl=tt({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),el=tt({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),rl=tt({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),nl=tt({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),sl=tt({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Ws={};it(Ws,{base36:()=>il,base36upper:()=>ol});var il=ye({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),ol=ye({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Js={};it(Js,{base64:()=>_r,base64pad:()=>al,base64url:()=>cl,base64urlpad:()=>ul});var _r=tt({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),al=tt({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),cl=tt({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),ul=tt({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Xs={};it(Xs,{base8:()=>ll});var ll=tt({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Qs={};it(Qs,{identity:()=>fl});var fl=We({prefix:"\0",name:"identity",encode:r=>Uo(r),decode:r=>Lo(r)});var w0=new TextEncoder,x0=new TextDecoder;var ei={};it(ei,{identity:()=>te});var pl=Ko,Mo=128,gl=127,ml=~gl,yl=Math.pow(2,31);function Ko(r,t,e){t=t||[],e=e||0;for(var n=e;r>=yl;)t[e++]=r&255|Mo,r/=128;for(;r&ml;)t[e++]=r&255|Mo,r>>>=7;return t[e]=r|0,Ko.bytes=e-n+1,t}var bl=ti,wl=128,Ho=127;function ti(r,n){var e=0,n=n||0,s=0,i=n,o,a=r.length;do{if(i>=a)throw ti.bytes=0,new RangeError("Could not decode varint");o=r[i++],e+=s<28?(o&Ho)<<s:(o&Ho)*Math.pow(2,s),s+=7}while(o>=wl);return ti.bytes=i-n,e}var xl=Math.pow(2,7),El=Math.pow(2,14),vl=Math.pow(2,21),Bl=Math.pow(2,28),Al=Math.pow(2,35),Sl=Math.pow(2,42),kl=Math.pow(2,49),Il=Math.pow(2,56),Nl=Math.pow(2,63),Rl=function(r){return r<xl?1:r<El?2:r<vl?3:r<Bl?4:r<Al?5:r<Sl?6:r<kl?7:r<Il?8:r<Nl?9:10},_l={encode:pl,decode:bl,encodingLength:Rl},Tl=_l,Tr=Tl;function Cr(r,t=0){return[Tr.decode(r,t),Tr.decode.bytes]}function Xe(r,t,e=0){return Tr.encode(r,t,e),t}function Qe(r){return Tr.encodingLength(r)}function zt(r,t){let e=t.byteLength,n=Qe(r),s=n+Qe(e),i=new Uint8Array(s+e);return Xe(r,i,0),Xe(e,i,n),i.set(t,s),new tr(r,e,t,i)}function Lr(r){let t=Qt(r),[e,n]=Cr(t),[s,i]=Cr(t.subarray(n)),o=t.subarray(n+i);if(o.byteLength!==s)throw new Error("Incorrect length");return new tr(e,s,o,t)}function Fo(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&Co(r.bytes,e.bytes)}}var tr=class{code;size;digest;bytes;constructor(t,e,n,s){this.code=t,this.size=e,this.digest=n,this.bytes=s}};var qo=0,Cl="identity",$o=Qt;function Ll(r){return zt(qo,$o(r))}var te={code:qo,name:Cl,encode:$o,digest:Ll};var si={};it(si,{sha256:()=>ct,sha512:()=>Ul});function ni({name:r,code:t,encode:e}){return new ri(r,t,e)}var ri=class{name;code;encode;constructor(t,e,n){this.name=t,this.code=e,this.encode=n}digest(t){if(t instanceof Uint8Array){let e=this.encode(t);return e instanceof Uint8Array?zt(this.code,e):e.then(n=>zt(this.code,n))}else throw Error("Unknown type, must be binary type")}};function zo(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var ct=ni({name:"sha2-256",code:18,encode:zo("SHA-256")}),Ul=ni({name:"sha2-512",code:19,encode:zo("SHA-512")});function Yo(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return Pl(e,ii(r),t??vt.encoder);default:return Ol(e,ii(r),t??Je.encoder)}}var jo=new WeakMap;function ii(r){let t=jo.get(r);if(t==null){let e=new Map;return jo.set(r,e),e}return t}var be=class r{code;version;multihash;bytes;"/";constructor(t,e,n,s){this.code=e,this.version=t,this.multihash=n,this.bytes=s,this["/"]=s}get asCID(){return this}get byteOffset(){return this.bytes.byteOffset}get byteLength(){return this.bytes.byteLength}toV0(){switch(this.version){case 0:return this;case 1:{let{code:t,multihash:e}=this;if(t!==Ur)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==Vl)throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");return r.createV0(e)}default:throw Error(`Can not convert CID version ${this.version} to version 0. This is a bug please report`)}}toV1(){switch(this.version){case 0:{let{code:t,digest:e}=this.multihash,n=zt(t,e);return r.createV1(this.code,n)}case 1:return this;default:throw Error(`Can not convert CID version ${this.version} to version 1. This is a bug please report`)}}equals(t){return r.equals(this,t)}static equals(t,e){let n=e;return n!=null&&t.code===n.code&&t.version===n.version&&Fo(t.multihash,n.multihash)}toString(t){return Yo(this,t)}toJSON(){return{"/":Yo(this)}}link(){return this}[Symbol.toStringTag]="CID";[Symbol.for("nodejs.util.inspect.custom")](){return`CID(${this.toString()})`}static asCID(t){if(t==null)return null;let e=t;if(e instanceof r)return e;if(e["/"]!=null&&e["/"]===e.bytes||e.asCID===e){let{version:n,code:s,multihash:i,bytes:o}=e;return new r(n,s,i,o??Zo(n,s,i.bytes))}else if(e[Ml]===!0){let{version:n,multihash:s,code:i}=e,o=Lr(s);return r.create(n,i,o)}else return null}static create(t,e,n){if(typeof e!="number")throw new Error("String codecs are no longer supported");if(!(n.bytes instanceof Uint8Array))throw new Error("Invalid digest");switch(t){case 0:{if(e!==Ur)throw new Error(`Version 0 CID must use dag-pb (code: ${Ur}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let s=Zo(t,e,n.bytes);return new r(t,e,n,s)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,Ur,t)}static createV1(t,e){return r.create(1,t,e)}static decode(t){let[e,n]=r.decodeFirst(t);if(n.length!==0)throw new Error("Incorrect length");return e}static decodeFirst(t){let e=r.inspectBytes(t),n=e.size-e.multihashSize,s=Qt(t.subarray(n,n+e.multihashSize));if(s.byteLength!==e.multihashSize)throw new Error("Incorrect length");let i=s.subarray(e.multihashSize-e.digestSize),o=new tr(e.multihashCode,e.digestSize,i,s);return[e.version===0?r.createV0(o):r.createV1(e.codec,o),t.subarray(e.size)]}static inspectBytes(t){let e=0,n=()=>{let[u,p]=Cr(t.subarray(e));return e+=p,u},s=n(),i=Ur;if(s===18?(s=0,e=0):i=n(),s!==0&&s!==1)throw new RangeError(`Invalid CID version ${s}`);let o=e,a=n(),c=n(),f=e+c,l=f-o;return{version:s,codec:i,multihashCode:a,digestSize:c,multihashSize:l,size:f}}static parse(t,e){let[n,s]=Dl(t,e),i=r.decode(s);if(i.version===0&&t[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return ii(i).set(n,t),i}};function Dl(r,t){switch(r[0]){case"Q":{let e=t??vt;return[vt.prefix,e.decode(`${vt.prefix}${r}`)]}case vt.prefix:{let e=t??vt;return[vt.prefix,e.decode(r)]}case Je.prefix:{let e=t??Je;return[Je.prefix,e.decode(r)]}default:{if(t==null)throw Error("To parse non base32 or base58btc encoded CID multibase decoder must be provided");return[r[0],t.decode(r)]}}}function Pl(r,t,e){let{prefix:n}=e;if(n!==vt.prefix)throw Error(`Cannot string encode V0 in ${e.name} encoding`);let s=t.get(n);if(s==null){let i=e.encode(r).slice(1);return t.set(n,i),i}else return s}function Ol(r,t,e){let{prefix:n}=e,s=t.get(n);if(s==null){let i=e.encode(r);return t.set(n,i),i}else return s}var Ur=112,Vl=18;function Zo(r,t,e){let n=Qe(r),s=n+Qe(t),i=new Uint8Array(s+e.byteLength);return Xe(r,i,0),Xe(t,i,n),i.set(e,s),i}var Ml=Symbol.for("@ipld/js-cid/CID");var rr={...Qs,...Ys,...Xs,...Gs,...zs,...Zs,...Ws,...$s,...Js,...js},K0={...si,...ei};function mt(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function ee(r=0){return new Uint8Array(r)}function yt(r=0){return new Uint8Array(r)}function Jo(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var Wo=Jo("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),oi=Jo("ascii","a",r=>{let t="a";for(let e=0;e<r.length;e++)t+=String.fromCharCode(r[e]);return t},r=>{r=r.substring(1);let t=yt(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),Hl={utf8:Wo,"utf-8":Wo,hex:rr.base16,latin1:oi,ascii:oi,binary:oi,...rr},fn=Hl;function $(r,t="utf8"){let e=fn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function Y(r,t="utf8"){let e=fn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}var Qo=Symbol.for("nodejs.util.inspect.custom"),Xo=Object.values(rr).map(r=>r.decoder).reduce((r,t)=>r.or(t),rr.identity.decoder),ta=114,ui=36,li=37,Dr=class{type;multihash;privateKey;publicKey;string;constructor(t){this.type=t.type,this.multihash=t.multihash,this.privateKey=t.privateKey,Object.defineProperty(this,"string",{enumerable:!1,writable:!0})}get[Symbol.toStringTag](){return`PeerId(${this.toString()})`}[Vs]=!0;toString(){return this.string==null&&(this.string=vt.encode(this.multihash.bytes).slice(1)),this.string}toCID(){return be.createV1(ta,this.multihash)}toBytes(){return this.multihash.bytes}toJSON(){return this.toString()}equals(t){if(t==null)return!1;if(t instanceof Uint8Array)return mt(this.multihash.bytes,t);if(typeof t=="string")return re(t).equals(this);if(t?.multihash?.bytes!=null)return mt(this.multihash.bytes,t.multihash.bytes);throw new Error("not valid Id")}[Qo](){return`PeerId(${this.toString()})`}},nr=class extends Dr{type="RSA";publicKey;constructor(t){super({...t,type:"RSA"}),this.publicKey=t.publicKey}},sr=class extends Dr{type="Ed25519";publicKey;constructor(t){super({...t,type:"Ed25519"}),this.publicKey=t.multihash.digest}},ir=class extends Dr{type="secp256k1";publicKey;constructor(t){super({...t,type:"secp256k1"}),this.publicKey=t.multihash.digest}},ai=2336,ci=class{type="url";multihash;privateKey;publicKey;url;constructor(t){this.url=t.toString(),this.multihash=te.digest($(this.url))}[Qo](){return`PeerId(${this.url})`}[Vs]=!0;toString(){return this.toCID().toString()}toCID(){return be.createV1(ai,this.multihash)}toBytes(){return this.toCID().bytes}equals(t){return t==null?!1:(t instanceof Uint8Array&&(t=Y(t)),t.toString()===this.toString())}};function re(r,t){if(t=t??Xo,r.charAt(0)==="1"||r.charAt(0)==="Q"){let e=Lr(vt.decode(`z${r}`));return r.startsWith("12D")?new sr({multihash:e}):r.startsWith("16U")?new ir({multihash:e}):new nr({multihash:e})}return Pr(Xo.decode(r))}function Pr(r){try{let t=Lr(r);if(t.code===te.code){if(t.digest.length===ui)return new sr({multihash:t});if(t.digest.length===li)return new ir({multihash:t})}if(t.code===ct.code)return new nr({multihash:t})}catch{return Kl(be.decode(r))}throw new Error("Supplied PeerID CID is invalid")}function Kl(r){if(r==null||r.multihash==null||r.version==null||r.version===1&&r.code!==ta&&r.code!==ai)throw new Error("Supplied PeerID CID is invalid");if(r.code===ai){let e=Y(r.multihash.digest);return new ci(new URL(e))}let t=r.multihash;if(t.code===ct.code)return new nr({multihash:r.multihash});if(t.code===te.code){if(t.digest.length===ui)return new sr({multihash:r.multihash});if(t.digest.length===li)return new ir({multihash:r.multihash})}throw new Error("Supplied PeerID CID is invalid")}async function hn(r,t){return r.length===ui?new sr({multihash:zt(te.code,r),privateKey:t}):r.length===li?new ir({multihash:zt(te.code,r),privateKey:t}):new nr({multihash:await ct.digest(r),publicKey:r,privateKey:t})}function or(r,t){let e={[Symbol.iterator]:()=>e,next:()=>{let n=r.next(),s=n.value;return n.done===!0||s==null?{done:!0,value:void 0}:{done:!1,value:t(s)}}};return e}var Or=class{map;constructor(t){if(this.map=new Map,t!=null)for(let[e,n]of t.entries())this.map.set(e.toString(),n)}[Symbol.iterator](){return this.entries()}clear(){this.map.clear()}delete(t){return this.map.delete(t.toString())}entries(){return or(this.map.entries(),t=>[re(t[0]),t[1]])}forEach(t){this.map.forEach((e,n)=>{t(e,re(n),this)})}get(t){return this.map.get(t.toString())}has(t){return this.map.has(t.toString())}set(t,e){this.map.set(t.toString(),e)}keys(){return or(this.map.keys(),t=>re(t))}values(){return this.map.values()}get size(){return this.map.size}};var Vr=class r{set;constructor(t){if(this.set=new Set,t!=null)for(let e of t)this.set.add(e.toString())}get size(){return this.set.size}[Symbol.iterator](){return this.values()}add(t){this.set.add(t.toString())}clear(){this.set.clear()}delete(t){this.set.delete(t.toString())}entries(){return or(this.set.entries(),t=>{let e=re(t[0]);return[e,e]})}forEach(t){this.set.forEach(e=>{let n=re(e);t(n,n,this)})}has(t){return this.set.has(t.toString())}values(){return or(this.set.values(),t=>re(t))}intersection(t){let e=new r;for(let n of t)this.has(n)&&e.add(n);return e}difference(t){let e=new r;for(let n of this)t.has(n)||e.add(n);return e}union(t){let e=new r;for(let n of t)e.add(n);for(let n of this)e.add(n);return e}};var W={get(r=globalThis){let t=r.crypto;if(t==null||t.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 t}};var ea={SHA1:20,SHA256:32,SHA512:64};var Fl={SHA1:"SHA-1",SHA256:"SHA-256",SHA512:"SHA-512"},ql=async(r,t)=>{let e=await W.get().subtle.sign({name:"HMAC"},r,t);return new Uint8Array(e,0,e.byteLength)};async function ra(r,t){let e=Fl[r],n=await W.get().subtle.importKey("raw",t,{name:"HMAC",hash:{name:e}},!1,["sign"]);return{async digest(s){return ql(n,s)},length:ea[r]}}var tn={};it(tn,{Ed25519PrivateKey:()=>ce,Ed25519PublicKey:()=>He,MAX_RSA_KEY_SIZE:()=>qe,RsaPrivateKey:()=>_e,RsaPublicKey:()=>Fe,Secp256k1PrivateKey:()=>ze,Secp256k1PublicKey:()=>Ge,generateEphemeralKeyPair:()=>qa,generateKeyPair:()=>nd,generateKeyPairFromSeed:()=>sd,importKey:()=>cd,keyStretcher:()=>za,keysPBM:()=>wr,marshalPrivateKey:()=>ad,marshalPublicKey:()=>od,supportedKeys:()=>me,unmarshalPrivateKey:()=>Xc,unmarshalPublicKey:()=>id});var Gi={};it(Gi,{Ed25519PrivateKey:()=>ce,Ed25519PublicKey:()=>He,generateKeyPair:()=>dh,generateKeyPairFromSeed:()=>$i,unmarshalEd25519PrivateKey:()=>fh,unmarshalEd25519PublicKey:()=>hh});function Bt(r,t){t==null&&(t=r.reduce((s,i)=>s+i.length,0));let e=yt(t),n=0;for(let s of r)e.set(s,n),n+=s.length;return e}function fi(r,t){let e=$(r,"base64urlpad");if(t!=null){if(e.length>t)throw new Error("byte array longer than desired length");e=Bt([new Uint8Array(t-e.length),e])}return e}function Lt(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function ar(r){if(!Number.isSafeInteger(r)||r<0)throw new Error(`positive integer expected, not ${r}`)}function Gl(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function cr(r,...t){if(!Gl(r))throw new Error("Uint8Array expected");if(t.length>0&&!t.includes(r.length))throw new Error(`Uint8Array expected of length ${t}, not of length=${r.length}`)}function dn(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");ar(r.outputLen),ar(r.blockLen)}function ur(r,t=!0){if(r.destroyed)throw new Error("Hash instance has been destroyed");if(t&&r.finished)throw new Error("Hash#digest() has already been called")}function na(r,t){cr(r);let e=t.outputLen;if(r.length<e)throw new Error(`digestInto() expects output buffer of length at least ${e}`)}var pn=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;var fr=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),Pt=(r,t)=>r<<32-t|r>>>t;var Tp=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;var zl=async()=>{};async function sa(r,t,e){let n=Date.now();for(let s=0;s<r;s++){e(s);let i=Date.now()-n;i>=0&&i<t||(await zl(),n+=i)}}function ia(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function we(r){return typeof r=="string"&&(r=ia(r)),cr(r),r}function hi(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];cr(s),t+=s.length}let e=new Uint8Array(t);for(let n=0,s=0;n<r.length;n++){let i=r[n];e.set(i,s),s+=i.length}return e}var lr=class{clone(){return this._cloneInto()}},Yl={}.toString;function oa(r,t){if(t!==void 0&&Yl.call(t)!=="[object Object]")throw new Error("Options should be object or undefined");return Object.assign(r,t)}function gn(r){let t=n=>r().update(we(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function hr(r=32){if(pn&&typeof pn.getRandomValues=="function")return pn.getRandomValues(new Uint8Array(r));throw new Error("crypto.getRandomValues must be defined")}function jl(r,t,e,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(t,e,n);let s=BigInt(32),i=BigInt(4294967295),o=Number(e>>s&i),a=Number(e&i),c=n?4:0,f=n?0:4;r.setUint32(t+c,o,n),r.setUint32(t+f,a,n)}var aa=(r,t,e)=>r&t^~r&e,ca=(r,t,e)=>r&t^r&e^t&e,dr=class extends lr{constructor(t,e,n,s){super(),this.blockLen=t,this.outputLen=e,this.padOffset=n,this.isLE=s,this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.buffer=new Uint8Array(t),this.view=fr(this.buffer)}update(t){ur(this);let{view:e,buffer:n,blockLen:s}=this;t=we(t);let i=t.length;for(let o=0;o<i;){let a=Math.min(s-this.pos,i-o);if(a===s){let c=fr(t);for(;s<=i-o;o+=s)this.process(c,o);continue}n.set(t.subarray(o,o+a),this.pos),this.pos+=a,o+=a,this.pos===s&&(this.process(e,0),this.pos=0)}return this.length+=t.length,this.roundClean(),this}digestInto(t){ur(this),na(t,this),this.finished=!0;let{buffer:e,view:n,blockLen:s,isLE:i}=this,{pos:o}=this;e[o++]=128,this.buffer.subarray(o).fill(0),this.padOffset>s-o&&(this.process(n,0),o=0);for(let u=o;u<s;u++)e[u]=0;jl(n,s-8,BigInt(this.length*8),i),this.process(n,0);let a=fr(t),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let f=c/4,l=this.get();if(f>l.length)throw new Error("_sha2: outputLen bigger than state");for(let u=0;u<f;u++)a.setUint32(4*u,l[u],i)}digest(){let{buffer:t,outputLen:e}=this;this.digestInto(t);let n=t.slice(0,e);return this.destroy(),n}_cloneInto(t){t||(t=new this.constructor),t.set(...this.get());let{blockLen:e,buffer:n,length:s,finished:i,destroyed:o,pos:a}=this;return t.length=s,t.pos=a,t.finished=i,t.destroyed=o,s%e&&t.buffer.set(n),t}};var mn=BigInt(4294967295),di=BigInt(32);function ua(r,t=!1){return t?{h:Number(r&mn),l:Number(r>>di&mn)}:{h:Number(r>>di&mn)|0,l:Number(r&mn)|0}}function Zl(r,t=!1){let e=new Uint32Array(r.length),n=new Uint32Array(r.length);for(let s=0;s<r.length;s++){let{h:i,l:o}=ua(r[s],t);[e[s],n[s]]=[i,o]}return[e,n]}var Wl=(r,t)=>BigInt(r>>>0)<<di|BigInt(t>>>0),Jl=(r,t,e)=>r>>>e,Xl=(r,t,e)=>r<<32-e|t>>>e,Ql=(r,t,e)=>r>>>e|t<<32-e,tf=(r,t,e)=>r<<32-e|t>>>e,ef=(r,t,e)=>r<<64-e|t>>>e-32,rf=(r,t,e)=>r>>>e-32|t<<64-e,nf=(r,t)=>t,sf=(r,t)=>r,of=(r,t,e)=>r<<e|t>>>32-e,af=(r,t,e)=>t<<e|r>>>32-e,cf=(r,t,e)=>t<<e-32|r>>>64-e,uf=(r,t,e)=>r<<e-32|t>>>64-e;function lf(r,t,e,n){let s=(t>>>0)+(n>>>0);return{h:r+e+(s/2**32|0)|0,l:s|0}}var ff=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),hf=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,df=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),pf=(r,t,e,n,s)=>t+e+n+s+(r/2**32|0)|0,gf=(r,t,e,n,s)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(s>>>0),mf=(r,t,e,n,s,i)=>t+e+n+s+i+(r/2**32|0)|0;var yf={fromBig:ua,split:Zl,toBig:Wl,shrSH:Jl,shrSL:Xl,rotrSH:Ql,rotrSL:tf,rotrBH:ef,rotrBL:rf,rotr32H:nf,rotr32L:sf,rotlSH:of,rotlSL:af,rotlBH:cf,rotlBL:uf,add:lf,add3L:ff,add3H:hf,add4L:df,add4H:pf,add5H:mf,add5L:gf},U=yf;var[bf,wf]=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))),xe=new Uint32Array(80),Ee=new Uint32Array(80),pi=class extends dr{constructor(){super(128,64,16,!1),this.Ah=1779033703,this.Al=-205731576,this.Bh=-1150833019,this.Bl=-2067093701,this.Ch=1013904242,this.Cl=-23791573,this.Dh=-1521486534,this.Dl=1595750129,this.Eh=1359893119,this.El=-1377402159,this.Fh=-1694144372,this.Fl=725511199,this.Gh=528734635,this.Gl=-79577749,this.Hh=1541459225,this.Hl=327033209}get(){let{Ah:t,Al:e,Bh:n,Bl:s,Ch:i,Cl:o,Dh:a,Dl:c,Eh:f,El:l,Fh:u,Fl:p,Gh:w,Gl:g,Hh:h,Hl:d}=this;return[t,e,n,s,i,o,a,c,f,l,u,p,w,g,h,d]}set(t,e,n,s,i,o,a,c,f,l,u,p,w,g,h,d){this.Ah=t|0,this.Al=e|0,this.Bh=n|0,this.Bl=s|0,this.Ch=i|0,this.Cl=o|0,this.Dh=a|0,this.Dl=c|0,this.Eh=f|0,this.El=l|0,this.Fh=u|0,this.Fl=p|0,this.Gh=w|0,this.Gl=g|0,this.Hh=h|0,this.Hl=d|0}process(t,e){for(let b=0;b<16;b++,e+=4)xe[b]=t.getUint32(e),Ee[b]=t.getUint32(e+=4);for(let b=16;b<80;b++){let T=xe[b-15]|0,E=Ee[b-15]|0,S=U.rotrSH(T,E,1)^U.rotrSH(T,E,8)^U.shrSH(T,E,7),R=U.rotrSL(T,E,1)^U.rotrSL(T,E,8)^U.shrSL(T,E,7),_=xe[b-2]|0,G=Ee[b-2]|0,K=U.rotrSH(_,G,19)^U.rotrBH(_,G,61)^U.shrSH(_,G,6),D=U.rotrSL(_,G,19)^U.rotrBL(_,G,61)^U.shrSL(_,G,6),nt=U.add4L(R,D,Ee[b-7],Ee[b-16]),rt=U.add4H(nt,S,K,xe[b-7],xe[b-16]);xe[b]=rt|0,Ee[b]=nt|0}let{Ah:n,Al:s,Bh:i,Bl:o,Ch:a,Cl:c,Dh:f,Dl:l,Eh:u,El:p,Fh:w,Fl:g,Gh:h,Gl:d,Hh:m,Hl:x}=this;for(let b=0;b<80;b++){let T=U.rotrSH(u,p,14)^U.rotrSH(u,p,18)^U.rotrBH(u,p,41),E=U.rotrSL(u,p,14)^U.rotrSL(u,p,18)^U.rotrBL(u,p,41),S=u&w^~u&h,R=p&g^~p&d,_=U.add5L(x,E,R,wf[b],Ee[b]),G=U.add5H(_,m,T,S,bf[b],xe[b]),K=_|0,D=U.rotrSH(n,s,28)^U.rotrBH(n,s,34)^U.rotrBH(n,s,39),nt=U.rotrSL(n,s,28)^U.rotrBL(n,s,34)^U.rotrBL(n,s,39),rt=n&i^n&a^i&a,Ct=s&o^s&c^o&c;m=h|0,x=d|0,h=w|0,d=g|0,w=u|0,g=p|0,{h:u,l:p}=U.add(f|0,l|0,G|0,K|0),f=a|0,l=c|0,a=i|0,c=o|0,i=n|0,o=s|0;let v=U.add3L(K,nt,Ct);n=U.add3H(v,G,D,rt),s=v|0}({h:n,l:s}=U.add(this.Ah|0,this.Al|0,n|0,s|0)),{h:i,l:o}=U.add(this.Bh|0,this.Bl|0,i|0,o|0),{h:a,l:c}=U.add(this.Ch|0,this.Cl|0,a|0,c|0),{h:f,l}=U.add(this.Dh|0,this.Dl|0,f|0,l|0),{h:u,l:p}=U.add(this.Eh|0,this.El|0,u|0,p|0),{h:w,l:g}=U.add(this.Fh|0,this.Fl|0,w|0,g|0),{h,l:d}=U.add(this.Gh|0,this.Gl|0,h|0,d|0),{h:m,l:x}=U.add(this.Hh|0,this.Hl|0,m|0,x|0),this.set(n,s,i,o,a,c,f,l,u,p,w,g,h,d,m,x)}roundClean(){xe.fill(0),Ee.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 Mr=gn(()=>new pi);var bn={};it(bn,{abytes:()=>pr,bitGet:()=>kf,bitLen:()=>Sf,bitMask:()=>Hr,bitSet:()=>If,bytesToHex:()=>se,bytesToNumberBE:()=>ie,bytesToNumberLE:()=>Be,concatBytes:()=>oe,createHmacDrbg:()=>yi,ensureBytes:()=>et,equalBytes:()=>Bf,hexToBytes:()=>De,hexToNumber:()=>mi,isBytes:()=>ve,numberToBytesBE:()=>Ae,numberToBytesLE:()=>Pe,numberToHexUnpadded:()=>da,numberToVarBytesBE:()=>vf,utf8ToBytes:()=>Af,validateObject:()=>Yt});var ha=BigInt(0),yn=BigInt(1),xf=BigInt(2);function ve(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function pr(r){if(!ve(r))throw new Error("Uint8Array expected")}var Ef=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function se(r){pr(r);let t="";for(let e=0;e<r.length;e++)t+=Ef[r[e]];return t}function da(r){let t=r.toString(16);return t.length&1?`0${t}`:t}function mi(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return BigInt(r===""?"0":`0x${r}`)}var ne={_0:48,_9:57,_A:65,_F:70,_a:97,_f:102};function la(r){if(r>=ne._0&&r<=ne._9)return r-ne._0;if(r>=ne._A&&r<=ne._F)return r-(ne._A-10);if(r>=ne._a&&r<=ne._f)return r-(ne._a-10)}function De(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);let t=r.length,e=t/2;if(t%2)throw new Error("padded hex string expected, got unpadded hex of length "+t);let n=new Uint8Array(e);for(let s=0,i=0;s<e;s++,i+=2){let o=la(r.charCodeAt(i)),a=la(r.charCodeAt(i+1));if(o===void 0||a===void 0){let c=r[i]+r[i+1];throw new Error('hex string expected, got non-hex character "'+c+'" at index '+i)}n[s]=o*16+a}return n}function ie(r){return mi(se(r))}function Be(r){return pr(r),mi(se(Uint8Array.from(r).reverse()))}function Ae(r,t){return De(r.toString(16).padStart(t*2,"0"))}function Pe(r,t){return Ae(r,t).reverse()}function vf(r){return De(da(r))}function et(r,t,e){let n;if(typeof t=="string")try{n=De(t)}catch(i){throw new Error(`${r} must be valid hex string, got "${t}". Cause: ${i}`)}else if(ve(t))n=Uint8Array.from(t);else throw new Error(`${r} must be hex string or Uint8Array`);let s=n.length;if(typeof e=="number"&&s!==e)throw new Error(`${r} expected ${e} bytes, got ${s}`);return n}function oe(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];pr(s),t+=s.length}let e=new Uint8Array(t);for(let n=0,s=0;n<r.length;n++){let i=r[n];e.set(i,s),s+=i.length}return e}function Bf(r,t){if(r.length!==t.length)return!1;let e=0;for(let n=0;n<r.length;n++)e|=r[n]^t[n];return e===0}function Af(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function Sf(r){let t;for(t=0;r>ha;r>>=yn,t+=1);return t}function kf(r,t){return r>>BigInt(t)&yn}function If(r,t,e){return r|(e?yn:ha)<<BigInt(t)}var Hr=r=>(xf<<BigInt(r-1))-yn,gi=r=>new Uint8Array(r),fa=r=>Uint8Array.from(r);function yi(r,t,e){if(typeof r!="number"||r<2)throw new Error("hashLen must be a number");if(typeof t!="number"||t<2)throw new Error("qByteLen must be a number");if(typeof e!="function")throw new Error("hmacFn must be a function");let n=gi(r),s=gi(r),i=0,o=()=>{n.fill(1),s.fill(0),i=0},a=(...u)=>e(s,n,...u),c=(u=gi())=>{s=a(fa([0]),u),n=a(),u.length!==0&&(s=a(fa([1]),u),n=a())},f=()=>{if(i++>=1e3)throw new Error("drbg: tried 1000 values");let u=0,p=[];for(;u<t;){n=a();let w=n.slice();p.push(w),u+=n.length}return oe(...p)};return(u,p)=>{o(),c(u);let w;for(;!(w=p(f()));)c();return o(),w}}var Nf={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"||ve(r),isSafeInteger:r=>Number.isSafeInteger(r),array:r=>Array.isArray(r),field:(r,t)=>t.Fp.isValid(r),hash:r=>typeof r=="function"&&Number.isSafeInteger(r.outputLen)};function Yt(r,t,e={}){let n=(s,i,o)=>{let a=Nf[i];if(typeof a!="function")throw new Error(`Invalid validator "${i}", expected function`);let c=r[s];if(!(o&&c===void 0)&&!a(c,r))throw new Error(`Invalid param ${String(s)}=${c} (${typeof c}), expected ${i}`)};for(let[s,i]of Object.entries(t))n(s,i,!1);for(let[s,i]of Object.entries(e))n(s,i,!0);return r}var ut=BigInt(0),J=BigInt(1),Oe=BigInt(2),Rf=BigInt(3),bi=BigInt(4),pa=BigInt(5),ga=BigInt(8),_f=BigInt(9),Tf=BigInt(16);function j(r,t){let e=r%t;return e>=ut?e:t+e}function Cf(r,t,e){if(e<=ut||t<ut)throw new Error("Expected power/modulo > 0");if(e===J)return ut;let n=J;for(;t>ut;)t&J&&(n=n*r%e),r=r*r%e,t>>=J;return n}function X(r,t,e){let n=r;for(;t-- >ut;)n*=n,n%=e;return n}function wn(r,t){if(r===ut||t<=ut)throw new Error(`invert: expected positive integers, got n=${r} mod=${t}`);let e=j(r,t),n=t,s=ut,i=J,o=J,a=ut;for(;e!==ut;){let f=n/e,l=n%e,u=s-o*f,p=i-a*f;n=e,e=l,s=o,i=a,o=u,a=p}if(n!==J)throw new Error("invert: does not exist");return j(s,t)}function Lf(r){let t=(r-J)/Oe,e,n,s;for(e=r-J,n=0;e%Oe===ut;e/=Oe,n++);for(s=Oe;s<r&&Cf(s,t,r)!==r-J;s++);if(n===1){let o=(r+J)/bi;return function(c,f){let l=c.pow(f,o);if(!c.eql(c.sqr(l),f))throw new Error("Cannot find square root");return l}}let i=(e+J)/Oe;return function(a,c){if(a.pow(c,t)===a.neg(a.ONE))throw new Error("Cannot find square root");let f=n,l=a.pow(a.mul(a.ONE,s),e),u=a.pow(c,i),p=a.pow(c,e);for(;!a.eql(p,a.ONE);){if(a.eql(p,a.ZERO))return a.ZERO;let w=1;for(let h=a.sqr(p);w<f&&!a.eql(h,a.ONE);w++)h=a.sqr(h);let g=a.pow(l,J<<BigInt(f-w-1));l=a.sqr(g),u=a.mul(u,g),p=a.mul(p,l),f=w}return u}}function Uf(r){if(r%bi===Rf){let t=(r+J)/bi;return function(n,s){let i=n.pow(s,t);if(!n.eql(n.sqr(i),s))throw new Error("Cannot find square root");return i}}if(r%ga===pa){let t=(r-pa)/ga;return function(n,s){let i=n.mul(s,Oe),o=n.pow(i,t),a=n.mul(s,o),c=n.mul(n.mul(a,Oe),o),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%Tf,Lf(r)}var ma=(r,t)=>(j(r,t)&J)===J,Df=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function wi(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=Df.reduce((n,s)=>(n[s]="function",n),t);return Yt(r,e)}function Pf(r,t,e){if(e<ut)throw new Error("Expected power > 0");if(e===ut)return r.ONE;if(e===J)return t;let n=r.ONE,s=t;for(;e>ut;)e&J&&(n=r.mul(n,s)),s=r.sqr(s),e>>=J;return n}function Of(r,t){let e=new Array(t.length),n=t.reduce((i,o,a)=>r.is0(o)?i:(e[a]=i,r.mul(i,o)),r.ONE),s=r.inv(n);return t.reduceRight((i,o,a)=>r.is0(o)?i:(e[a]=r.mul(i,e[a]),r.mul(i,o)),s),e}function xi(r,t){let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function xn(r,t,e=!1,n={}){if(r<=ut)throw new Error(`Expected Field ORDER > 0, got ${r}`);let{nBitLength:s,nByteLength:i}=xi(r,t);if(i>2048)throw new Error("Field lengths over 2048 bytes are not supported");let o=Uf(r),a=Object.freeze({ORDER:r,BITS:s,BYTES:i,MASK:Hr(s),ZERO:ut,ONE:J,create:c=>j(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error(`Invalid field element: expected bigint, got ${typeof c}`);return ut<=c&&c<r},is0:c=>c===ut,isOdd:c=>(c&J)===J,neg:c=>j(-c,r),eql:(c,f)=>c===f,sqr:c=>j(c*c,r),add:(c,f)=>j(c+f,r),sub:(c,f)=>j(c-f,r),mul:(c,f)=>j(c*f,r),pow:(c,f)=>Pf(a,c,f),div:(c,f)=>j(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=>o(a,c)),invertBatch:c=>Of(a,c),cmov:(c,f,l)=>l?f:c,toBytes:c=>e?Pe(c,i):Ae(c,i),fromBytes:c=>{if(c.length!==i)throw new Error(`Fp.fromBytes: expected ${i}, got ${c.length}`);return e?Be(c):ie(c)}});return Object.freeze(a)}function ya(r){if(typeof r!="bigint")throw new Error("field order must be bigint");let t=r.toString(2).length;return Math.ceil(t/8)}function Ei(r){let t=ya(r);return t+Math.ceil(t/2)}function ba(r,t,e=!1){let n=r.length,s=ya(t),i=Ei(t);if(n<16||n<i||n>1024)throw new Error(`expected ${i}-1024 bytes of input, got ${n}`);let o=e?ie(r):Be(r),a=j(o,t-J)+J;return e?Pe(a,s):Ae(a,s)}var Mf=BigInt(0),vi=BigInt(1);function En(r,t){let e=(s,i)=>{let o=i.negate();return s?o:i},n=s=>{let i=Math.ceil(t/s)+1,o=2**(s-1);return{windows:i,windowSize:o}};return{constTimeNegate:e,unsafeLadder(s,i){let o=r.ZERO,a=s;for(;i>Mf;)i&vi&&(o=o.add(a)),a=a.double(),i>>=vi;return o},precomputeWindow(s,i){let{windows:o,windowSize:a}=n(i),c=[],f=s,l=f;for(let u=0;u<o;u++){l=f,c.push(l);for(let p=1;p<a;p++)l=l.add(f),c.push(l);f=l.double()}return c},wNAF(s,i,o){let{windows:a,windowSize:c}=n(s),f=r.ZERO,l=r.BASE,u=BigInt(2**s-1),p=2**s,w=BigInt(s);for(let g=0;g<a;g++){let h=g*c,d=Number(o&u);o>>=w,d>c&&(d-=p,o+=vi);let m=h,x=h+Math.abs(d)-1,b=g%2!==0,T=d<0;d===0?l=l.add(e(b,i[m])):f=f.add(e(T,i[x]))}return{p:f,f:l}},wNAFCached(s,i,o,a){let c=s._WINDOW_SIZE||1,f=i.get(s);return f||(f=this.precomputeWindow(s,c),c!==1&&i.set(s,a(f))),this.wNAF(c,f,o)}}}function Kr(r){return wi(r.Fp),Yt(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...xi(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Ot=BigInt(0),_t=BigInt(1),vn=BigInt(2),Hf=BigInt(8),Kf={zip215:!0};function Ff(r){let t=Kr(r);return Yt(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function wa(r){let t=Ff(r),{Fp:e,n,prehash:s,hash:i,randomBytes:o,nByteLength:a,h:c}=t,f=vn<<BigInt(a*8)-_t,l=e.create,u=t.uvRatio||((B,y)=>{try{return{isValid:!0,value:e.sqrt(B*e.inv(y))}}catch{return{isValid:!1,value:Ot}}}),p=t.adjustScalarBytes||(B=>B),w=t.domain||((B,y,I)=>{if(y.length||I)throw new Error("Contexts/pre-hash are not supported");return B}),g=B=>typeof B=="bigint"&&Ot<B,h=(B,y)=>g(B)&&g(y)&&B<y,d=B=>B===Ot||h(B,f);function m(B,y){if(h(B,y))return B;throw new Error(`Expected valid scalar < ${y}, got ${typeof B} ${B}`)}function x(B){return B===Ot?B:m(B,n)}let b=new Map;function T(B){if(!(B instanceof E))throw new Error("ExtendedPoint expected")}class E{constructor(y,I,C,L){if(this.ex=y,this.ey=I,this.ez=C,this.et=L,!d(y))throw new Error("x required");if(!d(I))throw new Error("y required");if(!d(C))throw new Error("z required");if(!d(L))throw new Error("t required")}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(y){if(y instanceof E)throw new Error("extended point not allowed");let{x:I,y:C}=y||{};if(!d(I)||!d(C))throw new Error("invalid affine point");return new E(I,C,_t,l(I*C))}static normalizeZ(y){let I=e.invertBatch(y.map(C=>C.ez));return y.map((C,L)=>C.toAffine(I[L])).map(E.fromAffine)}_setWindowSize(y){this._WINDOW_SIZE=y,b.delete(this)}assertValidity(){let{a:y,d:I}=t;if(this.is0())throw new Error("bad point: ZERO");let{ex:C,ey:L,ez:O,et:V}=this,q=l(C*C),H=l(L*L),F=l(O*O),st=l(F*F),Q=l(q*y),ht=l(F*l(Q+H)),dt=l(st+l(I*l(q*H)));if(ht!==dt)throw new Error("bad point: equation left != right (1)");let at=l(C*L),gt=l(O*V);if(at!==gt)throw new Error("bad point: equation left != right (2)")}equals(y){T(y);let{ex:I,ey:C,ez:L}=this,{ex:O,ey:V,ez:q}=y,H=l(I*q),F=l(O*L),st=l(C*q),Q=l(V*L);return H===F&&st===Q}is0(){return this.equals(E.ZERO)}negate(){return new E(l(-this.ex),this.ey,this.ez,l(-this.et))}double(){let{a:y}=t,{ex:I,ey:C,ez:L}=this,O=l(I*I),V=l(C*C),q=l(vn*l(L*L)),H=l(y*O),F=I+C,st=l(l(F*F)-O-V),Q=H+V,ht=Q-q,dt=H-V,at=l(st*ht),gt=l(Q*dt),Xt=l(st*dt),Ue=l(ht*Q);return new E(at,gt,Ue,Xt)}add(y){T(y);let{a:I,d:C}=t,{ex:L,ey:O,ez:V,et:q}=this,{ex:H,ey:F,ez:st,et:Q}=y;if(I===BigInt(-1)){let vo=l((O-L)*(F+H)),Bo=l((O+L)*(F-H)),Ds=l(Bo-vo);if(Ds===Ot)return this.double();let Ao=l(V*vn*Q),So=l(q*vn*st),ko=So+Ao,Io=Bo+vo,No=So-Ao,ku=l(ko*Ds),Iu=l(Io*No),Nu=l(ko*No),Ru=l(Ds*Io);return new E(ku,Iu,Ru,Nu)}let ht=l(L*H),dt=l(O*F),at=l(q*C*Q),gt=l(V*st),Xt=l((L+O)*(H+F)-ht-dt),Ue=gt-at,Nr=gt+at,Eo=l(dt-I*ht),vu=l(Xt*Ue),Bu=l(Nr*Eo),Au=l(Xt*Eo),Su=l(Ue*Nr);return new E(vu,Bu,Su,Au)}subtract(y){return this.add(y.negate())}wNAF(y){return _.wNAFCached(this,b,y,E.normalizeZ)}multiply(y){let{p:I,f:C}=this.wNAF(m(y,n));return E.normalizeZ([I,C])[0]}multiplyUnsafe(y){let I=x(y);return I===Ot?R:this.equals(R)||I===_t?this:this.equals(S)?this.wNAF(I).p:_.unsafeLadder(this,I)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return _.unsafeLadder(this,n).is0()}toAffine(y){let{ex:I,ey:C,ez:L}=this,O=this.is0();y==null&&(y=O?Hf:e.inv(L));let V=l(I*y),q=l(C*y),H=l(L*y);if(O)return{x:Ot,y:_t};if(H!==_t)throw new Error("invZ was invalid");return{x:V,y:q}}clearCofactor(){let{h:y}=t;return y===_t?this:this.multiplyUnsafe(y)}static fromHex(y,I=!1){let{d:C,a:L}=t,O=e.BYTES;y=et("pointHex",y,O);let V=y.slice(),q=y[O-1];V[O-1]=q&-129;let H=Be(V);H===Ot||(I?m(H,f):m(H,e.ORDER));let F=l(H*H),st=l(F-_t),Q=l(C*F-L),{isValid:ht,value:dt}=u(st,Q);if(!ht)throw new Error("Point.fromHex: invalid y coordinate");let at=(dt&_t)===_t,gt=(q&128)!==0;if(!I&&dt===Ot&>)throw new Error("Point.fromHex: x=0 and x_0=1");return gt!==at&&(dt=l(-dt)),E.fromAffine({x:dt,y:H})}static fromPrivateKey(y){return D(y).point}toRawBytes(){let{x:y,y:I}=this.toAffine(),C=Pe(I,e.BYTES);return C[C.length-1]|=y&_t?128:0,C}toHex(){return se(this.toRawBytes())}}E.BASE=new E(t.Gx,t.Gy,_t,l(t.Gx*t.Gy)),E.ZERO=new E(Ot,_t,_t,Ot);let{BASE:S,ZERO:R}=E,_=En(E,a*8);function G(B){return j(B,n)}function K(B){return G(Be(B))}function D(B){let y=a;B=et("private key",B,y);let I=et("hashed private key",i(B),2*y),C=p(I.slice(0,y)),L=I.slice(y,2*y),O=K(C),V=S.multiply(O),q=V.toRawBytes();return{head:C,prefix:L,scalar:O,point:V,pointBytes:q}}function nt(B){return D(B).pointBytes}function rt(B=new Uint8Array,...y){let I=oe(...y);return K(i(w(I,et("context",B),!!s)))}function Ct(B,y,I={}){B=et("message",B),s&&(B=s(B));let{prefix:C,scalar:L,pointBytes:O}=D(y),V=rt(I.context,C,B),q=S.multiply(V).toRawBytes(),H=rt(I.context,q,O,B),F=G(V+H*L);x(F);let st=oe(q,Pe(F,e.BYTES));return et("result",st,a*2)}let v=Kf;function N(B,y,I,C=v){let{context:L,zip215:O}=C,V=e.BYTES;B=et("signature",B,2*V),y=et("message",y),s&&(y=s(y));let q=Be(B.slice(V,2*V)),H,F,st;try{H=E.fromHex(I,O),F=E.fromHex(B.slice(0,V),O),st=S.multiplyUnsafe(q)}catch{return!1}if(!O&&H.isSmallOrder())return!1;let Q=rt(L,F.toRawBytes(),H.toRawBytes(),y);return F.add(H.multiplyUnsafe(Q)).subtract(st).clearCofactor().equals(E.ZERO)}return S._setWindowSize(8),{CURVE:t,getPublicKey:nt,sign:Ct,verify:N,ExtendedPoint:E,utils:{getExtendedPublicKey:D,randomPrivateKey:()=>o(e.BYTES),precompute(B=8,y=E.BASE){return y._setWindowSize(B),y.multiply(BigInt(3)),y}}}}var Bi=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),xa=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),tg=BigInt(0),qf=BigInt(1),Ea=BigInt(2),eg=BigInt(3),$f=BigInt(5),Gf=BigInt(8);function zf(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),s=BigInt(80),i=Bi,a=r*r%i*r%i,c=X(a,Ea,i)*a%i,f=X(c,qf,i)*r%i,l=X(f,$f,i)*f%i,u=X(l,t,i)*l%i,p=X(u,e,i)*u%i,w=X(p,n,i)*p%i,g=X(w,s,i)*w%i,h=X(g,s,i)*w%i,d=X(h,t,i)*l%i;return{pow_p_5_8:X(d,Ea,i)*r%i,b2:a}}function Yf(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function jf(r,t){let e=Bi,n=j(t*t*t,e),s=j(n*n*t,e),i=zf(r*s).pow_p_5_8,o=j(r*n*i,e),a=j(t*o*o,e),c=o,f=j(o*xa,e),l=a===r,u=a===j(-r,e),p=a===j(-r*xa,e);return l&&(o=c),(u||p)&&(o=f),ma(o,e)&&(o=j(-o,e)),{isValid:l||u,value:o}}var Zf=xn(Bi,void 0,!0),Wf={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:Zf,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:Gf,Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:Mr,randomBytes:hr,adjustScalarBytes:Yf,uvRatio:jf},gr=wa(Wf);var mr=32,ae=64,Bn=32;function va(){let r=gr.utils.randomPrivateKey(),t=gr.getPublicKey(r);return{privateKey:ka(r,t),publicKey:t}}function Ba(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 t=r,e=gr.getPublicKey(t);return{privateKey:ka(t,e),publicKey:e}}function Aa(r,t){let e=r.subarray(0,Bn);return gr.sign(t instanceof Uint8Array?t:t.subarray(),e)}function Sa(r,t,e){return gr.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}function ka(r,t){let e=new Uint8Array(ae);for(let n=0;n<Bn;n++)e[n]=r[n],e[Bn+n]=t[n];return e}var Ai={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function An(r){let t=r?.algorithm??"AES-GCM",e=r?.keyLength??16,n=r?.nonceLength??12,s=r?.digest??"SHA-256",i=r?.saltLength??16,o=r?.iterations??32767,a=W.get();e*=8;async function c(u,p){let w=a.getRandomValues(new Uint8Array(i)),g=a.getRandomValues(new Uint8Array(n)),h={name:t,iv:g};typeof p=="string"&&(p=$(p));let d;if(p.length===0){d=await a.subtle.importKey("jwk",Ai,{name:"AES-GCM"},!0,["encrypt"]);try{let x={name:"PBKDF2",salt:w,iterations:o,hash:{name:s}},b=await a.subtle.importKey("raw",p,{name:"PBKDF2"},!1,["deriveKey"]);d=await a.subtle.deriveKey(x,b,{name:t,length:e},!0,["encrypt"])}catch{d=await a.subtle.importKey("jwk",Ai,{name:"AES-GCM"},!0,["encrypt"])}}else{let x={name:"PBKDF2",salt:w,iterations:o,hash:{name:s}},b=await a.subtle.importKey("raw",p,{name:"PBKDF2"},!1,["deriveKey"]);d=await a.subtle.deriveKey(x,b,{name:t,length:e},!0,["encrypt"])}let m=await a.subtle.encrypt(h,d,u);return Bt([w,h.iv,new Uint8Array(m)])}async function f(u,p){let w=u.subarray(0,i),g=u.subarray(i,i+n),h=u.subarray(i+n),d={name:t,iv:g};typeof p=="string"&&(p=$(p));let m;if(p.length===0)try{let b={name:"PBKDF2",salt:w,iterations:o,hash:{name:s}},T=await a.subtle.importKey("raw",p,{name:"PBKDF2"},!1,["deriveKey"]);m=await a.subtle.deriveKey(b,T,{name:t,length:e},!0,["decrypt"])}catch{m=await a.subtle.importKey("jwk",Ai,{name:"AES-GCM"},!0,["decrypt"])}else{let b={name:"PBKDF2",salt:w,iterations:o,hash:{name:s}},T=await a.subtle.importKey("raw",p,{name:"PBKDF2"},!1,["deriveKey"]);m=await a.subtle.deriveKey(b,T,{name:t,length:e},!0,["decrypt"])}let x=await a.subtle.decrypt(d,m,h);return new Uint8Array(x)}return{encrypt:c,decrypt:f}}async function yr(r,t){let n=await An().encrypt(r,t);return _r.encode(n)}var wr={};it(wr,{KeyType:()=>Z,PrivateKey:()=>Kt,PublicKey:()=>Ht});var Xf=Math.pow(2,7),Qf=Math.pow(2,14),th=Math.pow(2,21),Si=Math.pow(2,28),ki=Math.pow(2,35),Ii=Math.pow(2,42),Ni=Math.pow(2,49),z=128,bt=127;function Vt(r){if(r<Xf)return 1;if(r<Qf)return 2;if(r<th)return 3;if(r<Si)return 4;if(r<ki)return 5;if(r<Ii)return 6;if(r<Ni)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function Ri(r,t,e=0){switch(Vt(r)){case 8:t[e++]=r&255|z,r/=128;case 7:t[e++]=r&255|z,r/=128;case 6:t[e++]=r&255|z,r/=128;case 5:t[e++]=r&255|z,r/=128;case 4:t[e++]=r&255|z,r>>>=7;case 3:t[e++]=r&255|z,r>>>=7;case 2:t[e++]=r&255|z,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function eh(r,t,e=0){switch(Vt(r)){case 8:t.set(e++,r&255|z),r/=128;case 7:t.set(e++,r&255|z),r/=128;case 6:t.set(e++,r&255|z),r/=128;case 5:t.set(e++,r&255|z),r/=128;case 4:t.set(e++,r&255|z),r>>>=7;case 3:t.set(e++,r&255|z),r>>>=7;case 2:t.set(e++,r&255|z),r>>>=7;case 1:{t.set(e++,r&255),r>>>=7;break}default:throw new Error("unreachable")}return t}function _i(r,t){let e=r[t],n=0;if(n+=e&bt,e<z||(e=r[t+1],n+=(e&bt)<<7,e<z)||(e=r[t+2],n+=(e&bt)<<14,e<z)||(e=r[t+3],n+=(e&bt)<<21,e<z)||(e=r[t+4],n+=(e&bt)*Si,e<z)||(e=r[t+5],n+=(e&bt)*ki,e<z)||(e=r[t+6],n+=(e&bt)*Ii,e<z)||(e=r[t+7],n+=(e&bt)*Ni,e<z))return n;throw new RangeError("Could not decode varint")}function rh(r,t){let e=r.get(t),n=0;if(n+=e&bt,e<z||(e=r.get(t+1),n+=(e&bt)<<7,e<z)||(e=r.get(t+2),n+=(e&bt)<<14,e<z)||(e=r.get(t+3),n+=(e&bt)<<21,e<z)||(e=r.get(t+4),n+=(e&bt)*Si,e<z)||(e=r.get(t+5),n+=(e&bt)*ki,e<z)||(e=r.get(t+6),n+=(e&bt)*Ii,e<z)||(e=r.get(t+7),n+=(e&bt)*Ni,e<z))return n;throw new RangeError("Could not decode varint")}function Na(r,t,e=0){return t==null&&(t=yt(Vt(r))),t instanceof Uint8Array?Ri(r,t,e):eh(r,t,e)}function Ra(r,t=0){return r instanceof Uint8Array?_i(r,t):rh(r,t)}var Ti=new Float32Array([-0]),Se=new Uint8Array(Ti.buffer);function Ta(r,t,e){Ti[0]=r,t[e]=Se[0],t[e+1]=Se[1],t[e+2]=Se[2],t[e+3]=Se[3]}function Ca(r,t){return Se[0]=r[t],Se[1]=r[t+1],Se[2]=r[t+2],Se[3]=r[t+3],Ti[0]}var Ci=new Float64Array([-0]),wt=new Uint8Array(Ci.buffer);function La(r,t,e){Ci[0]=r,t[e]=wt[0],t[e+1]=wt[1],t[e+2]=wt[2],t[e+3]=wt[3],t[e+4]=wt[4],t[e+5]=wt[5],t[e+6]=wt[6],t[e+7]=wt[7]}function Ua(r,t){return wt[0]=r[t],wt[1]=r[t+1],wt[2]=r[t+2],wt[3]=r[t+3],wt[4]=r[t+4],wt[5]=r[t+5],wt[6]=r[t+6],wt[7]=r[t+7],Ci[0]}var nh=BigInt(Number.MAX_SAFE_INTEGER),sh=BigInt(Number.MIN_SAFE_INTEGER),Tt=class r{lo;hi;constructor(t,e){this.lo=t|0,this.hi=e|0}toNumber(t=!1){if(!t&&this.hi>>>31>0){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(e+n*4294967296)}return this.lo+this.hi*4294967296}toBigInt(t=!1){if(t)return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n);if(this.hi>>>31){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(BigInt(e)+(BigInt(n)<<32n))}return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n)}toString(t=!1){return this.toBigInt(t).toString()}zzEncode(){let t=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^t)>>>0,this.lo=(this.lo<<1^t)>>>0,this}zzDecode(){let t=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^t)>>>0,this.hi=(this.hi>>>1^t)>>>0,this}length(){let t=this.lo,e=(this.lo>>>28|this.hi<<4)>>>0,n=this.hi>>>24;return n===0?e===0?t<16384?t<128?1:2:t<2097152?3:4:e<16384?e<128?5:6:e<2097152?7:8:n<128?9:10}static fromBigInt(t){if(t===0n)return Ve;if(t<nh&&t>sh)return this.fromNumber(Number(t));let e=t<0n;e&&(t=-t);let n=t>>32n,s=t-(n<<32n);return e&&(n=~n|0n,s=~s|0n,++s>Da&&(s=0n,++n>Da&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(t){if(t===0)return Ve;let e=t<0;e&&(t=-t);let n=t>>>0,s=(t-n)/4294967296>>>0;return e&&(s=~s>>>0,n=~n>>>0,++n>4294967295&&(n=0,++s>4294967295&&(s=0))),new r(n,s)}static from(t){return typeof t=="number"?r.fromNumber(t):typeof t=="bigint"?r.fromBigInt(t):typeof t=="string"?r.fromBigInt(BigInt(t)):t.low!=null||t.high!=null?new r(t.low>>>0,t.high>>>0):Ve}},Ve=new Tt(0,0);Ve.toBigInt=function(){return 0n};Ve.zzEncode=Ve.zzDecode=function(){return this};Ve.length=function(){return 1};var Da=4294967296n;function Pa(r){let t=0,e=0;for(let n=0;n<r.length;++n)e=r.charCodeAt(n),e<128?t+=1:e<2048?t+=2:(e&64512)===55296&&(r.charCodeAt(n+1)&64512)===56320?(++n,t+=4):t+=3;return t}function Oa(r,t,e){if(e-t<1)return"";let s,i=[],o=0,a;for(;t<e;)a=r[t++],a<128?i[o++]=a:a>191&&a<224?i[o++]=(a&31)<<6|r[t++]&63:a>239&&a<365?(a=((a&7)<<18|(r[t++]&63)<<12|(r[t++]&63)<<6|r[t++]&63)-65536,i[o++]=55296+(a>>10),i[o++]=56320+(a&1023)):i[o++]=(a&15)<<12|(r[t++]&63)<<6|r[t++]&63,o>8191&&((s??(s=[])).push(String.fromCharCode.apply(String,i)),o=0);return s!=null?(o>0&&s.push(String.fromCharCode.apply(String,i.slice(0,o))),s.join("")):String.fromCharCode.apply(String,i.slice(0,o))}function Li(r,t,e){let n=e,s,i;for(let o=0;o<r.length;++o)s=r.charCodeAt(o),s<128?t[e++]=s:s<2048?(t[e++]=s>>6|192,t[e++]=s&63|128):(s&64512)===55296&&((i=r.charCodeAt(o+1))&64512)===56320?(s=65536+((s&1023)<<10)+(i&1023),++o,t[e++]=s>>18|240,t[e++]=s>>12&63|128,t[e++]=s>>6&63|128,t[e++]=s&63|128):(t[e++]=s>>12|224,t[e++]=s>>6&63|128,t[e++]=s&63|128);return e-n}function Mt(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function Sn(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var Ui=class{buf;pos;len;_slice=Uint8Array.prototype.subarray;constructor(t){this.buf=t,this.pos=0,this.len=t.length}uint32(){let t=4294967295;if(t=(this.buf[this.pos]&127)>>>0,this.buf[this.pos++]<128||(t=(t|(this.buf[this.pos]&127)<<7)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<14)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<21)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&15)<<28)>>>0,this.buf[this.pos++]<128))return t;if((this.pos+=5)>this.len)throw this.pos=this.len,Mt(this,10);return t}int32(){return this.uint32()|0}sint32(){let t=this.uint32();return t>>>1^-(t&1)|0}bool(){return this.uint32()!==0}fixed32(){if(this.pos+4>this.len)throw Mt(this,4);return Sn(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Mt(this,4);return Sn(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Mt(this,4);let t=Ca(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Mt(this,4);let t=Ua(this.buf,this.pos);return this.pos+=8,t}bytes(){let t=this.uint32(),e=this.pos,n=this.pos+t;if(n>this.len)throw Mt(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return Oa(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw Mt(this,t);this.pos+=t}else do if(this.pos>=this.len)throw Mt(this);while(this.buf[this.pos++]&128);return this}skipType(t){switch(t){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;(t=this.uint32()&7)!==4;)this.skipType(t);break;case 5:this.skip(4);break;default:throw Error(`invalid wire type ${t} at offset ${this.pos}`)}return this}readLongVarint(){let t=new Tt(0,0),e=0;if(this.len-this.pos>4){for(;e<4;++e)if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t;if(t.lo=(t.lo|(this.buf[this.pos]&127)<<28)>>>0,t.hi=(t.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return t;e=0}else{for(;e<3;++e){if(this.pos>=this.len)throw Mt(this);if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t}return t.lo=(t.lo|(this.buf[this.pos++]&127)<<e*7)>>>0,t}if(this.len-this.pos>4){for(;e<5;++e)if(t.hi=(t.hi|(this.buf[this.pos]&127)<<e*7+3)>>>0,this.buf[this.pos++]<128)return t}else for(;e<5;++e){if(this.pos>=this.len)throw Mt(this);if(t.hi=(t.hi|(this.buf[this.pos]&127)<<e*7+3)>>>0,this.buf[this.pos++]<128)return t}throw Error("invalid varint encoding")}readFixed64(){if(this.pos+8>this.len)throw Mt(this,8);let t=Sn(this.buf,this.pos+=4),e=Sn(this.buf,this.pos+=4);return new Tt(t,e)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){let t=_i(this.buf,this.pos);return this.pos+=Vt(t),t}uint64String(){return this.readLongVarint().toString(!0)}sint64(){return this.readLongVarint().zzDecode().toBigInt()}sint64Number(){return this.readLongVarint().zzDecode().toNumber()}sint64String(){return this.readLongVarint().zzDecode().toString()}fixed64(){return this.readFixed64().toBigInt()}fixed64Number(){return this.readFixed64().toNumber()}fixed64String(){return this.readFixed64().toString()}sfixed64(){return this.readFixed64().toBigInt()}sfixed64Number(){return this.readFixed64().toNumber()}sfixed64String(){return this.readFixed64().toString()}};function Di(r){return new Ui(r instanceof Uint8Array?r:r.subarray())}function kt(r,t,e){let n=Di(r);return t.decode(n,void 0,e)}function Pi(r){let t=r??8192,e=t>>>1,n,s=t;return function(o){if(o<1||o>e)return yt(o);s+o>t&&(n=yt(t),s=0);let a=n.subarray(s,s+=o);return s&7&&(s=(s|7)+1),a}}var Me=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function Oi(){}var Mi=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},ih=Pi();function oh(r){return globalThis.Buffer!=null?yt(r):ih(r)}var qr=class{len;head;tail;states;constructor(){this.len=0,this.head=new Me(Oi,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new Me(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new Hi((t=t>>>0)<128?1:t<16384?2:t<2097152?3:t<268435456?4:5,t)).len,this}int32(t){return t<0?this._push(kn,10,Tt.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=Tt.fromBigInt(t);return this._push(kn,e.length(),e)}uint64Number(t){return this._push(Ri,Vt(t),t)}uint64String(t){return this.uint64(BigInt(t))}int64(t){return this.uint64(t)}int64Number(t){return this.uint64Number(t)}int64String(t){return this.uint64String(t)}sint64(t){let e=Tt.fromBigInt(t).zzEncode();return this._push(kn,e.length(),e)}sint64Number(t){let e=Tt.fromNumber(t).zzEncode();return this._push(kn,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(Vi,1,t?1:0)}fixed32(t){return this._push(Fr,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=Tt.fromBigInt(t);return this._push(Fr,4,e.lo)._push(Fr,4,e.hi)}fixed64Number(t){let e=Tt.fromNumber(t);return this._push(Fr,4,e.lo)._push(Fr,4,e.hi)}fixed64String(t){return this.fixed64(BigInt(t))}sfixed64(t){return this.fixed64(t)}sfixed64Number(t){return this.fixed64Number(t)}sfixed64String(t){return this.fixed64String(t)}float(t){return this._push(Ta,4,t)}double(t){return this._push(La,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(Vi,1,0):this.uint32(e)._push(ch,e,t)}string(t){let e=Pa(t);return e!==0?this.uint32(e)._push(Li,e,t):this._push(Vi,1,0)}fork(){return this.states=new Mi(this),this.head=this.tail=new Me(Oi,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 Me(Oi,0,0),this.len=0),this}ldelim(){let t=this.head,e=this.tail,n=this.len;return this.reset().uint32(n),n!==0&&(this.tail.next=t.next,this.tail=e,this.len+=n),this}finish(){let t=this.head.next,e=oh(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function Vi(r,t,e){t[e]=r&255}function ah(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var Hi=class extends Me{next;constructor(t,e){super(ah,t,e),this.next=void 0}};function kn(r,t,e){for(;r.hi!==0;)t[e++]=r.lo&127|128,r.lo=(r.lo>>>7|r.hi<<25)>>>0,r.hi>>>=7;for(;r.lo>127;)t[e++]=r.lo&127|128,r.lo=r.lo>>>7;t[e++]=r.lo}function Fr(r,t,e){t[e]=r&255,t[e+1]=r>>>8&255,t[e+2]=r>>>16&255,t[e+3]=r>>>24}function ch(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(qr.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(uh,t,r),this},qr.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(lh,t,r),this});function uh(r,t,e){t.set(r,e)}function lh(r,t,e){r.length<40?Li(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set($(r),e)}function Ki(){return new qr}function It(r,t){let e=Ki();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var br;(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"})(br||(br={}));function In(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function Fi(r){function t(s){if(r[s.toString()]==null)throw new Error("Invalid enum value");return r[s]}let e=function(i,o){let a=t(i);o.int32(a)},n=function(i){let o=i.int32();return t(o)};return In("enum",br.VARINT,e,n)}function Nt(r,t){return In("message",br.LENGTH_DELIMITED,r,t)}var Z;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.Secp256k1="Secp256k1"})(Z||(Z={}));var qi;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.Secp256k1=2]="Secp256k1"})(qi||(qi={}));(function(r){r.codec=()=>Fi(qi)})(Z||(Z={}));var Ht;(function(r){let t;r.codec=()=>(t==null&&(t=Nt((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),Z.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let s={},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let o=e.uint32();switch(o>>>3){case 1:s.Type=Z.codec().decode(e);break;case 2:s.Data=e.bytes();break;default:e.skipType(o&7);break}}return s})),t),r.encode=e=>It(e,r.codec()),r.decode=e=>kt(e,r.codec())})(Ht||(Ht={}));var Kt;(function(r){let t;r.codec=()=>(t==null&&(t=Nt((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),Z.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let s={},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let o=e.uint32();switch(o>>>3){case 1:s.Type=Z.codec().decode(e);break;case 2:s.Data=e.bytes();break;default:e.skipType(o&7);break}}return s})),t),r.encode=e=>It(e,r.codec()),r.decode=e=>kt(e,r.codec())})(Kt||(Kt={}));var He=class{_key;constructor(t){this._key=xr(t,mr)}verify(t,e){return Sa(this._key,e,t)}marshal(){return this._key}get bytes(){return Ht.encode({Type:Z.Ed25519,Data:this.marshal()}).subarray()}equals(t){return mt(this.bytes,t.bytes)}hash(){let t=ct.digest(this.bytes);return Lt(t)?t.then(({bytes:e})=>e):t.bytes}},ce=class{_key;_publicKey;constructor(t,e){this._key=xr(t,ae),this._publicKey=xr(e,mr)}sign(t){return Aa(this._key,t)}get public(){return new He(this._publicKey)}marshal(){return this._key}get bytes(){return Kt.encode({Type:Z.Ed25519,Data:this.marshal()}).subarray()}equals(t){return mt(this.bytes,t.bytes)}async hash(){let t=ct.digest(this.bytes),e;return Lt(t)?{bytes:e}=await t:e=t.bytes,e}async id(){let t=te.digest(this.public.bytes);return vt.encode(t.bytes).substring(1)}async export(t,e="libp2p-key"){if(e==="libp2p-key")return yr(this.bytes,t);throw new A(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function fh(r){if(r.length>ae){r=xr(r,ae+mr);let n=r.subarray(0,ae),s=r.subarray(ae,r.length);return new ce(n,s)}r=xr(r,ae);let t=r.subarray(0,ae),e=r.subarray(mr);return new ce(t,e)}function hh(r){return r=xr(r,mr),new He(r)}async function dh(){let{privateKey:r,publicKey:t}=va();return new ce(r,t)}async function $i(r){let{privateKey:t,publicKey:e}=Ba(r);return new ce(t,e)}function xr(r,t){if(r=Uint8Array.from(r??[]),r.length!==t)throw new A(`Key must be a Uint8Array of length ${t}, got ${r.length}`,"ERR_INVALID_KEY_TYPE");return r}var Ma={"P-256":256,"P-384":384,"P-521":521},ph=Object.keys(Ma),zi=ph.join(" / ");async function Ha(r){if(r!=="P-256"&&r!=="P-384"&&r!=="P-521")throw new A(`Unknown curve: ${r}. Must be ${zi}`,"ERR_INVALID_CURVE");let t=await W.get().subtle.generateKey({name:"ECDH",namedCurve:r},!0,["deriveBits"]),e=async(i,o)=>{let a;o!=null?a=await W.get().subtle.importKey("jwk",mh(r,o),{name:"ECDH",namedCurve:r},!1,["deriveBits"]):a=t.privateKey;let c=await W.get().subtle.importKey("jwk",Fa(r,i),{name:"ECDH",namedCurve:r},!1,[]),f=await W.get().subtle.deriveBits({name:"ECDH",namedCurve:r,public:c},a,Ma[r]);return new Uint8Array(f,0,f.byteLength)},n=await W.get().subtle.exportKey("jwk",t.publicKey);return{key:gh(n),genSharedKey:e}}var Ka={"P-256":32,"P-384":48,"P-521":66};function gh(r){if(r.crv==null||r.x==null||r.y==null)throw new A("JWK was missing components","ERR_INVALID_PARAMETERS");if(r.crv!=="P-256"&&r.crv!=="P-384"&&r.crv!=="P-521")throw new A(`Unknown curve: ${r.crv}. Must be ${zi}`,"ERR_INVALID_CURVE");let t=Ka[r.crv];return Bt([Uint8Array.from([4]),fi(r.x,t),fi(r.y,t)],1+t*2)}function Fa(r,t){if(r!=="P-256"&&r!=="P-384"&&r!=="P-521")throw new A(`Unknown curve: ${r}. Must be ${zi}`,"ERR_INVALID_CURVE");let e=Ka[r];if(!mt(t.subarray(0,1),Uint8Array.from([4])))throw new A("Cannot unmarshal public key - invalid key format","ERR_INVALID_KEY_FORMAT");return{kty:"EC",crv:r,x:Y(t.subarray(1,e+1),"base64url"),y:Y(t.subarray(1+e),"base64url"),ext:!0}}var mh=(r,t)=>({...Fa(r,t.public),d:Y(t.private,"base64url")});var qa=Ha;async function $a(r,t){let e=_r.decode(r);return An().decrypt(e,t)}var Ga={"AES-128":{ivSize:16,keySize:16},"AES-256":{ivSize:16,keySize:32},Blowfish:{ivSize:8,keySize:32}};async function za(r,t,e){let n=Ga[r];if(n==null){let x=Object.keys(Ga).join(" / ");throw new A(`unknown cipher type '${r}'. Must be ${x}`,"ERR_INVALID_CIPHER_TYPE")}if(t==null)throw new A("missing hash type","ERR_MISSING_HASH_TYPE");let s=n.keySize,i=n.ivSize,o=20,a=$("key expansion"),c=2*(i+s+o),f=await ra(t,e),l=await f.digest(a),u=[],p=0;for(;p<c;){let x=await f.digest(Bt([l,a])),b=x.length;p+b>c&&(b=c-p),u.push(x),p+=b,l=await f.digest(l)}let w=c/2,g=Bt(u),h=g.subarray(0,w),d=g.subarray(w,c),m=x=>({iv:x.subarray(0,i),cipherKey:x.subarray(i,i+s),macKey:x.subarray(i+s)});return{k1:m(h),k2:m(d)}}var no={};it(no,{MAX_RSA_KEY_SIZE:()=>qe,RsaPrivateKey:()=>_e,RsaPublicKey:()=>Fe,fromJwk:()=>Fh,generateKeyPair:()=>qh,unmarshalRsaPrivateKey:()=>eo,unmarshalRsaPublicKey:()=>Kh});function jt(r){if(isNaN(r)||r<=0)throw new A("random bytes length must be a Number bigger than 0","ERR_INVALID_LENGTH");return hr(r)}var Re={};it(Re,{exportToPem:()=>Oh,importFromPem:()=>to,jwkToPkcs1:()=>Lh,jwkToPkix:()=>Dh,pkcs1ToJwk:()=>Ch,pkixToJwk:()=>Uh});var Nn=class extends lr{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,dn(t);let n=we(e);if(this.iHash=t.create(),typeof this.iHash.update!="function")throw new Error("Expected instance of class which extends utils.Hash");this.blockLen=this.iHash.blockLen,this.outputLen=this.iHash.outputLen;let s=this.blockLen,i=new Uint8Array(s);i.set(n.length>s?t.create().update(n).digest():n);for(let o=0;o<i.length;o++)i[o]^=54;this.iHash.update(i),this.oHash=t.create();for(let o=0;o<i.length;o++)i[o]^=106;this.oHash.update(i),i.fill(0)}update(t){return ur(this),this.iHash.update(t),this}digestInto(t){ur(this),cr(t,this.outputLen),this.finished=!0,this.iHash.digestInto(t),this.oHash.update(t),this.oHash.digestInto(t),this.destroy()}digest(){let t=new Uint8Array(this.oHash.outputLen);return this.digestInto(t),t}_cloneInto(t){t||(t=Object.create(Object.getPrototypeOf(this),{}));let{oHash:e,iHash:n,finished:s,destroyed:i,blockLen:o,outputLen:a}=this;return t=t,t.finished=s,t.destroyed=i,t.blockLen=o,t.outputLen=a,t.oHash=e._cloneInto(t.oHash),t.iHash=n._cloneInto(t.iHash),t}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},$r=(r,t,e)=>new Nn(r,t).update(e).digest();$r.create=(r,t)=>new Nn(r,t);function yh(r,t,e,n){dn(r);let s=oa({dkLen:32,asyncTick:10},n),{c:i,dkLen:o,asyncTick:a}=s;if(ar(i),ar(o),ar(a),i<1)throw new Error("PBKDF2: iterations (c) should be >= 1");let c=we(t),f=we(e),l=new Uint8Array(o),u=$r.create(r,c),p=u._cloneInto().update(f);return{c:i,dkLen:o,asyncTick:a,DK:l,PRF:u,PRFSalt:p}}function bh(r,t,e,n,s){return r.destroy(),t.destroy(),n&&n.destroy(),s.fill(0),e}async function Yi(r,t,e,n){let{c:s,dkLen:i,asyncTick:o,DK:a,PRF:c,PRFSalt:f}=yh(r,t,e,n),l,u=new Uint8Array(4),p=fr(u),w=new Uint8Array(c.outputLen);for(let g=1,h=0;h<i;g++,h+=c.outputLen){let d=a.subarray(h,h+c.outputLen);p.setInt32(0,g,!1),(l=f._cloneInto(l)).update(u).digestInto(w),d.set(w.subarray(0,d.length)),await sa(s-1,o,()=>{c._cloneInto(l).update(w).digestInto(w);for(let m=0;m<d.length;m++)d[m]^=w[m]})}return bh(c,f,a,l,w)}var M=Os(Ya());function Ke(r,t){let e=0;if(r.length===1)return r[0];for(let n=r.length-1;n>=0;n--)e+=r[r.length-1-n]*Math.pow(2,t*n);return e}function ke(r,t,e=-1){let n=e,s=r,i=0,o=Math.pow(2,t);for(let a=1;a<8;a++){if(r<o){let c;if(n<0)c=new ArrayBuffer(a),i=a;else{if(n<a)return new ArrayBuffer(0);c=new ArrayBuffer(n),i=n}let f=new Uint8Array(c);for(let l=a-1;l>=0;l--){let u=Math.pow(2,l*t);f[i-l-1]=Math.floor(s/u),s-=f[i-l-1]*u}return c}o*=Math.pow(2,t)}return new ArrayBuffer(0)}function Tn(...r){let t=0,e=0;for(let i of r)t+=i.length;let n=new ArrayBuffer(t),s=new Uint8Array(n);for(let i of r)s.set(i,e),e+=i.length;return s}function Zi(){let r=new Uint8Array(this.valueHex);if(this.valueHex.byteLength>=2){let a=r[0]===255&&r[1]&128,c=r[0]===0&&(r[1]&128)===0;(a||c)&&this.warnings.push("Needlessly long format")}let t=new ArrayBuffer(this.valueHex.byteLength),e=new Uint8Array(t);for(let a=0;a<this.valueHex.byteLength;a++)e[a]=0;e[0]=r[0]&128;let n=Ke(e,8),s=new ArrayBuffer(this.valueHex.byteLength),i=new Uint8Array(s);for(let a=0;a<this.valueHex.byteLength;a++)i[a]=r[a];return i[0]&=127,Ke(i,8)-n}function ja(r){let t=r<0?r*-1:r,e=128;for(let n=1;n<8;n++){if(t<=e){if(r<0){let o=e-t,a=ke(o,8,n),c=new Uint8Array(a);return c[0]|=128,a}let s=ke(t,8,n),i=new Uint8Array(s);if(i[0]&128){let o=s.slice(0),a=new Uint8Array(o);s=new ArrayBuffer(s.byteLength+1),i=new Uint8Array(s);for(let c=0;c<o.byteLength;c++)i[c+1]=a[c];i[0]=0}return s}e*=Math.pow(2,8)}return new ArrayBuffer(0)}function Za(r,t){if(r.byteLength!==t.byteLength)return!1;let e=new Uint8Array(r),n=new Uint8Array(t);for(let s=0;s<e.length;s++)if(e[s]!==n[s])return!1;return!0}function Rt(r,t){let e=r.toString(10);if(t<e.length)return"";let n=t-e.length,s=new Array(n);for(let o=0;o<n;o++)s[o]="0";return s.join("").concat(e)}var Em=Math.log(2);function Cn(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function Wi(r){let t=0,e=0;for(let s=0;s<r.length;s++){let i=r[s];t+=i.byteLength}let n=new Uint8Array(t);for(let s=0;s<r.length;s++){let i=r[s];n.set(new Uint8Array(i),e),e+=i.byteLength}return n.buffer}function de(r,t,e,n){return t instanceof Uint8Array?t.byteLength?e<0?(r.error="Wrong parameter: inputOffset less than zero",!1):n<0?(r.error="Wrong parameter: inputLength less than zero",!1):t.byteLength-e-n<0?(r.error="End of input reached before message was fully decoded (inconsistent offset and length values)",!1):!0:(r.error="Wrong parameter: inputBuffer has zero length",!1):(r.error="Wrong parameter: inputBuffer must be 'Uint8Array'",!1)}var zr=class{constructor(){this.items=[]}write(t){this.items.push(t)}final(){return Wi(this.items)}},Gr=[new Uint8Array([1])],Wa="0123456789";var Br="",qt=new ArrayBuffer(0),Ji=new Uint8Array(0),Yr="EndOfContent",Xa="OCTET STRING",Qa="BIT STRING";function pe(r){var t;return t=class extends r{constructor(...n){var s;super(...n);let i=n[0]||{};this.isHexOnly=(s=i.isHexOnly)!==null&&s!==void 0?s:!1,this.valueHexView=i.valueHex?M.BufferSourceConverter.toUint8Array(i.valueHex):Ji}get valueHex(){return this.valueHexView.slice().buffer}set valueHex(n){this.valueHexView=new Uint8Array(n)}fromBER(n,s,i){let o=n instanceof ArrayBuffer?new Uint8Array(n):n;if(!de(this,o,s,i))return-1;let a=s+i;return this.valueHexView=o.subarray(s,a),this.valueHexView.length?(this.blockLength=i,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",qt)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:M.Convert.ToHex(this.valueHexView)}}},t.NAME="hexBlock",t}var le=class{constructor({blockLength:t=0,error:e=Br,warnings:n=[],valueBeforeDecode:s=Ji}={}){this.blockLength=t,this.error=e,this.warnings=n,this.valueBeforeDecodeView=M.BufferSourceConverter.toUint8Array(s)}static blockName(){return this.NAME}get valueBeforeDecode(){return this.valueBeforeDecodeView.slice().buffer}set valueBeforeDecode(t){this.valueBeforeDecodeView=new Uint8Array(t)}toJSON(){return{blockName:this.constructor.NAME,blockLength:this.blockLength,error:this.error,warnings:this.warnings,valueBeforeDecode:M.Convert.ToHex(this.valueBeforeDecodeView)}}};le.NAME="baseBlock";var xt=class extends le{fromBER(t,e,n){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}toBER(t,e){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}};xt.NAME="valueBlock";var Ln=class extends pe(le){constructor({idBlock:t={}}={}){var e,n,s,i;super(),t?(this.isHexOnly=(e=t.isHexOnly)!==null&&e!==void 0?e:!1,this.valueHexView=t.valueHex?M.BufferSourceConverter.toUint8Array(t.valueHex):Ji,this.tagClass=(n=t.tagClass)!==null&&n!==void 0?n:-1,this.tagNumber=(s=t.tagNumber)!==null&&s!==void 0?s:-1,this.isConstructed=(i=t.isConstructed)!==null&&i!==void 0?i:!1):(this.tagClass=-1,this.tagNumber=-1,this.isConstructed=!1)}toBER(t=!1){let e=0;switch(this.tagClass){case 1:e|=0;break;case 2:e|=64;break;case 3:e|=128;break;case 4:e|=192;break;default:return this.error="Unknown tag class",qt}if(this.isConstructed&&(e|=32),this.tagNumber<31&&!this.isHexOnly){let s=new Uint8Array(1);if(!t){let i=this.tagNumber;i&=31,e|=i,s[0]=e}return s.buffer}if(!this.isHexOnly){let s=ke(this.tagNumber,7),i=new Uint8Array(s),o=s.byteLength,a=new Uint8Array(o+1);if(a[0]=e|31,!t){for(let c=0;c<o-1;c++)a[c+1]=i[c]|128;a[o]=i[o-1]}return a.buffer}let n=new Uint8Array(this.valueHexView.byteLength+1);if(n[0]=e|31,!t){let s=this.valueHexView;for(let i=0;i<s.length-1;i++)n[i+1]=s[i]|128;n[this.valueHexView.byteLength]=s[s.length-1]}return n.buffer}fromBER(t,e,n){let s=M.BufferSourceConverter.toUint8Array(t);if(!de(this,s,e,n))return-1;let i=s.subarray(e,e+n);if(i.length===0)return this.error="Zero buffer length",-1;switch(i[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=(i[0]&32)===32,this.isHexOnly=!1;let a=i[0]&31;if(a!==31)this.tagNumber=a,this.blockLength=1;else{let c=1,f=this.valueHexView=new Uint8Array(255),l=255;for(;i[c]&128;){if(f[c-1]=i[c]&127,c++,c>=i.length)return this.error="End of input reached before message was fully decoded",-1;if(c===l){l+=255;let p=new Uint8Array(l);for(let w=0;w<f.length;w++)p[w]=f[w];f=this.valueHexView=new Uint8Array(l)}}this.blockLength=c+1,f[c-1]=i[c]&127;let u=new Uint8Array(c);for(let p=0;p<c;p++)u[p]=f[p];f=this.valueHexView=new Uint8Array(c),f.set(u),this.blockLength<=9?this.tagNumber=Ke(f,7):(this.isHexOnly=!0,this.warnings.push("Tag too long, represented as hex-coded"))}if(this.tagClass===1&&this.isConstructed)switch(this.tagNumber){case 1:case 2:case 5:case 6:case 9:case 13:case 14:case 23:case 24:case 31:case 32:case 33:case 34:return this.error="Constructed encoding used for primitive type",-1}return e+this.blockLength}toJSON(){return{...super.toJSON(),tagClass:this.tagClass,tagNumber:this.tagNumber,isConstructed:this.isConstructed}}};Ln.NAME="identificationBlock";var Un=class extends le{constructor({lenBlock:t={}}={}){var e,n,s;super(),this.isIndefiniteForm=(e=t.isIndefiniteForm)!==null&&e!==void 0?e:!1,this.longFormUsed=(n=t.longFormUsed)!==null&&n!==void 0?n:!1,this.length=(s=t.length)!==null&&s!==void 0?s:0}fromBER(t,e,n){let s=M.BufferSourceConverter.toUint8Array(t);if(!de(this,s,e,n))return-1;let i=s.subarray(e,e+n);if(i.length===0)return this.error="Zero buffer length",-1;if(i[0]===255)return this.error="Length block 0xFF is reserved by standard",-1;if(this.isIndefiniteForm=i[0]===128,this.isIndefiniteForm)return this.blockLength=1,e+this.blockLength;if(this.longFormUsed=!!(i[0]&128),this.longFormUsed===!1)return this.length=i[0],this.blockLength=1,e+this.blockLength;let o=i[0]&127;if(o>8)return this.error="Too big integer",-1;if(o+1>i.length)return this.error="End of input reached before message was fully decoded",-1;let a=e+1,c=s.subarray(a,a+o);return c[o-1]===0&&this.warnings.push("Needlessly long encoded length"),this.length=Ke(c,8),this.longFormUsed&&this.length<=127&&this.warnings.push("Unnecessary usage of long length form"),this.blockLength=o+1,e+this.blockLength}toBER(t=!1){let e,n;if(this.length>127&&(this.longFormUsed=!0),this.isIndefiniteForm)return e=new ArrayBuffer(1),t===!1&&(n=new Uint8Array(e),n[0]=128),e;if(this.longFormUsed){let s=ke(this.length,8);if(s.byteLength>127)return this.error="Too big length",qt;if(e=new ArrayBuffer(s.byteLength+1),t)return e;let i=new Uint8Array(s);n=new Uint8Array(e),n[0]=s.byteLength|128;for(let o=0;o<s.byteLength;o++)n[o+1]=i[o];return e}return e=new ArrayBuffer(1),t===!1&&(n=new Uint8Array(e),n[0]=this.length),e}toJSON(){return{...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,longFormUsed:this.longFormUsed,length:this.length}}};Un.NAME="lengthBlock";var k={},pt=class extends le{constructor({name:t=Br,optional:e=!1,primitiveSchema:n,...s}={},i){super(s),this.name=t,this.optional=e,n&&(this.primitiveSchema=n),this.idBlock=new Ln(s),this.lenBlock=new Un(s),this.valueBlock=i?new i(s):new xt(s)}fromBER(t,e,n){let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}toBER(t,e){let n=e||new zr;e||tc(this);let s=this.idBlock.toBER(t);if(n.write(s),this.lenBlock.isIndefiniteForm)n.write(new Uint8Array([128]).buffer),this.valueBlock.toBER(t,n),n.write(new ArrayBuffer(2));else{let i=this.valueBlock.toBER(t);this.lenBlock.length=i.byteLength;let o=this.lenBlock.toBER(t);n.write(o),n.write(i)}return e?qt:n.final()}toJSON(){let t={...super.toJSON(),idBlock:this.idBlock.toJSON(),lenBlock:this.lenBlock.toJSON(),valueBlock:this.valueBlock.toJSON(),name:this.name,optional:this.optional};return this.primitiveSchema&&(t.primitiveSchema=this.primitiveSchema.toJSON()),t}toString(t="ascii"){return t==="ascii"?this.onAsciiEncoding():M.Convert.ToHex(this.toBER())}onAsciiEncoding(){return`${this.constructor.NAME} : ${M.Convert.ToHex(this.valueBlock.valueBeforeDecodeView)}`}isEqual(t){if(this===t)return!0;if(!(t instanceof this.constructor))return!1;let e=this.toBER(),n=t.toBER();return Za(e,n)}};pt.NAME="BaseBlock";function tc(r){if(r instanceof k.Constructed)for(let t of r.valueBlock.value)tc(t)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var Dn=class extends pt{constructor({value:t=Br,...e}={},n){super(e,n),t&&this.fromString(t)}getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}fromBER(t,e,n){let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.fromBuffer(this.valueBlock.valueHexView),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}onAsciiEncoding(){return`${this.constructor.NAME} : '${this.valueBlock.value}'`}};Dn.NAME="BaseStringBlock";var Pn=class extends pe(xt){constructor({isHexOnly:t=!0,...e}={}){super(e),this.isHexOnly=t}};Pn.NAME="PrimitiveValueBlock";var ec,On=class extends pt{constructor(t={}){super(t,Pn),this.idBlock.isConstructed=!1}};ec=On;k.Primitive=ec;On.NAME="PRIMITIVE";function Ih(r,t){if(r instanceof t)return r;let e=new t;return e.idBlock=r.idBlock,e.lenBlock=r.lenBlock,e.warnings=r.warnings,e.valueBeforeDecodeView=r.valueBeforeDecodeView,e}function ms(r,t=0,e=r.length){let n=t,s=new pt({},xt),i=new le;if(!de(i,r,t,e))return s.error=i.error,{offset:-1,result:s};if(!r.subarray(t,t+e).length)return s.error="Zero buffer length",{offset:-1,result:s};let a=s.idBlock.fromBER(r,t,e);if(s.idBlock.warnings.length&&s.warnings.concat(s.idBlock.warnings),a===-1)return s.error=s.idBlock.error,{offset:-1,result:s};if(t=a,e-=s.idBlock.blockLength,a=s.lenBlock.fromBER(r,t,e),s.lenBlock.warnings.length&&s.warnings.concat(s.lenBlock.warnings),a===-1)return s.error=s.lenBlock.error,{offset:-1,result:s};if(t=a,e-=s.lenBlock.blockLength,!s.idBlock.isConstructed&&s.lenBlock.isIndefiniteForm)return s.error="Indefinite length form used for primitive encoding form",{offset:-1,result:s};let c=pt;switch(s.idBlock.tagClass){case 1:if(s.idBlock.tagNumber>=37&&s.idBlock.isHexOnly===!1)return s.error="UNIVERSAL 37 and upper tags are reserved by ASN.1 standard",{offset:-1,result:s};switch(s.idBlock.tagNumber){case 0:if(s.idBlock.isConstructed&&s.lenBlock.length>0)return s.error="Type [UNIVERSAL 0] is reserved",{offset:-1,result:s};c=k.EndOfContent;break;case 1:c=k.Boolean;break;case 2:c=k.Integer;break;case 3:c=k.BitString;break;case 4:c=k.OctetString;break;case 5:c=k.Null;break;case 6:c=k.ObjectIdentifier;break;case 10:c=k.Enumerated;break;case 12:c=k.Utf8String;break;case 13:c=k.RelativeObjectIdentifier;break;case 14:c=k.TIME;break;case 15:return s.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:s};case 16:c=k.Sequence;break;case 17:c=k.Set;break;case 18:c=k.NumericString;break;case 19:c=k.PrintableString;break;case 20:c=k.TeletexString;break;case 21:c=k.VideotexString;break;case 22:c=k.IA5String;break;case 23:c=k.UTCTime;break;case 24:c=k.GeneralizedTime;break;case 25:c=k.GraphicString;break;case 26:c=k.VisibleString;break;case 27:c=k.GeneralString;break;case 28:c=k.UniversalString;break;case 29:c=k.CharacterString;break;case 30:c=k.BmpString;break;case 31:c=k.DATE;break;case 32:c=k.TimeOfDay;break;case 33:c=k.DateTime;break;case 34:c=k.Duration;break;default:{let f=s.idBlock.isConstructed?new k.Constructed:new k.Primitive;f.idBlock=s.idBlock,f.lenBlock=s.lenBlock,f.warnings=s.warnings,s=f}}break;case 2:case 3:case 4:default:c=s.idBlock.isConstructed?k.Constructed:k.Primitive}return s=Ih(s,c),a=s.fromBER(r,t,s.lenBlock.isIndefiniteForm?e:s.lenBlock.length),s.valueBeforeDecodeView=r.subarray(n,n+s.blockLength),{offset:a,result:s}}function Ar(r){if(!r.byteLength){let t=new pt({},xt);return t.error="Input buffer has zero length",{offset:-1,result:t}}return ms(M.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function Nh(r,t){return r?1:t}var Zt=class extends xt{constructor({value:t=[],isIndefiniteForm:e=!1,...n}={}){super(n),this.value=t,this.isIndefiniteForm=e}fromBER(t,e,n){let s=M.BufferSourceConverter.toUint8Array(t);if(!de(this,s,e,n))return-1;if(this.valueBeforeDecodeView=s.subarray(e,e+n),this.valueBeforeDecodeView.length===0)return this.warnings.push("Zero buffer length"),e;let i=e;for(;Nh(this.isIndefiniteForm,n)>0;){let o=ms(s,i,n);if(o.offset===-1)return this.error=o.result.error,this.warnings.concat(o.result.warnings),-1;if(i=o.offset,this.blockLength+=o.result.blockLength,n-=o.result.blockLength,this.value.push(o.result),this.isIndefiniteForm&&o.result.constructor.NAME===Yr)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===Yr?this.value.pop():this.warnings.push("No EndOfContent block encoded")),i}toBER(t,e){let n=e||new zr;for(let s=0;s<this.value.length;s++)this.value[s].toBER(t,n);return e?qt:n.final()}toJSON(){let t={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let e of this.value)t.value.push(e.toJSON());return t}};Zt.NAME="ConstructedValueBlock";var rc,Ie=class extends pt{constructor(t={}){super(t,Zt),this.idBlock.isConstructed=!0}fromBER(t,e,n){this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm;let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}onAsciiEncoding(){let t=[];for(let n of this.valueBlock.value)t.push(n.toString("ascii").split(`
|
3
3
|
`).map(s=>` ${s}`).join(`
|
4
4
|
`));let e=this.idBlock.tagClass===3?`[${this.idBlock.tagNumber}]`:this.constructor.NAME;return t.length?`${e} :
|
5
5
|
${t.join(`
|
6
|
-
`)}`:`${e} :`}};ic=Ie;k.Constructed=ic;Ie.NAME="CONSTRUCTED";var Kn=class extends xt{fromBER(t,e,n){return e}toBER(t){return qt}};Kn.override="EndOfContentValueBlock";var oc,Fn=class extends pt{constructor(t={}){super(t,Kn),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};oc=Fn;k.EndOfContent=oc;Fn.NAME=jr;var ac,Ne=class extends pt{constructor(t={}){super(t,xt),this.idBlock.tagClass=1,this.idBlock.tagNumber=5}fromBER(t,e,n){return this.lenBlock.length>0&&this.warnings.push("Non-zero length of value block for Null type"),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.blockLength+=n,e+n>t.byteLength?(this.error="End of input reached before message was fully decoded (inconsistent offset and length values)",-1):e+n}toBER(t,e){let n=new ArrayBuffer(2);if(!t){let s=new Uint8Array(n);s[0]=5,s[1]=0}return e&&e.write(n),n}onAsciiEncoding(){return`${this.constructor.NAME}`}};ac=Ne;k.Null=ac;Ne.NAME="NULL";var qn=class extends pe(xt){constructor({value:t,...e}={}){super(e),e.valueHex?this.valueHexView=M.BufferSourceConverter.toUint8Array(e.valueHex):this.valueHexView=new Uint8Array(1),t&&(this.value=t)}get value(){for(let t of this.valueHexView)if(t>0)return!0;return!1}set value(t){this.valueHexView[0]=t?255:0}fromBER(t,e,n){let s=M.BufferSourceConverter.toUint8Array(t);return de(this,s,e,n)?(this.valueHexView=s.subarray(e,e+n),n>1&&this.warnings.push("Boolean value encoded in more then 1 octet"),this.isHexOnly=!0,Ji.call(this),this.blockLength=n,e+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};qn.NAME="BooleanValueBlock";var cc,$n=class extends pt{constructor(t={}){super(t,qn),this.idBlock.tagClass=1,this.idBlock.tagNumber=1}getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.getValue}`}};cc=$n;k.Boolean=cc;$n.NAME="BOOLEAN";var Gn=class extends pe(Zt){constructor({isConstructed:t=!1,...e}={}){super(e),this.isConstructed=t}fromBER(t,e,n){let s=0;if(this.isConstructed){if(this.isHexOnly=!1,s=Zt.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let i=0;i<this.value.length;i++){let o=this.value[i].constructor.NAME;if(o===jr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(o!==ec)return this.error="OCTET STRING may consists of OCTET STRINGs only",-1}}else this.isHexOnly=!0,s=super.fromBER(t,e,n),this.blockLength=n;return s}toBER(t,e){return this.isConstructed?Zt.prototype.toBER.call(this,t,e):t?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};Gn.NAME="OctetStringValueBlock";var uc,fe=class r extends pt{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,i;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((i=n.value)===null||i===void 0)&&i.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},Gn),this.idBlock.tagClass=1,this.idBlock.tagNumber=4}fromBER(t,e,n){if(this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,n===0)return this.idBlock.error.length===0&&(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length===0&&(this.blockLength+=this.lenBlock.blockLength),e;if(!this.valueBlock.isConstructed){let i=(t instanceof ArrayBuffer?new Uint8Array(t):t).subarray(e,e+n);try{if(i.byteLength){let o=ws(i,0,i.byteLength);o.offset!==-1&&o.offset===n&&(this.valueBlock.value=[o.result])}}catch{}}return super.fromBER(t,e,n)}onAsciiEncoding(){return this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length?Ie.prototype.onAsciiEncoding.call(this):`${this.constructor.NAME} : ${M.Convert.ToHex(this.valueBlock.valueHexView)}`}getValue(){if(!this.idBlock.isConstructed)return this.valueBlock.valueHexView.slice().buffer;let t=[];for(let e of this.valueBlock.value)e instanceof r&&t.push(e.valueBlock.valueHexView);return M.BufferSourceConverter.concat(t)}};uc=fe;k.OctetString=uc;fe.NAME=ec;var zn=class extends pe(Zt){constructor({unusedBits:t=0,isConstructed:e=!1,...n}={}){super(n),this.unusedBits=t,this.isConstructed=e,this.blockLength=this.valueHexView.byteLength}fromBER(t,e,n){if(!n)return e;let s=-1;if(this.isConstructed){if(s=Zt.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let a of this.value){let c=a.constructor.NAME;if(c===jr){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 l=a.valueBlock;if(this.unusedBits>0&&l.unusedBits>0)return this.error='Using of "unused bits" inside constructive BIT STRING allowed for least one only',-1;this.unusedBits=l.unusedBits}return s}let i=M.BufferSourceConverter.toUint8Array(t);if(!de(this,i,e,n))return-1;let o=i.subarray(e,e+n);if(this.unusedBits=o[0],this.unusedBits>7)return this.error="Unused bits for BitString must be in range 0-7",-1;if(!this.unusedBits){let a=o.subarray(1);try{if(a.byteLength){let c=ws(a,0,a.byteLength);c.offset!==-1&&c.offset===n-1&&(this.value=[c.result])}}catch{}}return this.valueHexView=o.subarray(1),this.blockLength=o.length,e+n}toBER(t,e){if(this.isConstructed)return Zt.prototype.toBER.call(this,t,e);if(t)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return qt;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}}};zn.NAME="BitStringValueBlock";var lc,Ar=class extends pt{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,i;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((i=n.value)===null||i===void 0)&&i.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},zn),this.idBlock.tagClass=1,this.idBlock.tagNumber=3}fromBER(t,e,n){return this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,super.fromBER(t,e,n)}onAsciiEncoding(){if(this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length)return Ie.prototype.onAsciiEncoding.call(this);{let t=[],e=this.valueBlock.valueHexView;for(let s of e)t.push(s.toString(2).padStart(8,"0"));let n=t.join("");return`${this.constructor.NAME} : ${n.substring(0,n.length-this.valueBlock.unusedBits)}`}}};lc=Ar;k.BitString=lc;Ar.NAME=rc;var fc;function Lh(r,t){let e=new Uint8Array([0]),n=new Uint8Array(r),s=new Uint8Array(t),i=n.slice(0),o=i.length-1,a=s.slice(0),c=a.length-1,l=0,f=c<o?o:c,u=0;for(let p=f;p>=0;p--,u++){switch(!0){case u<a.length:l=i[o-u]+a[c-u]+e[0];break;default:l=i[o-u]+e[0]}switch(e[0]=l/10,!0){case u>=i.length:i=Un(new Uint8Array([l%10]),i);break;default:i[o-u]=l%10}}return e[0]>0&&(i=Un(e,i)),i}function tc(r){if(r>=zr.length)for(let t=zr.length;t<=r;t++){let e=new Uint8Array([0]),n=zr[t-1].slice(0);for(let s=n.length-1;s>=0;s--){let i=new Uint8Array([(n[s]<<1)+e[0]]);e[0]=i[0]/10,n[s]=i[0]%10}e[0]>0&&(n=Un(e,n)),zr.push(n)}return zr[r]}function Uh(r,t){let e=0,n=new Uint8Array(r),s=new Uint8Array(t),i=n.slice(0),o=i.length-1,a=s.slice(0),c=a.length-1,l,f=0;for(let u=c;u>=0;u--,f++)switch(l=i[o-f]-a[c-f]-e,!0){case l<0:e=1,i[o-f]=l+10;break;default:e=0,i[o-f]=l}if(e>0)for(let u=o-c+1;u>=0;u--,f++)if(l=i[o-f]-e,l<0)e=1,i[o-f]=l+10;else{e=0,i[o-f]=l;break}return i.slice()}var Zr=class extends pe(xt){constructor({value:t,...e}={}){super(e),this._valueDec=0,e.valueHex&&this.setValueHex(),t!==void 0&&(this.valueDec=t)}setValueHex(){this.valueHexView.length>=4?(this.warnings.push("Too big Integer for decoding, hex only"),this.isHexOnly=!0,this._valueDec=0):(this.isHexOnly=!1,this.valueHexView.length>0&&(this._valueDec=Ji.call(this)))}set valueDec(t){this._valueDec=t,this.isHexOnly=!1,this.valueHexView=new Uint8Array(Ja(t))}get valueDec(){return this._valueDec}fromDER(t,e,n,s=0){let i=this.fromBER(t,e,n);if(i===-1)return i;let o=this.valueHexView;return o[0]===0&&o[1]&128?this.valueHexView=o.subarray(1):s!==0&&o.length<s&&(s-o.length>1&&(s=o.length+1),this.valueHexView=o.subarray(s-o.length)),i}toDER(t=!1){let e=this.valueHexView;switch(!0){case(e[0]&128)!==0:{let n=new Uint8Array(this.valueHexView.length+1);n[0]=0,n.set(e,1),this.valueHexView=n}break;case(e[0]===0&&(e[1]&128)===0):this.valueHexView=this.valueHexView.subarray(1);break}return this.toBER(t)}fromBER(t,e,n){let s=super.fromBER(t,e,n);return s===-1||this.setValueHex(),s}toBER(t){return t?new ArrayBuffer(this.valueHexView.length):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}toString(){let t=this.valueHexView.length*8-1,e=new Uint8Array(this.valueHexView.length*8/3),n=0,s,i=this.valueHexView,o="",a=!1;for(let c=i.byteLength-1;c>=0;c--){s=i[c];for(let l=0;l<8;l++){if((s&1)===1)switch(n){case t:e=Uh(tc(n),e),o="-";break;default:e=Lh(e,tc(n))}n++,s>>=1}}for(let c=0;c<e.length;c++)e[c]&&(a=!0),a&&(o+=Qa.charAt(e[c]));return a===!1&&(o+=Qa.charAt(0)),o}};fc=Zr;Zr.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,ot=class r extends pt{constructor(t={}){super(t,Zr),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return Dn(),BigInt(this.valueBlock.toString())}static fromBigInt(t){Dn();let e=BigInt(t),n=new Yr,s=e.toString(16).replace(/^-/,""),i=new Uint8Array(M.Convert.FromHex(s));if(e<0){let a=new Uint8Array(i.length+(i[0]&128?1:0));a[0]|=128;let l=BigInt(`0x${M.Convert.ToHex(a)}`)+e,f=M.BufferSourceConverter.toUint8Array(M.Convert.FromHex(l.toString(16)));f[0]|=128,n.write(f)}else i[0]&128&&n.write(new Uint8Array([0])),n.write(i);return new r({valueHex:n.final()})}convertToDER(){let t=new r({valueHex:this.valueBlock.valueHexView});return t.valueBlock.toDER(),t}convertFromDER(){return new r({valueHex:this.valueBlock.valueHexView[0]===0?this.valueBlock.valueHexView.subarray(1):this.valueBlock.valueHexView})}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()}`}};hc=ot;k.Integer=hc;ot.NAME="INTEGER";var dc,Yn=class extends ot{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};dc=Yn;k.Enumerated=dc;Yn.NAME="ENUMERATED";var Wr=class extends pe(xt){constructor({valueDec:t=-1,isFirstSid:e=!1,...n}={}){super(n),this.valueDec=t,this.isFirstSid=e}fromBER(t,e,n){if(!n)return e;let s=M.BufferSourceConverter.toUint8Array(t);if(!de(this,s,e,n))return-1;let i=s.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=i[a]&127,this.blockLength++,!!(i[a]&128));a++);let o=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)o[a]=this.valueHexView[a];return this.valueHexView=o,i[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=Fe(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}set valueBigInt(t){Dn();let e=BigInt(t).toString(2);for(;e.length%7;)e="0"+e;let n=new Uint8Array(e.length/7);for(let s=0;s<n.length;s++)n[s]=parseInt(e.slice(s*7,s*7+7),2)+(s+1<n.length?128:0);this.fromBER(n.buffer,0,n.length)}toBER(t){if(this.isHexOnly){if(t)return new ArrayBuffer(this.valueHexView.byteLength);let s=this.valueHexView,i=new Uint8Array(this.blockLength);for(let o=0;o<this.blockLength-1;o++)i[o]=s[o]|128;return i[this.blockLength-1]=s[this.blockLength-1],i.buffer}let e=ke(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",qt;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),i=e.byteLength-1;for(let o=0;o<i;o++)n[o]=s[o]|128;n[i]=s[i]}return n}toString(){let t="";if(this.isHexOnly)t=M.Convert.ToHex(this.valueHexView);else if(this.isFirstSid){let e=this.valueDec;this.valueDec<=39?t="0.":this.valueDec<=79?(t="1.",e-=40):(t="2.",e-=80),t+=e.toString()}else t=this.valueDec.toString();return t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec,isFirstSid:this.isFirstSid}}};Wr.NAME="sidBlock";var jn=class extends xt{constructor({value:t=Sr,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let i=new Wr;if(s=i.fromBER(t,s,n),s===-1)return this.blockLength=0,this.error=i.error,s;this.value.length===0&&(i.isFirstSid=!0),this.blockLength+=i.blockLength,n-=i.blockLength,this.value.push(i)}return s}toBER(t){let e=[];for(let n=0;n<this.value.length;n++){let s=this.value[n].toBER(t);if(s.byteLength===0)return this.error=this.value[n].error,qt;e.push(s)}return Xi(e)}fromString(t){this.value=[];let e=0,n=0,s="",i=!1;do if(n=t.indexOf(".",e),n===-1?s=t.substring(e):s=t.substring(e,n),e=n+1,i){let o=this.value[0],a=0;switch(o.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;o.valueDec=c+a,i=!1}else{let o=new Wr;if(s>Number.MAX_SAFE_INTEGER){Dn();let a=BigInt(s);o.valueBigInt=a}else if(o.valueDec=parseInt(s,10),isNaN(o.valueDec))return;this.value.length||(o.isFirstSid=!0,i=!0),this.value.push(o)}while(n!==-1)}toString(){let t="",e=!1;for(let n=0;n<this.value.length;n++){e=this.value[n].isHexOnly;let s=this.value[n].toString();n!==0&&(t=`${t}.`),e?(s=`{${s}}`,this.value[n].isFirstSid?t=`2.{${s} - 80}`:t+=s):t+=s}return t}toJSON(){let t={...super.toJSON(),value:this.toString(),sidArray:[]};for(let e=0;e<this.value.length;e++)t.sidArray.push(this.value[e].toJSON());return t}};jn.NAME="ObjectIdentifierValueBlock";var pc,Ft=class extends pt{constructor(t={}){super(t,jn),this.idBlock.tagClass=1,this.idBlock.tagNumber=6}getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};pc=Ft;k.ObjectIdentifier=pc;Ft.NAME="OBJECT IDENTIFIER";var Jr=class extends pe(le){constructor({valueDec:t=0,...e}={}){super(e),this.valueDec=t}fromBER(t,e,n){if(n===0)return e;let s=M.BufferSourceConverter.toUint8Array(t);if(!de(this,s,e,n))return-1;let i=s.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=i[a]&127,this.blockLength++,!!(i[a]&128));a++);let o=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)o[a]=this.valueHexView[a];return this.valueHexView=o,i[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=Fe(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}toBER(t){if(this.isHexOnly){if(t)return new ArrayBuffer(this.valueHexView.byteLength);let s=this.valueHexView,i=new Uint8Array(this.blockLength);for(let o=0;o<this.blockLength-1;o++)i[o]=s[o]|128;return i[this.blockLength-1]=s[this.blockLength-1],i.buffer}let e=ke(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",qt;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),i=e.byteLength-1;for(let o=0;o<i;o++)n[o]=s[o]|128;n[i]=s[i]}return n.buffer}toString(){let t="";return this.isHexOnly?t=M.Convert.ToHex(this.valueHexView):t=this.valueDec.toString(),t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};Jr.NAME="relativeSidBlock";var Zn=class extends xt{constructor({value:t=Sr,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let i=new Jr;if(s=i.fromBER(t,s,n),s===-1)return this.blockLength=0,this.error=i.error,s;this.blockLength+=i.blockLength,n-=i.blockLength,this.value.push(i)}return s}toBER(t,e){let n=[];for(let s=0;s<this.value.length;s++){let i=this.value[s].toBER(t);if(i.byteLength===0)return this.error=this.value[s].error,qt;n.push(i)}return Xi(n)}fromString(t){this.value=[];let e=0,n=0,s="";do{n=t.indexOf(".",e),n===-1?s=t.substring(e):s=t.substring(e,n),e=n+1;let i=new Jr;if(i.valueDec=parseInt(s,10),isNaN(i.valueDec))return!0;this.value.push(i)}while(n!==-1);return!0}toString(){let t="",e=!1;for(let n=0;n<this.value.length;n++){e=this.value[n].isHexOnly;let s=this.value[n].toString();n!==0&&(t=`${t}.`),e&&(s=`{${s}}`),t+=s}return t}toJSON(){let t={...super.toJSON(),value:this.toString(),sidArray:[]};for(let e=0;e<this.value.length;e++)t.sidArray.push(this.value[e].toJSON());return t}};Zn.NAME="RelativeObjectIdentifierValueBlock";var gc,Wn=class extends pt{constructor(t={}){super(t,Zn),this.idBlock.tagClass=1,this.idBlock.tagNumber=13}getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};gc=Wn;k.RelativeObjectIdentifier=gc;Wn.NAME="RelativeObjectIdentifier";var mc,ft=class extends Ie{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};mc=ft;k.Sequence=mc;ft.NAME="SEQUENCE";var yc,Jn=class extends Ie{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};yc=Jn;k.Set=yc;Jn.NAME="SET";var Xn=class extends pe(xt){constructor({...t}={}){super(t),this.isHexOnly=!0,this.value=Sr}toJSON(){return{...super.toJSON(),value:this.value}}};Xn.NAME="StringValueBlock";var Qn=class extends Xn{};Qn.NAME="SimpleStringValueBlock";var At=class extends On{constructor({...t}={}){super(t,Qn)}fromBuffer(t){this.valueBlock.value=String.fromCharCode.apply(null,M.BufferSourceConverter.toUint8Array(t))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e);for(let s=0;s<e;s++)n[s]=t.charCodeAt(s);this.valueBlock.value=t}};At.NAME="SIMPLE STRING";var ts=class extends At{fromBuffer(t){this.valueBlock.valueHexView=M.BufferSourceConverter.toUint8Array(t);try{this.valueBlock.value=M.Convert.ToUtf8String(t)}catch(e){this.warnings.push(`Error during "decodeURIComponent": ${e}, using raw string`),this.valueBlock.value=M.Convert.ToBinary(t)}}fromString(t){this.valueBlock.valueHexView=new Uint8Array(M.Convert.FromUtf8String(t)),this.valueBlock.value=t}};ts.NAME="Utf8StringValueBlock";var bc,he=class extends ts{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};bc=he;k.Utf8String=bc;he.NAME="UTF8String";var es=class extends At{fromBuffer(t){this.valueBlock.value=M.Convert.ToUtf16String(t),this.valueBlock.valueHexView=M.BufferSourceConverter.toUint8Array(t)}fromString(t){this.valueBlock.value=t,this.valueBlock.valueHexView=new Uint8Array(M.Convert.FromUtf16String(t))}};es.NAME="BmpStringValueBlock";var wc,rs=class extends es{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};wc=rs;k.BmpString=wc;rs.NAME="BMPString";var ns=class extends At{fromBuffer(t){let e=ArrayBuffer.isView(t)?t.slice().buffer:t.slice(0),n=new Uint8Array(e);for(let s=0;s<n.length;s+=4)n[s]=n[s+3],n[s+1]=n[s+2],n[s+2]=0,n[s+3]=0;this.valueBlock.value=String.fromCharCode.apply(null,new Uint32Array(e))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e*4);for(let s=0;s<e;s++){let i=ke(t.charCodeAt(s),8),o=new Uint8Array(i);if(o.length>4)continue;let a=4-o.length;for(let c=o.length-1;c>=0;c--)n[s*4+c+a]=o[c]}this.valueBlock.value=t}};ns.NAME="UniversalStringValueBlock";var xc,ss=class extends ns{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};xc=ss;k.UniversalString=xc;ss.NAME="UniversalString";var Ec,is=class extends At{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};Ec=is;k.NumericString=Ec;is.NAME="NumericString";var vc,os=class extends At{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};vc=os;k.PrintableString=vc;os.NAME="PrintableString";var Bc,as=class extends At{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};Bc=as;k.TeletexString=Bc;as.NAME="TeletexString";var Ac,cs=class extends At{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};Ac=cs;k.VideotexString=Ac;cs.NAME="VideotexString";var Sc,us=class extends At{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};Sc=us;k.IA5String=Sc;us.NAME="IA5String";var kc,ls=class extends At{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};kc=ls;k.GraphicString=kc;ls.NAME="GraphicString";var Ic,Xr=class extends At{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};Ic=Xr;k.VisibleString=Ic;Xr.NAME="VisibleString";var Nc,fs=class extends At{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};Nc=fs;k.GeneralString=Nc;fs.NAME="GeneralString";var Rc,hs=class extends At{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};Rc=hs;k.CharacterString=Rc;hs.NAME="CharacterString";var _c,Qr=class extends Xr{constructor({value:t,valueDate:e,...n}={}){if(super(n),this.year=0,this.month=0,this.day=0,this.hour=0,this.minute=0,this.second=0,t){this.fromString(t),this.valueBlock.valueHexView=new Uint8Array(t.length);for(let s=0;s<t.length;s++)this.valueBlock.valueHexView[s]=t.charCodeAt(s)}e&&(this.fromDate(e),this.valueBlock.valueHexView=new Uint8Array(this.toBuffer())),this.idBlock.tagClass=1,this.idBlock.tagNumber=23}fromBuffer(t){this.fromString(String.fromCharCode.apply(null,M.BufferSourceConverter.toUint8Array(t)))}toBuffer(){let t=this.toString(),e=new ArrayBuffer(t.length),n=new Uint8Array(e);for(let s=0;s<t.length;s++)n[s]=t.charCodeAt(s);return e}fromDate(t){this.year=t.getUTCFullYear(),this.month=t.getUTCMonth()+1,this.day=t.getUTCDate(),this.hour=t.getUTCHours(),this.minute=t.getUTCMinutes(),this.second=t.getUTCSeconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second))}fromString(t){let n=/(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})Z/ig.exec(t);if(n===null){this.error="Wrong input string for conversion";return}let s=parseInt(n[1],10);s>=50?this.year=1900+s:this.year=2e3+s,this.month=parseInt(n[2],10),this.day=parseInt(n[3],10),this.hour=parseInt(n[4],10),this.minute=parseInt(n[5],10),this.second=parseInt(n[6],10)}toString(t="iso"){if(t==="iso"){let e=new Array(7);return e[0]=Rt(this.year<2e3?this.year-1900:this.year-2e3,2),e[1]=Rt(this.month,2),e[2]=Rt(this.day,2),e[3]=Rt(this.hour,2),e[4]=Rt(this.minute,2),e[5]=Rt(this.second,2),e[6]="Z",e.join("")}return super.toString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.toDate().toISOString()}`}toJSON(){return{...super.toJSON(),year:this.year,month:this.month,day:this.day,hour:this.hour,minute:this.minute,second:this.second}}};_c=Qr;k.UTCTime=_c;Qr.NAME="UTCTime";var Tc,ds=class extends Qr{constructor(t={}){var e;super(t),(e=this.millisecond)!==null&&e!==void 0||(this.millisecond=0),this.idBlock.tagClass=1,this.idBlock.tagNumber=24}fromDate(t){super.fromDate(t),this.millisecond=t.getUTCMilliseconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second,this.millisecond))}fromString(t){let e=!1,n="",s="",i=0,o,a=0,c=0;if(t[t.length-1]==="Z")n=t.substring(0,t.length-1),e=!0;else{let u=new Number(t[t.length-1]);if(isNaN(u.valueOf()))throw new Error("Wrong input string for conversion");n=t}if(e){if(n.indexOf("+")!==-1)throw new Error("Wrong input string for conversion");if(n.indexOf("-")!==-1)throw new Error("Wrong input string for conversion")}else{let u=1,p=n.indexOf("+"),w="";if(p===-1&&(p=n.indexOf("-"),u=-1),p!==-1){if(w=n.substring(p+1),n=n.substring(0,p),w.length!==2&&w.length!==4)throw new Error("Wrong input string for conversion");let g=parseInt(w.substring(0,2),10);if(isNaN(g.valueOf()))throw new Error("Wrong input string for conversion");if(a=u*g,w.length===4){if(g=parseInt(w.substring(2,4),10),isNaN(g.valueOf()))throw new Error("Wrong input string for conversion");c=u*g}}}let l=n.indexOf(".");if(l===-1&&(l=n.indexOf(",")),l!==-1){let u=new Number(`0${n.substring(l)}`);if(isNaN(u.valueOf()))throw new Error("Wrong input string for conversion");i=u.valueOf(),s=n.substring(0,l)}else s=n;switch(!0){case s.length===8:if(o=/(\d{4})(\d{2})(\d{2})/ig,l!==-1)throw new Error("Wrong input string for conversion");break;case s.length===10:if(o=/(\d{4})(\d{2})(\d{2})(\d{2})/ig,l!==-1){let u=60*i;this.minute=Math.floor(u),u=60*(u-this.minute),this.second=Math.floor(u),u=1e3*(u-this.second),this.millisecond=Math.floor(u)}break;case s.length===12:if(o=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})/ig,l!==-1){let u=60*i;this.second=Math.floor(u),u=1e3*(u-this.second),this.millisecond=Math.floor(u)}break;case s.length===14:if(o=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})/ig,l!==-1){let u=1e3*i;this.millisecond=Math.floor(u)}break;default:throw new Error("Wrong input string for conversion")}let f=o.exec(s);if(f===null)throw new Error("Wrong input string for conversion");for(let u=1;u<f.length;u++)switch(u){case 1:this.year=parseInt(f[u],10);break;case 2:this.month=parseInt(f[u],10);break;case 3:this.day=parseInt(f[u],10);break;case 4:this.hour=parseInt(f[u],10)+a;break;case 5:this.minute=parseInt(f[u],10)+c;break;case 6:this.second=parseInt(f[u],10);break;default:throw new Error("Wrong input string for conversion")}if(e===!1){let u=new Date(this.year,this.month,this.day,this.hour,this.minute,this.second,this.millisecond);this.year=u.getUTCFullYear(),this.month=u.getUTCMonth(),this.day=u.getUTCDay(),this.hour=u.getUTCHours(),this.minute=u.getUTCMinutes(),this.second=u.getUTCSeconds(),this.millisecond=u.getUTCMilliseconds()}}toString(t="iso"){if(t==="iso"){let e=[];return e.push(Rt(this.year,4)),e.push(Rt(this.month,2)),e.push(Rt(this.day,2)),e.push(Rt(this.hour,2)),e.push(Rt(this.minute,2)),e.push(Rt(this.second,2)),this.millisecond!==0&&(e.push("."),e.push(Rt(this.millisecond,3))),e.push("Z"),e.join("")}return super.toString(t)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};Tc=ds;k.GeneralizedTime=Tc;ds.NAME="GeneralizedTime";var Cc,ps=class extends he{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};Cc=ps;k.DATE=Cc;ps.NAME="DATE";var Lc,gs=class extends he{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};Lc=gs;k.TimeOfDay=Lc;gs.NAME="TimeOfDay";var Uc,ms=class extends he{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};Uc=ms;k.DateTime=Uc;ms.NAME="DateTime";var Dc,ys=class extends he{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};Dc=ys;k.Duration=Dc;ys.NAME="Duration";var Pc,bs=class extends he{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};Pc=bs;k.TIME=Pc;bs.NAME="TIME";function Ph(r){let{result:t}=kr(r),e=t.valueBlock.value;return{n:Z(Wt(e[1].toBigInt()),"base64url"),e:Z(Wt(e[2].toBigInt()),"base64url"),d:Z(Wt(e[3].toBigInt()),"base64url"),p:Z(Wt(e[4].toBigInt()),"base64url"),q:Z(Wt(e[5].toBigInt()),"base64url"),dp:Z(Wt(e[6].toBigInt()),"base64url"),dq:Z(Wt(e[7].toBigInt()),"base64url"),qi:Z(Wt(e[8].toBigInt()),"base64url"),kty:"RSA",alg:"RS256"}}function Vh(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 A("JWK was missing components","ERR_INVALID_PARAMETERS");let e=new ft({value:[new ot({value:0}),ot.fromBigInt(Jt(z(r.n,"base64url"))),ot.fromBigInt(Jt(z(r.e,"base64url"))),ot.fromBigInt(Jt(z(r.d,"base64url"))),ot.fromBigInt(Jt(z(r.p,"base64url"))),ot.fromBigInt(Jt(z(r.q,"base64url"))),ot.fromBigInt(Jt(z(r.dp,"base64url"))),ot.fromBigInt(Jt(z(r.dq,"base64url"))),ot.fromBigInt(Jt(z(r.qi,"base64url")))]}).toBER();return new Uint8Array(e,0,e.byteLength)}function Oh(r){let{result:t}=kr(r),e=t.valueBlock.value[1].valueBlock.value[0].valueBlock.value;return{kty:"RSA",n:Z(Wt(e[0].toBigInt()),"base64url"),e:Z(Wt(e[1].toBigInt()),"base64url")}}function Mh(r){if(r.n==null||r.e==null)throw new A("JWK was missing components","ERR_INVALID_PARAMETERS");let e=new ft({value:[new ft({value:[new Ft({value:"1.2.840.113549.1.1.1"}),new Ne]}),new Ar({valueHex:new ft({value:[ot.fromBigInt(Jt(z(r.n,"base64url"))),ot.fromBigInt(Jt(z(r.e,"base64url")))]}).toBER()})]}).toBER();return new Uint8Array(e,0,e.byteLength)}function Wt(r){let t=r.toString(16);t.length%2>0&&(t=`0${t}`);let e=t.length/2,n=new Uint8Array(e),s=0,i=0;for(;s<e;)n[s]=parseInt(t.slice(i,i+2),16),s+=1,i+=2;return n}function Jt(r){let t=[];return r.forEach(function(e){let n=e.toString(16);n.length%2>0&&(n=`0${n}`),t.push(n)}),BigInt("0x"+t.join(""))}var Hh=16,to=32,eo=1e4;async function Kh(r,t){let e=W.get(),s=new ft({value:[new ot({value:0}),new ft({value:[new Ft({value:"1.2.840.113549.1.1.1"}),new Ne]}),new fe({valueHex:r.marshal()})]}).toBER(),i=new Uint8Array(s,0,s.byteLength),o=jt(Hh),a=await Zi(gr,t,o,{c:eo,dkLen:to}),c=jt(16),l=await e.subtle.importKey("raw",a,"AES-CBC",!1,["encrypt"]),f=await e.subtle.encrypt({name:"AES-CBC",iv:c},l,i),u=new ft({value:[new fe({valueHex:o}),new ot({value:eo}),new ot({value:to}),new ft({value:[new Ft({value:"1.2.840.113549.2.11"}),new Ne]})]}),p=new ft({value:[new Ft({value:"1.2.840.113549.1.5.13"}),new ft({value:[new ft({value:[new Ft({value:"1.2.840.113549.1.5.12"}),u]}),new ft({value:[new Ft({value:"2.16.840.1.101.3.4.1.42"}),new fe({valueHex:c})]})]})]}),g=new ft({value:[p,new fe({valueHex:f})]}).toBER(),h=new Uint8Array(g,0,g.byteLength);return["-----BEGIN ENCRYPTED PRIVATE KEY-----",...Z(h,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
|
7
|
-
`)}async function ro(r,t){let e=W.get(),n;if(r.includes("-----BEGIN ENCRYPTED PRIVATE KEY-----")){let s=z(r.replace("-----BEGIN ENCRYPTED PRIVATE KEY-----","").replace("-----END ENCRYPTED PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:i}=kr(s),{iv:o,salt:a,iterations:c,keySize:l,cipherText:f}=Fh(i),u=await Zi(gr,t,a,{c,dkLen:l}),p=await e.subtle.importKey("raw",u,"AES-CBC",!1,["decrypt"]),w=tn(await e.subtle.decrypt({name:"AES-CBC",iv:o},p,f)),{result:g}=kr(w);n=Vc(g)}else if(r.includes("-----BEGIN PRIVATE KEY-----")){let s=z(r.replace("-----BEGIN PRIVATE KEY-----","").replace("-----END PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:i}=kr(s);n=Vc(i)}else throw new A("Could not parse private key from PEM data","ERR_INVALID_PARAMETERS");return no(n)}function Fh(r){let t=r.valueBlock.value[0];if(t.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.13")throw new A("Only pkcs5PBES2 encrypted private keys are supported","ERR_INVALID_PARAMS");let n=t.valueBlock.value[1].valueBlock.value[0];if(n.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.12")throw new A("Only pkcs5PBKDF2 key derivation functions are supported","ERR_INVALID_PARAMS");let i=n.valueBlock.value[1],o=tn(i.valueBlock.value[0].getValue()),a=eo,c=to;if(i.valueBlock.value.length===3)a=Number(i.valueBlock.value[1].toBigInt()),c=Number(i.valueBlock.value[2].toBigInt());else if(i.valueBlock.value.length===2)throw new A("Could not derive key size and iterations from PEM file - please use @libp2p/rsa to re-import your key","ERR_INVALID_PARAMS");let l=t.valueBlock.value[1].valueBlock.value[1],f=l.valueBlock.value[0].toString();if(f!=="OBJECT IDENTIFIER : 1.2.840.113549.3.7"){if(f!=="OBJECT IDENTIFIER : 1.3.14.3.2.7"){if(f!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.2"){if(f!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.22"){if(f!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.42")throw new A("Only AES-CBC encryption schemes are supported","ERR_INVALID_PARAMS")}}}}let u=tn(l.valueBlock.value[1].getValue());return{cipherText:tn(r.valueBlock.value[1].getValue()),salt:o,iterations:a,keySize:c,iv:u}}function Vc(r){return tn(r.valueBlock.value[2].getValue())}function tn(r){return new Uint8Array(r,0,r.byteLength)}async function Oc(r){let t=await W.get().subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:r,publicExponent:new Uint8Array([1,0,1]),hash:{name:"SHA-256"}},!0,["sign","verify"]),e=await Kc(t);return{privateKey:e[0],publicKey:e[1]}}async function so(r){let e=[await W.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["sign"]),await qh(r)],n=await Kc({privateKey:e[0],publicKey:e[1]});return{privateKey:n[0],publicKey:n[1]}}async function Mc(r,t){let e=await W.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await W.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},e,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(n,0,n.byteLength)}async function Hc(r,t,e){let n=await W.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return W.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,t,e instanceof Uint8Array?e:e.subarray())}async function Kc(r){if(r.privateKey==null||r.publicKey==null)throw new A("Private and public key are required","ERR_INVALID_PARAMETERS");return Promise.all([W.get().subtle.exportKey("jwk",r.privateKey),W.get().subtle.exportKey("jwk",r.publicKey)])}async function qh(r){return W.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 xs(r){if(r.kty!=="RSA")throw new A("invalid key type","ERR_INVALID_KEY_TYPE");if(r.n==null)throw new A("invalid key modulus","ERR_INVALID_KEY_MODULUS");return z(r.n,"base64url").length*8}var $e=8192,qe=class{_key;constructor(t){this._key=t}verify(t,e){return Hc(this._key,e,t)}marshal(){return Re.jwkToPkix(this._key)}get bytes(){return Ht.encode({Type:j.RSA,Data:this.marshal()}).subarray()}equals(t){return mt(this.bytes,t.bytes)}hash(){let t=ct.digest(this.bytes);return Lt(t)?t.then(({bytes:e})=>e):t.bytes}},_e=class{_key;_publicKey;constructor(t,e){this._key=t,this._publicKey=e}genSecret(){return jt(16)}sign(t){return Mc(this._key,t)}get public(){if(this._publicKey==null)throw new A("public key not provided","ERR_PUBKEY_NOT_PROVIDED");return new qe(this._publicKey)}marshal(){return Re.jwkToPkcs1(this._key)}get bytes(){return Kt.encode({Type:j.RSA,Data:this.marshal()}).subarray()}equals(t){return mt(this.bytes,t.bytes)}hash(){let t=ct.digest(this.bytes);return Lt(t)?t.then(({bytes:e})=>e):t.bytes}async id(){let t=await this.public.hash();return Z(t,"base58btc")}async export(t,e="pkcs-8"){if(e==="pkcs-8")return Re.exportToPem(this,t);if(e==="libp2p-key")return wr(this.bytes,t);throw new A(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};async function no(r){let t=Re.pkcs1ToJwk(r);if(xs(t)>$e)throw new A("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await so(t);return new _e(e.privateKey,e.publicKey)}function Gh(r){let t=Re.pkixToJwk(r);if(xs(t)>$e)throw new A("key size is too large","ERR_KEY_SIZE_TOO_LARGE");return new qe(t)}async function zh(r){if(xs(r)>$e)throw new A("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await so(r);return new _e(t.privateKey,t.publicKey)}async function Yh(r){if(r>$e)throw new A("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await Oc(r);return new _e(t.privateKey,t.publicKey)}var lo={};it(lo,{Secp256k1PrivateKey:()=>Ye,Secp256k1PublicKey:()=>ze,generateKeyPair:()=>od,unmarshalSecp256k1PrivateKey:()=>sd,unmarshalSecp256k1PublicKey:()=>id});var jh=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]),Te=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),Ce=new Uint32Array(64),oo=class extends pr{constructor(){super(64,32,8,!1),this.A=Te[0]|0,this.B=Te[1]|0,this.C=Te[2]|0,this.D=Te[3]|0,this.E=Te[4]|0,this.F=Te[5]|0,this.G=Te[6]|0,this.H=Te[7]|0}get(){let{A:t,B:e,C:n,D:s,E:i,F:o,G:a,H:c}=this;return[t,e,n,s,i,o,a,c]}set(t,e,n,s,i,o,a,c){this.A=t|0,this.B=e|0,this.C=n|0,this.D=s|0,this.E=i|0,this.F=o|0,this.G=a|0,this.H=c|0}process(t,e){for(let u=0;u<16;u++,e+=4)Ce[u]=t.getUint32(e,!1);for(let u=16;u<64;u++){let p=Ce[u-15],w=Ce[u-2],g=Pt(p,7)^Pt(p,18)^p>>>3,h=Pt(w,17)^Pt(w,19)^w>>>10;Ce[u]=h+Ce[u-7]+g+Ce[u-16]|0}let{A:n,B:s,C:i,D:o,E:a,F:c,G:l,H:f}=this;for(let u=0;u<64;u++){let p=Pt(a,6)^Pt(a,11)^Pt(a,25),w=f+p+ca(a,c,l)+jh[u]+Ce[u]|0,h=(Pt(n,2)^Pt(n,13)^Pt(n,22))+ua(n,s,i)|0;f=l,l=c,c=a,a=o+w|0,o=i,i=s,s=n,n=w+h|0}n=n+this.A|0,s=s+this.B|0,i=i+this.C|0,o=o+this.D|0,a=a+this.E|0,c=c+this.F|0,l=l+this.G|0,f=f+this.H|0,this.set(n,s,i,o,a,c,l,f)}roundClean(){Ce.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var Fc=yn(()=>new oo);function Zh(r){let t=Fr(r);Yt(t,{a:"field",b:"field"},{allowedPrivateKeyLengths:"array",wrapPrivateKey:"boolean",isTorsionFree:"function",clearCofactor:"function",allowInfinityPoint:"boolean",fromBytes:"function",toBytes:"function"});let{endo:e,Fp:n,a:s}=t;if(e){if(!n.eql(s,n.ZERO))throw new Error("Endomorphism can only be defined for Koblitz curves that have a=0");if(typeof e!="object"||typeof e.beta!="bigint"||typeof e.splitScalar!="function")throw new Error("Expected endomorphism with beta: bigint and splitScalar: function")}return Object.freeze({...t})}var{bytesToNumberBE:Wh,hexToBytes:Jh}=xn,Ge={Err:class extends Error{constructor(t=""){super(t)}},_parseInt(r){let{Err:t}=Ge;if(r.length<2||r[0]!==2)throw new t("Invalid signature integer tag");let e=r[1],n=r.subarray(2,e+2);if(!e||n.length!==e)throw new t("Invalid signature integer: wrong length");if(n[0]&128)throw new t("Invalid signature integer: negative");if(n[0]===0&&!(n[1]&128))throw new t("Invalid signature integer: unnecessary leading zero");return{d:Wh(n),l:r.subarray(e+2)}},toSig(r){let{Err:t}=Ge,e=typeof r=="string"?Jh(r):r;mr(e);let n=e.length;if(n<2||e[0]!=48)throw new t("Invalid signature tag");if(e[1]!==n-2)throw new t("Invalid signature: incorrect length");let{d:s,l:i}=Ge._parseInt(e.subarray(2)),{d:o,l:a}=Ge._parseInt(i);if(a.length)throw new t("Invalid signature: left bytes after parsing");return{r:s,s:o}},hexFromSig(r){let t=l=>Number.parseInt(l[0],16)&8?"00"+l:l,e=l=>{let f=l.toString(16);return f.length&1?`0${f}`:f},n=t(e(r.s)),s=t(e(r.r)),i=n.length/2,o=s.length/2,a=e(i),c=e(o);return`30${e(o+i+4)}02${c}${s}02${a}${n}`}},ge=BigInt(0),Dt=BigInt(1),iy=BigInt(2),qc=BigInt(3),oy=BigInt(4);function Xh(r){let t=Zh(r),{Fp:e}=t,n=t.toBytes||((g,h,d)=>{let m=h.toAffine();return ie(Uint8Array.from([4]),e.toBytes(m.x),e.toBytes(m.y))}),s=t.fromBytes||(g=>{let h=g.subarray(1),d=e.fromBytes(h.subarray(0,e.BYTES)),m=e.fromBytes(h.subarray(e.BYTES,2*e.BYTES));return{x:d,y:m}});function i(g){let{a:h,b:d}=t,m=e.sqr(g),x=e.mul(m,g);return e.add(e.add(x,e.mul(g,h)),d)}if(!e.eql(e.sqr(t.Gy),i(t.Gx)))throw new Error("bad generator point: equation left != right");function o(g){return typeof g=="bigint"&&ge<g&&g<t.n}function a(g){if(!o(g))throw new Error("Expected valid bigint: 0 < bigint < curve.n")}function c(g){let{allowedPrivateKeyLengths:h,nByteLength:d,wrapPrivateKey:m,n:x}=t;if(h&&typeof g!="bigint"){if(ve(g)&&(g=ne(g)),typeof g!="string"||!h.includes(g.length))throw new Error("Invalid key");g=g.padStart(d*2,"0")}let b;try{b=typeof g=="bigint"?g:se(et("private key",g,d))}catch{throw new Error(`private key must be ${d} bytes, hex or bigint, not ${typeof g}`)}return m&&(b=Y(b,x)),a(b),b}let l=new Map;function f(g){if(!(g instanceof u))throw new Error("ProjectivePoint expected")}class u{constructor(h,d,m){if(this.px=h,this.py=d,this.pz=m,h==null||!e.isValid(h))throw new Error("x required");if(d==null||!e.isValid(d))throw new Error("y required");if(m==null||!e.isValid(m))throw new Error("z required")}static fromAffine(h){let{x:d,y:m}=h||{};if(!h||!e.isValid(d)||!e.isValid(m))throw new Error("invalid affine point");if(h instanceof u)throw new Error("projective point not allowed");let x=b=>e.eql(b,e.ZERO);return x(d)&&x(m)?u.ZERO:new u(d,m,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(h){let d=e.invertBatch(h.map(m=>m.pz));return h.map((m,x)=>m.toAffine(d[x])).map(u.fromAffine)}static fromHex(h){let d=u.fromAffine(s(et("pointHex",h)));return d.assertValidity(),d}static fromPrivateKey(h){return u.BASE.multiply(c(h))}_setWindowSize(h){this._WINDOW_SIZE=h,l.delete(this)}assertValidity(){if(this.is0()){if(t.allowInfinityPoint&&!e.is0(this.py))return;throw new Error("bad point: ZERO")}let{x:h,y:d}=this.toAffine();if(!e.isValid(h)||!e.isValid(d))throw new Error("bad point: x or y not FE");let m=e.sqr(d),x=i(h);if(!e.eql(m,x))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(e.isOdd)return!e.isOdd(h);throw new Error("Field doesn't support isOdd")}equals(h){f(h);let{px:d,py:m,pz:x}=this,{px:b,py:T,pz:E}=h,S=e.eql(e.mul(d,E),e.mul(b,x)),R=e.eql(e.mul(m,E),e.mul(T,x));return S&&R}negate(){return new u(this.px,e.neg(this.py),this.pz)}double(){let{a:h,b:d}=t,m=e.mul(d,qc),{px:x,py:b,pz:T}=this,E=e.ZERO,S=e.ZERO,R=e.ZERO,_=e.mul(x,x),$=e.mul(b,b),K=e.mul(T,T),D=e.mul(x,b);return D=e.add(D,D),R=e.mul(x,T),R=e.add(R,R),E=e.mul(h,R),S=e.mul(m,K),S=e.add(E,S),E=e.sub($,S),S=e.add($,S),S=e.mul(E,S),E=e.mul(D,E),R=e.mul(m,R),K=e.mul(h,K),D=e.sub(_,K),D=e.mul(h,D),D=e.add(D,R),R=e.add(_,_),_=e.add(R,_),_=e.add(_,K),_=e.mul(_,D),S=e.add(S,_),K=e.mul(b,T),K=e.add(K,K),_=e.mul(K,D),E=e.sub(E,_),R=e.mul(K,$),R=e.add(R,R),R=e.add(R,R),new u(E,S,R)}add(h){f(h);let{px:d,py:m,pz:x}=this,{px:b,py:T,pz:E}=h,S=e.ZERO,R=e.ZERO,_=e.ZERO,$=t.a,K=e.mul(t.b,qc),D=e.mul(d,b),nt=e.mul(m,T),rt=e.mul(x,E),Ct=e.add(d,m),v=e.add(b,T);Ct=e.mul(Ct,v),v=e.add(D,nt),Ct=e.sub(Ct,v),v=e.add(d,x);let N=e.add(b,E);return v=e.mul(v,N),N=e.add(D,rt),v=e.sub(v,N),N=e.add(m,x),S=e.add(T,E),N=e.mul(N,S),S=e.add(nt,rt),N=e.sub(N,S),_=e.mul($,v),S=e.mul(K,rt),_=e.add(S,_),S=e.sub(nt,_),_=e.add(nt,_),R=e.mul(S,_),nt=e.add(D,D),nt=e.add(nt,D),rt=e.mul($,rt),v=e.mul(K,v),nt=e.add(nt,rt),rt=e.sub(D,rt),rt=e.mul($,rt),v=e.add(v,rt),D=e.mul(nt,v),R=e.add(R,D),D=e.mul(N,v),S=e.mul(Ct,S),S=e.sub(S,D),D=e.mul(Ct,nt),_=e.mul(N,_),_=e.add(_,D),new u(S,R,_)}subtract(h){return this.add(h.negate())}is0(){return this.equals(u.ZERO)}wNAF(h){return w.wNAFCached(this,l,h,d=>{let m=e.invertBatch(d.map(x=>x.pz));return d.map((x,b)=>x.toAffine(m[b])).map(u.fromAffine)})}multiplyUnsafe(h){let d=u.ZERO;if(h===ge)return d;if(a(h),h===Dt)return this;let{endo:m}=t;if(!m)return w.unsafeLadder(this,h);let{k1neg:x,k1:b,k2neg:T,k2:E}=m.splitScalar(h),S=d,R=d,_=this;for(;b>ge||E>ge;)b&Dt&&(S=S.add(_)),E&Dt&&(R=R.add(_)),_=_.double(),b>>=Dt,E>>=Dt;return x&&(S=S.negate()),T&&(R=R.negate()),R=new u(e.mul(R.px,m.beta),R.py,R.pz),S.add(R)}multiply(h){a(h);let d=h,m,x,{endo:b}=t;if(b){let{k1neg:T,k1:E,k2neg:S,k2:R}=b.splitScalar(d),{p:_,f:$}=this.wNAF(E),{p:K,f:D}=this.wNAF(R);_=w.constTimeNegate(T,_),K=w.constTimeNegate(S,K),K=new u(e.mul(K.px,b.beta),K.py,K.pz),m=_.add(K),x=$.add(D)}else{let{p:T,f:E}=this.wNAF(d);m=T,x=E}return u.normalizeZ([m,x])[0]}multiplyAndAddUnsafe(h,d,m){let x=u.BASE,b=(E,S)=>S===ge||S===Dt||!E.equals(x)?E.multiplyUnsafe(S):E.multiply(S),T=b(this,d).add(b(h,m));return T.is0()?void 0:T}toAffine(h){let{px:d,py:m,pz:x}=this,b=this.is0();h==null&&(h=b?e.ONE:e.inv(x));let T=e.mul(d,h),E=e.mul(m,h),S=e.mul(x,h);if(b)return{x:e.ZERO,y:e.ZERO};if(!e.eql(S,e.ONE))throw new Error("invZ was invalid");return{x:T,y:E}}isTorsionFree(){let{h,isTorsionFree:d}=t;if(h===Dt)return!0;if(d)return d(u,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h,clearCofactor:d}=t;return h===Dt?this:d?d(u,this):this.multiplyUnsafe(t.h)}toRawBytes(h=!0){return this.assertValidity(),n(u,this,h)}toHex(h=!0){return ne(this.toRawBytes(h))}}u.BASE=new u(t.Gx,t.Gy,e.ONE),u.ZERO=new u(e.ZERO,e.ONE,e.ZERO);let p=t.nBitLength,w=Bn(u,t.endo?Math.ceil(p/2):p);return{CURVE:t,ProjectivePoint:u,normPrivateKeyToScalar:c,weierstrassEquation:i,isWithinCurveOrder:o}}function Qh(r){let t=Fr(r);return Yt(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function $c(r){let t=Qh(r),{Fp:e,n}=t,s=e.BYTES+1,i=2*e.BYTES+1;function o(v){return ge<v&&v<e.ORDER}function a(v){return Y(v,n)}function c(v){return En(v,n)}let{ProjectivePoint:l,normPrivateKeyToScalar:f,weierstrassEquation:u,isWithinCurveOrder:p}=Xh({...t,toBytes(v,N,P){let B=N.toAffine(),y=e.toBytes(B.x),I=ie;return P?I(Uint8Array.from([N.hasEvenY()?2:3]),y):I(Uint8Array.from([4]),y,e.toBytes(B.y))},fromBytes(v){let N=v.length,P=v[0],B=v.subarray(1);if(N===s&&(P===2||P===3)){let y=se(B);if(!o(y))throw new Error("Point is not on curve");let I=u(y),C;try{C=e.sqrt(I)}catch(O){let q=O instanceof Error?": "+O.message:"";throw new Error("Point is not on curve"+q)}let L=(C&Dt)===Dt;return(P&1)===1!==L&&(C=e.neg(C)),{x:y,y:C}}else if(N===i&&P===4){let y=e.fromBytes(B.subarray(0,e.BYTES)),I=e.fromBytes(B.subarray(e.BYTES,2*e.BYTES));return{x:y,y:I}}else throw new Error(`Point of length ${N} was invalid. Expected ${s} compressed bytes or ${i} uncompressed bytes`)}}),w=v=>ne(Ae(v,t.nByteLength));function g(v){let N=n>>Dt;return v>N}function h(v){return g(v)?a(-v):v}let d=(v,N,P)=>se(v.slice(N,P));class m{constructor(N,P,B){this.r=N,this.s=P,this.recovery=B,this.assertValidity()}static fromCompact(N){let P=t.nByteLength;return N=et("compactSignature",N,P*2),new m(d(N,0,P),d(N,P,2*P))}static fromDER(N){let{r:P,s:B}=Ge.toSig(et("DER",N));return new m(P,B)}assertValidity(){if(!p(this.r))throw new Error("r must be 0 < r < CURVE.n");if(!p(this.s))throw new Error("s must be 0 < s < CURVE.n")}addRecoveryBit(N){return new m(this.r,this.s,N)}recoverPublicKey(N){let{r:P,s:B,recovery:y}=this,I=R(et("msgHash",N));if(y==null||![0,1,2,3].includes(y))throw new Error("recovery id invalid");let C=y===2||y===3?P+t.n:P;if(C>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let L=y&1?"03":"02",V=l.fromHex(L+w(C)),O=c(C),q=a(-I*O),H=a(B*O),F=l.BASE.multiplyAndAddUnsafe(V,q,H);if(!F)throw new Error("point at infinify");return F.assertValidity(),F}hasHighS(){return g(this.s)}normalizeS(){return this.hasHighS()?new m(this.r,a(-this.s),this.recovery):this}toDERRawBytes(){return Pe(this.toDERHex())}toDERHex(){return Ge.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return Pe(this.toCompactHex())}toCompactHex(){return w(this.r)+w(this.s)}}let x={isValidPrivateKey(v){try{return f(v),!0}catch{return!1}},normPrivateKeyToScalar:f,randomPrivateKey:()=>{let v=Ei(t.n);return xa(t.randomBytes(v),t.n)},precompute(v=8,N=l.BASE){return N._setWindowSize(v),N.multiply(BigInt(3)),N}};function b(v,N=!0){return l.fromPrivateKey(v).toRawBytes(N)}function T(v){let N=ve(v),P=typeof v=="string",B=(N||P)&&v.length;return N?B===s||B===i:P?B===2*s||B===2*i:v instanceof l}function E(v,N,P=!0){if(T(v))throw new Error("first arg must be private key");if(!T(N))throw new Error("second arg must be public key");return l.fromHex(N).multiply(f(v)).toRawBytes(P)}let S=t.bits2int||function(v){let N=se(v),P=v.length*8-t.nBitLength;return P>0?N>>BigInt(P):N},R=t.bits2int_modN||function(v){return a(S(v))},_=Kr(t.nBitLength);function $(v){if(typeof v!="bigint")throw new Error("bigint expected");if(!(ge<=v&&v<_))throw new Error(`bigint expected < 2^${t.nBitLength}`);return Ae(v,t.nByteLength)}function K(v,N,P=D){if(["recovered","canonical"].some(Q=>Q in P))throw new Error("sign() legacy options not supported");let{hash:B,randomBytes:y}=t,{lowS:I,prehash:C,extraEntropy:L}=P;I==null&&(I=!0),v=et("msgHash",v),C&&(v=et("prehashed msgHash",B(v)));let V=R(v),O=f(N),q=[$(O),$(V)];if(L!=null&&L!==!1){let Q=L===!0?y(e.BYTES):L;q.push(et("extraEntropy",Q))}let H=ie(...q),F=V;function st(Q){let ht=S(Q);if(!p(ht))return;let dt=c(ht),at=l.BASE.multiply(ht).toAffine(),gt=a(at.x);if(gt===ge)return;let Xt=a(dt*a(F+gt*O));if(Xt===ge)return;let Ue=(at.x===gt?0:2)|Number(at.y&Dt),_r=Xt;return I&&g(Xt)&&(_r=h(Xt),Ue^=1),new m(gt,_r,Ue)}return{seed:H,k2sig:st}}let D={lowS:t.lowS,prehash:!1},nt={lowS:t.lowS,prehash:!1};function rt(v,N,P=D){let{seed:B,k2sig:y}=K(v,N,P),I=t;return yi(I.hash.outputLen,I.nByteLength,I.hmac)(B,y)}l.BASE._setWindowSize(8);function Ct(v,N,P,B=nt){let y=v;if(N=et("msgHash",N),P=et("publicKey",P),"strict"in B)throw new Error("options.strict was renamed to lowS");let{lowS:I,prehash:C}=B,L,V;try{if(typeof y=="string"||ve(y))try{L=m.fromDER(y)}catch(at){if(!(at instanceof Ge.Err))throw at;L=m.fromCompact(y)}else if(typeof y=="object"&&typeof y.r=="bigint"&&typeof y.s=="bigint"){let{r:at,s:gt}=y;L=new m(at,gt)}else throw new Error("PARSE");V=l.fromHex(P)}catch(at){if(at.message==="PARSE")throw new Error("signature must be Signature instance, Uint8Array or hex string");return!1}if(I&&L.hasHighS())return!1;C&&(N=t.hash(N));let{r:O,s:q}=L,H=R(N),F=c(q),st=a(H*F),Q=a(O*F),ht=l.BASE.multiplyAndAddUnsafe(V,st,Q)?.toAffine();return ht?a(ht.x)===O:!1}return{CURVE:t,getPublicKey:b,getSharedSecret:E,sign:rt,verify:Ct,ProjectivePoint:l,Signature:m,utils:x}}function td(r){return{hash:r,hmac:(t,...e)=>Gr(r,t,mn(...e)),randomBytes:dr}}function Gc(r,t){let e=n=>$c({...r,...td(n)});return Object.freeze({...e(t),create:e})}var jc=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),zc=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),ed=BigInt(1),ao=BigInt(2),Yc=(r,t)=>(r+t/ao)/t;function rd(r){let t=jc,e=BigInt(3),n=BigInt(6),s=BigInt(11),i=BigInt(22),o=BigInt(23),a=BigInt(44),c=BigInt(88),l=r*r*r%t,f=l*l*r%t,u=X(f,e,t)*f%t,p=X(u,e,t)*f%t,w=X(p,ao,t)*l%t,g=X(w,s,t)*w%t,h=X(g,i,t)*g%t,d=X(h,a,t)*h%t,m=X(d,c,t)*d%t,x=X(m,a,t)*h%t,b=X(x,e,t)*f%t,T=X(b,o,t)*g%t,E=X(T,n,t)*l%t,S=X(E,ao,t);if(!co.eql(co.sqr(S),r))throw new Error("Cannot find square root");return S}var co=vn(jc,void 0,void 0,{sqrt:rd}),$t=Gc({a:BigInt(0),b:BigInt(7),Fp:co,n:zc,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=zc,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-ed*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),s=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),i=e,o=BigInt("0x100000000000000000000000000000000"),a=Yc(i*r,t),c=Yc(-n*r,t),l=Y(r-a*e-c*s,t),f=Y(-a*n-c*i,t),u=l>o,p=f>o;if(u&&(l=t-l),p&&(f=t-f),l>o||f>o)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:u,k1:l,k2neg:p,k2:f}}}},Fc),gy=BigInt(0);var my=$t.ProjectivePoint;function Zc(){return $t.utils.randomPrivateKey()}function Wc(r,t){let e=ct.digest(t instanceof Uint8Array?t:t.subarray());if(Lt(e))return e.then(({digest:n})=>$t.sign(n,r).toDERRawBytes()).catch(n=>{throw new A(String(n),"ERR_INVALID_INPUT")});try{return $t.sign(e.digest,r).toDERRawBytes()}catch(n){throw new A(String(n),"ERR_INVALID_INPUT")}}function Jc(r,t,e){let n=ct.digest(e instanceof Uint8Array?e:e.subarray());if(Lt(n))return n.then(({digest:s})=>$t.verify(t,s,r)).catch(s=>{throw new A(String(s),"ERR_INVALID_INPUT")});try{return $t.verify(t,n.digest,r)}catch(s){throw new A(String(s),"ERR_INVALID_INPUT")}}function Xc(r){return $t.ProjectivePoint.fromHex(r).toRawBytes(!0)}function Qc(r){try{$t.getPublicKey(r,!0)}catch(t){throw new A(String(t),"ERR_INVALID_PRIVATE_KEY")}}function uo(r){try{$t.ProjectivePoint.fromHex(r)}catch(t){throw new A(String(t),"ERR_INVALID_PUBLIC_KEY")}}function tu(r){try{return $t.getPublicKey(r,!0)}catch(t){throw new A(String(t),"ERR_INVALID_PRIVATE_KEY")}}var ze=class{_key;constructor(t){uo(t),this._key=t}verify(t,e){return Jc(this._key,e,t)}marshal(){return Xc(this._key)}get bytes(){return Ht.encode({Type:j.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return mt(this.bytes,t.bytes)}async hash(){let t=ct.digest(this.bytes),e;return Lt(t)?{bytes:e}=await t:e=t.bytes,e}},Ye=class{_key;_publicKey;constructor(t,e){this._key=t,this._publicKey=e??tu(t),Qc(this._key),uo(this._publicKey)}sign(t){return Wc(this._key,t)}get public(){return new ze(this._publicKey)}marshal(){return this._key}get bytes(){return Kt.encode({Type:j.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return mt(this.bytes,t.bytes)}hash(){let t=ct.digest(this.bytes);return Lt(t)?t.then(({bytes:e})=>e):t.bytes}async id(){let t=await this.public.hash();return Z(t,"base58btc")}async export(t,e="libp2p-key"){if(e==="libp2p-key")return wr(this.bytes,t);throw new A(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function sd(r){return new Ye(r)}function id(r){return new ze(r)}async function od(){let r=Zc();return new Ye(r)}var me={rsa:io,ed25519:Yi,secp256k1:lo};function fo(r){let t=Object.keys(me).join(" / ");return new A(`invalid or unsupported key type ${r}. Must be ${t}`,"ERR_UNSUPPORTED_KEY_TYPE")}function ho(r){if(r=r.toLowerCase(),r==="rsa"||r==="ed25519"||r==="secp256k1")return me[r];throw fo(r)}async function ad(r,t){return ho(r).generateKeyPair(t??2048)}async function cd(r,t,e){if(r.toLowerCase()!=="ed25519")throw new A("Seed key derivation is unimplemented for RSA or secp256k1","ERR_UNSUPPORTED_KEY_DERIVATION_TYPE");return zi(t)}function ud(r){let t=Ht.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case j.RSA:return me.rsa.unmarshalRsaPublicKey(e);case j.Ed25519:return me.ed25519.unmarshalEd25519PublicKey(e);case j.Secp256k1:return me.secp256k1.unmarshalSecp256k1PublicKey(e);default:throw fo(t.Type??"unknown")}}function ld(r,t){return t=(t??"rsa").toLowerCase(),ho(t),r.bytes}async function eu(r){let t=Kt.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case j.RSA:return me.rsa.unmarshalRsaPrivateKey(e);case j.Ed25519:return me.ed25519.unmarshalEd25519PrivateKey(e);case j.Secp256k1:return me.secp256k1.unmarshalSecp256k1PrivateKey(e);default:throw fo(t.Type??"RSA")}}function fd(r,t){return t=(t??"rsa").toLowerCase(),ho(t),r.bytes}async function hd(r,t){try{let e=await Ya(r,t);return await eu(e)}catch{}if(!r.includes("BEGIN"))throw new A("Encrypted key was not a libp2p-key or a PEM file","ERR_INVALID_IMPORT_FORMAT");return ro(r,t)}var nu=Symbol.for("@achingbrain/uint8arraylist");function ru(r,t){if(t==null||t<0)throw new RangeError("index is out of bounds");let e=0;for(let n of r){let s=e+n.byteLength;if(t<s)return{buf:n,index:t-e};e=s}throw new RangeError("index is out of bounds")}function Es(r){return!!r?.[nu]}var Le=class r{bufs;length;[nu]=!0;constructor(...t){this.bufs=[],this.length=0,t.length>0&&this.appendAll(t)}*[Symbol.iterator](){yield*this.bufs}get byteLength(){return this.length}append(...t){this.appendAll(t)}appendAll(t){let e=0;for(let n of t)if(n instanceof Uint8Array)e+=n.byteLength,this.bufs.push(n);else if(Es(n))e+=n.byteLength,this.bufs.push(...n.bufs);else throw new Error("Could not append value, must be an Uint8Array or a Uint8ArrayList");this.length+=e}prepend(...t){this.prependAll(t)}prependAll(t){let e=0;for(let n of t.reverse())if(n instanceof Uint8Array)e+=n.byteLength,this.bufs.unshift(n);else if(Es(n))e+=n.byteLength,this.bufs.unshift(...n.bufs);else throw new Error("Could not prepend value, must be an Uint8Array or a Uint8ArrayList");this.length+=e}get(t){let e=ru(this.bufs,t);return e.buf[e.index]}set(t,e){let n=ru(this.bufs,t);n.buf[n.index]=e}write(t,e=0){if(t instanceof Uint8Array)for(let n=0;n<t.length;n++)this.set(e+n,t[n]);else if(Es(t))for(let n=0;n<t.length;n++)this.set(e+n,t.get(n));else throw new Error("Could not write value, must be an Uint8Array or a Uint8ArrayList")}consume(t){if(t=Math.trunc(t),!(Number.isNaN(t)||t<=0)){if(t===this.byteLength){this.bufs=[],this.length=0;return}for(;this.bufs.length>0;)if(t>=this.bufs[0].byteLength)t-=this.bufs[0].byteLength,this.length-=this.bufs[0].byteLength,this.bufs.shift();else{this.bufs[0]=this.bufs[0].subarray(t),this.length-=t;break}}}slice(t,e){let{bufs:n,length:s}=this._subList(t,e);return Bt(n,s)}subarray(t,e){let{bufs:n,length:s}=this._subList(t,e);return n.length===1?n[0]:Bt(n,s)}sublist(t,e){let{bufs:n,length:s}=this._subList(t,e),i=new r;return i.length=s,i.bufs=[...n],i}_subList(t,e){if(t=t??0,e=e??this.length,t<0&&(t=this.length+t),e<0&&(e=this.length+e),t<0||e>this.length)throw new RangeError("index is out of bounds");if(t===e)return{bufs:[],length:0};if(t===0&&e===this.length)return{bufs:this.bufs,length:this.length};let n=[],s=0;for(let i=0;i<this.bufs.length;i++){let o=this.bufs[i],a=s,c=a+o.byteLength;if(s=c,t>=c)continue;let l=t>=a&&t<c,f=e>a&&e<=c;if(l&&f){if(t===a&&e===c){n.push(o);break}let u=t-a;n.push(o.subarray(u,u+(e-t)));break}if(l){if(t===0){n.push(o);continue}n.push(o.subarray(t-a));continue}if(f){if(e===c){n.push(o);break}n.push(o.subarray(0,e-a));break}n.push(o)}return{bufs:n,length:e-t}}indexOf(t,e=0){if(!Es(t)&&!(t instanceof Uint8Array))throw new TypeError('The "value" argument must be a Uint8ArrayList or Uint8Array');let n=t instanceof Uint8Array?t:t.subarray();if(e=Number(e??0),isNaN(e)&&(e=0),e<0&&(e=this.length+e),e<0&&(e=0),t.length===0)return e>this.length?this.length:e;let s=n.byteLength;if(s===0)throw new TypeError("search must be at least 1 byte long");let i=256,o=new Int32Array(i);for(let u=0;u<i;u++)o[u]=-1;for(let u=0;u<s;u++)o[n[u]]=u;let a=o,c=this.byteLength-n.byteLength,l=n.byteLength-1,f;for(let u=e;u<=c;u+=f){f=0;for(let p=l;p>=0;p--){let w=this.get(u+p);if(n[p]!==w){f=Math.max(1,p-a[w]);break}}if(f===0)return u}return-1}getInt8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getInt8(0)}setInt8(t,e){let n=yt(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setInt8(0,e),this.write(n,t)}getInt16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt16(0,e)}setInt16(t,e,n){let s=ee(2);new DataView(s.buffer,s.byteOffset,s.byteLength).setInt16(0,e,n),this.write(s,t)}getInt32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt32(0,e)}setInt32(t,e,n){let s=ee(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setInt32(0,e,n),this.write(s,t)}getBigInt64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigInt64(0,e)}setBigInt64(t,e,n){let s=ee(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigInt64(0,e,n),this.write(s,t)}getUint8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getUint8(0)}setUint8(t,e){let n=yt(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setUint8(0,e),this.write(n,t)}getUint16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint16(0,e)}setUint16(t,e,n){let s=ee(2);new DataView(s.buffer,s.byteOffset,s.byteLength).setUint16(0,e,n),this.write(s,t)}getUint32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint32(0,e)}setUint32(t,e,n){let s=ee(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setUint32(0,e,n),this.write(s,t)}getBigUint64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigUint64(0,e)}setBigUint64(t,e,n){let s=ee(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigUint64(0,e,n),this.write(s,t)}getFloat32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat32(0,e)}setFloat32(t,e,n){let s=ee(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setFloat32(0,e,n),this.write(s,t)}getFloat64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat64(0,e)}setFloat64(t,e,n){let s=ee(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setFloat64(0,e,n),this.write(s,t)}equals(t){if(t==null||!(t instanceof r)||t.bufs.length!==this.bufs.length)return!1;for(let e=0;e<this.bufs.length;e++)if(!mt(this.bufs[e],t.bufs[e]))return!1;return!0}static fromUint8Arrays(t,e){let n=new r;return n.bufs=t,e==null&&(e=t.reduce((s,i)=>s+i.byteLength,0)),n.length=e,n}};function vs(){let r={};return r.promise=new Promise((t,e)=>{r.resolve=t,r.reject=e}),r}var Bs=class{buffer;mask;top;btm;next;constructor(t){if(!(t>0)||t-1&t)throw new Error("Max size for a FixedFIFO should be a power of two");this.buffer=new Array(t),this.mask=t-1,this.top=0,this.btm=0,this.next=null}push(t){return this.buffer[this.top]!==void 0?!1:(this.buffer[this.top]=t,this.top=this.top+1&this.mask,!0)}shift(){let t=this.buffer[this.btm];if(t!==void 0)return this.buffer[this.btm]=void 0,this.btm=this.btm+1&this.mask,t}isEmpty(){return this.buffer[this.btm]===void 0}},Ir=class{size;hwm;head;tail;constructor(t={}){this.hwm=t.splitLimit??16,this.head=new Bs(this.hwm),this.tail=this.head,this.size=0}calculateSize(t){return t?.byteLength!=null?t.byteLength:1}push(t){if(t?.value!=null&&(this.size+=this.calculateSize(t.value)),!this.head.push(t)){let e=this.head;this.head=e.next=new Bs(2*this.head.buffer.length),this.head.push(t)}}shift(){let t=this.tail.shift();if(t===void 0&&this.tail.next!=null){let e=this.tail.next;this.tail.next=null,this.tail=e,t=this.tail.shift()}return t?.value!=null&&(this.size-=this.calculateSize(t.value)),t}isEmpty(){return this.head.isEmpty()}};var po=class extends Error{type;code;constructor(t,e){super(t??"The operation was aborted"),this.type="aborted",this.code=e??"ABORT_ERR"}};function Nr(r={}){return dd(e=>{let n=e.shift();if(n==null)return{done:!0};if(n.error!=null)throw n.error;return{done:n.done===!0,value:n.value}},r)}function dd(r,t){t=t??{};let e=t.onEnd,n=new Ir,s,i,o,a=vs(),c=async()=>{try{return n.isEmpty()?o?{done:!0}:await new Promise((d,m)=>{i=x=>{i=null,n.push(x);try{d(r(n))}catch(b){m(b)}return s}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{a.resolve(),a=vs()})}},l=d=>i!=null?i(d):(n.push(d),s),f=d=>(n=new Ir,i!=null?i({error:d}):(n.push({error:d}),s)),u=d=>{if(o)return s;if(t?.objectMode!==!0&&d?.byteLength==null)throw new Error("objectMode was not true but tried to push non-Uint8Array value");return l({done:!1,value:d})},p=d=>o?s:(o=!0,d!=null?f(d):l({done:!0})),w=()=>(n=new Ir,p(),{done:!0}),g=d=>(p(d),{done:!0});if(s={[Symbol.asyncIterator](){return this},next:c,return:w,throw:g,push:u,end:p,get readableLength(){return n.size},onEmpty:async d=>{let m=d?.signal;if(m?.throwIfAborted(),n.isEmpty())return;let x,b;m!=null&&(x=new Promise((T,E)=>{b=()=>{E(new po)},m.addEventListener("abort",b)}));try{await Promise.race([a.promise,x])}finally{b!=null&&m!=null&&m?.removeEventListener("abort",b)}}},e==null)return s;let h=s;return s={[Symbol.asyncIterator](){return this},next(){return h.next()},throw(d){return h.throw(d),e!=null&&(e(d),e=void 0),{done:!0}},return(){return h.return(),e!=null&&(e(),e=void 0),{done:!0}},push:u,end(d){return h.end(d),e!=null&&(e(d),e=void 0),s},get readableLength(){return h.readableLength},onEmpty:d=>h.onEmpty(d)},s}function pd(r){return r[Symbol.asyncIterator]!=null}function gd(...r){let t=[];for(let e of r)pd(e)||t.push(e);return t.length===r.length?function*(){for(let e of t)yield*e}():async function*(){let e=Nr({objectMode:!0});Promise.resolve().then(async()=>{try{await Promise.all(r.map(async n=>{for await(let s of n)e.push(s)})),e.end()}catch(n){e.end(n)}}),yield*e}()}var su=gd;function rn(r,...t){if(r==null)throw new Error("Empty pipeline");if(go(r)){let n=r;r=()=>n.source}else if(ou(r)||iu(r)){let n=r;r=()=>n}let e=[r,...t];if(e.length>1&&go(e[e.length-1])&&(e[e.length-1]=e[e.length-1].sink),e.length>2)for(let n=1;n<e.length-1;n++)go(e[n])&&(e[n]=yd(e[n]));return md(...e)}var md=(...r)=>{let t;for(;r.length>0;)t=r.shift()(t);return t},iu=r=>r?.[Symbol.asyncIterator]!=null,ou=r=>r?.[Symbol.iterator]!=null,go=r=>r==null?!1:r.sink!=null&&r.source!=null,yd=r=>t=>{let e=r.sink(t);if(e?.then!=null){let n=Nr({objectMode:!0});e.then(()=>{n.end()},o=>{n.end(o)});let s,i=r.source;if(iu(i))s=async function*(){yield*i,n.end()};else if(ou(i))s=function*(){yield*i,n.end()};else throw new Error("Unknown duplex source type - must be Iterable or AsyncIterable");return su(n,s())}return r.source};var yo=Hs(cu(),1);var sn=class extends Error{constructor(t){super(t),this.name="TimeoutError"}},bo=class extends Error{constructor(t){super(),this.name="AbortError",this.message=t}},uu=r=>globalThis.DOMException===void 0?new bo(r):new DOMException(r),lu=r=>{let t=r.reason===void 0?uu("This operation was aborted."):r.reason;return t instanceof Error?t:uu(t)};function wo(r,t){let{milliseconds:e,fallback:n,message:s,customTimers:i={setTimeout,clearTimeout}}=t,o,c=new Promise((l,f)=>{if(typeof e!="number"||Math.sign(e)!==1)throw new TypeError(`Expected \`milliseconds\` to be a positive number, got \`${e}\``);if(t.signal){let{signal:p}=t;p.aborted&&f(lu(p)),p.addEventListener("abort",()=>{f(lu(p))})}if(e===Number.POSITIVE_INFINITY){r.then(l,f);return}let u=new sn;o=i.setTimeout.call(void 0,()=>{if(n){try{l(n())}catch(p){f(p)}return}typeof r.cancel=="function"&&r.cancel(),s===!1?l():s instanceof Error?f(s):(u.message=s??`Promise timed out after ${e} milliseconds`,f(u))},e),(async()=>{try{l(await r)}catch(p){f(p)}})()}).finally(()=>{c.clear()});return c.clear=()=>{i.clearTimeout.call(void 0,o),o=void 0},c}function xo(r,t,e){let n=0,s=r.length;for(;s>0;){let i=Math.trunc(s/2),o=n+i;e(r[o],t)<=0?(n=++o,s-=i+1):s=i}return n}var on=class{#t=[];enqueue(t,e){e={priority:0,...e};let n={priority:e.priority,run:t};if(this.size&&this.#t[this.size-1].priority>=e.priority){this.#t.push(n);return}let s=xo(this.#t,n,(i,o)=>o.priority-i.priority);this.#t.splice(s,0,n)}dequeue(){return this.#t.shift()?.run}filter(t){return this.#t.filter(e=>e.priority===t.priority).map(e=>e.run)}get size(){return this.#t.length}};var an=class extends yo.default{#t;#o;#i=0;#d;#a;#p=0;#r;#c;#e;#g;#n=0;#u;#s;#m;timeout;constructor(t){if(super(),t={carryoverConcurrencyCount:!1,intervalCap:Number.POSITIVE_INFINITY,interval:0,concurrency:Number.POSITIVE_INFINITY,autoStart:!0,queueClass:on,...t},!(typeof t.intervalCap=="number"&&t.intervalCap>=1))throw new TypeError(`Expected \`intervalCap\` to be a number from 1 and up, got \`${t.intervalCap?.toString()??""}\` (${typeof t.intervalCap})`);if(t.interval===void 0||!(Number.isFinite(t.interval)&&t.interval>=0))throw new TypeError(`Expected \`interval\` to be a finite number >= 0, got \`${t.interval?.toString()??""}\` (${typeof t.interval})`);this.#t=t.carryoverConcurrencyCount,this.#o=t.intervalCap===Number.POSITIVE_INFINITY||t.interval===0,this.#d=t.intervalCap,this.#a=t.interval,this.#e=new t.queueClass,this.#g=t.queueClass,this.concurrency=t.concurrency,this.timeout=t.timeout,this.#m=t.throwOnTimeout===!0,this.#s=t.autoStart===!1}get#w(){return this.#o||this.#i<this.#d}get#x(){return this.#n<this.#u}#E(){this.#n--,this.#l(),this.emit("next")}#v(){this.#b(),this.#y(),this.#c=void 0}get#B(){let t=Date.now();if(this.#r===void 0){let e=this.#p-t;if(e<0)this.#i=this.#t?this.#n:0;else return this.#c===void 0&&(this.#c=setTimeout(()=>{this.#v()},e)),!0}return!1}#l(){if(this.#e.size===0)return this.#r&&clearInterval(this.#r),this.#r=void 0,this.emit("empty"),this.#n===0&&this.emit("idle"),!1;if(!this.#s){let t=!this.#B;if(this.#w&&this.#x){let e=this.#e.dequeue();return e?(this.emit("active"),e(),t&&this.#y(),!0):!1}}return!1}#y(){this.#o||this.#r!==void 0||(this.#r=setInterval(()=>{this.#b()},this.#a),this.#p=Date.now()+this.#a)}#b(){this.#i===0&&this.#n===0&&this.#r&&(clearInterval(this.#r),this.#r=void 0),this.#i=this.#t?this.#n:0,this.#f()}#f(){for(;this.#l(););}get concurrency(){return this.#u}set concurrency(t){if(!(typeof t=="number"&&t>=1))throw new TypeError(`Expected \`concurrency\` to be a number from 1 and up, got \`${t}\` (${typeof t})`);this.#u=t,this.#f()}async#A(t){return new Promise((e,n)=>{t.addEventListener("abort",()=>{n(t.reason)},{once:!0})})}async add(t,e={}){return e={timeout:this.timeout,throwOnTimeout:this.#m,...e},new Promise((n,s)=>{this.#e.enqueue(async()=>{this.#n++,this.#i++;try{e.signal?.throwIfAborted();let i=t({signal:e.signal});e.timeout&&(i=wo(Promise.resolve(i),{milliseconds:e.timeout})),e.signal&&(i=Promise.race([i,this.#A(e.signal)]));let o=await i;n(o),this.emit("completed",o)}catch(i){if(i instanceof sn&&!e.throwOnTimeout){n();return}s(i),this.emit("error",i)}finally{this.#E()}},e),this.emit("add"),this.#l()})}async addAll(t,e){return Promise.all(t.map(async n=>this.add(n,e)))}start(){return this.#s?(this.#s=!1,this.#f(),this):this}pause(){this.#s=!0}clear(){this.#e=new this.#g}async onEmpty(){this.#e.size!==0&&await this.#h("empty")}async onSizeLessThan(t){this.#e.size<t||await this.#h("next",()=>this.#e.size<t)}async onIdle(){this.#n===0&&this.#e.size===0||await this.#h("idle")}async#h(t,e){return new Promise(n=>{let s=()=>{e&&!e()||(this.off(t,s),n())};this.on(t,s)})}get size(){return this.#e.size}sizeBy(t){return this.#e.filter(t).length}get pending(){return this.#n}get isPaused(){return this.#s}};var lt={ERR_INVALID_SIGNATURE_POLICY:"ERR_INVALID_SIGNATURE_POLICY",ERR_UNHANDLED_SIGNATURE_POLICY:"ERR_UNHANDLED_SIGNATURE_POLICY",ERR_MISSING_SIGNATURE:"ERR_MISSING_SIGNATURE",ERR_MISSING_SEQNO:"ERR_MISSING_SEQNO",ERR_MISSING_KEY:"ERR_MISSING_KEY",ERR_INVALID_SIGNATURE:"ERR_INVALID_SIGNATURE",ERR_MISSING_FROM:"ERR_MISSING_FROM",ERR_UNEXPECTED_FROM:"ERR_UNEXPECTED_FROM",ERR_UNEXPECTED_SIGNATURE:"ERR_UNEXPECTED_SIGNATURE",ERR_UNEXPECTED_KEY:"ERR_UNEXPECTED_KEY",ERR_UNEXPECTED_SEQNO:"ERR_UNEXPECTED_SEQNO",ERR_TOPIC_VALIDATOR_REJECT:"ERR_TOPIC_VALIDATOR_REJECT"};function fu(r){if(r!=null){if(typeof r[Symbol.iterator]=="function")return r[Symbol.iterator]();if(typeof r[Symbol.asyncIterator]=="function")return r[Symbol.asyncIterator]();if(typeof r.next=="function")return r}throw new Error("argument is not an iterator or iterable")}function hu(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function du(r,t){let e=fu(r).return?.();hu(e)&&e.catch(n=>{t.error("could not cause iterator to return",n)})}function Ss(r){return r[Symbol.asyncIterator]!=null}var ks=r=>{let t=Ot(r),e=yt(t);return Ta(r,e),ks.bytes=t,e};ks.bytes=0;function Is(r,t){t=t??{};let e=t.lengthEncoder??ks;function*n(s){let i=e(s.byteLength);i instanceof Uint8Array?yield i:yield*i,s instanceof Uint8Array?yield s:yield*s}return Ss(r)?async function*(){for await(let s of r)yield*n(s)}():function*(){for(let s of r)yield*n(s)}()}Is.single=(r,t)=>{t=t??{};let e=t.lengthEncoder??ks;return new Le(e(r.byteLength),r)};var Rr=Hs(mu(),1);var Ed=8,vd=1024*1024*4,je;(function(r){r[r.LENGTH=0]="LENGTH",r[r.DATA=1]="DATA"})(je||(je={}));var Eo=r=>{let t=Ca(r);return Eo.bytes=Ot(t),t};Eo.bytes=0;function cn(r,t){let e=new Le,n=je.LENGTH,s=-1,i=t?.lengthDecoder??Eo,o=t?.maxLengthLength??Ed,a=t?.maxDataLength??vd;function*c(){for(;e.byteLength>0;){if(n===je.LENGTH)try{if(s=i(e),s<0)throw(0,Rr.default)(new Error("invalid message length"),"ERR_INVALID_MSG_LENGTH");if(s>a)throw(0,Rr.default)(new Error("message length too long"),"ERR_MSG_DATA_TOO_LONG");let l=i.bytes;e.consume(l),t?.onLength!=null&&t.onLength(s),n=je.DATA}catch(l){if(l instanceof RangeError){if(e.byteLength>o)throw(0,Rr.default)(new Error("message length length too long"),"ERR_MSG_LENGTH_TOO_LONG");break}throw l}if(n===je.DATA){if(e.byteLength<s)break;let l=e.sublist(0,s);e.consume(s),t?.onData!=null&&t.onData(l),yield l,n=je.LENGTH}}}return Ss(r)?async function*(){for await(let l of r)e.append(l),yield*c();if(e.byteLength>0)throw(0,Rr.default)(new Error("unexpected end of input"),"ERR_UNEXPECTED_EOF")}():function*(){for(let l of r)e.append(l),yield*c();if(e.byteLength>0)throw(0,Rr.default)(new Error("unexpected end of input"),"ERR_UNEXPECTED_EOF")}()}cn.fromReader=(r,t)=>{let e=1,n=async function*(){for(;;)try{let{done:i,value:o}=await r.next(e);if(i===!0)return;o!=null&&(yield o)}catch(i){if(i.code==="ERR_UNDER_READ")return{done:!0,value:null};throw i}finally{e=1}}();return cn(n,{...t??{},onLength:i=>{e=i}})};var Ns=class extends We{id;protocol;outboundStream;inboundStream;_rawOutboundStream;_rawInboundStream;_inboundAbortController;closed;log;constructor(t,e){super(),this.log=t.logger.forComponent("libp2p-pubsub:peer-streams"),this.id=e.id,this.protocol=e.protocol,this._inboundAbortController=new AbortController,this.closed=!1}get isReadable(){return!!this.inboundStream}get isWritable(){return!!this.outboundStream}write(t){if(this.outboundStream==null){let e=this.id.toString();throw new Error("No writable connection to "+e)}this.outboundStream.push(t instanceof Uint8Array?new Le(t):t)}attachInboundStream(t){let e=()=>{du(t.source,this.log)};return this._inboundAbortController.signal.addEventListener("abort",e,{once:!0}),this._rawInboundStream=t,this.inboundStream=rn(this._rawInboundStream,n=>cn(n)),this.dispatchEvent(new Gt("stream:inbound")),this.inboundStream}async attachOutboundStream(t){let e=this.outboundStream;return this.outboundStream!=null&&this.outboundStream.end(),this._rawOutboundStream=t,this.outboundStream=Nr({onEnd:n=>{this._rawOutboundStream!=null&&this._rawOutboundStream.closeWrite().catch(s=>{this.log("error closing outbound stream",s)}),this._rawOutboundStream=void 0,this.outboundStream=void 0,n!=null&&this.dispatchEvent(new Gt("close"))}}),rn(this.outboundStream,n=>Is(n),this._rawOutboundStream).catch(n=>{this.log.error(n)}),e==null&&this.dispatchEvent(new Gt("stream:outbound")),this.outboundStream}close(){this.closed||(this.closed=!0,this.outboundStream!=null&&this.outboundStream.end(),this.inboundStream!=null&&this._inboundAbortController.abort(),this._rawOutboundStream=void 0,this.outboundStream=void 0,this._rawInboundStream=void 0,this.inboundStream=void 0,this.dispatchEvent(new Gt("close")))}};function yu(){return BigInt(`0x${Z(jt(8),"base16")}`)}var bu=(r,t)=>{let e=z(t.toString(16).padStart(16,"0"),"base16"),n=new Uint8Array(r.length+e.length);return n.set(r,0),n.set(e,r.length),n},wu=r=>ct.encode(r);var xu=function(r){return Array.isArray(r)?r:[r]},Ad=async r=>{if(r.sequenceNumber==null||r.from==null||r.signature==null)return!1;let t=Or(r.from);return t.publicKey!=null?!0:r.key!=null?(await hn(r.key)).equals(t):!1},Eu=async r=>{if(r.from==null)throw new A("RPC message was missing from",lt.ERR_MISSING_FROM);if(!await Ad(r))return{type:"unsigned",topic:r.topic??"",data:r.data??new Uint8Array(0)};let t=Or(r.from),e={type:"signed",from:Or(r.from),topic:r.topic??"",sequenceNumber:kd(r.sequenceNumber??new Uint8Array(0)),data:r.data??new Uint8Array(0),signature:r.signature??new Uint8Array(0),key:r.key??t.publicKey??new Uint8Array(0)};if(e.key.length===0)throw new A("Signed RPC message was missing key",lt.ERR_MISSING_KEY);return e},un=r=>r.type==="signed"?{from:r.from.multihash.bytes,data:r.data,sequenceNumber:Sd(r.sequenceNumber),topic:r.topic,signature:r.signature,key:r.key}:{data:r.data,topic:r.topic},Sd=r=>{let t=r.toString(16);return t.length%2!==0&&(t=`0${t}`),z(t,"base16")},kd=r=>BigInt(`0x${Z(r,"base16")}`);var vu=z("libp2p-pubsub:");async function Bu(r,t,e){if(r.privateKey==null)throw new Error("Cannot sign message, no private key present");if(r.publicKey==null)throw new Error("Cannot sign message, no public key present");let n={type:"signed",topic:t.topic,data:t.data,sequenceNumber:t.sequenceNumber,from:r},s=Bt([vu,e(un(n)).subarray()]),i=await en.unmarshalPrivateKey(r.privateKey);return n.signature=await i.sign(s),n.key=r.publicKey,n}async function Au(r,t){if(r.type!=="signed")throw new Error('Message type must be "signed" to be verified');if(r.signature==null)throw new Error("Message must contain a signature to be verified");if(r.from==null)throw new Error("Message must contain a from property to be verified");let e=Bt([vu,t({...un(r),signature:void 0,key:void 0}).subarray()]),n=await Id(r);return en.unmarshalPublicKey(n).verify(e,r.signature)}async function Id(r){if(r.type!=="signed")throw new Error('Message type must be "signed" to have a public key');if(r.from==null)throw new Error("Could not get the public key from the originator id");if(r.key!=null){let t=await hn(r.key);if(t.publicKey!=null)return t.publicKey}if(r.from.publicKey!=null)return r.from.publicKey;throw new Error("Could not get the public key from the originator id")}var Rs=class extends We{log;started;topics;subscriptions;peers;globalSignaturePolicy;canRelayMessage;emitSelf;topicValidators;queue;multicodecs;components;_registrarTopologyIds;enabled;maxInboundStreams;maxOutboundStreams;constructor(t,e){super();let{multicodecs:n=[],globalSignaturePolicy:s="StrictSign",canRelayMessage:i=!1,emitSelf:o=!1,messageProcessingConcurrency:a=10,maxInboundStreams:c=1,maxOutboundStreams:l=1}=e;this.log=t.logger.forComponent("libp2p:pubsub"),this.components=t,this.multicodecs=xu(n),this.enabled=e.enabled!==!1,this.started=!1,this.topics=new Map,this.subscriptions=new Set,this.peers=new Mr,this.globalSignaturePolicy=s==="StrictNoSign"?"StrictNoSign":"StrictSign",this.canRelayMessage=i,this.emitSelf=o,this.topicValidators=new Map,this.queue=new an({concurrency:a}),this.maxInboundStreams=c,this.maxOutboundStreams=l,this._onIncomingStream=this._onIncomingStream.bind(this),this._onPeerConnected=this._onPeerConnected.bind(this),this._onPeerDisconnected=this._onPeerDisconnected.bind(this)}async start(){if(this.started||!this.enabled)return;this.log("starting");let t=this.components.registrar;await Promise.all(this.multicodecs.map(async n=>{await t.handle(n,this._onIncomingStream,{maxInboundStreams:this.maxInboundStreams,maxOutboundStreams:this.maxOutboundStreams})}));let e={onConnect:this._onPeerConnected,onDisconnect:this._onPeerDisconnected};this._registrarTopologyIds=await Promise.all(this.multicodecs.map(async n=>t.register(n,e))),this.log("started"),this.started=!0}async stop(){if(!this.started||!this.enabled)return;let t=this.components.registrar;this._registrarTopologyIds!=null&&this._registrarTopologyIds?.forEach(e=>{t.unregister(e)}),await Promise.all(this.multicodecs.map(async e=>{await t.unhandle(e)})),this.log("stopping");for(let e of this.peers.values())e.close();this.peers.clear(),this.subscriptions=new Set,this.started=!1,this.log("stopped")}isStarted(){return this.started}_onIncomingStream(t){let{stream:e,connection:n}=t,s=n.remotePeer;if(e.protocol==null){e.abort(new Error("Stream was not multiplexed"));return}let i=this.addPeer(s,e.protocol),o=i.attachInboundStream(e);this.processMessages(s,o,i).catch(a=>{this.log(a)})}_onPeerConnected(t,e){if(this.log("connected %p",t),e.streams.find(n=>n.direction==="outbound"&&n.protocol!=null&&this.multicodecs.includes(n.protocol))!=null){this.log("outbound pubsub streams already present on connection from %p",t);return}Promise.resolve().then(async()=>{try{let n=await e.newStream(this.multicodecs);if(n.protocol==null){n.abort(new Error("Stream was not multiplexed"));return}await this.addPeer(t,n.protocol).attachOutboundStream(n)}catch(n){this.log.error(n)}this.send(t,{subscriptions:Array.from(this.subscriptions).map(n=>n.toString()),subscribe:!0})}).catch(n=>{this.log.error(n)})}_onPeerDisconnected(t,e){let n=t.toString();this.log("connection ended",n),this._removePeer(t)}addPeer(t,e){let n=this.peers.get(t);if(n!=null)return n;this.log("new peer %p",t);let s=new Ns(this.components,{id:t,protocol:e});return this.peers.set(t,s),s.addEventListener("close",()=>this._removePeer(t),{once:!0}),s}_removePeer(t){let e=this.peers.get(t);if(e!=null){e.close(),this.log("delete peer %p",t),this.peers.delete(t);for(let n of this.topics.values())n.delete(t);return e}}async processMessages(t,e,n){try{await rn(e,async s=>{for await(let i of s){let o=this.decodeRpc(i),a=[];for(let c of o.messages??[]){if(c.from==null||c.data==null||c.topic==null){this.log("message from %p was missing from, data or topic fields, dropping",t);continue}a.push({from:c.from,data:c.data,topic:c.topic,sequenceNumber:c.sequenceNumber??void 0,signature:c.signature??void 0,key:c.key??void 0})}this.processRpc(t,n,{subscriptions:(o.subscriptions??[]).map(c=>({subscribe:!!c.subscribe,topic:c.topic??""})),messages:a}).catch(c=>{this.log(c)})}})}catch(s){this._onPeerDisconnected(n.id,s)}}async processRpc(t,e,n){if(!this.acceptFrom(t))return this.log("received message from unacceptable peer %p",t),!1;this.log("rpc from %p",t);let{subscriptions:s,messages:i}=n;return s!=null&&s.length>0&&(this.log("subscription update from %p",t),s.forEach(o=>{this.processRpcSubOpt(t,o)}),super.dispatchEvent(new Gt("subscription-change",{detail:{peerId:e.id,subscriptions:s.map(({topic:o,subscribe:a})=>({topic:`${o??""}`,subscribe:!!a}))}}))),i!=null&&i.length>0&&(this.log("messages from %p",t),this.queue.addAll(i.map(o=>async()=>{if(o.topic==null||!this.subscriptions.has(o.topic)&&!this.canRelayMessage)return this.log("received message we didn't subscribe to. Dropping."),!1;try{let a=await Eu(o);await this.processMessage(t,a)}catch(a){this.log.error(a)}})).catch(o=>{this.log(o)})),!0}processRpcSubOpt(t,e){let n=e.topic;if(n==null)return;let s=this.topics.get(n);s==null&&(s=new Hr,this.topics.set(n,s)),e.subscribe===!0?s.add(t):s.delete(t)}async processMessage(t,e){if(!(this.components.peerId.equals(t)&&!this.emitSelf)){try{await this.validate(t,e)}catch(n){this.log("Message is invalid, dropping it. %O",n);return}this.subscriptions.has(e.topic)&&(!this.components.peerId.equals(t)||this.emitSelf)&&super.dispatchEvent(new Gt("message",{detail:e})),await this.publishMessage(t,e)}}getMsgId(t){switch(this.globalSignaturePolicy){case"StrictSign":if(t.type!=="signed")throw new A('Message type should be "signed" when signature policy is StrictSign but it was not',lt.ERR_MISSING_SIGNATURE);if(t.sequenceNumber==null)throw new A("Need seqno when signature policy is StrictSign but it was missing",lt.ERR_MISSING_SEQNO);if(t.key==null)throw new A("Need key when signature policy is StrictSign but it was missing",lt.ERR_MISSING_KEY);return bu(t.key,t.sequenceNumber);case"StrictNoSign":return wu(t.data);default:throw new A("Cannot get message id: unhandled signature policy",lt.ERR_UNHANDLED_SIGNATURE_POLICY)}}acceptFrom(t){return!0}send(t,e){let{messages:n,subscriptions:s,subscribe:i}=e;this.sendRpc(t,{subscriptions:(s??[]).map(o=>({topic:o,subscribe:!!i})),messages:(n??[]).map(un)})}sendRpc(t,e){let n=this.peers.get(t);if(n==null){this.log.error("Cannot send RPC to %p as there are no streams to it available",t);return}if(!n.isWritable){this.log.error("Cannot send RPC to %p as there is no outbound stream to it available",t);return}n.write(this.encodeRpc(e))}async validate(t,e){switch(this.globalSignaturePolicy){case"StrictNoSign":if(e.type!=="unsigned")throw new A('Message type should be "unsigned" when signature policy is StrictNoSign but it was not',lt.ERR_MISSING_SIGNATURE);if(e.signature!=null)throw new A("StrictNoSigning: signature should not be present",lt.ERR_UNEXPECTED_SIGNATURE);if(e.key!=null)throw new A("StrictNoSigning: key should not be present",lt.ERR_UNEXPECTED_KEY);if(e.sequenceNumber!=null)throw new A("StrictNoSigning: seqno should not be present",lt.ERR_UNEXPECTED_SEQNO);break;case"StrictSign":if(e.type!=="signed")throw new A('Message type should be "signed" when signature policy is StrictSign but it was not',lt.ERR_MISSING_SIGNATURE);if(e.signature==null)throw new A("StrictSigning: Signing required and no signature was present",lt.ERR_MISSING_SIGNATURE);if(e.sequenceNumber==null)throw new A("StrictSigning: Signing required and no sequenceNumber was present",lt.ERR_MISSING_SEQNO);if(!await Au(e,this.encodeMessage.bind(this)))throw new A("StrictSigning: Invalid message signature",lt.ERR_INVALID_SIGNATURE);break;default:throw new A("Cannot validate message: unhandled signature policy",lt.ERR_UNHANDLED_SIGNATURE_POLICY)}let s=this.topicValidators.get(e.topic);if(s!=null){let i=await s(t,e);if(i===Tr.Reject||i===Tr.Ignore)throw new A("Message validation failed",lt.ERR_TOPIC_VALIDATOR_REJECT)}}async buildMessage(t){switch(this.globalSignaturePolicy){case"StrictSign":return Bu(this.components.peerId,t,this.encodeMessage.bind(this));case"StrictNoSign":return Promise.resolve({type:"unsigned",...t});default:throw new A("Cannot build message: unhandled signature policy",lt.ERR_UNHANDLED_SIGNATURE_POLICY)}}getSubscribers(t){if(!this.started)throw new A("not started yet","ERR_NOT_STARTED_YET");if(t==null)throw new A("topic is required","ERR_NOT_VALID_TOPIC");let e=this.topics.get(t.toString());return e==null?[]:Array.from(e.values())}async publish(t,e){if(!this.started)throw new Error("Pubsub has not started");let n={from:this.components.peerId,topic:t,data:e??new Uint8Array(0),sequenceNumber:yu()};this.log("publish topic: %s from: %p data: %m",t,n.from,n.data);let s=await this.buildMessage(n),i=!1;this.emitSelf&&this.subscriptions.has(t)&&(i=!0,super.dispatchEvent(new Gt("message",{detail:s})));let o=await this.publishMessage(this.components.peerId,s);return i&&(o.recipients=[...o.recipients,this.components.peerId]),o}subscribe(t){if(!this.started)throw new Error("Pubsub has not started");if(this.log("subscribe to topic: %s",t),!this.subscriptions.has(t)){this.subscriptions.add(t);for(let e of this.peers.keys())this.send(e,{subscriptions:[t],subscribe:!0})}}unsubscribe(t){if(!this.started)throw new Error("Pubsub is not started");super.removeEventListener(t);let e=this.subscriptions.has(t);if(this.log("unsubscribe from %s - am subscribed %s",t,e),e){this.subscriptions.delete(t);for(let n of this.peers.keys())this.send(n,{subscriptions:[t],subscribe:!1})}}getTopics(){if(!this.started)throw new Error("Pubsub is not started");return Array.from(this.subscriptions)}getPeers(){if(!this.started)throw new Error("Pubsub is not started");return Array.from(this.peers.keys())}};var _s=class{entries;validityMs;lastPruneTime=0;constructor(t){this.entries=new Map,this.validityMs=t.validityMs}put(t,e){this.entries.set(t,{value:e,validUntilMs:Date.now()+this.validityMs}),this.prune()}prune(){let t=Date.now();if(!(t-this.lastPruneTime<200)){this.lastPruneTime=t;for(let[e,n]of this.entries.entries())if(n.validUntilMs<t)this.entries.delete(e);else break}}has(t){return this.entries.has(t)}get(t){let e=this.entries.get(t);return e!=null&&e.validUntilMs>=Date.now()?e.value:void 0}clear(){this.entries=new Map,this.lastPruneTime=0}};var vo="/floodsub/1.0.0";var Ze;(function(r){let t;(function(s){let i;s.codec=()=>(i==null&&(i=Nt((o,a,c={})=>{c.lengthDelimited!==!1&&a.fork(),o.subscribe!=null&&(a.uint32(8),a.bool(o.subscribe)),o.topic!=null&&(a.uint32(18),a.string(o.topic)),c.lengthDelimited!==!1&&a.ldelim()},(o,a)=>{let c={},l=a==null?o.len:o.pos+a;for(;o.pos<l;){let f=o.uint32();switch(f>>>3){case 1:c.subscribe=o.bool();break;case 2:c.topic=o.string();break;default:o.skipType(f&7);break}}return c})),i),s.encode=o=>It(o,s.codec()),s.decode=o=>kt(o,s.codec())})(t=r.SubOpts||(r.SubOpts={}));let e;(function(s){let i;s.codec=()=>(i==null&&(i=Nt((o,a,c={})=>{c.lengthDelimited!==!1&&a.fork(),o.from!=null&&(a.uint32(10),a.bytes(o.from)),o.data!=null&&(a.uint32(18),a.bytes(o.data)),o.sequenceNumber!=null&&(a.uint32(26),a.bytes(o.sequenceNumber)),o.topic!=null&&(a.uint32(34),a.string(o.topic)),o.signature!=null&&(a.uint32(42),a.bytes(o.signature)),o.key!=null&&(a.uint32(50),a.bytes(o.key)),c.lengthDelimited!==!1&&a.ldelim()},(o,a)=>{let c={},l=a==null?o.len:o.pos+a;for(;o.pos<l;){let f=o.uint32();switch(f>>>3){case 1:c.from=o.bytes();break;case 2:c.data=o.bytes();break;case 3:c.sequenceNumber=o.bytes();break;case 4:c.topic=o.string();break;case 5:c.signature=o.bytes();break;case 6:c.key=o.bytes();break;default:o.skipType(f&7);break}}return c})),i),s.encode=o=>It(o,s.codec()),s.decode=o=>kt(o,s.codec())})(e=r.Message||(r.Message={}));let n;r.codec=()=>(n==null&&(n=Nt((s,i,o={})=>{if(o.lengthDelimited!==!1&&i.fork(),s.subscriptions!=null)for(let a of s.subscriptions)i.uint32(10),r.SubOpts.codec().encode(a,i);if(s.messages!=null)for(let a of s.messages)i.uint32(18),r.Message.codec().encode(a,i);s.control!=null&&(i.uint32(26),Ts.codec().encode(s.control,i)),o.lengthDelimited!==!1&&i.ldelim()},(s,i)=>{let o={subscriptions:[],messages:[]},a=i==null?s.len:s.pos+i;for(;s.pos<a;){let c=s.uint32();switch(c>>>3){case 1:o.subscriptions.push(r.SubOpts.codec().decode(s,s.uint32()));break;case 2:o.messages.push(r.Message.codec().decode(s,s.uint32()));break;case 3:o.control=Ts.codec().decode(s,s.uint32());break;default:s.skipType(c&7);break}}return o})),n),r.encode=s=>It(s,r.codec()),r.decode=s=>kt(s,r.codec())})(Ze||(Ze={}));var Ts;(function(r){let t;r.codec=()=>(t==null&&(t=Nt((e,n,s={})=>{if(s.lengthDelimited!==!1&&n.fork(),e.ihave!=null)for(let i of e.ihave)n.uint32(10),Cs.codec().encode(i,n);if(e.iwant!=null)for(let i of e.iwant)n.uint32(18),Ls.codec().encode(i,n);if(e.graft!=null)for(let i of e.graft)n.uint32(26),Us.codec().encode(i,n);if(e.prune!=null)for(let i of e.prune)n.uint32(34),Ds.codec().encode(i,n);s.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let s={ihave:[],iwant:[],graft:[],prune:[]},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let o=e.uint32();switch(o>>>3){case 1:s.ihave.push(Cs.codec().decode(e,e.uint32()));break;case 2:s.iwant.push(Ls.codec().decode(e,e.uint32()));break;case 3:s.graft.push(Us.codec().decode(e,e.uint32()));break;case 4:s.prune.push(Ds.codec().decode(e,e.uint32()));break;default:e.skipType(o&7);break}}return s})),t),r.encode=e=>It(e,r.codec()),r.decode=e=>kt(e,r.codec())})(Ts||(Ts={}));var Cs;(function(r){let t;r.codec=()=>(t==null&&(t=Nt((e,n,s={})=>{if(s.lengthDelimited!==!1&&n.fork(),e.topic!=null&&(n.uint32(10),n.string(e.topic)),e.messageIDs!=null)for(let i of e.messageIDs)n.uint32(18),n.bytes(i);s.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let s={messageIDs:[]},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let o=e.uint32();switch(o>>>3){case 1:s.topic=e.string();break;case 2:s.messageIDs.push(e.bytes());break;default:e.skipType(o&7);break}}return s})),t),r.encode=e=>It(e,r.codec()),r.decode=e=>kt(e,r.codec())})(Cs||(Cs={}));var Ls;(function(r){let t;r.codec=()=>(t==null&&(t=Nt((e,n,s={})=>{if(s.lengthDelimited!==!1&&n.fork(),e.messageIDs!=null)for(let i of e.messageIDs)n.uint32(10),n.bytes(i);s.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let s={messageIDs:[]},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let o=e.uint32();switch(o>>>3){case 1:s.messageIDs.push(e.bytes());break;default:e.skipType(o&7);break}}return s})),t),r.encode=e=>It(e,r.codec()),r.decode=e=>kt(e,r.codec())})(Ls||(Ls={}));var Us;(function(r){let t;r.codec=()=>(t==null&&(t=Nt((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.topic!=null&&(n.uint32(10),n.string(e.topic)),s.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let s={},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let o=e.uint32();switch(o>>>3){case 1:s.topic=e.string();break;default:e.skipType(o&7);break}}return s})),t),r.encode=e=>It(e,r.codec()),r.decode=e=>kt(e,r.codec())})(Us||(Us={}));var Ds;(function(r){let t;r.codec=()=>(t==null&&(t=Nt((e,n,s={})=>{if(s.lengthDelimited!==!1&&n.fork(),e.topic!=null&&(n.uint32(10),n.string(e.topic)),e.peers!=null)for(let i of e.peers)n.uint32(18),Ps.codec().encode(i,n);e.backoff!=null&&(n.uint32(24),n.uint64(e.backoff)),s.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let s={peers:[]},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let o=e.uint32();switch(o>>>3){case 1:s.topic=e.string();break;case 2:s.peers.push(Ps.codec().decode(e,e.uint32()));break;case 3:s.backoff=e.uint64();break;default:e.skipType(o&7);break}}return s})),t),r.encode=e=>It(e,r.codec()),r.decode=e=>kt(e,r.codec())})(Ds||(Ds={}));var Ps;(function(r){let t;r.codec=()=>(t==null&&(t=Nt((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.peerID!=null&&(n.uint32(10),n.bytes(e.peerID)),e.signedPeerRecord!=null&&(n.uint32(18),n.bytes(e.signedPeerRecord)),s.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let s={},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let o=e.uint32();switch(o>>>3){case 1:s.peerID=e.bytes();break;case 2:s.signedPeerRecord=e.bytes();break;default:e.skipType(o&7);break}}return s})),t),r.encode=e=>It(e,r.codec()),r.decode=e=>kt(e,r.codec())})(Ps||(Ps={}));var Vs=class extends Rs{seenCache;constructor(t,e){super(t,{...e,canRelayMessage:!0,multicodecs:[vo]}),this.log=t.logger.forComponent("libp2p:floodsub"),this.seenCache=new _s({validityMs:e?.seenTTL??3e4})}[Symbol.toStringTag]="@libp2p/floodsub";[Uo]=["@libp2p/identify"];decodeRpc(t){return Ze.decode(t)}encodeRpc(t){return Ze.encode(t)}decodeMessage(t){return Ze.Message.decode(t)}encodeMessage(t){return Ze.Message.encode(t)}async processMessage(t,e){let n=await super.getMsgId(e),s=Z(n,"base64");this.seenCache.has(s)||(this.seenCache.put(s,!0),await super.processMessage(t,e))}async publishMessage(t,e){let n=this.getSubscribers(e.topic),s=[];return n==null||n.length===0?(this.log("no peers are subscribed to topic %s",e.topic),{recipients:s}):(n.forEach(i=>{if(this.components.peerId.equals(i)){this.log("not sending message on topic %s to myself",e.topic);return}if(i.equals(t)){this.log("not sending message on topic %s to sender %p",e.topic,i);return}this.log("publish msgs on topics %s %p",e.topic,i),s.push(i),this.send(i,{messages:[e]})}),{recipients:s})}};function Nd(r={}){return t=>new Vs(t,r)}return Ou(Rd);})();
|
6
|
+
`)}`:`${e} :`}};rc=Ie;k.Constructed=rc;Ie.NAME="CONSTRUCTED";var Vn=class extends xt{fromBER(t,e,n){return e}toBER(t){return qt}};Vn.override="EndOfContentValueBlock";var nc,Mn=class extends pt{constructor(t={}){super(t,Vn),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};nc=Mn;k.EndOfContent=nc;Mn.NAME=Yr;var sc,Ne=class extends pt{constructor(t={}){super(t,xt),this.idBlock.tagClass=1,this.idBlock.tagNumber=5}fromBER(t,e,n){return this.lenBlock.length>0&&this.warnings.push("Non-zero length of value block for Null type"),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.blockLength+=n,e+n>t.byteLength?(this.error="End of input reached before message was fully decoded (inconsistent offset and length values)",-1):e+n}toBER(t,e){let n=new ArrayBuffer(2);if(!t){let s=new Uint8Array(n);s[0]=5,s[1]=0}return e&&e.write(n),n}onAsciiEncoding(){return`${this.constructor.NAME}`}};sc=Ne;k.Null=sc;Ne.NAME="NULL";var Hn=class extends pe(xt){constructor({value:t,...e}={}){super(e),e.valueHex?this.valueHexView=M.BufferSourceConverter.toUint8Array(e.valueHex):this.valueHexView=new Uint8Array(1),t&&(this.value=t)}get value(){for(let t of this.valueHexView)if(t>0)return!0;return!1}set value(t){this.valueHexView[0]=t?255:0}fromBER(t,e,n){let s=M.BufferSourceConverter.toUint8Array(t);return de(this,s,e,n)?(this.valueHexView=s.subarray(e,e+n),n>1&&this.warnings.push("Boolean value encoded in more then 1 octet"),this.isHexOnly=!0,Zi.call(this),this.blockLength=n,e+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};Hn.NAME="BooleanValueBlock";var ic,Kn=class extends pt{constructor(t={}){super(t,Hn),this.idBlock.tagClass=1,this.idBlock.tagNumber=1}getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.getValue}`}};ic=Kn;k.Boolean=ic;Kn.NAME="BOOLEAN";var Fn=class extends pe(Zt){constructor({isConstructed:t=!1,...e}={}){super(e),this.isConstructed=t}fromBER(t,e,n){let s=0;if(this.isConstructed){if(this.isHexOnly=!1,s=Zt.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let i=0;i<this.value.length;i++){let o=this.value[i].constructor.NAME;if(o===Yr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(o!==Xa)return this.error="OCTET STRING may consists of OCTET STRINGs only",-1}}else this.isHexOnly=!0,s=super.fromBER(t,e,n),this.blockLength=n;return s}toBER(t,e){return this.isConstructed?Zt.prototype.toBER.call(this,t,e):t?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};Fn.NAME="OctetStringValueBlock";var oc,fe=class r extends pt{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,i;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((i=n.value)===null||i===void 0)&&i.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},Fn),this.idBlock.tagClass=1,this.idBlock.tagNumber=4}fromBER(t,e,n){if(this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,n===0)return this.idBlock.error.length===0&&(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length===0&&(this.blockLength+=this.lenBlock.blockLength),e;if(!this.valueBlock.isConstructed){let i=(t instanceof ArrayBuffer?new Uint8Array(t):t).subarray(e,e+n);try{if(i.byteLength){let o=ms(i,0,i.byteLength);o.offset!==-1&&o.offset===n&&(this.valueBlock.value=[o.result])}}catch{}}return super.fromBER(t,e,n)}onAsciiEncoding(){return this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length?Ie.prototype.onAsciiEncoding.call(this):`${this.constructor.NAME} : ${M.Convert.ToHex(this.valueBlock.valueHexView)}`}getValue(){if(!this.idBlock.isConstructed)return this.valueBlock.valueHexView.slice().buffer;let t=[];for(let e of this.valueBlock.value)e instanceof r&&t.push(e.valueBlock.valueHexView);return M.BufferSourceConverter.concat(t)}};oc=fe;k.OctetString=oc;fe.NAME=Xa;var qn=class extends pe(Zt){constructor({unusedBits:t=0,isConstructed:e=!1,...n}={}){super(n),this.unusedBits=t,this.isConstructed=e,this.blockLength=this.valueHexView.byteLength}fromBER(t,e,n){if(!n)return e;let s=-1;if(this.isConstructed){if(s=Zt.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let a of this.value){let c=a.constructor.NAME;if(c===Yr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==Qa)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 i=M.BufferSourceConverter.toUint8Array(t);if(!de(this,i,e,n))return-1;let o=i.subarray(e,e+n);if(this.unusedBits=o[0],this.unusedBits>7)return this.error="Unused bits for BitString must be in range 0-7",-1;if(!this.unusedBits){let a=o.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=o.subarray(1),this.blockLength=o.length,e+n}toBER(t,e){if(this.isConstructed)return Zt.prototype.toBER.call(this,t,e);if(t)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return qt;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 ac,vr=class extends pt{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,i;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((i=n.value)===null||i===void 0)&&i.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},qn),this.idBlock.tagClass=1,this.idBlock.tagNumber=3}fromBER(t,e,n){return this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,super.fromBER(t,e,n)}onAsciiEncoding(){if(this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length)return Ie.prototype.onAsciiEncoding.call(this);{let t=[],e=this.valueBlock.valueHexView;for(let s of e)t.push(s.toString(2).padStart(8,"0"));let n=t.join("");return`${this.constructor.NAME} : ${n.substring(0,n.length-this.valueBlock.unusedBits)}`}}};ac=vr;k.BitString=ac;vr.NAME=Qa;var cc;function Rh(r,t){let e=new Uint8Array([0]),n=new Uint8Array(r),s=new Uint8Array(t),i=n.slice(0),o=i.length-1,a=s.slice(0),c=a.length-1,f=0,l=c<o?o:c,u=0;for(let p=l;p>=0;p--,u++){switch(!0){case u<a.length:f=i[o-u]+a[c-u]+e[0];break;default:f=i[o-u]+e[0]}switch(e[0]=f/10,!0){case u>=i.length:i=Tn(new Uint8Array([f%10]),i);break;default:i[o-u]=f%10}}return e[0]>0&&(i=Tn(e,i)),i}function Ja(r){if(r>=Gr.length)for(let t=Gr.length;t<=r;t++){let e=new Uint8Array([0]),n=Gr[t-1].slice(0);for(let s=n.length-1;s>=0;s--){let i=new Uint8Array([(n[s]<<1)+e[0]]);e[0]=i[0]/10,n[s]=i[0]%10}e[0]>0&&(n=Tn(e,n)),Gr.push(n)}return Gr[r]}function _h(r,t){let e=0,n=new Uint8Array(r),s=new Uint8Array(t),i=n.slice(0),o=i.length-1,a=s.slice(0),c=a.length-1,f,l=0;for(let u=c;u>=0;u--,l++)switch(f=i[o-l]-a[c-l]-e,!0){case f<0:e=1,i[o-l]=f+10;break;default:e=0,i[o-l]=f}if(e>0)for(let u=o-c+1;u>=0;u--,l++)if(f=i[o-l]-e,f<0)e=1,i[o-l]=f+10;else{e=0,i[o-l]=f;break}return i.slice()}var jr=class extends pe(xt){constructor({value:t,...e}={}){super(e),this._valueDec=0,e.valueHex&&this.setValueHex(),t!==void 0&&(this.valueDec=t)}setValueHex(){this.valueHexView.length>=4?(this.warnings.push("Too big Integer for decoding, hex only"),this.isHexOnly=!0,this._valueDec=0):(this.isHexOnly=!1,this.valueHexView.length>0&&(this._valueDec=Zi.call(this)))}set valueDec(t){this._valueDec=t,this.isHexOnly=!1,this.valueHexView=new Uint8Array(ja(t))}get valueDec(){return this._valueDec}fromDER(t,e,n,s=0){let i=this.fromBER(t,e,n);if(i===-1)return i;let o=this.valueHexView;return o[0]===0&&o[1]&128?this.valueHexView=o.subarray(1):s!==0&&o.length<s&&(s-o.length>1&&(s=o.length+1),this.valueHexView=o.subarray(s-o.length)),i}toDER(t=!1){let e=this.valueHexView;switch(!0){case(e[0]&128)!==0:{let n=new Uint8Array(this.valueHexView.length+1);n[0]=0,n.set(e,1),this.valueHexView=n}break;case(e[0]===0&&(e[1]&128)===0):this.valueHexView=this.valueHexView.subarray(1);break}return this.toBER(t)}fromBER(t,e,n){let s=super.fromBER(t,e,n);return s===-1||this.setValueHex(),s}toBER(t){return t?new ArrayBuffer(this.valueHexView.length):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}toString(){let t=this.valueHexView.length*8-1,e=new Uint8Array(this.valueHexView.length*8/3),n=0,s,i=this.valueHexView,o="",a=!1;for(let c=i.byteLength-1;c>=0;c--){s=i[c];for(let f=0;f<8;f++){if((s&1)===1)switch(n){case t:e=_h(Ja(n),e),o="-";break;default:e=Rh(e,Ja(n))}n++,s>>=1}}for(let c=0;c<e.length;c++)e[c]&&(a=!0),a&&(o+=Wa.charAt(e[c]));return a===!1&&(o+=Wa.charAt(0)),o}};cc=jr;jr.NAME="IntegerValueBlock";Object.defineProperty(cc.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var uc,ot=class r extends pt{constructor(t={}){super(t,jr),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return Cn(),BigInt(this.valueBlock.toString())}static fromBigInt(t){Cn();let e=BigInt(t),n=new zr,s=e.toString(16).replace(/^-/,""),i=new Uint8Array(M.Convert.FromHex(s));if(e<0){let a=new Uint8Array(i.length+(i[0]&128?1:0));a[0]|=128;let f=BigInt(`0x${M.Convert.ToHex(a)}`)+e,l=M.BufferSourceConverter.toUint8Array(M.Convert.FromHex(f.toString(16)));l[0]|=128,n.write(l)}else i[0]&128&&n.write(new Uint8Array([0])),n.write(i);return new r({valueHex:n.final()})}convertToDER(){let t=new r({valueHex:this.valueBlock.valueHexView});return t.valueBlock.toDER(),t}convertFromDER(){return new r({valueHex:this.valueBlock.valueHexView[0]===0?this.valueBlock.valueHexView.subarray(1):this.valueBlock.valueHexView})}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()}`}};uc=ot;k.Integer=uc;ot.NAME="INTEGER";var lc,$n=class extends ot{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};lc=$n;k.Enumerated=lc;$n.NAME="ENUMERATED";var Zr=class extends pe(xt){constructor({valueDec:t=-1,isFirstSid:e=!1,...n}={}){super(n),this.valueDec=t,this.isFirstSid=e}fromBER(t,e,n){if(!n)return e;let s=M.BufferSourceConverter.toUint8Array(t);if(!de(this,s,e,n))return-1;let i=s.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=i[a]&127,this.blockLength++,!!(i[a]&128));a++);let o=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)o[a]=this.valueHexView[a];return this.valueHexView=o,i[this.blockLength-1]&128?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=Ke(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}set valueBigInt(t){Cn();let e=BigInt(t).toString(2);for(;e.length%7;)e="0"+e;let n=new Uint8Array(e.length/7);for(let s=0;s<n.length;s++)n[s]=parseInt(e.slice(s*7,s*7+7),2)+(s+1<n.length?128:0);this.fromBER(n.buffer,0,n.length)}toBER(t){if(this.isHexOnly){if(t)return new ArrayBuffer(this.valueHexView.byteLength);let s=this.valueHexView,i=new Uint8Array(this.blockLength);for(let o=0;o<this.blockLength-1;o++)i[o]=s[o]|128;return i[this.blockLength-1]=s[this.blockLength-1],i.buffer}let e=ke(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",qt;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),i=e.byteLength-1;for(let o=0;o<i;o++)n[o]=s[o]|128;n[i]=s[i]}return n}toString(){let t="";if(this.isHexOnly)t=M.Convert.ToHex(this.valueHexView);else if(this.isFirstSid){let e=this.valueDec;this.valueDec<=39?t="0.":this.valueDec<=79?(t="1.",e-=40):(t="2.",e-=80),t+=e.toString()}else t=this.valueDec.toString();return t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec,isFirstSid:this.isFirstSid}}};Zr.NAME="sidBlock";var Gn=class extends xt{constructor({value:t=Br,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let i=new Zr;if(s=i.fromBER(t,s,n),s===-1)return this.blockLength=0,this.error=i.error,s;this.value.length===0&&(i.isFirstSid=!0),this.blockLength+=i.blockLength,n-=i.blockLength,this.value.push(i)}return s}toBER(t){let e=[];for(let n=0;n<this.value.length;n++){let s=this.value[n].toBER(t);if(s.byteLength===0)return this.error=this.value[n].error,qt;e.push(s)}return Wi(e)}fromString(t){this.value=[];let e=0,n=0,s="",i=!1;do if(n=t.indexOf(".",e),n===-1?s=t.substring(e):s=t.substring(e,n),e=n+1,i){let o=this.value[0],a=0;switch(o.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;o.valueDec=c+a,i=!1}else{let o=new Zr;if(s>Number.MAX_SAFE_INTEGER){Cn();let a=BigInt(s);o.valueBigInt=a}else if(o.valueDec=parseInt(s,10),isNaN(o.valueDec))return;this.value.length||(o.isFirstSid=!0,i=!0),this.value.push(o)}while(n!==-1)}toString(){let t="",e=!1;for(let n=0;n<this.value.length;n++){e=this.value[n].isHexOnly;let s=this.value[n].toString();n!==0&&(t=`${t}.`),e?(s=`{${s}}`,this.value[n].isFirstSid?t=`2.{${s} - 80}`:t+=s):t+=s}return t}toJSON(){let t={...super.toJSON(),value:this.toString(),sidArray:[]};for(let e=0;e<this.value.length;e++)t.sidArray.push(this.value[e].toJSON());return t}};Gn.NAME="ObjectIdentifierValueBlock";var fc,Ft=class extends pt{constructor(t={}){super(t,Gn),this.idBlock.tagClass=1,this.idBlock.tagNumber=6}getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};fc=Ft;k.ObjectIdentifier=fc;Ft.NAME="OBJECT IDENTIFIER";var Wr=class extends pe(le){constructor({valueDec:t=0,...e}={}){super(e),this.valueDec=t}fromBER(t,e,n){if(n===0)return e;let s=M.BufferSourceConverter.toUint8Array(t);if(!de(this,s,e,n))return-1;let i=s.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=i[a]&127,this.blockLength++,!!(i[a]&128));a++);let o=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)o[a]=this.valueHexView[a];return this.valueHexView=o,i[this.blockLength-1]&128?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=Ke(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}toBER(t){if(this.isHexOnly){if(t)return new ArrayBuffer(this.valueHexView.byteLength);let s=this.valueHexView,i=new Uint8Array(this.blockLength);for(let o=0;o<this.blockLength-1;o++)i[o]=s[o]|128;return i[this.blockLength-1]=s[this.blockLength-1],i.buffer}let e=ke(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",qt;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),i=e.byteLength-1;for(let o=0;o<i;o++)n[o]=s[o]|128;n[i]=s[i]}return n.buffer}toString(){let t="";return this.isHexOnly?t=M.Convert.ToHex(this.valueHexView):t=this.valueDec.toString(),t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};Wr.NAME="relativeSidBlock";var zn=class extends xt{constructor({value:t=Br,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let i=new Wr;if(s=i.fromBER(t,s,n),s===-1)return this.blockLength=0,this.error=i.error,s;this.blockLength+=i.blockLength,n-=i.blockLength,this.value.push(i)}return s}toBER(t,e){let n=[];for(let s=0;s<this.value.length;s++){let i=this.value[s].toBER(t);if(i.byteLength===0)return this.error=this.value[s].error,qt;n.push(i)}return Wi(n)}fromString(t){this.value=[];let e=0,n=0,s="";do{n=t.indexOf(".",e),n===-1?s=t.substring(e):s=t.substring(e,n),e=n+1;let i=new Wr;if(i.valueDec=parseInt(s,10),isNaN(i.valueDec))return!0;this.value.push(i)}while(n!==-1);return!0}toString(){let t="",e=!1;for(let n=0;n<this.value.length;n++){e=this.value[n].isHexOnly;let s=this.value[n].toString();n!==0&&(t=`${t}.`),e&&(s=`{${s}}`),t+=s}return t}toJSON(){let t={...super.toJSON(),value:this.toString(),sidArray:[]};for(let e=0;e<this.value.length;e++)t.sidArray.push(this.value[e].toJSON());return t}};zn.NAME="RelativeObjectIdentifierValueBlock";var hc,Yn=class extends pt{constructor(t={}){super(t,zn),this.idBlock.tagClass=1,this.idBlock.tagNumber=13}getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};hc=Yn;k.RelativeObjectIdentifier=hc;Yn.NAME="RelativeObjectIdentifier";var dc,ft=class extends Ie{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};dc=ft;k.Sequence=dc;ft.NAME="SEQUENCE";var pc,jn=class extends Ie{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};pc=jn;k.Set=pc;jn.NAME="SET";var Zn=class extends pe(xt){constructor({...t}={}){super(t),this.isHexOnly=!0,this.value=Br}toJSON(){return{...super.toJSON(),value:this.value}}};Zn.NAME="StringValueBlock";var Wn=class extends Zn{};Wn.NAME="SimpleStringValueBlock";var At=class extends Dn{constructor({...t}={}){super(t,Wn)}fromBuffer(t){this.valueBlock.value=String.fromCharCode.apply(null,M.BufferSourceConverter.toUint8Array(t))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e);for(let s=0;s<e;s++)n[s]=t.charCodeAt(s);this.valueBlock.value=t}};At.NAME="SIMPLE STRING";var Jn=class extends At{fromBuffer(t){this.valueBlock.valueHexView=M.BufferSourceConverter.toUint8Array(t);try{this.valueBlock.value=M.Convert.ToUtf8String(t)}catch(e){this.warnings.push(`Error during "decodeURIComponent": ${e}, using raw string`),this.valueBlock.value=M.Convert.ToBinary(t)}}fromString(t){this.valueBlock.valueHexView=new Uint8Array(M.Convert.FromUtf8String(t)),this.valueBlock.value=t}};Jn.NAME="Utf8StringValueBlock";var gc,he=class extends Jn{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};gc=he;k.Utf8String=gc;he.NAME="UTF8String";var Xn=class extends At{fromBuffer(t){this.valueBlock.value=M.Convert.ToUtf16String(t),this.valueBlock.valueHexView=M.BufferSourceConverter.toUint8Array(t)}fromString(t){this.valueBlock.value=t,this.valueBlock.valueHexView=new Uint8Array(M.Convert.FromUtf16String(t))}};Xn.NAME="BmpStringValueBlock";var mc,Qn=class extends Xn{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};mc=Qn;k.BmpString=mc;Qn.NAME="BMPString";var ts=class extends At{fromBuffer(t){let e=ArrayBuffer.isView(t)?t.slice().buffer:t.slice(0),n=new Uint8Array(e);for(let s=0;s<n.length;s+=4)n[s]=n[s+3],n[s+1]=n[s+2],n[s+2]=0,n[s+3]=0;this.valueBlock.value=String.fromCharCode.apply(null,new Uint32Array(e))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e*4);for(let s=0;s<e;s++){let i=ke(t.charCodeAt(s),8),o=new Uint8Array(i);if(o.length>4)continue;let a=4-o.length;for(let c=o.length-1;c>=0;c--)n[s*4+c+a]=o[c]}this.valueBlock.value=t}};ts.NAME="UniversalStringValueBlock";var yc,es=class extends ts{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};yc=es;k.UniversalString=yc;es.NAME="UniversalString";var bc,rs=class extends At{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};bc=rs;k.NumericString=bc;rs.NAME="NumericString";var wc,ns=class extends At{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};wc=ns;k.PrintableString=wc;ns.NAME="PrintableString";var xc,ss=class extends At{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};xc=ss;k.TeletexString=xc;ss.NAME="TeletexString";var Ec,is=class extends At{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};Ec=is;k.VideotexString=Ec;is.NAME="VideotexString";var vc,os=class extends At{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};vc=os;k.IA5String=vc;os.NAME="IA5String";var Bc,as=class extends At{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};Bc=as;k.GraphicString=Bc;as.NAME="GraphicString";var Ac,Jr=class extends At{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};Ac=Jr;k.VisibleString=Ac;Jr.NAME="VisibleString";var Sc,cs=class extends At{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};Sc=cs;k.GeneralString=Sc;cs.NAME="GeneralString";var kc,us=class extends At{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};kc=us;k.CharacterString=kc;us.NAME="CharacterString";var Ic,Xr=class extends Jr{constructor({value:t,valueDate:e,...n}={}){if(super(n),this.year=0,this.month=0,this.day=0,this.hour=0,this.minute=0,this.second=0,t){this.fromString(t),this.valueBlock.valueHexView=new Uint8Array(t.length);for(let s=0;s<t.length;s++)this.valueBlock.valueHexView[s]=t.charCodeAt(s)}e&&(this.fromDate(e),this.valueBlock.valueHexView=new Uint8Array(this.toBuffer())),this.idBlock.tagClass=1,this.idBlock.tagNumber=23}fromBuffer(t){this.fromString(String.fromCharCode.apply(null,M.BufferSourceConverter.toUint8Array(t)))}toBuffer(){let t=this.toString(),e=new ArrayBuffer(t.length),n=new Uint8Array(e);for(let s=0;s<t.length;s++)n[s]=t.charCodeAt(s);return e}fromDate(t){this.year=t.getUTCFullYear(),this.month=t.getUTCMonth()+1,this.day=t.getUTCDate(),this.hour=t.getUTCHours(),this.minute=t.getUTCMinutes(),this.second=t.getUTCSeconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second))}fromString(t){let n=/(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})Z/ig.exec(t);if(n===null){this.error="Wrong input string for conversion";return}let s=parseInt(n[1],10);s>=50?this.year=1900+s:this.year=2e3+s,this.month=parseInt(n[2],10),this.day=parseInt(n[3],10),this.hour=parseInt(n[4],10),this.minute=parseInt(n[5],10),this.second=parseInt(n[6],10)}toString(t="iso"){if(t==="iso"){let e=new Array(7);return e[0]=Rt(this.year<2e3?this.year-1900:this.year-2e3,2),e[1]=Rt(this.month,2),e[2]=Rt(this.day,2),e[3]=Rt(this.hour,2),e[4]=Rt(this.minute,2),e[5]=Rt(this.second,2),e[6]="Z",e.join("")}return super.toString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.toDate().toISOString()}`}toJSON(){return{...super.toJSON(),year:this.year,month:this.month,day:this.day,hour:this.hour,minute:this.minute,second:this.second}}};Ic=Xr;k.UTCTime=Ic;Xr.NAME="UTCTime";var Nc,ls=class extends Xr{constructor(t={}){var e;super(t),(e=this.millisecond)!==null&&e!==void 0||(this.millisecond=0),this.idBlock.tagClass=1,this.idBlock.tagNumber=24}fromDate(t){super.fromDate(t),this.millisecond=t.getUTCMilliseconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second,this.millisecond))}fromString(t){let e=!1,n="",s="",i=0,o,a=0,c=0;if(t[t.length-1]==="Z")n=t.substring(0,t.length-1),e=!0;else{let u=new Number(t[t.length-1]);if(isNaN(u.valueOf()))throw new Error("Wrong input string for conversion");n=t}if(e){if(n.indexOf("+")!==-1)throw new Error("Wrong input string for conversion");if(n.indexOf("-")!==-1)throw new Error("Wrong input string for conversion")}else{let u=1,p=n.indexOf("+"),w="";if(p===-1&&(p=n.indexOf("-"),u=-1),p!==-1){if(w=n.substring(p+1),n=n.substring(0,p),w.length!==2&&w.length!==4)throw new Error("Wrong input string for conversion");let g=parseInt(w.substring(0,2),10);if(isNaN(g.valueOf()))throw new Error("Wrong input string for conversion");if(a=u*g,w.length===4){if(g=parseInt(w.substring(2,4),10),isNaN(g.valueOf()))throw new Error("Wrong input string for conversion");c=u*g}}}let f=n.indexOf(".");if(f===-1&&(f=n.indexOf(",")),f!==-1){let u=new Number(`0${n.substring(f)}`);if(isNaN(u.valueOf()))throw new Error("Wrong input string for conversion");i=u.valueOf(),s=n.substring(0,f)}else s=n;switch(!0){case s.length===8:if(o=/(\d{4})(\d{2})(\d{2})/ig,f!==-1)throw new Error("Wrong input string for conversion");break;case s.length===10:if(o=/(\d{4})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let u=60*i;this.minute=Math.floor(u),u=60*(u-this.minute),this.second=Math.floor(u),u=1e3*(u-this.second),this.millisecond=Math.floor(u)}break;case s.length===12:if(o=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let u=60*i;this.second=Math.floor(u),u=1e3*(u-this.second),this.millisecond=Math.floor(u)}break;case s.length===14:if(o=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let u=1e3*i;this.millisecond=Math.floor(u)}break;default:throw new Error("Wrong input string for conversion")}let l=o.exec(s);if(l===null)throw new Error("Wrong input string for conversion");for(let u=1;u<l.length;u++)switch(u){case 1:this.year=parseInt(l[u],10);break;case 2:this.month=parseInt(l[u],10);break;case 3:this.day=parseInt(l[u],10);break;case 4:this.hour=parseInt(l[u],10)+a;break;case 5:this.minute=parseInt(l[u],10)+c;break;case 6:this.second=parseInt(l[u],10);break;default:throw new Error("Wrong input string for conversion")}if(e===!1){let u=new Date(this.year,this.month,this.day,this.hour,this.minute,this.second,this.millisecond);this.year=u.getUTCFullYear(),this.month=u.getUTCMonth(),this.day=u.getUTCDay(),this.hour=u.getUTCHours(),this.minute=u.getUTCMinutes(),this.second=u.getUTCSeconds(),this.millisecond=u.getUTCMilliseconds()}}toString(t="iso"){if(t==="iso"){let e=[];return e.push(Rt(this.year,4)),e.push(Rt(this.month,2)),e.push(Rt(this.day,2)),e.push(Rt(this.hour,2)),e.push(Rt(this.minute,2)),e.push(Rt(this.second,2)),this.millisecond!==0&&(e.push("."),e.push(Rt(this.millisecond,3))),e.push("Z"),e.join("")}return super.toString(t)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};Nc=ls;k.GeneralizedTime=Nc;ls.NAME="GeneralizedTime";var Rc,fs=class extends he{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};Rc=fs;k.DATE=Rc;fs.NAME="DATE";var _c,hs=class extends he{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};_c=hs;k.TimeOfDay=_c;hs.NAME="TimeOfDay";var Tc,ds=class extends he{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};Tc=ds;k.DateTime=Tc;ds.NAME="DateTime";var Cc,ps=class extends he{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};Cc=ps;k.Duration=Cc;ps.NAME="Duration";var Lc,gs=class extends he{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};Lc=gs;k.TIME=Lc;gs.NAME="TIME";function Ch(r){let{result:t}=Ar(r),e=t.valueBlock.value;return{n:Y(Wt(e[1].toBigInt()),"base64url"),e:Y(Wt(e[2].toBigInt()),"base64url"),d:Y(Wt(e[3].toBigInt()),"base64url"),p:Y(Wt(e[4].toBigInt()),"base64url"),q:Y(Wt(e[5].toBigInt()),"base64url"),dp:Y(Wt(e[6].toBigInt()),"base64url"),dq:Y(Wt(e[7].toBigInt()),"base64url"),qi:Y(Wt(e[8].toBigInt()),"base64url"),kty:"RSA",alg:"RS256"}}function Lh(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 A("JWK was missing components","ERR_INVALID_PARAMETERS");let e=new ft({value:[new ot({value:0}),ot.fromBigInt(Jt($(r.n,"base64url"))),ot.fromBigInt(Jt($(r.e,"base64url"))),ot.fromBigInt(Jt($(r.d,"base64url"))),ot.fromBigInt(Jt($(r.p,"base64url"))),ot.fromBigInt(Jt($(r.q,"base64url"))),ot.fromBigInt(Jt($(r.dp,"base64url"))),ot.fromBigInt(Jt($(r.dq,"base64url"))),ot.fromBigInt(Jt($(r.qi,"base64url")))]}).toBER();return new Uint8Array(e,0,e.byteLength)}function Uh(r){let{result:t}=Ar(r),e=t.valueBlock.value[1].valueBlock.value[0].valueBlock.value;return{kty:"RSA",n:Y(Wt(e[0].toBigInt()),"base64url"),e:Y(Wt(e[1].toBigInt()),"base64url")}}function Dh(r){if(r.n==null||r.e==null)throw new A("JWK was missing components","ERR_INVALID_PARAMETERS");let e=new ft({value:[new ft({value:[new Ft({value:"1.2.840.113549.1.1.1"}),new Ne]}),new vr({valueHex:new ft({value:[ot.fromBigInt(Jt($(r.n,"base64url"))),ot.fromBigInt(Jt($(r.e,"base64url")))]}).toBER()})]}).toBER();return new Uint8Array(e,0,e.byteLength)}function Wt(r){let t=r.toString(16);t.length%2>0&&(t=`0${t}`);let e=t.length/2,n=new Uint8Array(e),s=0,i=0;for(;s<e;)n[s]=parseInt(t.slice(i,i+2),16),s+=1,i+=2;return n}function Jt(r){let t=[];return r.forEach(function(e){let n=e.toString(16);n.length%2>0&&(n=`0${n}`),t.push(n)}),BigInt("0x"+t.join(""))}var Ph=16,Xi=32,Qi=1e4;async function Oh(r,t){let e=W.get(),s=new ft({value:[new ot({value:0}),new ft({value:[new Ft({value:"1.2.840.113549.1.1.1"}),new Ne]}),new fe({valueHex:r.marshal()})]}).toBER(),i=new Uint8Array(s,0,s.byteLength),o=jt(Ph),a=await Yi(Mr,t,o,{c:Qi,dkLen:Xi}),c=jt(16),f=await e.subtle.importKey("raw",a,"AES-CBC",!1,["encrypt"]),l=await e.subtle.encrypt({name:"AES-CBC",iv:c},f,i),u=new ft({value:[new fe({valueHex:o}),new ot({value:Qi}),new ot({value:Xi}),new ft({value:[new Ft({value:"1.2.840.113549.2.11"}),new Ne]})]}),p=new ft({value:[new Ft({value:"1.2.840.113549.1.5.13"}),new ft({value:[new ft({value:[new Ft({value:"1.2.840.113549.1.5.12"}),u]}),new ft({value:[new Ft({value:"2.16.840.1.101.3.4.1.42"}),new fe({valueHex:c})]})]})]}),g=new ft({value:[p,new fe({valueHex:l})]}).toBER(),h=new Uint8Array(g,0,g.byteLength);return["-----BEGIN ENCRYPTED PRIVATE KEY-----",...Y(h,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
|
7
|
+
`)}async function to(r,t){let e=W.get(),n;if(r.includes("-----BEGIN ENCRYPTED PRIVATE KEY-----")){let s=$(r.replace("-----BEGIN ENCRYPTED PRIVATE KEY-----","").replace("-----END ENCRYPTED PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:i}=Ar(s),{iv:o,salt:a,iterations:c,keySize:f,cipherText:l}=Vh(i),u=await Yi(Mr,t,a,{c,dkLen:f}),p=await e.subtle.importKey("raw",u,"AES-CBC",!1,["decrypt"]),w=Qr(await e.subtle.decrypt({name:"AES-CBC",iv:o},p,l)),{result:g}=Ar(w);n=Uc(g)}else if(r.includes("-----BEGIN PRIVATE KEY-----")){let s=$(r.replace("-----BEGIN PRIVATE KEY-----","").replace("-----END PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:i}=Ar(s);n=Uc(i)}else throw new A("Could not parse private key from PEM data","ERR_INVALID_PARAMETERS");return eo(n)}function Vh(r){let t=r.valueBlock.value[0];if(t.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.13")throw new A("Only pkcs5PBES2 encrypted private keys are supported","ERR_INVALID_PARAMS");let n=t.valueBlock.value[1].valueBlock.value[0];if(n.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.12")throw new A("Only pkcs5PBKDF2 key derivation functions are supported","ERR_INVALID_PARAMS");let i=n.valueBlock.value[1],o=Qr(i.valueBlock.value[0].getValue()),a=Qi,c=Xi;if(i.valueBlock.value.length===3)a=Number(i.valueBlock.value[1].toBigInt()),c=Number(i.valueBlock.value[2].toBigInt());else if(i.valueBlock.value.length===2)throw new A("Could not derive key size and iterations from PEM file - please use @libp2p/rsa to re-import your key","ERR_INVALID_PARAMS");let f=t.valueBlock.value[1].valueBlock.value[1],l=f.valueBlock.value[0].toString();if(l!=="OBJECT IDENTIFIER : 1.2.840.113549.3.7"){if(l!=="OBJECT IDENTIFIER : 1.3.14.3.2.7"){if(l!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.2"){if(l!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.22"){if(l!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.42")throw new A("Only AES-CBC encryption schemes are supported","ERR_INVALID_PARAMS")}}}}let u=Qr(f.valueBlock.value[1].getValue());return{cipherText:Qr(r.valueBlock.value[1].getValue()),salt:o,iterations:a,keySize:c,iv:u}}function Uc(r){return Qr(r.valueBlock.value[2].getValue())}function Qr(r){return new Uint8Array(r,0,r.byteLength)}async function Dc(r){let t=await W.get().subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:r,publicExponent:new Uint8Array([1,0,1]),hash:{name:"SHA-256"}},!0,["sign","verify"]),e=await Vc(t);return{privateKey:e[0],publicKey:e[1]}}async function ro(r){let e=[await W.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["sign"]),await Mh(r)],n=await Vc({privateKey:e[0],publicKey:e[1]});return{privateKey:n[0],publicKey:n[1]}}async function Pc(r,t){let e=await W.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await W.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},e,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(n,0,n.byteLength)}async function Oc(r,t,e){let n=await W.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return W.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,t,e instanceof Uint8Array?e:e.subarray())}async function Vc(r){if(r.privateKey==null||r.publicKey==null)throw new A("Private and public key are required","ERR_INVALID_PARAMETERS");return Promise.all([W.get().subtle.exportKey("jwk",r.privateKey),W.get().subtle.exportKey("jwk",r.publicKey)])}async function Mh(r){return W.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 A("invalid key type","ERR_INVALID_KEY_TYPE");if(r.n==null)throw new A("invalid key modulus","ERR_INVALID_KEY_MODULUS");return $(r.n,"base64url").length*8}var qe=8192,Fe=class{_key;constructor(t){this._key=t}verify(t,e){return Oc(this._key,e,t)}marshal(){return Re.jwkToPkix(this._key)}get bytes(){return Ht.encode({Type:Z.RSA,Data:this.marshal()}).subarray()}equals(t){return mt(this.bytes,t.bytes)}hash(){let t=ct.digest(this.bytes);return Lt(t)?t.then(({bytes:e})=>e):t.bytes}},_e=class{_key;_publicKey;constructor(t,e){this._key=t,this._publicKey=e}genSecret(){return jt(16)}sign(t){return Pc(this._key,t)}get public(){if(this._publicKey==null)throw new A("public key not provided","ERR_PUBKEY_NOT_PROVIDED");return new Fe(this._publicKey)}marshal(){return Re.jwkToPkcs1(this._key)}get bytes(){return Kt.encode({Type:Z.RSA,Data:this.marshal()}).subarray()}equals(t){return mt(this.bytes,t.bytes)}hash(){let t=ct.digest(this.bytes);return Lt(t)?t.then(({bytes:e})=>e):t.bytes}async id(){let t=await this.public.hash();return Y(t,"base58btc")}async export(t,e="pkcs-8"){if(e==="pkcs-8")return Re.exportToPem(this,t);if(e==="libp2p-key")return yr(this.bytes,t);throw new A(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};async function eo(r){let t=Re.pkcs1ToJwk(r);if(ys(t)>qe)throw new A("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await ro(t);return new _e(e.privateKey,e.publicKey)}function Kh(r){let t=Re.pkixToJwk(r);if(ys(t)>qe)throw new A("key size is too large","ERR_KEY_SIZE_TOO_LARGE");return new Fe(t)}async function Fh(r){if(ys(r)>qe)throw new A("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await ro(r);return new _e(t.privateKey,t.publicKey)}async function qh(r){if(r>qe)throw new A("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await Dc(r);return new _e(t.privateKey,t.publicKey)}var co={};it(co,{Secp256k1PrivateKey:()=>ze,Secp256k1PublicKey:()=>Ge,generateKeyPair:()=>rd,unmarshalSecp256k1PrivateKey:()=>td,unmarshalSecp256k1PublicKey:()=>ed});var $h=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]),Te=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),Ce=new Uint32Array(64),so=class extends dr{constructor(){super(64,32,8,!1),this.A=Te[0]|0,this.B=Te[1]|0,this.C=Te[2]|0,this.D=Te[3]|0,this.E=Te[4]|0,this.F=Te[5]|0,this.G=Te[6]|0,this.H=Te[7]|0}get(){let{A:t,B:e,C:n,D:s,E:i,F:o,G:a,H:c}=this;return[t,e,n,s,i,o,a,c]}set(t,e,n,s,i,o,a,c){this.A=t|0,this.B=e|0,this.C=n|0,this.D=s|0,this.E=i|0,this.F=o|0,this.G=a|0,this.H=c|0}process(t,e){for(let u=0;u<16;u++,e+=4)Ce[u]=t.getUint32(e,!1);for(let u=16;u<64;u++){let p=Ce[u-15],w=Ce[u-2],g=Pt(p,7)^Pt(p,18)^p>>>3,h=Pt(w,17)^Pt(w,19)^w>>>10;Ce[u]=h+Ce[u-7]+g+Ce[u-16]|0}let{A:n,B:s,C:i,D:o,E:a,F:c,G:f,H:l}=this;for(let u=0;u<64;u++){let p=Pt(a,6)^Pt(a,11)^Pt(a,25),w=l+p+aa(a,c,f)+$h[u]+Ce[u]|0,h=(Pt(n,2)^Pt(n,13)^Pt(n,22))+ca(n,s,i)|0;l=f,f=c,c=a,a=o+w|0,o=i,i=s,s=n,n=w+h|0}n=n+this.A|0,s=s+this.B|0,i=i+this.C|0,o=o+this.D|0,a=a+this.E|0,c=c+this.F|0,f=f+this.G|0,l=l+this.H|0,this.set(n,s,i,o,a,c,f,l)}roundClean(){Ce.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var Mc=gn(()=>new so);function Gh(r){let t=Kr(r);Yt(t,{a:"field",b:"field"},{allowedPrivateKeyLengths:"array",wrapPrivateKey:"boolean",isTorsionFree:"function",clearCofactor:"function",allowInfinityPoint:"boolean",fromBytes:"function",toBytes:"function"});let{endo:e,Fp:n,a:s}=t;if(e){if(!n.eql(s,n.ZERO))throw new Error("Endomorphism can only be defined for Koblitz curves that have a=0");if(typeof e!="object"||typeof e.beta!="bigint"||typeof e.splitScalar!="function")throw new Error("Expected endomorphism with beta: bigint and splitScalar: function")}return Object.freeze({...t})}var{bytesToNumberBE:zh,hexToBytes:Yh}=bn,$e={Err:class extends Error{constructor(t=""){super(t)}},_parseInt(r){let{Err:t}=$e;if(r.length<2||r[0]!==2)throw new t("Invalid signature integer tag");let e=r[1],n=r.subarray(2,e+2);if(!e||n.length!==e)throw new t("Invalid signature integer: wrong length");if(n[0]&128)throw new t("Invalid signature integer: negative");if(n[0]===0&&!(n[1]&128))throw new t("Invalid signature integer: unnecessary leading zero");return{d:zh(n),l:r.subarray(e+2)}},toSig(r){let{Err:t}=$e,e=typeof r=="string"?Yh(r):r;pr(e);let n=e.length;if(n<2||e[0]!=48)throw new t("Invalid signature tag");if(e[1]!==n-2)throw new t("Invalid signature: incorrect length");let{d:s,l:i}=$e._parseInt(e.subarray(2)),{d:o,l:a}=$e._parseInt(i);if(a.length)throw new t("Invalid signature: left bytes after parsing");return{r:s,s:o}},hexFromSig(r){let t=f=>Number.parseInt(f[0],16)&8?"00"+f:f,e=f=>{let l=f.toString(16);return l.length&1?`0${l}`:l},n=t(e(r.s)),s=t(e(r.r)),i=n.length/2,o=s.length/2,a=e(i),c=e(o);return`30${e(o+i+4)}02${c}${s}02${a}${n}`}},ge=BigInt(0),Dt=BigInt(1),Ym=BigInt(2),Hc=BigInt(3),jm=BigInt(4);function jh(r){let t=Gh(r),{Fp:e}=t,n=t.toBytes||((g,h,d)=>{let m=h.toAffine();return oe(Uint8Array.from([4]),e.toBytes(m.x),e.toBytes(m.y))}),s=t.fromBytes||(g=>{let h=g.subarray(1),d=e.fromBytes(h.subarray(0,e.BYTES)),m=e.fromBytes(h.subarray(e.BYTES,2*e.BYTES));return{x:d,y:m}});function i(g){let{a:h,b:d}=t,m=e.sqr(g),x=e.mul(m,g);return e.add(e.add(x,e.mul(g,h)),d)}if(!e.eql(e.sqr(t.Gy),i(t.Gx)))throw new Error("bad generator point: equation left != right");function o(g){return typeof g=="bigint"&&ge<g&&g<t.n}function a(g){if(!o(g))throw new Error("Expected valid bigint: 0 < bigint < curve.n")}function c(g){let{allowedPrivateKeyLengths:h,nByteLength:d,wrapPrivateKey:m,n:x}=t;if(h&&typeof g!="bigint"){if(ve(g)&&(g=se(g)),typeof g!="string"||!h.includes(g.length))throw new Error("Invalid key");g=g.padStart(d*2,"0")}let b;try{b=typeof g=="bigint"?g:ie(et("private key",g,d))}catch{throw new Error(`private key must be ${d} bytes, hex or bigint, not ${typeof g}`)}return m&&(b=j(b,x)),a(b),b}let f=new Map;function l(g){if(!(g instanceof u))throw new Error("ProjectivePoint expected")}class u{constructor(h,d,m){if(this.px=h,this.py=d,this.pz=m,h==null||!e.isValid(h))throw new Error("x required");if(d==null||!e.isValid(d))throw new Error("y required");if(m==null||!e.isValid(m))throw new Error("z required")}static fromAffine(h){let{x:d,y:m}=h||{};if(!h||!e.isValid(d)||!e.isValid(m))throw new Error("invalid affine point");if(h instanceof u)throw new Error("projective point not allowed");let x=b=>e.eql(b,e.ZERO);return x(d)&&x(m)?u.ZERO:new u(d,m,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(h){let d=e.invertBatch(h.map(m=>m.pz));return h.map((m,x)=>m.toAffine(d[x])).map(u.fromAffine)}static fromHex(h){let d=u.fromAffine(s(et("pointHex",h)));return d.assertValidity(),d}static fromPrivateKey(h){return u.BASE.multiply(c(h))}_setWindowSize(h){this._WINDOW_SIZE=h,f.delete(this)}assertValidity(){if(this.is0()){if(t.allowInfinityPoint&&!e.is0(this.py))return;throw new Error("bad point: ZERO")}let{x:h,y:d}=this.toAffine();if(!e.isValid(h)||!e.isValid(d))throw new Error("bad point: x or y not FE");let m=e.sqr(d),x=i(h);if(!e.eql(m,x))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(e.isOdd)return!e.isOdd(h);throw new Error("Field doesn't support isOdd")}equals(h){l(h);let{px:d,py:m,pz:x}=this,{px:b,py:T,pz:E}=h,S=e.eql(e.mul(d,E),e.mul(b,x)),R=e.eql(e.mul(m,E),e.mul(T,x));return S&&R}negate(){return new u(this.px,e.neg(this.py),this.pz)}double(){let{a:h,b:d}=t,m=e.mul(d,Hc),{px:x,py:b,pz:T}=this,E=e.ZERO,S=e.ZERO,R=e.ZERO,_=e.mul(x,x),G=e.mul(b,b),K=e.mul(T,T),D=e.mul(x,b);return D=e.add(D,D),R=e.mul(x,T),R=e.add(R,R),E=e.mul(h,R),S=e.mul(m,K),S=e.add(E,S),E=e.sub(G,S),S=e.add(G,S),S=e.mul(E,S),E=e.mul(D,E),R=e.mul(m,R),K=e.mul(h,K),D=e.sub(_,K),D=e.mul(h,D),D=e.add(D,R),R=e.add(_,_),_=e.add(R,_),_=e.add(_,K),_=e.mul(_,D),S=e.add(S,_),K=e.mul(b,T),K=e.add(K,K),_=e.mul(K,D),E=e.sub(E,_),R=e.mul(K,G),R=e.add(R,R),R=e.add(R,R),new u(E,S,R)}add(h){l(h);let{px:d,py:m,pz:x}=this,{px:b,py:T,pz:E}=h,S=e.ZERO,R=e.ZERO,_=e.ZERO,G=t.a,K=e.mul(t.b,Hc),D=e.mul(d,b),nt=e.mul(m,T),rt=e.mul(x,E),Ct=e.add(d,m),v=e.add(b,T);Ct=e.mul(Ct,v),v=e.add(D,nt),Ct=e.sub(Ct,v),v=e.add(d,x);let N=e.add(b,E);return v=e.mul(v,N),N=e.add(D,rt),v=e.sub(v,N),N=e.add(m,x),S=e.add(T,E),N=e.mul(N,S),S=e.add(nt,rt),N=e.sub(N,S),_=e.mul(G,v),S=e.mul(K,rt),_=e.add(S,_),S=e.sub(nt,_),_=e.add(nt,_),R=e.mul(S,_),nt=e.add(D,D),nt=e.add(nt,D),rt=e.mul(G,rt),v=e.mul(K,v),nt=e.add(nt,rt),rt=e.sub(D,rt),rt=e.mul(G,rt),v=e.add(v,rt),D=e.mul(nt,v),R=e.add(R,D),D=e.mul(N,v),S=e.mul(Ct,S),S=e.sub(S,D),D=e.mul(Ct,nt),_=e.mul(N,_),_=e.add(_,D),new u(S,R,_)}subtract(h){return this.add(h.negate())}is0(){return this.equals(u.ZERO)}wNAF(h){return w.wNAFCached(this,f,h,d=>{let m=e.invertBatch(d.map(x=>x.pz));return d.map((x,b)=>x.toAffine(m[b])).map(u.fromAffine)})}multiplyUnsafe(h){let d=u.ZERO;if(h===ge)return d;if(a(h),h===Dt)return this;let{endo:m}=t;if(!m)return w.unsafeLadder(this,h);let{k1neg:x,k1:b,k2neg:T,k2:E}=m.splitScalar(h),S=d,R=d,_=this;for(;b>ge||E>ge;)b&Dt&&(S=S.add(_)),E&Dt&&(R=R.add(_)),_=_.double(),b>>=Dt,E>>=Dt;return x&&(S=S.negate()),T&&(R=R.negate()),R=new u(e.mul(R.px,m.beta),R.py,R.pz),S.add(R)}multiply(h){a(h);let d=h,m,x,{endo:b}=t;if(b){let{k1neg:T,k1:E,k2neg:S,k2:R}=b.splitScalar(d),{p:_,f:G}=this.wNAF(E),{p:K,f:D}=this.wNAF(R);_=w.constTimeNegate(T,_),K=w.constTimeNegate(S,K),K=new u(e.mul(K.px,b.beta),K.py,K.pz),m=_.add(K),x=G.add(D)}else{let{p:T,f:E}=this.wNAF(d);m=T,x=E}return u.normalizeZ([m,x])[0]}multiplyAndAddUnsafe(h,d,m){let x=u.BASE,b=(E,S)=>S===ge||S===Dt||!E.equals(x)?E.multiplyUnsafe(S):E.multiply(S),T=b(this,d).add(b(h,m));return T.is0()?void 0:T}toAffine(h){let{px:d,py:m,pz:x}=this,b=this.is0();h==null&&(h=b?e.ONE:e.inv(x));let T=e.mul(d,h),E=e.mul(m,h),S=e.mul(x,h);if(b)return{x:e.ZERO,y:e.ZERO};if(!e.eql(S,e.ONE))throw new Error("invZ was invalid");return{x:T,y:E}}isTorsionFree(){let{h,isTorsionFree:d}=t;if(h===Dt)return!0;if(d)return d(u,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h,clearCofactor:d}=t;return h===Dt?this:d?d(u,this):this.multiplyUnsafe(t.h)}toRawBytes(h=!0){return this.assertValidity(),n(u,this,h)}toHex(h=!0){return se(this.toRawBytes(h))}}u.BASE=new u(t.Gx,t.Gy,e.ONE),u.ZERO=new u(e.ZERO,e.ONE,e.ZERO);let p=t.nBitLength,w=En(u,t.endo?Math.ceil(p/2):p);return{CURVE:t,ProjectivePoint:u,normPrivateKeyToScalar:c,weierstrassEquation:i,isWithinCurveOrder:o}}function Zh(r){let t=Kr(r);return Yt(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function Kc(r){let t=Zh(r),{Fp:e,n}=t,s=e.BYTES+1,i=2*e.BYTES+1;function o(v){return ge<v&&v<e.ORDER}function a(v){return j(v,n)}function c(v){return wn(v,n)}let{ProjectivePoint:f,normPrivateKeyToScalar:l,weierstrassEquation:u,isWithinCurveOrder:p}=jh({...t,toBytes(v,N,P){let B=N.toAffine(),y=e.toBytes(B.x),I=oe;return P?I(Uint8Array.from([N.hasEvenY()?2:3]),y):I(Uint8Array.from([4]),y,e.toBytes(B.y))},fromBytes(v){let N=v.length,P=v[0],B=v.subarray(1);if(N===s&&(P===2||P===3)){let y=ie(B);if(!o(y))throw new Error("Point is not on curve");let I=u(y),C;try{C=e.sqrt(I)}catch(V){let q=V instanceof Error?": "+V.message:"";throw new Error("Point is not on curve"+q)}let L=(C&Dt)===Dt;return(P&1)===1!==L&&(C=e.neg(C)),{x:y,y:C}}else if(N===i&&P===4){let y=e.fromBytes(B.subarray(0,e.BYTES)),I=e.fromBytes(B.subarray(e.BYTES,2*e.BYTES));return{x:y,y:I}}else throw new Error(`Point of length ${N} was invalid. Expected ${s} compressed bytes or ${i} uncompressed bytes`)}}),w=v=>se(Ae(v,t.nByteLength));function g(v){let N=n>>Dt;return v>N}function h(v){return g(v)?a(-v):v}let d=(v,N,P)=>ie(v.slice(N,P));class m{constructor(N,P,B){this.r=N,this.s=P,this.recovery=B,this.assertValidity()}static fromCompact(N){let P=t.nByteLength;return N=et("compactSignature",N,P*2),new m(d(N,0,P),d(N,P,2*P))}static fromDER(N){let{r:P,s:B}=$e.toSig(et("DER",N));return new m(P,B)}assertValidity(){if(!p(this.r))throw new Error("r must be 0 < r < CURVE.n");if(!p(this.s))throw new Error("s must be 0 < s < CURVE.n")}addRecoveryBit(N){return new m(this.r,this.s,N)}recoverPublicKey(N){let{r:P,s:B,recovery:y}=this,I=R(et("msgHash",N));if(y==null||![0,1,2,3].includes(y))throw new Error("recovery id invalid");let C=y===2||y===3?P+t.n:P;if(C>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let L=y&1?"03":"02",O=f.fromHex(L+w(C)),V=c(C),q=a(-I*V),H=a(B*V),F=f.BASE.multiplyAndAddUnsafe(O,q,H);if(!F)throw new Error("point at infinify");return F.assertValidity(),F}hasHighS(){return g(this.s)}normalizeS(){return this.hasHighS()?new m(this.r,a(-this.s),this.recovery):this}toDERRawBytes(){return De(this.toDERHex())}toDERHex(){return $e.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return De(this.toCompactHex())}toCompactHex(){return w(this.r)+w(this.s)}}let x={isValidPrivateKey(v){try{return l(v),!0}catch{return!1}},normPrivateKeyToScalar:l,randomPrivateKey:()=>{let v=Ei(t.n);return ba(t.randomBytes(v),t.n)},precompute(v=8,N=f.BASE){return N._setWindowSize(v),N.multiply(BigInt(3)),N}};function b(v,N=!0){return f.fromPrivateKey(v).toRawBytes(N)}function T(v){let N=ve(v),P=typeof v=="string",B=(N||P)&&v.length;return N?B===s||B===i:P?B===2*s||B===2*i:v instanceof f}function E(v,N,P=!0){if(T(v))throw new Error("first arg must be private key");if(!T(N))throw new Error("second arg must be public key");return f.fromHex(N).multiply(l(v)).toRawBytes(P)}let S=t.bits2int||function(v){let N=ie(v),P=v.length*8-t.nBitLength;return P>0?N>>BigInt(P):N},R=t.bits2int_modN||function(v){return a(S(v))},_=Hr(t.nBitLength);function G(v){if(typeof v!="bigint")throw new Error("bigint expected");if(!(ge<=v&&v<_))throw new Error(`bigint expected < 2^${t.nBitLength}`);return Ae(v,t.nByteLength)}function K(v,N,P=D){if(["recovered","canonical"].some(Q=>Q in P))throw new Error("sign() legacy options not supported");let{hash:B,randomBytes:y}=t,{lowS:I,prehash:C,extraEntropy:L}=P;I==null&&(I=!0),v=et("msgHash",v),C&&(v=et("prehashed msgHash",B(v)));let O=R(v),V=l(N),q=[G(V),G(O)];if(L!=null&&L!==!1){let Q=L===!0?y(e.BYTES):L;q.push(et("extraEntropy",Q))}let H=oe(...q),F=O;function st(Q){let ht=S(Q);if(!p(ht))return;let dt=c(ht),at=f.BASE.multiply(ht).toAffine(),gt=a(at.x);if(gt===ge)return;let Xt=a(dt*a(F+gt*V));if(Xt===ge)return;let Ue=(at.x===gt?0:2)|Number(at.y&Dt),Nr=Xt;return I&&g(Xt)&&(Nr=h(Xt),Ue^=1),new m(gt,Nr,Ue)}return{seed:H,k2sig:st}}let D={lowS:t.lowS,prehash:!1},nt={lowS:t.lowS,prehash:!1};function rt(v,N,P=D){let{seed:B,k2sig:y}=K(v,N,P),I=t;return yi(I.hash.outputLen,I.nByteLength,I.hmac)(B,y)}f.BASE._setWindowSize(8);function Ct(v,N,P,B=nt){let y=v;if(N=et("msgHash",N),P=et("publicKey",P),"strict"in B)throw new Error("options.strict was renamed to lowS");let{lowS:I,prehash:C}=B,L,O;try{if(typeof y=="string"||ve(y))try{L=m.fromDER(y)}catch(at){if(!(at instanceof $e.Err))throw at;L=m.fromCompact(y)}else if(typeof y=="object"&&typeof y.r=="bigint"&&typeof y.s=="bigint"){let{r:at,s:gt}=y;L=new m(at,gt)}else throw new Error("PARSE");O=f.fromHex(P)}catch(at){if(at.message==="PARSE")throw new Error("signature must be Signature instance, Uint8Array or hex string");return!1}if(I&&L.hasHighS())return!1;C&&(N=t.hash(N));let{r:V,s:q}=L,H=R(N),F=c(q),st=a(H*F),Q=a(V*F),ht=f.BASE.multiplyAndAddUnsafe(O,st,Q)?.toAffine();return ht?a(ht.x)===V:!1}return{CURVE:t,getPublicKey:b,getSharedSecret:E,sign:rt,verify:Ct,ProjectivePoint:f,Signature:m,utils:x}}function Wh(r){return{hash:r,hmac:(t,...e)=>$r(r,t,hi(...e)),randomBytes:hr}}function Fc(r,t){let e=n=>Kc({...r,...Wh(n)});return Object.freeze({...e(t),create:e})}var Gc=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),qc=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),Jh=BigInt(1),io=BigInt(2),$c=(r,t)=>(r+t/io)/t;function Xh(r){let t=Gc,e=BigInt(3),n=BigInt(6),s=BigInt(11),i=BigInt(22),o=BigInt(23),a=BigInt(44),c=BigInt(88),f=r*r*r%t,l=f*f*r%t,u=X(l,e,t)*l%t,p=X(u,e,t)*l%t,w=X(p,io,t)*f%t,g=X(w,s,t)*w%t,h=X(g,i,t)*g%t,d=X(h,a,t)*h%t,m=X(d,c,t)*d%t,x=X(m,a,t)*h%t,b=X(x,e,t)*l%t,T=X(b,o,t)*g%t,E=X(T,n,t)*f%t,S=X(E,io,t);if(!oo.eql(oo.sqr(S),r))throw new Error("Cannot find square root");return S}var oo=xn(Gc,void 0,void 0,{sqrt:Xh}),$t=Fc({a:BigInt(0),b:BigInt(7),Fp:oo,n:qc,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=qc,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-Jh*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),s=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),i=e,o=BigInt("0x100000000000000000000000000000000"),a=$c(i*r,t),c=$c(-n*r,t),f=j(r-a*e-c*s,t),l=j(-a*n-c*i,t),u=f>o,p=l>o;if(u&&(f=t-f),p&&(l=t-l),f>o||l>o)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:u,k1:f,k2neg:p,k2:l}}}},Mc),ny=BigInt(0);var sy=$t.ProjectivePoint;function zc(){return $t.utils.randomPrivateKey()}function Yc(r,t){let e=ct.digest(t instanceof Uint8Array?t:t.subarray());if(Lt(e))return e.then(({digest:n})=>$t.sign(n,r).toDERRawBytes()).catch(n=>{throw new A(String(n),"ERR_INVALID_INPUT")});try{return $t.sign(e.digest,r).toDERRawBytes()}catch(n){throw new A(String(n),"ERR_INVALID_INPUT")}}function jc(r,t,e){let n=ct.digest(e instanceof Uint8Array?e:e.subarray());if(Lt(n))return n.then(({digest:s})=>$t.verify(t,s,r)).catch(s=>{throw new A(String(s),"ERR_INVALID_INPUT")});try{return $t.verify(t,n.digest,r)}catch(s){throw new A(String(s),"ERR_INVALID_INPUT")}}function Zc(r){return $t.ProjectivePoint.fromHex(r).toRawBytes(!0)}function Wc(r){try{$t.getPublicKey(r,!0)}catch(t){throw new A(String(t),"ERR_INVALID_PRIVATE_KEY")}}function ao(r){try{$t.ProjectivePoint.fromHex(r)}catch(t){throw new A(String(t),"ERR_INVALID_PUBLIC_KEY")}}function Jc(r){try{return $t.getPublicKey(r,!0)}catch(t){throw new A(String(t),"ERR_INVALID_PRIVATE_KEY")}}var Ge=class{_key;constructor(t){ao(t),this._key=t}verify(t,e){return jc(this._key,e,t)}marshal(){return Zc(this._key)}get bytes(){return Ht.encode({Type:Z.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return mt(this.bytes,t.bytes)}async hash(){let t=ct.digest(this.bytes),e;return Lt(t)?{bytes:e}=await t:e=t.bytes,e}},ze=class{_key;_publicKey;constructor(t,e){this._key=t,this._publicKey=e??Jc(t),Wc(this._key),ao(this._publicKey)}sign(t){return Yc(this._key,t)}get public(){return new Ge(this._publicKey)}marshal(){return this._key}get bytes(){return Kt.encode({Type:Z.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return mt(this.bytes,t.bytes)}hash(){let t=ct.digest(this.bytes);return Lt(t)?t.then(({bytes:e})=>e):t.bytes}async id(){let t=await this.public.hash();return Y(t,"base58btc")}async export(t,e="libp2p-key"){if(e==="libp2p-key")return yr(this.bytes,t);throw new A(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function td(r){return new ze(r)}function ed(r){return new Ge(r)}async function rd(){let r=zc();return new ze(r)}var me={rsa:no,ed25519:Gi,secp256k1:co};function uo(r){let t=Object.keys(me).join(" / ");return new A(`invalid or unsupported key type ${r}. Must be ${t}`,"ERR_UNSUPPORTED_KEY_TYPE")}function lo(r){if(r=r.toLowerCase(),r==="rsa"||r==="ed25519"||r==="secp256k1")return me[r];throw uo(r)}async function nd(r,t){return lo(r).generateKeyPair(t??2048)}async function sd(r,t,e){if(r.toLowerCase()!=="ed25519")throw new A("Seed key derivation is unimplemented for RSA or secp256k1","ERR_UNSUPPORTED_KEY_DERIVATION_TYPE");return $i(t)}function id(r){let t=Ht.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case Z.RSA:return me.rsa.unmarshalRsaPublicKey(e);case Z.Ed25519:return me.ed25519.unmarshalEd25519PublicKey(e);case Z.Secp256k1:return me.secp256k1.unmarshalSecp256k1PublicKey(e);default:throw uo(t.Type??"unknown")}}function od(r,t){return t=(t??"rsa").toLowerCase(),lo(t),r.bytes}async function Xc(r){let t=Kt.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case Z.RSA:return me.rsa.unmarshalRsaPrivateKey(e);case Z.Ed25519:return me.ed25519.unmarshalEd25519PrivateKey(e);case Z.Secp256k1:return me.secp256k1.unmarshalSecp256k1PrivateKey(e);default:throw uo(t.Type??"RSA")}}function ad(r,t){return t=(t??"rsa").toLowerCase(),lo(t),r.bytes}async function cd(r,t){try{let e=await $a(r,t);return await Xc(e)}catch{}if(!r.includes("BEGIN"))throw new A("Encrypted key was not a libp2p-key or a PEM file","ERR_INVALID_IMPORT_FORMAT");return to(r,t)}var tu=Symbol.for("@achingbrain/uint8arraylist");function Qc(r,t){if(t==null||t<0)throw new RangeError("index is out of bounds");let e=0;for(let n of r){let s=e+n.byteLength;if(t<s)return{buf:n,index:t-e};e=s}throw new RangeError("index is out of bounds")}function bs(r){return!!r?.[tu]}var Le=class r{bufs;length;[tu]=!0;constructor(...t){this.bufs=[],this.length=0,t.length>0&&this.appendAll(t)}*[Symbol.iterator](){yield*this.bufs}get byteLength(){return this.length}append(...t){this.appendAll(t)}appendAll(t){let e=0;for(let n of t)if(n instanceof Uint8Array)e+=n.byteLength,this.bufs.push(n);else if(bs(n))e+=n.byteLength,this.bufs.push(...n.bufs);else throw new Error("Could not append value, must be an Uint8Array or a Uint8ArrayList");this.length+=e}prepend(...t){this.prependAll(t)}prependAll(t){let e=0;for(let n of t.reverse())if(n instanceof Uint8Array)e+=n.byteLength,this.bufs.unshift(n);else if(bs(n))e+=n.byteLength,this.bufs.unshift(...n.bufs);else throw new Error("Could not prepend value, must be an Uint8Array or a Uint8ArrayList");this.length+=e}get(t){let e=Qc(this.bufs,t);return e.buf[e.index]}set(t,e){let n=Qc(this.bufs,t);n.buf[n.index]=e}write(t,e=0){if(t instanceof Uint8Array)for(let n=0;n<t.length;n++)this.set(e+n,t[n]);else if(bs(t))for(let n=0;n<t.length;n++)this.set(e+n,t.get(n));else throw new Error("Could not write value, must be an Uint8Array or a Uint8ArrayList")}consume(t){if(t=Math.trunc(t),!(Number.isNaN(t)||t<=0)){if(t===this.byteLength){this.bufs=[],this.length=0;return}for(;this.bufs.length>0;)if(t>=this.bufs[0].byteLength)t-=this.bufs[0].byteLength,this.length-=this.bufs[0].byteLength,this.bufs.shift();else{this.bufs[0]=this.bufs[0].subarray(t),this.length-=t;break}}}slice(t,e){let{bufs:n,length:s}=this._subList(t,e);return Bt(n,s)}subarray(t,e){let{bufs:n,length:s}=this._subList(t,e);return n.length===1?n[0]:Bt(n,s)}sublist(t,e){let{bufs:n,length:s}=this._subList(t,e),i=new r;return i.length=s,i.bufs=[...n],i}_subList(t,e){if(t=t??0,e=e??this.length,t<0&&(t=this.length+t),e<0&&(e=this.length+e),t<0||e>this.length)throw new RangeError("index is out of bounds");if(t===e)return{bufs:[],length:0};if(t===0&&e===this.length)return{bufs:this.bufs,length:this.length};let n=[],s=0;for(let i=0;i<this.bufs.length;i++){let o=this.bufs[i],a=s,c=a+o.byteLength;if(s=c,t>=c)continue;let f=t>=a&&t<c,l=e>a&&e<=c;if(f&&l){if(t===a&&e===c){n.push(o);break}let u=t-a;n.push(o.subarray(u,u+(e-t)));break}if(f){if(t===0){n.push(o);continue}n.push(o.subarray(t-a));continue}if(l){if(e===c){n.push(o);break}n.push(o.subarray(0,e-a));break}n.push(o)}return{bufs:n,length:e-t}}indexOf(t,e=0){if(!bs(t)&&!(t instanceof Uint8Array))throw new TypeError('The "value" argument must be a Uint8ArrayList or Uint8Array');let n=t instanceof Uint8Array?t:t.subarray();if(e=Number(e??0),isNaN(e)&&(e=0),e<0&&(e=this.length+e),e<0&&(e=0),t.length===0)return e>this.length?this.length:e;let s=n.byteLength;if(s===0)throw new TypeError("search must be at least 1 byte long");let i=256,o=new Int32Array(i);for(let u=0;u<i;u++)o[u]=-1;for(let u=0;u<s;u++)o[n[u]]=u;let a=o,c=this.byteLength-n.byteLength,f=n.byteLength-1,l;for(let u=e;u<=c;u+=l){l=0;for(let p=f;p>=0;p--){let w=this.get(u+p);if(n[p]!==w){l=Math.max(1,p-a[w]);break}}if(l===0)return u}return-1}getInt8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getInt8(0)}setInt8(t,e){let n=yt(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setInt8(0,e),this.write(n,t)}getInt16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt16(0,e)}setInt16(t,e,n){let s=ee(2);new DataView(s.buffer,s.byteOffset,s.byteLength).setInt16(0,e,n),this.write(s,t)}getInt32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt32(0,e)}setInt32(t,e,n){let s=ee(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setInt32(0,e,n),this.write(s,t)}getBigInt64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigInt64(0,e)}setBigInt64(t,e,n){let s=ee(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigInt64(0,e,n),this.write(s,t)}getUint8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getUint8(0)}setUint8(t,e){let n=yt(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setUint8(0,e),this.write(n,t)}getUint16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint16(0,e)}setUint16(t,e,n){let s=ee(2);new DataView(s.buffer,s.byteOffset,s.byteLength).setUint16(0,e,n),this.write(s,t)}getUint32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint32(0,e)}setUint32(t,e,n){let s=ee(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setUint32(0,e,n),this.write(s,t)}getBigUint64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigUint64(0,e)}setBigUint64(t,e,n){let s=ee(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigUint64(0,e,n),this.write(s,t)}getFloat32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat32(0,e)}setFloat32(t,e,n){let s=ee(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setFloat32(0,e,n),this.write(s,t)}getFloat64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat64(0,e)}setFloat64(t,e,n){let s=ee(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setFloat64(0,e,n),this.write(s,t)}equals(t){if(t==null||!(t instanceof r)||t.bufs.length!==this.bufs.length)return!1;for(let e=0;e<this.bufs.length;e++)if(!mt(this.bufs[e],t.bufs[e]))return!1;return!0}static fromUint8Arrays(t,e){let n=new r;return n.bufs=t,e==null&&(e=t.reduce((s,i)=>s+i.byteLength,0)),n.length=e,n}};function ws(){let r={};return r.promise=new Promise((t,e)=>{r.resolve=t,r.reject=e}),r}var xs=class{buffer;mask;top;btm;next;constructor(t){if(!(t>0)||t-1&t)throw new Error("Max size for a FixedFIFO should be a power of two");this.buffer=new Array(t),this.mask=t-1,this.top=0,this.btm=0,this.next=null}push(t){return this.buffer[this.top]!==void 0?!1:(this.buffer[this.top]=t,this.top=this.top+1&this.mask,!0)}shift(){let t=this.buffer[this.btm];if(t!==void 0)return this.buffer[this.btm]=void 0,this.btm=this.btm+1&this.mask,t}isEmpty(){return this.buffer[this.btm]===void 0}},Sr=class{size;hwm;head;tail;constructor(t={}){this.hwm=t.splitLimit??16,this.head=new xs(this.hwm),this.tail=this.head,this.size=0}calculateSize(t){return t?.byteLength!=null?t.byteLength:1}push(t){if(t?.value!=null&&(this.size+=this.calculateSize(t.value)),!this.head.push(t)){let e=this.head;this.head=e.next=new xs(2*this.head.buffer.length),this.head.push(t)}}shift(){let t=this.tail.shift();if(t===void 0&&this.tail.next!=null){let e=this.tail.next;this.tail.next=null,this.tail=e,t=this.tail.shift()}return t?.value!=null&&(this.size-=this.calculateSize(t.value)),t}isEmpty(){return this.head.isEmpty()}};var fo=class extends Error{type;code;constructor(t,e){super(t??"The operation was aborted"),this.type="aborted",this.code=e??"ABORT_ERR"}};function kr(r={}){return ud(e=>{let n=e.shift();if(n==null)return{done:!0};if(n.error!=null)throw n.error;return{done:n.done===!0,value:n.value}},r)}function ud(r,t){t=t??{};let e=t.onEnd,n=new Sr,s,i,o,a=ws(),c=async()=>{try{return n.isEmpty()?o?{done:!0}:await new Promise((d,m)=>{i=x=>{i=null,n.push(x);try{d(r(n))}catch(b){m(b)}return s}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{a.resolve(),a=ws()})}},f=d=>i!=null?i(d):(n.push(d),s),l=d=>(n=new Sr,i!=null?i({error:d}):(n.push({error:d}),s)),u=d=>{if(o)return s;if(t?.objectMode!==!0&&d?.byteLength==null)throw new Error("objectMode was not true but tried to push non-Uint8Array value");return f({done:!1,value:d})},p=d=>o?s:(o=!0,d!=null?l(d):f({done:!0})),w=()=>(n=new Sr,p(),{done:!0}),g=d=>(p(d),{done:!0});if(s={[Symbol.asyncIterator](){return this},next:c,return:w,throw:g,push:u,end:p,get readableLength(){return n.size},onEmpty:async d=>{let m=d?.signal;if(m?.throwIfAborted(),n.isEmpty())return;let x,b;m!=null&&(x=new Promise((T,E)=>{b=()=>{E(new fo)},m.addEventListener("abort",b)}));try{await Promise.race([a.promise,x])}finally{b!=null&&m!=null&&m?.removeEventListener("abort",b)}}},e==null)return s;let h=s;return s={[Symbol.asyncIterator](){return this},next(){return h.next()},throw(d){return h.throw(d),e!=null&&(e(d),e=void 0),{done:!0}},return(){return h.return(),e!=null&&(e(),e=void 0),{done:!0}},push:u,end(d){return h.end(d),e!=null&&(e(d),e=void 0),s},get readableLength(){return h.readableLength},onEmpty:d=>h.onEmpty(d)},s}function ld(r){return r[Symbol.asyncIterator]!=null}function fd(...r){let t=[];for(let e of r)ld(e)||t.push(e);return t.length===r.length?function*(){for(let e of t)yield*e}():async function*(){let e=kr({objectMode:!0});Promise.resolve().then(async()=>{try{await Promise.all(r.map(async n=>{for await(let s of n)e.push(s)})),e.end()}catch(n){e.end(n)}}),yield*e}()}var eu=fd;function en(r,...t){if(r==null)throw new Error("Empty pipeline");if(ho(r)){let n=r;r=()=>n.source}else if(nu(r)||ru(r)){let n=r;r=()=>n}let e=[r,...t];if(e.length>1&&ho(e[e.length-1])&&(e[e.length-1]=e[e.length-1].sink),e.length>2)for(let n=1;n<e.length-1;n++)ho(e[n])&&(e[n]=dd(e[n]));return hd(...e)}var hd=(...r)=>{let t;for(;r.length>0;)t=r.shift()(t);return t},ru=r=>r?.[Symbol.asyncIterator]!=null,nu=r=>r?.[Symbol.iterator]!=null,ho=r=>r==null?!1:r.sink!=null&&r.source!=null,dd=r=>t=>{let e=r.sink(t);if(e?.then!=null){let n=kr({objectMode:!0});e.then(()=>{n.end()},o=>{n.end(o)});let s,i=r.source;if(ru(i))s=async function*(){yield*i,n.end()};else if(nu(i))s=function*(){yield*i,n.end()};else throw new Error("Unknown duplex source type - must be Iterable or AsyncIterable");return eu(n,s())}return r.source};var go=Os(iu(),1);var nn=class extends Error{constructor(t){super(t),this.name="TimeoutError"}},mo=class extends Error{constructor(t){super(),this.name="AbortError",this.message=t}},ou=r=>globalThis.DOMException===void 0?new mo(r):new DOMException(r),au=r=>{let t=r.reason===void 0?ou("This operation was aborted."):r.reason;return t instanceof Error?t:ou(t)};function yo(r,t){let{milliseconds:e,fallback:n,message:s,customTimers:i={setTimeout,clearTimeout}}=t,o,c=new Promise((f,l)=>{if(typeof e!="number"||Math.sign(e)!==1)throw new TypeError(`Expected \`milliseconds\` to be a positive number, got \`${e}\``);if(t.signal){let{signal:p}=t;p.aborted&&l(au(p)),p.addEventListener("abort",()=>{l(au(p))})}if(e===Number.POSITIVE_INFINITY){r.then(f,l);return}let u=new nn;o=i.setTimeout.call(void 0,()=>{if(n){try{f(n())}catch(p){l(p)}return}typeof r.cancel=="function"&&r.cancel(),s===!1?f():s instanceof Error?l(s):(u.message=s??`Promise timed out after ${e} milliseconds`,l(u))},e),(async()=>{try{f(await r)}catch(p){l(p)}})()}).finally(()=>{c.clear()});return c.clear=()=>{i.clearTimeout.call(void 0,o),o=void 0},c}function bo(r,t,e){let n=0,s=r.length;for(;s>0;){let i=Math.trunc(s/2),o=n+i;e(r[o],t)<=0?(n=++o,s-=i+1):s=i}return n}var sn=class{#t=[];enqueue(t,e){e={priority:0,...e};let n={priority:e.priority,run:t};if(this.size&&this.#t[this.size-1].priority>=e.priority){this.#t.push(n);return}let s=bo(this.#t,n,(i,o)=>o.priority-i.priority);this.#t.splice(s,0,n)}dequeue(){return this.#t.shift()?.run}filter(t){return this.#t.filter(e=>e.priority===t.priority).map(e=>e.run)}get size(){return this.#t.length}};var on=class extends go.default{#t;#o;#i=0;#d;#a;#p=0;#r;#c;#e;#g;#n=0;#u;#s;#m;timeout;constructor(t){if(super(),t={carryoverConcurrencyCount:!1,intervalCap:Number.POSITIVE_INFINITY,interval:0,concurrency:Number.POSITIVE_INFINITY,autoStart:!0,queueClass:sn,...t},!(typeof t.intervalCap=="number"&&t.intervalCap>=1))throw new TypeError(`Expected \`intervalCap\` to be a number from 1 and up, got \`${t.intervalCap?.toString()??""}\` (${typeof t.intervalCap})`);if(t.interval===void 0||!(Number.isFinite(t.interval)&&t.interval>=0))throw new TypeError(`Expected \`interval\` to be a finite number >= 0, got \`${t.interval?.toString()??""}\` (${typeof t.interval})`);this.#t=t.carryoverConcurrencyCount,this.#o=t.intervalCap===Number.POSITIVE_INFINITY||t.interval===0,this.#d=t.intervalCap,this.#a=t.interval,this.#e=new t.queueClass,this.#g=t.queueClass,this.concurrency=t.concurrency,this.timeout=t.timeout,this.#m=t.throwOnTimeout===!0,this.#s=t.autoStart===!1}get#w(){return this.#o||this.#i<this.#d}get#x(){return this.#n<this.#u}#E(){this.#n--,this.#l(),this.emit("next")}#v(){this.#b(),this.#y(),this.#c=void 0}get#B(){let t=Date.now();if(this.#r===void 0){let e=this.#p-t;if(e<0)this.#i=this.#t?this.#n:0;else return this.#c===void 0&&(this.#c=setTimeout(()=>{this.#v()},e)),!0}return!1}#l(){if(this.#e.size===0)return this.#r&&clearInterval(this.#r),this.#r=void 0,this.emit("empty"),this.#n===0&&this.emit("idle"),!1;if(!this.#s){let t=!this.#B;if(this.#w&&this.#x){let e=this.#e.dequeue();return e?(this.emit("active"),e(),t&&this.#y(),!0):!1}}return!1}#y(){this.#o||this.#r!==void 0||(this.#r=setInterval(()=>{this.#b()},this.#a),this.#p=Date.now()+this.#a)}#b(){this.#i===0&&this.#n===0&&this.#r&&(clearInterval(this.#r),this.#r=void 0),this.#i=this.#t?this.#n:0,this.#f()}#f(){for(;this.#l(););}get concurrency(){return this.#u}set concurrency(t){if(!(typeof t=="number"&&t>=1))throw new TypeError(`Expected \`concurrency\` to be a number from 1 and up, got \`${t}\` (${typeof t})`);this.#u=t,this.#f()}async#A(t){return new Promise((e,n)=>{t.addEventListener("abort",()=>{n(t.reason)},{once:!0})})}async add(t,e={}){return e={timeout:this.timeout,throwOnTimeout:this.#m,...e},new Promise((n,s)=>{this.#e.enqueue(async()=>{this.#n++,this.#i++;try{e.signal?.throwIfAborted();let i=t({signal:e.signal});e.timeout&&(i=yo(Promise.resolve(i),{milliseconds:e.timeout})),e.signal&&(i=Promise.race([i,this.#A(e.signal)]));let o=await i;n(o),this.emit("completed",o)}catch(i){if(i instanceof nn&&!e.throwOnTimeout){n();return}s(i),this.emit("error",i)}finally{this.#E()}},e),this.emit("add"),this.#l()})}async addAll(t,e){return Promise.all(t.map(async n=>this.add(n,e)))}start(){return this.#s?(this.#s=!1,this.#f(),this):this}pause(){this.#s=!0}clear(){this.#e=new this.#g}async onEmpty(){this.#e.size!==0&&await this.#h("empty")}async onSizeLessThan(t){this.#e.size<t||await this.#h("next",()=>this.#e.size<t)}async onIdle(){this.#n===0&&this.#e.size===0||await this.#h("idle")}async#h(t,e){return new Promise(n=>{let s=()=>{e&&!e()||(this.off(t,s),n())};this.on(t,s)})}get size(){return this.#e.size}sizeBy(t){return this.#e.filter(t).length}get pending(){return this.#n}get isPaused(){return this.#s}};var lt={ERR_INVALID_SIGNATURE_POLICY:"ERR_INVALID_SIGNATURE_POLICY",ERR_UNHANDLED_SIGNATURE_POLICY:"ERR_UNHANDLED_SIGNATURE_POLICY",ERR_MISSING_SIGNATURE:"ERR_MISSING_SIGNATURE",ERR_MISSING_SEQNO:"ERR_MISSING_SEQNO",ERR_MISSING_KEY:"ERR_MISSING_KEY",ERR_INVALID_SIGNATURE:"ERR_INVALID_SIGNATURE",ERR_MISSING_FROM:"ERR_MISSING_FROM",ERR_UNEXPECTED_FROM:"ERR_UNEXPECTED_FROM",ERR_UNEXPECTED_SIGNATURE:"ERR_UNEXPECTED_SIGNATURE",ERR_UNEXPECTED_KEY:"ERR_UNEXPECTED_KEY",ERR_UNEXPECTED_SEQNO:"ERR_UNEXPECTED_SEQNO",ERR_TOPIC_VALIDATOR_REJECT:"ERR_TOPIC_VALIDATOR_REJECT"};function cu(r){if(r!=null){if(typeof r[Symbol.iterator]=="function")return r[Symbol.iterator]();if(typeof r[Symbol.asyncIterator]=="function")return r[Symbol.asyncIterator]();if(typeof r.next=="function")return r}throw new Error("argument is not an iterator or iterable")}function uu(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function lu(r,t){let e=cu(r).return?.();uu(e)&&e.catch(n=>{t.error("could not cause iterator to return",n)})}function vs(r){return r[Symbol.asyncIterator]!=null}var Bs=r=>{let t=Vt(r),e=yt(t);return Na(r,e),Bs.bytes=t,e};Bs.bytes=0;function As(r,t){t=t??{};let e=t.lengthEncoder??Bs;function*n(s){let i=e(s.byteLength);i instanceof Uint8Array?yield i:yield*i,s instanceof Uint8Array?yield s:yield*s}return vs(r)?async function*(){for await(let s of r)yield*n(s)}():function*(){for(let s of r)yield*n(s)}()}As.single=(r,t)=>{t=t??{};let e=t.lengthEncoder??Bs;return new Le(e(r.byteLength),r)};var Ir=Os(du(),1);var yd=8,bd=1024*1024*4,Ye;(function(r){r[r.LENGTH=0]="LENGTH",r[r.DATA=1]="DATA"})(Ye||(Ye={}));var wo=r=>{let t=Ra(r);return wo.bytes=Vt(t),t};wo.bytes=0;function an(r,t){let e=new Le,n=Ye.LENGTH,s=-1,i=t?.lengthDecoder??wo,o=t?.maxLengthLength??yd,a=t?.maxDataLength??bd;function*c(){for(;e.byteLength>0;){if(n===Ye.LENGTH)try{if(s=i(e),s<0)throw(0,Ir.default)(new Error("invalid message length"),"ERR_INVALID_MSG_LENGTH");if(s>a)throw(0,Ir.default)(new Error("message length too long"),"ERR_MSG_DATA_TOO_LONG");let f=i.bytes;e.consume(f),t?.onLength!=null&&t.onLength(s),n=Ye.DATA}catch(f){if(f instanceof RangeError){if(e.byteLength>o)throw(0,Ir.default)(new Error("message length length too long"),"ERR_MSG_LENGTH_TOO_LONG");break}throw f}if(n===Ye.DATA){if(e.byteLength<s)break;let f=e.sublist(0,s);e.consume(s),t?.onData!=null&&t.onData(f),yield f,n=Ye.LENGTH}}}return vs(r)?async function*(){for await(let f of r)e.append(f),yield*c();if(e.byteLength>0)throw(0,Ir.default)(new Error("unexpected end of input"),"ERR_UNEXPECTED_EOF")}():function*(){for(let f of r)e.append(f),yield*c();if(e.byteLength>0)throw(0,Ir.default)(new Error("unexpected end of input"),"ERR_UNEXPECTED_EOF")}()}an.fromReader=(r,t)=>{let e=1,n=async function*(){for(;;)try{let{done:i,value:o}=await r.next(e);if(i===!0)return;o!=null&&(yield o)}catch(i){if(i.code==="ERR_UNDER_READ")return{done:!0,value:null};throw i}finally{e=1}}();return an(n,{...t??{},onLength:i=>{e=i}})};var Ss=class extends Ze{id;protocol;outboundStream;inboundStream;_rawOutboundStream;_rawInboundStream;_inboundAbortController;closed;log;constructor(t,e){super(),this.log=t.logger.forComponent("libp2p-pubsub:peer-streams"),this.id=e.id,this.protocol=e.protocol,this._inboundAbortController=new AbortController,this.closed=!1}get isReadable(){return!!this.inboundStream}get isWritable(){return!!this.outboundStream}write(t){if(this.outboundStream==null){let e=this.id.toString();throw new Error("No writable connection to "+e)}this.outboundStream.push(t instanceof Uint8Array?new Le(t):t)}attachInboundStream(t){let e=()=>{lu(t.source,this.log)};return this._inboundAbortController.signal.addEventListener("abort",e,{once:!0}),this._rawInboundStream=t,this.inboundStream=en(this._rawInboundStream,n=>an(n)),this.dispatchEvent(new Gt("stream:inbound")),this.inboundStream}async attachOutboundStream(t){let e=this.outboundStream;return this.outboundStream!=null&&this.outboundStream.end(),this._rawOutboundStream=t,this.outboundStream=kr({onEnd:n=>{this._rawOutboundStream!=null&&this._rawOutboundStream.closeWrite().catch(s=>{this.log("error closing outbound stream",s)}),this._rawOutboundStream=void 0,this.outboundStream=void 0,n!=null&&this.dispatchEvent(new Gt("close"))}}),en(this.outboundStream,n=>As(n),this._rawOutboundStream).catch(n=>{this.log.error(n)}),e==null&&this.dispatchEvent(new Gt("stream:outbound")),this.outboundStream}close(){this.closed||(this.closed=!0,this.outboundStream!=null&&this.outboundStream.end(),this.inboundStream!=null&&this._inboundAbortController.abort(),this._rawOutboundStream=void 0,this.outboundStream=void 0,this._rawInboundStream=void 0,this.inboundStream=void 0,this.dispatchEvent(new Gt("close")))}};function pu(){return BigInt(`0x${Y(jt(8),"base16")}`)}var gu=(r,t)=>{let e=$(t.toString(16).padStart(16,"0"),"base16"),n=new Uint8Array(r.length+e.length);return n.set(r,0),n.set(e,r.length),n},mu=r=>ct.encode(r);var yu=function(r){return Array.isArray(r)?r:[r]},xd=async r=>{if(r.sequenceNumber==null||r.from==null||r.signature==null)return!1;let t=Pr(r.from);return t.publicKey!=null?!0:r.key!=null?(await hn(r.key)).equals(t):!1},bu=async r=>{if(r.from==null)throw new A("RPC message was missing from",lt.ERR_MISSING_FROM);if(!await xd(r))return{type:"unsigned",topic:r.topic??"",data:r.data??new Uint8Array(0)};let t=Pr(r.from),e={type:"signed",from:Pr(r.from),topic:r.topic??"",sequenceNumber:vd(r.sequenceNumber??new Uint8Array(0)),data:r.data??new Uint8Array(0),signature:r.signature??new Uint8Array(0),key:r.key??t.publicKey??new Uint8Array(0)};if(e.key.length===0)throw new A("Signed RPC message was missing key",lt.ERR_MISSING_KEY);return e},cn=r=>r.type==="signed"?{from:r.from.multihash.bytes,data:r.data,sequenceNumber:Ed(r.sequenceNumber),topic:r.topic,signature:r.signature,key:r.key}:{data:r.data,topic:r.topic},Ed=r=>{let t=r.toString(16);return t.length%2!==0&&(t=`0${t}`),$(t,"base16")},vd=r=>BigInt(`0x${Y(r,"base16")}`);var wu=$("libp2p-pubsub:");async function xu(r,t,e){if(r.privateKey==null)throw new Error("Cannot sign message, no private key present");if(r.publicKey==null)throw new Error("Cannot sign message, no public key present");let n={type:"signed",topic:t.topic,data:t.data,sequenceNumber:t.sequenceNumber,from:r},s=Bt([wu,e(cn(n)).subarray()]),i=await tn.unmarshalPrivateKey(r.privateKey);return n.signature=await i.sign(s),n.key=r.publicKey,n}async function Eu(r,t){if(r.type!=="signed")throw new Error('Message type must be "signed" to be verified');if(r.signature==null)throw new Error("Message must contain a signature to be verified");if(r.from==null)throw new Error("Message must contain a from property to be verified");let e=Bt([wu,t({...cn(r),signature:void 0,key:void 0}).subarray()]),n=await Bd(r);return tn.unmarshalPublicKey(n).verify(e,r.signature)}async function Bd(r){if(r.type!=="signed")throw new Error('Message type must be "signed" to have a public key');if(r.from==null)throw new Error("Could not get the public key from the originator id");if(r.key!=null){let t=await hn(r.key);if(t.publicKey!=null)return t.publicKey}if(r.from.publicKey!=null)return r.from.publicKey;throw new Error("Could not get the public key from the originator id")}var ks=class extends Ze{log;started;topics;subscriptions;peers;globalSignaturePolicy;canRelayMessage;emitSelf;topicValidators;queue;multicodecs;components;_registrarTopologyIds;enabled;maxInboundStreams;maxOutboundStreams;constructor(t,e){super();let{multicodecs:n=[],globalSignaturePolicy:s="StrictSign",canRelayMessage:i=!1,emitSelf:o=!1,messageProcessingConcurrency:a=10,maxInboundStreams:c=1,maxOutboundStreams:f=1}=e;this.log=t.logger.forComponent("libp2p:pubsub"),this.components=t,this.multicodecs=yu(n),this.enabled=e.enabled!==!1,this.started=!1,this.topics=new Map,this.subscriptions=new Set,this.peers=new Or,this.globalSignaturePolicy=s==="StrictNoSign"?"StrictNoSign":"StrictSign",this.canRelayMessage=i,this.emitSelf=o,this.topicValidators=new Map,this.queue=new on({concurrency:a}),this.maxInboundStreams=c,this.maxOutboundStreams=f,this._onIncomingStream=this._onIncomingStream.bind(this),this._onPeerConnected=this._onPeerConnected.bind(this),this._onPeerDisconnected=this._onPeerDisconnected.bind(this)}async start(){if(this.started||!this.enabled)return;this.log("starting");let t=this.components.registrar;await Promise.all(this.multicodecs.map(async n=>{await t.handle(n,this._onIncomingStream,{maxInboundStreams:this.maxInboundStreams,maxOutboundStreams:this.maxOutboundStreams})}));let e={onConnect:this._onPeerConnected,onDisconnect:this._onPeerDisconnected};this._registrarTopologyIds=await Promise.all(this.multicodecs.map(async n=>t.register(n,e))),this.log("started"),this.started=!0}async stop(){if(!this.started||!this.enabled)return;let t=this.components.registrar;this._registrarTopologyIds!=null&&this._registrarTopologyIds?.forEach(e=>{t.unregister(e)}),await Promise.all(this.multicodecs.map(async e=>{await t.unhandle(e)})),this.log("stopping");for(let e of this.peers.values())e.close();this.peers.clear(),this.subscriptions=new Set,this.started=!1,this.log("stopped")}isStarted(){return this.started}_onIncomingStream(t){let{stream:e,connection:n}=t,s=n.remotePeer;if(e.protocol==null){e.abort(new Error("Stream was not multiplexed"));return}let i=this.addPeer(s,e.protocol),o=i.attachInboundStream(e);this.processMessages(s,o,i).catch(a=>{this.log(a)})}_onPeerConnected(t,e){if(this.log("connected %p",t),e.streams.find(n=>n.direction==="outbound"&&n.protocol!=null&&this.multicodecs.includes(n.protocol))!=null){this.log("outbound pubsub streams already present on connection from %p",t);return}Promise.resolve().then(async()=>{try{let n=await e.newStream(this.multicodecs);if(n.protocol==null){n.abort(new Error("Stream was not multiplexed"));return}await this.addPeer(t,n.protocol).attachOutboundStream(n)}catch(n){this.log.error(n)}this.send(t,{subscriptions:Array.from(this.subscriptions).map(n=>n.toString()),subscribe:!0})}).catch(n=>{this.log.error(n)})}_onPeerDisconnected(t,e){let n=t.toString();this.log("connection ended",n),this._removePeer(t)}addPeer(t,e){let n=this.peers.get(t);if(n!=null)return n;this.log("new peer %p",t);let s=new Ss(this.components,{id:t,protocol:e});return this.peers.set(t,s),s.addEventListener("close",()=>this._removePeer(t),{once:!0}),s}_removePeer(t){let e=this.peers.get(t);if(e!=null){e.close(),this.log("delete peer %p",t),this.peers.delete(t);for(let n of this.topics.values())n.delete(t);return e}}async processMessages(t,e,n){try{await en(e,async s=>{for await(let i of s){let o=this.decodeRpc(i),a=[];for(let c of o.messages??[]){if(c.from==null||c.data==null||c.topic==null){this.log("message from %p was missing from, data or topic fields, dropping",t);continue}a.push({from:c.from,data:c.data,topic:c.topic,sequenceNumber:c.sequenceNumber??void 0,signature:c.signature??void 0,key:c.key??void 0})}this.processRpc(t,n,{subscriptions:(o.subscriptions??[]).map(c=>({subscribe:!!c.subscribe,topic:c.topic??""})),messages:a}).catch(c=>{this.log(c)})}})}catch(s){this._onPeerDisconnected(n.id,s)}}async processRpc(t,e,n){if(!this.acceptFrom(t))return this.log("received message from unacceptable peer %p",t),!1;this.log("rpc from %p",t);let{subscriptions:s,messages:i}=n;return s!=null&&s.length>0&&(this.log("subscription update from %p",t),s.forEach(o=>{this.processRpcSubOpt(t,o)}),super.dispatchEvent(new Gt("subscription-change",{detail:{peerId:e.id,subscriptions:s.map(({topic:o,subscribe:a})=>({topic:`${o??""}`,subscribe:!!a}))}}))),i!=null&&i.length>0&&(this.log("messages from %p",t),this.queue.addAll(i.map(o=>async()=>{if(o.topic==null||!this.subscriptions.has(o.topic)&&!this.canRelayMessage)return this.log("received message we didn't subscribe to. Dropping."),!1;try{let a=await bu(o);await this.processMessage(t,a)}catch(a){this.log.error(a)}})).catch(o=>{this.log(o)})),!0}processRpcSubOpt(t,e){let n=e.topic;if(n==null)return;let s=this.topics.get(n);s==null&&(s=new Vr,this.topics.set(n,s)),e.subscribe===!0?s.add(t):s.delete(t)}async processMessage(t,e){if(!(this.components.peerId.equals(t)&&!this.emitSelf)){try{await this.validate(t,e)}catch(n){this.log("Message is invalid, dropping it. %O",n);return}this.subscriptions.has(e.topic)&&(!this.components.peerId.equals(t)||this.emitSelf)&&super.dispatchEvent(new Gt("message",{detail:e})),await this.publishMessage(t,e)}}getMsgId(t){switch(this.globalSignaturePolicy){case"StrictSign":if(t.type!=="signed")throw new A('Message type should be "signed" when signature policy is StrictSign but it was not',lt.ERR_MISSING_SIGNATURE);if(t.sequenceNumber==null)throw new A("Need seqno when signature policy is StrictSign but it was missing",lt.ERR_MISSING_SEQNO);if(t.key==null)throw new A("Need key when signature policy is StrictSign but it was missing",lt.ERR_MISSING_KEY);return gu(t.key,t.sequenceNumber);case"StrictNoSign":return mu(t.data);default:throw new A("Cannot get message id: unhandled signature policy",lt.ERR_UNHANDLED_SIGNATURE_POLICY)}}acceptFrom(t){return!0}send(t,e){let{messages:n,subscriptions:s,subscribe:i}=e;this.sendRpc(t,{subscriptions:(s??[]).map(o=>({topic:o,subscribe:!!i})),messages:(n??[]).map(cn)})}sendRpc(t,e){let n=this.peers.get(t);if(n==null){this.log.error("Cannot send RPC to %p as there are no streams to it available",t);return}if(!n.isWritable){this.log.error("Cannot send RPC to %p as there is no outbound stream to it available",t);return}n.write(this.encodeRpc(e))}async validate(t,e){switch(this.globalSignaturePolicy){case"StrictNoSign":if(e.type!=="unsigned")throw new A('Message type should be "unsigned" when signature policy is StrictNoSign but it was not',lt.ERR_MISSING_SIGNATURE);if(e.signature!=null)throw new A("StrictNoSigning: signature should not be present",lt.ERR_UNEXPECTED_SIGNATURE);if(e.key!=null)throw new A("StrictNoSigning: key should not be present",lt.ERR_UNEXPECTED_KEY);if(e.sequenceNumber!=null)throw new A("StrictNoSigning: seqno should not be present",lt.ERR_UNEXPECTED_SEQNO);break;case"StrictSign":if(e.type!=="signed")throw new A('Message type should be "signed" when signature policy is StrictSign but it was not',lt.ERR_MISSING_SIGNATURE);if(e.signature==null)throw new A("StrictSigning: Signing required and no signature was present",lt.ERR_MISSING_SIGNATURE);if(e.sequenceNumber==null)throw new A("StrictSigning: Signing required and no sequenceNumber was present",lt.ERR_MISSING_SEQNO);if(!await Eu(e,this.encodeMessage.bind(this)))throw new A("StrictSigning: Invalid message signature",lt.ERR_INVALID_SIGNATURE);break;default:throw new A("Cannot validate message: unhandled signature policy",lt.ERR_UNHANDLED_SIGNATURE_POLICY)}let s=this.topicValidators.get(e.topic);if(s!=null){let i=await s(t,e);if(i===Rr.Reject||i===Rr.Ignore)throw new A("Message validation failed",lt.ERR_TOPIC_VALIDATOR_REJECT)}}async buildMessage(t){switch(this.globalSignaturePolicy){case"StrictSign":return xu(this.components.peerId,t,this.encodeMessage.bind(this));case"StrictNoSign":return Promise.resolve({type:"unsigned",...t});default:throw new A("Cannot build message: unhandled signature policy",lt.ERR_UNHANDLED_SIGNATURE_POLICY)}}getSubscribers(t){if(!this.started)throw new A("not started yet","ERR_NOT_STARTED_YET");if(t==null)throw new A("topic is required","ERR_NOT_VALID_TOPIC");let e=this.topics.get(t.toString());return e==null?[]:Array.from(e.values())}async publish(t,e){if(!this.started)throw new Error("Pubsub has not started");let n={from:this.components.peerId,topic:t,data:e??new Uint8Array(0),sequenceNumber:pu()};this.log("publish topic: %s from: %p data: %m",t,n.from,n.data);let s=await this.buildMessage(n),i=!1;this.emitSelf&&this.subscriptions.has(t)&&(i=!0,super.dispatchEvent(new Gt("message",{detail:s})));let o=await this.publishMessage(this.components.peerId,s);return i&&(o.recipients=[...o.recipients,this.components.peerId]),o}subscribe(t){if(!this.started)throw new Error("Pubsub has not started");if(this.log("subscribe to topic: %s",t),!this.subscriptions.has(t)){this.subscriptions.add(t);for(let e of this.peers.keys())this.send(e,{subscriptions:[t],subscribe:!0})}}unsubscribe(t){if(!this.started)throw new Error("Pubsub is not started");super.removeEventListener(t);let e=this.subscriptions.has(t);if(this.log("unsubscribe from %s - am subscribed %s",t,e),e){this.subscriptions.delete(t);for(let n of this.peers.keys())this.send(n,{subscriptions:[t],subscribe:!1})}}getTopics(){if(!this.started)throw new Error("Pubsub is not started");return Array.from(this.subscriptions)}getPeers(){if(!this.started)throw new Error("Pubsub is not started");return Array.from(this.peers.keys())}};var Is=class{entries;validityMs;lastPruneTime=0;constructor(t){this.entries=new Map,this.validityMs=t.validityMs}put(t,e){this.entries.set(t,{value:e,validUntilMs:Date.now()+this.validityMs}),this.prune()}prune(){let t=Date.now();if(!(t-this.lastPruneTime<200)){this.lastPruneTime=t;for(let[e,n]of this.entries.entries())if(n.validUntilMs<t)this.entries.delete(e);else break}}has(t){return this.entries.has(t)}get(t){let e=this.entries.get(t);return e!=null&&e.validUntilMs>=Date.now()?e.value:void 0}clear(){this.entries=new Map,this.lastPruneTime=0}};var xo="/floodsub/1.0.0";var je;(function(r){let t;(function(s){let i;s.codec=()=>(i==null&&(i=Nt((o,a,c={})=>{c.lengthDelimited!==!1&&a.fork(),o.subscribe!=null&&(a.uint32(8),a.bool(o.subscribe)),o.topic!=null&&(a.uint32(18),a.string(o.topic)),c.lengthDelimited!==!1&&a.ldelim()},(o,a)=>{let c={},f=a==null?o.len:o.pos+a;for(;o.pos<f;){let l=o.uint32();switch(l>>>3){case 1:c.subscribe=o.bool();break;case 2:c.topic=o.string();break;default:o.skipType(l&7);break}}return c})),i),s.encode=o=>It(o,s.codec()),s.decode=o=>kt(o,s.codec())})(t=r.SubOpts||(r.SubOpts={}));let e;(function(s){let i;s.codec=()=>(i==null&&(i=Nt((o,a,c={})=>{c.lengthDelimited!==!1&&a.fork(),o.from!=null&&(a.uint32(10),a.bytes(o.from)),o.data!=null&&(a.uint32(18),a.bytes(o.data)),o.sequenceNumber!=null&&(a.uint32(26),a.bytes(o.sequenceNumber)),o.topic!=null&&(a.uint32(34),a.string(o.topic)),o.signature!=null&&(a.uint32(42),a.bytes(o.signature)),o.key!=null&&(a.uint32(50),a.bytes(o.key)),c.lengthDelimited!==!1&&a.ldelim()},(o,a)=>{let c={},f=a==null?o.len:o.pos+a;for(;o.pos<f;){let l=o.uint32();switch(l>>>3){case 1:c.from=o.bytes();break;case 2:c.data=o.bytes();break;case 3:c.sequenceNumber=o.bytes();break;case 4:c.topic=o.string();break;case 5:c.signature=o.bytes();break;case 6:c.key=o.bytes();break;default:o.skipType(l&7);break}}return c})),i),s.encode=o=>It(o,s.codec()),s.decode=o=>kt(o,s.codec())})(e=r.Message||(r.Message={}));let n;r.codec=()=>(n==null&&(n=Nt((s,i,o={})=>{if(o.lengthDelimited!==!1&&i.fork(),s.subscriptions!=null)for(let a of s.subscriptions)i.uint32(10),r.SubOpts.codec().encode(a,i);if(s.messages!=null)for(let a of s.messages)i.uint32(18),r.Message.codec().encode(a,i);s.control!=null&&(i.uint32(26),Ns.codec().encode(s.control,i)),o.lengthDelimited!==!1&&i.ldelim()},(s,i)=>{let o={subscriptions:[],messages:[]},a=i==null?s.len:s.pos+i;for(;s.pos<a;){let c=s.uint32();switch(c>>>3){case 1:o.subscriptions.push(r.SubOpts.codec().decode(s,s.uint32()));break;case 2:o.messages.push(r.Message.codec().decode(s,s.uint32()));break;case 3:o.control=Ns.codec().decode(s,s.uint32());break;default:s.skipType(c&7);break}}return o})),n),r.encode=s=>It(s,r.codec()),r.decode=s=>kt(s,r.codec())})(je||(je={}));var Ns;(function(r){let t;r.codec=()=>(t==null&&(t=Nt((e,n,s={})=>{if(s.lengthDelimited!==!1&&n.fork(),e.ihave!=null)for(let i of e.ihave)n.uint32(10),Rs.codec().encode(i,n);if(e.iwant!=null)for(let i of e.iwant)n.uint32(18),_s.codec().encode(i,n);if(e.graft!=null)for(let i of e.graft)n.uint32(26),Ts.codec().encode(i,n);if(e.prune!=null)for(let i of e.prune)n.uint32(34),Cs.codec().encode(i,n);s.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let s={ihave:[],iwant:[],graft:[],prune:[]},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let o=e.uint32();switch(o>>>3){case 1:s.ihave.push(Rs.codec().decode(e,e.uint32()));break;case 2:s.iwant.push(_s.codec().decode(e,e.uint32()));break;case 3:s.graft.push(Ts.codec().decode(e,e.uint32()));break;case 4:s.prune.push(Cs.codec().decode(e,e.uint32()));break;default:e.skipType(o&7);break}}return s})),t),r.encode=e=>It(e,r.codec()),r.decode=e=>kt(e,r.codec())})(Ns||(Ns={}));var Rs;(function(r){let t;r.codec=()=>(t==null&&(t=Nt((e,n,s={})=>{if(s.lengthDelimited!==!1&&n.fork(),e.topic!=null&&(n.uint32(10),n.string(e.topic)),e.messageIDs!=null)for(let i of e.messageIDs)n.uint32(18),n.bytes(i);s.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let s={messageIDs:[]},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let o=e.uint32();switch(o>>>3){case 1:s.topic=e.string();break;case 2:s.messageIDs.push(e.bytes());break;default:e.skipType(o&7);break}}return s})),t),r.encode=e=>It(e,r.codec()),r.decode=e=>kt(e,r.codec())})(Rs||(Rs={}));var _s;(function(r){let t;r.codec=()=>(t==null&&(t=Nt((e,n,s={})=>{if(s.lengthDelimited!==!1&&n.fork(),e.messageIDs!=null)for(let i of e.messageIDs)n.uint32(10),n.bytes(i);s.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let s={messageIDs:[]},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let o=e.uint32();switch(o>>>3){case 1:s.messageIDs.push(e.bytes());break;default:e.skipType(o&7);break}}return s})),t),r.encode=e=>It(e,r.codec()),r.decode=e=>kt(e,r.codec())})(_s||(_s={}));var Ts;(function(r){let t;r.codec=()=>(t==null&&(t=Nt((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.topic!=null&&(n.uint32(10),n.string(e.topic)),s.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let s={},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let o=e.uint32();switch(o>>>3){case 1:s.topic=e.string();break;default:e.skipType(o&7);break}}return s})),t),r.encode=e=>It(e,r.codec()),r.decode=e=>kt(e,r.codec())})(Ts||(Ts={}));var Cs;(function(r){let t;r.codec=()=>(t==null&&(t=Nt((e,n,s={})=>{if(s.lengthDelimited!==!1&&n.fork(),e.topic!=null&&(n.uint32(10),n.string(e.topic)),e.peers!=null)for(let i of e.peers)n.uint32(18),Ls.codec().encode(i,n);e.backoff!=null&&(n.uint32(24),n.uint64(e.backoff)),s.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let s={peers:[]},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let o=e.uint32();switch(o>>>3){case 1:s.topic=e.string();break;case 2:s.peers.push(Ls.codec().decode(e,e.uint32()));break;case 3:s.backoff=e.uint64();break;default:e.skipType(o&7);break}}return s})),t),r.encode=e=>It(e,r.codec()),r.decode=e=>kt(e,r.codec())})(Cs||(Cs={}));var Ls;(function(r){let t;r.codec=()=>(t==null&&(t=Nt((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.peerID!=null&&(n.uint32(10),n.bytes(e.peerID)),e.signedPeerRecord!=null&&(n.uint32(18),n.bytes(e.signedPeerRecord)),s.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let s={},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let o=e.uint32();switch(o>>>3){case 1:s.peerID=e.bytes();break;case 2:s.signedPeerRecord=e.bytes();break;default:e.skipType(o&7);break}}return s})),t),r.encode=e=>It(e,r.codec()),r.decode=e=>kt(e,r.codec())})(Ls||(Ls={}));var Us=class extends ks{seenCache;constructor(t,e){super(t,{...e,canRelayMessage:!0,multicodecs:[xo]}),this.log=t.logger.forComponent("libp2p:floodsub"),this.seenCache=new Is({validityMs:e?.seenTTL??3e4})}[Symbol.toStringTag]="@libp2p/floodsub";[To]=["@libp2p/identify"];decodeRpc(t){return je.decode(t)}encodeRpc(t){return je.encode(t)}decodeMessage(t){return je.Message.decode(t)}encodeMessage(t){return je.Message.encode(t)}async processMessage(t,e){let n=await super.getMsgId(e),s=Y(n,"base64");this.seenCache.has(s)||(this.seenCache.put(s,!0),await super.processMessage(t,e))}async publishMessage(t,e){let n=this.getSubscribers(e.topic),s=[];return n==null||n.length===0?(this.log("no peers are subscribed to topic %s",e.topic),{recipients:s}):(n.forEach(i=>{if(this.components.peerId.equals(i)){this.log("not sending message on topic %s to myself",e.topic);return}if(i.equals(t)){this.log("not sending message on topic %s to sender %p",e.topic,i);return}this.log("publish msgs on topics %s %p",e.topic,i),s.push(i),this.send(i,{messages:[e]})}),{recipients:s})}};function Ad(r={}){return t=>new Us(t,r)}return Du(Sd);})();
|
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/floodsub",
|
3
|
-
"version": "9.1.
|
3
|
+
"version": "9.1.1",
|
4
4
|
"description": "libp2p-floodsub, also known as pubsub-flood or just dumbsub, this implementation of pubsub focused on delivering an API for Publish/Subscribe, but with no CastTree Forming (it just floods the network).",
|
5
5
|
"license": "Apache-2.0 OR MIT",
|
6
6
|
"homepage": "https://github.com/libp2p/js-libp2p/tree/main/packages/pubsub-floodsub#readme",
|
@@ -60,17 +60,17 @@
|
|
60
60
|
"test:electron-main": "aegir test -t electron-main"
|
61
61
|
},
|
62
62
|
"dependencies": {
|
63
|
-
"@libp2p/interface": "^1.
|
64
|
-
"@libp2p/pubsub": "^9.0.
|
63
|
+
"@libp2p/interface": "^1.6.0",
|
64
|
+
"@libp2p/pubsub": "^9.0.22",
|
65
65
|
"protons-runtime": "^5.4.0",
|
66
66
|
"uint8arraylist": "^2.4.8",
|
67
67
|
"uint8arrays": "^5.1.0"
|
68
68
|
},
|
69
69
|
"devDependencies": {
|
70
|
-
"@libp2p/interface-compliance-tests": "^5.4.
|
71
|
-
"@libp2p/logger": "^4.0.
|
72
|
-
"@libp2p/peer-collections": "^5.2.
|
73
|
-
"@libp2p/peer-id-factory": "^4.
|
70
|
+
"@libp2p/interface-compliance-tests": "^5.4.8",
|
71
|
+
"@libp2p/logger": "^4.0.16",
|
72
|
+
"@libp2p/peer-collections": "^5.2.5",
|
73
|
+
"@libp2p/peer-id-factory": "^4.2.0",
|
74
74
|
"@multiformats/multiaddr": "^12.2.3",
|
75
75
|
"@types/sinon": "^17.0.3",
|
76
76
|
"aegir": "^43.0.1",
|