@libp2p/pubsub 9.0.26-2265e59ba → 9.0.26-2bbaf4361

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,9 @@
1
1
  (function (root, factory) {(typeof module === 'object' && module.exports) ? module.exports = factory() : root.Libp2PPubsub = factory()}(typeof self !== 'undefined' ? self : this, function () {
2
- "use strict";var Libp2PPubsub=(()=>{var Iu=Object.create;var fn=Object.defineProperty;var ku=Object.getOwnPropertyDescriptor;var Ru=Object.getOwnPropertyNames;var Nu=Object.getPrototypeOf,_u=Object.prototype.hasOwnProperty;var ko=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),et=(r,t)=>{for(var e in t)fn(r,e,{get:t[e],enumerable:!0})},Ro=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of Ru(t))!_u.call(r,s)&&s!==e&&fn(r,s,{get:()=>t[s],enumerable:!(n=ku(t,s))||n.enumerable});return r};var No=(r,t,e)=>(e=r!=null?Iu(Nu(r)):{},Ro(t||!r||!r.__esModule?fn(e,"default",{value:r,enumerable:!0}):e,r)),Tu=r=>Ro(fn({},"__esModule",{value:!0}),r);var Ga=ko(Er=>{"use strict";var gh="[object ArrayBuffer]",ae=class r{static isArrayBuffer(t){return Object.prototype.toString.call(t)===gh}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 c=this.toUint8Array(o);s.set(c,i),i+=c.length}return t[t.length-1]instanceof Function?this.toView(s,t[t.length-1]):s.buffer}},ji="string",yh=/^[0-9a-f]+$/i,mh=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,bh=/^[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=ae.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=ae.toArrayBuffer(t),s=new DataView(n),i="";for(let o=0;o<n.byteLength;o+=2){let c=s.getUint16(o,e);i+=String.fromCharCode(c)}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}},Un=class r{static isHex(t){return typeof t===ji&&yh.test(t)}static isBase64(t){return typeof t===ji&&mh.test(t)}static isBase64Url(t){return typeof t===ji&&bh.test(t)}static ToString(t,e="utf8"){let n=ae.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=ae.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=ae.toUint8Array(t),n="";for(let s=0;s<e.length;s++)n+=String.fromCharCode(e[s]);return n}static ToHex(t){let e=ae.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,"")||""}};Un.DEFAULT_UTF8_ENCODING="utf8";function wh(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 xh(...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 Eh(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=ae;Er.Convert=Un;Er.assign=wh;Er.combine=xh;Er.isEqual=Eh});var su=ko((gm,ho)=>{"use strict";var ld=Object.prototype.hasOwnProperty,St="~";function nn(){}Object.create&&(nn.prototype=Object.create(null),new nn().__proto__||(St=!1));function fd(r,t,e){this.fn=r,this.context=t,this.once=e||!1}function nu(r,t,e,n,s){if(typeof e!="function")throw new TypeError("The listener must be a function");var i=new fd(e,n||r,s),o=St?St+t:t;return r._events[o]?r._events[o].fn?r._events[o]=[r._events[o],i]:r._events[o].push(i):(r._events[o]=i,r._eventsCount++),r}function Ss(r,t){--r._eventsCount===0?r._events=new nn:delete r._events[t]}function xt(){this._events=new nn,this._eventsCount=0}xt.prototype.eventNames=function(){var t=[],e,n;if(this._eventsCount===0)return t;for(n in e=this._events)ld.call(e,n)&&t.push(St?n.slice(1):n);return Object.getOwnPropertySymbols?t.concat(Object.getOwnPropertySymbols(e)):t};xt.prototype.listeners=function(t){var e=St?St+t:t,n=this._events[e];if(!n)return[];if(n.fn)return[n.fn];for(var s=0,i=n.length,o=new Array(i);s<i;s++)o[s]=n[s].fn;return o};xt.prototype.listenerCount=function(t){var e=St?St+t:t,n=this._events[e];return n?n.fn?1:n.length:0};xt.prototype.emit=function(t,e,n,s,i,o){var c=St?St+t:t;if(!this._events[c])return!1;var a=this._events[c],f=arguments.length,l,u;if(a.fn){switch(a.once&&this.removeListener(t,a.fn,void 0,!0),f){case 1:return a.fn.call(a.context),!0;case 2:return a.fn.call(a.context,e),!0;case 3:return a.fn.call(a.context,e,n),!0;case 4:return a.fn.call(a.context,e,n,s),!0;case 5:return a.fn.call(a.context,e,n,s,i),!0;case 6:return a.fn.call(a.context,e,n,s,i,o),!0}for(u=1,l=new Array(f-1);u<f;u++)l[u-1]=arguments[u];a.fn.apply(a.context,l)}else{var h=a.length,b;for(u=0;u<h;u++)switch(a[u].once&&this.removeListener(t,a[u].fn,void 0,!0),f){case 1:a[u].fn.call(a[u].context);break;case 2:a[u].fn.call(a[u].context,e);break;case 3:a[u].fn.call(a[u].context,e,n);break;case 4:a[u].fn.call(a[u].context,e,n,s);break;default:if(!l)for(b=1,l=new Array(f-1);b<f;b++)l[b-1]=arguments[b];a[u].fn.apply(a[u].context,l)}}return!0};xt.prototype.on=function(t,e,n){return nu(this,t,e,n,!1)};xt.prototype.once=function(t,e,n){return nu(this,t,e,n,!0)};xt.prototype.removeListener=function(t,e,n,s){var i=St?St+t:t;if(!this._events[i])return this;if(!e)return Ss(this,i),this;var o=this._events[i];if(o.fn)o.fn===e&&(!s||o.once)&&(!n||o.context===n)&&Ss(this,i);else{for(var c=0,a=[],f=o.length;c<f;c++)(o[c].fn!==e||s&&!o[c].once||n&&o[c].context!==n)&&a.push(o[c]);a.length?this._events[i]=a.length===1?a[0]:a:Ss(this,i)}return this};xt.prototype.removeAllListeners=function(t){var e;return t?(e=St?St+t:t,this._events[e]&&Ss(this,e)):(this._events=new nn,this._eventsCount=0),this};xt.prototype.off=xt.prototype.removeListener;xt.prototype.addListener=xt.prototype.on;xt.prefixed=St;xt.EventEmitter=xt;typeof ho<"u"&&(ho.exports=xt)});var wd={};et(wd,{PubSubBaseProtocol:()=>wo});var Us=Symbol.for("@libp2p/peer-id");var Nr;(function(r){r.Accept="accept",r.Ignore="ignore",r.Reject="reject"})(Nr||(Nr={}));var A=class extends Error{code;props;constructor(t,e,n){super(t),this.code=e,this.name=n?.name??"CodeError",this.props=n??{}}};var _o=(r,...t)=>{try{[...t]}catch{}};var Ze=class extends EventTarget{#t=new Map;constructor(){super(),_o(1/0,this)}listenerCount(t){let e=this.#t.get(t);return e==null?0:e.length}addEventListener(t,e,n){super.addEventListener(t,e,n);let s=this.#t.get(t);s==null&&(s=[],this.#t.set(t,s)),s.push({callback:e,once:(n!==!0&&n!==!1&&n?.once)??!1})}removeEventListener(t,e,n){super.removeEventListener(t.toString(),e??null,n);let s=this.#t.get(t);s!=null&&(s=s.filter(({callback:i})=>i!==e),this.#t.set(t,s))}dispatchEvent(t){let e=super.dispatchEvent(t),n=this.#t.get(t.type);return n==null||(n=n.filter(({once:s})=>!s),this.#t.set(t.type,n)),e}safeDispatchEvent(t,e={}){return this.dispatchEvent(new qt(t,e))}},qt=globalThis.CustomEvent;var Hs={};et(Hs,{base58btc:()=>vt,base58flickr:()=>Ou});var kd=new Uint8Array(0);function To(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function Jt(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 Co(r){return new TextEncoder().encode(r)}function Lo(r){return new TextDecoder().decode(r)}function Cu(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 c=r.length,a=r.charAt(0),f=Math.log(c)/Math.log(256),l=Math.log(256)/Math.log(c);function u(E){if(E instanceof Uint8Array||(ArrayBuffer.isView(E)?E=new Uint8Array(E.buffer,E.byteOffset,E.byteLength):Array.isArray(E)&&(E=Uint8Array.from(E))),!(E instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(E.length===0)return"";for(var y=0,d=0,m=0,x=E.length;m!==x&&E[m]===0;)m++,y++;for(var p=(x-m)*l+1>>>0,B=new Uint8Array(p);m!==x;){for(var L=E[m],C=0,k=p-1;(L!==0||C<d)&&k!==-1;k--,C++)L+=256*B[k]>>>0,B[k]=L%c>>>0,L=L/c>>>0;if(L!==0)throw new Error("Non-zero carry");d=C,m++}for(var R=p-d;R!==p&&B[R]===0;)R++;for(var T=a.repeat(y);R<p;++R)T+=r.charAt(B[R]);return T}function h(E){if(typeof E!="string")throw new TypeError("Expected String");if(E.length===0)return new Uint8Array;var y=0;if(E[y]!==" "){for(var d=0,m=0;E[y]===a;)d++,y++;for(var x=(E.length-y)*f+1>>>0,p=new Uint8Array(x);E[y];){var B=e[E.charCodeAt(y)];if(B===255)return;for(var L=0,C=x-1;(B!==0||L<m)&&C!==-1;C--,L++)B+=c*p[C]>>>0,p[C]=B%256>>>0,B=B/256>>>0;if(B!==0)throw new Error("Non-zero carry");m=L,y++}if(E[y]!==" "){for(var k=x-m;k!==x&&p[k]===0;)k++;for(var R=new Uint8Array(d+(x-k)),T=d;k!==x;)R[T++]=p[k++];return R}}}function b(E){var y=h(E);if(y)return y;throw new Error(`Non-${t} character`)}return{encode:u,decodeUnsafe:h,decode:b}}var Lu=Cu,Uu=Lu,Do=Uu;var Ds=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")}},Ps=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 Po(this,t)}},Os=class{decoders;constructor(t){this.decoders=t}or(t){return Po(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 Po(r,t){return new Os({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var Vs=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 Ds(t,e,n),this.decoder=new Ps(t,e,s)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function We({name:r,prefix:t,encode:e,decode:n}){return new Vs(r,t,e,n)}function ye({name:r,prefix:t,alphabet:e}){let{encode:n,decode:s}=Do(e,r);return We({prefix:t,name:r,encode:n,decode:i=>Jt(s(i))})}function Du(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),c=0,a=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`);a=a<<e|u,c+=e,c>=8&&(c-=8,o[f++]=255&a>>c)}if(c>=e||255&a<<8-c)throw new SyntaxError("Unexpected end of data");return o}function Pu(r,t,e){let n=t[t.length-1]==="=",s=(1<<e)-1,i="",o=0,c=0;for(let a=0;a<r.length;++a)for(c=c<<8|r[a],o+=8;o>e;)o-=e,i+=t[s&c>>o];if(o!==0&&(i+=t[s&c<<e-o]),n)for(;i.length*e&7;)i+="=";return i}function Q({name:r,prefix:t,bitsPerChar:e,alphabet:n}){return We({prefix:t,name:r,encode(s){return Pu(s,n,e)},decode(s){return Du(s,n,e,r)}})}var vt=ye({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),Ou=ye({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Ms={};et(Ms,{base10:()=>Vu});var Vu=ye({prefix:"9",name:"base10",alphabet:"0123456789"});var Ks={};et(Ks,{base16:()=>Hu,base16upper:()=>Mu});var Hu=Q({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Mu=Q({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Fs={};et(Fs,{base2:()=>Ku});var Ku=Q({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var qs={};et(qs,{base256emoji:()=>zu});var Oo=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}"),Fu=Oo.reduce((r,t,e)=>(r[e]=t,r),[]),qu=Oo.reduce((r,t,e)=>(r[t.codePointAt(0)]=e,r),[]);function $u(r){return r.reduce((t,e)=>(t+=Fu[e],t),"")}function Gu(r){let t=[];for(let e of r){let n=qu[e.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${e}`);t.push(n)}return new Uint8Array(t)}var zu=We({prefix:"\u{1F680}",name:"base256emoji",encode:$u,decode:Gu});var $s={};et($s,{base32:()=>Je,base32hex:()=>Wu,base32hexpad:()=>Xu,base32hexpadupper:()=>Qu,base32hexupper:()=>Ju,base32pad:()=>Yu,base32padupper:()=>Zu,base32upper:()=>ju,base32z:()=>tl});var Je=Q({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),ju=Q({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Yu=Q({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),Zu=Q({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),Wu=Q({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),Ju=Q({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),Xu=Q({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),Qu=Q({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),tl=Q({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Gs={};et(Gs,{base36:()=>el,base36upper:()=>rl});var el=ye({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),rl=ye({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var zs={};et(zs,{base64:()=>_r,base64pad:()=>nl,base64url:()=>sl,base64urlpad:()=>il});var _r=Q({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),nl=Q({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),sl=Q({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),il=Q({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var js={};et(js,{base8:()=>ol});var ol=Q({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Ys={};et(Ys,{identity:()=>al});var al=We({prefix:"\0",name:"identity",encode:r=>Lo(r),decode:r=>Co(r)});var qd=new TextEncoder,$d=new TextDecoder;var Ws={};et(Ws,{identity:()=>Xt});var ll=Mo,Vo=128,fl=127,hl=~fl,dl=Math.pow(2,31);function Mo(r,t,e){t=t||[],e=e||0;for(var n=e;r>=dl;)t[e++]=r&255|Vo,r/=128;for(;r&hl;)t[e++]=r&255|Vo,r>>>=7;return t[e]=r|0,Mo.bytes=e-n+1,t}var pl=Zs,gl=128,Ho=127;function Zs(r,n){var e=0,n=n||0,s=0,i=n,o,c=r.length;do{if(i>=c)throw Zs.bytes=0,new RangeError("Could not decode varint");o=r[i++],e+=s<28?(o&Ho)<<s:(o&Ho)*Math.pow(2,s),s+=7}while(o>=gl);return Zs.bytes=i-n,e}var yl=Math.pow(2,7),ml=Math.pow(2,14),bl=Math.pow(2,21),wl=Math.pow(2,28),xl=Math.pow(2,35),El=Math.pow(2,42),vl=Math.pow(2,49),Bl=Math.pow(2,56),Al=Math.pow(2,63),Sl=function(r){return r<yl?1:r<ml?2:r<bl?3:r<wl?4:r<xl?5:r<El?6:r<vl?7:r<Bl?8:r<Al?9:10},Il={encode:ll,decode:pl,encodingLength:Sl},kl=Il,Tr=kl;function Cr(r,t=0){return[Tr.decode(r,t),Tr.decode.bytes]}function Xe(r,t,e=0){return Tr.encode(r,t,e),t}function Qe(r){return Tr.encodingLength(r)}function $t(r,t){let e=t.byteLength,n=Qe(r),s=n+Qe(e),i=new Uint8Array(s+e);return Xe(r,i,0),Xe(e,i,n),i.set(t,s),new tr(r,e,t,i)}function Lr(r){let t=Jt(r),[e,n]=Cr(t),[s,i]=Cr(t.subarray(n)),o=t.subarray(n+i);if(o.byteLength!==s)throw new Error("Incorrect length");return new tr(e,s,o,t)}function Ko(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&To(r.bytes,e.bytes)}}var tr=class{code;size;digest;bytes;constructor(t,e,n,s){this.code=t,this.size=e,this.digest=n,this.bytes=s}};var Fo=0,Rl="identity",qo=Jt;function Nl(r){return $t(Fo,qo(r))}var Xt={code:Fo,name:Rl,encode:qo,digest:Nl};var Qs={};et(Qs,{sha256:()=>ot,sha512:()=>_l});function Xs({name:r,code:t,encode:e}){return new Js(r,t,e)}var Js=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?$t(this.code,e):e.then(n=>$t(this.code,n))}else throw Error("Unknown type, must be binary type")}};function Go(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var ot=Xs({name:"sha2-256",code:18,encode:Go("SHA-256")}),_l=Xs({name:"sha2-512",code:19,encode:Go("SHA-512")});function zo(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return Cl(e,ti(r),t??vt.encoder);default:return Ll(e,ti(r),t??Je.encoder)}}var jo=new WeakMap;function ti(r){let t=jo.get(r);if(t==null){let e=new Map;return jo.set(r,e),e}return t}var me=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!==Ul)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=$t(t,e);return r.createV1(this.code,n)}case 1:return this;default:throw Error(`Can not convert CID version ${this.version} to version 1. This is a bug please report`)}}equals(t){return r.equals(this,t)}static equals(t,e){let n=e;return n!=null&&t.code===n.code&&t.version===n.version&&Ko(t.multihash,n.multihash)}toString(t){return zo(this,t)}toJSON(){return{"/":zo(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??Yo(n,s,i.bytes))}else if(e[Dl]===!0){let{version:n,multihash:s,code:i}=e,o=Lr(s);return r.create(n,i,o)}else return null}static create(t,e,n){if(typeof e!="number")throw new Error("String codecs are no longer supported");if(!(n.bytes instanceof Uint8Array))throw new Error("Invalid digest");switch(t){case 0:{if(e!==Ur)throw new Error(`Version 0 CID must use dag-pb (code: ${Ur}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let s=Yo(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=Jt(t.subarray(n,n+e.multihashSize));if(s.byteLength!==e.multihashSize)throw new Error("Incorrect length");let i=s.subarray(e.multihashSize-e.digestSize),o=new tr(e.multihashCode,e.digestSize,i,s);return[e.version===0?r.createV0(o):r.createV1(e.codec,o),t.subarray(e.size)]}static inspectBytes(t){let e=0,n=()=>{let[u,h]=Cr(t.subarray(e));return e+=h,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,c=n(),a=n(),f=e+a,l=f-o;return{version:s,codec:i,multihashCode:c,digestSize:a,multihashSize:l,size:f}}static parse(t,e){let[n,s]=Tl(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 ti(i).set(n,t),i}};function Tl(r,t){switch(r[0]){case"Q":{let e=t??vt;return[vt.prefix,e.decode(`${vt.prefix}${r}`)]}case vt.prefix:{let e=t??vt;return[vt.prefix,e.decode(r)]}case Je.prefix:{let e=t??Je;return[Je.prefix,e.decode(r)]}default:{if(t==null)throw Error("To parse non base32 or base58btc encoded CID multibase decoder must be provided");return[r[0],t.decode(r)]}}}function Cl(r,t,e){let{prefix:n}=e;if(n!==vt.prefix)throw Error(`Cannot string encode V0 in ${e.name} encoding`);let s=t.get(n);if(s==null){let i=e.encode(r).slice(1);return t.set(n,i),i}else return s}function Ll(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,Ul=18;function Yo(r,t,e){let n=Qe(r),s=n+Qe(t),i=new Uint8Array(s+e.byteLength);return Xe(r,i,0),Xe(t,i,n),i.set(e,s),i}var Dl=Symbol.for("@ipld/js-cid/CID");var rr={...Ys,...Fs,...js,...Ms,...Ks,...$s,...Gs,...Hs,...zs,...qs},f0={...Qs,...Ws};function gt(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=0){return new Uint8Array(r)}function yt(r=0){return new Uint8Array(r)}function Wo(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var Zo=Wo("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),ei=Wo("ascii","a",r=>{let t="a";for(let e=0;e<r.length;e++)t+=String.fromCharCode(r[e]);return t},r=>{r=r.substring(1);let t=yt(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),Pl={utf8:Zo,"utf-8":Zo,hex:rr.base16,latin1:ei,ascii:ei,binary:ei,...rr},dn=Pl;function q(r,t="utf8"){let e=dn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function Y(r,t="utf8"){let e=dn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}var Xo=Symbol.for("nodejs.util.inspect.custom"),Jo=Object.values(rr).map(r=>r.decoder).reduce((r,t)=>r.or(t),rr.identity.decoder),Qo=114,si=36,ii=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()})`}[Us]=!0;toString(){return this.string==null&&(this.string=vt.encode(this.multihash.bytes).slice(1)),this.string}toCID(){return me.createV1(Qo,this.multihash)}toBytes(){return this.multihash.bytes}toJSON(){return this.toString()}equals(t){if(t==null)return!1;if(t instanceof Uint8Array)return gt(this.multihash.bytes,t);if(typeof t=="string")return te(t).equals(this);if(t?.multihash?.bytes!=null)return gt(this.multihash.bytes,t.multihash.bytes);throw new Error("not valid Id")}[Xo](){return`PeerId(${this.toString()})`}},nr=class extends Dr{type="RSA";publicKey;constructor(t){super({...t,type:"RSA"}),this.publicKey=t.publicKey}},sr=class extends Dr{type="Ed25519";publicKey;constructor(t){super({...t,type:"Ed25519"}),this.publicKey=t.multihash.digest}},ir=class extends Dr{type="secp256k1";publicKey;constructor(t){super({...t,type:"secp256k1"}),this.publicKey=t.multihash.digest}},ri=2336,ni=class{type="url";multihash;privateKey;publicKey;url;constructor(t){this.url=t.toString(),this.multihash=Xt.digest(q(this.url))}[Xo](){return`PeerId(${this.url})`}[Us]=!0;toString(){return this.toCID().toString()}toCID(){return me.createV1(ri,this.multihash)}toBytes(){return this.toCID().bytes}equals(t){return t==null?!1:(t instanceof Uint8Array&&(t=Y(t)),t.toString()===this.toString())}};function te(r,t){if(t=t??Jo,r.charAt(0)==="1"||r.charAt(0)==="Q"){let e=Lr(vt.decode(`z${r}`));return r.startsWith("12D")?new sr({multihash:e}):r.startsWith("16U")?new ir({multihash:e}):new nr({multihash:e})}return Pr(Jo.decode(r))}function Pr(r){try{let t=Lr(r);if(t.code===Xt.code){if(t.digest.length===si)return new sr({multihash:t});if(t.digest.length===ii)return new ir({multihash:t})}if(t.code===ot.code)return new nr({multihash:t})}catch{return Ol(me.decode(r))}throw new Error("Supplied PeerID CID is invalid")}function Ol(r){if(r?.multihash==null||r.version==null||r.version===1&&r.code!==Qo&&r.code!==ri)throw new Error("Supplied PeerID CID is invalid");if(r.code===ri){let e=Y(r.multihash.digest);return new ni(new URL(e))}let t=r.multihash;if(t.code===ot.code)return new nr({multihash:r.multihash});if(t.code===Xt.code){if(t.digest.length===si)return new sr({multihash:r.multihash});if(t.digest.length===ii)return new ir({multihash:r.multihash})}throw new Error("Supplied PeerID CID is invalid")}async function pn(r,t){return r.length===si?new sr({multihash:$t(Xt.code,r),privateKey:t}):r.length===ii?new ir({multihash:$t(Xt.code,r),privateKey:t}):new nr({multihash:await ot.digest(r),publicKey:r,privateKey:t})}function or(r,t){let e={[Symbol.iterator]:()=>e,next:()=>{let n=r.next(),s=n.value;return n.done===!0||s==null?{done:!0,value:void 0}:{done:!1,value:t(s)}}};return e}var Or=class{map;constructor(t){if(this.map=new Map,t!=null)for(let[e,n]of t.entries())this.map.set(e.toString(),n)}[Symbol.iterator](){return this.entries()}clear(){this.map.clear()}delete(t){return this.map.delete(t.toString())}entries(){return or(this.map.entries(),t=>[te(t[0]),t[1]])}forEach(t){this.map.forEach((e,n)=>{t(e,te(n),this)})}get(t){return this.map.get(t.toString())}has(t){return this.map.has(t.toString())}set(t,e){this.map.set(t.toString(),e)}keys(){return or(this.map.keys(),t=>te(t))}values(){return this.map.values()}get size(){return this.map.size}};var Vr=class r{set;constructor(t){if(this.set=new Set,t!=null)for(let e of t)this.set.add(e.toString())}get size(){return this.set.size}[Symbol.iterator](){return this.values()}add(t){this.set.add(t.toString())}clear(){this.set.clear()}delete(t){this.set.delete(t.toString())}entries(){return or(this.set.entries(),t=>{let e=te(t[0]);return[e,e]})}forEach(t){this.set.forEach(e=>{let n=te(e);t(n,n,this)})}has(t){return this.set.has(t.toString())}values(){return or(this.set.values(),t=>te(t))}intersection(t){let e=new r;for(let n of t)this.has(n)&&e.add(n);return e}difference(t){let e=new r;for(let n of this)t.has(n)||e.add(n);return e}union(t){let e=new r;for(let n of t)e.add(n);for(let n of this)e.add(n);return e}};var W={get(r=globalThis){let t=r.crypto;if(t?.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 ta={SHA1:20,SHA256:32,SHA512:64};var Vl={SHA1:"SHA-1",SHA256:"SHA-256",SHA512:"SHA-512"},Hl=async(r,t)=>{let e=await W.get().subtle.sign({name:"HMAC"},r,t);return new Uint8Array(e,0,e.byteLength)};async function ea(r,t){let e=Vl[r],n=await W.get().subtle.importKey("raw",t,{name:"HMAC",hash:{name:e}},!1,["sign"]);return{async digest(s){return Hl(n,s)},length:ta[r]}}var en={};et(en,{Ed25519PrivateKey:()=>oe,Ed25519PublicKey:()=>Fe,MAX_RSA_KEY_SIZE:()=>Ge,RsaPrivateKey:()=>_e,RsaPublicKey:()=>$e,Secp256k1PrivateKey:()=>je,Secp256k1PublicKey:()=>ze,generateEphemeralKeyPair:()=>Ka,generateKeyPair:()=>Qh,generateKeyPairFromSeed:()=>td,importKey:()=>sd,keyStretcher:()=>$a,keysPBM:()=>wr,marshalPrivateKey:()=>nd,marshalPublicKey:()=>rd,supportedKeys:()=>ge,unmarshalPrivateKey:()=>Jc,unmarshalPublicKey:()=>ed});var $i={};et($i,{Ed25519PrivateKey:()=>oe,Ed25519PublicKey:()=>Fe,generateKeyPair:()=>uh,generateKeyPairFromSeed:()=>qi,unmarshalEd25519PrivateKey:()=>ah,unmarshalEd25519PublicKey:()=>ch});function Bt(r,t){t==null&&(t=r.reduce((s,i)=>s+i.length,0));let e=yt(t),n=0;for(let s of r)e.set(s,n),n+=s.length;return e}function oi(r,t){let e=q(r,"base64urlpad");if(t!=null){if(e.length>t)throw new Error("byte array longer than desired length");e=Bt([new Uint8Array(t-e.length),e])}return e}function Tt(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function ar(r){if(!Number.isSafeInteger(r)||r<0)throw new Error(`positive integer expected, not ${r}`)}function Kl(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function cr(r,...t){if(!Kl(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 gn(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");ar(r.outputLen),ar(r.blockLen)}function ur(r,t=!0){if(r.destroyed)throw new Error("Hash instance has been destroyed");if(t&&r.finished)throw new Error("Hash#digest() has already been called")}function ra(r,t){cr(r);let e=t.outputLen;if(r.length<e)throw new Error(`digestInto() expects output buffer of length at least ${e}`)}var Ue=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;var fr=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),Lt=(r,t)=>r<<32-t|r>>>t;var ep=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;var Fl=async()=>{};async function na(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 Fl(),n+=i)}}function sa(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=sa(r)),cr(r),r}function ai(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];cr(s),t+=s.length}let e=new Uint8Array(t);for(let n=0,s=0;n<r.length;n++){let i=r[n];e.set(i,s),s+=i.length}return e}var lr=class{clone(){return this._cloneInto()}},ql={}.toString;function ia(r,t){if(t!==void 0&&ql.call(t)!=="[object Object]")throw new Error("Options should be object or undefined");return Object.assign(r,t)}function yn(r){let t=n=>r().update(be(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function hr(r=32){if(Ue&&typeof Ue.getRandomValues=="function")return Ue.getRandomValues(new Uint8Array(r));if(Ue&&typeof Ue.randomBytes=="function")return Ue.randomBytes(r);throw new Error("crypto.getRandomValues must be defined")}function $l(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),c=Number(e&i),a=n?4:0,f=n?0:4;r.setUint32(t+a,o,n),r.setUint32(t+f,c,n)}var oa=(r,t,e)=>r&t^~r&e,aa=(r,t,e)=>r&t^r&e^t&e,dr=class extends lr{constructor(t,e,n,s){super(),this.blockLen=t,this.outputLen=e,this.padOffset=n,this.isLE=s,this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.buffer=new Uint8Array(t),this.view=fr(this.buffer)}update(t){ur(this);let{view:e,buffer:n,blockLen:s}=this;t=be(t);let i=t.length;for(let o=0;o<i;){let c=Math.min(s-this.pos,i-o);if(c===s){let a=fr(t);for(;s<=i-o;o+=s)this.process(a,o);continue}n.set(t.subarray(o,o+c),this.pos),this.pos+=c,o+=c,this.pos===s&&(this.process(e,0),this.pos=0)}return this.length+=t.length,this.roundClean(),this}digestInto(t){ur(this),ra(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;$l(n,s-8,BigInt(this.length*8),i),this.process(n,0);let c=fr(t),a=this.outputLen;if(a%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let f=a/4,l=this.get();if(f>l.length)throw new Error("_sha2: outputLen bigger than state");for(let u=0;u<f;u++)c.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:c}=this;return t.length=s,t.pos=c,t.finished=i,t.destroyed=o,s%e&&t.buffer.set(n),t}};var mn=BigInt(4294967295),ci=BigInt(32);function ca(r,t=!1){return t?{h:Number(r&mn),l:Number(r>>ci&mn)}:{h:Number(r>>ci&mn)|0,l:Number(r&mn)|0}}function Gl(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}=ca(r[s],t);[e[s],n[s]]=[i,o]}return[e,n]}var zl=(r,t)=>BigInt(r>>>0)<<ci|BigInt(t>>>0),jl=(r,t,e)=>r>>>e,Yl=(r,t,e)=>r<<32-e|t>>>e,Zl=(r,t,e)=>r>>>e|t<<32-e,Wl=(r,t,e)=>r<<32-e|t>>>e,Jl=(r,t,e)=>r<<64-e|t>>>e-32,Xl=(r,t,e)=>r>>>e-32|t<<64-e,Ql=(r,t)=>t,tf=(r,t)=>r,ef=(r,t,e)=>r<<e|t>>>32-e,rf=(r,t,e)=>t<<e|r>>>32-e,nf=(r,t,e)=>t<<e-32|r>>>64-e,sf=(r,t,e)=>r<<e-32|t>>>64-e;function of(r,t,e,n){let s=(t>>>0)+(n>>>0);return{h:r+e+(s/2**32|0)|0,l:s|0}}var af=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),cf=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,uf=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),lf=(r,t,e,n,s)=>t+e+n+s+(r/2**32|0)|0,ff=(r,t,e,n,s)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(s>>>0),hf=(r,t,e,n,s,i)=>t+e+n+s+i+(r/2**32|0)|0;var df={fromBig:ca,split:Gl,toBig:zl,shrSH:jl,shrSL:Yl,rotrSH:Zl,rotrSL:Wl,rotrBH:Jl,rotrBL:Xl,rotr32H:Ql,rotr32L:tf,rotlSH:ef,rotlSL:rf,rotlBH:nf,rotlBL:sf,add:of,add3L:af,add3H:cf,add4L:uf,add4H:lf,add5H:hf,add5L:ff},P=df;var[pf,gf]=P.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),ui=class extends dr{constructor(){super(128,64,16,!1),this.Ah=1779033703,this.Al=-205731576,this.Bh=-1150833019,this.Bl=-2067093701,this.Ch=1013904242,this.Cl=-23791573,this.Dh=-1521486534,this.Dl=1595750129,this.Eh=1359893119,this.El=-1377402159,this.Fh=-1694144372,this.Fl=725511199,this.Gh=528734635,this.Gl=-79577749,this.Hh=1541459225,this.Hl=327033209}get(){let{Ah:t,Al:e,Bh:n,Bl:s,Ch:i,Cl:o,Dh:c,Dl:a,Eh:f,El:l,Fh:u,Fl:h,Gh:b,Gl:E,Hh:y,Hl:d}=this;return[t,e,n,s,i,o,c,a,f,l,u,h,b,E,y,d]}set(t,e,n,s,i,o,c,a,f,l,u,h,b,E,y,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=c|0,this.Dl=a|0,this.Eh=f|0,this.El=l|0,this.Fh=u|0,this.Fl=h|0,this.Gh=b|0,this.Gl=E|0,this.Hh=y|0,this.Hl=d|0}process(t,e){for(let p=0;p<16;p++,e+=4)we[p]=t.getUint32(e),xe[p]=t.getUint32(e+=4);for(let p=16;p<80;p++){let B=we[p-15]|0,L=xe[p-15]|0,C=P.rotrSH(B,L,1)^P.rotrSH(B,L,8)^P.shrSH(B,L,7),k=P.rotrSL(B,L,1)^P.rotrSL(B,L,8)^P.shrSL(B,L,7),R=we[p-2]|0,T=xe[p-2]|0,nt=P.rotrSH(R,T,19)^P.rotrBH(R,T,61)^P.shrSH(R,T,6),F=P.rotrSL(R,T,19)^P.rotrBL(R,T,61)^P.shrSL(R,T,6),O=P.add4L(k,F,xe[p-7],xe[p-16]),st=P.add4H(O,C,nt,we[p-7],we[p-16]);we[p]=st|0,xe[p]=O|0}let{Ah:n,Al:s,Bh:i,Bl:o,Ch:c,Cl:a,Dh:f,Dl:l,Eh:u,El:h,Fh:b,Fl:E,Gh:y,Gl:d,Hh:m,Hl:x}=this;for(let p=0;p<80;p++){let B=P.rotrSH(u,h,14)^P.rotrSH(u,h,18)^P.rotrBH(u,h,41),L=P.rotrSL(u,h,14)^P.rotrSL(u,h,18)^P.rotrBL(u,h,41),C=u&b^~u&y,k=h&E^~h&d,R=P.add5L(x,L,k,gf[p],xe[p]),T=P.add5H(R,m,B,C,pf[p],we[p]),nt=R|0,F=P.rotrSH(n,s,28)^P.rotrBH(n,s,34)^P.rotrBH(n,s,39),O=P.rotrSL(n,s,28)^P.rotrBL(n,s,34)^P.rotrBL(n,s,39),st=n&i^n&c^i&c,S=s&o^s&a^o&a;m=y|0,x=d|0,y=b|0,d=E|0,b=u|0,E=h|0,{h:u,l:h}=P.add(f|0,l|0,T|0,nt|0),f=c|0,l=a|0,c=i|0,a=o|0,i=n|0,o=s|0;let N=P.add3L(nt,O,S);n=P.add3H(N,T,F,st),s=N|0}({h:n,l:s}=P.add(this.Ah|0,this.Al|0,n|0,s|0)),{h:i,l:o}=P.add(this.Bh|0,this.Bl|0,i|0,o|0),{h:c,l:a}=P.add(this.Ch|0,this.Cl|0,c|0,a|0),{h:f,l}=P.add(this.Dh|0,this.Dl|0,f|0,l|0),{h:u,l:h}=P.add(this.Eh|0,this.El|0,u|0,h|0),{h:b,l:E}=P.add(this.Fh|0,this.Fl|0,b|0,E|0),{h:y,l:d}=P.add(this.Gh|0,this.Gl|0,y|0,d|0),{h:m,l:x}=P.add(this.Hh|0,this.Hl|0,m|0,x|0),this.set(n,s,i,o,c,a,f,l,u,h,b,E,y,d,m,x)}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 Hr=yn(()=>new ui);var wn={};et(wn,{aInRange:()=>kt,abool:()=>Ut,abytes:()=>pr,bitGet:()=>Ef,bitLen:()=>pi,bitMask:()=>Kr,bitSet:()=>vf,bytesToHex:()=>re,bytesToNumberBE:()=>ne,bytesToNumberLE:()=>ve,concatBytes:()=>se,createHmacDrbg:()=>gi,ensureBytes:()=>tt,equalBytes:()=>wf,hexToBytes:()=>Pe,hexToNumber:()=>di,inRange:()=>Mr,isBytes:()=>Ee,memoized:()=>Ve,notImplemented:()=>Af,numberToBytesBE:()=>Be,numberToBytesLE:()=>Oe,numberToHexUnpadded:()=>De,numberToVarBytesBE:()=>bf,utf8ToBytes:()=>xf,validateObject:()=>Gt});var hi=BigInt(0),bn=BigInt(1),yf=BigInt(2);function Ee(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function pr(r){if(!Ee(r))throw new Error("Uint8Array expected")}function Ut(r,t){if(typeof t!="boolean")throw new Error(`${r} must be valid boolean, got "${t}".`)}var mf=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function re(r){pr(r);let t="";for(let e=0;e<r.length;e++)t+=mf[r[e]];return t}function De(r){let t=r.toString(16);return t.length&1?`0${t}`:t}function di(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return BigInt(r===""?"0":`0x${r}`)}var ee={_0:48,_9:57,_A:65,_F:70,_a:97,_f:102};function ua(r){if(r>=ee._0&&r<=ee._9)return r-ee._0;if(r>=ee._A&&r<=ee._F)return r-(ee._A-10);if(r>=ee._a&&r<=ee._f)return r-(ee._a-10)}function Pe(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);let t=r.length,e=t/2;if(t%2)throw new Error("padded hex string expected, got unpadded hex of length "+t);let n=new Uint8Array(e);for(let s=0,i=0;s<e;s++,i+=2){let o=ua(r.charCodeAt(i)),c=ua(r.charCodeAt(i+1));if(o===void 0||c===void 0){let a=r[i]+r[i+1];throw new Error('hex string expected, got non-hex character "'+a+'" at index '+i)}n[s]=o*16+c}return n}function ne(r){return di(re(r))}function ve(r){return pr(r),di(re(Uint8Array.from(r).reverse()))}function Be(r,t){return Pe(r.toString(16).padStart(t*2,"0"))}function Oe(r,t){return Be(r,t).reverse()}function bf(r){return Pe(De(r))}function tt(r,t,e){let n;if(typeof t=="string")try{n=Pe(t)}catch(i){throw new Error(`${r} must be valid hex string, got "${t}". Cause: ${i}`)}else if(Ee(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 se(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];pr(s),t+=s.length}let e=new Uint8Array(t);for(let n=0,s=0;n<r.length;n++){let i=r[n];e.set(i,s),s+=i.length}return e}function wf(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 xf(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}var li=r=>typeof r=="bigint"&&hi<=r;function Mr(r,t,e){return li(r)&&li(t)&&li(e)&&t<=r&&r<e}function kt(r,t,e,n){if(!Mr(t,e,n))throw new Error(`expected valid ${r}: ${e} <= n < ${n}, got ${typeof t} ${t}`)}function pi(r){let t;for(t=0;r>hi;r>>=bn,t+=1);return t}function Ef(r,t){return r>>BigInt(t)&bn}function vf(r,t,e){return r|(e?bn:hi)<<BigInt(t)}var Kr=r=>(yf<<BigInt(r-1))-bn,fi=r=>new Uint8Array(r),la=r=>Uint8Array.from(r);function gi(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=fi(r),s=fi(r),i=0,o=()=>{n.fill(1),s.fill(0),i=0},c=(...u)=>e(s,n,...u),a=(u=fi())=>{s=c(la([0]),u),n=c(),u.length!==0&&(s=c(la([1]),u),n=c())},f=()=>{if(i++>=1e3)throw new Error("drbg: tried 1000 values");let u=0,h=[];for(;u<t;){n=c();let b=n.slice();h.push(b),u+=n.length}return se(...h)};return(u,h)=>{o(),a(u);let b;for(;!(b=h(f()));)a();return o(),b}}var Bf={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"||Ee(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 Gt(r,t,e={}){let n=(s,i,o)=>{let c=Bf[i];if(typeof c!="function")throw new Error(`Invalid validator "${i}", expected function`);let a=r[s];if(!(o&&a===void 0)&&!c(a,r))throw new Error(`Invalid param ${String(s)}=${a} (${typeof a}), 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 Af=()=>{throw new Error("not implemented")};function Ve(r){let t=new WeakMap;return(e,...n)=>{let s=t.get(e);if(s!==void 0)return s;let i=r(e,...n);return t.set(e,i),i}}var at=BigInt(0),J=BigInt(1),He=BigInt(2),Sf=BigInt(3),yi=BigInt(4),fa=BigInt(5),ha=BigInt(8),If=BigInt(9),kf=BigInt(16);function z(r,t){let e=r%t;return e>=at?e:t+e}function Rf(r,t,e){if(e<=at||t<at)throw new Error("Expected power/modulo > 0");if(e===J)return at;let n=J;for(;t>at;)t&J&&(n=n*r%e),r=r*r%e,t>>=J;return n}function X(r,t,e){let n=r;for(;t-- >at;)n*=n,n%=e;return n}function xn(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=J,o=J,c=at;for(;e!==at;){let f=n/e,l=n%e,u=s-o*f,h=i-c*f;n=e,e=l,s=o,i=c,o=u,c=h}if(n!==J)throw new Error("invert: does not exist");return z(s,t)}function Nf(r){let t=(r-J)/He,e,n,s;for(e=r-J,n=0;e%He===at;e/=He,n++);for(s=He;s<r&&Rf(s,t,r)!==r-J;s++);if(n===1){let o=(r+J)/yi;return function(a,f){let l=a.pow(f,o);if(!a.eql(a.sqr(l),f))throw new Error("Cannot find square root");return l}}let i=(e+J)/He;return function(c,a){if(c.pow(a,t)===c.neg(c.ONE))throw new Error("Cannot find square root");let f=n,l=c.pow(c.mul(c.ONE,s),e),u=c.pow(a,i),h=c.pow(a,e);for(;!c.eql(h,c.ONE);){if(c.eql(h,c.ZERO))return c.ZERO;let b=1;for(let y=c.sqr(h);b<f&&!c.eql(y,c.ONE);b++)y=c.sqr(y);let E=c.pow(l,J<<BigInt(f-b-1));l=c.sqr(E),u=c.mul(u,E),h=c.mul(h,l),f=b}return u}}function _f(r){if(r%yi===Sf){let t=(r+J)/yi;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%ha===fa){let t=(r-fa)/ha;return function(n,s){let i=n.mul(s,He),o=n.pow(i,t),c=n.mul(s,o),a=n.mul(n.mul(c,He),o),f=n.mul(c,n.sub(a,n.ONE));if(!n.eql(n.sqr(f),s))throw new Error("Cannot find square root");return f}}return r%kf,Nf(r)}var da=(r,t)=>(z(r,t)&J)===J,Tf=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function mi(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=Tf.reduce((n,s)=>(n[s]="function",n),t);return Gt(r,e)}function Cf(r,t,e){if(e<at)throw new Error("Expected power > 0");if(e===at)return r.ONE;if(e===J)return t;let n=r.ONE,s=t;for(;e>at;)e&J&&(n=r.mul(n,s)),s=r.sqr(s),e>>=J;return n}function Lf(r,t){let e=new Array(t.length),n=t.reduce((i,o,c)=>r.is0(o)?i:(e[c]=i,r.mul(i,o)),r.ONE),s=r.inv(n);return t.reduceRight((i,o,c)=>r.is0(o)?i:(e[c]=r.mul(i,e[c]),r.mul(i,o)),s),e}function bi(r,t){let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function Ae(r,t,e=!1,n={}){if(r<=at)throw new Error(`Expected Field ORDER > 0, got ${r}`);let{nBitLength:s,nByteLength:i}=bi(r,t);if(i>2048)throw new Error("Field lengths over 2048 bytes are not supported");let o=_f(r),c=Object.freeze({ORDER:r,BITS:s,BYTES:i,MASK:Kr(s),ZERO:at,ONE:J,create:a=>z(a,r),isValid:a=>{if(typeof a!="bigint")throw new Error(`Invalid field element: expected bigint, got ${typeof a}`);return at<=a&&a<r},is0:a=>a===at,isOdd:a=>(a&J)===J,neg:a=>z(-a,r),eql:(a,f)=>a===f,sqr:a=>z(a*a,r),add:(a,f)=>z(a+f,r),sub:(a,f)=>z(a-f,r),mul:(a,f)=>z(a*f,r),pow:(a,f)=>Cf(c,a,f),div:(a,f)=>z(a*xn(f,r),r),sqrN:a=>a*a,addN:(a,f)=>a+f,subN:(a,f)=>a-f,mulN:(a,f)=>a*f,inv:a=>xn(a,r),sqrt:n.sqrt||(a=>o(c,a)),invertBatch:a=>Lf(c,a),cmov:(a,f,l)=>l?f:a,toBytes:a=>e?Oe(a,i):Be(a,i),fromBytes:a=>{if(a.length!==i)throw new Error(`Fp.fromBytes: expected ${i}, got ${a.length}`);return e?ve(a):ne(a)}});return Object.freeze(c)}function pa(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 wi(r){let t=pa(r);return t+Math.ceil(t/2)}function ga(r,t,e=!1){let n=r.length,s=pa(t),i=wi(t);if(n<16||n<i||n>1024)throw new Error(`expected ${i}-1024 bytes of input, got ${n}`);let o=e?ne(r):ve(r),c=z(o,t-J)+J;return e?Oe(c,s):Be(c,s)}var Df=BigInt(0),xi=BigInt(1),Ei=new WeakMap,ya=new WeakMap;function En(r,t){let e=(i,o)=>{let c=o.negate();return i?c: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,c=2**(i-1);return{windows:o,windowSize:c}};return{constTimeNegate:e,unsafeLadder(i,o){let c=r.ZERO,a=i;for(;o>Df;)o&xi&&(c=c.add(a)),a=a.double(),o>>=xi;return c},precomputeWindow(i,o){let{windows:c,windowSize:a}=s(o),f=[],l=i,u=l;for(let h=0;h<c;h++){u=l,f.push(u);for(let b=1;b<a;b++)u=u.add(l),f.push(u);l=u.double()}return f},wNAF(i,o,c){let{windows:a,windowSize:f}=s(i),l=r.ZERO,u=r.BASE,h=BigInt(2**i-1),b=2**i,E=BigInt(i);for(let y=0;y<a;y++){let d=y*f,m=Number(c&h);c>>=E,m>f&&(m-=b,c+=xi);let x=d,p=d+Math.abs(m)-1,B=y%2!==0,L=m<0;m===0?u=u.add(e(B,o[x])):l=l.add(e(L,o[p]))}return{p:l,f:u}},wNAFCached(i,o,c){let a=ya.get(i)||1,f=Ei.get(i);return f||(f=this.precomputeWindow(i,a),a!==1&&Ei.set(i,c(f))),this.wNAF(a,f,o)},setWindowSize(i,o){n(o),ya.set(i,o),Ei.delete(i)}}}function vn(r,t,e,n){if(!Array.isArray(e)||!Array.isArray(n)||n.length!==e.length)throw new Error("arrays of points and scalars must have equal length");n.forEach((l,u)=>{if(!t.isValid(l))throw new Error(`wrong scalar at index ${u}`)}),e.forEach((l,u)=>{if(!(l instanceof r))throw new Error(`wrong point at index ${u}`)});let s=pi(BigInt(e.length)),i=s>12?s-3:s>4?s-2:s?2:1,o=(1<<i)-1,c=new Array(o+1).fill(r.ZERO),a=Math.floor((t.BITS-1)/i)*i,f=r.ZERO;for(let l=a;l>=0;l-=i){c.fill(r.ZERO);for(let h=0;h<n.length;h++){let b=n[h],E=Number(b>>BigInt(l)&BigInt(o));c[E]=c[E].add(e[h])}let u=r.ZERO;for(let h=c.length-1,b=r.ZERO;h>0;h--)b=b.add(c[h]),u=u.add(b);if(f=f.add(u),l!==0)for(let h=0;h<i;h++)f=f.double()}return f}function Fr(r){return mi(r.Fp),Gt(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...bi(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Dt=BigInt(0),Rt=BigInt(1),Bn=BigInt(2),Pf=BigInt(8),Of={zip215:!0};function Vf(r){let t=Fr(r);return Gt(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function ma(r){let t=Vf(r),{Fp:e,n,prehash:s,hash:i,randomBytes:o,nByteLength:c,h:a}=t,f=Bn<<BigInt(c*8)-Rt,l=e.create,u=Ae(t.n,t.nBitLength),h=t.uvRatio||((w,g)=>{try{return{isValid:!0,value:e.sqrt(w*e.inv(g))}}catch{return{isValid:!1,value:Dt}}}),b=t.adjustScalarBytes||(w=>w),E=t.domain||((w,g,v)=>{if(Ut("phflag",v),g.length||v)throw new Error("Contexts/pre-hash are not supported");return w});function y(w,g){kt("coordinate "+w,g,Dt,f)}function d(w){if(!(w instanceof p))throw new Error("ExtendedPoint expected")}let m=Ve((w,g)=>{let{ex:v,ey:_,ez:U}=w,D=w.is0();g==null&&(g=D?Pf:e.inv(U));let V=l(v*g),K=l(_*g),H=l(U*g);if(D)return{x:Dt,y:Rt};if(H!==Rt)throw new Error("invZ was invalid");return{x:V,y:K}}),x=Ve(w=>{let{a:g,d:v}=t;if(w.is0())throw new Error("bad point: ZERO");let{ex:_,ey:U,ez:D,et:V}=w,K=l(_*_),H=l(U*U),G=l(D*D),j=l(G*G),ut=l(K*g),lt=l(G*l(ut+H)),dt=l(j+l(v*l(K*H)));if(lt!==dt)throw new Error("bad point: equation left != right (1)");let Et=l(_*U),it=l(D*V);if(Et!==it)throw new Error("bad point: equation left != right (2)");return!0});class p{constructor(g,v,_,U){this.ex=g,this.ey=v,this.ez=_,this.et=U,y("x",g),y("y",v),y("z",_),y("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:v,y:_}=g||{};return y("x",v),y("y",_),new p(v,_,Rt,l(v*_))}static normalizeZ(g){let v=e.invertBatch(g.map(_=>_.ez));return g.map((_,U)=>_.toAffine(v[U])).map(p.fromAffine)}static msm(g,v){return vn(p,u,g,v)}_setWindowSize(g){C.setWindowSize(this,g)}assertValidity(){x(this)}equals(g){d(g);let{ex:v,ey:_,ez:U}=this,{ex:D,ey:V,ez:K}=g,H=l(v*K),G=l(D*U),j=l(_*K),ut=l(V*U);return H===G&&j===ut}is0(){return this.equals(p.ZERO)}negate(){return new p(l(-this.ex),this.ey,this.ez,l(-this.et))}double(){let{a:g}=t,{ex:v,ey:_,ez:U}=this,D=l(v*v),V=l(_*_),K=l(Bn*l(U*U)),H=l(g*D),G=v+_,j=l(l(G*G)-D-V),ut=H+V,lt=ut-K,dt=H-V,Et=l(j*lt),it=l(ut*dt),It=l(j*dt),Wt=l(lt*ut);return new p(Et,it,Wt,It)}add(g){d(g);let{a:v,d:_}=t,{ex:U,ey:D,ez:V,et:K}=this,{ex:H,ey:G,ez:j,et:ut}=g;if(v===BigInt(-1)){let xo=l((D-U)*(G+H)),Eo=l((D+U)*(G-H)),Ls=l(Eo-xo);if(Ls===Dt)return this.double();let vo=l(V*Bn*ut),Bo=l(K*Bn*j),Ao=Bo+vo,So=Eo+xo,Io=Bo-vo,vu=l(Ao*Ls),Bu=l(So*Io),Au=l(Ao*Io),Su=l(Ls*So);return new p(vu,Bu,Su,Au)}let lt=l(U*H),dt=l(D*G),Et=l(K*_*ut),it=l(V*j),It=l((U+D)*(H+G)-lt-dt),Wt=it-Et,kr=it+Et,Rr=l(dt-v*lt),bu=l(It*Wt),wu=l(kr*Rr),xu=l(It*Rr),Eu=l(Wt*kr);return new p(bu,wu,Eu,xu)}subtract(g){return this.add(g.negate())}wNAF(g){return C.wNAFCached(this,g,p.normalizeZ)}multiply(g){let v=g;kt("scalar",v,Rt,n);let{p:_,f:U}=this.wNAF(v);return p.normalizeZ([_,U])[0]}multiplyUnsafe(g){let v=g;return kt("scalar",v,Dt,n),v===Dt?L:this.equals(L)||v===Rt?this:this.equals(B)?this.wNAF(v).p:C.unsafeLadder(this,v)}isSmallOrder(){return this.multiplyUnsafe(a).is0()}isTorsionFree(){return C.unsafeLadder(this,n).is0()}toAffine(g){return m(this,g)}clearCofactor(){let{h:g}=t;return g===Rt?this:this.multiplyUnsafe(g)}static fromHex(g,v=!1){let{d:_,a:U}=t,D=e.BYTES;g=tt("pointHex",g,D),Ut("zip215",v);let V=g.slice(),K=g[D-1];V[D-1]=K&-129;let H=ve(V),G=v?f:e.ORDER;kt("pointHex.y",H,Dt,G);let j=l(H*H),ut=l(j-Rt),lt=l(_*j-U),{isValid:dt,value:Et}=h(ut,lt);if(!dt)throw new Error("Point.fromHex: invalid y coordinate");let it=(Et&Rt)===Rt,It=(K&128)!==0;if(!v&&Et===Dt&&It)throw new Error("Point.fromHex: x=0 and x_0=1");return It!==it&&(Et=l(-Et)),p.fromAffine({x:Et,y:H})}static fromPrivateKey(g){return T(g).point}toRawBytes(){let{x:g,y:v}=this.toAffine(),_=Oe(v,e.BYTES);return _[_.length-1]|=g&Rt?128:0,_}toHex(){return re(this.toRawBytes())}}p.BASE=new p(t.Gx,t.Gy,Rt,l(t.Gx*t.Gy)),p.ZERO=new p(Dt,Rt,Rt,Dt);let{BASE:B,ZERO:L}=p,C=En(p,c*8);function k(w){return z(w,n)}function R(w){return k(ve(w))}function T(w){let g=c;w=tt("private key",w,g);let v=tt("hashed private key",i(w),2*g),_=b(v.slice(0,g)),U=v.slice(g,2*g),D=R(_),V=B.multiply(D),K=V.toRawBytes();return{head:_,prefix:U,scalar:D,point:V,pointBytes:K}}function nt(w){return T(w).pointBytes}function F(w=new Uint8Array,...g){let v=se(...g);return R(i(E(v,tt("context",w),!!s)))}function O(w,g,v={}){w=tt("message",w),s&&(w=s(w));let{prefix:_,scalar:U,pointBytes:D}=T(g),V=F(v.context,_,w),K=B.multiply(V).toRawBytes(),H=F(v.context,K,D,w),G=k(V+H*U);kt("signature.s",G,Dt,n);let j=se(K,Oe(G,e.BYTES));return tt("result",j,c*2)}let st=Of;function S(w,g,v,_=st){let{context:U,zip215:D}=_,V=e.BYTES;w=tt("signature",w,2*V),g=tt("message",g),D!==void 0&&Ut("zip215",D),s&&(g=s(g));let K=ve(w.slice(V,2*V)),H,G,j;try{H=p.fromHex(v,D),G=p.fromHex(w.slice(0,V),D),j=B.multiplyUnsafe(K)}catch{return!1}if(!D&&H.isSmallOrder())return!1;let ut=F(U,G.toRawBytes(),H.toRawBytes(),g);return G.add(H.multiplyUnsafe(ut)).subtract(j).clearCofactor().equals(p.ZERO)}return B._setWindowSize(8),{CURVE:t,getPublicKey:nt,sign:O,verify:S,ExtendedPoint:p,utils:{getExtendedPublicKey:T,randomPrivateKey:()=>o(e.BYTES),precompute(w=8,g=p.BASE){return g._setWindowSize(w),g.multiply(BigInt(3)),g}}}}var vi=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),ba=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),Ap=BigInt(0),Hf=BigInt(1),wa=BigInt(2),Sp=BigInt(3),Mf=BigInt(5),Kf=BigInt(8);function Ff(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),s=BigInt(80),i=vi,c=r*r%i*r%i,a=X(c,wa,i)*c%i,f=X(a,Hf,i)*r%i,l=X(f,Mf,i)*f%i,u=X(l,t,i)*l%i,h=X(u,e,i)*u%i,b=X(h,n,i)*h%i,E=X(b,s,i)*b%i,y=X(E,s,i)*b%i,d=X(y,t,i)*l%i;return{pow_p_5_8:X(d,wa,i)*r%i,b2:c}}function qf(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function $f(r,t){let e=vi,n=z(t*t*t,e),s=z(n*n*t,e),i=Ff(r*s).pow_p_5_8,o=z(r*n*i,e),c=z(t*o*o,e),a=o,f=z(o*ba,e),l=c===r,u=c===z(-r,e),h=c===z(-r*ba,e);return l&&(o=a),(u||h)&&(o=f),da(o,e)&&(o=z(-o,e)),{isValid:l||u,value:o}}var Gf=Ae(vi,void 0,!0),zf={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:Gf,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:Kf,Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:Hr,randomBytes:hr,adjustScalarBytes:qf,uvRatio:$f},gr=ma(zf);var yr=32,ie=64,An=32;function xa(){let r=gr.utils.randomPrivateKey(),t=gr.getPublicKey(r);return{privateKey:Aa(r,t),publicKey:t}}function Ea(r){if(r.length!==An)throw new TypeError('"seed" must be 32 bytes in length.');if(!(r instanceof Uint8Array))throw new TypeError('"seed" must be a node.js Buffer, or Uint8Array.');let t=r,e=gr.getPublicKey(t);return{privateKey:Aa(t,e),publicKey:e}}function va(r,t){let e=r.subarray(0,An);return gr.sign(t instanceof Uint8Array?t:t.subarray(),e)}function Ba(r,t,e){return gr.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}function Aa(r,t){let e=new Uint8Array(ie);for(let n=0;n<An;n++)e[n]=r[n],e[An+n]=t[n];return e}var Bi={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function Sn(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,c=W.get();e*=8;async function a(u,h){let b=c.getRandomValues(new Uint8Array(i)),E=c.getRandomValues(new Uint8Array(n)),y={name:t,iv:E};typeof h=="string"&&(h=q(h));let d;if(h.length===0){d=await c.subtle.importKey("jwk",Bi,{name:"AES-GCM"},!0,["encrypt"]);try{let x={name:"PBKDF2",salt:b,iterations:o,hash:{name:s}},p=await c.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);d=await c.subtle.deriveKey(x,p,{name:t,length:e},!0,["encrypt"])}catch{d=await c.subtle.importKey("jwk",Bi,{name:"AES-GCM"},!0,["encrypt"])}}else{let x={name:"PBKDF2",salt:b,iterations:o,hash:{name:s}},p=await c.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);d=await c.subtle.deriveKey(x,p,{name:t,length:e},!0,["encrypt"])}let m=await c.subtle.encrypt(y,d,u);return Bt([b,y.iv,new Uint8Array(m)])}async function f(u,h){let b=u.subarray(0,i),E=u.subarray(i,i+n),y=u.subarray(i+n),d={name:t,iv:E};typeof h=="string"&&(h=q(h));let m;if(h.length===0)try{let p={name:"PBKDF2",salt:b,iterations:o,hash:{name:s}},B=await c.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);m=await c.subtle.deriveKey(p,B,{name:t,length:e},!0,["decrypt"])}catch{m=await c.subtle.importKey("jwk",Bi,{name:"AES-GCM"},!0,["decrypt"])}else{let p={name:"PBKDF2",salt:b,iterations:o,hash:{name:s}},B=await c.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);m=await c.subtle.deriveKey(p,B,{name:t,length:e},!0,["decrypt"])}let x=await c.subtle.decrypt(d,m,y);return new Uint8Array(x)}return{encrypt:a,decrypt:f}}async function mr(r,t){let n=await Sn().encrypt(r,t);return _r.encode(n)}var wr={};et(wr,{KeyType:()=>Z,PrivateKey:()=>Ht,PublicKey:()=>Vt});var Yf=Math.pow(2,7),Zf=Math.pow(2,14),Wf=Math.pow(2,21),Ai=Math.pow(2,28),Si=Math.pow(2,35),Ii=Math.pow(2,42),ki=Math.pow(2,49),$=128,mt=127;function Pt(r){if(r<Yf)return 1;if(r<Zf)return 2;if(r<Wf)return 3;if(r<Ai)return 4;if(r<Si)return 5;if(r<Ii)return 6;if(r<ki)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function Ri(r,t,e=0){switch(Pt(r)){case 8:t[e++]=r&255|$,r/=128;case 7:t[e++]=r&255|$,r/=128;case 6:t[e++]=r&255|$,r/=128;case 5:t[e++]=r&255|$,r/=128;case 4:t[e++]=r&255|$,r>>>=7;case 3:t[e++]=r&255|$,r>>>=7;case 2:t[e++]=r&255|$,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function Jf(r,t,e=0){switch(Pt(r)){case 8:t.set(e++,r&255|$),r/=128;case 7:t.set(e++,r&255|$),r/=128;case 6:t.set(e++,r&255|$),r/=128;case 5:t.set(e++,r&255|$),r/=128;case 4:t.set(e++,r&255|$),r>>>=7;case 3:t.set(e++,r&255|$),r>>>=7;case 2:t.set(e++,r&255|$),r>>>=7;case 1:{t.set(e++,r&255),r>>>=7;break}default:throw new Error("unreachable")}return t}function Ni(r,t){let e=r[t],n=0;if(n+=e&mt,e<$||(e=r[t+1],n+=(e&mt)<<7,e<$)||(e=r[t+2],n+=(e&mt)<<14,e<$)||(e=r[t+3],n+=(e&mt)<<21,e<$)||(e=r[t+4],n+=(e&mt)*Ai,e<$)||(e=r[t+5],n+=(e&mt)*Si,e<$)||(e=r[t+6],n+=(e&mt)*Ii,e<$)||(e=r[t+7],n+=(e&mt)*ki,e<$))return n;throw new RangeError("Could not decode varint")}function Xf(r,t){let e=r.get(t),n=0;if(n+=e&mt,e<$||(e=r.get(t+1),n+=(e&mt)<<7,e<$)||(e=r.get(t+2),n+=(e&mt)<<14,e<$)||(e=r.get(t+3),n+=(e&mt)<<21,e<$)||(e=r.get(t+4),n+=(e&mt)*Ai,e<$)||(e=r.get(t+5),n+=(e&mt)*Si,e<$)||(e=r.get(t+6),n+=(e&mt)*Ii,e<$)||(e=r.get(t+7),n+=(e&mt)*ki,e<$))return n;throw new RangeError("Could not decode varint")}function Ia(r,t,e=0){return t==null&&(t=yt(Pt(r))),t instanceof Uint8Array?Ri(r,t,e):Jf(r,t,e)}function ka(r,t=0){return r instanceof Uint8Array?Ni(r,t):Xf(r,t)}var _i=new Float32Array([-0]),Se=new Uint8Array(_i.buffer);function Na(r,t,e){_i[0]=r,t[e]=Se[0],t[e+1]=Se[1],t[e+2]=Se[2],t[e+3]=Se[3]}function _a(r,t){return Se[0]=r[t],Se[1]=r[t+1],Se[2]=r[t+2],Se[3]=r[t+3],_i[0]}var Ti=new Float64Array([-0]),bt=new Uint8Array(Ti.buffer);function Ta(r,t,e){Ti[0]=r,t[e]=bt[0],t[e+1]=bt[1],t[e+2]=bt[2],t[e+3]=bt[3],t[e+4]=bt[4],t[e+5]=bt[5],t[e+6]=bt[6],t[e+7]=bt[7]}function Ca(r,t){return bt[0]=r[t],bt[1]=r[t+1],bt[2]=r[t+2],bt[3]=r[t+3],bt[4]=r[t+4],bt[5]=r[t+5],bt[6]=r[t+6],bt[7]=r[t+7],Ti[0]}var Qf=BigInt(Number.MAX_SAFE_INTEGER),th=BigInt(Number.MIN_SAFE_INTEGER),_t=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<Qf&&t>th)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>La&&(s=0n,++n>La&&(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 _t(0,0);Me.toBigInt=function(){return 0n};Me.zzEncode=Me.zzDecode=function(){return this};Me.length=function(){return 1};var La=4294967296n;function Ua(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 Da(r,t,e){if(e-t<1)return"";let s,i=[],o=0,c;for(;t<e;)c=r[t++],c<128?i[o++]=c:c>191&&c<224?i[o++]=(c&31)<<6|r[t++]&63:c>239&&c<365?(c=((c&7)<<18|(r[t++]&63)<<12|(r[t++]&63)<<6|r[t++]&63)-65536,i[o++]=55296+(c>>10),i[o++]=56320+(c&1023)):i[o++]=(c&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 Ci(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 Ot(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function In(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var Li=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,Ot(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 Ot(this,4);return In(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Ot(this,4);return In(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Ot(this,4);let t=_a(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Ot(this,4);let t=Ca(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 Ot(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return Da(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw Ot(this,t);this.pos+=t}else do if(this.pos>=this.len)throw Ot(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 _t(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 Ot(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 Ot(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 Ot(this,8);let t=In(this.buf,this.pos+=4),e=In(this.buf,this.pos+=4);return new _t(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=Ni(this.buf,this.pos);return this.pos+=Pt(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 Ui(r){return new Li(r instanceof Uint8Array?r:r.subarray())}function kn(r,t,e){let n=Ui(r);return t.decode(n,void 0,e)}function Di(r){let t=r??8192,e=t>>>1,n,s=t;return function(o){if(o<1||o>e)return yt(o);s+o>t&&(n=yt(t),s=0);let c=n.subarray(s,s+=o);return s&7&&(s=(s|7)+1),c}}var Ke=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function Pi(){}var Vi=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},eh=Di();function rh(r){return globalThis.Buffer!=null?yt(r):eh(r)}var $r=class{len;head;tail;states;constructor(){this.len=0,this.head=new Ke(Pi,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new Ke(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new Hi((t=t>>>0)<128?1:t<16384?2:t<2097152?3:t<268435456?4:5,t)).len,this}int32(t){return t<0?this._push(Rn,10,_t.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=_t.fromBigInt(t);return this._push(Rn,e.length(),e)}uint64Number(t){return this._push(Ri,Pt(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=_t.fromBigInt(t).zzEncode();return this._push(Rn,e.length(),e)}sint64Number(t){let e=_t.fromNumber(t).zzEncode();return this._push(Rn,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(Oi,1,t?1:0)}fixed32(t){return this._push(qr,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=_t.fromBigInt(t);return this._push(qr,4,e.lo)._push(qr,4,e.hi)}fixed64Number(t){let e=_t.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(Na,4,t)}double(t){return this._push(Ta,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(Oi,1,0):this.uint32(e)._push(sh,e,t)}string(t){let e=Ua(t);return e!==0?this.uint32(e)._push(Ci,e,t):this._push(Oi,1,0)}fork(){return this.states=new Vi(this),this.head=this.tail=new Ke(Pi,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 Ke(Pi,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=rh(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function Oi(r,t,e){t[e]=r&255}function nh(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var Hi=class extends Ke{next;constructor(t,e){super(nh,t,e),this.next=void 0}};function Rn(r,t,e){for(;r.hi!==0;)t[e++]=r.lo&127|128,r.lo=(r.lo>>>7|r.hi<<25)>>>0,r.hi>>>=7;for(;r.lo>127;)t[e++]=r.lo&127|128,r.lo=r.lo>>>7;t[e++]=r.lo}function qr(r,t,e){t[e]=r&255,t[e+1]=r>>>8&255,t[e+2]=r>>>16&255,t[e+3]=r>>>24}function sh(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(ih,t,r),this},$r.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(oh,t,r),this});function ih(r,t,e){t.set(r,e)}function oh(r,t,e){r.length<40?Ci(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(q(r),e)}function Mi(){return new $r}function Nn(r,t){let e=Mi();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var br;(function(r){r[r.VARINT=0]="VARINT",r[r.BIT64=1]="BIT64",r[r.LENGTH_DELIMITED=2]="LENGTH_DELIMITED",r[r.START_GROUP=3]="START_GROUP",r[r.END_GROUP=4]="END_GROUP",r[r.BIT32=5]="BIT32"})(br||(br={}));function _n(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function Ki(r){function t(s){if(r[s.toString()]==null)throw new Error("Invalid enum value");return r[s]}let e=function(i,o){let c=t(i);o.int32(c)},n=function(i){let o=i.int32();return t(o)};return _n("enum",br.VARINT,e,n)}function Tn(r,t){return _n("message",br.LENGTH_DELIMITED,r,t)}var Z;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.Secp256k1="Secp256k1"})(Z||(Z={}));var Fi;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.Secp256k1=2]="Secp256k1"})(Fi||(Fi={}));(function(r){r.codec=()=>Ki(Fi)})(Z||(Z={}));var Vt;(function(r){let t;r.codec=()=>(t==null&&(t=Tn((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),Z.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let s={},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let o=e.uint32();switch(o>>>3){case 1:s.Type=Z.codec().decode(e);break;case 2:s.Data=e.bytes();break;default:e.skipType(o&7);break}}return s})),t),r.encode=e=>Nn(e,r.codec()),r.decode=e=>kn(e,r.codec())})(Vt||(Vt={}));var Ht;(function(r){let t;r.codec=()=>(t==null&&(t=Tn((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),Z.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let s={},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let o=e.uint32();switch(o>>>3){case 1:s.Type=Z.codec().decode(e);break;case 2:s.Data=e.bytes();break;default:e.skipType(o&7);break}}return s})),t),r.encode=e=>Nn(e,r.codec()),r.decode=e=>kn(e,r.codec())})(Ht||(Ht={}));var Fe=class{_key;constructor(t){this._key=xr(t,yr)}verify(t,e){return Ba(this._key,e,t)}marshal(){return this._key}get bytes(){return Vt.encode({Type:Z.Ed25519,Data:this.marshal()}).subarray()}equals(t){return gt(this.bytes,t.bytes)}hash(){let t=ot.digest(this.bytes);return Tt(t)?t.then(({bytes:e})=>e):t.bytes}},oe=class{_key;_publicKey;constructor(t,e){this._key=xr(t,ie),this._publicKey=xr(e,yr)}sign(t){return va(this._key,t)}get public(){return new Fe(this._publicKey)}marshal(){return this._key}get bytes(){return Ht.encode({Type:Z.Ed25519,Data:this.marshal()}).subarray()}equals(t){return gt(this.bytes,t.bytes)}async hash(){let t=ot.digest(this.bytes),e;return Tt(t)?{bytes:e}=await t:e=t.bytes,e}async id(){let t=Xt.digest(this.public.bytes);return vt.encode(t.bytes).substring(1)}async export(t,e="libp2p-key"){if(e==="libp2p-key")return mr(this.bytes,t);throw new A(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function ah(r){if(r.length>ie){r=xr(r,ie+yr);let n=r.subarray(0,ie),s=r.subarray(ie,r.length);return new oe(n,s)}r=xr(r,ie);let t=r.subarray(0,ie),e=r.subarray(yr);return new oe(t,e)}function ch(r){return r=xr(r,yr),new Fe(r)}async function uh(){let{privateKey:r,publicKey:t}=xa();return new oe(r,t)}async function qi(r){let{privateKey:t,publicKey:e}=Ea(r);return new oe(t,e)}function xr(r,t){if(r=Uint8Array.from(r??[]),r.length!==t)throw new A(`Key must be a Uint8Array of length ${t}, got ${r.length}`,"ERR_INVALID_KEY_TYPE");return r}var Oa={"P-256":256,"P-384":384,"P-521":521},lh=Object.keys(Oa),Gi=lh.join(" / ");async function Va(r){if(r!=="P-256"&&r!=="P-384"&&r!=="P-521")throw new A(`Unknown curve: ${r}. Must be ${Gi}`,"ERR_INVALID_CURVE");let t=await W.get().subtle.generateKey({name:"ECDH",namedCurve:r},!0,["deriveBits"]),e=async(i,o)=>{let c;o!=null?c=await W.get().subtle.importKey("jwk",hh(r,o),{name:"ECDH",namedCurve:r},!1,["deriveBits"]):c=t.privateKey;let a=await W.get().subtle.importKey("jwk",Ma(r,i),{name:"ECDH",namedCurve:r},!1,[]),f=await W.get().subtle.deriveBits({name:"ECDH",namedCurve:r,public:a},c,Oa[r]);return new Uint8Array(f,0,f.byteLength)},n=await W.get().subtle.exportKey("jwk",t.publicKey);return{key:fh(n),genSharedKey:e}}var Ha={"P-256":32,"P-384":48,"P-521":66};function fh(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 ${Gi}`,"ERR_INVALID_CURVE");let t=Ha[r.crv];return Bt([Uint8Array.from([4]),oi(r.x,t),oi(r.y,t)],1+t*2)}function Ma(r,t){if(r!=="P-256"&&r!=="P-384"&&r!=="P-521")throw new A(`Unknown curve: ${r}. Must be ${Gi}`,"ERR_INVALID_CURVE");let e=Ha[r];if(!gt(t.subarray(0,1),Uint8Array.from([4])))throw new A("Cannot unmarshal public key - invalid key format","ERR_INVALID_KEY_FORMAT");return{kty:"EC",crv:r,x:Y(t.subarray(1,e+1),"base64url"),y:Y(t.subarray(1+e),"base64url"),ext:!0}}var hh=(r,t)=>({...Ma(r,t.public),d:Y(t.private,"base64url")});var Ka=Va;async function Fa(r,t){let e=_r.decode(r);return Sn().decrypt(e,t)}var qa={"AES-128":{ivSize:16,keySize:16},"AES-256":{ivSize:16,keySize:32},Blowfish:{ivSize:8,keySize:32}};async function $a(r,t,e){let n=qa[r];if(n==null){let x=Object.keys(qa).join(" / ");throw new A(`unknown cipher type '${r}'. Must be ${x}`,"ERR_INVALID_CIPHER_TYPE")}if(t==null)throw new A("missing hash type","ERR_MISSING_HASH_TYPE");let s=n.keySize,i=n.ivSize,o=20,c=q("key expansion"),a=2*(i+s+o),f=await ea(t,e),l=await f.digest(c),u=[],h=0;for(;h<a;){let x=await f.digest(Bt([l,c])),p=x.length;h+p>a&&(p=a-h),u.push(x),h+=p,l=await f.digest(l)}let b=a/2,E=Bt(u),y=E.subarray(0,b),d=E.subarray(b,a),m=x=>({iv:x.subarray(0,i),cipherKey:x.subarray(i,i+s),macKey:x.subarray(i+s)});return{k1:m(y),k2:m(d)}}var ro={};et(ro,{MAX_RSA_KEY_SIZE:()=>Ge,RsaPrivateKey:()=>_e,RsaPublicKey:()=>$e,fromJwk:()=>Vh,generateKeyPair:()=>Hh,unmarshalRsaPrivateKey:()=>to,unmarshalRsaPublicKey:()=>Oh});function zt(r){if(isNaN(r)||r<=0)throw new A("random bytes length must be a Number bigger than 0","ERR_INVALID_LENGTH");return hr(r)}var Ne={};et(Ne,{exportToPem:()=>Lh,importFromPem:()=>Qi,jwkToPkcs1:()=>Nh,jwkToPkix:()=>Th,pkcs1ToJwk:()=>Rh,pkixToJwk:()=>_h});var Cn=class extends lr{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,gn(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 ur(this),this.iHash.update(t),this}digestInto(t){ur(this),cr(t,this.outputLen),this.finished=!0,this.iHash.digestInto(t),this.oHash.update(t),this.oHash.digestInto(t),this.destroy()}digest(){let t=new Uint8Array(this.oHash.outputLen);return this.digestInto(t),t}_cloneInto(t){t||(t=Object.create(Object.getPrototypeOf(this),{}));let{oHash:e,iHash:n,finished:s,destroyed:i,blockLen:o,outputLen:c}=this;return t=t,t.finished=s,t.destroyed=i,t.blockLen=o,t.outputLen=c,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 Cn(r,t).update(e).digest();Gr.create=(r,t)=>new Cn(r,t);function dh(r,t,e,n){gn(r);let s=ia({dkLen:32,asyncTick:10},n),{c:i,dkLen:o,asyncTick:c}=s;if(ar(i),ar(o),ar(c),i<1)throw new Error("PBKDF2: iterations (c) should be >= 1");let a=be(t),f=be(e),l=new Uint8Array(o),u=Gr.create(r,a),h=u._cloneInto().update(f);return{c:i,dkLen:o,asyncTick:c,DK:l,PRF:u,PRFSalt:h}}function ph(r,t,e,n,s){return r.destroy(),t.destroy(),n&&n.destroy(),s.fill(0),e}async function zi(r,t,e,n){let{c:s,dkLen:i,asyncTick:o,DK:c,PRF:a,PRFSalt:f}=dh(r,t,e,n),l,u=new Uint8Array(4),h=fr(u),b=new Uint8Array(a.outputLen);for(let E=1,y=0;y<i;E++,y+=a.outputLen){let d=c.subarray(y,y+a.outputLen);h.setInt32(0,E,!1),(l=f._cloneInto(l)).update(u).digestInto(b),d.set(b.subarray(0,d.length)),await na(s-1,o,()=>{a._cloneInto(l).update(b).digestInto(b);for(let m=0;m<d.length;m++)d[m]^=b[m]})}return ph(a,f,c,l,b)}var M=No(Ga());function qe(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 Ie(r,t,e=-1){let n=e,s=r,i=0,o=Math.pow(2,t);for(let c=1;c<8;c++){if(r<o){let a;if(n<0)a=new ArrayBuffer(c),i=c;else{if(n<c)return new ArrayBuffer(0);a=new ArrayBuffer(n),i=n}let f=new Uint8Array(a);for(let l=c-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 a}o*=Math.pow(2,t)}return new ArrayBuffer(0)}function Dn(...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 Yi(){let r=new Uint8Array(this.valueHex);if(this.valueHex.byteLength>=2){let c=r[0]===255&&r[1]&128,a=r[0]===0&&(r[1]&128)===0;(c||a)&&this.warnings.push("Needlessly long format")}let t=new ArrayBuffer(this.valueHex.byteLength),e=new Uint8Array(t);for(let c=0;c<this.valueHex.byteLength;c++)e[c]=0;e[0]=r[0]&128;let n=qe(e,8),s=new ArrayBuffer(this.valueHex.byteLength),i=new Uint8Array(s);for(let c=0;c<this.valueHex.byteLength;c++)i[c]=r[c];return i[0]&=127,qe(i,8)-n}function za(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,c=Ie(o,8,n),a=new Uint8Array(c);return a[0]|=128,c}let s=Ie(t,8,n),i=new Uint8Array(s);if(i[0]&128){let o=s.slice(0),c=new Uint8Array(o);s=new ArrayBuffer(s.byteLength+1),i=new Uint8Array(s);for(let a=0;a<o.byteLength;a++)i[a+1]=c[a];i[0]=0}return s}e*=Math.pow(2,8)}return new ArrayBuffer(0)}function ja(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 Nt(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 Gg=Math.log(2);function Pn(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function Zi(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 fe(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 jr=class{constructor(){this.items=[]}write(t){this.items.push(t)}final(){return Zi(this.items)}},zr=[new Uint8Array([1])],Ya="0123456789";var Br="",Kt=new ArrayBuffer(0),Wi=new Uint8Array(0),Yr="EndOfContent",Wa="OCTET STRING",Ja="BIT STRING";function he(r){var t;return t=class extends r{constructor(...n){var s;super(...n);let i=n[0]||{};this.isHexOnly=(s=i.isHexOnly)!==null&&s!==void 0?s:!1,this.valueHexView=i.valueHex?M.BufferSourceConverter.toUint8Array(i.valueHex):Wi}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(!fe(this,o,s,i))return-1;let c=s+i;return this.valueHexView=o.subarray(s,c),this.valueHexView.length?(this.blockLength=i,c):(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",Kt)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:M.Convert.ToHex(this.valueHexView)}}},t.NAME="hexBlock",t}var ce=class{constructor({blockLength:t=0,error:e=Br,warnings:n=[],valueBeforeDecode:s=Wi}={}){this.blockLength=t,this.error=e,this.warnings=n,this.valueBeforeDecodeView=M.BufferSourceConverter.toUint8Array(s)}static blockName(){return this.NAME}get valueBeforeDecode(){return this.valueBeforeDecodeView.slice().buffer}set valueBeforeDecode(t){this.valueBeforeDecodeView=new Uint8Array(t)}toJSON(){return{blockName:this.constructor.NAME,blockLength:this.blockLength,error:this.error,warnings:this.warnings,valueBeforeDecode:M.Convert.ToHex(this.valueBeforeDecodeView)}}};ce.NAME="baseBlock";var wt=class extends ce{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'")}};wt.NAME="valueBlock";var On=class extends he(ce){constructor({idBlock:t={}}={}){var e,n,s,i;super(),t?(this.isHexOnly=(e=t.isHexOnly)!==null&&e!==void 0?e:!1,this.valueHexView=t.valueHex?M.BufferSourceConverter.toUint8Array(t.valueHex):Wi,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",Kt}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=Ie(this.tagNumber,7),i=new Uint8Array(s),o=s.byteLength,c=new Uint8Array(o+1);if(c[0]=e|31,!t){for(let a=0;a<o-1;a++)c[a+1]=i[a]|128;c[o]=i[o-1]}return c.buffer}let n=new Uint8Array(this.valueHexView.byteLength+1);if(n[0]=e|31,!t){let s=this.valueHexView;for(let i=0;i<s.length-1;i++)n[i+1]=s[i]|128;n[this.valueHexView.byteLength]=s[s.length-1]}return n.buffer}fromBER(t,e,n){let s=M.BufferSourceConverter.toUint8Array(t);if(!fe(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 c=i[0]&31;if(c!==31)this.tagNumber=c,this.blockLength=1;else{let a=1,f=this.valueHexView=new Uint8Array(255),l=255;for(;i[a]&128;){if(f[a-1]=i[a]&127,a++,a>=i.length)return this.error="End of input reached before message was fully decoded",-1;if(a===l){l+=255;let h=new Uint8Array(l);for(let b=0;b<f.length;b++)h[b]=f[b];f=this.valueHexView=new Uint8Array(l)}}this.blockLength=a+1,f[a-1]=i[a]&127;let u=new Uint8Array(a);for(let h=0;h<a;h++)u[h]=f[h];f=this.valueHexView=new Uint8Array(a),f.set(u),this.blockLength<=9?this.tagNumber=qe(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}}};On.NAME="identificationBlock";var Vn=class extends ce{constructor({lenBlock:t={}}={}){var e,n,s;super(),this.isIndefiniteForm=(e=t.isIndefiniteForm)!==null&&e!==void 0?e:!1,this.longFormUsed=(n=t.longFormUsed)!==null&&n!==void 0?n:!1,this.length=(s=t.length)!==null&&s!==void 0?s:0}fromBER(t,e,n){let s=M.BufferSourceConverter.toUint8Array(t);if(!fe(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 c=e+1,a=s.subarray(c,c+o);return a[o-1]===0&&this.warnings.push("Needlessly long encoded length"),this.length=qe(a,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=Ie(this.length,8);if(s.byteLength>127)return this.error="Too big length",Kt;if(e=new ArrayBuffer(s.byteLength+1),t)return e;let i=new Uint8Array(s);n=new Uint8Array(e),n[0]=s.byteLength|128;for(let o=0;o<s.byteLength;o++)n[o+1]=i[o];return e}return e=new ArrayBuffer(1),t===!1&&(n=new Uint8Array(e),n[0]=this.length),e}toJSON(){return{...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,longFormUsed:this.longFormUsed,length:this.length}}};Vn.NAME="lengthBlock";var I={},pt=class extends ce{constructor({name:t=Br,optional:e=!1,primitiveSchema:n,...s}={},i){super(s),this.name=t,this.optional=e,n&&(this.primitiveSchema=n),this.idBlock=new On(s),this.lenBlock=new Vn(s),this.valueBlock=i?new i(s):new wt(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 jr;e||Xa(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?Kt:n.final()}toJSON(){let t={...super.toJSON(),idBlock:this.idBlock.toJSON(),lenBlock:this.lenBlock.toJSON(),valueBlock:this.valueBlock.toJSON(),name:this.name,optional:this.optional};return this.primitiveSchema&&(t.primitiveSchema=this.primitiveSchema.toJSON()),t}toString(t="ascii"){return t==="ascii"?this.onAsciiEncoding():M.Convert.ToHex(this.toBER())}onAsciiEncoding(){return`${this.constructor.NAME} : ${M.Convert.ToHex(this.valueBlock.valueBeforeDecodeView)}`}isEqual(t){if(this===t)return!0;if(!(t instanceof this.constructor))return!1;let e=this.toBER(),n=t.toBER();return ja(e,n)}};pt.NAME="BaseBlock";function Xa(r){if(r instanceof I.Constructed)for(let t of r.valueBlock.value)Xa(t)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var Hn=class extends pt{constructor({value:t=Br,...e}={},n){super(e,n),t&&this.fromString(t)}getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}fromBER(t,e,n){let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.fromBuffer(this.valueBlock.valueHexView),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}onAsciiEncoding(){return`${this.constructor.NAME} : '${this.valueBlock.value}'`}};Hn.NAME="BaseStringBlock";var Mn=class extends he(wt){constructor({isHexOnly:t=!0,...e}={}){super(e),this.isHexOnly=t}};Mn.NAME="PrimitiveValueBlock";var Qa,Kn=class extends pt{constructor(t={}){super(t,Mn),this.idBlock.isConstructed=!1}};Qa=Kn;I.Primitive=Qa;Kn.NAME="PRIMITIVE";function Bh(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 xs(r,t=0,e=r.length){let n=t,s=new pt({},wt),i=new ce;if(!fe(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 c=s.idBlock.fromBER(r,t,e);if(s.idBlock.warnings.length&&s.warnings.concat(s.idBlock.warnings),c===-1)return s.error=s.idBlock.error,{offset:-1,result:s};if(t=c,e-=s.idBlock.blockLength,c=s.lenBlock.fromBER(r,t,e),s.lenBlock.warnings.length&&s.warnings.concat(s.lenBlock.warnings),c===-1)return s.error=s.lenBlock.error,{offset:-1,result:s};if(t=c,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 a=pt;switch(s.idBlock.tagClass){case 1:if(s.idBlock.tagNumber>=37&&s.idBlock.isHexOnly===!1)return s.error="UNIVERSAL 37 and upper tags are reserved by ASN.1 standard",{offset:-1,result:s};switch(s.idBlock.tagNumber){case 0:if(s.idBlock.isConstructed&&s.lenBlock.length>0)return s.error="Type [UNIVERSAL 0] is reserved",{offset:-1,result:s};a=I.EndOfContent;break;case 1:a=I.Boolean;break;case 2:a=I.Integer;break;case 3:a=I.BitString;break;case 4:a=I.OctetString;break;case 5:a=I.Null;break;case 6:a=I.ObjectIdentifier;break;case 10:a=I.Enumerated;break;case 12:a=I.Utf8String;break;case 13:a=I.RelativeObjectIdentifier;break;case 14:a=I.TIME;break;case 15:return s.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:s};case 16:a=I.Sequence;break;case 17:a=I.Set;break;case 18:a=I.NumericString;break;case 19:a=I.PrintableString;break;case 20:a=I.TeletexString;break;case 21:a=I.VideotexString;break;case 22:a=I.IA5String;break;case 23:a=I.UTCTime;break;case 24:a=I.GeneralizedTime;break;case 25:a=I.GraphicString;break;case 26:a=I.VisibleString;break;case 27:a=I.GeneralString;break;case 28:a=I.UniversalString;break;case 29:a=I.CharacterString;break;case 30:a=I.BmpString;break;case 31:a=I.DATE;break;case 32:a=I.TimeOfDay;break;case 33:a=I.DateTime;break;case 34:a=I.Duration;break;default:{let f=s.idBlock.isConstructed?new I.Constructed:new I.Primitive;f.idBlock=s.idBlock,f.lenBlock=s.lenBlock,f.warnings=s.warnings,s=f}}break;case 2:case 3:case 4:default:a=s.idBlock.isConstructed?I.Constructed:I.Primitive}return s=Bh(s,a),c=s.fromBER(r,t,s.lenBlock.isIndefiniteForm?e:s.lenBlock.length),s.valueBeforeDecodeView=r.subarray(n,n+s.blockLength),{offset:c,result:s}}function Ar(r){if(!r.byteLength){let t=new pt({},wt);return t.error="Input buffer has zero length",{offset:-1,result:t}}return xs(M.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function Ah(r,t){return r?1:t}var jt=class extends wt{constructor({value:t=[],isIndefiniteForm:e=!1,...n}={}){super(n),this.value=t,this.isIndefiniteForm=e}fromBER(t,e,n){let s=M.BufferSourceConverter.toUint8Array(t);if(!fe(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(;Ah(this.isIndefiniteForm,n)>0;){let o=xs(s,i,n);if(o.offset===-1)return this.error=o.result.error,this.warnings.concat(o.result.warnings),-1;if(i=o.offset,this.blockLength+=o.result.blockLength,n-=o.result.blockLength,this.value.push(o.result),this.isIndefiniteForm&&o.result.constructor.NAME===Yr)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===Yr?this.value.pop():this.warnings.push("No EndOfContent block encoded")),i}toBER(t,e){let n=e||new jr;for(let s=0;s<this.value.length;s++)this.value[s].toBER(t,n);return e?Kt:n.final()}toJSON(){let t={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let e of this.value)t.value.push(e.toJSON());return t}};jt.NAME="ConstructedValueBlock";var tc,ke=class extends pt{constructor(t={}){super(t,jt),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 Libp2PPubsub=(()=>{var Zc=Object.create;var Kr=Object.defineProperty;var Wc=Object.getOwnPropertyDescriptor;var Jc=Object.getOwnPropertyNames;var Yc=Object.getPrototypeOf,Xc=Object.prototype.hasOwnProperty;var so=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),yt=(r,t)=>{for(var e in t)Kr(r,e,{get:t[e],enumerable:!0})},io=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of Jc(t))!Xc.call(r,s)&&s!==e&&Kr(r,s,{get:()=>t[s],enumerable:!(n=Wc(t,s))||n.enumerable});return r};var oo=(r,t,e)=>(e=r!=null?Zc(Yc(r)):{},io(t||!r||!r.__esModule?Kr(e,"default",{value:r,enumerable:!0}):e,r)),Qc=r=>io(Kr({},"__esModule",{value:!0}),r);var ua=so(Je=>{"use strict";var Af="[object ArrayBuffer]",Wt=class r{static isArrayBuffer(t){return Object.prototype.toString.call(t)===Af}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 c=this.toUint8Array(o);s.set(c,i),i+=c.length}return t[t.length-1]instanceof Function?this.toView(s,t[t.length-1]):s.buffer}},Ii="string",kf=/^[0-9a-f]+$/i,If=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,Nf=/^[a-zA-Z0-9-_]+$/,fn=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=Wt.toUint8Array(t),n="";for(let i=0;i<e.length;i++)n+=String.fromCharCode(e[i]);return decodeURIComponent(escape(n))}},Nt=class{static toString(t,e=!1){let n=Wt.toArrayBuffer(t),s=new DataView(n),i="";for(let o=0;o<n.byteLength;o+=2){let c=s.getUint16(o,e);i+=String.fromCharCode(c)}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}},hn=class r{static isHex(t){return typeof t===Ii&&kf.test(t)}static isBase64(t){return typeof t===Ii&&If.test(t)}static isBase64Url(t){return typeof t===Ii&&Nf.test(t)}static ToString(t,e="utf8"){let n=Wt.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 Nt.toString(n,!0);case"utf16":case"utf16be":return Nt.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 Nt.fromString(t,!0);case"utf16":case"utf16be":return Nt.fromString(t);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToBase64(t){let e=Wt.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 fn.fromString(t);case"utf16":case"utf16be":return Nt.fromString(t);case"utf16le":case"usc2":return Nt.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 fn.toString(t);case"utf16":case"utf16be":return Nt.toString(t);case"utf16le":case"usc2":return Nt.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=Wt.toUint8Array(t),n="";for(let s=0;s<e.length;s++)n+=String.fromCharCode(e[s]);return n}static ToHex(t){let e=Wt.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 Nt.toString(t,e)}static FromUtf16String(t,e=!1){return Nt.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,"")||""}};hn.DEFAULT_UTF8_ENCODING="utf8";function Cf(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 Tf(...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 Lf(r,t){if(!(r&&t)||r.byteLength!==t.byteLength)return!1;let e=new Uint8Array(r),n=new Uint8Array(t);for(let s=0;s<r.byteLength;s++)if(e[s]!==n[s])return!1;return!0}Je.BufferSourceConverter=Wt;Je.Convert=hn;Je.assign=Cf;Je.combine=Tf;Je.isEqual=Lf});var kc=so((mm,$i)=>{"use strict";var nh=Object.prototype.hasOwnProperty,xt="~";function Vr(){}Object.create&&(Vr.prototype=Object.create(null),new Vr().__proto__||(xt=!1));function sh(r,t,e){this.fn=r,this.context=t,this.once=e||!1}function Ac(r,t,e,n,s){if(typeof e!="function")throw new TypeError("The listener must be a function");var i=new sh(e,n||r,s),o=xt?xt+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 ls(r,t){--r._eventsCount===0?r._events=new Vr:delete r._events[t]}function mt(){this._events=new Vr,this._eventsCount=0}mt.prototype.eventNames=function(){var t=[],e,n;if(this._eventsCount===0)return t;for(n in e=this._events)nh.call(e,n)&&t.push(xt?n.slice(1):n);return Object.getOwnPropertySymbols?t.concat(Object.getOwnPropertySymbols(e)):t};mt.prototype.listeners=function(t){var e=xt?xt+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};mt.prototype.listenerCount=function(t){var e=xt?xt+t:t,n=this._events[e];return n?n.fn?1:n.length:0};mt.prototype.emit=function(t,e,n,s,i,o){var c=xt?xt+t:t;if(!this._events[c])return!1;var a=this._events[c],f=arguments.length,l,u;if(a.fn){switch(a.once&&this.removeListener(t,a.fn,void 0,!0),f){case 1:return a.fn.call(a.context),!0;case 2:return a.fn.call(a.context,e),!0;case 3:return a.fn.call(a.context,e,n),!0;case 4:return a.fn.call(a.context,e,n,s),!0;case 5:return a.fn.call(a.context,e,n,s,i),!0;case 6:return a.fn.call(a.context,e,n,s,i,o),!0}for(u=1,l=new Array(f-1);u<f;u++)l[u-1]=arguments[u];a.fn.apply(a.context,l)}else{var d=a.length,x;for(u=0;u<d;u++)switch(a[u].once&&this.removeListener(t,a[u].fn,void 0,!0),f){case 1:a[u].fn.call(a[u].context);break;case 2:a[u].fn.call(a[u].context,e);break;case 3:a[u].fn.call(a[u].context,e,n);break;case 4:a[u].fn.call(a[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];a[u].fn.apply(a[u].context,l)}}return!0};mt.prototype.on=function(t,e,n){return Ac(this,t,e,n,!1)};mt.prototype.once=function(t,e,n){return Ac(this,t,e,n,!0)};mt.prototype.removeListener=function(t,e,n,s){var i=xt?xt+t:t;if(!this._events[i])return this;if(!e)return ls(this,i),this;var o=this._events[i];if(o.fn)o.fn===e&&(!s||o.once)&&(!n||o.context===n)&&ls(this,i);else{for(var c=0,a=[],f=o.length;c<f;c++)(o[c].fn!==e||s&&!o[c].once||n&&o[c].context!==n)&&a.push(o[c]);a.length?this._events[i]=a.length===1?a[0]:a:ls(this,i)}return this};mt.prototype.removeAllListeners=function(t){var e;return t?(e=xt?xt+t:t,this._events[e]&&ls(this,e)):(this._events=new Vr,this._eventsCount=0),this};mt.prototype.off=mt.prototype.removeListener;mt.prototype.addListener=mt.prototype.on;mt.prefixed=xt;mt.EventEmitter=mt;typeof $i<"u"&&($i.exports=mt)});var hh={};yt(hh,{PubSubBaseProtocol:()=>Ji});var ws=Symbol.for("@libp2p/peer-id");var or;(function(r){r.Accept="accept",r.Ignore="ignore",r.Reject="reject"})(or||(or={}));var rt=class extends Error{static name="InvalidParametersError";constructor(t="Invalid parameters"){super(t),this.name="InvalidParametersError"}},Ve=class extends Error{static name="InvalidPublicKeyError";constructor(t="Invalid public key"){super(t),this.name="InvalidPublicKeyError"}};var qr=class extends Error{static name="InvalidMultihashError";constructor(t="Invalid Multihash"){super(t),this.name="InvalidMultihashError"}};var Y=class extends Error{static name="InvalidMessageError";constructor(t="Invalid message"){super(t),this.name="InvalidMessageError"}};var $r=class extends Error{static name="NotStartedError";constructor(t="Not started"){super(t),this.name="NotStartedError"}};var we=class extends Error{static name="UnsupportedKeyTypeError";constructor(t="Unsupported key type"){super(t),this.name="UnsupportedKeyTypeError"}};var ao=(r,...t)=>{try{[...t]}catch{}};var He=class extends EventTarget{#t=new Map;constructor(){super(),ao(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 CustomEvent(t,e))}};var Ss={};yt(Ss,{base58btc:()=>X,base58flickr:()=>iu});var xh=new Uint8Array(0);function co(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function Kt(r){if(r instanceof Uint8Array&&r.constructor.name==="Uint8Array")return r;if(r instanceof ArrayBuffer)return new Uint8Array(r);if(ArrayBuffer.isView(r))return new Uint8Array(r.buffer,r.byteOffset,r.byteLength);throw new Error("Unknown type, must be binary type")}function uo(r){return new TextEncoder().encode(r)}function lo(r){return new TextDecoder().decode(r)}function tu(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 c=r.length,a=r.charAt(0),f=Math.log(c)/Math.log(256),l=Math.log(256)/Math.log(c);function u(E){if(E instanceof Uint8Array||(ArrayBuffer.isView(E)?E=new Uint8Array(E.buffer,E.byteOffset,E.byteLength):Array.isArray(E)&&(E=Uint8Array.from(E))),!(E instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(E.length===0)return"";for(var b=0,h=0,y=0,v=E.length;y!==v&&E[y]===0;)y++,b++;for(var g=(v-y)*l+1>>>0,S=new Uint8Array(g);y!==v;){for(var U=E[y],L=0,k=g-1;(U!==0||L<h)&&k!==-1;k--,L++)U+=256*S[k]>>>0,S[k]=U%c>>>0,U=U/c>>>0;if(U!==0)throw new Error("Non-zero carry");h=L,y++}for(var I=g-h;I!==g&&S[I]===0;)I++;for(var T=a.repeat(b);I<g;++I)T+=r.charAt(S[I]);return T}function d(E){if(typeof E!="string")throw new TypeError("Expected String");if(E.length===0)return new Uint8Array;var b=0;if(E[b]!==" "){for(var h=0,y=0;E[b]===a;)h++,b++;for(var v=(E.length-b)*f+1>>>0,g=new Uint8Array(v);E[b];){var S=e[E.charCodeAt(b)];if(S===255)return;for(var U=0,L=v-1;(S!==0||U<y)&&L!==-1;L--,U++)S+=c*g[L]>>>0,g[L]=S%256>>>0,S=S/256>>>0;if(S!==0)throw new Error("Non-zero carry");y=U,b++}if(E[b]!==" "){for(var k=v-y;k!==v&&g[k]===0;)k++;for(var I=new Uint8Array(h+(v-k)),T=h;k!==v;)I[T++]=g[k++];return I}}}function x(E){var b=d(E);if(b)return b;throw new Error(`Non-${t} character`)}return{encode:u,decodeUnsafe:d,decode:x}}var eu=tu,ru=eu,ho=ru;var xs=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")}},vs=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 po(this,t)}},Es=class{decoders;constructor(t){this.decoders=t}or(t){return po(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 po(r,t){return new Es({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var Bs=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 xs(t,e,n),this.decoder=new vs(t,e,s)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function Oe({name:r,prefix:t,encode:e,decode:n}){return new Bs(r,t,e,n)}function ne({name:r,prefix:t,alphabet:e}){let{encode:n,decode:s}=ho(e,r);return Oe({prefix:t,name:r,encode:n,decode:i=>Kt(s(i))})}function nu(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),c=0,a=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`);a=a<<e|u,c+=e,c>=8&&(c-=8,o[f++]=255&a>>c)}if(c>=e||255&a<<8-c)throw new SyntaxError("Unexpected end of data");return o}function su(r,t,e){let n=t[t.length-1]==="=",s=(1<<e)-1,i="",o=0,c=0;for(let a=0;a<r.length;++a)for(c=c<<8|r[a],o+=8;o>e;)o-=e,i+=t[s&c>>o];if(o!==0&&(i+=t[s&c<<e-o]),n)for(;i.length*e&7;)i+="=";return i}function W({name:r,prefix:t,bitsPerChar:e,alphabet:n}){return Oe({prefix:t,name:r,encode(s){return su(s,n,e)},decode(s){return nu(s,n,e,r)}})}var X=ne({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),iu=ne({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var As={};yt(As,{base32:()=>Me,base32hex:()=>uu,base32hexpad:()=>fu,base32hexpadupper:()=>hu,base32hexupper:()=>lu,base32pad:()=>au,base32padupper:()=>cu,base32upper:()=>ou,base32z:()=>du});var Me=W({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),ou=W({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),au=W({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),cu=W({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),uu=W({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),lu=W({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),fu=W({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),hu=W({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),du=W({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var pu=bo,go=128,gu=127,mu=~gu,bu=Math.pow(2,31);function bo(r,t,e){t=t||[],e=e||0;for(var n=e;r>=bu;)t[e++]=r&255|go,r/=128;for(;r&mu;)t[e++]=r&255|go,r>>>=7;return t[e]=r|0,bo.bytes=e-n+1,t}var yu=ks,wu=128,mo=127;function ks(r,n){var e=0,n=n||0,s=0,i=n,o,c=r.length;do{if(i>=c)throw ks.bytes=0,new RangeError("Could not decode varint");o=r[i++],e+=s<28?(o&mo)<<s:(o&mo)*Math.pow(2,s),s+=7}while(o>=wu);return ks.bytes=i-n,e}var xu=Math.pow(2,7),vu=Math.pow(2,14),Eu=Math.pow(2,21),Bu=Math.pow(2,28),Su=Math.pow(2,35),Au=Math.pow(2,42),ku=Math.pow(2,49),Iu=Math.pow(2,56),Nu=Math.pow(2,63),Cu=function(r){return r<xu?1:r<vu?2:r<Eu?3:r<Bu?4:r<Su?5:r<Au?6:r<ku?7:r<Iu?8:r<Nu?9:10},Tu={encode:pu,decode:yu,encodingLength:Cu},Lu=Tu,ar=Lu;function cr(r,t=0){return[ar.decode(r,t),ar.decode.bytes]}function De(r,t,e=0){return ar.encode(r,t,e),t}function Pe(r){return ar.encodingLength(r)}function Ct(r,t){let e=t.byteLength,n=Pe(r),s=n+Pe(e),i=new Uint8Array(s+e);return De(r,i,0),De(e,i,n),i.set(t,s),new Fe(r,e,t,i)}function se(r){let t=Kt(r),[e,n]=cr(t),[s,i]=cr(t.subarray(n)),o=t.subarray(n+i);if(o.byteLength!==s)throw new Error("Incorrect length");return new Fe(e,s,o,t)}function yo(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&co(r.bytes,e.bytes)}}var Fe=class{code;size;digest;bytes;constructor(t,e,n,s){this.code=t,this.size=e,this.digest=n,this.bytes=s}};function wo(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return Ru(e,Is(r),t??X.encoder);default:return _u(e,Is(r),t??Me.encoder)}}var xo=new WeakMap;function Is(r){let t=xo.get(r);if(t==null){let e=new Map;return xo.set(r,e),e}return t}var At=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!==Vu)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=Ct(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&&yo(t.multihash,n.multihash)}toString(t){return wo(this,t)}toJSON(){return{"/":wo(this)}}link(){return this}[Symbol.toStringTag]="CID";[Symbol.for("nodejs.util.inspect.custom")](){return`CID(${this.toString()})`}static asCID(t){if(t==null)return null;let e=t;if(e instanceof r)return e;if(e["/"]!=null&&e["/"]===e.bytes||e.asCID===e){let{version:n,code:s,multihash:i,bytes:o}=e;return new r(n,s,i,o??vo(n,s,i.bytes))}else if(e[Hu]===!0){let{version:n,multihash:s,code:i}=e,o=se(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=vo(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=Kt(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 Fe(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,d]=cr(t.subarray(e));return e+=d,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,c=n(),a=n(),f=e+a,l=f-o;return{version:s,codec:i,multihashCode:c,digestSize:a,multihashSize:l,size:f}}static parse(t,e){let[n,s]=Uu(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 Is(i).set(n,t),i}};function Uu(r,t){switch(r[0]){case"Q":{let e=t??X;return[X.prefix,e.decode(`${X.prefix}${r}`)]}case X.prefix:{let e=t??X;return[X.prefix,e.decode(r)]}case Me.prefix:{let e=t??Me;return[Me.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 Ru(r,t,e){let{prefix:n}=e;if(n!==X.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 _u(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,Vu=18;function vo(r,t,e){let n=Pe(r),s=n+Pe(t),i=new Uint8Array(s+e.byteLength);return De(r,i,0),De(t,i,n),i.set(e,s),i}var Hu=Symbol.for("@ipld/js-cid/CID");var Ns={};yt(Ns,{identity:()=>qt});var Eo=0,Ou="identity",Bo=Kt;function Mu(r){return Ct(Eo,Bo(r))}var qt={code:Eo,name:Ou,encode:Bo,digest:Mu};function It(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 So(r){if(!Number.isSafeInteger(r)||r<0)throw new Error(`positive integer expected, not ${r}`)}function Du(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function Ke(r,...t){if(!Du(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 Ao(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");So(r.outputLen),So(r.blockLen)}function qe(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 ko(r,t){Ke(r);let e=t.outputLen;if(r.length<e)throw new Error(`digestInto() expects output buffer of length at least ${e}`)}var xe=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;var Gr=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),Tt=(r,t)=>r<<32-t|r>>>t;var Fh=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;function Io(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function lr(r){return typeof r=="string"&&(r=Io(r)),Ke(r),r}function Cs(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];Ke(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 $e=class{clone(){return this._cloneInto()}},Kh={}.toString;function jr(r){let t=n=>r().update(lr(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function ze(r=32){if(xe&&typeof xe.getRandomValues=="function")return xe.getRandomValues(new Uint8Array(r));if(xe&&typeof xe.randomBytes=="function")return xe.randomBytes(r);throw new Error("crypto.getRandomValues must be defined")}function Pu(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),c=Number(e&i),a=n?4:0,f=n?0:4;r.setUint32(t+a,o,n),r.setUint32(t+f,c,n)}var No=(r,t,e)=>r&t^~r&e,Co=(r,t,e)=>r&t^r&e^t&e,Ge=class extends $e{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=Gr(this.buffer)}update(t){qe(this);let{view:e,buffer:n,blockLen:s}=this;t=lr(t);let i=t.length;for(let o=0;o<i;){let c=Math.min(s-this.pos,i-o);if(c===s){let a=Gr(t);for(;s<=i-o;o+=s)this.process(a,o);continue}n.set(t.subarray(o,o+c),this.pos),this.pos+=c,o+=c,this.pos===s&&(this.process(e,0),this.pos=0)}return this.length+=t.length,this.roundClean(),this}digestInto(t){qe(this),ko(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;Pu(n,s-8,BigInt(this.length*8),i),this.process(n,0);let c=Gr(t),a=this.outputLen;if(a%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let f=a/4,l=this.get();if(f>l.length)throw new Error("_sha2: outputLen bigger than state");for(let u=0;u<f;u++)c.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:c}=this;return t.length=s,t.pos=c,t.finished=i,t.destroyed=o,s%e&&t.buffer.set(n),t}};var Zr=BigInt(4294967295),Ts=BigInt(32);function To(r,t=!1){return t?{h:Number(r&Zr),l:Number(r>>Ts&Zr)}:{h:Number(r>>Ts&Zr)|0,l:Number(r&Zr)|0}}function Fu(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}=To(r[s],t);[e[s],n[s]]=[i,o]}return[e,n]}var Ku=(r,t)=>BigInt(r>>>0)<<Ts|BigInt(t>>>0),qu=(r,t,e)=>r>>>e,$u=(r,t,e)=>r<<32-e|t>>>e,zu=(r,t,e)=>r>>>e|t<<32-e,Gu=(r,t,e)=>r<<32-e|t>>>e,ju=(r,t,e)=>r<<64-e|t>>>e-32,Zu=(r,t,e)=>r>>>e-32|t<<64-e,Wu=(r,t)=>t,Ju=(r,t)=>r,Yu=(r,t,e)=>r<<e|t>>>32-e,Xu=(r,t,e)=>t<<e|r>>>32-e,Qu=(r,t,e)=>t<<e-32|r>>>64-e,tl=(r,t,e)=>r<<e-32|t>>>64-e;function el(r,t,e,n){let s=(t>>>0)+(n>>>0);return{h:r+e+(s/2**32|0)|0,l:s|0}}var rl=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),nl=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,sl=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),il=(r,t,e,n,s)=>t+e+n+s+(r/2**32|0)|0,ol=(r,t,e,n,s)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(s>>>0),al=(r,t,e,n,s,i)=>t+e+n+s+i+(r/2**32|0)|0;var cl={fromBig:To,split:Fu,toBig:Ku,shrSH:qu,shrSL:$u,rotrSH:zu,rotrSL:Gu,rotrBH:ju,rotrBL:Zu,rotr32H:Wu,rotr32L:Ju,rotlSH:Yu,rotlSL:Xu,rotlBH:Qu,rotlBL:tl,add:el,add3L:rl,add3H:nl,add4L:sl,add4H:il,add5H:al,add5L:ol},V=cl;var[ul,ll]=V.split(["0x428a2f98d728ae22","0x7137449123ef65cd","0xb5c0fbcfec4d3b2f","0xe9b5dba58189dbbc","0x3956c25bf348b538","0x59f111f1b605d019","0x923f82a4af194f9b","0xab1c5ed5da6d8118","0xd807aa98a3030242","0x12835b0145706fbe","0x243185be4ee4b28c","0x550c7dc3d5ffb4e2","0x72be5d74f27b896f","0x80deb1fe3b1696b1","0x9bdc06a725c71235","0xc19bf174cf692694","0xe49b69c19ef14ad2","0xefbe4786384f25e3","0x0fc19dc68b8cd5b5","0x240ca1cc77ac9c65","0x2de92c6f592b0275","0x4a7484aa6ea6e483","0x5cb0a9dcbd41fbd4","0x76f988da831153b5","0x983e5152ee66dfab","0xa831c66d2db43210","0xb00327c898fb213f","0xbf597fc7beef0ee4","0xc6e00bf33da88fc2","0xd5a79147930aa725","0x06ca6351e003826f","0x142929670a0e6e70","0x27b70a8546d22ffc","0x2e1b21385c26c926","0x4d2c6dfc5ac42aed","0x53380d139d95b3df","0x650a73548baf63de","0x766a0abb3c77b2a8","0x81c2c92e47edaee6","0x92722c851482353b","0xa2bfe8a14cf10364","0xa81a664bbc423001","0xc24b8b70d0f89791","0xc76c51a30654be30","0xd192e819d6ef5218","0xd69906245565a910","0xf40e35855771202a","0x106aa07032bbd1b8","0x19a4c116b8d2d0c8","0x1e376c085141ab53","0x2748774cdf8eeb99","0x34b0bcb5e19b48a8","0x391c0cb3c5c95a63","0x4ed8aa4ae3418acb","0x5b9cca4f7763e373","0x682e6ff3d6b2b8a3","0x748f82ee5defb2fc","0x78a5636f43172f60","0x84c87814a1f0ab72","0x8cc702081a6439ec","0x90befffa23631e28","0xa4506cebde82bde9","0xbef9a3f7b2c67915","0xc67178f2e372532b","0xca273eceea26619c","0xd186b8c721c0c207","0xeada7dd6cde0eb1e","0xf57d4f7fee6ed178","0x06f067aa72176fba","0x0a637dc5a2c898a6","0x113f9804bef90dae","0x1b710b35131c471b","0x28db77f523047d84","0x32caab7b40c72493","0x3c9ebe0a15c9bebc","0x431d67c49c100d4c","0x4cc5d4becb3e42b6","0x597f299cfc657e2a","0x5fcb6fab3ad6faec","0x6c44198c4a475817"].map(r=>BigInt(r))),oe=new Uint32Array(80),ae=new Uint32Array(80),Ls=class extends Ge{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:c,Dl:a,Eh:f,El:l,Fh:u,Fl:d,Gh:x,Gl:E,Hh:b,Hl:h}=this;return[t,e,n,s,i,o,c,a,f,l,u,d,x,E,b,h]}set(t,e,n,s,i,o,c,a,f,l,u,d,x,E,b,h){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=c|0,this.Dl=a|0,this.Eh=f|0,this.El=l|0,this.Fh=u|0,this.Fl=d|0,this.Gh=x|0,this.Gl=E|0,this.Hh=b|0,this.Hl=h|0}process(t,e){for(let g=0;g<16;g++,e+=4)oe[g]=t.getUint32(e),ae[g]=t.getUint32(e+=4);for(let g=16;g<80;g++){let S=oe[g-15]|0,U=ae[g-15]|0,L=V.rotrSH(S,U,1)^V.rotrSH(S,U,8)^V.shrSH(S,U,7),k=V.rotrSL(S,U,1)^V.rotrSL(S,U,8)^V.shrSL(S,U,7),I=oe[g-2]|0,T=ae[g-2]|0,Q=V.rotrSH(I,T,19)^V.rotrBH(I,T,61)^V.shrSH(I,T,6),F=V.rotrSL(I,T,19)^V.rotrBL(I,T,61)^V.shrSL(I,T,6),H=V.add4L(k,F,ae[g-7],ae[g-16]),tt=V.add4H(H,L,Q,oe[g-7],oe[g-16]);oe[g]=tt|0,ae[g]=H|0}let{Ah:n,Al:s,Bh:i,Bl:o,Ch:c,Cl:a,Dh:f,Dl:l,Eh:u,El:d,Fh:x,Fl:E,Gh:b,Gl:h,Hh:y,Hl:v}=this;for(let g=0;g<80;g++){let S=V.rotrSH(u,d,14)^V.rotrSH(u,d,18)^V.rotrBH(u,d,41),U=V.rotrSL(u,d,14)^V.rotrSL(u,d,18)^V.rotrBL(u,d,41),L=u&x^~u&b,k=d&E^~d&h,I=V.add5L(v,U,k,ll[g],ae[g]),T=V.add5H(I,y,S,L,ul[g],oe[g]),Q=I|0,F=V.rotrSH(n,s,28)^V.rotrBH(n,s,34)^V.rotrBH(n,s,39),H=V.rotrSL(n,s,28)^V.rotrBL(n,s,34)^V.rotrBL(n,s,39),tt=n&i^n&c^i&c,B=s&o^s&a^o&a;y=b|0,v=h|0,b=x|0,h=E|0,x=u|0,E=d|0,{h:u,l:d}=V.add(f|0,l|0,T|0,Q|0),f=c|0,l=a|0,c=i|0,a=o|0,i=n|0,o=s|0;let N=V.add3L(Q,H,B);n=V.add3H(N,T,F,tt),s=N|0}({h:n,l:s}=V.add(this.Ah|0,this.Al|0,n|0,s|0)),{h:i,l:o}=V.add(this.Bh|0,this.Bl|0,i|0,o|0),{h:c,l:a}=V.add(this.Ch|0,this.Cl|0,c|0,a|0),{h:f,l}=V.add(this.Dh|0,this.Dl|0,f|0,l|0),{h:u,l:d}=V.add(this.Eh|0,this.El|0,u|0,d|0),{h:x,l:E}=V.add(this.Fh|0,this.Fl|0,x|0,E|0),{h:b,l:h}=V.add(this.Gh|0,this.Gl|0,b|0,h|0),{h:y,l:v}=V.add(this.Hh|0,this.Hl|0,y|0,v|0),this.set(n,s,i,o,c,a,f,l,u,d,x,E,b,h,y,v)}roundClean(){oe.fill(0),ae.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 Lo=jr(()=>new Ls);var Jr={};yt(Jr,{aInRange:()=>Et,abool:()=>Lt,abytes:()=>je,bitGet:()=>ml,bitLen:()=>Hs,bitMask:()=>hr,bitSet:()=>bl,bytesToHex:()=>zt,bytesToNumberBE:()=>Gt,bytesToNumberLE:()=>ue,concatBytes:()=>jt,createHmacDrbg:()=>Os,ensureBytes:()=>J,equalBytes:()=>pl,hexToBytes:()=>Ee,hexToNumber:()=>Vs,inRange:()=>fr,isBytes:()=>ce,memoized:()=>Se,notImplemented:()=>wl,numberToBytesBE:()=>le,numberToBytesLE:()=>Be,numberToHexUnpadded:()=>ve,numberToVarBytesBE:()=>dl,utf8ToBytes:()=>gl,validateObject:()=>Ht});var _s=BigInt(0),Wr=BigInt(1),fl=BigInt(2);function ce(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function je(r){if(!ce(r))throw new Error("Uint8Array expected")}function Lt(r,t){if(typeof t!="boolean")throw new Error(`${r} must be valid boolean, got "${t}".`)}var hl=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function zt(r){je(r);let t="";for(let e=0;e<r.length;e++)t+=hl[r[e]];return t}function ve(r){let t=r.toString(16);return t.length&1?`0${t}`:t}function Vs(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return BigInt(r===""?"0":`0x${r}`)}var $t={_0:48,_9:57,_A:65,_F:70,_a:97,_f:102};function Uo(r){if(r>=$t._0&&r<=$t._9)return r-$t._0;if(r>=$t._A&&r<=$t._F)return r-($t._A-10);if(r>=$t._a&&r<=$t._f)return r-($t._a-10)}function Ee(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=Uo(r.charCodeAt(i)),c=Uo(r.charCodeAt(i+1));if(o===void 0||c===void 0){let a=r[i]+r[i+1];throw new Error('hex string expected, got non-hex character "'+a+'" at index '+i)}n[s]=o*16+c}return n}function Gt(r){return Vs(zt(r))}function ue(r){return je(r),Vs(zt(Uint8Array.from(r).reverse()))}function le(r,t){return Ee(r.toString(16).padStart(t*2,"0"))}function Be(r,t){return le(r,t).reverse()}function dl(r){return Ee(ve(r))}function J(r,t,e){let n;if(typeof t=="string")try{n=Ee(t)}catch(i){throw new Error(`${r} must be valid hex string, got "${t}". Cause: ${i}`)}else if(ce(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 jt(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];je(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 pl(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 gl(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}var Us=r=>typeof r=="bigint"&&_s<=r;function fr(r,t,e){return Us(r)&&Us(t)&&Us(e)&&t<=r&&r<e}function Et(r,t,e,n){if(!fr(t,e,n))throw new Error(`expected valid ${r}: ${e} <= n < ${n}, got ${typeof t} ${t}`)}function Hs(r){let t;for(t=0;r>_s;r>>=Wr,t+=1);return t}function ml(r,t){return r>>BigInt(t)&Wr}function bl(r,t,e){return r|(e?Wr:_s)<<BigInt(t)}var hr=r=>(fl<<BigInt(r-1))-Wr,Rs=r=>new Uint8Array(r),Ro=r=>Uint8Array.from(r);function Os(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=Rs(r),s=Rs(r),i=0,o=()=>{n.fill(1),s.fill(0),i=0},c=(...u)=>e(s,n,...u),a=(u=Rs())=>{s=c(Ro([0]),u),n=c(),u.length!==0&&(s=c(Ro([1]),u),n=c())},f=()=>{if(i++>=1e3)throw new Error("drbg: tried 1000 values");let u=0,d=[];for(;u<t;){n=c();let x=n.slice();d.push(x),u+=n.length}return jt(...d)};return(u,d)=>{o(),a(u);let x;for(;!(x=d(f()));)a();return o(),x}}var yl={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"||ce(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 Ht(r,t,e={}){let n=(s,i,o)=>{let c=yl[i];if(typeof c!="function")throw new Error(`Invalid validator "${i}", expected function`);let a=r[s];if(!(o&&a===void 0)&&!c(a,r))throw new Error(`Invalid param ${String(s)}=${a} (${typeof a}), 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 wl=()=>{throw new Error("not implemented")};function Se(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 nt=BigInt(0),G=BigInt(1),Ae=BigInt(2),xl=BigInt(3),Ms=BigInt(4),_o=BigInt(5),Vo=BigInt(8),vl=BigInt(9),El=BigInt(16);function $(r,t){let e=r%t;return e>=nt?e:t+e}function Bl(r,t,e){if(e<=nt||t<nt)throw new Error("Expected power/modulo > 0");if(e===G)return nt;let n=G;for(;t>nt;)t&G&&(n=n*r%e),r=r*r%e,t>>=G;return n}function j(r,t,e){let n=r;for(;t-- >nt;)n*=n,n%=e;return n}function Yr(r,t){if(r===nt||t<=nt)throw new Error(`invert: expected positive integers, got n=${r} mod=${t}`);let e=$(r,t),n=t,s=nt,i=G,o=G,c=nt;for(;e!==nt;){let f=n/e,l=n%e,u=s-o*f,d=i-c*f;n=e,e=l,s=o,i=c,o=u,c=d}if(n!==G)throw new Error("invert: does not exist");return $(s,t)}function Sl(r){let t=(r-G)/Ae,e,n,s;for(e=r-G,n=0;e%Ae===nt;e/=Ae,n++);for(s=Ae;s<r&&Bl(s,t,r)!==r-G;s++);if(n===1){let o=(r+G)/Ms;return function(a,f){let l=a.pow(f,o);if(!a.eql(a.sqr(l),f))throw new Error("Cannot find square root");return l}}let i=(e+G)/Ae;return function(c,a){if(c.pow(a,t)===c.neg(c.ONE))throw new Error("Cannot find square root");let f=n,l=c.pow(c.mul(c.ONE,s),e),u=c.pow(a,i),d=c.pow(a,e);for(;!c.eql(d,c.ONE);){if(c.eql(d,c.ZERO))return c.ZERO;let x=1;for(let b=c.sqr(d);x<f&&!c.eql(b,c.ONE);x++)b=c.sqr(b);let E=c.pow(l,G<<BigInt(f-x-1));l=c.sqr(E),u=c.mul(u,E),d=c.mul(d,l),f=x}return u}}function Al(r){if(r%Ms===xl){let t=(r+G)/Ms;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%Vo===_o){let t=(r-_o)/Vo;return function(n,s){let i=n.mul(s,Ae),o=n.pow(i,t),c=n.mul(s,o),a=n.mul(n.mul(c,Ae),o),f=n.mul(c,n.sub(a,n.ONE));if(!n.eql(n.sqr(f),s))throw new Error("Cannot find square root");return f}}return r%El,Sl(r)}var Ho=(r,t)=>($(r,t)&G)===G,kl=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function Ds(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=kl.reduce((n,s)=>(n[s]="function",n),t);return Ht(r,e)}function Il(r,t,e){if(e<nt)throw new Error("Expected power > 0");if(e===nt)return r.ONE;if(e===G)return t;let n=r.ONE,s=t;for(;e>nt;)e&G&&(n=r.mul(n,s)),s=r.sqr(s),e>>=G;return n}function Nl(r,t){let e=new Array(t.length),n=t.reduce((i,o,c)=>r.is0(o)?i:(e[c]=i,r.mul(i,o)),r.ONE),s=r.inv(n);return t.reduceRight((i,o,c)=>r.is0(o)?i:(e[c]=r.mul(i,e[c]),r.mul(i,o)),s),e}function Ps(r,t){let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function fe(r,t,e=!1,n={}){if(r<=nt)throw new Error(`Expected Field ORDER > 0, got ${r}`);let{nBitLength:s,nByteLength:i}=Ps(r,t);if(i>2048)throw new Error("Field lengths over 2048 bytes are not supported");let o=Al(r),c=Object.freeze({ORDER:r,BITS:s,BYTES:i,MASK:hr(s),ZERO:nt,ONE:G,create:a=>$(a,r),isValid:a=>{if(typeof a!="bigint")throw new Error(`Invalid field element: expected bigint, got ${typeof a}`);return nt<=a&&a<r},is0:a=>a===nt,isOdd:a=>(a&G)===G,neg:a=>$(-a,r),eql:(a,f)=>a===f,sqr:a=>$(a*a,r),add:(a,f)=>$(a+f,r),sub:(a,f)=>$(a-f,r),mul:(a,f)=>$(a*f,r),pow:(a,f)=>Il(c,a,f),div:(a,f)=>$(a*Yr(f,r),r),sqrN:a=>a*a,addN:(a,f)=>a+f,subN:(a,f)=>a-f,mulN:(a,f)=>a*f,inv:a=>Yr(a,r),sqrt:n.sqrt||(a=>o(c,a)),invertBatch:a=>Nl(c,a),cmov:(a,f,l)=>l?f:a,toBytes:a=>e?Be(a,i):le(a,i),fromBytes:a=>{if(a.length!==i)throw new Error(`Fp.fromBytes: expected ${i}, got ${a.length}`);return e?ue(a):Gt(a)}});return Object.freeze(c)}function Oo(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 Fs(r){let t=Oo(r);return t+Math.ceil(t/2)}function Mo(r,t,e=!1){let n=r.length,s=Oo(t),i=Fs(t);if(n<16||n<i||n>1024)throw new Error(`expected ${i}-1024 bytes of input, got ${n}`);let o=e?Gt(r):ue(r),c=$(o,t-G)+G;return e?Be(c,s):le(c,s)}var Tl=BigInt(0),Ks=BigInt(1),qs=new WeakMap,Do=new WeakMap;function Xr(r,t){let e=(i,o)=>{let c=o.negate();return i?c: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,c=2**(i-1);return{windows:o,windowSize:c}};return{constTimeNegate:e,unsafeLadder(i,o){let c=r.ZERO,a=i;for(;o>Tl;)o&Ks&&(c=c.add(a)),a=a.double(),o>>=Ks;return c},precomputeWindow(i,o){let{windows:c,windowSize:a}=s(o),f=[],l=i,u=l;for(let d=0;d<c;d++){u=l,f.push(u);for(let x=1;x<a;x++)u=u.add(l),f.push(u);l=u.double()}return f},wNAF(i,o,c){let{windows:a,windowSize:f}=s(i),l=r.ZERO,u=r.BASE,d=BigInt(2**i-1),x=2**i,E=BigInt(i);for(let b=0;b<a;b++){let h=b*f,y=Number(c&d);c>>=E,y>f&&(y-=x,c+=Ks);let v=h,g=h+Math.abs(y)-1,S=b%2!==0,U=y<0;y===0?u=u.add(e(S,o[v])):l=l.add(e(U,o[g]))}return{p:l,f:u}},wNAFCached(i,o,c){let a=Do.get(i)||1,f=qs.get(i);return f||(f=this.precomputeWindow(i,a),a!==1&&qs.set(i,c(f))),this.wNAF(a,f,o)},setWindowSize(i,o){n(o),Do.set(i,o),qs.delete(i)}}}function Qr(r,t,e,n){if(!Array.isArray(e)||!Array.isArray(n)||n.length!==e.length)throw new Error("arrays of points and scalars must have equal length");n.forEach((l,u)=>{if(!t.isValid(l))throw new Error(`wrong scalar at index ${u}`)}),e.forEach((l,u)=>{if(!(l instanceof r))throw new Error(`wrong point at index ${u}`)});let s=Hs(BigInt(e.length)),i=s>12?s-3:s>4?s-2:s?2:1,o=(1<<i)-1,c=new Array(o+1).fill(r.ZERO),a=Math.floor((t.BITS-1)/i)*i,f=r.ZERO;for(let l=a;l>=0;l-=i){c.fill(r.ZERO);for(let d=0;d<n.length;d++){let x=n[d],E=Number(x>>BigInt(l)&BigInt(o));c[E]=c[E].add(e[d])}let u=r.ZERO;for(let d=c.length-1,x=r.ZERO;d>0;d--)x=x.add(c[d]),u=u.add(x);if(f=f.add(u),l!==0)for(let d=0;d<i;d++)f=f.double()}return f}function dr(r){return Ds(r.Fp),Ht(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...Ps(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Ut=BigInt(0),Bt=BigInt(1),tn=BigInt(2),Ll=BigInt(8),Ul={zip215:!0};function Rl(r){let t=dr(r);return Ht(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function Po(r){let t=Rl(r),{Fp:e,n,prehash:s,hash:i,randomBytes:o,nByteLength:c,h:a}=t,f=tn<<BigInt(c*8)-Bt,l=e.create,u=fe(t.n,t.nBitLength),d=t.uvRatio||((m,p)=>{try{return{isValid:!0,value:e.sqrt(m*e.inv(p))}}catch{return{isValid:!1,value:Ut}}}),x=t.adjustScalarBytes||(m=>m),E=t.domain||((m,p,w)=>{if(Lt("phflag",w),p.length||w)throw new Error("Contexts/pre-hash are not supported");return m});function b(m,p){Et("coordinate "+m,p,Ut,f)}function h(m){if(!(m instanceof g))throw new Error("ExtendedPoint expected")}let y=Se((m,p)=>{let{ex:w,ey:C,ez:R}=m,_=m.is0();p==null&&(p=_?Ll:e.inv(R));let O=l(w*p),P=l(C*p),M=l(R*p);if(_)return{x:Ut,y:Bt};if(M!==Bt)throw new Error("invZ was invalid");return{x:O,y:P}}),v=Se(m=>{let{a:p,d:w}=t;if(m.is0())throw new Error("bad point: ZERO");let{ex:C,ey:R,ez:_,et:O}=m,P=l(C*C),M=l(R*R),q=l(_*_),z=l(q*q),it=l(P*p),ot=l(q*l(it+M)),ut=l(z+l(w*l(P*M)));if(ot!==ut)throw new Error("bad point: equation left != right (1)");let bt=l(C*R),et=l(_*O);if(bt!==et)throw new Error("bad point: equation left != right (2)");return!0});class g{constructor(p,w,C,R){this.ex=p,this.ey=w,this.ez=C,this.et=R,b("x",p),b("y",w),b("z",C),b("t",R),Object.freeze(this)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(p){if(p instanceof g)throw new Error("extended point not allowed");let{x:w,y:C}=p||{};return b("x",w),b("y",C),new g(w,C,Bt,l(w*C))}static normalizeZ(p){let w=e.invertBatch(p.map(C=>C.ez));return p.map((C,R)=>C.toAffine(w[R])).map(g.fromAffine)}static msm(p,w){return Qr(g,u,p,w)}_setWindowSize(p){L.setWindowSize(this,p)}assertValidity(){v(this)}equals(p){h(p);let{ex:w,ey:C,ez:R}=this,{ex:_,ey:O,ez:P}=p,M=l(w*P),q=l(_*R),z=l(C*P),it=l(O*R);return M===q&&z===it}is0(){return this.equals(g.ZERO)}negate(){return new g(l(-this.ex),this.ey,this.ez,l(-this.et))}double(){let{a:p}=t,{ex:w,ey:C,ez:R}=this,_=l(w*w),O=l(C*C),P=l(tn*l(R*R)),M=l(p*_),q=w+C,z=l(l(q*q)-_-O),it=M+O,ot=it-P,ut=M-O,bt=l(z*ot),et=l(it*ut),vt=l(z*ut),Ft=l(ot*it);return new g(bt,et,Ft,vt)}add(p){h(p);let{a:w,d:C}=t,{ex:R,ey:_,ez:O,et:P}=this,{ex:M,ey:q,ez:z,et:it}=p;if(w===BigInt(-1)){let Yi=l((_-R)*(q+M)),Xi=l((_+R)*(q-M)),ys=l(Xi-Yi);if(ys===Ut)return this.double();let Qi=l(O*tn*it),to=l(P*tn*z),eo=to+Qi,ro=Xi+Yi,no=to-Qi,$c=l(eo*ys),zc=l(ro*no),Gc=l(eo*no),jc=l(ys*ro);return new g($c,zc,jc,Gc)}let ot=l(R*M),ut=l(_*q),bt=l(P*C*it),et=l(O*z),vt=l((R+_)*(M+q)-ot-ut),Ft=et-bt,sr=et+bt,ir=l(ut-w*ot),Pc=l(vt*Ft),Fc=l(sr*ir),Kc=l(vt*ir),qc=l(Ft*sr);return new g(Pc,Fc,qc,Kc)}subtract(p){return this.add(p.negate())}wNAF(p){return L.wNAFCached(this,p,g.normalizeZ)}multiply(p){let w=p;Et("scalar",w,Bt,n);let{p:C,f:R}=this.wNAF(w);return g.normalizeZ([C,R])[0]}multiplyUnsafe(p){let w=p;return Et("scalar",w,Ut,n),w===Ut?U:this.equals(U)||w===Bt?this:this.equals(S)?this.wNAF(w).p:L.unsafeLadder(this,w)}isSmallOrder(){return this.multiplyUnsafe(a).is0()}isTorsionFree(){return L.unsafeLadder(this,n).is0()}toAffine(p){return y(this,p)}clearCofactor(){let{h:p}=t;return p===Bt?this:this.multiplyUnsafe(p)}static fromHex(p,w=!1){let{d:C,a:R}=t,_=e.BYTES;p=J("pointHex",p,_),Lt("zip215",w);let O=p.slice(),P=p[_-1];O[_-1]=P&-129;let M=ue(O),q=w?f:e.ORDER;Et("pointHex.y",M,Ut,q);let z=l(M*M),it=l(z-Bt),ot=l(C*z-R),{isValid:ut,value:bt}=d(it,ot);if(!ut)throw new Error("Point.fromHex: invalid y coordinate");let et=(bt&Bt)===Bt,vt=(P&128)!==0;if(!w&&bt===Ut&&vt)throw new Error("Point.fromHex: x=0 and x_0=1");return vt!==et&&(bt=l(-bt)),g.fromAffine({x:bt,y:M})}static fromPrivateKey(p){return T(p).point}toRawBytes(){let{x:p,y:w}=this.toAffine(),C=Be(w,e.BYTES);return C[C.length-1]|=p&Bt?128:0,C}toHex(){return zt(this.toRawBytes())}}g.BASE=new g(t.Gx,t.Gy,Bt,l(t.Gx*t.Gy)),g.ZERO=new g(Ut,Bt,Bt,Ut);let{BASE:S,ZERO:U}=g,L=Xr(g,c*8);function k(m){return $(m,n)}function I(m){return k(ue(m))}function T(m){let p=c;m=J("private key",m,p);let w=J("hashed private key",i(m),2*p),C=x(w.slice(0,p)),R=w.slice(p,2*p),_=I(C),O=S.multiply(_),P=O.toRawBytes();return{head:C,prefix:R,scalar:_,point:O,pointBytes:P}}function Q(m){return T(m).pointBytes}function F(m=new Uint8Array,...p){let w=jt(...p);return I(i(E(w,J("context",m),!!s)))}function H(m,p,w={}){m=J("message",m),s&&(m=s(m));let{prefix:C,scalar:R,pointBytes:_}=T(p),O=F(w.context,C,m),P=S.multiply(O).toRawBytes(),M=F(w.context,P,_,m),q=k(O+M*R);Et("signature.s",q,Ut,n);let z=jt(P,Be(q,e.BYTES));return J("result",z,c*2)}let tt=Ul;function B(m,p,w,C=tt){let{context:R,zip215:_}=C,O=e.BYTES;m=J("signature",m,2*O),p=J("message",p),_!==void 0&&Lt("zip215",_),s&&(p=s(p));let P=ue(m.slice(O,2*O)),M,q,z;try{M=g.fromHex(w,_),q=g.fromHex(m.slice(0,O),_),z=S.multiplyUnsafe(P)}catch{return!1}if(!_&&M.isSmallOrder())return!1;let it=F(R,q.toRawBytes(),M.toRawBytes(),p);return q.add(M.multiplyUnsafe(it)).subtract(z).clearCofactor().equals(g.ZERO)}return S._setWindowSize(8),{CURVE:t,getPublicKey:Q,sign:H,verify:B,ExtendedPoint:g,utils:{getExtendedPublicKey:T,randomPrivateKey:()=>o(e.BYTES),precompute(m=8,p=g.BASE){return p._setWindowSize(m),p.multiply(BigInt(3)),p}}}}var $s=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),Fo=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),fd=BigInt(0),_l=BigInt(1),Ko=BigInt(2),hd=BigInt(3),Vl=BigInt(5),Hl=BigInt(8);function Ol(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),s=BigInt(80),i=$s,c=r*r%i*r%i,a=j(c,Ko,i)*c%i,f=j(a,_l,i)*r%i,l=j(f,Vl,i)*f%i,u=j(l,t,i)*l%i,d=j(u,e,i)*u%i,x=j(d,n,i)*d%i,E=j(x,s,i)*x%i,b=j(E,s,i)*x%i,h=j(b,t,i)*l%i;return{pow_p_5_8:j(h,Ko,i)*r%i,b2:c}}function Ml(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function Dl(r,t){let e=$s,n=$(t*t*t,e),s=$(n*n*t,e),i=Ol(r*s).pow_p_5_8,o=$(r*n*i,e),c=$(t*o*o,e),a=o,f=$(o*Fo,e),l=c===r,u=c===$(-r,e),d=c===$(-r*Fo,e);return l&&(o=a),(u||d)&&(o=f),Ho(o,e)&&(o=$(-o,e)),{isValid:l||u,value:o}}var Pl=fe($s,void 0,!0),Fl={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:Pl,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:Hl,Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:Lo,randomBytes:ze,adjustScalarBytes:Ml,uvRatio:Dl},qo=Po(Fl);var en=32;function $o(r,t,e){return qo.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}var rn=class{type="Ed25519";raw;constructor(t){this.raw=zs(t,en)}toMultihash(){return qt.digest(ke(this))}toCID(){return At.createV1(114,this.toMultihash())}toString(){return X.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:It(this.raw,t.raw)}verify(t,e){return $o(this.raw,e,t)}};function Gs(r){return r=zs(r,en),new rn(r)}function zs(r,t){if(r=Uint8Array.from(r??[]),r.length!==t)throw new rt(`Key must be a Uint8Array of length ${t}, got ${r.length}`);return r}function Zt(r=0){return new Uint8Array(r)}function ht(r=0){return new Uint8Array(r)}var ql=Math.pow(2,7),$l=Math.pow(2,14),zl=Math.pow(2,21),js=Math.pow(2,28),Zs=Math.pow(2,35),Ws=Math.pow(2,42),Js=Math.pow(2,49),K=128,dt=127;function Rt(r){if(r<ql)return 1;if(r<$l)return 2;if(r<zl)return 3;if(r<js)return 4;if(r<Zs)return 5;if(r<Ws)return 6;if(r<Js)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function Ys(r,t,e=0){switch(Rt(r)){case 8:t[e++]=r&255|K,r/=128;case 7:t[e++]=r&255|K,r/=128;case 6:t[e++]=r&255|K,r/=128;case 5:t[e++]=r&255|K,r/=128;case 4:t[e++]=r&255|K,r>>>=7;case 3:t[e++]=r&255|K,r>>>=7;case 2:t[e++]=r&255|K,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function Gl(r,t,e=0){switch(Rt(r)){case 8:t.set(e++,r&255|K),r/=128;case 7:t.set(e++,r&255|K),r/=128;case 6:t.set(e++,r&255|K),r/=128;case 5:t.set(e++,r&255|K),r/=128;case 4:t.set(e++,r&255|K),r>>>=7;case 3:t.set(e++,r&255|K),r>>>=7;case 2:t.set(e++,r&255|K),r>>>=7;case 1:{t.set(e++,r&255),r>>>=7;break}default:throw new Error("unreachable")}return t}function Xs(r,t){let e=r[t],n=0;if(n+=e&dt,e<K||(e=r[t+1],n+=(e&dt)<<7,e<K)||(e=r[t+2],n+=(e&dt)<<14,e<K)||(e=r[t+3],n+=(e&dt)<<21,e<K)||(e=r[t+4],n+=(e&dt)*js,e<K)||(e=r[t+5],n+=(e&dt)*Zs,e<K)||(e=r[t+6],n+=(e&dt)*Ws,e<K)||(e=r[t+7],n+=(e&dt)*Js,e<K))return n;throw new RangeError("Could not decode varint")}function jl(r,t){let e=r.get(t),n=0;if(n+=e&dt,e<K||(e=r.get(t+1),n+=(e&dt)<<7,e<K)||(e=r.get(t+2),n+=(e&dt)<<14,e<K)||(e=r.get(t+3),n+=(e&dt)<<21,e<K)||(e=r.get(t+4),n+=(e&dt)*js,e<K)||(e=r.get(t+5),n+=(e&dt)*Zs,e<K)||(e=r.get(t+6),n+=(e&dt)*Ws,e<K)||(e=r.get(t+7),n+=(e&dt)*Js,e<K))return n;throw new RangeError("Could not decode varint")}function Go(r,t,e=0){return t==null&&(t=ht(Rt(r))),t instanceof Uint8Array?Ys(r,t,e):Gl(r,t,e)}function jo(r,t=0){return r instanceof Uint8Array?Xs(r,t):jl(r,t)}var Qs=new Float32Array([-0]),he=new Uint8Array(Qs.buffer);function Wo(r,t,e){Qs[0]=r,t[e]=he[0],t[e+1]=he[1],t[e+2]=he[2],t[e+3]=he[3]}function Jo(r,t){return he[0]=r[t],he[1]=r[t+1],he[2]=r[t+2],he[3]=r[t+3],Qs[0]}var ti=new Float64Array([-0]),pt=new Uint8Array(ti.buffer);function Yo(r,t,e){ti[0]=r,t[e]=pt[0],t[e+1]=pt[1],t[e+2]=pt[2],t[e+3]=pt[3],t[e+4]=pt[4],t[e+5]=pt[5],t[e+6]=pt[6],t[e+7]=pt[7]}function Xo(r,t){return pt[0]=r[t],pt[1]=r[t+1],pt[2]=r[t+2],pt[3]=r[t+3],pt[4]=r[t+4],pt[5]=r[t+5],pt[6]=r[t+6],pt[7]=r[t+7],ti[0]}var Zl=BigInt(Number.MAX_SAFE_INTEGER),Wl=BigInt(Number.MIN_SAFE_INTEGER),kt=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 Ie;if(t<Zl&&t>Wl)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>Qo&&(s=0n,++n>Qo&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(t){if(t===0)return Ie;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):Ie}},Ie=new kt(0,0);Ie.toBigInt=function(){return 0n};Ie.zzEncode=Ie.zzDecode=function(){return this};Ie.length=function(){return 1};var Qo=4294967296n;function ta(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 ea(r,t,e){if(e-t<1)return"";let s,i=[],o=0,c;for(;t<e;)c=r[t++],c<128?i[o++]=c:c>191&&c<224?i[o++]=(c&31)<<6|r[t++]&63:c>239&&c<365?(c=((c&7)<<18|(r[t++]&63)<<12|(r[t++]&63)<<6|r[t++]&63)-65536,i[o++]=55296+(c>>10),i[o++]=56320+(c&1023)):i[o++]=(c&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 ei(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 _t(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function nn(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var ri=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,_t(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 _t(this,4);return nn(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw _t(this,4);return nn(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw _t(this,4);let t=Jo(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw _t(this,4);let t=Xo(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 _t(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return ea(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw _t(this,t);this.pos+=t}else do if(this.pos>=this.len)throw _t(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 kt(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 _t(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 _t(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 _t(this,8);let t=nn(this.buf,this.pos+=4),e=nn(this.buf,this.pos+=4);return new kt(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=Xs(this.buf,this.pos);return this.pos+=Rt(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 ni(r){return new ri(r instanceof Uint8Array?r:r.subarray())}function sn(r,t,e){let n=ni(r);return t.decode(n,void 0,e)}var si={};yt(si,{base10:()=>Jl});var Jl=ne({prefix:"9",name:"base10",alphabet:"0123456789"});var ii={};yt(ii,{base16:()=>Yl,base16upper:()=>Xl});var Yl=W({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Xl=W({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var oi={};yt(oi,{base2:()=>Ql});var Ql=W({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var ai={};yt(ai,{base256emoji:()=>sf});var na=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}"),tf=na.reduce((r,t,e)=>(r[e]=t,r),[]),ef=na.reduce((r,t,e)=>(r[t.codePointAt(0)]=e,r),[]);function rf(r){return r.reduce((t,e)=>(t+=tf[e],t),"")}function nf(r){let t=[];for(let e of r){let n=ef[e.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${e}`);t.push(n)}return new Uint8Array(t)}var sf=Oe({prefix:"\u{1F680}",name:"base256emoji",encode:rf,decode:nf});var ci={};yt(ci,{base36:()=>of,base36upper:()=>af});var of=ne({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),af=ne({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var ui={};yt(ui,{base64:()=>cf,base64pad:()=>uf,base64url:()=>lf,base64urlpad:()=>ff});var cf=W({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),uf=W({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),lf=W({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),ff=W({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var li={};yt(li,{base8:()=>hf});var hf=W({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var fi={};yt(fi,{identity:()=>df});var df=Oe({prefix:"\0",name:"identity",encode:r=>lo(r),decode:r=>uo(r)});var Wd=new TextEncoder,Jd=new TextDecoder;var pi={};yt(pi,{sha256:()=>Ne,sha512:()=>mf});function di({name:r,code:t,encode:e}){return new hi(r,t,e)}var hi=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?Ct(this.code,e):e.then(n=>Ct(this.code,n))}else throw Error("Unknown type, must be binary type")}};function ia(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var Ne=di({name:"sha2-256",code:18,encode:ia("SHA-256")}),mf=di({name:"sha2-512",code:19,encode:ia("SHA-512")});var gi={...fi,...oi,...li,...si,...ii,...As,...ci,...Ss,...ui,...ai},c0={...pi,...Ns};function aa(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var oa=aa("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),mi=aa("ascii","a",r=>{let t="a";for(let e=0;e<r.length;e++)t+=String.fromCharCode(r[e]);return t},r=>{r=r.substring(1);let t=ht(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),bf={utf8:oa,"utf-8":oa,hex:gi.base16,latin1:mi,ascii:mi,binary:mi,...gi},on=bf;function Z(r,t="utf8"){let e=on[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function bi(r){let t=r??8192,e=t>>>1,n,s=t;return function(o){if(o<1||o>e)return ht(o);s+o>t&&(n=ht(t),s=0);let c=n.subarray(s,s+=o);return s&7&&(s=(s|7)+1),c}}var Ce=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function yi(){}var xi=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},yf=bi();function wf(r){return globalThis.Buffer!=null?ht(r):yf(r)}var gr=class{len;head;tail;states;constructor(){this.len=0,this.head=new Ce(yi,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new Ce(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new vi((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(an,10,kt.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=kt.fromBigInt(t);return this._push(an,e.length(),e)}uint64Number(t){return this._push(Ys,Rt(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=kt.fromBigInt(t).zzEncode();return this._push(an,e.length(),e)}sint64Number(t){let e=kt.fromNumber(t).zzEncode();return this._push(an,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(wi,1,t?1:0)}fixed32(t){return this._push(pr,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=kt.fromBigInt(t);return this._push(pr,4,e.lo)._push(pr,4,e.hi)}fixed64Number(t){let e=kt.fromNumber(t);return this._push(pr,4,e.lo)._push(pr,4,e.hi)}fixed64String(t){return this.fixed64(BigInt(t))}sfixed64(t){return this.fixed64(t)}sfixed64Number(t){return this.fixed64Number(t)}sfixed64String(t){return this.fixed64String(t)}float(t){return this._push(Wo,4,t)}double(t){return this._push(Yo,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(wi,1,0):this.uint32(e)._push(vf,e,t)}string(t){let e=ta(t);return e!==0?this.uint32(e)._push(ei,e,t):this._push(wi,1,0)}fork(){return this.states=new xi(this),this.head=this.tail=new Ce(yi,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 Ce(yi,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=wf(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function wi(r,t,e){t[e]=r&255}function xf(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var vi=class extends Ce{next;constructor(t,e){super(xf,t,e),this.next=void 0}};function an(r,t,e){for(;r.hi!==0;)t[e++]=r.lo&127|128,r.lo=(r.lo>>>7|r.hi<<25)>>>0,r.hi>>>=7;for(;r.lo>127;)t[e++]=r.lo&127|128,r.lo=r.lo>>>7;t[e++]=r.lo}function pr(r,t,e){t[e]=r&255,t[e+1]=r>>>8&255,t[e+2]=r>>>16&255,t[e+3]=r>>>24}function vf(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(gr.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(Ef,t,r),this},gr.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(Bf,t,r),this});function Ef(r,t,e){t.set(r,e)}function Bf(r,t,e){r.length<40?ei(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(Z(r),e)}function Ei(){return new gr}function cn(r,t){let e=Ei();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var Ze;(function(r){r[r.VARINT=0]="VARINT",r[r.BIT64=1]="BIT64",r[r.LENGTH_DELIMITED=2]="LENGTH_DELIMITED",r[r.START_GROUP=3]="START_GROUP",r[r.END_GROUP=4]="END_GROUP",r[r.BIT32=5]="BIT32"})(Ze||(Ze={}));function un(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function Bi(r){function t(s){if(r[s.toString()]==null)throw new Error("Invalid enum value");return r[s]}let e=function(i,o){let c=t(i);o.int32(c)},n=function(i){let o=i.int32();return t(o)};return un("enum",Ze.VARINT,e,n)}function ln(r,t){return un("message",Ze.LENGTH_DELIMITED,r,t)}var st;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.secp256k1="secp256k1"})(st||(st={}));var Si;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1"})(Si||(Si={}));(function(r){r.codec=()=>Bi(Si)})(st||(st={}));var Ot;(function(r){let t;r.codec=()=>(t==null&&(t=ln((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),st.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let i={},o=n==null?e.len:e.pos+n;for(;e.pos<o;){let c=e.uint32();switch(c>>>3){case 1:{i.Type=st.codec().decode(e);break}case 2:{i.Data=e.bytes();break}default:{e.skipType(c&7);break}}}return i})),t),r.encode=e=>cn(e,r.codec()),r.decode=(e,n)=>sn(e,r.codec(),n)})(Ot||(Ot={}));var Ai;(function(r){let t;r.codec=()=>(t==null&&(t=ln((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),st.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let i={},o=n==null?e.len:e.pos+n;for(;e.pos<o;){let c=e.uint32();switch(c>>>3){case 1:{i.Type=st.codec().decode(e);break}case 2:{i.Data=e.bytes();break}default:{e.skipType(c&7);break}}}return i})),t),r.encode=e=>cn(e,r.codec()),r.decode=(e,n)=>sn(e,r.codec(),n)})(Ai||(Ai={}));var Ar={};yt(Ar,{MAX_RSA_KEY_SIZE:()=>rs,generateRSAKeyPair:()=>sc,jwkToJWKKeyPair:()=>ic,jwkToPkcs1:()=>Df,jwkToPkix:()=>_i,jwkToRSAPrivateKey:()=>nc,pkcs1ToJwk:()=>tc,pkcs1ToRSAPrivateKey:()=>rc,pkixToJwk:()=>ec,pkixToRSAPublicKey:()=>Vi});var Sf=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]),de=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),pe=new Uint32Array(64),ki=class extends Ge{constructor(){super(64,32,8,!1),this.A=de[0]|0,this.B=de[1]|0,this.C=de[2]|0,this.D=de[3]|0,this.E=de[4]|0,this.F=de[5]|0,this.G=de[6]|0,this.H=de[7]|0}get(){let{A:t,B:e,C:n,D:s,E:i,F:o,G:c,H:a}=this;return[t,e,n,s,i,o,c,a]}set(t,e,n,s,i,o,c,a){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=c|0,this.H=a|0}process(t,e){for(let u=0;u<16;u++,e+=4)pe[u]=t.getUint32(e,!1);for(let u=16;u<64;u++){let d=pe[u-15],x=pe[u-2],E=Tt(d,7)^Tt(d,18)^d>>>3,b=Tt(x,17)^Tt(x,19)^x>>>10;pe[u]=b+pe[u-7]+E+pe[u-16]|0}let{A:n,B:s,C:i,D:o,E:c,F:a,G:f,H:l}=this;for(let u=0;u<64;u++){let d=Tt(c,6)^Tt(c,11)^Tt(c,25),x=l+d+No(c,a,f)+Sf[u]+pe[u]|0,b=(Tt(n,2)^Tt(n,13)^Tt(n,22))+Co(n,s,i)|0;l=f,f=a,a=c,c=o+x|0,o=i,i=s,s=n,n=x+b|0}n=n+this.A|0,s=s+this.B|0,i=i+this.C|0,o=o+this.D|0,c=c+this.E|0,a=a+this.F|0,f=f+this.G|0,l=l+this.H|0,this.set(n,s,i,o,c,a,f,l)}roundClean(){pe.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var We=jr(()=>new ki);var D=oo(ua());function Te(r,t){let e=0;if(r.length===1)return r[0];for(let n=r.length-1;n>=0;n--)e+=r[r.length-1-n]*Math.pow(2,t*n);return e}function ge(r,t,e=-1){let n=e,s=r,i=0,o=Math.pow(2,t);for(let c=1;c<8;c++){if(r<o){let a;if(n<0)a=new ArrayBuffer(c),i=c;else{if(n<c)return new ArrayBuffer(0);a=new ArrayBuffer(n),i=n}let f=new Uint8Array(a);for(let l=c-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 a}o*=Math.pow(2,t)}return new ArrayBuffer(0)}function dn(...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 Ni(){let r=new Uint8Array(this.valueHex);if(this.valueHex.byteLength>=2){let c=r[0]===255&&r[1]&128,a=r[0]===0&&(r[1]&128)===0;(c||a)&&this.warnings.push("Needlessly long format")}let t=new ArrayBuffer(this.valueHex.byteLength),e=new Uint8Array(t);for(let c=0;c<this.valueHex.byteLength;c++)e[c]=0;e[0]=r[0]&128;let n=Te(e,8),s=new ArrayBuffer(this.valueHex.byteLength),i=new Uint8Array(s);for(let c=0;c<this.valueHex.byteLength;c++)i[c]=r[c];return i[0]&=127,Te(i,8)-n}function la(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,c=ge(o,8,n),a=new Uint8Array(c);return a[0]|=128,c}let s=ge(t,8,n),i=new Uint8Array(s);if(i[0]&128){let o=s.slice(0),c=new Uint8Array(o);s=new ArrayBuffer(s.byteLength+1),i=new Uint8Array(s);for(let a=0;a<o.byteLength;a++)i[a+1]=c[a];i[0]=0}return s}e*=Math.pow(2,8)}return new ArrayBuffer(0)}function fa(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 St(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 q0=Math.log(2);function pn(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function Ci(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 Qt(r,t,e,n){return t instanceof Uint8Array?t.byteLength?e<0?(r.error="Wrong parameter: inputOffset less than zero",!1):n<0?(r.error="Wrong parameter: inputLength less than zero",!1):t.byteLength-e-n<0?(r.error="End of input reached before message was fully decoded (inconsistent offset and length values)",!1):!0:(r.error="Wrong parameter: inputBuffer has zero length",!1):(r.error="Wrong parameter: inputBuffer must be 'Uint8Array'",!1)}var br=class{constructor(){this.items=[]}write(t){this.items.push(t)}final(){return Ci(this.items)}},mr=[new Uint8Array([1])],ha="0123456789";var tr="",Vt=new ArrayBuffer(0),Ti=new Uint8Array(0),yr="EndOfContent",pa="OCTET STRING",ga="BIT STRING";function te(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?D.BufferSourceConverter.toUint8Array(i.valueHex):Ti}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(!Qt(this,o,s,i))return-1;let c=s+i;return this.valueHexView=o.subarray(s,c),this.valueHexView.length?(this.blockLength=i,c):(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",Vt)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:D.Convert.ToHex(this.valueHexView)}}},t.NAME="hexBlock",t}var Jt=class{constructor({blockLength:t=0,error:e=tr,warnings:n=[],valueBeforeDecode:s=Ti}={}){this.blockLength=t,this.error=e,this.warnings=n,this.valueBeforeDecodeView=D.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:D.Convert.ToHex(this.valueBeforeDecodeView)}}};Jt.NAME="baseBlock";var gt=class extends Jt{fromBER(t,e,n){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}toBER(t,e){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}};gt.NAME="valueBlock";var gn=class extends te(Jt){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?D.BufferSourceConverter.toUint8Array(t.valueHex):Ti,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",Vt}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=ge(this.tagNumber,7),i=new Uint8Array(s),o=s.byteLength,c=new Uint8Array(o+1);if(c[0]=e|31,!t){for(let a=0;a<o-1;a++)c[a+1]=i[a]|128;c[o]=i[o-1]}return c.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=D.BufferSourceConverter.toUint8Array(t);if(!Qt(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 c=i[0]&31;if(c!==31)this.tagNumber=c,this.blockLength=1;else{let a=1,f=this.valueHexView=new Uint8Array(255),l=255;for(;i[a]&128;){if(f[a-1]=i[a]&127,a++,a>=i.length)return this.error="End of input reached before message was fully decoded",-1;if(a===l){l+=255;let d=new Uint8Array(l);for(let x=0;x<f.length;x++)d[x]=f[x];f=this.valueHexView=new Uint8Array(l)}}this.blockLength=a+1,f[a-1]=i[a]&127;let u=new Uint8Array(a);for(let d=0;d<a;d++)u[d]=f[d];f=this.valueHexView=new Uint8Array(a),f.set(u),this.blockLength<=9?this.tagNumber=Te(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}}};gn.NAME="identificationBlock";var mn=class extends Jt{constructor({lenBlock:t={}}={}){var e,n,s;super(),this.isIndefiniteForm=(e=t.isIndefiniteForm)!==null&&e!==void 0?e:!1,this.longFormUsed=(n=t.longFormUsed)!==null&&n!==void 0?n:!1,this.length=(s=t.length)!==null&&s!==void 0?s:0}fromBER(t,e,n){let s=D.BufferSourceConverter.toUint8Array(t);if(!Qt(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 c=e+1,a=s.subarray(c,c+o);return a[o-1]===0&&this.warnings.push("Needlessly long encoded length"),this.length=Te(a,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=ge(this.length,8);if(s.byteLength>127)return this.error="Too big length",Vt;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}}};mn.NAME="lengthBlock";var A={},lt=class extends Jt{constructor({name:t=tr,optional:e=!1,primitiveSchema:n,...s}={},i){super(s),this.name=t,this.optional=e,n&&(this.primitiveSchema=n),this.idBlock=new gn(s),this.lenBlock=new mn(s),this.valueBlock=i?new i(s):new gt(s)}fromBER(t,e,n){let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}toBER(t,e){let n=e||new br;e||ma(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?Vt: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():D.Convert.ToHex(this.toBER())}onAsciiEncoding(){return`${this.constructor.NAME} : ${D.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 fa(e,n)}};lt.NAME="BaseBlock";function ma(r){if(r instanceof A.Constructed)for(let t of r.valueBlock.value)ma(t)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var bn=class extends lt{constructor({value:t=tr,...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}'`}};bn.NAME="BaseStringBlock";var yn=class extends te(gt){constructor({isHexOnly:t=!0,...e}={}){super(e),this.isHexOnly=t}};yn.NAME="PrimitiveValueBlock";var ba,wn=class extends lt{constructor(t={}){super(t,yn),this.idBlock.isConstructed=!1}};ba=wn;A.Primitive=ba;wn.NAME="PRIMITIVE";function Rf(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 Qn(r,t=0,e=r.length){let n=t,s=new lt({},gt),i=new Jt;if(!Qt(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 c=s.idBlock.fromBER(r,t,e);if(s.idBlock.warnings.length&&s.warnings.concat(s.idBlock.warnings),c===-1)return s.error=s.idBlock.error,{offset:-1,result:s};if(t=c,e-=s.idBlock.blockLength,c=s.lenBlock.fromBER(r,t,e),s.lenBlock.warnings.length&&s.warnings.concat(s.lenBlock.warnings),c===-1)return s.error=s.lenBlock.error,{offset:-1,result:s};if(t=c,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 a=lt;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};a=A.EndOfContent;break;case 1:a=A.Boolean;break;case 2:a=A.Integer;break;case 3:a=A.BitString;break;case 4:a=A.OctetString;break;case 5:a=A.Null;break;case 6:a=A.ObjectIdentifier;break;case 10:a=A.Enumerated;break;case 12:a=A.Utf8String;break;case 13:a=A.RelativeObjectIdentifier;break;case 14:a=A.TIME;break;case 15:return s.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:s};case 16:a=A.Sequence;break;case 17:a=A.Set;break;case 18:a=A.NumericString;break;case 19:a=A.PrintableString;break;case 20:a=A.TeletexString;break;case 21:a=A.VideotexString;break;case 22:a=A.IA5String;break;case 23:a=A.UTCTime;break;case 24:a=A.GeneralizedTime;break;case 25:a=A.GraphicString;break;case 26:a=A.VisibleString;break;case 27:a=A.GeneralString;break;case 28:a=A.UniversalString;break;case 29:a=A.CharacterString;break;case 30:a=A.BmpString;break;case 31:a=A.DATE;break;case 32:a=A.TimeOfDay;break;case 33:a=A.DateTime;break;case 34:a=A.Duration;break;default:{let f=s.idBlock.isConstructed?new A.Constructed:new A.Primitive;f.idBlock=s.idBlock,f.lenBlock=s.lenBlock,f.warnings=s.warnings,s=f}}break;case 2:case 3:case 4:default:a=s.idBlock.isConstructed?A.Constructed:A.Primitive}return s=Rf(s,a),c=s.fromBER(r,t,s.lenBlock.isIndefiniteForm?e:s.lenBlock.length),s.valueBeforeDecodeView=r.subarray(n,n+s.blockLength),{offset:c,result:s}}function Li(r){if(!r.byteLength){let t=new lt({},gt);return t.error="Input buffer has zero length",{offset:-1,result:t}}return Qn(D.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function _f(r,t){return r?1:t}var Mt=class extends gt{constructor({value:t=[],isIndefiniteForm:e=!1,...n}={}){super(n),this.value=t,this.isIndefiniteForm=e}fromBER(t,e,n){let s=D.BufferSourceConverter.toUint8Array(t);if(!Qt(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(;_f(this.isIndefiniteForm,n)>0;){let o=Qn(s,i,n);if(o.offset===-1)return this.error=o.result.error,this.warnings.concat(o.result.warnings),-1;if(i=o.offset,this.blockLength+=o.result.blockLength,n-=o.result.blockLength,this.value.push(o.result),this.isIndefiniteForm&&o.result.constructor.NAME===yr)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===yr?this.value.pop():this.warnings.push("No EndOfContent block encoded")),i}toBER(t,e){let n=e||new br;for(let s=0;s<this.value.length;s++)this.value[s].toBER(t,n);return e?Vt:n.final()}toJSON(){let t={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let e of this.value)t.value.push(e.toJSON());return t}};Mt.NAME="ConstructedValueBlock";var ya,me=class extends lt{constructor(t={}){super(t,Mt),this.idBlock.isConstructed=!0}fromBER(t,e,n){this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm;let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}onAsciiEncoding(){let t=[];for(let n of this.valueBlock.value)t.push(n.toString("ascii").split(`
3
3
  `).map(s=>` ${s}`).join(`
4
4
  `));let e=this.idBlock.tagClass===3?`[${this.idBlock.tagNumber}]`:this.constructor.NAME;return t.length?`${e} :
5
5
  ${t.join(`
6
- `)}`:`${e} :`}};tc=ke;I.Constructed=tc;ke.NAME="CONSTRUCTED";var Fn=class extends wt{fromBER(t,e,n){return e}toBER(t){return Kt}};Fn.override="EndOfContentValueBlock";var ec,qn=class extends pt{constructor(t={}){super(t,Fn),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};ec=qn;I.EndOfContent=ec;qn.NAME=Yr;var rc,Re=class extends pt{constructor(t={}){super(t,wt),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}`}};rc=Re;I.Null=rc;Re.NAME="NULL";var $n=class extends he(wt){constructor({value:t,...e}={}){super(e),e.valueHex?this.valueHexView=M.BufferSourceConverter.toUint8Array(e.valueHex):this.valueHexView=new Uint8Array(1),t&&(this.value=t)}get value(){for(let t of this.valueHexView)if(t>0)return!0;return!1}set value(t){this.valueHexView[0]=t?255:0}fromBER(t,e,n){let s=M.BufferSourceConverter.toUint8Array(t);return fe(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,Yi.call(this),this.blockLength=n,e+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};$n.NAME="BooleanValueBlock";var nc,Gn=class extends pt{constructor(t={}){super(t,$n),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}`}};nc=Gn;I.Boolean=nc;Gn.NAME="BOOLEAN";var zn=class extends he(jt){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=jt.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let i=0;i<this.value.length;i++){let o=this.value[i].constructor.NAME;if(o===Yr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(o!==Wa)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?jt.prototype.toBER.call(this,t,e):t?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};zn.NAME="OctetStringValueBlock";var sc,ue=class r extends pt{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,i;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((i=n.value)===null||i===void 0)&&i.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},zn),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=xs(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} : ${M.Convert.ToHex(this.valueBlock.valueHexView)}`}getValue(){if(!this.idBlock.isConstructed)return this.valueBlock.valueHexView.slice().buffer;let t=[];for(let e of this.valueBlock.value)e instanceof r&&t.push(e.valueBlock.valueHexView);return M.BufferSourceConverter.concat(t)}};sc=ue;I.OctetString=sc;ue.NAME=Wa;var jn=class extends he(jt){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=jt.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let c of this.value){let a=c.constructor.NAME;if(a===Yr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(a!==Ja)return this.error="BIT STRING may consists of BIT STRINGs only",-1;let f=c.valueBlock;if(this.unusedBits>0&&f.unusedBits>0)return this.error='Using of "unused bits" inside constructive BIT STRING allowed for least one only',-1;this.unusedBits=f.unusedBits}return s}let i=M.BufferSourceConverter.toUint8Array(t);if(!fe(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 c=o.subarray(1);try{if(c.byteLength){let a=xs(c,0,c.byteLength);a.offset!==-1&&a.offset===n-1&&(this.value=[a.result])}}catch{}}return this.valueHexView=o.subarray(1),this.blockLength=o.length,e+n}toBER(t,e){if(this.isConstructed)return jt.prototype.toBER.call(this,t,e);if(t)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return Kt;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 ic,vr=class extends pt{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,i;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((i=n.value)===null||i===void 0)&&i.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},jn),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)}`}}};ic=vr;I.BitString=ic;vr.NAME=Ja;var oc;function Sh(r,t){let e=new Uint8Array([0]),n=new Uint8Array(r),s=new Uint8Array(t),i=n.slice(0),o=i.length-1,c=s.slice(0),a=c.length-1,f=0,l=a<o?o:a,u=0;for(let h=l;h>=0;h--,u++){switch(!0){case u<c.length:f=i[o-u]+c[a-u]+e[0];break;default:f=i[o-u]+e[0]}switch(e[0]=f/10,!0){case u>=i.length:i=Dn(new Uint8Array([f%10]),i);break;default:i[o-u]=f%10}}return e[0]>0&&(i=Dn(e,i)),i}function Za(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=Dn(e,n)),zr.push(n)}return zr[r]}function Ih(r,t){let e=0,n=new Uint8Array(r),s=new Uint8Array(t),i=n.slice(0),o=i.length-1,c=s.slice(0),a=c.length-1,f,l=0;for(let u=a;u>=0;u--,l++)switch(f=i[o-l]-c[a-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-a+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 he(wt){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=Yi.call(this)))}set valueDec(t){this._valueDec=t,this.isHexOnly=!1,this.valueHexView=new Uint8Array(za(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="",c=!1;for(let a=i.byteLength-1;a>=0;a--){s=i[a];for(let f=0;f<8;f++){if((s&1)===1)switch(n){case t:e=Ih(Za(n),e),o="-";break;default:e=Sh(e,Za(n))}n++,s>>=1}}for(let a=0;a<e.length;a++)e[a]&&(c=!0),c&&(o+=Ya.charAt(e[a]));return c===!1&&(o+=Ya.charAt(0)),o}};oc=Zr;Zr.NAME="IntegerValueBlock";Object.defineProperty(oc.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var ac,rt=class r extends pt{constructor(t={}){super(t,Zr),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return Pn(),BigInt(this.valueBlock.toString())}static fromBigInt(t){Pn();let e=BigInt(t),n=new jr,s=e.toString(16).replace(/^-/,""),i=new Uint8Array(M.Convert.FromHex(s));if(e<0){let c=new Uint8Array(i.length+(i[0]&128?1:0));c[0]|=128;let f=BigInt(`0x${M.Convert.ToHex(c)}`)+e,l=M.BufferSourceConverter.toUint8Array(M.Convert.FromHex(f.toString(16)));l[0]|=128,n.write(l)}else i[0]&128&&n.write(new Uint8Array([0])),n.write(i);return new r({valueHex:n.final()})}convertToDER(){let t=new r({valueHex:this.valueBlock.valueHexView});return t.valueBlock.toDER(),t}convertFromDER(){return new r({valueHex:this.valueBlock.valueHexView[0]===0?this.valueBlock.valueHexView.subarray(1):this.valueBlock.valueHexView})}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()}`}};ac=rt;I.Integer=ac;rt.NAME="INTEGER";var cc,Yn=class extends rt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};cc=Yn;I.Enumerated=cc;Yn.NAME="ENUMERATED";var Wr=class extends he(wt){constructor({valueDec:t=-1,isFirstSid:e=!1,...n}={}){super(n),this.valueDec=t,this.isFirstSid=e}fromBER(t,e,n){if(!n)return e;let s=M.BufferSourceConverter.toUint8Array(t);if(!fe(this,s,e,n))return-1;let i=s.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let c=0;c<n&&(this.valueHexView[c]=i[c]&127,this.blockLength++,!!(i[c]&128));c++);let o=new Uint8Array(this.blockLength);for(let c=0;c<this.blockLength;c++)o[c]=this.valueHexView[c];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=qe(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}set valueBigInt(t){Pn();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=Ie(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Kt;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),i=e.byteLength-1;for(let o=0;o<i;o++)n[o]=s[o]|128;n[i]=s[i]}return n}toString(){let t="";if(this.isHexOnly)t=M.Convert.ToHex(this.valueHexView);else if(this.isFirstSid){let e=this.valueDec;this.valueDec<=39?t="0.":this.valueDec<=79?(t="1.",e-=40):(t="2.",e-=80),t+=e.toString()}else t=this.valueDec.toString();return t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec,isFirstSid:this.isFirstSid}}};Wr.NAME="sidBlock";var Zn=class extends wt{constructor({value:t=Br,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let i=new Wr;if(s=i.fromBER(t,s,n),s===-1)return this.blockLength=0,this.error=i.error,s;this.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,Kt;e.push(s)}return Zi(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],c=0;switch(o.valueDec){case 0:break;case 1:c=40;break;case 2:c=80;break;default:this.value=[];return}let a=parseInt(s,10);if(isNaN(a))return;o.valueDec=a+c,i=!1}else{let o=new Wr;if(s>Number.MAX_SAFE_INTEGER){Pn();let c=BigInt(s);o.valueBigInt=c}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}};Zn.NAME="ObjectIdentifierValueBlock";var uc,Mt=class extends pt{constructor(t={}){super(t,Zn),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()}}};uc=Mt;I.ObjectIdentifier=uc;Mt.NAME="OBJECT IDENTIFIER";var Jr=class extends he(ce){constructor({valueDec:t=0,...e}={}){super(e),this.valueDec=t}fromBER(t,e,n){if(n===0)return e;let s=M.BufferSourceConverter.toUint8Array(t);if(!fe(this,s,e,n))return-1;let i=s.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let c=0;c<n&&(this.valueHexView[c]=i[c]&127,this.blockLength++,!!(i[c]&128));c++);let o=new Uint8Array(this.blockLength);for(let c=0;c<this.blockLength;c++)o[c]=this.valueHexView[c];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=qe(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=Ie(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Kt;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),i=e.byteLength-1;for(let o=0;o<i;o++)n[o]=s[o]|128;n[i]=s[i]}return n.buffer}toString(){let t="";return this.isHexOnly?t=M.Convert.ToHex(this.valueHexView):t=this.valueDec.toString(),t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};Jr.NAME="relativeSidBlock";var Wn=class extends wt{constructor({value:t=Br,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let i=new 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,Kt;n.push(i)}return Zi(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}};Wn.NAME="RelativeObjectIdentifierValueBlock";var lc,Jn=class extends pt{constructor(t={}){super(t,Wn),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()}}};lc=Jn;I.RelativeObjectIdentifier=lc;Jn.NAME="RelativeObjectIdentifier";var fc,ft=class extends ke{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};fc=ft;I.Sequence=fc;ft.NAME="SEQUENCE";var hc,Xn=class extends ke{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};hc=Xn;I.Set=hc;Xn.NAME="SET";var Qn=class extends he(wt){constructor({...t}={}){super(t),this.isHexOnly=!0,this.value=Br}toJSON(){return{...super.toJSON(),value:this.value}}};Qn.NAME="StringValueBlock";var ts=class extends Qn{};ts.NAME="SimpleStringValueBlock";var At=class extends Hn{constructor({...t}={}){super(t,ts)}fromBuffer(t){this.valueBlock.value=String.fromCharCode.apply(null,M.BufferSourceConverter.toUint8Array(t))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e);for(let s=0;s<e;s++)n[s]=t.charCodeAt(s);this.valueBlock.value=t}};At.NAME="SIMPLE STRING";var es=class extends At{fromBuffer(t){this.valueBlock.valueHexView=M.BufferSourceConverter.toUint8Array(t);try{this.valueBlock.value=M.Convert.ToUtf8String(t)}catch(e){this.warnings.push(`Error during "decodeURIComponent": ${e}, using raw string`),this.valueBlock.value=M.Convert.ToBinary(t)}}fromString(t){this.valueBlock.valueHexView=new Uint8Array(M.Convert.FromUtf8String(t)),this.valueBlock.value=t}};es.NAME="Utf8StringValueBlock";var dc,le=class extends es{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};dc=le;I.Utf8String=dc;le.NAME="UTF8String";var rs=class extends At{fromBuffer(t){this.valueBlock.value=M.Convert.ToUtf16String(t),this.valueBlock.valueHexView=M.BufferSourceConverter.toUint8Array(t)}fromString(t){this.valueBlock.value=t,this.valueBlock.valueHexView=new Uint8Array(M.Convert.FromUtf16String(t))}};rs.NAME="BmpStringValueBlock";var pc,ns=class extends rs{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};pc=ns;I.BmpString=pc;ns.NAME="BMPString";var ss=class extends At{fromBuffer(t){let e=ArrayBuffer.isView(t)?t.slice().buffer:t.slice(0),n=new Uint8Array(e);for(let s=0;s<n.length;s+=4)n[s]=n[s+3],n[s+1]=n[s+2],n[s+2]=0,n[s+3]=0;this.valueBlock.value=String.fromCharCode.apply(null,new Uint32Array(e))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e*4);for(let s=0;s<e;s++){let i=Ie(t.charCodeAt(s),8),o=new Uint8Array(i);if(o.length>4)continue;let c=4-o.length;for(let a=o.length-1;a>=0;a--)n[s*4+a+c]=o[a]}this.valueBlock.value=t}};ss.NAME="UniversalStringValueBlock";var gc,is=class extends ss{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};gc=is;I.UniversalString=gc;is.NAME="UniversalString";var yc,os=class extends At{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};yc=os;I.NumericString=yc;os.NAME="NumericString";var mc,as=class extends At{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};mc=as;I.PrintableString=mc;as.NAME="PrintableString";var bc,cs=class extends At{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};bc=cs;I.TeletexString=bc;cs.NAME="TeletexString";var wc,us=class extends At{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};wc=us;I.VideotexString=wc;us.NAME="VideotexString";var xc,ls=class extends At{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};xc=ls;I.IA5String=xc;ls.NAME="IA5String";var Ec,fs=class extends At{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};Ec=fs;I.GraphicString=Ec;fs.NAME="GraphicString";var vc,Xr=class extends At{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};vc=Xr;I.VisibleString=vc;Xr.NAME="VisibleString";var Bc,hs=class extends At{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};Bc=hs;I.GeneralString=Bc;hs.NAME="GeneralString";var Ac,ds=class extends At{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};Ac=ds;I.CharacterString=Ac;ds.NAME="CharacterString";var Sc,Qr=class extends Xr{constructor({value:t,valueDate:e,...n}={}){if(super(n),this.year=0,this.month=0,this.day=0,this.hour=0,this.minute=0,this.second=0,t){this.fromString(t),this.valueBlock.valueHexView=new Uint8Array(t.length);for(let s=0;s<t.length;s++)this.valueBlock.valueHexView[s]=t.charCodeAt(s)}e&&(this.fromDate(e),this.valueBlock.valueHexView=new Uint8Array(this.toBuffer())),this.idBlock.tagClass=1,this.idBlock.tagNumber=23}fromBuffer(t){this.fromString(String.fromCharCode.apply(null,M.BufferSourceConverter.toUint8Array(t)))}toBuffer(){let t=this.toString(),e=new ArrayBuffer(t.length),n=new Uint8Array(e);for(let s=0;s<t.length;s++)n[s]=t.charCodeAt(s);return e}fromDate(t){this.year=t.getUTCFullYear(),this.month=t.getUTCMonth()+1,this.day=t.getUTCDate(),this.hour=t.getUTCHours(),this.minute=t.getUTCMinutes(),this.second=t.getUTCSeconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second))}fromString(t){let n=/(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})Z/ig.exec(t);if(n===null){this.error="Wrong input string for conversion";return}let s=parseInt(n[1],10);s>=50?this.year=1900+s:this.year=2e3+s,this.month=parseInt(n[2],10),this.day=parseInt(n[3],10),this.hour=parseInt(n[4],10),this.minute=parseInt(n[5],10),this.second=parseInt(n[6],10)}toString(t="iso"){if(t==="iso"){let e=new Array(7);return e[0]=Nt(this.year<2e3?this.year-1900:this.year-2e3,2),e[1]=Nt(this.month,2),e[2]=Nt(this.day,2),e[3]=Nt(this.hour,2),e[4]=Nt(this.minute,2),e[5]=Nt(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}}};Sc=Qr;I.UTCTime=Sc;Qr.NAME="UTCTime";var Ic,ps=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,c=0,a=0;if(t[t.length-1]==="Z")n=t.substring(0,t.length-1),e=!0;else{let u=new Number(t[t.length-1]);if(isNaN(u.valueOf()))throw new Error("Wrong input string for conversion");n=t}if(e){if(n.indexOf("+")!==-1)throw new Error("Wrong input string for conversion");if(n.indexOf("-")!==-1)throw new Error("Wrong input string for conversion")}else{let u=1,h=n.indexOf("+"),b="";if(h===-1&&(h=n.indexOf("-"),u=-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 E=parseInt(b.substring(0,2),10);if(isNaN(E.valueOf()))throw new Error("Wrong input string for conversion");if(c=u*E,b.length===4){if(E=parseInt(b.substring(2,4),10),isNaN(E.valueOf()))throw new Error("Wrong input string for conversion");a=u*E}}}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)+c;break;case 5:this.minute=parseInt(l[u],10)+a;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(Nt(this.year,4)),e.push(Nt(this.month,2)),e.push(Nt(this.day,2)),e.push(Nt(this.hour,2)),e.push(Nt(this.minute,2)),e.push(Nt(this.second,2)),this.millisecond!==0&&(e.push("."),e.push(Nt(this.millisecond,3))),e.push("Z"),e.join("")}return super.toString(t)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};Ic=ps;I.GeneralizedTime=Ic;ps.NAME="GeneralizedTime";var kc,gs=class extends le{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};kc=gs;I.DATE=kc;gs.NAME="DATE";var Rc,ys=class extends le{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};Rc=ys;I.TimeOfDay=Rc;ys.NAME="TimeOfDay";var Nc,ms=class extends le{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};Nc=ms;I.DateTime=Nc;ms.NAME="DateTime";var _c,bs=class extends le{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};_c=bs;I.Duration=_c;bs.NAME="Duration";var Tc,ws=class extends le{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};Tc=ws;I.TIME=Tc;ws.NAME="TIME";function Rh(r){let{result:t}=Ar(r),e=t.valueBlock.value;return{n:Y(Yt(e[1].toBigInt()),"base64url"),e:Y(Yt(e[2].toBigInt()),"base64url"),d:Y(Yt(e[3].toBigInt()),"base64url"),p:Y(Yt(e[4].toBigInt()),"base64url"),q:Y(Yt(e[5].toBigInt()),"base64url"),dp:Y(Yt(e[6].toBigInt()),"base64url"),dq:Y(Yt(e[7].toBigInt()),"base64url"),qi:Y(Yt(e[8].toBigInt()),"base64url"),kty:"RSA",alg:"RS256"}}function Nh(r){if(r.n==null||r.e==null||r.d==null||r.p==null||r.q==null||r.dp==null||r.dq==null||r.qi==null)throw new A("JWK was missing components","ERR_INVALID_PARAMETERS");let e=new ft({value:[new rt({value:0}),rt.fromBigInt(Zt(q(r.n,"base64url"))),rt.fromBigInt(Zt(q(r.e,"base64url"))),rt.fromBigInt(Zt(q(r.d,"base64url"))),rt.fromBigInt(Zt(q(r.p,"base64url"))),rt.fromBigInt(Zt(q(r.q,"base64url"))),rt.fromBigInt(Zt(q(r.dp,"base64url"))),rt.fromBigInt(Zt(q(r.dq,"base64url"))),rt.fromBigInt(Zt(q(r.qi,"base64url")))]}).toBER();return new Uint8Array(e,0,e.byteLength)}function _h(r){let{result:t}=Ar(r),e=t.valueBlock.value[1].valueBlock.value[0].valueBlock.value;return{kty:"RSA",n:Y(Yt(e[0].toBigInt()),"base64url"),e:Y(Yt(e[1].toBigInt()),"base64url")}}function Th(r){if(r.n==null||r.e==null)throw new A("JWK was missing components","ERR_INVALID_PARAMETERS");let e=new ft({value:[new ft({value:[new Mt({value:"1.2.840.113549.1.1.1"}),new Re]}),new vr({valueHex:new ft({value:[rt.fromBigInt(Zt(q(r.n,"base64url"))),rt.fromBigInt(Zt(q(r.e,"base64url")))]}).toBER()})]}).toBER();return new Uint8Array(e,0,e.byteLength)}function Yt(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 Zt(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 Ch=16,Ji=32,Xi=1e4;async function Lh(r,t){let e=W.get(),s=new ft({value:[new rt({value:0}),new ft({value:[new Mt({value:"1.2.840.113549.1.1.1"}),new Re]}),new ue({valueHex:r.marshal()})]}).toBER(),i=new Uint8Array(s,0,s.byteLength),o=zt(Ch),c=await zi(Hr,t,o,{c:Xi,dkLen:Ji}),a=zt(16),f=await e.subtle.importKey("raw",c,"AES-CBC",!1,["encrypt"]),l=await e.subtle.encrypt({name:"AES-CBC",iv:a},f,i),u=new ft({value:[new ue({valueHex:o}),new rt({value:Xi}),new rt({value:Ji}),new ft({value:[new Mt({value:"1.2.840.113549.2.11"}),new Re]})]}),h=new ft({value:[new Mt({value:"1.2.840.113549.1.5.13"}),new ft({value:[new ft({value:[new Mt({value:"1.2.840.113549.1.5.12"}),u]}),new ft({value:[new Mt({value:"2.16.840.1.101.3.4.1.42"}),new ue({valueHex:a})]})]})]}),E=new ft({value:[h,new ue({valueHex:l})]}).toBER(),y=new Uint8Array(E,0,E.byteLength);return["-----BEGIN ENCRYPTED PRIVATE KEY-----",...Y(y,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
7
- `)}async function Qi(r,t){let e=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}=Ar(s),{iv:o,salt:c,iterations:a,keySize:f,cipherText:l}=Uh(i),u=await zi(Hr,t,c,{c:a,dkLen:f}),h=await e.subtle.importKey("raw",u,"AES-CBC",!1,["decrypt"]),b=tn(await e.subtle.decrypt({name:"AES-CBC",iv:o},h,l)),{result:E}=Ar(b);n=Cc(E)}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}=Ar(s);n=Cc(i)}else throw new A("Could not parse private key from PEM data","ERR_INVALID_PARAMETERS");return to(n)}function Uh(r){let t=r.valueBlock.value[0];if(t.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.13")throw new A("Only pkcs5PBES2 encrypted private keys are supported","ERR_INVALID_PARAMS");let n=t.valueBlock.value[1].valueBlock.value[0];if(n.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.12")throw new A("Only pkcs5PBKDF2 key derivation functions are supported","ERR_INVALID_PARAMS");let i=n.valueBlock.value[1],o=tn(i.valueBlock.value[0].getValue()),c=Xi,a=Ji;if(i.valueBlock.value.length===3)c=Number(i.valueBlock.value[1].toBigInt()),a=Number(i.valueBlock.value[2].toBigInt());else if(i.valueBlock.value.length===2)throw new A("Could not derive key size and iterations from PEM file - please use @libp2p/rsa to re-import your key","ERR_INVALID_PARAMS");let f=t.valueBlock.value[1].valueBlock.value[1],l=f.valueBlock.value[0].toString();if(l!=="OBJECT IDENTIFIER : 1.2.840.113549.3.7"){if(l!=="OBJECT IDENTIFIER : 1.3.14.3.2.7"){if(l!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.2"){if(l!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.22"){if(l!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.42")throw new A("Only AES-CBC encryption schemes are supported","ERR_INVALID_PARAMS")}}}}let u=tn(f.valueBlock.value[1].getValue());return{cipherText:tn(r.valueBlock.value[1].getValue()),salt:o,iterations:c,keySize:a,iv:u}}function Cc(r){return tn(r.valueBlock.value[2].getValue())}function tn(r){return new Uint8Array(r,0,r.byteLength)}async function Lc(r){let t=await W.get().subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:r,publicExponent:new Uint8Array([1,0,1]),hash:{name:"SHA-256"}},!0,["sign","verify"]),e=await Pc(t);return{privateKey:e[0],publicKey:e[1]}}async function eo(r){let e=[await W.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["sign"]),await Dh(r)],n=await Pc({privateKey:e[0],publicKey:e[1]});return{privateKey:n[0],publicKey:n[1]}}async function Uc(r,t){let e=await W.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await W.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},e,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(n,0,n.byteLength)}async function Dc(r,t,e){let n=await W.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return W.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,t,e instanceof Uint8Array?e:e.subarray())}async function Pc(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 Dh(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 Ge=8192,$e=class{_key;constructor(t){this._key=t}verify(t,e){return Dc(this._key,e,t)}marshal(){return Ne.jwkToPkix(this._key)}get bytes(){return Vt.encode({Type:Z.RSA,Data:this.marshal()}).subarray()}equals(t){return gt(this.bytes,t.bytes)}hash(){let t=ot.digest(this.bytes);return Tt(t)?t.then(({bytes:e})=>e):t.bytes}},_e=class{_key;_publicKey;constructor(t,e){this._key=t,this._publicKey=e}genSecret(){return zt(16)}sign(t){return Uc(this._key,t)}get public(){if(this._publicKey==null)throw new A("public key not provided","ERR_PUBKEY_NOT_PROVIDED");return new $e(this._publicKey)}marshal(){return Ne.jwkToPkcs1(this._key)}get bytes(){return Ht.encode({Type:Z.RSA,Data:this.marshal()}).subarray()}equals(t){return gt(this.bytes,t.bytes)}hash(){let t=ot.digest(this.bytes);return Tt(t)?t.then(({bytes:e})=>e):t.bytes}async id(){let t=await this.public.hash();return Y(t,"base58btc")}async export(t,e="pkcs-8"){if(e==="pkcs-8")return Ne.exportToPem(this,t);if(e==="libp2p-key")return mr(this.bytes,t);throw new A(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};async function to(r){let t=Ne.pkcs1ToJwk(r);if(Es(t)>Ge)throw new A("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await eo(t);return new _e(e.privateKey,e.publicKey)}function Oh(r){let t=Ne.pkixToJwk(r);if(Es(t)>Ge)throw new A("key size is too large","ERR_KEY_SIZE_TOO_LARGE");return new $e(t)}async function Vh(r){if(Es(r)>Ge)throw new A("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await eo(r);return new _e(t.privateKey,t.publicKey)}async function Hh(r){if(r>Ge)throw new A("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await Lc(r);return new _e(t.privateKey,t.publicKey)}var ao={};et(ao,{Secp256k1PrivateKey:()=>je,Secp256k1PublicKey:()=>ze,generateKeyPair:()=>Xh,unmarshalSecp256k1PrivateKey:()=>Wh,unmarshalSecp256k1PublicKey:()=>Jh});var Mh=new Uint32Array([1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298]),Te=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),Ce=new Uint32Array(64),no=class extends dr{constructor(){super(64,32,8,!1),this.A=Te[0]|0,this.B=Te[1]|0,this.C=Te[2]|0,this.D=Te[3]|0,this.E=Te[4]|0,this.F=Te[5]|0,this.G=Te[6]|0,this.H=Te[7]|0}get(){let{A:t,B:e,C:n,D:s,E:i,F:o,G:c,H:a}=this;return[t,e,n,s,i,o,c,a]}set(t,e,n,s,i,o,c,a){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=c|0,this.H=a|0}process(t,e){for(let u=0;u<16;u++,e+=4)Ce[u]=t.getUint32(e,!1);for(let u=16;u<64;u++){let h=Ce[u-15],b=Ce[u-2],E=Lt(h,7)^Lt(h,18)^h>>>3,y=Lt(b,17)^Lt(b,19)^b>>>10;Ce[u]=y+Ce[u-7]+E+Ce[u-16]|0}let{A:n,B:s,C:i,D:o,E:c,F:a,G:f,H:l}=this;for(let u=0;u<64;u++){let h=Lt(c,6)^Lt(c,11)^Lt(c,25),b=l+h+oa(c,a,f)+Mh[u]+Ce[u]|0,y=(Lt(n,2)^Lt(n,13)^Lt(n,22))+aa(n,s,i)|0;l=f,f=a,a=c,c=o+b|0,o=i,i=s,s=n,n=b+y|0}n=n+this.A|0,s=s+this.B|0,i=i+this.C|0,o=o+this.D|0,c=c+this.E|0,a=a+this.F|0,f=f+this.G|0,l=l+this.H|0,this.set(n,s,i,o,c,a,f,l)}roundClean(){Ce.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var Oc=yn(()=>new no);function Vc(r){r.lowS!==void 0&&Ut("lowS",r.lowS),r.prehash!==void 0&&Ut("prehash",r.prehash)}function Kh(r){let t=Fr(r);Gt(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:Fh,hexToBytes:qh}=wn,de={Err:class extends Error{constructor(t=""){super(t)}},_tlv:{encode:(r,t)=>{let{Err:e}=de;if(r<0||r>256)throw new e("tlv.encode: wrong tag");if(t.length&1)throw new e("tlv.encode: unpadded data");let n=t.length/2,s=De(n);if(s.length/2&128)throw new e("tlv.encode: long form length too big");let i=n>127?De(s.length/2|128):"";return`${De(r)}${i}${s}${t}`},decode(r,t){let{Err:e}=de,n=0;if(r<0||r>256)throw new e("tlv.encode: wrong tag");if(t.length<2||t[n++]!==r)throw new e("tlv.decode: wrong tlv");let s=t[n++],i=!!(s&128),o=0;if(!i)o=s;else{let a=s&127;if(!a)throw new e("tlv.decode(long): indefinite length not supported");if(a>4)throw new e("tlv.decode(long): byte length is too big");let f=t.subarray(n,n+a);if(f.length!==a)throw new e("tlv.decode: length bytes not complete");if(f[0]===0)throw new e("tlv.decode(long): zero leftmost byte");for(let l of f)o=o<<8|l;if(n+=a,o<128)throw new e("tlv.decode(long): not minimal encoding")}let c=t.subarray(n,n+o);if(c.length!==o)throw new e("tlv.decode: wrong value length");return{v:c,l:t.subarray(n+o)}}},_int:{encode(r){let{Err:t}=de;if(r<pe)throw new t("integer: negative integers are not allowed");let e=De(r);if(Number.parseInt(e[0],16)&8&&(e="00"+e),e.length&1)throw new t("unexpected assertion");return e},decode(r){let{Err:t}=de;if(r[0]&128)throw new t("Invalid signature integer: negative");if(r[0]===0&&!(r[1]&128))throw new t("Invalid signature integer: unnecessary leading zero");return Fh(r)}},toSig(r){let{Err:t,_int:e,_tlv:n}=de,s=typeof r=="string"?qh(r):r;pr(s);let{v:i,l:o}=n.decode(48,s);if(o.length)throw new t("Invalid signature: left bytes after parsing");let{v:c,l:a}=n.decode(2,i),{v:f,l}=n.decode(2,a);if(l.length)throw new t("Invalid signature: left bytes after parsing");return{r:e.decode(c),s:e.decode(f)}},hexFromSig(r){let{_tlv:t,_int:e}=de,n=`${t.encode(2,e.encode(r.r))}${t.encode(2,e.encode(r.s))}`;return t.encode(48,n)}},pe=BigInt(0),ht=BigInt(1),my=BigInt(2),Hc=BigInt(3),by=BigInt(4);function $h(r){let t=Kh(r),{Fp:e}=t,n=Ae(t.n,t.nBitLength),s=t.toBytes||((y,d,m)=>{let x=d.toAffine();return se(Uint8Array.from([4]),e.toBytes(x.x),e.toBytes(x.y))}),i=t.fromBytes||(y=>{let d=y.subarray(1),m=e.fromBytes(d.subarray(0,e.BYTES)),x=e.fromBytes(d.subarray(e.BYTES,2*e.BYTES));return{x:m,y:x}});function o(y){let{a:d,b:m}=t,x=e.sqr(y),p=e.mul(x,y);return e.add(e.add(p,e.mul(y,d)),m)}if(!e.eql(e.sqr(t.Gy),o(t.Gx)))throw new Error("bad generator point: equation left != right");function c(y){return Mr(y,ht,t.n)}function a(y){let{allowedPrivateKeyLengths:d,nByteLength:m,wrapPrivateKey:x,n:p}=t;if(d&&typeof y!="bigint"){if(Ee(y)&&(y=re(y)),typeof y!="string"||!d.includes(y.length))throw new Error("Invalid key");y=y.padStart(m*2,"0")}let B;try{B=typeof y=="bigint"?y:ne(tt("private key",y,m))}catch{throw new Error(`private key must be ${m} bytes, hex or bigint, not ${typeof y}`)}return x&&(B=z(B,p)),kt("private key",B,ht,p),B}function f(y){if(!(y instanceof h))throw new Error("ProjectivePoint expected")}let l=Ve((y,d)=>{let{px:m,py:x,pz:p}=y;if(e.eql(p,e.ONE))return{x:m,y:x};let B=y.is0();d==null&&(d=B?e.ONE:e.inv(p));let L=e.mul(m,d),C=e.mul(x,d),k=e.mul(p,d);if(B)return{x:e.ZERO,y:e.ZERO};if(!e.eql(k,e.ONE))throw new Error("invZ was invalid");return{x:L,y:C}}),u=Ve(y=>{if(y.is0()){if(t.allowInfinityPoint&&!e.is0(y.py))return;throw new Error("bad point: ZERO")}let{x:d,y:m}=y.toAffine();if(!e.isValid(d)||!e.isValid(m))throw new Error("bad point: x or y not FE");let x=e.sqr(m),p=o(d);if(!e.eql(x,p))throw new Error("bad point: equation left != right");if(!y.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});class h{constructor(d,m,x){if(this.px=d,this.py=m,this.pz=x,d==null||!e.isValid(d))throw new Error("x required");if(m==null||!e.isValid(m))throw new Error("y required");if(x==null||!e.isValid(x))throw new Error("z required");Object.freeze(this)}static fromAffine(d){let{x:m,y:x}=d||{};if(!d||!e.isValid(m)||!e.isValid(x))throw new Error("invalid affine point");if(d instanceof h)throw new Error("projective point not allowed");let p=B=>e.eql(B,e.ZERO);return p(m)&&p(x)?h.ZERO:new h(m,x,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(d){let m=e.invertBatch(d.map(x=>x.pz));return d.map((x,p)=>x.toAffine(m[p])).map(h.fromAffine)}static fromHex(d){let m=h.fromAffine(i(tt("pointHex",d)));return m.assertValidity(),m}static fromPrivateKey(d){return h.BASE.multiply(a(d))}static msm(d,m){return vn(h,n,d,m)}_setWindowSize(d){E.setWindowSize(this,d)}assertValidity(){u(this)}hasEvenY(){let{y:d}=this.toAffine();if(e.isOdd)return!e.isOdd(d);throw new Error("Field doesn't support isOdd")}equals(d){f(d);let{px:m,py:x,pz:p}=this,{px:B,py:L,pz:C}=d,k=e.eql(e.mul(m,C),e.mul(B,p)),R=e.eql(e.mul(x,C),e.mul(L,p));return k&&R}negate(){return new h(this.px,e.neg(this.py),this.pz)}double(){let{a:d,b:m}=t,x=e.mul(m,Hc),{px:p,py:B,pz:L}=this,C=e.ZERO,k=e.ZERO,R=e.ZERO,T=e.mul(p,p),nt=e.mul(B,B),F=e.mul(L,L),O=e.mul(p,B);return O=e.add(O,O),R=e.mul(p,L),R=e.add(R,R),C=e.mul(d,R),k=e.mul(x,F),k=e.add(C,k),C=e.sub(nt,k),k=e.add(nt,k),k=e.mul(C,k),C=e.mul(O,C),R=e.mul(x,R),F=e.mul(d,F),O=e.sub(T,F),O=e.mul(d,O),O=e.add(O,R),R=e.add(T,T),T=e.add(R,T),T=e.add(T,F),T=e.mul(T,O),k=e.add(k,T),F=e.mul(B,L),F=e.add(F,F),T=e.mul(F,O),C=e.sub(C,T),R=e.mul(F,nt),R=e.add(R,R),R=e.add(R,R),new h(C,k,R)}add(d){f(d);let{px:m,py:x,pz:p}=this,{px:B,py:L,pz:C}=d,k=e.ZERO,R=e.ZERO,T=e.ZERO,nt=t.a,F=e.mul(t.b,Hc),O=e.mul(m,B),st=e.mul(x,L),S=e.mul(p,C),N=e.add(m,x),w=e.add(B,L);N=e.mul(N,w),w=e.add(O,st),N=e.sub(N,w),w=e.add(m,p);let g=e.add(B,C);return w=e.mul(w,g),g=e.add(O,S),w=e.sub(w,g),g=e.add(x,p),k=e.add(L,C),g=e.mul(g,k),k=e.add(st,S),g=e.sub(g,k),T=e.mul(nt,w),k=e.mul(F,S),T=e.add(k,T),k=e.sub(st,T),T=e.add(st,T),R=e.mul(k,T),st=e.add(O,O),st=e.add(st,O),S=e.mul(nt,S),w=e.mul(F,w),st=e.add(st,S),S=e.sub(O,S),S=e.mul(nt,S),w=e.add(w,S),O=e.mul(st,w),R=e.add(R,O),O=e.mul(g,w),k=e.mul(N,k),k=e.sub(k,O),O=e.mul(N,st),T=e.mul(g,T),T=e.add(T,O),new h(k,R,T)}subtract(d){return this.add(d.negate())}is0(){return this.equals(h.ZERO)}wNAF(d){return E.wNAFCached(this,d,h.normalizeZ)}multiplyUnsafe(d){kt("scalar",d,pe,t.n);let m=h.ZERO;if(d===pe)return m;if(d===ht)return this;let{endo:x}=t;if(!x)return E.unsafeLadder(this,d);let{k1neg:p,k1:B,k2neg:L,k2:C}=x.splitScalar(d),k=m,R=m,T=this;for(;B>pe||C>pe;)B&ht&&(k=k.add(T)),C&ht&&(R=R.add(T)),T=T.double(),B>>=ht,C>>=ht;return p&&(k=k.negate()),L&&(R=R.negate()),R=new h(e.mul(R.px,x.beta),R.py,R.pz),k.add(R)}multiply(d){let{endo:m,n:x}=t;kt("scalar",d,ht,x);let p,B;if(m){let{k1neg:L,k1:C,k2neg:k,k2:R}=m.splitScalar(d),{p:T,f:nt}=this.wNAF(C),{p:F,f:O}=this.wNAF(R);T=E.constTimeNegate(L,T),F=E.constTimeNegate(k,F),F=new h(e.mul(F.px,m.beta),F.py,F.pz),p=T.add(F),B=nt.add(O)}else{let{p:L,f:C}=this.wNAF(d);p=L,B=C}return h.normalizeZ([p,B])[0]}multiplyAndAddUnsafe(d,m,x){let p=h.BASE,B=(C,k)=>k===pe||k===ht||!C.equals(p)?C.multiplyUnsafe(k):C.multiply(k),L=B(this,m).add(B(d,x));return L.is0()?void 0:L}toAffine(d){return l(this,d)}isTorsionFree(){let{h:d,isTorsionFree:m}=t;if(d===ht)return!0;if(m)return m(h,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h:d,clearCofactor:m}=t;return d===ht?this:m?m(h,this):this.multiplyUnsafe(t.h)}toRawBytes(d=!0){return Ut("isCompressed",d),this.assertValidity(),s(h,this,d)}toHex(d=!0){return Ut("isCompressed",d),re(this.toRawBytes(d))}}h.BASE=new h(t.Gx,t.Gy,e.ONE),h.ZERO=new h(e.ZERO,e.ONE,e.ZERO);let b=t.nBitLength,E=En(h,t.endo?Math.ceil(b/2):b);return{CURVE:t,ProjectivePoint:h,normPrivateKeyToScalar:a,weierstrassEquation:o,isWithinCurveOrder:c}}function Gh(r){let t=Fr(r);return Gt(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function Mc(r){let t=Gh(r),{Fp:e,n}=t,s=e.BYTES+1,i=2*e.BYTES+1;function o(S){return z(S,n)}function c(S){return xn(S,n)}let{ProjectivePoint:a,normPrivateKeyToScalar:f,weierstrassEquation:l,isWithinCurveOrder:u}=$h({...t,toBytes(S,N,w){let g=N.toAffine(),v=e.toBytes(g.x),_=se;return Ut("isCompressed",w),w?_(Uint8Array.from([N.hasEvenY()?2:3]),v):_(Uint8Array.from([4]),v,e.toBytes(g.y))},fromBytes(S){let N=S.length,w=S[0],g=S.subarray(1);if(N===s&&(w===2||w===3)){let v=ne(g);if(!Mr(v,ht,e.ORDER))throw new Error("Point is not on curve");let _=l(v),U;try{U=e.sqrt(_)}catch(K){let H=K instanceof Error?": "+K.message:"";throw new Error("Point is not on curve"+H)}let D=(U&ht)===ht;return(w&1)===1!==D&&(U=e.neg(U)),{x:v,y:U}}else if(N===i&&w===4){let v=e.fromBytes(g.subarray(0,e.BYTES)),_=e.fromBytes(g.subarray(e.BYTES,2*e.BYTES));return{x:v,y:_}}else throw new Error(`Point of length ${N} was invalid. Expected ${s} compressed bytes or ${i} uncompressed bytes`)}}),h=S=>re(Be(S,t.nByteLength));function b(S){let N=n>>ht;return S>N}function E(S){return b(S)?o(-S):S}let y=(S,N,w)=>ne(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=t.nByteLength;return N=tt("compactSignature",N,w*2),new d(y(N,0,w),y(N,w,2*w))}static fromDER(N){let{r:w,s:g}=de.toSig(tt("DER",N));return new d(w,g)}assertValidity(){kt("r",this.r,ht,n),kt("s",this.s,ht,n)}addRecoveryBit(N){return new d(this.r,this.s,N)}recoverPublicKey(N){let{r:w,s:g,recovery:v}=this,_=C(tt("msgHash",N));if(v==null||![0,1,2,3].includes(v))throw new Error("recovery id invalid");let U=v===2||v===3?w+t.n:w;if(U>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let D=v&1?"03":"02",V=a.fromHex(D+h(U)),K=c(U),H=o(-_*K),G=o(g*K),j=a.BASE.multiplyAndAddUnsafe(V,H,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 Pe(this.toDERHex())}toDERHex(){return de.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return Pe(this.toCompactHex())}toCompactHex(){return h(this.r)+h(this.s)}}let m={isValidPrivateKey(S){try{return f(S),!0}catch{return!1}},normPrivateKeyToScalar:f,randomPrivateKey:()=>{let S=wi(t.n);return ga(t.randomBytes(S),t.n)},precompute(S=8,N=a.BASE){return N._setWindowSize(S),N.multiply(BigInt(3)),N}};function x(S,N=!0){return a.fromPrivateKey(S).toRawBytes(N)}function p(S){let N=Ee(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 a}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 a.fromHex(N).multiply(f(S)).toRawBytes(w)}let L=t.bits2int||function(S){let N=ne(S),w=S.length*8-t.nBitLength;return w>0?N>>BigInt(w):N},C=t.bits2int_modN||function(S){return o(L(S))},k=Kr(t.nBitLength);function R(S){return kt(`num < 2^${t.nBitLength}`,S,pe,k),Be(S,t.nByteLength)}function T(S,N,w=nt){if(["recovered","canonical"].some(lt=>lt in w))throw new Error("sign() legacy options not supported");let{hash:g,randomBytes:v}=t,{lowS:_,prehash:U,extraEntropy:D}=w;_==null&&(_=!0),S=tt("msgHash",S),Vc(w),U&&(S=tt("prehashed msgHash",g(S)));let V=C(S),K=f(N),H=[R(K),R(V)];if(D!=null&&D!==!1){let lt=D===!0?v(e.BYTES):D;H.push(tt("extraEntropy",lt))}let G=se(...H),j=V;function ut(lt){let dt=L(lt);if(!u(dt))return;let Et=c(dt),it=a.BASE.multiply(dt).toAffine(),It=o(it.x);if(It===pe)return;let Wt=o(Et*o(j+It*K));if(Wt===pe)return;let kr=(it.x===It?0:2)|Number(it.y&ht),Rr=Wt;return _&&b(Wt)&&(Rr=E(Wt),kr^=1),new d(It,Rr,kr)}return{seed:G,k2sig:ut}}let nt={lowS:t.lowS,prehash:!1},F={lowS:t.lowS,prehash:!1};function O(S,N,w=nt){let{seed:g,k2sig:v}=T(S,N,w),_=t;return gi(_.hash.outputLen,_.nByteLength,_.hmac)(g,v)}a.BASE._setWindowSize(8);function st(S,N,w,g=F){let v=S;if(N=tt("msgHash",N),w=tt("publicKey",w),"strict"in g)throw new Error("options.strict was renamed to lowS");Vc(g);let{lowS:_,prehash:U}=g,D,V;try{if(typeof v=="string"||Ee(v))try{D=d.fromDER(v)}catch(it){if(!(it instanceof de.Err))throw it;D=d.fromCompact(v)}else if(typeof v=="object"&&typeof v.r=="bigint"&&typeof v.s=="bigint"){let{r:it,s:It}=v;D=new d(it,It)}else throw new Error("PARSE");V=a.fromHex(w)}catch(it){if(it.message==="PARSE")throw new Error("signature must be Signature instance, Uint8Array or hex string");return!1}if(_&&D.hasHighS())return!1;U&&(N=t.hash(N));let{r:K,s:H}=D,G=C(N),j=c(H),ut=o(G*j),lt=o(K*j),dt=a.BASE.multiplyAndAddUnsafe(V,ut,lt)?.toAffine();return dt?o(dt.x)===K:!1}return{CURVE:t,getPublicKey:x,getSharedSecret:B,sign:O,verify:st,ProjectivePoint:a,Signature:d,utils:m}}function zh(r){return{hash:r,hmac:(t,...e)=>Gr(r,t,ai(...e)),randomBytes:hr}}function Kc(r,t){let e=n=>Mc({...r,...zh(n)});return Object.freeze({...e(t),create:e})}var $c=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),Fc=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),jh=BigInt(1),so=BigInt(2),qc=(r,t)=>(r+t/so)/t;function Yh(r){let t=$c,e=BigInt(3),n=BigInt(6),s=BigInt(11),i=BigInt(22),o=BigInt(23),c=BigInt(44),a=BigInt(88),f=r*r*r%t,l=f*f*r%t,u=X(l,e,t)*l%t,h=X(u,e,t)*l%t,b=X(h,so,t)*f%t,E=X(b,s,t)*b%t,y=X(E,i,t)*E%t,d=X(y,c,t)*y%t,m=X(d,a,t)*d%t,x=X(m,c,t)*y%t,p=X(x,e,t)*l%t,B=X(p,o,t)*E%t,L=X(B,n,t)*f%t,C=X(L,so,t);if(!io.eql(io.sqr(C),r))throw new Error("Cannot find square root");return C}var io=Ae($c,void 0,void 0,{sqrt:Yh}),Ft=Kc({a:BigInt(0),b:BigInt(7),Fp:io,n:Fc,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=Fc,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-jh*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),s=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),i=e,o=BigInt("0x100000000000000000000000000000000"),c=qc(i*r,t),a=qc(-n*r,t),f=z(r-c*e-a*s,t),l=z(-c*n-a*i,t),u=f>o,h=l>o;if(u&&(f=t-f),h&&(l=t-l),f>o||l>o)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:u,k1:f,k2neg:h,k2:l}}}},Oc),ky=BigInt(0);var Ry=Ft.ProjectivePoint;function Gc(){return Ft.utils.randomPrivateKey()}function zc(r,t){let e=ot.digest(t instanceof Uint8Array?t:t.subarray());if(Tt(e))return e.then(({digest:n})=>Ft.sign(n,r).toDERRawBytes()).catch(n=>{throw new A(String(n),"ERR_INVALID_INPUT")});try{return Ft.sign(e.digest,r).toDERRawBytes()}catch(n){throw new A(String(n),"ERR_INVALID_INPUT")}}function jc(r,t,e){let n=ot.digest(e instanceof Uint8Array?e:e.subarray());if(Tt(n))return n.then(({digest:s})=>Ft.verify(t,s,r)).catch(s=>{throw new A(String(s),"ERR_INVALID_INPUT")});try{return Ft.verify(t,n.digest,r)}catch(s){throw new A(String(s),"ERR_INVALID_INPUT")}}function Yc(r){return Ft.ProjectivePoint.fromHex(r).toRawBytes(!0)}function Zc(r){try{Ft.getPublicKey(r,!0)}catch(t){throw new A(String(t),"ERR_INVALID_PRIVATE_KEY")}}function oo(r){try{Ft.ProjectivePoint.fromHex(r)}catch(t){throw new A(String(t),"ERR_INVALID_PUBLIC_KEY")}}function Wc(r){try{return Ft.getPublicKey(r,!0)}catch(t){throw new A(String(t),"ERR_INVALID_PRIVATE_KEY")}}var ze=class{_key;constructor(t){oo(t),this._key=t}verify(t,e){return jc(this._key,e,t)}marshal(){return Yc(this._key)}get bytes(){return Vt.encode({Type:Z.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return gt(this.bytes,t.bytes)}async hash(){let t=ot.digest(this.bytes),e;return Tt(t)?{bytes:e}=await t:e=t.bytes,e}},je=class{_key;_publicKey;constructor(t,e){this._key=t,this._publicKey=e??Wc(t),Zc(this._key),oo(this._publicKey)}sign(t){return zc(this._key,t)}get public(){return new ze(this._publicKey)}marshal(){return this._key}get bytes(){return Ht.encode({Type:Z.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return gt(this.bytes,t.bytes)}hash(){let t=ot.digest(this.bytes);return Tt(t)?t.then(({bytes:e})=>e):t.bytes}async id(){let t=await this.public.hash();return Y(t,"base58btc")}async export(t,e="libp2p-key"){if(e==="libp2p-key")return mr(this.bytes,t);throw new A(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function Wh(r){return new je(r)}function Jh(r){return new ze(r)}async function Xh(){let r=Gc();return new je(r)}var ge={rsa:ro,ed25519:$i,secp256k1:ao};function co(r){let t=Object.keys(ge).join(" / ");return new A(`invalid or unsupported key type ${r}. Must be ${t}`,"ERR_UNSUPPORTED_KEY_TYPE")}function uo(r){if(r=r.toLowerCase(),r==="rsa"||r==="ed25519"||r==="secp256k1")return ge[r];throw co(r)}async function Qh(r,t){return uo(r).generateKeyPair(t??2048)}async function td(r,t,e){if(r.toLowerCase()!=="ed25519")throw new A("Seed key derivation is unimplemented for RSA or secp256k1","ERR_UNSUPPORTED_KEY_DERIVATION_TYPE");return qi(t)}function ed(r){let t=Vt.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case Z.RSA:return ge.rsa.unmarshalRsaPublicKey(e);case Z.Ed25519:return ge.ed25519.unmarshalEd25519PublicKey(e);case Z.Secp256k1:return ge.secp256k1.unmarshalSecp256k1PublicKey(e);default:throw co(t.Type??"unknown")}}function rd(r,t){return t=(t??"rsa").toLowerCase(),uo(t),r.bytes}async function Jc(r){let t=Ht.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case Z.RSA:return ge.rsa.unmarshalRsaPrivateKey(e);case Z.Ed25519:return ge.ed25519.unmarshalEd25519PrivateKey(e);case Z.Secp256k1:return ge.secp256k1.unmarshalSecp256k1PrivateKey(e);default:throw co(t.Type??"RSA")}}function nd(r,t){return t=(t??"rsa").toLowerCase(),uo(t),r.bytes}async function sd(r,t){try{let e=await Fa(r,t);return await Jc(e)}catch{}if(!r.includes("BEGIN"))throw new A("Encrypted key was not a libp2p-key or a PEM file","ERR_INVALID_IMPORT_FORMAT");return Qi(r,t)}var Qc=Symbol.for("@achingbrain/uint8arraylist");function Xc(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?.[Qc]}var Le=class r{bufs;length;[Qc]=!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=Xc(this.bufs,t);return e.buf[e.index]}set(t,e){let n=Xc(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 Bt(n,s)}subarray(t,e){let{bufs:n,length:s}=this._subList(t,e);return n.length===1?n[0]:Bt(n,s)}sublist(t,e){let{bufs:n,length:s}=this._subList(t,e),i=new r;return i.length=s,i.bufs=[...n],i}_subList(t,e){if(t=t??0,e=e??this.length,t<0&&(t=this.length+t),e<0&&(e=this.length+e),t<0||e>this.length)throw new RangeError("index is out of bounds");if(t===e)return{bufs:[],length:0};if(t===0&&e===this.length)return{bufs:this.bufs,length:this.length};let n=[],s=0;for(let i=0;i<this.bufs.length;i++){let o=this.bufs[i],c=s,a=c+o.byteLength;if(s=a,t>=a)continue;let f=t>=c&&t<a,l=e>c&&e<=a;if(f&&l){if(t===c&&e===a){n.push(o);break}let u=t-c;n.push(o.subarray(u,u+(e-t)));break}if(f){if(t===0){n.push(o);continue}n.push(o.subarray(t-c));continue}if(l){if(e===a){n.push(o);break}n.push(o.subarray(0,e-c));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 c=o,a=this.byteLength-n.byteLength,f=n.byteLength-1,l;for(let u=e;u<=a;u+=l){l=0;for(let h=f;h>=0;h--){let b=this.get(u+h);if(n[h]!==b){l=Math.max(1,h-c[b]);break}}if(l===0)return u}return-1}getInt8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getInt8(0)}setInt8(t,e){let n=yt(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setInt8(0,e),this.write(n,t)}getInt16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt16(0,e)}setInt16(t,e,n){let s=Qt(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=Qt(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=Qt(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigInt64(0,e,n),this.write(s,t)}getUint8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getUint8(0)}setUint8(t,e){let n=yt(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setUint8(0,e),this.write(n,t)}getUint16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint16(0,e)}setUint16(t,e,n){let s=Qt(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=Qt(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=Qt(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=Qt(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=Qt(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(!gt(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 Bs(){let r={};return r.promise=new Promise((t,e)=>{r.resolve=t,r.reject=e}),r}var As=class{buffer;mask;top;btm;next;constructor(t){if(!(t>0)||t-1&t)throw new Error("Max size for a FixedFIFO should be a power of two");this.buffer=new Array(t),this.mask=t-1,this.top=0,this.btm=0,this.next=null}push(t){return this.buffer[this.top]!==void 0?!1:(this.buffer[this.top]=t,this.top=this.top+1&this.mask,!0)}shift(){let t=this.buffer[this.btm];if(t!==void 0)return this.buffer[this.btm]=void 0,this.btm=this.btm+1&this.mask,t}isEmpty(){return this.buffer[this.btm]===void 0}},Sr=class{size;hwm;head;tail;constructor(t={}){this.hwm=t.splitLimit??16,this.head=new As(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 As(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 lo=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 id(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 id(r,t){t=t??{};let e=t.onEnd,n=new Sr,s,i,o,c=Bs(),a=async()=>{try{return n.isEmpty()?o?{done:!0}:await new Promise((d,m)=>{i=x=>{i=null,n.push(x);try{d(r(n))}catch(p){m(p)}return s}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{c.resolve(),c=Bs()})}},f=d=>i!=null?i(d):(n.push(d),s),l=d=>(n=new Sr,i!=null?i({error:d}):(n.push({error:d}),s)),u=d=>{if(o)return s;if(t?.objectMode!==!0&&d?.byteLength==null)throw new Error("objectMode was not true but tried to push non-Uint8Array value");return f({done:!1,value:d})},h=d=>o?s:(o=!0,d!=null?l(d):f({done:!0})),b=()=>(n=new Sr,h(),{done:!0}),E=d=>(h(d),{done:!0});if(s={[Symbol.asyncIterator](){return this},next:a,return:b,throw:E,push:u,end:h,get readableLength(){return n.size},onEmpty:async d=>{let m=d?.signal;if(m?.throwIfAborted(),n.isEmpty())return;let x,p;m!=null&&(x=new Promise((B,L)=>{p=()=>{L(new lo)},m.addEventListener("abort",p)}));try{await Promise.race([c.promise,x])}finally{p!=null&&m!=null&&m?.removeEventListener("abort",p)}}},e==null)return s;let y=s;return s={[Symbol.asyncIterator](){return this},next(){return y.next()},throw(d){return y.throw(d),e!=null&&(e(d),e=void 0),{done:!0}},return(){return y.return(),e!=null&&(e(),e=void 0),{done:!0}},push:u,end(d){return y.end(d),e!=null&&(e(d),e=void 0),s},get readableLength(){return y.readableLength},onEmpty:d=>y.onEmpty(d)},s}function od(r){return r[Symbol.asyncIterator]!=null}function ad(...r){let t=[];for(let e of r)od(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 tu=ad;function rn(r,...t){if(r==null)throw new Error("Empty pipeline");if(fo(r)){let n=r;r=()=>n.source}else if(ru(r)||eu(r)){let n=r;r=()=>n}let e=[r,...t];if(e.length>1&&fo(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++)fo(e[n])&&(e[n]=ud(e[n]));return cd(...e)}var cd=(...r)=>{let t;for(;r.length>0;)t=r.shift()(t);return t},eu=r=>r?.[Symbol.asyncIterator]!=null,ru=r=>r?.[Symbol.iterator]!=null,fo=r=>r==null?!1:r.sink!=null&&r.source!=null,ud=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(eu(i))s=async function*(){yield*i,n.end()};else if(ru(i))s=function*(){yield*i,n.end()};else throw new Error("Unknown duplex source type - must be Iterable or AsyncIterable");return tu(n,s())}return r.source};var po=No(su(),1);var sn=class extends Error{constructor(t){super(t),this.name="TimeoutError"}},go=class extends Error{constructor(t){super(),this.name="AbortError",this.message=t}},iu=r=>globalThis.DOMException===void 0?new go(r):new DOMException(r),ou=r=>{let t=r.reason===void 0?iu("This operation was aborted."):r.reason;return t instanceof Error?t:iu(t)};function yo(r,t){let{milliseconds:e,fallback:n,message:s,customTimers:i={setTimeout,clearTimeout}}=t,o,a=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:h}=t;h.aborted&&l(ou(h)),h.addEventListener("abort",()=>{l(ou(h))})}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(h){l(h)}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(h){l(h)}})()}).finally(()=>{a.clear()});return a.clear=()=>{i.clearTimeout.call(void 0,o),o=void 0},a}function mo(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=mo(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 po.default{#t;#o;#i=0;#d;#a;#p=0;#r;#c;#e;#g;#n=0;#u;#s;#y;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.#y=t.throwOnTimeout===!0,this.#s=t.autoStart===!1}get#w(){return this.#o||this.#i<this.#d}get#x(){return this.#n<this.#u}#E(){this.#n--,this.#l(),this.emit("next")}#v(){this.#b(),this.#m(),this.#c=void 0}get#B(){let t=Date.now();if(this.#r===void 0){let e=this.#p-t;if(e<0)this.#i=this.#t?this.#n:0;else return this.#c===void 0&&(this.#c=setTimeout(()=>{this.#v()},e)),!0}return!1}#l(){if(this.#e.size===0)return this.#r&&clearInterval(this.#r),this.#r=void 0,this.emit("empty"),this.#n===0&&this.emit("idle"),!1;if(!this.#s){let t=!this.#B;if(this.#w&&this.#x){let e=this.#e.dequeue();return e?(this.emit("active"),e(),t&&this.#m(),!0):!1}}return!1}#m(){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.#y,...e},new Promise((n,s)=>{this.#e.enqueue(async()=>{this.#n++,this.#i++;try{e.signal?.throwIfAborted();let i=t({signal:e.signal});e.timeout&&(i=yo(Promise.resolve(i),{milliseconds:e.timeout})),e.signal&&(i=Promise.race([i,this.#A(e.signal)]));let o=await i;n(o),this.emit("completed",o)}catch(i){if(i instanceof sn&&!e.throwOnTimeout){n();return}s(i),this.emit("error",i)}finally{this.#E()}},e),this.emit("add"),this.#l()})}async addAll(t,e){return Promise.all(t.map(async n=>this.add(n,e)))}start(){return this.#s?(this.#s=!1,this.#f(),this):this}pause(){this.#s=!0}clear(){this.#e=new this.#g}async onEmpty(){this.#e.size!==0&&await this.#h("empty")}async onSizeLessThan(t){this.#e.size<t||await this.#h("next",()=>this.#e.size<t)}async onIdle(){this.#n===0&&this.#e.size===0||await this.#h("idle")}async#h(t,e){return new Promise(n=>{let s=()=>{e&&!e()||(this.off(t,s),n())};this.on(t,s)})}get size(){return this.#e.size}sizeBy(t){return this.#e.filter(t).length}get pending(){return this.#n}get isPaused(){return this.#s}};var 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 au(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 cu(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function uu(r,t){let e=au(r).return?.();cu(e)&&e.catch(n=>{t.error("could not cause iterator to return",n)})}function Is(r){return r[Symbol.asyncIterator]!=null}var ks=r=>{let t=Pt(r),e=yt(t);return Ia(r,e),ks.bytes=t,e};ks.bytes=0;function Rs(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 Is(r)?async function*(){for await(let s of r)yield*n(s)}():function*(){for(let s of r)yield*n(s)}()}Rs.single=(r,t)=>{t=t??{};let e=t.lengthEncoder??ks;return new Le(e(r.byteLength),r)};var Ns=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},_s=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},Ts=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"},cn=class extends Error{name="UnexpectedEOFError";code="ERR_UNEXPECTED_EOF"};var hd=8,dd=1024*1024*4,Ye;(function(r){r[r.LENGTH=0]="LENGTH",r[r.DATA=1]="DATA"})(Ye||(Ye={}));var bo=r=>{let t=ka(r);return bo.bytes=Pt(t),t};bo.bytes=0;function un(r,t){let e=new Le,n=Ye.LENGTH,s=-1,i=t?.lengthDecoder??bo,o=t?.maxLengthLength??hd,c=t?.maxDataLength??dd;function*a(){for(;e.byteLength>0;){if(n===Ye.LENGTH)try{if(s=i(e),s<0)throw new Ns("Invalid message length");if(s>c)throw new _s("Message length too long");let f=i.bytes;e.consume(f),t?.onLength!=null&&t.onLength(s),n=Ye.DATA}catch(f){if(f instanceof RangeError){if(e.byteLength>o)throw new Ts("Message length length too long");break}throw f}if(n===Ye.DATA){if(e.byteLength<s)break;let f=e.sublist(0,s);e.consume(s),t?.onData!=null&&t.onData(f),yield f,n=Ye.LENGTH}}}return Is(r)?async function*(){for await(let f of r)e.append(f),yield*a();if(e.byteLength>0)throw new cn("Unexpected end of input")}():function*(){for(let f of r)e.append(f),yield*a();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 Cs=class extends Ze{id;protocol;outboundStream;inboundStream;_rawOutboundStream;_rawInboundStream;_inboundAbortController;closed;log;constructor(t,e){super(),this.log=t.logger.forComponent("libp2p-pubsub:peer-streams"),this.id=e.id,this.protocol=e.protocol,this._inboundAbortController=new AbortController,this.closed=!1}get isReadable(){return!!this.inboundStream}get isWritable(){return!!this.outboundStream}write(t){if(this.outboundStream==null){let e=this.id.toString();throw new Error("No writable connection to "+e)}this.outboundStream.push(t instanceof Uint8Array?new Le(t):t)}attachInboundStream(t){let e=()=>{uu(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 qt("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 qt("close"))}}),rn(this.outboundStream,n=>Rs(n),this._rawOutboundStream).catch(n=>{this.log.error(n)}),e==null&&this.dispatchEvent(new qt("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 qt("close")))}};function lu(){return BigInt(`0x${Y(zt(8),"base16")}`)}var fu=(r,t)=>{let e=q(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},hu=r=>ot.encode(r);var du=function(r){return Array.isArray(r)?r:[r]},gd=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 pn(r.key)).equals(t):!1},pu=async r=>{if(r.from==null)throw new A("RPC message was missing from",ct.ERR_MISSING_FROM);if(!await gd(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:md(r.sequenceNumber??new Uint8Array(0)),data:r.data??new Uint8Array(0),signature:r.signature??new Uint8Array(0),key:r.key??t.publicKey??new Uint8Array(0)};if(e.key.length===0)throw new A("Signed RPC message was missing key",ct.ERR_MISSING_KEY);return e},ln=r=>r.type==="signed"?{from:r.from.multihash.bytes,data:r.data,sequenceNumber:yd(r.sequenceNumber),topic:r.topic,signature:r.signature,key:r.key}:{data:r.data,topic:r.topic},yd=r=>{let t=r.toString(16);return t.length%2!==0&&(t=`0${t}`),q(t,"base16")},md=r=>BigInt(`0x${Y(r,"base16")}`);var gu=q("libp2p-pubsub:");async function yu(r,t,e){if(r.privateKey==null)throw new Error("Cannot sign message, no private key present");if(r.publicKey==null)throw new Error("Cannot sign message, no public key present");let n={type:"signed",topic:t.topic,data:t.data,sequenceNumber:t.sequenceNumber,from:r},s=Bt([gu,e(ln(n)).subarray()]),i=await en.unmarshalPrivateKey(r.privateKey);return n.signature=await i.sign(s),n.key=r.publicKey,n}async function mu(r,t){if(r.type!=="signed")throw new Error('Message type must be "signed" to be verified');if(r.signature==null)throw new Error("Message must contain a signature to be verified");if(r.from==null)throw new Error("Message must contain a from property to be verified");let e=Bt([gu,t({...ln(r),signature:void 0,key:void 0}).subarray()]),n=await bd(r);return en.unmarshalPublicKey(n).verify(e,r.signature)}async function bd(r){if(r.type!=="signed")throw new Error('Message type must be "signed" to have a public key');if(r.from==null)throw new Error("Could not get the public key from the originator id");if(r.key!=null){let t=await pn(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 wo=class extends Ze{log;started;topics;subscriptions;peers;globalSignaturePolicy;canRelayMessage;emitSelf;topicValidators;queue;multicodecs;components;_registrarTopologyIds;enabled;maxInboundStreams;maxOutboundStreams;constructor(t,e){super();let{multicodecs:n=[],globalSignaturePolicy:s="StrictSign",canRelayMessage:i=!1,emitSelf:o=!1,messageProcessingConcurrency:c=10,maxInboundStreams:a=1,maxOutboundStreams:f=1}=e;this.log=t.logger.forComponent("libp2p:pubsub"),this.components=t,this.multicodecs=du(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:c}),this.maxInboundStreams=a,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(c=>{this.log(c)})}_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 Cs(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),c=[];for(let a of o.messages??[]){if(a.from==null||a.data==null||a.topic==null){this.log("message from %p was missing from, data or topic fields, dropping",t);continue}c.push({from:a.from,data:a.data,topic:a.topic,sequenceNumber:a.sequenceNumber??void 0,signature:a.signature??void 0,key:a.key??void 0})}this.processRpc(t,n,{subscriptions:(o.subscriptions??[]).map(a=>({subscribe:!!a.subscribe,topic:a.topic??""})),messages:c}).catch(a=>{this.log(a)})}})}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 qt("subscription-change",{detail:{peerId:e.id,subscriptions:s.map(({topic:o,subscribe:c})=>({topic:`${o??""}`,subscribe:!!c}))}}))),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 c=await pu(o);await this.processMessage(t,c)}catch(c){this.log.error(c)}})).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 qt("message",{detail:e})),await this.publishMessage(t,e)}}getMsgId(t){switch(this.globalSignaturePolicy){case"StrictSign":if(t.type!=="signed")throw new A('Message type should be "signed" when signature policy is StrictSign but it was not',ct.ERR_MISSING_SIGNATURE);if(t.sequenceNumber==null)throw new A("Need seqno when signature policy is StrictSign but it was missing",ct.ERR_MISSING_SEQNO);if(t.key==null)throw new A("Need key when signature policy is StrictSign but it was missing",ct.ERR_MISSING_KEY);return fu(t.key,t.sequenceNumber);case"StrictNoSign":return hu(t.data);default:throw new A("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 A('Message type should be "unsigned" when signature policy is StrictNoSign but it was not',ct.ERR_MISSING_SIGNATURE);if(e.signature!=null)throw new A("StrictNoSigning: signature should not be present",ct.ERR_UNEXPECTED_SIGNATURE);if(e.key!=null)throw new A("StrictNoSigning: key should not be present",ct.ERR_UNEXPECTED_KEY);if(e.sequenceNumber!=null)throw new A("StrictNoSigning: seqno should not be present",ct.ERR_UNEXPECTED_SEQNO);break;case"StrictSign":if(e.type!=="signed")throw new A('Message type should be "signed" when signature policy is StrictSign but it was not',ct.ERR_MISSING_SIGNATURE);if(e.signature==null)throw new A("StrictSigning: Signing required and no signature was present",ct.ERR_MISSING_SIGNATURE);if(e.sequenceNumber==null)throw new A("StrictSigning: Signing required and no sequenceNumber was present",ct.ERR_MISSING_SEQNO);if(!await mu(e,this.encodeMessage.bind(this)))throw new A("StrictSigning: Invalid message signature",ct.ERR_INVALID_SIGNATURE);break;default:throw new A("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 A("Message validation failed",ct.ERR_TOPIC_VALIDATOR_REJECT)}}async buildMessage(t){switch(this.globalSignaturePolicy){case"StrictSign":return yu(this.components.peerId,t,this.encodeMessage.bind(this));case"StrictNoSign":return Promise.resolve({type:"unsigned",...t});default:throw new A("Cannot build message: unhandled signature policy",ct.ERR_UNHANDLED_SIGNATURE_POLICY)}}getSubscribers(t){if(!this.started)throw new A("not started yet","ERR_NOT_STARTED_YET");if(t==null)throw new A("topic is required","ERR_NOT_VALID_TOPIC");let e=this.topics.get(t.toString());return e==null?[]:Array.from(e.values())}async publish(t,e){if(!this.started)throw new Error("Pubsub has not started");let n={from:this.components.peerId,topic:t,data:e??new Uint8Array(0),sequenceNumber:lu()};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 qt("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())}};return Tu(wd);})();
6
+ `)}`:`${e} :`}};ya=me;A.Constructed=ya;me.NAME="CONSTRUCTED";var xn=class extends gt{fromBER(t,e,n){return e}toBER(t){return Vt}};xn.override="EndOfContentValueBlock";var wa,vn=class extends lt{constructor(t={}){super(t,xn),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};wa=vn;A.EndOfContent=wa;vn.NAME=yr;var xa,Ye=class extends lt{constructor(t={}){super(t,gt),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}`}};xa=Ye;A.Null=xa;Ye.NAME="NULL";var En=class extends te(gt){constructor({value:t,...e}={}){super(e),e.valueHex?this.valueHexView=D.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=D.BufferSourceConverter.toUint8Array(t);return Qt(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,Ni.call(this),this.blockLength=n,e+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};En.NAME="BooleanValueBlock";var va,Bn=class extends lt{constructor(t={}){super(t,En),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}`}};va=Bn;A.Boolean=va;Bn.NAME="BOOLEAN";var Sn=class extends te(Mt){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=Mt.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let i=0;i<this.value.length;i++){let o=this.value[i].constructor.NAME;if(o===yr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(o!==pa)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?Mt.prototype.toBER.call(this,t,e):t?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};Sn.NAME="OctetStringValueBlock";var Ea,An=class r extends lt{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},Sn),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=Qn(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?me.prototype.onAsciiEncoding.call(this):`${this.constructor.NAME} : ${D.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 D.BufferSourceConverter.concat(t)}};Ea=An;A.OctetString=Ea;An.NAME=pa;var kn=class extends te(Mt){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=Mt.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let c of this.value){let a=c.constructor.NAME;if(a===yr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(a!==ga)return this.error="BIT STRING may consists of BIT STRINGs only",-1;let f=c.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=D.BufferSourceConverter.toUint8Array(t);if(!Qt(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 c=o.subarray(1);try{if(c.byteLength){let a=Qn(c,0,c.byteLength);a.offset!==-1&&a.offset===n-1&&(this.value=[a.result])}}catch{}}return this.valueHexView=o.subarray(1),this.blockLength=o.length,e+n}toBER(t,e){if(this.isConstructed)return Mt.prototype.toBER.call(this,t,e);if(t)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return Vt;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}}};kn.NAME="BitStringValueBlock";var Ba,Xe=class extends lt{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},kn),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 me.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)}`}}};Ba=Xe;A.BitString=Ba;Xe.NAME=ga;var Sa;function Vf(r,t){let e=new Uint8Array([0]),n=new Uint8Array(r),s=new Uint8Array(t),i=n.slice(0),o=i.length-1,c=s.slice(0),a=c.length-1,f=0,l=a<o?o:a,u=0;for(let d=l;d>=0;d--,u++){switch(!0){case u<c.length:f=i[o-u]+c[a-u]+e[0];break;default:f=i[o-u]+e[0]}switch(e[0]=f/10,!0){case u>=i.length:i=dn(new Uint8Array([f%10]),i);break;default:i[o-u]=f%10}}return e[0]>0&&(i=dn(e,i)),i}function da(r){if(r>=mr.length)for(let t=mr.length;t<=r;t++){let e=new Uint8Array([0]),n=mr[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=dn(e,n)),mr.push(n)}return mr[r]}function Hf(r,t){let e=0,n=new Uint8Array(r),s=new Uint8Array(t),i=n.slice(0),o=i.length-1,c=s.slice(0),a=c.length-1,f,l=0;for(let u=a;u>=0;u--,l++)switch(f=i[o-l]-c[a-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-a+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 wr=class extends te(gt){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=Ni.call(this)))}set valueDec(t){this._valueDec=t,this.isHexOnly=!1,this.valueHexView=new Uint8Array(la(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="",c=!1;for(let a=i.byteLength-1;a>=0;a--){s=i[a];for(let f=0;f<8;f++){if((s&1)===1)switch(n){case t:e=Hf(da(n),e),o="-";break;default:e=Vf(e,da(n))}n++,s>>=1}}for(let a=0;a<e.length;a++)e[a]&&(c=!0),c&&(o+=ha.charAt(e[a]));return c===!1&&(o+=ha.charAt(0)),o}};Sa=wr;wr.NAME="IntegerValueBlock";Object.defineProperty(Sa.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var Aa,ft=class r extends lt{constructor(t={}){super(t,wr),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return pn(),BigInt(this.valueBlock.toString())}static fromBigInt(t){pn();let e=BigInt(t),n=new br,s=e.toString(16).replace(/^-/,""),i=new Uint8Array(D.Convert.FromHex(s));if(e<0){let c=new Uint8Array(i.length+(i[0]&128?1:0));c[0]|=128;let f=BigInt(`0x${D.Convert.ToHex(c)}`)+e,l=D.BufferSourceConverter.toUint8Array(D.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()}`}};Aa=ft;A.Integer=Aa;ft.NAME="INTEGER";var ka,In=class extends ft{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};ka=In;A.Enumerated=ka;In.NAME="ENUMERATED";var xr=class extends te(gt){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=D.BufferSourceConverter.toUint8Array(t);if(!Qt(this,s,e,n))return-1;let i=s.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let c=0;c<n&&(this.valueHexView[c]=i[c]&127,this.blockLength++,!!(i[c]&128));c++);let o=new Uint8Array(this.blockLength);for(let c=0;c<this.blockLength;c++)o[c]=this.valueHexView[c];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=Te(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}set valueBigInt(t){pn();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=ge(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Vt;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=D.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}}};xr.NAME="sidBlock";var Nn=class extends gt{constructor({value:t=tr,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let i=new xr;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,Vt;e.push(s)}return Ci(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],c=0;switch(o.valueDec){case 0:break;case 1:c=40;break;case 2:c=80;break;default:this.value=[];return}let a=parseInt(s,10);if(isNaN(a))return;o.valueDec=a+c,i=!1}else{let o=new xr;if(s>Number.MAX_SAFE_INTEGER){pn();let c=BigInt(s);o.valueBigInt=c}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}};Nn.NAME="ObjectIdentifierValueBlock";var Ia,Qe=class extends lt{constructor(t={}){super(t,Nn),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()}}};Ia=Qe;A.ObjectIdentifier=Ia;Qe.NAME="OBJECT IDENTIFIER";var vr=class extends te(Jt){constructor({valueDec:t=0,...e}={}){super(e),this.valueDec=t}fromBER(t,e,n){if(n===0)return e;let s=D.BufferSourceConverter.toUint8Array(t);if(!Qt(this,s,e,n))return-1;let i=s.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let c=0;c<n&&(this.valueHexView[c]=i[c]&127,this.blockLength++,!!(i[c]&128));c++);let o=new Uint8Array(this.blockLength);for(let c=0;c<this.blockLength;c++)o[c]=this.valueHexView[c];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=Te(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=ge(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Vt;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=D.Convert.ToHex(this.valueHexView):t=this.valueDec.toString(),t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};vr.NAME="relativeSidBlock";var Cn=class extends gt{constructor({value:t=tr,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let i=new vr;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,Vt;n.push(i)}return Ci(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 vr;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}};Cn.NAME="RelativeObjectIdentifierValueBlock";var Na,Tn=class extends lt{constructor(t={}){super(t,Cn),this.idBlock.tagClass=1,this.idBlock.tagNumber=13}getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};Na=Tn;A.RelativeObjectIdentifier=Na;Tn.NAME="RelativeObjectIdentifier";var Ca,Yt=class extends me{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};Ca=Yt;A.Sequence=Ca;Yt.NAME="SEQUENCE";var Ta,Ln=class extends me{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};Ta=Ln;A.Set=Ta;Ln.NAME="SET";var Un=class extends te(gt){constructor({...t}={}){super(t),this.isHexOnly=!0,this.value=tr}toJSON(){return{...super.toJSON(),value:this.value}}};Un.NAME="StringValueBlock";var Rn=class extends Un{};Rn.NAME="SimpleStringValueBlock";var wt=class extends bn{constructor({...t}={}){super(t,Rn)}fromBuffer(t){this.valueBlock.value=String.fromCharCode.apply(null,D.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}};wt.NAME="SIMPLE STRING";var _n=class extends wt{fromBuffer(t){this.valueBlock.valueHexView=D.BufferSourceConverter.toUint8Array(t);try{this.valueBlock.value=D.Convert.ToUtf8String(t)}catch(e){this.warnings.push(`Error during "decodeURIComponent": ${e}, using raw string`),this.valueBlock.value=D.Convert.ToBinary(t)}}fromString(t){this.valueBlock.valueHexView=new Uint8Array(D.Convert.FromUtf8String(t)),this.valueBlock.value=t}};_n.NAME="Utf8StringValueBlock";var La,Xt=class extends _n{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};La=Xt;A.Utf8String=La;Xt.NAME="UTF8String";var Vn=class extends wt{fromBuffer(t){this.valueBlock.value=D.Convert.ToUtf16String(t),this.valueBlock.valueHexView=D.BufferSourceConverter.toUint8Array(t)}fromString(t){this.valueBlock.value=t,this.valueBlock.valueHexView=new Uint8Array(D.Convert.FromUtf16String(t))}};Vn.NAME="BmpStringValueBlock";var Ua,Hn=class extends Vn{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};Ua=Hn;A.BmpString=Ua;Hn.NAME="BMPString";var On=class extends wt{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=ge(t.charCodeAt(s),8),o=new Uint8Array(i);if(o.length>4)continue;let c=4-o.length;for(let a=o.length-1;a>=0;a--)n[s*4+a+c]=o[a]}this.valueBlock.value=t}};On.NAME="UniversalStringValueBlock";var Ra,Mn=class extends On{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};Ra=Mn;A.UniversalString=Ra;Mn.NAME="UniversalString";var _a,Dn=class extends wt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};_a=Dn;A.NumericString=_a;Dn.NAME="NumericString";var Va,Pn=class extends wt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};Va=Pn;A.PrintableString=Va;Pn.NAME="PrintableString";var Ha,Fn=class extends wt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};Ha=Fn;A.TeletexString=Ha;Fn.NAME="TeletexString";var Oa,Kn=class extends wt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};Oa=Kn;A.VideotexString=Oa;Kn.NAME="VideotexString";var Ma,qn=class extends wt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};Ma=qn;A.IA5String=Ma;qn.NAME="IA5String";var Da,$n=class extends wt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};Da=$n;A.GraphicString=Da;$n.NAME="GraphicString";var Pa,Er=class extends wt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};Pa=Er;A.VisibleString=Pa;Er.NAME="VisibleString";var Fa,zn=class extends wt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};Fa=zn;A.GeneralString=Fa;zn.NAME="GeneralString";var Ka,Gn=class extends wt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};Ka=Gn;A.CharacterString=Ka;Gn.NAME="CharacterString";var qa,Br=class extends Er{constructor({value:t,valueDate:e,...n}={}){if(super(n),this.year=0,this.month=0,this.day=0,this.hour=0,this.minute=0,this.second=0,t){this.fromString(t),this.valueBlock.valueHexView=new Uint8Array(t.length);for(let s=0;s<t.length;s++)this.valueBlock.valueHexView[s]=t.charCodeAt(s)}e&&(this.fromDate(e),this.valueBlock.valueHexView=new Uint8Array(this.toBuffer())),this.idBlock.tagClass=1,this.idBlock.tagNumber=23}fromBuffer(t){this.fromString(String.fromCharCode.apply(null,D.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]=St(this.year<2e3?this.year-1900:this.year-2e3,2),e[1]=St(this.month,2),e[2]=St(this.day,2),e[3]=St(this.hour,2),e[4]=St(this.minute,2),e[5]=St(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}}};qa=Br;A.UTCTime=qa;Br.NAME="UTCTime";var $a,jn=class extends Br{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,c=0,a=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,d=n.indexOf("+"),x="";if(d===-1&&(d=n.indexOf("-"),u=-1),d!==-1){if(x=n.substring(d+1),n=n.substring(0,d),x.length!==2&&x.length!==4)throw new Error("Wrong input string for conversion");let E=parseInt(x.substring(0,2),10);if(isNaN(E.valueOf()))throw new Error("Wrong input string for conversion");if(c=u*E,x.length===4){if(E=parseInt(x.substring(2,4),10),isNaN(E.valueOf()))throw new Error("Wrong input string for conversion");a=u*E}}}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)+c;break;case 5:this.minute=parseInt(l[u],10)+a;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(St(this.year,4)),e.push(St(this.month,2)),e.push(St(this.day,2)),e.push(St(this.hour,2)),e.push(St(this.minute,2)),e.push(St(this.second,2)),this.millisecond!==0&&(e.push("."),e.push(St(this.millisecond,3))),e.push("Z"),e.join("")}return super.toString(t)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};$a=jn;A.GeneralizedTime=$a;jn.NAME="GeneralizedTime";var za,Zn=class extends Xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};za=Zn;A.DATE=za;Zn.NAME="DATE";var Ga,Wn=class extends Xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};Ga=Wn;A.TimeOfDay=Ga;Wn.NAME="TimeOfDay";var ja,Jn=class extends Xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};ja=Jn;A.DateTime=ja;Jn.NAME="DateTime";var Za,Yn=class extends Xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};Za=Yn;A.Duration=Za;Yn.NAME="Duration";var Wa,Xn=class extends Xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};Wa=Xn;A.TIME=Wa;Xn.NAME="TIME";function at(r,t="utf8"){let e=on[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}function ts(r){if(isNaN(r)||r<=0)throw new rt("random bytes length must be a Number bigger than 0");return ze(r)}var Sr=class extends Error{constructor(t="An error occurred while verifying a message"){super(t),this.name="VerificationError"}},es=class extends Error{constructor(t="Missing Web Crypto API"){super(t),this.name="WebCryptoMissingError"}};var Ja={get(r=globalThis){let t=r.crypto;if(t?.subtle==null)throw new es("Missing Web Crypto API. The most likely cause of this error is that this page is being accessed from an insecure context (i.e. not HTTPS). For more information and possible resolutions see https://github.com/libp2p/js-libp2p/blob/main/packages/crypto/README.md#web-crypto-api");return t}};var be=Ja;async function Ya(r){let t=await be.get().subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:r,publicExponent:new Uint8Array([1,0,1]),hash:{name:"SHA-256"}},!0,["sign","verify"]),e=await Mf(t);return{privateKey:e[0],publicKey:e[1]}}async function Xa(r,t){let e=await be.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await be.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},e,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(n,0,n.byteLength)}async function Qa(r,t,e){let n=await be.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return be.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,t,e instanceof Uint8Array?e:e.subarray())}async function Mf(r){if(r.privateKey==null||r.publicKey==null)throw new rt("Private and public key are required");return Promise.all([be.get().subtle.exportKey("jwk",r.privateKey),be.get().subtle.exportKey("jwk",r.publicKey)])}function Ui(r){if(r.kty!=="RSA")throw new rt("invalid key type");if(r.n==null)throw new rt("invalid key modulus");return Z(r.n,"base64url").length*8}var er=class{type="RSA";_key;_raw;_multihash;constructor(t,e){this._key=t,this._multihash=e}get raw(){return this._raw==null&&(this._raw=Ar.jwkToPkix(this._key)),this._raw}toMultihash(){return this._multihash}toCID(){return At.createV1(114,this._multihash)}toString(){return X.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:It(this.raw,t.raw)}verify(t,e){return Qa(this._key,e,t)}},kr=class{type="RSA";_key;_raw;publicKey;constructor(t,e){this._key=t,this.publicKey=e}get raw(){return this._raw==null&&(this._raw=Ar.jwkToPkcs1(this._key)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:It(this.raw,t.raw)}sign(t){return Xa(this._key,t)}};var rs=8192,Ri=18;function tc(r){let{result:t}=Li(r),e=t.valueBlock.value;return{n:at(Dt(e[1].toBigInt()),"base64url"),e:at(Dt(e[2].toBigInt()),"base64url"),d:at(Dt(e[3].toBigInt()),"base64url"),p:at(Dt(e[4].toBigInt()),"base64url"),q:at(Dt(e[5].toBigInt()),"base64url"),dp:at(Dt(e[6].toBigInt()),"base64url"),dq:at(Dt(e[7].toBigInt()),"base64url"),qi:at(Dt(e[8].toBigInt()),"base64url"),kty:"RSA",alg:"RS256"}}function Df(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 rt("JWK was missing components");let e=new Yt({value:[new ft({value:0}),ft.fromBigInt(Pt(Z(r.n,"base64url"))),ft.fromBigInt(Pt(Z(r.e,"base64url"))),ft.fromBigInt(Pt(Z(r.d,"base64url"))),ft.fromBigInt(Pt(Z(r.p,"base64url"))),ft.fromBigInt(Pt(Z(r.q,"base64url"))),ft.fromBigInt(Pt(Z(r.dp,"base64url"))),ft.fromBigInt(Pt(Z(r.dq,"base64url"))),ft.fromBigInt(Pt(Z(r.qi,"base64url")))]}).toBER();return new Uint8Array(e,0,e.byteLength)}function ec(r){let{result:t}=Li(r),e=t.valueBlock.value[1].valueBlock.value[0].valueBlock.value;return{kty:"RSA",n:at(Dt(e[0].toBigInt()),"base64url"),e:at(Dt(e[1].toBigInt()),"base64url")}}function _i(r){if(r.n==null||r.e==null)throw new rt("JWK was missing components");let e=new Yt({value:[new Yt({value:[new Qe({value:"1.2.840.113549.1.1.1"}),new Ye]}),new Xe({valueHex:new Yt({value:[ft.fromBigInt(Pt(Z(r.n,"base64url"))),ft.fromBigInt(Pt(Z(r.e,"base64url")))]}).toBER()})]}).toBER();return new Uint8Array(e,0,e.byteLength)}function Dt(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 Pt(r){let t=[];return r.forEach(function(e){let n=e.toString(16);n.length%2>0&&(n=`0${n}`),t.push(n)}),BigInt("0x"+t.join(""))}function rc(r){let t=tc(r);return nc(t)}function Vi(r){let t=ec(r);if(Ui(t)>rs)throw new Ve("Key size is too large");let e=We(Ot.encode({Type:st.RSA,Data:r})),n=Ct(Ri,e);return new er(t,n)}function nc(r){if(Ui(r)>rs)throw new rt("Key size is too large");let t=ic(r),e=We(Ot.encode({Type:st.RSA,Data:_i(t.publicKey)})),n=Ct(Ri,e);return new kr(t.privateKey,new er(t.publicKey,n))}async function sc(r){if(r>rs)throw new rt("Key size is too large");let t=await Ya(r),e=We(Ot.encode({Type:st.RSA,Data:_i(t.publicKey)})),n=Ct(Ri,e);return new kr(t.privateKey,new er(t.publicKey,n))}function ic(r){if(r==null)throw new rt("Missing key parameter");return{privateKey:r,publicKey:{kty:r.kty,n:r.n,e:r.e}}}var ns=class extends $e{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,Ao(t);let n=lr(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 qe(this),this.iHash.update(t),this}digestInto(t){qe(this),Ke(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:c}=this;return t=t,t.finished=s,t.destroyed=i,t.blockLen=o,t.outputLen=c,t.oHash=e._cloneInto(t.oHash),t.iHash=n._cloneInto(t.iHash),t}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},Hi=(r,t,e)=>new ns(r,t).update(e).digest();Hi.create=(r,t)=>new ns(r,t);function oc(r){r.lowS!==void 0&&Lt("lowS",r.lowS),r.prehash!==void 0&&Lt("prehash",r.prehash)}function Pf(r){let t=dr(r);Ht(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:Ff,hexToBytes:Kf}=Jr,ee={Err:class extends Error{constructor(t=""){super(t)}},_tlv:{encode:(r,t)=>{let{Err:e}=ee;if(r<0||r>256)throw new e("tlv.encode: wrong tag");if(t.length&1)throw new e("tlv.encode: unpadded data");let n=t.length/2,s=ve(n);if(s.length/2&128)throw new e("tlv.encode: long form length too big");let i=n>127?ve(s.length/2|128):"";return`${ve(r)}${i}${s}${t}`},decode(r,t){let{Err:e}=ee,n=0;if(r<0||r>256)throw new e("tlv.encode: wrong tag");if(t.length<2||t[n++]!==r)throw new e("tlv.decode: wrong tlv");let s=t[n++],i=!!(s&128),o=0;if(!i)o=s;else{let a=s&127;if(!a)throw new e("tlv.decode(long): indefinite length not supported");if(a>4)throw new e("tlv.decode(long): byte length is too big");let f=t.subarray(n,n+a);if(f.length!==a)throw new e("tlv.decode: length bytes not complete");if(f[0]===0)throw new e("tlv.decode(long): zero leftmost byte");for(let l of f)o=o<<8|l;if(n+=a,o<128)throw new e("tlv.decode(long): not minimal encoding")}let c=t.subarray(n,n+o);if(c.length!==o)throw new e("tlv.decode: wrong value length");return{v:c,l:t.subarray(n+o)}}},_int:{encode(r){let{Err:t}=ee;if(r<re)throw new t("integer: negative integers are not allowed");let e=ve(r);if(Number.parseInt(e[0],16)&8&&(e="00"+e),e.length&1)throw new t("unexpected assertion");return e},decode(r){let{Err:t}=ee;if(r[0]&128)throw new t("Invalid signature integer: negative");if(r[0]===0&&!(r[1]&128))throw new t("Invalid signature integer: unnecessary leading zero");return Ff(r)}},toSig(r){let{Err:t,_int:e,_tlv:n}=ee,s=typeof r=="string"?Kf(r):r;je(s);let{v:i,l:o}=n.decode(48,s);if(o.length)throw new t("Invalid signature: left bytes after parsing");let{v:c,l:a}=n.decode(2,i),{v:f,l}=n.decode(2,a);if(l.length)throw new t("Invalid signature: left bytes after parsing");return{r:e.decode(c),s:e.decode(f)}},hexFromSig(r){let{_tlv:t,_int:e}=ee,n=`${t.encode(2,e.encode(r.r))}${t.encode(2,e.encode(r.s))}`;return t.encode(48,n)}},re=BigInt(0),ct=BigInt(1),Sp=BigInt(2),ac=BigInt(3),Ap=BigInt(4);function qf(r){let t=Pf(r),{Fp:e}=t,n=fe(t.n,t.nBitLength),s=t.toBytes||((b,h,y)=>{let v=h.toAffine();return jt(Uint8Array.from([4]),e.toBytes(v.x),e.toBytes(v.y))}),i=t.fromBytes||(b=>{let h=b.subarray(1),y=e.fromBytes(h.subarray(0,e.BYTES)),v=e.fromBytes(h.subarray(e.BYTES,2*e.BYTES));return{x:y,y:v}});function o(b){let{a:h,b:y}=t,v=e.sqr(b),g=e.mul(v,b);return e.add(e.add(g,e.mul(b,h)),y)}if(!e.eql(e.sqr(t.Gy),o(t.Gx)))throw new Error("bad generator point: equation left != right");function c(b){return fr(b,ct,t.n)}function a(b){let{allowedPrivateKeyLengths:h,nByteLength:y,wrapPrivateKey:v,n:g}=t;if(h&&typeof b!="bigint"){if(ce(b)&&(b=zt(b)),typeof b!="string"||!h.includes(b.length))throw new Error("Invalid key");b=b.padStart(y*2,"0")}let S;try{S=typeof b=="bigint"?b:Gt(J("private key",b,y))}catch{throw new Error(`private key must be ${y} bytes, hex or bigint, not ${typeof b}`)}return v&&(S=$(S,g)),Et("private key",S,ct,g),S}function f(b){if(!(b instanceof d))throw new Error("ProjectivePoint expected")}let l=Se((b,h)=>{let{px:y,py:v,pz:g}=b;if(e.eql(g,e.ONE))return{x:y,y:v};let S=b.is0();h==null&&(h=S?e.ONE:e.inv(g));let U=e.mul(y,h),L=e.mul(v,h),k=e.mul(g,h);if(S)return{x:e.ZERO,y:e.ZERO};if(!e.eql(k,e.ONE))throw new Error("invZ was invalid");return{x:U,y:L}}),u=Se(b=>{if(b.is0()){if(t.allowInfinityPoint&&!e.is0(b.py))return;throw new Error("bad point: ZERO")}let{x:h,y}=b.toAffine();if(!e.isValid(h)||!e.isValid(y))throw new Error("bad point: x or y not FE");let v=e.sqr(y),g=o(h);if(!e.eql(v,g))throw new Error("bad point: equation left != right");if(!b.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});class d{constructor(h,y,v){if(this.px=h,this.py=y,this.pz=v,h==null||!e.isValid(h))throw new Error("x required");if(y==null||!e.isValid(y))throw new Error("y required");if(v==null||!e.isValid(v))throw new Error("z required");Object.freeze(this)}static fromAffine(h){let{x:y,y:v}=h||{};if(!h||!e.isValid(y)||!e.isValid(v))throw new Error("invalid affine point");if(h instanceof d)throw new Error("projective point not allowed");let g=S=>e.eql(S,e.ZERO);return g(y)&&g(v)?d.ZERO:new d(y,v,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(h){let y=e.invertBatch(h.map(v=>v.pz));return h.map((v,g)=>v.toAffine(y[g])).map(d.fromAffine)}static fromHex(h){let y=d.fromAffine(i(J("pointHex",h)));return y.assertValidity(),y}static fromPrivateKey(h){return d.BASE.multiply(a(h))}static msm(h,y){return Qr(d,n,h,y)}_setWindowSize(h){E.setWindowSize(this,h)}assertValidity(){u(this)}hasEvenY(){let{y:h}=this.toAffine();if(e.isOdd)return!e.isOdd(h);throw new Error("Field doesn't support isOdd")}equals(h){f(h);let{px:y,py:v,pz:g}=this,{px:S,py:U,pz:L}=h,k=e.eql(e.mul(y,L),e.mul(S,g)),I=e.eql(e.mul(v,L),e.mul(U,g));return k&&I}negate(){return new d(this.px,e.neg(this.py),this.pz)}double(){let{a:h,b:y}=t,v=e.mul(y,ac),{px:g,py:S,pz:U}=this,L=e.ZERO,k=e.ZERO,I=e.ZERO,T=e.mul(g,g),Q=e.mul(S,S),F=e.mul(U,U),H=e.mul(g,S);return H=e.add(H,H),I=e.mul(g,U),I=e.add(I,I),L=e.mul(h,I),k=e.mul(v,F),k=e.add(L,k),L=e.sub(Q,k),k=e.add(Q,k),k=e.mul(L,k),L=e.mul(H,L),I=e.mul(v,I),F=e.mul(h,F),H=e.sub(T,F),H=e.mul(h,H),H=e.add(H,I),I=e.add(T,T),T=e.add(I,T),T=e.add(T,F),T=e.mul(T,H),k=e.add(k,T),F=e.mul(S,U),F=e.add(F,F),T=e.mul(F,H),L=e.sub(L,T),I=e.mul(F,Q),I=e.add(I,I),I=e.add(I,I),new d(L,k,I)}add(h){f(h);let{px:y,py:v,pz:g}=this,{px:S,py:U,pz:L}=h,k=e.ZERO,I=e.ZERO,T=e.ZERO,Q=t.a,F=e.mul(t.b,ac),H=e.mul(y,S),tt=e.mul(v,U),B=e.mul(g,L),N=e.add(y,v),m=e.add(S,U);N=e.mul(N,m),m=e.add(H,tt),N=e.sub(N,m),m=e.add(y,g);let p=e.add(S,L);return m=e.mul(m,p),p=e.add(H,B),m=e.sub(m,p),p=e.add(v,g),k=e.add(U,L),p=e.mul(p,k),k=e.add(tt,B),p=e.sub(p,k),T=e.mul(Q,m),k=e.mul(F,B),T=e.add(k,T),k=e.sub(tt,T),T=e.add(tt,T),I=e.mul(k,T),tt=e.add(H,H),tt=e.add(tt,H),B=e.mul(Q,B),m=e.mul(F,m),tt=e.add(tt,B),B=e.sub(H,B),B=e.mul(Q,B),m=e.add(m,B),H=e.mul(tt,m),I=e.add(I,H),H=e.mul(p,m),k=e.mul(N,k),k=e.sub(k,H),H=e.mul(N,tt),T=e.mul(p,T),T=e.add(T,H),new d(k,I,T)}subtract(h){return this.add(h.negate())}is0(){return this.equals(d.ZERO)}wNAF(h){return E.wNAFCached(this,h,d.normalizeZ)}multiplyUnsafe(h){Et("scalar",h,re,t.n);let y=d.ZERO;if(h===re)return y;if(h===ct)return this;let{endo:v}=t;if(!v)return E.unsafeLadder(this,h);let{k1neg:g,k1:S,k2neg:U,k2:L}=v.splitScalar(h),k=y,I=y,T=this;for(;S>re||L>re;)S&ct&&(k=k.add(T)),L&ct&&(I=I.add(T)),T=T.double(),S>>=ct,L>>=ct;return g&&(k=k.negate()),U&&(I=I.negate()),I=new d(e.mul(I.px,v.beta),I.py,I.pz),k.add(I)}multiply(h){let{endo:y,n:v}=t;Et("scalar",h,ct,v);let g,S;if(y){let{k1neg:U,k1:L,k2neg:k,k2:I}=y.splitScalar(h),{p:T,f:Q}=this.wNAF(L),{p:F,f:H}=this.wNAF(I);T=E.constTimeNegate(U,T),F=E.constTimeNegate(k,F),F=new d(e.mul(F.px,y.beta),F.py,F.pz),g=T.add(F),S=Q.add(H)}else{let{p:U,f:L}=this.wNAF(h);g=U,S=L}return d.normalizeZ([g,S])[0]}multiplyAndAddUnsafe(h,y,v){let g=d.BASE,S=(L,k)=>k===re||k===ct||!L.equals(g)?L.multiplyUnsafe(k):L.multiply(k),U=S(this,y).add(S(h,v));return U.is0()?void 0:U}toAffine(h){return l(this,h)}isTorsionFree(){let{h,isTorsionFree:y}=t;if(h===ct)return!0;if(y)return y(d,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h,clearCofactor:y}=t;return h===ct?this:y?y(d,this):this.multiplyUnsafe(t.h)}toRawBytes(h=!0){return Lt("isCompressed",h),this.assertValidity(),s(d,this,h)}toHex(h=!0){return Lt("isCompressed",h),zt(this.toRawBytes(h))}}d.BASE=new d(t.Gx,t.Gy,e.ONE),d.ZERO=new d(e.ZERO,e.ONE,e.ZERO);let x=t.nBitLength,E=Xr(d,t.endo?Math.ceil(x/2):x);return{CURVE:t,ProjectivePoint:d,normPrivateKeyToScalar:a,weierstrassEquation:o,isWithinCurveOrder:c}}function $f(r){let t=dr(r);return Ht(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function cc(r){let t=$f(r),{Fp:e,n}=t,s=e.BYTES+1,i=2*e.BYTES+1;function o(B){return $(B,n)}function c(B){return Yr(B,n)}let{ProjectivePoint:a,normPrivateKeyToScalar:f,weierstrassEquation:l,isWithinCurveOrder:u}=qf({...t,toBytes(B,N,m){let p=N.toAffine(),w=e.toBytes(p.x),C=jt;return Lt("isCompressed",m),m?C(Uint8Array.from([N.hasEvenY()?2:3]),w):C(Uint8Array.from([4]),w,e.toBytes(p.y))},fromBytes(B){let N=B.length,m=B[0],p=B.subarray(1);if(N===s&&(m===2||m===3)){let w=Gt(p);if(!fr(w,ct,e.ORDER))throw new Error("Point is not on curve");let C=l(w),R;try{R=e.sqrt(C)}catch(P){let M=P instanceof Error?": "+P.message:"";throw new Error("Point is not on curve"+M)}let _=(R&ct)===ct;return(m&1)===1!==_&&(R=e.neg(R)),{x:w,y:R}}else if(N===i&&m===4){let w=e.fromBytes(p.subarray(0,e.BYTES)),C=e.fromBytes(p.subarray(e.BYTES,2*e.BYTES));return{x:w,y:C}}else throw new Error(`Point of length ${N} was invalid. Expected ${s} compressed bytes or ${i} uncompressed bytes`)}}),d=B=>zt(le(B,t.nByteLength));function x(B){let N=n>>ct;return B>N}function E(B){return x(B)?o(-B):B}let b=(B,N,m)=>Gt(B.slice(N,m));class h{constructor(N,m,p){this.r=N,this.s=m,this.recovery=p,this.assertValidity()}static fromCompact(N){let m=t.nByteLength;return N=J("compactSignature",N,m*2),new h(b(N,0,m),b(N,m,2*m))}static fromDER(N){let{r:m,s:p}=ee.toSig(J("DER",N));return new h(m,p)}assertValidity(){Et("r",this.r,ct,n),Et("s",this.s,ct,n)}addRecoveryBit(N){return new h(this.r,this.s,N)}recoverPublicKey(N){let{r:m,s:p,recovery:w}=this,C=L(J("msgHash",N));if(w==null||![0,1,2,3].includes(w))throw new Error("recovery id invalid");let R=w===2||w===3?m+t.n:m;if(R>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let _=w&1?"03":"02",O=a.fromHex(_+d(R)),P=c(R),M=o(-C*P),q=o(p*P),z=a.BASE.multiplyAndAddUnsafe(O,M,q);if(!z)throw new Error("point at infinify");return z.assertValidity(),z}hasHighS(){return x(this.s)}normalizeS(){return this.hasHighS()?new h(this.r,o(-this.s),this.recovery):this}toDERRawBytes(){return Ee(this.toDERHex())}toDERHex(){return ee.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return Ee(this.toCompactHex())}toCompactHex(){return d(this.r)+d(this.s)}}let y={isValidPrivateKey(B){try{return f(B),!0}catch{return!1}},normPrivateKeyToScalar:f,randomPrivateKey:()=>{let B=Fs(t.n);return Mo(t.randomBytes(B),t.n)},precompute(B=8,N=a.BASE){return N._setWindowSize(B),N.multiply(BigInt(3)),N}};function v(B,N=!0){return a.fromPrivateKey(B).toRawBytes(N)}function g(B){let N=ce(B),m=typeof B=="string",p=(N||m)&&B.length;return N?p===s||p===i:m?p===2*s||p===2*i:B instanceof a}function S(B,N,m=!0){if(g(B))throw new Error("first arg must be private key");if(!g(N))throw new Error("second arg must be public key");return a.fromHex(N).multiply(f(B)).toRawBytes(m)}let U=t.bits2int||function(B){let N=Gt(B),m=B.length*8-t.nBitLength;return m>0?N>>BigInt(m):N},L=t.bits2int_modN||function(B){return o(U(B))},k=hr(t.nBitLength);function I(B){return Et(`num < 2^${t.nBitLength}`,B,re,k),le(B,t.nByteLength)}function T(B,N,m=Q){if(["recovered","canonical"].some(ot=>ot in m))throw new Error("sign() legacy options not supported");let{hash:p,randomBytes:w}=t,{lowS:C,prehash:R,extraEntropy:_}=m;C==null&&(C=!0),B=J("msgHash",B),oc(m),R&&(B=J("prehashed msgHash",p(B)));let O=L(B),P=f(N),M=[I(P),I(O)];if(_!=null&&_!==!1){let ot=_===!0?w(e.BYTES):_;M.push(J("extraEntropy",ot))}let q=jt(...M),z=O;function it(ot){let ut=U(ot);if(!u(ut))return;let bt=c(ut),et=a.BASE.multiply(ut).toAffine(),vt=o(et.x);if(vt===re)return;let Ft=o(bt*o(z+vt*P));if(Ft===re)return;let sr=(et.x===vt?0:2)|Number(et.y&ct),ir=Ft;return C&&x(Ft)&&(ir=E(Ft),sr^=1),new h(vt,ir,sr)}return{seed:q,k2sig:it}}let Q={lowS:t.lowS,prehash:!1},F={lowS:t.lowS,prehash:!1};function H(B,N,m=Q){let{seed:p,k2sig:w}=T(B,N,m),C=t;return Os(C.hash.outputLen,C.nByteLength,C.hmac)(p,w)}a.BASE._setWindowSize(8);function tt(B,N,m,p=F){let w=B;if(N=J("msgHash",N),m=J("publicKey",m),"strict"in p)throw new Error("options.strict was renamed to lowS");oc(p);let{lowS:C,prehash:R}=p,_,O;try{if(typeof w=="string"||ce(w))try{_=h.fromDER(w)}catch(et){if(!(et instanceof ee.Err))throw et;_=h.fromCompact(w)}else if(typeof w=="object"&&typeof w.r=="bigint"&&typeof w.s=="bigint"){let{r:et,s:vt}=w;_=new h(et,vt)}else throw new Error("PARSE");O=a.fromHex(m)}catch(et){if(et.message==="PARSE")throw new Error("signature must be Signature instance, Uint8Array or hex string");return!1}if(C&&_.hasHighS())return!1;R&&(N=t.hash(N));let{r:P,s:M}=_,q=L(N),z=c(M),it=o(q*z),ot=o(P*z),ut=a.BASE.multiplyAndAddUnsafe(O,it,ot)?.toAffine();return ut?o(ut.x)===P:!1}return{CURVE:t,getPublicKey:v,getSharedSecret:S,sign:H,verify:tt,ProjectivePoint:a,Signature:h,utils:y}}function zf(r){return{hash:r,hmac:(t,...e)=>Hi(r,t,Cs(...e)),randomBytes:ze}}function uc(r,t){let e=n=>cc({...r,...zf(n)});return Object.freeze({...e(t),create:e})}var hc=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),lc=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),Gf=BigInt(1),Oi=BigInt(2),fc=(r,t)=>(r+t/Oi)/t;function jf(r){let t=hc,e=BigInt(3),n=BigInt(6),s=BigInt(11),i=BigInt(22),o=BigInt(23),c=BigInt(44),a=BigInt(88),f=r*r*r%t,l=f*f*r%t,u=j(l,e,t)*l%t,d=j(u,e,t)*l%t,x=j(d,Oi,t)*f%t,E=j(x,s,t)*x%t,b=j(E,i,t)*E%t,h=j(b,c,t)*b%t,y=j(h,a,t)*h%t,v=j(y,c,t)*b%t,g=j(v,e,t)*l%t,S=j(g,o,t)*E%t,U=j(S,n,t)*f%t,L=j(U,Oi,t);if(!Mi.eql(Mi.sqr(L),r))throw new Error("Cannot find square root");return L}var Mi=fe(hc,void 0,void 0,{sqrt:jf}),Le=uc({a:BigInt(0),b:BigInt(7),Fp:Mi,n:lc,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=lc,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-Gf*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),s=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),i=e,o=BigInt("0x100000000000000000000000000000000"),c=fc(i*r,t),a=fc(-n*r,t),f=$(r-c*e-a*s,t),l=$(-c*n-a*i,t),u=f>o,d=l>o;if(u&&(f=t-f),d&&(l=t-l),f>o||l>o)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:u,k1:f,k2neg:d,k2:l}}}},We),_p=BigInt(0);var Vp=Le.ProjectivePoint;function Ue(r,t){t==null&&(t=r.reduce((s,i)=>s+i.length,0));let e=ht(t),n=0;for(let s of r)e.set(s,n),n+=s.length;return e}function dc(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function pc(r,t,e){let n=Ne.digest(e instanceof Uint8Array?e:e.subarray());if(dc(n))return n.then(({digest:s})=>Le.verify(t,s,r)).catch(s=>{throw new Sr(String(s))});try{return Le.verify(t,n.digest,r)}catch(s){throw new Sr(String(s))}}var ss=class{type="secp256k1";raw;_key;constructor(t){this._key=mc(t),this.raw=gc(this._key)}toMultihash(){return qt.digest(ke(this))}toCID(){return At.createV1(114,this.toMultihash())}toString(){return X.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:It(this.raw,t.raw)}verify(t,e){return pc(this._key,e,t)}};function Di(r){return new ss(r)}function gc(r){return Le.ProjectivePoint.fromHex(r).toRawBytes(!0)}function mc(r){try{return Le.ProjectivePoint.fromHex(r),r}catch(t){throw new Ve(String(t))}}function Pi(r){let{Type:t,Data:e}=Ot.decode(r),n=e??new Uint8Array;switch(t){case st.RSA:return Vi(n);case st.Ed25519:return Gs(n);case st.secp256k1:return Di(n);default:throw new we}}function bc(r){let{Type:t,Data:e}=Ot.decode(r.digest),n=e??new Uint8Array;switch(t){case st.Ed25519:return Gs(n);case st.secp256k1:return Di(n);default:throw new we}}function ke(r){return Ot.encode({Type:st[r.type],Data:r.raw})}var yc=Symbol.for("nodejs.util.inspect.custom"),Zf=114,Ir=class{type;multihash;publicKey;string;constructor(t){this.type=t.type,this.multihash=t.multihash,Object.defineProperty(this,"string",{enumerable:!1,writable:!0})}get[Symbol.toStringTag](){return`PeerId(${this.toString()})`}[ws]=!0;toString(){return this.string==null&&(this.string=X.encode(this.multihash.bytes).slice(1)),this.string}toMultihash(){return this.multihash}toCID(){return At.createV1(Zf,this.multihash)}toJSON(){return this.toString()}equals(t){if(t==null)return!1;if(t instanceof Uint8Array)return It(this.multihash.bytes,t);if(typeof t=="string")return this.toString()===t;if(t?.toMultihash()?.bytes!=null)return It(this.multihash.bytes,t.toMultihash().bytes);throw new Error("not valid Id")}[yc](){return`PeerId(${this.toString()})`}},Nr=class extends Ir{type="RSA";publicKey;constructor(t){super({...t,type:"RSA"}),this.publicKey=t.publicKey}},Cr=class extends Ir{type="Ed25519";publicKey;constructor(t){super({...t,type:"Ed25519"}),this.publicKey=t.publicKey}},Tr=class extends Ir{type="secp256k1";publicKey;constructor(t){super({...t,type:"secp256k1"}),this.publicKey=t.publicKey}},Wf=2336,is=class{type="url";multihash;publicKey;url;constructor(t){this.url=t.toString(),this.multihash=qt.digest(Z(this.url))}[yc](){return`PeerId(${this.url})`}[ws]=!0;toString(){return this.toCID().toString()}toMultihash(){return this.multihash}toCID(){return At.createV1(Wf,this.toMultihash())}toJSON(){return this.toString()}equals(t){return t==null?!1:(t instanceof Uint8Array&&(t=at(t)),t.toString()===this.toString())}};function Fi(r){if(r.type==="Ed25519")return new Cr({multihash:r.toCID().multihash,publicKey:r});if(r.type==="secp256k1")return new Tr({multihash:r.toCID().multihash,publicKey:r});if(r.type==="RSA")return new Nr({multihash:r.toCID().multihash,publicKey:r});throw new we}function wc(r){return Fi(r.publicKey)}function Lr(r){if(Yf(r))return new Nr({multihash:r});if(Jf(r))try{let t=bc(r);if(t.type==="Ed25519")return new Cr({multihash:r,publicKey:t});if(t.type==="secp256k1")return new Tr({multihash:r,publicKey:t})}catch{let e=at(r.digest);return new is(new URL(e))}throw new qr("Supplied PeerID Multihash is invalid")}function Jf(r){return r.code===qt.code}function Yf(r){return r.code===Ne.code}function Re(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}function os(r){let t=se(X.decode(`z${r}`));return Lr(t)}var Ur=class{map;constructor(t){if(this.map=new Map,t!=null)for(let[e,n]of t.entries())this.map.set(e.toString(),{key:e,value:n})}[Symbol.iterator](){return this.entries()}clear(){this.map.clear()}delete(t){return this.map.delete(t.toString())}entries(){return Re(this.map.entries(),t=>[t[1].key,t[1].value])}forEach(t){this.map.forEach((e,n)=>{t(e.value,e.key,this)})}get(t){return this.map.get(t.toString())?.value}has(t){return this.map.has(t.toString())}set(t,e){this.map.set(t.toString(),{key:t,value:e})}keys(){return Re(this.map.values(),t=>t.key)}values(){return Re(this.map.values(),t=>t.value)}get size(){return this.map.size}};var Rr=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 Re(this.set.entries(),t=>{let e=os(t[0]);return[e,e]})}forEach(t){this.set.forEach(e=>{let n=os(e);t(n,n,this)})}has(t){return this.set.has(t.toString())}values(){return Re(this.set.values(),t=>os(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 vc=Symbol.for("@achingbrain/uint8arraylist");function xc(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 as(r){return!!r?.[vc]}var ye=class r{bufs;length;[vc]=!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(as(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(as(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=xc(this.bufs,t);return e.buf[e.index]}set(t,e){let n=xc(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(as(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 Ue(n,s)}subarray(t,e){let{bufs:n,length:s}=this._subList(t,e);return n.length===1?n[0]:Ue(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],c=s,a=c+o.byteLength;if(s=a,t>=a)continue;let f=t>=c&&t<a,l=e>c&&e<=a;if(f&&l){if(t===c&&e===a){n.push(o);break}let u=t-c;n.push(o.subarray(u,u+(e-t)));break}if(f){if(t===0){n.push(o);continue}n.push(o.subarray(t-c));continue}if(l){if(e===a){n.push(o);break}n.push(o.subarray(0,e-c));break}n.push(o)}return{bufs:n,length:e-t}}indexOf(t,e=0){if(!as(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 c=o,a=this.byteLength-n.byteLength,f=n.byteLength-1,l;for(let u=e;u<=a;u+=l){l=0;for(let d=f;d>=0;d--){let x=this.get(u+d);if(n[d]!==x){l=Math.max(1,d-c[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=ht(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=Zt(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=Zt(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=Zt(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=ht(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=Zt(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=Zt(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=Zt(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=Zt(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=Zt(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(!It(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 cs(){let r={};return r.promise=new Promise((t,e)=>{r.resolve=t,r.reject=e}),r}var us=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}},rr=class{size;hwm;head;tail;constructor(t={}){this.hwm=t.splitLimit??16,this.head=new us(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 us(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 Ki=class extends Error{type;code;constructor(t,e){super(t??"The operation was aborted"),this.type="aborted",this.code=e??"ABORT_ERR"}};function nr(r={}){return Xf(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 Xf(r,t){t=t??{};let e=t.onEnd,n=new rr,s,i,o,c=cs(),a=async()=>{try{return n.isEmpty()?o?{done:!0}:await new Promise((h,y)=>{i=v=>{i=null,n.push(v);try{h(r(n))}catch(g){y(g)}return s}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{c.resolve(),c=cs()})}},f=h=>i!=null?i(h):(n.push(h),s),l=h=>(n=new rr,i!=null?i({error:h}):(n.push({error:h}),s)),u=h=>{if(o)return s;if(t?.objectMode!==!0&&h?.byteLength==null)throw new Error("objectMode was not true but tried to push non-Uint8Array value");return f({done:!1,value:h})},d=h=>o?s:(o=!0,h!=null?l(h):f({done:!0})),x=()=>(n=new rr,d(),{done:!0}),E=h=>(d(h),{done:!0});if(s={[Symbol.asyncIterator](){return this},next:a,return:x,throw:E,push:u,end:d,get readableLength(){return n.size},onEmpty:async h=>{let y=h?.signal;if(y?.throwIfAborted(),n.isEmpty())return;let v,g;y!=null&&(v=new Promise((S,U)=>{g=()=>{U(new Ki)},y.addEventListener("abort",g)}));try{await Promise.race([c.promise,v])}finally{g!=null&&y!=null&&y?.removeEventListener("abort",g)}}},e==null)return s;let b=s;return s={[Symbol.asyncIterator](){return this},next(){return b.next()},throw(h){return b.throw(h),e!=null&&(e(h),e=void 0),{done:!0}},return(){return b.return(),e!=null&&(e(),e=void 0),{done:!0}},push:u,end(h){return b.end(h),e!=null&&(e(h),e=void 0),s},get readableLength(){return b.readableLength},onEmpty:h=>b.onEmpty(h)},s}function Qf(r){return r[Symbol.asyncIterator]!=null}function th(...r){let t=[];for(let e of r)Qf(e)||t.push(e);return t.length===r.length?function*(){for(let e of t)yield*e}():async function*(){let e=nr({objectMode:!0});Promise.resolve().then(async()=>{try{await Promise.all(r.map(async n=>{for await(let s of n)e.push(s)})),e.end()}catch(n){e.end(n)}}),yield*e}()}var Ec=th;function _r(r,...t){if(r==null)throw new Error("Empty pipeline");if(qi(r)){let n=r;r=()=>n.source}else if(Sc(r)||Bc(r)){let n=r;r=()=>n}let e=[r,...t];if(e.length>1&&qi(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++)qi(e[n])&&(e[n]=rh(e[n]));return eh(...e)}var eh=(...r)=>{let t;for(;r.length>0;)t=r.shift()(t);return t},Bc=r=>r?.[Symbol.asyncIterator]!=null,Sc=r=>r?.[Symbol.iterator]!=null,qi=r=>r==null?!1:r.sink!=null&&r.source!=null,rh=r=>t=>{let e=r.sink(t);if(e?.then!=null){let n=nr({objectMode:!0});e.then(()=>{n.end()},o=>{n.end(o)});let s,i=r.source;if(Bc(i))s=async function*(){yield*i,n.end()};else if(Sc(i))s=function*(){yield*i,n.end()};else throw new Error("Unknown duplex source type - must be Iterable or AsyncIterable");return Ec(n,s())}return r.source};var zi=oo(kc(),1);var Hr=class extends Error{constructor(t){super(t),this.name="TimeoutError"}},Gi=class extends Error{constructor(t){super(),this.name="AbortError",this.message=t}},Ic=r=>globalThis.DOMException===void 0?new Gi(r):new DOMException(r),Nc=r=>{let t=r.reason===void 0?Ic("This operation was aborted."):r.reason;return t instanceof Error?t:Ic(t)};function ji(r,t){let{milliseconds:e,fallback:n,message:s,customTimers:i={setTimeout,clearTimeout}}=t,o,a=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:d}=t;d.aborted&&l(Nc(d)),d.addEventListener("abort",()=>{l(Nc(d))})}if(e===Number.POSITIVE_INFINITY){r.then(f,l);return}let u=new Hr;o=i.setTimeout.call(void 0,()=>{if(n){try{f(n())}catch(d){l(d)}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(d){l(d)}})()}).finally(()=>{a.clear()});return a.clear=()=>{i.clearTimeout.call(void 0,o),o=void 0},a}function Zi(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 Or=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=Zi(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 Mr=class extends zi.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:Or,...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.#y(),this.#b(),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.#b(),!0):!1}}return!1}#b(){this.#o||this.#r!==void 0||(this.#r=setInterval(()=>{this.#y()},this.#a),this.#p=Date.now()+this.#a)}#y(){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#S(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=ji(Promise.resolve(i),{milliseconds:e.timeout})),e.signal&&(i=Promise.race([i,this.#S(e.signal)]));let o=await i;n(o),this.emit("completed",o)}catch(i){if(i instanceof Hr&&!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}};function Cc(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 Tc(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function Lc(r,t){let e=Cc(r).return?.();Tc(e)&&e.catch(n=>{t.error("could not cause iterator to return",n)})}function fs(r){return r[Symbol.asyncIterator]!=null}var hs=r=>{let t=Rt(r),e=ht(t);return Go(r,e),hs.bytes=t,e};hs.bytes=0;function ds(r,t){t=t??{};let e=t.lengthEncoder??hs;function*n(s){let i=e(s.byteLength);i instanceof Uint8Array?yield i:yield*i,s instanceof Uint8Array?yield s:yield*s}return fs(r)?async function*(){for await(let s of r)yield*n(s)}():function*(){for(let s of r)yield*n(s)}()}ds.single=(r,t)=>{t=t??{};let e=t.lengthEncoder??hs;return new ye(e(r.byteLength),r)};var ps=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},gs=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},ms=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"},Dr=class extends Error{name="UnexpectedEOFError";code="ERR_UNEXPECTED_EOF"};var ih=8,oh=1024*1024*4,_e;(function(r){r[r.LENGTH=0]="LENGTH",r[r.DATA=1]="DATA"})(_e||(_e={}));var Wi=r=>{let t=jo(r);return Wi.bytes=Rt(t),t};Wi.bytes=0;function Pr(r,t){let e=new ye,n=_e.LENGTH,s=-1,i=t?.lengthDecoder??Wi,o=t?.maxLengthLength??ih,c=t?.maxDataLength??oh;function*a(){for(;e.byteLength>0;){if(n===_e.LENGTH)try{if(s=i(e),s<0)throw new ps("Invalid message length");if(s>c)throw new gs("Message length too long");let f=i.bytes;e.consume(f),t?.onLength!=null&&t.onLength(s),n=_e.DATA}catch(f){if(f instanceof RangeError){if(e.byteLength>o)throw new ms("Message length length too long");break}throw f}if(n===_e.DATA){if(e.byteLength<s)break;let f=e.sublist(0,s);e.consume(s),t?.onData!=null&&t.onData(f),yield f,n=_e.LENGTH}}}return fs(r)?async function*(){for await(let f of r)e.append(f),yield*a();if(e.byteLength>0)throw new Dr("Unexpected end of input")}():function*(){for(let f of r)e.append(f),yield*a();if(e.byteLength>0)throw new Dr("Unexpected end of input")}()}Pr.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 Pr(n,{...t??{},onLength:i=>{e=i}})};var bs=class extends He{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 ye(t):t)}attachInboundStream(t){let e=()=>{Lc(t.source,this.log)};return this._inboundAbortController.signal.addEventListener("abort",e,{once:!0}),this._rawInboundStream=t,this.inboundStream=_r(this._rawInboundStream,n=>Pr(n)),this.dispatchEvent(new CustomEvent("stream:inbound")),this.inboundStream}async attachOutboundStream(t){let e=this.outboundStream;return this.outboundStream!=null&&this.outboundStream.end(),this._rawOutboundStream=t,this.outboundStream=nr({onEnd:n=>{this._rawOutboundStream!=null&&this._rawOutboundStream.closeWrite().catch(s=>{this.log("error closing outbound stream",s)}),this._rawOutboundStream=void 0,this.outboundStream=void 0,n!=null&&this.dispatchEvent(new CustomEvent("close"))}}),_r(this.outboundStream,n=>ds(n),this._rawOutboundStream).catch(n=>{this.log.error(n)}),e==null&&this.dispatchEvent(new CustomEvent("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 CustomEvent("close")))}};function Uc(){return BigInt(`0x${at(ts(8),"base16")}`)}var Rc=(r,t)=>{let e=Z(t.toString(16).padStart(16,"0"),"base16"),n=ke(r),s=new Uint8Array(n.byteLength+e.length);return s.set(n,0),s.set(e,n.byteLength),s},_c=r=>Ne.encode(r);var Vc=function(r){return Array.isArray(r)?r:[r]},ch=async r=>{if(r.sequenceNumber==null||r.from==null||r.signature==null)return!1;let t=Lr(se(r.from));if(t.publicKey!=null)return!0;if(r.key!=null){let e=r.key;return Fi(Pi(e)).equals(t)}return!1},Hc=async r=>{if(r.from==null)throw new Y("RPC message was missing from");if(!await ch(r))return{type:"unsigned",topic:r.topic??"",data:r.data??new Uint8Array(0)};let t=Lr(se(r.from)),e=r.key??t.publicKey;if(e==null)throw new Y("RPC message was missing public key");return{type:"signed",from:t,topic:r.topic??"",sequenceNumber:lh(r.sequenceNumber??new Uint8Array(0)),data:r.data??new Uint8Array(0),signature:r.signature??new Uint8Array(0),key:e instanceof Uint8Array?Pi(e):e}},Fr=r=>r.type==="signed"?{from:r.from.toMultihash().bytes,data:r.data,sequenceNumber:uh(r.sequenceNumber),topic:r.topic,signature:r.signature,key:r.key?ke(r.key):void 0}:{data:r.data,topic:r.topic},uh=r=>{let t=r.toString(16);return t.length%2!==0&&(t=`0${t}`),Z(t,"base16")},lh=r=>BigInt(`0x${at(r,"base16")}`);var Oc=Z("libp2p-pubsub:");async function Mc(r,t,e){let n={type:"signed",topic:t.topic,data:t.data,sequenceNumber:t.sequenceNumber,from:wc(r)},s=Ue([Oc,e(Fr(n)).subarray()]);return n.signature=await r.sign(s),n.key=r.publicKey,n}async function Dc(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=Ue([Oc,t({...Fr(r),signature:void 0,key:void 0}).subarray()]);return fh(r).verify(e,r.signature)}function fh(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)return r.key;if(r.from.publicKey!=null)return r.from.publicKey;throw new Error("Could not get the public key from the originator id")}var Ji=class extends He{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:c=10,maxInboundStreams:a=1,maxOutboundStreams:f=1}=e;this.log=t.logger.forComponent("libp2p:pubsub"),this.components=t,this.multicodecs=Vc(n),this.enabled=e.enabled!==!1,this.started=!1,this.topics=new Map,this.subscriptions=new Set,this.peers=new Ur,this.globalSignaturePolicy=s==="StrictNoSign"?"StrictNoSign":"StrictSign",this.canRelayMessage=i,this.emitSelf=o,this.topicValidators=new Map,this.queue=new Mr({concurrency:c}),this.maxInboundStreams=a,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(c=>{this.log(c)})}_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){this.log("connection ended %p",t),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 bs(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 _r(e,async s=>{for await(let i of s){let o=this.decodeRpc(i),c=[];for(let a of o.messages??[]){if(a.from==null||a.data==null||a.topic==null){this.log("message from %p was missing from, data or topic fields, dropping",t);continue}c.push({from:a.from,data:a.data,topic:a.topic,sequenceNumber:a.sequenceNumber??void 0,signature:a.signature??void 0,key:a.key??void 0})}this.processRpc(t,n,{subscriptions:(o.subscriptions??[]).map(a=>({subscribe:!!a.subscribe,topic:a.topic??""})),messages:c}).catch(a=>{this.log(a)})}})}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 CustomEvent("subscription-change",{detail:{peerId:e.id,subscriptions:s.map(({topic:o,subscribe:c})=>({topic:`${o??""}`,subscribe:!!c}))}}))),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 c=await Hc(o);await this.processMessage(t,c)}catch(c){this.log.error(c)}})).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 Rr,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 CustomEvent("message",{detail:e})),await this.publishMessage(t,e)}}getMsgId(t){switch(this.globalSignaturePolicy){case"StrictSign":if(t.type!=="signed")throw new Y('Message type should be "signed" when signature policy is StrictSign but it was not');if(t.sequenceNumber==null)throw new Y("Need seqno when signature policy is StrictSign but it was missing");if(t.key==null)throw new Y("Need key when signature policy is StrictSign but it was missing");return Rc(t.key,t.sequenceNumber);case"StrictNoSign":return _c(t.data);default:throw new Y("Cannot get message id: 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(Fr)})}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 Y('Message type should be "unsigned" when signature policy is StrictNoSign but it was not');if(e.signature!=null)throw new Y("StrictNoSigning: signature should not be present");if(e.key!=null)throw new Y("StrictNoSigning: key should not be present");if(e.sequenceNumber!=null)throw new Y("StrictNoSigning: seqno should not be present");break;case"StrictSign":if(e.type!=="signed")throw new Y('Message type should be "signed" when signature policy is StrictSign but it was not');if(e.signature==null)throw new Y("StrictSigning: Signing required and no signature was present");if(e.sequenceNumber==null)throw new Y("StrictSigning: Signing required and no sequenceNumber was present");if(!await Dc(e,this.encodeMessage.bind(this)))throw new Y("StrictSigning: Invalid message signature");break;default:throw new Y("Cannot validate message: unhandled signature policy")}let s=this.topicValidators.get(e.topic);if(s!=null){let i=await s(t,e);if(i===or.Reject||i===or.Ignore)throw new Y("Message validation failed")}}async buildMessage(t){switch(this.globalSignaturePolicy){case"StrictSign":return Mc(this.components.privateKey,t,this.encodeMessage.bind(this));case"StrictNoSign":return Promise.resolve({type:"unsigned",...t});default:throw new Y("Cannot build message: unhandled signature policy")}}getSubscribers(t){if(!this.started)throw new $r("not started yet");if(t==null)throw new rt("Topic is required");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:Uc()};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 CustomEvent("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())}};return Qc(hh);})();
8
7
  /*! Bundled license information:
9
8
 
10
9
  pvtsutils/build/index.js: