@libp2p/peer-record 8.0.11-656db81cf → 8.0.12-0862522fe

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.min.js CHANGED
@@ -3,7 +3,7 @@
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} :`}};ea=we;A.Constructed=ea;we.NAME="CONSTRUCTED";var on=class extends mt{fromBER(t,e,n){return e}toBER(t){return _t}};on.override="EndOfContentValueBlock";var ra,an=class extends ft{constructor(t={}){super(t,on),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};ra=an;A.EndOfContent=ra;an.NAME=yr;var na,Ze=class extends ft{constructor(t={}){super(t,mt),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}`}};na=Ze;A.Null=na;Ze.NAME="NULL";var cn=class extends se(mt){constructor({value:t,...e}={}){super(e),e.valueHex?this.valueHexView=P.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=P.BufferSourceConverter.toUint8Array(t);return ne(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,po.call(this),this.blockLength=n,e+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};cn.NAME="BooleanValueBlock";var sa,ln=class extends ft{constructor(t={}){super(t,cn),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}`}};sa=ln;A.Boolean=sa;ln.NAME="BOOLEAN";var un=class extends se(Pt){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=Pt.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let o=0;o<this.value.length;o++){let i=this.value[o].constructor.NAME;if(i===yr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(i!==Yi)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?Pt.prototype.toBER.call(this,t,e):t?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};un.NAME="OctetStringValueBlock";var oa,fn=class r extends ft{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,o;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((o=n.value)===null||o===void 0)&&o.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},un),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 o=(t instanceof ArrayBuffer?new Uint8Array(t):t).subarray(e,e+n);try{if(o.byteLength){let i=Pn(o,0,o.byteLength);i.offset!==-1&&i.offset===n&&(this.valueBlock.value=[i.result])}}catch{}}return super.fromBER(t,e,n)}onAsciiEncoding(){return this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length?we.prototype.onAsciiEncoding.call(this):`${this.constructor.NAME} : ${P.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 P.BufferSourceConverter.concat(t)}};oa=fn;A.OctetString=oa;fn.NAME=Yi;var hn=class extends se(Pt){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=Pt.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let a of this.value){let c=a.constructor.NAME;if(c===yr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==Xi)return this.error="BIT STRING may consists of BIT STRINGs only",-1;let f=a.valueBlock;if(this.unusedBits>0&&f.unusedBits>0)return this.error='Using of "unused bits" inside constructive BIT STRING allowed for least one only',-1;this.unusedBits=f.unusedBits}return s}let o=P.BufferSourceConverter.toUint8Array(t);if(!ne(this,o,e,n))return-1;let i=o.subarray(e,e+n);if(this.unusedBits=i[0],this.unusedBits>7)return this.error="Unused bits for BitString must be in range 0-7",-1;if(!this.unusedBits){let a=i.subarray(1);try{if(a.byteLength){let c=Pn(a,0,a.byteLength);c.offset!==-1&&c.offset===n-1&&(this.value=[c.result])}}catch{}}return this.valueHexView=i.subarray(1),this.blockLength=i.length,e+n}toBER(t,e){if(this.isConstructed)return Pt.prototype.toBER.call(this,t,e);if(t)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return _t;let n=new Uint8Array(this.valueHexView.length+1);return n[0]=this.unusedBits,n.set(this.valueHexView,1),n.buffer}toJSON(){return{...super.toJSON(),unusedBits:this.unusedBits,isConstructed:this.isConstructed}}};hn.NAME="BitStringValueBlock";var ia,We=class extends ft{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,o;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((o=n.value)===null||o===void 0)&&o.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},hn),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 we.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)}`}}};ia=We;A.BitString=ia;We.NAME=Xi;var aa;function vf(r,t){let e=new Uint8Array([0]),n=new Uint8Array(r),s=new Uint8Array(t),o=n.slice(0),i=o.length-1,a=s.slice(0),c=a.length-1,f=0,l=c<i?i:c,u=0;for(let h=l;h>=0;h--,u++){switch(!0){case u<a.length:f=o[i-u]+a[c-u]+e[0];break;default:f=o[i-u]+e[0]}switch(e[0]=f/10,!0){case u>=o.length:o=Xr(new Uint8Array([f%10]),o);break;default:o[i-u]=f%10}}return e[0]>0&&(o=Xr(e,o)),o}function Ji(r){if(r>=gr.length)for(let t=gr.length;t<=r;t++){let e=new Uint8Array([0]),n=gr[t-1].slice(0);for(let s=n.length-1;s>=0;s--){let o=new Uint8Array([(n[s]<<1)+e[0]]);e[0]=o[0]/10,n[s]=o[0]%10}e[0]>0&&(n=Xr(e,n)),gr.push(n)}return gr[r]}function Bf(r,t){let e=0,n=new Uint8Array(r),s=new Uint8Array(t),o=n.slice(0),i=o.length-1,a=s.slice(0),c=a.length-1,f,l=0;for(let u=c;u>=0;u--,l++)switch(f=o[i-l]-a[c-l]-e,!0){case f<0:e=1,o[i-l]=f+10;break;default:e=0,o[i-l]=f}if(e>0)for(let u=i-c+1;u>=0;u--,l++)if(f=o[i-l]-e,f<0)e=1,o[i-l]=f+10;else{e=0,o[i-l]=f;break}return o.slice()}var br=class extends se(mt){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=po.call(this)))}set valueDec(t){this._valueDec=t,this.isHexOnly=!1,this.valueHexView=new Uint8Array(ji(t))}get valueDec(){return this._valueDec}fromDER(t,e,n,s=0){let o=this.fromBER(t,e,n);if(o===-1)return o;let i=this.valueHexView;return i[0]===0&&i[1]&128?this.valueHexView=i.subarray(1):s!==0&&i.length<s&&(s-i.length>1&&(s=i.length+1),this.valueHexView=i.subarray(s-i.length)),o}toDER(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,o=this.valueHexView,i="",a=!1;for(let c=o.byteLength-1;c>=0;c--){s=o[c];for(let f=0;f<8;f++){if((s&1)===1)switch(n){case t:e=Bf(Ji(n),e),i="-";break;default:e=vf(e,Ji(n))}n++,s>>=1}}for(let c=0;c<e.length;c++)e[c]&&(a=!0),a&&(i+=Wi.charAt(e[c]));return a===!1&&(i+=Wi.charAt(0)),i}};aa=br;br.NAME="IntegerValueBlock";Object.defineProperty(aa.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var ca,ht=class r extends ft{constructor(t={}){super(t,br),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return Qr(),BigInt(this.valueBlock.toString())}static fromBigInt(t){Qr();let e=BigInt(t),n=new mr,s=e.toString(16).replace(/^-/,""),o=new Uint8Array(P.Convert.FromHex(s));if(e<0){let a=new Uint8Array(o.length+(o[0]&128?1:0));a[0]|=128;let f=BigInt(`0x${P.Convert.ToHex(a)}`)+e,l=P.BufferSourceConverter.toUint8Array(P.Convert.FromHex(f.toString(16)));l[0]|=128,n.write(l)}else o[0]&128&&n.write(new Uint8Array([0])),n.write(o);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()}`}};ca=ht;A.Integer=ca;ht.NAME="INTEGER";var la,dn=class extends ht{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};la=dn;A.Enumerated=la;dn.NAME="ENUMERATED";var wr=class extends se(mt){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=P.BufferSourceConverter.toUint8Array(t);if(!ne(this,s,e,n))return-1;let o=s.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=o[a]&127,this.blockLength++,!!(o[a]&128));a++);let i=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)i[a]=this.valueHexView[a];return this.valueHexView=i,o[this.blockLength-1]&128?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=Ue(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}set valueBigInt(t){Qr();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,o=new Uint8Array(this.blockLength);for(let i=0;i<this.blockLength-1;i++)o[i]=s[i]|128;return o[this.blockLength-1]=s[this.blockLength-1],o.buffer}let e=be(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",_t;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),o=e.byteLength-1;for(let i=0;i<o;i++)n[i]=s[i]|128;n[o]=s[o]}return n}toString(){let t="";if(this.isHexOnly)t=P.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 pn=class extends mt{constructor({value:t=Ye,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new wr;if(s=o.fromBER(t,s,n),s===-1)return this.blockLength=0,this.error=o.error,s;this.value.length===0&&(o.isFirstSid=!0),this.blockLength+=o.blockLength,n-=o.blockLength,this.value.push(o)}return s}toBER(t){let e=[];for(let n=0;n<this.value.length;n++){let s=this.value[n].toBER(t);if(s.byteLength===0)return this.error=this.value[n].error,_t;e.push(s)}return go(e)}fromString(t){this.value=[];let e=0,n=0,s="",o=!1;do if(n=t.indexOf(".",e),n===-1?s=t.substring(e):s=t.substring(e,n),e=n+1,o){let i=this.value[0],a=0;switch(i.valueDec){case 0:break;case 1:a=40;break;case 2:a=80;break;default:this.value=[];return}let c=parseInt(s,10);if(isNaN(c))return;i.valueDec=c+a,o=!1}else{let i=new wr;if(s>Number.MAX_SAFE_INTEGER){Qr();let a=BigInt(s);i.valueBigInt=a}else if(i.valueDec=parseInt(s,10),isNaN(i.valueDec))return;this.value.length||(i.isFirstSid=!0,o=!0),this.value.push(i)}while(n!==-1)}toString(){let 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}};pn.NAME="ObjectIdentifierValueBlock";var ua,Je=class extends ft{constructor(t={}){super(t,pn),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()}}};ua=Je;A.ObjectIdentifier=ua;Je.NAME="OBJECT IDENTIFIER";var xr=class extends se(te){constructor({valueDec:t=0,...e}={}){super(e),this.valueDec=t}fromBER(t,e,n){if(n===0)return e;let s=P.BufferSourceConverter.toUint8Array(t);if(!ne(this,s,e,n))return-1;let o=s.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=o[a]&127,this.blockLength++,!!(o[a]&128));a++);let i=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)i[a]=this.valueHexView[a];return this.valueHexView=i,o[this.blockLength-1]&128?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=Ue(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,o=new Uint8Array(this.blockLength);for(let i=0;i<this.blockLength-1;i++)o[i]=s[i]|128;return o[this.blockLength-1]=s[this.blockLength-1],o.buffer}let e=be(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",_t;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),o=e.byteLength-1;for(let i=0;i<o;i++)n[i]=s[i]|128;n[o]=s[o]}return n.buffer}toString(){let t="";return this.isHexOnly?t=P.Convert.ToHex(this.valueHexView):t=this.valueDec.toString(),t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};xr.NAME="relativeSidBlock";var gn=class extends mt{constructor({value:t=Ye,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new xr;if(s=o.fromBER(t,s,n),s===-1)return this.blockLength=0,this.error=o.error,s;this.blockLength+=o.blockLength,n-=o.blockLength,this.value.push(o)}return s}toBER(t,e){let n=[];for(let s=0;s<this.value.length;s++){let o=this.value[s].toBER(t);if(o.byteLength===0)return this.error=this.value[s].error,_t;n.push(o)}return go(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 o=new xr;if(o.valueDec=parseInt(s,10),isNaN(o.valueDec))return!0;this.value.push(o)}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}};gn.NAME="RelativeObjectIdentifierValueBlock";var fa,mn=class extends ft{constructor(t={}){super(t,gn),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()}}};fa=mn;A.RelativeObjectIdentifier=fa;mn.NAME="RelativeObjectIdentifier";var ha,ee=class extends we{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};ha=ee;A.Sequence=ha;ee.NAME="SEQUENCE";var da,yn=class extends we{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};da=yn;A.Set=da;yn.NAME="SET";var bn=class extends se(mt){constructor({...t}={}){super(t),this.isHexOnly=!0,this.value=Ye}toJSON(){return{...super.toJSON(),value:this.value}}};bn.NAME="StringValueBlock";var wn=class extends bn{};wn.NAME="SimpleStringValueBlock";var xt=class extends rn{constructor({...t}={}){super(t,wn)}fromBuffer(t){this.valueBlock.value=String.fromCharCode.apply(null,P.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}};xt.NAME="SIMPLE STRING";var xn=class extends xt{fromBuffer(t){this.valueBlock.valueHexView=P.BufferSourceConverter.toUint8Array(t);try{this.valueBlock.value=P.Convert.ToUtf8String(t)}catch(e){this.warnings.push(`Error during "decodeURIComponent": ${e}, using raw string`),this.valueBlock.value=P.Convert.ToBinary(t)}}fromString(t){this.valueBlock.valueHexView=new Uint8Array(P.Convert.FromUtf8String(t)),this.valueBlock.value=t}};xn.NAME="Utf8StringValueBlock";var pa,re=class extends xn{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};pa=re;A.Utf8String=pa;re.NAME="UTF8String";var vn=class extends xt{fromBuffer(t){this.valueBlock.value=P.Convert.ToUtf16String(t),this.valueBlock.valueHexView=P.BufferSourceConverter.toUint8Array(t)}fromString(t){this.valueBlock.value=t,this.valueBlock.valueHexView=new Uint8Array(P.Convert.FromUtf16String(t))}};vn.NAME="BmpStringValueBlock";var ga,Bn=class extends vn{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};ga=Bn;A.BmpString=ga;Bn.NAME="BMPString";var En=class extends xt{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 o=be(t.charCodeAt(s),8),i=new Uint8Array(o);if(i.length>4)continue;let a=4-i.length;for(let c=i.length-1;c>=0;c--)n[s*4+c+a]=i[c]}this.valueBlock.value=t}};En.NAME="UniversalStringValueBlock";var ma,An=class extends En{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};ma=An;A.UniversalString=ma;An.NAME="UniversalString";var ya,Sn=class extends xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};ya=Sn;A.NumericString=ya;Sn.NAME="NumericString";var ba,kn=class extends xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};ba=kn;A.PrintableString=ba;kn.NAME="PrintableString";var wa,In=class extends xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};wa=In;A.TeletexString=wa;In.NAME="TeletexString";var xa,Nn=class extends xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};xa=Nn;A.VideotexString=xa;Nn.NAME="VideotexString";var va,Cn=class extends xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};va=Cn;A.IA5String=va;Cn.NAME="IA5String";var Ba,Tn=class extends xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};Ba=Tn;A.GraphicString=Ba;Tn.NAME="GraphicString";var Ea,vr=class extends xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};Ea=vr;A.VisibleString=Ea;vr.NAME="VisibleString";var Aa,Un=class extends xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};Aa=Un;A.GeneralString=Aa;Un.NAME="GeneralString";var Sa,Ln=class extends xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};Sa=Ln;A.CharacterString=Sa;Ln.NAME="CharacterString";var ka,Br=class extends vr{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,P.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}}};ka=Br;A.UTCTime=ka;Br.NAME="UTCTime";var Ia,Rn=class extends Br{constructor(t={}){var e;super(t),(e=this.millisecond)!==null&&e!==void 0||(this.millisecond=0),this.idBlock.tagClass=1,this.idBlock.tagNumber=24}fromDate(t){super.fromDate(t),this.millisecond=t.getUTCMilliseconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second,this.millisecond))}fromString(t){let e=!1,n="",s="",o=0,i,a=0,c=0;if(t[t.length-1]==="Z")n=t.substring(0,t.length-1),e=!0;else{let u=new Number(t[t.length-1]);if(isNaN(u.valueOf()))throw new Error("Wrong input string for conversion");n=t}if(e){if(n.indexOf("+")!==-1)throw new Error("Wrong input string for conversion");if(n.indexOf("-")!==-1)throw new Error("Wrong input string for conversion")}else{let u=1,h=n.indexOf("+"),w="";if(h===-1&&(h=n.indexOf("-"),u=-1),h!==-1){if(w=n.substring(h+1),n=n.substring(0,h),w.length!==2&&w.length!==4)throw new Error("Wrong input string for conversion");let v=parseInt(w.substring(0,2),10);if(isNaN(v.valueOf()))throw new Error("Wrong input string for conversion");if(a=u*v,w.length===4){if(v=parseInt(w.substring(2,4),10),isNaN(v.valueOf()))throw new Error("Wrong input string for conversion");c=u*v}}}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");o=u.valueOf(),s=n.substring(0,f)}else s=n;switch(!0){case s.length===8:if(i=/(\d{4})(\d{2})(\d{2})/ig,f!==-1)throw new Error("Wrong input string for conversion");break;case s.length===10:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let u=60*o;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(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let u=60*o;this.second=Math.floor(u),u=1e3*(u-this.second),this.millisecond=Math.floor(u)}break;case s.length===14:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let u=1e3*o;this.millisecond=Math.floor(u)}break;default:throw new Error("Wrong input string for conversion")}let l=i.exec(s);if(l===null)throw new Error("Wrong input string for conversion");for(let u=1;u<l.length;u++)switch(u){case 1:this.year=parseInt(l[u],10);break;case 2:this.month=parseInt(l[u],10);break;case 3:this.day=parseInt(l[u],10);break;case 4:this.hour=parseInt(l[u],10)+a;break;case 5:this.minute=parseInt(l[u],10)+c;break;case 6:this.second=parseInt(l[u],10);break;default:throw new Error("Wrong input string for conversion")}if(e===!1){let u=new Date(this.year,this.month,this.day,this.hour,this.minute,this.second,this.millisecond);this.year=u.getUTCFullYear(),this.month=u.getUTCMonth(),this.day=u.getUTCDay(),this.hour=u.getUTCHours(),this.minute=u.getUTCMinutes(),this.second=u.getUTCSeconds(),this.millisecond=u.getUTCMilliseconds()}}toString(t="iso"){if(t==="iso"){let e=[];return e.push(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}}};Ia=Rn;A.GeneralizedTime=Ia;Rn.NAME="GeneralizedTime";var Na,Vn=class extends re{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};Na=Vn;A.DATE=Na;Vn.NAME="DATE";var Ca,_n=class extends re{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};Ca=_n;A.TimeOfDay=Ca;_n.NAME="TimeOfDay";var Ta,Hn=class extends re{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};Ta=Hn;A.DateTime=Ta;Hn.NAME="DateTime";var Ua,Dn=class extends re{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};Ua=Dn;A.Duration=Ua;Dn.NAME="Duration";var La,On=class extends re{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};La=On;A.TIME=La;On.NAME="TIME";function Q(r,t="utf8"){let e=Gr[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}var Er=class extends Error{constructor(t="An error occurred while verifying a message"){super(t),this.name="VerificationError"}},Mn=class extends Error{constructor(t="Missing Web Crypto API"){super(t),this.name="WebCryptoMissingError"}};var Ra={get(r=globalThis){let t=r.crypto;if(t?.subtle==null)throw new Mn("Missing Web Crypto API. The most likely cause of this error is that this page is being accessed from an insecure context (i.e. not HTTPS). For more information and possible resolutions see https://github.com/libp2p/js-libp2p/blob/main/packages/crypto/README.md#web-crypto-api");return t}};var xe=Ra;async function Va(r){let t=await xe.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 Af(t);return{privateKey:e[0],publicKey:e[1]}}async function _a(r,t){let e=await xe.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await xe.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},e,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(n,0,n.byteLength)}async function Ha(r,t,e){let n=await xe.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return xe.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,t,e instanceof Uint8Array?e:e.subarray())}async function Af(r){if(r.privateKey==null||r.publicKey==null)throw new wt("Private and public key are required");return Promise.all([xe.get().subtle.exportKey("jwk",r.privateKey),xe.get().subtle.exportKey("jwk",r.publicKey)])}function bo(r){if(r.kty!=="RSA")throw new wt("invalid key type");if(r.n==null)throw new wt("invalid key modulus");return J(r.n,"base64url").length*8}var Xe=class{type="RSA";_key;_raw;_multihash;constructor(t,e){this._key=t,this._multihash=e}get raw(){return this._raw==null&&(this._raw=Ar.jwkToPkix(this._key)),this._raw}toMultihash(){return this._multihash}toCID(){return lt.createV1(114,this._multihash)}toString(){return W.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:dt(this.raw,t.raw)}verify(t,e){return Ha(this._key,e,t)}},Sr=class{type="RSA";_key;_raw;publicKey;constructor(t,e){this._key=t,this.publicKey=e}get raw(){return this._raw==null&&(this._raw=Ar.jwkToPkcs1(this._key)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:dt(this.raw,t.raw)}sign(t){return _a(this._key,t)}};var Fn=8192,wo=18;function Da(r){let{result:t}=yo(r),e=t.valueBlock.value;return{n:Mt(e[1]),e:Mt(e[2]),d:Mt(e[3]),p:Mt(e[4]),q:Mt(e[5]),dp:Mt(e[6]),dq:Mt(e[7]),qi:Mt(e[8]),kty:"RSA",alg:"RS256"}}function Sf(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 wt("JWK was missing components");let e=new ee({value:[new ht({value:0}),ht.fromBigInt(Ft(J(r.n,"base64url"))),ht.fromBigInt(Ft(J(r.e,"base64url"))),ht.fromBigInt(Ft(J(r.d,"base64url"))),ht.fromBigInt(Ft(J(r.p,"base64url"))),ht.fromBigInt(Ft(J(r.q,"base64url"))),ht.fromBigInt(Ft(J(r.dp,"base64url"))),ht.fromBigInt(Ft(J(r.dq,"base64url"))),ht.fromBigInt(Ft(J(r.qi,"base64url")))]}).toBER();return new Uint8Array(e,0,e.byteLength)}function Oa(r){let{result:t}=yo(r),e=t.valueBlock.value[1].valueBlock.value[0].valueBlock.value;return{kty:"RSA",n:Mt(e[0]),e:Mt(e[1])}}function xo(r){if(r.n==null||r.e==null)throw new wt("JWK was missing components");let e=new ee({value:[new ee({value:[new Je({value:"1.2.840.113549.1.1.1"}),new Ze]}),new We({valueHex:new ee({value:[ht.fromBigInt(Ft(J(r.n,"base64url"))),ht.fromBigInt(Ft(J(r.e,"base64url")))]}).toBER()})]}).toBER();return new Uint8Array(e,0,e.byteLength)}function Mt(r){let t=r.valueBlock.valueHexView;for(;t[0]===0;)t=t.subarray(1);return Q(t,"base64url")}function Ft(r){let t=[];return r.forEach(function(e){let n=e.toString(16);n.length%2>0&&(n=`0${n}`),t.push(n)}),BigInt("0x"+t.join(""))}function Pa(r){let t=Da(r);return Ma(t)}function vo(r){let t=Oa(r);if(bo(t)>Fn)throw new Re("Key size is too large");let e=Ge(Ot.encode({Type:st.RSA,Data:r})),n=Tt(wo,e);return new Xe(t,n)}function Ma(r){if(bo(r)>Fn)throw new wt("Key size is too large");let t=Ka(r),e=Ge(Ot.encode({Type:st.RSA,Data:xo(t.publicKey)})),n=Tt(wo,e);return new Sr(t.privateKey,new Xe(t.publicKey,n))}async function Fa(r){if(r>Fn)throw new wt("Key size is too large");let t=await Va(r),e=Ge(Ot.encode({Type:st.RSA,Data:xo(t.publicKey)})),n=Tt(wo,e);return new Sr(t.privateKey,new Xe(t.publicKey,n))}function Ka(r){if(r==null)throw new wt("Missing key parameter");return{privateKey:r,publicKey:{kty:r.kty,n:r.n,e:r.e}}}var Kn=class extends Fe{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,fi(t);let n=ar(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,o=new Uint8Array(s);o.set(n.length>s?t.create().update(n).digest():n);for(let i=0;i<o.length;i++)o[i]^=54;this.iHash.update(o),this.oHash=t.create();for(let i=0;i<o.length;i++)o[i]^=106;this.oHash.update(o),o.fill(0)}update(t){return Me(this),this.iHash.update(t),this}digestInto(t){Me(this),Pe(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:o,blockLen:i,outputLen:a}=this;return t=t,t.finished=s,t.destroyed=o,t.blockLen=i,t.outputLen=a,t.oHash=e._cloneInto(t.oHash),t.iHash=n._cloneInto(t.iHash),t}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},Bo=(r,t,e)=>new Kn(r,t).update(e).digest();Bo.create=(r,t)=>new Kn(r,t);function $a(r){r.lowS!==void 0&&Lt("lowS",r.lowS),r.prehash!==void 0&&Lt("prehash",r.prehash)}function kf(r){let t=ur(r);Ht(t,{a:"field",b:"field"},{allowedPrivateKeyLengths:"array",wrapPrivateKey:"boolean",isTorsionFree:"function",clearCofactor:"function",allowInfinityPoint:"boolean",fromBytes:"function",toBytes:"function"});let{endo:e,Fp:n,a:s}=t;if(e){if(!n.eql(s,n.ZERO))throw new Error("Endomorphism can only be defined for Koblitz curves that have a=0");if(typeof e!="object"||typeof e.beta!="bigint"||typeof e.splitScalar!="function")throw new Error("Expected endomorphism with beta: bigint and splitScalar: function")}return Object.freeze({...t})}var{bytesToNumberBE:If,hexToBytes:Nf}=Or,oe={Err:class extends Error{constructor(t=""){super(t)}},_tlv:{encode:(r,t)=>{let{Err:e}=oe;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=Ee(n);if(s.length/2&128)throw new e("tlv.encode: long form length too big");let o=n>127?Ee(s.length/2|128):"";return`${Ee(r)}${o}${s}${t}`},decode(r,t){let{Err:e}=oe,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++],o=!!(s&128),i=0;if(!o)i=s;else{let c=s&127;if(!c)throw new e("tlv.decode(long): indefinite length not supported");if(c>4)throw new e("tlv.decode(long): byte length is too big");let f=t.subarray(n,n+c);if(f.length!==c)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)i=i<<8|l;if(n+=c,i<128)throw new e("tlv.decode(long): not minimal encoding")}let a=t.subarray(n,n+i);if(a.length!==i)throw new e("tlv.decode: wrong value length");return{v:a,l:t.subarray(n+i)}}},_int:{encode(r){let{Err:t}=oe;if(r<ie)throw new t("integer: negative integers are not allowed");let e=Ee(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}=oe;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 If(r)}},toSig(r){let{Err:t,_int:e,_tlv:n}=oe,s=typeof r=="string"?Nf(r):r;$e(s);let{v:o,l:i}=n.decode(48,s);if(i.length)throw new t("Invalid signature: left bytes after parsing");let{v:a,l:c}=n.decode(2,o),{v:f,l}=n.decode(2,c);if(l.length)throw new t("Invalid signature: left bytes after parsing");return{r:e.decode(a),s:e.decode(f)}},hexFromSig(r){let{_tlv:t,_int:e}=oe,n=`${t.encode(2,e.encode(r.r))}${t.encode(2,e.encode(r.s))}`;return t.encode(48,n)}},ie=BigInt(0),at=BigInt(1),up=BigInt(2),qa=BigInt(3),fp=BigInt(4);function Cf(r){let t=kf(r),{Fp:e}=t,n=pe(t.n,t.nBitLength),s=t.toBytes||((y,d,b)=>{let E=d.toAffine();return Wt(Uint8Array.from([4]),e.toBytes(E.x),e.toBytes(E.y))}),o=t.fromBytes||(y=>{let d=y.subarray(1),b=e.fromBytes(d.subarray(0,e.BYTES)),E=e.fromBytes(d.subarray(e.BYTES,2*e.BYTES));return{x:b,y:E}});function i(y){let{a:d,b}=t,E=e.sqr(y),g=e.mul(E,y);return e.add(e.add(g,e.mul(y,d)),b)}if(!e.eql(e.sqr(t.Gy),i(t.Gx)))throw new Error("bad generator point: equation left != right");function a(y){return cr(y,at,t.n)}function c(y){let{allowedPrivateKeyLengths:d,nByteLength:b,wrapPrivateKey:E,n:g}=t;if(d&&typeof y!="bigint"){if(fe(y)&&(y=jt(y)),typeof y!="string"||!d.includes(y.length))throw new Error("Invalid key");y=y.padStart(b*2,"0")}let S;try{S=typeof y=="bigint"?y:Zt(X("private key",y,b))}catch{throw new Error(`private key must be ${b} bytes, hex or bigint, not ${typeof y}`)}return E&&(S=q(S,g)),Bt("private key",S,at,g),S}function f(y){if(!(y instanceof h))throw new Error("ProjectivePoint expected")}let l=ke((y,d)=>{let{px:b,py:E,pz:g}=y;if(e.eql(g,e.ONE))return{x:b,y:E};let S=y.is0();d==null&&(d=S?e.ONE:e.inv(g));let L=e.mul(b,d),U=e.mul(E,d),k=e.mul(g,d);if(S)return{x:e.ZERO,y:e.ZERO};if(!e.eql(k,e.ONE))throw new Error("invZ was invalid");return{x:L,y:U}}),u=ke(y=>{if(y.is0()){if(t.allowInfinityPoint&&!e.is0(y.py))return;throw new Error("bad point: ZERO")}let{x:d,y:b}=y.toAffine();if(!e.isValid(d)||!e.isValid(b))throw new Error("bad point: x or y not FE");let E=e.sqr(b),g=i(d);if(!e.eql(E,g))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,b,E){if(this.px=d,this.py=b,this.pz=E,d==null||!e.isValid(d))throw new Error("x required");if(b==null||!e.isValid(b))throw new Error("y required");if(E==null||!e.isValid(E))throw new Error("z required");Object.freeze(this)}static fromAffine(d){let{x:b,y:E}=d||{};if(!d||!e.isValid(b)||!e.isValid(E))throw new Error("invalid affine point");if(d instanceof h)throw new Error("projective point not allowed");let g=S=>e.eql(S,e.ZERO);return g(b)&&g(E)?h.ZERO:new h(b,E,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(d){let b=e.invertBatch(d.map(E=>E.pz));return d.map((E,g)=>E.toAffine(b[g])).map(h.fromAffine)}static fromHex(d){let b=h.fromAffine(o(X("pointHex",d)));return b.assertValidity(),b}static fromPrivateKey(d){return h.BASE.multiply(c(d))}static msm(d,b){return Fr(h,n,d,b)}_setWindowSize(d){v.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:b,py:E,pz:g}=this,{px:S,py:L,pz:U}=d,k=e.eql(e.mul(b,U),e.mul(S,g)),I=e.eql(e.mul(E,U),e.mul(L,g));return k&&I}negate(){return new h(this.px,e.neg(this.py),this.pz)}double(){let{a:d,b}=t,E=e.mul(b,qa),{px:g,py:S,pz:L}=this,U=e.ZERO,k=e.ZERO,I=e.ZERO,T=e.mul(g,g),tt=e.mul(S,S),F=e.mul(L,L),H=e.mul(g,S);return H=e.add(H,H),I=e.mul(g,L),I=e.add(I,I),U=e.mul(d,I),k=e.mul(E,F),k=e.add(U,k),U=e.sub(tt,k),k=e.add(tt,k),k=e.mul(U,k),U=e.mul(H,U),I=e.mul(E,I),F=e.mul(d,F),H=e.sub(T,F),H=e.mul(d,H),H=e.add(H,I),I=e.add(T,T),T=e.add(I,T),T=e.add(T,F),T=e.mul(T,H),k=e.add(k,T),F=e.mul(S,L),F=e.add(F,F),T=e.mul(F,H),U=e.sub(U,T),I=e.mul(F,tt),I=e.add(I,I),I=e.add(I,I),new h(U,k,I)}add(d){f(d);let{px:b,py:E,pz:g}=this,{px:S,py:L,pz:U}=d,k=e.ZERO,I=e.ZERO,T=e.ZERO,tt=t.a,F=e.mul(t.b,qa),H=e.mul(b,S),et=e.mul(E,L),B=e.mul(g,U),N=e.add(b,E),m=e.add(S,L);N=e.mul(N,m),m=e.add(H,et),N=e.sub(N,m),m=e.add(b,g);let p=e.add(S,U);return m=e.mul(m,p),p=e.add(H,B),m=e.sub(m,p),p=e.add(E,g),k=e.add(L,U),p=e.mul(p,k),k=e.add(et,B),p=e.sub(p,k),T=e.mul(tt,m),k=e.mul(F,B),T=e.add(k,T),k=e.sub(et,T),T=e.add(et,T),I=e.mul(k,T),et=e.add(H,H),et=e.add(et,H),B=e.mul(tt,B),m=e.mul(F,m),et=e.add(et,B),B=e.sub(H,B),B=e.mul(tt,B),m=e.add(m,B),H=e.mul(et,m),I=e.add(I,H),H=e.mul(p,m),k=e.mul(N,k),k=e.sub(k,H),H=e.mul(N,et),T=e.mul(p,T),T=e.add(T,H),new h(k,I,T)}subtract(d){return this.add(d.negate())}is0(){return this.equals(h.ZERO)}wNAF(d){return v.wNAFCached(this,d,h.normalizeZ)}multiplyUnsafe(d){Bt("scalar",d,ie,t.n);let b=h.ZERO;if(d===ie)return b;if(d===at)return this;let{endo:E}=t;if(!E)return v.unsafeLadder(this,d);let{k1neg:g,k1:S,k2neg:L,k2:U}=E.splitScalar(d),k=b,I=b,T=this;for(;S>ie||U>ie;)S&at&&(k=k.add(T)),U&at&&(I=I.add(T)),T=T.double(),S>>=at,U>>=at;return g&&(k=k.negate()),L&&(I=I.negate()),I=new h(e.mul(I.px,E.beta),I.py,I.pz),k.add(I)}multiply(d){let{endo:b,n:E}=t;Bt("scalar",d,at,E);let g,S;if(b){let{k1neg:L,k1:U,k2neg:k,k2:I}=b.splitScalar(d),{p:T,f:tt}=this.wNAF(U),{p:F,f:H}=this.wNAF(I);T=v.constTimeNegate(L,T),F=v.constTimeNegate(k,F),F=new h(e.mul(F.px,b.beta),F.py,F.pz),g=T.add(F),S=tt.add(H)}else{let{p:L,f:U}=this.wNAF(d);g=L,S=U}return h.normalizeZ([g,S])[0]}multiplyAndAddUnsafe(d,b,E){let g=h.BASE,S=(U,k)=>k===ie||k===at||!U.equals(g)?U.multiplyUnsafe(k):U.multiply(k),L=S(this,b).add(S(d,E));return L.is0()?void 0:L}toAffine(d){return l(this,d)}isTorsionFree(){let{h:d,isTorsionFree:b}=t;if(d===at)return!0;if(b)return b(h,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h:d,clearCofactor:b}=t;return d===at?this:b?b(h,this):this.multiplyUnsafe(t.h)}toRawBytes(d=!0){return Lt("isCompressed",d),this.assertValidity(),s(h,this,d)}toHex(d=!0){return Lt("isCompressed",d),jt(this.toRawBytes(d))}}h.BASE=new h(t.Gx,t.Gy,e.ONE),h.ZERO=new h(e.ZERO,e.ONE,e.ZERO);let w=t.nBitLength,v=Mr(h,t.endo?Math.ceil(w/2):w);return{CURVE:t,ProjectivePoint:h,normPrivateKeyToScalar:c,weierstrassEquation:i,isWithinCurveOrder:a}}function Tf(r){let t=ur(r);return Ht(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function za(r){let t=Tf(r),{Fp:e,n}=t,s=e.BYTES+1,o=2*e.BYTES+1;function i(B){return q(B,n)}function a(B){return Pr(B,n)}let{ProjectivePoint:c,normPrivateKeyToScalar:f,weierstrassEquation:l,isWithinCurveOrder:u}=Cf({...t,toBytes(B,N,m){let p=N.toAffine(),x=e.toBytes(p.x),C=Wt;return Lt("isCompressed",m),m?C(Uint8Array.from([N.hasEvenY()?2:3]),x):C(Uint8Array.from([4]),x,e.toBytes(p.y))},fromBytes(B){let N=B.length,m=B[0],p=B.subarray(1);if(N===s&&(m===2||m===3)){let x=Zt(p);if(!cr(x,at,e.ORDER))throw new Error("Point is not on curve");let C=l(x),R;try{R=e.sqrt(C)}catch(M){let O=M instanceof Error?": "+M.message:"";throw new Error("Point is not on curve"+O)}let V=(R&at)===at;return(m&1)===1!==V&&(R=e.neg(R)),{x,y:R}}else if(N===o&&m===4){let x=e.fromBytes(p.subarray(0,e.BYTES)),C=e.fromBytes(p.subarray(e.BYTES,2*e.BYTES));return{x,y:C}}else throw new Error(`Point of length ${N} was invalid. Expected ${s} compressed bytes or ${o} uncompressed bytes`)}}),h=B=>jt(de(B,t.nByteLength));function w(B){let N=n>>at;return B>N}function v(B){return w(B)?i(-B):B}let y=(B,N,m)=>Zt(B.slice(N,m));class d{constructor(N,m,p){this.r=N,this.s=m,this.recovery=p,this.assertValidity()}static fromCompact(N){let m=t.nByteLength;return N=X("compactSignature",N,m*2),new d(y(N,0,m),y(N,m,2*m))}static fromDER(N){let{r:m,s:p}=oe.toSig(X("DER",N));return new d(m,p)}assertValidity(){Bt("r",this.r,at,n),Bt("s",this.s,at,n)}addRecoveryBit(N){return new d(this.r,this.s,N)}recoverPublicKey(N){let{r:m,s:p,recovery:x}=this,C=U(X("msgHash",N));if(x==null||![0,1,2,3].includes(x))throw new Error("recovery id invalid");let R=x===2||x===3?m+t.n:m;if(R>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let V=x&1?"03":"02",D=c.fromHex(V+h(R)),M=a(R),O=i(-C*M),$=i(p*M),G=c.BASE.multiplyAndAddUnsafe(D,O,$);if(!G)throw new Error("point at infinify");return G.assertValidity(),G}hasHighS(){return w(this.s)}normalizeS(){return this.hasHighS()?new d(this.r,i(-this.s),this.recovery):this}toDERRawBytes(){return Ae(this.toDERHex())}toDERHex(){return oe.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return Ae(this.toCompactHex())}toCompactHex(){return h(this.r)+h(this.s)}}let b={isValidPrivateKey(B){try{return f(B),!0}catch{return!1}},normPrivateKeyToScalar:f,randomPrivateKey:()=>{let B=Is(t.n);return Ai(t.randomBytes(B),t.n)},precompute(B=8,N=c.BASE){return N._setWindowSize(B),N.multiply(BigInt(3)),N}};function E(B,N=!0){return c.fromPrivateKey(B).toRawBytes(N)}function g(B){let N=fe(B),m=typeof B=="string",p=(N||m)&&B.length;return N?p===s||p===o:m?p===2*s||p===2*o:B instanceof c}function S(B,N,m=!0){if(g(B))throw new Error("first arg must be private key");if(!g(N))throw new Error("second arg must be public key");return c.fromHex(N).multiply(f(B)).toRawBytes(m)}let L=t.bits2int||function(B){let N=Zt(B),m=B.length*8-t.nBitLength;return m>0?N>>BigInt(m):N},U=t.bits2int_modN||function(B){return i(L(B))},k=lr(t.nBitLength);function I(B){return Bt(`num < 2^${t.nBitLength}`,B,ie,k),de(B,t.nByteLength)}function T(B,N,m=tt){if(["recovered","canonical"].some(it=>it in m))throw new Error("sign() legacy options not supported");let{hash:p,randomBytes:x}=t,{lowS:C,prehash:R,extraEntropy:V}=m;C==null&&(C=!0),B=X("msgHash",B),$a(m),R&&(B=X("prehashed msgHash",p(B)));let D=U(B),M=f(N),O=[I(M),I(D)];if(V!=null&&V!==!1){let it=V===!0?x(e.BYTES):V;O.push(X("extraEntropy",it))}let $=Wt(...O),G=D;function ot(it){let ct=L(it);if(!u(ct))return;let yt=a(ct),rt=c.BASE.multiply(ct).toAffine(),vt=i(rt.x);if(vt===ie)return;let Kt=i(yt*i(G+vt*M));if(Kt===ie)return;let er=(rt.x===vt?0:2)|Number(rt.y&at),rr=Kt;return C&&w(Kt)&&(rr=v(Kt),er^=1),new d(vt,rr,er)}return{seed:$,k2sig:ot}}let tt={lowS:t.lowS,prehash:!1},F={lowS:t.lowS,prehash:!1};function H(B,N,m=tt){let{seed:p,k2sig:x}=T(B,N,m),C=t;return Es(C.hash.outputLen,C.nByteLength,C.hmac)(p,x)}c.BASE._setWindowSize(8);function et(B,N,m,p=F){let x=B;if(N=X("msgHash",N),m=X("publicKey",m),"strict"in p)throw new Error("options.strict was renamed to lowS");$a(p);let{lowS:C,prehash:R}=p,V,D;try{if(typeof x=="string"||fe(x))try{V=d.fromDER(x)}catch(rt){if(!(rt instanceof oe.Err))throw rt;V=d.fromCompact(x)}else if(typeof x=="object"&&typeof x.r=="bigint"&&typeof x.s=="bigint"){let{r:rt,s:vt}=x;V=new d(rt,vt)}else throw new Error("PARSE");D=c.fromHex(m)}catch(rt){if(rt.message==="PARSE")throw new Error("signature must be Signature instance, Uint8Array or hex string");return!1}if(C&&V.hasHighS())return!1;R&&(N=t.hash(N));let{r:M,s:O}=V,$=U(N),G=a(O),ot=i($*G),it=i(M*G),ct=c.BASE.multiplyAndAddUnsafe(D,ot,it)?.toAffine();return ct?i(ct.x)===M:!1}return{CURVE:t,getPublicKey:E,getSharedSecret:S,sign:H,verify:et,ProjectivePoint:c,Signature:d,utils:b}}function Uf(r){return{hash:r,hmac:(t,...e)=>Bo(r,t,gs(...e)),randomBytes:_r}}function Ga(r,t){let e=n=>za({...r,...Uf(n)});return Object.freeze({...e(t),create:e})}var Wa=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),ja=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),Lf=BigInt(1),Eo=BigInt(2),Za=(r,t)=>(r+t/Eo)/t;function Rf(r){let t=Wa,e=BigInt(3),n=BigInt(6),s=BigInt(11),o=BigInt(22),i=BigInt(23),a=BigInt(44),c=BigInt(88),f=r*r*r%t,l=f*f*r%t,u=Z(l,e,t)*l%t,h=Z(u,e,t)*l%t,w=Z(h,Eo,t)*f%t,v=Z(w,s,t)*w%t,y=Z(v,o,t)*v%t,d=Z(y,a,t)*y%t,b=Z(d,c,t)*d%t,E=Z(b,a,t)*y%t,g=Z(E,e,t)*l%t,S=Z(g,i,t)*v%t,L=Z(S,n,t)*f%t,U=Z(L,Eo,t);if(!Ao.eql(Ao.sqr(U),r))throw new Error("Cannot find square root");return U}var Ao=pe(Wa,void 0,void 0,{sqrt:Rf}),Le=Ga({a:BigInt(0),b:BigInt(7),Fp:Ao,n:ja,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=ja,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-Lf*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),s=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),o=e,i=BigInt("0x100000000000000000000000000000000"),a=Za(o*r,t),c=Za(-n*r,t),f=q(r-a*e-c*s,t),l=q(-a*n-c*o,t),u=f>i,h=l>i;if(u&&(f=t-f),h&&(l=t-l),f>i||l>i)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:u,k1:f,k2neg:h,k2:l}}}},Ge),xp=BigInt(0);var vp=Le.ProjectivePoint;function Nt(r,t){t==null&&(t=r.reduce((s,o)=>s+o.length,0));let e=At(t),n=0;for(let s of r)e.set(s,n),n+=s.length;return e}function Ja(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function Ya(r,t,e){let n=fr.digest(e instanceof Uint8Array?e:e.subarray());if(Ja(n))return n.then(({digest:s})=>Le.verify(t,s,r)).catch(s=>{throw new Er(String(s))});try{return Le.verify(t,n.digest,r)}catch(s){throw new Er(String(s))}}var $n=class{type="secp256k1";raw;_key;constructor(t){this._key=Qa(t),this.raw=Xa(this._key)}toMultihash(){return zt.digest(qe(this))}toCID(){return lt.createV1(114,this.toMultihash())}toString(){return W.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:dt(this.raw,t.raw)}verify(t,e){return Ya(this._key,e,t)}};function So(r){return new $n(r)}function Xa(r){return Le.ProjectivePoint.fromHex(r).toRawBytes(!0)}function Qa(r){try{return Le.ProjectivePoint.fromHex(r),r}catch(t){throw new Re(String(t))}}function tc(r){let{Type:t,Data:e}=Ot.decode(r),n=e??new Uint8Array;switch(t){case st.RSA:return vo(n);case st.Ed25519:return Ls(n);case st.secp256k1:return So(n);default:throw new Ve}}function ec(r){let{Type:t,Data:e}=Ot.decode(r.digest),n=e??new Uint8Array;switch(t){case st.Ed25519:return Ls(n);case st.secp256k1:return So(n);default:throw new Ve}}function qe(r){return Ot.encode({Type:st[r.type],Data:r.raw})}var nc=Symbol.for("@achingbrain/uint8arraylist");function rc(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 qn(r){return!!r?.[nc]}var zn=class r{bufs;length;[nc]=!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(qn(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(qn(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=rc(this.bufs,t);return e.buf[e.index]}set(t,e){let n=rc(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(qn(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 Nt(n,s)}subarray(t,e){let{bufs:n,length:s}=this._subList(t,e);return n.length===1?n[0]:Nt(n,s)}sublist(t,e){let{bufs:n,length:s}=this._subList(t,e),o=new r;return o.length=s,o.bufs=[...n],o}_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 o=0;o<this.bufs.length;o++){let i=this.bufs[o],a=s,c=a+i.byteLength;if(s=c,t>=c)continue;let f=t>=a&&t<c,l=e>a&&e<=c;if(f&&l){if(t===a&&e===c){n.push(i);break}let u=t-a;n.push(i.subarray(u,u+(e-t)));break}if(f){if(t===0){n.push(i);continue}n.push(i.subarray(t-a));continue}if(l){if(e===c){n.push(i);break}n.push(i.subarray(0,e-a));break}n.push(i)}return{bufs:n,length:e-t}}indexOf(t,e=0){if(!qn(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 o=256,i=new Int32Array(o);for(let u=0;u<o;u++)i[u]=-1;for(let u=0;u<s;u++)i[n[u]]=u;let a=i,c=this.byteLength-n.byteLength,f=n.byteLength-1,l;for(let u=e;u<=c;u+=l){l=0;for(let h=f;h>=0;h--){let w=this.get(u+h);if(n[h]!==w){l=Math.max(1,h-a[w]);break}}if(l===0)return u}return-1}getInt8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getInt8(0)}setInt8(t,e){let n=At(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=ut(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=ut(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=ut(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=At(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=ut(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=ut(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=ut(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=ut(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=ut(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(!dt(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,o)=>s+o.byteLength,0)),n.length=e,n}};var kr;(function(r){let t;r.codec=()=>(t==null&&(t=Xt((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.publicKey!=null&&e.publicKey.byteLength>0&&(n.uint32(10),n.bytes(e.publicKey)),e.payloadType!=null&&e.payloadType.byteLength>0&&(n.uint32(18),n.bytes(e.payloadType)),e.payload!=null&&e.payload.byteLength>0&&(n.uint32(26),n.bytes(e.payload)),e.signature!=null&&e.signature.byteLength>0&&(n.uint32(42),n.bytes(e.signature)),s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let o={publicKey:ut(0),payloadType:ut(0),payload:ut(0),signature:ut(0)},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let a=e.uint32();switch(a>>>3){case 1:{o.publicKey=e.bytes();break}case 2:{o.payloadType=e.bytes();break}case 3:{o.payload=e.bytes();break}case 5:{o.signature=e.bytes();break}default:{e.skipType(a&7);break}}}return o})),t),r.encode=e=>Yt(e,r.codec()),r.decode=(e,n)=>Jt(e,r.codec(),n)})(kr||(kr={}));var Gn=class extends Error{constructor(t="Invalid signature"){super(t),this.name="InvalidSignatureError"}};var jn=class r{static createFromProtobuf=async t=>{let e=kr.decode(t),n=tc(e.publicKey);return new r({publicKey:n,payloadType:e.payloadType,payload:e.payload,signature:e.signature})};static seal=async(t,e)=>{if(e==null)throw new Error("Missing private key");let n=t.domain,s=t.codec,o=t.marshal(),i=sc(n,s,o),a=await e.sign(i.subarray());return new r({publicKey:e.publicKey,payloadType:s,payload:o,signature:a})};static openAndCertify=async(t,e)=>{let n=await r.createFromProtobuf(t);if(!await n.validate(e))throw new Gn("Envelope signature is not valid for the given domain");return n};publicKey;payloadType;payload;signature;marshaled;constructor(t){let{publicKey:e,payloadType:n,payload:s,signature:o}=t;this.publicKey=e,this.payloadType=n,this.payload=s,this.signature=o}marshal(){return this.marshaled==null&&(this.marshaled=kr.encode({publicKey:qe(this.publicKey),payloadType:this.payloadType,payload:this.payload.subarray(),signature:this.signature})),this.marshaled}equals(t){return dt(this.marshal(),t.marshal())}async validate(t){let e=sc(t,this.payloadType,this.payload);return this.publicKey.verify(e.subarray(),this.signature)}},sc=(r,t,e)=>{let n=J(r),s=Dt(n.byteLength),o=Dt(t.length),i=Dt(e.length);return new zn(s,n,o,t,i,e)};var oc=Symbol.for("nodejs.util.inspect.custom"),Vf=114,Ir=class{type;multihash;publicKey;string;constructor(t){this.type=t.type,this.multihash=t.multihash,Object.defineProperty(this,"string",{enumerable:!1,writable:!0})}get[Symbol.toStringTag](){return`PeerId(${this.toString()})`}[ss]=!0;toString(){return this.string==null&&(this.string=W.encode(this.multihash.bytes).slice(1)),this.string}toMultihash(){return this.multihash}toCID(){return lt.createV1(Vf,this.multihash)}toJSON(){return this.toString()}equals(t){if(t==null)return!1;if(t instanceof Uint8Array)return dt(this.multihash.bytes,t);if(typeof t=="string")return this.toString()===t;if(t?.toMultihash()?.bytes!=null)return dt(this.multihash.bytes,t.toMultihash().bytes);throw new Error("not valid Id")}[oc](){return`PeerId(${this.toString()})`}},Zn=class extends Ir{type="RSA";publicKey;constructor(t){super({...t,type:"RSA"}),this.publicKey=t.publicKey}},Wn=class extends Ir{type="Ed25519";publicKey;constructor(t){super({...t,type:"Ed25519"}),this.publicKey=t.publicKey}},Jn=class extends Ir{type="secp256k1";publicKey;constructor(t){super({...t,type:"secp256k1"}),this.publicKey=t.publicKey}},_f=2336,Yn=class{type="url";multihash;publicKey;url;constructor(t){this.url=t.toString(),this.multihash=zt.digest(J(this.url))}[oc](){return`PeerId(${this.url})`}[ss]=!0;toString(){return this.toCID().toString()}toMultihash(){return this.multihash}toCID(){return lt.createV1(_f,this.toMultihash())}toJSON(){return this.toString()}equals(t){return t==null?!1:(t instanceof Uint8Array&&(t=Q(t)),t.toString()===this.toString())}};function ic(r){if(Df(r))return new Zn({multihash:r});if(Hf(r))try{let t=ec(r);if(t.type==="Ed25519")return new Wn({multihash:r,publicKey:t});if(t.type==="secp256k1")return new Jn({multihash:r,publicKey:t})}catch{let e=Q(r.digest);return new Yn(new URL(e))}throw new Ur("Supplied PeerID Multihash is invalid")}function Hf(r){return r.code===zt.code}function Df(r){return r.code===fr.code}function ac(r,t){let e=(n,s)=>n.toString().localeCompare(s.toString());return r.length!==t.length?!1:(t.sort(e),r.sort(e).every((n,s)=>t[s].equals(n)))}var Xn=class{index=0;input="";new(t){return this.index=0,this.input=t,this}readAtomically(t){let e=this.index,n=t();return n===void 0&&(this.index=e),n}parseWith(t){let e=t();if(this.index===this.input.length)return e}peekChar(){if(!(this.index>=this.input.length))return this.input[this.index]}readChar(){if(!(this.index>=this.input.length))return this.input[this.index++]}readGivenChar(t){return this.readAtomically(()=>{let e=this.readChar();if(e===t)return e})}readSeparator(t,e,n){return this.readAtomically(()=>{if(!(e>0&&this.readGivenChar(t)===void 0))return n()})}readNumber(t,e,n,s){return this.readAtomically(()=>{let o=0,i=0,a=this.peekChar();if(a===void 0)return;let c=a==="0",f=2**(8*s)-1;for(;;){let l=this.readAtomically(()=>{let u=this.readChar();if(u===void 0)return;let h=Number.parseInt(u,t);if(!Number.isNaN(h))return h});if(l===void 0)break;if(o*=t,o+=l,o>f||(i+=1,e!==void 0&&i>e))return}if(i!==0)return!n&&c&&i>1?void 0:o})}readIPv4Addr(){return this.readAtomically(()=>{let t=new Uint8Array(4);for(let e=0;e<t.length;e++){let n=this.readSeparator(".",e,()=>this.readNumber(10,3,!1,1));if(n===void 0)return;t[e]=n}return t})}readIPv6Addr(){let t=e=>{for(let n=0;n<e.length/2;n++){let s=n*2;if(n<e.length-3){let i=this.readSeparator(":",n,()=>this.readIPv4Addr());if(i!==void 0)return e[s]=i[0],e[s+1]=i[1],e[s+2]=i[2],e[s+3]=i[3],[s+4,!0]}let o=this.readSeparator(":",n,()=>this.readNumber(16,4,!0,2));if(o===void 0)return[s,!1];e[s]=o>>8,e[s+1]=o&255}return[e.length,!1]};return this.readAtomically(()=>{let e=new Uint8Array(16),[n,s]=t(e);if(n===16)return e;if(s||this.readGivenChar(":")===void 0||this.readGivenChar(":")===void 0)return;let o=new Uint8Array(14),i=16-(n+2),[a]=t(o.subarray(0,i));return e.set(o.subarray(0,a),16-a),e})}readIPAddr(){return this.readIPv4Addr()??this.readIPv6Addr()}};var cc=45,Of=15,Qe=new Xn;function ko(r){if(!(r.length>Of))return Qe.new(r).parseWith(()=>Qe.readIPv4Addr())}function Io(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>cc))return Qe.new(r).parseWith(()=>Qe.readIPv6Addr())}function Qn(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>cc))return Qe.new(r).parseWith(()=>Qe.readIPAddr())}var Qg=parseInt("0xFFFF",16),tm=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);function fc(r){return!!ko(r)}function hc(r){return!!Io(r)}function ts(r){return!!Qn(r)}var dc=fc,$f=hc,No=function(r){let t=0;if(r=r.toString().trim(),dc(r)){let e=new Uint8Array(t+4);return r.split(/\./g).forEach(n=>{e[t++]=parseInt(n,10)&255}),e}if($f(r)){let e=r.split(":",8),n;for(n=0;n<e.length;n++){let o=dc(e[n]),i;o&&(i=No(e[n]),e[n]=Q(i.slice(0,2),"base16")),i!=null&&++n<8&&e.splice(n,0,Q(i.slice(2,4),"base16"))}if(e[0]==="")for(;e.length<8;)e.unshift("0");else if(e[e.length-1]==="")for(;e.length<8;)e.push("0");else if(e.length<8){for(n=0;n<e.length&&e[n]!=="";n++);let o=[n,1];for(n=9-e.length;n>0;n--)o.push("0");e.splice.apply(e,o)}let s=new Uint8Array(t+16);for(n=0;n<e.length;n++){let o=parseInt(e[n],16);s[t++]=o>>8&255,s[t++]=o&255}return s}throw new Error("invalid ip address")},pc=function(r,t=0,e){t=~~t,e=e??r.length-t;let n=new DataView(r.buffer);if(e===4){let s=[];for(let o=0;o<e;o++)s.push(r[t+o]);return s.join(".")}if(e===16){let s=[];for(let o=0;o<e;o+=2)s.push(n.getUint16(t+o).toString(16));return s.join(":").replace(/(^|:)0(:0)*:0(:|$)/,"$1::$3").replace(/:{3,4}/,"::")}return""};var tr={},Co={},zf=[[4,32,"ip4"],[6,16,"tcp"],[33,16,"dccp"],[41,128,"ip6"],[42,-1,"ip6zone"],[43,8,"ipcidr"],[53,-1,"dns",!0],[54,-1,"dns4",!0],[55,-1,"dns6",!0],[56,-1,"dnsaddr",!0],[132,16,"sctp"],[273,16,"udp"],[275,0,"p2p-webrtc-star"],[276,0,"p2p-webrtc-direct"],[277,0,"p2p-stardust"],[280,0,"webrtc-direct"],[281,0,"webrtc"],[290,0,"p2p-circuit"],[301,0,"udt"],[302,0,"utp"],[400,-1,"unix",!1,!0],[421,-1,"ipfs"],[421,-1,"p2p"],[443,0,"https"],[444,96,"onion"],[445,296,"onion3"],[446,-1,"garlic64"],[448,0,"tls"],[449,-1,"sni"],[460,0,"quic"],[461,0,"quic-v1"],[465,0,"webtransport"],[466,-1,"certhash"],[477,0,"ws"],[478,0,"wss"],[479,0,"p2p-websocket-star"],[480,0,"http"],[481,-1,"http-path"],[777,-1,"memory"]];zf.forEach(r=>{let t=Gf(...r);Co[t.code]=t,tr[t.name]=t});function Gf(r,t,e,n,s){return{code:r,size:t,name:e,resolvable:!!n,path:!!s}}function z(r){if(typeof r=="number"){if(Co[r]!=null)return Co[r];throw new Error(`no protocol with code: ${r}`)}else if(typeof r=="string"){if(tr[r]!=null)return tr[r];throw new Error(`no protocol with name: ${r}`)}throw new Error(`invalid protocol id type: ${typeof r}`)}var Dm=z("ip4"),Om=z("ip6"),Pm=z("ipcidr");function Ro(r,t){switch(z(r).code){case 4:case 41:return Zf(t);case 42:return Lo(t);case 6:case 273:case 33:case 132:return yc(t).toString();case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Lo(t);case 421:return Xf(t);case 444:return mc(t);case 445:return mc(t);case 466:return Yf(t);case 481:return globalThis.encodeURIComponent(Lo(t));default:return Q(t,"base16")}}function Vo(r,t){switch(z(r).code){case 4:return gc(t);case 41:return gc(t);case 42:return Uo(t);case 6:case 273:case 33:case 132:return _o(parseInt(t,10));case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Uo(t);case 421:return Wf(t);case 444:return Qf(t);case 445:return th(t);case 466:return Jf(t);case 481:return Uo(globalThis.decodeURIComponent(t));default:return J(t,"base16")}}var To=Object.values(hr).map(r=>r.decoder),jf=function(){let r=To[0].or(To[1]);return To.slice(2).forEach(t=>r=r.or(t)),r}();function gc(r){if(!ts(r))throw new Error("invalid ip address");return No(r)}function Zf(r){let t=pc(r,0,r.length);if(t==null)throw new Error("ipBuff is required");if(!ts(t))throw new Error("invalid ip address");return t}function _o(r){let t=new ArrayBuffer(2);return new DataView(t).setUint16(0,r),new Uint8Array(t)}function yc(r){return new DataView(r.buffer).getUint16(r.byteOffset)}function Uo(r){let t=J(r),e=Uint8Array.from(Dt(t.length));return Nt([e,t],e.length+t.length)}function Lo(r){let t=Ne(r);if(r=r.slice(St(t)),r.length!==t)throw new Error("inconsistent lengths");return Q(r)}function Wf(r){let t;r[0]==="Q"||r[0]==="1"?t=ve(W.decode(`z${r}`)).bytes:t=lt.parse(r).multihash.bytes;let e=Uint8Array.from(Dt(t.length));return Nt([e,t],e.length+t.length)}function Jf(r){let t=jf.decode(r),e=Uint8Array.from(Dt(t.length));return Nt([e,t],e.length+t.length)}function Yf(r){let t=Ne(r),e=r.slice(St(t));if(e.length!==t)throw new Error("inconsistent lengths");return"u"+Q(e,"base64url")}function Xf(r){let t=Ne(r),e=r.slice(St(t));if(e.length!==t)throw new Error("inconsistent lengths");return Q(e,"base58btc")}function Qf(r){let t=r.split(":");if(t.length!==2)throw new Error(`failed to parse onion addr: ["'${t.join('", "')}'"]' does not contain a port number`);if(t[0].length!==16)throw new Error(`failed to parse onion addr: ${t[0]} not a Tor onion address.`);let e=qt.decode("b"+t[0]),n=parseInt(t[1],10);if(n<1||n>65536)throw new Error("Port number is not in range(1, 65536)");let s=_o(n);return Nt([e,s],e.length+s.length)}function th(r){let t=r.split(":");if(t.length!==2)throw new Error(`failed to parse onion addr: ["'${t.join('", "')}'"]' does not contain a port number`);if(t[0].length!==56)throw new Error(`failed to parse onion addr: ${t[0]} not a Tor onion3 address.`);let e=qt.decode(`b${t[0]}`),n=parseInt(t[1],10);if(n<1||n>65536)throw new Error("Port number is not in range(1, 65536)");let s=_o(n);return Nt([e,s],e.length+s.length)}function mc(r){let t=r.slice(0,r.length-2),e=r.slice(r.length-2),n=Q(t,"base32"),s=yc(e);return`${n}:${s}`}function bc(r){r=Ho(r);let t=[],e=[],n=null,s=r.split("/").slice(1);if(s.length===1&&s[0]==="")return{bytes:new Uint8Array,string:"/",tuples:[],stringTuples:[],path:null};for(let o=0;o<s.length;o++){let i=s[o],a=z(i);if(a.size===0){t.push([a.code]),e.push([a.code]);continue}if(o++,o>=s.length)throw xc("invalid address: "+r);if(a.path===!0){n=Ho(s.slice(o).join("/")),t.push([a.code,Vo(a.code,n)]),e.push([a.code,n]);break}let c=Vo(a.code,s[o]);t.push([a.code,c]),e.push([a.code,Ro(a.code,c)])}return{string:wc(e),bytes:Oo(t),tuples:t,stringTuples:e,path:n}}function Do(r){let t=[],e=[],n=null,s=0;for(;s<r.length;){let o=Ne(r,s),i=St(o),a=z(o),c=eh(a,r.slice(s+i));if(c===0){t.push([o]),e.push([o]),s+=i;continue}let f=r.slice(s+i,s+i+c);if(s+=c+i,s>r.length)throw xc("Invalid address Uint8Array: "+Q(r,"base16"));t.push([o,f]);let l=Ro(o,f);if(e.push([o,l]),a.path===!0){n=l;break}}return{bytes:Uint8Array.from(r),string:wc(e),tuples:t,stringTuples:e,path:n}}function wc(r){let t=[];return r.map(e=>{let n=z(e[0]);return t.push(n.name),e.length>1&&e[1]!=null&&t.push(e[1]),null}),Ho(t.join("/"))}function Oo(r){return Nt(r.map(t=>{let e=z(t[0]),n=Uint8Array.from(Dt(e.code));return t.length>1&&t[1]!=null&&(n=Nt([n,t[1]])),n}))}function eh(r,t){if(r.size>0)return r.size/8;if(r.size===0)return 0;{let e=Ne(t instanceof Uint8Array?t:Uint8Array.from(t));return e+St(e)}}function Ho(r){return"/"+r.trim().split("/").filter(t=>t).join("/")}function xc(r){return new Error("Error parsing address: "+r)}var rh=Symbol.for("nodejs.util.inspect.custom"),Mo=Symbol.for("@multiformats/js-multiaddr/multiaddr"),nh=[z("dns").code,z("dns4").code,z("dns6").code,z("dnsaddr").code],Po=class extends Error{constructor(t="No available resolver"){super(t),this.name="NoAvailableResolverError"}},es=class r{bytes;#e;#t;#r;#n;[Mo]=!0;constructor(t){t==null&&(t="");let e;if(t instanceof Uint8Array)e=Do(t);else if(typeof t=="string"){if(t.length>0&&t.charAt(0)!=="/")throw new Error(`multiaddr "${t}" must start with a "/"`);e=bc(t)}else if(Bc(t))e=Do(t.bytes);else throw new Error("addr must be a string, Buffer, or another Multiaddr");this.bytes=e.bytes,this.#e=e.string,this.#t=e.tuples,this.#r=e.stringTuples,this.#n=e.path}toString(){return this.#e}toJSON(){return this.toString()}toOptions(){let t,e,n,s,o="",i=z("tcp"),a=z("udp"),c=z("ip4"),f=z("ip6"),l=z("dns6"),u=z("ip6zone");for(let[w,v]of this.stringTuples())w===u.code&&(o=`%${v??""}`),nh.includes(w)&&(e=i.name,s=443,n=`${v??""}${o}`,t=w===l.code?6:4),(w===i.code||w===a.code)&&(e=z(w).name,s=parseInt(v??"")),(w===c.code||w===f.code)&&(e=z(w).name,n=`${v??""}${o}`,t=w===f.code?6:4);if(t==null||e==null||n==null||s==null)throw new Error('multiaddr must have a valid format: "/{ip4, ip6, dns4, dns6, dnsaddr}/{address}/{tcp, udp}/{port}".');return{family:t,host:n,transport:e,port:s}}protos(){return this.#t.map(([t])=>Object.assign({},z(t)))}protoCodes(){return this.#t.map(([t])=>t)}protoNames(){return this.#t.map(([t])=>z(t).name)}tuples(){return this.#t}stringTuples(){return this.#r}encapsulate(t){return t=new r(t),new r(this.toString()+t.toString())}decapsulate(t){let e=t.toString(),n=this.toString(),s=n.lastIndexOf(e);if(s<0)throw new Error(`Address ${this.toString()} does not contain subaddress: ${t.toString()}`);return new r(n.slice(0,s))}decapsulateCode(t){let e=this.tuples();for(let n=e.length-1;n>=0;n--)if(e[n][0]===t)return new r(Oo(e.slice(0,n)));return this}getPeerId(){try{let t=[];this.stringTuples().forEach(([n,s])=>{n===tr.p2p.code&&t.push([n,s]),n===tr["p2p-circuit"].code&&(t=[])});let e=t.pop();if(e?.[1]!=null){let n=e[1];return n[0]==="Q"||n[0]==="1"?Q(W.decode(`z${n}`),"base58btc"):Q(lt.parse(n).multihash.bytes,"base58btc")}return null}catch{return null}}getPath(){return this.#n}equals(t){return dt(this.bytes,t.bytes)}async resolve(t){let e=this.protos().find(o=>o.resolvable);if(e==null)return[this];let n=vc.get(e.name);if(n==null)throw new Po(`no available resolver for ${e.name}`);return(await n(this,t)).map(o=>Nr(o))}nodeAddress(){let t=this.toOptions();if(t.transport!=="tcp"&&t.transport!=="udp")throw new Error(`multiaddr must have a valid format - no protocol with name: "${t.transport}". Must have a valid transport protocol: "{tcp, udp}"`);return{family:t.family,address:t.host,port:t.port}}isThinWaistAddress(t){let e=(t??this).protos();return!(e.length!==2||e[0].code!==4&&e[0].code!==41||e[1].code!==6&&e[1].code!==273)}[rh](){return`Multiaddr(${this.#e})`}};var vc=new Map;function Bc(r){return!!r?.[Mo]}function Nr(r){return new es(r)}var Ec="libp2p-peer-record",Ac=Uint8Array.from([3,1]);var Cr;(function(r){let t;(function(n){let s;n.codec=()=>(s==null&&(s=Xt((o,i,a={})=>{a.lengthDelimited!==!1&&i.fork(),o.multiaddr!=null&&o.multiaddr.byteLength>0&&(i.uint32(10),i.bytes(o.multiaddr)),a.lengthDelimited!==!1&&i.ldelim()},(o,i,a={})=>{let c={multiaddr:ut(0)},f=i==null?o.len:o.pos+i;for(;o.pos<f;){let l=o.uint32();switch(l>>>3){case 1:{c.multiaddr=o.bytes();break}default:{o.skipType(l&7);break}}}return c})),s),n.encode=o=>Yt(o,n.codec()),n.decode=(o,i)=>Jt(o,n.codec(),i)})(t=r.AddressInfo||(r.AddressInfo={}));let e;r.codec=()=>(e==null&&(e=Xt((n,s,o={})=>{if(o.lengthDelimited!==!1&&s.fork(),n.peerId!=null&&n.peerId.byteLength>0&&(s.uint32(10),s.bytes(n.peerId)),n.seq!=null&&n.seq!==0n&&(s.uint32(16),s.uint64(n.seq)),n.addresses!=null)for(let i of n.addresses)s.uint32(26),r.AddressInfo.codec().encode(i,s);o.lengthDelimited!==!1&&s.ldelim()},(n,s,o={})=>{let i={peerId:ut(0),seq:0n,addresses:[]},a=s==null?n.len:n.pos+s;for(;n.pos<a;){let c=n.uint32();switch(c>>>3){case 1:{i.peerId=n.bytes();break}case 2:{i.seq=n.uint64();break}case 3:{if(o.limits?.addresses!=null&&i.addresses.length===o.limits.addresses)throw new Wr('Decode error - map field "addresses" had too many elements');i.addresses.push(r.AddressInfo.codec().decode(n,n.uint32(),{limits:o.limits?.addresses$}));break}default:{n.skipType(c&7);break}}}return i})),e),r.encode=n=>Yt(n,r.codec()),r.decode=(n,s)=>Jt(n,r.codec(),s)})(Cr||(Cr={}));var rs=class r{static createFromProtobuf=t=>{let e=Cr.decode(t),n=ic(ve(e.peerId)),s=(e.addresses??[]).map(i=>Nr(i.multiaddr)),o=e.seq;return new r({peerId:n,multiaddrs:s,seqNumber:o})};static DOMAIN=Ec;static CODEC=Ac;peerId;multiaddrs;seqNumber;domain=r.DOMAIN;codec=r.CODEC;marshaled;constructor(t){let{peerId:e,multiaddrs:n,seqNumber:s}=t;this.peerId=e,this.multiaddrs=n??[],this.seqNumber=s??BigInt(Date.now())}marshal(){return this.marshaled==null&&(this.marshaled=Cr.encode({peerId:this.peerId.toMultihash().bytes,seq:BigInt(this.seqNumber),addresses:this.multiaddrs.map(t=>({multiaddr:t.bytes}))})),this.marshaled}equals(t){return!(!(t instanceof r)||!this.peerId.equals(t.peerId)||this.seqNumber!==t.seqNumber||!ac(this.multiaddrs,t.multiaddrs))}};return Mc(sh);})();
6
+ `)}`:`${e} :`}};ea=we;A.Constructed=ea;we.NAME="CONSTRUCTED";var on=class extends mt{fromBER(t,e,n){return e}toBER(t){return _t}};on.override="EndOfContentValueBlock";var ra,an=class extends ft{constructor(t={}){super(t,on),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};ra=an;A.EndOfContent=ra;an.NAME=yr;var na,Ze=class extends ft{constructor(t={}){super(t,mt),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}`}};na=Ze;A.Null=na;Ze.NAME="NULL";var cn=class extends se(mt){constructor({value:t,...e}={}){super(e),e.valueHex?this.valueHexView=P.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=P.BufferSourceConverter.toUint8Array(t);return ne(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,po.call(this),this.blockLength=n,e+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};cn.NAME="BooleanValueBlock";var sa,ln=class extends ft{constructor(t={}){super(t,cn),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}`}};sa=ln;A.Boolean=sa;ln.NAME="BOOLEAN";var un=class extends se(Pt){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=Pt.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let o=0;o<this.value.length;o++){let i=this.value[o].constructor.NAME;if(i===yr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(i!==Yi)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?Pt.prototype.toBER.call(this,t,e):t?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};un.NAME="OctetStringValueBlock";var oa,fn=class r extends ft{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,o;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((o=n.value)===null||o===void 0)&&o.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},un),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 o=(t instanceof ArrayBuffer?new Uint8Array(t):t).subarray(e,e+n);try{if(o.byteLength){let i=Pn(o,0,o.byteLength);i.offset!==-1&&i.offset===n&&(this.valueBlock.value=[i.result])}}catch{}}return super.fromBER(t,e,n)}onAsciiEncoding(){return this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length?we.prototype.onAsciiEncoding.call(this):`${this.constructor.NAME} : ${P.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 P.BufferSourceConverter.concat(t)}};oa=fn;A.OctetString=oa;fn.NAME=Yi;var hn=class extends se(Pt){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=Pt.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let a of this.value){let c=a.constructor.NAME;if(c===yr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==Xi)return this.error="BIT STRING may consists of BIT STRINGs only",-1;let f=a.valueBlock;if(this.unusedBits>0&&f.unusedBits>0)return this.error='Using of "unused bits" inside constructive BIT STRING allowed for least one only',-1;this.unusedBits=f.unusedBits}return s}let o=P.BufferSourceConverter.toUint8Array(t);if(!ne(this,o,e,n))return-1;let i=o.subarray(e,e+n);if(this.unusedBits=i[0],this.unusedBits>7)return this.error="Unused bits for BitString must be in range 0-7",-1;if(!this.unusedBits){let a=i.subarray(1);try{if(a.byteLength){let c=Pn(a,0,a.byteLength);c.offset!==-1&&c.offset===n-1&&(this.value=[c.result])}}catch{}}return this.valueHexView=i.subarray(1),this.blockLength=i.length,e+n}toBER(t,e){if(this.isConstructed)return Pt.prototype.toBER.call(this,t,e);if(t)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return _t;let n=new Uint8Array(this.valueHexView.length+1);return n[0]=this.unusedBits,n.set(this.valueHexView,1),n.buffer}toJSON(){return{...super.toJSON(),unusedBits:this.unusedBits,isConstructed:this.isConstructed}}};hn.NAME="BitStringValueBlock";var ia,We=class extends ft{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,o;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((o=n.value)===null||o===void 0)&&o.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},hn),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 we.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)}`}}};ia=We;A.BitString=ia;We.NAME=Xi;var aa;function vf(r,t){let e=new Uint8Array([0]),n=new Uint8Array(r),s=new Uint8Array(t),o=n.slice(0),i=o.length-1,a=s.slice(0),c=a.length-1,f=0,l=c<i?i:c,u=0;for(let h=l;h>=0;h--,u++){switch(!0){case u<a.length:f=o[i-u]+a[c-u]+e[0];break;default:f=o[i-u]+e[0]}switch(e[0]=f/10,!0){case u>=o.length:o=Xr(new Uint8Array([f%10]),o);break;default:o[i-u]=f%10}}return e[0]>0&&(o=Xr(e,o)),o}function Ji(r){if(r>=gr.length)for(let t=gr.length;t<=r;t++){let e=new Uint8Array([0]),n=gr[t-1].slice(0);for(let s=n.length-1;s>=0;s--){let o=new Uint8Array([(n[s]<<1)+e[0]]);e[0]=o[0]/10,n[s]=o[0]%10}e[0]>0&&(n=Xr(e,n)),gr.push(n)}return gr[r]}function Bf(r,t){let e=0,n=new Uint8Array(r),s=new Uint8Array(t),o=n.slice(0),i=o.length-1,a=s.slice(0),c=a.length-1,f,l=0;for(let u=c;u>=0;u--,l++)switch(f=o[i-l]-a[c-l]-e,!0){case f<0:e=1,o[i-l]=f+10;break;default:e=0,o[i-l]=f}if(e>0)for(let u=i-c+1;u>=0;u--,l++)if(f=o[i-l]-e,f<0)e=1,o[i-l]=f+10;else{e=0,o[i-l]=f;break}return o.slice()}var br=class extends se(mt){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=po.call(this)))}set valueDec(t){this._valueDec=t,this.isHexOnly=!1,this.valueHexView=new Uint8Array(ji(t))}get valueDec(){return this._valueDec}fromDER(t,e,n,s=0){let o=this.fromBER(t,e,n);if(o===-1)return o;let i=this.valueHexView;return i[0]===0&&i[1]&128?this.valueHexView=i.subarray(1):s!==0&&i.length<s&&(s-i.length>1&&(s=i.length+1),this.valueHexView=i.subarray(s-i.length)),o}toDER(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,o=this.valueHexView,i="",a=!1;for(let c=o.byteLength-1;c>=0;c--){s=o[c];for(let f=0;f<8;f++){if((s&1)===1)switch(n){case t:e=Bf(Ji(n),e),i="-";break;default:e=vf(e,Ji(n))}n++,s>>=1}}for(let c=0;c<e.length;c++)e[c]&&(a=!0),a&&(i+=Wi.charAt(e[c]));return a===!1&&(i+=Wi.charAt(0)),i}};aa=br;br.NAME="IntegerValueBlock";Object.defineProperty(aa.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var ca,ht=class r extends ft{constructor(t={}){super(t,br),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return Qr(),BigInt(this.valueBlock.toString())}static fromBigInt(t){Qr();let e=BigInt(t),n=new mr,s=e.toString(16).replace(/^-/,""),o=new Uint8Array(P.Convert.FromHex(s));if(e<0){let a=new Uint8Array(o.length+(o[0]&128?1:0));a[0]|=128;let f=BigInt(`0x${P.Convert.ToHex(a)}`)+e,l=P.BufferSourceConverter.toUint8Array(P.Convert.FromHex(f.toString(16)));l[0]|=128,n.write(l)}else o[0]&128&&n.write(new Uint8Array([0])),n.write(o);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()}`}};ca=ht;A.Integer=ca;ht.NAME="INTEGER";var la,dn=class extends ht{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};la=dn;A.Enumerated=la;dn.NAME="ENUMERATED";var wr=class extends se(mt){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=P.BufferSourceConverter.toUint8Array(t);if(!ne(this,s,e,n))return-1;let o=s.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=o[a]&127,this.blockLength++,!!(o[a]&128));a++);let i=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)i[a]=this.valueHexView[a];return this.valueHexView=i,o[this.blockLength-1]&128?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=Ue(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}set valueBigInt(t){Qr();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,o=new Uint8Array(this.blockLength);for(let i=0;i<this.blockLength-1;i++)o[i]=s[i]|128;return o[this.blockLength-1]=s[this.blockLength-1],o.buffer}let e=be(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",_t;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),o=e.byteLength-1;for(let i=0;i<o;i++)n[i]=s[i]|128;n[o]=s[o]}return n}toString(){let t="";if(this.isHexOnly)t=P.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 pn=class extends mt{constructor({value:t=Ye,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new wr;if(s=o.fromBER(t,s,n),s===-1)return this.blockLength=0,this.error=o.error,s;this.value.length===0&&(o.isFirstSid=!0),this.blockLength+=o.blockLength,n-=o.blockLength,this.value.push(o)}return s}toBER(t){let e=[];for(let n=0;n<this.value.length;n++){let s=this.value[n].toBER(t);if(s.byteLength===0)return this.error=this.value[n].error,_t;e.push(s)}return go(e)}fromString(t){this.value=[];let e=0,n=0,s="",o=!1;do if(n=t.indexOf(".",e),n===-1?s=t.substring(e):s=t.substring(e,n),e=n+1,o){let i=this.value[0],a=0;switch(i.valueDec){case 0:break;case 1:a=40;break;case 2:a=80;break;default:this.value=[];return}let c=parseInt(s,10);if(isNaN(c))return;i.valueDec=c+a,o=!1}else{let i=new wr;if(s>Number.MAX_SAFE_INTEGER){Qr();let a=BigInt(s);i.valueBigInt=a}else if(i.valueDec=parseInt(s,10),isNaN(i.valueDec))return;this.value.length||(i.isFirstSid=!0,o=!0),this.value.push(i)}while(n!==-1)}toString(){let 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}};pn.NAME="ObjectIdentifierValueBlock";var ua,Je=class extends ft{constructor(t={}){super(t,pn),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()}}};ua=Je;A.ObjectIdentifier=ua;Je.NAME="OBJECT IDENTIFIER";var xr=class extends se(te){constructor({valueDec:t=0,...e}={}){super(e),this.valueDec=t}fromBER(t,e,n){if(n===0)return e;let s=P.BufferSourceConverter.toUint8Array(t);if(!ne(this,s,e,n))return-1;let o=s.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=o[a]&127,this.blockLength++,!!(o[a]&128));a++);let i=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)i[a]=this.valueHexView[a];return this.valueHexView=i,o[this.blockLength-1]&128?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=Ue(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,o=new Uint8Array(this.blockLength);for(let i=0;i<this.blockLength-1;i++)o[i]=s[i]|128;return o[this.blockLength-1]=s[this.blockLength-1],o.buffer}let e=be(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",_t;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),o=e.byteLength-1;for(let i=0;i<o;i++)n[i]=s[i]|128;n[o]=s[o]}return n.buffer}toString(){let t="";return this.isHexOnly?t=P.Convert.ToHex(this.valueHexView):t=this.valueDec.toString(),t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};xr.NAME="relativeSidBlock";var gn=class extends mt{constructor({value:t=Ye,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new xr;if(s=o.fromBER(t,s,n),s===-1)return this.blockLength=0,this.error=o.error,s;this.blockLength+=o.blockLength,n-=o.blockLength,this.value.push(o)}return s}toBER(t,e){let n=[];for(let s=0;s<this.value.length;s++){let o=this.value[s].toBER(t);if(o.byteLength===0)return this.error=this.value[s].error,_t;n.push(o)}return go(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 o=new xr;if(o.valueDec=parseInt(s,10),isNaN(o.valueDec))return!0;this.value.push(o)}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}};gn.NAME="RelativeObjectIdentifierValueBlock";var fa,mn=class extends ft{constructor(t={}){super(t,gn),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()}}};fa=mn;A.RelativeObjectIdentifier=fa;mn.NAME="RelativeObjectIdentifier";var ha,ee=class extends we{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};ha=ee;A.Sequence=ha;ee.NAME="SEQUENCE";var da,yn=class extends we{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};da=yn;A.Set=da;yn.NAME="SET";var bn=class extends se(mt){constructor({...t}={}){super(t),this.isHexOnly=!0,this.value=Ye}toJSON(){return{...super.toJSON(),value:this.value}}};bn.NAME="StringValueBlock";var wn=class extends bn{};wn.NAME="SimpleStringValueBlock";var xt=class extends rn{constructor({...t}={}){super(t,wn)}fromBuffer(t){this.valueBlock.value=String.fromCharCode.apply(null,P.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}};xt.NAME="SIMPLE STRING";var xn=class extends xt{fromBuffer(t){this.valueBlock.valueHexView=P.BufferSourceConverter.toUint8Array(t);try{this.valueBlock.value=P.Convert.ToUtf8String(t)}catch(e){this.warnings.push(`Error during "decodeURIComponent": ${e}, using raw string`),this.valueBlock.value=P.Convert.ToBinary(t)}}fromString(t){this.valueBlock.valueHexView=new Uint8Array(P.Convert.FromUtf8String(t)),this.valueBlock.value=t}};xn.NAME="Utf8StringValueBlock";var pa,re=class extends xn{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};pa=re;A.Utf8String=pa;re.NAME="UTF8String";var vn=class extends xt{fromBuffer(t){this.valueBlock.value=P.Convert.ToUtf16String(t),this.valueBlock.valueHexView=P.BufferSourceConverter.toUint8Array(t)}fromString(t){this.valueBlock.value=t,this.valueBlock.valueHexView=new Uint8Array(P.Convert.FromUtf16String(t))}};vn.NAME="BmpStringValueBlock";var ga,Bn=class extends vn{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};ga=Bn;A.BmpString=ga;Bn.NAME="BMPString";var En=class extends xt{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 o=be(t.charCodeAt(s),8),i=new Uint8Array(o);if(i.length>4)continue;let a=4-i.length;for(let c=i.length-1;c>=0;c--)n[s*4+c+a]=i[c]}this.valueBlock.value=t}};En.NAME="UniversalStringValueBlock";var ma,An=class extends En{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};ma=An;A.UniversalString=ma;An.NAME="UniversalString";var ya,Sn=class extends xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};ya=Sn;A.NumericString=ya;Sn.NAME="NumericString";var ba,kn=class extends xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};ba=kn;A.PrintableString=ba;kn.NAME="PrintableString";var wa,In=class extends xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};wa=In;A.TeletexString=wa;In.NAME="TeletexString";var xa,Nn=class extends xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};xa=Nn;A.VideotexString=xa;Nn.NAME="VideotexString";var va,Cn=class extends xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};va=Cn;A.IA5String=va;Cn.NAME="IA5String";var Ba,Tn=class extends xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};Ba=Tn;A.GraphicString=Ba;Tn.NAME="GraphicString";var Ea,vr=class extends xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};Ea=vr;A.VisibleString=Ea;vr.NAME="VisibleString";var Aa,Un=class extends xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};Aa=Un;A.GeneralString=Aa;Un.NAME="GeneralString";var Sa,Ln=class extends xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};Sa=Ln;A.CharacterString=Sa;Ln.NAME="CharacterString";var ka,Br=class extends vr{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,P.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}}};ka=Br;A.UTCTime=ka;Br.NAME="UTCTime";var Ia,Rn=class extends Br{constructor(t={}){var e;super(t),(e=this.millisecond)!==null&&e!==void 0||(this.millisecond=0),this.idBlock.tagClass=1,this.idBlock.tagNumber=24}fromDate(t){super.fromDate(t),this.millisecond=t.getUTCMilliseconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second,this.millisecond))}fromString(t){let e=!1,n="",s="",o=0,i,a=0,c=0;if(t[t.length-1]==="Z")n=t.substring(0,t.length-1),e=!0;else{let u=new Number(t[t.length-1]);if(isNaN(u.valueOf()))throw new Error("Wrong input string for conversion");n=t}if(e){if(n.indexOf("+")!==-1)throw new Error("Wrong input string for conversion");if(n.indexOf("-")!==-1)throw new Error("Wrong input string for conversion")}else{let u=1,h=n.indexOf("+"),w="";if(h===-1&&(h=n.indexOf("-"),u=-1),h!==-1){if(w=n.substring(h+1),n=n.substring(0,h),w.length!==2&&w.length!==4)throw new Error("Wrong input string for conversion");let v=parseInt(w.substring(0,2),10);if(isNaN(v.valueOf()))throw new Error("Wrong input string for conversion");if(a=u*v,w.length===4){if(v=parseInt(w.substring(2,4),10),isNaN(v.valueOf()))throw new Error("Wrong input string for conversion");c=u*v}}}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");o=u.valueOf(),s=n.substring(0,f)}else s=n;switch(!0){case s.length===8:if(i=/(\d{4})(\d{2})(\d{2})/ig,f!==-1)throw new Error("Wrong input string for conversion");break;case s.length===10:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let u=60*o;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(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let u=60*o;this.second=Math.floor(u),u=1e3*(u-this.second),this.millisecond=Math.floor(u)}break;case s.length===14:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let u=1e3*o;this.millisecond=Math.floor(u)}break;default:throw new Error("Wrong input string for conversion")}let l=i.exec(s);if(l===null)throw new Error("Wrong input string for conversion");for(let u=1;u<l.length;u++)switch(u){case 1:this.year=parseInt(l[u],10);break;case 2:this.month=parseInt(l[u],10);break;case 3:this.day=parseInt(l[u],10);break;case 4:this.hour=parseInt(l[u],10)+a;break;case 5:this.minute=parseInt(l[u],10)+c;break;case 6:this.second=parseInt(l[u],10);break;default:throw new Error("Wrong input string for conversion")}if(e===!1){let u=new Date(this.year,this.month,this.day,this.hour,this.minute,this.second,this.millisecond);this.year=u.getUTCFullYear(),this.month=u.getUTCMonth(),this.day=u.getUTCDay(),this.hour=u.getUTCHours(),this.minute=u.getUTCMinutes(),this.second=u.getUTCSeconds(),this.millisecond=u.getUTCMilliseconds()}}toString(t="iso"){if(t==="iso"){let e=[];return e.push(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}}};Ia=Rn;A.GeneralizedTime=Ia;Rn.NAME="GeneralizedTime";var Na,Vn=class extends re{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};Na=Vn;A.DATE=Na;Vn.NAME="DATE";var Ca,_n=class extends re{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};Ca=_n;A.TimeOfDay=Ca;_n.NAME="TimeOfDay";var Ta,Hn=class extends re{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};Ta=Hn;A.DateTime=Ta;Hn.NAME="DateTime";var Ua,Dn=class extends re{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};Ua=Dn;A.Duration=Ua;Dn.NAME="Duration";var La,On=class extends re{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};La=On;A.TIME=La;On.NAME="TIME";function Q(r,t="utf8"){let e=Gr[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}var Er=class extends Error{constructor(t="An error occurred while verifying a message"){super(t),this.name="VerificationError"}},Mn=class extends Error{constructor(t="Missing Web Crypto API"){super(t),this.name="WebCryptoMissingError"}};var Ra={get(r=globalThis){let t=r.crypto;if(t?.subtle==null)throw new Mn("Missing Web Crypto API. The most likely cause of this error is that this page is being accessed from an insecure context (i.e. not HTTPS). For more information and possible resolutions see https://github.com/libp2p/js-libp2p/blob/main/packages/crypto/README.md#web-crypto-api");return t}};var xe=Ra;async function Va(r){let t=await xe.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 Af(t);return{privateKey:e[0],publicKey:e[1]}}async function _a(r,t){let e=await xe.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await xe.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},e,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(n,0,n.byteLength)}async function Ha(r,t,e){let n=await xe.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return xe.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,t,e instanceof Uint8Array?e:e.subarray())}async function Af(r){if(r.privateKey==null||r.publicKey==null)throw new wt("Private and public key are required");return Promise.all([xe.get().subtle.exportKey("jwk",r.privateKey),xe.get().subtle.exportKey("jwk",r.publicKey)])}function bo(r){if(r.kty!=="RSA")throw new wt("invalid key type");if(r.n==null)throw new wt("invalid key modulus");return J(r.n,"base64url").length*8}var Xe=class{type="RSA";_key;_raw;_multihash;constructor(t,e){this._key=t,this._multihash=e}get raw(){return this._raw==null&&(this._raw=Ar.jwkToPkix(this._key)),this._raw}toMultihash(){return this._multihash}toCID(){return lt.createV1(114,this._multihash)}toString(){return W.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:dt(this.raw,t.raw)}verify(t,e){return Ha(this._key,e,t)}},Sr=class{type="RSA";_key;_raw;publicKey;constructor(t,e){this._key=t,this.publicKey=e}get raw(){return this._raw==null&&(this._raw=Ar.jwkToPkcs1(this._key)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:dt(this.raw,t.raw)}sign(t){return _a(this._key,t)}};var Fn=8192,wo=18;function Da(r){let{result:t}=yo(r),e=t.valueBlock.value;return{n:Mt(e[1]),e:Mt(e[2]),d:Mt(e[3]),p:Mt(e[4]),q:Mt(e[5]),dp:Mt(e[6]),dq:Mt(e[7]),qi:Mt(e[8]),kty:"RSA",alg:"RS256"}}function Sf(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 wt("JWK was missing components");let e=new ee({value:[new ht({value:0}),ht.fromBigInt(Ft(J(r.n,"base64url"))),ht.fromBigInt(Ft(J(r.e,"base64url"))),ht.fromBigInt(Ft(J(r.d,"base64url"))),ht.fromBigInt(Ft(J(r.p,"base64url"))),ht.fromBigInt(Ft(J(r.q,"base64url"))),ht.fromBigInt(Ft(J(r.dp,"base64url"))),ht.fromBigInt(Ft(J(r.dq,"base64url"))),ht.fromBigInt(Ft(J(r.qi,"base64url")))]}).toBER();return new Uint8Array(e,0,e.byteLength)}function Oa(r){let{result:t}=yo(r),e=t.valueBlock.value[1].valueBlock.value[0].valueBlock.value;return{kty:"RSA",n:Mt(e[0]),e:Mt(e[1])}}function xo(r){if(r.n==null||r.e==null)throw new wt("JWK was missing components");let e=new ee({value:[new ee({value:[new Je({value:"1.2.840.113549.1.1.1"}),new Ze]}),new We({valueHex:new ee({value:[ht.fromBigInt(Ft(J(r.n,"base64url"))),ht.fromBigInt(Ft(J(r.e,"base64url")))]}).toBER()})]}).toBER();return new Uint8Array(e,0,e.byteLength)}function Mt(r){let t=r.valueBlock.valueHexView;for(;t[0]===0;)t=t.subarray(1);return Q(t,"base64url")}function Ft(r){let t=[];return r.forEach(function(e){let n=e.toString(16);n.length%2>0&&(n=`0${n}`),t.push(n)}),BigInt("0x"+t.join(""))}function Pa(r){let t=Da(r);return Ma(t)}function vo(r){let t=Oa(r);if(bo(t)>Fn)throw new Re("Key size is too large");let e=Ge(Ot.encode({Type:st.RSA,Data:r})),n=Tt(wo,e);return new Xe(t,n)}function Ma(r){if(bo(r)>Fn)throw new wt("Key size is too large");let t=Ka(r),e=Ge(Ot.encode({Type:st.RSA,Data:xo(t.publicKey)})),n=Tt(wo,e);return new Sr(t.privateKey,new Xe(t.publicKey,n))}async function Fa(r){if(r>Fn)throw new wt("Key size is too large");let t=await Va(r),e=Ge(Ot.encode({Type:st.RSA,Data:xo(t.publicKey)})),n=Tt(wo,e);return new Sr(t.privateKey,new Xe(t.publicKey,n))}function Ka(r){if(r==null)throw new wt("Missing key parameter");return{privateKey:r,publicKey:{kty:r.kty,n:r.n,e:r.e}}}var Kn=class extends Fe{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,fi(t);let n=ar(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,o=new Uint8Array(s);o.set(n.length>s?t.create().update(n).digest():n);for(let i=0;i<o.length;i++)o[i]^=54;this.iHash.update(o),this.oHash=t.create();for(let i=0;i<o.length;i++)o[i]^=106;this.oHash.update(o),o.fill(0)}update(t){return Me(this),this.iHash.update(t),this}digestInto(t){Me(this),Pe(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:o,blockLen:i,outputLen:a}=this;return t=t,t.finished=s,t.destroyed=o,t.blockLen=i,t.outputLen=a,t.oHash=e._cloneInto(t.oHash),t.iHash=n._cloneInto(t.iHash),t}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},Bo=(r,t,e)=>new Kn(r,t).update(e).digest();Bo.create=(r,t)=>new Kn(r,t);function $a(r){r.lowS!==void 0&&Lt("lowS",r.lowS),r.prehash!==void 0&&Lt("prehash",r.prehash)}function kf(r){let t=ur(r);Ht(t,{a:"field",b:"field"},{allowedPrivateKeyLengths:"array",wrapPrivateKey:"boolean",isTorsionFree:"function",clearCofactor:"function",allowInfinityPoint:"boolean",fromBytes:"function",toBytes:"function"});let{endo:e,Fp:n,a:s}=t;if(e){if(!n.eql(s,n.ZERO))throw new Error("Endomorphism can only be defined for Koblitz curves that have a=0");if(typeof e!="object"||typeof e.beta!="bigint"||typeof e.splitScalar!="function")throw new Error("Expected endomorphism with beta: bigint and splitScalar: function")}return Object.freeze({...t})}var{bytesToNumberBE:If,hexToBytes:Nf}=Or,oe={Err:class extends Error{constructor(t=""){super(t)}},_tlv:{encode:(r,t)=>{let{Err:e}=oe;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=Ee(n);if(s.length/2&128)throw new e("tlv.encode: long form length too big");let o=n>127?Ee(s.length/2|128):"";return`${Ee(r)}${o}${s}${t}`},decode(r,t){let{Err:e}=oe,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++],o=!!(s&128),i=0;if(!o)i=s;else{let c=s&127;if(!c)throw new e("tlv.decode(long): indefinite length not supported");if(c>4)throw new e("tlv.decode(long): byte length is too big");let f=t.subarray(n,n+c);if(f.length!==c)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)i=i<<8|l;if(n+=c,i<128)throw new e("tlv.decode(long): not minimal encoding")}let a=t.subarray(n,n+i);if(a.length!==i)throw new e("tlv.decode: wrong value length");return{v:a,l:t.subarray(n+i)}}},_int:{encode(r){let{Err:t}=oe;if(r<ie)throw new t("integer: negative integers are not allowed");let e=Ee(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}=oe;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 If(r)}},toSig(r){let{Err:t,_int:e,_tlv:n}=oe,s=typeof r=="string"?Nf(r):r;$e(s);let{v:o,l:i}=n.decode(48,s);if(i.length)throw new t("Invalid signature: left bytes after parsing");let{v:a,l:c}=n.decode(2,o),{v:f,l}=n.decode(2,c);if(l.length)throw new t("Invalid signature: left bytes after parsing");return{r:e.decode(a),s:e.decode(f)}},hexFromSig(r){let{_tlv:t,_int:e}=oe,n=`${t.encode(2,e.encode(r.r))}${t.encode(2,e.encode(r.s))}`;return t.encode(48,n)}},ie=BigInt(0),at=BigInt(1),up=BigInt(2),qa=BigInt(3),fp=BigInt(4);function Cf(r){let t=kf(r),{Fp:e}=t,n=pe(t.n,t.nBitLength),s=t.toBytes||((y,d,b)=>{let E=d.toAffine();return Wt(Uint8Array.from([4]),e.toBytes(E.x),e.toBytes(E.y))}),o=t.fromBytes||(y=>{let d=y.subarray(1),b=e.fromBytes(d.subarray(0,e.BYTES)),E=e.fromBytes(d.subarray(e.BYTES,2*e.BYTES));return{x:b,y:E}});function i(y){let{a:d,b}=t,E=e.sqr(y),g=e.mul(E,y);return e.add(e.add(g,e.mul(y,d)),b)}if(!e.eql(e.sqr(t.Gy),i(t.Gx)))throw new Error("bad generator point: equation left != right");function a(y){return cr(y,at,t.n)}function c(y){let{allowedPrivateKeyLengths:d,nByteLength:b,wrapPrivateKey:E,n:g}=t;if(d&&typeof y!="bigint"){if(fe(y)&&(y=jt(y)),typeof y!="string"||!d.includes(y.length))throw new Error("Invalid key");y=y.padStart(b*2,"0")}let S;try{S=typeof y=="bigint"?y:Zt(X("private key",y,b))}catch{throw new Error(`private key must be ${b} bytes, hex or bigint, not ${typeof y}`)}return E&&(S=q(S,g)),Bt("private key",S,at,g),S}function f(y){if(!(y instanceof h))throw new Error("ProjectivePoint expected")}let l=ke((y,d)=>{let{px:b,py:E,pz:g}=y;if(e.eql(g,e.ONE))return{x:b,y:E};let S=y.is0();d==null&&(d=S?e.ONE:e.inv(g));let L=e.mul(b,d),U=e.mul(E,d),k=e.mul(g,d);if(S)return{x:e.ZERO,y:e.ZERO};if(!e.eql(k,e.ONE))throw new Error("invZ was invalid");return{x:L,y:U}}),u=ke(y=>{if(y.is0()){if(t.allowInfinityPoint&&!e.is0(y.py))return;throw new Error("bad point: ZERO")}let{x:d,y:b}=y.toAffine();if(!e.isValid(d)||!e.isValid(b))throw new Error("bad point: x or y not FE");let E=e.sqr(b),g=i(d);if(!e.eql(E,g))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,b,E){if(this.px=d,this.py=b,this.pz=E,d==null||!e.isValid(d))throw new Error("x required");if(b==null||!e.isValid(b))throw new Error("y required");if(E==null||!e.isValid(E))throw new Error("z required");Object.freeze(this)}static fromAffine(d){let{x:b,y:E}=d||{};if(!d||!e.isValid(b)||!e.isValid(E))throw new Error("invalid affine point");if(d instanceof h)throw new Error("projective point not allowed");let g=S=>e.eql(S,e.ZERO);return g(b)&&g(E)?h.ZERO:new h(b,E,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(d){let b=e.invertBatch(d.map(E=>E.pz));return d.map((E,g)=>E.toAffine(b[g])).map(h.fromAffine)}static fromHex(d){let b=h.fromAffine(o(X("pointHex",d)));return b.assertValidity(),b}static fromPrivateKey(d){return h.BASE.multiply(c(d))}static msm(d,b){return Fr(h,n,d,b)}_setWindowSize(d){v.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:b,py:E,pz:g}=this,{px:S,py:L,pz:U}=d,k=e.eql(e.mul(b,U),e.mul(S,g)),I=e.eql(e.mul(E,U),e.mul(L,g));return k&&I}negate(){return new h(this.px,e.neg(this.py),this.pz)}double(){let{a:d,b}=t,E=e.mul(b,qa),{px:g,py:S,pz:L}=this,U=e.ZERO,k=e.ZERO,I=e.ZERO,T=e.mul(g,g),tt=e.mul(S,S),F=e.mul(L,L),H=e.mul(g,S);return H=e.add(H,H),I=e.mul(g,L),I=e.add(I,I),U=e.mul(d,I),k=e.mul(E,F),k=e.add(U,k),U=e.sub(tt,k),k=e.add(tt,k),k=e.mul(U,k),U=e.mul(H,U),I=e.mul(E,I),F=e.mul(d,F),H=e.sub(T,F),H=e.mul(d,H),H=e.add(H,I),I=e.add(T,T),T=e.add(I,T),T=e.add(T,F),T=e.mul(T,H),k=e.add(k,T),F=e.mul(S,L),F=e.add(F,F),T=e.mul(F,H),U=e.sub(U,T),I=e.mul(F,tt),I=e.add(I,I),I=e.add(I,I),new h(U,k,I)}add(d){f(d);let{px:b,py:E,pz:g}=this,{px:S,py:L,pz:U}=d,k=e.ZERO,I=e.ZERO,T=e.ZERO,tt=t.a,F=e.mul(t.b,qa),H=e.mul(b,S),et=e.mul(E,L),B=e.mul(g,U),N=e.add(b,E),m=e.add(S,L);N=e.mul(N,m),m=e.add(H,et),N=e.sub(N,m),m=e.add(b,g);let p=e.add(S,U);return m=e.mul(m,p),p=e.add(H,B),m=e.sub(m,p),p=e.add(E,g),k=e.add(L,U),p=e.mul(p,k),k=e.add(et,B),p=e.sub(p,k),T=e.mul(tt,m),k=e.mul(F,B),T=e.add(k,T),k=e.sub(et,T),T=e.add(et,T),I=e.mul(k,T),et=e.add(H,H),et=e.add(et,H),B=e.mul(tt,B),m=e.mul(F,m),et=e.add(et,B),B=e.sub(H,B),B=e.mul(tt,B),m=e.add(m,B),H=e.mul(et,m),I=e.add(I,H),H=e.mul(p,m),k=e.mul(N,k),k=e.sub(k,H),H=e.mul(N,et),T=e.mul(p,T),T=e.add(T,H),new h(k,I,T)}subtract(d){return this.add(d.negate())}is0(){return this.equals(h.ZERO)}wNAF(d){return v.wNAFCached(this,d,h.normalizeZ)}multiplyUnsafe(d){Bt("scalar",d,ie,t.n);let b=h.ZERO;if(d===ie)return b;if(d===at)return this;let{endo:E}=t;if(!E)return v.unsafeLadder(this,d);let{k1neg:g,k1:S,k2neg:L,k2:U}=E.splitScalar(d),k=b,I=b,T=this;for(;S>ie||U>ie;)S&at&&(k=k.add(T)),U&at&&(I=I.add(T)),T=T.double(),S>>=at,U>>=at;return g&&(k=k.negate()),L&&(I=I.negate()),I=new h(e.mul(I.px,E.beta),I.py,I.pz),k.add(I)}multiply(d){let{endo:b,n:E}=t;Bt("scalar",d,at,E);let g,S;if(b){let{k1neg:L,k1:U,k2neg:k,k2:I}=b.splitScalar(d),{p:T,f:tt}=this.wNAF(U),{p:F,f:H}=this.wNAF(I);T=v.constTimeNegate(L,T),F=v.constTimeNegate(k,F),F=new h(e.mul(F.px,b.beta),F.py,F.pz),g=T.add(F),S=tt.add(H)}else{let{p:L,f:U}=this.wNAF(d);g=L,S=U}return h.normalizeZ([g,S])[0]}multiplyAndAddUnsafe(d,b,E){let g=h.BASE,S=(U,k)=>k===ie||k===at||!U.equals(g)?U.multiplyUnsafe(k):U.multiply(k),L=S(this,b).add(S(d,E));return L.is0()?void 0:L}toAffine(d){return l(this,d)}isTorsionFree(){let{h:d,isTorsionFree:b}=t;if(d===at)return!0;if(b)return b(h,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h:d,clearCofactor:b}=t;return d===at?this:b?b(h,this):this.multiplyUnsafe(t.h)}toRawBytes(d=!0){return Lt("isCompressed",d),this.assertValidity(),s(h,this,d)}toHex(d=!0){return Lt("isCompressed",d),jt(this.toRawBytes(d))}}h.BASE=new h(t.Gx,t.Gy,e.ONE),h.ZERO=new h(e.ZERO,e.ONE,e.ZERO);let w=t.nBitLength,v=Mr(h,t.endo?Math.ceil(w/2):w);return{CURVE:t,ProjectivePoint:h,normPrivateKeyToScalar:c,weierstrassEquation:i,isWithinCurveOrder:a}}function Tf(r){let t=ur(r);return Ht(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function za(r){let t=Tf(r),{Fp:e,n}=t,s=e.BYTES+1,o=2*e.BYTES+1;function i(B){return q(B,n)}function a(B){return Pr(B,n)}let{ProjectivePoint:c,normPrivateKeyToScalar:f,weierstrassEquation:l,isWithinCurveOrder:u}=Cf({...t,toBytes(B,N,m){let p=N.toAffine(),x=e.toBytes(p.x),C=Wt;return Lt("isCompressed",m),m?C(Uint8Array.from([N.hasEvenY()?2:3]),x):C(Uint8Array.from([4]),x,e.toBytes(p.y))},fromBytes(B){let N=B.length,m=B[0],p=B.subarray(1);if(N===s&&(m===2||m===3)){let x=Zt(p);if(!cr(x,at,e.ORDER))throw new Error("Point is not on curve");let C=l(x),R;try{R=e.sqrt(C)}catch(M){let O=M instanceof Error?": "+M.message:"";throw new Error("Point is not on curve"+O)}let V=(R&at)===at;return(m&1)===1!==V&&(R=e.neg(R)),{x,y:R}}else if(N===o&&m===4){let x=e.fromBytes(p.subarray(0,e.BYTES)),C=e.fromBytes(p.subarray(e.BYTES,2*e.BYTES));return{x,y:C}}else throw new Error(`Point of length ${N} was invalid. Expected ${s} compressed bytes or ${o} uncompressed bytes`)}}),h=B=>jt(de(B,t.nByteLength));function w(B){let N=n>>at;return B>N}function v(B){return w(B)?i(-B):B}let y=(B,N,m)=>Zt(B.slice(N,m));class d{constructor(N,m,p){this.r=N,this.s=m,this.recovery=p,this.assertValidity()}static fromCompact(N){let m=t.nByteLength;return N=X("compactSignature",N,m*2),new d(y(N,0,m),y(N,m,2*m))}static fromDER(N){let{r:m,s:p}=oe.toSig(X("DER",N));return new d(m,p)}assertValidity(){Bt("r",this.r,at,n),Bt("s",this.s,at,n)}addRecoveryBit(N){return new d(this.r,this.s,N)}recoverPublicKey(N){let{r:m,s:p,recovery:x}=this,C=U(X("msgHash",N));if(x==null||![0,1,2,3].includes(x))throw new Error("recovery id invalid");let R=x===2||x===3?m+t.n:m;if(R>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let V=x&1?"03":"02",D=c.fromHex(V+h(R)),M=a(R),O=i(-C*M),$=i(p*M),G=c.BASE.multiplyAndAddUnsafe(D,O,$);if(!G)throw new Error("point at infinify");return G.assertValidity(),G}hasHighS(){return w(this.s)}normalizeS(){return this.hasHighS()?new d(this.r,i(-this.s),this.recovery):this}toDERRawBytes(){return Ae(this.toDERHex())}toDERHex(){return oe.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return Ae(this.toCompactHex())}toCompactHex(){return h(this.r)+h(this.s)}}let b={isValidPrivateKey(B){try{return f(B),!0}catch{return!1}},normPrivateKeyToScalar:f,randomPrivateKey:()=>{let B=Is(t.n);return Ai(t.randomBytes(B),t.n)},precompute(B=8,N=c.BASE){return N._setWindowSize(B),N.multiply(BigInt(3)),N}};function E(B,N=!0){return c.fromPrivateKey(B).toRawBytes(N)}function g(B){let N=fe(B),m=typeof B=="string",p=(N||m)&&B.length;return N?p===s||p===o:m?p===2*s||p===2*o:B instanceof c}function S(B,N,m=!0){if(g(B))throw new Error("first arg must be private key");if(!g(N))throw new Error("second arg must be public key");return c.fromHex(N).multiply(f(B)).toRawBytes(m)}let L=t.bits2int||function(B){let N=Zt(B),m=B.length*8-t.nBitLength;return m>0?N>>BigInt(m):N},U=t.bits2int_modN||function(B){return i(L(B))},k=lr(t.nBitLength);function I(B){return Bt(`num < 2^${t.nBitLength}`,B,ie,k),de(B,t.nByteLength)}function T(B,N,m=tt){if(["recovered","canonical"].some(it=>it in m))throw new Error("sign() legacy options not supported");let{hash:p,randomBytes:x}=t,{lowS:C,prehash:R,extraEntropy:V}=m;C==null&&(C=!0),B=X("msgHash",B),$a(m),R&&(B=X("prehashed msgHash",p(B)));let D=U(B),M=f(N),O=[I(M),I(D)];if(V!=null&&V!==!1){let it=V===!0?x(e.BYTES):V;O.push(X("extraEntropy",it))}let $=Wt(...O),G=D;function ot(it){let ct=L(it);if(!u(ct))return;let yt=a(ct),rt=c.BASE.multiply(ct).toAffine(),vt=i(rt.x);if(vt===ie)return;let Kt=i(yt*i(G+vt*M));if(Kt===ie)return;let er=(rt.x===vt?0:2)|Number(rt.y&at),rr=Kt;return C&&w(Kt)&&(rr=v(Kt),er^=1),new d(vt,rr,er)}return{seed:$,k2sig:ot}}let tt={lowS:t.lowS,prehash:!1},F={lowS:t.lowS,prehash:!1};function H(B,N,m=tt){let{seed:p,k2sig:x}=T(B,N,m),C=t;return Es(C.hash.outputLen,C.nByteLength,C.hmac)(p,x)}c.BASE._setWindowSize(8);function et(B,N,m,p=F){let x=B;if(N=X("msgHash",N),m=X("publicKey",m),"strict"in p)throw new Error("options.strict was renamed to lowS");$a(p);let{lowS:C,prehash:R}=p,V,D;try{if(typeof x=="string"||fe(x))try{V=d.fromDER(x)}catch(rt){if(!(rt instanceof oe.Err))throw rt;V=d.fromCompact(x)}else if(typeof x=="object"&&typeof x.r=="bigint"&&typeof x.s=="bigint"){let{r:rt,s:vt}=x;V=new d(rt,vt)}else throw new Error("PARSE");D=c.fromHex(m)}catch(rt){if(rt.message==="PARSE")throw new Error("signature must be Signature instance, Uint8Array or hex string");return!1}if(C&&V.hasHighS())return!1;R&&(N=t.hash(N));let{r:M,s:O}=V,$=U(N),G=a(O),ot=i($*G),it=i(M*G),ct=c.BASE.multiplyAndAddUnsafe(D,ot,it)?.toAffine();return ct?i(ct.x)===M:!1}return{CURVE:t,getPublicKey:E,getSharedSecret:S,sign:H,verify:et,ProjectivePoint:c,Signature:d,utils:b}}function Uf(r){return{hash:r,hmac:(t,...e)=>Bo(r,t,gs(...e)),randomBytes:_r}}function Ga(r,t){let e=n=>za({...r,...Uf(n)});return Object.freeze({...e(t),create:e})}var Wa=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),ja=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),Lf=BigInt(1),Eo=BigInt(2),Za=(r,t)=>(r+t/Eo)/t;function Rf(r){let t=Wa,e=BigInt(3),n=BigInt(6),s=BigInt(11),o=BigInt(22),i=BigInt(23),a=BigInt(44),c=BigInt(88),f=r*r*r%t,l=f*f*r%t,u=Z(l,e,t)*l%t,h=Z(u,e,t)*l%t,w=Z(h,Eo,t)*f%t,v=Z(w,s,t)*w%t,y=Z(v,o,t)*v%t,d=Z(y,a,t)*y%t,b=Z(d,c,t)*d%t,E=Z(b,a,t)*y%t,g=Z(E,e,t)*l%t,S=Z(g,i,t)*v%t,L=Z(S,n,t)*f%t,U=Z(L,Eo,t);if(!Ao.eql(Ao.sqr(U),r))throw new Error("Cannot find square root");return U}var Ao=pe(Wa,void 0,void 0,{sqrt:Rf}),Le=Ga({a:BigInt(0),b:BigInt(7),Fp:Ao,n:ja,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=ja,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-Lf*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),s=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),o=e,i=BigInt("0x100000000000000000000000000000000"),a=Za(o*r,t),c=Za(-n*r,t),f=q(r-a*e-c*s,t),l=q(-a*n-c*o,t),u=f>i,h=l>i;if(u&&(f=t-f),h&&(l=t-l),f>i||l>i)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:u,k1:f,k2neg:h,k2:l}}}},Ge),xp=BigInt(0);var vp=Le.ProjectivePoint;function Nt(r,t){t==null&&(t=r.reduce((s,o)=>s+o.length,0));let e=At(t),n=0;for(let s of r)e.set(s,n),n+=s.length;return e}function Ja(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function Ya(r,t,e){let n=fr.digest(e instanceof Uint8Array?e:e.subarray());if(Ja(n))return n.then(({digest:s})=>Le.verify(t,s,r)).catch(s=>{throw new Er(String(s))});try{return Le.verify(t,n.digest,r)}catch(s){throw new Er(String(s))}}var $n=class{type="secp256k1";raw;_key;constructor(t){this._key=Qa(t),this.raw=Xa(this._key)}toMultihash(){return zt.digest(qe(this))}toCID(){return lt.createV1(114,this.toMultihash())}toString(){return W.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:dt(this.raw,t.raw)}verify(t,e){return Ya(this._key,e,t)}};function So(r){return new $n(r)}function Xa(r){return Le.ProjectivePoint.fromHex(r).toRawBytes(!0)}function Qa(r){try{return Le.ProjectivePoint.fromHex(r),r}catch(t){throw new Re(String(t))}}function tc(r){let{Type:t,Data:e}=Ot.decode(r),n=e??new Uint8Array;switch(t){case st.RSA:return vo(n);case st.Ed25519:return Ls(n);case st.secp256k1:return So(n);default:throw new Ve}}function ec(r){let{Type:t,Data:e}=Ot.decode(r.digest),n=e??new Uint8Array;switch(t){case st.Ed25519:return Ls(n);case st.secp256k1:return So(n);default:throw new Ve}}function qe(r){return Ot.encode({Type:st[r.type],Data:r.raw})}var nc=Symbol.for("@achingbrain/uint8arraylist");function rc(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 qn(r){return!!r?.[nc]}var zn=class r{bufs;length;[nc]=!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(qn(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(qn(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=rc(this.bufs,t);return e.buf[e.index]}set(t,e){let n=rc(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(qn(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 Nt(n,s)}subarray(t,e){let{bufs:n,length:s}=this._subList(t,e);return n.length===1?n[0]:Nt(n,s)}sublist(t,e){let{bufs:n,length:s}=this._subList(t,e),o=new r;return o.length=s,o.bufs=[...n],o}_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 o=0;o<this.bufs.length;o++){let i=this.bufs[o],a=s,c=a+i.byteLength;if(s=c,t>=c)continue;let f=t>=a&&t<c,l=e>a&&e<=c;if(f&&l){if(t===a&&e===c){n.push(i);break}let u=t-a;n.push(i.subarray(u,u+(e-t)));break}if(f){if(t===0){n.push(i);continue}n.push(i.subarray(t-a));continue}if(l){if(e===c){n.push(i);break}n.push(i.subarray(0,e-a));break}n.push(i)}return{bufs:n,length:e-t}}indexOf(t,e=0){if(!qn(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 o=256,i=new Int32Array(o);for(let u=0;u<o;u++)i[u]=-1;for(let u=0;u<s;u++)i[n[u]]=u;let a=i,c=this.byteLength-n.byteLength,f=n.byteLength-1,l;for(let u=e;u<=c;u+=l){l=0;for(let h=f;h>=0;h--){let w=this.get(u+h);if(n[h]!==w){l=Math.max(1,h-a[w]);break}}if(l===0)return u}return-1}getInt8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getInt8(0)}setInt8(t,e){let n=At(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=ut(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=ut(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=ut(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=At(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=ut(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=ut(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=ut(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=ut(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=ut(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(!dt(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,o)=>s+o.byteLength,0)),n.length=e,n}};var kr;(function(r){let t;r.codec=()=>(t==null&&(t=Xt((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.publicKey!=null&&e.publicKey.byteLength>0&&(n.uint32(10),n.bytes(e.publicKey)),e.payloadType!=null&&e.payloadType.byteLength>0&&(n.uint32(18),n.bytes(e.payloadType)),e.payload!=null&&e.payload.byteLength>0&&(n.uint32(26),n.bytes(e.payload)),e.signature!=null&&e.signature.byteLength>0&&(n.uint32(42),n.bytes(e.signature)),s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let o={publicKey:ut(0),payloadType:ut(0),payload:ut(0),signature:ut(0)},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let a=e.uint32();switch(a>>>3){case 1:{o.publicKey=e.bytes();break}case 2:{o.payloadType=e.bytes();break}case 3:{o.payload=e.bytes();break}case 5:{o.signature=e.bytes();break}default:{e.skipType(a&7);break}}}return o})),t),r.encode=e=>Yt(e,r.codec()),r.decode=(e,n)=>Jt(e,r.codec(),n)})(kr||(kr={}));var Gn=class extends Error{constructor(t="Invalid signature"){super(t),this.name="InvalidSignatureError"}};var jn=class r{static createFromProtobuf=async t=>{let e=kr.decode(t),n=tc(e.publicKey);return new r({publicKey:n,payloadType:e.payloadType,payload:e.payload,signature:e.signature})};static seal=async(t,e)=>{if(e==null)throw new Error("Missing private key");let n=t.domain,s=t.codec,o=t.marshal(),i=sc(n,s,o),a=await e.sign(i.subarray());return new r({publicKey:e.publicKey,payloadType:s,payload:o,signature:a})};static openAndCertify=async(t,e)=>{let n=await r.createFromProtobuf(t);if(!await n.validate(e))throw new Gn("Envelope signature is not valid for the given domain");return n};publicKey;payloadType;payload;signature;marshaled;constructor(t){let{publicKey:e,payloadType:n,payload:s,signature:o}=t;this.publicKey=e,this.payloadType=n,this.payload=s,this.signature=o}marshal(){return this.marshaled==null&&(this.marshaled=kr.encode({publicKey:qe(this.publicKey),payloadType:this.payloadType,payload:this.payload.subarray(),signature:this.signature})),this.marshaled}equals(t){return dt(this.marshal(),t.marshal())}async validate(t){let e=sc(t,this.payloadType,this.payload);return this.publicKey.verify(e.subarray(),this.signature)}},sc=(r,t,e)=>{let n=J(r),s=Dt(n.byteLength),o=Dt(t.length),i=Dt(e.length);return new zn(s,n,o,t,i,e)};var oc=Symbol.for("nodejs.util.inspect.custom"),Vf=114,Ir=class{type;multihash;publicKey;string;constructor(t){this.type=t.type,this.multihash=t.multihash,Object.defineProperty(this,"string",{enumerable:!1,writable:!0})}get[Symbol.toStringTag](){return`PeerId(${this.toString()})`}[ss]=!0;toString(){return this.string==null&&(this.string=W.encode(this.multihash.bytes).slice(1)),this.string}toMultihash(){return this.multihash}toCID(){return lt.createV1(Vf,this.multihash)}toJSON(){return this.toString()}equals(t){if(t==null)return!1;if(t instanceof Uint8Array)return dt(this.multihash.bytes,t);if(typeof t=="string")return this.toString()===t;if(t?.toMultihash()?.bytes!=null)return dt(this.multihash.bytes,t.toMultihash().bytes);throw new Error("not valid Id")}[oc](){return`PeerId(${this.toString()})`}},Zn=class extends Ir{type="RSA";publicKey;constructor(t){super({...t,type:"RSA"}),this.publicKey=t.publicKey}},Wn=class extends Ir{type="Ed25519";publicKey;constructor(t){super({...t,type:"Ed25519"}),this.publicKey=t.publicKey}},Jn=class extends Ir{type="secp256k1";publicKey;constructor(t){super({...t,type:"secp256k1"}),this.publicKey=t.publicKey}},_f=2336,Yn=class{type="url";multihash;publicKey;url;constructor(t){this.url=t.toString(),this.multihash=zt.digest(J(this.url))}[oc](){return`PeerId(${this.url})`}[ss]=!0;toString(){return this.toCID().toString()}toMultihash(){return this.multihash}toCID(){return lt.createV1(_f,this.toMultihash())}toJSON(){return this.toString()}equals(t){return t==null?!1:(t instanceof Uint8Array&&(t=Q(t)),t.toString()===this.toString())}};function ic(r){if(Df(r))return new Zn({multihash:r});if(Hf(r))try{let t=ec(r);if(t.type==="Ed25519")return new Wn({multihash:r,publicKey:t});if(t.type==="secp256k1")return new Jn({multihash:r,publicKey:t})}catch{let e=Q(r.digest);return new Yn(new URL(e))}throw new Ur("Supplied PeerID Multihash is invalid")}function Hf(r){return r.code===zt.code}function Df(r){return r.code===fr.code}function ac(r,t){let e=(n,s)=>n.toString().localeCompare(s.toString());return r.length!==t.length?!1:(t.sort(e),r.sort(e).every((n,s)=>t[s].equals(n)))}var Xn=class{index=0;input="";new(t){return this.index=0,this.input=t,this}readAtomically(t){let e=this.index,n=t();return n===void 0&&(this.index=e),n}parseWith(t){let e=t();if(this.index===this.input.length)return e}peekChar(){if(!(this.index>=this.input.length))return this.input[this.index]}readChar(){if(!(this.index>=this.input.length))return this.input[this.index++]}readGivenChar(t){return this.readAtomically(()=>{let e=this.readChar();if(e===t)return e})}readSeparator(t,e,n){return this.readAtomically(()=>{if(!(e>0&&this.readGivenChar(t)===void 0))return n()})}readNumber(t,e,n,s){return this.readAtomically(()=>{let o=0,i=0,a=this.peekChar();if(a===void 0)return;let c=a==="0",f=2**(8*s)-1;for(;;){let l=this.readAtomically(()=>{let u=this.readChar();if(u===void 0)return;let h=Number.parseInt(u,t);if(!Number.isNaN(h))return h});if(l===void 0)break;if(o*=t,o+=l,o>f||(i+=1,e!==void 0&&i>e))return}if(i!==0)return!n&&c&&i>1?void 0:o})}readIPv4Addr(){return this.readAtomically(()=>{let t=new Uint8Array(4);for(let e=0;e<t.length;e++){let n=this.readSeparator(".",e,()=>this.readNumber(10,3,!1,1));if(n===void 0)return;t[e]=n}return t})}readIPv6Addr(){let t=e=>{for(let n=0;n<e.length/2;n++){let s=n*2;if(n<e.length-3){let i=this.readSeparator(":",n,()=>this.readIPv4Addr());if(i!==void 0)return e[s]=i[0],e[s+1]=i[1],e[s+2]=i[2],e[s+3]=i[3],[s+4,!0]}let o=this.readSeparator(":",n,()=>this.readNumber(16,4,!0,2));if(o===void 0)return[s,!1];e[s]=o>>8,e[s+1]=o&255}return[e.length,!1]};return this.readAtomically(()=>{let e=new Uint8Array(16),[n,s]=t(e);if(n===16)return e;if(s||this.readGivenChar(":")===void 0||this.readGivenChar(":")===void 0)return;let o=new Uint8Array(14),i=16-(n+2),[a]=t(o.subarray(0,i));return e.set(o.subarray(0,a),16-a),e})}readIPAddr(){return this.readIPv4Addr()??this.readIPv6Addr()}};var cc=45,Of=15,Qe=new Xn;function ko(r){if(!(r.length>Of))return Qe.new(r).parseWith(()=>Qe.readIPv4Addr())}function Io(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>cc))return Qe.new(r).parseWith(()=>Qe.readIPv6Addr())}function Qn(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>cc))return Qe.new(r).parseWith(()=>Qe.readIPAddr())}var Qg=parseInt("0xFFFF",16),tm=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);function fc(r){return!!ko(r)}function hc(r){return!!Io(r)}function ts(r){return!!Qn(r)}var dc=fc,$f=hc,No=function(r){let t=0;if(r=r.toString().trim(),dc(r)){let e=new Uint8Array(t+4);return r.split(/\./g).forEach(n=>{e[t++]=parseInt(n,10)&255}),e}if($f(r)){let e=r.split(":",8),n;for(n=0;n<e.length;n++){let o=dc(e[n]),i;o&&(i=No(e[n]),e[n]=Q(i.slice(0,2),"base16")),i!=null&&++n<8&&e.splice(n,0,Q(i.slice(2,4),"base16"))}if(e[0]==="")for(;e.length<8;)e.unshift("0");else if(e[e.length-1]==="")for(;e.length<8;)e.push("0");else if(e.length<8){for(n=0;n<e.length&&e[n]!=="";n++);let o=[n,1];for(n=9-e.length;n>0;n--)o.push("0");e.splice.apply(e,o)}let s=new Uint8Array(t+16);for(n=0;n<e.length;n++){let o=parseInt(e[n],16);s[t++]=o>>8&255,s[t++]=o&255}return s}throw new Error("invalid ip address")},pc=function(r,t=0,e){t=~~t,e=e??r.length-t;let n=new DataView(r.buffer);if(e===4){let s=[];for(let o=0;o<e;o++)s.push(r[t+o]);return s.join(".")}if(e===16){let s=[];for(let o=0;o<e;o+=2)s.push(n.getUint16(t+o).toString(16));return s.join(":").replace(/(^|:)0(:0)*:0(:|$)/,"$1::$3").replace(/:{3,4}/,"::")}return""};var tr={},Co={},zf=[[4,32,"ip4"],[6,16,"tcp"],[33,16,"dccp"],[41,128,"ip6"],[42,-1,"ip6zone"],[43,8,"ipcidr"],[53,-1,"dns",!0],[54,-1,"dns4",!0],[55,-1,"dns6",!0],[56,-1,"dnsaddr",!0],[132,16,"sctp"],[273,16,"udp"],[275,0,"p2p-webrtc-star"],[276,0,"p2p-webrtc-direct"],[277,0,"p2p-stardust"],[280,0,"webrtc-direct"],[281,0,"webrtc"],[290,0,"p2p-circuit"],[301,0,"udt"],[302,0,"utp"],[400,-1,"unix",!1,!0],[421,-1,"ipfs"],[421,-1,"p2p"],[443,0,"https"],[444,96,"onion"],[445,296,"onion3"],[446,-1,"garlic64"],[448,0,"tls"],[449,-1,"sni"],[460,0,"quic"],[461,0,"quic-v1"],[465,0,"webtransport"],[466,-1,"certhash"],[477,0,"ws"],[478,0,"wss"],[479,0,"p2p-websocket-star"],[480,0,"http"],[481,-1,"http-path"],[777,-1,"memory"]];zf.forEach(r=>{let t=Gf(...r);Co[t.code]=t,tr[t.name]=t});function Gf(r,t,e,n,s){return{code:r,size:t,name:e,resolvable:!!n,path:!!s}}function z(r){if(typeof r=="number"){if(Co[r]!=null)return Co[r];throw new Error(`no protocol with code: ${r}`)}else if(typeof r=="string"){if(tr[r]!=null)return tr[r];throw new Error(`no protocol with name: ${r}`)}throw new Error(`invalid protocol id type: ${typeof r}`)}var Dm=z("ip4"),Om=z("ip6"),Pm=z("ipcidr");function Ro(r,t){switch(z(r).code){case 4:case 41:return Zf(t);case 42:return Lo(t);case 6:case 273:case 33:case 132:return yc(t).toString();case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Lo(t);case 421:return Xf(t);case 444:return mc(t);case 445:return mc(t);case 466:return Yf(t);case 481:return globalThis.encodeURIComponent(Lo(t));default:return Q(t,"base16")}}function Vo(r,t){switch(z(r).code){case 4:return gc(t);case 41:return gc(t);case 42:return Uo(t);case 6:case 273:case 33:case 132:return _o(parseInt(t,10));case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Uo(t);case 421:return Wf(t);case 444:return Qf(t);case 445:return th(t);case 466:return Jf(t);case 481:return Uo(globalThis.decodeURIComponent(t));default:return J(t,"base16")}}var To=Object.values(hr).map(r=>r.decoder),jf=function(){let r=To[0].or(To[1]);return To.slice(2).forEach(t=>r=r.or(t)),r}();function gc(r){if(!ts(r))throw new Error("invalid ip address");return No(r)}function Zf(r){let t=pc(r,0,r.length);if(t==null)throw new Error("ipBuff is required");if(!ts(t))throw new Error("invalid ip address");return t}function _o(r){let t=new ArrayBuffer(2);return new DataView(t).setUint16(0,r),new Uint8Array(t)}function yc(r){return new DataView(r.buffer).getUint16(r.byteOffset)}function Uo(r){let t=J(r),e=Uint8Array.from(Dt(t.length));return Nt([e,t],e.length+t.length)}function Lo(r){let t=Ne(r);if(r=r.slice(St(t)),r.length!==t)throw new Error("inconsistent lengths");return Q(r)}function Wf(r){let t;r[0]==="Q"||r[0]==="1"?t=ve(W.decode(`z${r}`)).bytes:t=lt.parse(r).multihash.bytes;let e=Uint8Array.from(Dt(t.length));return Nt([e,t],e.length+t.length)}function Jf(r){let t=jf.decode(r),e=Uint8Array.from(Dt(t.length));return Nt([e,t],e.length+t.length)}function Yf(r){let t=Ne(r),e=r.slice(St(t));if(e.length!==t)throw new Error("inconsistent lengths");return"u"+Q(e,"base64url")}function Xf(r){let t=Ne(r),e=r.slice(St(t));if(e.length!==t)throw new Error("inconsistent lengths");return Q(e,"base58btc")}function Qf(r){let t=r.split(":");if(t.length!==2)throw new Error(`failed to parse onion addr: ["'${t.join('", "')}'"]' does not contain a port number`);if(t[0].length!==16)throw new Error(`failed to parse onion addr: ${t[0]} not a Tor onion address.`);let e=qt.decode("b"+t[0]),n=parseInt(t[1],10);if(n<1||n>65536)throw new Error("Port number is not in range(1, 65536)");let s=_o(n);return Nt([e,s],e.length+s.length)}function th(r){let t=r.split(":");if(t.length!==2)throw new Error(`failed to parse onion addr: ["'${t.join('", "')}'"]' does not contain a port number`);if(t[0].length!==56)throw new Error(`failed to parse onion addr: ${t[0]} not a Tor onion3 address.`);let e=qt.decode(`b${t[0]}`),n=parseInt(t[1],10);if(n<1||n>65536)throw new Error("Port number is not in range(1, 65536)");let s=_o(n);return Nt([e,s],e.length+s.length)}function mc(r){let t=r.slice(0,r.length-2),e=r.slice(r.length-2),n=Q(t,"base32"),s=yc(e);return`${n}:${s}`}function bc(r){r=Ho(r);let t=[],e=[],n=null,s=r.split("/").slice(1);if(s.length===1&&s[0]==="")return{bytes:new Uint8Array,string:"/",tuples:[],stringTuples:[],path:null};for(let o=0;o<s.length;o++){let i=s[o],a=z(i);if(a.size===0){t.push([a.code]),e.push([a.code]);continue}if(o++,o>=s.length)throw xc("invalid address: "+r);if(a.path===!0){n=Ho(s.slice(o).join("/")),t.push([a.code,Vo(a.code,n)]),e.push([a.code,n]);break}let c=Vo(a.code,s[o]);t.push([a.code,c]),e.push([a.code,Ro(a.code,c)])}return{string:wc(e),bytes:Oo(t),tuples:t,stringTuples:e,path:n}}function Do(r){let t=[],e=[],n=null,s=0;for(;s<r.length;){let o=Ne(r,s),i=St(o),a=z(o),c=eh(a,r.slice(s+i));if(c===0){t.push([o]),e.push([o]),s+=i;continue}let f=r.slice(s+i,s+i+c);if(s+=c+i,s>r.length)throw xc("Invalid address Uint8Array: "+Q(r,"base16"));t.push([o,f]);let l=Ro(o,f);if(e.push([o,l]),a.path===!0){n=l;break}}return{bytes:Uint8Array.from(r),string:wc(e),tuples:t,stringTuples:e,path:n}}function wc(r){let t=[];return r.map(e=>{let n=z(e[0]);return t.push(n.name),e.length>1&&e[1]!=null&&t.push(e[1]),null}),Ho(t.join("/"))}function Oo(r){return Nt(r.map(t=>{let e=z(t[0]),n=Uint8Array.from(Dt(e.code));return t.length>1&&t[1]!=null&&(n=Nt([n,t[1]])),n}))}function eh(r,t){if(r.size>0)return r.size/8;if(r.size===0)return 0;{let e=Ne(t instanceof Uint8Array?t:Uint8Array.from(t));return e+St(e)}}function Ho(r){return"/"+r.trim().split("/").filter(t=>t).join("/")}function xc(r){return new Error("Error parsing address: "+r)}var rh=Symbol.for("nodejs.util.inspect.custom"),Mo=Symbol.for("@multiformats/js-multiaddr/multiaddr"),nh=[z("dns").code,z("dns4").code,z("dns6").code,z("dnsaddr").code],Po=class extends Error{constructor(t="No available resolver"){super(t),this.name="NoAvailableResolverError"}},es=class r{bytes;#e;#t;#r;#n;[Mo]=!0;constructor(t){t==null&&(t="");let e;if(t instanceof Uint8Array)e=Do(t);else if(typeof t=="string"){if(t.length>0&&t.charAt(0)!=="/")throw new Error(`multiaddr "${t}" must start with a "/"`);e=bc(t)}else if(Bc(t))e=Do(t.bytes);else throw new Error("addr must be a string, Buffer, or another Multiaddr");this.bytes=e.bytes,this.#e=e.string,this.#t=e.tuples,this.#r=e.stringTuples,this.#n=e.path}toString(){return this.#e}toJSON(){return this.toString()}toOptions(){let t,e,n,s,o="",i=z("tcp"),a=z("udp"),c=z("ip4"),f=z("ip6"),l=z("dns6"),u=z("ip6zone");for(let[w,v]of this.stringTuples())w===u.code&&(o=`%${v??""}`),nh.includes(w)&&(e=i.name,s=443,n=`${v??""}${o}`,t=w===l.code?6:4),(w===i.code||w===a.code)&&(e=z(w).name,s=parseInt(v??"")),(w===c.code||w===f.code)&&(e=z(w).name,n=`${v??""}${o}`,t=w===f.code?6:4);if(t==null||e==null||n==null||s==null)throw new Error('multiaddr must have a valid format: "/{ip4, ip6, dns4, dns6, dnsaddr}/{address}/{tcp, udp}/{port}".');return{family:t,host:n,transport:e,port:s}}protos(){return this.#t.map(([t])=>Object.assign({},z(t)))}protoCodes(){return this.#t.map(([t])=>t)}protoNames(){return this.#t.map(([t])=>z(t).name)}tuples(){return this.#t.map(([t,e])=>e==null?[t]:[t,e])}stringTuples(){return this.#r.map(([t,e])=>e==null?[t]:[t,e])}encapsulate(t){return t=new r(t),new r(this.toString()+t.toString())}decapsulate(t){let e=t.toString(),n=this.toString(),s=n.lastIndexOf(e);if(s<0)throw new Error(`Address ${this.toString()} does not contain subaddress: ${t.toString()}`);return new r(n.slice(0,s))}decapsulateCode(t){let e=this.tuples();for(let n=e.length-1;n>=0;n--)if(e[n][0]===t)return new r(Oo(e.slice(0,n)));return this}getPeerId(){try{let t=[];this.stringTuples().forEach(([n,s])=>{n===tr.p2p.code&&t.push([n,s]),n===tr["p2p-circuit"].code&&(t=[])});let e=t.pop();if(e?.[1]!=null){let n=e[1];return n[0]==="Q"||n[0]==="1"?Q(W.decode(`z${n}`),"base58btc"):Q(lt.parse(n).multihash.bytes,"base58btc")}return null}catch{return null}}getPath(){return this.#n}equals(t){return dt(this.bytes,t.bytes)}async resolve(t){let e=this.protos().find(o=>o.resolvable);if(e==null)return[this];let n=vc.get(e.name);if(n==null)throw new Po(`no available resolver for ${e.name}`);return(await n(this,t)).map(o=>Nr(o))}nodeAddress(){let t=this.toOptions();if(t.transport!=="tcp"&&t.transport!=="udp")throw new Error(`multiaddr must have a valid format - no protocol with name: "${t.transport}". Must have a valid transport protocol: "{tcp, udp}"`);return{family:t.family,address:t.host,port:t.port}}isThinWaistAddress(t){let e=(t??this).protos();return!(e.length!==2||e[0].code!==4&&e[0].code!==41||e[1].code!==6&&e[1].code!==273)}[rh](){return`Multiaddr(${this.#e})`}};var vc=new Map;function Bc(r){return!!r?.[Mo]}function Nr(r){return new es(r)}var Ec="libp2p-peer-record",Ac=Uint8Array.from([3,1]);var Cr;(function(r){let t;(function(n){let s;n.codec=()=>(s==null&&(s=Xt((o,i,a={})=>{a.lengthDelimited!==!1&&i.fork(),o.multiaddr!=null&&o.multiaddr.byteLength>0&&(i.uint32(10),i.bytes(o.multiaddr)),a.lengthDelimited!==!1&&i.ldelim()},(o,i,a={})=>{let c={multiaddr:ut(0)},f=i==null?o.len:o.pos+i;for(;o.pos<f;){let l=o.uint32();switch(l>>>3){case 1:{c.multiaddr=o.bytes();break}default:{o.skipType(l&7);break}}}return c})),s),n.encode=o=>Yt(o,n.codec()),n.decode=(o,i)=>Jt(o,n.codec(),i)})(t=r.AddressInfo||(r.AddressInfo={}));let e;r.codec=()=>(e==null&&(e=Xt((n,s,o={})=>{if(o.lengthDelimited!==!1&&s.fork(),n.peerId!=null&&n.peerId.byteLength>0&&(s.uint32(10),s.bytes(n.peerId)),n.seq!=null&&n.seq!==0n&&(s.uint32(16),s.uint64(n.seq)),n.addresses!=null)for(let i of n.addresses)s.uint32(26),r.AddressInfo.codec().encode(i,s);o.lengthDelimited!==!1&&s.ldelim()},(n,s,o={})=>{let i={peerId:ut(0),seq:0n,addresses:[]},a=s==null?n.len:n.pos+s;for(;n.pos<a;){let c=n.uint32();switch(c>>>3){case 1:{i.peerId=n.bytes();break}case 2:{i.seq=n.uint64();break}case 3:{if(o.limits?.addresses!=null&&i.addresses.length===o.limits.addresses)throw new Wr('Decode error - map field "addresses" had too many elements');i.addresses.push(r.AddressInfo.codec().decode(n,n.uint32(),{limits:o.limits?.addresses$}));break}default:{n.skipType(c&7);break}}}return i})),e),r.encode=n=>Yt(n,r.codec()),r.decode=(n,s)=>Jt(n,r.codec(),s)})(Cr||(Cr={}));var rs=class r{static createFromProtobuf=t=>{let e=Cr.decode(t),n=ic(ve(e.peerId)),s=(e.addresses??[]).map(i=>Nr(i.multiaddr)),o=e.seq;return new r({peerId:n,multiaddrs:s,seqNumber:o})};static DOMAIN=Ec;static CODEC=Ac;peerId;multiaddrs;seqNumber;domain=r.DOMAIN;codec=r.CODEC;marshaled;constructor(t){let{peerId:e,multiaddrs:n,seqNumber:s}=t;this.peerId=e,this.multiaddrs=n??[],this.seqNumber=s??BigInt(Date.now())}marshal(){return this.marshaled==null&&(this.marshaled=Cr.encode({peerId:this.peerId.toMultihash().bytes,seq:BigInt(this.seqNumber),addresses:this.multiaddrs.map(t=>({multiaddr:t.bytes}))})),this.marshaled}equals(t){return!(!(t instanceof r)||!this.peerId.equals(t.peerId)||this.seqNumber!==t.seqNumber||!ac(this.multiaddrs,t.multiaddrs))}};return Mc(sh);})();
7
7
  /*! Bundled license information:
8
8
 
9
9
  pvtsutils/build/index.js:
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@libp2p/peer-record",
3
- "version": "8.0.11-656db81cf",
3
+ "version": "8.0.12-0862522fe",
4
4
  "description": "Used to transfer signed peer data across the network",
5
5
  "license": "Apache-2.0 OR MIT",
6
6
  "homepage": "https://github.com/libp2p/js-libp2p/tree/main/packages/peer-record#readme",
@@ -61,10 +61,10 @@
61
61
  "test:electron-main": "aegir test -t electron-main"
62
62
  },
63
63
  "dependencies": {
64
- "@libp2p/crypto": "5.0.6-656db81cf",
65
- "@libp2p/interface": "2.2.0-656db81cf",
66
- "@libp2p/peer-id": "5.0.7-656db81cf",
67
- "@libp2p/utils": "6.2.0-656db81cf",
64
+ "@libp2p/crypto": "5.0.7-0862522fe",
65
+ "@libp2p/interface": "2.2.1-0862522fe",
66
+ "@libp2p/peer-id": "5.0.8-0862522fe",
67
+ "@libp2p/utils": "6.2.1-0862522fe",
68
68
  "@multiformats/multiaddr": "^12.2.3",
69
69
  "multiformats": "^13.2.2",
70
70
  "protons-runtime": "^5.4.0",