@libp2p/floodsub 9.1.5-50b897139 → 9.1.5-737b3ea5b

Sign up to get free protection for your applications and to get access to all the features.
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 Uu=Object.create;var hn=Object.defineProperty;var Du=Object.getOwnPropertyDescriptor;var Pu=Object.getOwnPropertyNames;var Ou=Object.getPrototypeOf,Vu=Object.prototype.hasOwnProperty;var Uo=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),rt=(r,t)=>{for(var e in t)hn(r,e,{get:t[e],enumerable:!0})},Do=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of Pu(t))!Vu.call(r,s)&&s!==e&&hn(r,s,{get:()=>t[s],enumerable:!(n=Du(t,s))||n.enumerable});return r};var Po=(r,t,e)=>(e=r!=null?Uu(Ou(r)):{},Do(t||!r||!r.__esModule?hn(e,"default",{value:r,enumerable:!0}):e,r)),Mu=r=>Do(hn({},"__esModule",{value:!0}),r);var tc=Uo(Er=>{"use strict";var Ah="[object ArrayBuffer]",ue=class r{static isArrayBuffer(t){return Object.prototype.toString.call(t)===Ah}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}},to="string",Sh=/^[0-9a-f]+$/i,kh=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,Ih=/^[a-zA-Z0-9-_]+$/,Ln=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))}},Ct=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}},Cn=class r{static isHex(t){return typeof t===to&&Sh.test(t)}static isBase64(t){return typeof t===to&&kh.test(t)}static isBase64Url(t){return typeof t===to&&Ih.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 Ct.toString(n,!0);case"utf16":case"utf16be":return Ct.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 Ct.fromString(t,!0);case"utf16":case"utf16be":return Ct.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 Ln.fromString(t);case"utf16":case"utf16be":return Ct.fromString(t);case"utf16le":case"usc2":return Ct.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 Ln.toString(t);case"utf16":case"utf16be":return Ct.toString(t);case"utf16le":case"usc2":return Ct.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 Ct.toString(t,e)}static FromUtf16String(t,e=!1){return Ct.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,"")||""}};Cn.DEFAULT_UTF8_ENCODING="utf8";function Rh(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 _h(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=Cn;Er.assign=Rh;Er.combine=Nh;Er.isEqual=_h});var du=Uo((Zy,xo)=>{"use strict";var wd=Object.prototype.hasOwnProperty,Bt="~";function nn(){}Object.create&&(nn.prototype=Object.create(null),new nn().__proto__||(Bt=!1));function xd(r,t,e){this.fn=r,this.context=t,this.once=e||!1}function hu(r,t,e,n,s){if(typeof e!="function")throw new TypeError("The listener must be a function");var i=new xd(e,n||r,s),o=Bt?Bt+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 wt(){this._events=new nn,this._eventsCount=0}wt.prototype.eventNames=function(){var t=[],e,n;if(this._eventsCount===0)return t;for(n in e=this._events)wd.call(e,n)&&t.push(Bt?n.slice(1):n);return Object.getOwnPropertySymbols?t.concat(Object.getOwnPropertySymbols(e)):t};wt.prototype.listeners=function(t){var e=Bt?Bt+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};wt.prototype.listenerCount=function(t){var e=Bt?Bt+t:t,n=this._events[e];return n?n.fn?1:n.length:0};wt.prototype.emit=function(t,e,n,s,i,o){var a=Bt?Bt+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,x;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(x=1,l=new Array(f-1);x<f;x++)l[x-1]=arguments[x];c[u].fn.apply(c[u].context,l)}}return!0};wt.prototype.on=function(t,e,n){return hu(this,t,e,n,!1)};wt.prototype.once=function(t,e,n){return hu(this,t,e,n,!0)};wt.prototype.removeListener=function(t,e,n,s){var i=Bt?Bt+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=[],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:As(this,i)}return this};wt.prototype.removeAllListeners=function(t){var e;return t?(e=Bt?Bt+t:t,this._events[e]&&As(this,e)):(this._events=new nn,this._eventsCount=0),this};wt.prototype.off=wt.prototype.removeListener;wt.prototype.addListener=wt.prototype.on;wt.prefixed=Bt;wt.EventEmitter=wt;typeof xo<"u"&&(xo.exports=wt)});var Nd={};rt(Nd,{FloodSub:()=>Hs,floodsub:()=>Rd,multicodec:()=>ko});var Fs=Symbol.for("@libp2p/peer-id");var Nr;(function(r){r.Accept="accept",r.Ignore="ignore",r.Reject="reject"})(Nr||(Nr={}));var B=class extends Error{code;props;constructor(t,e,n){super(t),this.code=e,this.name=n?.name??"CodeError",this.props=n??{}}};var Oo=(r,...t)=>{try{[...t]}catch{}};var We=class extends EventTarget{#t=new Map;constructor(){super(),Oo(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 zt(t,e))}},zt=globalThis.CustomEvent;var Od=Symbol.for("@libp2p/service-capabilities"),Vo=Symbol.for("@libp2p/service-dependencies");var Ys={};rt(Ys,{base58btc:()=>xt,base58flickr:()=>Gu});var a0=new Uint8Array(0);function Mo(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 Ho(r){return new TextEncoder().encode(r)}function Ko(r){return new TextDecoder().decode(r)}function Hu(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(m){if(m instanceof Uint8Array||(ArrayBuffer.isView(m)?m=new Uint8Array(m.buffer,m.byteOffset,m.byteLength):Array.isArray(m)&&(m=Uint8Array.from(m))),!(m instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(m.length===0)return"";for(var h=0,d=0,v=0,b=m.length;v!==b&&m[v]===0;)v++,h++;for(var w=(b-v)*l+1>>>0,_=new Uint8Array(w);v!==b;){for(var I=m[v],k=0,T=w-1;(I!==0||k<d)&&T!==-1;T--,k++)I+=256*_[T]>>>0,_[T]=I%a>>>0,I=I/a>>>0;if(I!==0)throw new Error("Non-zero carry");d=k,v++}for(var R=w-d;R!==w&&_[R]===0;)R++;for(var $=c.repeat(h);R<w;++R)$+=r.charAt(_[R]);return $}function p(m){if(typeof m!="string")throw new TypeError("Expected String");if(m.length===0)return new Uint8Array;var h=0;if(m[h]!==" "){for(var d=0,v=0;m[h]===c;)d++,h++;for(var b=(m.length-h)*f+1>>>0,w=new Uint8Array(b);m[h];){var _=e[m.charCodeAt(h)];if(_===255)return;for(var I=0,k=b-1;(_!==0||I<v)&&k!==-1;k--,I++)_+=a*w[k]>>>0,w[k]=_%256>>>0,_=_/256>>>0;if(_!==0)throw new Error("Non-zero carry");v=I,h++}if(m[h]!==" "){for(var T=b-v;T!==b&&w[T]===0;)T++;for(var R=new Uint8Array(d+(b-T)),$=d;T!==b;)R[$++]=w[T++];return R}}}function x(m){var h=p(m);if(h)return h;throw new Error(`Non-${t} character`)}return{encode:u,decodeUnsafe:p,decode:x}}var Ku=Hu,Fu=Ku,qo=Fu;var qs=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")}},$s=class{name;prefix;baseDecode;prefixCodePoint;constructor(t,e,n){if(this.name=t,this.prefix=e,e.codePointAt(0)===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=e.codePointAt(0),this.baseDecode=n}decode(t){if(typeof t=="string"){if(t.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(t)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(t.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(t){return $o(this,t)}},Gs=class{decoders;constructor(t){this.decoders=t}or(t){return $o(this,t)}decode(t){let e=t[0],n=this.decoders[e];if(n!=null)return n.decode(t);throw RangeError(`Unable to decode multibase string ${JSON.stringify(t)}, only inputs prefixed with ${Object.keys(this.decoders)} are supported`)}};function $o(r,t){return new Gs({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var zs=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 qs(t,e,n),this.decoder=new $s(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 zs(r,t,e,n)}function me({name:r,prefix:t,alphabet:e}){let{encode:n,decode:s}=qo(e,r);return Je({prefix:t,name:r,encode:n,decode:i=>Qt(s(i))})}function qu(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 $u(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 Q({name:r,prefix:t,bitsPerChar:e,alphabet:n}){return Je({prefix:t,name:r,encode(s){return $u(s,n,e)},decode(s){return qu(s,n,e,r)}})}var xt=me({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),Gu=me({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var js={};rt(js,{base10:()=>zu});var zu=me({prefix:"9",name:"base10",alphabet:"0123456789"});var Zs={};rt(Zs,{base16:()=>Yu,base16upper:()=>ju});var Yu=Q({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),ju=Q({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Ws={};rt(Ws,{base2:()=>Zu});var Zu=Q({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Js={};rt(Js,{base256emoji:()=>tl});var Go=Array.from("\u{1F680}\u{1FA90}\u2604\u{1F6F0}\u{1F30C}\u{1F311}\u{1F312}\u{1F313}\u{1F314}\u{1F315}\u{1F316}\u{1F317}\u{1F318}\u{1F30D}\u{1F30F}\u{1F30E}\u{1F409}\u2600\u{1F4BB}\u{1F5A5}\u{1F4BE}\u{1F4BF}\u{1F602}\u2764\u{1F60D}\u{1F923}\u{1F60A}\u{1F64F}\u{1F495}\u{1F62D}\u{1F618}\u{1F44D}\u{1F605}\u{1F44F}\u{1F601}\u{1F525}\u{1F970}\u{1F494}\u{1F496}\u{1F499}\u{1F622}\u{1F914}\u{1F606}\u{1F644}\u{1F4AA}\u{1F609}\u263A\u{1F44C}\u{1F917}\u{1F49C}\u{1F614}\u{1F60E}\u{1F607}\u{1F339}\u{1F926}\u{1F389}\u{1F49E}\u270C\u2728\u{1F937}\u{1F631}\u{1F60C}\u{1F338}\u{1F64C}\u{1F60B}\u{1F497}\u{1F49A}\u{1F60F}\u{1F49B}\u{1F642}\u{1F493}\u{1F929}\u{1F604}\u{1F600}\u{1F5A4}\u{1F603}\u{1F4AF}\u{1F648}\u{1F447}\u{1F3B6}\u{1F612}\u{1F92D}\u2763\u{1F61C}\u{1F48B}\u{1F440}\u{1F62A}\u{1F611}\u{1F4A5}\u{1F64B}\u{1F61E}\u{1F629}\u{1F621}\u{1F92A}\u{1F44A}\u{1F973}\u{1F625}\u{1F924}\u{1F449}\u{1F483}\u{1F633}\u270B\u{1F61A}\u{1F61D}\u{1F634}\u{1F31F}\u{1F62C}\u{1F643}\u{1F340}\u{1F337}\u{1F63B}\u{1F613}\u2B50\u2705\u{1F97A}\u{1F308}\u{1F608}\u{1F918}\u{1F4A6}\u2714\u{1F623}\u{1F3C3}\u{1F490}\u2639\u{1F38A}\u{1F498}\u{1F620}\u261D\u{1F615}\u{1F33A}\u{1F382}\u{1F33B}\u{1F610}\u{1F595}\u{1F49D}\u{1F64A}\u{1F639}\u{1F5E3}\u{1F4AB}\u{1F480}\u{1F451}\u{1F3B5}\u{1F91E}\u{1F61B}\u{1F534}\u{1F624}\u{1F33C}\u{1F62B}\u26BD\u{1F919}\u2615\u{1F3C6}\u{1F92B}\u{1F448}\u{1F62E}\u{1F646}\u{1F37B}\u{1F343}\u{1F436}\u{1F481}\u{1F632}\u{1F33F}\u{1F9E1}\u{1F381}\u26A1\u{1F31E}\u{1F388}\u274C\u270A\u{1F44B}\u{1F630}\u{1F928}\u{1F636}\u{1F91D}\u{1F6B6}\u{1F4B0}\u{1F353}\u{1F4A2}\u{1F91F}\u{1F641}\u{1F6A8}\u{1F4A8}\u{1F92C}\u2708\u{1F380}\u{1F37A}\u{1F913}\u{1F619}\u{1F49F}\u{1F331}\u{1F616}\u{1F476}\u{1F974}\u25B6\u27A1\u2753\u{1F48E}\u{1F4B8}\u2B07\u{1F628}\u{1F31A}\u{1F98B}\u{1F637}\u{1F57A}\u26A0\u{1F645}\u{1F61F}\u{1F635}\u{1F44E}\u{1F932}\u{1F920}\u{1F927}\u{1F4CC}\u{1F535}\u{1F485}\u{1F9D0}\u{1F43E}\u{1F352}\u{1F617}\u{1F911}\u{1F30A}\u{1F92F}\u{1F437}\u260E\u{1F4A7}\u{1F62F}\u{1F486}\u{1F446}\u{1F3A4}\u{1F647}\u{1F351}\u2744\u{1F334}\u{1F4A3}\u{1F438}\u{1F48C}\u{1F4CD}\u{1F940}\u{1F922}\u{1F445}\u{1F4A1}\u{1F4A9}\u{1F450}\u{1F4F8}\u{1F47B}\u{1F910}\u{1F92E}\u{1F3BC}\u{1F975}\u{1F6A9}\u{1F34E}\u{1F34A}\u{1F47C}\u{1F48D}\u{1F4E3}\u{1F942}"),Wu=Go.reduce((r,t,e)=>(r[e]=t,r),[]),Ju=Go.reduce((r,t,e)=>(r[t.codePointAt(0)]=e,r),[]);function Xu(r){return r.reduce((t,e)=>(t+=Wu[e],t),"")}function Qu(r){let t=[];for(let e of r){let n=Ju[e.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${e}`);t.push(n)}return new Uint8Array(t)}var tl=Je({prefix:"\u{1F680}",name:"base256emoji",encode:Xu,decode:Qu});var Xs={};rt(Xs,{base32:()=>Xe,base32hex:()=>sl,base32hexpad:()=>ol,base32hexpadupper:()=>al,base32hexupper:()=>il,base32pad:()=>rl,base32padupper:()=>nl,base32upper:()=>el,base32z:()=>cl});var Xe=Q({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),el=Q({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),rl=Q({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),nl=Q({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),sl=Q({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),il=Q({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),ol=Q({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),al=Q({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),cl=Q({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Qs={};rt(Qs,{base36:()=>ul,base36upper:()=>ll});var ul=me({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),ll=me({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var ti={};rt(ti,{base64:()=>_r,base64pad:()=>fl,base64url:()=>hl,base64urlpad:()=>dl});var _r=Q({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),fl=Q({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),hl=Q({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),dl=Q({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var ei={};rt(ei,{base8:()=>pl});var pl=Q({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var ri={};rt(ri,{identity:()=>gl});var gl=Je({prefix:"\0",name:"identity",encode:r=>Ko(r),decode:r=>Ho(r)});var B0=new TextEncoder,A0=new TextDecoder;var si={};rt(si,{identity:()=>te});var bl=jo,zo=128,wl=127,xl=~wl,vl=Math.pow(2,31);function jo(r,t,e){t=t||[],e=e||0;for(var n=e;r>=vl;)t[e++]=r&255|zo,r/=128;for(;r&xl;)t[e++]=r&255|zo,r>>>=7;return t[e]=r|0,jo.bytes=e-n+1,t}var El=ni,Bl=128,Yo=127;function ni(r,n){var e=0,n=n||0,s=0,i=n,o,a=r.length;do{if(i>=a)throw ni.bytes=0,new RangeError("Could not decode varint");o=r[i++],e+=s<28?(o&Yo)<<s:(o&Yo)*Math.pow(2,s),s+=7}while(o>=Bl);return ni.bytes=i-n,e}var Al=Math.pow(2,7),Sl=Math.pow(2,14),kl=Math.pow(2,21),Il=Math.pow(2,28),Rl=Math.pow(2,35),Nl=Math.pow(2,42),_l=Math.pow(2,49),Tl=Math.pow(2,56),Ll=Math.pow(2,63),Cl=function(r){return r<Al?1:r<Sl?2:r<kl?3:r<Il?4:r<Rl?5:r<Nl?6:r<_l?7:r<Tl?8:r<Ll?9:10},Ul={encode:bl,decode:El,encodingLength:Cl},Dl=Ul,Tr=Dl;function Lr(r,t=0){return[Tr.decode(r,t),Tr.decode.bytes]}function Qe(r,t,e=0){return Tr.encode(r,t,e),t}function tr(r){return Tr.encodingLength(r)}function Yt(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 Cr(r){let t=Qt(r),[e,n]=Lr(t),[s,i]=Lr(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 Zo(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&Mo(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 Wo=0,Pl="identity",Jo=Qt;function Ol(r){return Yt(Wo,Jo(r))}var te={code:Wo,name:Pl,encode:Jo,digest:Ol};var ai={};rt(ai,{sha256:()=>ot,sha512:()=>Vl});function oi({name:r,code:t,encode:e}){return new ii(r,t,e)}var ii=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?Yt(this.code,e):e.then(n=>Yt(this.code,n))}else throw Error("Unknown type, must be binary type")}};function Qo(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var ot=oi({name:"sha2-256",code:18,encode:Qo("SHA-256")}),Vl=oi({name:"sha2-512",code:19,encode:Qo("SHA-512")});function ta(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return Hl(e,ci(r),t??xt.encoder);default:return Kl(e,ci(r),t??Xe.encoder)}}var ea=new WeakMap;function ci(r){let t=ea.get(r);if(t==null){let e=new Map;return ea.set(r,e),e}return t}var ye=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!==Fl)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=Yt(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&&Zo(t.multihash,n.multihash)}toString(t){return ta(this,t)}toJSON(){return{"/":ta(this)}}link(){return this}[Symbol.toStringTag]="CID";[Symbol.for("nodejs.util.inspect.custom")](){return`CID(${this.toString()})`}static asCID(t){if(t==null)return null;let e=t;if(e instanceof r)return e;if(e["/"]!=null&&e["/"]===e.bytes||e.asCID===e){let{version:n,code:s,multihash:i,bytes:o}=e;return new r(n,s,i,o??ra(n,s,i.bytes))}else if(e[ql]===!0){let{version:n,multihash:s,code:i}=e,o=Cr(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=ra(t,e,n.bytes);return new r(t,e,n,s)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,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 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]=Lr(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]=Ml(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 ci(i).set(n,t),i}};function Ml(r,t){switch(r[0]){case"Q":{let e=t??xt;return[xt.prefix,e.decode(`${xt.prefix}${r}`)]}case xt.prefix:{let e=t??xt;return[xt.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 Hl(r,t,e){let{prefix:n}=e;if(n!==xt.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 Kl(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,Fl=18;function ra(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 ql=Symbol.for("@ipld/js-cid/CID");var nr={...ri,...Ws,...ei,...js,...Zs,...Xs,...Qs,...Ys,...ti,...Js},G0={...ai,...si};function pt(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 gt(r=0){return new Uint8Array(r)}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))),ui=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=gt(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),$l={utf8:na,"utf-8":na,hex:nr.base16,latin1:ui,ascii:ui,binary:ui,...nr},pn=$l;function F(r,t="utf8"){let e=pn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function G(r,t="utf8"){let e=pn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}var oa=Symbol.for("nodejs.util.inspect.custom"),ia=Object.values(nr).map(r=>r.decoder).reduce((r,t)=>r.or(t),nr.identity.decoder),aa=114,hi=36,di=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()})`}[Fs]=!0;toString(){return this.string==null&&(this.string=xt.encode(this.multihash.bytes).slice(1)),this.string}toCID(){return ye.createV1(aa,this.multihash)}toBytes(){return this.multihash.bytes}toJSON(){return this.toString()}equals(t){if(t==null)return!1;if(t instanceof Uint8Array)return pt(this.multihash.bytes,t);if(typeof t=="string")return re(t).equals(this);if(t?.multihash?.bytes!=null)return pt(this.multihash.bytes,t.multihash.bytes);throw new Error("not valid Id")}[oa](){return`PeerId(${this.toString()})`}},sr=class extends Dr{type="RSA";publicKey;constructor(t){super({...t,type:"RSA"}),this.publicKey=t.publicKey}},ir=class extends Dr{type="Ed25519";publicKey;constructor(t){super({...t,type:"Ed25519"}),this.publicKey=t.multihash.digest}},or=class extends Dr{type="secp256k1";publicKey;constructor(t){super({...t,type:"secp256k1"}),this.publicKey=t.multihash.digest}},li=2336,fi=class{type="url";multihash;privateKey;publicKey;url;constructor(t){this.url=t.toString(),this.multihash=te.digest(F(this.url))}[oa](){return`PeerId(${this.url})`}[Fs]=!0;toString(){return this.toCID().toString()}toCID(){return ye.createV1(li,this.multihash)}toBytes(){return this.toCID().bytes}equals(t){return t==null?!1:(t instanceof Uint8Array&&(t=G(t)),t.toString()===this.toString())}};function re(r,t){if(t=t??ia,r.charAt(0)==="1"||r.charAt(0)==="Q"){let e=Cr(xt.decode(`z${r}`));return r.startsWith("12D")?new ir({multihash:e}):r.startsWith("16U")?new or({multihash:e}):new sr({multihash:e})}return Pr(ia.decode(r))}function Pr(r){try{let t=Cr(r);if(t.code===te.code){if(t.digest.length===hi)return new ir({multihash:t});if(t.digest.length===di)return new or({multihash:t})}if(t.code===ot.code)return new sr({multihash:t})}catch{return Gl(ye.decode(r))}throw new Error("Supplied PeerID CID is invalid")}function Gl(r){if(r?.multihash==null||r.version==null||r.version===1&&r.code!==aa&&r.code!==li)throw new Error("Supplied PeerID CID is invalid");if(r.code===li){let e=G(r.multihash.digest);return new fi(new URL(e))}let t=r.multihash;if(t.code===ot.code)return new sr({multihash:r.multihash});if(t.code===te.code){if(t.digest.length===hi)return new ir({multihash:r.multihash});if(t.digest.length===di)return new or({multihash:r.multihash})}throw new Error("Supplied PeerID CID is invalid")}async function gn(r,t){return r.length===hi?new ir({multihash:Yt(te.code,r),privateKey:t}):r.length===di?new or({multihash:Yt(te.code,r),privateKey:t}):new sr({multihash:await ot.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 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 ar(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 ar(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 ar(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 ar(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 j={get(r=globalThis){let t=r.crypto;if(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 ca={SHA1:20,SHA256:32,SHA512:64};var zl={SHA1:"SHA-1",SHA256:"SHA-256",SHA512:"SHA-512"},Yl=async(r,t)=>{let e=await j.get().subtle.sign({name:"HMAC"},r,t);return new Uint8Array(e,0,e.byteLength)};async function ua(r,t){let e=zl[r],n=await j.get().subtle.importKey("raw",t,{name:"HMAC",hash:{name:e}},!1,["sign"]);return{async digest(s){return Yl(n,s)},length:ca[r]}}var en={};rt(en,{Ed25519PrivateKey:()=>ce,Ed25519PublicKey:()=>Ke,MAX_RSA_KEY_SIZE:()=>$e,RsaPrivateKey:()=>Ne,RsaPublicKey:()=>qe,Secp256k1PrivateKey:()=>Ye,Secp256k1PublicKey:()=>ze,generateEphemeralKeyPair:()=>Wa,generateKeyPair:()=>cd,generateKeyPairFromSeed:()=>ud,importKey:()=>dd,keyStretcher:()=>Qa,keysPBM:()=>xr,marshalPrivateKey:()=>hd,marshalPublicKey:()=>fd,supportedKeys:()=>ge,unmarshalPrivateKey:()=>ou,unmarshalPublicKey:()=>ld});var Ji={};rt(Ji,{Ed25519PrivateKey:()=>ce,Ed25519PublicKey:()=>Ke,generateKeyPair:()=>bh,generateKeyPairFromSeed:()=>Wi,unmarshalEd25519PrivateKey:()=>mh,unmarshalEd25519PublicKey:()=>yh});function vt(r,t){t==null&&(t=r.reduce((s,i)=>s+i.length,0));let e=gt(t),n=0;for(let s of r)e.set(s,n),n+=s.length;return e}function pi(r,t){let e=F(r,"base64urlpad");if(t!=null){if(e.length>t)throw new Error("byte array longer than desired length");e=vt([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 mn(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 la(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 yn=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 Dp=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;var Wl=async()=>{};async function fa(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 ha(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function be(r){return typeof r=="string"&&(r=ha(r)),ur(r),r}function gi(...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 da(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 bn(r){let t=n=>r().update(be(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function dr(r=32){if(yn&&typeof yn.getRandomValues=="function")return yn.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,f=n?0:4;r.setUint32(t+c,o,n),r.setUint32(t+f,a,n)}var pa=(r,t,e)=>r&t^~r&e,ga=(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=be(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),la(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 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 wn=BigInt(4294967295),mi=BigInt(32);function ma(r,t=!1){return t?{h:Number(r&wn),l:Number(r>>mi&wn)}:{h:Number(r>>mi&wn)|0,l:Number(r&wn)|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}=ma(r[s],t);[e[s],n[s]]=[i,o]}return[e,n]}var tf=(r,t)=>BigInt(r>>>0)<<mi|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 vf={fromBig:ma,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},D=vf;var[Ef,Bf]=D.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))),we=new Uint32Array(80),xe=new Uint32Array(80),yi=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:f,El:l,Fh:u,Fl:p,Gh:x,Gl:m,Hh:h,Hl:d}=this;return[t,e,n,s,i,o,a,c,f,l,u,p,x,m,h,d]}set(t,e,n,s,i,o,a,c,f,l,u,p,x,m,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=x|0,this.Gl=m|0,this.Hh=h|0,this.Hl=d|0}process(t,e){for(let w=0;w<16;w++,e+=4)we[w]=t.getUint32(e),xe[w]=t.getUint32(e+=4);for(let w=16;w<80;w++){let _=we[w-15]|0,I=xe[w-15]|0,k=D.rotrSH(_,I,1)^D.rotrSH(_,I,8)^D.shrSH(_,I,7),T=D.rotrSL(_,I,1)^D.rotrSL(_,I,8)^D.shrSL(_,I,7),R=we[w-2]|0,$=xe[w-2]|0,V=D.rotrSH(R,$,19)^D.rotrBH(R,$,61)^D.shrSH(R,$,6),M=D.rotrSL(R,$,19)^D.rotrBL(R,$,61)^D.shrSL(R,$,6),et=D.add4L(T,M,xe[w-7],xe[w-16]),st=D.add4H(et,k,V,we[w-7],we[w-16]);we[w]=st|0,xe[w]=et|0}let{Ah:n,Al:s,Bh:i,Bl:o,Ch:a,Cl:c,Dh:f,Dl:l,Eh:u,El:p,Fh:x,Fl:m,Gh:h,Gl:d,Hh:v,Hl:b}=this;for(let w=0;w<80;w++){let _=D.rotrSH(u,p,14)^D.rotrSH(u,p,18)^D.rotrBH(u,p,41),I=D.rotrSL(u,p,14)^D.rotrSL(u,p,18)^D.rotrBL(u,p,41),k=u&x^~u&h,T=p&m^~p&d,R=D.add5L(b,I,T,Bf[w],xe[w]),$=D.add5H(R,v,_,k,Ef[w],we[w]),V=R|0,M=D.rotrSH(n,s,28)^D.rotrBH(n,s,34)^D.rotrBH(n,s,39),et=D.rotrSL(n,s,28)^D.rotrBL(n,s,34)^D.rotrBL(n,s,39),st=n&i^n&a^i&a,N=s&o^s&c^o&c;v=h|0,b=d|0,h=x|0,d=m|0,x=u|0,m=p|0,{h:u,l:p}=D.add(f|0,l|0,$|0,V|0),f=a|0,l=c|0,a=i|0,c=o|0,i=n|0,o=s|0;let y=D.add3L(V,et,N);n=D.add3H(y,$,M,st),s=y|0}({h:n,l:s}=D.add(this.Ah|0,this.Al|0,n|0,s|0)),{h:i,l:o}=D.add(this.Bh|0,this.Bl|0,i|0,o|0),{h:a,l:c}=D.add(this.Ch|0,this.Cl|0,a|0,c|0),{h:f,l}=D.add(this.Dh|0,this.Dl|0,f|0,l|0),{h:u,l:p}=D.add(this.Eh|0,this.El|0,u|0,p|0),{h:x,l:m}=D.add(this.Fh|0,this.Fl|0,x|0,m|0),{h,l:d}=D.add(this.Gh|0,this.Gl|0,h|0,d|0),{h:v,l:b}=D.add(this.Hh|0,this.Hl|0,v|0,b|0),this.set(n,s,i,o,a,c,f,l,u,p,x,m,h,d,v,b)}roundClean(){we.fill(0),xe.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=bn(()=>new yi);var vn={};rt(vn,{aInRange:()=>St,abool:()=>Ot,abytes:()=>gr,bitGet:()=>_f,bitLen:()=>Nf,bitMask:()=>Kr,bitSet:()=>Tf,bytesToHex:()=>se,bytesToNumberBE:()=>ie,bytesToNumberLE:()=>Ee,concatBytes:()=>oe,createHmacDrbg:()=>Ei,ensureBytes:()=>tt,equalBytes:()=>If,hexToBytes:()=>De,hexToNumber:()=>vi,inRange:()=>Hr,isBytes:()=>ve,memoized:()=>Oe,notImplemented:()=>Cf,numberToBytesBE:()=>Be,numberToBytesLE:()=>Pe,numberToHexUnpadded:()=>wa,numberToVarBytesBE:()=>kf,utf8ToBytes:()=>Rf,validateObject:()=>jt});var xi=BigInt(0),xn=BigInt(1),Af=BigInt(2);function ve(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function gr(r){if(!ve(r))throw new Error("Uint8Array expected")}function Ot(r,t){if(typeof t!="boolean")throw new Error(`${r} must be valid boolean, got "${t}".`)}var Sf=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function se(r){gr(r);let t="";for(let e=0;e<r.length;e++)t+=Sf[r[e]];return t}function wa(r){let t=r.toString(16);return t.length&1?`0${t}`:t}function vi(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 ya(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=ya(r.charCodeAt(i)),a=ya(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 vi(se(r))}function Ee(r){return gr(r),vi(se(Uint8Array.from(r).reverse()))}function Be(r,t){return De(r.toString(16).padStart(t*2,"0"))}function Pe(r,t){return Be(r,t).reverse()}function kf(r){return De(wa(r))}function tt(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];gr(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 Rf(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}var bi=r=>typeof r=="bigint"&&xi<=r;function Hr(r,t,e){return bi(r)&&bi(t)&&bi(e)&&t<=r&&r<e}function St(r,t,e,n){if(!Hr(t,e,n))throw new Error(`expected valid ${r}: ${e} <= n < ${n}, got ${typeof t} ${t}`)}function Nf(r){let t;for(t=0;r>xi;r>>=xn,t+=1);return t}function _f(r,t){return r>>BigInt(t)&xn}function Tf(r,t,e){return r|(e?xn:xi)<<BigInt(t)}var Kr=r=>(Af<<BigInt(r-1))-xn,wi=r=>new Uint8Array(r),ba=r=>Uint8Array.from(r);function Ei(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=wi(r),s=wi(r),i=0,o=()=>{n.fill(1),s.fill(0),i=0},a=(...u)=>e(s,n,...u),c=(u=wi())=>{s=a(ba([0]),u),n=a(),u.length!==0&&(s=a(ba([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 x=n.slice();p.push(x),u+=n.length}return oe(...p)};return(u,p)=>{o(),c(u);let x;for(;!(x=p(f()));)c();return o(),x}}var Lf={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 jt(r,t,e={}){let n=(s,i,o)=>{let a=Lf[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 Cf=()=>{throw new Error("not implemented")};function Oe(r){let t=new WeakMap;return(e,...n)=>{let s=t.get(e);if(s!==void 0)return s;let i=r(e,...n);return t.set(e,i),i}}var at=BigInt(0),Z=BigInt(1),Ve=BigInt(2),Uf=BigInt(3),Bi=BigInt(4),xa=BigInt(5),va=BigInt(8),Df=BigInt(9),Pf=BigInt(16);function z(r,t){let e=r%t;return e>=at?e:t+e}function Of(r,t,e){if(e<=at||t<at)throw new Error("Expected power/modulo > 0");if(e===Z)return at;let n=Z;for(;t>at;)t&Z&&(n=n*r%e),r=r*r%e,t>>=Z;return n}function W(r,t,e){let n=r;for(;t-- >at;)n*=n,n%=e;return n}function En(r,t){if(r===at||t<=at)throw new Error(`invert: expected positive integers, got n=${r} mod=${t}`);let e=z(r,t),n=t,s=at,i=Z,o=Z,a=at;for(;e!==at;){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!==Z)throw new Error("invert: does not exist");return z(s,t)}function Vf(r){let t=(r-Z)/Ve,e,n,s;for(e=r-Z,n=0;e%Ve===at;e/=Ve,n++);for(s=Ve;s<r&&Of(s,t,r)!==r-Z;s++);if(n===1){let o=(r+Z)/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+Z)/Ve;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 x=1;for(let h=a.sqr(p);x<f&&!a.eql(h,a.ONE);x++)h=a.sqr(h);let m=a.pow(l,Z<<BigInt(f-x-1));l=a.sqr(m),u=a.mul(u,m),p=a.mul(p,l),f=x}return u}}function Mf(r){if(r%Bi===Uf){let t=(r+Z)/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%va===xa){let t=(r-xa)/va;return function(n,s){let i=n.mul(s,Ve),o=n.pow(i,t),a=n.mul(s,o),c=n.mul(n.mul(a,Ve),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%Pf,Vf(r)}var Ea=(r,t)=>(z(r,t)&Z)===Z,Hf=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function Ai(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=Hf.reduce((n,s)=>(n[s]="function",n),t);return jt(r,e)}function Kf(r,t,e){if(e<at)throw new Error("Expected power > 0");if(e===at)return r.ONE;if(e===Z)return t;let n=r.ONE,s=t;for(;e>at;)e&Z&&(n=r.mul(n,s)),s=r.sqr(s),e>>=Z;return n}function Ff(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 Si(r,t){let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function Bn(r,t,e=!1,n={}){if(r<=at)throw new Error(`Expected Field ORDER > 0, got ${r}`);let{nBitLength:s,nByteLength:i}=Si(r,t);if(i>2048)throw new Error("Field lengths over 2048 bytes are not supported");let o=Mf(r),a=Object.freeze({ORDER:r,BITS:s,BYTES:i,MASK:Kr(s),ZERO:at,ONE:Z,create:c=>z(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error(`Invalid field element: expected bigint, got ${typeof c}`);return at<=c&&c<r},is0:c=>c===at,isOdd:c=>(c&Z)===Z,neg:c=>z(-c,r),eql:(c,f)=>c===f,sqr:c=>z(c*c,r),add:(c,f)=>z(c+f,r),sub:(c,f)=>z(c-f,r),mul:(c,f)=>z(c*f,r),pow:(c,f)=>Kf(a,c,f),div:(c,f)=>z(c*En(f,r),r),sqrN:c=>c*c,addN:(c,f)=>c+f,subN:(c,f)=>c-f,mulN:(c,f)=>c*f,inv:c=>En(c,r),sqrt:n.sqrt||(c=>o(a,c)),invertBatch:c=>Ff(a,c),cmov:(c,f,l)=>l?f:c,toBytes:c=>e?Pe(c,i):Be(c,i),fromBytes:c=>{if(c.length!==i)throw new Error(`Fp.fromBytes: expected ${i}, got ${c.length}`);return e?Ee(c):ie(c)}});return Object.freeze(a)}function Ba(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 ki(r){let t=Ba(r);return t+Math.ceil(t/2)}function Aa(r,t,e=!1){let n=r.length,s=Ba(t),i=ki(t);if(n<16||n<i||n>1024)throw new Error(`expected ${i}-1024 bytes of input, got ${n}`);let o=e?ie(r):Ee(r),a=z(o,t-Z)+Z;return e?Pe(a,s):Be(a,s)}var $f=BigInt(0),Ii=BigInt(1),Ri=new WeakMap,Sa=new WeakMap;function An(r,t){let e=(i,o)=>{let a=o.negate();return i?a:o},n=i=>{if(!Number.isSafeInteger(i)||i<=0||i>t)throw new Error(`Wrong window size=${i}, should be [1..${t}]`)},s=i=>{n(i);let o=Math.ceil(t/i)+1,a=2**(i-1);return{windows:o,windowSize:a}};return{constTimeNegate:e,unsafeLadder(i,o){let a=r.ZERO,c=i;for(;o>$f;)o&Ii&&(a=a.add(c)),c=c.double(),o>>=Ii;return a},precomputeWindow(i,o){let{windows:a,windowSize:c}=s(o),f=[],l=i,u=l;for(let p=0;p<a;p++){u=l,f.push(u);for(let x=1;x<c;x++)u=u.add(l),f.push(u);l=u.double()}return f},wNAF(i,o,a){let{windows:c,windowSize:f}=s(i),l=r.ZERO,u=r.BASE,p=BigInt(2**i-1),x=2**i,m=BigInt(i);for(let h=0;h<c;h++){let d=h*f,v=Number(a&p);a>>=m,v>f&&(v-=x,a+=Ii);let b=d,w=d+Math.abs(v)-1,_=h%2!==0,I=v<0;v===0?u=u.add(e(_,o[b])):l=l.add(e(I,o[w]))}return{p:l,f:u}},wNAFCached(i,o,a){let c=Sa.get(i)||1,f=Ri.get(i);return f||(f=this.precomputeWindow(i,c),c!==1&&Ri.set(i,a(f))),this.wNAF(c,f,o)},setWindowSize(i,o){n(o),Sa.set(i,o),Ri.delete(i)}}}function Fr(r){return Ai(r.Fp),jt(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...Si(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Vt=BigInt(0),kt=BigInt(1),Sn=BigInt(2),Gf=BigInt(8),zf={zip215:!0};function Yf(r){let t=Fr(r);return jt(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function ka(r){let t=Yf(r),{Fp:e,n,prehash:s,hash:i,randomBytes:o,nByteLength:a,h:c}=t,f=Sn<<BigInt(a*8)-kt,l=e.create,u=t.uvRatio||((y,g)=>{try{return{isValid:!0,value:e.sqrt(y*e.inv(g))}}catch{return{isValid:!1,value:Vt}}}),p=t.adjustScalarBytes||(y=>y),x=t.domain||((y,g,E)=>{if(Ot("phflag",E),g.length||E)throw new Error("Contexts/pre-hash are not supported");return y});function m(y,g){St("coordinate "+y,g,Vt,f)}function h(y){if(!(y instanceof b))throw new Error("ExtendedPoint expected")}let d=Oe((y,g)=>{let{ex:E,ey:A,ez:L}=y,C=y.is0();g==null&&(g=C?Gf:e.inv(L));let U=l(E*g),H=l(A*g),P=l(L*g);if(C)return{x:Vt,y:kt};if(P!==kt)throw new Error("invZ was invalid");return{x:U,y:H}}),v=Oe(y=>{let{a:g,d:E}=t;if(y.is0())throw new Error("bad point: ZERO");let{ex:A,ey:L,ez:C,et:U}=y,H=l(A*A),P=l(L*L),K=l(C*C),J=l(K*K),X=l(H*g),At=l(K*l(X+P)),ut=l(J+l(E*l(H*P)));if(At!==ut)throw new Error("bad point: equation left != right (1)");let it=l(A*L),Ut=l(C*U);if(it!==Ut)throw new Error("bad point: equation left != right (2)");return!0});class b{constructor(g,E,A,L){this.ex=g,this.ey=E,this.ez=A,this.et=L,m("x",g),m("y",E),m("z",A),m("t",L),Object.freeze(this)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(g){if(g instanceof b)throw new Error("extended point not allowed");let{x:E,y:A}=g||{};return m("x",E),m("y",A),new b(E,A,kt,l(E*A))}static normalizeZ(g){let E=e.invertBatch(g.map(A=>A.ez));return g.map((A,L)=>A.toAffine(E[L])).map(b.fromAffine)}_setWindowSize(g){I.setWindowSize(this,g)}assertValidity(){v(this)}equals(g){h(g);let{ex:E,ey:A,ez:L}=this,{ex:C,ey:U,ez:H}=g,P=l(E*H),K=l(C*L),J=l(A*H),X=l(U*L);return P===K&&J===X}is0(){return this.equals(b.ZERO)}negate(){return new b(l(-this.ex),this.ey,this.ez,l(-this.et))}double(){let{a:g}=t,{ex:E,ey:A,ez:L}=this,C=l(E*E),U=l(A*A),H=l(Sn*l(L*L)),P=l(g*C),K=E+A,J=l(l(K*K)-C-U),X=P+U,At=X-H,ut=P-U,it=l(J*At),Ut=l(X*ut),lt=l(J*ut),Dt=l(At*X);return new b(it,Ut,Dt,lt)}add(g){h(g);let{a:E,d:A}=t,{ex:L,ey:C,ez:U,et:H}=this,{ex:P,ey:K,ez:J,et:X}=g;if(E===BigInt(-1)){let Io=l((C-L)*(K+P)),Ro=l((C+L)*(K-P)),Ks=l(Ro-Io);if(Ks===Vt)return this.double();let No=l(U*Sn*X),_o=l(H*Sn*J),To=_o+No,Lo=Ro+Io,Co=_o-No,_u=l(To*Ks),Tu=l(Lo*Co),Lu=l(To*Co),Cu=l(Ks*Lo);return new b(_u,Tu,Cu,Lu)}let At=l(L*P),ut=l(C*K),it=l(H*A*X),Ut=l(U*J),lt=l((L+C)*(P+K)-At-ut),Dt=Ut-it,Ue=Ut+it,Rr=l(ut-E*At),fn=l(lt*Dt),Iu=l(Ue*Rr),Ru=l(lt*Rr),Nu=l(Dt*Ue);return new b(fn,Iu,Nu,Ru)}subtract(g){return this.add(g.negate())}wNAF(g){return I.wNAFCached(this,g,b.normalizeZ)}multiply(g){let E=g;St("scalar",E,kt,n);let{p:A,f:L}=this.wNAF(E);return b.normalizeZ([A,L])[0]}multiplyUnsafe(g){let E=g;return St("scalar",E,Vt,n),E===Vt?_:this.equals(_)||E===kt?this:this.equals(w)?this.wNAF(E).p:I.unsafeLadder(this,E)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return I.unsafeLadder(this,n).is0()}toAffine(g){return d(this,g)}clearCofactor(){let{h:g}=t;return g===kt?this:this.multiplyUnsafe(g)}static fromHex(g,E=!1){let{d:A,a:L}=t,C=e.BYTES;g=tt("pointHex",g,C),Ot("zip215",E);let U=g.slice(),H=g[C-1];U[C-1]=H&-129;let P=Ee(U),K=E?f:e.ORDER;St("pointHex.y",P,Vt,K);let J=l(P*P),X=l(J-kt),At=l(A*J-L),{isValid:ut,value:it}=u(X,At);if(!ut)throw new Error("Point.fromHex: invalid y coordinate");let Ut=(it&kt)===kt,lt=(H&128)!==0;if(!E&&it===Vt&&lt)throw new Error("Point.fromHex: x=0 and x_0=1");return lt!==Ut&&(it=l(-it)),b.fromAffine({x:it,y:P})}static fromPrivateKey(g){return R(g).point}toRawBytes(){let{x:g,y:E}=this.toAffine(),A=Pe(E,e.BYTES);return A[A.length-1]|=g&kt?128:0,A}toHex(){return se(this.toRawBytes())}}b.BASE=new b(t.Gx,t.Gy,kt,l(t.Gx*t.Gy)),b.ZERO=new b(Vt,kt,kt,Vt);let{BASE:w,ZERO:_}=b,I=An(b,a*8);function k(y){return z(y,n)}function T(y){return k(Ee(y))}function R(y){let g=a;y=tt("private key",y,g);let E=tt("hashed private key",i(y),2*g),A=p(E.slice(0,g)),L=E.slice(g,2*g),C=T(A),U=w.multiply(C),H=U.toRawBytes();return{head:A,prefix:L,scalar:C,point:U,pointBytes:H}}function $(y){return R(y).pointBytes}function V(y=new Uint8Array,...g){let E=oe(...g);return T(i(x(E,tt("context",y),!!s)))}function M(y,g,E={}){y=tt("message",y),s&&(y=s(y));let{prefix:A,scalar:L,pointBytes:C}=R(g),U=V(E.context,A,y),H=w.multiply(U).toRawBytes(),P=V(E.context,H,C,y),K=k(U+P*L);St("signature.s",K,Vt,n);let J=oe(H,Pe(K,e.BYTES));return tt("result",J,a*2)}let et=zf;function st(y,g,E,A=et){let{context:L,zip215:C}=A,U=e.BYTES;y=tt("signature",y,2*U),g=tt("message",g),C!==void 0&&Ot("zip215",C),s&&(g=s(g));let H=Ee(y.slice(U,2*U)),P,K,J;try{P=b.fromHex(E,C),K=b.fromHex(y.slice(0,U),C),J=w.multiplyUnsafe(H)}catch{return!1}if(!C&&P.isSmallOrder())return!1;let X=V(L,K.toRawBytes(),P.toRawBytes(),g);return K.add(P.multiplyUnsafe(X)).subtract(J).clearCofactor().equals(b.ZERO)}return w._setWindowSize(8),{CURVE:t,getPublicKey:$,sign:M,verify:st,ExtendedPoint:b,utils:{getExtendedPublicKey:R,randomPrivateKey:()=>o(e.BYTES),precompute(y=8,g=b.BASE){return g._setWindowSize(y),g.multiply(BigInt(3)),g}}}}var Ni=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),Ia=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),sg=BigInt(0),jf=BigInt(1),Ra=BigInt(2),ig=BigInt(3),Zf=BigInt(5),Wf=BigInt(8);function Jf(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),s=BigInt(80),i=Ni,a=r*r%i*r%i,c=W(a,Ra,i)*a%i,f=W(c,jf,i)*r%i,l=W(f,Zf,i)*f%i,u=W(l,t,i)*l%i,p=W(u,e,i)*u%i,x=W(p,n,i)*p%i,m=W(x,s,i)*x%i,h=W(m,s,i)*x%i,d=W(h,t,i)*l%i;return{pow_p_5_8:W(d,Ra,i)*r%i,b2:a}}function Xf(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function Qf(r,t){let e=Ni,n=z(t*t*t,e),s=z(n*n*t,e),i=Jf(r*s).pow_p_5_8,o=z(r*n*i,e),a=z(t*o*o,e),c=o,f=z(o*Ia,e),l=a===r,u=a===z(-r,e),p=a===z(-r*Ia,e);return l&&(o=c),(u||p)&&(o=f),Ea(o,e)&&(o=z(-o,e)),{isValid:l||u,value:o}}var th=Bn(Ni,void 0,!0),eh={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:th,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:Wf,Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:Mr,randomBytes:dr,adjustScalarBytes:Xf,uvRatio:Qf},mr=ka(eh);var yr=32,ae=64,kn=32;function Na(){let r=mr.utils.randomPrivateKey(),t=mr.getPublicKey(r);return{privateKey:Ca(r,t),publicKey:t}}function _a(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=mr.getPublicKey(t);return{privateKey:Ca(t,e),publicKey:e}}function Ta(r,t){let e=r.subarray(0,kn);return mr.sign(t instanceof Uint8Array?t:t.subarray(),e)}function La(r,t,e){return mr.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}function Ca(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 _i={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=j.get();e*=8;async function c(u,p){let x=a.getRandomValues(new Uint8Array(i)),m=a.getRandomValues(new Uint8Array(n)),h={name:t,iv:m};typeof p=="string"&&(p=F(p));let d;if(p.length===0){d=await a.subtle.importKey("jwk",_i,{name:"AES-GCM"},!0,["encrypt"]);try{let b={name:"PBKDF2",salt:x,iterations:o,hash:{name:s}},w=await a.subtle.importKey("raw",p,{name:"PBKDF2"},!1,["deriveKey"]);d=await a.subtle.deriveKey(b,w,{name:t,length:e},!0,["encrypt"])}catch{d=await a.subtle.importKey("jwk",_i,{name:"AES-GCM"},!0,["encrypt"])}}else{let b={name:"PBKDF2",salt:x,iterations:o,hash:{name:s}},w=await a.subtle.importKey("raw",p,{name:"PBKDF2"},!1,["deriveKey"]);d=await a.subtle.deriveKey(b,w,{name:t,length:e},!0,["encrypt"])}let v=await a.subtle.encrypt(h,d,u);return vt([x,h.iv,new Uint8Array(v)])}async function f(u,p){let x=u.subarray(0,i),m=u.subarray(i,i+n),h=u.subarray(i+n),d={name:t,iv:m};typeof p=="string"&&(p=F(p));let v;if(p.length===0)try{let w={name:"PBKDF2",salt:x,iterations:o,hash:{name:s}},_=await a.subtle.importKey("raw",p,{name:"PBKDF2"},!1,["deriveKey"]);v=await a.subtle.deriveKey(w,_,{name:t,length:e},!0,["decrypt"])}catch{v=await a.subtle.importKey("jwk",_i,{name:"AES-GCM"},!0,["decrypt"])}else{let w={name:"PBKDF2",salt:x,iterations:o,hash:{name:s}},_=await a.subtle.importKey("raw",p,{name:"PBKDF2"},!1,["deriveKey"]);v=await a.subtle.deriveKey(w,_,{name:t,length:e},!0,["decrypt"])}let b=await a.subtle.decrypt(d,v,h);return new Uint8Array(b)}return{encrypt:c,decrypt:f}}async function br(r,t){let n=await In().encrypt(r,t);return _r.encode(n)}var xr={};rt(xr,{KeyType:()=>Y,PrivateKey:()=>Ft,PublicKey:()=>Kt});var nh=Math.pow(2,7),sh=Math.pow(2,14),ih=Math.pow(2,21),Ti=Math.pow(2,28),Li=Math.pow(2,35),Ci=Math.pow(2,42),Ui=Math.pow(2,49),q=128,mt=127;function Mt(r){if(r<nh)return 1;if(r<sh)return 2;if(r<ih)return 3;if(r<Ti)return 4;if(r<Li)return 5;if(r<Ci)return 6;if(r<Ui)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function Di(r,t,e=0){switch(Mt(r)){case 8:t[e++]=r&255|q,r/=128;case 7:t[e++]=r&255|q,r/=128;case 6:t[e++]=r&255|q,r/=128;case 5:t[e++]=r&255|q,r/=128;case 4:t[e++]=r&255|q,r>>>=7;case 3:t[e++]=r&255|q,r>>>=7;case 2:t[e++]=r&255|q,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function oh(r,t,e=0){switch(Mt(r)){case 8:t.set(e++,r&255|q),r/=128;case 7:t.set(e++,r&255|q),r/=128;case 6:t.set(e++,r&255|q),r/=128;case 5:t.set(e++,r&255|q),r/=128;case 4:t.set(e++,r&255|q),r>>>=7;case 3:t.set(e++,r&255|q),r>>>=7;case 2:t.set(e++,r&255|q),r>>>=7;case 1:{t.set(e++,r&255),r>>>=7;break}default:throw new Error("unreachable")}return t}function Pi(r,t){let e=r[t],n=0;if(n+=e&mt,e<q||(e=r[t+1],n+=(e&mt)<<7,e<q)||(e=r[t+2],n+=(e&mt)<<14,e<q)||(e=r[t+3],n+=(e&mt)<<21,e<q)||(e=r[t+4],n+=(e&mt)*Ti,e<q)||(e=r[t+5],n+=(e&mt)*Li,e<q)||(e=r[t+6],n+=(e&mt)*Ci,e<q)||(e=r[t+7],n+=(e&mt)*Ui,e<q))return n;throw new RangeError("Could not decode varint")}function ah(r,t){let e=r.get(t),n=0;if(n+=e&mt,e<q||(e=r.get(t+1),n+=(e&mt)<<7,e<q)||(e=r.get(t+2),n+=(e&mt)<<14,e<q)||(e=r.get(t+3),n+=(e&mt)<<21,e<q)||(e=r.get(t+4),n+=(e&mt)*Ti,e<q)||(e=r.get(t+5),n+=(e&mt)*Li,e<q)||(e=r.get(t+6),n+=(e&mt)*Ci,e<q)||(e=r.get(t+7),n+=(e&mt)*Ui,e<q))return n;throw new RangeError("Could not decode varint")}function Da(r,t,e=0){return t==null&&(t=gt(Mt(r))),t instanceof Uint8Array?Di(r,t,e):oh(r,t,e)}function Pa(r,t=0){return r instanceof Uint8Array?Pi(r,t):ah(r,t)}var Oi=new Float32Array([-0]),Ae=new Uint8Array(Oi.buffer);function Va(r,t,e){Oi[0]=r,t[e]=Ae[0],t[e+1]=Ae[1],t[e+2]=Ae[2],t[e+3]=Ae[3]}function Ma(r,t){return Ae[0]=r[t],Ae[1]=r[t+1],Ae[2]=r[t+2],Ae[3]=r[t+3],Oi[0]}var Vi=new Float64Array([-0]),yt=new Uint8Array(Vi.buffer);function Ha(r,t,e){Vi[0]=r,t[e]=yt[0],t[e+1]=yt[1],t[e+2]=yt[2],t[e+3]=yt[3],t[e+4]=yt[4],t[e+5]=yt[5],t[e+6]=yt[6],t[e+7]=yt[7]}function Ka(r,t){return yt[0]=r[t],yt[1]=r[t+1],yt[2]=r[t+2],yt[3]=r[t+3],yt[4]=r[t+4],yt[5]=r[t+5],yt[6]=r[t+6],yt[7]=r[t+7],Vi[0]}var ch=BigInt(Number.MAX_SAFE_INTEGER),uh=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<ch&&t>uh)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>Fa&&(s=0n,++n>Fa&&(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 Fa=4294967296n;function qa(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 $a(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 Mi(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 Ht(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function Rn(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var Hi=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,Ht(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 Ht(this,4);return Rn(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Ht(this,4);return Rn(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Ht(this,4);let t=Ma(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Ht(this,4);let t=Ka(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 Ht(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return $a(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw Ht(this,t);this.pos+=t}else do if(this.pos>=this.len)throw Ht(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 Ht(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 Ht(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 Ht(this,8);let t=Rn(this.buf,this.pos+=4),e=Rn(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=Pi(this.buf,this.pos);return this.pos+=Mt(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 Ki(r){return new Hi(r instanceof Uint8Array?r:r.subarray())}function It(r,t,e){let n=Ki(r);return t.decode(n,void 0,e)}function Fi(r){let t=r??8192,e=t>>>1,n,s=t;return function(o){if(o<1||o>e)return gt(o);s+o>t&&(n=gt(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 qi(){}var Gi=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},lh=Fi();function fh(r){return globalThis.Buffer!=null?gt(r):lh(r)}var $r=class{len;head;tail;states;constructor(){this.len=0,this.head=new He(qi,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 zi((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(Nn,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(Nn,e.length(),e)}uint64Number(t){return this._push(Di,Mt(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(Nn,e.length(),e)}sint64Number(t){let e=Tt.fromNumber(t).zzEncode();return this._push(Nn,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push($i,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(Va,4,t)}double(t){return this._push(Ha,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push($i,1,0):this.uint32(e)._push(dh,e,t)}string(t){let e=qa(t);return e!==0?this.uint32(e)._push(Mi,e,t):this._push($i,1,0)}fork(){return this.states=new Gi(this),this.head=this.tail=new He(qi,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(qi,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=fh(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function $i(r,t,e){t[e]=r&255}function hh(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var zi=class extends He{next;constructor(t,e){super(hh,t,e),this.next=void 0}};function Nn(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 dh(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(ph,t,r),this},$r.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(gh,t,r),this});function ph(r,t,e){t.set(r,e)}function gh(r,t,e){r.length<40?Mi(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(F(r),e)}function Yi(){return new $r}function Rt(r,t){let e=Yi();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var wr;(function(r){r[r.VARINT=0]="VARINT",r[r.BIT64=1]="BIT64",r[r.LENGTH_DELIMITED=2]="LENGTH_DELIMITED",r[r.START_GROUP=3]="START_GROUP",r[r.END_GROUP=4]="END_GROUP",r[r.BIT32=5]="BIT32"})(wr||(wr={}));function _n(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function ji(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",wr.VARINT,e,n)}function Nt(r,t){return _n("message",wr.LENGTH_DELIMITED,r,t)}var Y;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.Secp256k1="Secp256k1"})(Y||(Y={}));var Zi;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.Secp256k1=2]="Secp256k1"})(Zi||(Zi={}));(function(r){r.codec=()=>ji(Zi)})(Y||(Y={}));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),Y.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=Y.codec().decode(e);break;case 2:s.Data=e.bytes();break;default:e.skipType(o&7);break}}return s})),t),r.encode=e=>Rt(e,r.codec()),r.decode=e=>It(e,r.codec())})(Kt||(Kt={}));var Ft;(function(r){let t;r.codec=()=>(t==null&&(t=Nt((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),Y.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=Y.codec().decode(e);break;case 2:s.Data=e.bytes();break;default:e.skipType(o&7);break}}return s})),t),r.encode=e=>Rt(e,r.codec()),r.decode=e=>It(e,r.codec())})(Ft||(Ft={}));var Ke=class{_key;constructor(t){this._key=vr(t,yr)}verify(t,e){return La(this._key,e,t)}marshal(){return this._key}get bytes(){return Kt.encode({Type:Y.Ed25519,Data:this.marshal()}).subarray()}equals(t){return pt(this.bytes,t.bytes)}hash(){let t=ot.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,yr)}sign(t){return Ta(this._key,t)}get public(){return new Ke(this._publicKey)}marshal(){return this._key}get bytes(){return Ft.encode({Type:Y.Ed25519,Data:this.marshal()}).subarray()}equals(t){return pt(this.bytes,t.bytes)}async hash(){let t=ot.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 xt.encode(t.bytes).substring(1)}async export(t,e="libp2p-key"){if(e==="libp2p-key")return br(this.bytes,t);throw new B(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function mh(r){if(r.length>ae){r=vr(r,ae+yr);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(yr);return new ce(t,e)}function yh(r){return r=vr(r,yr),new Ke(r)}async function bh(){let{privateKey:r,publicKey:t}=Na();return new ce(r,t)}async function Wi(r){let{privateKey:t,publicKey:e}=_a(r);return new ce(t,e)}function vr(r,t){if(r=Uint8Array.from(r??[]),r.length!==t)throw new B(`Key must be a Uint8Array of length ${t}, got ${r.length}`,"ERR_INVALID_KEY_TYPE");return r}var za={"P-256":256,"P-384":384,"P-521":521},wh=Object.keys(za),Xi=wh.join(" / ");async function Ya(r){if(r!=="P-256"&&r!=="P-384"&&r!=="P-521")throw new B(`Unknown curve: ${r}. Must be ${Xi}`,"ERR_INVALID_CURVE");let t=await j.get().subtle.generateKey({name:"ECDH",namedCurve:r},!0,["deriveBits"]),e=async(i,o)=>{let a;o!=null?a=await j.get().subtle.importKey("jwk",vh(r,o),{name:"ECDH",namedCurve:r},!1,["deriveBits"]):a=t.privateKey;let c=await j.get().subtle.importKey("jwk",Za(r,i),{name:"ECDH",namedCurve:r},!1,[]),f=await j.get().subtle.deriveBits({name:"ECDH",namedCurve:r,public:c},a,za[r]);return new Uint8Array(f,0,f.byteLength)},n=await j.get().subtle.exportKey("jwk",t.publicKey);return{key:xh(n),genSharedKey:e}}var ja={"P-256":32,"P-384":48,"P-521":66};function xh(r){if(r.crv==null||r.x==null||r.y==null)throw new B("JWK was missing components","ERR_INVALID_PARAMETERS");if(r.crv!=="P-256"&&r.crv!=="P-384"&&r.crv!=="P-521")throw new B(`Unknown curve: ${r.crv}. Must be ${Xi}`,"ERR_INVALID_CURVE");let t=ja[r.crv];return vt([Uint8Array.from([4]),pi(r.x,t),pi(r.y,t)],1+t*2)}function Za(r,t){if(r!=="P-256"&&r!=="P-384"&&r!=="P-521")throw new B(`Unknown curve: ${r}. Must be ${Xi}`,"ERR_INVALID_CURVE");let e=ja[r];if(!pt(t.subarray(0,1),Uint8Array.from([4])))throw new B("Cannot unmarshal public key - invalid key format","ERR_INVALID_KEY_FORMAT");return{kty:"EC",crv:r,x:G(t.subarray(1,e+1),"base64url"),y:G(t.subarray(1+e),"base64url"),ext:!0}}var vh=(r,t)=>({...Za(r,t.public),d:G(t.private,"base64url")});var Wa=Ya;async function Ja(r,t){let e=_r.decode(r);return In().decrypt(e,t)}var Xa={"AES-128":{ivSize:16,keySize:16},"AES-256":{ivSize:16,keySize:32},Blowfish:{ivSize:8,keySize:32}};async function Qa(r,t,e){let n=Xa[r];if(n==null){let b=Object.keys(Xa).join(" / ");throw new B(`unknown cipher type '${r}'. Must be ${b}`,"ERR_INVALID_CIPHER_TYPE")}if(t==null)throw new B("missing hash type","ERR_MISSING_HASH_TYPE");let s=n.keySize,i=n.ivSize,o=20,a=F("key expansion"),c=2*(i+s+o),f=await ua(t,e),l=await f.digest(a),u=[],p=0;for(;p<c;){let b=await f.digest(vt([l,a])),w=b.length;p+w>c&&(w=c-p),u.push(b),p+=w,l=await f.digest(l)}let x=c/2,m=vt(u),h=m.subarray(0,x),d=m.subarray(x,c),v=b=>({iv:b.subarray(0,i),cipherKey:b.subarray(i,i+s),macKey:b.subarray(i+s)});return{k1:v(h),k2:v(d)}}var uo={};rt(uo,{MAX_RSA_KEY_SIZE:()=>$e,RsaPrivateKey:()=>Ne,RsaPublicKey:()=>qe,fromJwk:()=>Yh,generateKeyPair:()=>jh,unmarshalRsaPrivateKey:()=>ao,unmarshalRsaPublicKey:()=>zh});function Zt(r){if(isNaN(r)||r<=0)throw new B("random bytes length must be a Number bigger than 0","ERR_INVALID_LENGTH");return dr(r)}var Re={};rt(Re,{exportToPem:()=>Fh,importFromPem:()=>oo,jwkToPkcs1:()=>Vh,jwkToPkix:()=>Hh,pkcs1ToJwk:()=>Oh,pkixToJwk:()=>Mh});var Tn=class extends fr{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,mn(t);let n=be(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){mn(r);let s=da({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=be(t),f=be(e),l=new Uint8Array(o),u=Gr.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 Qi(r,t,e,n){let{c:s,dkLen:i,asyncTick:o,DK:a,PRF:c,PRFSalt:f}=Eh(r,t,e,n),l,u=new Uint8Array(4),p=hr(u),x=new Uint8Array(c.outputLen);for(let m=1,h=0;h<i;m++,h+=c.outputLen){let d=a.subarray(h,h+c.outputLen);p.setInt32(0,m,!1),(l=f._cloneInto(l)).update(u).digestInto(x),d.set(x.subarray(0,d.length)),await fa(s-1,o,()=>{c._cloneInto(l).update(x).digestInto(x);for(let v=0;v<d.length;v++)d[v]^=x[v]})}return Bh(c,f,a,l,x)}var O=Po(tc());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 Se(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 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 eo(){let r=new Uint8Array(this.valueHex);if(this.valueHex.byteLength>=2){let a=r[0]===255&&r[1]&128,c=r[0]===0&&(r[1]&128)===0;(a||c)&&this.warnings.push("Needlessly long format")}let t=new ArrayBuffer(this.valueHex.byteLength),e=new Uint8Array(t);for(let a=0;a<this.valueHex.byteLength;a++)e[a]=0;e[0]=r[0]&128;let n=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 ec(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=Se(o,8,n),c=new Uint8Array(a);return c[0]|=128,a}let s=Se(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 rc(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 _t(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 Sm=Math.log(2);function Dn(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function ro(r){let t=0,e=0;for(let s=0;s<r.length;s++){let 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 ro(this.items)}},zr=[new Uint8Array([1])],nc="0123456789";var Ar="",$t=new ArrayBuffer(0),no=new Uint8Array(0),jr="EndOfContent",ic="OCTET STRING",oc="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?O.BufferSourceConverter.toUint8Array(i.valueHex):no}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",$t)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:O.Convert.ToHex(this.valueHexView)}}},t.NAME="hexBlock",t}var le=class{constructor({blockLength:t=0,error:e=Ar,warnings:n=[],valueBeforeDecode:s=no}={}){this.blockLength=t,this.error=e,this.warnings=n,this.valueBeforeDecodeView=O.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:O.Convert.ToHex(this.valueBeforeDecodeView)}}};le.NAME="baseBlock";var bt=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'")}};bt.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?O.BufferSourceConverter.toUint8Array(t.valueHex):no,this.tagClass=(n=t.tagClass)!==null&&n!==void 0?n:-1,this.tagNumber=(s=t.tagNumber)!==null&&s!==void 0?s:-1,this.isConstructed=(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",$t}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=Se(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=O.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 x=0;x<f.length;x++)p[x]=f[x];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=Fe(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}}};Pn.NAME="identificationBlock";var On=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=O.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=Se(this.length,8);if(s.byteLength>127)return this.error="Too big length",$t;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}}};On.NAME="lengthBlock";var S={},dt=class extends le{constructor({name:t=Ar,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 On(s),this.valueBlock=i?new i(s):new bt(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||ac(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?$t: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():O.Convert.ToHex(this.toBER())}onAsciiEncoding(){return`${this.constructor.NAME} : ${O.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 rc(e,n)}};dt.NAME="BaseBlock";function ac(r){if(r instanceof S.Constructed)for(let t of r.valueBlock.value)ac(t)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var Vn=class extends dt{constructor({value:t=Ar,...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}'`}};Vn.NAME="BaseStringBlock";var Mn=class extends pe(bt){constructor({isHexOnly:t=!0,...e}={}){super(e),this.isHexOnly=t}};Mn.NAME="PrimitiveValueBlock";var cc,Hn=class extends dt{constructor(t={}){super(t,Mn),this.idBlock.isConstructed=!1}};cc=Hn;S.Primitive=cc;Hn.NAME="PRIMITIVE";function Lh(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 dt({},bt),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=dt;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=S.EndOfContent;break;case 1:c=S.Boolean;break;case 2:c=S.Integer;break;case 3:c=S.BitString;break;case 4:c=S.OctetString;break;case 5:c=S.Null;break;case 6:c=S.ObjectIdentifier;break;case 10:c=S.Enumerated;break;case 12:c=S.Utf8String;break;case 13:c=S.RelativeObjectIdentifier;break;case 14:c=S.TIME;break;case 15:return s.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:s};case 16:c=S.Sequence;break;case 17:c=S.Set;break;case 18:c=S.NumericString;break;case 19:c=S.PrintableString;break;case 20:c=S.TeletexString;break;case 21:c=S.VideotexString;break;case 22:c=S.IA5String;break;case 23:c=S.UTCTime;break;case 24:c=S.GeneralizedTime;break;case 25:c=S.GraphicString;break;case 26:c=S.VisibleString;break;case 27:c=S.GeneralString;break;case 28:c=S.UniversalString;break;case 29:c=S.CharacterString;break;case 30:c=S.BmpString;break;case 31:c=S.DATE;break;case 32:c=S.TimeOfDay;break;case 33:c=S.DateTime;break;case 34:c=S.Duration;break;default:{let f=s.idBlock.isConstructed?new S.Constructed:new S.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?S.Constructed:S.Primitive}return s=Lh(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 Sr(r){if(!r.byteLength){let t=new dt({},bt);return t.error="Input buffer has zero length",{offset:-1,result:t}}return ws(O.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function Ch(r,t){return r?1:t}var Wt=class extends bt{constructor({value:t=[],isIndefiniteForm:e=!1,...n}={}){super(n),this.value=t,this.isIndefiniteForm=e}fromBER(t,e,n){let s=O.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?$t:n.final()}toJSON(){let t={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let e of this.value)t.value.push(e.toJSON());return t}};Wt.NAME="ConstructedValueBlock";var uc,ke=class extends dt{constructor(t={}){super(t,Wt),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 Pu=Object.create;var gn=Object.defineProperty;var Vu=Object.getOwnPropertyDescriptor;var Mu=Object.getOwnPropertyNames;var Hu=Object.getPrototypeOf,Ku=Object.prototype.hasOwnProperty;var Po=(r,e)=>()=>(e||r((e={exports:{}}).exports,e),e.exports),te=(r,e)=>{for(var t in e)gn(r,t,{get:e[t],enumerable:!0})},Vo=(r,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of Mu(e))!Ku.call(r,s)&&s!==t&&gn(r,s,{get:()=>e[s],enumerable:!(n=Vu(e,s))||n.enumerable});return r};var Mo=(r,e,t)=>(t=r!=null?Pu(Hu(r)):{},Vo(e||!r||!r.__esModule?gn(t,"default",{value:r,enumerable:!0}):t,r)),Fu=r=>Vo(gn({},"__esModule",{value:!0}),r);var rc=Po(Sr=>{"use strict";var kh="[object ArrayBuffer]",lt=class r{static isArrayBuffer(e){return Object.prototype.toString.call(e)===kh}static toArrayBuffer(e){return this.isArrayBuffer(e)?e:e.byteLength===e.buffer.byteLength||e.byteOffset===0&&e.byteLength===e.buffer.byteLength?e.buffer:this.toUint8Array(e.buffer).slice(e.byteOffset,e.byteOffset+e.byteLength).buffer}static toUint8Array(e){return this.toView(e,Uint8Array)}static toView(e,t){if(e.constructor===t)return e;if(this.isArrayBuffer(e))return new t(e);if(this.isArrayBufferView(e))return new t(e.buffer,e.byteOffset,e.byteLength);throw new TypeError("The provided value is not of type '(ArrayBuffer or ArrayBufferView)'")}static isBufferSource(e){return this.isArrayBufferView(e)||this.isArrayBuffer(e)}static isArrayBufferView(e){return ArrayBuffer.isView(e)||e&&this.isArrayBuffer(e.buffer)}static isEqual(e,t){let n=r.toUint8Array(e),s=r.toUint8Array(t);if(n.length!==s.byteLength)return!1;for(let i=0;i<n.length;i++)if(n[i]!==s[i])return!1;return!0}static concat(...e){let t;Array.isArray(e[0])&&!(e[1]instanceof Function)||Array.isArray(e[0])&&e[1]instanceof Function?t=e[0]:e[e.length-1]instanceof Function?t=e.slice(0,e.length-1):t=e;let n=0;for(let o of t)n+=o.byteLength;let s=new Uint8Array(n),i=0;for(let o of t){let a=this.toUint8Array(o);s.set(a,i),i+=a.length}return e[e.length-1]instanceof Function?this.toView(s,e[e.length-1]):s.buffer}},no="string",Ih=/^[0-9a-f]+$/i,Rh=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,Nh=/^[a-zA-Z0-9-_]+$/,Un=class{static fromString(e){let t=unescape(encodeURIComponent(e)),n=new Uint8Array(t.length);for(let s=0;s<t.length;s++)n[s]=t.charCodeAt(s);return n.buffer}static toString(e){let t=lt.toUint8Array(e),n="";for(let i=0;i<t.length;i++)n+=String.fromCharCode(t[i]);return decodeURIComponent(escape(n))}},De=class{static toString(e,t=!1){let n=lt.toArrayBuffer(e),s=new DataView(n),i="";for(let o=0;o<n.byteLength;o+=2){let a=s.getUint16(o,t);i+=String.fromCharCode(a)}return i}static fromString(e,t=!1){let n=new ArrayBuffer(e.length*2),s=new DataView(n);for(let i=0;i<e.length;i++)s.setUint16(i*2,e.charCodeAt(i),t);return n}},Dn=class r{static isHex(e){return typeof e===no&&Ih.test(e)}static isBase64(e){return typeof e===no&&Rh.test(e)}static isBase64Url(e){return typeof e===no&&Nh.test(e)}static ToString(e,t="utf8"){let n=lt.toUint8Array(e);switch(t.toLowerCase()){case"utf8":return this.ToUtf8String(n);case"binary":return this.ToBinary(n);case"hex":return this.ToHex(n);case"base64":return this.ToBase64(n);case"base64url":return this.ToBase64Url(n);case"utf16le":return De.toString(n,!0);case"utf16":case"utf16be":return De.toString(n);default:throw new Error(`Unknown type of encoding '${t}'`)}}static FromString(e,t="utf8"){if(!e)return new ArrayBuffer(0);switch(t.toLowerCase()){case"utf8":return this.FromUtf8String(e);case"binary":return this.FromBinary(e);case"hex":return this.FromHex(e);case"base64":return this.FromBase64(e);case"base64url":return this.FromBase64Url(e);case"utf16le":return De.fromString(e,!0);case"utf16":case"utf16be":return De.fromString(e);default:throw new Error(`Unknown type of encoding '${t}'`)}}static ToBase64(e){let t=lt.toUint8Array(e);if(typeof btoa<"u"){let n=this.ToString(t,"binary");return btoa(n)}else return Buffer.from(t).toString("base64")}static FromBase64(e){let t=this.formatString(e);if(!t)return new ArrayBuffer(0);if(!r.isBase64(t))throw new TypeError("Argument 'base64Text' is not Base64 encoded");return typeof atob<"u"?this.FromBinary(atob(t)):new Uint8Array(Buffer.from(t,"base64")).buffer}static FromBase64Url(e){let t=this.formatString(e);if(!t)return new ArrayBuffer(0);if(!r.isBase64Url(t))throw new TypeError("Argument 'base64url' is not Base64Url encoded");return this.FromBase64(this.Base64Padding(t.replace(/\-/g,"+").replace(/\_/g,"/")))}static ToBase64Url(e){return this.ToBase64(e).replace(/\+/g,"-").replace(/\//g,"_").replace(/\=/g,"")}static FromUtf8String(e,t=r.DEFAULT_UTF8_ENCODING){switch(t){case"ascii":return this.FromBinary(e);case"utf8":return Un.fromString(e);case"utf16":case"utf16be":return De.fromString(e);case"utf16le":case"usc2":return De.fromString(e,!0);default:throw new Error(`Unknown type of encoding '${t}'`)}}static ToUtf8String(e,t=r.DEFAULT_UTF8_ENCODING){switch(t){case"ascii":return this.ToBinary(e);case"utf8":return Un.toString(e);case"utf16":case"utf16be":return De.toString(e);case"utf16le":case"usc2":return De.toString(e,!0);default:throw new Error(`Unknown type of encoding '${t}'`)}}static FromBinary(e){let t=e.length,n=new Uint8Array(t);for(let s=0;s<t;s++)n[s]=e.charCodeAt(s);return n.buffer}static ToBinary(e){let t=lt.toUint8Array(e),n="";for(let s=0;s<t.length;s++)n+=String.fromCharCode(t[s]);return n}static ToHex(e){let t=lt.toUint8Array(e),n="",s=t.length;for(let i=0;i<s;i++){let o=t[i];o<16&&(n+="0"),n+=o.toString(16)}return n}static FromHex(e){let t=this.formatString(e);if(!t)return new ArrayBuffer(0);if(!r.isHex(t))throw new TypeError("Argument 'hexString' is not HEX encoded");t.length%2&&(t=`0${t}`);let n=new Uint8Array(t.length/2);for(let s=0;s<t.length;s=s+2){let i=t.slice(s,s+2);n[s/2]=parseInt(i,16)}return n.buffer}static ToUtf16String(e,t=!1){return De.toString(e,t)}static FromUtf16String(e,t=!1){return De.fromString(e,t)}static Base64Padding(e){let t=4-e.length%4;if(t<4)for(let n=0;n<t;n++)e+="=";return e}static formatString(e){return e?.replace(/[\n\r\t ]/g,"")||""}};Dn.DEFAULT_UTF8_ENCODING="utf8";function _h(r,...e){let t=arguments[0];for(let n=1;n<arguments.length;n++){let s=arguments[n];for(let i in s)t[i]=s[i]}return t}function Th(...r){let e=r.map(s=>s.byteLength).reduce((s,i)=>s+i),t=new Uint8Array(e),n=0;return r.map(s=>new Uint8Array(s)).forEach(s=>{for(let i of s)t[n++]=i}),t.buffer}function Lh(r,e){if(!(r&&e)||r.byteLength!==e.byteLength)return!1;let t=new Uint8Array(r),n=new Uint8Array(e);for(let s=0;s<r.byteLength;s++)if(t[s]!==n[s])return!1;return!0}Sr.BufferSourceConverter=lt;Sr.Convert=Dn;Sr.assign=_h;Sr.combine=Th;Sr.isEqual=Lh});var gu=Po((Jy,Bo)=>{"use strict";var vd=Object.prototype.hasOwnProperty,Se="~";function cn(){}Object.create&&(cn.prototype=Object.create(null),new cn().__proto__||(Se=!1));function Ed(r,e,t){this.fn=r,this.context=e,this.once=t||!1}function pu(r,e,t,n,s){if(typeof t!="function")throw new TypeError("The listener must be a function");var i=new Ed(t,n||r,s),o=Se?Se+e:e;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 ks(r,e){--r._eventsCount===0?r._events=new cn:delete r._events[e]}function xe(){this._events=new cn,this._eventsCount=0}xe.prototype.eventNames=function(){var e=[],t,n;if(this._eventsCount===0)return e;for(n in t=this._events)vd.call(t,n)&&e.push(Se?n.slice(1):n);return Object.getOwnPropertySymbols?e.concat(Object.getOwnPropertySymbols(t)):e};xe.prototype.listeners=function(e){var t=Se?Se+e:e,n=this._events[t];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};xe.prototype.listenerCount=function(e){var t=Se?Se+e:e,n=this._events[t];return n?n.fn?1:n.length:0};xe.prototype.emit=function(e,t,n,s,i,o){var a=Se?Se+e:e;if(!this._events[a])return!1;var c=this._events[a],f=arguments.length,u,l;if(c.fn){switch(c.once&&this.removeListener(e,c.fn,void 0,!0),f){case 1:return c.fn.call(c.context),!0;case 2:return c.fn.call(c.context,t),!0;case 3:return c.fn.call(c.context,t,n),!0;case 4:return c.fn.call(c.context,t,n,s),!0;case 5:return c.fn.call(c.context,t,n,s,i),!0;case 6:return c.fn.call(c.context,t,n,s,i,o),!0}for(l=1,u=new Array(f-1);l<f;l++)u[l-1]=arguments[l];c.fn.apply(c.context,u)}else{var h=c.length,b;for(l=0;l<h;l++)switch(c[l].once&&this.removeListener(e,c[l].fn,void 0,!0),f){case 1:c[l].fn.call(c[l].context);break;case 2:c[l].fn.call(c[l].context,t);break;case 3:c[l].fn.call(c[l].context,t,n);break;case 4:c[l].fn.call(c[l].context,t,n,s);break;default:if(!u)for(b=1,u=new Array(f-1);b<f;b++)u[b-1]=arguments[b];c[l].fn.apply(c[l].context,u)}}return!0};xe.prototype.on=function(e,t,n){return pu(this,e,t,n,!1)};xe.prototype.once=function(e,t,n){return pu(this,e,t,n,!0)};xe.prototype.removeListener=function(e,t,n,s){var i=Se?Se+e:e;if(!this._events[i])return this;if(!t)return ks(this,i),this;var o=this._events[i];if(o.fn)o.fn===t&&(!s||o.once)&&(!n||o.context===n)&&ks(this,i);else{for(var a=0,c=[],f=o.length;a<f;a++)(o[a].fn!==t||s&&!o[a].once||n&&o[a].context!==n)&&c.push(o[a]);c.length?this._events[i]=c.length===1?c[0]:c:ks(this,i)}return this};xe.prototype.removeAllListeners=function(e){var t;return e?(t=Se?Se+e:e,this._events[t]&&ks(this,t)):(this._events=new cn,this._eventsCount=0),this};xe.prototype.off=xe.prototype.removeListener;xe.prototype.addListener=xe.prototype.on;xe.prefixed=Se;xe.EventEmitter=xe;typeof Bo<"u"&&(Bo.exports=xe)});var Td={};te(Td,{FloodSub:()=>Fs,floodsub:()=>_d,multicodec:()=>No});var $s=Symbol.for("@libp2p/peer-id");var Cr;(function(r){r.Accept="accept",r.Ignore="ignore",r.Reject="reject"})(Cr||(Cr={}));var A=class extends Error{code;props;constructor(e,t,n){super(e),this.code=t,this.name=n?.name??"CodeError",this.props=n??{}}};var Ho=(r,...e)=>{try{[...e]}catch{}};var Qt=class extends EventTarget{#e=new Map;constructor(){super(),Ho(1/0,this)}listenerCount(e){let t=this.#e.get(e);return t==null?0:t.length}addEventListener(e,t,n){super.addEventListener(e,t,n);let s=this.#e.get(e);s==null&&(s=[],this.#e.set(e,s)),s.push({callback:t,once:(n!==!0&&n!==!1&&n?.once)??!1})}removeEventListener(e,t,n){super.removeEventListener(e.toString(),t??null,n);let s=this.#e.get(e);s!=null&&(s=s.filter(({callback:i})=>i!==t),this.#e.set(e,s))}dispatchEvent(e){let t=super.dispatchEvent(e),n=this.#e.get(e.type);return n==null||(n=n.filter(({once:s})=>!s),this.#e.set(e.type,n)),t}safeDispatchEvent(e,t={}){return this.dispatchEvent(new ze(e,t))}},ze=globalThis.CustomEvent;var Md=Symbol.for("@libp2p/service-capabilities"),Ko=Symbol.for("@libp2p/service-dependencies");var Zs={};te(Zs,{base58btc:()=>Ee,base58flickr:()=>ju});var up=new Uint8Array(0);function Fo(r,e){if(r===e)return!0;if(r.byteLength!==e.byteLength)return!1;for(let t=0;t<r.byteLength;t++)if(r[t]!==e[t])return!1;return!0}function et(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 qo(r){return new TextEncoder().encode(r)}function $o(r){return new TextDecoder().decode(r)}function qu(r,e){if(r.length>=255)throw new TypeError("Alphabet too long");for(var t=new Uint8Array(256),n=0;n<t.length;n++)t[n]=255;for(var s=0;s<r.length;s++){var i=r.charAt(s),o=i.charCodeAt(0);if(t[o]!==255)throw new TypeError(i+" is ambiguous");t[o]=s}var a=r.length,c=r.charAt(0),f=Math.log(a)/Math.log(256),u=Math.log(256)/Math.log(a);function l(v){if(v instanceof Uint8Array||(ArrayBuffer.isView(v)?v=new Uint8Array(v.buffer,v.byteOffset,v.byteLength):Array.isArray(v)&&(v=Uint8Array.from(v))),!(v instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(v.length===0)return"";for(var m=0,d=0,y=0,x=v.length;y!==x&&v[y]===0;)y++,m++;for(var p=(x-y)*u+1>>>0,B=new Uint8Array(p);y!==x;){for(var C=v[y],L=0,I=p-1;(C!==0||L<d)&&I!==-1;I--,L++)C+=256*B[I]>>>0,B[I]=C%a>>>0,C=C/a>>>0;if(C!==0)throw new Error("Non-zero carry");d=L,y++}for(var R=p-d;R!==p&&B[R]===0;)R++;for(var T=c.repeat(m);R<p;++R)T+=r.charAt(B[R]);return T}function h(v){if(typeof v!="string")throw new TypeError("Expected String");if(v.length===0)return new Uint8Array;var m=0;if(v[m]!==" "){for(var d=0,y=0;v[m]===c;)d++,m++;for(var x=(v.length-m)*f+1>>>0,p=new Uint8Array(x);v[m];){var B=t[v.charCodeAt(m)];if(B===255)return;for(var C=0,L=x-1;(B!==0||C<y)&&L!==-1;L--,C++)B+=a*p[L]>>>0,p[L]=B%256>>>0,B=B/256>>>0;if(B!==0)throw new Error("Non-zero carry");y=C,m++}if(v[m]!==" "){for(var I=x-y;I!==x&&p[I]===0;)I++;for(var R=new Uint8Array(d+(x-I)),T=d;I!==x;)R[T++]=p[I++];return R}}}function b(v){var m=h(v);if(m)return m;throw new Error(`Non-${e} character`)}return{encode:l,decodeUnsafe:h,decode:b}}var $u=qu,Gu=$u,zo=Gu;var Gs=class{name;prefix;baseEncode;constructor(e,t,n){this.name=e,this.prefix=t,this.baseEncode=n}encode(e){if(e instanceof Uint8Array)return`${this.prefix}${this.baseEncode(e)}`;throw Error("Unknown type, must be binary type")}},zs=class{name;prefix;baseDecode;prefixCodePoint;constructor(e,t,n){if(this.name=e,this.prefix=t,t.codePointAt(0)===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=t.codePointAt(0),this.baseDecode=n}decode(e){if(typeof e=="string"){if(e.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(e)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(e.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(e){return Yo(this,e)}},Ys=class{decoders;constructor(e){this.decoders=e}or(e){return Yo(this,e)}decode(e){let t=e[0],n=this.decoders[t];if(n!=null)return n.decode(e);throw RangeError(`Unable to decode multibase string ${JSON.stringify(e)}, only inputs prefixed with ${Object.keys(this.decoders)} are supported`)}};function Yo(r,e){return new Ys({...r.decoders??{[r.prefix]:r},...e.decoders??{[e.prefix]:e}})}var js=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(e,t,n,s){this.name=e,this.prefix=t,this.baseEncode=n,this.baseDecode=s,this.encoder=new Gs(e,t,n),this.decoder=new zs(e,t,s)}encode(e){return this.encoder.encode(e)}decode(e){return this.decoder.decode(e)}};function er({name:r,prefix:e,encode:t,decode:n}){return new js(r,e,t,n)}function wt({name:r,prefix:e,alphabet:t}){let{encode:n,decode:s}=zo(t,r);return er({prefix:e,name:r,encode:n,decode:i=>et(s(i))})}function zu(r,e,t,n){let s={};for(let u=0;u<e.length;++u)s[e[u]]=u;let i=r.length;for(;r[i-1]==="=";)--i;let o=new Uint8Array(i*t/8|0),a=0,c=0,f=0;for(let u=0;u<i;++u){let l=s[r[u]];if(l===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<t|l,a+=t,a>=8&&(a-=8,o[f++]=255&c>>a)}if(a>=t||255&c<<8-a)throw new SyntaxError("Unexpected end of data");return o}function Yu(r,e,t){let n=e[e.length-1]==="=",s=(1<<t)-1,i="",o=0,a=0;for(let c=0;c<r.length;++c)for(a=a<<8|r[c],o+=8;o>t;)o-=t,i+=e[s&a>>o];if(o!==0&&(i+=e[s&a<<t-o]),n)for(;i.length*t&7;)i+="=";return i}function Q({name:r,prefix:e,bitsPerChar:t,alphabet:n}){return er({prefix:e,name:r,encode(s){return Yu(s,n,t)},decode(s){return zu(s,n,t,r)}})}var Ee=wt({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),ju=wt({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Ws={};te(Ws,{base10:()=>Zu});var Zu=wt({prefix:"9",name:"base10",alphabet:"0123456789"});var Js={};te(Js,{base16:()=>Wu,base16upper:()=>Ju});var Wu=Q({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Ju=Q({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Xs={};te(Xs,{base2:()=>Xu});var Xu=Q({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Qs={};te(Qs,{base256emoji:()=>nl});var jo=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}"),Qu=jo.reduce((r,e,t)=>(r[t]=e,r),[]),el=jo.reduce((r,e,t)=>(r[e.codePointAt(0)]=t,r),[]);function tl(r){return r.reduce((e,t)=>(e+=Qu[t],e),"")}function rl(r){let e=[];for(let t of r){let n=el[t.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${t}`);e.push(n)}return new Uint8Array(e)}var nl=er({prefix:"\u{1F680}",name:"base256emoji",encode:tl,decode:rl});var ei={};te(ei,{base32:()=>tr,base32hex:()=>al,base32hexpad:()=>ul,base32hexpadupper:()=>ll,base32hexupper:()=>cl,base32pad:()=>il,base32padupper:()=>ol,base32upper:()=>sl,base32z:()=>fl});var tr=Q({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),sl=Q({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),il=Q({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),ol=Q({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),al=Q({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),cl=Q({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),ul=Q({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),ll=Q({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),fl=Q({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var ti={};te(ti,{base36:()=>hl,base36upper:()=>dl});var hl=wt({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),dl=wt({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var ri={};te(ri,{base64:()=>Ur,base64pad:()=>pl,base64url:()=>gl,base64urlpad:()=>ml});var Ur=Q({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),pl=Q({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),gl=Q({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),ml=Q({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var ni={};te(ni,{base8:()=>yl});var yl=Q({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var si={};te(si,{identity:()=>bl});var bl=er({prefix:"\0",name:"identity",encode:r=>$o(r),decode:r=>qo(r)});var Sp=new TextEncoder,kp=new TextDecoder;var oi={};te(oi,{identity:()=>tt});var vl=Jo,Zo=128,El=127,Bl=~El,Al=Math.pow(2,31);function Jo(r,e,t){e=e||[],t=t||0;for(var n=t;r>=Al;)e[t++]=r&255|Zo,r/=128;for(;r&Bl;)e[t++]=r&255|Zo,r>>>=7;return e[t]=r|0,Jo.bytes=t-n+1,e}var Sl=ii,kl=128,Wo=127;function ii(r,n){var t=0,n=n||0,s=0,i=n,o,a=r.length;do{if(i>=a)throw ii.bytes=0,new RangeError("Could not decode varint");o=r[i++],t+=s<28?(o&Wo)<<s:(o&Wo)*Math.pow(2,s),s+=7}while(o>=kl);return ii.bytes=i-n,t}var Il=Math.pow(2,7),Rl=Math.pow(2,14),Nl=Math.pow(2,21),_l=Math.pow(2,28),Tl=Math.pow(2,35),Ll=Math.pow(2,42),Cl=Math.pow(2,49),Ul=Math.pow(2,56),Dl=Math.pow(2,63),Ol=function(r){return r<Il?1:r<Rl?2:r<Nl?3:r<_l?4:r<Tl?5:r<Ll?6:r<Cl?7:r<Ul?8:r<Dl?9:10},Pl={encode:vl,decode:Sl,encodingLength:Ol},Vl=Pl,Dr=Vl;function Or(r,e=0){return[Dr.decode(r,e),Dr.decode.bytes]}function rr(r,e,t=0){return Dr.encode(r,e,t),e}function nr(r){return Dr.encodingLength(r)}function Ye(r,e){let t=e.byteLength,n=nr(r),s=n+nr(t),i=new Uint8Array(s+t);return rr(r,i,0),rr(t,i,n),i.set(e,s),new sr(r,t,e,i)}function Pr(r){let e=et(r),[t,n]=Or(e),[s,i]=Or(e.subarray(n)),o=e.subarray(n+i);if(o.byteLength!==s)throw new Error("Incorrect length");return new sr(t,s,o,e)}function Xo(r,e){if(r===e)return!0;{let t=e;return r.code===t.code&&r.size===t.size&&t.bytes instanceof Uint8Array&&Fo(r.bytes,t.bytes)}}var sr=class{code;size;digest;bytes;constructor(e,t,n,s){this.code=e,this.size=t,this.digest=n,this.bytes=s}};var Qo=0,Ml="identity",ea=et;function Hl(r){return Ye(Qo,ea(r))}var tt={code:Qo,name:Ml,encode:ea,digest:Hl};var ui={};te(ui,{sha256:()=>oe,sha512:()=>Kl});function ci({name:r,code:e,encode:t}){return new ai(r,e,t)}var ai=class{name;code;encode;constructor(e,t,n){this.name=e,this.code=t,this.encode=n}digest(e){if(e instanceof Uint8Array){let t=this.encode(e);return t instanceof Uint8Array?Ye(this.code,t):t.then(n=>Ye(this.code,n))}else throw Error("Unknown type, must be binary type")}};function ra(r){return async e=>new Uint8Array(await crypto.subtle.digest(r,e))}var oe=ci({name:"sha2-256",code:18,encode:ra("SHA-256")}),Kl=ci({name:"sha2-512",code:19,encode:ra("SHA-512")});function na(r,e){let{bytes:t,version:n}=r;switch(n){case 0:return ql(t,li(r),e??Ee.encoder);default:return $l(t,li(r),e??tr.encoder)}}var sa=new WeakMap;function li(r){let e=sa.get(r);if(e==null){let t=new Map;return sa.set(r,t),t}return e}var xt=class r{code;version;multihash;bytes;"/";constructor(e,t,n,s){this.code=t,this.version=e,this.multihash=n,this.bytes=s,this["/"]=s}get asCID(){return this}get byteOffset(){return this.bytes.byteOffset}get byteLength(){return this.bytes.byteLength}toV0(){switch(this.version){case 0:return this;case 1:{let{code:e,multihash:t}=this;if(e!==Vr)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(t.code!==Gl)throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");return r.createV0(t)}default:throw Error(`Can not convert CID version ${this.version} to version 0. This is a bug please report`)}}toV1(){switch(this.version){case 0:{let{code:e,digest:t}=this.multihash,n=Ye(e,t);return r.createV1(this.code,n)}case 1:return this;default:throw Error(`Can not convert CID version ${this.version} to version 1. This is a bug please report`)}}equals(e){return r.equals(this,e)}static equals(e,t){let n=t;return n!=null&&e.code===n.code&&e.version===n.version&&Xo(e.multihash,n.multihash)}toString(e){return na(this,e)}toJSON(){return{"/":na(this)}}link(){return this}[Symbol.toStringTag]="CID";[Symbol.for("nodejs.util.inspect.custom")](){return`CID(${this.toString()})`}static asCID(e){if(e==null)return null;let t=e;if(t instanceof r)return t;if(t["/"]!=null&&t["/"]===t.bytes||t.asCID===t){let{version:n,code:s,multihash:i,bytes:o}=t;return new r(n,s,i,o??ia(n,s,i.bytes))}else if(t[zl]===!0){let{version:n,multihash:s,code:i}=t,o=Pr(s);return r.create(n,i,o)}else return null}static create(e,t,n){if(typeof t!="number")throw new Error("String codecs are no longer supported");if(!(n.bytes instanceof Uint8Array))throw new Error("Invalid digest");switch(e){case 0:{if(t!==Vr)throw new Error(`Version 0 CID must use dag-pb (code: ${Vr}) block encoding`);return new r(e,t,n,n.bytes)}case 1:{let s=ia(e,t,n.bytes);return new r(e,t,n,s)}default:throw new Error("Invalid version")}}static createV0(e){return r.create(0,Vr,e)}static createV1(e,t){return r.create(1,e,t)}static decode(e){let[t,n]=r.decodeFirst(e);if(n.length!==0)throw new Error("Incorrect length");return t}static decodeFirst(e){let t=r.inspectBytes(e),n=t.size-t.multihashSize,s=et(e.subarray(n,n+t.multihashSize));if(s.byteLength!==t.multihashSize)throw new Error("Incorrect length");let i=s.subarray(t.multihashSize-t.digestSize),o=new sr(t.multihashCode,t.digestSize,i,s);return[t.version===0?r.createV0(o):r.createV1(t.codec,o),e.subarray(t.size)]}static inspectBytes(e){let t=0,n=()=>{let[l,h]=Or(e.subarray(t));return t+=h,l},s=n(),i=Vr;if(s===18?(s=0,t=0):i=n(),s!==0&&s!==1)throw new RangeError(`Invalid CID version ${s}`);let o=t,a=n(),c=n(),f=t+c,u=f-o;return{version:s,codec:i,multihashCode:a,digestSize:c,multihashSize:u,size:f}}static parse(e,t){let[n,s]=Fl(e,t),i=r.decode(s);if(i.version===0&&e[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return li(i).set(n,e),i}};function Fl(r,e){switch(r[0]){case"Q":{let t=e??Ee;return[Ee.prefix,t.decode(`${Ee.prefix}${r}`)]}case Ee.prefix:{let t=e??Ee;return[Ee.prefix,t.decode(r)]}case tr.prefix:{let t=e??tr;return[tr.prefix,t.decode(r)]}default:{if(e==null)throw Error("To parse non base32 or base58btc encoded CID multibase decoder must be provided");return[r[0],e.decode(r)]}}}function ql(r,e,t){let{prefix:n}=t;if(n!==Ee.prefix)throw Error(`Cannot string encode V0 in ${t.name} encoding`);let s=e.get(n);if(s==null){let i=t.encode(r).slice(1);return e.set(n,i),i}else return s}function $l(r,e,t){let{prefix:n}=t,s=e.get(n);if(s==null){let i=t.encode(r);return e.set(n,i),i}else return s}var Vr=112,Gl=18;function ia(r,e,t){let n=nr(r),s=n+nr(e),i=new Uint8Array(s+t.byteLength);return rr(r,i,0),rr(e,i,n),i.set(t,s),i}var zl=Symbol.for("@ipld/js-cid/CID");var or={...si,...Xs,...ni,...Ws,...Js,...ei,...ti,...Zs,...ri,...Qs},Yp={...ui,...oi};function ge(r,e){if(r===e)return!0;if(r.byteLength!==e.byteLength)return!1;for(let t=0;t<r.byteLength;t++)if(r[t]!==e[t])return!1;return!0}function rt(r=0){return new Uint8Array(r)}function me(r=0){return new Uint8Array(r)}function aa(r,e,t,n){return{name:r,prefix:e,encoder:{name:r,prefix:e,encode:t},decoder:{decode:n}}}var oa=aa("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),fi=aa("ascii","a",r=>{let e="a";for(let t=0;t<r.length;t++)e+=String.fromCharCode(r[t]);return e},r=>{r=r.substring(1);let e=me(r.length);for(let t=0;t<r.length;t++)e[t]=r.charCodeAt(t);return e}),Yl={utf8:oa,"utf-8":oa,hex:or.base16,latin1:fi,ascii:fi,binary:fi,...or},yn=Yl;function q(r,e="utf8"){let t=yn[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return t.decoder.decode(`${t.prefix}${r}`)}function z(r,e="utf8"){let t=yn[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return t.encoder.encode(r).substring(1)}var ua=Symbol.for("nodejs.util.inspect.custom"),ca=Object.values(or).map(r=>r.decoder).reduce((r,e)=>r.or(e),or.identity.decoder),la=114,pi=36,gi=37,Mr=class{type;multihash;privateKey;publicKey;string;constructor(e){this.type=e.type,this.multihash=e.multihash,this.privateKey=e.privateKey,Object.defineProperty(this,"string",{enumerable:!1,writable:!0})}get[Symbol.toStringTag](){return`PeerId(${this.toString()})`}[$s]=!0;toString(){return this.string==null&&(this.string=Ee.encode(this.multihash.bytes).slice(1)),this.string}toCID(){return xt.createV1(la,this.multihash)}toBytes(){return this.multihash.bytes}toJSON(){return this.toString()}equals(e){if(e==null)return!1;if(e instanceof Uint8Array)return ge(this.multihash.bytes,e);if(typeof e=="string")return nt(e).equals(this);if(e?.multihash?.bytes!=null)return ge(this.multihash.bytes,e.multihash.bytes);throw new Error("not valid Id")}[ua](){return`PeerId(${this.toString()})`}},ar=class extends Mr{type="RSA";publicKey;constructor(e){super({...e,type:"RSA"}),this.publicKey=e.publicKey}},cr=class extends Mr{type="Ed25519";publicKey;constructor(e){super({...e,type:"Ed25519"}),this.publicKey=e.multihash.digest}},ur=class extends Mr{type="secp256k1";publicKey;constructor(e){super({...e,type:"secp256k1"}),this.publicKey=e.multihash.digest}},hi=2336,di=class{type="url";multihash;privateKey;publicKey;url;constructor(e){this.url=e.toString(),this.multihash=tt.digest(q(this.url))}[ua](){return`PeerId(${this.url})`}[$s]=!0;toString(){return this.toCID().toString()}toCID(){return xt.createV1(hi,this.multihash)}toBytes(){return this.toCID().bytes}equals(e){return e==null?!1:(e instanceof Uint8Array&&(e=z(e)),e.toString()===this.toString())}};function nt(r,e){if(e=e??ca,r.charAt(0)==="1"||r.charAt(0)==="Q"){let t=Pr(Ee.decode(`z${r}`));return r.startsWith("12D")?new cr({multihash:t}):r.startsWith("16U")?new ur({multihash:t}):new ar({multihash:t})}return Hr(ca.decode(r))}function Hr(r){try{let e=Pr(r);if(e.code===tt.code){if(e.digest.length===pi)return new cr({multihash:e});if(e.digest.length===gi)return new ur({multihash:e})}if(e.code===oe.code)return new ar({multihash:e})}catch{return jl(xt.decode(r))}throw new Error("Supplied PeerID CID is invalid")}function jl(r){if(r?.multihash==null||r.version==null||r.version===1&&r.code!==la&&r.code!==hi)throw new Error("Supplied PeerID CID is invalid");if(r.code===hi){let t=z(r.multihash.digest);return new di(new URL(t))}let e=r.multihash;if(e.code===oe.code)return new ar({multihash:r.multihash});if(e.code===tt.code){if(e.digest.length===pi)return new cr({multihash:r.multihash});if(e.digest.length===gi)return new ur({multihash:r.multihash})}throw new Error("Supplied PeerID CID is invalid")}async function bn(r,e){return r.length===pi?new cr({multihash:Ye(tt.code,r),privateKey:e}):r.length===gi?new ur({multihash:Ye(tt.code,r),privateKey:e}):new ar({multihash:await oe.digest(r),publicKey:r,privateKey:e})}function lr(r,e){let t={[Symbol.iterator]:()=>t,next:()=>{let n=r.next(),s=n.value;return n.done===!0||s==null?{done:!0,value:void 0}:{done:!1,value:e(s)}}};return t}var Kr=class{map;constructor(e){if(this.map=new Map,e!=null)for(let[t,n]of e.entries())this.map.set(t.toString(),n)}[Symbol.iterator](){return this.entries()}clear(){this.map.clear()}delete(e){return this.map.delete(e.toString())}entries(){return lr(this.map.entries(),e=>[nt(e[0]),e[1]])}forEach(e){this.map.forEach((t,n)=>{e(t,nt(n),this)})}get(e){return this.map.get(e.toString())}has(e){return this.map.has(e.toString())}set(e,t){this.map.set(e.toString(),t)}keys(){return lr(this.map.keys(),e=>nt(e))}values(){return this.map.values()}get size(){return this.map.size}};var Fr=class r{set;constructor(e){if(this.set=new Set,e!=null)for(let t of e)this.set.add(t.toString())}get size(){return this.set.size}[Symbol.iterator](){return this.values()}add(e){this.set.add(e.toString())}clear(){this.set.clear()}delete(e){this.set.delete(e.toString())}entries(){return lr(this.set.entries(),e=>{let t=nt(e[0]);return[t,t]})}forEach(e){this.set.forEach(t=>{let n=nt(t);e(n,n,this)})}has(e){return this.set.has(e.toString())}values(){return lr(this.set.values(),e=>nt(e))}intersection(e){let t=new r;for(let n of e)this.has(n)&&t.add(n);return t}difference(e){let t=new r;for(let n of this)e.has(n)||t.add(n);return t}union(e){let t=new r;for(let n of e)t.add(n);for(let n of this)t.add(n);return t}};var W={get(r=globalThis){let e=r.crypto;if(e?.subtle==null)throw Object.assign(new Error("Missing Web Crypto API. The most likely cause of this error is that this page is being accessed from an insecure context (i.e. not HTTPS). For more information and possible resolutions see https://github.com/libp2p/js-libp2p/blob/main/packages/crypto/README.md#web-crypto-api"),{code:"ERR_MISSING_WEB_CRYPTO"});return e}};var fa={SHA1:20,SHA256:32,SHA512:64};var Zl={SHA1:"SHA-1",SHA256:"SHA-256",SHA512:"SHA-512"},Wl=async(r,e)=>{let t=await W.get().subtle.sign({name:"HMAC"},r,e);return new Uint8Array(t,0,t.byteLength)};async function ha(r,e){let t=Zl[r],n=await W.get().subtle.importKey("raw",e,{name:"HMAC",hash:{name:t}},!1,["sign"]);return{async digest(s){return Wl(n,s)},length:fa[r]}}var on={};te(on,{Ed25519PrivateKey:()=>ut,Ed25519PublicKey:()=>Gt,MAX_RSA_KEY_SIZE:()=>jt,RsaPrivateKey:()=>Ct,RsaPublicKey:()=>Yt,Secp256k1PrivateKey:()=>Wt,Secp256k1PublicKey:()=>Zt,generateEphemeralKeyPair:()=>Xa,generateKeyPair:()=>ld,generateKeyPairFromSeed:()=>fd,importKey:()=>gd,keyStretcher:()=>tc,keysPBM:()=>Br,marshalPrivateKey:()=>pd,marshalPublicKey:()=>dd,supportedKeys:()=>bt,unmarshalPrivateKey:()=>cu,unmarshalPublicKey:()=>hd});var eo={};te(eo,{Ed25519PrivateKey:()=>ut,Ed25519PublicKey:()=>Gt,generateKeyPair:()=>xh,generateKeyPairFromSeed:()=>Qi,unmarshalEd25519PrivateKey:()=>bh,unmarshalEd25519PublicKey:()=>wh});function Be(r,e){e==null&&(e=r.reduce((s,i)=>s+i.length,0));let t=me(e),n=0;for(let s of r)t.set(s,n),n+=s.length;return t}function mi(r,e){let t=q(r,"base64urlpad");if(e!=null){if(t.length>e)throw new Error("byte array longer than desired length");t=Be([new Uint8Array(e-t.length),t])}return t}function Ue(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function fr(r){if(!Number.isSafeInteger(r)||r<0)throw new Error(`positive integer expected, not ${r}`)}function Xl(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function hr(r,...e){if(!Xl(r))throw new Error("Uint8Array expected");if(e.length>0&&!e.includes(r.length))throw new Error(`Uint8Array expected of length ${e}, not of length=${r.length}`)}function wn(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");fr(r.outputLen),fr(r.blockLen)}function dr(r,e=!0){if(r.destroyed)throw new Error("Hash instance has been destroyed");if(e&&r.finished)throw new Error("Hash#digest() has already been called")}function da(r,e){hr(r);let t=e.outputLen;if(r.length<t)throw new Error(`digestInto() expects output buffer of length at least ${t}`)}var Pt=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;var gr=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),Oe=(r,e)=>r<<32-e|r>>>e;var P0=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;var Ql=async()=>{};async function pa(r,e,t){let n=Date.now();for(let s=0;s<r;s++){t(s);let i=Date.now()-n;i>=0&&i<e||(await Ql(),n+=i)}}function ga(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function vt(r){return typeof r=="string"&&(r=ga(r)),hr(r),r}function yi(...r){let e=0;for(let n=0;n<r.length;n++){let s=r[n];hr(s),e+=s.length}let t=new Uint8Array(e);for(let n=0,s=0;n<r.length;n++){let i=r[n];t.set(i,s),s+=i.length}return t}var pr=class{clone(){return this._cloneInto()}},ef={}.toString;function ma(r,e){if(e!==void 0&&ef.call(e)!=="[object Object]")throw new Error("Options should be object or undefined");return Object.assign(r,e)}function xn(r){let e=n=>r().update(vt(n)).digest(),t=r();return e.outputLen=t.outputLen,e.blockLen=t.blockLen,e.create=()=>r(),e}function mr(r=32){if(Pt&&typeof Pt.getRandomValues=="function")return Pt.getRandomValues(new Uint8Array(r));if(Pt&&typeof Pt.randomBytes=="function")return Pt.randomBytes(r);throw new Error("crypto.getRandomValues must be defined")}function tf(r,e,t,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(e,t,n);let s=BigInt(32),i=BigInt(4294967295),o=Number(t>>s&i),a=Number(t&i),c=n?4:0,f=n?0:4;r.setUint32(e+c,o,n),r.setUint32(e+f,a,n)}var ya=(r,e,t)=>r&e^~r&t,ba=(r,e,t)=>r&e^r&t^e&t,yr=class extends pr{constructor(e,t,n,s){super(),this.blockLen=e,this.outputLen=t,this.padOffset=n,this.isLE=s,this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.buffer=new Uint8Array(e),this.view=gr(this.buffer)}update(e){dr(this);let{view:t,buffer:n,blockLen:s}=this;e=vt(e);let i=e.length;for(let o=0;o<i;){let a=Math.min(s-this.pos,i-o);if(a===s){let c=gr(e);for(;s<=i-o;o+=s)this.process(c,o);continue}n.set(e.subarray(o,o+a),this.pos),this.pos+=a,o+=a,this.pos===s&&(this.process(t,0),this.pos=0)}return this.length+=e.length,this.roundClean(),this}digestInto(e){dr(this),da(e,this),this.finished=!0;let{buffer:t,view:n,blockLen:s,isLE:i}=this,{pos:o}=this;t[o++]=128,this.buffer.subarray(o).fill(0),this.padOffset>s-o&&(this.process(n,0),o=0);for(let l=o;l<s;l++)t[l]=0;tf(n,s-8,BigInt(this.length*8),i),this.process(n,0);let a=gr(e),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let f=c/4,u=this.get();if(f>u.length)throw new Error("_sha2: outputLen bigger than state");for(let l=0;l<f;l++)a.setUint32(4*l,u[l],i)}digest(){let{buffer:e,outputLen:t}=this;this.digestInto(e);let n=e.slice(0,t);return this.destroy(),n}_cloneInto(e){e||(e=new this.constructor),e.set(...this.get());let{blockLen:t,buffer:n,length:s,finished:i,destroyed:o,pos:a}=this;return e.length=s,e.pos=a,e.finished=i,e.destroyed=o,s%t&&e.buffer.set(n),e}};var vn=BigInt(4294967295),bi=BigInt(32);function wa(r,e=!1){return e?{h:Number(r&vn),l:Number(r>>bi&vn)}:{h:Number(r>>bi&vn)|0,l:Number(r&vn)|0}}function rf(r,e=!1){let t=new Uint32Array(r.length),n=new Uint32Array(r.length);for(let s=0;s<r.length;s++){let{h:i,l:o}=wa(r[s],e);[t[s],n[s]]=[i,o]}return[t,n]}var nf=(r,e)=>BigInt(r>>>0)<<bi|BigInt(e>>>0),sf=(r,e,t)=>r>>>t,of=(r,e,t)=>r<<32-t|e>>>t,af=(r,e,t)=>r>>>t|e<<32-t,cf=(r,e,t)=>r<<32-t|e>>>t,uf=(r,e,t)=>r<<64-t|e>>>t-32,lf=(r,e,t)=>r>>>t-32|e<<64-t,ff=(r,e)=>e,hf=(r,e)=>r,df=(r,e,t)=>r<<t|e>>>32-t,pf=(r,e,t)=>e<<t|r>>>32-t,gf=(r,e,t)=>e<<t-32|r>>>64-t,mf=(r,e,t)=>r<<t-32|e>>>64-t;function yf(r,e,t,n){let s=(e>>>0)+(n>>>0);return{h:r+t+(s/2**32|0)|0,l:s|0}}var bf=(r,e,t)=>(r>>>0)+(e>>>0)+(t>>>0),wf=(r,e,t,n)=>e+t+n+(r/2**32|0)|0,xf=(r,e,t,n)=>(r>>>0)+(e>>>0)+(t>>>0)+(n>>>0),vf=(r,e,t,n,s)=>e+t+n+s+(r/2**32|0)|0,Ef=(r,e,t,n,s)=>(r>>>0)+(e>>>0)+(t>>>0)+(n>>>0)+(s>>>0),Bf=(r,e,t,n,s,i)=>e+t+n+s+i+(r/2**32|0)|0;var Af={fromBig:wa,split:rf,toBig:nf,shrSH:sf,shrSL:of,rotrSH:af,rotrSL:cf,rotrBH:uf,rotrBL:lf,rotr32H:ff,rotr32L:hf,rotlSH:df,rotlSL:pf,rotlBH:gf,rotlBL:mf,add:yf,add3L:bf,add3H:wf,add4L:xf,add4H:vf,add5H:Bf,add5L:Ef},O=Af;var[Sf,kf]=O.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))),Et=new Uint32Array(80),Bt=new Uint32Array(80),wi=class extends yr{constructor(){super(128,64,16,!1),this.Ah=1779033703,this.Al=-205731576,this.Bh=-1150833019,this.Bl=-2067093701,this.Ch=1013904242,this.Cl=-23791573,this.Dh=-1521486534,this.Dl=1595750129,this.Eh=1359893119,this.El=-1377402159,this.Fh=-1694144372,this.Fl=725511199,this.Gh=528734635,this.Gl=-79577749,this.Hh=1541459225,this.Hl=327033209}get(){let{Ah:e,Al:t,Bh:n,Bl:s,Ch:i,Cl:o,Dh:a,Dl:c,Eh:f,El:u,Fh:l,Fl:h,Gh:b,Gl:v,Hh:m,Hl:d}=this;return[e,t,n,s,i,o,a,c,f,u,l,h,b,v,m,d]}set(e,t,n,s,i,o,a,c,f,u,l,h,b,v,m,d){this.Ah=e|0,this.Al=t|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=u|0,this.Fh=l|0,this.Fl=h|0,this.Gh=b|0,this.Gl=v|0,this.Hh=m|0,this.Hl=d|0}process(e,t){for(let p=0;p<16;p++,t+=4)Et[p]=e.getUint32(t),Bt[p]=e.getUint32(t+=4);for(let p=16;p<80;p++){let B=Et[p-15]|0,C=Bt[p-15]|0,L=O.rotrSH(B,C,1)^O.rotrSH(B,C,8)^O.shrSH(B,C,7),I=O.rotrSL(B,C,1)^O.rotrSL(B,C,8)^O.shrSL(B,C,7),R=Et[p-2]|0,T=Bt[p-2]|0,ne=O.rotrSH(R,T,19)^O.rotrBH(R,T,61)^O.shrSH(R,T,6),F=O.rotrSL(R,T,19)^O.rotrBL(R,T,61)^O.shrSL(R,T,6),P=O.add4L(I,F,Bt[p-7],Bt[p-16]),se=O.add4H(P,L,ne,Et[p-7],Et[p-16]);Et[p]=se|0,Bt[p]=P|0}let{Ah:n,Al:s,Bh:i,Bl:o,Ch:a,Cl:c,Dh:f,Dl:u,Eh:l,El:h,Fh:b,Fl:v,Gh:m,Gl:d,Hh:y,Hl:x}=this;for(let p=0;p<80;p++){let B=O.rotrSH(l,h,14)^O.rotrSH(l,h,18)^O.rotrBH(l,h,41),C=O.rotrSL(l,h,14)^O.rotrSL(l,h,18)^O.rotrBL(l,h,41),L=l&b^~l&m,I=h&v^~h&d,R=O.add5L(x,C,I,kf[p],Bt[p]),T=O.add5H(R,y,B,L,Sf[p],Et[p]),ne=R|0,F=O.rotrSH(n,s,28)^O.rotrBH(n,s,34)^O.rotrBH(n,s,39),P=O.rotrSL(n,s,28)^O.rotrBL(n,s,34)^O.rotrBL(n,s,39),se=n&i^n&a^i&a,S=s&o^s&c^o&c;y=m|0,x=d|0,m=b|0,d=v|0,b=l|0,v=h|0,{h:l,l:h}=O.add(f|0,u|0,T|0,ne|0),f=a|0,u=c|0,a=i|0,c=o|0,i=n|0,o=s|0;let N=O.add3L(ne,P,S);n=O.add3H(N,T,F,se),s=N|0}({h:n,l:s}=O.add(this.Ah|0,this.Al|0,n|0,s|0)),{h:i,l:o}=O.add(this.Bh|0,this.Bl|0,i|0,o|0),{h:a,l:c}=O.add(this.Ch|0,this.Cl|0,a|0,c|0),{h:f,l:u}=O.add(this.Dh|0,this.Dl|0,f|0,u|0),{h:l,l:h}=O.add(this.Eh|0,this.El|0,l|0,h|0),{h:b,l:v}=O.add(this.Fh|0,this.Fl|0,b|0,v|0),{h:m,l:d}=O.add(this.Gh|0,this.Gl|0,m|0,d|0),{h:y,l:x}=O.add(this.Hh|0,this.Hl|0,y|0,x|0),this.set(n,s,i,o,a,c,f,u,l,h,b,v,m,d,y,x)}roundClean(){Et.fill(0),Bt.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 qr=xn(()=>new wi);var Bn={};te(Bn,{aInRange:()=>Ie,abool:()=>Pe,abytes:()=>br,bitGet:()=>Lf,bitLen:()=>Ai,bitMask:()=>Gr,bitSet:()=>Cf,bytesToHex:()=>it,bytesToNumberBE:()=>ot,bytesToNumberLE:()=>St,concatBytes:()=>at,createHmacDrbg:()=>Si,ensureBytes:()=>ee,equalBytes:()=>_f,hexToBytes:()=>Mt,hexToNumber:()=>Bi,inRange:()=>$r,isBytes:()=>At,memoized:()=>Kt,notImplemented:()=>Df,numberToBytesBE:()=>kt,numberToBytesLE:()=>Ht,numberToHexUnpadded:()=>Vt,numberToVarBytesBE:()=>Nf,utf8ToBytes:()=>Tf,validateObject:()=>je});var Ei=BigInt(0),En=BigInt(1),If=BigInt(2);function At(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function br(r){if(!At(r))throw new Error("Uint8Array expected")}function Pe(r,e){if(typeof e!="boolean")throw new Error(`${r} must be valid boolean, got "${e}".`)}var Rf=Array.from({length:256},(r,e)=>e.toString(16).padStart(2,"0"));function it(r){br(r);let e="";for(let t=0;t<r.length;t++)e+=Rf[r[t]];return e}function Vt(r){let e=r.toString(16);return e.length&1?`0${e}`:e}function Bi(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return BigInt(r===""?"0":`0x${r}`)}var st={_0:48,_9:57,_A:65,_F:70,_a:97,_f:102};function xa(r){if(r>=st._0&&r<=st._9)return r-st._0;if(r>=st._A&&r<=st._F)return r-(st._A-10);if(r>=st._a&&r<=st._f)return r-(st._a-10)}function Mt(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);let e=r.length,t=e/2;if(e%2)throw new Error("padded hex string expected, got unpadded hex of length "+e);let n=new Uint8Array(t);for(let s=0,i=0;s<t;s++,i+=2){let o=xa(r.charCodeAt(i)),a=xa(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 ot(r){return Bi(it(r))}function St(r){return br(r),Bi(it(Uint8Array.from(r).reverse()))}function kt(r,e){return Mt(r.toString(16).padStart(e*2,"0"))}function Ht(r,e){return kt(r,e).reverse()}function Nf(r){return Mt(Vt(r))}function ee(r,e,t){let n;if(typeof e=="string")try{n=Mt(e)}catch(i){throw new Error(`${r} must be valid hex string, got "${e}". Cause: ${i}`)}else if(At(e))n=Uint8Array.from(e);else throw new Error(`${r} must be hex string or Uint8Array`);let s=n.length;if(typeof t=="number"&&s!==t)throw new Error(`${r} expected ${t} bytes, got ${s}`);return n}function at(...r){let e=0;for(let n=0;n<r.length;n++){let s=r[n];br(s),e+=s.length}let t=new Uint8Array(e);for(let n=0,s=0;n<r.length;n++){let i=r[n];t.set(i,s),s+=i.length}return t}function _f(r,e){if(r.length!==e.length)return!1;let t=0;for(let n=0;n<r.length;n++)t|=r[n]^e[n];return t===0}function Tf(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}var xi=r=>typeof r=="bigint"&&Ei<=r;function $r(r,e,t){return xi(r)&&xi(e)&&xi(t)&&e<=r&&r<t}function Ie(r,e,t,n){if(!$r(e,t,n))throw new Error(`expected valid ${r}: ${t} <= n < ${n}, got ${typeof e} ${e}`)}function Ai(r){let e;for(e=0;r>Ei;r>>=En,e+=1);return e}function Lf(r,e){return r>>BigInt(e)&En}function Cf(r,e,t){return r|(t?En:Ei)<<BigInt(e)}var Gr=r=>(If<<BigInt(r-1))-En,vi=r=>new Uint8Array(r),va=r=>Uint8Array.from(r);function Si(r,e,t){if(typeof r!="number"||r<2)throw new Error("hashLen must be a number");if(typeof e!="number"||e<2)throw new Error("qByteLen must be a number");if(typeof t!="function")throw new Error("hmacFn must be a function");let n=vi(r),s=vi(r),i=0,o=()=>{n.fill(1),s.fill(0),i=0},a=(...l)=>t(s,n,...l),c=(l=vi())=>{s=a(va([0]),l),n=a(),l.length!==0&&(s=a(va([1]),l),n=a())},f=()=>{if(i++>=1e3)throw new Error("drbg: tried 1000 values");let l=0,h=[];for(;l<e;){n=a();let b=n.slice();h.push(b),l+=n.length}return at(...h)};return(l,h)=>{o(),c(l);let b;for(;!(b=h(f()));)c();return o(),b}}var Uf={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"||At(r),isSafeInteger:r=>Number.isSafeInteger(r),array:r=>Array.isArray(r),field:(r,e)=>e.Fp.isValid(r),hash:r=>typeof r=="function"&&Number.isSafeInteger(r.outputLen)};function je(r,e,t={}){let n=(s,i,o)=>{let a=Uf[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(e))n(s,i,!1);for(let[s,i]of Object.entries(t))n(s,i,!0);return r}var Df=()=>{throw new Error("not implemented")};function Kt(r){let e=new WeakMap;return(t,...n)=>{let s=e.get(t);if(s!==void 0)return s;let i=r(t,...n);return e.set(t,i),i}}var ae=BigInt(0),J=BigInt(1),Ft=BigInt(2),Of=BigInt(3),ki=BigInt(4),Ea=BigInt(5),Ba=BigInt(8),Pf=BigInt(9),Vf=BigInt(16);function Y(r,e){let t=r%e;return t>=ae?t:e+t}function Mf(r,e,t){if(t<=ae||e<ae)throw new Error("Expected power/modulo > 0");if(t===J)return ae;let n=J;for(;e>ae;)e&J&&(n=n*r%t),r=r*r%t,e>>=J;return n}function X(r,e,t){let n=r;for(;e-- >ae;)n*=n,n%=t;return n}function An(r,e){if(r===ae||e<=ae)throw new Error(`invert: expected positive integers, got n=${r} mod=${e}`);let t=Y(r,e),n=e,s=ae,i=J,o=J,a=ae;for(;t!==ae;){let f=n/t,u=n%t,l=s-o*f,h=i-a*f;n=t,t=u,s=o,i=a,o=l,a=h}if(n!==J)throw new Error("invert: does not exist");return Y(s,e)}function Hf(r){let e=(r-J)/Ft,t,n,s;for(t=r-J,n=0;t%Ft===ae;t/=Ft,n++);for(s=Ft;s<r&&Mf(s,e,r)!==r-J;s++);if(n===1){let o=(r+J)/ki;return function(c,f){let u=c.pow(f,o);if(!c.eql(c.sqr(u),f))throw new Error("Cannot find square root");return u}}let i=(t+J)/Ft;return function(a,c){if(a.pow(c,e)===a.neg(a.ONE))throw new Error("Cannot find square root");let f=n,u=a.pow(a.mul(a.ONE,s),t),l=a.pow(c,i),h=a.pow(c,t);for(;!a.eql(h,a.ONE);){if(a.eql(h,a.ZERO))return a.ZERO;let b=1;for(let m=a.sqr(h);b<f&&!a.eql(m,a.ONE);b++)m=a.sqr(m);let v=a.pow(u,J<<BigInt(f-b-1));u=a.sqr(v),l=a.mul(l,v),h=a.mul(h,u),f=b}return l}}function Kf(r){if(r%ki===Of){let e=(r+J)/ki;return function(n,s){let i=n.pow(s,e);if(!n.eql(n.sqr(i),s))throw new Error("Cannot find square root");return i}}if(r%Ba===Ea){let e=(r-Ea)/Ba;return function(n,s){let i=n.mul(s,Ft),o=n.pow(i,e),a=n.mul(s,o),c=n.mul(n.mul(a,Ft),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%Vf,Hf(r)}var Aa=(r,e)=>(Y(r,e)&J)===J,Ff=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function Ii(r){let e={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},t=Ff.reduce((n,s)=>(n[s]="function",n),e);return je(r,t)}function qf(r,e,t){if(t<ae)throw new Error("Expected power > 0");if(t===ae)return r.ONE;if(t===J)return e;let n=r.ONE,s=e;for(;t>ae;)t&J&&(n=r.mul(n,s)),s=r.sqr(s),t>>=J;return n}function $f(r,e){let t=new Array(e.length),n=e.reduce((i,o,a)=>r.is0(o)?i:(t[a]=i,r.mul(i,o)),r.ONE),s=r.inv(n);return e.reduceRight((i,o,a)=>r.is0(o)?i:(t[a]=r.mul(i,t[a]),r.mul(i,o)),s),t}function Ri(r,e){let t=e!==void 0?e:r.toString(2).length,n=Math.ceil(t/8);return{nBitLength:t,nByteLength:n}}function It(r,e,t=!1,n={}){if(r<=ae)throw new Error(`Expected Field ORDER > 0, got ${r}`);let{nBitLength:s,nByteLength:i}=Ri(r,e);if(i>2048)throw new Error("Field lengths over 2048 bytes are not supported");let o=Kf(r),a=Object.freeze({ORDER:r,BITS:s,BYTES:i,MASK:Gr(s),ZERO:ae,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 ae<=c&&c<r},is0:c=>c===ae,isOdd:c=>(c&J)===J,neg:c=>Y(-c,r),eql:(c,f)=>c===f,sqr:c=>Y(c*c,r),add:(c,f)=>Y(c+f,r),sub:(c,f)=>Y(c-f,r),mul:(c,f)=>Y(c*f,r),pow:(c,f)=>qf(a,c,f),div:(c,f)=>Y(c*An(f,r),r),sqrN:c=>c*c,addN:(c,f)=>c+f,subN:(c,f)=>c-f,mulN:(c,f)=>c*f,inv:c=>An(c,r),sqrt:n.sqrt||(c=>o(a,c)),invertBatch:c=>$f(a,c),cmov:(c,f,u)=>u?f:c,toBytes:c=>t?Ht(c,i):kt(c,i),fromBytes:c=>{if(c.length!==i)throw new Error(`Fp.fromBytes: expected ${i}, got ${c.length}`);return t?St(c):ot(c)}});return Object.freeze(a)}function Sa(r){if(typeof r!="bigint")throw new Error("field order must be bigint");let e=r.toString(2).length;return Math.ceil(e/8)}function Ni(r){let e=Sa(r);return e+Math.ceil(e/2)}function ka(r,e,t=!1){let n=r.length,s=Sa(e),i=Ni(e);if(n<16||n<i||n>1024)throw new Error(`expected ${i}-1024 bytes of input, got ${n}`);let o=t?ot(r):St(r),a=Y(o,e-J)+J;return t?Ht(a,s):kt(a,s)}var zf=BigInt(0),_i=BigInt(1),Ti=new WeakMap,Ia=new WeakMap;function Sn(r,e){let t=(i,o)=>{let a=o.negate();return i?a:o},n=i=>{if(!Number.isSafeInteger(i)||i<=0||i>e)throw new Error(`Wrong window size=${i}, should be [1..${e}]`)},s=i=>{n(i);let o=Math.ceil(e/i)+1,a=2**(i-1);return{windows:o,windowSize:a}};return{constTimeNegate:t,unsafeLadder(i,o){let a=r.ZERO,c=i;for(;o>zf;)o&_i&&(a=a.add(c)),c=c.double(),o>>=_i;return a},precomputeWindow(i,o){let{windows:a,windowSize:c}=s(o),f=[],u=i,l=u;for(let h=0;h<a;h++){l=u,f.push(l);for(let b=1;b<c;b++)l=l.add(u),f.push(l);u=l.double()}return f},wNAF(i,o,a){let{windows:c,windowSize:f}=s(i),u=r.ZERO,l=r.BASE,h=BigInt(2**i-1),b=2**i,v=BigInt(i);for(let m=0;m<c;m++){let d=m*f,y=Number(a&h);a>>=v,y>f&&(y-=b,a+=_i);let x=d,p=d+Math.abs(y)-1,B=m%2!==0,C=y<0;y===0?l=l.add(t(B,o[x])):u=u.add(t(C,o[p]))}return{p:u,f:l}},wNAFCached(i,o,a){let c=Ia.get(i)||1,f=Ti.get(i);return f||(f=this.precomputeWindow(i,c),c!==1&&Ti.set(i,a(f))),this.wNAF(c,f,o)},setWindowSize(i,o){n(o),Ia.set(i,o),Ti.delete(i)}}}function kn(r,e,t,n){if(!Array.isArray(t)||!Array.isArray(n)||n.length!==t.length)throw new Error("arrays of points and scalars must have equal length");n.forEach((u,l)=>{if(!e.isValid(u))throw new Error(`wrong scalar at index ${l}`)}),t.forEach((u,l)=>{if(!(u instanceof r))throw new Error(`wrong point at index ${l}`)});let s=Ai(BigInt(t.length)),i=s>12?s-3:s>4?s-2:s?2:1,o=(1<<i)-1,a=new Array(o+1).fill(r.ZERO),c=Math.floor((e.BITS-1)/i)*i,f=r.ZERO;for(let u=c;u>=0;u-=i){a.fill(r.ZERO);for(let h=0;h<n.length;h++){let b=n[h],v=Number(b>>BigInt(u)&BigInt(o));a[v]=a[v].add(t[h])}let l=r.ZERO;for(let h=a.length-1,b=r.ZERO;h>0;h--)b=b.add(a[h]),l=l.add(b);if(f=f.add(l),u!==0)for(let h=0;h<i;h++)f=f.double()}return f}function zr(r){return Ii(r.Fp),je(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...Ri(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Ve=BigInt(0),Re=BigInt(1),In=BigInt(2),Yf=BigInt(8),jf={zip215:!0};function Zf(r){let e=zr(r);return je(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...e})}function Ra(r){let e=Zf(r),{Fp:t,n,prehash:s,hash:i,randomBytes:o,nByteLength:a,h:c}=e,f=In<<BigInt(a*8)-Re,u=t.create,l=It(e.n,e.nBitLength),h=e.uvRatio||((w,g)=>{try{return{isValid:!0,value:t.sqrt(w*t.inv(g))}}catch{return{isValid:!1,value:Ve}}}),b=e.adjustScalarBytes||(w=>w),v=e.domain||((w,g,E)=>{if(Pe("phflag",E),g.length||E)throw new Error("Contexts/pre-hash are not supported");return w});function m(w,g){Ie("coordinate "+w,g,Ve,f)}function d(w){if(!(w instanceof p))throw new Error("ExtendedPoint expected")}let y=Kt((w,g)=>{let{ex:E,ey:_,ez:U}=w,D=w.is0();g==null&&(g=D?Yf:t.inv(U));let V=u(E*g),K=u(_*g),M=u(U*g);if(D)return{x:Ve,y:Re};if(M!==Re)throw new Error("invZ was invalid");return{x:V,y:K}}),x=Kt(w=>{let{a:g,d:E}=e;if(w.is0())throw new Error("bad point: ZERO");let{ex:_,ey:U,ez:D,et:V}=w,K=u(_*_),M=u(U*U),G=u(D*D),j=u(G*G),ue=u(K*g),le=u(G*u(ue+M)),de=u(j+u(E*u(K*M)));if(le!==de)throw new Error("bad point: equation left != right (1)");let ve=u(_*U),ie=u(D*V);if(ve!==ie)throw new Error("bad point: equation left != right (2)");return!0});class p{constructor(g,E,_,U){this.ex=g,this.ey=E,this.ez=_,this.et=U,m("x",g),m("y",E),m("z",_),m("t",U),Object.freeze(this)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(g){if(g instanceof p)throw new Error("extended point not allowed");let{x:E,y:_}=g||{};return m("x",E),m("y",_),new p(E,_,Re,u(E*_))}static normalizeZ(g){let E=t.invertBatch(g.map(_=>_.ez));return g.map((_,U)=>_.toAffine(E[U])).map(p.fromAffine)}static msm(g,E){return kn(p,l,g,E)}_setWindowSize(g){L.setWindowSize(this,g)}assertValidity(){x(this)}equals(g){d(g);let{ex:E,ey:_,ez:U}=this,{ex:D,ey:V,ez:K}=g,M=u(E*K),G=u(D*U),j=u(_*K),ue=u(V*U);return M===G&&j===ue}is0(){return this.equals(p.ZERO)}negate(){return new p(u(-this.ex),this.ey,this.ez,u(-this.et))}double(){let{a:g}=e,{ex:E,ey:_,ez:U}=this,D=u(E*E),V=u(_*_),K=u(In*u(U*U)),M=u(g*D),G=E+_,j=u(u(G*G)-D-V),ue=M+V,le=ue-K,de=M-V,ve=u(j*le),ie=u(ue*de),ke=u(j*de),Qe=u(le*ue);return new p(ve,ie,Qe,ke)}add(g){d(g);let{a:E,d:_}=e,{ex:U,ey:D,ez:V,et:K}=this,{ex:M,ey:G,ez:j,et:ue}=g;if(E===BigInt(-1)){let _o=u((D-U)*(G+M)),To=u((D+U)*(G-M)),qs=u(To-_o);if(qs===Ve)return this.double();let Lo=u(V*In*ue),Co=u(K*In*j),Uo=Co+Lo,Do=To+_o,Oo=Co-Lo,Cu=u(Uo*qs),Uu=u(Do*Oo),Du=u(Uo*Oo),Ou=u(qs*Do);return new p(Cu,Uu,Ou,Du)}let le=u(U*M),de=u(D*G),ve=u(K*_*ue),ie=u(V*j),ke=u((U+D)*(M+G)-le-de),Qe=ie-ve,Tr=ie+ve,Lr=u(de-E*le),Nu=u(ke*Qe),_u=u(Tr*Lr),Tu=u(ke*Lr),Lu=u(Qe*Tr);return new p(Nu,_u,Lu,Tu)}subtract(g){return this.add(g.negate())}wNAF(g){return L.wNAFCached(this,g,p.normalizeZ)}multiply(g){let E=g;Ie("scalar",E,Re,n);let{p:_,f:U}=this.wNAF(E);return p.normalizeZ([_,U])[0]}multiplyUnsafe(g){let E=g;return Ie("scalar",E,Ve,n),E===Ve?C:this.equals(C)||E===Re?this:this.equals(B)?this.wNAF(E).p:L.unsafeLadder(this,E)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return L.unsafeLadder(this,n).is0()}toAffine(g){return y(this,g)}clearCofactor(){let{h:g}=e;return g===Re?this:this.multiplyUnsafe(g)}static fromHex(g,E=!1){let{d:_,a:U}=e,D=t.BYTES;g=ee("pointHex",g,D),Pe("zip215",E);let V=g.slice(),K=g[D-1];V[D-1]=K&-129;let M=St(V),G=E?f:t.ORDER;Ie("pointHex.y",M,Ve,G);let j=u(M*M),ue=u(j-Re),le=u(_*j-U),{isValid:de,value:ve}=h(ue,le);if(!de)throw new Error("Point.fromHex: invalid y coordinate");let ie=(ve&Re)===Re,ke=(K&128)!==0;if(!E&&ve===Ve&&ke)throw new Error("Point.fromHex: x=0 and x_0=1");return ke!==ie&&(ve=u(-ve)),p.fromAffine({x:ve,y:M})}static fromPrivateKey(g){return T(g).point}toRawBytes(){let{x:g,y:E}=this.toAffine(),_=Ht(E,t.BYTES);return _[_.length-1]|=g&Re?128:0,_}toHex(){return it(this.toRawBytes())}}p.BASE=new p(e.Gx,e.Gy,Re,u(e.Gx*e.Gy)),p.ZERO=new p(Ve,Re,Re,Ve);let{BASE:B,ZERO:C}=p,L=Sn(p,a*8);function I(w){return Y(w,n)}function R(w){return I(St(w))}function T(w){let g=a;w=ee("private key",w,g);let E=ee("hashed private key",i(w),2*g),_=b(E.slice(0,g)),U=E.slice(g,2*g),D=R(_),V=B.multiply(D),K=V.toRawBytes();return{head:_,prefix:U,scalar:D,point:V,pointBytes:K}}function ne(w){return T(w).pointBytes}function F(w=new Uint8Array,...g){let E=at(...g);return R(i(v(E,ee("context",w),!!s)))}function P(w,g,E={}){w=ee("message",w),s&&(w=s(w));let{prefix:_,scalar:U,pointBytes:D}=T(g),V=F(E.context,_,w),K=B.multiply(V).toRawBytes(),M=F(E.context,K,D,w),G=I(V+M*U);Ie("signature.s",G,Ve,n);let j=at(K,Ht(G,t.BYTES));return ee("result",j,a*2)}let se=jf;function S(w,g,E,_=se){let{context:U,zip215:D}=_,V=t.BYTES;w=ee("signature",w,2*V),g=ee("message",g),D!==void 0&&Pe("zip215",D),s&&(g=s(g));let K=St(w.slice(V,2*V)),M,G,j;try{M=p.fromHex(E,D),G=p.fromHex(w.slice(0,V),D),j=B.multiplyUnsafe(K)}catch{return!1}if(!D&&M.isSmallOrder())return!1;let ue=F(U,G.toRawBytes(),M.toRawBytes(),g);return G.add(M.multiplyUnsafe(ue)).subtract(j).clearCofactor().equals(p.ZERO)}return B._setWindowSize(8),{CURVE:e,getPublicKey:ne,sign:P,verify:S,ExtendedPoint:p,utils:{getExtendedPublicKey:T,randomPrivateKey:()=>o(t.BYTES),precompute(w=8,g=p.BASE){return g._setWindowSize(w),g.multiply(BigInt(3)),g}}}}var Li=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),Na=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),og=BigInt(0),Wf=BigInt(1),_a=BigInt(2),ag=BigInt(3),Jf=BigInt(5),Xf=BigInt(8);function Qf(r){let e=BigInt(10),t=BigInt(20),n=BigInt(40),s=BigInt(80),i=Li,a=r*r%i*r%i,c=X(a,_a,i)*a%i,f=X(c,Wf,i)*r%i,u=X(f,Jf,i)*f%i,l=X(u,e,i)*u%i,h=X(l,t,i)*l%i,b=X(h,n,i)*h%i,v=X(b,s,i)*b%i,m=X(v,s,i)*b%i,d=X(m,e,i)*u%i;return{pow_p_5_8:X(d,_a,i)*r%i,b2:a}}function eh(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function th(r,e){let t=Li,n=Y(e*e*e,t),s=Y(n*n*e,t),i=Qf(r*s).pow_p_5_8,o=Y(r*n*i,t),a=Y(e*o*o,t),c=o,f=Y(o*Na,t),u=a===r,l=a===Y(-r,t),h=a===Y(-r*Na,t);return u&&(o=c),(l||h)&&(o=f),Aa(o,t)&&(o=Y(-o,t)),{isValid:u||l,value:o}}var rh=It(Li,void 0,!0),nh={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:rh,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:Xf,Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:qr,randomBytes:mr,adjustScalarBytes:eh,uvRatio:th},wr=Ra(nh);var xr=32,ct=64,Rn=32;function Ta(){let r=wr.utils.randomPrivateKey(),e=wr.getPublicKey(r);return{privateKey:Da(r,e),publicKey:e}}function La(r){if(r.length!==Rn)throw new TypeError('"seed" must be 32 bytes in length.');if(!(r instanceof Uint8Array))throw new TypeError('"seed" must be a node.js Buffer, or Uint8Array.');let e=r,t=wr.getPublicKey(e);return{privateKey:Da(e,t),publicKey:t}}function Ca(r,e){let t=r.subarray(0,Rn);return wr.sign(e instanceof Uint8Array?e:e.subarray(),t)}function Ua(r,e,t){return wr.verify(e,t instanceof Uint8Array?t:t.subarray(),r)}function Da(r,e){let t=new Uint8Array(ct);for(let n=0;n<Rn;n++)t[n]=r[n],t[Rn+n]=e[n];return t}var Ci={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function Nn(r){let e=r?.algorithm??"AES-GCM",t=r?.keyLength??16,n=r?.nonceLength??12,s=r?.digest??"SHA-256",i=r?.saltLength??16,o=r?.iterations??32767,a=W.get();t*=8;async function c(l,h){let b=a.getRandomValues(new Uint8Array(i)),v=a.getRandomValues(new Uint8Array(n)),m={name:e,iv:v};typeof h=="string"&&(h=q(h));let d;if(h.length===0){d=await a.subtle.importKey("jwk",Ci,{name:"AES-GCM"},!0,["encrypt"]);try{let x={name:"PBKDF2",salt:b,iterations:o,hash:{name:s}},p=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);d=await a.subtle.deriveKey(x,p,{name:e,length:t},!0,["encrypt"])}catch{d=await a.subtle.importKey("jwk",Ci,{name:"AES-GCM"},!0,["encrypt"])}}else{let x={name:"PBKDF2",salt:b,iterations:o,hash:{name:s}},p=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);d=await a.subtle.deriveKey(x,p,{name:e,length:t},!0,["encrypt"])}let y=await a.subtle.encrypt(m,d,l);return Be([b,m.iv,new Uint8Array(y)])}async function f(l,h){let b=l.subarray(0,i),v=l.subarray(i,i+n),m=l.subarray(i+n),d={name:e,iv:v};typeof h=="string"&&(h=q(h));let y;if(h.length===0)try{let p={name:"PBKDF2",salt:b,iterations:o,hash:{name:s}},B=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);y=await a.subtle.deriveKey(p,B,{name:e,length:t},!0,["decrypt"])}catch{y=await a.subtle.importKey("jwk",Ci,{name:"AES-GCM"},!0,["decrypt"])}else{let p={name:"PBKDF2",salt:b,iterations:o,hash:{name:s}},B=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);y=await a.subtle.deriveKey(p,B,{name:e,length:t},!0,["decrypt"])}let x=await a.subtle.decrypt(d,y,m);return new Uint8Array(x)}return{encrypt:c,decrypt:f}}async function vr(r,e){let n=await Nn().encrypt(r,e);return Ur.encode(n)}var Br={};te(Br,{KeyType:()=>Z,PrivateKey:()=>Fe,PublicKey:()=>Ke});var ih=Math.pow(2,7),oh=Math.pow(2,14),ah=Math.pow(2,21),Ui=Math.pow(2,28),Di=Math.pow(2,35),Oi=Math.pow(2,42),Pi=Math.pow(2,49),$=128,ye=127;function Me(r){if(r<ih)return 1;if(r<oh)return 2;if(r<ah)return 3;if(r<Ui)return 4;if(r<Di)return 5;if(r<Oi)return 6;if(r<Pi)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function Vi(r,e,t=0){switch(Me(r)){case 8:e[t++]=r&255|$,r/=128;case 7:e[t++]=r&255|$,r/=128;case 6:e[t++]=r&255|$,r/=128;case 5:e[t++]=r&255|$,r/=128;case 4:e[t++]=r&255|$,r>>>=7;case 3:e[t++]=r&255|$,r>>>=7;case 2:e[t++]=r&255|$,r>>>=7;case 1:{e[t++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return e}function ch(r,e,t=0){switch(Me(r)){case 8:e.set(t++,r&255|$),r/=128;case 7:e.set(t++,r&255|$),r/=128;case 6:e.set(t++,r&255|$),r/=128;case 5:e.set(t++,r&255|$),r/=128;case 4:e.set(t++,r&255|$),r>>>=7;case 3:e.set(t++,r&255|$),r>>>=7;case 2:e.set(t++,r&255|$),r>>>=7;case 1:{e.set(t++,r&255),r>>>=7;break}default:throw new Error("unreachable")}return e}function Mi(r,e){let t=r[e],n=0;if(n+=t&ye,t<$||(t=r[e+1],n+=(t&ye)<<7,t<$)||(t=r[e+2],n+=(t&ye)<<14,t<$)||(t=r[e+3],n+=(t&ye)<<21,t<$)||(t=r[e+4],n+=(t&ye)*Ui,t<$)||(t=r[e+5],n+=(t&ye)*Di,t<$)||(t=r[e+6],n+=(t&ye)*Oi,t<$)||(t=r[e+7],n+=(t&ye)*Pi,t<$))return n;throw new RangeError("Could not decode varint")}function uh(r,e){let t=r.get(e),n=0;if(n+=t&ye,t<$||(t=r.get(e+1),n+=(t&ye)<<7,t<$)||(t=r.get(e+2),n+=(t&ye)<<14,t<$)||(t=r.get(e+3),n+=(t&ye)<<21,t<$)||(t=r.get(e+4),n+=(t&ye)*Ui,t<$)||(t=r.get(e+5),n+=(t&ye)*Di,t<$)||(t=r.get(e+6),n+=(t&ye)*Oi,t<$)||(t=r.get(e+7),n+=(t&ye)*Pi,t<$))return n;throw new RangeError("Could not decode varint")}function Pa(r,e,t=0){return e==null&&(e=me(Me(r))),e instanceof Uint8Array?Vi(r,e,t):ch(r,e,t)}function Va(r,e=0){return r instanceof Uint8Array?Mi(r,e):uh(r,e)}var Hi=new Float32Array([-0]),Rt=new Uint8Array(Hi.buffer);function Ha(r,e,t){Hi[0]=r,e[t]=Rt[0],e[t+1]=Rt[1],e[t+2]=Rt[2],e[t+3]=Rt[3]}function Ka(r,e){return Rt[0]=r[e],Rt[1]=r[e+1],Rt[2]=r[e+2],Rt[3]=r[e+3],Hi[0]}var Ki=new Float64Array([-0]),be=new Uint8Array(Ki.buffer);function Fa(r,e,t){Ki[0]=r,e[t]=be[0],e[t+1]=be[1],e[t+2]=be[2],e[t+3]=be[3],e[t+4]=be[4],e[t+5]=be[5],e[t+6]=be[6],e[t+7]=be[7]}function qa(r,e){return be[0]=r[e],be[1]=r[e+1],be[2]=r[e+2],be[3]=r[e+3],be[4]=r[e+4],be[5]=r[e+5],be[6]=r[e+6],be[7]=r[e+7],Ki[0]}var lh=BigInt(Number.MAX_SAFE_INTEGER),fh=BigInt(Number.MIN_SAFE_INTEGER),Ce=class r{lo;hi;constructor(e,t){this.lo=e|0,this.hi=t|0}toNumber(e=!1){if(!e&&this.hi>>>31>0){let t=~this.lo+1>>>0,n=~this.hi>>>0;return t===0&&(n=n+1>>>0),-(t+n*4294967296)}return this.lo+this.hi*4294967296}toBigInt(e=!1){if(e)return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n);if(this.hi>>>31){let t=~this.lo+1>>>0,n=~this.hi>>>0;return t===0&&(n=n+1>>>0),-(BigInt(t)+(BigInt(n)<<32n))}return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n)}toString(e=!1){return this.toBigInt(e).toString()}zzEncode(){let e=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^e)>>>0,this.lo=(this.lo<<1^e)>>>0,this}zzDecode(){let e=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^e)>>>0,this.hi=(this.hi>>>1^e)>>>0,this}length(){let e=this.lo,t=(this.lo>>>28|this.hi<<4)>>>0,n=this.hi>>>24;return n===0?t===0?e<16384?e<128?1:2:e<2097152?3:4:t<16384?t<128?5:6:t<2097152?7:8:n<128?9:10}static fromBigInt(e){if(e===0n)return qt;if(e<lh&&e>fh)return this.fromNumber(Number(e));let t=e<0n;t&&(e=-e);let n=e>>32n,s=e-(n<<32n);return t&&(n=~n|0n,s=~s|0n,++s>$a&&(s=0n,++n>$a&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(e){if(e===0)return qt;let t=e<0;t&&(e=-e);let n=e>>>0,s=(e-n)/4294967296>>>0;return t&&(s=~s>>>0,n=~n>>>0,++n>4294967295&&(n=0,++s>4294967295&&(s=0))),new r(n,s)}static from(e){return typeof e=="number"?r.fromNumber(e):typeof e=="bigint"?r.fromBigInt(e):typeof e=="string"?r.fromBigInt(BigInt(e)):e.low!=null||e.high!=null?new r(e.low>>>0,e.high>>>0):qt}},qt=new Ce(0,0);qt.toBigInt=function(){return 0n};qt.zzEncode=qt.zzDecode=function(){return this};qt.length=function(){return 1};var $a=4294967296n;function Ga(r){let e=0,t=0;for(let n=0;n<r.length;++n)t=r.charCodeAt(n),t<128?e+=1:t<2048?e+=2:(t&64512)===55296&&(r.charCodeAt(n+1)&64512)===56320?(++n,e+=4):e+=3;return e}function za(r,e,t){if(t-e<1)return"";let s,i=[],o=0,a;for(;e<t;)a=r[e++],a<128?i[o++]=a:a>191&&a<224?i[o++]=(a&31)<<6|r[e++]&63:a>239&&a<365?(a=((a&7)<<18|(r[e++]&63)<<12|(r[e++]&63)<<6|r[e++]&63)-65536,i[o++]=55296+(a>>10),i[o++]=56320+(a&1023)):i[o++]=(a&15)<<12|(r[e++]&63)<<6|r[e++]&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 Fi(r,e,t){let n=t,s,i;for(let o=0;o<r.length;++o)s=r.charCodeAt(o),s<128?e[t++]=s:s<2048?(e[t++]=s>>6|192,e[t++]=s&63|128):(s&64512)===55296&&((i=r.charCodeAt(o+1))&64512)===56320?(s=65536+((s&1023)<<10)+(i&1023),++o,e[t++]=s>>18|240,e[t++]=s>>12&63|128,e[t++]=s>>6&63|128,e[t++]=s&63|128):(e[t++]=s>>12|224,e[t++]=s>>6&63|128,e[t++]=s&63|128);return t-n}function He(r,e){return RangeError(`index out of range: ${r.pos} + ${e??1} > ${r.len}`)}function _n(r,e){return(r[e-4]|r[e-3]<<8|r[e-2]<<16|r[e-1]<<24)>>>0}var qi=class{buf;pos;len;_slice=Uint8Array.prototype.subarray;constructor(e){this.buf=e,this.pos=0,this.len=e.length}uint32(){let e=4294967295;if(e=(this.buf[this.pos]&127)>>>0,this.buf[this.pos++]<128||(e=(e|(this.buf[this.pos]&127)<<7)>>>0,this.buf[this.pos++]<128)||(e=(e|(this.buf[this.pos]&127)<<14)>>>0,this.buf[this.pos++]<128)||(e=(e|(this.buf[this.pos]&127)<<21)>>>0,this.buf[this.pos++]<128)||(e=(e|(this.buf[this.pos]&15)<<28)>>>0,this.buf[this.pos++]<128))return e;if((this.pos+=5)>this.len)throw this.pos=this.len,He(this,10);return e}int32(){return this.uint32()|0}sint32(){let e=this.uint32();return e>>>1^-(e&1)|0}bool(){return this.uint32()!==0}fixed32(){if(this.pos+4>this.len)throw He(this,4);return _n(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw He(this,4);return _n(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw He(this,4);let e=Ka(this.buf,this.pos);return this.pos+=4,e}double(){if(this.pos+8>this.len)throw He(this,4);let e=qa(this.buf,this.pos);return this.pos+=8,e}bytes(){let e=this.uint32(),t=this.pos,n=this.pos+e;if(n>this.len)throw He(this,e);return this.pos+=e,t===n?new Uint8Array(0):this.buf.subarray(t,n)}string(){let e=this.bytes();return za(e,0,e.length)}skip(e){if(typeof e=="number"){if(this.pos+e>this.len)throw He(this,e);this.pos+=e}else do if(this.pos>=this.len)throw He(this);while(this.buf[this.pos++]&128);return this}skipType(e){switch(e){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;(e=this.uint32()&7)!==4;)this.skipType(e);break;case 5:this.skip(4);break;default:throw Error(`invalid wire type ${e} at offset ${this.pos}`)}return this}readLongVarint(){let e=new Ce(0,0),t=0;if(this.len-this.pos>4){for(;t<4;++t)if(e.lo=(e.lo|(this.buf[this.pos]&127)<<t*7)>>>0,this.buf[this.pos++]<128)return e;if(e.lo=(e.lo|(this.buf[this.pos]&127)<<28)>>>0,e.hi=(e.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return e;t=0}else{for(;t<3;++t){if(this.pos>=this.len)throw He(this);if(e.lo=(e.lo|(this.buf[this.pos]&127)<<t*7)>>>0,this.buf[this.pos++]<128)return e}return e.lo=(e.lo|(this.buf[this.pos++]&127)<<t*7)>>>0,e}if(this.len-this.pos>4){for(;t<5;++t)if(e.hi=(e.hi|(this.buf[this.pos]&127)<<t*7+3)>>>0,this.buf[this.pos++]<128)return e}else for(;t<5;++t){if(this.pos>=this.len)throw He(this);if(e.hi=(e.hi|(this.buf[this.pos]&127)<<t*7+3)>>>0,this.buf[this.pos++]<128)return e}throw Error("invalid varint encoding")}readFixed64(){if(this.pos+8>this.len)throw He(this,8);let e=_n(this.buf,this.pos+=4),t=_n(this.buf,this.pos+=4);return new Ce(e,t)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){let e=Mi(this.buf,this.pos);return this.pos+=Me(e),e}uint64String(){return this.readLongVarint().toString(!0)}sint64(){return this.readLongVarint().zzDecode().toBigInt()}sint64Number(){return this.readLongVarint().zzDecode().toNumber()}sint64String(){return this.readLongVarint().zzDecode().toString()}fixed64(){return this.readFixed64().toBigInt()}fixed64Number(){return this.readFixed64().toNumber()}fixed64String(){return this.readFixed64().toString()}sfixed64(){return this.readFixed64().toBigInt()}sfixed64Number(){return this.readFixed64().toNumber()}sfixed64String(){return this.readFixed64().toString()}};function $i(r){return new qi(r instanceof Uint8Array?r:r.subarray())}function Ne(r,e,t){let n=$i(r);return e.decode(n,void 0,t)}function Gi(r){let e=r??8192,t=e>>>1,n,s=e;return function(o){if(o<1||o>t)return me(o);s+o>e&&(n=me(e),s=0);let a=n.subarray(s,s+=o);return s&7&&(s=(s|7)+1),a}}var $t=class{fn;len;next;val;constructor(e,t,n){this.fn=e,this.len=t,this.next=void 0,this.val=n}};function zi(){}var ji=class{head;tail;len;next;constructor(e){this.head=e.head,this.tail=e.tail,this.len=e.len,this.next=e.states}},hh=Gi();function dh(r){return globalThis.Buffer!=null?me(r):hh(r)}var jr=class{len;head;tail;states;constructor(){this.len=0,this.head=new $t(zi,0,0),this.tail=this.head,this.states=null}_push(e,t,n){return this.tail=this.tail.next=new $t(e,t,n),this.len+=t,this}uint32(e){return this.len+=(this.tail=this.tail.next=new Zi((e=e>>>0)<128?1:e<16384?2:e<2097152?3:e<268435456?4:5,e)).len,this}int32(e){return e<0?this._push(Tn,10,Ce.fromNumber(e)):this.uint32(e)}sint32(e){return this.uint32((e<<1^e>>31)>>>0)}uint64(e){let t=Ce.fromBigInt(e);return this._push(Tn,t.length(),t)}uint64Number(e){return this._push(Vi,Me(e),e)}uint64String(e){return this.uint64(BigInt(e))}int64(e){return this.uint64(e)}int64Number(e){return this.uint64Number(e)}int64String(e){return this.uint64String(e)}sint64(e){let t=Ce.fromBigInt(e).zzEncode();return this._push(Tn,t.length(),t)}sint64Number(e){let t=Ce.fromNumber(e).zzEncode();return this._push(Tn,t.length(),t)}sint64String(e){return this.sint64(BigInt(e))}bool(e){return this._push(Yi,1,e?1:0)}fixed32(e){return this._push(Yr,4,e>>>0)}sfixed32(e){return this.fixed32(e)}fixed64(e){let t=Ce.fromBigInt(e);return this._push(Yr,4,t.lo)._push(Yr,4,t.hi)}fixed64Number(e){let t=Ce.fromNumber(e);return this._push(Yr,4,t.lo)._push(Yr,4,t.hi)}fixed64String(e){return this.fixed64(BigInt(e))}sfixed64(e){return this.fixed64(e)}sfixed64Number(e){return this.fixed64Number(e)}sfixed64String(e){return this.fixed64String(e)}float(e){return this._push(Ha,4,e)}double(e){return this._push(Fa,8,e)}bytes(e){let t=e.length>>>0;return t===0?this._push(Yi,1,0):this.uint32(t)._push(gh,t,e)}string(e){let t=Ga(e);return t!==0?this.uint32(t)._push(Fi,t,e):this._push(Yi,1,0)}fork(){return this.states=new ji(this),this.head=this.tail=new $t(zi,0,0),this.len=0,this}reset(){return this.states!=null?(this.head=this.states.head,this.tail=this.states.tail,this.len=this.states.len,this.states=this.states.next):(this.head=this.tail=new $t(zi,0,0),this.len=0),this}ldelim(){let e=this.head,t=this.tail,n=this.len;return this.reset().uint32(n),n!==0&&(this.tail.next=e.next,this.tail=t,this.len+=n),this}finish(){let e=this.head.next,t=dh(this.len),n=0;for(;e!=null;)e.fn(e.val,t,n),n+=e.len,e=e.next;return t}};function Yi(r,e,t){e[t]=r&255}function ph(r,e,t){for(;r>127;)e[t++]=r&127|128,r>>>=7;e[t]=r}var Zi=class extends $t{next;constructor(e,t){super(ph,e,t),this.next=void 0}};function Tn(r,e,t){for(;r.hi!==0;)e[t++]=r.lo&127|128,r.lo=(r.lo>>>7|r.hi<<25)>>>0,r.hi>>>=7;for(;r.lo>127;)e[t++]=r.lo&127|128,r.lo=r.lo>>>7;e[t++]=r.lo}function Yr(r,e,t){e[t]=r&255,e[t+1]=r>>>8&255,e[t+2]=r>>>16&255,e[t+3]=r>>>24}function gh(r,e,t){e.set(r,t)}globalThis.Buffer!=null&&(jr.prototype.bytes=function(r){let e=r.length>>>0;return this.uint32(e),e>0&&this._push(mh,e,r),this},jr.prototype.string=function(r){let e=globalThis.Buffer.byteLength(r);return this.uint32(e),e>0&&this._push(yh,e,r),this});function mh(r,e,t){e.set(r,t)}function yh(r,e,t){r.length<40?Fi(r,e,t):e.utf8Write!=null?e.utf8Write(r,t):e.set(q(r),t)}function Wi(){return new jr}function _e(r,e){let t=Wi();return e.encode(r,t,{lengthDelimited:!1}),t.finish()}var Er;(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"})(Er||(Er={}));function Ln(r,e,t,n){return{name:r,type:e,encode:t,decode:n}}function Ji(r){function e(s){if(r[s.toString()]==null)throw new Error("Invalid enum value");return r[s]}let t=function(i,o){let a=e(i);o.int32(a)},n=function(i){let o=i.int32();return e(o)};return Ln("enum",Er.VARINT,t,n)}function Te(r,e){return Ln("message",Er.LENGTH_DELIMITED,r,e)}var Z;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.Secp256k1="Secp256k1"})(Z||(Z={}));var Xi;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.Secp256k1=2]="Secp256k1"})(Xi||(Xi={}));(function(r){r.codec=()=>Ji(Xi)})(Z||(Z={}));var Ke;(function(r){let e;r.codec=()=>(e==null&&(e=Te((t,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),t.Type!=null&&(n.uint32(8),Z.codec().encode(t.Type,n)),t.Data!=null&&(n.uint32(18),n.bytes(t.Data)),s.lengthDelimited!==!1&&n.ldelim()},(t,n)=>{let s={},i=n==null?t.len:t.pos+n;for(;t.pos<i;){let o=t.uint32();switch(o>>>3){case 1:s.Type=Z.codec().decode(t);break;case 2:s.Data=t.bytes();break;default:t.skipType(o&7);break}}return s})),e),r.encode=t=>_e(t,r.codec()),r.decode=t=>Ne(t,r.codec())})(Ke||(Ke={}));var Fe;(function(r){let e;r.codec=()=>(e==null&&(e=Te((t,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),t.Type!=null&&(n.uint32(8),Z.codec().encode(t.Type,n)),t.Data!=null&&(n.uint32(18),n.bytes(t.Data)),s.lengthDelimited!==!1&&n.ldelim()},(t,n)=>{let s={},i=n==null?t.len:t.pos+n;for(;t.pos<i;){let o=t.uint32();switch(o>>>3){case 1:s.Type=Z.codec().decode(t);break;case 2:s.Data=t.bytes();break;default:t.skipType(o&7);break}}return s})),e),r.encode=t=>_e(t,r.codec()),r.decode=t=>Ne(t,r.codec())})(Fe||(Fe={}));var Gt=class{_key;constructor(e){this._key=Ar(e,xr)}verify(e,t){return Ua(this._key,t,e)}marshal(){return this._key}get bytes(){return Ke.encode({Type:Z.Ed25519,Data:this.marshal()}).subarray()}equals(e){return ge(this.bytes,e.bytes)}hash(){let e=oe.digest(this.bytes);return Ue(e)?e.then(({bytes:t})=>t):e.bytes}},ut=class{_key;_publicKey;constructor(e,t){this._key=Ar(e,ct),this._publicKey=Ar(t,xr)}sign(e){return Ca(this._key,e)}get public(){return new Gt(this._publicKey)}marshal(){return this._key}get bytes(){return Fe.encode({Type:Z.Ed25519,Data:this.marshal()}).subarray()}equals(e){return ge(this.bytes,e.bytes)}async hash(){let e=oe.digest(this.bytes),t;return Ue(e)?{bytes:t}=await e:t=e.bytes,t}async id(){let e=tt.digest(this.public.bytes);return Ee.encode(e.bytes).substring(1)}async export(e,t="libp2p-key"){if(t==="libp2p-key")return vr(this.bytes,e);throw new A(`export format '${t}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function bh(r){if(r.length>ct){r=Ar(r,ct+xr);let n=r.subarray(0,ct),s=r.subarray(ct,r.length);return new ut(n,s)}r=Ar(r,ct);let e=r.subarray(0,ct),t=r.subarray(xr);return new ut(e,t)}function wh(r){return r=Ar(r,xr),new Gt(r)}async function xh(){let{privateKey:r,publicKey:e}=Ta();return new ut(r,e)}async function Qi(r){let{privateKey:e,publicKey:t}=La(r);return new ut(e,t)}function Ar(r,e){if(r=Uint8Array.from(r??[]),r.length!==e)throw new A(`Key must be a Uint8Array of length ${e}, got ${r.length}`,"ERR_INVALID_KEY_TYPE");return r}var ja={"P-256":256,"P-384":384,"P-521":521},vh=Object.keys(ja),to=vh.join(" / ");async function Za(r){if(r!=="P-256"&&r!=="P-384"&&r!=="P-521")throw new A(`Unknown curve: ${r}. Must be ${to}`,"ERR_INVALID_CURVE");let e=await W.get().subtle.generateKey({name:"ECDH",namedCurve:r},!0,["deriveBits"]),t=async(i,o)=>{let a;o!=null?a=await W.get().subtle.importKey("jwk",Bh(r,o),{name:"ECDH",namedCurve:r},!1,["deriveBits"]):a=e.privateKey;let c=await W.get().subtle.importKey("jwk",Ja(r,i),{name:"ECDH",namedCurve:r},!1,[]),f=await W.get().subtle.deriveBits({name:"ECDH",namedCurve:r,public:c},a,ja[r]);return new Uint8Array(f,0,f.byteLength)},n=await W.get().subtle.exportKey("jwk",e.publicKey);return{key:Eh(n),genSharedKey:t}}var Wa={"P-256":32,"P-384":48,"P-521":66};function Eh(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 ${to}`,"ERR_INVALID_CURVE");let e=Wa[r.crv];return Be([Uint8Array.from([4]),mi(r.x,e),mi(r.y,e)],1+e*2)}function Ja(r,e){if(r!=="P-256"&&r!=="P-384"&&r!=="P-521")throw new A(`Unknown curve: ${r}. Must be ${to}`,"ERR_INVALID_CURVE");let t=Wa[r];if(!ge(e.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(e.subarray(1,t+1),"base64url"),y:z(e.subarray(1+t),"base64url"),ext:!0}}var Bh=(r,e)=>({...Ja(r,e.public),d:z(e.private,"base64url")});var Xa=Za;async function Qa(r,e){let t=Ur.decode(r);return Nn().decrypt(t,e)}var ec={"AES-128":{ivSize:16,keySize:16},"AES-256":{ivSize:16,keySize:32},Blowfish:{ivSize:8,keySize:32}};async function tc(r,e,t){let n=ec[r];if(n==null){let x=Object.keys(ec).join(" / ");throw new A(`unknown cipher type '${r}'. Must be ${x}`,"ERR_INVALID_CIPHER_TYPE")}if(e==null)throw new A("missing hash type","ERR_MISSING_HASH_TYPE");let s=n.keySize,i=n.ivSize,o=20,a=q("key expansion"),c=2*(i+s+o),f=await ha(e,t),u=await f.digest(a),l=[],h=0;for(;h<c;){let x=await f.digest(Be([u,a])),p=x.length;h+p>c&&(p=c-h),l.push(x),h+=p,u=await f.digest(u)}let b=c/2,v=Be(l),m=v.subarray(0,b),d=v.subarray(b,c),y=x=>({iv:x.subarray(0,i),cipherKey:x.subarray(i,i+s),macKey:x.subarray(i+s)});return{k1:y(m),k2:y(d)}}var ho={};te(ho,{MAX_RSA_KEY_SIZE:()=>jt,RsaPrivateKey:()=>Ct,RsaPublicKey:()=>Yt,fromJwk:()=>Zh,generateKeyPair:()=>Wh,unmarshalRsaPrivateKey:()=>lo,unmarshalRsaPublicKey:()=>jh});function Ze(r){if(isNaN(r)||r<=0)throw new A("random bytes length must be a Number bigger than 0","ERR_INVALID_LENGTH");return mr(r)}var Lt={};te(Lt,{exportToPem:()=>$h,importFromPem:()=>uo,jwkToPkcs1:()=>Hh,jwkToPkix:()=>Fh,pkcs1ToJwk:()=>Mh,pkixToJwk:()=>Kh});var Cn=class extends pr{constructor(e,t){super(),this.finished=!1,this.destroyed=!1,wn(e);let n=vt(t);if(this.iHash=e.create(),typeof this.iHash.update!="function")throw new Error("Expected instance of class which extends utils.Hash");this.blockLen=this.iHash.blockLen,this.outputLen=this.iHash.outputLen;let s=this.blockLen,i=new Uint8Array(s);i.set(n.length>s?e.create().update(n).digest():n);for(let o=0;o<i.length;o++)i[o]^=54;this.iHash.update(i),this.oHash=e.create();for(let o=0;o<i.length;o++)i[o]^=106;this.oHash.update(i),i.fill(0)}update(e){return dr(this),this.iHash.update(e),this}digestInto(e){dr(this),hr(e,this.outputLen),this.finished=!0,this.iHash.digestInto(e),this.oHash.update(e),this.oHash.digestInto(e),this.destroy()}digest(){let e=new Uint8Array(this.oHash.outputLen);return this.digestInto(e),e}_cloneInto(e){e||(e=Object.create(Object.getPrototypeOf(this),{}));let{oHash:t,iHash:n,finished:s,destroyed:i,blockLen:o,outputLen:a}=this;return e=e,e.finished=s,e.destroyed=i,e.blockLen=o,e.outputLen=a,e.oHash=t._cloneInto(e.oHash),e.iHash=n._cloneInto(e.iHash),e}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},Zr=(r,e,t)=>new Cn(r,e).update(t).digest();Zr.create=(r,e)=>new Cn(r,e);function Ah(r,e,t,n){wn(r);let s=ma({dkLen:32,asyncTick:10},n),{c:i,dkLen:o,asyncTick:a}=s;if(fr(i),fr(o),fr(a),i<1)throw new Error("PBKDF2: iterations (c) should be >= 1");let c=vt(e),f=vt(t),u=new Uint8Array(o),l=Zr.create(r,c),h=l._cloneInto().update(f);return{c:i,dkLen:o,asyncTick:a,DK:u,PRF:l,PRFSalt:h}}function Sh(r,e,t,n,s){return r.destroy(),e.destroy(),n&&n.destroy(),s.fill(0),t}async function ro(r,e,t,n){let{c:s,dkLen:i,asyncTick:o,DK:a,PRF:c,PRFSalt:f}=Ah(r,e,t,n),u,l=new Uint8Array(4),h=gr(l),b=new Uint8Array(c.outputLen);for(let v=1,m=0;m<i;v++,m+=c.outputLen){let d=a.subarray(m,m+c.outputLen);h.setInt32(0,v,!1),(u=f._cloneInto(u)).update(l).digestInto(b),d.set(b.subarray(0,d.length)),await pa(s-1,o,()=>{c._cloneInto(u).update(b).digestInto(b);for(let y=0;y<d.length;y++)d[y]^=b[y]})}return Sh(c,f,a,u,b)}var H=Mo(rc());function zt(r,e){let t=0;if(r.length===1)return r[0];for(let n=r.length-1;n>=0;n--)t+=r[r.length-1-n]*Math.pow(2,e*n);return t}function Nt(r,e,t=-1){let n=t,s=r,i=0,o=Math.pow(2,e);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 u=a-1;u>=0;u--){let l=Math.pow(2,u*e);f[i-u-1]=Math.floor(s/l),s-=f[i-u-1]*l}return c}o*=Math.pow(2,e)}return new ArrayBuffer(0)}function On(...r){let e=0,t=0;for(let i of r)e+=i.length;let n=new ArrayBuffer(e),s=new Uint8Array(n);for(let i of r)s.set(i,t),t+=i.length;return s}function so(){let r=new Uint8Array(this.valueHex);if(this.valueHex.byteLength>=2){let a=r[0]===255&&r[1]&128,c=r[0]===0&&(r[1]&128)===0;(a||c)&&this.warnings.push("Needlessly long format")}let e=new ArrayBuffer(this.valueHex.byteLength),t=new Uint8Array(e);for(let a=0;a<this.valueHex.byteLength;a++)t[a]=0;t[0]=r[0]&128;let n=zt(t,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,zt(i,8)-n}function nc(r){let e=r<0?r*-1:r,t=128;for(let n=1;n<8;n++){if(e<=t){if(r<0){let o=t-e,a=Nt(o,8,n),c=new Uint8Array(a);return c[0]|=128,a}let s=Nt(e,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}t*=Math.pow(2,8)}return new ArrayBuffer(0)}function sc(r,e){if(r.byteLength!==e.byteLength)return!1;let t=new Uint8Array(r),n=new Uint8Array(e);for(let s=0;s<t.length;s++)if(t[s]!==n[s])return!1;return!0}function Le(r,e){let t=r.toString(10);if(e<t.length)return"";let n=e-t.length,s=new Array(n);for(let o=0;o<n;o++)s[o]="0";return s.join("").concat(t)}var Im=Math.log(2);function Pn(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function io(r){let e=0,t=0;for(let s=0;s<r.length;s++){let i=r[s];e+=i.byteLength}let n=new Uint8Array(e);for(let s=0;s<r.length;s++){let i=r[s];n.set(new Uint8Array(i),t),t+=i.byteLength}return n.buffer}function pt(r,e,t,n){return e instanceof Uint8Array?e.byteLength?t<0?(r.error="Wrong parameter: inputOffset less than zero",!1):n<0?(r.error="Wrong parameter: inputLength less than zero",!1):e.byteLength-t-n<0?(r.error="End of input reached before message was fully decoded (inconsistent offset and length values)",!1):!0:(r.error="Wrong parameter: inputBuffer has zero length",!1):(r.error="Wrong parameter: inputBuffer must be 'Uint8Array'",!1)}var Jr=class{constructor(){this.items=[]}write(e){this.items.push(e)}final(){return io(this.items)}},Wr=[new Uint8Array([1])],ic="0123456789";var Ir="",$e=new ArrayBuffer(0),oo=new Uint8Array(0),Xr="EndOfContent",ac="OCTET STRING",cc="BIT STRING";function gt(r){var e;return e=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?H.BufferSourceConverter.toUint8Array(i.valueHex):oo}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(!pt(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",$e)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:H.Convert.ToHex(this.valueHexView)}}},e.NAME="hexBlock",e}var ft=class{constructor({blockLength:e=0,error:t=Ir,warnings:n=[],valueBeforeDecode:s=oo}={}){this.blockLength=e,this.error=t,this.warnings=n,this.valueBeforeDecodeView=H.BufferSourceConverter.toUint8Array(s)}static blockName(){return this.NAME}get valueBeforeDecode(){return this.valueBeforeDecodeView.slice().buffer}set valueBeforeDecode(e){this.valueBeforeDecodeView=new Uint8Array(e)}toJSON(){return{blockName:this.constructor.NAME,blockLength:this.blockLength,error:this.error,warnings:this.warnings,valueBeforeDecode:H.Convert.ToHex(this.valueBeforeDecodeView)}}};ft.NAME="baseBlock";var we=class extends ft{fromBER(e,t,n){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}toBER(e,t){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}};we.NAME="valueBlock";var Vn=class extends gt(ft){constructor({idBlock:e={}}={}){var t,n,s,i;super(),e?(this.isHexOnly=(t=e.isHexOnly)!==null&&t!==void 0?t:!1,this.valueHexView=e.valueHex?H.BufferSourceConverter.toUint8Array(e.valueHex):oo,this.tagClass=(n=e.tagClass)!==null&&n!==void 0?n:-1,this.tagNumber=(s=e.tagNumber)!==null&&s!==void 0?s:-1,this.isConstructed=(i=e.isConstructed)!==null&&i!==void 0?i:!1):(this.tagClass=-1,this.tagNumber=-1,this.isConstructed=!1)}toBER(e=!1){let t=0;switch(this.tagClass){case 1:t|=0;break;case 2:t|=64;break;case 3:t|=128;break;case 4:t|=192;break;default:return this.error="Unknown tag class",$e}if(this.isConstructed&&(t|=32),this.tagNumber<31&&!this.isHexOnly){let s=new Uint8Array(1);if(!e){let i=this.tagNumber;i&=31,t|=i,s[0]=t}return s.buffer}if(!this.isHexOnly){let s=Nt(this.tagNumber,7),i=new Uint8Array(s),o=s.byteLength,a=new Uint8Array(o+1);if(a[0]=t|31,!e){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]=t|31,!e){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(e,t,n){let s=H.BufferSourceConverter.toUint8Array(e);if(!pt(this,s,t,n))return-1;let i=s.subarray(t,t+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),u=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===u){u+=255;let h=new Uint8Array(u);for(let b=0;b<f.length;b++)h[b]=f[b];f=this.valueHexView=new Uint8Array(u)}}this.blockLength=c+1,f[c-1]=i[c]&127;let l=new Uint8Array(c);for(let h=0;h<c;h++)l[h]=f[h];f=this.valueHexView=new Uint8Array(c),f.set(l),this.blockLength<=9?this.tagNumber=zt(f,7):(this.isHexOnly=!0,this.warnings.push("Tag too long, represented as hex-coded"))}if(this.tagClass===1&&this.isConstructed)switch(this.tagNumber){case 1:case 2:case 5:case 6:case 9:case 13:case 14:case 23:case 24:case 31:case 32:case 33:case 34:return this.error="Constructed encoding used for primitive type",-1}return t+this.blockLength}toJSON(){return{...super.toJSON(),tagClass:this.tagClass,tagNumber:this.tagNumber,isConstructed:this.isConstructed}}};Vn.NAME="identificationBlock";var Mn=class extends ft{constructor({lenBlock:e={}}={}){var t,n,s;super(),this.isIndefiniteForm=(t=e.isIndefiniteForm)!==null&&t!==void 0?t:!1,this.longFormUsed=(n=e.longFormUsed)!==null&&n!==void 0?n:!1,this.length=(s=e.length)!==null&&s!==void 0?s:0}fromBER(e,t,n){let s=H.BufferSourceConverter.toUint8Array(e);if(!pt(this,s,t,n))return-1;let i=s.subarray(t,t+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,t+this.blockLength;if(this.longFormUsed=!!(i[0]&128),this.longFormUsed===!1)return this.length=i[0],this.blockLength=1,t+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=t+1,c=s.subarray(a,a+o);return c[o-1]===0&&this.warnings.push("Needlessly long encoded length"),this.length=zt(c,8),this.longFormUsed&&this.length<=127&&this.warnings.push("Unnecessary usage of long length form"),this.blockLength=o+1,t+this.blockLength}toBER(e=!1){let t,n;if(this.length>127&&(this.longFormUsed=!0),this.isIndefiniteForm)return t=new ArrayBuffer(1),e===!1&&(n=new Uint8Array(t),n[0]=128),t;if(this.longFormUsed){let s=Nt(this.length,8);if(s.byteLength>127)return this.error="Too big length",$e;if(t=new ArrayBuffer(s.byteLength+1),e)return t;let i=new Uint8Array(s);n=new Uint8Array(t),n[0]=s.byteLength|128;for(let o=0;o<s.byteLength;o++)n[o+1]=i[o];return t}return t=new ArrayBuffer(1),e===!1&&(n=new Uint8Array(t),n[0]=this.length),t}toJSON(){return{...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,longFormUsed:this.longFormUsed,length:this.length}}};Mn.NAME="lengthBlock";var k={},pe=class extends ft{constructor({name:e=Ir,optional:t=!1,primitiveSchema:n,...s}={},i){super(s),this.name=e,this.optional=t,n&&(this.primitiveSchema=n),this.idBlock=new Vn(s),this.lenBlock=new Mn(s),this.valueBlock=i?new i(s):new we(s)}fromBER(e,t,n){let s=this.valueBlock.fromBER(e,t,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}toBER(e,t){let n=t||new Jr;t||uc(this);let s=this.idBlock.toBER(e);if(n.write(s),this.lenBlock.isIndefiniteForm)n.write(new Uint8Array([128]).buffer),this.valueBlock.toBER(e,n),n.write(new ArrayBuffer(2));else{let i=this.valueBlock.toBER(e);this.lenBlock.length=i.byteLength;let o=this.lenBlock.toBER(e);n.write(o),n.write(i)}return t?$e:n.final()}toJSON(){let e={...super.toJSON(),idBlock:this.idBlock.toJSON(),lenBlock:this.lenBlock.toJSON(),valueBlock:this.valueBlock.toJSON(),name:this.name,optional:this.optional};return this.primitiveSchema&&(e.primitiveSchema=this.primitiveSchema.toJSON()),e}toString(e="ascii"){return e==="ascii"?this.onAsciiEncoding():H.Convert.ToHex(this.toBER())}onAsciiEncoding(){return`${this.constructor.NAME} : ${H.Convert.ToHex(this.valueBlock.valueBeforeDecodeView)}`}isEqual(e){if(this===e)return!0;if(!(e instanceof this.constructor))return!1;let t=this.toBER(),n=e.toBER();return sc(t,n)}};pe.NAME="BaseBlock";function uc(r){if(r instanceof k.Constructed)for(let e of r.valueBlock.value)uc(e)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var Hn=class extends pe{constructor({value:e=Ir,...t}={},n){super(t,n),e&&this.fromString(e)}getValue(){return this.valueBlock.value}setValue(e){this.valueBlock.value=e}fromBER(e,t,n){let s=this.valueBlock.fromBER(e,t,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.fromBuffer(this.valueBlock.valueHexView),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}onAsciiEncoding(){return`${this.constructor.NAME} : '${this.valueBlock.value}'`}};Hn.NAME="BaseStringBlock";var Kn=class extends gt(we){constructor({isHexOnly:e=!0,...t}={}){super(t),this.isHexOnly=e}};Kn.NAME="PrimitiveValueBlock";var lc,Fn=class extends pe{constructor(e={}){super(e,Kn),this.idBlock.isConstructed=!1}};lc=Fn;k.Primitive=lc;Fn.NAME="PRIMITIVE";function Uh(r,e){if(r instanceof e)return r;let t=new e;return t.idBlock=r.idBlock,t.lenBlock=r.lenBlock,t.warnings=r.warnings,t.valueBeforeDecodeView=r.valueBeforeDecodeView,t}function vs(r,e=0,t=r.length){let n=e,s=new pe({},we),i=new ft;if(!pt(i,r,e,t))return s.error=i.error,{offset:-1,result:s};if(!r.subarray(e,e+t).length)return s.error="Zero buffer length",{offset:-1,result:s};let a=s.idBlock.fromBER(r,e,t);if(s.idBlock.warnings.length&&s.warnings.concat(s.idBlock.warnings),a===-1)return s.error=s.idBlock.error,{offset:-1,result:s};if(e=a,t-=s.idBlock.blockLength,a=s.lenBlock.fromBER(r,e,t),s.lenBlock.warnings.length&&s.warnings.concat(s.lenBlock.warnings),a===-1)return s.error=s.lenBlock.error,{offset:-1,result:s};if(e=a,t-=s.lenBlock.blockLength,!s.idBlock.isConstructed&&s.lenBlock.isIndefiniteForm)return s.error="Indefinite length form used for primitive encoding form",{offset:-1,result:s};let c=pe;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=Uh(s,c),a=s.fromBER(r,e,s.lenBlock.isIndefiniteForm?t:s.lenBlock.length),s.valueBeforeDecodeView=r.subarray(n,n+s.blockLength),{offset:a,result:s}}function Rr(r){if(!r.byteLength){let e=new pe({},we);return e.error="Input buffer has zero length",{offset:-1,result:e}}return vs(H.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function Dh(r,e){return r?1:e}var We=class extends we{constructor({value:e=[],isIndefiniteForm:t=!1,...n}={}){super(n),this.value=e,this.isIndefiniteForm=t}fromBER(e,t,n){let s=H.BufferSourceConverter.toUint8Array(e);if(!pt(this,s,t,n))return-1;if(this.valueBeforeDecodeView=s.subarray(t,t+n),this.valueBeforeDecodeView.length===0)return this.warnings.push("Zero buffer length"),t;let i=t;for(;Dh(this.isIndefiniteForm,n)>0;){let o=vs(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===Xr)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===Xr?this.value.pop():this.warnings.push("No EndOfContent block encoded")),i}toBER(e,t){let n=t||new Jr;for(let s=0;s<this.value.length;s++)this.value[s].toBER(e,n);return t?$e:n.final()}toJSON(){let e={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let t of this.value)e.value.push(t.toJSON());return e}};We.NAME="ConstructedValueBlock";var fc,_t=class extends pe{constructor(e={}){super(e,We),this.idBlock.isConstructed=!0}fromBER(e,t,n){this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm;let s=this.valueBlock.fromBER(e,t,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}onAsciiEncoding(){let e=[];for(let n of this.valueBlock.value)e.push(n.toString("ascii").split(`
3
3
  `).map(s=>` ${s}`).join(`
4
- `));let e=this.idBlock.tagClass===3?`[${this.idBlock.tagNumber}]`:this.constructor.NAME;return t.length?`${e} :
5
- ${t.join(`
6
- `)}`:`${e} :`}};uc=ke;S.Constructed=uc;ke.NAME="CONSTRUCTED";var Kn=class extends bt{fromBER(t,e,n){return e}toBER(t){return $t}};Kn.override="EndOfContentValueBlock";var lc,Fn=class extends dt{constructor(t={}){super(t,Kn),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};lc=Fn;S.EndOfContent=lc;Fn.NAME=jr;var fc,Ie=class extends dt{constructor(t={}){super(t,bt),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}`}};fc=Ie;S.Null=fc;Ie.NAME="NULL";var qn=class extends pe(bt){constructor({value:t,...e}={}){super(e),e.valueHex?this.valueHexView=O.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=O.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,eo.call(this),this.blockLength=n,e+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};qn.NAME="BooleanValueBlock";var hc,$n=class extends dt{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}`}};hc=$n;S.Boolean=hc;$n.NAME="BOOLEAN";var Gn=class extends pe(Wt){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=Wt.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!==ic)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?Wt.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 dc,fe=class r extends dt{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?ke.prototype.onAsciiEncoding.call(this):`${this.constructor.NAME} : ${O.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 O.BufferSourceConverter.concat(t)}};dc=fe;S.OctetString=dc;fe.NAME=ic;var zn=class extends pe(Wt){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=Wt.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!==oc)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=O.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 Wt.prototype.toBER.call(this,t,e);if(t)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return $t;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 pc,Br=class extends dt{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 ke.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)}`}}};pc=Br;S.BitString=pc;Br.NAME=oc;var gc;function Uh(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=Un(new Uint8Array([f%10]),i);break;default:i[o-u]=f%10}}return e[0]>0&&(i=Un(e,i)),i}function sc(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 Dh(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 Zr=class extends pe(bt){constructor({value:t,...e}={}){super(e),this._valueDec=0,e.valueHex&&this.setValueHex(),t!==void 0&&(this.valueDec=t)}setValueHex(){this.valueHexView.length>=4?(this.warnings.push("Too big Integer for decoding, hex only"),this.isHexOnly=!0,this._valueDec=0):(this.isHexOnly=!1,this.valueHexView.length>0&&(this._valueDec=eo.call(this)))}set valueDec(t){this._valueDec=t,this.isHexOnly=!1,this.valueHexView=new Uint8Array(ec(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=Dh(sc(n),e),o="-";break;default:e=Uh(e,sc(n))}n++,s>>=1}}for(let c=0;c<e.length;c++)e[c]&&(a=!0),a&&(o+=nc.charAt(e[c]));return a===!1&&(o+=nc.charAt(0)),o}};gc=Zr;Zr.NAME="IntegerValueBlock";Object.defineProperty(gc.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var mc,nt=class r extends dt{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(O.Convert.FromHex(s));if(e<0){let a=new Uint8Array(i.length+(i[0]&128?1:0));a[0]|=128;let f=BigInt(`0x${O.Convert.ToHex(a)}`)+e,l=O.BufferSourceConverter.toUint8Array(O.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()}`}};mc=nt;S.Integer=mc;nt.NAME="INTEGER";var yc,Yn=class extends nt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};yc=Yn;S.Enumerated=yc;Yn.NAME="ENUMERATED";var Wr=class extends pe(bt){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=O.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=Se(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",$t;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=O.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 bt{constructor({value:t=Ar,...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,$t;e.push(s)}return ro(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 bc,qt=class extends dt{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()}}};bc=qt;S.ObjectIdentifier=bc;qt.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=O.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=Se(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",$t;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=O.Convert.ToHex(this.valueHexView):t=this.valueDec.toString(),t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};Jr.NAME="relativeSidBlock";var Zn=class extends bt{constructor({value:t=Ar,...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,$t;n.push(i)}return ro(n)}fromString(t){this.value=[];let e=0,n=0,s="";do{n=t.indexOf(".",e),n===-1?s=t.substring(e):s=t.substring(e,n),e=n+1;let 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 wc,Wn=class extends dt{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()}}};wc=Wn;S.RelativeObjectIdentifier=wc;Wn.NAME="RelativeObjectIdentifier";var xc,ft=class extends ke{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};xc=ft;S.Sequence=xc;ft.NAME="SEQUENCE";var vc,Jn=class extends ke{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};vc=Jn;S.Set=vc;Jn.NAME="SET";var Xn=class extends pe(bt){constructor({...t}={}){super(t),this.isHexOnly=!0,this.value=Ar}toJSON(){return{...super.toJSON(),value:this.value}}};Xn.NAME="StringValueBlock";var Qn=class extends Xn{};Qn.NAME="SimpleStringValueBlock";var Et=class extends Vn{constructor({...t}={}){super(t,Qn)}fromBuffer(t){this.valueBlock.value=String.fromCharCode.apply(null,O.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}};Et.NAME="SIMPLE STRING";var ts=class extends Et{fromBuffer(t){this.valueBlock.valueHexView=O.BufferSourceConverter.toUint8Array(t);try{this.valueBlock.value=O.Convert.ToUtf8String(t)}catch(e){this.warnings.push(`Error during "decodeURIComponent": ${e}, using raw string`),this.valueBlock.value=O.Convert.ToBinary(t)}}fromString(t){this.valueBlock.valueHexView=new Uint8Array(O.Convert.FromUtf8String(t)),this.valueBlock.value=t}};ts.NAME="Utf8StringValueBlock";var Ec,he=class extends ts{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};Ec=he;S.Utf8String=Ec;he.NAME="UTF8String";var es=class extends Et{fromBuffer(t){this.valueBlock.value=O.Convert.ToUtf16String(t),this.valueBlock.valueHexView=O.BufferSourceConverter.toUint8Array(t)}fromString(t){this.valueBlock.value=t,this.valueBlock.valueHexView=new Uint8Array(O.Convert.FromUtf16String(t))}};es.NAME="BmpStringValueBlock";var Bc,rs=class extends es{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};Bc=rs;S.BmpString=Bc;rs.NAME="BMPString";var ns=class extends Et{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=Se(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 Ac,ss=class extends ns{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};Ac=ss;S.UniversalString=Ac;ss.NAME="UniversalString";var Sc,is=class extends Et{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};Sc=is;S.NumericString=Sc;is.NAME="NumericString";var kc,os=class extends Et{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};kc=os;S.PrintableString=kc;os.NAME="PrintableString";var Ic,as=class extends Et{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};Ic=as;S.TeletexString=Ic;as.NAME="TeletexString";var Rc,cs=class extends Et{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};Rc=cs;S.VideotexString=Rc;cs.NAME="VideotexString";var Nc,us=class extends Et{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};Nc=us;S.IA5String=Nc;us.NAME="IA5String";var _c,ls=class extends Et{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};_c=ls;S.GraphicString=_c;ls.NAME="GraphicString";var Tc,Xr=class extends Et{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};Tc=Xr;S.VisibleString=Tc;Xr.NAME="VisibleString";var Lc,fs=class extends Et{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};Lc=fs;S.GeneralString=Lc;fs.NAME="GeneralString";var Cc,hs=class extends Et{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};Cc=hs;S.CharacterString=Cc;hs.NAME="CharacterString";var Uc,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,O.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]=_t(this.year<2e3?this.year-1900:this.year-2e3,2),e[1]=_t(this.month,2),e[2]=_t(this.day,2),e[3]=_t(this.hour,2),e[4]=_t(this.minute,2),e[5]=_t(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}}};Uc=Qr;S.UTCTime=Uc;Qr.NAME="UTCTime";var Dc,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("+"),x="";if(p===-1&&(p=n.indexOf("-"),u=-1),p!==-1){if(x=n.substring(p+1),n=n.substring(0,p),x.length!==2&&x.length!==4)throw new Error("Wrong input string for conversion");let m=parseInt(x.substring(0,2),10);if(isNaN(m.valueOf()))throw new Error("Wrong input string for conversion");if(a=u*m,x.length===4){if(m=parseInt(x.substring(2,4),10),isNaN(m.valueOf()))throw new Error("Wrong input string for conversion");c=u*m}}}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(_t(this.year,4)),e.push(_t(this.month,2)),e.push(_t(this.day,2)),e.push(_t(this.hour,2)),e.push(_t(this.minute,2)),e.push(_t(this.second,2)),this.millisecond!==0&&(e.push("."),e.push(_t(this.millisecond,3))),e.push("Z"),e.join("")}return super.toString(t)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};Dc=ds;S.GeneralizedTime=Dc;ds.NAME="GeneralizedTime";var Pc,ps=class extends he{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};Pc=ps;S.DATE=Pc;ps.NAME="DATE";var Oc,gs=class extends he{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};Oc=gs;S.TimeOfDay=Oc;gs.NAME="TimeOfDay";var Vc,ms=class extends he{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};Vc=ms;S.DateTime=Vc;ms.NAME="DateTime";var Mc,ys=class extends he{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};Mc=ys;S.Duration=Mc;ys.NAME="Duration";var Hc,bs=class extends he{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};Hc=bs;S.TIME=Hc;bs.NAME="TIME";function Oh(r){let{result:t}=Sr(r),e=t.valueBlock.value;return{n:G(Jt(e[1].toBigInt()),"base64url"),e:G(Jt(e[2].toBigInt()),"base64url"),d:G(Jt(e[3].toBigInt()),"base64url"),p:G(Jt(e[4].toBigInt()),"base64url"),q:G(Jt(e[5].toBigInt()),"base64url"),dp:G(Jt(e[6].toBigInt()),"base64url"),dq:G(Jt(e[7].toBigInt()),"base64url"),qi:G(Jt(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 B("JWK was missing components","ERR_INVALID_PARAMETERS");let e=new ft({value:[new nt({value:0}),nt.fromBigInt(Xt(F(r.n,"base64url"))),nt.fromBigInt(Xt(F(r.e,"base64url"))),nt.fromBigInt(Xt(F(r.d,"base64url"))),nt.fromBigInt(Xt(F(r.p,"base64url"))),nt.fromBigInt(Xt(F(r.q,"base64url"))),nt.fromBigInt(Xt(F(r.dp,"base64url"))),nt.fromBigInt(Xt(F(r.dq,"base64url"))),nt.fromBigInt(Xt(F(r.qi,"base64url")))]}).toBER();return new Uint8Array(e,0,e.byteLength)}function Mh(r){let{result:t}=Sr(r),e=t.valueBlock.value[1].valueBlock.value[0].valueBlock.value;return{kty:"RSA",n:G(Jt(e[0].toBigInt()),"base64url"),e:G(Jt(e[1].toBigInt()),"base64url")}}function Hh(r){if(r.n==null||r.e==null)throw new B("JWK was missing components","ERR_INVALID_PARAMETERS");let e=new ft({value:[new ft({value:[new qt({value:"1.2.840.113549.1.1.1"}),new Ie]}),new Br({valueHex:new ft({value:[nt.fromBigInt(Xt(F(r.n,"base64url"))),nt.fromBigInt(Xt(F(r.e,"base64url")))]}).toBER()})]}).toBER();return new Uint8Array(e,0,e.byteLength)}function Jt(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 Xt(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 Kh=16,so=32,io=1e4;async function Fh(r,t){let e=j.get(),s=new ft({value:[new nt({value:0}),new ft({value:[new qt({value:"1.2.840.113549.1.1.1"}),new Ie]}),new fe({valueHex:r.marshal()})]}).toBER(),i=new Uint8Array(s,0,s.byteLength),o=Zt(Kh),a=await Qi(Mr,t,o,{c:io,dkLen:so}),c=Zt(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 nt({value:io}),new nt({value:so}),new ft({value:[new qt({value:"1.2.840.113549.2.11"}),new Ie]})]}),p=new ft({value:[new qt({value:"1.2.840.113549.1.5.13"}),new ft({value:[new ft({value:[new qt({value:"1.2.840.113549.1.5.12"}),u]}),new ft({value:[new qt({value:"2.16.840.1.101.3.4.1.42"}),new fe({valueHex:c})]})]})]}),m=new ft({value:[p,new fe({valueHex:l})]}).toBER(),h=new Uint8Array(m,0,m.byteLength);return["-----BEGIN ENCRYPTED PRIVATE KEY-----",...G(h,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
7
- `)}async function oo(r,t){let e=j.get(),n;if(r.includes("-----BEGIN ENCRYPTED PRIVATE KEY-----")){let s=F(r.replace("-----BEGIN ENCRYPTED PRIVATE KEY-----","").replace("-----END ENCRYPTED PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:i}=Sr(s),{iv:o,salt:a,iterations:c,keySize:f,cipherText:l}=qh(i),u=await Qi(Mr,t,a,{c,dkLen:f}),p=await e.subtle.importKey("raw",u,"AES-CBC",!1,["decrypt"]),x=tn(await e.subtle.decrypt({name:"AES-CBC",iv:o},p,l)),{result:m}=Sr(x);n=Kc(m)}else if(r.includes("-----BEGIN PRIVATE KEY-----")){let s=F(r.replace("-----BEGIN PRIVATE KEY-----","").replace("-----END PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:i}=Sr(s);n=Kc(i)}else throw new B("Could not parse private key from PEM data","ERR_INVALID_PARAMETERS");return ao(n)}function qh(r){let t=r.valueBlock.value[0];if(t.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.13")throw new B("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 B("Only pkcs5PBKDF2 key derivation functions are supported","ERR_INVALID_PARAMS");let i=n.valueBlock.value[1],o=tn(i.valueBlock.value[0].getValue()),a=io,c=so;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 B("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 B("Only AES-CBC encryption schemes are supported","ERR_INVALID_PARAMS")}}}}let u=tn(f.valueBlock.value[1].getValue());return{cipherText:tn(r.valueBlock.value[1].getValue()),salt:o,iterations:a,keySize:c,iv:u}}function Kc(r){return tn(r.valueBlock.value[2].getValue())}function tn(r){return new Uint8Array(r,0,r.byteLength)}async function Fc(r){let t=await j.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 Gc(t);return{privateKey:e[0],publicKey:e[1]}}async function co(r){let e=[await j.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["sign"]),await $h(r)],n=await Gc({privateKey:e[0],publicKey:e[1]});return{privateKey:n[0],publicKey:n[1]}}async function qc(r,t){let e=await j.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await j.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},e,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(n,0,n.byteLength)}async function $c(r,t,e){let n=await j.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return j.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,t,e instanceof Uint8Array?e:e.subarray())}async function Gc(r){if(r.privateKey==null||r.publicKey==null)throw new B("Private and public key are required","ERR_INVALID_PARAMETERS");return Promise.all([j.get().subtle.exportKey("jwk",r.privateKey),j.get().subtle.exportKey("jwk",r.publicKey)])}async function $h(r){return j.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 B("invalid key type","ERR_INVALID_KEY_TYPE");if(r.n==null)throw new B("invalid key modulus","ERR_INVALID_KEY_MODULUS");return F(r.n,"base64url").length*8}var $e=8192,qe=class{_key;constructor(t){this._key=t}verify(t,e){return $c(this._key,e,t)}marshal(){return Re.jwkToPkix(this._key)}get bytes(){return Kt.encode({Type:Y.RSA,Data:this.marshal()}).subarray()}equals(t){return pt(this.bytes,t.bytes)}hash(){let t=ot.digest(this.bytes);return Lt(t)?t.then(({bytes:e})=>e):t.bytes}},Ne=class{_key;_publicKey;constructor(t,e){this._key=t,this._publicKey=e}genSecret(){return Zt(16)}sign(t){return qc(this._key,t)}get public(){if(this._publicKey==null)throw new B("public key not provided","ERR_PUBKEY_NOT_PROVIDED");return new qe(this._publicKey)}marshal(){return Re.jwkToPkcs1(this._key)}get bytes(){return Ft.encode({Type:Y.RSA,Data:this.marshal()}).subarray()}equals(t){return pt(this.bytes,t.bytes)}hash(){let t=ot.digest(this.bytes);return Lt(t)?t.then(({bytes:e})=>e):t.bytes}async id(){let t=await this.public.hash();return G(t,"base58btc")}async export(t,e="pkcs-8"){if(e==="pkcs-8")return Re.exportToPem(this,t);if(e==="libp2p-key")return br(this.bytes,t);throw new B(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};async function ao(r){let t=Re.pkcs1ToJwk(r);if(xs(t)>$e)throw new B("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await co(t);return new Ne(e.privateKey,e.publicKey)}function zh(r){let t=Re.pkixToJwk(r);if(xs(t)>$e)throw new B("key size is too large","ERR_KEY_SIZE_TOO_LARGE");return new qe(t)}async function Yh(r){if(xs(r)>$e)throw new B("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await co(r);return new Ne(t.privateKey,t.publicKey)}async function jh(r){if(r>$e)throw new B("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await Fc(r);return new Ne(t.privateKey,t.publicKey)}var go={};rt(go,{Secp256k1PrivateKey:()=>Ye,Secp256k1PublicKey:()=>ze,generateKeyPair:()=>ad,unmarshalSecp256k1PrivateKey:()=>id,unmarshalSecp256k1PublicKey:()=>od});var Zh=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]),_e=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),Te=new Uint32Array(64),lo=class extends pr{constructor(){super(64,32,8,!1),this.A=_e[0]|0,this.B=_e[1]|0,this.C=_e[2]|0,this.D=_e[3]|0,this.E=_e[4]|0,this.F=_e[5]|0,this.G=_e[6]|0,this.H=_e[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)Te[u]=t.getUint32(e,!1);for(let u=16;u<64;u++){let p=Te[u-15],x=Te[u-2],m=Pt(p,7)^Pt(p,18)^p>>>3,h=Pt(x,17)^Pt(x,19)^x>>>10;Te[u]=h+Te[u-7]+m+Te[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),x=l+p+pa(a,c,f)+Zh[u]+Te[u]|0,h=(Pt(n,2)^Pt(n,13)^Pt(n,22))+ga(n,s,i)|0;l=f,f=c,c=a,a=o+x|0,o=i,i=s,s=n,n=x+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(){Te.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var zc=bn(()=>new lo);function Yc(r){r.lowS!==void 0&&Ot("lowS",r.lowS),r.prehash!==void 0&&Ot("prehash",r.prehash)}function Wh(r){let t=Fr(r);jt(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:Jh,hexToBytes:Xh}=vn,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:Jh(n),l:r.subarray(e+2)}},toSig(r){let{Err:t}=Ge,e=typeof r=="string"?Xh(r):r;gr(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=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}`}},Le=BigInt(0),ht=BigInt(1),Jm=BigInt(2),jc=BigInt(3),Xm=BigInt(4);function Qh(r){let t=Wh(r),{Fp:e}=t,n=t.toBytes||((m,h,d)=>{let v=h.toAffine();return oe(Uint8Array.from([4]),e.toBytes(v.x),e.toBytes(v.y))}),s=t.fromBytes||(m=>{let h=m.subarray(1),d=e.fromBytes(h.subarray(0,e.BYTES)),v=e.fromBytes(h.subarray(e.BYTES,2*e.BYTES));return{x:d,y:v}});function i(m){let{a:h,b:d}=t,v=e.sqr(m),b=e.mul(v,m);return e.add(e.add(b,e.mul(m,h)),d)}if(!e.eql(e.sqr(t.Gy),i(t.Gx)))throw new Error("bad generator point: equation left != right");function o(m){return Hr(m,ht,t.n)}function a(m){let{allowedPrivateKeyLengths:h,nByteLength:d,wrapPrivateKey:v,n:b}=t;if(h&&typeof m!="bigint"){if(ve(m)&&(m=se(m)),typeof m!="string"||!h.includes(m.length))throw new Error("Invalid key");m=m.padStart(d*2,"0")}let w;try{w=typeof m=="bigint"?m:ie(tt("private key",m,d))}catch{throw new Error(`private key must be ${d} bytes, hex or bigint, not ${typeof m}`)}return v&&(w=z(w,b)),St("private key",w,ht,b),w}function c(m){if(!(m instanceof u))throw new Error("ProjectivePoint expected")}let f=Oe((m,h)=>{let{px:d,py:v,pz:b}=m;if(e.eql(b,e.ONE))return{x:d,y:v};let w=m.is0();h==null&&(h=w?e.ONE:e.inv(b));let _=e.mul(d,h),I=e.mul(v,h),k=e.mul(b,h);if(w)return{x:e.ZERO,y:e.ZERO};if(!e.eql(k,e.ONE))throw new Error("invZ was invalid");return{x:_,y:I}}),l=Oe(m=>{if(m.is0()){if(t.allowInfinityPoint&&!e.is0(m.py))return;throw new Error("bad point: ZERO")}let{x:h,y:d}=m.toAffine();if(!e.isValid(h)||!e.isValid(d))throw new Error("bad point: x or y not FE");let v=e.sqr(d),b=i(h);if(!e.eql(v,b))throw new Error("bad point: equation left != right");if(!m.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});class u{constructor(h,d,v){if(this.px=h,this.py=d,this.pz=v,h==null||!e.isValid(h))throw new Error("x required");if(d==null||!e.isValid(d))throw new Error("y required");if(v==null||!e.isValid(v))throw new Error("z required");Object.freeze(this)}static fromAffine(h){let{x:d,y:v}=h||{};if(!h||!e.isValid(d)||!e.isValid(v))throw new Error("invalid affine point");if(h instanceof u)throw new Error("projective point not allowed");let b=w=>e.eql(w,e.ZERO);return b(d)&&b(v)?u.ZERO:new u(d,v,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(h){let d=e.invertBatch(h.map(v=>v.pz));return h.map((v,b)=>v.toAffine(d[b])).map(u.fromAffine)}static fromHex(h){let d=u.fromAffine(s(tt("pointHex",h)));return d.assertValidity(),d}static fromPrivateKey(h){return u.BASE.multiply(a(h))}_setWindowSize(h){x.setWindowSize(this,h)}assertValidity(){l(this)}hasEvenY(){let{y:h}=this.toAffine();if(e.isOdd)return!e.isOdd(h);throw new Error("Field doesn't support isOdd")}equals(h){c(h);let{px:d,py:v,pz:b}=this,{px:w,py:_,pz:I}=h,k=e.eql(e.mul(d,I),e.mul(w,b)),T=e.eql(e.mul(v,I),e.mul(_,b));return k&&T}negate(){return new u(this.px,e.neg(this.py),this.pz)}double(){let{a:h,b:d}=t,v=e.mul(d,jc),{px:b,py:w,pz:_}=this,I=e.ZERO,k=e.ZERO,T=e.ZERO,R=e.mul(b,b),$=e.mul(w,w),V=e.mul(_,_),M=e.mul(b,w);return M=e.add(M,M),T=e.mul(b,_),T=e.add(T,T),I=e.mul(h,T),k=e.mul(v,V),k=e.add(I,k),I=e.sub($,k),k=e.add($,k),k=e.mul(I,k),I=e.mul(M,I),T=e.mul(v,T),V=e.mul(h,V),M=e.sub(R,V),M=e.mul(h,M),M=e.add(M,T),T=e.add(R,R),R=e.add(T,R),R=e.add(R,V),R=e.mul(R,M),k=e.add(k,R),V=e.mul(w,_),V=e.add(V,V),R=e.mul(V,M),I=e.sub(I,R),T=e.mul(V,$),T=e.add(T,T),T=e.add(T,T),new u(I,k,T)}add(h){c(h);let{px:d,py:v,pz:b}=this,{px:w,py:_,pz:I}=h,k=e.ZERO,T=e.ZERO,R=e.ZERO,$=t.a,V=e.mul(t.b,jc),M=e.mul(d,w),et=e.mul(v,_),st=e.mul(b,I),N=e.add(d,v),y=e.add(w,_);N=e.mul(N,y),y=e.add(M,et),N=e.sub(N,y),y=e.add(d,b);let g=e.add(w,I);return y=e.mul(y,g),g=e.add(M,st),y=e.sub(y,g),g=e.add(v,b),k=e.add(_,I),g=e.mul(g,k),k=e.add(et,st),g=e.sub(g,k),R=e.mul($,y),k=e.mul(V,st),R=e.add(k,R),k=e.sub(et,R),R=e.add(et,R),T=e.mul(k,R),et=e.add(M,M),et=e.add(et,M),st=e.mul($,st),y=e.mul(V,y),et=e.add(et,st),st=e.sub(M,st),st=e.mul($,st),y=e.add(y,st),M=e.mul(et,y),T=e.add(T,M),M=e.mul(g,y),k=e.mul(N,k),k=e.sub(k,M),M=e.mul(N,et),R=e.mul(g,R),R=e.add(R,M),new u(k,T,R)}subtract(h){return this.add(h.negate())}is0(){return this.equals(u.ZERO)}wNAF(h){return x.wNAFCached(this,h,u.normalizeZ)}multiplyUnsafe(h){St("scalar",h,Le,t.n);let d=u.ZERO;if(h===Le)return d;if(h===ht)return this;let{endo:v}=t;if(!v)return x.unsafeLadder(this,h);let{k1neg:b,k1:w,k2neg:_,k2:I}=v.splitScalar(h),k=d,T=d,R=this;for(;w>Le||I>Le;)w&ht&&(k=k.add(R)),I&ht&&(T=T.add(R)),R=R.double(),w>>=ht,I>>=ht;return b&&(k=k.negate()),_&&(T=T.negate()),T=new u(e.mul(T.px,v.beta),T.py,T.pz),k.add(T)}multiply(h){let{endo:d,n:v}=t;St("scalar",h,ht,v);let b,w;if(d){let{k1neg:_,k1:I,k2neg:k,k2:T}=d.splitScalar(h),{p:R,f:$}=this.wNAF(I),{p:V,f:M}=this.wNAF(T);R=x.constTimeNegate(_,R),V=x.constTimeNegate(k,V),V=new u(e.mul(V.px,d.beta),V.py,V.pz),b=R.add(V),w=$.add(M)}else{let{p:_,f:I}=this.wNAF(h);b=_,w=I}return u.normalizeZ([b,w])[0]}multiplyAndAddUnsafe(h,d,v){let b=u.BASE,w=(I,k)=>k===Le||k===ht||!I.equals(b)?I.multiplyUnsafe(k):I.multiply(k),_=w(this,d).add(w(h,v));return _.is0()?void 0:_}toAffine(h){return f(this,h)}isTorsionFree(){let{h,isTorsionFree:d}=t;if(h===ht)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===ht?this:d?d(u,this):this.multiplyUnsafe(t.h)}toRawBytes(h=!0){return Ot("isCompressed",h),this.assertValidity(),n(u,this,h)}toHex(h=!0){return Ot("isCompressed",h),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,x=An(u,t.endo?Math.ceil(p/2):p);return{CURVE:t,ProjectivePoint:u,normPrivateKeyToScalar:a,weierstrassEquation:i,isWithinCurveOrder:o}}function td(r){let t=Fr(r);return jt(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function Zc(r){let t=td(r),{Fp:e,n}=t,s=e.BYTES+1,i=2*e.BYTES+1;function o(N){return z(N,n)}function a(N){return En(N,n)}let{ProjectivePoint:c,normPrivateKeyToScalar:f,weierstrassEquation:l,isWithinCurveOrder:u}=Qh({...t,toBytes(N,y,g){let E=y.toAffine(),A=e.toBytes(E.x),L=oe;return Ot("isCompressed",g),g?L(Uint8Array.from([y.hasEvenY()?2:3]),A):L(Uint8Array.from([4]),A,e.toBytes(E.y))},fromBytes(N){let y=N.length,g=N[0],E=N.subarray(1);if(y===s&&(g===2||g===3)){let A=ie(E);if(!Hr(A,ht,e.ORDER))throw new Error("Point is not on curve");let L=l(A),C;try{C=e.sqrt(L)}catch(P){let K=P instanceof Error?": "+P.message:"";throw new Error("Point is not on curve"+K)}let U=(C&ht)===ht;return(g&1)===1!==U&&(C=e.neg(C)),{x:A,y:C}}else if(y===i&&g===4){let A=e.fromBytes(E.subarray(0,e.BYTES)),L=e.fromBytes(E.subarray(e.BYTES,2*e.BYTES));return{x:A,y:L}}else throw new Error(`Point of length ${y} was invalid. Expected ${s} compressed bytes or ${i} uncompressed bytes`)}}),p=N=>se(Be(N,t.nByteLength));function x(N){let y=n>>ht;return N>y}function m(N){return x(N)?o(-N):N}let h=(N,y,g)=>ie(N.slice(y,g));class d{constructor(y,g,E){this.r=y,this.s=g,this.recovery=E,this.assertValidity()}static fromCompact(y){let g=t.nByteLength;return y=tt("compactSignature",y,g*2),new d(h(y,0,g),h(y,g,2*g))}static fromDER(y){let{r:g,s:E}=Ge.toSig(tt("DER",y));return new d(g,E)}assertValidity(){St("r",this.r,ht,n),St("s",this.s,ht,n)}addRecoveryBit(y){return new d(this.r,this.s,y)}recoverPublicKey(y){let{r:g,s:E,recovery:A}=this,L=k(tt("msgHash",y));if(A==null||![0,1,2,3].includes(A))throw new Error("recovery id invalid");let C=A===2||A===3?g+t.n:g;if(C>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let U=A&1?"03":"02",H=c.fromHex(U+p(C)),P=a(C),K=o(-L*P),J=o(E*P),X=c.BASE.multiplyAndAddUnsafe(H,K,J);if(!X)throw new Error("point at infinify");return X.assertValidity(),X}hasHighS(){return x(this.s)}normalizeS(){return this.hasHighS()?new d(this.r,o(-this.s),this.recovery):this}toDERRawBytes(){return De(this.toDERHex())}toDERHex(){return Ge.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return De(this.toCompactHex())}toCompactHex(){return p(this.r)+p(this.s)}}let v={isValidPrivateKey(N){try{return f(N),!0}catch{return!1}},normPrivateKeyToScalar:f,randomPrivateKey:()=>{let N=ki(t.n);return Aa(t.randomBytes(N),t.n)},precompute(N=8,y=c.BASE){return y._setWindowSize(N),y.multiply(BigInt(3)),y}};function b(N,y=!0){return c.fromPrivateKey(N).toRawBytes(y)}function w(N){let y=ve(N),g=typeof N=="string",E=(y||g)&&N.length;return y?E===s||E===i:g?E===2*s||E===2*i:N instanceof c}function _(N,y,g=!0){if(w(N))throw new Error("first arg must be private key");if(!w(y))throw new Error("second arg must be public key");return c.fromHex(y).multiply(f(N)).toRawBytes(g)}let I=t.bits2int||function(N){let y=ie(N),g=N.length*8-t.nBitLength;return g>0?y>>BigInt(g):y},k=t.bits2int_modN||function(N){return o(I(N))},T=Kr(t.nBitLength);function R(N){return St(`num < 2^${t.nBitLength}`,N,Le,T),Be(N,t.nByteLength)}function $(N,y,g=V){if(["recovered","canonical"].some(ut=>ut in g))throw new Error("sign() legacy options not supported");let{hash:E,randomBytes:A}=t,{lowS:L,prehash:C,extraEntropy:U}=g;L==null&&(L=!0),N=tt("msgHash",N),Yc(g),C&&(N=tt("prehashed msgHash",E(N)));let H=k(N),P=f(y),K=[R(P),R(H)];if(U!=null&&U!==!1){let ut=U===!0?A(e.BYTES):U;K.push(tt("extraEntropy",ut))}let J=oe(...K),X=H;function At(ut){let it=I(ut);if(!u(it))return;let Ut=a(it),lt=c.BASE.multiply(it).toAffine(),Dt=o(lt.x);if(Dt===Le)return;let Ue=o(Ut*o(X+Dt*P));if(Ue===Le)return;let Rr=(lt.x===Dt?0:2)|Number(lt.y&ht),fn=Ue;return L&&x(Ue)&&(fn=m(Ue),Rr^=1),new d(Dt,fn,Rr)}return{seed:J,k2sig:At}}let V={lowS:t.lowS,prehash:!1},M={lowS:t.lowS,prehash:!1};function et(N,y,g=V){let{seed:E,k2sig:A}=$(N,y,g),L=t;return Ei(L.hash.outputLen,L.nByteLength,L.hmac)(E,A)}c.BASE._setWindowSize(8);function st(N,y,g,E=M){let A=N;if(y=tt("msgHash",y),g=tt("publicKey",g),"strict"in E)throw new Error("options.strict was renamed to lowS");Yc(E);let{lowS:L,prehash:C}=E,U,H;try{if(typeof A=="string"||ve(A))try{U=d.fromDER(A)}catch(lt){if(!(lt instanceof Ge.Err))throw lt;U=d.fromCompact(A)}else if(typeof A=="object"&&typeof A.r=="bigint"&&typeof A.s=="bigint"){let{r:lt,s:Dt}=A;U=new d(lt,Dt)}else throw new Error("PARSE");H=c.fromHex(g)}catch(lt){if(lt.message==="PARSE")throw new Error("signature must be Signature instance, Uint8Array or hex string");return!1}if(L&&U.hasHighS())return!1;C&&(y=t.hash(y));let{r:P,s:K}=U,J=k(y),X=a(K),At=o(J*X),ut=o(P*X),it=c.BASE.multiplyAndAddUnsafe(H,At,ut)?.toAffine();return it?o(it.x)===P:!1}return{CURVE:t,getPublicKey:b,getSharedSecret:_,sign:et,verify:st,ProjectivePoint:c,Signature:d,utils:v}}function ed(r){return{hash:r,hmac:(t,...e)=>Gr(r,t,gi(...e)),randomBytes:dr}}function Wc(r,t){let e=n=>Zc({...r,...ed(n)});return Object.freeze({...e(t),create:e})}var Qc=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),Jc=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),rd=BigInt(1),fo=BigInt(2),Xc=(r,t)=>(r+t/fo)/t;function nd(r){let t=Qc,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=W(l,e,t)*l%t,p=W(u,e,t)*l%t,x=W(p,fo,t)*f%t,m=W(x,s,t)*x%t,h=W(m,i,t)*m%t,d=W(h,a,t)*h%t,v=W(d,c,t)*d%t,b=W(v,a,t)*h%t,w=W(b,e,t)*l%t,_=W(w,o,t)*m%t,I=W(_,n,t)*f%t,k=W(I,fo,t);if(!ho.eql(ho.sqr(k),r))throw new Error("Cannot find square root");return k}var ho=Bn(Qc,void 0,void 0,{sqrt:nd}),Gt=Wc({a:BigInt(0),b:BigInt(7),Fp:ho,n:Jc,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=Jc,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-rd*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),s=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),i=e,o=BigInt("0x100000000000000000000000000000000"),a=Xc(i*r,t),c=Xc(-n*r,t),f=z(r-a*e-c*s,t),l=z(-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}}}},zc),ay=BigInt(0);var cy=Gt.ProjectivePoint;function tu(){return Gt.utils.randomPrivateKey()}function eu(r,t){let e=ot.digest(t instanceof Uint8Array?t:t.subarray());if(Lt(e))return e.then(({digest:n})=>Gt.sign(n,r).toDERRawBytes()).catch(n=>{throw new B(String(n),"ERR_INVALID_INPUT")});try{return Gt.sign(e.digest,r).toDERRawBytes()}catch(n){throw new B(String(n),"ERR_INVALID_INPUT")}}function ru(r,t,e){let n=ot.digest(e instanceof Uint8Array?e:e.subarray());if(Lt(n))return n.then(({digest:s})=>Gt.verify(t,s,r)).catch(s=>{throw new B(String(s),"ERR_INVALID_INPUT")});try{return Gt.verify(t,n.digest,r)}catch(s){throw new B(String(s),"ERR_INVALID_INPUT")}}function nu(r){return Gt.ProjectivePoint.fromHex(r).toRawBytes(!0)}function su(r){try{Gt.getPublicKey(r,!0)}catch(t){throw new B(String(t),"ERR_INVALID_PRIVATE_KEY")}}function po(r){try{Gt.ProjectivePoint.fromHex(r)}catch(t){throw new B(String(t),"ERR_INVALID_PUBLIC_KEY")}}function iu(r){try{return Gt.getPublicKey(r,!0)}catch(t){throw new B(String(t),"ERR_INVALID_PRIVATE_KEY")}}var ze=class{_key;constructor(t){po(t),this._key=t}verify(t,e){return ru(this._key,e,t)}marshal(){return nu(this._key)}get bytes(){return Kt.encode({Type:Y.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return pt(this.bytes,t.bytes)}async hash(){let t=ot.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??iu(t),su(this._key),po(this._publicKey)}sign(t){return eu(this._key,t)}get public(){return new ze(this._publicKey)}marshal(){return this._key}get bytes(){return Ft.encode({Type:Y.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return pt(this.bytes,t.bytes)}hash(){let t=ot.digest(this.bytes);return Lt(t)?t.then(({bytes:e})=>e):t.bytes}async id(){let t=await this.public.hash();return G(t,"base58btc")}async export(t,e="libp2p-key"){if(e==="libp2p-key")return br(this.bytes,t);throw new B(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function id(r){return new Ye(r)}function od(r){return new ze(r)}async function ad(){let r=tu();return new Ye(r)}var ge={rsa:uo,ed25519:Ji,secp256k1:go};function mo(r){let t=Object.keys(ge).join(" / ");return new B(`invalid or unsupported key type ${r}. Must be ${t}`,"ERR_UNSUPPORTED_KEY_TYPE")}function yo(r){if(r=r.toLowerCase(),r==="rsa"||r==="ed25519"||r==="secp256k1")return ge[r];throw mo(r)}async function cd(r,t){return yo(r).generateKeyPair(t??2048)}async function ud(r,t,e){if(r.toLowerCase()!=="ed25519")throw new B("Seed key derivation is unimplemented for RSA or secp256k1","ERR_UNSUPPORTED_KEY_DERIVATION_TYPE");return Wi(t)}function ld(r){let t=Kt.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case Y.RSA:return ge.rsa.unmarshalRsaPublicKey(e);case Y.Ed25519:return ge.ed25519.unmarshalEd25519PublicKey(e);case Y.Secp256k1:return ge.secp256k1.unmarshalSecp256k1PublicKey(e);default:throw mo(t.Type??"unknown")}}function fd(r,t){return t=(t??"rsa").toLowerCase(),yo(t),r.bytes}async function ou(r){let t=Ft.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case Y.RSA:return ge.rsa.unmarshalRsaPrivateKey(e);case Y.Ed25519:return ge.ed25519.unmarshalEd25519PrivateKey(e);case Y.Secp256k1:return ge.secp256k1.unmarshalSecp256k1PrivateKey(e);default:throw mo(t.Type??"RSA")}}function hd(r,t){return t=(t??"rsa").toLowerCase(),yo(t),r.bytes}async function dd(r,t){try{let e=await Ja(r,t);return await ou(e)}catch{}if(!r.includes("BEGIN"))throw new B("Encrypted key was not a libp2p-key or a PEM file","ERR_INVALID_IMPORT_FORMAT");return oo(r,t)}var cu=Symbol.for("@achingbrain/uint8arraylist");function au(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 vs(r){return!!r?.[cu]}var Ce=class r{bufs;length;[cu]=!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(vs(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(vs(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=au(this.bufs,t);return e.buf[e.index]}set(t,e){let n=au(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(vs(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 vt(n,s)}subarray(t,e){let{bufs:n,length:s}=this._subList(t,e);return n.length===1?n[0]:vt(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(!vs(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 x=this.get(u+p);if(n[p]!==x){l=Math.max(1,p-a[x]);break}}if(l===0)return u}return-1}getInt8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getInt8(0)}setInt8(t,e){let n=gt(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=gt(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(!pt(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 Es(){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}},kr=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 bo=class extends Error{type;code;constructor(t,e){super(t??"The operation was aborted"),this.type="aborted",this.code=e??"ABORT_ERR"}};function Ir(r={}){return pd(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 pd(r,t){t=t??{};let e=t.onEnd,n=new kr,s,i,o,a=Es(),c=async()=>{try{return n.isEmpty()?o?{done:!0}:await new Promise((d,v)=>{i=b=>{i=null,n.push(b);try{d(r(n))}catch(w){v(w)}return s}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{a.resolve(),a=Es()})}},f=d=>i!=null?i(d):(n.push(d),s),l=d=>(n=new kr,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})),x=()=>(n=new kr,p(),{done:!0}),m=d=>(p(d),{done:!0});if(s={[Symbol.asyncIterator](){return this},next:c,return:x,throw:m,push:u,end:p,get readableLength(){return n.size},onEmpty:async d=>{let v=d?.signal;if(v?.throwIfAborted(),n.isEmpty())return;let b,w;v!=null&&(b=new Promise((_,I)=>{w=()=>{I(new bo)},v.addEventListener("abort",w)}));try{await Promise.race([a.promise,b])}finally{w!=null&&v!=null&&v?.removeEventListener("abort",w)}}},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 gd(r){return r[Symbol.asyncIterator]!=null}function md(...r){let t=[];for(let e of r)gd(e)||t.push(e);return t.length===r.length?function*(){for(let e of t)yield*e}():async function*(){let e=Ir({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 uu=md;function rn(r,...t){if(r==null)throw new Error("Empty pipeline");if(wo(r)){let n=r;r=()=>n.source}else if(fu(r)||lu(r)){let n=r;r=()=>n}let e=[r,...t];if(e.length>1&&wo(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++)wo(e[n])&&(e[n]=bd(e[n]));return yd(...e)}var yd=(...r)=>{let t;for(;r.length>0;)t=r.shift()(t);return t},lu=r=>r?.[Symbol.asyncIterator]!=null,fu=r=>r?.[Symbol.iterator]!=null,wo=r=>r==null?!1:r.sink!=null&&r.source!=null,bd=r=>t=>{let e=r.sink(t);if(e?.then!=null){let n=Ir({objectMode:!0});e.then(()=>{n.end()},o=>{n.end(o)});let s,i=r.source;if(lu(i))s=async function*(){yield*i,n.end()};else if(fu(i))s=function*(){yield*i,n.end()};else throw new Error("Unknown duplex source type - must be Iterable or AsyncIterable");return uu(n,s())}return r.source};var vo=Po(du(),1);var sn=class extends Error{constructor(t){super(t),this.name="TimeoutError"}},Eo=class extends Error{constructor(t){super(),this.name="AbortError",this.message=t}},pu=r=>globalThis.DOMException===void 0?new Eo(r):new DOMException(r),gu=r=>{let t=r.reason===void 0?pu("This operation was aborted."):r.reason;return t instanceof Error?t:pu(t)};function Bo(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(gu(p)),p.addEventListener("abort",()=>{l(gu(p))})}if(e===Number.POSITIVE_INFINITY){r.then(f,l);return}let u=new sn;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 Ao(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=Ao(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 vo.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}#v(){this.#n--,this.#l(),this.emit("next")}#E(){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.#E()},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=Bo(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.#v()}},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 ct={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 mu(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 yu(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function bu(r,t){let e=mu(r).return?.();yu(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=Mt(r),e=gt(t);return Da(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 Ce(e(r.byteLength),r)};var Rs=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},Ns=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},_s=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"},cn=class extends Error{name="UnexpectedEOFError";code="ERR_UNEXPECTED_EOF"};var vd=8,Ed=1024*1024*4,je;(function(r){r[r.LENGTH=0]="LENGTH",r[r.DATA=1]="DATA"})(je||(je={}));var So=r=>{let t=Pa(r);return So.bytes=Mt(t),t};So.bytes=0;function un(r,t){let e=new Ce,n=je.LENGTH,s=-1,i=t?.lengthDecoder??So,o=t?.maxLengthLength??vd,a=t?.maxDataLength??Ed;function*c(){for(;e.byteLength>0;){if(n===je.LENGTH)try{if(s=i(e),s<0)throw new Rs("Invalid message length");if(s>a)throw new Ns("Message length too long");let f=i.bytes;e.consume(f),t?.onLength!=null&&t.onLength(s),n=je.DATA}catch(f){if(f instanceof RangeError){if(e.byteLength>o)throw new _s("Message length length too long");break}throw f}if(n===je.DATA){if(e.byteLength<s)break;let f=e.sublist(0,s);e.consume(s),t?.onData!=null&&t.onData(f),yield f,n=je.LENGTH}}}return Ss(r)?async function*(){for await(let f of r)e.append(f),yield*c();if(e.byteLength>0)throw new cn("Unexpected end of input")}():function*(){for(let f of r)e.append(f),yield*c();if(e.byteLength>0)throw new cn("Unexpected end of input")}()}un.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 un(n,{...t??{},onLength:i=>{e=i}})};var Ts=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 Ce(t):t)}attachInboundStream(t){let e=()=>{bu(t.source,this.log)};return this._inboundAbortController.signal.addEventListener("abort",e,{once:!0}),this._rawInboundStream=t,this.inboundStream=rn(this._rawInboundStream,n=>un(n)),this.dispatchEvent(new zt("stream:inbound")),this.inboundStream}async attachOutboundStream(t){let e=this.outboundStream;return this.outboundStream!=null&&this.outboundStream.end(),this._rawOutboundStream=t,this.outboundStream=Ir({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 zt("close"))}}),rn(this.outboundStream,n=>Is(n),this._rawOutboundStream).catch(n=>{this.log.error(n)}),e==null&&this.dispatchEvent(new zt("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 zt("close")))}};function wu(){return BigInt(`0x${G(Zt(8),"base16")}`)}var xu=(r,t)=>{let e=F(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},vu=r=>ot.encode(r);var Eu=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=Pr(r.from);return t.publicKey!=null?!0:r.key!=null?(await gn(r.key)).equals(t):!1},Bu=async r=>{if(r.from==null)throw new B("RPC message was missing from",ct.ERR_MISSING_FROM);if(!await Ad(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: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 B("Signed RPC message was missing key",ct.ERR_MISSING_KEY);return e},ln=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}`),F(t,"base16")},kd=r=>BigInt(`0x${G(r,"base16")}`);var Au=F("libp2p-pubsub:");async function Su(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=vt([Au,e(ln(n)).subarray()]),i=await en.unmarshalPrivateKey(r.privateKey);return n.signature=await i.sign(s),n.key=r.publicKey,n}async function ku(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=vt([Au,t({...ln(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 gn(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 Ls=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:f=1}=e;this.log=t.logger.forComponent("libp2p:pubsub"),this.components=t,this.multicodecs=Eu(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 an({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 Ts(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 zt("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 zt("message",{detail:e})),await this.publishMessage(t,e)}}getMsgId(t){switch(this.globalSignaturePolicy){case"StrictSign":if(t.type!=="signed")throw new B('Message type should be "signed" when signature policy is StrictSign but it was not',ct.ERR_MISSING_SIGNATURE);if(t.sequenceNumber==null)throw new B("Need seqno when signature policy is StrictSign but it was missing",ct.ERR_MISSING_SEQNO);if(t.key==null)throw new B("Need key when signature policy is StrictSign but it was missing",ct.ERR_MISSING_KEY);return xu(t.key,t.sequenceNumber);case"StrictNoSign":return vu(t.data);default:throw new B("Cannot get message id: unhandled signature policy",ct.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(ln)})}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 B('Message type should be "unsigned" when signature policy is StrictNoSign but it was not',ct.ERR_MISSING_SIGNATURE);if(e.signature!=null)throw new B("StrictNoSigning: signature should not be present",ct.ERR_UNEXPECTED_SIGNATURE);if(e.key!=null)throw new B("StrictNoSigning: key should not be present",ct.ERR_UNEXPECTED_KEY);if(e.sequenceNumber!=null)throw new B("StrictNoSigning: seqno should not be present",ct.ERR_UNEXPECTED_SEQNO);break;case"StrictSign":if(e.type!=="signed")throw new B('Message type should be "signed" when signature policy is StrictSign but it was not',ct.ERR_MISSING_SIGNATURE);if(e.signature==null)throw new B("StrictSigning: Signing required and no signature was present",ct.ERR_MISSING_SIGNATURE);if(e.sequenceNumber==null)throw new B("StrictSigning: Signing required and no sequenceNumber was present",ct.ERR_MISSING_SEQNO);if(!await ku(e,this.encodeMessage.bind(this)))throw new B("StrictSigning: Invalid message signature",ct.ERR_INVALID_SIGNATURE);break;default:throw new B("Cannot validate message: unhandled signature policy",ct.ERR_UNHANDLED_SIGNATURE_POLICY)}let s=this.topicValidators.get(e.topic);if(s!=null){let i=await s(t,e);if(i===Nr.Reject||i===Nr.Ignore)throw new B("Message validation failed",ct.ERR_TOPIC_VALIDATOR_REJECT)}}async buildMessage(t){switch(this.globalSignaturePolicy){case"StrictSign":return Su(this.components.peerId,t,this.encodeMessage.bind(this));case"StrictNoSign":return Promise.resolve({type:"unsigned",...t});default:throw new B("Cannot build message: unhandled signature policy",ct.ERR_UNHANDLED_SIGNATURE_POLICY)}}getSubscribers(t){if(!this.started)throw new B("not started yet","ERR_NOT_STARTED_YET");if(t==null)throw new B("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:wu()};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 zt("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 Cs=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 ko="/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={},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=>Rt(o,s.codec()),s.decode=o=>It(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=>Rt(o,s.codec()),s.decode=o=>It(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),Us.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=Us.codec().decode(s,s.uint32());break;default:s.skipType(c&7);break}}return o})),n),r.encode=s=>Rt(s,r.codec()),r.decode=s=>It(s,r.codec())})(Ze||(Ze={}));var Us;(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),Ds.codec().encode(i,n);if(e.iwant!=null)for(let i of e.iwant)n.uint32(18),Ps.codec().encode(i,n);if(e.graft!=null)for(let i of e.graft)n.uint32(26),Os.codec().encode(i,n);if(e.prune!=null)for(let i of e.prune)n.uint32(34),Vs.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(Ds.codec().decode(e,e.uint32()));break;case 2:s.iwant.push(Ps.codec().decode(e,e.uint32()));break;case 3:s.graft.push(Os.codec().decode(e,e.uint32()));break;case 4:s.prune.push(Vs.codec().decode(e,e.uint32()));break;default:e.skipType(o&7);break}}return s})),t),r.encode=e=>Rt(e,r.codec()),r.decode=e=>It(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.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=>Rt(e,r.codec()),r.decode=e=>It(e,r.codec())})(Ds||(Ds={}));var Ps;(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=>Rt(e,r.codec()),r.decode=e=>It(e,r.codec())})(Ps||(Ps={}));var Os;(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=>Rt(e,r.codec()),r.decode=e=>It(e,r.codec())})(Os||(Os={}));var Vs;(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),Ms.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(Ms.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=>Rt(e,r.codec()),r.decode=e=>It(e,r.codec())})(Vs||(Vs={}));var Ms;(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=>Rt(e,r.codec()),r.decode=e=>It(e,r.codec())})(Ms||(Ms={}));var Hs=class extends Ls{seenCache;constructor(t,e){super(t,{...e,canRelayMessage:!0,multicodecs:[ko]}),this.log=t.logger.forComponent("libp2p:floodsub"),this.seenCache=new Cs({validityMs:e?.seenTTL??3e4})}[Symbol.toStringTag]="@libp2p/floodsub";[Vo]=["@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=G(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 Rd(r={}){return t=>new Hs(t,r)}return Mu(Nd);})();
4
+ `));let t=this.idBlock.tagClass===3?`[${this.idBlock.tagNumber}]`:this.constructor.NAME;return e.length?`${t} :
5
+ ${e.join(`
6
+ `)}`:`${t} :`}};fc=_t;k.Constructed=fc;_t.NAME="CONSTRUCTED";var qn=class extends we{fromBER(e,t,n){return t}toBER(e){return $e}};qn.override="EndOfContentValueBlock";var hc,$n=class extends pe{constructor(e={}){super(e,qn),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};hc=$n;k.EndOfContent=hc;$n.NAME=Xr;var dc,Tt=class extends pe{constructor(e={}){super(e,we),this.idBlock.tagClass=1,this.idBlock.tagNumber=5}fromBER(e,t,n){return this.lenBlock.length>0&&this.warnings.push("Non-zero length of value block for Null type"),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.blockLength+=n,t+n>e.byteLength?(this.error="End of input reached before message was fully decoded (inconsistent offset and length values)",-1):t+n}toBER(e,t){let n=new ArrayBuffer(2);if(!e){let s=new Uint8Array(n);s[0]=5,s[1]=0}return t&&t.write(n),n}onAsciiEncoding(){return`${this.constructor.NAME}`}};dc=Tt;k.Null=dc;Tt.NAME="NULL";var Gn=class extends gt(we){constructor({value:e,...t}={}){super(t),t.valueHex?this.valueHexView=H.BufferSourceConverter.toUint8Array(t.valueHex):this.valueHexView=new Uint8Array(1),e&&(this.value=e)}get value(){for(let e of this.valueHexView)if(e>0)return!0;return!1}set value(e){this.valueHexView[0]=e?255:0}fromBER(e,t,n){let s=H.BufferSourceConverter.toUint8Array(e);return pt(this,s,t,n)?(this.valueHexView=s.subarray(t,t+n),n>1&&this.warnings.push("Boolean value encoded in more then 1 octet"),this.isHexOnly=!0,so.call(this),this.blockLength=n,t+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};Gn.NAME="BooleanValueBlock";var pc,zn=class extends pe{constructor(e={}){super(e,Gn),this.idBlock.tagClass=1,this.idBlock.tagNumber=1}getValue(){return this.valueBlock.value}setValue(e){this.valueBlock.value=e}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.getValue}`}};pc=zn;k.Boolean=pc;zn.NAME="BOOLEAN";var Yn=class extends gt(We){constructor({isConstructed:e=!1,...t}={}){super(t),this.isConstructed=e}fromBER(e,t,n){let s=0;if(this.isConstructed){if(this.isHexOnly=!1,s=We.prototype.fromBER.call(this,e,t,n),s===-1)return s;for(let i=0;i<this.value.length;i++){let o=this.value[i].constructor.NAME;if(o===Xr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(o!==ac)return this.error="OCTET STRING may consists of OCTET STRINGs only",-1}}else this.isHexOnly=!0,s=super.fromBER(e,t,n),this.blockLength=n;return s}toBER(e,t){return this.isConstructed?We.prototype.toBER.call(this,e,t):e?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};Yn.NAME="OctetStringValueBlock";var gc,ht=class r extends pe{constructor({idBlock:e={},lenBlock:t={},...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,...e},lenBlock:{...t,isIndefiniteForm:!!n.isIndefiniteForm},...n},Yn),this.idBlock.tagClass=1,this.idBlock.tagNumber=4}fromBER(e,t,n){if(this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,n===0)return this.idBlock.error.length===0&&(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length===0&&(this.blockLength+=this.lenBlock.blockLength),t;if(!this.valueBlock.isConstructed){let i=(e instanceof ArrayBuffer?new Uint8Array(e):e).subarray(t,t+n);try{if(i.byteLength){let o=vs(i,0,i.byteLength);o.offset!==-1&&o.offset===n&&(this.valueBlock.value=[o.result])}}catch{}}return super.fromBER(e,t,n)}onAsciiEncoding(){return this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length?_t.prototype.onAsciiEncoding.call(this):`${this.constructor.NAME} : ${H.Convert.ToHex(this.valueBlock.valueHexView)}`}getValue(){if(!this.idBlock.isConstructed)return this.valueBlock.valueHexView.slice().buffer;let e=[];for(let t of this.valueBlock.value)t instanceof r&&e.push(t.valueBlock.valueHexView);return H.BufferSourceConverter.concat(e)}};gc=ht;k.OctetString=gc;ht.NAME=ac;var jn=class extends gt(We){constructor({unusedBits:e=0,isConstructed:t=!1,...n}={}){super(n),this.unusedBits=e,this.isConstructed=t,this.blockLength=this.valueHexView.byteLength}fromBER(e,t,n){if(!n)return t;let s=-1;if(this.isConstructed){if(s=We.prototype.fromBER.call(this,e,t,n),s===-1)return s;for(let a of this.value){let c=a.constructor.NAME;if(c===Xr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==cc)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=H.BufferSourceConverter.toUint8Array(e);if(!pt(this,i,t,n))return-1;let o=i.subarray(t,t+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=vs(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,t+n}toBER(e,t){if(this.isConstructed)return We.prototype.toBER.call(this,e,t);if(e)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return $e;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}}};jn.NAME="BitStringValueBlock";var mc,kr=class extends pe{constructor({idBlock:e={},lenBlock:t={},...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,...e},lenBlock:{...t,isIndefiniteForm:!!n.isIndefiniteForm},...n},jn),this.idBlock.tagClass=1,this.idBlock.tagNumber=3}fromBER(e,t,n){return this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,super.fromBER(e,t,n)}onAsciiEncoding(){if(this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length)return _t.prototype.onAsciiEncoding.call(this);{let e=[],t=this.valueBlock.valueHexView;for(let s of t)e.push(s.toString(2).padStart(8,"0"));let n=e.join("");return`${this.constructor.NAME} : ${n.substring(0,n.length-this.valueBlock.unusedBits)}`}}};mc=kr;k.BitString=mc;kr.NAME=cc;var yc;function Oh(r,e){let t=new Uint8Array([0]),n=new Uint8Array(r),s=new Uint8Array(e),i=n.slice(0),o=i.length-1,a=s.slice(0),c=a.length-1,f=0,u=c<o?o:c,l=0;for(let h=u;h>=0;h--,l++){switch(!0){case l<a.length:f=i[o-l]+a[c-l]+t[0];break;default:f=i[o-l]+t[0]}switch(t[0]=f/10,!0){case l>=i.length:i=On(new Uint8Array([f%10]),i);break;default:i[o-l]=f%10}}return t[0]>0&&(i=On(t,i)),i}function oc(r){if(r>=Wr.length)for(let e=Wr.length;e<=r;e++){let t=new Uint8Array([0]),n=Wr[e-1].slice(0);for(let s=n.length-1;s>=0;s--){let i=new Uint8Array([(n[s]<<1)+t[0]]);t[0]=i[0]/10,n[s]=i[0]%10}t[0]>0&&(n=On(t,n)),Wr.push(n)}return Wr[r]}function Ph(r,e){let t=0,n=new Uint8Array(r),s=new Uint8Array(e),i=n.slice(0),o=i.length-1,a=s.slice(0),c=a.length-1,f,u=0;for(let l=c;l>=0;l--,u++)switch(f=i[o-u]-a[c-u]-t,!0){case f<0:t=1,i[o-u]=f+10;break;default:t=0,i[o-u]=f}if(t>0)for(let l=o-c+1;l>=0;l--,u++)if(f=i[o-u]-t,f<0)t=1,i[o-u]=f+10;else{t=0,i[o-u]=f;break}return i.slice()}var Qr=class extends gt(we){constructor({value:e,...t}={}){super(t),this._valueDec=0,t.valueHex&&this.setValueHex(),e!==void 0&&(this.valueDec=e)}setValueHex(){this.valueHexView.length>=4?(this.warnings.push("Too big Integer for decoding, hex only"),this.isHexOnly=!0,this._valueDec=0):(this.isHexOnly=!1,this.valueHexView.length>0&&(this._valueDec=so.call(this)))}set valueDec(e){this._valueDec=e,this.isHexOnly=!1,this.valueHexView=new Uint8Array(nc(e))}get valueDec(){return this._valueDec}fromDER(e,t,n,s=0){let i=this.fromBER(e,t,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(e=!1){let t=this.valueHexView;switch(!0){case(t[0]&128)!==0:{let n=new Uint8Array(this.valueHexView.length+1);n[0]=0,n.set(t,1),this.valueHexView=n}break;case(t[0]===0&&(t[1]&128)===0):this.valueHexView=this.valueHexView.subarray(1);break}return this.toBER(e)}fromBER(e,t,n){let s=super.fromBER(e,t,n);return s===-1||this.setValueHex(),s}toBER(e){return e?new ArrayBuffer(this.valueHexView.length):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}toString(){let e=this.valueHexView.length*8-1,t=new Uint8Array(this.valueHexView.length*8/3),n=0,s,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 e:t=Ph(oc(n),t),o="-";break;default:t=Oh(t,oc(n))}n++,s>>=1}}for(let c=0;c<t.length;c++)t[c]&&(a=!0),a&&(o+=ic.charAt(t[c]));return a===!1&&(o+=ic.charAt(0)),o}};yc=Qr;Qr.NAME="IntegerValueBlock";Object.defineProperty(yc.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var bc,re=class r extends pe{constructor(e={}){super(e,Qr),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return Pn(),BigInt(this.valueBlock.toString())}static fromBigInt(e){Pn();let t=BigInt(e),n=new Jr,s=t.toString(16).replace(/^-/,""),i=new Uint8Array(H.Convert.FromHex(s));if(t<0){let a=new Uint8Array(i.length+(i[0]&128?1:0));a[0]|=128;let f=BigInt(`0x${H.Convert.ToHex(a)}`)+t,u=H.BufferSourceConverter.toUint8Array(H.Convert.FromHex(f.toString(16)));u[0]|=128,n.write(u)}else i[0]&128&&n.write(new Uint8Array([0])),n.write(i);return new r({valueHex:n.final()})}convertToDER(){let e=new r({valueHex:this.valueBlock.valueHexView});return e.valueBlock.toDER(),e}convertFromDER(){return new r({valueHex:this.valueBlock.valueHexView[0]===0?this.valueBlock.valueHexView.subarray(1):this.valueBlock.valueHexView})}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()}`}};bc=re;k.Integer=bc;re.NAME="INTEGER";var wc,Zn=class extends re{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};wc=Zn;k.Enumerated=wc;Zn.NAME="ENUMERATED";var en=class extends gt(we){constructor({valueDec:e=-1,isFirstSid:t=!1,...n}={}){super(n),this.valueDec=e,this.isFirstSid=t}fromBER(e,t,n){if(!n)return t;let s=H.BufferSourceConverter.toUint8Array(e);if(!pt(this,s,t,n))return-1;let i=s.subarray(t,t+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=zt(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),t+this.blockLength)}set valueBigInt(e){Pn();let t=BigInt(e).toString(2);for(;t.length%7;)t="0"+t;let n=new Uint8Array(t.length/7);for(let s=0;s<n.length;s++)n[s]=parseInt(t.slice(s*7,s*7+7),2)+(s+1<n.length?128:0);this.fromBER(n.buffer,0,n.length)}toBER(e){if(this.isHexOnly){if(e)return new ArrayBuffer(this.valueHexView.byteLength);let s=this.valueHexView,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 t=Nt(this.valueDec,7);if(t.byteLength===0)return this.error="Error during encoding SID value",$e;let n=new Uint8Array(t.byteLength);if(!e){let s=new Uint8Array(t),i=t.byteLength-1;for(let o=0;o<i;o++)n[o]=s[o]|128;n[i]=s[i]}return n}toString(){let e="";if(this.isHexOnly)e=H.Convert.ToHex(this.valueHexView);else if(this.isFirstSid){let t=this.valueDec;this.valueDec<=39?e="0.":this.valueDec<=79?(e="1.",t-=40):(e="2.",t-=80),e+=t.toString()}else e=this.valueDec.toString();return e}toJSON(){return{...super.toJSON(),valueDec:this.valueDec,isFirstSid:this.isFirstSid}}};en.NAME="sidBlock";var Wn=class extends we{constructor({value:e=Ir,...t}={}){super(t),this.value=[],e&&this.fromString(e)}fromBER(e,t,n){let s=t;for(;n>0;){let i=new en;if(s=i.fromBER(e,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(e){let t=[];for(let n=0;n<this.value.length;n++){let s=this.value[n].toBER(e);if(s.byteLength===0)return this.error=this.value[n].error,$e;t.push(s)}return io(t)}fromString(e){this.value=[];let t=0,n=0,s="",i=!1;do if(n=e.indexOf(".",t),n===-1?s=e.substring(t):s=e.substring(t,n),t=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 en;if(s>Number.MAX_SAFE_INTEGER){Pn();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 e="",t=!1;for(let n=0;n<this.value.length;n++){t=this.value[n].isHexOnly;let s=this.value[n].toString();n!==0&&(e=`${e}.`),t?(s=`{${s}}`,this.value[n].isFirstSid?e=`2.{${s} - 80}`:e+=s):e+=s}return e}toJSON(){let e={...super.toJSON(),value:this.toString(),sidArray:[]};for(let t=0;t<this.value.length;t++)e.sidArray.push(this.value[t].toJSON());return e}};Wn.NAME="ObjectIdentifierValueBlock";var xc,qe=class extends pe{constructor(e={}){super(e,Wn),this.idBlock.tagClass=1,this.idBlock.tagNumber=6}getValue(){return this.valueBlock.toString()}setValue(e){this.valueBlock.fromString(e)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};xc=qe;k.ObjectIdentifier=xc;qe.NAME="OBJECT IDENTIFIER";var tn=class extends gt(ft){constructor({valueDec:e=0,...t}={}){super(t),this.valueDec=e}fromBER(e,t,n){if(n===0)return t;let s=H.BufferSourceConverter.toUint8Array(e);if(!pt(this,s,t,n))return-1;let i=s.subarray(t,t+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=zt(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),t+this.blockLength)}toBER(e){if(this.isHexOnly){if(e)return new ArrayBuffer(this.valueHexView.byteLength);let s=this.valueHexView,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 t=Nt(this.valueDec,7);if(t.byteLength===0)return this.error="Error during encoding SID value",$e;let n=new Uint8Array(t.byteLength);if(!e){let s=new Uint8Array(t),i=t.byteLength-1;for(let o=0;o<i;o++)n[o]=s[o]|128;n[i]=s[i]}return n.buffer}toString(){let e="";return this.isHexOnly?e=H.Convert.ToHex(this.valueHexView):e=this.valueDec.toString(),e}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};tn.NAME="relativeSidBlock";var Jn=class extends we{constructor({value:e=Ir,...t}={}){super(t),this.value=[],e&&this.fromString(e)}fromBER(e,t,n){let s=t;for(;n>0;){let i=new tn;if(s=i.fromBER(e,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(e,t){let n=[];for(let s=0;s<this.value.length;s++){let i=this.value[s].toBER(e);if(i.byteLength===0)return this.error=this.value[s].error,$e;n.push(i)}return io(n)}fromString(e){this.value=[];let t=0,n=0,s="";do{n=e.indexOf(".",t),n===-1?s=e.substring(t):s=e.substring(t,n),t=n+1;let i=new tn;if(i.valueDec=parseInt(s,10),isNaN(i.valueDec))return!0;this.value.push(i)}while(n!==-1);return!0}toString(){let e="",t=!1;for(let n=0;n<this.value.length;n++){t=this.value[n].isHexOnly;let s=this.value[n].toString();n!==0&&(e=`${e}.`),t&&(s=`{${s}}`),e+=s}return e}toJSON(){let e={...super.toJSON(),value:this.toString(),sidArray:[]};for(let t=0;t<this.value.length;t++)e.sidArray.push(this.value[t].toJSON());return e}};Jn.NAME="RelativeObjectIdentifierValueBlock";var vc,Xn=class extends pe{constructor(e={}){super(e,Jn),this.idBlock.tagClass=1,this.idBlock.tagNumber=13}getValue(){return this.valueBlock.toString()}setValue(e){this.valueBlock.fromString(e)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};vc=Xn;k.RelativeObjectIdentifier=vc;Xn.NAME="RelativeObjectIdentifier";var Ec,fe=class extends _t{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};Ec=fe;k.Sequence=Ec;fe.NAME="SEQUENCE";var Bc,Qn=class extends _t{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};Bc=Qn;k.Set=Bc;Qn.NAME="SET";var es=class extends gt(we){constructor({...e}={}){super(e),this.isHexOnly=!0,this.value=Ir}toJSON(){return{...super.toJSON(),value:this.value}}};es.NAME="StringValueBlock";var ts=class extends es{};ts.NAME="SimpleStringValueBlock";var Ae=class extends Hn{constructor({...e}={}){super(e,ts)}fromBuffer(e){this.valueBlock.value=String.fromCharCode.apply(null,H.BufferSourceConverter.toUint8Array(e))}fromString(e){let t=e.length,n=this.valueBlock.valueHexView=new Uint8Array(t);for(let s=0;s<t;s++)n[s]=e.charCodeAt(s);this.valueBlock.value=e}};Ae.NAME="SIMPLE STRING";var rs=class extends Ae{fromBuffer(e){this.valueBlock.valueHexView=H.BufferSourceConverter.toUint8Array(e);try{this.valueBlock.value=H.Convert.ToUtf8String(e)}catch(t){this.warnings.push(`Error during "decodeURIComponent": ${t}, using raw string`),this.valueBlock.value=H.Convert.ToBinary(e)}}fromString(e){this.valueBlock.valueHexView=new Uint8Array(H.Convert.FromUtf8String(e)),this.valueBlock.value=e}};rs.NAME="Utf8StringValueBlock";var Ac,dt=class extends rs{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};Ac=dt;k.Utf8String=Ac;dt.NAME="UTF8String";var ns=class extends Ae{fromBuffer(e){this.valueBlock.value=H.Convert.ToUtf16String(e),this.valueBlock.valueHexView=H.BufferSourceConverter.toUint8Array(e)}fromString(e){this.valueBlock.value=e,this.valueBlock.valueHexView=new Uint8Array(H.Convert.FromUtf16String(e))}};ns.NAME="BmpStringValueBlock";var Sc,ss=class extends ns{constructor({...e}={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};Sc=ss;k.BmpString=Sc;ss.NAME="BMPString";var is=class extends Ae{fromBuffer(e){let t=ArrayBuffer.isView(e)?e.slice().buffer:e.slice(0),n=new Uint8Array(t);for(let s=0;s<n.length;s+=4)n[s]=n[s+3],n[s+1]=n[s+2],n[s+2]=0,n[s+3]=0;this.valueBlock.value=String.fromCharCode.apply(null,new Uint32Array(t))}fromString(e){let t=e.length,n=this.valueBlock.valueHexView=new Uint8Array(t*4);for(let s=0;s<t;s++){let i=Nt(e.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=e}};is.NAME="UniversalStringValueBlock";var kc,os=class extends is{constructor({...e}={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};kc=os;k.UniversalString=kc;os.NAME="UniversalString";var Ic,as=class extends Ae{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};Ic=as;k.NumericString=Ic;as.NAME="NumericString";var Rc,cs=class extends Ae{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};Rc=cs;k.PrintableString=Rc;cs.NAME="PrintableString";var Nc,us=class extends Ae{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};Nc=us;k.TeletexString=Nc;us.NAME="TeletexString";var _c,ls=class extends Ae{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};_c=ls;k.VideotexString=_c;ls.NAME="VideotexString";var Tc,fs=class extends Ae{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};Tc=fs;k.IA5String=Tc;fs.NAME="IA5String";var Lc,hs=class extends Ae{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};Lc=hs;k.GraphicString=Lc;hs.NAME="GraphicString";var Cc,rn=class extends Ae{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};Cc=rn;k.VisibleString=Cc;rn.NAME="VisibleString";var Uc,ds=class extends Ae{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};Uc=ds;k.GeneralString=Uc;ds.NAME="GeneralString";var Dc,ps=class extends Ae{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};Dc=ps;k.CharacterString=Dc;ps.NAME="CharacterString";var Oc,nn=class extends rn{constructor({value:e,valueDate:t,...n}={}){if(super(n),this.year=0,this.month=0,this.day=0,this.hour=0,this.minute=0,this.second=0,e){this.fromString(e),this.valueBlock.valueHexView=new Uint8Array(e.length);for(let s=0;s<e.length;s++)this.valueBlock.valueHexView[s]=e.charCodeAt(s)}t&&(this.fromDate(t),this.valueBlock.valueHexView=new Uint8Array(this.toBuffer())),this.idBlock.tagClass=1,this.idBlock.tagNumber=23}fromBuffer(e){this.fromString(String.fromCharCode.apply(null,H.BufferSourceConverter.toUint8Array(e)))}toBuffer(){let e=this.toString(),t=new ArrayBuffer(e.length),n=new Uint8Array(t);for(let s=0;s<e.length;s++)n[s]=e.charCodeAt(s);return t}fromDate(e){this.year=e.getUTCFullYear(),this.month=e.getUTCMonth()+1,this.day=e.getUTCDate(),this.hour=e.getUTCHours(),this.minute=e.getUTCMinutes(),this.second=e.getUTCSeconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second))}fromString(e){let n=/(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})Z/ig.exec(e);if(n===null){this.error="Wrong input string for conversion";return}let s=parseInt(n[1],10);s>=50?this.year=1900+s:this.year=2e3+s,this.month=parseInt(n[2],10),this.day=parseInt(n[3],10),this.hour=parseInt(n[4],10),this.minute=parseInt(n[5],10),this.second=parseInt(n[6],10)}toString(e="iso"){if(e==="iso"){let t=new Array(7);return t[0]=Le(this.year<2e3?this.year-1900:this.year-2e3,2),t[1]=Le(this.month,2),t[2]=Le(this.day,2),t[3]=Le(this.hour,2),t[4]=Le(this.minute,2),t[5]=Le(this.second,2),t[6]="Z",t.join("")}return super.toString(e)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.toDate().toISOString()}`}toJSON(){return{...super.toJSON(),year:this.year,month:this.month,day:this.day,hour:this.hour,minute:this.minute,second:this.second}}};Oc=nn;k.UTCTime=Oc;nn.NAME="UTCTime";var Pc,gs=class extends nn{constructor(e={}){var t;super(e),(t=this.millisecond)!==null&&t!==void 0||(this.millisecond=0),this.idBlock.tagClass=1,this.idBlock.tagNumber=24}fromDate(e){super.fromDate(e),this.millisecond=e.getUTCMilliseconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second,this.millisecond))}fromString(e){let t=!1,n="",s="",i=0,o,a=0,c=0;if(e[e.length-1]==="Z")n=e.substring(0,e.length-1),t=!0;else{let l=new Number(e[e.length-1]);if(isNaN(l.valueOf()))throw new Error("Wrong input string for conversion");n=e}if(t){if(n.indexOf("+")!==-1)throw new Error("Wrong input string for conversion");if(n.indexOf("-")!==-1)throw new Error("Wrong input string for conversion")}else{let l=1,h=n.indexOf("+"),b="";if(h===-1&&(h=n.indexOf("-"),l=-1),h!==-1){if(b=n.substring(h+1),n=n.substring(0,h),b.length!==2&&b.length!==4)throw new Error("Wrong input string for conversion");let v=parseInt(b.substring(0,2),10);if(isNaN(v.valueOf()))throw new Error("Wrong input string for conversion");if(a=l*v,b.length===4){if(v=parseInt(b.substring(2,4),10),isNaN(v.valueOf()))throw new Error("Wrong input string for conversion");c=l*v}}}let f=n.indexOf(".");if(f===-1&&(f=n.indexOf(",")),f!==-1){let l=new Number(`0${n.substring(f)}`);if(isNaN(l.valueOf()))throw new Error("Wrong input string for conversion");i=l.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 l=60*i;this.minute=Math.floor(l),l=60*(l-this.minute),this.second=Math.floor(l),l=1e3*(l-this.second),this.millisecond=Math.floor(l)}break;case s.length===12:if(o=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let l=60*i;this.second=Math.floor(l),l=1e3*(l-this.second),this.millisecond=Math.floor(l)}break;case s.length===14:if(o=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let l=1e3*i;this.millisecond=Math.floor(l)}break;default:throw new Error("Wrong input string for conversion")}let u=o.exec(s);if(u===null)throw new Error("Wrong input string for conversion");for(let l=1;l<u.length;l++)switch(l){case 1:this.year=parseInt(u[l],10);break;case 2:this.month=parseInt(u[l],10);break;case 3:this.day=parseInt(u[l],10);break;case 4:this.hour=parseInt(u[l],10)+a;break;case 5:this.minute=parseInt(u[l],10)+c;break;case 6:this.second=parseInt(u[l],10);break;default:throw new Error("Wrong input string for conversion")}if(t===!1){let l=new Date(this.year,this.month,this.day,this.hour,this.minute,this.second,this.millisecond);this.year=l.getUTCFullYear(),this.month=l.getUTCMonth(),this.day=l.getUTCDay(),this.hour=l.getUTCHours(),this.minute=l.getUTCMinutes(),this.second=l.getUTCSeconds(),this.millisecond=l.getUTCMilliseconds()}}toString(e="iso"){if(e==="iso"){let t=[];return t.push(Le(this.year,4)),t.push(Le(this.month,2)),t.push(Le(this.day,2)),t.push(Le(this.hour,2)),t.push(Le(this.minute,2)),t.push(Le(this.second,2)),this.millisecond!==0&&(t.push("."),t.push(Le(this.millisecond,3))),t.push("Z"),t.join("")}return super.toString(e)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};Pc=gs;k.GeneralizedTime=Pc;gs.NAME="GeneralizedTime";var Vc,ms=class extends dt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};Vc=ms;k.DATE=Vc;ms.NAME="DATE";var Mc,ys=class extends dt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};Mc=ys;k.TimeOfDay=Mc;ys.NAME="TimeOfDay";var Hc,bs=class extends dt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};Hc=bs;k.DateTime=Hc;bs.NAME="DateTime";var Kc,ws=class extends dt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};Kc=ws;k.Duration=Kc;ws.NAME="Duration";var Fc,xs=class extends dt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};Fc=xs;k.TIME=Fc;xs.NAME="TIME";function Mh(r){let{result:e}=Rr(r),t=e.valueBlock.value;return{n:z(Je(t[1].toBigInt()),"base64url"),e:z(Je(t[2].toBigInt()),"base64url"),d:z(Je(t[3].toBigInt()),"base64url"),p:z(Je(t[4].toBigInt()),"base64url"),q:z(Je(t[5].toBigInt()),"base64url"),dp:z(Je(t[6].toBigInt()),"base64url"),dq:z(Je(t[7].toBigInt()),"base64url"),qi:z(Je(t[8].toBigInt()),"base64url"),kty:"RSA",alg:"RS256"}}function Hh(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 t=new fe({value:[new re({value:0}),re.fromBigInt(Xe(q(r.n,"base64url"))),re.fromBigInt(Xe(q(r.e,"base64url"))),re.fromBigInt(Xe(q(r.d,"base64url"))),re.fromBigInt(Xe(q(r.p,"base64url"))),re.fromBigInt(Xe(q(r.q,"base64url"))),re.fromBigInt(Xe(q(r.dp,"base64url"))),re.fromBigInt(Xe(q(r.dq,"base64url"))),re.fromBigInt(Xe(q(r.qi,"base64url")))]}).toBER();return new Uint8Array(t,0,t.byteLength)}function Kh(r){let{result:e}=Rr(r),t=e.valueBlock.value[1].valueBlock.value[0].valueBlock.value;return{kty:"RSA",n:z(Je(t[0].toBigInt()),"base64url"),e:z(Je(t[1].toBigInt()),"base64url")}}function Fh(r){if(r.n==null||r.e==null)throw new A("JWK was missing components","ERR_INVALID_PARAMETERS");let t=new fe({value:[new fe({value:[new qe({value:"1.2.840.113549.1.1.1"}),new Tt]}),new kr({valueHex:new fe({value:[re.fromBigInt(Xe(q(r.n,"base64url"))),re.fromBigInt(Xe(q(r.e,"base64url")))]}).toBER()})]}).toBER();return new Uint8Array(t,0,t.byteLength)}function Je(r){let e=r.toString(16);e.length%2>0&&(e=`0${e}`);let t=e.length/2,n=new Uint8Array(t),s=0,i=0;for(;s<t;)n[s]=parseInt(e.slice(i,i+2),16),s+=1,i+=2;return n}function Xe(r){let e=[];return r.forEach(function(t){let n=t.toString(16);n.length%2>0&&(n=`0${n}`),e.push(n)}),BigInt("0x"+e.join(""))}var qh=16,ao=32,co=1e4;async function $h(r,e){let t=W.get(),s=new fe({value:[new re({value:0}),new fe({value:[new qe({value:"1.2.840.113549.1.1.1"}),new Tt]}),new ht({valueHex:r.marshal()})]}).toBER(),i=new Uint8Array(s,0,s.byteLength),o=Ze(qh),a=await ro(qr,e,o,{c:co,dkLen:ao}),c=Ze(16),f=await t.subtle.importKey("raw",a,"AES-CBC",!1,["encrypt"]),u=await t.subtle.encrypt({name:"AES-CBC",iv:c},f,i),l=new fe({value:[new ht({valueHex:o}),new re({value:co}),new re({value:ao}),new fe({value:[new qe({value:"1.2.840.113549.2.11"}),new Tt]})]}),h=new fe({value:[new qe({value:"1.2.840.113549.1.5.13"}),new fe({value:[new fe({value:[new qe({value:"1.2.840.113549.1.5.12"}),l]}),new fe({value:[new qe({value:"2.16.840.1.101.3.4.1.42"}),new ht({valueHex:c})]})]})]}),v=new fe({value:[h,new ht({valueHex:u})]}).toBER(),m=new Uint8Array(v,0,v.byteLength);return["-----BEGIN ENCRYPTED PRIVATE KEY-----",...z(m,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
7
+ `)}async function uo(r,e){let t=W.get(),n;if(r.includes("-----BEGIN ENCRYPTED PRIVATE KEY-----")){let s=q(r.replace("-----BEGIN ENCRYPTED PRIVATE KEY-----","").replace("-----END ENCRYPTED PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:i}=Rr(s),{iv:o,salt:a,iterations:c,keySize:f,cipherText:u}=Gh(i),l=await ro(qr,e,a,{c,dkLen:f}),h=await t.subtle.importKey("raw",l,"AES-CBC",!1,["decrypt"]),b=sn(await t.subtle.decrypt({name:"AES-CBC",iv:o},h,u)),{result:v}=Rr(b);n=qc(v)}else if(r.includes("-----BEGIN PRIVATE KEY-----")){let s=q(r.replace("-----BEGIN PRIVATE KEY-----","").replace("-----END PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:i}=Rr(s);n=qc(i)}else throw new A("Could not parse private key from PEM data","ERR_INVALID_PARAMETERS");return lo(n)}function Gh(r){let e=r.valueBlock.value[0];if(e.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=e.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=sn(i.valueBlock.value[0].getValue()),a=co,c=ao;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=e.valueBlock.value[1].valueBlock.value[1],u=f.valueBlock.value[0].toString();if(u!=="OBJECT IDENTIFIER : 1.2.840.113549.3.7"){if(u!=="OBJECT IDENTIFIER : 1.3.14.3.2.7"){if(u!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.2"){if(u!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.22"){if(u!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.42")throw new A("Only AES-CBC encryption schemes are supported","ERR_INVALID_PARAMS")}}}}let l=sn(f.valueBlock.value[1].getValue());return{cipherText:sn(r.valueBlock.value[1].getValue()),salt:o,iterations:a,keySize:c,iv:l}}function qc(r){return sn(r.valueBlock.value[2].getValue())}function sn(r){return new Uint8Array(r,0,r.byteLength)}async function $c(r){let e=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"]),t=await Yc(e);return{privateKey:t[0],publicKey:t[1]}}async function fo(r){let t=[await W.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["sign"]),await zh(r)],n=await Yc({privateKey:t[0],publicKey:t[1]});return{privateKey:n[0],publicKey:n[1]}}async function Gc(r,e){let t=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"},t,e instanceof Uint8Array?e:e.subarray());return new Uint8Array(n,0,n.byteLength)}async function zc(r,e,t){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,e,t instanceof Uint8Array?t:t.subarray())}async function Yc(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 zh(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 Es(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 q(r.n,"base64url").length*8}var jt=8192,Yt=class{_key;constructor(e){this._key=e}verify(e,t){return zc(this._key,t,e)}marshal(){return Lt.jwkToPkix(this._key)}get bytes(){return Ke.encode({Type:Z.RSA,Data:this.marshal()}).subarray()}equals(e){return ge(this.bytes,e.bytes)}hash(){let e=oe.digest(this.bytes);return Ue(e)?e.then(({bytes:t})=>t):e.bytes}},Ct=class{_key;_publicKey;constructor(e,t){this._key=e,this._publicKey=t}genSecret(){return Ze(16)}sign(e){return Gc(this._key,e)}get public(){if(this._publicKey==null)throw new A("public key not provided","ERR_PUBKEY_NOT_PROVIDED");return new Yt(this._publicKey)}marshal(){return Lt.jwkToPkcs1(this._key)}get bytes(){return Fe.encode({Type:Z.RSA,Data:this.marshal()}).subarray()}equals(e){return ge(this.bytes,e.bytes)}hash(){let e=oe.digest(this.bytes);return Ue(e)?e.then(({bytes:t})=>t):e.bytes}async id(){let e=await this.public.hash();return z(e,"base58btc")}async export(e,t="pkcs-8"){if(t==="pkcs-8")return Lt.exportToPem(this,e);if(t==="libp2p-key")return vr(this.bytes,e);throw new A(`export format '${t}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};async function lo(r){let e=Lt.pkcs1ToJwk(r);if(Es(e)>jt)throw new A("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await fo(e);return new Ct(t.privateKey,t.publicKey)}function jh(r){let e=Lt.pkixToJwk(r);if(Es(e)>jt)throw new A("key size is too large","ERR_KEY_SIZE_TOO_LARGE");return new Yt(e)}async function Zh(r){if(Es(r)>jt)throw new A("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await fo(r);return new Ct(e.privateKey,e.publicKey)}async function Wh(r){if(r>jt)throw new A("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await $c(r);return new Ct(e.privateKey,e.publicKey)}var bo={};te(bo,{Secp256k1PrivateKey:()=>Wt,Secp256k1PublicKey:()=>Zt,generateKeyPair:()=>ud,unmarshalSecp256k1PrivateKey:()=>ad,unmarshalSecp256k1PublicKey:()=>cd});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]),Ut=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),Dt=new Uint32Array(64),po=class extends yr{constructor(){super(64,32,8,!1),this.A=Ut[0]|0,this.B=Ut[1]|0,this.C=Ut[2]|0,this.D=Ut[3]|0,this.E=Ut[4]|0,this.F=Ut[5]|0,this.G=Ut[6]|0,this.H=Ut[7]|0}get(){let{A:e,B:t,C:n,D:s,E:i,F:o,G:a,H:c}=this;return[e,t,n,s,i,o,a,c]}set(e,t,n,s,i,o,a,c){this.A=e|0,this.B=t|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(e,t){for(let l=0;l<16;l++,t+=4)Dt[l]=e.getUint32(t,!1);for(let l=16;l<64;l++){let h=Dt[l-15],b=Dt[l-2],v=Oe(h,7)^Oe(h,18)^h>>>3,m=Oe(b,17)^Oe(b,19)^b>>>10;Dt[l]=m+Dt[l-7]+v+Dt[l-16]|0}let{A:n,B:s,C:i,D:o,E:a,F:c,G:f,H:u}=this;for(let l=0;l<64;l++){let h=Oe(a,6)^Oe(a,11)^Oe(a,25),b=u+h+ya(a,c,f)+Jh[l]+Dt[l]|0,m=(Oe(n,2)^Oe(n,13)^Oe(n,22))+ba(n,s,i)|0;u=f,f=c,c=a,a=o+b|0,o=i,i=s,s=n,n=b+m|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,u=u+this.H|0,this.set(n,s,i,o,a,c,f,u)}roundClean(){Dt.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var jc=xn(()=>new po);function Zc(r){r.lowS!==void 0&&Pe("lowS",r.lowS),r.prehash!==void 0&&Pe("prehash",r.prehash)}function Xh(r){let e=zr(r);je(e,{a:"field",b:"field"},{allowedPrivateKeyLengths:"array",wrapPrivateKey:"boolean",isTorsionFree:"function",clearCofactor:"function",allowInfinityPoint:"boolean",fromBytes:"function",toBytes:"function"});let{endo:t,Fp:n,a:s}=e;if(t){if(!n.eql(s,n.ZERO))throw new Error("Endomorphism can only be defined for Koblitz curves that have a=0");if(typeof t!="object"||typeof t.beta!="bigint"||typeof t.splitScalar!="function")throw new Error("Expected endomorphism with beta: bigint and splitScalar: function")}return Object.freeze({...e})}var{bytesToNumberBE:Qh,hexToBytes:ed}=Bn,mt={Err:class extends Error{constructor(e=""){super(e)}},_tlv:{encode:(r,e)=>{let{Err:t}=mt;if(r<0||r>256)throw new t("tlv.encode: wrong tag");if(e.length&1)throw new t("tlv.encode: unpadded data");let n=e.length/2,s=Vt(n);if(s.length/2&128)throw new t("tlv.encode: long form length too big");let i=n>127?Vt(s.length/2|128):"";return`${Vt(r)}${i}${s}${e}`},decode(r,e){let{Err:t}=mt,n=0;if(r<0||r>256)throw new t("tlv.encode: wrong tag");if(e.length<2||e[n++]!==r)throw new t("tlv.decode: wrong tlv");let s=e[n++],i=!!(s&128),o=0;if(!i)o=s;else{let c=s&127;if(!c)throw new t("tlv.decode(long): indefinite length not supported");if(c>4)throw new t("tlv.decode(long): byte length is too big");let f=e.subarray(n,n+c);if(f.length!==c)throw new t("tlv.decode: length bytes not complete");if(f[0]===0)throw new t("tlv.decode(long): zero leftmost byte");for(let u of f)o=o<<8|u;if(n+=c,o<128)throw new t("tlv.decode(long): not minimal encoding")}let a=e.subarray(n,n+o);if(a.length!==o)throw new t("tlv.decode: wrong value length");return{v:a,l:e.subarray(n+o)}}},_int:{encode(r){let{Err:e}=mt;if(r<yt)throw new e("integer: negative integers are not allowed");let t=Vt(r);if(Number.parseInt(t[0],16)&8&&(t="00"+t),t.length&1)throw new e("unexpected assertion");return t},decode(r){let{Err:e}=mt;if(r[0]&128)throw new e("Invalid signature integer: negative");if(r[0]===0&&!(r[1]&128))throw new e("Invalid signature integer: unnecessary leading zero");return Qh(r)}},toSig(r){let{Err:e,_int:t,_tlv:n}=mt,s=typeof r=="string"?ed(r):r;br(s);let{v:i,l:o}=n.decode(48,s);if(o.length)throw new e("Invalid signature: left bytes after parsing");let{v:a,l:c}=n.decode(2,i),{v:f,l:u}=n.decode(2,c);if(u.length)throw new e("Invalid signature: left bytes after parsing");return{r:t.decode(a),s:t.decode(f)}},hexFromSig(r){let{_tlv:e,_int:t}=mt,n=`${e.encode(2,t.encode(r.r))}${e.encode(2,t.encode(r.s))}`;return e.encode(48,n)}},yt=BigInt(0),he=BigInt(1),Qm=BigInt(2),Wc=BigInt(3),ey=BigInt(4);function td(r){let e=Xh(r),{Fp:t}=e,n=It(e.n,e.nBitLength),s=e.toBytes||((m,d,y)=>{let x=d.toAffine();return at(Uint8Array.from([4]),t.toBytes(x.x),t.toBytes(x.y))}),i=e.fromBytes||(m=>{let d=m.subarray(1),y=t.fromBytes(d.subarray(0,t.BYTES)),x=t.fromBytes(d.subarray(t.BYTES,2*t.BYTES));return{x:y,y:x}});function o(m){let{a:d,b:y}=e,x=t.sqr(m),p=t.mul(x,m);return t.add(t.add(p,t.mul(m,d)),y)}if(!t.eql(t.sqr(e.Gy),o(e.Gx)))throw new Error("bad generator point: equation left != right");function a(m){return $r(m,he,e.n)}function c(m){let{allowedPrivateKeyLengths:d,nByteLength:y,wrapPrivateKey:x,n:p}=e;if(d&&typeof m!="bigint"){if(At(m)&&(m=it(m)),typeof m!="string"||!d.includes(m.length))throw new Error("Invalid key");m=m.padStart(y*2,"0")}let B;try{B=typeof m=="bigint"?m:ot(ee("private key",m,y))}catch{throw new Error(`private key must be ${y} bytes, hex or bigint, not ${typeof m}`)}return x&&(B=Y(B,p)),Ie("private key",B,he,p),B}function f(m){if(!(m instanceof h))throw new Error("ProjectivePoint expected")}let u=Kt((m,d)=>{let{px:y,py:x,pz:p}=m;if(t.eql(p,t.ONE))return{x:y,y:x};let B=m.is0();d==null&&(d=B?t.ONE:t.inv(p));let C=t.mul(y,d),L=t.mul(x,d),I=t.mul(p,d);if(B)return{x:t.ZERO,y:t.ZERO};if(!t.eql(I,t.ONE))throw new Error("invZ was invalid");return{x:C,y:L}}),l=Kt(m=>{if(m.is0()){if(e.allowInfinityPoint&&!t.is0(m.py))return;throw new Error("bad point: ZERO")}let{x:d,y}=m.toAffine();if(!t.isValid(d)||!t.isValid(y))throw new Error("bad point: x or y not FE");let x=t.sqr(y),p=o(d);if(!t.eql(x,p))throw new Error("bad point: equation left != right");if(!m.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});class h{constructor(d,y,x){if(this.px=d,this.py=y,this.pz=x,d==null||!t.isValid(d))throw new Error("x required");if(y==null||!t.isValid(y))throw new Error("y required");if(x==null||!t.isValid(x))throw new Error("z required");Object.freeze(this)}static fromAffine(d){let{x:y,y:x}=d||{};if(!d||!t.isValid(y)||!t.isValid(x))throw new Error("invalid affine point");if(d instanceof h)throw new Error("projective point not allowed");let p=B=>t.eql(B,t.ZERO);return p(y)&&p(x)?h.ZERO:new h(y,x,t.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(d){let y=t.invertBatch(d.map(x=>x.pz));return d.map((x,p)=>x.toAffine(y[p])).map(h.fromAffine)}static fromHex(d){let y=h.fromAffine(i(ee("pointHex",d)));return y.assertValidity(),y}static fromPrivateKey(d){return h.BASE.multiply(c(d))}static msm(d,y){return kn(h,n,d,y)}_setWindowSize(d){v.setWindowSize(this,d)}assertValidity(){l(this)}hasEvenY(){let{y:d}=this.toAffine();if(t.isOdd)return!t.isOdd(d);throw new Error("Field doesn't support isOdd")}equals(d){f(d);let{px:y,py:x,pz:p}=this,{px:B,py:C,pz:L}=d,I=t.eql(t.mul(y,L),t.mul(B,p)),R=t.eql(t.mul(x,L),t.mul(C,p));return I&&R}negate(){return new h(this.px,t.neg(this.py),this.pz)}double(){let{a:d,b:y}=e,x=t.mul(y,Wc),{px:p,py:B,pz:C}=this,L=t.ZERO,I=t.ZERO,R=t.ZERO,T=t.mul(p,p),ne=t.mul(B,B),F=t.mul(C,C),P=t.mul(p,B);return P=t.add(P,P),R=t.mul(p,C),R=t.add(R,R),L=t.mul(d,R),I=t.mul(x,F),I=t.add(L,I),L=t.sub(ne,I),I=t.add(ne,I),I=t.mul(L,I),L=t.mul(P,L),R=t.mul(x,R),F=t.mul(d,F),P=t.sub(T,F),P=t.mul(d,P),P=t.add(P,R),R=t.add(T,T),T=t.add(R,T),T=t.add(T,F),T=t.mul(T,P),I=t.add(I,T),F=t.mul(B,C),F=t.add(F,F),T=t.mul(F,P),L=t.sub(L,T),R=t.mul(F,ne),R=t.add(R,R),R=t.add(R,R),new h(L,I,R)}add(d){f(d);let{px:y,py:x,pz:p}=this,{px:B,py:C,pz:L}=d,I=t.ZERO,R=t.ZERO,T=t.ZERO,ne=e.a,F=t.mul(e.b,Wc),P=t.mul(y,B),se=t.mul(x,C),S=t.mul(p,L),N=t.add(y,x),w=t.add(B,C);N=t.mul(N,w),w=t.add(P,se),N=t.sub(N,w),w=t.add(y,p);let g=t.add(B,L);return w=t.mul(w,g),g=t.add(P,S),w=t.sub(w,g),g=t.add(x,p),I=t.add(C,L),g=t.mul(g,I),I=t.add(se,S),g=t.sub(g,I),T=t.mul(ne,w),I=t.mul(F,S),T=t.add(I,T),I=t.sub(se,T),T=t.add(se,T),R=t.mul(I,T),se=t.add(P,P),se=t.add(se,P),S=t.mul(ne,S),w=t.mul(F,w),se=t.add(se,S),S=t.sub(P,S),S=t.mul(ne,S),w=t.add(w,S),P=t.mul(se,w),R=t.add(R,P),P=t.mul(g,w),I=t.mul(N,I),I=t.sub(I,P),P=t.mul(N,se),T=t.mul(g,T),T=t.add(T,P),new h(I,R,T)}subtract(d){return this.add(d.negate())}is0(){return this.equals(h.ZERO)}wNAF(d){return v.wNAFCached(this,d,h.normalizeZ)}multiplyUnsafe(d){Ie("scalar",d,yt,e.n);let y=h.ZERO;if(d===yt)return y;if(d===he)return this;let{endo:x}=e;if(!x)return v.unsafeLadder(this,d);let{k1neg:p,k1:B,k2neg:C,k2:L}=x.splitScalar(d),I=y,R=y,T=this;for(;B>yt||L>yt;)B&he&&(I=I.add(T)),L&he&&(R=R.add(T)),T=T.double(),B>>=he,L>>=he;return p&&(I=I.negate()),C&&(R=R.negate()),R=new h(t.mul(R.px,x.beta),R.py,R.pz),I.add(R)}multiply(d){let{endo:y,n:x}=e;Ie("scalar",d,he,x);let p,B;if(y){let{k1neg:C,k1:L,k2neg:I,k2:R}=y.splitScalar(d),{p:T,f:ne}=this.wNAF(L),{p:F,f:P}=this.wNAF(R);T=v.constTimeNegate(C,T),F=v.constTimeNegate(I,F),F=new h(t.mul(F.px,y.beta),F.py,F.pz),p=T.add(F),B=ne.add(P)}else{let{p:C,f:L}=this.wNAF(d);p=C,B=L}return h.normalizeZ([p,B])[0]}multiplyAndAddUnsafe(d,y,x){let p=h.BASE,B=(L,I)=>I===yt||I===he||!L.equals(p)?L.multiplyUnsafe(I):L.multiply(I),C=B(this,y).add(B(d,x));return C.is0()?void 0:C}toAffine(d){return u(this,d)}isTorsionFree(){let{h:d,isTorsionFree:y}=e;if(d===he)return!0;if(y)return y(h,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h:d,clearCofactor:y}=e;return d===he?this:y?y(h,this):this.multiplyUnsafe(e.h)}toRawBytes(d=!0){return Pe("isCompressed",d),this.assertValidity(),s(h,this,d)}toHex(d=!0){return Pe("isCompressed",d),it(this.toRawBytes(d))}}h.BASE=new h(e.Gx,e.Gy,t.ONE),h.ZERO=new h(t.ZERO,t.ONE,t.ZERO);let b=e.nBitLength,v=Sn(h,e.endo?Math.ceil(b/2):b);return{CURVE:e,ProjectivePoint:h,normPrivateKeyToScalar:c,weierstrassEquation:o,isWithinCurveOrder:a}}function rd(r){let e=zr(r);return je(e,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...e})}function Jc(r){let e=rd(r),{Fp:t,n}=e,s=t.BYTES+1,i=2*t.BYTES+1;function o(S){return Y(S,n)}function a(S){return An(S,n)}let{ProjectivePoint:c,normPrivateKeyToScalar:f,weierstrassEquation:u,isWithinCurveOrder:l}=td({...e,toBytes(S,N,w){let g=N.toAffine(),E=t.toBytes(g.x),_=at;return Pe("isCompressed",w),w?_(Uint8Array.from([N.hasEvenY()?2:3]),E):_(Uint8Array.from([4]),E,t.toBytes(g.y))},fromBytes(S){let N=S.length,w=S[0],g=S.subarray(1);if(N===s&&(w===2||w===3)){let E=ot(g);if(!$r(E,he,t.ORDER))throw new Error("Point is not on curve");let _=u(E),U;try{U=t.sqrt(_)}catch(K){let M=K instanceof Error?": "+K.message:"";throw new Error("Point is not on curve"+M)}let D=(U&he)===he;return(w&1)===1!==D&&(U=t.neg(U)),{x:E,y:U}}else if(N===i&&w===4){let E=t.fromBytes(g.subarray(0,t.BYTES)),_=t.fromBytes(g.subarray(t.BYTES,2*t.BYTES));return{x:E,y:_}}else throw new Error(`Point of length ${N} was invalid. Expected ${s} compressed bytes or ${i} uncompressed bytes`)}}),h=S=>it(kt(S,e.nByteLength));function b(S){let N=n>>he;return S>N}function v(S){return b(S)?o(-S):S}let m=(S,N,w)=>ot(S.slice(N,w));class d{constructor(N,w,g){this.r=N,this.s=w,this.recovery=g,this.assertValidity()}static fromCompact(N){let w=e.nByteLength;return N=ee("compactSignature",N,w*2),new d(m(N,0,w),m(N,w,2*w))}static fromDER(N){let{r:w,s:g}=mt.toSig(ee("DER",N));return new d(w,g)}assertValidity(){Ie("r",this.r,he,n),Ie("s",this.s,he,n)}addRecoveryBit(N){return new d(this.r,this.s,N)}recoverPublicKey(N){let{r:w,s:g,recovery:E}=this,_=L(ee("msgHash",N));if(E==null||![0,1,2,3].includes(E))throw new Error("recovery id invalid");let U=E===2||E===3?w+e.n:w;if(U>=t.ORDER)throw new Error("recovery id 2 or 3 invalid");let D=E&1?"03":"02",V=c.fromHex(D+h(U)),K=a(U),M=o(-_*K),G=o(g*K),j=c.BASE.multiplyAndAddUnsafe(V,M,G);if(!j)throw new Error("point at infinify");return j.assertValidity(),j}hasHighS(){return b(this.s)}normalizeS(){return this.hasHighS()?new d(this.r,o(-this.s),this.recovery):this}toDERRawBytes(){return Mt(this.toDERHex())}toDERHex(){return mt.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return Mt(this.toCompactHex())}toCompactHex(){return h(this.r)+h(this.s)}}let y={isValidPrivateKey(S){try{return f(S),!0}catch{return!1}},normPrivateKeyToScalar:f,randomPrivateKey:()=>{let S=Ni(e.n);return ka(e.randomBytes(S),e.n)},precompute(S=8,N=c.BASE){return N._setWindowSize(S),N.multiply(BigInt(3)),N}};function x(S,N=!0){return c.fromPrivateKey(S).toRawBytes(N)}function p(S){let N=At(S),w=typeof S=="string",g=(N||w)&&S.length;return N?g===s||g===i:w?g===2*s||g===2*i:S instanceof c}function B(S,N,w=!0){if(p(S))throw new Error("first arg must be private key");if(!p(N))throw new Error("second arg must be public key");return c.fromHex(N).multiply(f(S)).toRawBytes(w)}let C=e.bits2int||function(S){let N=ot(S),w=S.length*8-e.nBitLength;return w>0?N>>BigInt(w):N},L=e.bits2int_modN||function(S){return o(C(S))},I=Gr(e.nBitLength);function R(S){return Ie(`num < 2^${e.nBitLength}`,S,yt,I),kt(S,e.nByteLength)}function T(S,N,w=ne){if(["recovered","canonical"].some(le=>le in w))throw new Error("sign() legacy options not supported");let{hash:g,randomBytes:E}=e,{lowS:_,prehash:U,extraEntropy:D}=w;_==null&&(_=!0),S=ee("msgHash",S),Zc(w),U&&(S=ee("prehashed msgHash",g(S)));let V=L(S),K=f(N),M=[R(K),R(V)];if(D!=null&&D!==!1){let le=D===!0?E(t.BYTES):D;M.push(ee("extraEntropy",le))}let G=at(...M),j=V;function ue(le){let de=C(le);if(!l(de))return;let ve=a(de),ie=c.BASE.multiply(de).toAffine(),ke=o(ie.x);if(ke===yt)return;let Qe=o(ve*o(j+ke*K));if(Qe===yt)return;let Tr=(ie.x===ke?0:2)|Number(ie.y&he),Lr=Qe;return _&&b(Qe)&&(Lr=v(Qe),Tr^=1),new d(ke,Lr,Tr)}return{seed:G,k2sig:ue}}let ne={lowS:e.lowS,prehash:!1},F={lowS:e.lowS,prehash:!1};function P(S,N,w=ne){let{seed:g,k2sig:E}=T(S,N,w),_=e;return Si(_.hash.outputLen,_.nByteLength,_.hmac)(g,E)}c.BASE._setWindowSize(8);function se(S,N,w,g=F){let E=S;if(N=ee("msgHash",N),w=ee("publicKey",w),"strict"in g)throw new Error("options.strict was renamed to lowS");Zc(g);let{lowS:_,prehash:U}=g,D,V;try{if(typeof E=="string"||At(E))try{D=d.fromDER(E)}catch(ie){if(!(ie instanceof mt.Err))throw ie;D=d.fromCompact(E)}else if(typeof E=="object"&&typeof E.r=="bigint"&&typeof E.s=="bigint"){let{r:ie,s:ke}=E;D=new d(ie,ke)}else throw new Error("PARSE");V=c.fromHex(w)}catch(ie){if(ie.message==="PARSE")throw new Error("signature must be Signature instance, Uint8Array or hex string");return!1}if(_&&D.hasHighS())return!1;U&&(N=e.hash(N));let{r:K,s:M}=D,G=L(N),j=a(M),ue=o(G*j),le=o(K*j),de=c.BASE.multiplyAndAddUnsafe(V,ue,le)?.toAffine();return de?o(de.x)===K:!1}return{CURVE:e,getPublicKey:x,getSharedSecret:B,sign:P,verify:se,ProjectivePoint:c,Signature:d,utils:y}}function nd(r){return{hash:r,hmac:(e,...t)=>Zr(r,e,yi(...t)),randomBytes:mr}}function Xc(r,e){let t=n=>Jc({...r,...nd(n)});return Object.freeze({...t(e),create:t})}var tu=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),Qc=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),sd=BigInt(1),go=BigInt(2),eu=(r,e)=>(r+e/go)/e;function id(r){let e=tu,t=BigInt(3),n=BigInt(6),s=BigInt(11),i=BigInt(22),o=BigInt(23),a=BigInt(44),c=BigInt(88),f=r*r*r%e,u=f*f*r%e,l=X(u,t,e)*u%e,h=X(l,t,e)*u%e,b=X(h,go,e)*f%e,v=X(b,s,e)*b%e,m=X(v,i,e)*v%e,d=X(m,a,e)*m%e,y=X(d,c,e)*d%e,x=X(y,a,e)*m%e,p=X(x,t,e)*u%e,B=X(p,o,e)*v%e,C=X(B,n,e)*f%e,L=X(C,go,e);if(!mo.eql(mo.sqr(L),r))throw new Error("Cannot find square root");return L}var mo=It(tu,void 0,void 0,{sqrt:id}),Ge=Xc({a:BigInt(0),b:BigInt(7),Fp:mo,n:Qc,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let e=Qc,t=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-sd*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),s=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),i=t,o=BigInt("0x100000000000000000000000000000000"),a=eu(i*r,e),c=eu(-n*r,e),f=Y(r-a*t-c*s,e),u=Y(-a*n-c*i,e),l=f>o,h=u>o;if(l&&(f=e-f),h&&(u=e-u),f>o||u>o)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:l,k1:f,k2neg:h,k2:u}}}},jc),uy=BigInt(0);var ly=Ge.ProjectivePoint;function ru(){return Ge.utils.randomPrivateKey()}function nu(r,e){let t=oe.digest(e instanceof Uint8Array?e:e.subarray());if(Ue(t))return t.then(({digest:n})=>Ge.sign(n,r).toDERRawBytes()).catch(n=>{throw new A(String(n),"ERR_INVALID_INPUT")});try{return Ge.sign(t.digest,r).toDERRawBytes()}catch(n){throw new A(String(n),"ERR_INVALID_INPUT")}}function su(r,e,t){let n=oe.digest(t instanceof Uint8Array?t:t.subarray());if(Ue(n))return n.then(({digest:s})=>Ge.verify(e,s,r)).catch(s=>{throw new A(String(s),"ERR_INVALID_INPUT")});try{return Ge.verify(e,n.digest,r)}catch(s){throw new A(String(s),"ERR_INVALID_INPUT")}}function iu(r){return Ge.ProjectivePoint.fromHex(r).toRawBytes(!0)}function ou(r){try{Ge.getPublicKey(r,!0)}catch(e){throw new A(String(e),"ERR_INVALID_PRIVATE_KEY")}}function yo(r){try{Ge.ProjectivePoint.fromHex(r)}catch(e){throw new A(String(e),"ERR_INVALID_PUBLIC_KEY")}}function au(r){try{return Ge.getPublicKey(r,!0)}catch(e){throw new A(String(e),"ERR_INVALID_PRIVATE_KEY")}}var Zt=class{_key;constructor(e){yo(e),this._key=e}verify(e,t){return su(this._key,t,e)}marshal(){return iu(this._key)}get bytes(){return Ke.encode({Type:Z.Secp256k1,Data:this.marshal()}).subarray()}equals(e){return ge(this.bytes,e.bytes)}async hash(){let e=oe.digest(this.bytes),t;return Ue(e)?{bytes:t}=await e:t=e.bytes,t}},Wt=class{_key;_publicKey;constructor(e,t){this._key=e,this._publicKey=t??au(e),ou(this._key),yo(this._publicKey)}sign(e){return nu(this._key,e)}get public(){return new Zt(this._publicKey)}marshal(){return this._key}get bytes(){return Fe.encode({Type:Z.Secp256k1,Data:this.marshal()}).subarray()}equals(e){return ge(this.bytes,e.bytes)}hash(){let e=oe.digest(this.bytes);return Ue(e)?e.then(({bytes:t})=>t):e.bytes}async id(){let e=await this.public.hash();return z(e,"base58btc")}async export(e,t="libp2p-key"){if(t==="libp2p-key")return vr(this.bytes,e);throw new A(`export format '${t}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function ad(r){return new Wt(r)}function cd(r){return new Zt(r)}async function ud(){let r=ru();return new Wt(r)}var bt={rsa:ho,ed25519:eo,secp256k1:bo};function wo(r){let e=Object.keys(bt).join(" / ");return new A(`invalid or unsupported key type ${r}. Must be ${e}`,"ERR_UNSUPPORTED_KEY_TYPE")}function xo(r){if(r=r.toLowerCase(),r==="rsa"||r==="ed25519"||r==="secp256k1")return bt[r];throw wo(r)}async function ld(r,e){return xo(r).generateKeyPair(e??2048)}async function fd(r,e,t){if(r.toLowerCase()!=="ed25519")throw new A("Seed key derivation is unimplemented for RSA or secp256k1","ERR_UNSUPPORTED_KEY_DERIVATION_TYPE");return Qi(e)}function hd(r){let e=Ke.decode(r),t=e.Data??new Uint8Array;switch(e.Type){case Z.RSA:return bt.rsa.unmarshalRsaPublicKey(t);case Z.Ed25519:return bt.ed25519.unmarshalEd25519PublicKey(t);case Z.Secp256k1:return bt.secp256k1.unmarshalSecp256k1PublicKey(t);default:throw wo(e.Type??"unknown")}}function dd(r,e){return e=(e??"rsa").toLowerCase(),xo(e),r.bytes}async function cu(r){let e=Fe.decode(r),t=e.Data??new Uint8Array;switch(e.Type){case Z.RSA:return bt.rsa.unmarshalRsaPrivateKey(t);case Z.Ed25519:return bt.ed25519.unmarshalEd25519PrivateKey(t);case Z.Secp256k1:return bt.secp256k1.unmarshalSecp256k1PrivateKey(t);default:throw wo(e.Type??"RSA")}}function pd(r,e){return e=(e??"rsa").toLowerCase(),xo(e),r.bytes}async function gd(r,e){try{let t=await Qa(r,e);return await cu(t)}catch{}if(!r.includes("BEGIN"))throw new A("Encrypted key was not a libp2p-key or a PEM file","ERR_INVALID_IMPORT_FORMAT");return uo(r,e)}var lu=Symbol.for("@achingbrain/uint8arraylist");function uu(r,e){if(e==null||e<0)throw new RangeError("index is out of bounds");let t=0;for(let n of r){let s=t+n.byteLength;if(e<s)return{buf:n,index:e-t};t=s}throw new RangeError("index is out of bounds")}function Bs(r){return!!r?.[lu]}var Ot=class r{bufs;length;[lu]=!0;constructor(...e){this.bufs=[],this.length=0,e.length>0&&this.appendAll(e)}*[Symbol.iterator](){yield*this.bufs}get byteLength(){return this.length}append(...e){this.appendAll(e)}appendAll(e){let t=0;for(let n of e)if(n instanceof Uint8Array)t+=n.byteLength,this.bufs.push(n);else if(Bs(n))t+=n.byteLength,this.bufs.push(...n.bufs);else throw new Error("Could not append value, must be an Uint8Array or a Uint8ArrayList");this.length+=t}prepend(...e){this.prependAll(e)}prependAll(e){let t=0;for(let n of e.reverse())if(n instanceof Uint8Array)t+=n.byteLength,this.bufs.unshift(n);else if(Bs(n))t+=n.byteLength,this.bufs.unshift(...n.bufs);else throw new Error("Could not prepend value, must be an Uint8Array or a Uint8ArrayList");this.length+=t}get(e){let t=uu(this.bufs,e);return t.buf[t.index]}set(e,t){let n=uu(this.bufs,e);n.buf[n.index]=t}write(e,t=0){if(e instanceof Uint8Array)for(let n=0;n<e.length;n++)this.set(t+n,e[n]);else if(Bs(e))for(let n=0;n<e.length;n++)this.set(t+n,e.get(n));else throw new Error("Could not write value, must be an Uint8Array or a Uint8ArrayList")}consume(e){if(e=Math.trunc(e),!(Number.isNaN(e)||e<=0)){if(e===this.byteLength){this.bufs=[],this.length=0;return}for(;this.bufs.length>0;)if(e>=this.bufs[0].byteLength)e-=this.bufs[0].byteLength,this.length-=this.bufs[0].byteLength,this.bufs.shift();else{this.bufs[0]=this.bufs[0].subarray(e),this.length-=e;break}}}slice(e,t){let{bufs:n,length:s}=this._subList(e,t);return Be(n,s)}subarray(e,t){let{bufs:n,length:s}=this._subList(e,t);return n.length===1?n[0]:Be(n,s)}sublist(e,t){let{bufs:n,length:s}=this._subList(e,t),i=new r;return i.length=s,i.bufs=[...n],i}_subList(e,t){if(e=e??0,t=t??this.length,e<0&&(e=this.length+e),t<0&&(t=this.length+t),e<0||t>this.length)throw new RangeError("index is out of bounds");if(e===t)return{bufs:[],length:0};if(e===0&&t===this.length)return{bufs:this.bufs,length:this.length};let n=[],s=0;for(let i=0;i<this.bufs.length;i++){let o=this.bufs[i],a=s,c=a+o.byteLength;if(s=c,e>=c)continue;let f=e>=a&&e<c,u=t>a&&t<=c;if(f&&u){if(e===a&&t===c){n.push(o);break}let l=e-a;n.push(o.subarray(l,l+(t-e)));break}if(f){if(e===0){n.push(o);continue}n.push(o.subarray(e-a));continue}if(u){if(t===c){n.push(o);break}n.push(o.subarray(0,t-a));break}n.push(o)}return{bufs:n,length:t-e}}indexOf(e,t=0){if(!Bs(e)&&!(e instanceof Uint8Array))throw new TypeError('The "value" argument must be a Uint8ArrayList or Uint8Array');let n=e instanceof Uint8Array?e:e.subarray();if(t=Number(t??0),isNaN(t)&&(t=0),t<0&&(t=this.length+t),t<0&&(t=0),e.length===0)return t>this.length?this.length:t;let s=n.byteLength;if(s===0)throw new TypeError("search must be at least 1 byte long");let i=256,o=new Int32Array(i);for(let l=0;l<i;l++)o[l]=-1;for(let l=0;l<s;l++)o[n[l]]=l;let a=o,c=this.byteLength-n.byteLength,f=n.byteLength-1,u;for(let l=t;l<=c;l+=u){u=0;for(let h=f;h>=0;h--){let b=this.get(l+h);if(n[h]!==b){u=Math.max(1,h-a[b]);break}}if(u===0)return l}return-1}getInt8(e){let t=this.subarray(e,e+1);return new DataView(t.buffer,t.byteOffset,t.byteLength).getInt8(0)}setInt8(e,t){let n=me(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setInt8(0,t),this.write(n,e)}getInt16(e,t){let n=this.subarray(e,e+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt16(0,t)}setInt16(e,t,n){let s=rt(2);new DataView(s.buffer,s.byteOffset,s.byteLength).setInt16(0,t,n),this.write(s,e)}getInt32(e,t){let n=this.subarray(e,e+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt32(0,t)}setInt32(e,t,n){let s=rt(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setInt32(0,t,n),this.write(s,e)}getBigInt64(e,t){let n=this.subarray(e,e+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigInt64(0,t)}setBigInt64(e,t,n){let s=rt(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigInt64(0,t,n),this.write(s,e)}getUint8(e){let t=this.subarray(e,e+1);return new DataView(t.buffer,t.byteOffset,t.byteLength).getUint8(0)}setUint8(e,t){let n=me(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setUint8(0,t),this.write(n,e)}getUint16(e,t){let n=this.subarray(e,e+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint16(0,t)}setUint16(e,t,n){let s=rt(2);new DataView(s.buffer,s.byteOffset,s.byteLength).setUint16(0,t,n),this.write(s,e)}getUint32(e,t){let n=this.subarray(e,e+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint32(0,t)}setUint32(e,t,n){let s=rt(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setUint32(0,t,n),this.write(s,e)}getBigUint64(e,t){let n=this.subarray(e,e+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigUint64(0,t)}setBigUint64(e,t,n){let s=rt(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigUint64(0,t,n),this.write(s,e)}getFloat32(e,t){let n=this.subarray(e,e+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat32(0,t)}setFloat32(e,t,n){let s=rt(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setFloat32(0,t,n),this.write(s,e)}getFloat64(e,t){let n=this.subarray(e,e+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat64(0,t)}setFloat64(e,t,n){let s=rt(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setFloat64(0,t,n),this.write(s,e)}equals(e){if(e==null||!(e instanceof r)||e.bufs.length!==this.bufs.length)return!1;for(let t=0;t<this.bufs.length;t++)if(!ge(this.bufs[t],e.bufs[t]))return!1;return!0}static fromUint8Arrays(e,t){let n=new r;return n.bufs=e,t==null&&(t=e.reduce((s,i)=>s+i.byteLength,0)),n.length=t,n}};function As(){let r={};return r.promise=new Promise((e,t)=>{r.resolve=e,r.reject=t}),r}var Ss=class{buffer;mask;top;btm;next;constructor(e){if(!(e>0)||e-1&e)throw new Error("Max size for a FixedFIFO should be a power of two");this.buffer=new Array(e),this.mask=e-1,this.top=0,this.btm=0,this.next=null}push(e){return this.buffer[this.top]!==void 0?!1:(this.buffer[this.top]=e,this.top=this.top+1&this.mask,!0)}shift(){let e=this.buffer[this.btm];if(e!==void 0)return this.buffer[this.btm]=void 0,this.btm=this.btm+1&this.mask,e}isEmpty(){return this.buffer[this.btm]===void 0}},Nr=class{size;hwm;head;tail;constructor(e={}){this.hwm=e.splitLimit??16,this.head=new Ss(this.hwm),this.tail=this.head,this.size=0}calculateSize(e){return e?.byteLength!=null?e.byteLength:1}push(e){if(e?.value!=null&&(this.size+=this.calculateSize(e.value)),!this.head.push(e)){let t=this.head;this.head=t.next=new Ss(2*this.head.buffer.length),this.head.push(e)}}shift(){let e=this.tail.shift();if(e===void 0&&this.tail.next!=null){let t=this.tail.next;this.tail.next=null,this.tail=t,e=this.tail.shift()}return e?.value!=null&&(this.size-=this.calculateSize(e.value)),e}isEmpty(){return this.head.isEmpty()}};var vo=class extends Error{type;code;constructor(e,t){super(e??"The operation was aborted"),this.type="aborted",this.code=t??"ABORT_ERR"}};function _r(r={}){return md(t=>{let n=t.shift();if(n==null)return{done:!0};if(n.error!=null)throw n.error;return{done:n.done===!0,value:n.value}},r)}function md(r,e){e=e??{};let t=e.onEnd,n=new Nr,s,i,o,a=As(),c=async()=>{try{return n.isEmpty()?o?{done:!0}:await new Promise((d,y)=>{i=x=>{i=null,n.push(x);try{d(r(n))}catch(p){y(p)}return s}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{a.resolve(),a=As()})}},f=d=>i!=null?i(d):(n.push(d),s),u=d=>(n=new Nr,i!=null?i({error:d}):(n.push({error:d}),s)),l=d=>{if(o)return s;if(e?.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})},h=d=>o?s:(o=!0,d!=null?u(d):f({done:!0})),b=()=>(n=new Nr,h(),{done:!0}),v=d=>(h(d),{done:!0});if(s={[Symbol.asyncIterator](){return this},next:c,return:b,throw:v,push:l,end:h,get readableLength(){return n.size},onEmpty:async d=>{let y=d?.signal;if(y?.throwIfAborted(),n.isEmpty())return;let x,p;y!=null&&(x=new Promise((B,C)=>{p=()=>{C(new vo)},y.addEventListener("abort",p)}));try{await Promise.race([a.promise,x])}finally{p!=null&&y!=null&&y?.removeEventListener("abort",p)}}},t==null)return s;let m=s;return s={[Symbol.asyncIterator](){return this},next(){return m.next()},throw(d){return m.throw(d),t!=null&&(t(d),t=void 0),{done:!0}},return(){return m.return(),t!=null&&(t(),t=void 0),{done:!0}},push:l,end(d){return m.end(d),t!=null&&(t(d),t=void 0),s},get readableLength(){return m.readableLength},onEmpty:d=>m.onEmpty(d)},s}function yd(r){return r[Symbol.asyncIterator]!=null}function bd(...r){let e=[];for(let t of r)yd(t)||e.push(t);return e.length===r.length?function*(){for(let t of e)yield*t}():async function*(){let t=_r({objectMode:!0});Promise.resolve().then(async()=>{try{await Promise.all(r.map(async n=>{for await(let s of n)t.push(s)})),t.end()}catch(n){t.end(n)}}),yield*t}()}var fu=bd;function an(r,...e){if(r==null)throw new Error("Empty pipeline");if(Eo(r)){let n=r;r=()=>n.source}else if(du(r)||hu(r)){let n=r;r=()=>n}let t=[r,...e];if(t.length>1&&Eo(t[t.length-1])&&(t[t.length-1]=t[t.length-1].sink),t.length>2)for(let n=1;n<t.length-1;n++)Eo(t[n])&&(t[n]=xd(t[n]));return wd(...t)}var wd=(...r)=>{let e;for(;r.length>0;)e=r.shift()(e);return e},hu=r=>r?.[Symbol.asyncIterator]!=null,du=r=>r?.[Symbol.iterator]!=null,Eo=r=>r==null?!1:r.sink!=null&&r.source!=null,xd=r=>e=>{let t=r.sink(e);if(t?.then!=null){let n=_r({objectMode:!0});t.then(()=>{n.end()},o=>{n.end(o)});let s,i=r.source;if(hu(i))s=async function*(){yield*i,n.end()};else if(du(i))s=function*(){yield*i,n.end()};else throw new Error("Unknown duplex source type - must be Iterable or AsyncIterable");return fu(n,s())}return r.source};var Ao=Mo(gu(),1);var un=class extends Error{constructor(e){super(e),this.name="TimeoutError"}},So=class extends Error{constructor(e){super(),this.name="AbortError",this.message=e}},mu=r=>globalThis.DOMException===void 0?new So(r):new DOMException(r),yu=r=>{let e=r.reason===void 0?mu("This operation was aborted."):r.reason;return e instanceof Error?e:mu(e)};function ko(r,e){let{milliseconds:t,fallback:n,message:s,customTimers:i={setTimeout,clearTimeout}}=e,o,c=new Promise((f,u)=>{if(typeof t!="number"||Math.sign(t)!==1)throw new TypeError(`Expected \`milliseconds\` to be a positive number, got \`${t}\``);if(e.signal){let{signal:h}=e;h.aborted&&u(yu(h)),h.addEventListener("abort",()=>{u(yu(h))})}if(t===Number.POSITIVE_INFINITY){r.then(f,u);return}let l=new un;o=i.setTimeout.call(void 0,()=>{if(n){try{f(n())}catch(h){u(h)}return}typeof r.cancel=="function"&&r.cancel(),s===!1?f():s instanceof Error?u(s):(l.message=s??`Promise timed out after ${t} milliseconds`,u(l))},t),(async()=>{try{f(await r)}catch(h){u(h)}})()}).finally(()=>{c.clear()});return c.clear=()=>{i.clearTimeout.call(void 0,o),o=void 0},c}function Io(r,e,t){let n=0,s=r.length;for(;s>0;){let i=Math.trunc(s/2),o=n+i;t(r[o],e)<=0?(n=++o,s-=i+1):s=i}return n}var ln=class{#e=[];enqueue(e,t){t={priority:0,...t};let n={priority:t.priority,run:e};if(this.size&&this.#e[this.size-1].priority>=t.priority){this.#e.push(n);return}let s=Io(this.#e,n,(i,o)=>o.priority-i.priority);this.#e.splice(s,0,n)}dequeue(){return this.#e.shift()?.run}filter(e){return this.#e.filter(t=>t.priority===e.priority).map(t=>t.run)}get size(){return this.#e.length}};var fn=class extends Ao.default{#e;#o;#i=0;#d;#a;#p=0;#r;#c;#t;#g;#n=0;#u;#s;#m;timeout;constructor(e){if(super(),e={carryoverConcurrencyCount:!1,intervalCap:Number.POSITIVE_INFINITY,interval:0,concurrency:Number.POSITIVE_INFINITY,autoStart:!0,queueClass:ln,...e},!(typeof e.intervalCap=="number"&&e.intervalCap>=1))throw new TypeError(`Expected \`intervalCap\` to be a number from 1 and up, got \`${e.intervalCap?.toString()??""}\` (${typeof e.intervalCap})`);if(e.interval===void 0||!(Number.isFinite(e.interval)&&e.interval>=0))throw new TypeError(`Expected \`interval\` to be a finite number >= 0, got \`${e.interval?.toString()??""}\` (${typeof e.interval})`);this.#e=e.carryoverConcurrencyCount,this.#o=e.intervalCap===Number.POSITIVE_INFINITY||e.interval===0,this.#d=e.intervalCap,this.#a=e.interval,this.#t=new e.queueClass,this.#g=e.queueClass,this.concurrency=e.concurrency,this.timeout=e.timeout,this.#m=e.throwOnTimeout===!0,this.#s=e.autoStart===!1}get#w(){return this.#o||this.#i<this.#d}get#x(){return this.#n<this.#u}#v(){this.#n--,this.#l(),this.emit("next")}#E(){this.#b(),this.#y(),this.#c=void 0}get#B(){let e=Date.now();if(this.#r===void 0){let t=this.#p-e;if(t<0)this.#i=this.#e?this.#n:0;else return this.#c===void 0&&(this.#c=setTimeout(()=>{this.#E()},t)),!0}return!1}#l(){if(this.#t.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 e=!this.#B;if(this.#w&&this.#x){let t=this.#t.dequeue();return t?(this.emit("active"),t(),e&&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.#e?this.#n:0,this.#f()}#f(){for(;this.#l(););}get concurrency(){return this.#u}set concurrency(e){if(!(typeof e=="number"&&e>=1))throw new TypeError(`Expected \`concurrency\` to be a number from 1 and up, got \`${e}\` (${typeof e})`);this.#u=e,this.#f()}async#A(e){return new Promise((t,n)=>{e.addEventListener("abort",()=>{n(e.reason)},{once:!0})})}async add(e,t={}){return t={timeout:this.timeout,throwOnTimeout:this.#m,...t},new Promise((n,s)=>{this.#t.enqueue(async()=>{this.#n++,this.#i++;try{t.signal?.throwIfAborted();let i=e({signal:t.signal});t.timeout&&(i=ko(Promise.resolve(i),{milliseconds:t.timeout})),t.signal&&(i=Promise.race([i,this.#A(t.signal)]));let o=await i;n(o),this.emit("completed",o)}catch(i){if(i instanceof un&&!t.throwOnTimeout){n();return}s(i),this.emit("error",i)}finally{this.#v()}},t),this.emit("add"),this.#l()})}async addAll(e,t){return Promise.all(e.map(async n=>this.add(n,t)))}start(){return this.#s?(this.#s=!1,this.#f(),this):this}pause(){this.#s=!0}clear(){this.#t=new this.#g}async onEmpty(){this.#t.size!==0&&await this.#h("empty")}async onSizeLessThan(e){this.#t.size<e||await this.#h("next",()=>this.#t.size<e)}async onIdle(){this.#n===0&&this.#t.size===0||await this.#h("idle")}async#h(e,t){return new Promise(n=>{let s=()=>{t&&!t()||(this.off(e,s),n())};this.on(e,s)})}get size(){return this.#t.size}sizeBy(e){return this.#t.filter(e).length}get pending(){return this.#n}get isPaused(){return this.#s}};var ce={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 bu(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 wu(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function xu(r,e){let t=bu(r).return?.();wu(t)&&t.catch(n=>{e.error("could not cause iterator to return",n)})}function Is(r){return r[Symbol.asyncIterator]!=null}var Rs=r=>{let e=Me(r),t=me(e);return Pa(r,t),Rs.bytes=e,t};Rs.bytes=0;function Ns(r,e){e=e??{};let t=e.lengthEncoder??Rs;function*n(s){let i=t(s.byteLength);i instanceof Uint8Array?yield i:yield*i,s instanceof Uint8Array?yield s:yield*s}return Is(r)?async function*(){for await(let s of r)yield*n(s)}():function*(){for(let s of r)yield*n(s)}()}Ns.single=(r,e)=>{e=e??{};let t=e.lengthEncoder??Rs;return new Ot(t(r.byteLength),r)};var _s=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},Ts=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},Ls=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"},hn=class extends Error{name="UnexpectedEOFError";code="ERR_UNEXPECTED_EOF"};var Bd=8,Ad=1024*1024*4,Jt;(function(r){r[r.LENGTH=0]="LENGTH",r[r.DATA=1]="DATA"})(Jt||(Jt={}));var Ro=r=>{let e=Va(r);return Ro.bytes=Me(e),e};Ro.bytes=0;function dn(r,e){let t=new Ot,n=Jt.LENGTH,s=-1,i=e?.lengthDecoder??Ro,o=e?.maxLengthLength??Bd,a=e?.maxDataLength??Ad;function*c(){for(;t.byteLength>0;){if(n===Jt.LENGTH)try{if(s=i(t),s<0)throw new _s("Invalid message length");if(s>a)throw new Ts("Message length too long");let f=i.bytes;t.consume(f),e?.onLength!=null&&e.onLength(s),n=Jt.DATA}catch(f){if(f instanceof RangeError){if(t.byteLength>o)throw new Ls("Message length length too long");break}throw f}if(n===Jt.DATA){if(t.byteLength<s)break;let f=t.sublist(0,s);t.consume(s),e?.onData!=null&&e.onData(f),yield f,n=Jt.LENGTH}}}return Is(r)?async function*(){for await(let f of r)t.append(f),yield*c();if(t.byteLength>0)throw new hn("Unexpected end of input")}():function*(){for(let f of r)t.append(f),yield*c();if(t.byteLength>0)throw new hn("Unexpected end of input")}()}dn.fromReader=(r,e)=>{let t=1,n=async function*(){for(;;)try{let{done:i,value:o}=await r.next(t);if(i===!0)return;o!=null&&(yield o)}catch(i){if(i.code==="ERR_UNDER_READ")return{done:!0,value:null};throw i}finally{t=1}}();return dn(n,{...e??{},onLength:i=>{t=i}})};var Cs=class extends Qt{id;protocol;outboundStream;inboundStream;_rawOutboundStream;_rawInboundStream;_inboundAbortController;closed;log;constructor(e,t){super(),this.log=e.logger.forComponent("libp2p-pubsub:peer-streams"),this.id=t.id,this.protocol=t.protocol,this._inboundAbortController=new AbortController,this.closed=!1}get isReadable(){return!!this.inboundStream}get isWritable(){return!!this.outboundStream}write(e){if(this.outboundStream==null){let t=this.id.toString();throw new Error("No writable connection to "+t)}this.outboundStream.push(e instanceof Uint8Array?new Ot(e):e)}attachInboundStream(e){let t=()=>{xu(e.source,this.log)};return this._inboundAbortController.signal.addEventListener("abort",t,{once:!0}),this._rawInboundStream=e,this.inboundStream=an(this._rawInboundStream,n=>dn(n)),this.dispatchEvent(new ze("stream:inbound")),this.inboundStream}async attachOutboundStream(e){let t=this.outboundStream;return this.outboundStream!=null&&this.outboundStream.end(),this._rawOutboundStream=e,this.outboundStream=_r({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 ze("close"))}}),an(this.outboundStream,n=>Ns(n),this._rawOutboundStream).catch(n=>{this.log.error(n)}),t==null&&this.dispatchEvent(new ze("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 ze("close")))}};function vu(){return BigInt(`0x${z(Ze(8),"base16")}`)}var Eu=(r,e)=>{let t=q(e.toString(16).padStart(16,"0"),"base16"),n=new Uint8Array(r.length+t.length);return n.set(r,0),n.set(t,r.length),n},Bu=r=>oe.encode(r);var Au=function(r){return Array.isArray(r)?r:[r]},kd=async r=>{if(r.sequenceNumber==null||r.from==null||r.signature==null)return!1;let e=Hr(r.from);return e.publicKey!=null?!0:r.key!=null?(await bn(r.key)).equals(e):!1},Su=async r=>{if(r.from==null)throw new A("RPC message was missing from",ce.ERR_MISSING_FROM);if(!await kd(r))return{type:"unsigned",topic:r.topic??"",data:r.data??new Uint8Array(0)};let e=Hr(r.from),t={type:"signed",from:Hr(r.from),topic:r.topic??"",sequenceNumber:Rd(r.sequenceNumber??new Uint8Array(0)),data:r.data??new Uint8Array(0),signature:r.signature??new Uint8Array(0),key:r.key??e.publicKey??new Uint8Array(0)};if(t.key.length===0)throw new A("Signed RPC message was missing key",ce.ERR_MISSING_KEY);return t},pn=r=>r.type==="signed"?{from:r.from.multihash.bytes,data:r.data,sequenceNumber:Id(r.sequenceNumber),topic:r.topic,signature:r.signature,key:r.key}:{data:r.data,topic:r.topic},Id=r=>{let e=r.toString(16);return e.length%2!==0&&(e=`0${e}`),q(e,"base16")},Rd=r=>BigInt(`0x${z(r,"base16")}`);var ku=q("libp2p-pubsub:");async function Iu(r,e,t){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:e.topic,data:e.data,sequenceNumber:e.sequenceNumber,from:r},s=Be([ku,t(pn(n)).subarray()]),i=await on.unmarshalPrivateKey(r.privateKey);return n.signature=await i.sign(s),n.key=r.publicKey,n}async function Ru(r,e){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 t=Be([ku,e({...pn(r),signature:void 0,key:void 0}).subarray()]),n=await Nd(r);return on.unmarshalPublicKey(n).verify(t,r.signature)}async function Nd(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 e=await bn(r.key);if(e.publicKey!=null)return e.publicKey}if(r.from.publicKey!=null)return r.from.publicKey;throw new Error("Could not get the public key from the originator id")}var Us=class extends Qt{log;started;topics;subscriptions;peers;globalSignaturePolicy;canRelayMessage;emitSelf;topicValidators;queue;multicodecs;components;_registrarTopologyIds;enabled;maxInboundStreams;maxOutboundStreams;constructor(e,t){super();let{multicodecs:n=[],globalSignaturePolicy:s="StrictSign",canRelayMessage:i=!1,emitSelf:o=!1,messageProcessingConcurrency:a=10,maxInboundStreams:c=1,maxOutboundStreams:f=1}=t;this.log=e.logger.forComponent("libp2p:pubsub"),this.components=e,this.multicodecs=Au(n),this.enabled=t.enabled!==!1,this.started=!1,this.topics=new Map,this.subscriptions=new Set,this.peers=new Kr,this.globalSignaturePolicy=s==="StrictNoSign"?"StrictNoSign":"StrictSign",this.canRelayMessage=i,this.emitSelf=o,this.topicValidators=new Map,this.queue=new fn({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 e=this.components.registrar;await Promise.all(this.multicodecs.map(async n=>{await e.handle(n,this._onIncomingStream,{maxInboundStreams:this.maxInboundStreams,maxOutboundStreams:this.maxOutboundStreams})}));let t={onConnect:this._onPeerConnected,onDisconnect:this._onPeerDisconnected};this._registrarTopologyIds=await Promise.all(this.multicodecs.map(async n=>e.register(n,t))),this.log("started"),this.started=!0}async stop(){if(!this.started||!this.enabled)return;let e=this.components.registrar;this._registrarTopologyIds!=null&&this._registrarTopologyIds?.forEach(t=>{e.unregister(t)}),await Promise.all(this.multicodecs.map(async t=>{await e.unhandle(t)})),this.log("stopping");for(let t of this.peers.values())t.close();this.peers.clear(),this.subscriptions=new Set,this.started=!1,this.log("stopped")}isStarted(){return this.started}_onIncomingStream(e){let{stream:t,connection:n}=e,s=n.remotePeer;if(t.protocol==null){t.abort(new Error("Stream was not multiplexed"));return}let i=this.addPeer(s,t.protocol),o=i.attachInboundStream(t);this.processMessages(s,o,i).catch(a=>{this.log(a)})}_onPeerConnected(e,t){if(this.log("connected %p",e),t.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",e);return}Promise.resolve().then(async()=>{try{let n=await t.newStream(this.multicodecs);if(n.protocol==null){n.abort(new Error("Stream was not multiplexed"));return}await this.addPeer(e,n.protocol).attachOutboundStream(n)}catch(n){this.log.error(n)}this.send(e,{subscriptions:Array.from(this.subscriptions).map(n=>n.toString()),subscribe:!0})}).catch(n=>{this.log.error(n)})}_onPeerDisconnected(e,t){let n=e.toString();this.log("connection ended",n),this._removePeer(e)}addPeer(e,t){let n=this.peers.get(e);if(n!=null)return n;this.log("new peer %p",e);let s=new Cs(this.components,{id:e,protocol:t});return this.peers.set(e,s),s.addEventListener("close",()=>this._removePeer(e),{once:!0}),s}_removePeer(e){let t=this.peers.get(e);if(t!=null){t.close(),this.log("delete peer %p",e),this.peers.delete(e);for(let n of this.topics.values())n.delete(e);return t}}async processMessages(e,t,n){try{await an(t,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",e);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(e,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(e,t,n){if(!this.acceptFrom(e))return this.log("received message from unacceptable peer %p",e),!1;this.log("rpc from %p",e);let{subscriptions:s,messages:i}=n;return s!=null&&s.length>0&&(this.log("subscription update from %p",e),s.forEach(o=>{this.processRpcSubOpt(e,o)}),super.dispatchEvent(new ze("subscription-change",{detail:{peerId:t.id,subscriptions:s.map(({topic:o,subscribe:a})=>({topic:`${o??""}`,subscribe:!!a}))}}))),i!=null&&i.length>0&&(this.log("messages from %p",e),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 Su(o);await this.processMessage(e,a)}catch(a){this.log.error(a)}})).catch(o=>{this.log(o)})),!0}processRpcSubOpt(e,t){let n=t.topic;if(n==null)return;let s=this.topics.get(n);s==null&&(s=new Fr,this.topics.set(n,s)),t.subscribe===!0?s.add(e):s.delete(e)}async processMessage(e,t){if(!(this.components.peerId.equals(e)&&!this.emitSelf)){try{await this.validate(e,t)}catch(n){this.log("Message is invalid, dropping it. %O",n);return}this.subscriptions.has(t.topic)&&(!this.components.peerId.equals(e)||this.emitSelf)&&super.dispatchEvent(new ze("message",{detail:t})),await this.publishMessage(e,t)}}getMsgId(e){switch(this.globalSignaturePolicy){case"StrictSign":if(e.type!=="signed")throw new A('Message type should be "signed" when signature policy is StrictSign but it was not',ce.ERR_MISSING_SIGNATURE);if(e.sequenceNumber==null)throw new A("Need seqno when signature policy is StrictSign but it was missing",ce.ERR_MISSING_SEQNO);if(e.key==null)throw new A("Need key when signature policy is StrictSign but it was missing",ce.ERR_MISSING_KEY);return Eu(e.key,e.sequenceNumber);case"StrictNoSign":return Bu(e.data);default:throw new A("Cannot get message id: unhandled signature policy",ce.ERR_UNHANDLED_SIGNATURE_POLICY)}}acceptFrom(e){return!0}send(e,t){let{messages:n,subscriptions:s,subscribe:i}=t;this.sendRpc(e,{subscriptions:(s??[]).map(o=>({topic:o,subscribe:!!i})),messages:(n??[]).map(pn)})}sendRpc(e,t){let n=this.peers.get(e);if(n==null){this.log.error("Cannot send RPC to %p as there are no streams to it available",e);return}if(!n.isWritable){this.log.error("Cannot send RPC to %p as there is no outbound stream to it available",e);return}n.write(this.encodeRpc(t))}async validate(e,t){switch(this.globalSignaturePolicy){case"StrictNoSign":if(t.type!=="unsigned")throw new A('Message type should be "unsigned" when signature policy is StrictNoSign but it was not',ce.ERR_MISSING_SIGNATURE);if(t.signature!=null)throw new A("StrictNoSigning: signature should not be present",ce.ERR_UNEXPECTED_SIGNATURE);if(t.key!=null)throw new A("StrictNoSigning: key should not be present",ce.ERR_UNEXPECTED_KEY);if(t.sequenceNumber!=null)throw new A("StrictNoSigning: seqno should not be present",ce.ERR_UNEXPECTED_SEQNO);break;case"StrictSign":if(t.type!=="signed")throw new A('Message type should be "signed" when signature policy is StrictSign but it was not',ce.ERR_MISSING_SIGNATURE);if(t.signature==null)throw new A("StrictSigning: Signing required and no signature was present",ce.ERR_MISSING_SIGNATURE);if(t.sequenceNumber==null)throw new A("StrictSigning: Signing required and no sequenceNumber was present",ce.ERR_MISSING_SEQNO);if(!await Ru(t,this.encodeMessage.bind(this)))throw new A("StrictSigning: Invalid message signature",ce.ERR_INVALID_SIGNATURE);break;default:throw new A("Cannot validate message: unhandled signature policy",ce.ERR_UNHANDLED_SIGNATURE_POLICY)}let s=this.topicValidators.get(t.topic);if(s!=null){let i=await s(e,t);if(i===Cr.Reject||i===Cr.Ignore)throw new A("Message validation failed",ce.ERR_TOPIC_VALIDATOR_REJECT)}}async buildMessage(e){switch(this.globalSignaturePolicy){case"StrictSign":return Iu(this.components.peerId,e,this.encodeMessage.bind(this));case"StrictNoSign":return Promise.resolve({type:"unsigned",...e});default:throw new A("Cannot build message: unhandled signature policy",ce.ERR_UNHANDLED_SIGNATURE_POLICY)}}getSubscribers(e){if(!this.started)throw new A("not started yet","ERR_NOT_STARTED_YET");if(e==null)throw new A("topic is required","ERR_NOT_VALID_TOPIC");let t=this.topics.get(e.toString());return t==null?[]:Array.from(t.values())}async publish(e,t){if(!this.started)throw new Error("Pubsub has not started");let n={from:this.components.peerId,topic:e,data:t??new Uint8Array(0),sequenceNumber:vu()};this.log("publish topic: %s from: %p data: %m",e,n.from,n.data);let s=await this.buildMessage(n),i=!1;this.emitSelf&&this.subscriptions.has(e)&&(i=!0,super.dispatchEvent(new ze("message",{detail:s})));let o=await this.publishMessage(this.components.peerId,s);return i&&(o.recipients=[...o.recipients,this.components.peerId]),o}subscribe(e){if(!this.started)throw new Error("Pubsub has not started");if(this.log("subscribe to topic: %s",e),!this.subscriptions.has(e)){this.subscriptions.add(e);for(let t of this.peers.keys())this.send(t,{subscriptions:[e],subscribe:!0})}}unsubscribe(e){if(!this.started)throw new Error("Pubsub is not started");super.removeEventListener(e);let t=this.subscriptions.has(e);if(this.log("unsubscribe from %s - am subscribed %s",e,t),t){this.subscriptions.delete(e);for(let n of this.peers.keys())this.send(n,{subscriptions:[e],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 Ds=class{entries;validityMs;lastPruneTime=0;constructor(e){this.entries=new Map,this.validityMs=e.validityMs}put(e,t){this.entries.set(e,{value:t,validUntilMs:Date.now()+this.validityMs}),this.prune()}prune(){let e=Date.now();if(!(e-this.lastPruneTime<200)){this.lastPruneTime=e;for(let[t,n]of this.entries.entries())if(n.validUntilMs<e)this.entries.delete(t);else break}}has(e){return this.entries.has(e)}get(e){let t=this.entries.get(e);return t!=null&&t.validUntilMs>=Date.now()?t.value:void 0}clear(){this.entries=new Map,this.lastPruneTime=0}};var No="/floodsub/1.0.0";var Xt;(function(r){let e;(function(s){let i;s.codec=()=>(i==null&&(i=Te((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 u=o.uint32();switch(u>>>3){case 1:c.subscribe=o.bool();break;case 2:c.topic=o.string();break;default:o.skipType(u&7);break}}return c})),i),s.encode=o=>_e(o,s.codec()),s.decode=o=>Ne(o,s.codec())})(e=r.SubOpts||(r.SubOpts={}));let t;(function(s){let i;s.codec=()=>(i==null&&(i=Te((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 u=o.uint32();switch(u>>>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(u&7);break}}return c})),i),s.encode=o=>_e(o,s.codec()),s.decode=o=>Ne(o,s.codec())})(t=r.Message||(r.Message={}));let n;r.codec=()=>(n==null&&(n=Te((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),Os.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=Os.codec().decode(s,s.uint32());break;default:s.skipType(c&7);break}}return o})),n),r.encode=s=>_e(s,r.codec()),r.decode=s=>Ne(s,r.codec())})(Xt||(Xt={}));var Os;(function(r){let e;r.codec=()=>(e==null&&(e=Te((t,n,s={})=>{if(s.lengthDelimited!==!1&&n.fork(),t.ihave!=null)for(let i of t.ihave)n.uint32(10),Ps.codec().encode(i,n);if(t.iwant!=null)for(let i of t.iwant)n.uint32(18),Vs.codec().encode(i,n);if(t.graft!=null)for(let i of t.graft)n.uint32(26),Ms.codec().encode(i,n);if(t.prune!=null)for(let i of t.prune)n.uint32(34),Hs.codec().encode(i,n);s.lengthDelimited!==!1&&n.ldelim()},(t,n)=>{let s={ihave:[],iwant:[],graft:[],prune:[]},i=n==null?t.len:t.pos+n;for(;t.pos<i;){let o=t.uint32();switch(o>>>3){case 1:s.ihave.push(Ps.codec().decode(t,t.uint32()));break;case 2:s.iwant.push(Vs.codec().decode(t,t.uint32()));break;case 3:s.graft.push(Ms.codec().decode(t,t.uint32()));break;case 4:s.prune.push(Hs.codec().decode(t,t.uint32()));break;default:t.skipType(o&7);break}}return s})),e),r.encode=t=>_e(t,r.codec()),r.decode=t=>Ne(t,r.codec())})(Os||(Os={}));var Ps;(function(r){let e;r.codec=()=>(e==null&&(e=Te((t,n,s={})=>{if(s.lengthDelimited!==!1&&n.fork(),t.topic!=null&&(n.uint32(10),n.string(t.topic)),t.messageIDs!=null)for(let i of t.messageIDs)n.uint32(18),n.bytes(i);s.lengthDelimited!==!1&&n.ldelim()},(t,n)=>{let s={messageIDs:[]},i=n==null?t.len:t.pos+n;for(;t.pos<i;){let o=t.uint32();switch(o>>>3){case 1:s.topic=t.string();break;case 2:s.messageIDs.push(t.bytes());break;default:t.skipType(o&7);break}}return s})),e),r.encode=t=>_e(t,r.codec()),r.decode=t=>Ne(t,r.codec())})(Ps||(Ps={}));var Vs;(function(r){let e;r.codec=()=>(e==null&&(e=Te((t,n,s={})=>{if(s.lengthDelimited!==!1&&n.fork(),t.messageIDs!=null)for(let i of t.messageIDs)n.uint32(10),n.bytes(i);s.lengthDelimited!==!1&&n.ldelim()},(t,n)=>{let s={messageIDs:[]},i=n==null?t.len:t.pos+n;for(;t.pos<i;){let o=t.uint32();switch(o>>>3){case 1:s.messageIDs.push(t.bytes());break;default:t.skipType(o&7);break}}return s})),e),r.encode=t=>_e(t,r.codec()),r.decode=t=>Ne(t,r.codec())})(Vs||(Vs={}));var Ms;(function(r){let e;r.codec=()=>(e==null&&(e=Te((t,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),t.topic!=null&&(n.uint32(10),n.string(t.topic)),s.lengthDelimited!==!1&&n.ldelim()},(t,n)=>{let s={},i=n==null?t.len:t.pos+n;for(;t.pos<i;){let o=t.uint32();switch(o>>>3){case 1:s.topic=t.string();break;default:t.skipType(o&7);break}}return s})),e),r.encode=t=>_e(t,r.codec()),r.decode=t=>Ne(t,r.codec())})(Ms||(Ms={}));var Hs;(function(r){let e;r.codec=()=>(e==null&&(e=Te((t,n,s={})=>{if(s.lengthDelimited!==!1&&n.fork(),t.topic!=null&&(n.uint32(10),n.string(t.topic)),t.peers!=null)for(let i of t.peers)n.uint32(18),Ks.codec().encode(i,n);t.backoff!=null&&(n.uint32(24),n.uint64(t.backoff)),s.lengthDelimited!==!1&&n.ldelim()},(t,n)=>{let s={peers:[]},i=n==null?t.len:t.pos+n;for(;t.pos<i;){let o=t.uint32();switch(o>>>3){case 1:s.topic=t.string();break;case 2:s.peers.push(Ks.codec().decode(t,t.uint32()));break;case 3:s.backoff=t.uint64();break;default:t.skipType(o&7);break}}return s})),e),r.encode=t=>_e(t,r.codec()),r.decode=t=>Ne(t,r.codec())})(Hs||(Hs={}));var Ks;(function(r){let e;r.codec=()=>(e==null&&(e=Te((t,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),t.peerID!=null&&(n.uint32(10),n.bytes(t.peerID)),t.signedPeerRecord!=null&&(n.uint32(18),n.bytes(t.signedPeerRecord)),s.lengthDelimited!==!1&&n.ldelim()},(t,n)=>{let s={},i=n==null?t.len:t.pos+n;for(;t.pos<i;){let o=t.uint32();switch(o>>>3){case 1:s.peerID=t.bytes();break;case 2:s.signedPeerRecord=t.bytes();break;default:t.skipType(o&7);break}}return s})),e),r.encode=t=>_e(t,r.codec()),r.decode=t=>Ne(t,r.codec())})(Ks||(Ks={}));var Fs=class extends Us{seenCache;constructor(e,t){super(e,{...t,canRelayMessage:!0,multicodecs:[No]}),this.log=e.logger.forComponent("libp2p:floodsub"),this.seenCache=new Ds({validityMs:t?.seenTTL??3e4})}[Symbol.toStringTag]="@libp2p/floodsub";[Ko]=["@libp2p/identify"];decodeRpc(e){return Xt.decode(e)}encodeRpc(e){return Xt.encode(e)}decodeMessage(e){return Xt.Message.decode(e)}encodeMessage(e){return Xt.Message.encode(e)}async processMessage(e,t){let n=await super.getMsgId(t),s=z(n,"base64");this.seenCache.has(s)||(this.seenCache.put(s,!0),await super.processMessage(e,t))}async publishMessage(e,t){let n=this.getSubscribers(t.topic),s=[];return n==null||n.length===0?(this.log("no peers are subscribed to topic %s",t.topic),{recipients:s}):(n.forEach(i=>{if(this.components.peerId.equals(i)){this.log("not sending message on topic %s to myself",t.topic);return}if(i.equals(e)){this.log("not sending message on topic %s to sender %p",t.topic,i);return}this.log("publish msgs on topics %s %p",t.topic,i),s.push(i),this.send(i,{messages:[t]})}),{recipients:s})}};function _d(r={}){return e=>new Fs(e,r)}return Fu(Td);})();
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.5-50b897139",
3
+ "version": "9.1.5-737b3ea5b",
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.7.0-50b897139",
64
- "@libp2p/pubsub": "9.0.26-50b897139",
63
+ "@libp2p/interface": "1.7.0-737b3ea5b",
64
+ "@libp2p/pubsub": "9.0.26-737b3ea5b",
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.12-50b897139",
71
- "@libp2p/logger": "4.0.20-50b897139",
72
- "@libp2p/peer-collections": "5.2.9-50b897139",
73
- "@libp2p/peer-id-factory": "4.2.4-50b897139",
70
+ "@libp2p/interface-compliance-tests": "5.4.12-737b3ea5b",
71
+ "@libp2p/logger": "4.0.20-737b3ea5b",
72
+ "@libp2p/peer-collections": "5.2.9-737b3ea5b",
73
+ "@libp2p/peer-id-factory": "4.2.4-737b3ea5b",
74
74
  "@multiformats/multiaddr": "^12.2.3",
75
75
  "@types/sinon": "^17.0.3",
76
76
  "aegir": "^44.0.1",