@libp2p/pubsub 9.0.26-3c8dd5bbf → 9.0.26-737b3ea5b
Sign up to get free protection for your applications and to get access to all the features.
- package/dist/index.min.js +3 -3
- package/package.json +9 -9
package/dist/index.min.js
CHANGED
@@ -1,10 +1,10 @@
|
|
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 Bu=Object.create;var cn=Object.defineProperty;var Au=Object.getOwnPropertyDescriptor;var Su=Object.getOwnPropertyNames;var Iu=Object.getPrototypeOf,ku=Object.prototype.hasOwnProperty;var Ao=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),rt=(r,t)=>{for(var e in t)cn(r,e,{get:t[e],enumerable:!0})},So=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of Su(t))!ku.call(r,s)&&s!==e&&cn(r,s,{get:()=>t[s],enumerable:!(n=Au(t,s))||n.enumerable});return r};var Io=(r,t,e)=>(e=r!=null?Bu(Iu(r)):{},So(t||!r||!r.__esModule?cn(e,"default",{value:r,enumerable:!0}):e,r)),Ru=r=>So(cn({},"__esModule",{value:!0}),r);var qa=Ao(br=>{"use strict";var dh="[object ArrayBuffer]",oe=class r{static isArrayBuffer(t){return Object.prototype.toString.call(t)===dh}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}},$i="string",ph=/^[0-9a-f]+$/i,gh=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,yh=/^[a-zA-Z0-9-_]+$/,Tn=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=oe.toUint8Array(t),n="";for(let i=0;i<e.length;i++)n+=String.fromCharCode(e[i]);return decodeURIComponent(escape(n))}},_t=class{static toString(t,e=!1){let n=oe.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}},Cn=class r{static isHex(t){return typeof t===$i&&ph.test(t)}static isBase64(t){return typeof t===$i&&gh.test(t)}static isBase64Url(t){return typeof t===$i&&yh.test(t)}static ToString(t,e="utf8"){let n=oe.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 _t.toString(n,!0);case"utf16":case"utf16be":return _t.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 _t.fromString(t,!0);case"utf16":case"utf16be":return _t.fromString(t);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToBase64(t){let e=oe.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 Tn.fromString(t);case"utf16":case"utf16be":return _t.fromString(t);case"utf16le":case"usc2":return _t.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 Tn.toString(t);case"utf16":case"utf16be":return _t.toString(t);case"utf16le":case"usc2":return _t.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=oe.toUint8Array(t),n="";for(let s=0;s<e.length;s++)n+=String.fromCharCode(e[s]);return n}static ToHex(t){let e=oe.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 _t.toString(t,e)}static FromUtf16String(t,e=!1){return _t.fromString(t,e)}static Base64Padding(t){let e=4-t.length%4;if(e<4)for(let n=0;n<e;n++)t+="=";return t}static formatString(t){return t?.replace(/[\n\r\t ]/g,"")||""}};Cn.DEFAULT_UTF8_ENCODING="utf8";function mh(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 bh(...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 wh(r,t){if(!(r&&t)||r.byteLength!==t.byteLength)return!1;let e=new Uint8Array(r),n=new Uint8Array(t);for(let s=0;s<r.byteLength;s++)if(e[s]!==n[s])return!1;return!0}br.BufferSourceConverter=oe;br.Convert=Cn;br.assign=mh;br.combine=bh;br.isEqual=wh});var ru=Ao((dm,uo)=>{"use strict";var cd=Object.prototype.hasOwnProperty,Bt="~";function Qr(){}Object.create&&(Qr.prototype=Object.create(null),new Qr().__proto__||(Bt=!1));function ud(r,t,e){this.fn=r,this.context=t,this.once=e||!1}function eu(r,t,e,n,s){if(typeof e!="function")throw new TypeError("The listener must be a function");var i=new ud(e,n||r,s),o=Bt?Bt+t:t;return r._events[o]?r._events[o].fn?r._events[o]=[r._events[o],i]:r._events[o].push(i):(r._events[o]=i,r._eventsCount++),r}function Bs(r,t){--r._eventsCount===0?r._events=new Qr:delete r._events[t]}function wt(){this._events=new Qr,this._eventsCount=0}wt.prototype.eventNames=function(){var t=[],e,n;if(this._eventsCount===0)return t;for(n in e=this._events)cd.call(e,n)&&t.push(Bt?n.slice(1):n);return Object.getOwnPropertySymbols?t.concat(Object.getOwnPropertySymbols(e)):t};wt.prototype.listeners=function(t){var e=Bt?Bt+t:t,n=this._events[e];if(!n)return[];if(n.fn)return[n.fn];for(var s=0,i=n.length,o=new Array(i);s<i;s++)o[s]=n[s].fn;return o};wt.prototype.listenerCount=function(t){var e=Bt?Bt+t:t,n=this._events[e];return n?n.fn?1:n.length:0};wt.prototype.emit=function(t,e,n,s,i,o){var c=Bt?Bt+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 p=a.length,x;for(u=0;u<p;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};wt.prototype.on=function(t,e,n){return eu(this,t,e,n,!1)};wt.prototype.once=function(t,e,n){return eu(this,t,e,n,!0)};wt.prototype.removeListener=function(t,e,n,s){var i=Bt?Bt+t:t;if(!this._events[i])return this;if(!e)return Bs(this,i),this;var o=this._events[i];if(o.fn)o.fn===e&&(!s||o.once)&&(!n||o.context===n)&&Bs(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:Bs(this,i)}return this};wt.prototype.removeAllListeners=function(t){var e;return t?(e=Bt?Bt+t:t,this._events[e]&&Bs(this,e)):(this._events=new Qr,this._eventsCount=0),this};wt.prototype.off=wt.prototype.removeListener;wt.prototype.addListener=wt.prototype.on;wt.prefixed=Bt;wt.EventEmitter=wt;typeof uo<"u"&&(uo.exports=wt)});var md={};rt(md,{PubSubBaseProtocol:()=>yo});var Cs=Symbol.for("@libp2p/peer-id");var Sr;(function(r){r.Accept="accept",r.Ignore="ignore",r.Reject="reject"})(Sr||(Sr={}));var B=class extends Error{code;props;constructor(t,e,n){super(t),this.code=e,this.name=n?.name??"CodeError",this.props=n??{}}};var ko=(r,...t)=>{try{[...t]}catch{}};var ze=class extends EventTarget{#t=new Map;constructor(){super(),ko(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 Os={};rt(Os,{base58btc:()=>xt,base58flickr:()=>Uu});var Sd=new Uint8Array(0);function Ro(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 Zt(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 No(r){return new TextEncoder().encode(r)}function _o(r){return new TextDecoder().decode(r)}function Nu(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(y){if(y instanceof Uint8Array||(ArrayBuffer.isView(y)?y=new Uint8Array(y.buffer,y.byteOffset,y.byteLength):Array.isArray(y)&&(y=Uint8Array.from(y))),!(y instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(y.length===0)return"";for(var h=0,d=0,E=0,b=y.length;E!==b&&y[E]===0;)E++,h++;for(var w=(b-E)*l+1>>>0,_=new Uint8Array(w);E!==b;){for(var k=y[E],I=0,T=w-1;(k!==0||I<d)&&T!==-1;T--,I++)k+=256*_[T]>>>0,_[T]=k%c>>>0,k=k/c>>>0;if(k!==0)throw new Error("Non-zero carry");d=I,E++}for(var R=w-d;R!==w&&_[R]===0;)R++;for(var $=a.repeat(h);R<w;++R)$+=r.charAt(_[R]);return $}function p(y){if(typeof y!="string")throw new TypeError("Expected String");if(y.length===0)return new Uint8Array;var h=0;if(y[h]!==" "){for(var d=0,E=0;y[h]===a;)d++,h++;for(var b=(y.length-h)*f+1>>>0,w=new Uint8Array(b);y[h];){var _=e[y.charCodeAt(h)];if(_===255)return;for(var k=0,I=b-1;(_!==0||k<E)&&I!==-1;I--,k++)_+=c*w[I]>>>0,w[I]=_%256>>>0,_=_/256>>>0;if(_!==0)throw new Error("Non-zero carry");E=k,h++}if(y[h]!==" "){for(var T=b-E;T!==b&&w[T]===0;)T++;for(var R=new Uint8Array(d+(b-T)),$=d;T!==b;)R[$++]=w[T++];return R}}}function x(y){var h=p(y);if(h)return h;throw new Error(`Non-${t} character`)}return{encode:u,decodeUnsafe:p,decode:x}}var _u=Nu,Tu=_u,Co=Tu;var Ls=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")}},Us=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 Lo(this,t)}},Ds=class{decoders;constructor(t){this.decoders=t}or(t){return Lo(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 Lo(r,t){return new Ds({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var Ps=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 Ls(t,e,n),this.decoder=new Us(t,e,s)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function je({name:r,prefix:t,encode:e,decode:n}){return new Ps(r,t,e,n)}function de({name:r,prefix:t,alphabet:e}){let{encode:n,decode:s}=Co(e,r);return je({prefix:t,name:r,encode:n,decode:i=>Zt(s(i))})}function Cu(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 Lu(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 je({prefix:t,name:r,encode(s){return Lu(s,n,e)},decode(s){return Cu(s,n,e,r)}})}var xt=de({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),Uu=de({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Vs={};rt(Vs,{base10:()=>Du});var Du=de({prefix:"9",name:"base10",alphabet:"0123456789"});var Hs={};rt(Hs,{base16:()=>Pu,base16upper:()=>Ou});var Pu=Q({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Ou=Q({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Ms={};rt(Ms,{base2:()=>Vu});var Vu=Q({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Ks={};rt(Ks,{base256emoji:()=>qu});var Uo=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}"),Hu=Uo.reduce((r,t,e)=>(r[e]=t,r),[]),Mu=Uo.reduce((r,t,e)=>(r[t.codePointAt(0)]=e,r),[]);function Ku(r){return r.reduce((t,e)=>(t+=Hu[e],t),"")}function Fu(r){let t=[];for(let e of r){let n=Mu[e.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${e}`);t.push(n)}return new Uint8Array(t)}var qu=je({prefix:"\u{1F680}",name:"base256emoji",encode:Ku,decode:Fu});var Fs={};rt(Fs,{base32:()=>Ye,base32hex:()=>ju,base32hexpad:()=>Wu,base32hexpadupper:()=>Zu,base32hexupper:()=>Yu,base32pad:()=>Gu,base32padupper:()=>zu,base32upper:()=>$u,base32z:()=>Ju});var Ye=Q({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),$u=Q({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Gu=Q({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),zu=Q({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),ju=Q({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),Yu=Q({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),Wu=Q({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),Zu=Q({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),Ju=Q({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var qs={};rt(qs,{base36:()=>Xu,base36upper:()=>Qu});var Xu=de({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),Qu=de({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var $s={};rt($s,{base64:()=>Ir,base64pad:()=>tl,base64url:()=>el,base64urlpad:()=>rl});var Ir=Q({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),tl=Q({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),el=Q({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),rl=Q({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Gs={};rt(Gs,{base8:()=>nl});var nl=Q({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var zs={};rt(zs,{identity:()=>sl});var sl=je({prefix:"\0",name:"identity",encode:r=>_o(r),decode:r=>No(r)});var Kd=new TextEncoder,Fd=new TextDecoder;var Ys={};rt(Ys,{identity:()=>Jt});var al=Oo,Do=128,cl=127,ul=~cl,ll=Math.pow(2,31);function Oo(r,t,e){t=t||[],e=e||0;for(var n=e;r>=ll;)t[e++]=r&255|Do,r/=128;for(;r&ul;)t[e++]=r&255|Do,r>>>=7;return t[e]=r|0,Oo.bytes=e-n+1,t}var fl=js,hl=128,Po=127;function js(r,n){var e=0,n=n||0,s=0,i=n,o,c=r.length;do{if(i>=c)throw js.bytes=0,new RangeError("Could not decode varint");o=r[i++],e+=s<28?(o&Po)<<s:(o&Po)*Math.pow(2,s),s+=7}while(o>=hl);return js.bytes=i-n,e}var dl=Math.pow(2,7),pl=Math.pow(2,14),gl=Math.pow(2,21),yl=Math.pow(2,28),ml=Math.pow(2,35),bl=Math.pow(2,42),wl=Math.pow(2,49),xl=Math.pow(2,56),El=Math.pow(2,63),vl=function(r){return r<dl?1:r<pl?2:r<gl?3:r<yl?4:r<ml?5:r<bl?6:r<wl?7:r<xl?8:r<El?9:10},Bl={encode:al,decode:fl,encodingLength:vl},Al=Bl,kr=Al;function Rr(r,t=0){return[kr.decode(r,t),kr.decode.bytes]}function We(r,t,e=0){return kr.encode(r,t,e),t}function Ze(r){return kr.encodingLength(r)}function $t(r,t){let e=t.byteLength,n=Ze(r),s=n+Ze(e),i=new Uint8Array(s+e);return We(r,i,0),We(e,i,n),i.set(t,s),new Je(r,e,t,i)}function Nr(r){let t=Zt(r),[e,n]=Rr(t),[s,i]=Rr(t.subarray(n)),o=t.subarray(n+i);if(o.byteLength!==s)throw new Error("Incorrect length");return new Je(e,s,o,t)}function Vo(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&Ro(r.bytes,e.bytes)}}var Je=class{code;size;digest;bytes;constructor(t,e,n,s){this.code=t,this.size=e,this.digest=n,this.bytes=s}};var Ho=0,Sl="identity",Mo=Zt;function Il(r){return $t(Ho,Mo(r))}var Jt={code:Ho,name:Sl,encode:Mo,digest:Il};var Js={};rt(Js,{sha256:()=>ot,sha512:()=>kl});function Zs({name:r,code:t,encode:e}){return new Ws(r,t,e)}var Ws=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 Fo(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var ot=Zs({name:"sha2-256",code:18,encode:Fo("SHA-256")}),kl=Zs({name:"sha2-512",code:19,encode:Fo("SHA-512")});function qo(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return Nl(e,Xs(r),t??xt.encoder);default:return _l(e,Xs(r),t??Ye.encoder)}}var $o=new WeakMap;function Xs(r){let t=$o.get(r);if(t==null){let e=new Map;return $o.set(r,e),e}return t}var pe=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!==_r)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==Tl)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&&Vo(t.multihash,n.multihash)}toString(t){return qo(this,t)}toJSON(){return{"/":qo(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??Go(n,s,i.bytes))}else if(e[Cl]===!0){let{version:n,multihash:s,code:i}=e,o=Nr(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!==_r)throw new Error(`Version 0 CID must use dag-pb (code: ${_r}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let s=Go(t,e,n.bytes);return new r(t,e,n,s)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,_r,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=Zt(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 Je(e.multihashCode,e.digestSize,i,s);return[e.version===0?r.createV0(o):r.createV1(e.codec,o),t.subarray(e.size)]}static inspectBytes(t){let e=0,n=()=>{let[u,p]=Rr(t.subarray(e));return e+=p,u},s=n(),i=_r;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]=Rl(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 Xs(i).set(n,t),i}};function Rl(r,t){switch(r[0]){case"Q":{let e=t??xt;return[xt.prefix,e.decode(`${xt.prefix}${r}`)]}case xt.prefix:{let e=t??xt;return[xt.prefix,e.decode(r)]}case Ye.prefix:{let e=t??Ye;return[Ye.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 Nl(r,t,e){let{prefix:n}=e;if(n!==xt.prefix)throw Error(`Cannot string encode V0 in ${e.name} encoding`);let s=t.get(n);if(s==null){let i=e.encode(r).slice(1);return t.set(n,i),i}else return s}function _l(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 _r=112,Tl=18;function Go(r,t,e){let n=Ze(r),s=n+Ze(t),i=new Uint8Array(s+e.byteLength);return We(r,i,0),We(t,i,n),i.set(e,s),i}var Cl=Symbol.for("@ipld/js-cid/CID");var Qe={...zs,...Ms,...Gs,...Vs,...Hs,...Fs,...qs,...Os,...$s,...Ks},u0={...Js,...Ys};function pt(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function Xt(r=0){return new Uint8Array(r)}function gt(r=0){return new Uint8Array(r)}function jo(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var zo=jo("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),Qs=jo("ascii","a",r=>{let t="a";for(let e=0;e<r.length;e++)t+=String.fromCharCode(r[e]);return t},r=>{r=r.substring(1);let t=gt(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),Ll={utf8:zo,"utf-8":zo,hex:Qe.base16,latin1:Qs,ascii:Qs,binary:Qs,...Qe},ln=Ll;function F(r,t="utf8"){let e=ln[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function z(r,t="utf8"){let e=ln[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}var Wo=Symbol.for("nodejs.util.inspect.custom"),Yo=Object.values(Qe).map(r=>r.decoder).reduce((r,t)=>r.or(t),Qe.identity.decoder),Zo=114,ri=36,ni=37,Tr=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()})`}[Cs]=!0;toString(){return this.string==null&&(this.string=xt.encode(this.multihash.bytes).slice(1)),this.string}toCID(){return pe.createV1(Zo,this.multihash)}toBytes(){return this.multihash.bytes}toJSON(){return this.toString()}equals(t){if(t==null)return!1;if(t instanceof Uint8Array)return pt(this.multihash.bytes,t);if(typeof t=="string")return Qt(t).equals(this);if(t?.multihash?.bytes!=null)return pt(this.multihash.bytes,t.multihash.bytes);throw new Error("not valid Id")}[Wo](){return`PeerId(${this.toString()})`}},tr=class extends Tr{type="RSA";publicKey;constructor(t){super({...t,type:"RSA"}),this.publicKey=t.publicKey}},er=class extends Tr{type="Ed25519";publicKey;constructor(t){super({...t,type:"Ed25519"}),this.publicKey=t.multihash.digest}},rr=class extends Tr{type="secp256k1";publicKey;constructor(t){super({...t,type:"secp256k1"}),this.publicKey=t.multihash.digest}},ti=2336,ei=class{type="url";multihash;privateKey;publicKey;url;constructor(t){this.url=t.toString(),this.multihash=Jt.digest(F(this.url))}[Wo](){return`PeerId(${this.url})`}[Cs]=!0;toString(){return this.toCID().toString()}toCID(){return pe.createV1(ti,this.multihash)}toBytes(){return this.toCID().bytes}equals(t){return t==null?!1:(t instanceof Uint8Array&&(t=z(t)),t.toString()===this.toString())}};function Qt(r,t){if(t=t??Yo,r.charAt(0)==="1"||r.charAt(0)==="Q"){let e=Nr(xt.decode(`z${r}`));return r.startsWith("12D")?new er({multihash:e}):r.startsWith("16U")?new rr({multihash:e}):new tr({multihash:e})}return Cr(Yo.decode(r))}function Cr(r){try{let t=Nr(r);if(t.code===Jt.code){if(t.digest.length===ri)return new er({multihash:t});if(t.digest.length===ni)return new rr({multihash:t})}if(t.code===ot.code)return new tr({multihash:t})}catch{return Ul(pe.decode(r))}throw new Error("Supplied PeerID CID is invalid")}function Ul(r){if(r?.multihash==null||r.version==null||r.version===1&&r.code!==Zo&&r.code!==ti)throw new Error("Supplied PeerID CID is invalid");if(r.code===ti){let e=z(r.multihash.digest);return new ei(new URL(e))}let t=r.multihash;if(t.code===ot.code)return new tr({multihash:r.multihash});if(t.code===Jt.code){if(t.digest.length===ri)return new er({multihash:r.multihash});if(t.digest.length===ni)return new rr({multihash:r.multihash})}throw new Error("Supplied PeerID CID is invalid")}async function fn(r,t){return r.length===ri?new er({multihash:$t(Jt.code,r),privateKey:t}):r.length===ni?new rr({multihash:$t(Jt.code,r),privateKey:t}):new tr({multihash:await ot.digest(r),publicKey:r,privateKey:t})}function nr(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 Lr=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 nr(this.map.entries(),t=>[Qt(t[0]),t[1]])}forEach(t){this.map.forEach((e,n)=>{t(e,Qt(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 nr(this.map.keys(),t=>Qt(t))}values(){return this.map.values()}get size(){return this.map.size}};var Ur=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 nr(this.set.entries(),t=>{let e=Qt(t[0]);return[e,e]})}forEach(t){this.set.forEach(e=>{let n=Qt(e);t(n,n,this)})}has(t){return this.set.has(t.toString())}values(){return nr(this.set.values(),t=>Qt(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 Y={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 Jo={SHA1:20,SHA256:32,SHA512:64};var Dl={SHA1:"SHA-1",SHA256:"SHA-256",SHA512:"SHA-512"},Pl=async(r,t)=>{let e=await Y.get().subtle.sign({name:"HMAC"},r,t);return new Uint8Array(e,0,e.byteLength)};async function Xo(r,t){let e=Dl[r],n=await Y.get().subtle.importKey("raw",t,{name:"HMAC",hash:{name:e}},!1,["sign"]);return{async digest(s){return Pl(n,s)},length:Jo[r]}}var Jr={};rt(Jr,{Ed25519PrivateKey:()=>ie,Ed25519PublicKey:()=>Ve,MAX_RSA_KEY_SIZE:()=>Ke,RsaPrivateKey:()=>Ie,RsaPublicKey:()=>Me,Secp256k1PrivateKey:()=>$e,Secp256k1PublicKey:()=>qe,generateEphemeralKeyPair:()=>Ha,generateKeyPair:()=>Jh,generateKeyPairFromSeed:()=>Xh,importKey:()=>rd,keyStretcher:()=>Fa,keysPBM:()=>yr,marshalPrivateKey:()=>ed,marshalPublicKey:()=>td,supportedKeys:()=>he,unmarshalPrivateKey:()=>Wc,unmarshalPublicKey:()=>Qh});var Ki={};rt(Ki,{Ed25519PrivateKey:()=>ie,Ed25519PublicKey:()=>Ve,generateKeyPair:()=>ah,generateKeyPairFromSeed:()=>Mi,unmarshalEd25519PrivateKey:()=>ih,unmarshalEd25519PublicKey:()=>oh});function Et(r,t){t==null&&(t=r.reduce((s,i)=>s+i.length,0));let e=gt(t),n=0;for(let s of r)e.set(s,n),n+=s.length;return e}function si(r,t){let e=F(r,"base64urlpad");if(t!=null){if(e.length>t)throw new Error("byte array longer than desired length");e=Et([new Uint8Array(t-e.length),e])}return e}function Nt(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function sr(r){if(!Number.isSafeInteger(r)||r<0)throw new Error(`positive integer expected, not ${r}`)}function Vl(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function ir(r,...t){if(!Vl(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 hn(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");sr(r.outputLen),sr(r.blockLen)}function or(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 Qo(r,t){ir(r);let e=t.outputLen;if(r.length<e)throw new Error(`digestInto() expects output buffer of length at least ${e}`)}var dn=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;var cr=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),Lt=(r,t)=>r<<32-t|r>>>t;var Q0=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;var Hl=async()=>{};async function ta(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 Hl(),n+=i)}}function ea(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function ge(r){return typeof r=="string"&&(r=ea(r)),ir(r),r}function ii(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];ir(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 ar=class{clone(){return this._cloneInto()}},Ml={}.toString;function ra(r,t){if(t!==void 0&&Ml.call(t)!=="[object Object]")throw new Error("Options should be object or undefined");return Object.assign(r,t)}function pn(r){let t=n=>r().update(ge(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function ur(r=32){if(dn&&typeof dn.getRandomValues=="function")return dn.getRandomValues(new Uint8Array(r));throw new Error("crypto.getRandomValues must be defined")}function Kl(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 na=(r,t,e)=>r&t^~r&e,sa=(r,t,e)=>r&t^r&e^t&e,lr=class extends ar{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=cr(this.buffer)}update(t){or(this);let{view:e,buffer:n,blockLen:s}=this;t=ge(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=cr(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){or(this),Qo(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;Kl(n,s-8,BigInt(this.length*8),i),this.process(n,0);let c=cr(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 gn=BigInt(4294967295),oi=BigInt(32);function ia(r,t=!1){return t?{h:Number(r&gn),l:Number(r>>oi&gn)}:{h:Number(r>>oi&gn)|0,l:Number(r&gn)|0}}function Fl(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}=ia(r[s],t);[e[s],n[s]]=[i,o]}return[e,n]}var ql=(r,t)=>BigInt(r>>>0)<<oi|BigInt(t>>>0),$l=(r,t,e)=>r>>>e,Gl=(r,t,e)=>r<<32-e|t>>>e,zl=(r,t,e)=>r>>>e|t<<32-e,jl=(r,t,e)=>r<<32-e|t>>>e,Yl=(r,t,e)=>r<<64-e|t>>>e-32,Wl=(r,t,e)=>r>>>e-32|t<<64-e,Zl=(r,t)=>t,Jl=(r,t)=>r,Xl=(r,t,e)=>r<<e|t>>>32-e,Ql=(r,t,e)=>t<<e|r>>>32-e,tf=(r,t,e)=>t<<e-32|r>>>64-e,ef=(r,t,e)=>r<<e-32|t>>>64-e;function rf(r,t,e,n){let s=(t>>>0)+(n>>>0);return{h:r+e+(s/2**32|0)|0,l:s|0}}var nf=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),sf=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,of=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),af=(r,t,e,n,s)=>t+e+n+s+(r/2**32|0)|0,cf=(r,t,e,n,s)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(s>>>0),uf=(r,t,e,n,s,i)=>t+e+n+s+i+(r/2**32|0)|0;var lf={fromBig:ia,split:Fl,toBig:ql,shrSH:$l,shrSL:Gl,rotrSH:zl,rotrSL:jl,rotrBH:Yl,rotrBL:Wl,rotr32H:Zl,rotr32L:Jl,rotlSH:Xl,rotlSL:Ql,rotlBH:tf,rotlBL:ef,add:rf,add3L:nf,add3H:sf,add4L:of,add4H:af,add5H:uf,add5L:cf},D=lf;var[ff,hf]=D.split(["0x428a2f98d728ae22","0x7137449123ef65cd","0xb5c0fbcfec4d3b2f","0xe9b5dba58189dbbc","0x3956c25bf348b538","0x59f111f1b605d019","0x923f82a4af194f9b","0xab1c5ed5da6d8118","0xd807aa98a3030242","0x12835b0145706fbe","0x243185be4ee4b28c","0x550c7dc3d5ffb4e2","0x72be5d74f27b896f","0x80deb1fe3b1696b1","0x9bdc06a725c71235","0xc19bf174cf692694","0xe49b69c19ef14ad2","0xefbe4786384f25e3","0x0fc19dc68b8cd5b5","0x240ca1cc77ac9c65","0x2de92c6f592b0275","0x4a7484aa6ea6e483","0x5cb0a9dcbd41fbd4","0x76f988da831153b5","0x983e5152ee66dfab","0xa831c66d2db43210","0xb00327c898fb213f","0xbf597fc7beef0ee4","0xc6e00bf33da88fc2","0xd5a79147930aa725","0x06ca6351e003826f","0x142929670a0e6e70","0x27b70a8546d22ffc","0x2e1b21385c26c926","0x4d2c6dfc5ac42aed","0x53380d139d95b3df","0x650a73548baf63de","0x766a0abb3c77b2a8","0x81c2c92e47edaee6","0x92722c851482353b","0xa2bfe8a14cf10364","0xa81a664bbc423001","0xc24b8b70d0f89791","0xc76c51a30654be30","0xd192e819d6ef5218","0xd69906245565a910","0xf40e35855771202a","0x106aa07032bbd1b8","0x19a4c116b8d2d0c8","0x1e376c085141ab53","0x2748774cdf8eeb99","0x34b0bcb5e19b48a8","0x391c0cb3c5c95a63","0x4ed8aa4ae3418acb","0x5b9cca4f7763e373","0x682e6ff3d6b2b8a3","0x748f82ee5defb2fc","0x78a5636f43172f60","0x84c87814a1f0ab72","0x8cc702081a6439ec","0x90befffa23631e28","0xa4506cebde82bde9","0xbef9a3f7b2c67915","0xc67178f2e372532b","0xca273eceea26619c","0xd186b8c721c0c207","0xeada7dd6cde0eb1e","0xf57d4f7fee6ed178","0x06f067aa72176fba","0x0a637dc5a2c898a6","0x113f9804bef90dae","0x1b710b35131c471b","0x28db77f523047d84","0x32caab7b40c72493","0x3c9ebe0a15c9bebc","0x431d67c49c100d4c","0x4cc5d4becb3e42b6","0x597f299cfc657e2a","0x5fcb6fab3ad6faec","0x6c44198c4a475817"].map(r=>BigInt(r))),ye=new Uint32Array(80),me=new Uint32Array(80),ai=class extends lr{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:p,Gh:x,Gl:y,Hh:h,Hl:d}=this;return[t,e,n,s,i,o,c,a,f,l,u,p,x,y,h,d]}set(t,e,n,s,i,o,c,a,f,l,u,p,x,y,h,d){this.Ah=t|0,this.Al=e|0,this.Bh=n|0,this.Bl=s|0,this.Ch=i|0,this.Cl=o|0,this.Dh=c|0,this.Dl=a|0,this.Eh=f|0,this.El=l|0,this.Fh=u|0,this.Fl=p|0,this.Gh=x|0,this.Gl=y|0,this.Hh=h|0,this.Hl=d|0}process(t,e){for(let w=0;w<16;w++,e+=4)ye[w]=t.getUint32(e),me[w]=t.getUint32(e+=4);for(let w=16;w<80;w++){let _=ye[w-15]|0,k=me[w-15]|0,I=D.rotrSH(_,k,1)^D.rotrSH(_,k,8)^D.shrSH(_,k,7),T=D.rotrSL(_,k,1)^D.rotrSL(_,k,8)^D.shrSL(_,k,7),R=ye[w-2]|0,$=me[w-2]|0,V=D.rotrSH(R,$,19)^D.rotrBH(R,$,61)^D.shrSH(R,$,6),H=D.rotrSL(R,$,19)^D.rotrBL(R,$,61)^D.shrSL(R,$,6),et=D.add4L(T,H,me[w-7],me[w-16]),st=D.add4H(et,I,V,ye[w-7],ye[w-16]);ye[w]=st|0,me[w]=et|0}let{Ah:n,Al:s,Bh:i,Bl:o,Ch:c,Cl:a,Dh:f,Dl:l,Eh:u,El:p,Fh:x,Fl:y,Gh:h,Gl:d,Hh:E,Hl:b}=this;for(let w=0;w<80;w++){let _=D.rotrSH(u,p,14)^D.rotrSH(u,p,18)^D.rotrBH(u,p,41),k=D.rotrSL(u,p,14)^D.rotrSL(u,p,18)^D.rotrBL(u,p,41),I=u&x^~u&h,T=p&y^~p&d,R=D.add5L(b,k,T,hf[w],me[w]),$=D.add5H(R,E,_,I,ff[w],ye[w]),V=R|0,H=D.rotrSH(n,s,28)^D.rotrBH(n,s,34)^D.rotrBH(n,s,39),et=D.rotrSL(n,s,28)^D.rotrBL(n,s,34)^D.rotrBL(n,s,39),st=n&i^n&c^i&c,N=s&o^s&a^o&a;E=h|0,b=d|0,h=x|0,d=y|0,x=u|0,y=p|0,{h:u,l:p}=D.add(f|0,l|0,$|0,V|0),f=c|0,l=a|0,c=i|0,a=o|0,i=n|0,o=s|0;let m=D.add3L(V,et,N);n=D.add3H(m,$,H,st),s=m|0}({h:n,l:s}=D.add(this.Ah|0,this.Al|0,n|0,s|0)),{h:i,l:o}=D.add(this.Bh|0,this.Bl|0,i|0,o|0),{h:c,l:a}=D.add(this.Ch|0,this.Cl|0,c|0,a|0),{h:f,l}=D.add(this.Dh|0,this.Dl|0,f|0,l|0),{h:u,l:p}=D.add(this.Eh|0,this.El|0,u|0,p|0),{h:x,l:y}=D.add(this.Fh|0,this.Fl|0,x|0,y|0),{h,l:d}=D.add(this.Gh|0,this.Gl|0,h|0,d|0),{h:E,l:b}=D.add(this.Hh|0,this.Hl|0,E|0,b|0),this.set(n,s,i,o,c,a,f,l,u,p,x,y,h,d,E,b)}roundClean(){ye.fill(0),me.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 Dr=pn(()=>new ai);var mn={};rt(mn,{aInRange:()=>St,abool:()=>Ut,abytes:()=>fr,bitGet:()=>wf,bitLen:()=>bf,bitMask:()=>Or,bitSet:()=>xf,bytesToHex:()=>ee,bytesToNumberBE:()=>re,bytesToNumberLE:()=>we,concatBytes:()=>ne,createHmacDrbg:()=>hi,ensureBytes:()=>tt,equalBytes:()=>yf,hexToBytes:()=>Ce,hexToNumber:()=>fi,inRange:()=>Pr,isBytes:()=>be,memoized:()=>Ue,notImplemented:()=>vf,numberToBytesBE:()=>xe,numberToBytesLE:()=>Le,numberToHexUnpadded:()=>ca,numberToVarBytesBE:()=>gf,utf8ToBytes:()=>mf,validateObject:()=>Gt});var li=BigInt(0),yn=BigInt(1),df=BigInt(2);function be(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function fr(r){if(!be(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 pf=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function ee(r){fr(r);let t="";for(let e=0;e<r.length;e++)t+=pf[r[e]];return t}function ca(r){let t=r.toString(16);return t.length&1?`0${t}`:t}function fi(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return BigInt(r===""?"0":`0x${r}`)}var te={_0:48,_9:57,_A:65,_F:70,_a:97,_f:102};function oa(r){if(r>=te._0&&r<=te._9)return r-te._0;if(r>=te._A&&r<=te._F)return r-(te._A-10);if(r>=te._a&&r<=te._f)return r-(te._a-10)}function Ce(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=oa(r.charCodeAt(i)),c=oa(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 re(r){return fi(ee(r))}function we(r){return fr(r),fi(ee(Uint8Array.from(r).reverse()))}function xe(r,t){return Ce(r.toString(16).padStart(t*2,"0"))}function Le(r,t){return xe(r,t).reverse()}function gf(r){return Ce(ca(r))}function tt(r,t,e){let n;if(typeof t=="string")try{n=Ce(t)}catch(i){throw new Error(`${r} must be valid hex string, got "${t}". Cause: ${i}`)}else if(be(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 ne(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];fr(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 yf(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 mf(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}var ci=r=>typeof r=="bigint"&&li<=r;function Pr(r,t,e){return ci(r)&&ci(t)&&ci(e)&&t<=r&&r<e}function St(r,t,e,n){if(!Pr(t,e,n))throw new Error(`expected valid ${r}: ${e} <= n < ${n}, got ${typeof t} ${t}`)}function bf(r){let t;for(t=0;r>li;r>>=yn,t+=1);return t}function wf(r,t){return r>>BigInt(t)&yn}function xf(r,t,e){return r|(e?yn:li)<<BigInt(t)}var Or=r=>(df<<BigInt(r-1))-yn,ui=r=>new Uint8Array(r),aa=r=>Uint8Array.from(r);function hi(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=ui(r),s=ui(r),i=0,o=()=>{n.fill(1),s.fill(0),i=0},c=(...u)=>e(s,n,...u),a=(u=ui())=>{s=c(aa([0]),u),n=c(),u.length!==0&&(s=c(aa([1]),u),n=c())},f=()=>{if(i++>=1e3)throw new Error("drbg: tried 1000 values");let u=0,p=[];for(;u<t;){n=c();let x=n.slice();p.push(x),u+=n.length}return ne(...p)};return(u,p)=>{o(),a(u);let x;for(;!(x=p(f()));)a();return o(),x}}var Ef={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"||be(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=Ef[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 vf=()=>{throw new Error("not implemented")};function Ue(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),W=BigInt(1),De=BigInt(2),Bf=BigInt(3),di=BigInt(4),ua=BigInt(5),la=BigInt(8),Af=BigInt(9),Sf=BigInt(16);function G(r,t){let e=r%t;return e>=at?e:t+e}function If(r,t,e){if(e<=at||t<at)throw new Error("Expected power/modulo > 0");if(e===W)return at;let n=W;for(;t>at;)t&W&&(n=n*r%e),r=r*r%e,t>>=W;return n}function Z(r,t,e){let n=r;for(;t-- >at;)n*=n,n%=e;return n}function bn(r,t){if(r===at||t<=at)throw new Error(`invert: expected positive integers, got n=${r} mod=${t}`);let e=G(r,t),n=t,s=at,i=W,o=W,c=at;for(;e!==at;){let f=n/e,l=n%e,u=s-o*f,p=i-c*f;n=e,e=l,s=o,i=c,o=u,c=p}if(n!==W)throw new Error("invert: does not exist");return G(s,t)}function kf(r){let t=(r-W)/De,e,n,s;for(e=r-W,n=0;e%De===at;e/=De,n++);for(s=De;s<r&&If(s,t,r)!==r-W;s++);if(n===1){let o=(r+W)/di;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+W)/De;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),p=c.pow(a,e);for(;!c.eql(p,c.ONE);){if(c.eql(p,c.ZERO))return c.ZERO;let x=1;for(let h=c.sqr(p);x<f&&!c.eql(h,c.ONE);x++)h=c.sqr(h);let y=c.pow(l,W<<BigInt(f-x-1));l=c.sqr(y),u=c.mul(u,y),p=c.mul(p,l),f=x}return u}}function Rf(r){if(r%di===Bf){let t=(r+W)/di;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%la===ua){let t=(r-ua)/la;return function(n,s){let i=n.mul(s,De),o=n.pow(i,t),c=n.mul(s,o),a=n.mul(n.mul(c,De),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%Sf,kf(r)}var fa=(r,t)=>(G(r,t)&W)===W,Nf=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function pi(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=Nf.reduce((n,s)=>(n[s]="function",n),t);return Gt(r,e)}function _f(r,t,e){if(e<at)throw new Error("Expected power > 0");if(e===at)return r.ONE;if(e===W)return t;let n=r.ONE,s=t;for(;e>at;)e&W&&(n=r.mul(n,s)),s=r.sqr(s),e>>=W;return n}function Tf(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 gi(r,t){let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function wn(r,t,e=!1,n={}){if(r<=at)throw new Error(`Expected Field ORDER > 0, got ${r}`);let{nBitLength:s,nByteLength:i}=gi(r,t);if(i>2048)throw new Error("Field lengths over 2048 bytes are not supported");let o=Rf(r),c=Object.freeze({ORDER:r,BITS:s,BYTES:i,MASK:Or(s),ZERO:at,ONE:W,create:a=>G(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&W)===W,neg:a=>G(-a,r),eql:(a,f)=>a===f,sqr:a=>G(a*a,r),add:(a,f)=>G(a+f,r),sub:(a,f)=>G(a-f,r),mul:(a,f)=>G(a*f,r),pow:(a,f)=>_f(c,a,f),div:(a,f)=>G(a*bn(f,r),r),sqrN:a=>a*a,addN:(a,f)=>a+f,subN:(a,f)=>a-f,mulN:(a,f)=>a*f,inv:a=>bn(a,r),sqrt:n.sqrt||(a=>o(c,a)),invertBatch:a=>Tf(c,a),cmov:(a,f,l)=>l?f:a,toBytes:a=>e?Le(a,i):xe(a,i),fromBytes:a=>{if(a.length!==i)throw new Error(`Fp.fromBytes: expected ${i}, got ${a.length}`);return e?we(a):re(a)}});return Object.freeze(c)}function ha(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 yi(r){let t=ha(r);return t+Math.ceil(t/2)}function da(r,t,e=!1){let n=r.length,s=ha(t),i=yi(t);if(n<16||n<i||n>1024)throw new Error(`expected ${i}-1024 bytes of input, got ${n}`);let o=e?re(r):we(r),c=G(o,t-W)+W;return e?Le(c,s):xe(c,s)}var Lf=BigInt(0),mi=BigInt(1),bi=new WeakMap,pa=new WeakMap;function xn(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>Lf;)o&mi&&(c=c.add(a)),a=a.double(),o>>=mi;return c},precomputeWindow(i,o){let{windows:c,windowSize:a}=s(o),f=[],l=i,u=l;for(let p=0;p<c;p++){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,p=BigInt(2**i-1),x=2**i,y=BigInt(i);for(let h=0;h<a;h++){let d=h*f,E=Number(c&p);c>>=y,E>f&&(E-=x,c+=mi);let b=d,w=d+Math.abs(E)-1,_=h%2!==0,k=E<0;E===0?u=u.add(e(_,o[b])):l=l.add(e(k,o[w]))}return{p:l,f:u}},wNAFCached(i,o,c){let a=pa.get(i)||1,f=bi.get(i);return f||(f=this.precomputeWindow(i,a),a!==1&&bi.set(i,c(f))),this.wNAF(a,f,o)},setWindowSize(i,o){n(o),pa.set(i,o),bi.delete(i)}}}function Vr(r){return pi(r.Fp),Gt(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...gi(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Dt=BigInt(0),It=BigInt(1),En=BigInt(2),Uf=BigInt(8),Df={zip215:!0};function Pf(r){let t=Vr(r);return Gt(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function ga(r){let t=Pf(r),{Fp:e,n,prehash:s,hash:i,randomBytes:o,nByteLength:c,h:a}=t,f=En<<BigInt(c*8)-It,l=e.create,u=t.uvRatio||((m,g)=>{try{return{isValid:!0,value:e.sqrt(m*e.inv(g))}}catch{return{isValid:!1,value:Dt}}}),p=t.adjustScalarBytes||(m=>m),x=t.domain||((m,g,v)=>{if(Ut("phflag",v),g.length||v)throw new Error("Contexts/pre-hash are not supported");return m});function y(m,g){St("coordinate "+m,g,Dt,f)}function h(m){if(!(m instanceof b))throw new Error("ExtendedPoint expected")}let d=Ue((m,g)=>{let{ex:v,ey:A,ez:C}=m,L=m.is0();g==null&&(g=L?Uf:e.inv(C));let U=l(v*g),M=l(A*g),P=l(C*g);if(L)return{x:Dt,y:It};if(P!==It)throw new Error("invZ was invalid");return{x:U,y:M}}),E=Ue(m=>{let{a:g,d:v}=t;if(m.is0())throw new Error("bad point: ZERO");let{ex:A,ey:C,ez:L,et:U}=m,M=l(A*A),P=l(C*C),K=l(L*L),J=l(K*K),X=l(M*g),At=l(K*l(X+P)),ut=l(J+l(v*l(M*P)));if(At!==ut)throw new Error("bad point: equation left != right (1)");let it=l(A*C),Tt=l(L*U);if(it!==Tt)throw new Error("bad point: equation left != right (2)");return!0});class b{constructor(g,v,A,C){this.ex=g,this.ey=v,this.ez=A,this.et=C,y("x",g),y("y",v),y("z",A),y("t",C),Object.freeze(this)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(g){if(g instanceof b)throw new Error("extended point not allowed");let{x:v,y:A}=g||{};return y("x",v),y("y",A),new b(v,A,It,l(v*A))}static normalizeZ(g){let v=e.invertBatch(g.map(A=>A.ez));return g.map((A,C)=>A.toAffine(v[C])).map(b.fromAffine)}_setWindowSize(g){k.setWindowSize(this,g)}assertValidity(){E(this)}equals(g){h(g);let{ex:v,ey:A,ez:C}=this,{ex:L,ey:U,ez:M}=g,P=l(v*M),K=l(L*C),J=l(A*M),X=l(U*C);return P===K&&J===X}is0(){return this.equals(b.ZERO)}negate(){return new b(l(-this.ex),this.ey,this.ez,l(-this.et))}double(){let{a:g}=t,{ex:v,ey:A,ez:C}=this,L=l(v*v),U=l(A*A),M=l(En*l(C*C)),P=l(g*L),K=v+A,J=l(l(K*K)-L-U),X=P+U,At=X-M,ut=P-U,it=l(J*At),Tt=l(X*ut),lt=l(J*ut),Ct=l(At*X);return new b(it,Tt,Ct,lt)}add(g){h(g);let{a:v,d:A}=t,{ex:C,ey:L,ez:U,et:M}=this,{ex:P,ey:K,ez:J,et:X}=g;if(v===BigInt(-1)){let mo=l((L-C)*(K+P)),bo=l((L+C)*(K-P)),Ts=l(bo-mo);if(Ts===Dt)return this.double();let wo=l(U*En*X),xo=l(M*En*J),Eo=xo+wo,vo=bo+mo,Bo=xo-wo,wu=l(Eo*Ts),xu=l(vo*Bo),Eu=l(Eo*Bo),vu=l(Ts*vo);return new b(wu,xu,vu,Eu)}let At=l(C*P),ut=l(L*K),it=l(M*A*X),Tt=l(U*J),lt=l((C+L)*(P+K)-At-ut),Ct=Tt-it,Te=Tt+it,Ar=l(ut-v*At),an=l(lt*Ct),yu=l(Te*Ar),mu=l(lt*Ar),bu=l(Ct*Te);return new b(an,yu,bu,mu)}subtract(g){return this.add(g.negate())}wNAF(g){return k.wNAFCached(this,g,b.normalizeZ)}multiply(g){let v=g;St("scalar",v,It,n);let{p:A,f:C}=this.wNAF(v);return b.normalizeZ([A,C])[0]}multiplyUnsafe(g){let v=g;return St("scalar",v,Dt,n),v===Dt?_:this.equals(_)||v===It?this:this.equals(w)?this.wNAF(v).p:k.unsafeLadder(this,v)}isSmallOrder(){return this.multiplyUnsafe(a).is0()}isTorsionFree(){return k.unsafeLadder(this,n).is0()}toAffine(g){return d(this,g)}clearCofactor(){let{h:g}=t;return g===It?this:this.multiplyUnsafe(g)}static fromHex(g,v=!1){let{d:A,a:C}=t,L=e.BYTES;g=tt("pointHex",g,L),Ut("zip215",v);let U=g.slice(),M=g[L-1];U[L-1]=M&-129;let P=we(U),K=v?f:e.ORDER;St("pointHex.y",P,Dt,K);let J=l(P*P),X=l(J-It),At=l(A*J-C),{isValid:ut,value:it}=u(X,At);if(!ut)throw new Error("Point.fromHex: invalid y coordinate");let Tt=(it&It)===It,lt=(M&128)!==0;if(!v&&it===Dt&<)throw new Error("Point.fromHex: x=0 and x_0=1");return lt!==Tt&&(it=l(-it)),b.fromAffine({x:it,y:P})}static fromPrivateKey(g){return R(g).point}toRawBytes(){let{x:g,y:v}=this.toAffine(),A=Le(v,e.BYTES);return A[A.length-1]|=g&It?128:0,A}toHex(){return ee(this.toRawBytes())}}b.BASE=new b(t.Gx,t.Gy,It,l(t.Gx*t.Gy)),b.ZERO=new b(Dt,It,It,Dt);let{BASE:w,ZERO:_}=b,k=xn(b,c*8);function I(m){return G(m,n)}function T(m){return I(we(m))}function R(m){let g=c;m=tt("private key",m,g);let v=tt("hashed private key",i(m),2*g),A=p(v.slice(0,g)),C=v.slice(g,2*g),L=T(A),U=w.multiply(L),M=U.toRawBytes();return{head:A,prefix:C,scalar:L,point:U,pointBytes:M}}function $(m){return R(m).pointBytes}function V(m=new Uint8Array,...g){let v=ne(...g);return T(i(x(v,tt("context",m),!!s)))}function H(m,g,v={}){m=tt("message",m),s&&(m=s(m));let{prefix:A,scalar:C,pointBytes:L}=R(g),U=V(v.context,A,m),M=w.multiply(U).toRawBytes(),P=V(v.context,M,L,m),K=I(U+P*C);St("signature.s",K,Dt,n);let J=ne(M,Le(K,e.BYTES));return tt("result",J,c*2)}let et=Df;function st(m,g,v,A=et){let{context:C,zip215:L}=A,U=e.BYTES;m=tt("signature",m,2*U),g=tt("message",g),L!==void 0&&Ut("zip215",L),s&&(g=s(g));let M=we(m.slice(U,2*U)),P,K,J;try{P=b.fromHex(v,L),K=b.fromHex(m.slice(0,U),L),J=w.multiplyUnsafe(M)}catch{return!1}if(!L&&P.isSmallOrder())return!1;let X=V(C,K.toRawBytes(),P.toRawBytes(),g);return K.add(P.multiplyUnsafe(X)).subtract(J).clearCofactor().equals(b.ZERO)}return w._setWindowSize(8),{CURVE:t,getPublicKey:$,sign:H,verify:st,ExtendedPoint:b,utils:{getExtendedPublicKey:R,randomPrivateKey:()=>o(e.BYTES),precompute(m=8,g=b.BASE){return g._setWindowSize(m),g.multiply(BigInt(3)),g}}}}var wi=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),ya=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),vp=BigInt(0),Of=BigInt(1),ma=BigInt(2),Bp=BigInt(3),Vf=BigInt(5),Hf=BigInt(8);function Mf(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),s=BigInt(80),i=wi,c=r*r%i*r%i,a=Z(c,ma,i)*c%i,f=Z(a,Of,i)*r%i,l=Z(f,Vf,i)*f%i,u=Z(l,t,i)*l%i,p=Z(u,e,i)*u%i,x=Z(p,n,i)*p%i,y=Z(x,s,i)*x%i,h=Z(y,s,i)*x%i,d=Z(h,t,i)*l%i;return{pow_p_5_8:Z(d,ma,i)*r%i,b2:c}}function Kf(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function Ff(r,t){let e=wi,n=G(t*t*t,e),s=G(n*n*t,e),i=Mf(r*s).pow_p_5_8,o=G(r*n*i,e),c=G(t*o*o,e),a=o,f=G(o*ya,e),l=c===r,u=c===G(-r,e),p=c===G(-r*ya,e);return l&&(o=a),(u||p)&&(o=f),fa(o,e)&&(o=G(-o,e)),{isValid:l||u,value:o}}var qf=wn(wi,void 0,!0),$f={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:qf,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:Hf,Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:Dr,randomBytes:ur,adjustScalarBytes:Kf,uvRatio:Ff},hr=ga($f);var dr=32,se=64,vn=32;function ba(){let r=hr.utils.randomPrivateKey(),t=hr.getPublicKey(r);return{privateKey:va(r,t),publicKey:t}}function wa(r){if(r.length!==vn)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=hr.getPublicKey(t);return{privateKey:va(t,e),publicKey:e}}function xa(r,t){let e=r.subarray(0,vn);return hr.sign(t instanceof Uint8Array?t:t.subarray(),e)}function Ea(r,t,e){return hr.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}function va(r,t){let e=new Uint8Array(se);for(let n=0;n<vn;n++)e[n]=r[n],e[vn+n]=t[n];return e}var xi={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function Bn(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=Y.get();e*=8;async function a(u,p){let x=c.getRandomValues(new Uint8Array(i)),y=c.getRandomValues(new Uint8Array(n)),h={name:t,iv:y};typeof p=="string"&&(p=F(p));let d;if(p.length===0){d=await c.subtle.importKey("jwk",xi,{name:"AES-GCM"},!0,["encrypt"]);try{let b={name:"PBKDF2",salt:x,iterations:o,hash:{name:s}},w=await c.subtle.importKey("raw",p,{name:"PBKDF2"},!1,["deriveKey"]);d=await c.subtle.deriveKey(b,w,{name:t,length:e},!0,["encrypt"])}catch{d=await c.subtle.importKey("jwk",xi,{name:"AES-GCM"},!0,["encrypt"])}}else{let b={name:"PBKDF2",salt:x,iterations:o,hash:{name:s}},w=await c.subtle.importKey("raw",p,{name:"PBKDF2"},!1,["deriveKey"]);d=await c.subtle.deriveKey(b,w,{name:t,length:e},!0,["encrypt"])}let E=await c.subtle.encrypt(h,d,u);return Et([x,h.iv,new Uint8Array(E)])}async function f(u,p){let x=u.subarray(0,i),y=u.subarray(i,i+n),h=u.subarray(i+n),d={name:t,iv:y};typeof p=="string"&&(p=F(p));let E;if(p.length===0)try{let w={name:"PBKDF2",salt:x,iterations:o,hash:{name:s}},_=await c.subtle.importKey("raw",p,{name:"PBKDF2"},!1,["deriveKey"]);E=await c.subtle.deriveKey(w,_,{name:t,length:e},!0,["decrypt"])}catch{E=await c.subtle.importKey("jwk",xi,{name:"AES-GCM"},!0,["decrypt"])}else{let w={name:"PBKDF2",salt:x,iterations:o,hash:{name:s}},_=await c.subtle.importKey("raw",p,{name:"PBKDF2"},!1,["deriveKey"]);E=await c.subtle.deriveKey(w,_,{name:t,length:e},!0,["decrypt"])}let b=await c.subtle.decrypt(d,E,h);return new Uint8Array(b)}return{encrypt:a,decrypt:f}}async function pr(r,t){let n=await Bn().encrypt(r,t);return Ir.encode(n)}var yr={};rt(yr,{KeyType:()=>j,PrivateKey:()=>Ht,PublicKey:()=>Vt});var zf=Math.pow(2,7),jf=Math.pow(2,14),Yf=Math.pow(2,21),Ei=Math.pow(2,28),vi=Math.pow(2,35),Bi=Math.pow(2,42),Ai=Math.pow(2,49),q=128,yt=127;function Pt(r){if(r<zf)return 1;if(r<jf)return 2;if(r<Yf)return 3;if(r<Ei)return 4;if(r<vi)return 5;if(r<Bi)return 6;if(r<Ai)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function Si(r,t,e=0){switch(Pt(r)){case 8:t[e++]=r&255|q,r/=128;case 7:t[e++]=r&255|q,r/=128;case 6:t[e++]=r&255|q,r/=128;case 5:t[e++]=r&255|q,r/=128;case 4:t[e++]=r&255|q,r>>>=7;case 3:t[e++]=r&255|q,r>>>=7;case 2:t[e++]=r&255|q,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function Wf(r,t,e=0){switch(Pt(r)){case 8:t.set(e++,r&255|q),r/=128;case 7:t.set(e++,r&255|q),r/=128;case 6:t.set(e++,r&255|q),r/=128;case 5:t.set(e++,r&255|q),r/=128;case 4:t.set(e++,r&255|q),r>>>=7;case 3:t.set(e++,r&255|q),r>>>=7;case 2:t.set(e++,r&255|q),r>>>=7;case 1:{t.set(e++,r&255),r>>>=7;break}default:throw new Error("unreachable")}return t}function Ii(r,t){let e=r[t],n=0;if(n+=e&yt,e<q||(e=r[t+1],n+=(e&yt)<<7,e<q)||(e=r[t+2],n+=(e&yt)<<14,e<q)||(e=r[t+3],n+=(e&yt)<<21,e<q)||(e=r[t+4],n+=(e&yt)*Ei,e<q)||(e=r[t+5],n+=(e&yt)*vi,e<q)||(e=r[t+6],n+=(e&yt)*Bi,e<q)||(e=r[t+7],n+=(e&yt)*Ai,e<q))return n;throw new RangeError("Could not decode varint")}function Zf(r,t){let e=r.get(t),n=0;if(n+=e&yt,e<q||(e=r.get(t+1),n+=(e&yt)<<7,e<q)||(e=r.get(t+2),n+=(e&yt)<<14,e<q)||(e=r.get(t+3),n+=(e&yt)<<21,e<q)||(e=r.get(t+4),n+=(e&yt)*Ei,e<q)||(e=r.get(t+5),n+=(e&yt)*vi,e<q)||(e=r.get(t+6),n+=(e&yt)*Bi,e<q)||(e=r.get(t+7),n+=(e&yt)*Ai,e<q))return n;throw new RangeError("Could not decode varint")}function Aa(r,t,e=0){return t==null&&(t=gt(Pt(r))),t instanceof Uint8Array?Si(r,t,e):Wf(r,t,e)}function Sa(r,t=0){return r instanceof Uint8Array?Ii(r,t):Zf(r,t)}var ki=new Float32Array([-0]),Ee=new Uint8Array(ki.buffer);function ka(r,t,e){ki[0]=r,t[e]=Ee[0],t[e+1]=Ee[1],t[e+2]=Ee[2],t[e+3]=Ee[3]}function Ra(r,t){return Ee[0]=r[t],Ee[1]=r[t+1],Ee[2]=r[t+2],Ee[3]=r[t+3],ki[0]}var Ri=new Float64Array([-0]),mt=new Uint8Array(Ri.buffer);function Na(r,t,e){Ri[0]=r,t[e]=mt[0],t[e+1]=mt[1],t[e+2]=mt[2],t[e+3]=mt[3],t[e+4]=mt[4],t[e+5]=mt[5],t[e+6]=mt[6],t[e+7]=mt[7]}function _a(r,t){return mt[0]=r[t],mt[1]=r[t+1],mt[2]=r[t+2],mt[3]=r[t+3],mt[4]=r[t+4],mt[5]=r[t+5],mt[6]=r[t+6],mt[7]=r[t+7],Ri[0]}var Jf=BigInt(Number.MAX_SAFE_INTEGER),Xf=BigInt(Number.MIN_SAFE_INTEGER),Rt=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 Pe;if(t<Jf&&t>Xf)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>Ta&&(s=0n,++n>Ta&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(t){if(t===0)return Pe;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):Pe}},Pe=new Rt(0,0);Pe.toBigInt=function(){return 0n};Pe.zzEncode=Pe.zzDecode=function(){return this};Pe.length=function(){return 1};var Ta=4294967296n;function Ca(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 La(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 Ni(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 An(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var _i=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 An(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Ot(this,4);return An(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Ot(this,4);let t=Ra(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Ot(this,4);let t=_a(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 La(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 Rt(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=An(this.buf,this.pos+=4),e=An(this.buf,this.pos+=4);return new Rt(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=Ii(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 Ti(r){return new _i(r instanceof Uint8Array?r:r.subarray())}function Sn(r,t,e){let n=Ti(r);return t.decode(n,void 0,e)}function Ci(r){let t=r??8192,e=t>>>1,n,s=t;return function(o){if(o<1||o>e)return gt(o);s+o>t&&(n=gt(t),s=0);let c=n.subarray(s,s+=o);return s&7&&(s=(s|7)+1),c}}var Oe=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function Li(){}var Di=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},Qf=Ci();function th(r){return globalThis.Buffer!=null?gt(r):Qf(r)}var Mr=class{len;head;tail;states;constructor(){this.len=0,this.head=new Oe(Li,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new Oe(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new Pi((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(In,10,Rt.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=Rt.fromBigInt(t);return this._push(In,e.length(),e)}uint64Number(t){return this._push(Si,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=Rt.fromBigInt(t).zzEncode();return this._push(In,e.length(),e)}sint64Number(t){let e=Rt.fromNumber(t).zzEncode();return this._push(In,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(Ui,1,t?1:0)}fixed32(t){return this._push(Hr,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=Rt.fromBigInt(t);return this._push(Hr,4,e.lo)._push(Hr,4,e.hi)}fixed64Number(t){let e=Rt.fromNumber(t);return this._push(Hr,4,e.lo)._push(Hr,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(ka,4,t)}double(t){return this._push(Na,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(Ui,1,0):this.uint32(e)._push(rh,e,t)}string(t){let e=Ca(t);return e!==0?this.uint32(e)._push(Ni,e,t):this._push(Ui,1,0)}fork(){return this.states=new Di(this),this.head=this.tail=new Oe(Li,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 Oe(Li,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=th(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function Ui(r,t,e){t[e]=r&255}function eh(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var Pi=class extends Oe{next;constructor(t,e){super(eh,t,e),this.next=void 0}};function In(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 Hr(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 rh(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(Mr.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(nh,t,r),this},Mr.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(sh,t,r),this});function nh(r,t,e){t.set(r,e)}function sh(r,t,e){r.length<40?Ni(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(F(r),e)}function Oi(){return new Mr}function kn(r,t){let e=Oi();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var gr;(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"})(gr||(gr={}));function Rn(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function Vi(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 Rn("enum",gr.VARINT,e,n)}function Nn(r,t){return Rn("message",gr.LENGTH_DELIMITED,r,t)}var j;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.Secp256k1="Secp256k1"})(j||(j={}));var Hi;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.Secp256k1=2]="Secp256k1"})(Hi||(Hi={}));(function(r){r.codec=()=>Vi(Hi)})(j||(j={}));var Vt;(function(r){let t;r.codec=()=>(t==null&&(t=Nn((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),j.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let s={},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let o=e.uint32();switch(o>>>3){case 1:s.Type=j.codec().decode(e);break;case 2:s.Data=e.bytes();break;default:e.skipType(o&7);break}}return s})),t),r.encode=e=>kn(e,r.codec()),r.decode=e=>Sn(e,r.codec())})(Vt||(Vt={}));var Ht;(function(r){let t;r.codec=()=>(t==null&&(t=Nn((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),j.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let s={},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let o=e.uint32();switch(o>>>3){case 1:s.Type=j.codec().decode(e);break;case 2:s.Data=e.bytes();break;default:e.skipType(o&7);break}}return s})),t),r.encode=e=>kn(e,r.codec()),r.decode=e=>Sn(e,r.codec())})(Ht||(Ht={}));var Ve=class{_key;constructor(t){this._key=mr(t,dr)}verify(t,e){return Ea(this._key,e,t)}marshal(){return this._key}get bytes(){return Vt.encode({Type:j.Ed25519,Data:this.marshal()}).subarray()}equals(t){return pt(this.bytes,t.bytes)}hash(){let t=ot.digest(this.bytes);return Nt(t)?t.then(({bytes:e})=>e):t.bytes}},ie=class{_key;_publicKey;constructor(t,e){this._key=mr(t,se),this._publicKey=mr(e,dr)}sign(t){return xa(this._key,t)}get public(){return new Ve(this._publicKey)}marshal(){return this._key}get bytes(){return Ht.encode({Type:j.Ed25519,Data:this.marshal()}).subarray()}equals(t){return pt(this.bytes,t.bytes)}async hash(){let t=ot.digest(this.bytes),e;return Nt(t)?{bytes:e}=await t:e=t.bytes,e}async id(){let t=Jt.digest(this.public.bytes);return xt.encode(t.bytes).substring(1)}async export(t,e="libp2p-key"){if(e==="libp2p-key")return pr(this.bytes,t);throw new B(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function ih(r){if(r.length>se){r=mr(r,se+dr);let n=r.subarray(0,se),s=r.subarray(se,r.length);return new ie(n,s)}r=mr(r,se);let t=r.subarray(0,se),e=r.subarray(dr);return new ie(t,e)}function oh(r){return r=mr(r,dr),new Ve(r)}async function ah(){let{privateKey:r,publicKey:t}=ba();return new ie(r,t)}async function Mi(r){let{privateKey:t,publicKey:e}=wa(r);return new ie(t,e)}function mr(r,t){if(r=Uint8Array.from(r??[]),r.length!==t)throw new B(`Key must be a Uint8Array of length ${t}, got ${r.length}`,"ERR_INVALID_KEY_TYPE");return r}var Da={"P-256":256,"P-384":384,"P-521":521},ch=Object.keys(Da),Fi=ch.join(" / ");async function Pa(r){if(r!=="P-256"&&r!=="P-384"&&r!=="P-521")throw new B(`Unknown curve: ${r}. Must be ${Fi}`,"ERR_INVALID_CURVE");let t=await Y.get().subtle.generateKey({name:"ECDH",namedCurve:r},!0,["deriveBits"]),e=async(i,o)=>{let c;o!=null?c=await Y.get().subtle.importKey("jwk",lh(r,o),{name:"ECDH",namedCurve:r},!1,["deriveBits"]):c=t.privateKey;let a=await Y.get().subtle.importKey("jwk",Va(r,i),{name:"ECDH",namedCurve:r},!1,[]),f=await Y.get().subtle.deriveBits({name:"ECDH",namedCurve:r,public:a},c,Da[r]);return new Uint8Array(f,0,f.byteLength)},n=await Y.get().subtle.exportKey("jwk",t.publicKey);return{key:uh(n),genSharedKey:e}}var Oa={"P-256":32,"P-384":48,"P-521":66};function uh(r){if(r.crv==null||r.x==null||r.y==null)throw new B("JWK was missing components","ERR_INVALID_PARAMETERS");if(r.crv!=="P-256"&&r.crv!=="P-384"&&r.crv!=="P-521")throw new B(`Unknown curve: ${r.crv}. Must be ${Fi}`,"ERR_INVALID_CURVE");let t=Oa[r.crv];return Et([Uint8Array.from([4]),si(r.x,t),si(r.y,t)],1+t*2)}function Va(r,t){if(r!=="P-256"&&r!=="P-384"&&r!=="P-521")throw new B(`Unknown curve: ${r}. Must be ${Fi}`,"ERR_INVALID_CURVE");let e=Oa[r];if(!pt(t.subarray(0,1),Uint8Array.from([4])))throw new B("Cannot unmarshal public key - invalid key format","ERR_INVALID_KEY_FORMAT");return{kty:"EC",crv:r,x:z(t.subarray(1,e+1),"base64url"),y:z(t.subarray(1+e),"base64url"),ext:!0}}var lh=(r,t)=>({...Va(r,t.public),d:z(t.private,"base64url")});var Ha=Pa;async function Ma(r,t){let e=Ir.decode(r);return Bn().decrypt(e,t)}var Ka={"AES-128":{ivSize:16,keySize:16},"AES-256":{ivSize:16,keySize:32},Blowfish:{ivSize:8,keySize:32}};async function Fa(r,t,e){let n=Ka[r];if(n==null){let b=Object.keys(Ka).join(" / ");throw new B(`unknown cipher type '${r}'. Must be ${b}`,"ERR_INVALID_CIPHER_TYPE")}if(t==null)throw new B("missing hash type","ERR_MISSING_HASH_TYPE");let s=n.keySize,i=n.ivSize,o=20,c=F("key expansion"),a=2*(i+s+o),f=await Xo(t,e),l=await f.digest(c),u=[],p=0;for(;p<a;){let b=await f.digest(Et([l,c])),w=b.length;p+w>a&&(w=a-p),u.push(b),p+=w,l=await f.digest(l)}let x=a/2,y=Et(u),h=y.subarray(0,x),d=y.subarray(x,a),E=b=>({iv:b.subarray(0,i),cipherKey:b.subarray(i,i+s),macKey:b.subarray(i+s)});return{k1:E(h),k2:E(d)}}var Qi={};rt(Qi,{MAX_RSA_KEY_SIZE:()=>Ke,RsaPrivateKey:()=>Ie,RsaPublicKey:()=>Me,fromJwk:()=>Ph,generateKeyPair:()=>Oh,unmarshalRsaPrivateKey:()=>Ji,unmarshalRsaPublicKey:()=>Dh});function zt(r){if(isNaN(r)||r<=0)throw new B("random bytes length must be a Number bigger than 0","ERR_INVALID_LENGTH");return ur(r)}var Se={};rt(Se,{exportToPem:()=>Th,importFromPem:()=>Zi,jwkToPkcs1:()=>kh,jwkToPkix:()=>Nh,pkcs1ToJwk:()=>Ih,pkixToJwk:()=>Rh});var _n=class extends ar{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,hn(t);let n=ge(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 or(this),this.iHash.update(t),this}digestInto(t){or(this),ir(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()}},Kr=(r,t,e)=>new _n(r,t).update(e).digest();Kr.create=(r,t)=>new _n(r,t);function fh(r,t,e,n){hn(r);let s=ra({dkLen:32,asyncTick:10},n),{c:i,dkLen:o,asyncTick:c}=s;if(sr(i),sr(o),sr(c),i<1)throw new Error("PBKDF2: iterations (c) should be >= 1");let a=ge(t),f=ge(e),l=new Uint8Array(o),u=Kr.create(r,a),p=u._cloneInto().update(f);return{c:i,dkLen:o,asyncTick:c,DK:l,PRF:u,PRFSalt:p}}function hh(r,t,e,n,s){return r.destroy(),t.destroy(),n&&n.destroy(),s.fill(0),e}async function qi(r,t,e,n){let{c:s,dkLen:i,asyncTick:o,DK:c,PRF:a,PRFSalt:f}=fh(r,t,e,n),l,u=new Uint8Array(4),p=cr(u),x=new Uint8Array(a.outputLen);for(let y=1,h=0;h<i;y++,h+=a.outputLen){let d=c.subarray(h,h+a.outputLen);p.setInt32(0,y,!1),(l=f._cloneInto(l)).update(u).digestInto(x),d.set(x.subarray(0,d.length)),await ta(s-1,o,()=>{a._cloneInto(l).update(x).digestInto(x);for(let E=0;E<d.length;E++)d[E]^=x[E]})}return hh(a,f,c,l,x)}var O=Io(qa());function He(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 ve(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 Ln(...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 Gi(){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=He(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,He(i,8)-n}function $a(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=ve(o,8,n),a=new Uint8Array(c);return a[0]|=128,c}let s=ve(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 Ga(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 kt(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 qg=Math.log(2);function Un(){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 le(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 qr=class{constructor(){this.items=[]}write(t){this.items.push(t)}final(){return zi(this.items)}},Fr=[new Uint8Array([1])],za="0123456789";var xr="",Kt=new ArrayBuffer(0),ji=new Uint8Array(0),$r="EndOfContent",Ya="OCTET STRING",Wa="BIT STRING";function fe(r){var t;return t=class extends r{constructor(...n){var s;super(...n);let i=n[0]||{};this.isHexOnly=(s=i.isHexOnly)!==null&&s!==void 0?s:!1,this.valueHexView=i.valueHex?O.BufferSourceConverter.toUint8Array(i.valueHex):ji}get valueHex(){return this.valueHexView.slice().buffer}set valueHex(n){this.valueHexView=new Uint8Array(n)}fromBER(n,s,i){let o=n instanceof ArrayBuffer?new Uint8Array(n):n;if(!le(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:O.Convert.ToHex(this.valueHexView)}}},t.NAME="hexBlock",t}var ae=class{constructor({blockLength:t=0,error:e=xr,warnings:n=[],valueBeforeDecode:s=ji}={}){this.blockLength=t,this.error=e,this.warnings=n,this.valueBeforeDecodeView=O.BufferSourceConverter.toUint8Array(s)}static blockName(){return this.NAME}get valueBeforeDecode(){return this.valueBeforeDecodeView.slice().buffer}set valueBeforeDecode(t){this.valueBeforeDecodeView=new Uint8Array(t)}toJSON(){return{blockName:this.constructor.NAME,blockLength:this.blockLength,error:this.error,warnings:this.warnings,valueBeforeDecode:O.Convert.ToHex(this.valueBeforeDecodeView)}}};ae.NAME="baseBlock";var bt=class extends ae{fromBER(t,e,n){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}toBER(t,e){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}};bt.NAME="valueBlock";var Dn=class extends fe(ae){constructor({idBlock:t={}}={}){var e,n,s,i;super(),t?(this.isHexOnly=(e=t.isHexOnly)!==null&&e!==void 0?e:!1,this.valueHexView=t.valueHex?O.BufferSourceConverter.toUint8Array(t.valueHex):ji,this.tagClass=(n=t.tagClass)!==null&&n!==void 0?n:-1,this.tagNumber=(s=t.tagNumber)!==null&&s!==void 0?s:-1,this.isConstructed=(i=t.isConstructed)!==null&&i!==void 0?i:!1):(this.tagClass=-1,this.tagNumber=-1,this.isConstructed=!1)}toBER(t=!1){let e=0;switch(this.tagClass){case 1:e|=0;break;case 2:e|=64;break;case 3:e|=128;break;case 4:e|=192;break;default:return this.error="Unknown tag class",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=ve(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=O.BufferSourceConverter.toUint8Array(t);if(!le(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 p=new Uint8Array(l);for(let x=0;x<f.length;x++)p[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 p=0;p<a;p++)u[p]=f[p];f=this.valueHexView=new Uint8Array(a),f.set(u),this.blockLength<=9?this.tagNumber=He(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}}};Dn.NAME="identificationBlock";var Pn=class extends ae{constructor({lenBlock:t={}}={}){var e,n,s;super(),this.isIndefiniteForm=(e=t.isIndefiniteForm)!==null&&e!==void 0?e:!1,this.longFormUsed=(n=t.longFormUsed)!==null&&n!==void 0?n:!1,this.length=(s=t.length)!==null&&s!==void 0?s:0}fromBER(t,e,n){let s=O.BufferSourceConverter.toUint8Array(t);if(!le(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=He(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=ve(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}}};Pn.NAME="lengthBlock";var S={},dt=class extends ae{constructor({name:t=xr,optional:e=!1,primitiveSchema:n,...s}={},i){super(s),this.name=t,this.optional=e,n&&(this.primitiveSchema=n),this.idBlock=new Dn(s),this.lenBlock=new Pn(s),this.valueBlock=i?new i(s):new bt(s)}fromBER(t,e,n){let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}toBER(t,e){let n=e||new qr;e||Za(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():O.Convert.ToHex(this.toBER())}onAsciiEncoding(){return`${this.constructor.NAME} : ${O.Convert.ToHex(this.valueBlock.valueBeforeDecodeView)}`}isEqual(t){if(this===t)return!0;if(!(t instanceof this.constructor))return!1;let e=this.toBER(),n=t.toBER();return Ga(e,n)}};dt.NAME="BaseBlock";function Za(r){if(r instanceof S.Constructed)for(let t of r.valueBlock.value)Za(t)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var On=class extends dt{constructor({value:t=xr,...e}={},n){super(e,n),t&&this.fromString(t)}getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}fromBER(t,e,n){let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.fromBuffer(this.valueBlock.valueHexView),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}onAsciiEncoding(){return`${this.constructor.NAME} : '${this.valueBlock.value}'`}};On.NAME="BaseStringBlock";var Vn=class extends fe(bt){constructor({isHexOnly:t=!0,...e}={}){super(e),this.isHexOnly=t}};Vn.NAME="PrimitiveValueBlock";var Ja,Hn=class extends dt{constructor(t={}){super(t,Vn),this.idBlock.isConstructed=!1}};Ja=Hn;S.Primitive=Ja;Hn.NAME="PRIMITIVE";function Eh(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 bs(r,t=0,e=r.length){let n=t,s=new dt({},bt),i=new ae;if(!le(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=dt;switch(s.idBlock.tagClass){case 1:if(s.idBlock.tagNumber>=37&&s.idBlock.isHexOnly===!1)return s.error="UNIVERSAL 37 and upper tags are reserved by ASN.1 standard",{offset:-1,result:s};switch(s.idBlock.tagNumber){case 0:if(s.idBlock.isConstructed&&s.lenBlock.length>0)return s.error="Type [UNIVERSAL 0] is reserved",{offset:-1,result:s};a=S.EndOfContent;break;case 1:a=S.Boolean;break;case 2:a=S.Integer;break;case 3:a=S.BitString;break;case 4:a=S.OctetString;break;case 5:a=S.Null;break;case 6:a=S.ObjectIdentifier;break;case 10:a=S.Enumerated;break;case 12:a=S.Utf8String;break;case 13:a=S.RelativeObjectIdentifier;break;case 14:a=S.TIME;break;case 15:return s.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:s};case 16:a=S.Sequence;break;case 17:a=S.Set;break;case 18:a=S.NumericString;break;case 19:a=S.PrintableString;break;case 20:a=S.TeletexString;break;case 21:a=S.VideotexString;break;case 22:a=S.IA5String;break;case 23:a=S.UTCTime;break;case 24:a=S.GeneralizedTime;break;case 25:a=S.GraphicString;break;case 26:a=S.VisibleString;break;case 27:a=S.GeneralString;break;case 28:a=S.UniversalString;break;case 29:a=S.CharacterString;break;case 30:a=S.BmpString;break;case 31:a=S.DATE;break;case 32:a=S.TimeOfDay;break;case 33:a=S.DateTime;break;case 34:a=S.Duration;break;default:{let f=s.idBlock.isConstructed?new S.Constructed:new S.Primitive;f.idBlock=s.idBlock,f.lenBlock=s.lenBlock,f.warnings=s.warnings,s=f}}break;case 2:case 3:case 4:default:a=s.idBlock.isConstructed?S.Constructed:S.Primitive}return s=Eh(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 Er(r){if(!r.byteLength){let t=new dt({},bt);return t.error="Input buffer has zero length",{offset:-1,result:t}}return bs(O.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function vh(r,t){return r?1:t}var jt=class extends bt{constructor({value:t=[],isIndefiniteForm:e=!1,...n}={}){super(n),this.value=t,this.isIndefiniteForm=e}fromBER(t,e,n){let s=O.BufferSourceConverter.toUint8Array(t);if(!le(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(;vh(this.isIndefiniteForm,n)>0;){let o=bs(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===$r)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===$r?this.value.pop():this.warnings.push("No EndOfContent block encoded")),i}toBER(t,e){let n=e||new qr;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 Xa,Be=class extends dt{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 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(`
|
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} :`}};Xa=Be;S.Constructed=Xa;Be.NAME="CONSTRUCTED";var Mn=class extends bt{fromBER(t,e,n){return e}toBER(t){return Kt}};Mn.override="EndOfContentValueBlock";var Qa,Kn=class extends dt{constructor(t={}){super(t,Mn),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};Qa=Kn;S.EndOfContent=Qa;Kn.NAME=$r;var tc,Ae=class extends dt{constructor(t={}){super(t,bt),this.idBlock.tagClass=1,this.idBlock.tagNumber=5}fromBER(t,e,n){return this.lenBlock.length>0&&this.warnings.push("Non-zero length of value block for Null type"),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.blockLength+=n,e+n>t.byteLength?(this.error="End of input reached before message was fully decoded (inconsistent offset and length values)",-1):e+n}toBER(t,e){let n=new ArrayBuffer(2);if(!t){let s=new Uint8Array(n);s[0]=5,s[1]=0}return e&&e.write(n),n}onAsciiEncoding(){return`${this.constructor.NAME}`}};tc=Ae;S.Null=tc;Ae.NAME="NULL";var Fn=class extends fe(bt){constructor({value:t,...e}={}){super(e),e.valueHex?this.valueHexView=O.BufferSourceConverter.toUint8Array(e.valueHex):this.valueHexView=new Uint8Array(1),t&&(this.value=t)}get value(){for(let t of this.valueHexView)if(t>0)return!0;return!1}set value(t){this.valueHexView[0]=t?255:0}fromBER(t,e,n){let s=O.BufferSourceConverter.toUint8Array(t);return le(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,Gi.call(this),this.blockLength=n,e+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};Fn.NAME="BooleanValueBlock";var ec,qn=class extends dt{constructor(t={}){super(t,Fn),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}`}};ec=qn;S.Boolean=ec;qn.NAME="BOOLEAN";var $n=class extends fe(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===$r){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(o!==Ya)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}}};$n.NAME="OctetStringValueBlock";var rc,ce=class r extends dt{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,i;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((i=n.value)===null||i===void 0)&&i.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},$n),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=bs(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?Be.prototype.onAsciiEncoding.call(this):`${this.constructor.NAME} : ${O.Convert.ToHex(this.valueBlock.valueHexView)}`}getValue(){if(!this.idBlock.isConstructed)return this.valueBlock.valueHexView.slice().buffer;let t=[];for(let e of this.valueBlock.value)e instanceof r&&t.push(e.valueBlock.valueHexView);return O.BufferSourceConverter.concat(t)}};rc=ce;S.OctetString=rc;ce.NAME=Ya;var Gn=class extends fe(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===$r){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(a!==Wa)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=O.BufferSourceConverter.toUint8Array(t);if(!le(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=bs(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}}};Gn.NAME="BitStringValueBlock";var nc,wr=class extends dt{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,i;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((i=n.value)===null||i===void 0)&&i.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},Gn),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 Be.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)}`}}};nc=wr;S.BitString=nc;wr.NAME=Wa;var sc;function Bh(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 p=l;p>=0;p--,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=Ln(new Uint8Array([f%10]),i);break;default:i[o-u]=f%10}}return e[0]>0&&(i=Ln(e,i)),i}function ja(r){if(r>=Fr.length)for(let t=Fr.length;t<=r;t++){let e=new Uint8Array([0]),n=Fr[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=Ln(e,n)),Fr.push(n)}return Fr[r]}function Ah(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 Gr=class extends fe(bt){constructor({value:t,...e}={}){super(e),this._valueDec=0,e.valueHex&&this.setValueHex(),t!==void 0&&(this.valueDec=t)}setValueHex(){this.valueHexView.length>=4?(this.warnings.push("Too big Integer for decoding, hex only"),this.isHexOnly=!0,this._valueDec=0):(this.isHexOnly=!1,this.valueHexView.length>0&&(this._valueDec=Gi.call(this)))}set valueDec(t){this._valueDec=t,this.isHexOnly=!1,this.valueHexView=new Uint8Array($a(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=Ah(ja(n),e),o="-";break;default:e=Bh(e,ja(n))}n++,s>>=1}}for(let a=0;a<e.length;a++)e[a]&&(c=!0),c&&(o+=za.charAt(e[a]));return c===!1&&(o+=za.charAt(0)),o}};sc=Gr;Gr.NAME="IntegerValueBlock";Object.defineProperty(sc.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var ic,nt=class r extends dt{constructor(t={}){super(t,Gr),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return Un(),BigInt(this.valueBlock.toString())}static fromBigInt(t){Un();let e=BigInt(t),n=new qr,s=e.toString(16).replace(/^-/,""),i=new Uint8Array(O.Convert.FromHex(s));if(e<0){let c=new Uint8Array(i.length+(i[0]&128?1:0));c[0]|=128;let f=BigInt(`0x${O.Convert.ToHex(c)}`)+e,l=O.BufferSourceConverter.toUint8Array(O.Convert.FromHex(f.toString(16)));l[0]|=128,n.write(l)}else i[0]&128&&n.write(new Uint8Array([0])),n.write(i);return new r({valueHex:n.final()})}convertToDER(){let t=new r({valueHex:this.valueBlock.valueHexView});return t.valueBlock.toDER(),t}convertFromDER(){return new r({valueHex:this.valueBlock.valueHexView[0]===0?this.valueBlock.valueHexView.subarray(1):this.valueBlock.valueHexView})}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()}`}};ic=nt;S.Integer=ic;nt.NAME="INTEGER";var oc,zn=class extends nt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};oc=zn;S.Enumerated=oc;zn.NAME="ENUMERATED";var zr=class extends fe(bt){constructor({valueDec:t=-1,isFirstSid:e=!1,...n}={}){super(n),this.valueDec=t,this.isFirstSid=e}fromBER(t,e,n){if(!n)return e;let s=O.BufferSourceConverter.toUint8Array(t);if(!le(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=He(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}set valueBigInt(t){Un();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=ve(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=O.Convert.ToHex(this.valueHexView);else if(this.isFirstSid){let e=this.valueDec;this.valueDec<=39?t="0.":this.valueDec<=79?(t="1.",e-=40):(t="2.",e-=80),t+=e.toString()}else t=this.valueDec.toString();return t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec,isFirstSid:this.isFirstSid}}};zr.NAME="sidBlock";var jn=class extends bt{constructor({value:t=xr,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let i=new zr;if(s=i.fromBER(t,s,n),s===-1)return this.blockLength=0,this.error=i.error,s;this.value.length===0&&(i.isFirstSid=!0),this.blockLength+=i.blockLength,n-=i.blockLength,this.value.push(i)}return s}toBER(t){let e=[];for(let n=0;n<this.value.length;n++){let s=this.value[n].toBER(t);if(s.byteLength===0)return this.error=this.value[n].error,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 zr;if(s>Number.MAX_SAFE_INTEGER){Un();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}};jn.NAME="ObjectIdentifierValueBlock";var ac,Mt=class extends dt{constructor(t={}){super(t,jn),this.idBlock.tagClass=1,this.idBlock.tagNumber=6}getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};ac=Mt;S.ObjectIdentifier=ac;Mt.NAME="OBJECT IDENTIFIER";var jr=class extends fe(ae){constructor({valueDec:t=0,...e}={}){super(e),this.valueDec=t}fromBER(t,e,n){if(n===0)return e;let s=O.BufferSourceConverter.toUint8Array(t);if(!le(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=He(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=ve(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=O.Convert.ToHex(this.valueHexView):t=this.valueDec.toString(),t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};jr.NAME="relativeSidBlock";var Yn=class extends bt{constructor({value:t=xr,...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}};Yn.NAME="RelativeObjectIdentifierValueBlock";var cc,Wn=class extends dt{constructor(t={}){super(t,Yn),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()}}};cc=Wn;S.RelativeObjectIdentifier=cc;Wn.NAME="RelativeObjectIdentifier";var uc,ft=class extends Be{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};uc=ft;S.Sequence=uc;ft.NAME="SEQUENCE";var lc,Zn=class extends Be{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};lc=Zn;S.Set=lc;Zn.NAME="SET";var Jn=class extends fe(bt){constructor({...t}={}){super(t),this.isHexOnly=!0,this.value=xr}toJSON(){return{...super.toJSON(),value:this.value}}};Jn.NAME="StringValueBlock";var Xn=class extends Jn{};Xn.NAME="SimpleStringValueBlock";var vt=class extends On{constructor({...t}={}){super(t,Xn)}fromBuffer(t){this.valueBlock.value=String.fromCharCode.apply(null,O.BufferSourceConverter.toUint8Array(t))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e);for(let s=0;s<e;s++)n[s]=t.charCodeAt(s);this.valueBlock.value=t}};vt.NAME="SIMPLE STRING";var Qn=class extends vt{fromBuffer(t){this.valueBlock.valueHexView=O.BufferSourceConverter.toUint8Array(t);try{this.valueBlock.value=O.Convert.ToUtf8String(t)}catch(e){this.warnings.push(`Error during "decodeURIComponent": ${e}, using raw string`),this.valueBlock.value=O.Convert.ToBinary(t)}}fromString(t){this.valueBlock.valueHexView=new Uint8Array(O.Convert.FromUtf8String(t)),this.valueBlock.value=t}};Qn.NAME="Utf8StringValueBlock";var fc,ue=class extends Qn{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};fc=ue;S.Utf8String=fc;ue.NAME="UTF8String";var ts=class extends vt{fromBuffer(t){this.valueBlock.value=O.Convert.ToUtf16String(t),this.valueBlock.valueHexView=O.BufferSourceConverter.toUint8Array(t)}fromString(t){this.valueBlock.value=t,this.valueBlock.valueHexView=new Uint8Array(O.Convert.FromUtf16String(t))}};ts.NAME="BmpStringValueBlock";var hc,es=class extends ts{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};hc=es;S.BmpString=hc;es.NAME="BMPString";var rs=class extends vt{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=ve(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}};rs.NAME="UniversalStringValueBlock";var dc,ns=class extends rs{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};dc=ns;S.UniversalString=dc;ns.NAME="UniversalString";var pc,ss=class extends vt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};pc=ss;S.NumericString=pc;ss.NAME="NumericString";var gc,is=class extends vt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};gc=is;S.PrintableString=gc;is.NAME="PrintableString";var yc,os=class extends vt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};yc=os;S.TeletexString=yc;os.NAME="TeletexString";var mc,as=class extends vt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};mc=as;S.VideotexString=mc;as.NAME="VideotexString";var bc,cs=class extends vt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};bc=cs;S.IA5String=bc;cs.NAME="IA5String";var wc,us=class extends vt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};wc=us;S.GraphicString=wc;us.NAME="GraphicString";var xc,Yr=class extends vt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};xc=Yr;S.VisibleString=xc;Yr.NAME="VisibleString";var Ec,ls=class extends vt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};Ec=ls;S.GeneralString=Ec;ls.NAME="GeneralString";var vc,fs=class extends vt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};vc=fs;S.CharacterString=vc;fs.NAME="CharacterString";var Bc,Wr=class extends Yr{constructor({value:t,valueDate:e,...n}={}){if(super(n),this.year=0,this.month=0,this.day=0,this.hour=0,this.minute=0,this.second=0,t){this.fromString(t),this.valueBlock.valueHexView=new Uint8Array(t.length);for(let s=0;s<t.length;s++)this.valueBlock.valueHexView[s]=t.charCodeAt(s)}e&&(this.fromDate(e),this.valueBlock.valueHexView=new Uint8Array(this.toBuffer())),this.idBlock.tagClass=1,this.idBlock.tagNumber=23}fromBuffer(t){this.fromString(String.fromCharCode.apply(null,O.BufferSourceConverter.toUint8Array(t)))}toBuffer(){let t=this.toString(),e=new ArrayBuffer(t.length),n=new Uint8Array(e);for(let s=0;s<t.length;s++)n[s]=t.charCodeAt(s);return e}fromDate(t){this.year=t.getUTCFullYear(),this.month=t.getUTCMonth()+1,this.day=t.getUTCDate(),this.hour=t.getUTCHours(),this.minute=t.getUTCMinutes(),this.second=t.getUTCSeconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second))}fromString(t){let n=/(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})Z/ig.exec(t);if(n===null){this.error="Wrong input string for conversion";return}let s=parseInt(n[1],10);s>=50?this.year=1900+s:this.year=2e3+s,this.month=parseInt(n[2],10),this.day=parseInt(n[3],10),this.hour=parseInt(n[4],10),this.minute=parseInt(n[5],10),this.second=parseInt(n[6],10)}toString(t="iso"){if(t==="iso"){let e=new Array(7);return e[0]=kt(this.year<2e3?this.year-1900:this.year-2e3,2),e[1]=kt(this.month,2),e[2]=kt(this.day,2),e[3]=kt(this.hour,2),e[4]=kt(this.minute,2),e[5]=kt(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}}};Bc=Wr;S.UTCTime=Bc;Wr.NAME="UTCTime";var Ac,hs=class extends Wr{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,p=n.indexOf("+"),x="";if(p===-1&&(p=n.indexOf("-"),u=-1),p!==-1){if(x=n.substring(p+1),n=n.substring(0,p),x.length!==2&&x.length!==4)throw new Error("Wrong input string for conversion");let y=parseInt(x.substring(0,2),10);if(isNaN(y.valueOf()))throw new Error("Wrong input string for conversion");if(c=u*y,x.length===4){if(y=parseInt(x.substring(2,4),10),isNaN(y.valueOf()))throw new Error("Wrong input string for conversion");a=u*y}}}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(kt(this.year,4)),e.push(kt(this.month,2)),e.push(kt(this.day,2)),e.push(kt(this.hour,2)),e.push(kt(this.minute,2)),e.push(kt(this.second,2)),this.millisecond!==0&&(e.push("."),e.push(kt(this.millisecond,3))),e.push("Z"),e.join("")}return super.toString(t)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};Ac=hs;S.GeneralizedTime=Ac;hs.NAME="GeneralizedTime";var Sc,ds=class extends ue{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};Sc=ds;S.DATE=Sc;ds.NAME="DATE";var Ic,ps=class extends ue{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};Ic=ps;S.TimeOfDay=Ic;ps.NAME="TimeOfDay";var kc,gs=class extends ue{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};kc=gs;S.DateTime=kc;gs.NAME="DateTime";var Rc,ys=class extends ue{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};Rc=ys;S.Duration=Rc;ys.NAME="Duration";var Nc,ms=class extends ue{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};Nc=ms;S.TIME=Nc;ms.NAME="TIME";function Ih(r){let{result:t}=Er(r),e=t.valueBlock.value;return{n:z(Yt(e[1].toBigInt()),"base64url"),e:z(Yt(e[2].toBigInt()),"base64url"),d:z(Yt(e[3].toBigInt()),"base64url"),p:z(Yt(e[4].toBigInt()),"base64url"),q:z(Yt(e[5].toBigInt()),"base64url"),dp:z(Yt(e[6].toBigInt()),"base64url"),dq:z(Yt(e[7].toBigInt()),"base64url"),qi:z(Yt(e[8].toBigInt()),"base64url"),kty:"RSA",alg:"RS256"}}function kh(r){if(r.n==null||r.e==null||r.d==null||r.p==null||r.q==null||r.dp==null||r.dq==null||r.qi==null)throw new B("JWK was missing components","ERR_INVALID_PARAMETERS");let e=new ft({value:[new nt({value:0}),nt.fromBigInt(Wt(F(r.n,"base64url"))),nt.fromBigInt(Wt(F(r.e,"base64url"))),nt.fromBigInt(Wt(F(r.d,"base64url"))),nt.fromBigInt(Wt(F(r.p,"base64url"))),nt.fromBigInt(Wt(F(r.q,"base64url"))),nt.fromBigInt(Wt(F(r.dp,"base64url"))),nt.fromBigInt(Wt(F(r.dq,"base64url"))),nt.fromBigInt(Wt(F(r.qi,"base64url")))]}).toBER();return new Uint8Array(e,0,e.byteLength)}function Rh(r){let{result:t}=Er(r),e=t.valueBlock.value[1].valueBlock.value[0].valueBlock.value;return{kty:"RSA",n:z(Yt(e[0].toBigInt()),"base64url"),e:z(Yt(e[1].toBigInt()),"base64url")}}function Nh(r){if(r.n==null||r.e==null)throw new B("JWK was missing components","ERR_INVALID_PARAMETERS");let e=new ft({value:[new ft({value:[new Mt({value:"1.2.840.113549.1.1.1"}),new Ae]}),new wr({valueHex:new ft({value:[nt.fromBigInt(Wt(F(r.n,"base64url"))),nt.fromBigInt(Wt(F(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 Wt(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 _h=16,Yi=32,Wi=1e4;async function Th(r,t){let e=Y.get(),s=new ft({value:[new nt({value:0}),new ft({value:[new Mt({value:"1.2.840.113549.1.1.1"}),new Ae]}),new ce({valueHex:r.marshal()})]}).toBER(),i=new Uint8Array(s,0,s.byteLength),o=zt(_h),c=await qi(Dr,t,o,{c:Wi,dkLen:Yi}),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 ce({valueHex:o}),new nt({value:Wi}),new nt({value:Yi}),new ft({value:[new Mt({value:"1.2.840.113549.2.11"}),new Ae]})]}),p=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 ce({valueHex:a})]})]})]}),y=new ft({value:[p,new ce({valueHex:l})]}).toBER(),h=new Uint8Array(y,0,y.byteLength);return["-----BEGIN ENCRYPTED PRIVATE KEY-----",...z(h,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
|
7
|
-
`)}async function Zi(r,t){let e=Y.get(),n;if(r.includes("-----BEGIN ENCRYPTED PRIVATE KEY-----")){let s=F(r.replace("-----BEGIN ENCRYPTED PRIVATE KEY-----","").replace("-----END ENCRYPTED PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:i}=Er(s),{iv:o,salt:c,iterations:a,keySize:f,cipherText:l}=Ch(i),u=await qi(Dr,t,c,{c:a,dkLen:f}),p=await e.subtle.importKey("raw",u,"AES-CBC",!1,["decrypt"]),x=Zr(await e.subtle.decrypt({name:"AES-CBC",iv:o},p,l)),{result:y}=Er(x);n=_c(y)}else if(r.includes("-----BEGIN PRIVATE KEY-----")){let s=F(r.replace("-----BEGIN PRIVATE KEY-----","").replace("-----END PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:i}=Er(s);n=_c(i)}else throw new B("Could not parse private key from PEM data","ERR_INVALID_PARAMETERS");return Ji(n)}function Ch(r){let t=r.valueBlock.value[0];if(t.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.13")throw new B("Only pkcs5PBES2 encrypted private keys are supported","ERR_INVALID_PARAMS");let n=t.valueBlock.value[1].valueBlock.value[0];if(n.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.12")throw new B("Only pkcs5PBKDF2 key derivation functions are supported","ERR_INVALID_PARAMS");let i=n.valueBlock.value[1],o=Zr(i.valueBlock.value[0].getValue()),c=Wi,a=Yi;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 B("Could not derive key size and iterations from PEM file - please use @libp2p/rsa to re-import your key","ERR_INVALID_PARAMS");let f=t.valueBlock.value[1].valueBlock.value[1],l=f.valueBlock.value[0].toString();if(l!=="OBJECT IDENTIFIER : 1.2.840.113549.3.7"){if(l!=="OBJECT IDENTIFIER : 1.3.14.3.2.7"){if(l!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.2"){if(l!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.22"){if(l!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.42")throw new B("Only AES-CBC encryption schemes are supported","ERR_INVALID_PARAMS")}}}}let u=Zr(f.valueBlock.value[1].getValue());return{cipherText:Zr(r.valueBlock.value[1].getValue()),salt:o,iterations:c,keySize:a,iv:u}}function _c(r){return Zr(r.valueBlock.value[2].getValue())}function Zr(r){return new Uint8Array(r,0,r.byteLength)}async function Tc(r){let t=await Y.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 Uc(t);return{privateKey:e[0],publicKey:e[1]}}async function Xi(r){let e=[await Y.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["sign"]),await Lh(r)],n=await Uc({privateKey:e[0],publicKey:e[1]});return{privateKey:n[0],publicKey:n[1]}}async function Cc(r,t){let e=await Y.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await Y.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},e,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(n,0,n.byteLength)}async function Lc(r,t,e){let n=await Y.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return Y.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,t,e instanceof Uint8Array?e:e.subarray())}async function Uc(r){if(r.privateKey==null||r.publicKey==null)throw new B("Private and public key are required","ERR_INVALID_PARAMETERS");return Promise.all([Y.get().subtle.exportKey("jwk",r.privateKey),Y.get().subtle.exportKey("jwk",r.publicKey)])}async function Lh(r){return Y.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 ws(r){if(r.kty!=="RSA")throw new B("invalid key type","ERR_INVALID_KEY_TYPE");if(r.n==null)throw new B("invalid key modulus","ERR_INVALID_KEY_MODULUS");return F(r.n,"base64url").length*8}var Ke=8192,Me=class{_key;constructor(t){this._key=t}verify(t,e){return Lc(this._key,e,t)}marshal(){return Se.jwkToPkix(this._key)}get bytes(){return Vt.encode({Type:j.RSA,Data:this.marshal()}).subarray()}equals(t){return pt(this.bytes,t.bytes)}hash(){let t=ot.digest(this.bytes);return Nt(t)?t.then(({bytes:e})=>e):t.bytes}},Ie=class{_key;_publicKey;constructor(t,e){this._key=t,this._publicKey=e}genSecret(){return zt(16)}sign(t){return Cc(this._key,t)}get public(){if(this._publicKey==null)throw new B("public key not provided","ERR_PUBKEY_NOT_PROVIDED");return new Me(this._publicKey)}marshal(){return Se.jwkToPkcs1(this._key)}get bytes(){return Ht.encode({Type:j.RSA,Data:this.marshal()}).subarray()}equals(t){return pt(this.bytes,t.bytes)}hash(){let t=ot.digest(this.bytes);return Nt(t)?t.then(({bytes:e})=>e):t.bytes}async id(){let t=await this.public.hash();return z(t,"base58btc")}async export(t,e="pkcs-8"){if(e==="pkcs-8")return Se.exportToPem(this,t);if(e==="libp2p-key")return pr(this.bytes,t);throw new B(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};async function Ji(r){let t=Se.pkcs1ToJwk(r);if(ws(t)>Ke)throw new B("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await Xi(t);return new Ie(e.privateKey,e.publicKey)}function Dh(r){let t=Se.pkixToJwk(r);if(ws(t)>Ke)throw new B("key size is too large","ERR_KEY_SIZE_TOO_LARGE");return new Me(t)}async function Ph(r){if(ws(r)>Ke)throw new B("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await Xi(r);return new Ie(t.privateKey,t.publicKey)}async function Oh(r){if(r>Ke)throw new B("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await Tc(r);return new Ie(t.privateKey,t.publicKey)}var so={};rt(so,{Secp256k1PrivateKey:()=>$e,Secp256k1PublicKey:()=>qe,generateKeyPair:()=>Zh,unmarshalSecp256k1PrivateKey:()=>Yh,unmarshalSecp256k1PublicKey:()=>Wh});var Vh=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]),ke=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),Re=new Uint32Array(64),to=class extends lr{constructor(){super(64,32,8,!1),this.A=ke[0]|0,this.B=ke[1]|0,this.C=ke[2]|0,this.D=ke[3]|0,this.E=ke[4]|0,this.F=ke[5]|0,this.G=ke[6]|0,this.H=ke[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)Re[u]=t.getUint32(e,!1);for(let u=16;u<64;u++){let p=Re[u-15],x=Re[u-2],y=Lt(p,7)^Lt(p,18)^p>>>3,h=Lt(x,17)^Lt(x,19)^x>>>10;Re[u]=h+Re[u-7]+y+Re[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 p=Lt(c,6)^Lt(c,11)^Lt(c,25),x=l+p+na(c,a,f)+Vh[u]+Re[u]|0,h=(Lt(n,2)^Lt(n,13)^Lt(n,22))+sa(n,s,i)|0;l=f,f=a,a=c,c=o+x|0,o=i,i=s,s=n,n=x+h|0}n=n+this.A|0,s=s+this.B|0,i=i+this.C|0,o=o+this.D|0,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(){Re.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var Dc=pn(()=>new to);function Pc(r){r.lowS!==void 0&&Ut("lowS",r.lowS),r.prehash!==void 0&&Ut("prehash",r.prehash)}function Hh(r){let t=Vr(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:Mh,hexToBytes:Kh}=mn,Fe={Err:class extends Error{constructor(t=""){super(t)}},_parseInt(r){let{Err:t}=Fe;if(r.length<2||r[0]!==2)throw new t("Invalid signature integer tag");let e=r[1],n=r.subarray(2,e+2);if(!e||n.length!==e)throw new t("Invalid signature integer: wrong length");if(n[0]&128)throw new t("Invalid signature integer: negative");if(n[0]===0&&!(n[1]&128))throw new t("Invalid signature integer: unnecessary leading zero");return{d:Mh(n),l:r.subarray(e+2)}},toSig(r){let{Err:t}=Fe,e=typeof r=="string"?Kh(r):r;fr(e);let n=e.length;if(n<2||e[0]!=48)throw new t("Invalid signature tag");if(e[1]!==n-2)throw new t("Invalid signature: incorrect length");let{d:s,l:i}=Fe._parseInt(e.subarray(2)),{d:o,l:c}=Fe._parseInt(i);if(c.length)throw new t("Invalid signature: left bytes after parsing");return{r:s,s:o}},hexFromSig(r){let t=f=>Number.parseInt(f[0],16)&8?"00"+f:f,e=f=>{let l=f.toString(16);return l.length&1?`0${l}`:l},n=t(e(r.s)),s=t(e(r.r)),i=n.length/2,o=s.length/2,c=e(i),a=e(o);return`30${e(o+i+4)}02${a}${s}02${c}${n}`}},Ne=BigInt(0),ht=BigInt(1),gy=BigInt(2),Oc=BigInt(3),yy=BigInt(4);function Fh(r){let t=Hh(r),{Fp:e}=t,n=t.toBytes||((y,h,d)=>{let E=h.toAffine();return ne(Uint8Array.from([4]),e.toBytes(E.x),e.toBytes(E.y))}),s=t.fromBytes||(y=>{let h=y.subarray(1),d=e.fromBytes(h.subarray(0,e.BYTES)),E=e.fromBytes(h.subarray(e.BYTES,2*e.BYTES));return{x:d,y:E}});function i(y){let{a:h,b:d}=t,E=e.sqr(y),b=e.mul(E,y);return e.add(e.add(b,e.mul(y,h)),d)}if(!e.eql(e.sqr(t.Gy),i(t.Gx)))throw new Error("bad generator point: equation left != right");function o(y){return Pr(y,ht,t.n)}function c(y){let{allowedPrivateKeyLengths:h,nByteLength:d,wrapPrivateKey:E,n:b}=t;if(h&&typeof y!="bigint"){if(be(y)&&(y=ee(y)),typeof y!="string"||!h.includes(y.length))throw new Error("Invalid key");y=y.padStart(d*2,"0")}let w;try{w=typeof y=="bigint"?y:re(tt("private key",y,d))}catch{throw new Error(`private key must be ${d} bytes, hex or bigint, not ${typeof y}`)}return E&&(w=G(w,b)),St("private key",w,ht,b),w}function a(y){if(!(y instanceof u))throw new Error("ProjectivePoint expected")}let f=Ue((y,h)=>{let{px:d,py:E,pz:b}=y;if(e.eql(b,e.ONE))return{x:d,y:E};let w=y.is0();h==null&&(h=w?e.ONE:e.inv(b));let _=e.mul(d,h),k=e.mul(E,h),I=e.mul(b,h);if(w)return{x:e.ZERO,y:e.ZERO};if(!e.eql(I,e.ONE))throw new Error("invZ was invalid");return{x:_,y:k}}),l=Ue(y=>{if(y.is0()){if(t.allowInfinityPoint&&!e.is0(y.py))return;throw new Error("bad point: ZERO")}let{x:h,y:d}=y.toAffine();if(!e.isValid(h)||!e.isValid(d))throw new Error("bad point: x or y not FE");let E=e.sqr(d),b=i(h);if(!e.eql(E,b))throw new Error("bad point: equation left != right");if(!y.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});class u{constructor(h,d,E){if(this.px=h,this.py=d,this.pz=E,h==null||!e.isValid(h))throw new Error("x required");if(d==null||!e.isValid(d))throw new Error("y required");if(E==null||!e.isValid(E))throw new Error("z required");Object.freeze(this)}static fromAffine(h){let{x:d,y:E}=h||{};if(!h||!e.isValid(d)||!e.isValid(E))throw new Error("invalid affine point");if(h instanceof u)throw new Error("projective point not allowed");let b=w=>e.eql(w,e.ZERO);return b(d)&&b(E)?u.ZERO:new u(d,E,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(h){let d=e.invertBatch(h.map(E=>E.pz));return h.map((E,b)=>E.toAffine(d[b])).map(u.fromAffine)}static fromHex(h){let d=u.fromAffine(s(tt("pointHex",h)));return d.assertValidity(),d}static fromPrivateKey(h){return u.BASE.multiply(c(h))}_setWindowSize(h){x.setWindowSize(this,h)}assertValidity(){l(this)}hasEvenY(){let{y:h}=this.toAffine();if(e.isOdd)return!e.isOdd(h);throw new Error("Field doesn't support isOdd")}equals(h){a(h);let{px:d,py:E,pz:b}=this,{px:w,py:_,pz:k}=h,I=e.eql(e.mul(d,k),e.mul(w,b)),T=e.eql(e.mul(E,k),e.mul(_,b));return I&&T}negate(){return new u(this.px,e.neg(this.py),this.pz)}double(){let{a:h,b:d}=t,E=e.mul(d,Oc),{px:b,py:w,pz:_}=this,k=e.ZERO,I=e.ZERO,T=e.ZERO,R=e.mul(b,b),$=e.mul(w,w),V=e.mul(_,_),H=e.mul(b,w);return H=e.add(H,H),T=e.mul(b,_),T=e.add(T,T),k=e.mul(h,T),I=e.mul(E,V),I=e.add(k,I),k=e.sub($,I),I=e.add($,I),I=e.mul(k,I),k=e.mul(H,k),T=e.mul(E,T),V=e.mul(h,V),H=e.sub(R,V),H=e.mul(h,H),H=e.add(H,T),T=e.add(R,R),R=e.add(T,R),R=e.add(R,V),R=e.mul(R,H),I=e.add(I,R),V=e.mul(w,_),V=e.add(V,V),R=e.mul(V,H),k=e.sub(k,R),T=e.mul(V,$),T=e.add(T,T),T=e.add(T,T),new u(k,I,T)}add(h){a(h);let{px:d,py:E,pz:b}=this,{px:w,py:_,pz:k}=h,I=e.ZERO,T=e.ZERO,R=e.ZERO,$=t.a,V=e.mul(t.b,Oc),H=e.mul(d,w),et=e.mul(E,_),st=e.mul(b,k),N=e.add(d,E),m=e.add(w,_);N=e.mul(N,m),m=e.add(H,et),N=e.sub(N,m),m=e.add(d,b);let g=e.add(w,k);return m=e.mul(m,g),g=e.add(H,st),m=e.sub(m,g),g=e.add(E,b),I=e.add(_,k),g=e.mul(g,I),I=e.add(et,st),g=e.sub(g,I),R=e.mul($,m),I=e.mul(V,st),R=e.add(I,R),I=e.sub(et,R),R=e.add(et,R),T=e.mul(I,R),et=e.add(H,H),et=e.add(et,H),st=e.mul($,st),m=e.mul(V,m),et=e.add(et,st),st=e.sub(H,st),st=e.mul($,st),m=e.add(m,st),H=e.mul(et,m),T=e.add(T,H),H=e.mul(g,m),I=e.mul(N,I),I=e.sub(I,H),H=e.mul(N,et),R=e.mul(g,R),R=e.add(R,H),new u(I,T,R)}subtract(h){return this.add(h.negate())}is0(){return this.equals(u.ZERO)}wNAF(h){return x.wNAFCached(this,h,u.normalizeZ)}multiplyUnsafe(h){St("scalar",h,Ne,t.n);let d=u.ZERO;if(h===Ne)return d;if(h===ht)return this;let{endo:E}=t;if(!E)return x.unsafeLadder(this,h);let{k1neg:b,k1:w,k2neg:_,k2:k}=E.splitScalar(h),I=d,T=d,R=this;for(;w>Ne||k>Ne;)w&ht&&(I=I.add(R)),k&ht&&(T=T.add(R)),R=R.double(),w>>=ht,k>>=ht;return b&&(I=I.negate()),_&&(T=T.negate()),T=new u(e.mul(T.px,E.beta),T.py,T.pz),I.add(T)}multiply(h){let{endo:d,n:E}=t;St("scalar",h,ht,E);let b,w;if(d){let{k1neg:_,k1:k,k2neg:I,k2:T}=d.splitScalar(h),{p:R,f:$}=this.wNAF(k),{p:V,f:H}=this.wNAF(T);R=x.constTimeNegate(_,R),V=x.constTimeNegate(I,V),V=new u(e.mul(V.px,d.beta),V.py,V.pz),b=R.add(V),w=$.add(H)}else{let{p:_,f:k}=this.wNAF(h);b=_,w=k}return u.normalizeZ([b,w])[0]}multiplyAndAddUnsafe(h,d,E){let b=u.BASE,w=(k,I)=>I===Ne||I===ht||!k.equals(b)?k.multiplyUnsafe(I):k.multiply(I),_=w(this,d).add(w(h,E));return _.is0()?void 0:_}toAffine(h){return f(this,h)}isTorsionFree(){let{h,isTorsionFree:d}=t;if(h===ht)return!0;if(d)return d(u,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h,clearCofactor:d}=t;return h===ht?this:d?d(u,this):this.multiplyUnsafe(t.h)}toRawBytes(h=!0){return Ut("isCompressed",h),this.assertValidity(),n(u,this,h)}toHex(h=!0){return Ut("isCompressed",h),ee(this.toRawBytes(h))}}u.BASE=new u(t.Gx,t.Gy,e.ONE),u.ZERO=new u(e.ZERO,e.ONE,e.ZERO);let p=t.nBitLength,x=xn(u,t.endo?Math.ceil(p/2):p);return{CURVE:t,ProjectivePoint:u,normPrivateKeyToScalar:c,weierstrassEquation:i,isWithinCurveOrder:o}}function qh(r){let t=Vr(r);return Gt(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function Vc(r){let t=qh(r),{Fp:e,n}=t,s=e.BYTES+1,i=2*e.BYTES+1;function o(N){return G(N,n)}function c(N){return bn(N,n)}let{ProjectivePoint:a,normPrivateKeyToScalar:f,weierstrassEquation:l,isWithinCurveOrder:u}=Fh({...t,toBytes(N,m,g){let v=m.toAffine(),A=e.toBytes(v.x),C=ne;return Ut("isCompressed",g),g?C(Uint8Array.from([m.hasEvenY()?2:3]),A):C(Uint8Array.from([4]),A,e.toBytes(v.y))},fromBytes(N){let m=N.length,g=N[0],v=N.subarray(1);if(m===s&&(g===2||g===3)){let A=re(v);if(!Pr(A,ht,e.ORDER))throw new Error("Point is not on curve");let C=l(A),L;try{L=e.sqrt(C)}catch(P){let K=P instanceof Error?": "+P.message:"";throw new Error("Point is not on curve"+K)}let U=(L&ht)===ht;return(g&1)===1!==U&&(L=e.neg(L)),{x:A,y:L}}else if(m===i&&g===4){let A=e.fromBytes(v.subarray(0,e.BYTES)),C=e.fromBytes(v.subarray(e.BYTES,2*e.BYTES));return{x:A,y:C}}else throw new Error(`Point of length ${m} was invalid. Expected ${s} compressed bytes or ${i} uncompressed bytes`)}}),p=N=>ee(xe(N,t.nByteLength));function x(N){let m=n>>ht;return N>m}function y(N){return x(N)?o(-N):N}let h=(N,m,g)=>re(N.slice(m,g));class d{constructor(m,g,v){this.r=m,this.s=g,this.recovery=v,this.assertValidity()}static fromCompact(m){let g=t.nByteLength;return m=tt("compactSignature",m,g*2),new d(h(m,0,g),h(m,g,2*g))}static fromDER(m){let{r:g,s:v}=Fe.toSig(tt("DER",m));return new d(g,v)}assertValidity(){St("r",this.r,ht,n),St("s",this.s,ht,n)}addRecoveryBit(m){return new d(this.r,this.s,m)}recoverPublicKey(m){let{r:g,s:v,recovery:A}=this,C=I(tt("msgHash",m));if(A==null||![0,1,2,3].includes(A))throw new Error("recovery id invalid");let L=A===2||A===3?g+t.n:g;if(L>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let U=A&1?"03":"02",M=a.fromHex(U+p(L)),P=c(L),K=o(-C*P),J=o(v*P),X=a.BASE.multiplyAndAddUnsafe(M,K,J);if(!X)throw new Error("point at infinify");return X.assertValidity(),X}hasHighS(){return x(this.s)}normalizeS(){return this.hasHighS()?new d(this.r,o(-this.s),this.recovery):this}toDERRawBytes(){return Ce(this.toDERHex())}toDERHex(){return Fe.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return Ce(this.toCompactHex())}toCompactHex(){return p(this.r)+p(this.s)}}let E={isValidPrivateKey(N){try{return f(N),!0}catch{return!1}},normPrivateKeyToScalar:f,randomPrivateKey:()=>{let N=yi(t.n);return da(t.randomBytes(N),t.n)},precompute(N=8,m=a.BASE){return m._setWindowSize(N),m.multiply(BigInt(3)),m}};function b(N,m=!0){return a.fromPrivateKey(N).toRawBytes(m)}function w(N){let m=be(N),g=typeof N=="string",v=(m||g)&&N.length;return m?v===s||v===i:g?v===2*s||v===2*i:N instanceof a}function _(N,m,g=!0){if(w(N))throw new Error("first arg must be private key");if(!w(m))throw new Error("second arg must be public key");return a.fromHex(m).multiply(f(N)).toRawBytes(g)}let k=t.bits2int||function(N){let m=re(N),g=N.length*8-t.nBitLength;return g>0?m>>BigInt(g):m},I=t.bits2int_modN||function(N){return o(k(N))},T=Or(t.nBitLength);function R(N){return St(`num < 2^${t.nBitLength}`,N,Ne,T),xe(N,t.nByteLength)}function $(N,m,g=V){if(["recovered","canonical"].some(ut=>ut in g))throw new Error("sign() legacy options not supported");let{hash:v,randomBytes:A}=t,{lowS:C,prehash:L,extraEntropy:U}=g;C==null&&(C=!0),N=tt("msgHash",N),Pc(g),L&&(N=tt("prehashed msgHash",v(N)));let M=I(N),P=f(m),K=[R(P),R(M)];if(U!=null&&U!==!1){let ut=U===!0?A(e.BYTES):U;K.push(tt("extraEntropy",ut))}let J=ne(...K),X=M;function At(ut){let it=k(ut);if(!u(it))return;let Tt=c(it),lt=a.BASE.multiply(it).toAffine(),Ct=o(lt.x);if(Ct===Ne)return;let Te=o(Tt*o(X+Ct*P));if(Te===Ne)return;let Ar=(lt.x===Ct?0:2)|Number(lt.y&ht),an=Te;return C&&x(Te)&&(an=y(Te),Ar^=1),new d(Ct,an,Ar)}return{seed:J,k2sig:At}}let V={lowS:t.lowS,prehash:!1},H={lowS:t.lowS,prehash:!1};function et(N,m,g=V){let{seed:v,k2sig:A}=$(N,m,g),C=t;return hi(C.hash.outputLen,C.nByteLength,C.hmac)(v,A)}a.BASE._setWindowSize(8);function st(N,m,g,v=H){let A=N;if(m=tt("msgHash",m),g=tt("publicKey",g),"strict"in v)throw new Error("options.strict was renamed to lowS");Pc(v);let{lowS:C,prehash:L}=v,U,M;try{if(typeof A=="string"||be(A))try{U=d.fromDER(A)}catch(lt){if(!(lt instanceof Fe.Err))throw lt;U=d.fromCompact(A)}else if(typeof A=="object"&&typeof A.r=="bigint"&&typeof A.s=="bigint"){let{r:lt,s:Ct}=A;U=new d(lt,Ct)}else throw new Error("PARSE");M=a.fromHex(g)}catch(lt){if(lt.message==="PARSE")throw new Error("signature must be Signature instance, Uint8Array or hex string");return!1}if(C&&U.hasHighS())return!1;L&&(m=t.hash(m));let{r:P,s:K}=U,J=I(m),X=c(K),At=o(J*X),ut=o(P*X),it=a.BASE.multiplyAndAddUnsafe(M,At,ut)?.toAffine();return it?o(it.x)===P:!1}return{CURVE:t,getPublicKey:b,getSharedSecret:_,sign:et,verify:st,ProjectivePoint:a,Signature:d,utils:E}}function $h(r){return{hash:r,hmac:(t,...e)=>Kr(r,t,ii(...e)),randomBytes:ur}}function Hc(r,t){let e=n=>Vc({...r,...$h(n)});return Object.freeze({...e(t),create:e})}var Fc=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),Mc=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),Gh=BigInt(1),eo=BigInt(2),Kc=(r,t)=>(r+t/eo)/t;function zh(r){let t=Fc,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=Z(l,e,t)*l%t,p=Z(u,e,t)*l%t,x=Z(p,eo,t)*f%t,y=Z(x,s,t)*x%t,h=Z(y,i,t)*y%t,d=Z(h,c,t)*h%t,E=Z(d,a,t)*d%t,b=Z(E,c,t)*h%t,w=Z(b,e,t)*l%t,_=Z(w,o,t)*y%t,k=Z(_,n,t)*f%t,I=Z(k,eo,t);if(!ro.eql(ro.sqr(I),r))throw new Error("Cannot find square root");return I}var ro=wn(Fc,void 0,void 0,{sqrt:zh}),Ft=Hc({a:BigInt(0),b:BigInt(7),Fp:ro,n:Mc,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=Mc,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-Gh*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),s=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),i=e,o=BigInt("0x100000000000000000000000000000000"),c=Kc(i*r,t),a=Kc(-n*r,t),f=G(r-c*e-a*s,t),l=G(-c*n-a*i,t),u=f>o,p=l>o;if(u&&(f=t-f),p&&(l=t-l),f>o||l>o)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:u,k1:f,k2neg:p,k2:l}}}},Dc),Sy=BigInt(0);var Iy=Ft.ProjectivePoint;function qc(){return Ft.utils.randomPrivateKey()}function $c(r,t){let e=ot.digest(t instanceof Uint8Array?t:t.subarray());if(Nt(e))return e.then(({digest:n})=>Ft.sign(n,r).toDERRawBytes()).catch(n=>{throw new B(String(n),"ERR_INVALID_INPUT")});try{return Ft.sign(e.digest,r).toDERRawBytes()}catch(n){throw new B(String(n),"ERR_INVALID_INPUT")}}function Gc(r,t,e){let n=ot.digest(e instanceof Uint8Array?e:e.subarray());if(Nt(n))return n.then(({digest:s})=>Ft.verify(t,s,r)).catch(s=>{throw new B(String(s),"ERR_INVALID_INPUT")});try{return Ft.verify(t,n.digest,r)}catch(s){throw new B(String(s),"ERR_INVALID_INPUT")}}function zc(r){return Ft.ProjectivePoint.fromHex(r).toRawBytes(!0)}function jc(r){try{Ft.getPublicKey(r,!0)}catch(t){throw new B(String(t),"ERR_INVALID_PRIVATE_KEY")}}function no(r){try{Ft.ProjectivePoint.fromHex(r)}catch(t){throw new B(String(t),"ERR_INVALID_PUBLIC_KEY")}}function Yc(r){try{return Ft.getPublicKey(r,!0)}catch(t){throw new B(String(t),"ERR_INVALID_PRIVATE_KEY")}}var qe=class{_key;constructor(t){no(t),this._key=t}verify(t,e){return Gc(this._key,e,t)}marshal(){return zc(this._key)}get bytes(){return Vt.encode({Type:j.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return pt(this.bytes,t.bytes)}async hash(){let t=ot.digest(this.bytes),e;return Nt(t)?{bytes:e}=await t:e=t.bytes,e}},$e=class{_key;_publicKey;constructor(t,e){this._key=t,this._publicKey=e??Yc(t),jc(this._key),no(this._publicKey)}sign(t){return $c(this._key,t)}get public(){return new qe(this._publicKey)}marshal(){return this._key}get bytes(){return Ht.encode({Type:j.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return pt(this.bytes,t.bytes)}hash(){let t=ot.digest(this.bytes);return Nt(t)?t.then(({bytes:e})=>e):t.bytes}async id(){let t=await this.public.hash();return z(t,"base58btc")}async export(t,e="libp2p-key"){if(e==="libp2p-key")return pr(this.bytes,t);throw new B(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function Yh(r){return new $e(r)}function Wh(r){return new qe(r)}async function Zh(){let r=qc();return new $e(r)}var he={rsa:Qi,ed25519:Ki,secp256k1:so};function io(r){let t=Object.keys(he).join(" / ");return new B(`invalid or unsupported key type ${r}. Must be ${t}`,"ERR_UNSUPPORTED_KEY_TYPE")}function oo(r){if(r=r.toLowerCase(),r==="rsa"||r==="ed25519"||r==="secp256k1")return he[r];throw io(r)}async function Jh(r,t){return oo(r).generateKeyPair(t??2048)}async function Xh(r,t,e){if(r.toLowerCase()!=="ed25519")throw new B("Seed key derivation is unimplemented for RSA or secp256k1","ERR_UNSUPPORTED_KEY_DERIVATION_TYPE");return Mi(t)}function Qh(r){let t=Vt.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case j.RSA:return he.rsa.unmarshalRsaPublicKey(e);case j.Ed25519:return he.ed25519.unmarshalEd25519PublicKey(e);case j.Secp256k1:return he.secp256k1.unmarshalSecp256k1PublicKey(e);default:throw io(t.Type??"unknown")}}function td(r,t){return t=(t??"rsa").toLowerCase(),oo(t),r.bytes}async function Wc(r){let t=Ht.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case j.RSA:return he.rsa.unmarshalRsaPrivateKey(e);case j.Ed25519:return he.ed25519.unmarshalEd25519PrivateKey(e);case j.Secp256k1:return he.secp256k1.unmarshalSecp256k1PrivateKey(e);default:throw io(t.Type??"RSA")}}function ed(r,t){return t=(t??"rsa").toLowerCase(),oo(t),r.bytes}async function rd(r,t){try{let e=await Ma(r,t);return await Wc(e)}catch{}if(!r.includes("BEGIN"))throw new B("Encrypted key was not a libp2p-key or a PEM file","ERR_INVALID_IMPORT_FORMAT");return Zi(r,t)}var Jc=Symbol.for("@achingbrain/uint8arraylist");function Zc(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 xs(r){return!!r?.[Jc]}var _e=class r{bufs;length;[Jc]=!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(xs(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(xs(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=Zc(this.bufs,t);return e.buf[e.index]}set(t,e){let n=Zc(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(xs(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 Et(n,s)}subarray(t,e){let{bufs:n,length:s}=this._subList(t,e);return n.length===1?n[0]:Et(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(!xs(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 p=f;p>=0;p--){let x=this.get(u+p);if(n[p]!==x){l=Math.max(1,p-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=gt(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setInt8(0,e),this.write(n,t)}getInt16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt16(0,e)}setInt16(t,e,n){let s=Xt(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=Xt(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=Xt(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigInt64(0,e,n),this.write(s,t)}getUint8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getUint8(0)}setUint8(t,e){let n=gt(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setUint8(0,e),this.write(n,t)}getUint16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint16(0,e)}setUint16(t,e,n){let s=Xt(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=Xt(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=Xt(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=Xt(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=Xt(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setFloat64(0,e,n),this.write(s,t)}equals(t){if(t==null||!(t instanceof r)||t.bufs.length!==this.bufs.length)return!1;for(let e=0;e<this.bufs.length;e++)if(!pt(this.bufs[e],t.bufs[e]))return!1;return!0}static fromUint8Arrays(t,e){let n=new r;return n.bufs=t,e==null&&(e=t.reduce((s,i)=>s+i.byteLength,0)),n.length=e,n}};function Es(){let r={};return r.promise=new Promise((t,e)=>{r.resolve=t,r.reject=e}),r}var vs=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}},vr=class{size;hwm;head;tail;constructor(t={}){this.hwm=t.splitLimit??16,this.head=new vs(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 vs(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 ao=class extends Error{type;code;constructor(t,e){super(t??"The operation was aborted"),this.type="aborted",this.code=e??"ABORT_ERR"}};function Br(r={}){return nd(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 nd(r,t){t=t??{};let e=t.onEnd,n=new vr,s,i,o,c=Es(),a=async()=>{try{return n.isEmpty()?o?{done:!0}:await new Promise((d,E)=>{i=b=>{i=null,n.push(b);try{d(r(n))}catch(w){E(w)}return s}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{c.resolve(),c=Es()})}},f=d=>i!=null?i(d):(n.push(d),s),l=d=>(n=new vr,i!=null?i({error:d}):(n.push({error:d}),s)),u=d=>{if(o)return s;if(t?.objectMode!==!0&&d?.byteLength==null)throw new Error("objectMode was not true but tried to push non-Uint8Array value");return f({done:!1,value:d})},p=d=>o?s:(o=!0,d!=null?l(d):f({done:!0})),x=()=>(n=new vr,p(),{done:!0}),y=d=>(p(d),{done:!0});if(s={[Symbol.asyncIterator](){return this},next:a,return:x,throw:y,push:u,end:p,get readableLength(){return n.size},onEmpty:async d=>{let E=d?.signal;if(E?.throwIfAborted(),n.isEmpty())return;let b,w;E!=null&&(b=new Promise((_,k)=>{w=()=>{k(new ao)},E.addEventListener("abort",w)}));try{await Promise.race([c.promise,b])}finally{w!=null&&E!=null&&E?.removeEventListener("abort",w)}}},e==null)return s;let h=s;return s={[Symbol.asyncIterator](){return this},next(){return h.next()},throw(d){return h.throw(d),e!=null&&(e(d),e=void 0),{done:!0}},return(){return h.return(),e!=null&&(e(),e=void 0),{done:!0}},push:u,end(d){return h.end(d),e!=null&&(e(d),e=void 0),s},get readableLength(){return h.readableLength},onEmpty:d=>h.onEmpty(d)},s}function sd(r){return r[Symbol.asyncIterator]!=null}function id(...r){let t=[];for(let e of r)sd(e)||t.push(e);return t.length===r.length?function*(){for(let e of t)yield*e}():async function*(){let e=Br({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 Xc=id;function Xr(r,...t){if(r==null)throw new Error("Empty pipeline");if(co(r)){let n=r;r=()=>n.source}else if(tu(r)||Qc(r)){let n=r;r=()=>n}let e=[r,...t];if(e.length>1&&co(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++)co(e[n])&&(e[n]=ad(e[n]));return od(...e)}var od=(...r)=>{let t;for(;r.length>0;)t=r.shift()(t);return t},Qc=r=>r?.[Symbol.asyncIterator]!=null,tu=r=>r?.[Symbol.iterator]!=null,co=r=>r==null?!1:r.sink!=null&&r.source!=null,ad=r=>t=>{let e=r.sink(t);if(e?.then!=null){let n=Br({objectMode:!0});e.then(()=>{n.end()},o=>{n.end(o)});let s,i=r.source;if(Qc(i))s=async function*(){yield*i,n.end()};else if(tu(i))s=function*(){yield*i,n.end()};else throw new Error("Unknown duplex source type - must be Iterable or AsyncIterable");return Xc(n,s())}return r.source};var lo=Io(ru(),1);var tn=class extends Error{constructor(t){super(t),this.name="TimeoutError"}},fo=class extends Error{constructor(t){super(),this.name="AbortError",this.message=t}},nu=r=>globalThis.DOMException===void 0?new fo(r):new DOMException(r),su=r=>{let t=r.reason===void 0?nu("This operation was aborted."):r.reason;return t instanceof Error?t:nu(t)};function ho(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:p}=t;p.aborted&&l(su(p)),p.addEventListener("abort",()=>{l(su(p))})}if(e===Number.POSITIVE_INFINITY){r.then(f,l);return}let u=new tn;o=i.setTimeout.call(void 0,()=>{if(n){try{f(n())}catch(p){l(p)}return}typeof r.cancel=="function"&&r.cancel(),s===!1?f():s instanceof Error?l(s):(u.message=s??`Promise timed out after ${e} milliseconds`,l(u))},e),(async()=>{try{f(await r)}catch(p){l(p)}})()}).finally(()=>{a.clear()});return a.clear=()=>{i.clearTimeout.call(void 0,o),o=void 0},a}function po(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 en=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=po(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 rn=class extends lo.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:en,...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=ho(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 tn&&!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 iu(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 ou(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function au(r,t){let e=iu(r).return?.();ou(e)&&e.catch(n=>{t.error("could not cause iterator to return",n)})}function As(r){return r[Symbol.asyncIterator]!=null}var Ss=r=>{let t=Pt(r),e=gt(t);return Aa(r,e),Ss.bytes=t,e};Ss.bytes=0;function Is(r,t){t=t??{};let e=t.lengthEncoder??Ss;function*n(s){let i=e(s.byteLength);i instanceof Uint8Array?yield i:yield*i,s instanceof Uint8Array?yield s:yield*s}return As(r)?async function*(){for await(let s of r)yield*n(s)}():function*(){for(let s of r)yield*n(s)}()}Is.single=(r,t)=>{t=t??{};let e=t.lengthEncoder??Ss;return new _e(e(r.byteLength),r)};var ks=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},Rs=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},Ns=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"},nn=class extends Error{name="UnexpectedEOFError";code="ERR_UNEXPECTED_EOF"};var ld=8,fd=1024*1024*4,Ge;(function(r){r[r.LENGTH=0]="LENGTH",r[r.DATA=1]="DATA"})(Ge||(Ge={}));var go=r=>{let t=Sa(r);return go.bytes=Pt(t),t};go.bytes=0;function sn(r,t){let e=new _e,n=Ge.LENGTH,s=-1,i=t?.lengthDecoder??go,o=t?.maxLengthLength??ld,c=t?.maxDataLength??fd;function*a(){for(;e.byteLength>0;){if(n===Ge.LENGTH)try{if(s=i(e),s<0)throw new ks("Invalid message length");if(s>c)throw new Rs("Message length too long");let f=i.bytes;e.consume(f),t?.onLength!=null&&t.onLength(s),n=Ge.DATA}catch(f){if(f instanceof RangeError){if(e.byteLength>o)throw new Ns("Message length length too long");break}throw f}if(n===Ge.DATA){if(e.byteLength<s)break;let f=e.sublist(0,s);e.consume(s),t?.onData!=null&&t.onData(f),yield f,n=Ge.LENGTH}}}return As(r)?async function*(){for await(let f of r)e.append(f),yield*a();if(e.byteLength>0)throw new nn("Unexpected end of input")}():function*(){for(let f of r)e.append(f),yield*a();if(e.byteLength>0)throw new nn("Unexpected end of input")}()}sn.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 sn(n,{...t??{},onLength:i=>{e=i}})};var _s=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 _e(t):t)}attachInboundStream(t){let e=()=>{au(t.source,this.log)};return this._inboundAbortController.signal.addEventListener("abort",e,{once:!0}),this._rawInboundStream=t,this.inboundStream=Xr(this._rawInboundStream,n=>sn(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=Br({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"))}}),Xr(this.outboundStream,n=>Is(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 cu(){return BigInt(`0x${z(zt(8),"base16")}`)}var uu=(r,t)=>{let e=F(t.toString(16).padStart(16,"0"),"base16"),n=new Uint8Array(r.length+e.length);return n.set(r,0),n.set(e,r.length),n},lu=r=>ot.encode(r);var fu=function(r){return Array.isArray(r)?r:[r]},dd=async r=>{if(r.sequenceNumber==null||r.from==null||r.signature==null)return!1;let t=Cr(r.from);return t.publicKey!=null?!0:r.key!=null?(await fn(r.key)).equals(t):!1},hu=async r=>{if(r.from==null)throw new B("RPC message was missing from",ct.ERR_MISSING_FROM);if(!await dd(r))return{type:"unsigned",topic:r.topic??"",data:r.data??new Uint8Array(0)};let t=Cr(r.from),e={type:"signed",from:Cr(r.from),topic:r.topic??"",sequenceNumber:gd(r.sequenceNumber??new Uint8Array(0)),data:r.data??new Uint8Array(0),signature:r.signature??new Uint8Array(0),key:r.key??t.publicKey??new Uint8Array(0)};if(e.key.length===0)throw new B("Signed RPC message was missing key",ct.ERR_MISSING_KEY);return e},on=r=>r.type==="signed"?{from:r.from.multihash.bytes,data:r.data,sequenceNumber:pd(r.sequenceNumber),topic:r.topic,signature:r.signature,key:r.key}:{data:r.data,topic:r.topic},pd=r=>{let t=r.toString(16);return t.length%2!==0&&(t=`0${t}`),F(t,"base16")},gd=r=>BigInt(`0x${z(r,"base16")}`);var du=F("libp2p-pubsub:");async function pu(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=Et([du,e(on(n)).subarray()]),i=await Jr.unmarshalPrivateKey(r.privateKey);return n.signature=await i.sign(s),n.key=r.publicKey,n}async function gu(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=Et([du,t({...on(r),signature:void 0,key:void 0}).subarray()]),n=await yd(r);return Jr.unmarshalPublicKey(n).verify(e,r.signature)}async function yd(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 fn(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 yo=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=fu(n),this.enabled=e.enabled!==!1,this.started=!1,this.topics=new Map,this.subscriptions=new Set,this.peers=new Lr,this.globalSignaturePolicy=s==="StrictNoSign"?"StrictNoSign":"StrictSign",this.canRelayMessage=i,this.emitSelf=o,this.topicValidators=new Map,this.queue=new rn({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 _s(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 Xr(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 hu(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 Ur,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 B('Message type should be "signed" when signature policy is StrictSign but it was not',ct.ERR_MISSING_SIGNATURE);if(t.sequenceNumber==null)throw new B("Need seqno when signature policy is StrictSign but it was missing",ct.ERR_MISSING_SEQNO);if(t.key==null)throw new B("Need key when signature policy is StrictSign but it was missing",ct.ERR_MISSING_KEY);return uu(t.key,t.sequenceNumber);case"StrictNoSign":return lu(t.data);default:throw new B("Cannot get message id: unhandled signature policy",ct.ERR_UNHANDLED_SIGNATURE_POLICY)}}acceptFrom(t){return!0}send(t,e){let{messages:n,subscriptions:s,subscribe:i}=e;this.sendRpc(t,{subscriptions:(s??[]).map(o=>({topic:o,subscribe:!!i})),messages:(n??[]).map(on)})}sendRpc(t,e){let n=this.peers.get(t);if(n==null){this.log.error("Cannot send RPC to %p as there are no streams to it available",t);return}if(!n.isWritable){this.log.error("Cannot send RPC to %p as there is no outbound stream to it available",t);return}n.write(this.encodeRpc(e))}async validate(t,e){switch(this.globalSignaturePolicy){case"StrictNoSign":if(e.type!=="unsigned")throw new B('Message type should be "unsigned" when signature policy is StrictNoSign but it was not',ct.ERR_MISSING_SIGNATURE);if(e.signature!=null)throw new B("StrictNoSigning: signature should not be present",ct.ERR_UNEXPECTED_SIGNATURE);if(e.key!=null)throw new B("StrictNoSigning: key should not be present",ct.ERR_UNEXPECTED_KEY);if(e.sequenceNumber!=null)throw new B("StrictNoSigning: seqno should not be present",ct.ERR_UNEXPECTED_SEQNO);break;case"StrictSign":if(e.type!=="signed")throw new B('Message type should be "signed" when signature policy is StrictSign but it was not',ct.ERR_MISSING_SIGNATURE);if(e.signature==null)throw new B("StrictSigning: Signing required and no signature was present",ct.ERR_MISSING_SIGNATURE);if(e.sequenceNumber==null)throw new B("StrictSigning: Signing required and no sequenceNumber was present",ct.ERR_MISSING_SEQNO);if(!await gu(e,this.encodeMessage.bind(this)))throw new B("StrictSigning: Invalid message signature",ct.ERR_INVALID_SIGNATURE);break;default:throw new B("Cannot validate message: unhandled signature policy",ct.ERR_UNHANDLED_SIGNATURE_POLICY)}let s=this.topicValidators.get(e.topic);if(s!=null){let i=await s(t,e);if(i===Sr.Reject||i===Sr.Ignore)throw new B("Message validation failed",ct.ERR_TOPIC_VALIDATOR_REJECT)}}async buildMessage(t){switch(this.globalSignaturePolicy){case"StrictSign":return pu(this.components.peerId,t,this.encodeMessage.bind(this));case"StrictNoSign":return Promise.resolve({type:"unsigned",...t});default:throw new B("Cannot build message: unhandled signature policy",ct.ERR_UNHANDLED_SIGNATURE_POLICY)}}getSubscribers(t){if(!this.started)throw new B("not started yet","ERR_NOT_STARTED_YET");if(t==null)throw new B("topic is required","ERR_NOT_VALID_TOPIC");let e=this.topics.get(t.toString());return e==null?[]:Array.from(e.values())}async publish(t,e){if(!this.started)throw new Error("Pubsub has not started");let n={from:this.components.peerId,topic:t,data:e??new Uint8Array(0),sequenceNumber:cu()};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 Ru(md);})();
|
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);})();
|
8
8
|
/*! Bundled license information:
|
9
9
|
|
10
10
|
pvtsutils/build/index.js:
|
package/package.json
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
{
|
2
2
|
"name": "@libp2p/pubsub",
|
3
|
-
"version": "9.0.26-
|
3
|
+
"version": "9.0.26-737b3ea5b",
|
4
4
|
"description": "libp2p pubsub base class",
|
5
5
|
"license": "Apache-2.0 OR MIT",
|
6
6
|
"homepage": "https://github.com/libp2p/js-libp2p/tree/main/packages/pubsub#readme",
|
@@ -84,12 +84,12 @@
|
|
84
84
|
"test:electron-main": "aegir test -t electron-main"
|
85
85
|
},
|
86
86
|
"dependencies": {
|
87
|
-
"@libp2p/crypto": "4.1.9-
|
88
|
-
"@libp2p/interface": "1.7.0-
|
89
|
-
"@libp2p/interface-internal": "1.3.4-
|
90
|
-
"@libp2p/peer-collections": "5.2.9-
|
91
|
-
"@libp2p/peer-id": "4.2.4-
|
92
|
-
"@libp2p/utils": "5.4.9-
|
87
|
+
"@libp2p/crypto": "4.1.9-737b3ea5b",
|
88
|
+
"@libp2p/interface": "1.7.0-737b3ea5b",
|
89
|
+
"@libp2p/interface-internal": "1.3.4-737b3ea5b",
|
90
|
+
"@libp2p/peer-collections": "5.2.9-737b3ea5b",
|
91
|
+
"@libp2p/peer-id": "4.2.4-737b3ea5b",
|
92
|
+
"@libp2p/utils": "5.4.9-737b3ea5b",
|
93
93
|
"it-length-prefixed": "^9.0.4",
|
94
94
|
"it-pipe": "^3.0.1",
|
95
95
|
"it-pushable": "^3.2.3",
|
@@ -99,8 +99,8 @@
|
|
99
99
|
"uint8arrays": "^5.1.0"
|
100
100
|
},
|
101
101
|
"devDependencies": {
|
102
|
-
"@libp2p/logger": "4.0.20-
|
103
|
-
"@libp2p/peer-id-factory": "4.2.4-
|
102
|
+
"@libp2p/logger": "4.0.20-737b3ea5b",
|
103
|
+
"@libp2p/peer-id-factory": "4.2.4-737b3ea5b",
|
104
104
|
"@types/sinon": "^17.0.3",
|
105
105
|
"aegir": "^44.0.1",
|
106
106
|
"delay": "^6.0.0",
|