@libp2p/plaintext 1.1.5 → 1.1.6
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 +101 -1
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/index.js +19 -4
- package/dist/src/index.js.map +1 -1
- package/package.json +3 -2
- package/src/index.ts +19 -5
package/dist/index.min.js
CHANGED
|
@@ -1,3 +1,103 @@
|
|
|
1
1
|
(function (root, factory) {(typeof module === 'object' && module.exports) ? module.exports = factory() : root.Libp2PPlaintext = factory()}(typeof self !== 'undefined' ? self : this, function () {
|
|
2
|
-
"use strict";var Libp2PPlaintext=(()=>{var Tt=Object.defineProperty;var yr=Object.getOwnPropertyDescriptor;var Er=Object.getOwnPropertyNames;var Ar=Object.prototype.hasOwnProperty;var y=(r,t)=>{for(var e in t)Tt(r,e,{get:t[e],enumerable:!0})},Sr=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let i of Er(t))!Ar.call(r,i)&&i!==e&&Tt(r,i,{get:()=>t[i],enumerable:!(n=yr(t,i))||n.enumerable});return r};var Lr=r=>Sr(Tt({},"__esModule",{value:!0}),r);var Kn={};y(Kn,{plaintext:()=>Jn});var _t=Symbol.for("@libp2p/peer-id");var pt=class r extends Error{code;constructor(t="Unexpected Peer"){super(t),this.name="UnexpectedPeerError",this.code=r.code}static code="ERR_UNEXPECTED_PEER"},mt=class r extends Error{code;constructor(t="Invalid crypto exchange"){super(t),this.name="InvalidCryptoExchangeError",this.code=r.code}static code="ERR_INVALID_CRYPTO_EXCHANGE"};var Be=Symbol.for("@libp2p/service-capabilities"),ti=Symbol.for("@libp2p/service-dependencies");var Pt={};y(Pt,{base58btc:()=>E,base58flickr:()=>Fr});var Li=new Uint8Array(0);function ve(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function v(r){if(r instanceof Uint8Array&&r.constructor.name==="Uint8Array")return r;if(r instanceof ArrayBuffer)return new Uint8Array(r);if(ArrayBuffer.isView(r))return new Uint8Array(r.buffer,r.byteOffset,r.byteLength);throw new Error("Unknown type, must be binary type")}function Te(r){return new TextEncoder().encode(r)}function _e(r){return new TextDecoder().decode(r)}function Dr(r,t){if(r.length>=255)throw new TypeError("Alphabet too long");for(var e=new Uint8Array(256),n=0;n<e.length;n++)e[n]=255;for(var i=0;i<r.length;i++){var o=r.charAt(i),s=o.charCodeAt(0);if(e[s]!==255)throw new TypeError(o+" is ambiguous");e[s]=i}var a=r.length,c=r.charAt(0),d=Math.log(a)/Math.log(256),l=Math.log(256)/Math.log(a);function u(f){if(f instanceof Uint8Array||(ArrayBuffer.isView(f)?f=new Uint8Array(f.buffer,f.byteOffset,f.byteLength):Array.isArray(f)&&(f=Uint8Array.from(f))),!(f instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(f.length===0)return"";for(var b=0,z=0,L=0,N=f.length;L!==N&&f[L]===0;)L++,b++;for(var U=(N-L)*l+1>>>0,S=new Uint8Array(U);L!==N;){for(var F=f[L],M=0,D=U-1;(F!==0||M<z)&&D!==-1;D--,M++)F+=256*S[D]>>>0,S[D]=F%a>>>0,F=F/a>>>0;if(F!==0)throw new Error("Non-zero carry");z=M,L++}for(var B=U-z;B!==U&&S[B]===0;)B++;for(var dt=c.repeat(b);B<U;++B)dt+=r.charAt(S[B]);return dt}function w(f){if(typeof f!="string")throw new TypeError("Expected String");if(f.length===0)return new Uint8Array;var b=0;if(f[b]!==" "){for(var z=0,L=0;f[b]===c;)z++,b++;for(var N=(f.length-b)*d+1>>>0,U=new Uint8Array(N);f[b];){var S=e[f.charCodeAt(b)];if(S===255)return;for(var F=0,M=N-1;(S!==0||F<L)&&M!==-1;M--,F++)S+=a*U[M]>>>0,U[M]=S%256>>>0,S=S/256>>>0;if(S!==0)throw new Error("Non-zero carry");L=F,b++}if(f[b]!==" "){for(var D=N-L;D!==N&&U[D]===0;)D++;for(var B=new Uint8Array(z+(N-D)),dt=z;D!==N;)B[dt++]=U[D++];return B}}}function lt(f){var b=w(f);if(b)return b;throw new Error(`Non-${t} character`)}return{encode:u,decodeUnsafe:w,decode:lt}}var Ir=Dr,Rr=Ir,Me=Rr;var kt=class{name;prefix;baseEncode;constructor(t,e,n){this.name=t,this.prefix=e,this.baseEncode=n}encode(t){if(t instanceof Uint8Array)return`${this.prefix}${this.baseEncode(t)}`;throw Error("Unknown type, must be binary type")}},Mt=class{name;prefix;baseDecode;prefixCodePoint;constructor(t,e,n){if(this.name=t,this.prefix=e,e.codePointAt(0)===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=e.codePointAt(0),this.baseDecode=n}decode(t){if(typeof t=="string"){if(t.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(t)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(t.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(t){return Oe(this,t)}},Ot=class{decoders;constructor(t){this.decoders=t}or(t){return Oe(this,t)}decode(t){let e=t[0],n=this.decoders[e];if(n!=null)return n.decode(t);throw RangeError(`Unable to decode multibase string ${JSON.stringify(t)}, only inputs prefixed with ${Object.keys(this.decoders)} are supported`)}};function Oe(r,t){return new Ot({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var Vt=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(t,e,n,i){this.name=t,this.prefix=e,this.baseEncode=n,this.baseDecode=i,this.encoder=new kt(t,e,n),this.decoder=new Mt(t,e,i)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function X({name:r,prefix:t,encode:e,decode:n}){return new Vt(r,t,e,n)}function O({name:r,prefix:t,alphabet:e}){let{encode:n,decode:i}=Me(e,r);return X({prefix:t,name:r,encode:n,decode:o=>v(i(o))})}function Nr(r,t,e,n){let i={};for(let l=0;l<t.length;++l)i[t[l]]=l;let o=r.length;for(;r[o-1]==="=";)--o;let s=new Uint8Array(o*e/8|0),a=0,c=0,d=0;for(let l=0;l<o;++l){let u=i[r[l]];if(u===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<e|u,a+=e,a>=8&&(a-=8,s[d++]=255&c>>a)}if(a>=e||255&c<<8-a)throw new SyntaxError("Unexpected end of data");return s}function Ur(r,t,e){let n=t[t.length-1]==="=",i=(1<<e)-1,o="",s=0,a=0;for(let c=0;c<r.length;++c)for(a=a<<8|r[c],s+=8;s>e;)s-=e,o+=t[i&a>>s];if(s!==0&&(o+=t[i&a<<e-s]),n)for(;o.length*e&7;)o+="=";return o}function p({name:r,prefix:t,bitsPerChar:e,alphabet:n}){return X({prefix:t,name:r,encode(i){return Ur(i,n,e)},decode(i){return Nr(i,n,e,r)}})}var E=O({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),Fr=O({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var zt={};y(zt,{base10:()=>Cr});var Cr=O({prefix:"9",name:"base10",alphabet:"0123456789"});var Gt={};y(Gt,{base16:()=>Br,base16upper:()=>vr});var Br=p({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),vr=p({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var $t={};y($t,{base2:()=>Tr});var Tr=p({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var qt={};y(qt,{base256emoji:()=>Vr});var Ve=Array.from("\u{1F680}\u{1FA90}\u2604\u{1F6F0}\u{1F30C}\u{1F311}\u{1F312}\u{1F313}\u{1F314}\u{1F315}\u{1F316}\u{1F317}\u{1F318}\u{1F30D}\u{1F30F}\u{1F30E}\u{1F409}\u2600\u{1F4BB}\u{1F5A5}\u{1F4BE}\u{1F4BF}\u{1F602}\u2764\u{1F60D}\u{1F923}\u{1F60A}\u{1F64F}\u{1F495}\u{1F62D}\u{1F618}\u{1F44D}\u{1F605}\u{1F44F}\u{1F601}\u{1F525}\u{1F970}\u{1F494}\u{1F496}\u{1F499}\u{1F622}\u{1F914}\u{1F606}\u{1F644}\u{1F4AA}\u{1F609}\u263A\u{1F44C}\u{1F917}\u{1F49C}\u{1F614}\u{1F60E}\u{1F607}\u{1F339}\u{1F926}\u{1F389}\u{1F49E}\u270C\u2728\u{1F937}\u{1F631}\u{1F60C}\u{1F338}\u{1F64C}\u{1F60B}\u{1F497}\u{1F49A}\u{1F60F}\u{1F49B}\u{1F642}\u{1F493}\u{1F929}\u{1F604}\u{1F600}\u{1F5A4}\u{1F603}\u{1F4AF}\u{1F648}\u{1F447}\u{1F3B6}\u{1F612}\u{1F92D}\u2763\u{1F61C}\u{1F48B}\u{1F440}\u{1F62A}\u{1F611}\u{1F4A5}\u{1F64B}\u{1F61E}\u{1F629}\u{1F621}\u{1F92A}\u{1F44A}\u{1F973}\u{1F625}\u{1F924}\u{1F449}\u{1F483}\u{1F633}\u270B\u{1F61A}\u{1F61D}\u{1F634}\u{1F31F}\u{1F62C}\u{1F643}\u{1F340}\u{1F337}\u{1F63B}\u{1F613}\u2B50\u2705\u{1F97A}\u{1F308}\u{1F608}\u{1F918}\u{1F4A6}\u2714\u{1F623}\u{1F3C3}\u{1F490}\u2639\u{1F38A}\u{1F498}\u{1F620}\u261D\u{1F615}\u{1F33A}\u{1F382}\u{1F33B}\u{1F610}\u{1F595}\u{1F49D}\u{1F64A}\u{1F639}\u{1F5E3}\u{1F4AB}\u{1F480}\u{1F451}\u{1F3B5}\u{1F91E}\u{1F61B}\u{1F534}\u{1F624}\u{1F33C}\u{1F62B}\u26BD\u{1F919}\u2615\u{1F3C6}\u{1F92B}\u{1F448}\u{1F62E}\u{1F646}\u{1F37B}\u{1F343}\u{1F436}\u{1F481}\u{1F632}\u{1F33F}\u{1F9E1}\u{1F381}\u26A1\u{1F31E}\u{1F388}\u274C\u270A\u{1F44B}\u{1F630}\u{1F928}\u{1F636}\u{1F91D}\u{1F6B6}\u{1F4B0}\u{1F353}\u{1F4A2}\u{1F91F}\u{1F641}\u{1F6A8}\u{1F4A8}\u{1F92C}\u2708\u{1F380}\u{1F37A}\u{1F913}\u{1F619}\u{1F49F}\u{1F331}\u{1F616}\u{1F476}\u{1F974}\u25B6\u27A1\u2753\u{1F48E}\u{1F4B8}\u2B07\u{1F628}\u{1F31A}\u{1F98B}\u{1F637}\u{1F57A}\u26A0\u{1F645}\u{1F61F}\u{1F635}\u{1F44E}\u{1F932}\u{1F920}\u{1F927}\u{1F4CC}\u{1F535}\u{1F485}\u{1F9D0}\u{1F43E}\u{1F352}\u{1F617}\u{1F911}\u{1F30A}\u{1F92F}\u{1F437}\u260E\u{1F4A7}\u{1F62F}\u{1F486}\u{1F446}\u{1F3A4}\u{1F647}\u{1F351}\u2744\u{1F334}\u{1F4A3}\u{1F438}\u{1F48C}\u{1F4CD}\u{1F940}\u{1F922}\u{1F445}\u{1F4A1}\u{1F4A9}\u{1F450}\u{1F4F8}\u{1F47B}\u{1F910}\u{1F92E}\u{1F3BC}\u{1F975}\u{1F6A9}\u{1F34E}\u{1F34A}\u{1F47C}\u{1F48D}\u{1F4E3}\u{1F942}"),_r=Ve.reduce((r,t,e)=>(r[e]=t,r),[]),kr=Ve.reduce((r,t,e)=>(r[t.codePointAt(0)]=e,r),[]);function Mr(r){return r.reduce((t,e)=>(t+=_r[e],t),"")}function Or(r){let t=[];for(let e of r){let n=kr[e.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${e}`);t.push(n)}return new Uint8Array(t)}var Vr=X({prefix:"\u{1F680}",name:"base256emoji",encode:Mr,decode:Or});var Xt={};y(Xt,{base32:()=>j,base32hex:()=>$r,base32hexpad:()=>Xr,base32hexpadupper:()=>jr,base32hexupper:()=>qr,base32pad:()=>zr,base32padupper:()=>Gr,base32upper:()=>Pr,base32z:()=>Hr});var j=p({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),Pr=p({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),zr=p({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),Gr=p({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),$r=p({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),qr=p({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),Xr=p({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),jr=p({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),Hr=p({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var jt={};y(jt,{base36:()=>Wr,base36upper:()=>Jr});var Wr=O({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),Jr=O({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Ht={};y(Ht,{base64:()=>Kr,base64pad:()=>Qr,base64url:()=>Zr,base64urlpad:()=>Yr});var Kr=p({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),Qr=p({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Zr=p({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Yr=p({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Wt={};y(Wt,{base8:()=>tn});var tn=p({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Jt={};y(Jt,{identity:()=>en});var en=X({prefix:"\0",name:"identity",encode:r=>_e(r),decode:r=>Te(r)});var Pi=new TextEncoder,zi=new TextDecoder;var Qt={};y(Qt,{identity:()=>G});var on=Ge,Pe=128,sn=127,an=~sn,cn=Math.pow(2,31);function Ge(r,t,e){t=t||[],e=e||0;for(var n=e;r>=cn;)t[e++]=r&255|Pe,r/=128;for(;r&an;)t[e++]=r&255|Pe,r>>>=7;return t[e]=r|0,Ge.bytes=e-n+1,t}var hn=Kt,un=128,ze=127;function Kt(r,n){var e=0,n=n||0,i=0,o=n,s,a=r.length;do{if(o>=a)throw Kt.bytes=0,new RangeError("Could not decode varint");s=r[o++],e+=i<28?(s&ze)<<i:(s&ze)*Math.pow(2,i),i+=7}while(s>=un);return Kt.bytes=o-n,e}var fn=Math.pow(2,7),ln=Math.pow(2,14),dn=Math.pow(2,21),pn=Math.pow(2,28),mn=Math.pow(2,35),gn=Math.pow(2,42),wn=Math.pow(2,49),bn=Math.pow(2,56),xn=Math.pow(2,63),yn=function(r){return r<fn?1:r<ln?2:r<dn?3:r<pn?4:r<mn?5:r<gn?6:r<wn?7:r<bn?8:r<xn?9:10},En={encode:on,decode:hn,encodingLength:yn},An=En,nt=An;function it(r,t=0){return[nt.decode(r,t),nt.decode.bytes]}function H(r,t,e=0){return nt.encode(r,t,e),t}function W(r){return nt.encodingLength(r)}function C(r,t){let e=t.byteLength,n=W(r),i=n+W(e),o=new Uint8Array(i+e);return H(r,o,0),H(e,o,n),o.set(t,i),new J(r,e,t,o)}function ot(r){let t=v(r),[e,n]=it(t),[i,o]=it(t.subarray(n)),s=t.subarray(n+o);if(s.byteLength!==i)throw new Error("Incorrect length");return new J(e,i,s,t)}function $e(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&ve(r.bytes,e.bytes)}}var J=class{code;size;digest;bytes;constructor(t,e,n,i){this.code=t,this.size=e,this.digest=n,this.bytes=i}};var qe=0,Sn="identity",Xe=v;function Ln(r){return C(qe,Xe(r))}var G={code:qe,name:Sn,encode:Xe,digest:Ln};var te={};y(te,{sha256:()=>st,sha512:()=>Dn});function Yt({name:r,code:t,encode:e}){return new Zt(r,t,e)}var Zt=class{name;code;encode;constructor(t,e,n){this.name=t,this.code=e,this.encode=n}digest(t){if(t instanceof Uint8Array){let e=this.encode(t);return e instanceof Uint8Array?C(this.code,e):e.then(n=>C(this.code,n))}else throw Error("Unknown type, must be binary type")}};function He(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var st=Yt({name:"sha2-256",code:18,encode:He("SHA-256")}),Dn=Yt({name:"sha2-512",code:19,encode:He("SHA-512")});function We(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return Rn(e,ee(r),t??E.encoder);default:return Nn(e,ee(r),t??j.encoder)}}var Je=new WeakMap;function ee(r){let t=Je.get(r);if(t==null){let e=new Map;return Je.set(r,e),e}return t}var V=class r{code;version;multihash;bytes;"/";constructor(t,e,n,i){this.code=e,this.version=t,this.multihash=n,this.bytes=i,this["/"]=i}get asCID(){return this}get byteOffset(){return this.bytes.byteOffset}get byteLength(){return this.bytes.byteLength}toV0(){switch(this.version){case 0:return this;case 1:{let{code:t,multihash:e}=this;if(t!==at)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==Un)throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");return r.createV0(e)}default:throw Error(`Can not convert CID version ${this.version} to version 0. This is a bug please report`)}}toV1(){switch(this.version){case 0:{let{code:t,digest:e}=this.multihash,n=C(t,e);return r.createV1(this.code,n)}case 1:return this;default:throw Error(`Can not convert CID version ${this.version} to version 1. This is a bug please report`)}}equals(t){return r.equals(this,t)}static equals(t,e){let n=e;return n!=null&&t.code===n.code&&t.version===n.version&&$e(t.multihash,n.multihash)}toString(t){return We(this,t)}toJSON(){return{"/":We(this)}}link(){return this}[Symbol.toStringTag]="CID";[Symbol.for("nodejs.util.inspect.custom")](){return`CID(${this.toString()})`}static asCID(t){if(t==null)return null;let e=t;if(e instanceof r)return e;if(e["/"]!=null&&e["/"]===e.bytes||e.asCID===e){let{version:n,code:i,multihash:o,bytes:s}=e;return new r(n,i,o,s??Ke(n,i,o.bytes))}else if(e[Fn]===!0){let{version:n,multihash:i,code:o}=e,s=ot(i);return r.create(n,o,s)}else return null}static create(t,e,n){if(typeof e!="number")throw new Error("String codecs are no longer supported");if(!(n.bytes instanceof Uint8Array))throw new Error("Invalid digest");switch(t){case 0:{if(e!==at)throw new Error(`Version 0 CID must use dag-pb (code: ${at}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let i=Ke(t,e,n.bytes);return new r(t,e,n,i)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,at,t)}static createV1(t,e){return r.create(1,t,e)}static decode(t){let[e,n]=r.decodeFirst(t);if(n.length!==0)throw new Error("Incorrect length");return e}static decodeFirst(t){let e=r.inspectBytes(t),n=e.size-e.multihashSize,i=v(t.subarray(n,n+e.multihashSize));if(i.byteLength!==e.multihashSize)throw new Error("Incorrect length");let o=i.subarray(e.multihashSize-e.digestSize),s=new J(e.multihashCode,e.digestSize,o,i);return[e.version===0?r.createV0(s):r.createV1(e.codec,s),t.subarray(e.size)]}static inspectBytes(t){let e=0,n=()=>{let[u,w]=it(t.subarray(e));return e+=w,u},i=n(),o=at;if(i===18?(i=0,e=0):o=n(),i!==0&&i!==1)throw new RangeError(`Invalid CID version ${i}`);let s=e,a=n(),c=n(),d=e+c,l=d-s;return{version:i,codec:o,multihashCode:a,digestSize:c,multihashSize:l,size:d}}static parse(t,e){let[n,i]=In(t,e),o=r.decode(i);if(o.version===0&&t[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return ee(o).set(n,t),o}};function In(r,t){switch(r[0]){case"Q":{let e=t??E;return[E.prefix,e.decode(`${E.prefix}${r}`)]}case E.prefix:{let e=t??E;return[E.prefix,e.decode(r)]}case j.prefix:{let e=t??j;return[j.prefix,e.decode(r)]}default:{if(t==null)throw Error("To parse non base32 or base58btc encoded CID multibase decoder must be provided");return[r[0],t.decode(r)]}}}function Rn(r,t,e){let{prefix:n}=e;if(n!==E.prefix)throw Error(`Cannot string encode V0 in ${e.name} encoding`);let i=t.get(n);if(i==null){let o=e.encode(r).slice(1);return t.set(n,o),o}else return i}function Nn(r,t,e){let{prefix:n}=e,i=t.get(n);if(i==null){let o=e.encode(r);return t.set(n,o),o}else return i}var at=112,Un=18;function Ke(r,t,e){let n=W(r),i=n+W(t),o=new Uint8Array(i+e.byteLength);return H(r,o,0),H(t,o,n),o.set(e,i),o}var Fn=Symbol.for("@ipld/js-cid/CID");var Q={...Jt,...$t,...Wt,...zt,...Gt,...Xt,...jt,...Pt,...Ht,...qt},co={...te,...Qt};function ct(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function T(r=0){return new Uint8Array(r)}function x(r=0){return new Uint8Array(r)}function Ze(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var Qe=Ze("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),re=Ze("ascii","a",r=>{let t="a";for(let e=0;e<r.length;e++)t+=String.fromCharCode(r[e]);return t},r=>{r=r.substring(1);let t=x(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),Cn={utf8:Qe,"utf-8":Qe,hex:Q.base16,latin1:re,ascii:re,binary:re,...Q},wt=Cn;function bt(r,t="utf8"){let e=wt[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function ne(r,t="utf8"){let e=wt[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}var tr=Symbol.for("nodejs.util.inspect.custom"),Ye=Object.values(Q).map(r=>r.decoder).reduce((r,t)=>r.or(t),Q.identity.decoder),er=114,se=36,ae=37,ht=class{type;multihash;privateKey;publicKey;string;constructor(t){this.type=t.type,this.multihash=t.multihash,this.privateKey=t.privateKey,Object.defineProperty(this,"string",{enumerable:!1,writable:!0})}get[Symbol.toStringTag](){return`PeerId(${this.toString()})`}[_t]=!0;toString(){return this.string==null&&(this.string=E.encode(this.multihash.bytes).slice(1)),this.string}toCID(){return V.createV1(er,this.multihash)}toBytes(){return this.multihash.bytes}toJSON(){return this.toString()}equals(t){if(t==null)return!1;if(t instanceof Uint8Array)return ct(this.multihash.bytes,t);if(typeof t=="string")return Bn(t).equals(this);if(t?.multihash?.bytes!=null)return ct(this.multihash.bytes,t.multihash.bytes);throw new Error("not valid Id")}[tr](){return`PeerId(${this.toString()})`}},Z=class extends ht{type="RSA";publicKey;constructor(t){super({...t,type:"RSA"}),this.publicKey=t.publicKey}},Y=class extends ht{type="Ed25519";publicKey;constructor(t){super({...t,type:"Ed25519"}),this.publicKey=t.multihash.digest}},tt=class extends ht{type="secp256k1";publicKey;constructor(t){super({...t,type:"secp256k1"}),this.publicKey=t.multihash.digest}},ie=2336,oe=class{type="url";multihash;privateKey;publicKey;url;constructor(t){this.url=t.toString(),this.multihash=G.digest(bt(this.url))}[tr](){return`PeerId(${this.url})`}[_t]=!0;toString(){return this.toCID().toString()}toCID(){return V.createV1(ie,this.multihash)}toBytes(){return this.toCID().bytes}equals(t){return t==null?!1:(t instanceof Uint8Array&&(t=ne(t)),t.toString()===this.toString())}};function Bn(r,t){if(t=t??Ye,r.charAt(0)==="1"||r.charAt(0)==="Q"){let e=ot(E.decode(`z${r}`));return r.startsWith("12D")?new Y({multihash:e}):r.startsWith("16U")?new tt({multihash:e}):new Z({multihash:e})}return ce(Ye.decode(r))}function ce(r){try{let t=ot(r);if(t.code===G.code){if(t.digest.length===se)return new Y({multihash:t});if(t.digest.length===ae)return new tt({multihash:t})}if(t.code===st.code)return new Z({multihash:t})}catch{return vn(V.decode(r))}throw new Error("Supplied PeerID CID is invalid")}function vn(r){if(r?.multihash==null||r.version==null||r.version===1&&r.code!==er&&r.code!==ie)throw new Error("Supplied PeerID CID is invalid");if(r.code===ie){let e=ne(r.multihash.digest);return new oe(new URL(e))}let t=r.multihash;if(t.code===st.code)return new Z({multihash:r.multihash});if(t.code===G.code){if(t.digest.length===se)return new Y({multihash:r.multihash});if(t.digest.length===ae)return new tt({multihash:r.multihash})}throw new Error("Supplied PeerID CID is invalid")}async function rr(r,t){return r.length===se?new Y({multihash:C(G.code,r),privateKey:t}):r.length===ae?new tt({multihash:C(G.code,r),privateKey:t}):new Z({multihash:await st.digest(r),publicKey:r,privateKey:t})}function et(){let r={};return r.promise=new Promise((t,e)=>{r.resolve=t,r.reject=e}),r}var xt=class extends Error{type;code;constructor(t,e,n){super(t??"The operation was aborted"),this.type="aborted",this.name=n??"AbortError",this.code=e??"ABORT_ERR"}};async function nr(r,t,e){if(t==null)return r;if(t.aborted)return Promise.reject(new xt(e?.errorMessage,e?.errorCode,e?.errorName));let n,i=new xt(e?.errorMessage,e?.errorCode,e?.errorName);try{return await Promise.race([r,new Promise((o,s)=>{n=()=>{s(i)},t.addEventListener("abort",n)})])}finally{n!=null&&t.removeEventListener("abort",n)}}var he=class{readNext;haveNext;ended;nextResult;constructor(){this.ended=!1,this.readNext=et(),this.haveNext=et()}[Symbol.asyncIterator](){return this}async next(){if(this.nextResult==null&&await this.haveNext.promise,this.nextResult==null)throw new Error("HaveNext promise resolved but nextResult was undefined");let t=this.nextResult;return this.nextResult=void 0,this.readNext.resolve(),this.readNext=et(),t}async throw(t){return this.ended=!0,t!=null&&(this.haveNext.promise.catch(()=>{}),this.haveNext.reject(t)),{done:!0,value:void 0}}async return(){let t={done:!0,value:void 0};return await this._push(void 0),t}async push(t,e){await this._push(t,e)}async end(t,e){t!=null?await this.throw(t):await this._push(void 0,e)}async _push(t,e){if(t!=null&&this.ended)throw new Error("Cannot push value onto an ended pushable");for(;this.nextResult!=null;)await this.readNext.promise;t!=null?this.nextResult={done:!1,value:t}:(this.ended=!0,this.nextResult={done:!0,value:void 0}),this.haveNext.resolve(),this.haveNext=et(),await nr(this.readNext.promise,e?.signal,e)}};function ir(){return new he}function ue(r,t){t==null&&(t=r.reduce((i,o)=>i+o.length,0));let e=x(t),n=0;for(let i of r)e.set(i,n),n+=i.length;return e}var sr=Symbol.for("@achingbrain/uint8arraylist");function or(r,t){if(t==null||t<0)throw new RangeError("index is out of bounds");let e=0;for(let n of r){let i=e+n.byteLength;if(t<i)return{buf:n,index:t-e};e=i}throw new RangeError("index is out of bounds")}function yt(r){return!!r?.[sr]}var _=class r{bufs;length;[sr]=!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(yt(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(yt(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=or(this.bufs,t);return e.buf[e.index]}set(t,e){let n=or(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(yt(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:i}=this._subList(t,e);return ue(n,i)}subarray(t,e){let{bufs:n,length:i}=this._subList(t,e);return n.length===1?n[0]:ue(n,i)}sublist(t,e){let{bufs:n,length:i}=this._subList(t,e),o=new r;return o.length=i,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=[],i=0;for(let o=0;o<this.bufs.length;o++){let s=this.bufs[o],a=i,c=a+s.byteLength;if(i=c,t>=c)continue;let d=t>=a&&t<c,l=e>a&&e<=c;if(d&&l){if(t===a&&e===c){n.push(s);break}let u=t-a;n.push(s.subarray(u,u+(e-t)));break}if(d){if(t===0){n.push(s);continue}n.push(s.subarray(t-a));continue}if(l){if(e===c){n.push(s);break}n.push(s.subarray(0,e-a));break}n.push(s)}return{bufs:n,length:e-t}}indexOf(t,e=0){if(!yt(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 i=n.byteLength;if(i===0)throw new TypeError("search must be at least 1 byte long");let o=256,s=new Int32Array(o);for(let u=0;u<o;u++)s[u]=-1;for(let u=0;u<i;u++)s[n[u]]=u;let a=s,c=this.byteLength-n.byteLength,d=n.byteLength-1,l;for(let u=e;u<=c;u+=l){l=0;for(let w=d;w>=0;w--){let lt=this.get(u+w);if(n[w]!==lt){l=Math.max(1,w-a[lt]);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=x(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 i=T(2);new DataView(i.buffer,i.byteOffset,i.byteLength).setInt16(0,e,n),this.write(i,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 i=T(4);new DataView(i.buffer,i.byteOffset,i.byteLength).setInt32(0,e,n),this.write(i,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 i=T(8);new DataView(i.buffer,i.byteOffset,i.byteLength).setBigInt64(0,e,n),this.write(i,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=x(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 i=T(2);new DataView(i.buffer,i.byteOffset,i.byteLength).setUint16(0,e,n),this.write(i,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 i=T(4);new DataView(i.buffer,i.byteOffset,i.byteLength).setUint32(0,e,n),this.write(i,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 i=T(8);new DataView(i.buffer,i.byteOffset,i.byteLength).setBigUint64(0,e,n),this.write(i,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 i=T(4);new DataView(i.buffer,i.byteOffset,i.byteLength).setFloat32(0,e,n),this.write(i,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 i=T(8);new DataView(i.buffer,i.byteOffset,i.byteLength).setFloat64(0,e,n),this.write(i,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(!ct(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((i,o)=>i+o.byteLength,0)),n.length=e,n}};var Et=class extends Error{name="UnexpectedEOFError";code="ERR_UNEXPECTED_EOF"};var fe=class extends Error{code;constructor(t,e){super(t),this.code=e}},le=class extends fe{type;constructor(t){super(t,"ABORT_ERR"),this.type="aborted",this.name="AbortError"}};function ar(r,t){let e=ir();r.sink(e).catch(async s=>{await e.end(s)}),r.sink=async s=>{for await(let a of s)await e.push(a);await e.end()};let n=r.source;r.source[Symbol.iterator]!=null?n=r.source[Symbol.iterator]():r.source[Symbol.asyncIterator]!=null&&(n=r.source[Symbol.asyncIterator]());let i=new _;return{read:async(s,a)=>{a?.signal?.throwIfAborted();let c,d=new Promise((l,u)=>{c=()=>{u(new le("Read aborted"))},a?.signal?.addEventListener("abort",c)});try{if(s==null){let{done:u,value:w}=await Promise.race([n.next(),d]);return u===!0?new _:w}for(;i.byteLength<s;){let{value:u,done:w}=await Promise.race([n.next(),d]);if(w===!0)throw new Et("unexpected end of input");i.append(u)}let l=i.sublist(0,s);return i.consume(s),l}finally{c!=null&&a?.signal?.removeEventListener("abort",c)}},write:async(s,a)=>{a?.signal?.throwIfAborted(),s instanceof Uint8Array?await e.push(s,a):await e.push(s.subarray(),a)},unwrap:()=>{if(i.byteLength>0){let s=r.source;r.source=async function*(){t?.yieldBytes===!1?yield i:yield*i,yield*s}()}return r}}}var Tn=Math.pow(2,7),_n=Math.pow(2,14),kn=Math.pow(2,21),de=Math.pow(2,28),pe=Math.pow(2,35),me=Math.pow(2,42),ge=Math.pow(2,49),h=128,m=127;function k(r){if(r<Tn)return 1;if(r<_n)return 2;if(r<kn)return 3;if(r<de)return 4;if(r<pe)return 5;if(r<me)return 6;if(r<ge)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function we(r,t,e=0){switch(k(r)){case 8:t[e++]=r&255|h,r/=128;case 7:t[e++]=r&255|h,r/=128;case 6:t[e++]=r&255|h,r/=128;case 5:t[e++]=r&255|h,r/=128;case 4:t[e++]=r&255|h,r>>>=7;case 3:t[e++]=r&255|h,r>>>=7;case 2:t[e++]=r&255|h,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function Mn(r,t,e=0){switch(k(r)){case 8:t.set(e++,r&255|h),r/=128;case 7:t.set(e++,r&255|h),r/=128;case 6:t.set(e++,r&255|h),r/=128;case 5:t.set(e++,r&255|h),r/=128;case 4:t.set(e++,r&255|h),r>>>=7;case 3:t.set(e++,r&255|h),r>>>=7;case 2:t.set(e++,r&255|h),r>>>=7;case 1:{t.set(e++,r&255),r>>>=7;break}default:throw new Error("unreachable")}return t}function be(r,t){let e=r[t],n=0;if(n+=e&m,e<h||(e=r[t+1],n+=(e&m)<<7,e<h)||(e=r[t+2],n+=(e&m)<<14,e<h)||(e=r[t+3],n+=(e&m)<<21,e<h)||(e=r[t+4],n+=(e&m)*de,e<h)||(e=r[t+5],n+=(e&m)*pe,e<h)||(e=r[t+6],n+=(e&m)*me,e<h)||(e=r[t+7],n+=(e&m)*ge,e<h))return n;throw new RangeError("Could not decode varint")}function On(r,t){let e=r.get(t),n=0;if(n+=e&m,e<h||(e=r.get(t+1),n+=(e&m)<<7,e<h)||(e=r.get(t+2),n+=(e&m)<<14,e<h)||(e=r.get(t+3),n+=(e&m)<<21,e<h)||(e=r.get(t+4),n+=(e&m)*de,e<h)||(e=r.get(t+5),n+=(e&m)*pe,e<h)||(e=r.get(t+6),n+=(e&m)*me,e<h)||(e=r.get(t+7),n+=(e&m)*ge,e<h))return n;throw new RangeError("Could not decode varint")}function cr(r,t,e=0){return t==null&&(t=x(k(r))),t instanceof Uint8Array?we(r,t,e):Mn(r,t,e)}function hr(r,t=0){return r instanceof Uint8Array?be(r,t):On(r,t)}var At=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},St=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},Lt=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"};function ur(r,t={}){let e=ar(r,t);t.maxDataLength!=null&&t.maxLengthLength==null&&(t.maxLengthLength=k(t.maxDataLength));let n=t?.lengthDecoder??hr,i=t?.lengthEncoder??cr;return{read:async s=>{let a=-1,c=new _;for(;;){c.append(await e.read(1,s));try{a=n(c)}catch(d){if(d instanceof RangeError)continue;throw d}if(a<0)throw new At("Invalid message length");if(t?.maxLengthLength!=null&&c.byteLength>t.maxLengthLength)throw new Lt("message length length too long");if(a>-1)break}if(t?.maxDataLength!=null&&a>t.maxDataLength)throw new St("message length too long");return e.read(a,s)},write:async(s,a)=>{await e.write(new _(i(s.byteLength),s),a)},writeV:async(s,a)=>{let c=new _(...s.flatMap(d=>[i(d.byteLength),d]));await e.write(c,a)},unwrap:()=>e.unwrap()}}function fr(r,t){let e=ur(r,t),n={read:async(i,o)=>{let s=await e.read(o);return i.decode(s)},write:async(i,o,s)=>{await e.write(o.encode(i),s)},writeV:async(i,o,s)=>{await e.writeV(i.map(a=>o.encode(a)),s)},pb:i=>({read:async o=>n.read(i,o),write:async(o,s)=>n.write(o,i,s),writeV:async(o,s)=>n.writeV(o,i,s),unwrap:()=>n}),unwrap:()=>e.unwrap()};return n}var xe=new Float32Array([-0]),P=new Uint8Array(xe.buffer);function lr(r,t,e){xe[0]=r,t[e]=P[0],t[e+1]=P[1],t[e+2]=P[2],t[e+3]=P[3]}function dr(r,t){return P[0]=r[t],P[1]=r[t+1],P[2]=r[t+2],P[3]=r[t+3],xe[0]}var ye=new Float64Array([-0]),g=new Uint8Array(ye.buffer);function pr(r,t,e){ye[0]=r,t[e]=g[0],t[e+1]=g[1],t[e+2]=g[2],t[e+3]=g[3],t[e+4]=g[4],t[e+5]=g[5],t[e+6]=g[6],t[e+7]=g[7]}function mr(r,t){return g[0]=r[t],g[1]=r[t+1],g[2]=r[t+2],g[3]=r[t+3],g[4]=r[t+4],g[5]=r[t+5],g[6]=r[t+6],g[7]=r[t+7],ye[0]}var Pn=BigInt(Number.MAX_SAFE_INTEGER),zn=BigInt(Number.MIN_SAFE_INTEGER),A=class r{lo;hi;constructor(t,e){this.lo=t|0,this.hi=e|0}toNumber(t=!1){if(!t&&this.hi>>>31>0){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(e+n*4294967296)}return this.lo+this.hi*4294967296}toBigInt(t=!1){if(t)return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n);if(this.hi>>>31){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(BigInt(e)+(BigInt(n)<<32n))}return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n)}toString(t=!1){return this.toBigInt(t).toString()}zzEncode(){let t=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^t)>>>0,this.lo=(this.lo<<1^t)>>>0,this}zzDecode(){let t=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^t)>>>0,this.hi=(this.hi>>>1^t)>>>0,this}length(){let t=this.lo,e=(this.lo>>>28|this.hi<<4)>>>0,n=this.hi>>>24;return n===0?e===0?t<16384?t<128?1:2:t<2097152?3:4:e<16384?e<128?5:6:e<2097152?7:8:n<128?9:10}static fromBigInt(t){if(t===0n)return $;if(t<Pn&&t>zn)return this.fromNumber(Number(t));let e=t<0n;e&&(t=-t);let n=t>>32n,i=t-(n<<32n);return e&&(n=~n|0n,i=~i|0n,++i>gr&&(i=0n,++n>gr&&(n=0n))),new r(Number(i),Number(n))}static fromNumber(t){if(t===0)return $;let e=t<0;e&&(t=-t);let n=t>>>0,i=(t-n)/4294967296>>>0;return e&&(i=~i>>>0,n=~n>>>0,++n>4294967295&&(n=0,++i>4294967295&&(i=0))),new r(n,i)}static from(t){return typeof t=="number"?r.fromNumber(t):typeof t=="bigint"?r.fromBigInt(t):typeof t=="string"?r.fromBigInt(BigInt(t)):t.low!=null||t.high!=null?new r(t.low>>>0,t.high>>>0):$}},$=new A(0,0);$.toBigInt=function(){return 0n};$.zzEncode=$.zzDecode=function(){return this};$.length=function(){return 1};var gr=4294967296n;function wr(r){let t=0,e=0;for(let n=0;n<r.length;++n)e=r.charCodeAt(n),e<128?t+=1:e<2048?t+=2:(e&64512)===55296&&(r.charCodeAt(n+1)&64512)===56320?(++n,t+=4):t+=3;return t}function br(r,t,e){if(e-t<1)return"";let i,o=[],s=0,a;for(;t<e;)a=r[t++],a<128?o[s++]=a:a>191&&a<224?o[s++]=(a&31)<<6|r[t++]&63:a>239&&a<365?(a=((a&7)<<18|(r[t++]&63)<<12|(r[t++]&63)<<6|r[t++]&63)-65536,o[s++]=55296+(a>>10),o[s++]=56320+(a&1023)):o[s++]=(a&15)<<12|(r[t++]&63)<<6|r[t++]&63,s>8191&&((i??(i=[])).push(String.fromCharCode.apply(String,o)),s=0);return i!=null?(s>0&&i.push(String.fromCharCode.apply(String,o.slice(0,s))),i.join("")):String.fromCharCode.apply(String,o.slice(0,s))}function Ee(r,t,e){let n=e,i,o;for(let s=0;s<r.length;++s)i=r.charCodeAt(s),i<128?t[e++]=i:i<2048?(t[e++]=i>>6|192,t[e++]=i&63|128):(i&64512)===55296&&((o=r.charCodeAt(s+1))&64512)===56320?(i=65536+((i&1023)<<10)+(o&1023),++s,t[e++]=i>>18|240,t[e++]=i>>12&63|128,t[e++]=i>>6&63|128,t[e++]=i&63|128):(t[e++]=i>>12|224,t[e++]=i>>6&63|128,t[e++]=i&63|128);return e-n}function I(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function Dt(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var Ae=class{buf;pos;len;_slice=Uint8Array.prototype.subarray;constructor(t){this.buf=t,this.pos=0,this.len=t.length}uint32(){let t=4294967295;if(t=(this.buf[this.pos]&127)>>>0,this.buf[this.pos++]<128||(t=(t|(this.buf[this.pos]&127)<<7)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<14)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<21)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&15)<<28)>>>0,this.buf[this.pos++]<128))return t;if((this.pos+=5)>this.len)throw this.pos=this.len,I(this,10);return t}int32(){return this.uint32()|0}sint32(){let t=this.uint32();return t>>>1^-(t&1)|0}bool(){return this.uint32()!==0}fixed32(){if(this.pos+4>this.len)throw I(this,4);return Dt(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw I(this,4);return Dt(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw I(this,4);let t=dr(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw I(this,4);let t=mr(this.buf,this.pos);return this.pos+=8,t}bytes(){let t=this.uint32(),e=this.pos,n=this.pos+t;if(n>this.len)throw I(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return br(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw I(this,t);this.pos+=t}else do if(this.pos>=this.len)throw I(this);while(this.buf[this.pos++]&128);return this}skipType(t){switch(t){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;(t=this.uint32()&7)!==4;)this.skipType(t);break;case 5:this.skip(4);break;default:throw Error(`invalid wire type ${t} at offset ${this.pos}`)}return this}readLongVarint(){let t=new A(0,0),e=0;if(this.len-this.pos>4){for(;e<4;++e)if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t;if(t.lo=(t.lo|(this.buf[this.pos]&127)<<28)>>>0,t.hi=(t.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return t;e=0}else{for(;e<3;++e){if(this.pos>=this.len)throw I(this);if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t}return t.lo=(t.lo|(this.buf[this.pos++]&127)<<e*7)>>>0,t}if(this.len-this.pos>4){for(;e<5;++e)if(t.hi=(t.hi|(this.buf[this.pos]&127)<<e*7+3)>>>0,this.buf[this.pos++]<128)return t}else for(;e<5;++e){if(this.pos>=this.len)throw I(this);if(t.hi=(t.hi|(this.buf[this.pos]&127)<<e*7+3)>>>0,this.buf[this.pos++]<128)return t}throw Error("invalid varint encoding")}readFixed64(){if(this.pos+8>this.len)throw I(this,8);let t=Dt(this.buf,this.pos+=4),e=Dt(this.buf,this.pos+=4);return new A(t,e)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){let t=be(this.buf,this.pos);return this.pos+=k(t),t}uint64String(){return this.readLongVarint().toString(!0)}sint64(){return this.readLongVarint().zzDecode().toBigInt()}sint64Number(){return this.readLongVarint().zzDecode().toNumber()}sint64String(){return this.readLongVarint().zzDecode().toString()}fixed64(){return this.readFixed64().toBigInt()}fixed64Number(){return this.readFixed64().toNumber()}fixed64String(){return this.readFixed64().toString()}sfixed64(){return this.readFixed64().toBigInt()}sfixed64Number(){return this.readFixed64().toNumber()}sfixed64String(){return this.readFixed64().toString()}};function Se(r){return new Ae(r instanceof Uint8Array?r:r.subarray())}function It(r,t,e){let n=Se(r);return t.decode(n,void 0,e)}function Le(r){let t=r??8192,e=t>>>1,n,i=t;return function(s){if(s<1||s>e)return x(s);i+s>t&&(n=x(t),i=0);let a=n.subarray(i,i+=s);return i&7&&(i=(i|7)+1),a}}var q=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function De(){}var Re=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},Gn=Le();function $n(r){return globalThis.Buffer!=null?x(r):Gn(r)}var ft=class{len;head;tail;states;constructor(){this.len=0,this.head=new q(De,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new q(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new Ne((t=t>>>0)<128?1:t<16384?2:t<2097152?3:t<268435456?4:5,t)).len,this}int32(t){return t<0?this._push(Rt,10,A.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=A.fromBigInt(t);return this._push(Rt,e.length(),e)}uint64Number(t){return this._push(we,k(t),t)}uint64String(t){return this.uint64(BigInt(t))}int64(t){return this.uint64(t)}int64Number(t){return this.uint64Number(t)}int64String(t){return this.uint64String(t)}sint64(t){let e=A.fromBigInt(t).zzEncode();return this._push(Rt,e.length(),e)}sint64Number(t){let e=A.fromNumber(t).zzEncode();return this._push(Rt,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(Ie,1,t?1:0)}fixed32(t){return this._push(ut,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=A.fromBigInt(t);return this._push(ut,4,e.lo)._push(ut,4,e.hi)}fixed64Number(t){let e=A.fromNumber(t);return this._push(ut,4,e.lo)._push(ut,4,e.hi)}fixed64String(t){return this.fixed64(BigInt(t))}sfixed64(t){return this.fixed64(t)}sfixed64Number(t){return this.fixed64Number(t)}sfixed64String(t){return this.fixed64String(t)}float(t){return this._push(lr,4,t)}double(t){return this._push(pr,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(Ie,1,0):this.uint32(e)._push(Xn,e,t)}string(t){let e=wr(t);return e!==0?this.uint32(e)._push(Ee,e,t):this._push(Ie,1,0)}fork(){return this.states=new Re(this),this.head=this.tail=new q(De,0,0),this.len=0,this}reset(){return this.states!=null?(this.head=this.states.head,this.tail=this.states.tail,this.len=this.states.len,this.states=this.states.next):(this.head=this.tail=new q(De,0,0),this.len=0),this}ldelim(){let t=this.head,e=this.tail,n=this.len;return this.reset().uint32(n),n!==0&&(this.tail.next=t.next,this.tail=e,this.len+=n),this}finish(){let t=this.head.next,e=$n(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function Ie(r,t,e){t[e]=r&255}function qn(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var Ne=class extends q{next;constructor(t,e){super(qn,t,e),this.next=void 0}};function Rt(r,t,e){for(;r.hi!==0;)t[e++]=r.lo&127|128,r.lo=(r.lo>>>7|r.hi<<25)>>>0,r.hi>>>=7;for(;r.lo>127;)t[e++]=r.lo&127|128,r.lo=r.lo>>>7;t[e++]=r.lo}function ut(r,t,e){t[e]=r&255,t[e+1]=r>>>8&255,t[e+2]=r>>>16&255,t[e+3]=r>>>24}function Xn(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(ft.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(jn,t,r),this},ft.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(Hn,t,r),this});function jn(r,t,e){t.set(r,e)}function Hn(r,t,e){r.length<40?Ee(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(bt(r),e)}function Ue(){return new ft}function Nt(r,t){let e=Ue();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var rt;(function(r){r[r.VARINT=0]="VARINT",r[r.BIT64=1]="BIT64",r[r.LENGTH_DELIMITED=2]="LENGTH_DELIMITED",r[r.START_GROUP=3]="START_GROUP",r[r.END_GROUP=4]="END_GROUP",r[r.BIT32=5]="BIT32"})(rt||(rt={}));function Ut(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function Fe(r){function t(i){if(r[i.toString()]==null)throw new Error("Invalid enum value");return r[i]}let e=function(o,s){let a=t(o);s.int32(a)},n=function(o){let s=o.int32();return t(s)};return Ut("enum",rt.VARINT,e,n)}function Ft(r,t){return Ut("message",rt.LENGTH_DELIMITED,r,t)}var Ct;(function(r){let t;r.codec=()=>(t==null&&(t=Ft((e,n,i={})=>{i.lengthDelimited!==!1&&n.fork(),e.id!=null&&(n.uint32(10),n.bytes(e.id)),e.pubkey!=null&&(n.uint32(18),vt.codec().encode(e.pubkey,n)),i.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let i={},o=n==null?e.len:e.pos+n;for(;e.pos<o;){let s=e.uint32();switch(s>>>3){case 1:i.id=e.bytes();break;case 2:i.pubkey=vt.codec().decode(e,e.uint32());break;default:e.skipType(s&7);break}}return i})),t),r.encode=e=>Nt(e,r.codec()),r.decode=e=>It(e,r.codec())})(Ct||(Ct={}));var R;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.Secp256k1="Secp256k1",r.ECDSA="ECDSA"})(R||(R={}));var Bt;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.Secp256k1=2]="Secp256k1",r[r.ECDSA=3]="ECDSA"})(Bt||(Bt={}));(function(r){r.codec=()=>Fe(Bt)})(R||(R={}));var vt;(function(r){let t;r.codec=()=>(t==null&&(t=Ft((e,n,i={})=>{i.lengthDelimited!==!1&&n.fork(),e.Type!=null&&Bt[e.Type]!==0&&(n.uint32(8),R.codec().encode(e.Type,n)),e.Data!=null&&e.Data.byteLength>0&&(n.uint32(18),n.bytes(e.Data)),i.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let i={Type:R.RSA,Data:new Uint8Array(0)},o=n==null?e.len:e.pos+n;for(;e.pos<o;){let s=e.uint32();switch(s>>>3){case 1:i.Type=R.codec().decode(e);break;case 2:i.Data=e.bytes();break;default:e.skipType(s&7);break}}return i})),t),r.encode=e=>Nt(e,r.codec()),r.decode=e=>It(e,r.codec())})(vt||(vt={}));var Wn="/plaintext/2.0.0",Ce=class{protocol=Wn;log;timeout;constructor(t,e={}){this.log=t.logger.forComponent("libp2p:plaintext"),this.timeout=e.timeout??1e3}[Symbol.toStringTag]="@libp2p/plaintext";[Be]=["@libp2p/connection-encryption"];async secureInbound(t,e,n){return this._encrypt(t,e,n)}async secureOutbound(t,e,n){return this._encrypt(t,e,n)}async _encrypt(t,e,n){let i=AbortSignal.timeout(this.timeout),o=fr(e).pb(Ct),s=R.RSA;t.type==="Ed25519"?s=R.Ed25519:t.type==="secp256k1"&&(s=R.Secp256k1),this.log("write pubkey exchange to peer %p",n);let[,a]=await Promise.all([o.write({id:t.toBytes(),pubkey:{Type:s,Data:t.publicKey??new Uint8Array(0)}},{signal:i}),o.read({signal:i})]),c;try{if(a.pubkey==null)throw new Error("Public key missing");if(a.pubkey.Data.length===0)throw new Error("Public key data too short");if(a.id==null)throw new Error("Remote id missing");if(c=await rr(a.pubkey.Data),!c.equals(ce(a.id)))throw new Error("Public key did not match id")}catch(d){throw this.log.error(d),new mt("Remote did not provide its public key")}if(n!=null&&!c.equals(n))throw new pt;return this.log("plaintext key exchange completed successfully with peer %p",c),{conn:o.unwrap().unwrap(),remotePeer:c}}};function Jn(r){return t=>new Ce(t,r)}return Lr(Kn);})();
|
|
2
|
+
"use strict";var Libp2PPlaintext=(()=>{var vc=Object.create;var $r=Object.defineProperty;var Bc=Object.getOwnPropertyDescriptor;var Ec=Object.getOwnPropertyNames;var Ac=Object.getPrototypeOf,kc=Object.prototype.hasOwnProperty;var Sc=(r,e)=>()=>(e||r((e={exports:{}}).exports,e),e.exports),ie=(r,e)=>{for(var t in e)$r(r,t,{get:e[t],enumerable:!0})},Go=(r,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of Ec(e))!kc.call(r,s)&&s!==t&&$r(r,s,{get:()=>e[s],enumerable:!(n=Bc(e,s))||n.enumerable});return r};var Ic=(r,e,t)=>(t=r!=null?vc(Ac(r)):{},Go(e||!r||!r.__esModule?$r(t,"default",{value:r,enumerable:!0}):t,r)),Nc=r=>Go($r({},"__esModule",{value:!0}),r);var Zi=Sc(nr=>{"use strict";var cf="[object ArrayBuffer]",Je=class r{static isArrayBuffer(e){return Object.prototype.toString.call(e)===cf}static toArrayBuffer(e){return this.isArrayBuffer(e)?e:e.byteLength===e.buffer.byteLength||e.byteOffset===0&&e.byteLength===e.buffer.byteLength?e.buffer:this.toUint8Array(e.buffer).slice(e.byteOffset,e.byteOffset+e.byteLength).buffer}static toUint8Array(e){return this.toView(e,Uint8Array)}static toView(e,t){if(e.constructor===t)return e;if(this.isArrayBuffer(e))return new t(e);if(this.isArrayBufferView(e))return new t(e.buffer,e.byteOffset,e.byteLength);throw new TypeError("The provided value is not of type '(ArrayBuffer or ArrayBufferView)'")}static isBufferSource(e){return this.isArrayBufferView(e)||this.isArrayBuffer(e)}static isArrayBufferView(e){return ArrayBuffer.isView(e)||e&&this.isArrayBuffer(e.buffer)}static isEqual(e,t){let n=r.toUint8Array(e),s=r.toUint8Array(t);if(n.length!==s.byteLength)return!1;for(let o=0;o<n.length;o++)if(n[o]!==s[o])return!1;return!0}static concat(...e){let t;Array.isArray(e[0])&&!(e[1]instanceof Function)||Array.isArray(e[0])&&e[1]instanceof Function?t=e[0]:e[e.length-1]instanceof Function?t=e.slice(0,e.length-1):t=e;let n=0;for(let i of t)n+=i.byteLength;let s=new Uint8Array(n),o=0;for(let i of t){let a=this.toUint8Array(i);s.set(a,o),o+=a.length}return e[e.length-1]instanceof Function?this.toView(s,e[e.length-1]):s.buffer}},yo="string",lf=/^[0-9a-f]+$/i,uf=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,ff=/^[a-zA-Z0-9-_]+$/,un=class{static fromString(e){let t=unescape(encodeURIComponent(e)),n=new Uint8Array(t.length);for(let s=0;s<t.length;s++)n[s]=t.charCodeAt(s);return n.buffer}static toString(e){let t=Je.toUint8Array(e),n="";for(let o=0;o<t.length;o++)n+=String.fromCharCode(t[o]);return decodeURIComponent(escape(n))}},Ie=class{static toString(e,t=!1){let n=Je.toArrayBuffer(e),s=new DataView(n),o="";for(let i=0;i<n.byteLength;i+=2){let a=s.getUint16(i,t);o+=String.fromCharCode(a)}return o}static fromString(e,t=!1){let n=new ArrayBuffer(e.length*2),s=new DataView(n);for(let o=0;o<e.length;o++)s.setUint16(o*2,e.charCodeAt(o),t);return n}},fn=class r{static isHex(e){return typeof e===yo&&lf.test(e)}static isBase64(e){return typeof e===yo&&uf.test(e)}static isBase64Url(e){return typeof e===yo&&ff.test(e)}static ToString(e,t="utf8"){let n=Je.toUint8Array(e);switch(t.toLowerCase()){case"utf8":return this.ToUtf8String(n);case"binary":return this.ToBinary(n);case"hex":return this.ToHex(n);case"base64":return this.ToBase64(n);case"base64url":return this.ToBase64Url(n);case"utf16le":return Ie.toString(n,!0);case"utf16":case"utf16be":return Ie.toString(n);default:throw new Error(`Unknown type of encoding '${t}'`)}}static FromString(e,t="utf8"){if(!e)return new ArrayBuffer(0);switch(t.toLowerCase()){case"utf8":return this.FromUtf8String(e);case"binary":return this.FromBinary(e);case"hex":return this.FromHex(e);case"base64":return this.FromBase64(e);case"base64url":return this.FromBase64Url(e);case"utf16le":return Ie.fromString(e,!0);case"utf16":case"utf16be":return Ie.fromString(e);default:throw new Error(`Unknown type of encoding '${t}'`)}}static ToBase64(e){let t=Je.toUint8Array(e);if(typeof btoa<"u"){let n=this.ToString(t,"binary");return btoa(n)}else return Buffer.from(t).toString("base64")}static FromBase64(e){let t=this.formatString(e);if(!t)return new ArrayBuffer(0);if(!r.isBase64(t))throw new TypeError("Argument 'base64Text' is not Base64 encoded");return typeof atob<"u"?this.FromBinary(atob(t)):new Uint8Array(Buffer.from(t,"base64")).buffer}static FromBase64Url(e){let t=this.formatString(e);if(!t)return new ArrayBuffer(0);if(!r.isBase64Url(t))throw new TypeError("Argument 'base64url' is not Base64Url encoded");return this.FromBase64(this.Base64Padding(t.replace(/\-/g,"+").replace(/\_/g,"/")))}static ToBase64Url(e){return this.ToBase64(e).replace(/\+/g,"-").replace(/\//g,"_").replace(/\=/g,"")}static FromUtf8String(e,t=r.DEFAULT_UTF8_ENCODING){switch(t){case"ascii":return this.FromBinary(e);case"utf8":return un.fromString(e);case"utf16":case"utf16be":return Ie.fromString(e);case"utf16le":case"usc2":return Ie.fromString(e,!0);default:throw new Error(`Unknown type of encoding '${t}'`)}}static ToUtf8String(e,t=r.DEFAULT_UTF8_ENCODING){switch(t){case"ascii":return this.ToBinary(e);case"utf8":return un.toString(e);case"utf16":case"utf16be":return Ie.toString(e);case"utf16le":case"usc2":return Ie.toString(e,!0);default:throw new Error(`Unknown type of encoding '${t}'`)}}static FromBinary(e){let t=e.length,n=new Uint8Array(t);for(let s=0;s<t;s++)n[s]=e.charCodeAt(s);return n.buffer}static ToBinary(e){let t=Je.toUint8Array(e),n="";for(let s=0;s<t.length;s++)n+=String.fromCharCode(t[s]);return n}static ToHex(e){let t=Je.toUint8Array(e),n="",s=t.length;for(let o=0;o<s;o++){let i=t[o];i<16&&(n+="0"),n+=i.toString(16)}return n}static FromHex(e){let t=this.formatString(e);if(!t)return new ArrayBuffer(0);if(!r.isHex(t))throw new TypeError("Argument 'hexString' is not HEX encoded");t.length%2&&(t=`0${t}`);let n=new Uint8Array(t.length/2);for(let s=0;s<t.length;s=s+2){let o=t.slice(s,s+2);n[s/2]=parseInt(o,16)}return n.buffer}static ToUtf16String(e,t=!1){return Ie.toString(e,t)}static FromUtf16String(e,t=!1){return Ie.fromString(e,t)}static Base64Padding(e){let t=4-e.length%4;if(t<4)for(let n=0;n<t;n++)e+="=";return e}static formatString(e){return e?.replace(/[\n\r\t ]/g,"")||""}};fn.DEFAULT_UTF8_ENCODING="utf8";function hf(r,...e){let t=arguments[0];for(let n=1;n<arguments.length;n++){let s=arguments[n];for(let o in s)t[o]=s[o]}return t}function df(...r){let e=r.map(s=>s.byteLength).reduce((s,o)=>s+o),t=new Uint8Array(e),n=0;return r.map(s=>new Uint8Array(s)).forEach(s=>{for(let o of s)t[n++]=o}),t.buffer}function pf(r,e){if(!(r&&e)||r.byteLength!==e.byteLength)return!1;let t=new Uint8Array(r),n=new Uint8Array(e);for(let s=0;s<r.byteLength;s++)if(t[s]!==n[s])return!1;return!0}nr.BufferSourceConverter=Je;nr.Convert=fn;nr.assign=hf;nr.combine=df;nr.isEqual=pf});var Qf={};ie(Qf,{plaintext:()=>Xf});var ls=Symbol.for("@libp2p/peer-id");var V=class extends Error{code;props;constructor(e,t,n){super(e),this.code=t,this.name=n?.name??"CodeError",this.props=n??{}}};var qr=class r extends Error{code;constructor(e="Unexpected Peer"){super(e),this.name="UnexpectedPeerError",this.code=r.code}static code="ERR_UNEXPECTED_PEER"},Gr=class r extends Error{code;constructor(e="Invalid crypto exchange"){super(e),this.name="InvalidCryptoExchangeError",this.code=r.code}static code="ERR_INVALID_CRYPTO_EXCHANGE"};var jo=Symbol.for("@libp2p/service-capabilities"),nh=Symbol.for("@libp2p/service-dependencies");var po={};ie(po,{Ed25519PrivateKey:()=>Lt,Ed25519PublicKey:()=>Sr,generateKeyPair:()=>sf,generateKeyPairFromSeed:()=>Wi,unmarshalEd25519PrivateKey:()=>rf,unmarshalEd25519PublicKey:()=>nf});var ps={};ie(ps,{base58btc:()=>ge,base58flickr:()=>Uc});var Ih=new Uint8Array(0);function zo(r,e){if(r===e)return!0;if(r.byteLength!==e.byteLength)return!1;for(let t=0;t<r.byteLength;t++)if(r[t]!==e[t])return!1;return!0}function Fe(r){if(r instanceof Uint8Array&&r.constructor.name==="Uint8Array")return r;if(r instanceof ArrayBuffer)return new Uint8Array(r);if(ArrayBuffer.isView(r))return new Uint8Array(r.buffer,r.byteOffset,r.byteLength);throw new Error("Unknown type, must be binary type")}function Wo(r){return new TextEncoder().encode(r)}function Zo(r){return new TextDecoder().decode(r)}function Rc(r,e){if(r.length>=255)throw new TypeError("Alphabet too long");for(var t=new Uint8Array(256),n=0;n<t.length;n++)t[n]=255;for(var s=0;s<r.length;s++){var o=r.charAt(s),i=o.charCodeAt(0);if(t[i]!==255)throw new TypeError(o+" is ambiguous");t[i]=s}var a=r.length,c=r.charAt(0),f=Math.log(a)/Math.log(256),u=Math.log(256)/Math.log(a);function l(y){if(y instanceof Uint8Array||(ArrayBuffer.isView(y)?y=new Uint8Array(y.buffer,y.byteOffset,y.byteLength):Array.isArray(y)&&(y=Uint8Array.from(y))),!(y instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(y.length===0)return"";for(var h=0,m=0,v=0,b=y.length;v!==b&&y[v]===0;)v++,h++;for(var w=(b-v)*u+1>>>0,T=new Uint8Array(w);v!==b;){for(var S=y[v],k=0,R=w-1;(S!==0||k<m)&&R!==-1;R--,k++)S+=256*T[R]>>>0,T[R]=S%a>>>0,S=S/a>>>0;if(S!==0)throw new Error("Non-zero carry");m=k,v++}for(var I=w-m;I!==w&&T[I]===0;)I++;for(var $=c.repeat(h);I<w;++I)$+=r.charAt(T[I]);return $}function p(y){if(typeof y!="string")throw new TypeError("Expected String");if(y.length===0)return new Uint8Array;var h=0;if(y[h]!==" "){for(var m=0,v=0;y[h]===c;)m++,h++;for(var b=(y.length-h)*f+1>>>0,w=new Uint8Array(b);y[h];){var T=t[y.charCodeAt(h)];if(T===255)return;for(var S=0,k=b-1;(T!==0||S<v)&&k!==-1;k--,S++)T+=a*w[k]>>>0,w[k]=T%256>>>0,T=T/256>>>0;if(T!==0)throw new Error("Non-zero carry");v=S,h++}if(y[h]!==" "){for(var R=b-v;R!==b&&w[R]===0;)R++;for(var I=new Uint8Array(m+(b-R)),$=m;R!==b;)I[$++]=w[R++];return I}}}function x(y){var h=p(y);if(h)return h;throw new Error(`Non-${e} character`)}return{encode:l,decodeUnsafe:p,decode:x}}var Tc=Rc,Cc=Tc,Jo=Cc;var us=class{name;prefix;baseEncode;constructor(e,t,n){this.name=e,this.prefix=t,this.baseEncode=n}encode(e){if(e instanceof Uint8Array)return`${this.prefix}${this.baseEncode(e)}`;throw Error("Unknown type, must be binary type")}},fs=class{name;prefix;baseDecode;prefixCodePoint;constructor(e,t,n){if(this.name=e,this.prefix=t,t.codePointAt(0)===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=t.codePointAt(0),this.baseDecode=n}decode(e){if(typeof e=="string"){if(e.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(e)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(e.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(e){return Xo(this,e)}},hs=class{decoders;constructor(e){this.decoders=e}or(e){return Xo(this,e)}decode(e){let t=e[0],n=this.decoders[t];if(n!=null)return n.decode(e);throw RangeError(`Unable to decode multibase string ${JSON.stringify(e)}, only inputs prefixed with ${Object.keys(this.decoders)} are supported`)}};function Xo(r,e){return new hs({...r.decoders??{[r.prefix]:r},...e.decoders??{[e.prefix]:e}})}var ds=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(e,t,n,s){this.name=e,this.prefix=t,this.baseEncode=n,this.baseDecode=s,this.encoder=new us(e,t,n),this.decoder=new fs(e,t,s)}encode(e){return this.encoder.encode(e)}decode(e){return this.decoder.decode(e)}};function Vt({name:r,prefix:e,encode:t,decode:n}){return new ds(r,e,t,n)}function st({name:r,prefix:e,alphabet:t}){let{encode:n,decode:s}=Jo(t,r);return Vt({prefix:e,name:r,encode:n,decode:o=>Fe(s(o))})}function Lc(r,e,t,n){let s={};for(let u=0;u<e.length;++u)s[e[u]]=u;let o=r.length;for(;r[o-1]==="=";)--o;let i=new Uint8Array(o*t/8|0),a=0,c=0,f=0;for(let u=0;u<o;++u){let l=s[r[u]];if(l===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<t|l,a+=t,a>=8&&(a-=8,i[f++]=255&c>>a)}if(a>=t||255&c<<8-a)throw new SyntaxError("Unexpected end of data");return i}function _c(r,e,t){let n=e[e.length-1]==="=",s=(1<<t)-1,o="",i=0,a=0;for(let c=0;c<r.length;++c)for(a=a<<8|r[c],i+=8;i>t;)i-=t,o+=e[s&a>>i];if(i!==0&&(o+=e[s&a<<t-i]),n)for(;o.length*t&7;)o+="=";return o}function Y({name:r,prefix:e,bitsPerChar:t,alphabet:n}){return Vt({prefix:e,name:r,encode(s){return _c(s,n,t)},decode(s){return Lc(s,n,t,r)}})}var ge=st({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),Uc=st({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var ys={};ie(ys,{identity:()=>$e});var Dc=ti,Qo=128,Vc=127,Oc=~Vc,Hc=Math.pow(2,31);function ti(r,e,t){e=e||[],t=t||0;for(var n=t;r>=Hc;)e[t++]=r&255|Qo,r/=128;for(;r&Oc;)e[t++]=r&255|Qo,r>>>=7;return e[t]=r|0,ti.bytes=t-n+1,e}var Pc=gs,Mc=128,ei=127;function gs(r,n){var t=0,n=n||0,s=0,o=n,i,a=r.length;do{if(o>=a)throw gs.bytes=0,new RangeError("Could not decode varint");i=r[o++],t+=s<28?(i&ei)<<s:(i&ei)*Math.pow(2,s),s+=7}while(i>=Mc);return gs.bytes=o-n,t}var Kc=Math.pow(2,7),Fc=Math.pow(2,14),$c=Math.pow(2,21),qc=Math.pow(2,28),Gc=Math.pow(2,35),jc=Math.pow(2,42),zc=Math.pow(2,49),Wc=Math.pow(2,56),Zc=Math.pow(2,63),Yc=function(r){return r<Kc?1:r<Fc?2:r<$c?3:r<qc?4:r<Gc?5:r<jc?6:r<zc?7:r<Wc?8:r<Zc?9:10},Jc={encode:Dc,decode:Pc,encodingLength:Yc},Xc=Jc,gr=Xc;function yr(r,e=0){return[gr.decode(r,e),gr.decode.bytes]}function Ot(r,e,t=0){return gr.encode(r,e,t),e}function Ht(r){return gr.encodingLength(r)}function Oe(r,e){let t=e.byteLength,n=Ht(r),s=n+Ht(t),o=new Uint8Array(s+t);return Ot(r,o,0),Ot(t,o,n),o.set(e,s),new Pt(r,t,e,o)}function mr(r){let e=Fe(r),[t,n]=yr(e),[s,o]=yr(e.subarray(n)),i=e.subarray(n+o);if(i.byteLength!==s)throw new Error("Incorrect length");return new Pt(t,s,i,e)}function ri(r,e){if(r===e)return!0;{let t=e;return r.code===t.code&&r.size===t.size&&t.bytes instanceof Uint8Array&&zo(r.bytes,t.bytes)}}var Pt=class{code;size;digest;bytes;constructor(e,t,n,s){this.code=e,this.size=t,this.digest=n,this.bytes=s}};var ni=0,Qc="identity",si=Fe;function el(r){return Oe(ni,si(r))}var $e={code:ni,name:Qc,encode:si,digest:el};var ws={};ie(ws,{sha256:()=>le,sha512:()=>tl});function bs({name:r,code:e,encode:t}){return new ms(r,e,t)}var ms=class{name;code;encode;constructor(e,t,n){this.name=e,this.code=t,this.encode=n}digest(e){if(e instanceof Uint8Array){let t=this.encode(e);return t instanceof Uint8Array?Oe(this.code,t):t.then(n=>Oe(this.code,n))}else throw Error("Unknown type, must be binary type")}};function ii(r){return async e=>new Uint8Array(await crypto.subtle.digest(r,e))}var le=bs({name:"sha2-256",code:18,encode:ii("SHA-256")}),tl=bs({name:"sha2-512",code:19,encode:ii("SHA-512")});function we(r,e){if(r===e)return!0;if(r.byteLength!==e.byteLength)return!1;for(let t=0;t<r.byteLength;t++)if(r[t]!==e[t])return!1;return!0}function qe(r=0){return new Uint8Array(r)}function xe(r=0){return new Uint8Array(r)}function Kt(r,e){e==null&&(e=r.reduce((s,o)=>s+o.length,0));let t=xe(e),n=0;for(let s of r)t.set(s,n),n+=s.length;return t}var xs={};ie(xs,{base10:()=>rl});var rl=st({prefix:"9",name:"base10",alphabet:"0123456789"});var vs={};ie(vs,{base16:()=>nl,base16upper:()=>sl});var nl=Y({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),sl=Y({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Bs={};ie(Bs,{base2:()=>ol});var ol=Y({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Es={};ie(Es,{base256emoji:()=>ul});var ai=Array.from("\u{1F680}\u{1FA90}\u2604\u{1F6F0}\u{1F30C}\u{1F311}\u{1F312}\u{1F313}\u{1F314}\u{1F315}\u{1F316}\u{1F317}\u{1F318}\u{1F30D}\u{1F30F}\u{1F30E}\u{1F409}\u2600\u{1F4BB}\u{1F5A5}\u{1F4BE}\u{1F4BF}\u{1F602}\u2764\u{1F60D}\u{1F923}\u{1F60A}\u{1F64F}\u{1F495}\u{1F62D}\u{1F618}\u{1F44D}\u{1F605}\u{1F44F}\u{1F601}\u{1F525}\u{1F970}\u{1F494}\u{1F496}\u{1F499}\u{1F622}\u{1F914}\u{1F606}\u{1F644}\u{1F4AA}\u{1F609}\u263A\u{1F44C}\u{1F917}\u{1F49C}\u{1F614}\u{1F60E}\u{1F607}\u{1F339}\u{1F926}\u{1F389}\u{1F49E}\u270C\u2728\u{1F937}\u{1F631}\u{1F60C}\u{1F338}\u{1F64C}\u{1F60B}\u{1F497}\u{1F49A}\u{1F60F}\u{1F49B}\u{1F642}\u{1F493}\u{1F929}\u{1F604}\u{1F600}\u{1F5A4}\u{1F603}\u{1F4AF}\u{1F648}\u{1F447}\u{1F3B6}\u{1F612}\u{1F92D}\u2763\u{1F61C}\u{1F48B}\u{1F440}\u{1F62A}\u{1F611}\u{1F4A5}\u{1F64B}\u{1F61E}\u{1F629}\u{1F621}\u{1F92A}\u{1F44A}\u{1F973}\u{1F625}\u{1F924}\u{1F449}\u{1F483}\u{1F633}\u270B\u{1F61A}\u{1F61D}\u{1F634}\u{1F31F}\u{1F62C}\u{1F643}\u{1F340}\u{1F337}\u{1F63B}\u{1F613}\u2B50\u2705\u{1F97A}\u{1F308}\u{1F608}\u{1F918}\u{1F4A6}\u2714\u{1F623}\u{1F3C3}\u{1F490}\u2639\u{1F38A}\u{1F498}\u{1F620}\u261D\u{1F615}\u{1F33A}\u{1F382}\u{1F33B}\u{1F610}\u{1F595}\u{1F49D}\u{1F64A}\u{1F639}\u{1F5E3}\u{1F4AB}\u{1F480}\u{1F451}\u{1F3B5}\u{1F91E}\u{1F61B}\u{1F534}\u{1F624}\u{1F33C}\u{1F62B}\u26BD\u{1F919}\u2615\u{1F3C6}\u{1F92B}\u{1F448}\u{1F62E}\u{1F646}\u{1F37B}\u{1F343}\u{1F436}\u{1F481}\u{1F632}\u{1F33F}\u{1F9E1}\u{1F381}\u26A1\u{1F31E}\u{1F388}\u274C\u270A\u{1F44B}\u{1F630}\u{1F928}\u{1F636}\u{1F91D}\u{1F6B6}\u{1F4B0}\u{1F353}\u{1F4A2}\u{1F91F}\u{1F641}\u{1F6A8}\u{1F4A8}\u{1F92C}\u2708\u{1F380}\u{1F37A}\u{1F913}\u{1F619}\u{1F49F}\u{1F331}\u{1F616}\u{1F476}\u{1F974}\u25B6\u27A1\u2753\u{1F48E}\u{1F4B8}\u2B07\u{1F628}\u{1F31A}\u{1F98B}\u{1F637}\u{1F57A}\u26A0\u{1F645}\u{1F61F}\u{1F635}\u{1F44E}\u{1F932}\u{1F920}\u{1F927}\u{1F4CC}\u{1F535}\u{1F485}\u{1F9D0}\u{1F43E}\u{1F352}\u{1F617}\u{1F911}\u{1F30A}\u{1F92F}\u{1F437}\u260E\u{1F4A7}\u{1F62F}\u{1F486}\u{1F446}\u{1F3A4}\u{1F647}\u{1F351}\u2744\u{1F334}\u{1F4A3}\u{1F438}\u{1F48C}\u{1F4CD}\u{1F940}\u{1F922}\u{1F445}\u{1F4A1}\u{1F4A9}\u{1F450}\u{1F4F8}\u{1F47B}\u{1F910}\u{1F92E}\u{1F3BC}\u{1F975}\u{1F6A9}\u{1F34E}\u{1F34A}\u{1F47C}\u{1F48D}\u{1F4E3}\u{1F942}"),il=ai.reduce((r,e,t)=>(r[t]=e,r),[]),al=ai.reduce((r,e,t)=>(r[e.codePointAt(0)]=t,r),[]);function cl(r){return r.reduce((e,t)=>(e+=il[t],e),"")}function ll(r){let e=[];for(let t of r){let n=al[t.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${t}`);e.push(n)}return new Uint8Array(e)}var ul=Vt({prefix:"\u{1F680}",name:"base256emoji",encode:cl,decode:ll});var As={};ie(As,{base32:()=>Ft,base32hex:()=>pl,base32hexpad:()=>yl,base32hexpadupper:()=>ml,base32hexupper:()=>gl,base32pad:()=>hl,base32padupper:()=>dl,base32upper:()=>fl,base32z:()=>bl});var Ft=Y({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),fl=Y({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),hl=Y({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),dl=Y({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),pl=Y({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),gl=Y({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),yl=Y({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),ml=Y({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),bl=Y({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var ks={};ie(ks,{base36:()=>wl,base36upper:()=>xl});var wl=st({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),xl=st({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Is={};ie(Is,{base64:()=>Ss,base64pad:()=>vl,base64url:()=>Bl,base64urlpad:()=>El});var Ss=Y({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),vl=Y({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Bl=Y({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),El=Y({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Ns={};ie(Ns,{base8:()=>Al});var Al=Y({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Rs={};ie(Rs,{identity:()=>kl});var kl=Vt({prefix:"\0",name:"identity",encode:r=>Zo(r),decode:r=>Wo(r)});var td=new TextEncoder,rd=new TextDecoder;function ci(r,e){let{bytes:t,version:n}=r;switch(n){case 0:return Rl(t,Ts(r),e??ge.encoder);default:return Tl(t,Ts(r),e??Ft.encoder)}}var li=new WeakMap;function Ts(r){let e=li.get(r);if(e==null){let t=new Map;return li.set(r,t),t}return e}var ot=class r{code;version;multihash;bytes;"/";constructor(e,t,n,s){this.code=t,this.version=e,this.multihash=n,this.bytes=s,this["/"]=s}get asCID(){return this}get byteOffset(){return this.bytes.byteOffset}get byteLength(){return this.bytes.byteLength}toV0(){switch(this.version){case 0:return this;case 1:{let{code:e,multihash:t}=this;if(e!==br)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(t.code!==Cl)throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");return r.createV0(t)}default:throw Error(`Can not convert CID version ${this.version} to version 0. This is a bug please report`)}}toV1(){switch(this.version){case 0:{let{code:e,digest:t}=this.multihash,n=Oe(e,t);return r.createV1(this.code,n)}case 1:return this;default:throw Error(`Can not convert CID version ${this.version} to version 1. This is a bug please report`)}}equals(e){return r.equals(this,e)}static equals(e,t){let n=t;return n!=null&&e.code===n.code&&e.version===n.version&&ri(e.multihash,n.multihash)}toString(e){return ci(this,e)}toJSON(){return{"/":ci(this)}}link(){return this}[Symbol.toStringTag]="CID";[Symbol.for("nodejs.util.inspect.custom")](){return`CID(${this.toString()})`}static asCID(e){if(e==null)return null;let t=e;if(t instanceof r)return t;if(t["/"]!=null&&t["/"]===t.bytes||t.asCID===t){let{version:n,code:s,multihash:o,bytes:i}=t;return new r(n,s,o,i??ui(n,s,o.bytes))}else if(t[Ll]===!0){let{version:n,multihash:s,code:o}=t,i=mr(s);return r.create(n,o,i)}else return null}static create(e,t,n){if(typeof t!="number")throw new Error("String codecs are no longer supported");if(!(n.bytes instanceof Uint8Array))throw new Error("Invalid digest");switch(e){case 0:{if(t!==br)throw new Error(`Version 0 CID must use dag-pb (code: ${br}) block encoding`);return new r(e,t,n,n.bytes)}case 1:{let s=ui(e,t,n.bytes);return new r(e,t,n,s)}default:throw new Error("Invalid version")}}static createV0(e){return r.create(0,br,e)}static createV1(e,t){return r.create(1,e,t)}static decode(e){let[t,n]=r.decodeFirst(e);if(n.length!==0)throw new Error("Incorrect length");return t}static decodeFirst(e){let t=r.inspectBytes(e),n=t.size-t.multihashSize,s=Fe(e.subarray(n,n+t.multihashSize));if(s.byteLength!==t.multihashSize)throw new Error("Incorrect length");let o=s.subarray(t.multihashSize-t.digestSize),i=new Pt(t.multihashCode,t.digestSize,o,s);return[t.version===0?r.createV0(i):r.createV1(t.codec,i),e.subarray(t.size)]}static inspectBytes(e){let t=0,n=()=>{let[l,p]=yr(e.subarray(t));return t+=p,l},s=n(),o=br;if(s===18?(s=0,t=0):o=n(),s!==0&&s!==1)throw new RangeError(`Invalid CID version ${s}`);let i=t,a=n(),c=n(),f=t+c,u=f-i;return{version:s,codec:o,multihashCode:a,digestSize:c,multihashSize:u,size:f}}static parse(e,t){let[n,s]=Nl(e,t),o=r.decode(s);if(o.version===0&&e[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return Ts(o).set(n,e),o}};function Nl(r,e){switch(r[0]){case"Q":{let t=e??ge;return[ge.prefix,t.decode(`${ge.prefix}${r}`)]}case ge.prefix:{let t=e??ge;return[ge.prefix,t.decode(r)]}case Ft.prefix:{let t=e??Ft;return[Ft.prefix,t.decode(r)]}default:{if(e==null)throw Error("To parse non base32 or base58btc encoded CID multibase decoder must be provided");return[r[0],e.decode(r)]}}}function Rl(r,e,t){let{prefix:n}=t;if(n!==ge.prefix)throw Error(`Cannot string encode V0 in ${t.name} encoding`);let s=e.get(n);if(s==null){let o=t.encode(r).slice(1);return e.set(n,o),o}else return s}function Tl(r,e,t){let{prefix:n}=t,s=e.get(n);if(s==null){let o=t.encode(r);return e.set(n,o),o}else return s}var br=112,Cl=18;function ui(r,e,t){let n=Ht(r),s=n+Ht(e),o=new Uint8Array(s+t.byteLength);return Ot(r,o,0),Ot(e,o,n),o.set(t,s),o}var Ll=Symbol.for("@ipld/js-cid/CID");var $t={...Rs,...Bs,...Ns,...xs,...vs,...As,...ks,...ps,...Is,...Es},bd={...ws,...ys};function hi(r,e,t,n){return{name:r,prefix:e,encoder:{name:r,prefix:e,encode:t},decoder:{decode:n}}}var fi=hi("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),Cs=hi("ascii","a",r=>{let e="a";for(let t=0;t<r.length;t++)e+=String.fromCharCode(r[t]);return e},r=>{r=r.substring(1);let e=xe(r.length);for(let t=0;t<r.length;t++)e[t]=r.charCodeAt(t);return e}),_l={utf8:fi,"utf-8":fi,hex:$t.base16,latin1:Cs,ascii:Cs,binary:Cs,...$t},zr=_l;function G(r,e="utf8"){let t=zr[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return t.decoder.decode(`${t.prefix}${r}`)}function Se(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function qt(r){if(!Number.isSafeInteger(r)||r<0)throw new Error(`positive integer expected, not ${r}`)}function Ul(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function Gt(r,...e){if(!Ul(r))throw new Error("Uint8Array expected");if(e.length>0&&!e.includes(r.length))throw new Error(`Uint8Array expected of length ${e}, not of length=${r.length}`)}function Wr(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");qt(r.outputLen),qt(r.blockLen)}function jt(r,e=!0){if(r.destroyed)throw new Error("Hash instance has been destroyed");if(e&&r.finished)throw new Error("Hash#digest() has already been called")}function di(r,e){Gt(r);let t=e.outputLen;if(r.length<t)throw new Error(`digestInto() expects output buffer of length at least ${t}`)}var Zr=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;var Wt=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),Te=(r,e)=>r<<32-e|r>>>e;var Ld=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;var Dl=async()=>{};async function pi(r,e,t){let n=Date.now();for(let s=0;s<r;s++){t(s);let o=Date.now()-n;o>=0&&o<e||(await Dl(),n+=o)}}function gi(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function it(r){return typeof r=="string"&&(r=gi(r)),Gt(r),r}function Ls(...r){let e=0;for(let n=0;n<r.length;n++){let s=r[n];Gt(s),e+=s.length}let t=new Uint8Array(e);for(let n=0,s=0;n<r.length;n++){let o=r[n];t.set(o,s),s+=o.length}return t}var zt=class{clone(){return this._cloneInto()}},Vl={}.toString;function yi(r,e){if(e!==void 0&&Vl.call(e)!=="[object Object]")throw new Error("Options should be object or undefined");return Object.assign(r,e)}function Yr(r){let e=n=>r().update(it(n)).digest(),t=r();return e.outputLen=t.outputLen,e.blockLen=t.blockLen,e.create=()=>r(),e}function Zt(r=32){if(Zr&&typeof Zr.getRandomValues=="function")return Zr.getRandomValues(new Uint8Array(r));throw new Error("crypto.getRandomValues must be defined")}function Ol(r,e,t,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(e,t,n);let s=BigInt(32),o=BigInt(4294967295),i=Number(t>>s&o),a=Number(t&o),c=n?4:0,f=n?0:4;r.setUint32(e+c,i,n),r.setUint32(e+f,a,n)}var mi=(r,e,t)=>r&e^~r&t,bi=(r,e,t)=>r&e^r&t^e&t,Yt=class extends zt{constructor(e,t,n,s){super(),this.blockLen=e,this.outputLen=t,this.padOffset=n,this.isLE=s,this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.buffer=new Uint8Array(e),this.view=Wt(this.buffer)}update(e){jt(this);let{view:t,buffer:n,blockLen:s}=this;e=it(e);let o=e.length;for(let i=0;i<o;){let a=Math.min(s-this.pos,o-i);if(a===s){let c=Wt(e);for(;s<=o-i;i+=s)this.process(c,i);continue}n.set(e.subarray(i,i+a),this.pos),this.pos+=a,i+=a,this.pos===s&&(this.process(t,0),this.pos=0)}return this.length+=e.length,this.roundClean(),this}digestInto(e){jt(this),di(e,this),this.finished=!0;let{buffer:t,view:n,blockLen:s,isLE:o}=this,{pos:i}=this;t[i++]=128,this.buffer.subarray(i).fill(0),this.padOffset>s-i&&(this.process(n,0),i=0);for(let l=i;l<s;l++)t[l]=0;Ol(n,s-8,BigInt(this.length*8),o),this.process(n,0);let a=Wt(e),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let f=c/4,u=this.get();if(f>u.length)throw new Error("_sha2: outputLen bigger than state");for(let l=0;l<f;l++)a.setUint32(4*l,u[l],o)}digest(){let{buffer:e,outputLen:t}=this;this.digestInto(e);let n=e.slice(0,t);return this.destroy(),n}_cloneInto(e){e||(e=new this.constructor),e.set(...this.get());let{blockLen:t,buffer:n,length:s,finished:o,destroyed:i,pos:a}=this;return e.length=s,e.pos=a,e.finished=o,e.destroyed=i,s%t&&e.buffer.set(n),e}};var Jr=BigInt(4294967295),_s=BigInt(32);function wi(r,e=!1){return e?{h:Number(r&Jr),l:Number(r>>_s&Jr)}:{h:Number(r>>_s&Jr)|0,l:Number(r&Jr)|0}}function Hl(r,e=!1){let t=new Uint32Array(r.length),n=new Uint32Array(r.length);for(let s=0;s<r.length;s++){let{h:o,l:i}=wi(r[s],e);[t[s],n[s]]=[o,i]}return[t,n]}var Pl=(r,e)=>BigInt(r>>>0)<<_s|BigInt(e>>>0),Ml=(r,e,t)=>r>>>t,Kl=(r,e,t)=>r<<32-t|e>>>t,Fl=(r,e,t)=>r>>>t|e<<32-t,$l=(r,e,t)=>r<<32-t|e>>>t,ql=(r,e,t)=>r<<64-t|e>>>t-32,Gl=(r,e,t)=>r>>>t-32|e<<64-t,jl=(r,e)=>e,zl=(r,e)=>r,Wl=(r,e,t)=>r<<t|e>>>32-t,Zl=(r,e,t)=>e<<t|r>>>32-t,Yl=(r,e,t)=>e<<t-32|r>>>64-t,Jl=(r,e,t)=>r<<t-32|e>>>64-t;function Xl(r,e,t,n){let s=(e>>>0)+(n>>>0);return{h:r+t+(s/2**32|0)|0,l:s|0}}var Ql=(r,e,t)=>(r>>>0)+(e>>>0)+(t>>>0),eu=(r,e,t,n)=>e+t+n+(r/2**32|0)|0,tu=(r,e,t,n)=>(r>>>0)+(e>>>0)+(t>>>0)+(n>>>0),ru=(r,e,t,n,s)=>e+t+n+s+(r/2**32|0)|0,nu=(r,e,t,n,s)=>(r>>>0)+(e>>>0)+(t>>>0)+(n>>>0)+(s>>>0),su=(r,e,t,n,s,o)=>e+t+n+s+o+(r/2**32|0)|0;var ou={fromBig:wi,split:Hl,toBig:Pl,shrSH:Ml,shrSL:Kl,rotrSH:Fl,rotrSL:$l,rotrBH:ql,rotrBL:Gl,rotr32H:jl,rotr32L:zl,rotlSH:Wl,rotlSL:Zl,rotlBH:Yl,rotlBL:Jl,add:Xl,add3L:Ql,add3H:eu,add4L:tu,add4H:ru,add5H:su,add5L:nu},U=ou;var[iu,au]=U.split(["0x428a2f98d728ae22","0x7137449123ef65cd","0xb5c0fbcfec4d3b2f","0xe9b5dba58189dbbc","0x3956c25bf348b538","0x59f111f1b605d019","0x923f82a4af194f9b","0xab1c5ed5da6d8118","0xd807aa98a3030242","0x12835b0145706fbe","0x243185be4ee4b28c","0x550c7dc3d5ffb4e2","0x72be5d74f27b896f","0x80deb1fe3b1696b1","0x9bdc06a725c71235","0xc19bf174cf692694","0xe49b69c19ef14ad2","0xefbe4786384f25e3","0x0fc19dc68b8cd5b5","0x240ca1cc77ac9c65","0x2de92c6f592b0275","0x4a7484aa6ea6e483","0x5cb0a9dcbd41fbd4","0x76f988da831153b5","0x983e5152ee66dfab","0xa831c66d2db43210","0xb00327c898fb213f","0xbf597fc7beef0ee4","0xc6e00bf33da88fc2","0xd5a79147930aa725","0x06ca6351e003826f","0x142929670a0e6e70","0x27b70a8546d22ffc","0x2e1b21385c26c926","0x4d2c6dfc5ac42aed","0x53380d139d95b3df","0x650a73548baf63de","0x766a0abb3c77b2a8","0x81c2c92e47edaee6","0x92722c851482353b","0xa2bfe8a14cf10364","0xa81a664bbc423001","0xc24b8b70d0f89791","0xc76c51a30654be30","0xd192e819d6ef5218","0xd69906245565a910","0xf40e35855771202a","0x106aa07032bbd1b8","0x19a4c116b8d2d0c8","0x1e376c085141ab53","0x2748774cdf8eeb99","0x34b0bcb5e19b48a8","0x391c0cb3c5c95a63","0x4ed8aa4ae3418acb","0x5b9cca4f7763e373","0x682e6ff3d6b2b8a3","0x748f82ee5defb2fc","0x78a5636f43172f60","0x84c87814a1f0ab72","0x8cc702081a6439ec","0x90befffa23631e28","0xa4506cebde82bde9","0xbef9a3f7b2c67915","0xc67178f2e372532b","0xca273eceea26619c","0xd186b8c721c0c207","0xeada7dd6cde0eb1e","0xf57d4f7fee6ed178","0x06f067aa72176fba","0x0a637dc5a2c898a6","0x113f9804bef90dae","0x1b710b35131c471b","0x28db77f523047d84","0x32caab7b40c72493","0x3c9ebe0a15c9bebc","0x431d67c49c100d4c","0x4cc5d4becb3e42b6","0x597f299cfc657e2a","0x5fcb6fab3ad6faec","0x6c44198c4a475817"].map(r=>BigInt(r))),at=new Uint32Array(80),ct=new Uint32Array(80),Us=class extends Yt{constructor(){super(128,64,16,!1),this.Ah=1779033703,this.Al=-205731576,this.Bh=-1150833019,this.Bl=-2067093701,this.Ch=1013904242,this.Cl=-23791573,this.Dh=-1521486534,this.Dl=1595750129,this.Eh=1359893119,this.El=-1377402159,this.Fh=-1694144372,this.Fl=725511199,this.Gh=528734635,this.Gl=-79577749,this.Hh=1541459225,this.Hl=327033209}get(){let{Ah:e,Al:t,Bh:n,Bl:s,Ch:o,Cl:i,Dh:a,Dl:c,Eh:f,El:u,Fh:l,Fl:p,Gh:x,Gl:y,Hh:h,Hl:m}=this;return[e,t,n,s,o,i,a,c,f,u,l,p,x,y,h,m]}set(e,t,n,s,o,i,a,c,f,u,l,p,x,y,h,m){this.Ah=e|0,this.Al=t|0,this.Bh=n|0,this.Bl=s|0,this.Ch=o|0,this.Cl=i|0,this.Dh=a|0,this.Dl=c|0,this.Eh=f|0,this.El=u|0,this.Fh=l|0,this.Fl=p|0,this.Gh=x|0,this.Gl=y|0,this.Hh=h|0,this.Hl=m|0}process(e,t){for(let w=0;w<16;w++,t+=4)at[w]=e.getUint32(t),ct[w]=e.getUint32(t+=4);for(let w=16;w<80;w++){let T=at[w-15]|0,S=ct[w-15]|0,k=U.rotrSH(T,S,1)^U.rotrSH(T,S,8)^U.shrSH(T,S,7),R=U.rotrSL(T,S,1)^U.rotrSL(T,S,8)^U.shrSL(T,S,7),I=at[w-2]|0,$=ct[w-2]|0,H=U.rotrSH(I,$,19)^U.rotrBH(I,$,61)^U.shrSH(I,$,6),P=U.rotrSL(I,$,19)^U.rotrBL(I,$,61)^U.shrSL(I,$,6),X=U.add4L(R,P,ct[w-7],ct[w-16]),ee=U.add4H(X,k,H,at[w-7],at[w-16]);at[w]=ee|0,ct[w]=X|0}let{Ah:n,Al:s,Bh:o,Bl:i,Ch:a,Cl:c,Dh:f,Dl:u,Eh:l,El:p,Fh:x,Fl:y,Gh:h,Gl:m,Hh:v,Hl:b}=this;for(let w=0;w<80;w++){let T=U.rotrSH(l,p,14)^U.rotrSH(l,p,18)^U.rotrBH(l,p,41),S=U.rotrSL(l,p,14)^U.rotrSL(l,p,18)^U.rotrBL(l,p,41),k=l&x^~l&h,R=p&y^~p&m,I=U.add5L(b,S,R,au[w],ct[w]),$=U.add5H(I,v,T,k,iu[w],at[w]),H=I|0,P=U.rotrSH(n,s,28)^U.rotrBH(n,s,34)^U.rotrBH(n,s,39),X=U.rotrSL(n,s,28)^U.rotrBL(n,s,34)^U.rotrBL(n,s,39),ee=n&o^n&a^o&a,N=s&i^s&c^i&c;v=h|0,b=m|0,h=x|0,m=y|0,x=l|0,y=p|0,{h:l,l:p}=U.add(f|0,u|0,$|0,H|0),f=a|0,u=c|0,a=o|0,c=i|0,o=n|0,i=s|0;let g=U.add3L(H,X,N);n=U.add3H(g,$,P,ee),s=g|0}({h:n,l:s}=U.add(this.Ah|0,this.Al|0,n|0,s|0)),{h:o,l:i}=U.add(this.Bh|0,this.Bl|0,o|0,i|0),{h:a,l:c}=U.add(this.Ch|0,this.Cl|0,a|0,c|0),{h:f,l:u}=U.add(this.Dh|0,this.Dl|0,f|0,u|0),{h:l,l:p}=U.add(this.Eh|0,this.El|0,l|0,p|0),{h:x,l:y}=U.add(this.Fh|0,this.Fl|0,x|0,y|0),{h,l:m}=U.add(this.Gh|0,this.Gl|0,h|0,m|0),{h:v,l:b}=U.add(this.Hh|0,this.Hl|0,v|0,b|0),this.set(n,s,o,i,a,c,f,u,l,p,x,y,h,m,v,b)}roundClean(){at.fill(0),ct.fill(0)}destroy(){this.buffer.fill(0),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}};var wr=Yr(()=>new Us);var Qr={};ie(Qr,{aInRange:()=>ve,abool:()=>Ce,abytes:()=>Jt,bitGet:()=>pu,bitLen:()=>du,bitMask:()=>vr,bitSet:()=>gu,bytesToHex:()=>je,bytesToNumberBE:()=>ze,bytesToNumberLE:()=>ut,concatBytes:()=>We,createHmacDrbg:()=>Ps,ensureBytes:()=>J,equalBytes:()=>fu,hexToBytes:()=>Et,hexToNumber:()=>Hs,inRange:()=>xr,isBytes:()=>lt,memoized:()=>kt,notImplemented:()=>mu,numberToBytesBE:()=>ft,numberToBytesLE:()=>At,numberToHexUnpadded:()=>Bi,numberToVarBytesBE:()=>uu,utf8ToBytes:()=>hu,validateObject:()=>He});var Os=BigInt(0),Xr=BigInt(1),cu=BigInt(2);function lt(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function Jt(r){if(!lt(r))throw new Error("Uint8Array expected")}function Ce(r,e){if(typeof e!="boolean")throw new Error(`${r} must be valid boolean, got "${e}".`)}var lu=Array.from({length:256},(r,e)=>e.toString(16).padStart(2,"0"));function je(r){Jt(r);let e="";for(let t=0;t<r.length;t++)e+=lu[r[t]];return e}function Bi(r){let e=r.toString(16);return e.length&1?`0${e}`:e}function Hs(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return BigInt(r===""?"0":`0x${r}`)}var Ge={_0:48,_9:57,_A:65,_F:70,_a:97,_f:102};function xi(r){if(r>=Ge._0&&r<=Ge._9)return r-Ge._0;if(r>=Ge._A&&r<=Ge._F)return r-(Ge._A-10);if(r>=Ge._a&&r<=Ge._f)return r-(Ge._a-10)}function Et(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);let e=r.length,t=e/2;if(e%2)throw new Error("padded hex string expected, got unpadded hex of length "+e);let n=new Uint8Array(t);for(let s=0,o=0;s<t;s++,o+=2){let i=xi(r.charCodeAt(o)),a=xi(r.charCodeAt(o+1));if(i===void 0||a===void 0){let c=r[o]+r[o+1];throw new Error('hex string expected, got non-hex character "'+c+'" at index '+o)}n[s]=i*16+a}return n}function ze(r){return Hs(je(r))}function ut(r){return Jt(r),Hs(je(Uint8Array.from(r).reverse()))}function ft(r,e){return Et(r.toString(16).padStart(e*2,"0"))}function At(r,e){return ft(r,e).reverse()}function uu(r){return Et(Bi(r))}function J(r,e,t){let n;if(typeof e=="string")try{n=Et(e)}catch(o){throw new Error(`${r} must be valid hex string, got "${e}". Cause: ${o}`)}else if(lt(e))n=Uint8Array.from(e);else throw new Error(`${r} must be hex string or Uint8Array`);let s=n.length;if(typeof t=="number"&&s!==t)throw new Error(`${r} expected ${t} bytes, got ${s}`);return n}function We(...r){let e=0;for(let n=0;n<r.length;n++){let s=r[n];Jt(s),e+=s.length}let t=new Uint8Array(e);for(let n=0,s=0;n<r.length;n++){let o=r[n];t.set(o,s),s+=o.length}return t}function fu(r,e){if(r.length!==e.length)return!1;let t=0;for(let n=0;n<r.length;n++)t|=r[n]^e[n];return t===0}function hu(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}var Ds=r=>typeof r=="bigint"&&Os<=r;function xr(r,e,t){return Ds(r)&&Ds(e)&&Ds(t)&&e<=r&&r<t}function ve(r,e,t,n){if(!xr(e,t,n))throw new Error(`expected valid ${r}: ${t} <= n < ${n}, got ${typeof e} ${e}`)}function du(r){let e;for(e=0;r>Os;r>>=Xr,e+=1);return e}function pu(r,e){return r>>BigInt(e)&Xr}function gu(r,e,t){return r|(t?Xr:Os)<<BigInt(e)}var vr=r=>(cu<<BigInt(r-1))-Xr,Vs=r=>new Uint8Array(r),vi=r=>Uint8Array.from(r);function Ps(r,e,t){if(typeof r!="number"||r<2)throw new Error("hashLen must be a number");if(typeof e!="number"||e<2)throw new Error("qByteLen must be a number");if(typeof t!="function")throw new Error("hmacFn must be a function");let n=Vs(r),s=Vs(r),o=0,i=()=>{n.fill(1),s.fill(0),o=0},a=(...l)=>t(s,n,...l),c=(l=Vs())=>{s=a(vi([0]),l),n=a(),l.length!==0&&(s=a(vi([1]),l),n=a())},f=()=>{if(o++>=1e3)throw new Error("drbg: tried 1000 values");let l=0,p=[];for(;l<e;){n=a();let x=n.slice();p.push(x),l+=n.length}return We(...p)};return(l,p)=>{i(),c(l);let x;for(;!(x=p(f()));)c();return i(),x}}var yu={bigint:r=>typeof r=="bigint",function:r=>typeof r=="function",boolean:r=>typeof r=="boolean",string:r=>typeof r=="string",stringOrUint8Array:r=>typeof r=="string"||lt(r),isSafeInteger:r=>Number.isSafeInteger(r),array:r=>Array.isArray(r),field:(r,e)=>e.Fp.isValid(r),hash:r=>typeof r=="function"&&Number.isSafeInteger(r.outputLen)};function He(r,e,t={}){let n=(s,o,i)=>{let a=yu[o];if(typeof a!="function")throw new Error(`Invalid validator "${o}", expected function`);let c=r[s];if(!(i&&c===void 0)&&!a(c,r))throw new Error(`Invalid param ${String(s)}=${c} (${typeof c}), expected ${o}`)};for(let[s,o]of Object.entries(e))n(s,o,!1);for(let[s,o]of Object.entries(t))n(s,o,!0);return r}var mu=()=>{throw new Error("not implemented")};function kt(r){let e=new WeakMap;return(t,...n)=>{let s=e.get(t);if(s!==void 0)return s;let o=r(t,...n);return e.set(t,o),o}}var re=BigInt(0),j=BigInt(1),St=BigInt(2),bu=BigInt(3),Ms=BigInt(4),Ei=BigInt(5),Ai=BigInt(8),wu=BigInt(9),xu=BigInt(16);function q(r,e){let t=r%e;return t>=re?t:e+t}function vu(r,e,t){if(t<=re||e<re)throw new Error("Expected power/modulo > 0");if(t===j)return re;let n=j;for(;e>re;)e&j&&(n=n*r%t),r=r*r%t,e>>=j;return n}function z(r,e,t){let n=r;for(;e-- >re;)n*=n,n%=t;return n}function en(r,e){if(r===re||e<=re)throw new Error(`invert: expected positive integers, got n=${r} mod=${e}`);let t=q(r,e),n=e,s=re,o=j,i=j,a=re;for(;t!==re;){let f=n/t,u=n%t,l=s-i*f,p=o-a*f;n=t,t=u,s=i,o=a,i=l,a=p}if(n!==j)throw new Error("invert: does not exist");return q(s,e)}function Bu(r){let e=(r-j)/St,t,n,s;for(t=r-j,n=0;t%St===re;t/=St,n++);for(s=St;s<r&&vu(s,e,r)!==r-j;s++);if(n===1){let i=(r+j)/Ms;return function(c,f){let u=c.pow(f,i);if(!c.eql(c.sqr(u),f))throw new Error("Cannot find square root");return u}}let o=(t+j)/St;return function(a,c){if(a.pow(c,e)===a.neg(a.ONE))throw new Error("Cannot find square root");let f=n,u=a.pow(a.mul(a.ONE,s),t),l=a.pow(c,o),p=a.pow(c,t);for(;!a.eql(p,a.ONE);){if(a.eql(p,a.ZERO))return a.ZERO;let x=1;for(let h=a.sqr(p);x<f&&!a.eql(h,a.ONE);x++)h=a.sqr(h);let y=a.pow(u,j<<BigInt(f-x-1));u=a.sqr(y),l=a.mul(l,y),p=a.mul(p,u),f=x}return l}}function Eu(r){if(r%Ms===bu){let e=(r+j)/Ms;return function(n,s){let o=n.pow(s,e);if(!n.eql(n.sqr(o),s))throw new Error("Cannot find square root");return o}}if(r%Ai===Ei){let e=(r-Ei)/Ai;return function(n,s){let o=n.mul(s,St),i=n.pow(o,e),a=n.mul(s,i),c=n.mul(n.mul(a,St),i),f=n.mul(a,n.sub(c,n.ONE));if(!n.eql(n.sqr(f),s))throw new Error("Cannot find square root");return f}}return r%xu,Bu(r)}var ki=(r,e)=>(q(r,e)&j)===j,Au=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function Ks(r){let e={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},t=Au.reduce((n,s)=>(n[s]="function",n),e);return He(r,t)}function ku(r,e,t){if(t<re)throw new Error("Expected power > 0");if(t===re)return r.ONE;if(t===j)return e;let n=r.ONE,s=e;for(;t>re;)t&j&&(n=r.mul(n,s)),s=r.sqr(s),t>>=j;return n}function Su(r,e){let t=new Array(e.length),n=e.reduce((o,i,a)=>r.is0(i)?o:(t[a]=o,r.mul(o,i)),r.ONE),s=r.inv(n);return e.reduceRight((o,i,a)=>r.is0(i)?o:(t[a]=r.mul(o,t[a]),r.mul(o,i)),s),t}function Fs(r,e){let t=e!==void 0?e:r.toString(2).length,n=Math.ceil(t/8);return{nBitLength:t,nByteLength:n}}function tn(r,e,t=!1,n={}){if(r<=re)throw new Error(`Expected Field ORDER > 0, got ${r}`);let{nBitLength:s,nByteLength:o}=Fs(r,e);if(o>2048)throw new Error("Field lengths over 2048 bytes are not supported");let i=Eu(r),a=Object.freeze({ORDER:r,BITS:s,BYTES:o,MASK:vr(s),ZERO:re,ONE:j,create:c=>q(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error(`Invalid field element: expected bigint, got ${typeof c}`);return re<=c&&c<r},is0:c=>c===re,isOdd:c=>(c&j)===j,neg:c=>q(-c,r),eql:(c,f)=>c===f,sqr:c=>q(c*c,r),add:(c,f)=>q(c+f,r),sub:(c,f)=>q(c-f,r),mul:(c,f)=>q(c*f,r),pow:(c,f)=>ku(a,c,f),div:(c,f)=>q(c*en(f,r),r),sqrN:c=>c*c,addN:(c,f)=>c+f,subN:(c,f)=>c-f,mulN:(c,f)=>c*f,inv:c=>en(c,r),sqrt:n.sqrt||(c=>i(a,c)),invertBatch:c=>Su(a,c),cmov:(c,f,u)=>u?f:c,toBytes:c=>t?At(c,o):ft(c,o),fromBytes:c=>{if(c.length!==o)throw new Error(`Fp.fromBytes: expected ${o}, got ${c.length}`);return t?ut(c):ze(c)}});return Object.freeze(a)}function Si(r){if(typeof r!="bigint")throw new Error("field order must be bigint");let e=r.toString(2).length;return Math.ceil(e/8)}function $s(r){let e=Si(r);return e+Math.ceil(e/2)}function Ii(r,e,t=!1){let n=r.length,s=Si(e),o=$s(e);if(n<16||n<o||n>1024)throw new Error(`expected ${o}-1024 bytes of input, got ${n}`);let i=t?ze(r):ut(r),a=q(i,e-j)+j;return t?At(a,s):ft(a,s)}var Nu=BigInt(0),qs=BigInt(1),Gs=new WeakMap,Ni=new WeakMap;function rn(r,e){let t=(o,i)=>{let a=i.negate();return o?a:i},n=o=>{if(!Number.isSafeInteger(o)||o<=0||o>e)throw new Error(`Wrong window size=${o}, should be [1..${e}]`)},s=o=>{n(o);let i=Math.ceil(e/o)+1,a=2**(o-1);return{windows:i,windowSize:a}};return{constTimeNegate:t,unsafeLadder(o,i){let a=r.ZERO,c=o;for(;i>Nu;)i&qs&&(a=a.add(c)),c=c.double(),i>>=qs;return a},precomputeWindow(o,i){let{windows:a,windowSize:c}=s(i),f=[],u=o,l=u;for(let p=0;p<a;p++){l=u,f.push(l);for(let x=1;x<c;x++)l=l.add(u),f.push(l);u=l.double()}return f},wNAF(o,i,a){let{windows:c,windowSize:f}=s(o),u=r.ZERO,l=r.BASE,p=BigInt(2**o-1),x=2**o,y=BigInt(o);for(let h=0;h<c;h++){let m=h*f,v=Number(a&p);a>>=y,v>f&&(v-=x,a+=qs);let b=m,w=m+Math.abs(v)-1,T=h%2!==0,S=v<0;v===0?l=l.add(t(T,i[b])):u=u.add(t(S,i[w]))}return{p:u,f:l}},wNAFCached(o,i,a){let c=Ni.get(o)||1,f=Gs.get(o);return f||(f=this.precomputeWindow(o,c),c!==1&&Gs.set(o,a(f))),this.wNAF(c,f,i)},setWindowSize(o,i){n(i),Ni.set(o,i),Gs.delete(o)}}}function Br(r){return Ks(r.Fp),He(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...Fs(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Le=BigInt(0),Be=BigInt(1),nn=BigInt(2),Ru=BigInt(8),Tu={zip215:!0};function Cu(r){let e=Br(r);return He(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...e})}function Ri(r){let e=Cu(r),{Fp:t,n,prehash:s,hash:o,randomBytes:i,nByteLength:a,h:c}=e,f=nn<<BigInt(a*8)-Be,u=t.create,l=e.uvRatio||((g,d)=>{try{return{isValid:!0,value:t.sqrt(g*t.inv(d))}}catch{return{isValid:!1,value:Le}}}),p=e.adjustScalarBytes||(g=>g),x=e.domain||((g,d,B)=>{if(Ce("phflag",B),d.length||B)throw new Error("Contexts/pre-hash are not supported");return g});function y(g,d){ve("coordinate "+g,d,Le,f)}function h(g){if(!(g instanceof b))throw new Error("ExtendedPoint expected")}let m=kt((g,d)=>{let{ex:B,ey:E,ez:C}=g,L=g.is0();d==null&&(d=L?Ru:t.inv(C));let _=u(B*d),M=u(E*d),D=u(C*d);if(L)return{x:Le,y:Be};if(D!==Be)throw new Error("invZ was invalid");return{x:_,y:M}}),v=kt(g=>{let{a:d,d:B}=e;if(g.is0())throw new Error("bad point: ZERO");let{ex:E,ey:C,ez:L,et:_}=g,M=u(E*E),D=u(C*C),K=u(L*L),W=u(K*K),Z=u(M*d),be=u(K*u(Z+D)),se=u(W+u(B*u(M*D)));if(be!==se)throw new Error("bad point: equation left != right (1)");let te=u(E*C),Ne=u(L*_);if(te!==Ne)throw new Error("bad point: equation left != right (2)");return!0});class b{constructor(d,B,E,C){this.ex=d,this.ey=B,this.ez=E,this.et=C,y("x",d),y("y",B),y("z",E),y("t",C),Object.freeze(this)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(d){if(d instanceof b)throw new Error("extended point not allowed");let{x:B,y:E}=d||{};return y("x",B),y("y",E),new b(B,E,Be,u(B*E))}static normalizeZ(d){let B=t.invertBatch(d.map(E=>E.ez));return d.map((E,C)=>E.toAffine(B[C])).map(b.fromAffine)}_setWindowSize(d){S.setWindowSize(this,d)}assertValidity(){v(this)}equals(d){h(d);let{ex:B,ey:E,ez:C}=this,{ex:L,ey:_,ez:M}=d,D=u(B*M),K=u(L*C),W=u(E*M),Z=u(_*C);return D===K&&W===Z}is0(){return this.equals(b.ZERO)}negate(){return new b(u(-this.ex),this.ey,this.ez,u(-this.et))}double(){let{a:d}=e,{ex:B,ey:E,ez:C}=this,L=u(B*B),_=u(E*E),M=u(nn*u(C*C)),D=u(d*L),K=B+E,W=u(u(K*K)-L-_),Z=D+_,be=Z-M,se=D-_,te=u(W*be),Ne=u(Z*se),oe=u(W*se),Re=u(be*Z);return new b(te,Ne,Re,oe)}add(d){h(d);let{a:B,d:E}=e,{ex:C,ey:L,ez:_,et:M}=this,{ex:D,ey:K,ez:W,et:Z}=d;if(B===BigInt(-1)){let Ho=u((L-C)*(K+D)),Po=u((L+C)*(K-D)),cs=u(Po-Ho);if(cs===Le)return this.double();let Mo=u(_*nn*Z),Ko=u(M*nn*W),Fo=Ko+Mo,$o=Po+Ho,qo=Ko-Mo,mc=u(Fo*cs),bc=u($o*qo),wc=u(Fo*qo),xc=u(cs*$o);return new b(mc,bc,xc,wc)}let be=u(C*D),se=u(L*K),te=u(M*E*Z),Ne=u(_*W),oe=u((C+L)*(D+K)-be-se),Re=Ne-te,Bt=Ne+te,pr=u(se-B*be),Fr=u(oe*Re),pc=u(Bt*pr),gc=u(oe*pr),yc=u(Re*Bt);return new b(Fr,pc,yc,gc)}subtract(d){return this.add(d.negate())}wNAF(d){return S.wNAFCached(this,d,b.normalizeZ)}multiply(d){let B=d;ve("scalar",B,Be,n);let{p:E,f:C}=this.wNAF(B);return b.normalizeZ([E,C])[0]}multiplyUnsafe(d){let B=d;return ve("scalar",B,Le,n),B===Le?T:this.equals(T)||B===Be?this:this.equals(w)?this.wNAF(B).p:S.unsafeLadder(this,B)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return S.unsafeLadder(this,n).is0()}toAffine(d){return m(this,d)}clearCofactor(){let{h:d}=e;return d===Be?this:this.multiplyUnsafe(d)}static fromHex(d,B=!1){let{d:E,a:C}=e,L=t.BYTES;d=J("pointHex",d,L),Ce("zip215",B);let _=d.slice(),M=d[L-1];_[L-1]=M&-129;let D=ut(_),K=B?f:t.ORDER;ve("pointHex.y",D,Le,K);let W=u(D*D),Z=u(W-Be),be=u(E*W-C),{isValid:se,value:te}=l(Z,be);if(!se)throw new Error("Point.fromHex: invalid y coordinate");let Ne=(te&Be)===Be,oe=(M&128)!==0;if(!B&&te===Le&&oe)throw new Error("Point.fromHex: x=0 and x_0=1");return oe!==Ne&&(te=u(-te)),b.fromAffine({x:te,y:D})}static fromPrivateKey(d){return I(d).point}toRawBytes(){let{x:d,y:B}=this.toAffine(),E=At(B,t.BYTES);return E[E.length-1]|=d&Be?128:0,E}toHex(){return je(this.toRawBytes())}}b.BASE=new b(e.Gx,e.Gy,Be,u(e.Gx*e.Gy)),b.ZERO=new b(Le,Be,Be,Le);let{BASE:w,ZERO:T}=b,S=rn(b,a*8);function k(g){return q(g,n)}function R(g){return k(ut(g))}function I(g){let d=a;g=J("private key",g,d);let B=J("hashed private key",o(g),2*d),E=p(B.slice(0,d)),C=B.slice(d,2*d),L=R(E),_=w.multiply(L),M=_.toRawBytes();return{head:E,prefix:C,scalar:L,point:_,pointBytes:M}}function $(g){return I(g).pointBytes}function H(g=new Uint8Array,...d){let B=We(...d);return R(o(x(B,J("context",g),!!s)))}function P(g,d,B={}){g=J("message",g),s&&(g=s(g));let{prefix:E,scalar:C,pointBytes:L}=I(d),_=H(B.context,E,g),M=w.multiply(_).toRawBytes(),D=H(B.context,M,L,g),K=k(_+D*C);ve("signature.s",K,Le,n);let W=We(M,At(K,t.BYTES));return J("result",W,a*2)}let X=Tu;function ee(g,d,B,E=X){let{context:C,zip215:L}=E,_=t.BYTES;g=J("signature",g,2*_),d=J("message",d),L!==void 0&&Ce("zip215",L),s&&(d=s(d));let M=ut(g.slice(_,2*_)),D,K,W;try{D=b.fromHex(B,L),K=b.fromHex(g.slice(0,_),L),W=w.multiplyUnsafe(M)}catch{return!1}if(!L&&D.isSmallOrder())return!1;let Z=H(C,K.toRawBytes(),D.toRawBytes(),d);return K.add(D.multiplyUnsafe(Z)).subtract(W).clearCofactor().equals(b.ZERO)}return w._setWindowSize(8),{CURVE:e,getPublicKey:$,sign:P,verify:ee,ExtendedPoint:b,utils:{getExtendedPublicKey:I,randomPrivateKey:()=>i(t.BYTES),precompute(g=8,d=b.BASE){return d._setWindowSize(g),d.multiply(BigInt(3)),d}}}}var js=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),Ti=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),t0=BigInt(0),Lu=BigInt(1),Ci=BigInt(2),r0=BigInt(3),_u=BigInt(5),Uu=BigInt(8);function Du(r){let e=BigInt(10),t=BigInt(20),n=BigInt(40),s=BigInt(80),o=js,a=r*r%o*r%o,c=z(a,Ci,o)*a%o,f=z(c,Lu,o)*r%o,u=z(f,_u,o)*f%o,l=z(u,e,o)*u%o,p=z(l,t,o)*l%o,x=z(p,n,o)*p%o,y=z(x,s,o)*x%o,h=z(y,s,o)*x%o,m=z(h,e,o)*u%o;return{pow_p_5_8:z(m,Ci,o)*r%o,b2:a}}function Vu(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function Ou(r,e){let t=js,n=q(e*e*e,t),s=q(n*n*e,t),o=Du(r*s).pow_p_5_8,i=q(r*n*o,t),a=q(e*i*i,t),c=i,f=q(i*Ti,t),u=a===r,l=a===q(-r,t),p=a===q(-r*Ti,t);return u&&(i=c),(l||p)&&(i=f),ki(i,t)&&(i=q(-i,t)),{isValid:u||l,value:i}}var Hu=tn(js,void 0,!0),Pu={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:Hu,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:Uu,Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:wr,randomBytes:Zt,adjustScalarBytes:Vu,uvRatio:Ou},Xt=Ri(Pu);var Qt=32,Ze=64,sn=32;function Li(){let r=Xt.utils.randomPrivateKey(),e=Xt.getPublicKey(r);return{privateKey:Vi(r,e),publicKey:e}}function _i(r){if(r.length!==sn)throw new TypeError('"seed" must be 32 bytes in length.');if(!(r instanceof Uint8Array))throw new TypeError('"seed" must be a node.js Buffer, or Uint8Array.');let e=r,t=Xt.getPublicKey(e);return{privateKey:Vi(e,t),publicKey:t}}function Ui(r,e){let t=r.subarray(0,sn);return Xt.sign(e instanceof Uint8Array?e:e.subarray(),t)}function Di(r,e,t){return Xt.verify(e,t instanceof Uint8Array?t:t.subarray(),r)}function Vi(r,e){let t=new Uint8Array(Ze);for(let n=0;n<sn;n++)t[n]=r[n],t[sn+n]=e[n];return t}var ye={get(r=globalThis){let e=r.crypto;if(e?.subtle==null)throw Object.assign(new Error("Missing Web Crypto API. The most likely cause of this error is that this page is being accessed from an insecure context (i.e. not HTTPS). For more information and possible resolutions see https://github.com/libp2p/js-libp2p/blob/main/packages/crypto/README.md#web-crypto-api"),{code:"ERR_MISSING_WEB_CRYPTO"});return e}};var zs={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function Oi(r){let e=r?.algorithm??"AES-GCM",t=r?.keyLength??16,n=r?.nonceLength??12,s=r?.digest??"SHA-256",o=r?.saltLength??16,i=r?.iterations??32767,a=ye.get();t*=8;async function c(l,p){let x=a.getRandomValues(new Uint8Array(o)),y=a.getRandomValues(new Uint8Array(n)),h={name:e,iv:y};typeof p=="string"&&(p=G(p));let m;if(p.length===0){m=await a.subtle.importKey("jwk",zs,{name:"AES-GCM"},!0,["encrypt"]);try{let b={name:"PBKDF2",salt:x,iterations:i,hash:{name:s}},w=await a.subtle.importKey("raw",p,{name:"PBKDF2"},!1,["deriveKey"]);m=await a.subtle.deriveKey(b,w,{name:e,length:t},!0,["encrypt"])}catch{m=await a.subtle.importKey("jwk",zs,{name:"AES-GCM"},!0,["encrypt"])}}else{let b={name:"PBKDF2",salt:x,iterations:i,hash:{name:s}},w=await a.subtle.importKey("raw",p,{name:"PBKDF2"},!1,["deriveKey"]);m=await a.subtle.deriveKey(b,w,{name:e,length:t},!0,["encrypt"])}let v=await a.subtle.encrypt(h,m,l);return Kt([x,h.iv,new Uint8Array(v)])}async function f(l,p){let x=l.subarray(0,o),y=l.subarray(o,o+n),h=l.subarray(o+n),m={name:e,iv:y};typeof p=="string"&&(p=G(p));let v;if(p.length===0)try{let w={name:"PBKDF2",salt:x,iterations:i,hash:{name:s}},T=await a.subtle.importKey("raw",p,{name:"PBKDF2"},!1,["deriveKey"]);v=await a.subtle.deriveKey(w,T,{name:e,length:t},!0,["decrypt"])}catch{v=await a.subtle.importKey("jwk",zs,{name:"AES-GCM"},!0,["decrypt"])}else{let w={name:"PBKDF2",salt:x,iterations:i,hash:{name:s}},T=await a.subtle.importKey("raw",p,{name:"PBKDF2"},!1,["deriveKey"]);v=await a.subtle.deriveKey(w,T,{name:e,length:t},!0,["decrypt"])}let b=await a.subtle.decrypt(m,v,h);return new Uint8Array(b)}return{encrypt:c,decrypt:f}}async function er(r,e){let n=await Oi().encrypt(r,e);return Ss.encode(n)}var Fu=Math.pow(2,7),$u=Math.pow(2,14),qu=Math.pow(2,21),Ws=Math.pow(2,28),Zs=Math.pow(2,35),Ys=Math.pow(2,42),Js=Math.pow(2,49),F=128,he=127;function Ye(r){if(r<Fu)return 1;if(r<$u)return 2;if(r<qu)return 3;if(r<Ws)return 4;if(r<Zs)return 5;if(r<Ys)return 6;if(r<Js)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function Xs(r,e,t=0){switch(Ye(r)){case 8:e[t++]=r&255|F,r/=128;case 7:e[t++]=r&255|F,r/=128;case 6:e[t++]=r&255|F,r/=128;case 5:e[t++]=r&255|F,r/=128;case 4:e[t++]=r&255|F,r>>>=7;case 3:e[t++]=r&255|F,r>>>=7;case 2:e[t++]=r&255|F,r>>>=7;case 1:{e[t++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return e}function Gu(r,e,t=0){switch(Ye(r)){case 8:e.set(t++,r&255|F),r/=128;case 7:e.set(t++,r&255|F),r/=128;case 6:e.set(t++,r&255|F),r/=128;case 5:e.set(t++,r&255|F),r/=128;case 4:e.set(t++,r&255|F),r>>>=7;case 3:e.set(t++,r&255|F),r>>>=7;case 2:e.set(t++,r&255|F),r>>>=7;case 1:{e.set(t++,r&255),r>>>=7;break}default:throw new Error("unreachable")}return e}function Qs(r,e){let t=r[e],n=0;if(n+=t&he,t<F||(t=r[e+1],n+=(t&he)<<7,t<F)||(t=r[e+2],n+=(t&he)<<14,t<F)||(t=r[e+3],n+=(t&he)<<21,t<F)||(t=r[e+4],n+=(t&he)*Ws,t<F)||(t=r[e+5],n+=(t&he)*Zs,t<F)||(t=r[e+6],n+=(t&he)*Ys,t<F)||(t=r[e+7],n+=(t&he)*Js,t<F))return n;throw new RangeError("Could not decode varint")}function ju(r,e){let t=r.get(e),n=0;if(n+=t&he,t<F||(t=r.get(e+1),n+=(t&he)<<7,t<F)||(t=r.get(e+2),n+=(t&he)<<14,t<F)||(t=r.get(e+3),n+=(t&he)<<21,t<F)||(t=r.get(e+4),n+=(t&he)*Ws,t<F)||(t=r.get(e+5),n+=(t&he)*Zs,t<F)||(t=r.get(e+6),n+=(t&he)*Ys,t<F)||(t=r.get(e+7),n+=(t&he)*Js,t<F))return n;throw new RangeError("Could not decode varint")}function Hi(r,e,t=0){return e==null&&(e=xe(Ye(r))),e instanceof Uint8Array?Xs(r,e,t):Gu(r,e,t)}function Pi(r,e=0){return r instanceof Uint8Array?Qs(r,e):ju(r,e)}var eo=new Float32Array([-0]),ht=new Uint8Array(eo.buffer);function Mi(r,e,t){eo[0]=r,e[t]=ht[0],e[t+1]=ht[1],e[t+2]=ht[2],e[t+3]=ht[3]}function Ki(r,e){return ht[0]=r[e],ht[1]=r[e+1],ht[2]=r[e+2],ht[3]=r[e+3],eo[0]}var to=new Float64Array([-0]),de=new Uint8Array(to.buffer);function Fi(r,e,t){to[0]=r,e[t]=de[0],e[t+1]=de[1],e[t+2]=de[2],e[t+3]=de[3],e[t+4]=de[4],e[t+5]=de[5],e[t+6]=de[6],e[t+7]=de[7]}function $i(r,e){return de[0]=r[e],de[1]=r[e+1],de[2]=r[e+2],de[3]=r[e+3],de[4]=r[e+4],de[5]=r[e+5],de[6]=r[e+6],de[7]=r[e+7],to[0]}var Wu=BigInt(Number.MAX_SAFE_INTEGER),Zu=BigInt(Number.MIN_SAFE_INTEGER),ke=class r{lo;hi;constructor(e,t){this.lo=e|0,this.hi=t|0}toNumber(e=!1){if(!e&&this.hi>>>31>0){let t=~this.lo+1>>>0,n=~this.hi>>>0;return t===0&&(n=n+1>>>0),-(t+n*4294967296)}return this.lo+this.hi*4294967296}toBigInt(e=!1){if(e)return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n);if(this.hi>>>31){let t=~this.lo+1>>>0,n=~this.hi>>>0;return t===0&&(n=n+1>>>0),-(BigInt(t)+(BigInt(n)<<32n))}return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n)}toString(e=!1){return this.toBigInt(e).toString()}zzEncode(){let e=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^e)>>>0,this.lo=(this.lo<<1^e)>>>0,this}zzDecode(){let e=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^e)>>>0,this.hi=(this.hi>>>1^e)>>>0,this}length(){let e=this.lo,t=(this.lo>>>28|this.hi<<4)>>>0,n=this.hi>>>24;return n===0?t===0?e<16384?e<128?1:2:e<2097152?3:4:t<16384?t<128?5:6:t<2097152?7:8:n<128?9:10}static fromBigInt(e){if(e===0n)return It;if(e<Wu&&e>Zu)return this.fromNumber(Number(e));let t=e<0n;t&&(e=-e);let n=e>>32n,s=e-(n<<32n);return t&&(n=~n|0n,s=~s|0n,++s>qi&&(s=0n,++n>qi&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(e){if(e===0)return It;let t=e<0;t&&(e=-e);let n=e>>>0,s=(e-n)/4294967296>>>0;return t&&(s=~s>>>0,n=~n>>>0,++n>4294967295&&(n=0,++s>4294967295&&(s=0))),new r(n,s)}static from(e){return typeof e=="number"?r.fromNumber(e):typeof e=="bigint"?r.fromBigInt(e):typeof e=="string"?r.fromBigInt(BigInt(e)):e.low!=null||e.high!=null?new r(e.low>>>0,e.high>>>0):It}},It=new ke(0,0);It.toBigInt=function(){return 0n};It.zzEncode=It.zzDecode=function(){return this};It.length=function(){return 1};var qi=4294967296n;function Gi(r){let e=0,t=0;for(let n=0;n<r.length;++n)t=r.charCodeAt(n),t<128?e+=1:t<2048?e+=2:(t&64512)===55296&&(r.charCodeAt(n+1)&64512)===56320?(++n,e+=4):e+=3;return e}function ji(r,e,t){if(t-e<1)return"";let s,o=[],i=0,a;for(;e<t;)a=r[e++],a<128?o[i++]=a:a>191&&a<224?o[i++]=(a&31)<<6|r[e++]&63:a>239&&a<365?(a=((a&7)<<18|(r[e++]&63)<<12|(r[e++]&63)<<6|r[e++]&63)-65536,o[i++]=55296+(a>>10),o[i++]=56320+(a&1023)):o[i++]=(a&15)<<12|(r[e++]&63)<<6|r[e++]&63,i>8191&&((s??(s=[])).push(String.fromCharCode.apply(String,o)),i=0);return s!=null?(i>0&&s.push(String.fromCharCode.apply(String,o.slice(0,i))),s.join("")):String.fromCharCode.apply(String,o.slice(0,i))}function ro(r,e,t){let n=t,s,o;for(let i=0;i<r.length;++i)s=r.charCodeAt(i),s<128?e[t++]=s:s<2048?(e[t++]=s>>6|192,e[t++]=s&63|128):(s&64512)===55296&&((o=r.charCodeAt(i+1))&64512)===56320?(s=65536+((s&1023)<<10)+(o&1023),++i,e[t++]=s>>18|240,e[t++]=s>>12&63|128,e[t++]=s>>6&63|128,e[t++]=s&63|128):(e[t++]=s>>12|224,e[t++]=s>>6&63|128,e[t++]=s&63|128);return t-n}function _e(r,e){return RangeError(`index out of range: ${r.pos} + ${e??1} > ${r.len}`)}function on(r,e){return(r[e-4]|r[e-3]<<8|r[e-2]<<16|r[e-1]<<24)>>>0}var no=class{buf;pos;len;_slice=Uint8Array.prototype.subarray;constructor(e){this.buf=e,this.pos=0,this.len=e.length}uint32(){let e=4294967295;if(e=(this.buf[this.pos]&127)>>>0,this.buf[this.pos++]<128||(e=(e|(this.buf[this.pos]&127)<<7)>>>0,this.buf[this.pos++]<128)||(e=(e|(this.buf[this.pos]&127)<<14)>>>0,this.buf[this.pos++]<128)||(e=(e|(this.buf[this.pos]&127)<<21)>>>0,this.buf[this.pos++]<128)||(e=(e|(this.buf[this.pos]&15)<<28)>>>0,this.buf[this.pos++]<128))return e;if((this.pos+=5)>this.len)throw this.pos=this.len,_e(this,10);return e}int32(){return this.uint32()|0}sint32(){let e=this.uint32();return e>>>1^-(e&1)|0}bool(){return this.uint32()!==0}fixed32(){if(this.pos+4>this.len)throw _e(this,4);return on(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw _e(this,4);return on(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw _e(this,4);let e=Ki(this.buf,this.pos);return this.pos+=4,e}double(){if(this.pos+8>this.len)throw _e(this,4);let e=$i(this.buf,this.pos);return this.pos+=8,e}bytes(){let e=this.uint32(),t=this.pos,n=this.pos+e;if(n>this.len)throw _e(this,e);return this.pos+=e,t===n?new Uint8Array(0):this.buf.subarray(t,n)}string(){let e=this.bytes();return ji(e,0,e.length)}skip(e){if(typeof e=="number"){if(this.pos+e>this.len)throw _e(this,e);this.pos+=e}else do if(this.pos>=this.len)throw _e(this);while(this.buf[this.pos++]&128);return this}skipType(e){switch(e){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;(e=this.uint32()&7)!==4;)this.skipType(e);break;case 5:this.skip(4);break;default:throw Error(`invalid wire type ${e} at offset ${this.pos}`)}return this}readLongVarint(){let e=new ke(0,0),t=0;if(this.len-this.pos>4){for(;t<4;++t)if(e.lo=(e.lo|(this.buf[this.pos]&127)<<t*7)>>>0,this.buf[this.pos++]<128)return e;if(e.lo=(e.lo|(this.buf[this.pos]&127)<<28)>>>0,e.hi=(e.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return e;t=0}else{for(;t<3;++t){if(this.pos>=this.len)throw _e(this);if(e.lo=(e.lo|(this.buf[this.pos]&127)<<t*7)>>>0,this.buf[this.pos++]<128)return e}return e.lo=(e.lo|(this.buf[this.pos++]&127)<<t*7)>>>0,e}if(this.len-this.pos>4){for(;t<5;++t)if(e.hi=(e.hi|(this.buf[this.pos]&127)<<t*7+3)>>>0,this.buf[this.pos++]<128)return e}else for(;t<5;++t){if(this.pos>=this.len)throw _e(this);if(e.hi=(e.hi|(this.buf[this.pos]&127)<<t*7+3)>>>0,this.buf[this.pos++]<128)return e}throw Error("invalid varint encoding")}readFixed64(){if(this.pos+8>this.len)throw _e(this,8);let e=on(this.buf,this.pos+=4),t=on(this.buf,this.pos+=4);return new ke(e,t)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){let e=Qs(this.buf,this.pos);return this.pos+=Ye(e),e}uint64String(){return this.readLongVarint().toString(!0)}sint64(){return this.readLongVarint().zzDecode().toBigInt()}sint64Number(){return this.readLongVarint().zzDecode().toNumber()}sint64String(){return this.readLongVarint().zzDecode().toString()}fixed64(){return this.readFixed64().toBigInt()}fixed64Number(){return this.readFixed64().toNumber()}fixed64String(){return this.readFixed64().toString()}sfixed64(){return this.readFixed64().toBigInt()}sfixed64Number(){return this.readFixed64().toNumber()}sfixed64String(){return this.readFixed64().toString()}};function so(r){return new no(r instanceof Uint8Array?r:r.subarray())}function Nt(r,e,t){let n=so(r);return e.decode(n,void 0,t)}function oo(r){let e=r??8192,t=e>>>1,n,s=e;return function(i){if(i<1||i>t)return xe(i);s+i>e&&(n=xe(e),s=0);let a=n.subarray(s,s+=i);return s&7&&(s=(s|7)+1),a}}var Rt=class{fn;len;next;val;constructor(e,t,n){this.fn=e,this.len=t,this.next=void 0,this.val=n}};function io(){}var co=class{head;tail;len;next;constructor(e){this.head=e.head,this.tail=e.tail,this.len=e.len,this.next=e.states}},Yu=oo();function Ju(r){return globalThis.Buffer!=null?xe(r):Yu(r)}var Ar=class{len;head;tail;states;constructor(){this.len=0,this.head=new Rt(io,0,0),this.tail=this.head,this.states=null}_push(e,t,n){return this.tail=this.tail.next=new Rt(e,t,n),this.len+=t,this}uint32(e){return this.len+=(this.tail=this.tail.next=new lo((e=e>>>0)<128?1:e<16384?2:e<2097152?3:e<268435456?4:5,e)).len,this}int32(e){return e<0?this._push(an,10,ke.fromNumber(e)):this.uint32(e)}sint32(e){return this.uint32((e<<1^e>>31)>>>0)}uint64(e){let t=ke.fromBigInt(e);return this._push(an,t.length(),t)}uint64Number(e){return this._push(Xs,Ye(e),e)}uint64String(e){return this.uint64(BigInt(e))}int64(e){return this.uint64(e)}int64Number(e){return this.uint64Number(e)}int64String(e){return this.uint64String(e)}sint64(e){let t=ke.fromBigInt(e).zzEncode();return this._push(an,t.length(),t)}sint64Number(e){let t=ke.fromNumber(e).zzEncode();return this._push(an,t.length(),t)}sint64String(e){return this.sint64(BigInt(e))}bool(e){return this._push(ao,1,e?1:0)}fixed32(e){return this._push(Er,4,e>>>0)}sfixed32(e){return this.fixed32(e)}fixed64(e){let t=ke.fromBigInt(e);return this._push(Er,4,t.lo)._push(Er,4,t.hi)}fixed64Number(e){let t=ke.fromNumber(e);return this._push(Er,4,t.lo)._push(Er,4,t.hi)}fixed64String(e){return this.fixed64(BigInt(e))}sfixed64(e){return this.fixed64(e)}sfixed64Number(e){return this.fixed64Number(e)}sfixed64String(e){return this.fixed64String(e)}float(e){return this._push(Mi,4,e)}double(e){return this._push(Fi,8,e)}bytes(e){let t=e.length>>>0;return t===0?this._push(ao,1,0):this.uint32(t)._push(Qu,t,e)}string(e){let t=Gi(e);return t!==0?this.uint32(t)._push(ro,t,e):this._push(ao,1,0)}fork(){return this.states=new co(this),this.head=this.tail=new Rt(io,0,0),this.len=0,this}reset(){return this.states!=null?(this.head=this.states.head,this.tail=this.states.tail,this.len=this.states.len,this.states=this.states.next):(this.head=this.tail=new Rt(io,0,0),this.len=0),this}ldelim(){let e=this.head,t=this.tail,n=this.len;return this.reset().uint32(n),n!==0&&(this.tail.next=e.next,this.tail=t,this.len+=n),this}finish(){let e=this.head.next,t=Ju(this.len),n=0;for(;e!=null;)e.fn(e.val,t,n),n+=e.len,e=e.next;return t}};function ao(r,e,t){e[t]=r&255}function Xu(r,e,t){for(;r>127;)e[t++]=r&127|128,r>>>=7;e[t]=r}var lo=class extends Rt{next;constructor(e,t){super(Xu,e,t),this.next=void 0}};function an(r,e,t){for(;r.hi!==0;)e[t++]=r.lo&127|128,r.lo=(r.lo>>>7|r.hi<<25)>>>0,r.hi>>>=7;for(;r.lo>127;)e[t++]=r.lo&127|128,r.lo=r.lo>>>7;e[t++]=r.lo}function Er(r,e,t){e[t]=r&255,e[t+1]=r>>>8&255,e[t+2]=r>>>16&255,e[t+3]=r>>>24}function Qu(r,e,t){e.set(r,t)}globalThis.Buffer!=null&&(Ar.prototype.bytes=function(r){let e=r.length>>>0;return this.uint32(e),e>0&&this._push(ef,e,r),this},Ar.prototype.string=function(r){let e=globalThis.Buffer.byteLength(r);return this.uint32(e),e>0&&this._push(tf,e,r),this});function ef(r,e,t){e.set(r,t)}function tf(r,e,t){r.length<40?ro(r,e,t):e.utf8Write!=null?e.utf8Write(r,t):e.set(G(r),t)}function uo(){return new Ar}function Tt(r,e){let t=uo();return e.encode(r,t,{lengthDelimited:!1}),t.finish()}var tr;(function(r){r[r.VARINT=0]="VARINT",r[r.BIT64=1]="BIT64",r[r.LENGTH_DELIMITED=2]="LENGTH_DELIMITED",r[r.START_GROUP=3]="START_GROUP",r[r.END_GROUP=4]="END_GROUP",r[r.BIT32=5]="BIT32"})(tr||(tr={}));function cn(r,e,t,n){return{name:r,type:e,encode:t,decode:n}}function kr(r){function e(s){if(r[s.toString()]==null)throw new Error("Invalid enum value");return r[s]}let t=function(o,i){let a=e(o);i.int32(a)},n=function(o){let i=o.int32();return e(i)};return cn("enum",tr.VARINT,t,n)}function Ct(r,e){return cn("message",tr.LENGTH_DELIMITED,r,e)}var ue;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.Secp256k1="Secp256k1"})(ue||(ue={}));var fo;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.Secp256k1=2]="Secp256k1"})(fo||(fo={}));(function(r){r.codec=()=>kr(fo)})(ue||(ue={}));var dt;(function(r){let e;r.codec=()=>(e==null&&(e=Ct((t,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),t.Type!=null&&(n.uint32(8),ue.codec().encode(t.Type,n)),t.Data!=null&&(n.uint32(18),n.bytes(t.Data)),s.lengthDelimited!==!1&&n.ldelim()},(t,n)=>{let s={},o=n==null?t.len:t.pos+n;for(;t.pos<o;){let i=t.uint32();switch(i>>>3){case 1:s.Type=ue.codec().decode(t);break;case 2:s.Data=t.bytes();break;default:t.skipType(i&7);break}}return s})),e),r.encode=t=>Tt(t,r.codec()),r.decode=t=>Nt(t,r.codec())})(dt||(dt={}));var pt;(function(r){let e;r.codec=()=>(e==null&&(e=Ct((t,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),t.Type!=null&&(n.uint32(8),ue.codec().encode(t.Type,n)),t.Data!=null&&(n.uint32(18),n.bytes(t.Data)),s.lengthDelimited!==!1&&n.ldelim()},(t,n)=>{let s={},o=n==null?t.len:t.pos+n;for(;t.pos<o;){let i=t.uint32();switch(i>>>3){case 1:s.Type=ue.codec().decode(t);break;case 2:s.Data=t.bytes();break;default:t.skipType(i&7);break}}return s})),e),r.encode=t=>Tt(t,r.codec()),r.decode=t=>Nt(t,r.codec())})(pt||(pt={}));var Sr=class{_key;constructor(e){this._key=rr(e,Qt)}verify(e,t){return Di(this._key,t,e)}marshal(){return this._key}get bytes(){return dt.encode({Type:ue.Ed25519,Data:this.marshal()}).subarray()}equals(e){return we(this.bytes,e.bytes)}hash(){let e=le.digest(this.bytes);return Se(e)?e.then(({bytes:t})=>t):e.bytes}},Lt=class{_key;_publicKey;constructor(e,t){this._key=rr(e,Ze),this._publicKey=rr(t,Qt)}sign(e){return Ui(this._key,e)}get public(){return new Sr(this._publicKey)}marshal(){return this._key}get bytes(){return pt.encode({Type:ue.Ed25519,Data:this.marshal()}).subarray()}equals(e){return we(this.bytes,e.bytes)}async hash(){let e=le.digest(this.bytes),t;return Se(e)?{bytes:t}=await e:t=e.bytes,t}async id(){let e=$e.digest(this.public.bytes);return ge.encode(e.bytes).substring(1)}async export(e,t="libp2p-key"){if(t==="libp2p-key")return er(this.bytes,e);throw new V(`export format '${t}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function rf(r){if(r.length>Ze){r=rr(r,Ze+Qt);let n=r.subarray(0,Ze),s=r.subarray(Ze,r.length);return new Lt(n,s)}r=rr(r,Ze);let e=r.subarray(0,Ze),t=r.subarray(Qt);return new Lt(e,t)}function nf(r){return r=rr(r,Qt),new Sr(r)}async function sf(){let{privateKey:r,publicKey:e}=Li();return new Lt(r,e)}async function Wi(r){let{privateKey:e,publicKey:t}=_i(r);return new Lt(e,t)}function rr(r,e){if(r=Uint8Array.from(r??[]),r.length!==e)throw new V(`Key must be a Uint8Array of length ${e}, got ${r.length}`,"ERR_INVALID_KEY_TYPE");return r}function ne(r,e="utf8"){let t=zr[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return t.encoder.encode(r).substring(1)}var Ao={};ie(Ao,{MAX_RSA_KEY_SIZE:()=>Hr,RsaPrivateKey:()=>ar,RsaPublicKey:()=>Or,fromJwk:()=>Lf,generateKeyPair:()=>_f,unmarshalRsaPrivateKey:()=>Bo,unmarshalRsaPublicKey:()=>Cf});function _t(r){if(isNaN(r)||r<=0)throw new V("random bytes length must be a Number bigger than 0","ERR_INVALID_LENGTH");return Zt(r)}var bt={};ie(bt,{exportToPem:()=>Sf,importFromPem:()=>If,jwkToPkcs1:()=>Bf,jwkToPkix:()=>Af,pkcs1ToJwk:()=>vf,pkixToJwk:()=>Ef});var ln=class extends zt{constructor(e,t){super(),this.finished=!1,this.destroyed=!1,Wr(e);let n=it(t);if(this.iHash=e.create(),typeof this.iHash.update!="function")throw new Error("Expected instance of class which extends utils.Hash");this.blockLen=this.iHash.blockLen,this.outputLen=this.iHash.outputLen;let s=this.blockLen,o=new Uint8Array(s);o.set(n.length>s?e.create().update(n).digest():n);for(let i=0;i<o.length;i++)o[i]^=54;this.iHash.update(o),this.oHash=e.create();for(let i=0;i<o.length;i++)o[i]^=106;this.oHash.update(o),o.fill(0)}update(e){return jt(this),this.iHash.update(e),this}digestInto(e){jt(this),Gt(e,this.outputLen),this.finished=!0,this.iHash.digestInto(e),this.oHash.update(e),this.oHash.digestInto(e),this.destroy()}digest(){let e=new Uint8Array(this.oHash.outputLen);return this.digestInto(e),e}_cloneInto(e){e||(e=Object.create(Object.getPrototypeOf(this),{}));let{oHash:t,iHash:n,finished:s,destroyed:o,blockLen:i,outputLen:a}=this;return e=e,e.finished=s,e.destroyed=o,e.blockLen=i,e.outputLen=a,e.oHash=t._cloneInto(e.oHash),e.iHash=n._cloneInto(e.iHash),e}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},Ir=(r,e,t)=>new ln(r,e).update(t).digest();Ir.create=(r,e)=>new ln(r,e);function of(r,e,t,n){Wr(r);let s=yi({dkLen:32,asyncTick:10},n),{c:o,dkLen:i,asyncTick:a}=s;if(qt(o),qt(i),qt(a),o<1)throw new Error("PBKDF2: iterations (c) should be >= 1");let c=it(e),f=it(t),u=new Uint8Array(i),l=Ir.create(r,c),p=l._cloneInto().update(f);return{c:o,dkLen:i,asyncTick:a,DK:u,PRF:l,PRFSalt:p}}function af(r,e,t,n,s){return r.destroy(),e.destroy(),n&&n.destroy(),s.fill(0),t}async function go(r,e,t,n){let{c:s,dkLen:o,asyncTick:i,DK:a,PRF:c,PRFSalt:f}=of(r,e,t,n),u,l=new Uint8Array(4),p=Wt(l),x=new Uint8Array(c.outputLen);for(let y=1,h=0;h<o;y++,h+=c.outputLen){let m=a.subarray(h,h+c.outputLen);p.setInt32(0,y,!1),(u=f._cloneInto(u)).update(l).digestInto(x),m.set(x.subarray(0,m.length)),await pi(s-1,i,()=>{c._cloneInto(u).update(x).digestInto(x);for(let v=0;v<m.length;v++)m[v]^=x[v]})}return af(c,f,a,u,x)}var O=Ic(Zi());function Ut(r,e){let t=0;if(r.length===1)return r[0];for(let n=r.length-1;n>=0;n--)t+=r[r.length-1-n]*Math.pow(2,e*n);return t}function gt(r,e,t=-1){let n=t,s=r,o=0,i=Math.pow(2,e);for(let a=1;a<8;a++){if(r<i){let c;if(n<0)c=new ArrayBuffer(a),o=a;else{if(n<a)return new ArrayBuffer(0);c=new ArrayBuffer(n),o=n}let f=new Uint8Array(c);for(let u=a-1;u>=0;u--){let l=Math.pow(2,u*e);f[o-u-1]=Math.floor(s/l),s-=f[o-u-1]*l}return c}i*=Math.pow(2,e)}return new ArrayBuffer(0)}function hn(...r){let e=0,t=0;for(let o of r)e+=o.length;let n=new ArrayBuffer(e),s=new Uint8Array(n);for(let o of r)s.set(o,t),t+=o.length;return s}function mo(){let r=new Uint8Array(this.valueHex);if(this.valueHex.byteLength>=2){let a=r[0]===255&&r[1]&128,c=r[0]===0&&(r[1]&128)===0;(a||c)&&this.warnings.push("Needlessly long format")}let e=new ArrayBuffer(this.valueHex.byteLength),t=new Uint8Array(e);for(let a=0;a<this.valueHex.byteLength;a++)t[a]=0;t[0]=r[0]&128;let n=Ut(t,8),s=new ArrayBuffer(this.valueHex.byteLength),o=new Uint8Array(s);for(let a=0;a<this.valueHex.byteLength;a++)o[a]=r[a];return o[0]&=127,Ut(o,8)-n}function Yi(r){let e=r<0?r*-1:r,t=128;for(let n=1;n<8;n++){if(e<=t){if(r<0){let i=t-e,a=gt(i,8,n),c=new Uint8Array(a);return c[0]|=128,a}let s=gt(e,8,n),o=new Uint8Array(s);if(o[0]&128){let i=s.slice(0),a=new Uint8Array(i);s=new ArrayBuffer(s.byteLength+1),o=new Uint8Array(s);for(let c=0;c<i.byteLength;c++)o[c+1]=a[c];o[0]=0}return s}t*=Math.pow(2,8)}return new ArrayBuffer(0)}function Ji(r,e){if(r.byteLength!==e.byteLength)return!1;let t=new Uint8Array(r),n=new Uint8Array(e);for(let s=0;s<t.length;s++)if(t[s]!==n[s])return!1;return!0}function Ee(r,e){let t=r.toString(10);if(e<t.length)return"";let n=e-t.length,s=new Array(n);for(let i=0;i<n;i++)s[i]="0";return s.join("").concat(t)}var up=Math.log(2);function dn(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function bo(r){let e=0,t=0;for(let s=0;s<r.length;s++){let o=r[s];e+=o.byteLength}let n=new Uint8Array(e);for(let s=0;s<r.length;s++){let o=r[s];n.set(new Uint8Array(o),t),t+=o.byteLength}return n.buffer}function tt(r,e,t,n){return e instanceof Uint8Array?e.byteLength?t<0?(r.error="Wrong parameter: inputOffset less than zero",!1):n<0?(r.error="Wrong parameter: inputLength less than zero",!1):e.byteLength-t-n<0?(r.error="End of input reached before message was fully decoded (inconsistent offset and length values)",!1):!0:(r.error="Wrong parameter: inputBuffer has zero length",!1):(r.error="Wrong parameter: inputBuffer must be 'Uint8Array'",!1)}var Rr=class{constructor(){this.items=[]}write(e){this.items.push(e)}final(){return bo(this.items)}},Nr=[new Uint8Array([1])],Xi="0123456789";var or="",De=new ArrayBuffer(0),wo=new Uint8Array(0),Tr="EndOfContent",ea="OCTET STRING",ta="BIT STRING";function rt(r){var e;return e=class extends r{constructor(...n){var s;super(...n);let o=n[0]||{};this.isHexOnly=(s=o.isHexOnly)!==null&&s!==void 0?s:!1,this.valueHexView=o.valueHex?O.BufferSourceConverter.toUint8Array(o.valueHex):wo}get valueHex(){return this.valueHexView.slice().buffer}set valueHex(n){this.valueHexView=new Uint8Array(n)}fromBER(n,s,o){let i=n instanceof ArrayBuffer?new Uint8Array(n):n;if(!tt(this,i,s,o))return-1;let a=s+o;return this.valueHexView=i.subarray(s,a),this.valueHexView.length?(this.blockLength=o,a):(this.warnings.push("Zero buffer length"),s)}toBER(n=!1){return this.isHexOnly?n?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.byteLength===this.valueHexView.buffer.byteLength?this.valueHexView.buffer:this.valueHexView.slice().buffer:(this.error="Flag 'isHexOnly' is not set, abort",De)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:O.Convert.ToHex(this.valueHexView)}}},e.NAME="hexBlock",e}var Xe=class{constructor({blockLength:e=0,error:t=or,warnings:n=[],valueBeforeDecode:s=wo}={}){this.blockLength=e,this.error=t,this.warnings=n,this.valueBeforeDecodeView=O.BufferSourceConverter.toUint8Array(s)}static blockName(){return this.NAME}get valueBeforeDecode(){return this.valueBeforeDecodeView.slice().buffer}set valueBeforeDecode(e){this.valueBeforeDecodeView=new Uint8Array(e)}toJSON(){return{blockName:this.constructor.NAME,blockLength:this.blockLength,error:this.error,warnings:this.warnings,valueBeforeDecode:O.Convert.ToHex(this.valueBeforeDecodeView)}}};Xe.NAME="baseBlock";var pe=class extends Xe{fromBER(e,t,n){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}toBER(e,t){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}};pe.NAME="valueBlock";var pn=class extends rt(Xe){constructor({idBlock:e={}}={}){var t,n,s,o;super(),e?(this.isHexOnly=(t=e.isHexOnly)!==null&&t!==void 0?t:!1,this.valueHexView=e.valueHex?O.BufferSourceConverter.toUint8Array(e.valueHex):wo,this.tagClass=(n=e.tagClass)!==null&&n!==void 0?n:-1,this.tagNumber=(s=e.tagNumber)!==null&&s!==void 0?s:-1,this.isConstructed=(o=e.isConstructed)!==null&&o!==void 0?o:!1):(this.tagClass=-1,this.tagNumber=-1,this.isConstructed=!1)}toBER(e=!1){let t=0;switch(this.tagClass){case 1:t|=0;break;case 2:t|=64;break;case 3:t|=128;break;case 4:t|=192;break;default:return this.error="Unknown tag class",De}if(this.isConstructed&&(t|=32),this.tagNumber<31&&!this.isHexOnly){let s=new Uint8Array(1);if(!e){let o=this.tagNumber;o&=31,t|=o,s[0]=t}return s.buffer}if(!this.isHexOnly){let s=gt(this.tagNumber,7),o=new Uint8Array(s),i=s.byteLength,a=new Uint8Array(i+1);if(a[0]=t|31,!e){for(let c=0;c<i-1;c++)a[c+1]=o[c]|128;a[i]=o[i-1]}return a.buffer}let n=new Uint8Array(this.valueHexView.byteLength+1);if(n[0]=t|31,!e){let s=this.valueHexView;for(let o=0;o<s.length-1;o++)n[o+1]=s[o]|128;n[this.valueHexView.byteLength]=s[s.length-1]}return n.buffer}fromBER(e,t,n){let s=O.BufferSourceConverter.toUint8Array(e);if(!tt(this,s,t,n))return-1;let o=s.subarray(t,t+n);if(o.length===0)return this.error="Zero buffer length",-1;switch(o[0]&192){case 0:this.tagClass=1;break;case 64:this.tagClass=2;break;case 128:this.tagClass=3;break;case 192:this.tagClass=4;break;default:return this.error="Unknown tag class",-1}this.isConstructed=(o[0]&32)===32,this.isHexOnly=!1;let a=o[0]&31;if(a!==31)this.tagNumber=a,this.blockLength=1;else{let c=1,f=this.valueHexView=new Uint8Array(255),u=255;for(;o[c]&128;){if(f[c-1]=o[c]&127,c++,c>=o.length)return this.error="End of input reached before message was fully decoded",-1;if(c===u){u+=255;let p=new Uint8Array(u);for(let x=0;x<f.length;x++)p[x]=f[x];f=this.valueHexView=new Uint8Array(u)}}this.blockLength=c+1,f[c-1]=o[c]&127;let l=new Uint8Array(c);for(let p=0;p<c;p++)l[p]=f[p];f=this.valueHexView=new Uint8Array(c),f.set(l),this.blockLength<=9?this.tagNumber=Ut(f,7):(this.isHexOnly=!0,this.warnings.push("Tag too long, represented as hex-coded"))}if(this.tagClass===1&&this.isConstructed)switch(this.tagNumber){case 1:case 2:case 5:case 6:case 9:case 13:case 14:case 23:case 24:case 31:case 32:case 33:case 34:return this.error="Constructed encoding used for primitive type",-1}return t+this.blockLength}toJSON(){return{...super.toJSON(),tagClass:this.tagClass,tagNumber:this.tagNumber,isConstructed:this.isConstructed}}};pn.NAME="identificationBlock";var gn=class extends Xe{constructor({lenBlock:e={}}={}){var t,n,s;super(),this.isIndefiniteForm=(t=e.isIndefiniteForm)!==null&&t!==void 0?t:!1,this.longFormUsed=(n=e.longFormUsed)!==null&&n!==void 0?n:!1,this.length=(s=e.length)!==null&&s!==void 0?s:0}fromBER(e,t,n){let s=O.BufferSourceConverter.toUint8Array(e);if(!tt(this,s,t,n))return-1;let o=s.subarray(t,t+n);if(o.length===0)return this.error="Zero buffer length",-1;if(o[0]===255)return this.error="Length block 0xFF is reserved by standard",-1;if(this.isIndefiniteForm=o[0]===128,this.isIndefiniteForm)return this.blockLength=1,t+this.blockLength;if(this.longFormUsed=!!(o[0]&128),this.longFormUsed===!1)return this.length=o[0],this.blockLength=1,t+this.blockLength;let i=o[0]&127;if(i>8)return this.error="Too big integer",-1;if(i+1>o.length)return this.error="End of input reached before message was fully decoded",-1;let a=t+1,c=s.subarray(a,a+i);return c[i-1]===0&&this.warnings.push("Needlessly long encoded length"),this.length=Ut(c,8),this.longFormUsed&&this.length<=127&&this.warnings.push("Unnecessary usage of long length form"),this.blockLength=i+1,t+this.blockLength}toBER(e=!1){let t,n;if(this.length>127&&(this.longFormUsed=!0),this.isIndefiniteForm)return t=new ArrayBuffer(1),e===!1&&(n=new Uint8Array(t),n[0]=128),t;if(this.longFormUsed){let s=gt(this.length,8);if(s.byteLength>127)return this.error="Too big length",De;if(t=new ArrayBuffer(s.byteLength+1),e)return t;let o=new Uint8Array(s);n=new Uint8Array(t),n[0]=s.byteLength|128;for(let i=0;i<s.byteLength;i++)n[i+1]=o[i];return t}return t=new ArrayBuffer(1),e===!1&&(n=new Uint8Array(t),n[0]=this.length),t}toJSON(){return{...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,longFormUsed:this.longFormUsed,length:this.length}}};gn.NAME="lengthBlock";var A={},fe=class extends Xe{constructor({name:e=or,optional:t=!1,primitiveSchema:n,...s}={},o){super(s),this.name=e,this.optional=t,n&&(this.primitiveSchema=n),this.idBlock=new pn(s),this.lenBlock=new gn(s),this.valueBlock=o?new o(s):new pe(s)}fromBER(e,t,n){let s=this.valueBlock.fromBER(e,t,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}toBER(e,t){let n=t||new Rr;t||ra(this);let s=this.idBlock.toBER(e);if(n.write(s),this.lenBlock.isIndefiniteForm)n.write(new Uint8Array([128]).buffer),this.valueBlock.toBER(e,n),n.write(new ArrayBuffer(2));else{let o=this.valueBlock.toBER(e);this.lenBlock.length=o.byteLength;let i=this.lenBlock.toBER(e);n.write(i),n.write(o)}return t?De:n.final()}toJSON(){let e={...super.toJSON(),idBlock:this.idBlock.toJSON(),lenBlock:this.lenBlock.toJSON(),valueBlock:this.valueBlock.toJSON(),name:this.name,optional:this.optional};return this.primitiveSchema&&(e.primitiveSchema=this.primitiveSchema.toJSON()),e}toString(e="ascii"){return e==="ascii"?this.onAsciiEncoding():O.Convert.ToHex(this.toBER())}onAsciiEncoding(){return`${this.constructor.NAME} : ${O.Convert.ToHex(this.valueBlock.valueBeforeDecodeView)}`}isEqual(e){if(this===e)return!0;if(!(e instanceof this.constructor))return!1;let t=this.toBER(),n=e.toBER();return Ji(t,n)}};fe.NAME="BaseBlock";function ra(r){if(r instanceof A.Constructed)for(let e of r.valueBlock.value)ra(e)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var yn=class extends fe{constructor({value:e=or,...t}={},n){super(t,n),e&&this.fromString(e)}getValue(){return this.valueBlock.value}setValue(e){this.valueBlock.value=e}fromBER(e,t,n){let s=this.valueBlock.fromBER(e,t,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.fromBuffer(this.valueBlock.valueHexView),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}onAsciiEncoding(){return`${this.constructor.NAME} : '${this.valueBlock.value}'`}};yn.NAME="BaseStringBlock";var mn=class extends rt(pe){constructor({isHexOnly:e=!0,...t}={}){super(t),this.isHexOnly=e}};mn.NAME="PrimitiveValueBlock";var na,bn=class extends fe{constructor(e={}){super(e,mn),this.idBlock.isConstructed=!1}};na=bn;A.Primitive=na;bn.NAME="PRIMITIVE";function yf(r,e){if(r instanceof e)return r;let t=new e;return t.idBlock=r.idBlock,t.lenBlock=r.lenBlock,t.warnings=r.warnings,t.valueBeforeDecodeView=r.valueBeforeDecodeView,t}function Jn(r,e=0,t=r.length){let n=e,s=new fe({},pe),o=new Xe;if(!tt(o,r,e,t))return s.error=o.error,{offset:-1,result:s};if(!r.subarray(e,e+t).length)return s.error="Zero buffer length",{offset:-1,result:s};let a=s.idBlock.fromBER(r,e,t);if(s.idBlock.warnings.length&&s.warnings.concat(s.idBlock.warnings),a===-1)return s.error=s.idBlock.error,{offset:-1,result:s};if(e=a,t-=s.idBlock.blockLength,a=s.lenBlock.fromBER(r,e,t),s.lenBlock.warnings.length&&s.warnings.concat(s.lenBlock.warnings),a===-1)return s.error=s.lenBlock.error,{offset:-1,result:s};if(e=a,t-=s.lenBlock.blockLength,!s.idBlock.isConstructed&&s.lenBlock.isIndefiniteForm)return s.error="Indefinite length form used for primitive encoding form",{offset:-1,result:s};let c=fe;switch(s.idBlock.tagClass){case 1:if(s.idBlock.tagNumber>=37&&s.idBlock.isHexOnly===!1)return s.error="UNIVERSAL 37 and upper tags are reserved by ASN.1 standard",{offset:-1,result:s};switch(s.idBlock.tagNumber){case 0:if(s.idBlock.isConstructed&&s.lenBlock.length>0)return s.error="Type [UNIVERSAL 0] is reserved",{offset:-1,result:s};c=A.EndOfContent;break;case 1:c=A.Boolean;break;case 2:c=A.Integer;break;case 3:c=A.BitString;break;case 4:c=A.OctetString;break;case 5:c=A.Null;break;case 6:c=A.ObjectIdentifier;break;case 10:c=A.Enumerated;break;case 12:c=A.Utf8String;break;case 13:c=A.RelativeObjectIdentifier;break;case 14:c=A.TIME;break;case 15:return s.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:s};case 16:c=A.Sequence;break;case 17:c=A.Set;break;case 18:c=A.NumericString;break;case 19:c=A.PrintableString;break;case 20:c=A.TeletexString;break;case 21:c=A.VideotexString;break;case 22:c=A.IA5String;break;case 23:c=A.UTCTime;break;case 24:c=A.GeneralizedTime;break;case 25:c=A.GraphicString;break;case 26:c=A.VisibleString;break;case 27:c=A.GeneralString;break;case 28:c=A.UniversalString;break;case 29:c=A.CharacterString;break;case 30:c=A.BmpString;break;case 31:c=A.DATE;break;case 32:c=A.TimeOfDay;break;case 33:c=A.DateTime;break;case 34:c=A.Duration;break;default:{let f=s.idBlock.isConstructed?new A.Constructed:new A.Primitive;f.idBlock=s.idBlock,f.lenBlock=s.lenBlock,f.warnings=s.warnings,s=f}}break;case 2:case 3:case 4:default:c=s.idBlock.isConstructed?A.Constructed:A.Primitive}return s=yf(s,c),a=s.fromBER(r,e,s.lenBlock.isIndefiniteForm?t:s.lenBlock.length),s.valueBeforeDecodeView=r.subarray(n,n+s.blockLength),{offset:a,result:s}}function ir(r){if(!r.byteLength){let e=new fe({},pe);return e.error="Input buffer has zero length",{offset:-1,result:e}}return Jn(O.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function mf(r,e){return r?1:e}var Pe=class extends pe{constructor({value:e=[],isIndefiniteForm:t=!1,...n}={}){super(n),this.value=e,this.isIndefiniteForm=t}fromBER(e,t,n){let s=O.BufferSourceConverter.toUint8Array(e);if(!tt(this,s,t,n))return-1;if(this.valueBeforeDecodeView=s.subarray(t,t+n),this.valueBeforeDecodeView.length===0)return this.warnings.push("Zero buffer length"),t;let o=t;for(;mf(this.isIndefiniteForm,n)>0;){let i=Jn(s,o,n);if(i.offset===-1)return this.error=i.result.error,this.warnings.concat(i.result.warnings),-1;if(o=i.offset,this.blockLength+=i.result.blockLength,n-=i.result.blockLength,this.value.push(i.result),this.isIndefiniteForm&&i.result.constructor.NAME===Tr)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===Tr?this.value.pop():this.warnings.push("No EndOfContent block encoded")),o}toBER(e,t){let n=t||new Rr;for(let s=0;s<this.value.length;s++)this.value[s].toBER(e,n);return t?De:n.final()}toJSON(){let e={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let t of this.value)e.value.push(t.toJSON());return e}};Pe.NAME="ConstructedValueBlock";var sa,yt=class extends fe{constructor(e={}){super(e,Pe),this.idBlock.isConstructed=!0}fromBER(e,t,n){this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm;let s=this.valueBlock.fromBER(e,t,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}onAsciiEncoding(){let e=[];for(let n of this.valueBlock.value)e.push(n.toString("ascii").split(`
|
|
3
|
+
`).map(s=>` ${s}`).join(`
|
|
4
|
+
`));let t=this.idBlock.tagClass===3?`[${this.idBlock.tagNumber}]`:this.constructor.NAME;return e.length?`${t} :
|
|
5
|
+
${e.join(`
|
|
6
|
+
`)}`:`${t} :`}};sa=yt;A.Constructed=sa;yt.NAME="CONSTRUCTED";var wn=class extends pe{fromBER(e,t,n){return t}toBER(e){return De}};wn.override="EndOfContentValueBlock";var oa,xn=class extends fe{constructor(e={}){super(e,wn),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};oa=xn;A.EndOfContent=oa;xn.NAME=Tr;var ia,mt=class extends fe{constructor(e={}){super(e,pe),this.idBlock.tagClass=1,this.idBlock.tagNumber=5}fromBER(e,t,n){return this.lenBlock.length>0&&this.warnings.push("Non-zero length of value block for Null type"),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.blockLength+=n,t+n>e.byteLength?(this.error="End of input reached before message was fully decoded (inconsistent offset and length values)",-1):t+n}toBER(e,t){let n=new ArrayBuffer(2);if(!e){let s=new Uint8Array(n);s[0]=5,s[1]=0}return t&&t.write(n),n}onAsciiEncoding(){return`${this.constructor.NAME}`}};ia=mt;A.Null=ia;mt.NAME="NULL";var vn=class extends rt(pe){constructor({value:e,...t}={}){super(t),t.valueHex?this.valueHexView=O.BufferSourceConverter.toUint8Array(t.valueHex):this.valueHexView=new Uint8Array(1),e&&(this.value=e)}get value(){for(let e of this.valueHexView)if(e>0)return!0;return!1}set value(e){this.valueHexView[0]=e?255:0}fromBER(e,t,n){let s=O.BufferSourceConverter.toUint8Array(e);return tt(this,s,t,n)?(this.valueHexView=s.subarray(t,t+n),n>1&&this.warnings.push("Boolean value encoded in more then 1 octet"),this.isHexOnly=!0,mo.call(this),this.blockLength=n,t+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};vn.NAME="BooleanValueBlock";var aa,Bn=class extends fe{constructor(e={}){super(e,vn),this.idBlock.tagClass=1,this.idBlock.tagNumber=1}getValue(){return this.valueBlock.value}setValue(e){this.valueBlock.value=e}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.getValue}`}};aa=Bn;A.Boolean=aa;Bn.NAME="BOOLEAN";var En=class extends rt(Pe){constructor({isConstructed:e=!1,...t}={}){super(t),this.isConstructed=e}fromBER(e,t,n){let s=0;if(this.isConstructed){if(this.isHexOnly=!1,s=Pe.prototype.fromBER.call(this,e,t,n),s===-1)return s;for(let o=0;o<this.value.length;o++){let i=this.value[o].constructor.NAME;if(i===Tr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(i!==ea)return this.error="OCTET STRING may consists of OCTET STRINGs only",-1}}else this.isHexOnly=!0,s=super.fromBER(e,t,n),this.blockLength=n;return s}toBER(e,t){return this.isConstructed?Pe.prototype.toBER.call(this,e,t):e?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};En.NAME="OctetStringValueBlock";var ca,Qe=class r extends fe{constructor({idBlock:e={},lenBlock:t={},...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,...e},lenBlock:{...t,isIndefiniteForm:!!n.isIndefiniteForm},...n},En),this.idBlock.tagClass=1,this.idBlock.tagNumber=4}fromBER(e,t,n){if(this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,n===0)return this.idBlock.error.length===0&&(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length===0&&(this.blockLength+=this.lenBlock.blockLength),t;if(!this.valueBlock.isConstructed){let o=(e instanceof ArrayBuffer?new Uint8Array(e):e).subarray(t,t+n);try{if(o.byteLength){let i=Jn(o,0,o.byteLength);i.offset!==-1&&i.offset===n&&(this.valueBlock.value=[i.result])}}catch{}}return super.fromBER(e,t,n)}onAsciiEncoding(){return this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length?yt.prototype.onAsciiEncoding.call(this):`${this.constructor.NAME} : ${O.Convert.ToHex(this.valueBlock.valueHexView)}`}getValue(){if(!this.idBlock.isConstructed)return this.valueBlock.valueHexView.slice().buffer;let e=[];for(let t of this.valueBlock.value)t instanceof r&&e.push(t.valueBlock.valueHexView);return O.BufferSourceConverter.concat(e)}};ca=Qe;A.OctetString=ca;Qe.NAME=ea;var An=class extends rt(Pe){constructor({unusedBits:e=0,isConstructed:t=!1,...n}={}){super(n),this.unusedBits=e,this.isConstructed=t,this.blockLength=this.valueHexView.byteLength}fromBER(e,t,n){if(!n)return t;let s=-1;if(this.isConstructed){if(s=Pe.prototype.fromBER.call(this,e,t,n),s===-1)return s;for(let a of this.value){let c=a.constructor.NAME;if(c===Tr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==ta)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=O.BufferSourceConverter.toUint8Array(e);if(!tt(this,o,t,n))return-1;let i=o.subarray(t,t+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=Jn(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,t+n}toBER(e,t){if(this.isConstructed)return Pe.prototype.toBER.call(this,e,t);if(e)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return De;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}}};An.NAME="BitStringValueBlock";var la,sr=class extends fe{constructor({idBlock:e={},lenBlock:t={},...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,...e},lenBlock:{...t,isIndefiniteForm:!!n.isIndefiniteForm},...n},An),this.idBlock.tagClass=1,this.idBlock.tagNumber=3}fromBER(e,t,n){return this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,super.fromBER(e,t,n)}onAsciiEncoding(){if(this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length)return yt.prototype.onAsciiEncoding.call(this);{let e=[],t=this.valueBlock.valueHexView;for(let s of t)e.push(s.toString(2).padStart(8,"0"));let n=e.join("");return`${this.constructor.NAME} : ${n.substring(0,n.length-this.valueBlock.unusedBits)}`}}};la=sr;A.BitString=la;sr.NAME=ta;var ua;function bf(r,e){let t=new Uint8Array([0]),n=new Uint8Array(r),s=new Uint8Array(e),o=n.slice(0),i=o.length-1,a=s.slice(0),c=a.length-1,f=0,u=c<i?i:c,l=0;for(let p=u;p>=0;p--,l++){switch(!0){case l<a.length:f=o[i-l]+a[c-l]+t[0];break;default:f=o[i-l]+t[0]}switch(t[0]=f/10,!0){case l>=o.length:o=hn(new Uint8Array([f%10]),o);break;default:o[i-l]=f%10}}return t[0]>0&&(o=hn(t,o)),o}function Qi(r){if(r>=Nr.length)for(let e=Nr.length;e<=r;e++){let t=new Uint8Array([0]),n=Nr[e-1].slice(0);for(let s=n.length-1;s>=0;s--){let o=new Uint8Array([(n[s]<<1)+t[0]]);t[0]=o[0]/10,n[s]=o[0]%10}t[0]>0&&(n=hn(t,n)),Nr.push(n)}return Nr[r]}function wf(r,e){let t=0,n=new Uint8Array(r),s=new Uint8Array(e),o=n.slice(0),i=o.length-1,a=s.slice(0),c=a.length-1,f,u=0;for(let l=c;l>=0;l--,u++)switch(f=o[i-u]-a[c-u]-t,!0){case f<0:t=1,o[i-u]=f+10;break;default:t=0,o[i-u]=f}if(t>0)for(let l=i-c+1;l>=0;l--,u++)if(f=o[i-u]-t,f<0)t=1,o[i-u]=f+10;else{t=0,o[i-u]=f;break}return o.slice()}var Cr=class extends rt(pe){constructor({value:e,...t}={}){super(t),this._valueDec=0,t.valueHex&&this.setValueHex(),e!==void 0&&(this.valueDec=e)}setValueHex(){this.valueHexView.length>=4?(this.warnings.push("Too big Integer for decoding, hex only"),this.isHexOnly=!0,this._valueDec=0):(this.isHexOnly=!1,this.valueHexView.length>0&&(this._valueDec=mo.call(this)))}set valueDec(e){this._valueDec=e,this.isHexOnly=!1,this.valueHexView=new Uint8Array(Yi(e))}get valueDec(){return this._valueDec}fromDER(e,t,n,s=0){let o=this.fromBER(e,t,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(e=!1){let t=this.valueHexView;switch(!0){case(t[0]&128)!==0:{let n=new Uint8Array(this.valueHexView.length+1);n[0]=0,n.set(t,1),this.valueHexView=n}break;case(t[0]===0&&(t[1]&128)===0):this.valueHexView=this.valueHexView.subarray(1);break}return this.toBER(e)}fromBER(e,t,n){let s=super.fromBER(e,t,n);return s===-1||this.setValueHex(),s}toBER(e){return e?new ArrayBuffer(this.valueHexView.length):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}toString(){let e=this.valueHexView.length*8-1,t=new Uint8Array(this.valueHexView.length*8/3),n=0,s,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 e:t=wf(Qi(n),t),i="-";break;default:t=bf(t,Qi(n))}n++,s>>=1}}for(let c=0;c<t.length;c++)t[c]&&(a=!0),a&&(i+=Xi.charAt(t[c]));return a===!1&&(i+=Xi.charAt(0)),i}};ua=Cr;Cr.NAME="IntegerValueBlock";Object.defineProperty(ua.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var fa,Q=class r extends fe{constructor(e={}){super(e,Cr),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return dn(),BigInt(this.valueBlock.toString())}static fromBigInt(e){dn();let t=BigInt(e),n=new Rr,s=t.toString(16).replace(/^-/,""),o=new Uint8Array(O.Convert.FromHex(s));if(t<0){let a=new Uint8Array(o.length+(o[0]&128?1:0));a[0]|=128;let f=BigInt(`0x${O.Convert.ToHex(a)}`)+t,u=O.BufferSourceConverter.toUint8Array(O.Convert.FromHex(f.toString(16)));u[0]|=128,n.write(u)}else o[0]&128&&n.write(new Uint8Array([0])),n.write(o);return new r({valueHex:n.final()})}convertToDER(){let e=new r({valueHex:this.valueBlock.valueHexView});return e.valueBlock.toDER(),e}convertFromDER(){return new r({valueHex:this.valueBlock.valueHexView[0]===0?this.valueBlock.valueHexView.subarray(1):this.valueBlock.valueHexView})}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()}`}};fa=Q;A.Integer=fa;Q.NAME="INTEGER";var ha,kn=class extends Q{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};ha=kn;A.Enumerated=ha;kn.NAME="ENUMERATED";var Lr=class extends rt(pe){constructor({valueDec:e=-1,isFirstSid:t=!1,...n}={}){super(n),this.valueDec=e,this.isFirstSid=t}fromBER(e,t,n){if(!n)return t;let s=O.BufferSourceConverter.toUint8Array(e);if(!tt(this,s,t,n))return-1;let o=s.subarray(t,t+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=Ut(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),t+this.blockLength)}set valueBigInt(e){dn();let t=BigInt(e).toString(2);for(;t.length%7;)t="0"+t;let n=new Uint8Array(t.length/7);for(let s=0;s<n.length;s++)n[s]=parseInt(t.slice(s*7,s*7+7),2)+(s+1<n.length?128:0);this.fromBER(n.buffer,0,n.length)}toBER(e){if(this.isHexOnly){if(e)return new ArrayBuffer(this.valueHexView.byteLength);let s=this.valueHexView,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 t=gt(this.valueDec,7);if(t.byteLength===0)return this.error="Error during encoding SID value",De;let n=new Uint8Array(t.byteLength);if(!e){let s=new Uint8Array(t),o=t.byteLength-1;for(let i=0;i<o;i++)n[i]=s[i]|128;n[o]=s[o]}return n}toString(){let e="";if(this.isHexOnly)e=O.Convert.ToHex(this.valueHexView);else if(this.isFirstSid){let t=this.valueDec;this.valueDec<=39?e="0.":this.valueDec<=79?(e="1.",t-=40):(e="2.",t-=80),e+=t.toString()}else e=this.valueDec.toString();return e}toJSON(){return{...super.toJSON(),valueDec:this.valueDec,isFirstSid:this.isFirstSid}}};Lr.NAME="sidBlock";var Sn=class extends pe{constructor({value:e=or,...t}={}){super(t),this.value=[],e&&this.fromString(e)}fromBER(e,t,n){let s=t;for(;n>0;){let o=new Lr;if(s=o.fromBER(e,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(e){let t=[];for(let n=0;n<this.value.length;n++){let s=this.value[n].toBER(e);if(s.byteLength===0)return this.error=this.value[n].error,De;t.push(s)}return bo(t)}fromString(e){this.value=[];let t=0,n=0,s="",o=!1;do if(n=e.indexOf(".",t),n===-1?s=e.substring(t):s=e.substring(t,n),t=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 Lr;if(s>Number.MAX_SAFE_INTEGER){dn();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 e="",t=!1;for(let n=0;n<this.value.length;n++){t=this.value[n].isHexOnly;let s=this.value[n].toString();n!==0&&(e=`${e}.`),t?(s=`{${s}}`,this.value[n].isFirstSid?e=`2.{${s} - 80}`:e+=s):e+=s}return e}toJSON(){let e={...super.toJSON(),value:this.toString(),sidArray:[]};for(let t=0;t<this.value.length;t++)e.sidArray.push(this.value[t].toJSON());return e}};Sn.NAME="ObjectIdentifierValueBlock";var da,Ue=class extends fe{constructor(e={}){super(e,Sn),this.idBlock.tagClass=1,this.idBlock.tagNumber=6}getValue(){return this.valueBlock.toString()}setValue(e){this.valueBlock.fromString(e)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};da=Ue;A.ObjectIdentifier=da;Ue.NAME="OBJECT IDENTIFIER";var _r=class extends rt(Xe){constructor({valueDec:e=0,...t}={}){super(t),this.valueDec=e}fromBER(e,t,n){if(n===0)return t;let s=O.BufferSourceConverter.toUint8Array(e);if(!tt(this,s,t,n))return-1;let o=s.subarray(t,t+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=Ut(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),t+this.blockLength)}toBER(e){if(this.isHexOnly){if(e)return new ArrayBuffer(this.valueHexView.byteLength);let s=this.valueHexView,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 t=gt(this.valueDec,7);if(t.byteLength===0)return this.error="Error during encoding SID value",De;let n=new Uint8Array(t.byteLength);if(!e){let s=new Uint8Array(t),o=t.byteLength-1;for(let i=0;i<o;i++)n[i]=s[i]|128;n[o]=s[o]}return n.buffer}toString(){let e="";return this.isHexOnly?e=O.Convert.ToHex(this.valueHexView):e=this.valueDec.toString(),e}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};_r.NAME="relativeSidBlock";var In=class extends pe{constructor({value:e=or,...t}={}){super(t),this.value=[],e&&this.fromString(e)}fromBER(e,t,n){let s=t;for(;n>0;){let o=new _r;if(s=o.fromBER(e,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(e,t){let n=[];for(let s=0;s<this.value.length;s++){let o=this.value[s].toBER(e);if(o.byteLength===0)return this.error=this.value[s].error,De;n.push(o)}return bo(n)}fromString(e){this.value=[];let t=0,n=0,s="";do{n=e.indexOf(".",t),n===-1?s=e.substring(t):s=e.substring(t,n),t=n+1;let o=new _r;if(o.valueDec=parseInt(s,10),isNaN(o.valueDec))return!0;this.value.push(o)}while(n!==-1);return!0}toString(){let e="",t=!1;for(let n=0;n<this.value.length;n++){t=this.value[n].isHexOnly;let s=this.value[n].toString();n!==0&&(e=`${e}.`),t&&(s=`{${s}}`),e+=s}return e}toJSON(){let e={...super.toJSON(),value:this.toString(),sidArray:[]};for(let t=0;t<this.value.length;t++)e.sidArray.push(this.value[t].toJSON());return e}};In.NAME="RelativeObjectIdentifierValueBlock";var pa,Nn=class extends fe{constructor(e={}){super(e,In),this.idBlock.tagClass=1,this.idBlock.tagNumber=13}getValue(){return this.valueBlock.toString()}setValue(e){this.valueBlock.fromString(e)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};pa=Nn;A.RelativeObjectIdentifier=pa;Nn.NAME="RelativeObjectIdentifier";var ga,ae=class extends yt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};ga=ae;A.Sequence=ga;ae.NAME="SEQUENCE";var ya,Rn=class extends yt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};ya=Rn;A.Set=ya;Rn.NAME="SET";var Tn=class extends rt(pe){constructor({...e}={}){super(e),this.isHexOnly=!0,this.value=or}toJSON(){return{...super.toJSON(),value:this.value}}};Tn.NAME="StringValueBlock";var Cn=class extends Tn{};Cn.NAME="SimpleStringValueBlock";var me=class extends yn{constructor({...e}={}){super(e,Cn)}fromBuffer(e){this.valueBlock.value=String.fromCharCode.apply(null,O.BufferSourceConverter.toUint8Array(e))}fromString(e){let t=e.length,n=this.valueBlock.valueHexView=new Uint8Array(t);for(let s=0;s<t;s++)n[s]=e.charCodeAt(s);this.valueBlock.value=e}};me.NAME="SIMPLE STRING";var Ln=class extends me{fromBuffer(e){this.valueBlock.valueHexView=O.BufferSourceConverter.toUint8Array(e);try{this.valueBlock.value=O.Convert.ToUtf8String(e)}catch(t){this.warnings.push(`Error during "decodeURIComponent": ${t}, using raw string`),this.valueBlock.value=O.Convert.ToBinary(e)}}fromString(e){this.valueBlock.valueHexView=new Uint8Array(O.Convert.FromUtf8String(e)),this.valueBlock.value=e}};Ln.NAME="Utf8StringValueBlock";var ma,et=class extends Ln{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};ma=et;A.Utf8String=ma;et.NAME="UTF8String";var _n=class extends me{fromBuffer(e){this.valueBlock.value=O.Convert.ToUtf16String(e),this.valueBlock.valueHexView=O.BufferSourceConverter.toUint8Array(e)}fromString(e){this.valueBlock.value=e,this.valueBlock.valueHexView=new Uint8Array(O.Convert.FromUtf16String(e))}};_n.NAME="BmpStringValueBlock";var ba,Un=class extends _n{constructor({...e}={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};ba=Un;A.BmpString=ba;Un.NAME="BMPString";var Dn=class extends me{fromBuffer(e){let t=ArrayBuffer.isView(e)?e.slice().buffer:e.slice(0),n=new Uint8Array(t);for(let s=0;s<n.length;s+=4)n[s]=n[s+3],n[s+1]=n[s+2],n[s+2]=0,n[s+3]=0;this.valueBlock.value=String.fromCharCode.apply(null,new Uint32Array(t))}fromString(e){let t=e.length,n=this.valueBlock.valueHexView=new Uint8Array(t*4);for(let s=0;s<t;s++){let o=gt(e.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=e}};Dn.NAME="UniversalStringValueBlock";var wa,Vn=class extends Dn{constructor({...e}={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};wa=Vn;A.UniversalString=wa;Vn.NAME="UniversalString";var xa,On=class extends me{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};xa=On;A.NumericString=xa;On.NAME="NumericString";var va,Hn=class extends me{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};va=Hn;A.PrintableString=va;Hn.NAME="PrintableString";var Ba,Pn=class extends me{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};Ba=Pn;A.TeletexString=Ba;Pn.NAME="TeletexString";var Ea,Mn=class extends me{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};Ea=Mn;A.VideotexString=Ea;Mn.NAME="VideotexString";var Aa,Kn=class extends me{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};Aa=Kn;A.IA5String=Aa;Kn.NAME="IA5String";var ka,Fn=class extends me{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};ka=Fn;A.GraphicString=ka;Fn.NAME="GraphicString";var Sa,Ur=class extends me{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};Sa=Ur;A.VisibleString=Sa;Ur.NAME="VisibleString";var Ia,$n=class extends me{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};Ia=$n;A.GeneralString=Ia;$n.NAME="GeneralString";var Na,qn=class extends me{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};Na=qn;A.CharacterString=Na;qn.NAME="CharacterString";var Ra,Dr=class extends Ur{constructor({value:e,valueDate:t,...n}={}){if(super(n),this.year=0,this.month=0,this.day=0,this.hour=0,this.minute=0,this.second=0,e){this.fromString(e),this.valueBlock.valueHexView=new Uint8Array(e.length);for(let s=0;s<e.length;s++)this.valueBlock.valueHexView[s]=e.charCodeAt(s)}t&&(this.fromDate(t),this.valueBlock.valueHexView=new Uint8Array(this.toBuffer())),this.idBlock.tagClass=1,this.idBlock.tagNumber=23}fromBuffer(e){this.fromString(String.fromCharCode.apply(null,O.BufferSourceConverter.toUint8Array(e)))}toBuffer(){let e=this.toString(),t=new ArrayBuffer(e.length),n=new Uint8Array(t);for(let s=0;s<e.length;s++)n[s]=e.charCodeAt(s);return t}fromDate(e){this.year=e.getUTCFullYear(),this.month=e.getUTCMonth()+1,this.day=e.getUTCDate(),this.hour=e.getUTCHours(),this.minute=e.getUTCMinutes(),this.second=e.getUTCSeconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second))}fromString(e){let n=/(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})Z/ig.exec(e);if(n===null){this.error="Wrong input string for conversion";return}let s=parseInt(n[1],10);s>=50?this.year=1900+s:this.year=2e3+s,this.month=parseInt(n[2],10),this.day=parseInt(n[3],10),this.hour=parseInt(n[4],10),this.minute=parseInt(n[5],10),this.second=parseInt(n[6],10)}toString(e="iso"){if(e==="iso"){let t=new Array(7);return t[0]=Ee(this.year<2e3?this.year-1900:this.year-2e3,2),t[1]=Ee(this.month,2),t[2]=Ee(this.day,2),t[3]=Ee(this.hour,2),t[4]=Ee(this.minute,2),t[5]=Ee(this.second,2),t[6]="Z",t.join("")}return super.toString(e)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.toDate().toISOString()}`}toJSON(){return{...super.toJSON(),year:this.year,month:this.month,day:this.day,hour:this.hour,minute:this.minute,second:this.second}}};Ra=Dr;A.UTCTime=Ra;Dr.NAME="UTCTime";var Ta,Gn=class extends Dr{constructor(e={}){var t;super(e),(t=this.millisecond)!==null&&t!==void 0||(this.millisecond=0),this.idBlock.tagClass=1,this.idBlock.tagNumber=24}fromDate(e){super.fromDate(e),this.millisecond=e.getUTCMilliseconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second,this.millisecond))}fromString(e){let t=!1,n="",s="",o=0,i,a=0,c=0;if(e[e.length-1]==="Z")n=e.substring(0,e.length-1),t=!0;else{let l=new Number(e[e.length-1]);if(isNaN(l.valueOf()))throw new Error("Wrong input string for conversion");n=e}if(t){if(n.indexOf("+")!==-1)throw new Error("Wrong input string for conversion");if(n.indexOf("-")!==-1)throw new Error("Wrong input string for conversion")}else{let l=1,p=n.indexOf("+"),x="";if(p===-1&&(p=n.indexOf("-"),l=-1),p!==-1){if(x=n.substring(p+1),n=n.substring(0,p),x.length!==2&&x.length!==4)throw new Error("Wrong input string for conversion");let y=parseInt(x.substring(0,2),10);if(isNaN(y.valueOf()))throw new Error("Wrong input string for conversion");if(a=l*y,x.length===4){if(y=parseInt(x.substring(2,4),10),isNaN(y.valueOf()))throw new Error("Wrong input string for conversion");c=l*y}}}let f=n.indexOf(".");if(f===-1&&(f=n.indexOf(",")),f!==-1){let l=new Number(`0${n.substring(f)}`);if(isNaN(l.valueOf()))throw new Error("Wrong input string for conversion");o=l.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 l=60*o;this.minute=Math.floor(l),l=60*(l-this.minute),this.second=Math.floor(l),l=1e3*(l-this.second),this.millisecond=Math.floor(l)}break;case s.length===12:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let l=60*o;this.second=Math.floor(l),l=1e3*(l-this.second),this.millisecond=Math.floor(l)}break;case s.length===14:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let l=1e3*o;this.millisecond=Math.floor(l)}break;default:throw new Error("Wrong input string for conversion")}let u=i.exec(s);if(u===null)throw new Error("Wrong input string for conversion");for(let l=1;l<u.length;l++)switch(l){case 1:this.year=parseInt(u[l],10);break;case 2:this.month=parseInt(u[l],10);break;case 3:this.day=parseInt(u[l],10);break;case 4:this.hour=parseInt(u[l],10)+a;break;case 5:this.minute=parseInt(u[l],10)+c;break;case 6:this.second=parseInt(u[l],10);break;default:throw new Error("Wrong input string for conversion")}if(t===!1){let l=new Date(this.year,this.month,this.day,this.hour,this.minute,this.second,this.millisecond);this.year=l.getUTCFullYear(),this.month=l.getUTCMonth(),this.day=l.getUTCDay(),this.hour=l.getUTCHours(),this.minute=l.getUTCMinutes(),this.second=l.getUTCSeconds(),this.millisecond=l.getUTCMilliseconds()}}toString(e="iso"){if(e==="iso"){let t=[];return t.push(Ee(this.year,4)),t.push(Ee(this.month,2)),t.push(Ee(this.day,2)),t.push(Ee(this.hour,2)),t.push(Ee(this.minute,2)),t.push(Ee(this.second,2)),this.millisecond!==0&&(t.push("."),t.push(Ee(this.millisecond,3))),t.push("Z"),t.join("")}return super.toString(e)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};Ta=Gn;A.GeneralizedTime=Ta;Gn.NAME="GeneralizedTime";var Ca,jn=class extends et{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};Ca=jn;A.DATE=Ca;jn.NAME="DATE";var La,zn=class extends et{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};La=zn;A.TimeOfDay=La;zn.NAME="TimeOfDay";var _a,Wn=class extends et{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};_a=Wn;A.DateTime=_a;Wn.NAME="DateTime";var Ua,Zn=class extends et{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};Ua=Zn;A.Duration=Ua;Zn.NAME="Duration";var Da,Yn=class extends et{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};Da=Yn;A.TIME=Da;Yn.NAME="TIME";function vf(r){let{result:e}=ir(r),t=e.valueBlock.value;return{n:ne(Me(t[1].toBigInt()),"base64url"),e:ne(Me(t[2].toBigInt()),"base64url"),d:ne(Me(t[3].toBigInt()),"base64url"),p:ne(Me(t[4].toBigInt()),"base64url"),q:ne(Me(t[5].toBigInt()),"base64url"),dp:ne(Me(t[6].toBigInt()),"base64url"),dq:ne(Me(t[7].toBigInt()),"base64url"),qi:ne(Me(t[8].toBigInt()),"base64url"),kty:"RSA",alg:"RS256"}}function Bf(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 V("JWK was missing components","ERR_INVALID_PARAMETERS");let t=new ae({value:[new Q({value:0}),Q.fromBigInt(Ke(G(r.n,"base64url"))),Q.fromBigInt(Ke(G(r.e,"base64url"))),Q.fromBigInt(Ke(G(r.d,"base64url"))),Q.fromBigInt(Ke(G(r.p,"base64url"))),Q.fromBigInt(Ke(G(r.q,"base64url"))),Q.fromBigInt(Ke(G(r.dp,"base64url"))),Q.fromBigInt(Ke(G(r.dq,"base64url"))),Q.fromBigInt(Ke(G(r.qi,"base64url")))]}).toBER();return new Uint8Array(t,0,t.byteLength)}function Ef(r){let{result:e}=ir(r),t=e.valueBlock.value[1].valueBlock.value[0].valueBlock.value;return{kty:"RSA",n:ne(Me(t[0].toBigInt()),"base64url"),e:ne(Me(t[1].toBigInt()),"base64url")}}function Af(r){if(r.n==null||r.e==null)throw new V("JWK was missing components","ERR_INVALID_PARAMETERS");let t=new ae({value:[new ae({value:[new Ue({value:"1.2.840.113549.1.1.1"}),new mt]}),new sr({valueHex:new ae({value:[Q.fromBigInt(Ke(G(r.n,"base64url"))),Q.fromBigInt(Ke(G(r.e,"base64url")))]}).toBER()})]}).toBER();return new Uint8Array(t,0,t.byteLength)}function Me(r){let e=r.toString(16);e.length%2>0&&(e=`0${e}`);let t=e.length/2,n=new Uint8Array(t),s=0,o=0;for(;s<t;)n[s]=parseInt(e.slice(o,o+2),16),s+=1,o+=2;return n}function Ke(r){let e=[];return r.forEach(function(t){let n=t.toString(16);n.length%2>0&&(n=`0${n}`),e.push(n)}),BigInt("0x"+e.join(""))}var kf=16,xo=32,vo=1e4;async function Sf(r,e){let t=ye.get(),s=new ae({value:[new Q({value:0}),new ae({value:[new Ue({value:"1.2.840.113549.1.1.1"}),new mt]}),new Qe({valueHex:r.marshal()})]}).toBER(),o=new Uint8Array(s,0,s.byteLength),i=_t(kf),a=await go(wr,e,i,{c:vo,dkLen:xo}),c=_t(16),f=await t.subtle.importKey("raw",a,"AES-CBC",!1,["encrypt"]),u=await t.subtle.encrypt({name:"AES-CBC",iv:c},f,o),l=new ae({value:[new Qe({valueHex:i}),new Q({value:vo}),new Q({value:xo}),new ae({value:[new Ue({value:"1.2.840.113549.2.11"}),new mt]})]}),p=new ae({value:[new Ue({value:"1.2.840.113549.1.5.13"}),new ae({value:[new ae({value:[new Ue({value:"1.2.840.113549.1.5.12"}),l]}),new ae({value:[new Ue({value:"2.16.840.1.101.3.4.1.42"}),new Qe({valueHex:c})]})]})]}),y=new ae({value:[p,new Qe({valueHex:u})]}).toBER(),h=new Uint8Array(y,0,y.byteLength);return["-----BEGIN ENCRYPTED PRIVATE KEY-----",...ne(h,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
|
|
7
|
+
`)}async function If(r,e){let t=ye.get(),n;if(r.includes("-----BEGIN ENCRYPTED PRIVATE KEY-----")){let s=G(r.replace("-----BEGIN ENCRYPTED PRIVATE KEY-----","").replace("-----END ENCRYPTED PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:o}=ir(s),{iv:i,salt:a,iterations:c,keySize:f,cipherText:u}=Nf(o),l=await go(wr,e,a,{c,dkLen:f}),p=await t.subtle.importKey("raw",l,"AES-CBC",!1,["decrypt"]),x=Vr(await t.subtle.decrypt({name:"AES-CBC",iv:i},p,u)),{result:y}=ir(x);n=Va(y)}else if(r.includes("-----BEGIN PRIVATE KEY-----")){let s=G(r.replace("-----BEGIN PRIVATE KEY-----","").replace("-----END PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:o}=ir(s);n=Va(o)}else throw new V("Could not parse private key from PEM data","ERR_INVALID_PARAMETERS");return Bo(n)}function Nf(r){let e=r.valueBlock.value[0];if(e.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.13")throw new V("Only pkcs5PBES2 encrypted private keys are supported","ERR_INVALID_PARAMS");let n=e.valueBlock.value[1].valueBlock.value[0];if(n.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.12")throw new V("Only pkcs5PBKDF2 key derivation functions are supported","ERR_INVALID_PARAMS");let o=n.valueBlock.value[1],i=Vr(o.valueBlock.value[0].getValue()),a=vo,c=xo;if(o.valueBlock.value.length===3)a=Number(o.valueBlock.value[1].toBigInt()),c=Number(o.valueBlock.value[2].toBigInt());else if(o.valueBlock.value.length===2)throw new V("Could not derive key size and iterations from PEM file - please use @libp2p/rsa to re-import your key","ERR_INVALID_PARAMS");let f=e.valueBlock.value[1].valueBlock.value[1],u=f.valueBlock.value[0].toString();if(u!=="OBJECT IDENTIFIER : 1.2.840.113549.3.7"){if(u!=="OBJECT IDENTIFIER : 1.3.14.3.2.7"){if(u!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.2"){if(u!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.22"){if(u!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.42")throw new V("Only AES-CBC encryption schemes are supported","ERR_INVALID_PARAMS")}}}}let l=Vr(f.valueBlock.value[1].getValue());return{cipherText:Vr(r.valueBlock.value[1].getValue()),salt:i,iterations:a,keySize:c,iv:l}}function Va(r){return Vr(r.valueBlock.value[2].getValue())}function Vr(r){return new Uint8Array(r,0,r.byteLength)}async function Oa(r){let e=await ye.get().subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:r,publicExponent:new Uint8Array([1,0,1]),hash:{name:"SHA-256"}},!0,["sign","verify"]),t=await Ma(e);return{privateKey:t[0],publicKey:t[1]}}async function Eo(r){let t=[await ye.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["sign"]),await Rf(r)],n=await Ma({privateKey:t[0],publicKey:t[1]});return{privateKey:n[0],publicKey:n[1]}}async function Ha(r,e){let t=await ye.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await ye.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},t,e instanceof Uint8Array?e:e.subarray());return new Uint8Array(n,0,n.byteLength)}async function Pa(r,e,t){let n=await ye.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return ye.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,e,t instanceof Uint8Array?t:t.subarray())}async function Ma(r){if(r.privateKey==null||r.publicKey==null)throw new V("Private and public key are required","ERR_INVALID_PARAMETERS");return Promise.all([ye.get().subtle.exportKey("jwk",r.privateKey),ye.get().subtle.exportKey("jwk",r.publicKey)])}async function Rf(r){return ye.get().subtle.importKey("jwk",{kty:r.kty,n:r.n,e:r.e},{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["verify"])}function Xn(r){if(r.kty!=="RSA")throw new V("invalid key type","ERR_INVALID_KEY_TYPE");if(r.n==null)throw new V("invalid key modulus","ERR_INVALID_KEY_MODULUS");return G(r.n,"base64url").length*8}var Hr=8192,Or=class{_key;constructor(e){this._key=e}verify(e,t){return Pa(this._key,t,e)}marshal(){return bt.jwkToPkix(this._key)}get bytes(){return dt.encode({Type:ue.RSA,Data:this.marshal()}).subarray()}equals(e){return we(this.bytes,e.bytes)}hash(){let e=le.digest(this.bytes);return Se(e)?e.then(({bytes:t})=>t):e.bytes}},ar=class{_key;_publicKey;constructor(e,t){this._key=e,this._publicKey=t}genSecret(){return _t(16)}sign(e){return Ha(this._key,e)}get public(){if(this._publicKey==null)throw new V("public key not provided","ERR_PUBKEY_NOT_PROVIDED");return new Or(this._publicKey)}marshal(){return bt.jwkToPkcs1(this._key)}get bytes(){return pt.encode({Type:ue.RSA,Data:this.marshal()}).subarray()}equals(e){return we(this.bytes,e.bytes)}hash(){let e=le.digest(this.bytes);return Se(e)?e.then(({bytes:t})=>t):e.bytes}async id(){let e=await this.public.hash();return ne(e,"base58btc")}async export(e,t="pkcs-8"){if(t==="pkcs-8")return bt.exportToPem(this,e);if(t==="libp2p-key")return er(this.bytes,e);throw new V(`export format '${t}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};async function Bo(r){let e=bt.pkcs1ToJwk(r);if(Xn(e)>Hr)throw new V("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await Eo(e);return new ar(t.privateKey,t.publicKey)}function Cf(r){let e=bt.pkixToJwk(r);if(Xn(e)>Hr)throw new V("key size is too large","ERR_KEY_SIZE_TOO_LARGE");return new Or(e)}async function Lf(r){if(Xn(r)>Hr)throw new V("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await Eo(r);return new ar(e.privateKey,e.publicKey)}async function _f(r){if(r>Hr)throw new V("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await Oa(r);return new ar(e.privateKey,e.publicKey)}var Ro={};ie(Ro,{Secp256k1PrivateKey:()=>Mr,Secp256k1PublicKey:()=>Pr,generateKeyPair:()=>jf,unmarshalSecp256k1PrivateKey:()=>qf,unmarshalSecp256k1PublicKey:()=>Gf});var Uf=new Uint32Array([1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298]),wt=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),xt=new Uint32Array(64),ko=class extends Yt{constructor(){super(64,32,8,!1),this.A=wt[0]|0,this.B=wt[1]|0,this.C=wt[2]|0,this.D=wt[3]|0,this.E=wt[4]|0,this.F=wt[5]|0,this.G=wt[6]|0,this.H=wt[7]|0}get(){let{A:e,B:t,C:n,D:s,E:o,F:i,G:a,H:c}=this;return[e,t,n,s,o,i,a,c]}set(e,t,n,s,o,i,a,c){this.A=e|0,this.B=t|0,this.C=n|0,this.D=s|0,this.E=o|0,this.F=i|0,this.G=a|0,this.H=c|0}process(e,t){for(let l=0;l<16;l++,t+=4)xt[l]=e.getUint32(t,!1);for(let l=16;l<64;l++){let p=xt[l-15],x=xt[l-2],y=Te(p,7)^Te(p,18)^p>>>3,h=Te(x,17)^Te(x,19)^x>>>10;xt[l]=h+xt[l-7]+y+xt[l-16]|0}let{A:n,B:s,C:o,D:i,E:a,F:c,G:f,H:u}=this;for(let l=0;l<64;l++){let p=Te(a,6)^Te(a,11)^Te(a,25),x=u+p+mi(a,c,f)+Uf[l]+xt[l]|0,h=(Te(n,2)^Te(n,13)^Te(n,22))+bi(n,s,o)|0;u=f,f=c,c=a,a=i+x|0,i=o,o=s,s=n,n=x+h|0}n=n+this.A|0,s=s+this.B|0,o=o+this.C|0,i=i+this.D|0,a=a+this.E|0,c=c+this.F|0,f=f+this.G|0,u=u+this.H|0,this.set(n,s,o,i,a,c,f,u)}roundClean(){xt.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var Ka=Yr(()=>new ko);function Fa(r){r.lowS!==void 0&&Ce("lowS",r.lowS),r.prehash!==void 0&&Ce("prehash",r.prehash)}function Df(r){let e=Br(r);He(e,{a:"field",b:"field"},{allowedPrivateKeyLengths:"array",wrapPrivateKey:"boolean",isTorsionFree:"function",clearCofactor:"function",allowInfinityPoint:"boolean",fromBytes:"function",toBytes:"function"});let{endo:t,Fp:n,a:s}=e;if(t){if(!n.eql(s,n.ZERO))throw new Error("Endomorphism can only be defined for Koblitz curves that have a=0");if(typeof t!="object"||typeof t.beta!="bigint"||typeof t.splitScalar!="function")throw new Error("Expected endomorphism with beta: bigint and splitScalar: function")}return Object.freeze({...e})}var{bytesToNumberBE:Vf,hexToBytes:Of}=Qr,Dt={Err:class extends Error{constructor(e=""){super(e)}},_parseInt(r){let{Err:e}=Dt;if(r.length<2||r[0]!==2)throw new e("Invalid signature integer tag");let t=r[1],n=r.subarray(2,t+2);if(!t||n.length!==t)throw new e("Invalid signature integer: wrong length");if(n[0]&128)throw new e("Invalid signature integer: negative");if(n[0]===0&&!(n[1]&128))throw new e("Invalid signature integer: unnecessary leading zero");return{d:Vf(n),l:r.subarray(t+2)}},toSig(r){let{Err:e}=Dt,t=typeof r=="string"?Of(r):r;Jt(t);let n=t.length;if(n<2||t[0]!=48)throw new e("Invalid signature tag");if(t[1]!==n-2)throw new e("Invalid signature: incorrect length");let{d:s,l:o}=Dt._parseInt(t.subarray(2)),{d:i,l:a}=Dt._parseInt(o);if(a.length)throw new e("Invalid signature: left bytes after parsing");return{r:s,s:i}},hexFromSig(r){let e=f=>Number.parseInt(f[0],16)&8?"00"+f:f,t=f=>{let u=f.toString(16);return u.length&1?`0${u}`:u},n=e(t(r.s)),s=e(t(r.r)),o=n.length/2,i=s.length/2,a=t(o),c=t(i);return`30${t(i+o+4)}02${c}${s}02${a}${n}`}},vt=BigInt(0),ce=BigInt(1),Vp=BigInt(2),$a=BigInt(3),Op=BigInt(4);function Hf(r){let e=Df(r),{Fp:t}=e,n=e.toBytes||((y,h,m)=>{let v=h.toAffine();return We(Uint8Array.from([4]),t.toBytes(v.x),t.toBytes(v.y))}),s=e.fromBytes||(y=>{let h=y.subarray(1),m=t.fromBytes(h.subarray(0,t.BYTES)),v=t.fromBytes(h.subarray(t.BYTES,2*t.BYTES));return{x:m,y:v}});function o(y){let{a:h,b:m}=e,v=t.sqr(y),b=t.mul(v,y);return t.add(t.add(b,t.mul(y,h)),m)}if(!t.eql(t.sqr(e.Gy),o(e.Gx)))throw new Error("bad generator point: equation left != right");function i(y){return xr(y,ce,e.n)}function a(y){let{allowedPrivateKeyLengths:h,nByteLength:m,wrapPrivateKey:v,n:b}=e;if(h&&typeof y!="bigint"){if(lt(y)&&(y=je(y)),typeof y!="string"||!h.includes(y.length))throw new Error("Invalid key");y=y.padStart(m*2,"0")}let w;try{w=typeof y=="bigint"?y:ze(J("private key",y,m))}catch{throw new Error(`private key must be ${m} bytes, hex or bigint, not ${typeof y}`)}return v&&(w=q(w,b)),ve("private key",w,ce,b),w}function c(y){if(!(y instanceof l))throw new Error("ProjectivePoint expected")}let f=kt((y,h)=>{let{px:m,py:v,pz:b}=y;if(t.eql(b,t.ONE))return{x:m,y:v};let w=y.is0();h==null&&(h=w?t.ONE:t.inv(b));let T=t.mul(m,h),S=t.mul(v,h),k=t.mul(b,h);if(w)return{x:t.ZERO,y:t.ZERO};if(!t.eql(k,t.ONE))throw new Error("invZ was invalid");return{x:T,y:S}}),u=kt(y=>{if(y.is0()){if(e.allowInfinityPoint&&!t.is0(y.py))return;throw new Error("bad point: ZERO")}let{x:h,y:m}=y.toAffine();if(!t.isValid(h)||!t.isValid(m))throw new Error("bad point: x or y not FE");let v=t.sqr(m),b=o(h);if(!t.eql(v,b))throw new Error("bad point: equation left != right");if(!y.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});class l{constructor(h,m,v){if(this.px=h,this.py=m,this.pz=v,h==null||!t.isValid(h))throw new Error("x required");if(m==null||!t.isValid(m))throw new Error("y required");if(v==null||!t.isValid(v))throw new Error("z required");Object.freeze(this)}static fromAffine(h){let{x:m,y:v}=h||{};if(!h||!t.isValid(m)||!t.isValid(v))throw new Error("invalid affine point");if(h instanceof l)throw new Error("projective point not allowed");let b=w=>t.eql(w,t.ZERO);return b(m)&&b(v)?l.ZERO:new l(m,v,t.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(h){let m=t.invertBatch(h.map(v=>v.pz));return h.map((v,b)=>v.toAffine(m[b])).map(l.fromAffine)}static fromHex(h){let m=l.fromAffine(s(J("pointHex",h)));return m.assertValidity(),m}static fromPrivateKey(h){return l.BASE.multiply(a(h))}_setWindowSize(h){x.setWindowSize(this,h)}assertValidity(){u(this)}hasEvenY(){let{y:h}=this.toAffine();if(t.isOdd)return!t.isOdd(h);throw new Error("Field doesn't support isOdd")}equals(h){c(h);let{px:m,py:v,pz:b}=this,{px:w,py:T,pz:S}=h,k=t.eql(t.mul(m,S),t.mul(w,b)),R=t.eql(t.mul(v,S),t.mul(T,b));return k&&R}negate(){return new l(this.px,t.neg(this.py),this.pz)}double(){let{a:h,b:m}=e,v=t.mul(m,$a),{px:b,py:w,pz:T}=this,S=t.ZERO,k=t.ZERO,R=t.ZERO,I=t.mul(b,b),$=t.mul(w,w),H=t.mul(T,T),P=t.mul(b,w);return P=t.add(P,P),R=t.mul(b,T),R=t.add(R,R),S=t.mul(h,R),k=t.mul(v,H),k=t.add(S,k),S=t.sub($,k),k=t.add($,k),k=t.mul(S,k),S=t.mul(P,S),R=t.mul(v,R),H=t.mul(h,H),P=t.sub(I,H),P=t.mul(h,P),P=t.add(P,R),R=t.add(I,I),I=t.add(R,I),I=t.add(I,H),I=t.mul(I,P),k=t.add(k,I),H=t.mul(w,T),H=t.add(H,H),I=t.mul(H,P),S=t.sub(S,I),R=t.mul(H,$),R=t.add(R,R),R=t.add(R,R),new l(S,k,R)}add(h){c(h);let{px:m,py:v,pz:b}=this,{px:w,py:T,pz:S}=h,k=t.ZERO,R=t.ZERO,I=t.ZERO,$=e.a,H=t.mul(e.b,$a),P=t.mul(m,w),X=t.mul(v,T),ee=t.mul(b,S),N=t.add(m,v),g=t.add(w,T);N=t.mul(N,g),g=t.add(P,X),N=t.sub(N,g),g=t.add(m,b);let d=t.add(w,S);return g=t.mul(g,d),d=t.add(P,ee),g=t.sub(g,d),d=t.add(v,b),k=t.add(T,S),d=t.mul(d,k),k=t.add(X,ee),d=t.sub(d,k),I=t.mul($,g),k=t.mul(H,ee),I=t.add(k,I),k=t.sub(X,I),I=t.add(X,I),R=t.mul(k,I),X=t.add(P,P),X=t.add(X,P),ee=t.mul($,ee),g=t.mul(H,g),X=t.add(X,ee),ee=t.sub(P,ee),ee=t.mul($,ee),g=t.add(g,ee),P=t.mul(X,g),R=t.add(R,P),P=t.mul(d,g),k=t.mul(N,k),k=t.sub(k,P),P=t.mul(N,X),I=t.mul(d,I),I=t.add(I,P),new l(k,R,I)}subtract(h){return this.add(h.negate())}is0(){return this.equals(l.ZERO)}wNAF(h){return x.wNAFCached(this,h,l.normalizeZ)}multiplyUnsafe(h){ve("scalar",h,vt,e.n);let m=l.ZERO;if(h===vt)return m;if(h===ce)return this;let{endo:v}=e;if(!v)return x.unsafeLadder(this,h);let{k1neg:b,k1:w,k2neg:T,k2:S}=v.splitScalar(h),k=m,R=m,I=this;for(;w>vt||S>vt;)w&ce&&(k=k.add(I)),S&ce&&(R=R.add(I)),I=I.double(),w>>=ce,S>>=ce;return b&&(k=k.negate()),T&&(R=R.negate()),R=new l(t.mul(R.px,v.beta),R.py,R.pz),k.add(R)}multiply(h){let{endo:m,n:v}=e;ve("scalar",h,ce,v);let b,w;if(m){let{k1neg:T,k1:S,k2neg:k,k2:R}=m.splitScalar(h),{p:I,f:$}=this.wNAF(S),{p:H,f:P}=this.wNAF(R);I=x.constTimeNegate(T,I),H=x.constTimeNegate(k,H),H=new l(t.mul(H.px,m.beta),H.py,H.pz),b=I.add(H),w=$.add(P)}else{let{p:T,f:S}=this.wNAF(h);b=T,w=S}return l.normalizeZ([b,w])[0]}multiplyAndAddUnsafe(h,m,v){let b=l.BASE,w=(S,k)=>k===vt||k===ce||!S.equals(b)?S.multiplyUnsafe(k):S.multiply(k),T=w(this,m).add(w(h,v));return T.is0()?void 0:T}toAffine(h){return f(this,h)}isTorsionFree(){let{h,isTorsionFree:m}=e;if(h===ce)return!0;if(m)return m(l,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h,clearCofactor:m}=e;return h===ce?this:m?m(l,this):this.multiplyUnsafe(e.h)}toRawBytes(h=!0){return Ce("isCompressed",h),this.assertValidity(),n(l,this,h)}toHex(h=!0){return Ce("isCompressed",h),je(this.toRawBytes(h))}}l.BASE=new l(e.Gx,e.Gy,t.ONE),l.ZERO=new l(t.ZERO,t.ONE,t.ZERO);let p=e.nBitLength,x=rn(l,e.endo?Math.ceil(p/2):p);return{CURVE:e,ProjectivePoint:l,normPrivateKeyToScalar:a,weierstrassEquation:o,isWithinCurveOrder:i}}function Pf(r){let e=Br(r);return He(e,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...e})}function qa(r){let e=Pf(r),{Fp:t,n}=e,s=t.BYTES+1,o=2*t.BYTES+1;function i(N){return q(N,n)}function a(N){return en(N,n)}let{ProjectivePoint:c,normPrivateKeyToScalar:f,weierstrassEquation:u,isWithinCurveOrder:l}=Hf({...e,toBytes(N,g,d){let B=g.toAffine(),E=t.toBytes(B.x),C=We;return Ce("isCompressed",d),d?C(Uint8Array.from([g.hasEvenY()?2:3]),E):C(Uint8Array.from([4]),E,t.toBytes(B.y))},fromBytes(N){let g=N.length,d=N[0],B=N.subarray(1);if(g===s&&(d===2||d===3)){let E=ze(B);if(!xr(E,ce,t.ORDER))throw new Error("Point is not on curve");let C=u(E),L;try{L=t.sqrt(C)}catch(D){let K=D instanceof Error?": "+D.message:"";throw new Error("Point is not on curve"+K)}let _=(L&ce)===ce;return(d&1)===1!==_&&(L=t.neg(L)),{x:E,y:L}}else if(g===o&&d===4){let E=t.fromBytes(B.subarray(0,t.BYTES)),C=t.fromBytes(B.subarray(t.BYTES,2*t.BYTES));return{x:E,y:C}}else throw new Error(`Point of length ${g} was invalid. Expected ${s} compressed bytes or ${o} uncompressed bytes`)}}),p=N=>je(ft(N,e.nByteLength));function x(N){let g=n>>ce;return N>g}function y(N){return x(N)?i(-N):N}let h=(N,g,d)=>ze(N.slice(g,d));class m{constructor(g,d,B){this.r=g,this.s=d,this.recovery=B,this.assertValidity()}static fromCompact(g){let d=e.nByteLength;return g=J("compactSignature",g,d*2),new m(h(g,0,d),h(g,d,2*d))}static fromDER(g){let{r:d,s:B}=Dt.toSig(J("DER",g));return new m(d,B)}assertValidity(){ve("r",this.r,ce,n),ve("s",this.s,ce,n)}addRecoveryBit(g){return new m(this.r,this.s,g)}recoverPublicKey(g){let{r:d,s:B,recovery:E}=this,C=k(J("msgHash",g));if(E==null||![0,1,2,3].includes(E))throw new Error("recovery id invalid");let L=E===2||E===3?d+e.n:d;if(L>=t.ORDER)throw new Error("recovery id 2 or 3 invalid");let _=E&1?"03":"02",M=c.fromHex(_+p(L)),D=a(L),K=i(-C*D),W=i(B*D),Z=c.BASE.multiplyAndAddUnsafe(M,K,W);if(!Z)throw new Error("point at infinify");return Z.assertValidity(),Z}hasHighS(){return x(this.s)}normalizeS(){return this.hasHighS()?new m(this.r,i(-this.s),this.recovery):this}toDERRawBytes(){return Et(this.toDERHex())}toDERHex(){return Dt.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return Et(this.toCompactHex())}toCompactHex(){return p(this.r)+p(this.s)}}let v={isValidPrivateKey(N){try{return f(N),!0}catch{return!1}},normPrivateKeyToScalar:f,randomPrivateKey:()=>{let N=$s(e.n);return Ii(e.randomBytes(N),e.n)},precompute(N=8,g=c.BASE){return g._setWindowSize(N),g.multiply(BigInt(3)),g}};function b(N,g=!0){return c.fromPrivateKey(N).toRawBytes(g)}function w(N){let g=lt(N),d=typeof N=="string",B=(g||d)&&N.length;return g?B===s||B===o:d?B===2*s||B===2*o:N instanceof c}function T(N,g,d=!0){if(w(N))throw new Error("first arg must be private key");if(!w(g))throw new Error("second arg must be public key");return c.fromHex(g).multiply(f(N)).toRawBytes(d)}let S=e.bits2int||function(N){let g=ze(N),d=N.length*8-e.nBitLength;return d>0?g>>BigInt(d):g},k=e.bits2int_modN||function(N){return i(S(N))},R=vr(e.nBitLength);function I(N){return ve(`num < 2^${e.nBitLength}`,N,vt,R),ft(N,e.nByteLength)}function $(N,g,d=H){if(["recovered","canonical"].some(se=>se in d))throw new Error("sign() legacy options not supported");let{hash:B,randomBytes:E}=e,{lowS:C,prehash:L,extraEntropy:_}=d;C==null&&(C=!0),N=J("msgHash",N),Fa(d),L&&(N=J("prehashed msgHash",B(N)));let M=k(N),D=f(g),K=[I(D),I(M)];if(_!=null&&_!==!1){let se=_===!0?E(t.BYTES):_;K.push(J("extraEntropy",se))}let W=We(...K),Z=M;function be(se){let te=S(se);if(!l(te))return;let Ne=a(te),oe=c.BASE.multiply(te).toAffine(),Re=i(oe.x);if(Re===vt)return;let Bt=i(Ne*i(Z+Re*D));if(Bt===vt)return;let pr=(oe.x===Re?0:2)|Number(oe.y&ce),Fr=Bt;return C&&x(Bt)&&(Fr=y(Bt),pr^=1),new m(Re,Fr,pr)}return{seed:W,k2sig:be}}let H={lowS:e.lowS,prehash:!1},P={lowS:e.lowS,prehash:!1};function X(N,g,d=H){let{seed:B,k2sig:E}=$(N,g,d),C=e;return Ps(C.hash.outputLen,C.nByteLength,C.hmac)(B,E)}c.BASE._setWindowSize(8);function ee(N,g,d,B=P){let E=N;if(g=J("msgHash",g),d=J("publicKey",d),"strict"in B)throw new Error("options.strict was renamed to lowS");Fa(B);let{lowS:C,prehash:L}=B,_,M;try{if(typeof E=="string"||lt(E))try{_=m.fromDER(E)}catch(oe){if(!(oe instanceof Dt.Err))throw oe;_=m.fromCompact(E)}else if(typeof E=="object"&&typeof E.r=="bigint"&&typeof E.s=="bigint"){let{r:oe,s:Re}=E;_=new m(oe,Re)}else throw new Error("PARSE");M=c.fromHex(d)}catch(oe){if(oe.message==="PARSE")throw new Error("signature must be Signature instance, Uint8Array or hex string");return!1}if(C&&_.hasHighS())return!1;L&&(g=e.hash(g));let{r:D,s:K}=_,W=k(g),Z=a(K),be=i(W*Z),se=i(D*Z),te=c.BASE.multiplyAndAddUnsafe(M,be,se)?.toAffine();return te?i(te.x)===D:!1}return{CURVE:e,getPublicKey:b,getSharedSecret:T,sign:X,verify:ee,ProjectivePoint:c,Signature:m,utils:v}}function Mf(r){return{hash:r,hmac:(e,...t)=>Ir(r,e,Ls(...t)),randomBytes:Zt}}function Ga(r,e){let t=n=>qa({...r,...Mf(n)});return Object.freeze({...t(e),create:t})}var Wa=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),ja=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),Kf=BigInt(1),So=BigInt(2),za=(r,e)=>(r+e/So)/e;function Ff(r){let e=Wa,t=BigInt(3),n=BigInt(6),s=BigInt(11),o=BigInt(22),i=BigInt(23),a=BigInt(44),c=BigInt(88),f=r*r*r%e,u=f*f*r%e,l=z(u,t,e)*u%e,p=z(l,t,e)*u%e,x=z(p,So,e)*f%e,y=z(x,s,e)*x%e,h=z(y,o,e)*y%e,m=z(h,a,e)*h%e,v=z(m,c,e)*m%e,b=z(v,a,e)*h%e,w=z(b,t,e)*u%e,T=z(w,i,e)*y%e,S=z(T,n,e)*f%e,k=z(S,So,e);if(!Io.eql(Io.sqr(k),r))throw new Error("Cannot find square root");return k}var Io=tn(Wa,void 0,void 0,{sqrt:Ff}),Ve=Ga({a:BigInt(0),b:BigInt(7),Fp:Io,n:ja,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let e=ja,t=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-Kf*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),s=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),o=t,i=BigInt("0x100000000000000000000000000000000"),a=za(o*r,e),c=za(-n*r,e),f=q(r-a*t-c*s,e),u=q(-a*n-c*o,e),l=f>i,p=u>i;if(l&&(f=e-f),p&&(u=e-u),f>i||u>i)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:l,k1:f,k2neg:p,k2:u}}}},Ka),jp=BigInt(0);var zp=Ve.ProjectivePoint;function Za(){return Ve.utils.randomPrivateKey()}function Ya(r,e){let t=le.digest(e instanceof Uint8Array?e:e.subarray());if(Se(t))return t.then(({digest:n})=>Ve.sign(n,r).toDERRawBytes()).catch(n=>{throw new V(String(n),"ERR_INVALID_INPUT")});try{return Ve.sign(t.digest,r).toDERRawBytes()}catch(n){throw new V(String(n),"ERR_INVALID_INPUT")}}function Ja(r,e,t){let n=le.digest(t instanceof Uint8Array?t:t.subarray());if(Se(n))return n.then(({digest:s})=>Ve.verify(e,s,r)).catch(s=>{throw new V(String(s),"ERR_INVALID_INPUT")});try{return Ve.verify(e,n.digest,r)}catch(s){throw new V(String(s),"ERR_INVALID_INPUT")}}function Xa(r){return Ve.ProjectivePoint.fromHex(r).toRawBytes(!0)}function Qa(r){try{Ve.getPublicKey(r,!0)}catch(e){throw new V(String(e),"ERR_INVALID_PRIVATE_KEY")}}function No(r){try{Ve.ProjectivePoint.fromHex(r)}catch(e){throw new V(String(e),"ERR_INVALID_PUBLIC_KEY")}}function ec(r){try{return Ve.getPublicKey(r,!0)}catch(e){throw new V(String(e),"ERR_INVALID_PRIVATE_KEY")}}var Pr=class{_key;constructor(e){No(e),this._key=e}verify(e,t){return Ja(this._key,t,e)}marshal(){return Xa(this._key)}get bytes(){return dt.encode({Type:ue.Secp256k1,Data:this.marshal()}).subarray()}equals(e){return we(this.bytes,e.bytes)}async hash(){let e=le.digest(this.bytes),t;return Se(e)?{bytes:t}=await e:t=e.bytes,t}},Mr=class{_key;_publicKey;constructor(e,t){this._key=e,this._publicKey=t??ec(e),Qa(this._key),No(this._publicKey)}sign(e){return Ya(this._key,e)}get public(){return new Pr(this._publicKey)}marshal(){return this._key}get bytes(){return pt.encode({Type:ue.Secp256k1,Data:this.marshal()}).subarray()}equals(e){return we(this.bytes,e.bytes)}hash(){let e=le.digest(this.bytes);return Se(e)?e.then(({bytes:t})=>t):e.bytes}async id(){let e=await this.public.hash();return ne(e,"base58btc")}async export(e,t="libp2p-key"){if(t==="libp2p-key")return er(this.bytes,e);throw new V(`export format '${t}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function qf(r){return new Mr(r)}function Gf(r){return new Pr(r)}async function jf(){let r=Za();return new Mr(r)}var cr={rsa:Ao,ed25519:po,secp256k1:Ro};function zf(r){let e=Object.keys(cr).join(" / ");return new V(`invalid or unsupported key type ${r}. Must be ${e}`,"ERR_UNSUPPORTED_KEY_TYPE")}function Wf(r){if(r=r.toLowerCase(),r==="rsa"||r==="ed25519"||r==="secp256k1")return cr[r];throw zf(r)}function tc(r,e){return e=(e??"rsa").toLowerCase(),Wf(e),r.bytes}var nc=Symbol.for("nodejs.util.inspect.custom"),rc=Object.values($t).map(r=>r.decoder).reduce((r,e)=>r.or(e),$t.identity.decoder),sc=114,Lo=36,_o=37,Kr=class{type;multihash;privateKey;publicKey;string;constructor(e){this.type=e.type,this.multihash=e.multihash,this.privateKey=e.privateKey,Object.defineProperty(this,"string",{enumerable:!1,writable:!0})}get[Symbol.toStringTag](){return`PeerId(${this.toString()})`}[ls]=!0;toString(){return this.string==null&&(this.string=ge.encode(this.multihash.bytes).slice(1)),this.string}toCID(){return ot.createV1(sc,this.multihash)}toBytes(){return this.multihash.bytes}toJSON(){return this.toString()}equals(e){if(e==null)return!1;if(e instanceof Uint8Array)return we(this.multihash.bytes,e);if(typeof e=="string")return Zf(e).equals(this);if(e?.multihash?.bytes!=null)return we(this.multihash.bytes,e.multihash.bytes);throw new Error("not valid Id")}[nc](){return`PeerId(${this.toString()})`}},lr=class extends Kr{type="RSA";publicKey;constructor(e){super({...e,type:"RSA"}),this.publicKey=e.publicKey}},ur=class extends Kr{type="Ed25519";publicKey;constructor(e){super({...e,type:"Ed25519"}),this.publicKey=e.multihash.digest}},fr=class extends Kr{type="secp256k1";publicKey;constructor(e){super({...e,type:"secp256k1"}),this.publicKey=e.multihash.digest}},To=2336,Co=class{type="url";multihash;privateKey;publicKey;url;constructor(e){this.url=e.toString(),this.multihash=$e.digest(G(this.url))}[nc](){return`PeerId(${this.url})`}[ls]=!0;toString(){return this.toCID().toString()}toCID(){return ot.createV1(To,this.multihash)}toBytes(){return this.toCID().bytes}equals(e){return e==null?!1:(e instanceof Uint8Array&&(e=ne(e)),e.toString()===this.toString())}};function Zf(r,e){if(e=e??rc,r.charAt(0)==="1"||r.charAt(0)==="Q"){let t=mr(ge.decode(`z${r}`));return r.startsWith("12D")?new ur({multihash:t}):r.startsWith("16U")?new fr({multihash:t}):new lr({multihash:t})}return Qn(rc.decode(r))}function Qn(r){try{let e=mr(r);if(e.code===$e.code){if(e.digest.length===Lo)return new ur({multihash:e});if(e.digest.length===_o)return new fr({multihash:e})}if(e.code===le.code)return new lr({multihash:e})}catch{return Yf(ot.decode(r))}throw new Error("Supplied PeerID CID is invalid")}function Yf(r){if(r?.multihash==null||r.version==null||r.version===1&&r.code!==sc&&r.code!==To)throw new Error("Supplied PeerID CID is invalid");if(r.code===To){let t=ne(r.multihash.digest);return new Co(new URL(t))}let e=r.multihash;if(e.code===le.code)return new lr({multihash:r.multihash});if(e.code===$e.code){if(e.digest.length===Lo)return new ur({multihash:r.multihash});if(e.digest.length===_o)return new fr({multihash:r.multihash})}throw new Error("Supplied PeerID CID is invalid")}async function oc(r,e){return r.length===Lo?new ur({multihash:Oe($e.code,r),privateKey:e}):r.length===_o?new fr({multihash:Oe($e.code,r),privateKey:e}):new lr({multihash:await le.digest(r),publicKey:r,privateKey:e})}async function ic(r){return oc(tc(r))}function hr(){let r={};return r.promise=new Promise((e,t)=>{r.resolve=e,r.reject=t}),r}var es=class extends Error{type;code;constructor(e,t,n){super(e??"The operation was aborted"),this.type="aborted",this.name=n??"AbortError",this.code=t??"ABORT_ERR"}};async function ac(r,e,t){if(e==null)return r;if(e.aborted)return Promise.reject(new es(t?.errorMessage,t?.errorCode,t?.errorName));let n,s=new es(t?.errorMessage,t?.errorCode,t?.errorName);try{return await Promise.race([r,new Promise((o,i)=>{n=()=>{i(s)},e.addEventListener("abort",n)})])}finally{n!=null&&e.removeEventListener("abort",n)}}var Uo=class{readNext;haveNext;ended;nextResult;constructor(){this.ended=!1,this.readNext=hr(),this.haveNext=hr()}[Symbol.asyncIterator](){return this}async next(){if(this.nextResult==null&&await this.haveNext.promise,this.nextResult==null)throw new Error("HaveNext promise resolved but nextResult was undefined");let e=this.nextResult;return this.nextResult=void 0,this.readNext.resolve(),this.readNext=hr(),e}async throw(e){return this.ended=!0,e!=null&&(this.haveNext.promise.catch(()=>{}),this.haveNext.reject(e)),{done:!0,value:void 0}}async return(){let e={done:!0,value:void 0};return await this._push(void 0),e}async push(e,t){await this._push(e,t)}async end(e,t){e!=null?await this.throw(e):await this._push(void 0,t)}async _push(e,t){if(e!=null&&this.ended)throw new Error("Cannot push value onto an ended pushable");for(;this.nextResult!=null;)await this.readNext.promise;e!=null?this.nextResult={done:!1,value:e}:(this.ended=!0,this.nextResult={done:!0,value:void 0}),this.haveNext.resolve(),this.haveNext=hr(),await ac(this.readNext.promise,t?.signal,t)}};function cc(){return new Uo}var uc=Symbol.for("@achingbrain/uint8arraylist");function lc(r,e){if(e==null||e<0)throw new RangeError("index is out of bounds");let t=0;for(let n of r){let s=t+n.byteLength;if(e<s)return{buf:n,index:e-t};t=s}throw new RangeError("index is out of bounds")}function ts(r){return!!r?.[uc]}var nt=class r{bufs;length;[uc]=!0;constructor(...e){this.bufs=[],this.length=0,e.length>0&&this.appendAll(e)}*[Symbol.iterator](){yield*this.bufs}get byteLength(){return this.length}append(...e){this.appendAll(e)}appendAll(e){let t=0;for(let n of e)if(n instanceof Uint8Array)t+=n.byteLength,this.bufs.push(n);else if(ts(n))t+=n.byteLength,this.bufs.push(...n.bufs);else throw new Error("Could not append value, must be an Uint8Array or a Uint8ArrayList");this.length+=t}prepend(...e){this.prependAll(e)}prependAll(e){let t=0;for(let n of e.reverse())if(n instanceof Uint8Array)t+=n.byteLength,this.bufs.unshift(n);else if(ts(n))t+=n.byteLength,this.bufs.unshift(...n.bufs);else throw new Error("Could not prepend value, must be an Uint8Array or a Uint8ArrayList");this.length+=t}get(e){let t=lc(this.bufs,e);return t.buf[t.index]}set(e,t){let n=lc(this.bufs,e);n.buf[n.index]=t}write(e,t=0){if(e instanceof Uint8Array)for(let n=0;n<e.length;n++)this.set(t+n,e[n]);else if(ts(e))for(let n=0;n<e.length;n++)this.set(t+n,e.get(n));else throw new Error("Could not write value, must be an Uint8Array or a Uint8ArrayList")}consume(e){if(e=Math.trunc(e),!(Number.isNaN(e)||e<=0)){if(e===this.byteLength){this.bufs=[],this.length=0;return}for(;this.bufs.length>0;)if(e>=this.bufs[0].byteLength)e-=this.bufs[0].byteLength,this.length-=this.bufs[0].byteLength,this.bufs.shift();else{this.bufs[0]=this.bufs[0].subarray(e),this.length-=e;break}}}slice(e,t){let{bufs:n,length:s}=this._subList(e,t);return Kt(n,s)}subarray(e,t){let{bufs:n,length:s}=this._subList(e,t);return n.length===1?n[0]:Kt(n,s)}sublist(e,t){let{bufs:n,length:s}=this._subList(e,t),o=new r;return o.length=s,o.bufs=[...n],o}_subList(e,t){if(e=e??0,t=t??this.length,e<0&&(e=this.length+e),t<0&&(t=this.length+t),e<0||t>this.length)throw new RangeError("index is out of bounds");if(e===t)return{bufs:[],length:0};if(e===0&&t===this.length)return{bufs:this.bufs,length:this.length};let n=[],s=0;for(let o=0;o<this.bufs.length;o++){let i=this.bufs[o],a=s,c=a+i.byteLength;if(s=c,e>=c)continue;let f=e>=a&&e<c,u=t>a&&t<=c;if(f&&u){if(e===a&&t===c){n.push(i);break}let l=e-a;n.push(i.subarray(l,l+(t-e)));break}if(f){if(e===0){n.push(i);continue}n.push(i.subarray(e-a));continue}if(u){if(t===c){n.push(i);break}n.push(i.subarray(0,t-a));break}n.push(i)}return{bufs:n,length:t-e}}indexOf(e,t=0){if(!ts(e)&&!(e instanceof Uint8Array))throw new TypeError('The "value" argument must be a Uint8ArrayList or Uint8Array');let n=e instanceof Uint8Array?e:e.subarray();if(t=Number(t??0),isNaN(t)&&(t=0),t<0&&(t=this.length+t),t<0&&(t=0),e.length===0)return t>this.length?this.length:t;let s=n.byteLength;if(s===0)throw new TypeError("search must be at least 1 byte long");let o=256,i=new Int32Array(o);for(let l=0;l<o;l++)i[l]=-1;for(let l=0;l<s;l++)i[n[l]]=l;let a=i,c=this.byteLength-n.byteLength,f=n.byteLength-1,u;for(let l=t;l<=c;l+=u){u=0;for(let p=f;p>=0;p--){let x=this.get(l+p);if(n[p]!==x){u=Math.max(1,p-a[x]);break}}if(u===0)return l}return-1}getInt8(e){let t=this.subarray(e,e+1);return new DataView(t.buffer,t.byteOffset,t.byteLength).getInt8(0)}setInt8(e,t){let n=xe(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setInt8(0,t),this.write(n,e)}getInt16(e,t){let n=this.subarray(e,e+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt16(0,t)}setInt16(e,t,n){let s=qe(2);new DataView(s.buffer,s.byteOffset,s.byteLength).setInt16(0,t,n),this.write(s,e)}getInt32(e,t){let n=this.subarray(e,e+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt32(0,t)}setInt32(e,t,n){let s=qe(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setInt32(0,t,n),this.write(s,e)}getBigInt64(e,t){let n=this.subarray(e,e+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigInt64(0,t)}setBigInt64(e,t,n){let s=qe(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigInt64(0,t,n),this.write(s,e)}getUint8(e){let t=this.subarray(e,e+1);return new DataView(t.buffer,t.byteOffset,t.byteLength).getUint8(0)}setUint8(e,t){let n=xe(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setUint8(0,t),this.write(n,e)}getUint16(e,t){let n=this.subarray(e,e+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint16(0,t)}setUint16(e,t,n){let s=qe(2);new DataView(s.buffer,s.byteOffset,s.byteLength).setUint16(0,t,n),this.write(s,e)}getUint32(e,t){let n=this.subarray(e,e+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint32(0,t)}setUint32(e,t,n){let s=qe(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setUint32(0,t,n),this.write(s,e)}getBigUint64(e,t){let n=this.subarray(e,e+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigUint64(0,t)}setBigUint64(e,t,n){let s=qe(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigUint64(0,t,n),this.write(s,e)}getFloat32(e,t){let n=this.subarray(e,e+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat32(0,t)}setFloat32(e,t,n){let s=qe(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setFloat32(0,t,n),this.write(s,e)}getFloat64(e,t){let n=this.subarray(e,e+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat64(0,t)}setFloat64(e,t,n){let s=qe(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setFloat64(0,t,n),this.write(s,e)}equals(e){if(e==null||!(e instanceof r)||e.bufs.length!==this.bufs.length)return!1;for(let t=0;t<this.bufs.length;t++)if(!we(this.bufs[t],e.bufs[t]))return!1;return!0}static fromUint8Arrays(e,t){let n=new r;return n.bufs=e,t==null&&(t=e.reduce((s,o)=>s+o.byteLength,0)),n.length=t,n}};var rs=class extends Error{name="UnexpectedEOFError";code="ERR_UNEXPECTED_EOF"};var Do=class extends Error{code;constructor(e,t){super(e),this.code=t}},Vo=class extends Do{type;constructor(e){super(e,"ABORT_ERR"),this.type="aborted",this.name="AbortError"}};function fc(r,e){let t=cc();r.sink(t).catch(async i=>{await t.end(i)}),r.sink=async i=>{for await(let a of i)await t.push(a);await t.end()};let n=r.source;r.source[Symbol.iterator]!=null?n=r.source[Symbol.iterator]():r.source[Symbol.asyncIterator]!=null&&(n=r.source[Symbol.asyncIterator]());let s=new nt;return{read:async(i,a)=>{a?.signal?.throwIfAborted();let c,f=new Promise((u,l)=>{c=()=>{l(new Vo("Read aborted"))},a?.signal?.addEventListener("abort",c)});try{if(i==null){let{done:l,value:p}=await Promise.race([n.next(),f]);return l===!0?new nt:p}for(;s.byteLength<i;){let{value:l,done:p}=await Promise.race([n.next(),f]);if(p===!0)throw new rs("unexpected end of input");s.append(l)}let u=s.sublist(0,i);return s.consume(i),u}finally{c!=null&&a?.signal?.removeEventListener("abort",c)}},write:async(i,a)=>{a?.signal?.throwIfAborted(),i instanceof Uint8Array?await t.push(i,a):await t.push(i.subarray(),a)},unwrap:()=>{if(s.byteLength>0){let i=r.source;r.source=async function*(){e?.yieldBytes===!1?yield s:yield*s,yield*i}()}return r}}}var ns=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},ss=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},os=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"};function hc(r,e={}){let t=fc(r,e);e.maxDataLength!=null&&e.maxLengthLength==null&&(e.maxLengthLength=Ye(e.maxDataLength));let n=e?.lengthDecoder??Pi,s=e?.lengthEncoder??Hi;return{read:async i=>{let a=-1,c=new nt;for(;;){c.append(await t.read(1,i));try{a=n(c)}catch(f){if(f instanceof RangeError)continue;throw f}if(a<0)throw new ns("Invalid message length");if(e?.maxLengthLength!=null&&c.byteLength>e.maxLengthLength)throw new os("message length length too long");if(a>-1)break}if(e?.maxDataLength!=null&&a>e.maxDataLength)throw new ss("message length too long");return t.read(a,i)},write:async(i,a)=>{await t.write(new nt(s(i.byteLength),i),a)},writeV:async(i,a)=>{let c=new nt(...i.flatMap(f=>[s(f.byteLength),f]));await t.write(c,a)},unwrap:()=>t.unwrap()}}function dc(r,e){let t=hc(r,e),n={read:async(s,o)=>{let i=await t.read(o);return s.decode(i)},write:async(s,o,i)=>{await t.write(o.encode(s),i)},writeV:async(s,o,i)=>{await t.writeV(s.map(a=>o.encode(a)),i)},pb:s=>({read:async o=>n.read(s,o),write:async(o,i)=>n.write(o,s,i),writeV:async(o,i)=>n.writeV(o,s,i),unwrap:()=>n}),unwrap:()=>t.unwrap()};return n}var is;(function(r){let e;r.codec=()=>(e==null&&(e=Ct((t,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),t.id!=null&&(n.uint32(10),n.bytes(t.id)),t.pubkey!=null&&(n.uint32(18),dr.codec().encode(t.pubkey,n)),s.lengthDelimited!==!1&&n.ldelim()},(t,n)=>{let s={},o=n==null?t.len:t.pos+n;for(;t.pos<o;){let i=t.uint32();switch(i>>>3){case 1:s.id=t.bytes();break;case 2:s.pubkey=dr.codec().decode(t,t.uint32());break;default:t.skipType(i&7);break}}return s})),e),r.encode=t=>Tt(t,r.codec()),r.decode=t=>Nt(t,r.codec())})(is||(is={}));var Ae;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.Secp256k1="Secp256k1",r.ECDSA="ECDSA"})(Ae||(Ae={}));var as;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.Secp256k1=2]="Secp256k1",r[r.ECDSA=3]="ECDSA"})(as||(as={}));(function(r){r.codec=()=>kr(as)})(Ae||(Ae={}));var dr;(function(r){let e;r.codec=()=>(e==null&&(e=Ct((t,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),t.Type!=null&&as[t.Type]!==0&&(n.uint32(8),Ae.codec().encode(t.Type,n)),t.Data!=null&&t.Data.byteLength>0&&(n.uint32(18),n.bytes(t.Data)),s.lengthDelimited!==!1&&n.ldelim()},(t,n)=>{let s={Type:Ae.RSA,Data:new Uint8Array(0)},o=n==null?t.len:t.pos+n;for(;t.pos<o;){let i=t.uint32();switch(i>>>3){case 1:s.Type=Ae.codec().decode(t);break;case 2:s.Data=t.bytes();break;default:t.skipType(i&7);break}}return s})),e),r.encode=t=>Tt(t,r.codec()),r.decode=t=>Nt(t,r.codec())})(dr||(dr={}));var Jf="/plaintext/2.0.0",Oo=class{protocol=Jf;log;timeout;constructor(e,t={}){this.log=e.logger.forComponent("libp2p:plaintext"),this.timeout=t.timeout??1e3}[Symbol.toStringTag]="@libp2p/plaintext";[jo]=["@libp2p/connection-encryption"];async secureInbound(e,t,n){return this._encrypt(e,t,n)}async secureOutbound(e,t,n){return this._encrypt(e,t,n)}async _encrypt(e,t,n){let s=AbortSignal.timeout(this.timeout),o=dc(t).pb(is),i=Ae.RSA;e.type==="Ed25519"?i=Ae.Ed25519:e.type==="secp256k1"&&(i=Ae.Secp256k1),this.log("write pubkey exchange to peer %p",n);let[,a]=await Promise.all([o.write({id:e.toBytes(),pubkey:{Type:i,Data:e.publicKey==null?new Uint8Array(0):dr.decode(e.publicKey).Data??new Uint8Array(0)}},{signal:s}),o.read({signal:s})]),c;try{if(a.pubkey==null)throw new Error("Public key missing");if(a.pubkey.Data.length===0)throw new Error("Public key data too short");if(a.id==null)throw new Error("Remote id missing");let f;if(a.pubkey.Type===Ae.RSA)f=cr.rsa.unmarshalRsaPublicKey(a.pubkey.Data);else if(a.pubkey.Type===Ae.Ed25519)f=cr.ed25519.unmarshalEd25519PublicKey(a.pubkey.Data);else if(a.pubkey.Type===Ae.Secp256k1)f=cr.secp256k1.unmarshalSecp256k1PublicKey(a.pubkey.Data);else throw new Error("Unknown public key type");if(c=await ic(f),!c.equals(Qn(a.id)))throw new Error("Public key did not match id")}catch(f){throw this.log.error(f),new Gr("Remote did not provide its public key")}if(n!=null&&!c.equals(n))throw new qr;return this.log("plaintext key exchange completed successfully with peer %p",c),{conn:o.unwrap().unwrap(),remotePeer:c}}};function Xf(r){return e=>new Oo(e,r)}return Nc(Qf);})();
|
|
8
|
+
/*! Bundled license information:
|
|
9
|
+
|
|
10
|
+
pvtsutils/build/index.js:
|
|
11
|
+
(*!
|
|
12
|
+
* MIT License
|
|
13
|
+
*
|
|
14
|
+
* Copyright (c) 2017-2022 Peculiar Ventures, LLC
|
|
15
|
+
*
|
|
16
|
+
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
17
|
+
* of this software and associated documentation files (the "Software"), to deal
|
|
18
|
+
* in the Software without restriction, including without limitation the rights
|
|
19
|
+
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
20
|
+
* copies of the Software, and to permit persons to whom the Software is
|
|
21
|
+
* furnished to do so, subject to the following conditions:
|
|
22
|
+
*
|
|
23
|
+
* The above copyright notice and this permission notice shall be included in all
|
|
24
|
+
* copies or substantial portions of the Software.
|
|
25
|
+
*
|
|
26
|
+
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
27
|
+
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
28
|
+
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
29
|
+
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
30
|
+
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
31
|
+
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
32
|
+
* SOFTWARE.
|
|
33
|
+
*
|
|
34
|
+
*)
|
|
35
|
+
|
|
36
|
+
@noble/hashes/esm/utils.js:
|
|
37
|
+
(*! noble-hashes - MIT License (c) 2022 Paul Miller (paulmillr.com) *)
|
|
38
|
+
|
|
39
|
+
@noble/curves/esm/abstract/utils.js:
|
|
40
|
+
(*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) *)
|
|
41
|
+
|
|
42
|
+
@noble/curves/esm/abstract/modular.js:
|
|
43
|
+
(*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) *)
|
|
44
|
+
|
|
45
|
+
@noble/curves/esm/abstract/curve.js:
|
|
46
|
+
(*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) *)
|
|
47
|
+
|
|
48
|
+
@noble/curves/esm/abstract/edwards.js:
|
|
49
|
+
(*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) *)
|
|
50
|
+
|
|
51
|
+
@noble/curves/esm/ed25519.js:
|
|
52
|
+
(*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) *)
|
|
53
|
+
|
|
54
|
+
pvutils/build/utils.es.js:
|
|
55
|
+
(*!
|
|
56
|
+
Copyright (c) Peculiar Ventures, LLC
|
|
57
|
+
*)
|
|
58
|
+
|
|
59
|
+
asn1js/build/index.es.js:
|
|
60
|
+
(*!
|
|
61
|
+
* Copyright (c) 2014, GMO GlobalSign
|
|
62
|
+
* Copyright (c) 2015-2022, Peculiar Ventures
|
|
63
|
+
* All rights reserved.
|
|
64
|
+
*
|
|
65
|
+
* Author 2014-2019, Yury Strozhevsky
|
|
66
|
+
*
|
|
67
|
+
* Redistribution and use in source and binary forms, with or without modification,
|
|
68
|
+
* are permitted provided that the following conditions are met:
|
|
69
|
+
*
|
|
70
|
+
* * Redistributions of source code must retain the above copyright notice, this
|
|
71
|
+
* list of conditions and the following disclaimer.
|
|
72
|
+
*
|
|
73
|
+
* * Redistributions in binary form must reproduce the above copyright notice, this
|
|
74
|
+
* list of conditions and the following disclaimer in the documentation and/or
|
|
75
|
+
* other materials provided with the distribution.
|
|
76
|
+
*
|
|
77
|
+
* * Neither the name of the copyright holder nor the names of its
|
|
78
|
+
* contributors may be used to endorse or promote products derived from
|
|
79
|
+
* this software without specific prior written permission.
|
|
80
|
+
*
|
|
81
|
+
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
|
|
82
|
+
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
|
83
|
+
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
|
84
|
+
* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR
|
|
85
|
+
* ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
|
86
|
+
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
|
87
|
+
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
|
|
88
|
+
* ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
89
|
+
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
|
90
|
+
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
91
|
+
*
|
|
92
|
+
*)
|
|
93
|
+
|
|
94
|
+
@noble/curves/esm/abstract/weierstrass.js:
|
|
95
|
+
(*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) *)
|
|
96
|
+
|
|
97
|
+
@noble/curves/esm/_shortw_utils.js:
|
|
98
|
+
(*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) *)
|
|
99
|
+
|
|
100
|
+
@noble/curves/esm/secp256k1.js:
|
|
101
|
+
(*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) *)
|
|
102
|
+
*/
|
|
3
103
|
return Libp2PPlaintext}));
|
package/dist/src/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;GAoBG;
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;GAoBG;AAQH,OAAO,KAAK,EAAE,eAAe,EAA+B,mBAAmB,EAAkD,MAAM,mBAAmB,CAAA;AAM1J,MAAM,WAAW,mBAAmB;IAClC,MAAM,EAAE,eAAe,CAAA;CACxB;AAED,MAAM,WAAW,aAAa;IAC5B;;;OAGG;IACH,OAAO,CAAC,EAAE,MAAM,CAAA;CACjB;AA+GD,wBAAgB,SAAS,CAAE,IAAI,CAAC,EAAE,aAAa,GAAG,CAAC,UAAU,EAAE,mBAAmB,KAAK,mBAAmB,CAEzG"}
|
package/dist/src/index.js
CHANGED
|
@@ -19,10 +19,12 @@
|
|
|
19
19
|
* })
|
|
20
20
|
* ```
|
|
21
21
|
*/
|
|
22
|
+
import { supportedKeys } from '@libp2p/crypto/keys';
|
|
22
23
|
import { UnexpectedPeerError, InvalidCryptoExchangeError, serviceCapabilities } from '@libp2p/interface';
|
|
23
|
-
import { peerIdFromBytes
|
|
24
|
+
import { peerIdFromBytes } from '@libp2p/peer-id';
|
|
25
|
+
import { createFromPubKey } from '@libp2p/peer-id-factory';
|
|
24
26
|
import { pbStream } from 'it-protobuf-stream';
|
|
25
|
-
import { Exchange, KeyType } from './pb/proto.js';
|
|
27
|
+
import { Exchange, KeyType, PublicKey } from './pb/proto.js';
|
|
26
28
|
const PROTOCOL = '/plaintext/2.0.0';
|
|
27
29
|
class Plaintext {
|
|
28
30
|
protocol = PROTOCOL;
|
|
@@ -62,7 +64,7 @@ class Plaintext {
|
|
|
62
64
|
id: localId.toBytes(),
|
|
63
65
|
pubkey: {
|
|
64
66
|
Type: type,
|
|
65
|
-
Data: localId.publicKey ?? new Uint8Array(0)
|
|
67
|
+
Data: localId.publicKey == null ? new Uint8Array(0) : (PublicKey.decode(localId.publicKey).Data ?? new Uint8Array(0))
|
|
66
68
|
}
|
|
67
69
|
}, {
|
|
68
70
|
signal
|
|
@@ -83,7 +85,20 @@ class Plaintext {
|
|
|
83
85
|
if (response.id == null) {
|
|
84
86
|
throw new Error('Remote id missing');
|
|
85
87
|
}
|
|
86
|
-
|
|
88
|
+
let pubKey;
|
|
89
|
+
if (response.pubkey.Type === KeyType.RSA) {
|
|
90
|
+
pubKey = supportedKeys.rsa.unmarshalRsaPublicKey(response.pubkey.Data);
|
|
91
|
+
}
|
|
92
|
+
else if (response.pubkey.Type === KeyType.Ed25519) {
|
|
93
|
+
pubKey = supportedKeys.ed25519.unmarshalEd25519PublicKey(response.pubkey.Data);
|
|
94
|
+
}
|
|
95
|
+
else if (response.pubkey.Type === KeyType.Secp256k1) {
|
|
96
|
+
pubKey = supportedKeys.secp256k1.unmarshalSecp256k1PublicKey(response.pubkey.Data);
|
|
97
|
+
}
|
|
98
|
+
else {
|
|
99
|
+
throw new Error('Unknown public key type');
|
|
100
|
+
}
|
|
101
|
+
peerId = await createFromPubKey(pubKey);
|
|
87
102
|
if (!peerId.equals(peerIdFromBytes(response.id))) {
|
|
88
103
|
throw new Error('Public key did not match id');
|
|
89
104
|
}
|
package/dist/src/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;GAoBG;AAEH,OAAO,EAAE,mBAAmB,EAAE,0BAA0B,EAAE,mBAAmB,EAAE,MAAM,mBAAmB,CAAA;AACxG,OAAO,EAAE,eAAe,EAAE,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;GAoBG;AAEH,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAA;AACnD,OAAO,EAAE,mBAAmB,EAAE,0BAA0B,EAAE,mBAAmB,EAAE,MAAM,mBAAmB,CAAA;AACxG,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AACjD,OAAO,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAA;AAC1D,OAAO,EAAE,QAAQ,EAAE,MAAM,oBAAoB,CAAA;AAC7C,OAAO,EAAE,QAAQ,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,eAAe,CAAA;AAK5D,MAAM,QAAQ,GAAG,kBAAkB,CAAA;AAcnC,MAAM,SAAS;IACN,QAAQ,GAAW,QAAQ,CAAA;IACjB,GAAG,CAAQ;IACX,OAAO,CAAQ;IAEhC,YAAa,UAA+B,EAAE,OAAsB,EAAE;QACpE,IAAI,CAAC,GAAG,GAAG,UAAU,CAAC,MAAM,CAAC,YAAY,CAAC,kBAAkB,CAAC,CAAA;QAC7D,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,IAAI,IAAI,CAAA;IACrC,CAAC;IAEQ,CAAC,MAAM,CAAC,WAAW,CAAC,GAAG,mBAAmB,CAAA;IAE1C,CAAC,mBAAmB,CAAC,GAAa;QACzC,+BAA+B;KAChC,CAAA;IAED,KAAK,CAAC,aAAa,CAA6F,OAAe,EAAE,IAAY,EAAE,QAAiB;QAC9J,OAAO,IAAI,CAAC,QAAQ,CAAC,OAAO,EAAE,IAAI,EAAE,QAAQ,CAAC,CAAA;IAC/C,CAAC;IAED,KAAK,CAAC,cAAc,CAA6F,OAAe,EAAE,IAAY,EAAE,QAAiB;QAC/J,OAAO,IAAI,CAAC,QAAQ,CAAC,OAAO,EAAE,IAAI,EAAE,QAAQ,CAAC,CAAA;IAC/C,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,QAAQ,CAA6F,OAAe,EAAE,IAAY,EAAE,QAAiB;QACzJ,MAAM,MAAM,GAAG,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,CAAA;QAChD,MAAM,EAAE,GAAG,QAAQ,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAA;QAEtC,IAAI,IAAI,GAAG,OAAO,CAAC,GAAG,CAAA;QAEtB,IAAI,OAAO,CAAC,IAAI,KAAK,SAAS,EAAE,CAAC;YAC/B,IAAI,GAAG,OAAO,CAAC,OAAO,CAAA;QACxB,CAAC;aAAM,IAAI,OAAO,CAAC,IAAI,KAAK,WAAW,EAAE,CAAC;YACxC,IAAI,GAAG,OAAO,CAAC,SAAS,CAAA;QAC1B,CAAC;QAED,IAAI,CAAC,GAAG,CAAC,kCAAkC,EAAE,QAAQ,CAAC,CAAA;QAEtD,MAAM,CACJ,AADK,EACH,QAAQ,CACX,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC;YACpB,wDAAwD;YACxD,EAAE,CAAC,KAAK,CAAC;gBACP,EAAE,EAAE,OAAO,CAAC,OAAO,EAAE;gBACrB,MAAM,EAAE;oBACN,IAAI,EAAE,IAAI;oBACV,IAAI,EAAE,OAAO,CAAC,SAAS,IAAI,IAAI,CAAC,CAAC,CAAC,IAAI,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,IAAI,IAAI,IAAI,UAAU,CAAC,CAAC,CAAC,CAAC;iBACtH;aACF,EAAE;gBACD,MAAM;aACP,CAAC;YACF,2BAA2B;YAC3B,EAAE,CAAC,IAAI,CAAC;gBACN,MAAM;aACP,CAAC;SACH,CAAC,CAAA;QAEF,IAAI,MAAM,CAAA;QACV,IAAI,CAAC;YACH,IAAI,QAAQ,CAAC,MAAM,IAAI,IAAI,EAAE,CAAC;gBAC5B,MAAM,IAAI,KAAK,CAAC,oBAAoB,CAAC,CAAA;YACvC,CAAC;YAED,IAAI,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBACtC,MAAM,IAAI,KAAK,CAAC,2BAA2B,CAAC,CAAA;YAC9C,CAAC;YAED,IAAI,QAAQ,CAAC,EAAE,IAAI,IAAI,EAAE,CAAC;gBACxB,MAAM,IAAI,KAAK,CAAC,mBAAmB,CAAC,CAAA;YACtC,CAAC;YAED,IAAI,MAAc,CAAA;YAElB,IAAI,QAAQ,CAAC,MAAM,CAAC,IAAI,KAAK,OAAO,CAAC,GAAG,EAAE,CAAC;gBACzC,MAAM,GAAG,aAAa,CAAC,GAAG,CAAC,qBAAqB,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,CAAA;YACxE,CAAC;iBAAM,IAAI,QAAQ,CAAC,MAAM,CAAC,IAAI,KAAK,OAAO,CAAC,OAAO,EAAE,CAAC;gBACpD,MAAM,GAAG,aAAa,CAAC,OAAO,CAAC,yBAAyB,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,CAAA;YAChF,CAAC;iBAAM,IAAI,QAAQ,CAAC,MAAM,CAAC,IAAI,KAAK,OAAO,CAAC,SAAS,EAAE,CAAC;gBACtD,MAAM,GAAG,aAAa,CAAC,SAAS,CAAC,2BAA2B,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,CAAA;YACpF,CAAC;iBAAM,CAAC;gBACN,MAAM,IAAI,KAAK,CAAC,yBAAyB,CAAC,CAAA;YAC5C,CAAC;YAED,MAAM,GAAG,MAAM,gBAAgB,CAAC,MAAM,CAAC,CAAA;YAEvC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,eAAe,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC;gBACjD,MAAM,IAAI,KAAK,CAAC,6BAA6B,CAAC,CAAA;YAChD,CAAC;QACH,CAAC;QAAC,OAAO,GAAQ,EAAE,CAAC;YAClB,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;YACnB,MAAM,IAAI,0BAA0B,CAAC,uCAAuC,CAAC,CAAA;QAC/E,CAAC;QAED,IAAI,QAAQ,IAAI,IAAI,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,EAAE,CAAC;YACjD,MAAM,IAAI,mBAAmB,EAAE,CAAA;QACjC,CAAC;QAED,IAAI,CAAC,GAAG,CAAC,4DAA4D,EAAE,MAAM,CAAC,CAAA;QAE9E,OAAO;YACL,IAAI,EAAE,EAAE,CAAC,MAAM,EAAE,CAAC,MAAM,EAAE;YAC1B,UAAU,EAAE,MAAM;SACnB,CAAA;IACH,CAAC;CACF;AAED,MAAM,UAAU,SAAS,CAAE,IAAoB;IAC7C,OAAO,CAAC,UAAU,EAAE,EAAE,CAAC,IAAI,SAAS,CAAC,UAAU,EAAE,IAAI,CAAC,CAAA;AACxD,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@libp2p/plaintext",
|
|
3
|
-
"version": "1.1.
|
|
3
|
+
"version": "1.1.6",
|
|
4
4
|
"description": "An insecure connection encrypter",
|
|
5
5
|
"license": "Apache-2.0 OR MIT",
|
|
6
6
|
"homepage": "https://github.com/libp2p/js-libp2p/tree/main/packages/connection-encrypter-plaintext#readme",
|
|
@@ -52,7 +52,9 @@
|
|
|
52
52
|
"doc-check": "aegir doc-check"
|
|
53
53
|
},
|
|
54
54
|
"dependencies": {
|
|
55
|
+
"@libp2p/crypto": "^4.1.9",
|
|
55
56
|
"@libp2p/interface": "^1.7.0",
|
|
57
|
+
"@libp2p/peer-id-factory": "^4.2.4",
|
|
56
58
|
"@libp2p/peer-id": "^4.2.4",
|
|
57
59
|
"it-protobuf-stream": "^1.1.3",
|
|
58
60
|
"it-stream-types": "^2.0.1",
|
|
@@ -62,7 +64,6 @@
|
|
|
62
64
|
"devDependencies": {
|
|
63
65
|
"@libp2p/interface-compliance-tests": "^5.4.12",
|
|
64
66
|
"@libp2p/logger": "^4.0.20",
|
|
65
|
-
"@libp2p/peer-id-factory": "^4.2.4",
|
|
66
67
|
"@multiformats/multiaddr": "^12.2.3",
|
|
67
68
|
"aegir": "^44.0.1",
|
|
68
69
|
"protons": "^7.5.0",
|
package/src/index.ts
CHANGED
|
@@ -20,11 +20,13 @@
|
|
|
20
20
|
* ```
|
|
21
21
|
*/
|
|
22
22
|
|
|
23
|
+
import { supportedKeys } from '@libp2p/crypto/keys'
|
|
23
24
|
import { UnexpectedPeerError, InvalidCryptoExchangeError, serviceCapabilities } from '@libp2p/interface'
|
|
24
|
-
import { peerIdFromBytes
|
|
25
|
+
import { peerIdFromBytes } from '@libp2p/peer-id'
|
|
26
|
+
import { createFromPubKey } from '@libp2p/peer-id-factory'
|
|
25
27
|
import { pbStream } from 'it-protobuf-stream'
|
|
26
|
-
import { Exchange, KeyType } from './pb/proto.js'
|
|
27
|
-
import type { ComponentLogger, Logger, MultiaddrConnection, ConnectionEncrypter, SecuredConnection, PeerId } from '@libp2p/interface'
|
|
28
|
+
import { Exchange, KeyType, PublicKey } from './pb/proto.js'
|
|
29
|
+
import type { ComponentLogger, Logger, MultiaddrConnection, ConnectionEncrypter, SecuredConnection, PeerId, PublicKey as PubKey } from '@libp2p/interface'
|
|
28
30
|
import type { Duplex } from 'it-stream-types'
|
|
29
31
|
import type { Uint8ArrayList } from 'uint8arraylist'
|
|
30
32
|
|
|
@@ -91,7 +93,7 @@ class Plaintext implements ConnectionEncrypter {
|
|
|
91
93
|
id: localId.toBytes(),
|
|
92
94
|
pubkey: {
|
|
93
95
|
Type: type,
|
|
94
|
-
Data: localId.publicKey ?? new Uint8Array(0)
|
|
96
|
+
Data: localId.publicKey == null ? new Uint8Array(0) : (PublicKey.decode(localId.publicKey).Data ?? new Uint8Array(0))
|
|
95
97
|
}
|
|
96
98
|
}, {
|
|
97
99
|
signal
|
|
@@ -116,7 +118,19 @@ class Plaintext implements ConnectionEncrypter {
|
|
|
116
118
|
throw new Error('Remote id missing')
|
|
117
119
|
}
|
|
118
120
|
|
|
119
|
-
|
|
121
|
+
let pubKey: PubKey
|
|
122
|
+
|
|
123
|
+
if (response.pubkey.Type === KeyType.RSA) {
|
|
124
|
+
pubKey = supportedKeys.rsa.unmarshalRsaPublicKey(response.pubkey.Data)
|
|
125
|
+
} else if (response.pubkey.Type === KeyType.Ed25519) {
|
|
126
|
+
pubKey = supportedKeys.ed25519.unmarshalEd25519PublicKey(response.pubkey.Data)
|
|
127
|
+
} else if (response.pubkey.Type === KeyType.Secp256k1) {
|
|
128
|
+
pubKey = supportedKeys.secp256k1.unmarshalSecp256k1PublicKey(response.pubkey.Data)
|
|
129
|
+
} else {
|
|
130
|
+
throw new Error('Unknown public key type')
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
peerId = await createFromPubKey(pubKey)
|
|
120
134
|
|
|
121
135
|
if (!peerId.equals(peerIdFromBytes(response.id))) {
|
|
122
136
|
throw new Error('Public key did not match id')
|